/* File: resources/css/base/reset.css */ * { margin: 0; padding: 0; box-sizing: border-box; } body { font-family: var(--typography); background-color: var(--bg); color: var(--text); display: flex; height: 100vh; overflow: hidden; } a { color: var(--rhpz-orange); text-decoration: none; transition: color 0.2s; } a:hover { color: var(--rhpz-orange-hover); text-decoration: underline; } #app { display: flex; width: 100%; height: 100%; } ul { margin-left: 20px; margin-bottom: 20px; list-style-type: square; } [x-cloak] {display: none !important;} /* File: resources/css/base/variables.css */ :root { /* RHPZ color */ --rhpz-orange: #ff7300; --rhpz-orange-hover: #e56700; /* Background colors */ --bg: #1e1e1e; --bg2: #252526; --bg3: #2d2d30; --bg4: #3e3e42; /* Text */ --text: #f1f1f1; --text2: #a1a1aa; --text3: #111111; /* Elements */ --border: #3f3f46; --error: #e57373; --info: #1976d2; --success: #81c784; --success2: #388e3c; /* Typo */ --typography: 'Segoe UI', 'San Francisco', 'Helvetica Neue', sans-serif; /* Menu settings */ --menu-size: 260px; --menu-user-avatar-bg: #555; } .\$light-mode { /* RHPZ color */ --rhpz-orange: #ff7300; --rhpz-orange-hover: #e56700; /* Background colors */ --bg: #f0f0f0; --bg2: #ffffff; --bg3: #e8e8e8; --bg4: #dcdcdc; /* Text */ --text: #454545; --text2: #737373; --text3: #111111; /* Elements */ --border: #d0d0d0; --error: #e57373; --info: #1976d2; --success: #81c784; --success2: #388e3c; } /* File: resources/css/components/cards.css */ /* STAT CARDS */ .\$stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 20px; margin-bottom: 30px; } .\$stat-card { background-color: var(--bg2); border: 1px solid var(--border); padding: 20px; display: flex; align-items: center; gap: 15px; border-left: 3px solid var(--rhpz-orange); } .\$stat-card i { color: var(--rhpz-orange); width: 32px; height: 32px; } /* ENTRY CARDS */ .\$entry-card { background-color: var(--bg2); border: 1px solid var(--border); display: flex; flex-direction: column; transition: transform 0.2s, border-color 0.2s; cursor: pointer; &:hover { transform: translateY(-3px); border-color: var(--rhpz-orange); } .\$entry-cover-wrapper { position: relative; aspect-ratio: 4/3; background-color: var(--bg); border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: center; overflow: hidden; } .\$entry-cover-wrapper img { width: 100%; height: 100%; object-fit: cover; } .\$entry-badge { position: absolute; top: 10px; right: 10px; background-color: rgba(0,0,0,0.7); backdrop-filter: blur(4px); border: 1px solid var(--border); padding: 4px 8px; font-size: 0.75rem; color: var(--text); } .\$entry-card-info { padding: 15px; flex-grow: 1; display: flex; flex-direction: column; } .\$entry-card-title { font-weight: 600; color: var(--text); font-size: 1.1rem; margin-bottom: 5px; line-height: 1.3; } .\$entry-card-author { color: var(--rhpz-orange); font-size: 0.85rem; margin-bottom: 10px; } .\$entry-card-meta { margin-top: auto; font-size: 0.8rem; color: var(--text2); display: flex; justify-content: space-between; align-items: center; } } /* File: resources/css/components/common.css */ /* BUTTONS */ .\$btn { background-color: var(--bg3); border: 1px solid var(--border); color: var(--text); padding: 8px 16px; font-size: 0.9rem; cursor: pointer; display: inline-flex; align-items: center; gap: 8px; transition: all 0.1s; } .\$btn:hover { background-color: var(--bg4); border-color: var(--menu-user-avatar-bg); } .\$btn.primary { background-color: var(--rhpz-orange); color: var(--text3); border-color: var(--rhpz-orange); font-weight: 600; } .\$btn.primary:hover { background-color: var(--rhpz-orange-hover); border-color: var(--rhpz-orange-hover); } .\$btn.danger { background-color: transparent; color: var(--error); border-color: var(--error); } .\$btn.danger:hover { background-color: rgba(229, 115, 115, 0.1); } .\$btn.success { background-color: transparent; color: var(--success); border-color: var(--success); } .\$btn.success:hover { background-color: rgba(129, 199, 132, 0.1); } /* BLOCK */ .\$block { background-color: var(--bg2); border: 1px solid var(--border); padding: 20px; margin-bottom: 20px; } .\$block.featured { border-left: 3px solid var(--rhpz-orange); } .\$block-header { font-size: 1.2rem; color: var(--text); margin-bottom: 15px; display: flex; align-items: center; gap: 10px; border-bottom: 1px solid var(--border); padding-bottom: 10px; } .\$block-success { background-color: var(--success); border: 1px solid var(--success); color: var(--text); padding: 20px; margin-bottom: 20px; } .\$block-error { background-color: var(--error); border: 1px solid var(--error); color: var(--text); padding: 20px; margin-bottom: 20px; } /* BADGES */ .\$badge { display: inline-block; padding: 2px 8px; font-size: 0.75rem; font-weight: bold; border-radius: 2px; background-color: var(--bg3); border: 1px solid var(--border); } .\$badge.orange { background-color: var(--rhpz-orange); color: var(--text3); border-color: var(--rhpz-orange); } .\$badge.blue, .\$badge.translations { background-color: var(--info); color: var(--text); border-color: var(--info); } .\$badge.green, .\$badge.romhacks { background-color: var(--success2); color: var(--text); border-color: var(--success2); } .\$badge.yellow, .\$badge.utilities { background-color: #fdeb0f; color: #000; border-color: #fdeb0f; } .\$topbar-badge { position: absolute; top: 0; right: 0; min-width: 18px; height: 18px; padding: 0 4px; border-radius: 9px; background-color: var(--rhpz-orange); color: #111; font-size: 0.65rem; font-weight: 700; display: flex; align-items: center; justify-content: center; line-height: 1; border: 2px solid var(--bg); animation: badge-pop 0.2s ease; } .\$topbar-badge--overflow { border-radius: 9px; padding: 0 5px; font-size: 0.6rem; } @keyframes badge-pop { 0% { transform: scale(0.5); opacity: 0; } 0% { transform: scale(0.5); opacity: 0; } 70% { transform: scale(1.2); } 100% { transform: scale(1); opacity: 1; } } /* BREADCRUMB */ .\$breadcrumb { margin-bottom: 15px; } /* PAGE */ .\$page-title { font-size: 1.8rem; font-weight: 300; margin-bottom: 20px; color: var(--text); } /* TEXTS */ .\$whisper { color: var(--text2); margin-bottom: 15px; } .\$content-title { color: var(--text); margin: 30px 0 15px 0; border-left: 3px solid var(--rhpz-orange); padding-left: 10px; } .\$quote { background-color: var(--bg); border-left: 4px solid #1976d2; padding: 15px; margin-top: 30px; font-style: italic; } /* ANIMATIONS */ @keyframes spin { from { transform: rotate(0deg); } from { transform: rotate(0deg); } to { transform: rotate(360deg); } } .\$spin { animation: spin 1s infinite linear; } .\$search-button { background: none; border: none; cursor: pointer; } /* File: resources/css/components/database.css */ .\$filter-bar { display: flex; gap: 15px; background-color: var(--bg2); padding: 15px; border: 1px solid var(--border); margin-bottom: 20px; flex-wrap: wrap; align-items: center; .\$filter-bar-search { flex: 1; max-width: 400px; background-color: var(--bg); border: 1px solid var(--border); display: flex; align-items: center; padding: 8px 12px; gap: 8px; } } .\$database-wrapper { display: flex; gap: 20px; align-items: flex-start; .\$database-filters { width: 300px; flex-shrink: 0; display: flex; flex-direction: column; gap: 2px; background-color: var(--bg2); border: 1px solid var(--border); .\$filter-group { border-bottom: 1px solid var(--border); overflow: hidden; &:last-child { border-bottom: none; } } .\$filter-title-row { display: flex; align-items: center; justify-content: space-between; padding: 10px 14px; background-color: var(--bg3); cursor: pointer; user-select: none; .\$filter-title { font-size: 0.8rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.8px; color: var(--text2); margin: 0; } } .\$filter-mode { display: flex; gap: 4px; } .\$filter-btn-mode { background: none; border: 1px solid var(--border); color: var(--text2); font-size: 0.7rem; font-weight: 600; padding: 2px 7px; cursor: pointer; font-family: var(--typography); transition: all 0.15s; letter-spacing: 0.5px; &:hover { border-color: var(--rhpz-orange); color: var(--rhpz-orange); } &.\$active { background-color: var(--rhpz-orange); border-color: var(--rhpz-orange); color: var(--text3); } } .\$filter-options { padding: 6px 0; max-height: 180px; overflow-y: auto; &::-webkit-scrollbar { width: 6px; } &::-webkit-scrollbar-track { background: var(--bg2); } &::-webkit-scrollbar-thumb { background: var(--border); } } .\$filter-option { display: flex; align-items: center; gap: 9px; padding: 6px 14px; font-size: 0.88rem; color: var(--text); cursor: pointer; transition: background-color 0.1s; &:hover { background-color: var(--bg4); } } .\$filter-option input[type="checkbox"] { accent-color: var(--rhpz-orange); width: 14px; height: 14px; cursor: pointer; flex-shrink: 0; } } .\$database-results { flex: 1; min-width: 0; .\$database-sort { display: flex; align-items: center; gap: 8px; margin-bottom: 15px; padding-bottom: 15px; border-bottom: 1px solid var(--border); flex-wrap: wrap; .\$btn { font-size: 0.85rem; padding: 6px 12px; &.\$active { border-color: var(--rhpz-orange); color: var(--rhpz-orange); } } } .\$database-results-count { margin-left: auto; font-size: 0.85rem; color: var(--text2); } .\$database-active-filters { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 15px; } .\$database-active-filter-tag { display: inline-flex; align-items: center; gap: 6px; background-color: var(--bg3); border: 1px solid var(--border); padding: 3px 10px; font-size: 0.8rem; color: var(--text); .\$tag-type { color: var(--rhpz-orange); font-weight: 600; font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.5px; } button { background: none; border: none; color: var(--text2); cursor: pointer; padding: 0; display: flex; align-items: center; transition: color 0.15s; &:hover { color: var(--text); } } } .\$database-empty { grid-column: 1 / -1; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 60px 20px; color: var(--text2); background-color: var(--bg2); border: 1px solid var(--border); gap: 15px; text-align: center; i { color: var(--border); } p { font-size: 0.95rem; } } } } .\$database-pagination { display: flex; justify-content: center; align-items: center; gap: 4px; margin-top: 20px; .\$btn { min-width: 36px; padding: 6px 10px; font-size: 0.85rem; display: flex; align-items: center; justify-content: center; } .\$active { background-color: var(--rhpz-orange); border-color: var(--rhpz-orange); color: #111; font-weight: 600; } } .\$database-search { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; } @media (max-width: 900px) { .\$database-layout { flex-direction: column; } .\$database-filters { width: 100%; display: grid; grid-template-columns: repeat(2,1fr); } .\$database-filter-group:last-child { border-bottom: 1px solid var(--border); } .\$database-results-count { margin-left: 0; width: 100%; } } @media (max-width: 600px) { .\$database-filters { grid-template-columns: 1fr; } .\$grid-entries { grid-template-columns: repeat(2, 1fr); } } @media (max-width: 420px) { .\$grid-entries { grid-template-columns: 1fr; } } .\$filter-chevron { transition: transform 0.2s ease; color: var(--text2); flex-shrink: 0; } .\$filter-chevron.rotated { transform: rotate(-90deg); } .\$internal-filter-search { display: flex; align-items: center; gap: 7px; padding: 7px 14px; border-bottom: 1px solid var(--border); background-color: var(--bg); i { color: var(--text2); flex-shrink: 0; } input { background: none; border: none; outline: none; color: var(--text); font-family: var(--typography); font-size: 0.85rem; width: 100%; &::placeholder { color: var(--text2); } } } .\$filter-title-left { display: flex; align-items: center; gap: 7px; } .\$filter-title-right { display: flex; align-items: center; gap: 6px; } .\$internal-filter-count { display: inline-flex; align-items: center; justify-content: center; background-color: var(--rhpz-orange); color: #111; font-size: 0.7rem; font-weight: 700; min-width: 18px; height: 18px; padding: 0 5px; line-height: 1; } .\$internal-filter-clear { background: none; border: 1px solid var(--border); color: var(--text2); cursor: pointer; display: flex; align-items: center; justify-content: center; width: 18px; height: 18px; padding: 0; transition: all 0.15s; &:hover { border-color: var(--error); color: var(--error); } } .\$filter-search-clear { background: none; border: none; color: var(--text2); cursor: pointer; display: flex; align-items: center; padding: 0; flex-shrink: 0; transition: color 0.15s; &:hover { color: var(--text); } } /* File: resources/css/components/drafts.css */ .\$drafts-count { font-size: 0.85rem; color: var(--text2); margin-bottom: 15px; padding-bottom: 10px; border-bottom: 1px solid var(--border); } .\$drafts-empty { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 15px; padding: 80px 20px; background-color: var(--bg2); border: 1px dashed var(--border); text-align: center; color: var(--text2); h3 { font-size: 1.1rem; color: var(--text); margin: 0; } p { font-size: 0.9rem; margin: 0; } } .\$drafts-list { display: flex; flex-direction: column; gap: 15px; } .\$drafts-item { display: flex; gap: 20px; background-color: var(--bg2); border: 1px solid var(--border); border-left: 3px solid var(--rhpz-orange); padding: 20px; transition: border-color 0.15s; &:hover { border-color: var(--rhpz-orange); } } .\$drafts-cover { width: 80px; height: 80px; flex-shrink: 0; background-color: var(--bg); border: 1px solid var(--border); overflow: hidden; display: flex; align-items: center; justify-content: center; img { width: 100%; height: 100%; object-fit: contain; } } .\$drafts-cover-placeholder { color: var(--border); } .\$drafts-info { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 12px; } .\$drafts-top { display: flex; justify-content: space-between; align-items: flex-start; gap: 15px; } .\$drafts-title { font-size: 1rem; font-weight: 600; color: var(--text); margin-bottom: 6px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } .\$drafts-meta { display: flex; gap: 6px; flex-wrap: wrap; } .\$drafts-dates { display: flex; flex-direction: column; gap: 4px; text-align: right; font-size: 0.78rem; color: var(--text2); flex-shrink: 0; span { display: flex; align-items: center; justify-content: flex-end; gap: 5px; } } .\$drafts-progress { display: flex; align-items: center; gap: 10px; } .\$drafts-progress-bar { flex: 1; height: 4px; background-color: var(--bg4); overflow: hidden; } .\$drafts-progress-fill { height: 100%; background-color: var(--rhpz-orange); transition: width 0.3s ease; .\$complete { background-color: var(--success); } } .\$drafts-progress-label { font-size: 0.75rem; color: var(--text2); white-space: nowrap; } .\$drafts-actions { display: flex; flex-direction: column; gap: 8px; justify-content: center; flex-shrink: 0; .\$btn { white-space: nowrap; } } /* File: resources/css/components/easymde.css */ .\$EasyMDEContainer { display: flex; flex-direction: column; .\$editor-toolbar { background-color: var(--bg3); border:1px solid var(--border); border-bottom: none; border-radius: var(--radius-md) var(--radius-md) 0 0; padding: 4px 8px; opacity: 1; button { color: var(--text2); border: none; &:hover { background-color: var(--bg2); color: var(--text) } .\$active { background-color: var(--bg2); color: var(--text); } } i.separator { border-left: 1px solid var(--border); margin: 0 4px; } } .\$CodeMirror { background-color: var(--bg2); color: var(--text); border: 1px solid var(--border) !important; &:focus-within { border-color: var(--rhpz-orange); outline: none; } } .\$CodeMirror-cursor { border-left: 2px solid var(--text2); } .\$CodeMirror-selected { background: color-mix(in srgb, var(--rhpz-orange-hover) 25%, transparent); } .\$cm-header { color: var(--rhpz-orange-hover); font-weight: 700; } .\$cm-strong { color: var(--text); font-weight: 700; } .\$cm-em { color: var(--text2); font-style: italic; } &.\$cm-link, &.\$cm-url { color: var(--rhpz-orange); } .\$cm-strikethrough, .\$cm-comment { color: var(--text2); } .\$editor-preview, .\$editor-preview-side { background: var(--bg2); color: var(--text); } } /* File: resources/css/components/files.css */ .\$file-list { display: flex; flex-direction: column; gap: 10px; } .\$file-item { display: flex; justify-content: space-between; align-items: center; padding: 12px 15px; background-color: var(--bg); border: 1px solid var(--border); transition: border-color 0.2s; &:hover { border-color: var(--rhpz-orange); } .\$file-info { display: flex; flex-direction: column; .\$file-name { font-weight: 600; color: var(--text); margin-bottom: 4px; } .\$file-meta { font-size: 0.8rem; color: var(--text2); } } } /* File: resources/css/components/forms.css */ .\$form-group { margin-bottom: 20px; } .\$form-group.level { background-color: var(--bg3); padding: 25px; border: 1px dashed var(--border); margin-bottom: 35px; border-radius: 4px; } .\$form-group-title { color: var(--text); margin-bottom: 20px; border-bottom: 1px solid var(--border); font-size: 1.15rem; display: flex; align-items: center; gap: 10px; padding-bottom: 10px; } .\$form-group label, .\$form-label { display: block; margin-bottom: 8px; font-weight: 600; color: var(--text); font-size: 0.95rem; } .\$form-group label span, .\$form-label span { color: var(--text2); font-weight: normal; font-size: 0.8rem; margin-left: 5px; } .\$form-error-text { margin-top: 10px; font-size: 0.85rem; color: var(--error); display: flex; align-items: center; gap: 5px; } .\$form-input, .\$form-select, .\$form-textarea, .\$form-field { width: 100%; background-color: var(--bg2); border: 1px solid var(--border); color: var(--text); padding: 10px 12px; font-family: var(--typography); font-size: 0.95rem; transition: border-color 0.2s; outline: none; &:focus { border-color: var(--rhpz-orange); } &:disabled { background-color: var(--bg3); color: var(--text); } } .\$form-textarea { resize: vertical; min-height: 120px; } .\$form-checkbox, .\$form-radio { accent-color: var(--rhpz-orange); background-color: var(--bg2); border: 1px solid var(--border); } .\$game-selector { position: relative; width: 100%; } .\$game-selector-level2 { position: relative; z-index: 1; } .\$game-selector-dropdown { position: absolute !important; width: 100%; min-width: 100%; top: calc(100% + 0.35rem); left: 0; margin: 0; padding: 0.35rem 0; z-index: 9999; max-height: 260px; overflow-y: auto; overflow-x: hidden; background-color: var(--bg2); border: 1px solid var(--border); box-shadow: 0 18px 35px rgba(0, 0, 0, 0.08); list-style: none; will-change: transform, opacity; } .\$game-selector-dropdown::-webkit-scrollbar { width: 8px; } .\$game-selector-dropdown::-webkit-scrollbar-thumb { background-color: rgba(255, 255, 255, 0.15); border-radius: 999px; } .\$game-selector-dropdown li { margin: 0; } .\$dropdown-item { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 0.75rem; padding: 0.85rem 1rem; background: transparent; border: none; color: var(--text); text-align: left; cursor: pointer; transition: background-color 0.18s ease, color 0.18s ease; } .dropdown-item:hover, .\$dropdown-item:focus { background-color: rgba(255, 255, 255, 0.08); color: var(--text); outline: none; } .dropdown-item[selected], .dropdown-item.selected, .\$dropdown-item.is-selected { background-color: rgba(255, 115, 0, 0.15); } .\$dropdown-item-name { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; } .\$dropdown-empty { padding: 0.85rem 1rem; color: var(--text2); } .\$form-upload { position: relative; display: flex; align-items: center; .\$disabled { opacity: 0.5; pointer-events: none; } input[type="file"] { position: absolute; left: 0; top: 0; width: 100%; height: 100%; opacity: 0; cursor: pointer; } } .\$form-upload-placeholder { width: 100%; display: flex; align-items: center; justify-content: space-between; background-color: var(--bg2); border: 1px dashed var(--border); padding: 12px; color: var(--text); transition: border-color 0.2s, background-color 0.2s; } .\$form-upload-placeholder.level { padding: 30px; text-align: center; display: block; background-color: var(--bg); } .\$form-upload:hover .\$form-upload-placeholder { border-color: var(--rhpz-orange); background-color: rgba(255, 115, 0, 0.05); } .\$form-type-of-checkboxes { display: grid; grid-template-columns: repeat(7, 1fr); gap: 1rem; label { box-sizing: border-box; margin: 0; } input[type="checkbox"] { transform: scale(1.5); margin-right: 1.33rem; } } .\$form-status-radio { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; label { box-sizing: border-box; margin: 0; } input[type="radio"] { transform: scale(1.5); margin-right: 1.33rem; } } .\$languages-selector { display: flex; flex-direction: column; gap: 1rem; } .\$language-search { display: flex; align-items: center; gap: 15px; background-color: var(--bg3); border: 1px solid var(--border); padding: 0 10px; height: 36px; } .\$language-search input { flex: 1; height: 100%; background: transparent; border: none; outline: none; color: var(--text); } .\$language-search [data-lucide] { color: var(--text2); flex-shrink: 0; } .\$language-search .\$btn { padding: 0; background: transparent; border: none; display: flex; align-items: center; flex-shrink: 0; } .\$language-list { display: flex; flex-direction: column; gap: 2px; max-height: 260px; overflow-y: auto; background: var(--bg3); border: 1px solid var(--border); scrollbar-width: thin; scrollbar-color: var(--rhpz-orange); padding: 2%; } .\$language-item { display: flex; align-items: center; gap: 15px; accent-color: var(--rhpz-orange); } .\$main-image-grid { display: flex; flex-direction: row; gap: 1rem; } .\$form-image-placeholder { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 15px; height: 100%; min-height: 120px; background-color: var(--bg); border: 1px solid var(--border); color: var(--text2); } .\$form-image-preview { display: flex; flex-direction: column; gap: 15px; } .\$form-image-preview-wrap { position: relative; overflow: hidden; border: 1px solid var(--border); aspect-ratio: 16/9; img { width: 100%; height: 100%; object-fit: cover; display: block; } } .\$form-image-remove { position: absolute; top: 6px; right: 6px; width: 24px; height: 24px; background-color: var(--bg2); border: none; display: flex; align-items: center; justify-content: center; cursor: pointer; color: var(--text); transition: background-color 0.15s; &:hover { background-color: var(--bg3); } } .\$form-gallery { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 15px; } .\$gallery-item { display: flex; flex-direction: column; gap: 5px; } .\$gallery-item { position: relative; cursor: grab; transition: opacity 0.2s, transform 0.15s; user-select: none; } .gallery-item:active { cursor: grabbing; } .\$gallery-item--dragging { opacity: 0.4; transform: scale(0.97); } .\$gallery-drag-handle { position: absolute; top: 4px; left: 4px; z-index: 10; background-color: rgba(0,0,0,0.6); color: #fff; padding: 3px 4px; display: flex; align-items: center; cursor: grab; opacity: 0; transition: opacity 0.15s; } .gallery-item:hover .gallery-drag-handle { opacity: 1; } .\$gallery-order-badge { position: absolute; bottom: 4px; left: 4px; z-index: 10; background-color: rgba(0,0,0,0.7); color: #fff; font-size: 0.7rem; font-weight: 700; padding: 2px 6px; min-width: 20px; text-align: center; } .\$authors-list { display: grid; grid-template-columns: repeat(4, 1fr); gap: 15px; button { padding: 5px; } } .\$submit { display: flex; align-items: center; justify-content: flex-end; gap: 15px; } .\$submit-level { display: flex; align-items: center; gap: 15px; } .\$nsfw-label { display: flex; align-items: center; gap: 8px; cursor: pointer; white-space: nowrap; } .\$upload-list { display: flex; flex-direction: column; gap: 5px; margin-top: 12px; } .\$upload-item { display: flex; align-items: center; gap: 15px; padding: 10px 14px; border-radius: 6px; border: 1px solid var(--border); background-color: var(--bg2); transition: background-color 0.15s, border-color 0.15s; & > [data-lucide] { flex-shrink: 0; width: 20px; height: 20px; } } .\$upload-item-uploading { border-color: var(--border); background-color: var(--bg2); & > [data-lucide] { color: var(--text2); } } .\$upload-item-done { border-color: color-mix(in srgb, var(--rhpz-orange) 40%, transparent); background-color: color-mix(in srgb, var(--rhpz-orange) 6%, transparent); & > [data-lucide] { color: var(--rhpz-orange); } } .\$upload-item-error { border-color: color-mix(in srgb, var(--error) 40%, transparent); background: color-mix(in srgb, var(--error) 6%, transparent); & > [data-lucide] { color: var(--error); } } .\$upload-item-info { display: flex; flex-direction: column; gap: 5px; flex: 1; min-width: 0; } .\$upload-item-name { color: var(--text); font-weight: 500; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; } .\$progress { height: 6px; background-color: var(--bg3); border-radius: 99px; overflow: hidden; position: relative; } .\$progress-bar { height: 100%; background-color: var(--rhpz-orange); border-radius: 99px; transition: width 0.2s ease; min-width: 4px; } .\$progress-bar-label { position: absolute; top: -18px; right: 0; font-size: 11px; color: var(--text2); white-space: nowrap; } .\$upload-item-actions { display: flex; flex-direction: row; gap: 15px; } .file-state-icon { width: 18px; height: 18px; } .file-state-icon--public { color: var(--success); } .file-state-icon--private { color: var(--text2); } .file-state-icon--archived { color: var(--error); } .upload-item-state { display: flex; align-items: center; gap: 8px; } .author-search { position: relative; } .\$author-search-input { display: flex; align-items: center; gap: 8px; background-color: var(--bg); border: 1px solid var(--border); padding: 8px 12px; } .\$author-search-input .\$form-input { border: none; padding: 0; background: none; flex: 1; } .\$author-search-selected { display: flex; align-items: center; gap: 5px; color: var(--success); font-size: 0.85rem; white-space: nowrap; } .\$author-search-dropdown { position: absolute; top: 100%; left: 0; right: 0; background-color: var(--bg2); border: 1px solid var(--border); border-top: none; z-index: 100; max-height: 200px; overflow-y: auto; } .\$author-search-item { display: flex; align-items: center; gap: 9px; width: 100%; padding: 9px 12px; background: none; border: none; color: var(--text); font-size: 0.88rem; cursor: pointer; text-align: left; font-family: var(--typography); transition: background-color 0.1s; } .author-search-item:hover { background-color: var(--bg3); } .\$game-selector-mode { display: flex; gap: 0; margin-bottom: 15px; border: 1px solid var(--border); } .\$game-selector-mode-btn { display: flex; align-items: center; gap: 7px; padding: 8px 14px; background: none; border: none; border-right: 1px solid var(--border); color: var(--text2); font-size: 0.85rem; cursor: pointer; font-family: var(--font-family); transition: background-color 0.1s, color 0.1s; } .\$game-selector-mode-btn:last-child { border-right: none; } .\$game-selector-mode-btn:hover { background-color: var(--bg3); color: var(--text); } .\$game-selector-mode-btn.active { background-color: var(--bg3); color: var(--rhpz-orange); border-bottom: 2px solid var(--rhpz-orange); } .\$game-selector-platform-only { grid-column: span 1; } /* File: resources/css/components/grid.css */ .\$grid-c2 { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; } .\$grid-c3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 20px; } @media (max-width: 1100px) { .grid-c3 { grid-template-columns: 1fr 1fr; } } @media (max-width: 768px) { .grid-c2, .grid-c3 { grid-template-columns: 1fr; } } .\$grid-hashes { display: grid; grid-template-columns: repeat(4,0.5fr) 0.25fr; gap: 20px; } .\$grid-credits { display: grid; grid-template-columns: 0.5fr 1fr 0.25fr; gap: 20px; } .\$grid-entries { display: grid; grid-template-columns: repeat(6,1fr); gap: 20px; margin-bottom: 20px; } /* File: resources/css/components/hovercard.css */ .\$hovercard-overlay { position: absolute; z-index: 2000; background-color: var(--bg2); border: 1px solid var(--border); box-shadow: 0 8px 24px rgba(0, 0, 0, 0.5); } .\$hovercard-overlay-loading { display: flex; align-items: center; justify-content: center; padding: 30px; color: var(--text2); } .\$hovercard-overlay-error { padding: 20px; text-align: center; color: var(--text2); font-size: 0.85rem; } .\$hovercard { width: 280px; } .\$hovercard-header { height: 70px; background-color: var(--bg3); border-bottom: 1px solid var(--border); position: relative; } .\$hovercard-avatar { position: absolute; bottom: -26px; left: 16px; width: 52px; height: 52px; border-radius: 50%; border: 3px solid var(--bg2); overflow: hidden; background-color: var(--bg4); display: flex; align-items: center; justify-content: center; font-weight: 600; font-size: 1.2rem; color: var(--text); img { width: 100%; height: 100%; object-fit: cover; } } .\$hovercard-body { padding: 34px 16px 16px; } .\$hovercard-username { font-weight: 600; font-size: 1rem; color: var(--text); margin-bottom: 2px; } .\$hovercard-title { font-size: 0.8rem; color: var(--rhpz-orange); margin-bottom: 14px; min-height: 14px; } .\$hovercard-stats { display: flex; border: 1px solid var(--border); margin-bottom: 14px; } .\$hovercard-stat { flex: 1; display: flex; flex-direction: column; align-items: center; padding: 8px 4px; border-right: 1px solid var(--border); &:last-child { border-right: none; } .\$stat-value { font-size: 0.95rem; font-weight: 600; color: var(--text); } .\$stat-label { font-size: 0.68rem; color: var(--text2); text-transform: uppercase; letter-spacing: 0.5px; margin-top: 2px; } } .\$hovercard-actions { display: flex; gap: 8px; } .\$hovercard-actions .\$btn { flex: 1; justify-content: center; font-size: 0.82rem; } /* File: resources/css/components/modal.css */ .\$modal-overlay { display: flex; position: fixed; top: 0; left: 0; right: 0; bottom: 0; background-color: rgba(0, 0, 0, 0.7); z-index: 1000; align-items: center; justify-content: center; backdrop-filter: blur(3px); animation: fadeIn 0.2s ease; } .\$modal-window { background-color: var(--bg2); border: 1px solid var(--border); width: 100%; max-width: 500px; box-shadow: 0 10px 30px rgba(0,0,0,0.5); display: flex; flex-direction: column; } .\$modal-header { padding: 15px 20px; border-bottom: 1px solid var(--border); display: flex; justify-content: space-between; align-items: center; background-color: var(--bg3); .\$modal-title { font-weight: 600; font-size: 1.1rem; color: var(--text); } .\$modal-close { background: none; border: none; color: var(--text2); cursor: pointer; transition: color 0.2s; &:hover { color: var(--text); } } } .\$modal-content, .\$modal-body { padding: 20px; } /* File: resources/css/components/modcp.css */ .\$modcp-wrapper { display: flex; gap: 0; align-items: flex-start; min-height: calc(100vh - 60px); } .\$modcp-sidebar { width: 220px; flex-shrink: 0; background-color: var(--bg2); border: 1px solid var(--border); position: sticky; top: 0; align-self: flex-start; margin-right: 15px; } .\$modcp-sidebar-header { display: flex; align-items: center; gap: 8px; padding: 14px 16px; font-weight: 600; font-size: 0.88rem; color: var(--text); border-bottom: 1px solid var(--border); background-color: var(--bg3); text-transform: uppercase; letter-spacing: 0.5px; } .modcp-nav { padding: 8px 0; } .modcp-nav-group { margin-bottom: 4px; } .\$modcp-nav-label { display: block; padding: 8px 16px 4px; font-size: 0.7rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.8px; color: var(--text2); } .\$modcp-nav-item { display: flex; align-items: center; gap: 9px; padding: 8px 16px; font-size: 0.88rem; color: var(--text); text-decoration: none; border-left: 3px solid transparent; transition: background-color 0.1s, border-color 0.1s; &:hover { background-color: var(--bg3); text-decoration: none; } .\$active { background-color: var(--bg3); border-left-color: var(--rhpz-orange); color: var(--text); font-weight: 600; } } .\$modcp-nav-badge { margin-left: auto; background-color: var(--rhpz-orange); color: #111; font-size: 0.65rem; font-weight: 700; min-width: 18px; height: 18px; border-radius: 9px; display: flex; align-items: center; justify-content: center; padding: 0 5px; } .\$modcp-content { flex: 1; min-width: 0; background-color: var(--bg2); border: 1px solid var(--border); padding: 25px; } .\$modcp-page-title { display: flex; align-items: center; gap: 10px; font-size: 1.3rem; font-weight: 600; color: var(--text); margin-bottom: 25px; padding-bottom: 15px; border-bottom: 1px solid var(--border); } .\$modcp-count { margin-left: auto; font-size: 0.85rem; font-weight: normal; color: var(--text2); } .\$modcp-section-title { font-size: 0.78rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.7px; color: var(--text2); margin-bottom: 12px; } .\$modcp-stats { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 12px; margin-bottom: 25px; } .\$modcp-stat-card { display: flex; align-items: center; gap: 12px; padding: 16px; background-color: var(--bg3); border: 1px solid var(--border); border-left: 3px solid var(--border); text-decoration: none; transition: border-color 0.15s, background-color 0.15s; color: var(--text); &:hover { background-color: var(--bg4); text-decoration: none; } } .modcp-stat-card--orange { border-left-color: var(--rhpz-orange); } .modcp-stat-card--danger { border-left-color: var(--error); } .modcp-stat-card--muted { cursor: default; } .modcp-stat-icon { color: var(--text2); } .modcp-stat-card--orange .modcp-stat-icon { color: var(--rhpz-orange); } .modcp-stat-card--danger .modcp-stat-icon { color: var(--error); } .modcp-stat-info { display: flex; flex-direction: column; } .modcp-stat-value { font-size: 1.4rem; font-weight: 700; color: var(--text); line-height: 1; } .modcp-stat-label { font-size: 0.75rem; color: var(--text2); margin-top: 3px; } .\$modcp-quick-actions { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 25px; } .\$modcp-quick-btn { display: inline-flex; align-items: center; gap: 7px; padding: 8px 14px; background-color: var(--bg3); border: 1px solid var(--border); color: var(--text); font-size: 0.85rem; text-decoration: none; transition: background-color 0.1s, border-color 0.1s; &:hover { background-color: var(--bg4); border-color: var(--rhpz-orange); text-decoration: none; } } .modcp-list { display: flex; flex-direction: column; } .\$modcp-list-item { display: flex; align-items: center; gap: 15px; padding: 12px 15px; border-bottom: 1px solid var(--border); transition: background-color 0.1s; } .modcp-list-item:last-child { border-bottom: none; } .modcp-list-item:hover { background-color: var(--bg3); } .modcp-list-item--deleted { opacity: 0.8; } .\$modcp-list-item-cover { width: 44px; height: 44px; flex-shrink: 0; background-color: var(--bg); border: 1px solid var(--border); display: flex; align-items: center; justify-content: center; overflow: hidden; color: var(--border); } .\$modcp-list-item-cover img { width: 100%; height: 100%; object-fit: contain; } .\$modcp-list-item-info { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 4px; } .\$modcp-list-item-title { font-size: 0.92rem; font-weight: 600; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } .\$modcp-list-item-meta { display: flex; align-items: center; gap: 6px; font-size: 0.78rem; color: var(--text2); } .\$modcp-list-item-actions { display: flex; gap: 6px; flex-shrink: 0; } .\$modcp-list-item-edit { display: flex; gap: 6px; flex: 1; align-items: center; } .\$modcp-list-item-edit .\$form-input { flex: 1; padding: 5px 10px; font-size: 0.88rem; } .\$modcp-list-see-all { display: block; text-align: center; padding: 10px; font-size: 0.85rem; color: var(--rhpz-orange); border-top: 1px solid var(--border); text-decoration: none; } .\$modcp-add-form { background-color: var(--bg3); border: 1px solid var(--border); padding: 15px; margin-bottom: 20px; } .\$modcp-add-form-inner { display: flex; gap: 8px; align-items: center; } .modcp-add-form-inner .form-input { flex: 1; } .\$modcp-empty { display: flex; flex-direction: column; align-items: center; gap: 12px; padding: 50px 20px; color: var(--text2); text-align: center; } .\$mod-alert { display: flex; align-items: center; gap: 8px; padding: 10px 15px; margin-bottom: 20px; font-size: 0.88rem; border: 1px solid; } .\$mod-alert--success { background-color: rgba(129, 199, 132, 0.08); border-color: rgba(129, 199, 132, 0.3); color: var(--success); } .\$modcp-list-item-edit--game { flex-wrap: wrap; gap: 6px; } .modcp-list-item-edit--game .form-input { min-width: 180px; flex: 2; } .modcp-list-item-edit--game .form-select { flex: 1; min-width: 120px; } .\$log-filters { margin-bottom: 16px; background-color: var(--bg3); border: 1px solid var(--border); } .\$log-filters-main { display: flex; align-items: center; gap: 8px; padding: 12px 14px; flex-wrap: wrap; } .\$log-search-wrap { flex: 1; min-width: 200px; position: relative; display: flex; align-items: center; } .\$log-search-wrap i { position: absolute; left: 10px; color: var(--text2); pointer-events: none; } .log-search-wrap .form-input { padding-left: 30px; } .log-select { min-width: 130px; } .\$log-filter-dot { width: 6px; height: 6px; border-radius: 50%; background-color: var(--rhpz-orange); flex-shrink: 0; } .\$log-filters-extra { border-top: 1px solid var(--border); padding: 12px 14px; } .\$log-filters-extra-inner { display: flex; align-items: flex-end; gap: 12px; flex-wrap: wrap; } .\$log-filter-field { display: flex; flex-direction: column; gap: 4px; } .\$log-filter-label { font-size: 0.7rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.6px; color: var(--text2); } .log-transition-enter { transition: all .15s ease; } .log-transition-leave { transition: all .1s ease; } .\$log-results-bar { display: flex; align-items: center; justify-content: space-between; font-size: 0.78rem; color: var(--text2); margin-bottom: 10px; padding: 0 2px; } .log-loading { opacity: 0.5; } .log-item { align-items: flex-start; padding: 11px 14px; } .log-item--open { background-color: var(--bg3); } .\$log-event-dot { width: 26px; height: 26px; flex-shrink: 0; border-radius: 50%; display: flex; align-items: center; justify-content: center; margin-top: 2px; border: 1px solid var(--border); background-color: var(--bg3); color: var(--text2); } .\$log-event-dot--created { background-color: rgba(129,199,132,.1); border-color: rgba(129,199,132,.35); color: var(--success); } .\$log-event-dot--updated { background-color: rgba(255,115,0,.1); border-color: rgba(255,115,0,.35); color: var(--rhpz-orange); } .\$log-event-dot--deleted { background-color: rgba(229,115,115,.1); border-color: rgba(229,115,115,.35); color: var(--error); } .\$log-channel-badge { display: inline-flex; align-items: center; font-size: 0.68rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; padding: 1px 6px; background-color: rgba(255,255,255,.05); border: 1px solid var(--border); color: var(--text2); } .log-id { color: var(--text2); font-size: 0.78rem; } .log-sep { color: var(--border); } .\$log-item-right { display: flex; align-items: center; gap: 8px; flex-shrink: 0; margin-left: auto; } .\$log-timestamp { font-size: 0.75rem; color: var(--text2); white-space: nowrap; } .log-expand-btn { padding: 4px 7px; } .\$log-properties { background-color: var(--bg); border-bottom: 1px solid var(--border); padding: 14px 14px 14px 54px; } .\$log-diff-label { font-size: 0.68rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.7px; color: var(--text2); margin-bottom: 8px; } .\$log-diff { width: 100%; border-collapse: collapse; font-size: 0.8rem; } .\$log-diff th { text-align: left; padding: 5px 10px; font-size: 0.68rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; color: var(--text2); border-bottom: 1px solid var(--border); } .\$log-diff td { padding: 5px 10px; border-bottom: 1px solid var(--border); vertical-align: top; max-width: 300px; overflow-wrap: break-word; } .log-diff tr:last-child td { border-bottom: none; } .\$log-diff-key { font-size: 0.78rem; font-weight: 600; color: var(--text); width: 160px; white-space: nowrap; } .log-diff-old-head { color: var(--error) !important; } .log-diff-new-head { color: var(--success) !important; } .\$log-diff-old { color: var(--error); background-color: rgba(229,115,115,.05); } .\$log-diff-new { color: var(--success); background-color: rgba(129,199,132,.05); } .\$log-raw { font-family: monospace; font-size: 0.78rem; color: var(--text2); background-color: var(--bg2); border: 1px solid var(--border); padding: 10px 12px; overflow-x: auto; white-space: pre-wrap; word-break: break-all; } .\$log-pagination { padding: 14px 0 4px; border-top: 1px solid var(--border); } /* File: resources/css/components/notifications.css */ .\$notifications, .\$conversations { position: absolute; top: calc(100% + 8px); right: 0; width: 340px; max-height: 480px; overflow-y: auto; background-color: var(--bg2); border: 1px solid var(--border); box-shadow: 0 8px 24px rgba(0,0,0,0.5); z-index: 2000; &::-webkit-scrollbar { width: 8px; } &::-webkit-scrollbar-thumb { background-color: var(--border); } &::-webkit-scrollbar-track { background-color: var(--bg2); } } @keyframes dropdown-enter { from { opacity: 0; transform: translateY(-6px); } from { opacity: 0; transform: translateY(-6px); } to { opacity: 1; transform: translateY(0); } } .\$dropdown-enter { animation: dropdown-enter 0.15s ease; } .\$notifications-header { display: flex; align-items: center; justify-content: space-between; padding: 12px 16px; border-bottom: 1px solid var(--border); position: sticky; top: 0; background-color: var(--bg3); z-index: 1; .\$notifications-header-title { font-weight: 600; font-size: 0.9rem; color: var(--text); } .\$notifications-header-actions { display: flex; gap: 6px; } } .\$notifications-loading, .\$notifications-empty { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px; padding: 40px 20px; color: var(--text2); font-size: 0.85rem; } .\$notifications-item { display: flex; align-items: flex-start; gap: 12px; padding: 12px 16px; border-bottom: 1px solid var(--border); text-decoration: none; color: var(--text); transition: background-color 0.1s; position: relative; &:last-child { border-bottom: none; } &:hover { background-color: var(--bg3); } .\$unread { border-left: 2px solid var(--rhpz-orange); background-color: var(--bg3); } } .\$notifications-avatar { width: 36px; height: 36px; border-radius: 50%; overflow: hidden; flex-shrink: 0; background-color: var(--bg4); display: flex; align-items: center; justify-content: center; font-weight: 600; font-size: 0.9rem; color: var(--text); img { width: 100%; height: 100%; object-fit: cover; } } .\$notifications-content { display: flex; flex-direction: column; gap: 4px; flex: 1; min-width: 0; .\$notifications-text { font-size: 0.88rem; color: var(--text); line-height: 1.4; } .\$notifications-date { font-size: 0.75rem; color: var(--text2); } } .\$notifications-unread-dot { width: 8px; height: 8px; border-radius: 50%; background-color: var(--rhpz-orange); flex-shrink: 0; margin-top: 4px; } /* File: resources/css/components/queue.css */ .\$queue-empty { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 15px; padding: 80px 20px; color: var(--text2); font-size: 0.95rem; } .\$queue-item { background-color: var(--bg2); border: 1px solid var(--border); border-left-width: 4px; margin-bottom: 20px; padding: 20px; } .\$queue-item--pending { border-left-color: var(--rhpz-orange); } .\$queue-item--rejected { position: relative; overflow: hidden; border-left-color: var(--error); &::after { content: ''; position: absolute; bottom: 0; left: 0; height: 2px; background-color: var(--error); width: var(--reject-progress, 100%); opacity: 0.5; transition: width 0.3s; } } .\$queue-item-header { display: flex; justify-content: space-between; align-items: flex-start; gap: 15px; margin-bottom: 20px; } .\$queue-item-title { font-size: 1.15rem; font-weight: 600; color: var(--text); margin-bottom: 6px; } .\$queue-item-meta { font-size: 0.85rem; color: var(--text2); display: flex; align-items: center; gap: 6px; flex-wrap: wrap; } .\$queue-item-actions-header { display: flex; gap: 8px; flex-shrink: 0; } .\$timeline-container { padding: 15px 20px; background-color: var(--bg); border: 1px solid var(--border); margin-bottom: 20px; } .\$timeline { display: flex; justify-content: space-between; position: relative; &::before { content: ''; position: absolute; top: 15px; left: 30px; right: 30px; height: 2px; background-color: var(--border); z-index: 0; } } .\$timeline-step { display: flex; flex-direction: column; align-items: center; position: relative; z-index: 1; width: 100px; } .\$timeline-dot { width: 32px; height: 32px; border-radius: 50%; background-color: var(--bg); border: 2px solid var(--border); display: flex; align-items: center; justify-content: center; color: var(--text2); margin-bottom: 10px; transition: all 0.2s; } .\$timeline-step--active .\$timeline-dot { border-color: var(--rhpz-orange); background-color: var(--rhpz-orange); color: #111; } .\$timeline-step--validated .\$timeline-dot { border-color: var(--success); background-color: var(--success); color: #111; } .\$timeline-step--rejected .\$timeline-dot { border-color: var(--error); background-color: var(--error); color: #fff; } .\$timeline-label { font-size: 0.78rem; text-align: center; color: var(--text2); font-weight: 500; } .timeline-step--active .timeline-label { color: var(--rhpz-orange); font-weight: 600; } .timeline-step--validated .timeline-label { color: var(--success); } .timeline-step--rejected .timeline-label { color: var(--error); } .\$queue-reject-reason { display: flex; gap: 10px; align-items: flex-start; padding: 12px 15px; background-color: rgba(229, 115, 115, 0.08); border-left: 2px solid var(--error); color: var(--text); font-size: 0.88rem; margin-bottom: 15px; line-height: 1.5; } .\$queue-mod-zone { border-top: 1px solid var(--border); padding-top: 15px; margin-top: 5px; display: flex; flex-direction: column; gap: 15px; } .\$queue-mod-separator { border-top: 1px solid var(--border); } .\$queue-mod-actions { display: flex; gap: 8px; justify-content: flex-end; margin-top: 10px; } .\$queue-reject-form { margin-top: 12px; padding: 15px; background-color: var(--bg3); border: 1px solid var(--border); } /* File: resources/css/components/settings.css */ .\$settings-dropdown { position: absolute; top: calc(100% + 8px); right: 0; width: 240px; background-color: var(--bg2); border: 1px solid var(--border); box-shadow: 0 8px 24px rgba(0,0,0,0.5); z-index: 2000; } .\$settings-header { padding: 12px 16px; border-bottom: 1px solid var(--border); background-color: var(--bg3); font-weight: 600; font-size: 0.9rem; color: var(--text); } .\$settings-section { padding: 12px 16px; } .\$settings-section-title { display: flex; align-items: center; gap: 7px; font-size: 0.78rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.7px; color: var(--text2); margin-bottom: 10px; } .\$settings-separator { border-top: 1px solid var(--border); } .\$settings-themes { display: flex; gap: 8px; flex-wrap: wrap; } .\$settings-theme-btn { width: 28px; height: 28px; border-radius: 50%; border: 2px solid transparent; cursor: pointer; display: flex; align-items: center; justify-content: center; color: var(--text); transition: transform 0.15s, border-color 0.15s; padding: 0; &:hover { transform: scale(1.15); } .\$active { border-color: var(--text); transform: scale(1.1); } } .\$settings-theme-toggle { width: 100%; background-color: var(--bg3); border: 1px solid var(--border); color: var(--text); padding: 8px 12px; cursor: pointer; font-family: var(--typography); font-size: 0.88rem; transition: background-color 0.1s; text-align: left; &:hover { background-color: var(--bg4); } } .\$settings-theme-toggle-inner { display: flex; align-items: center; gap: 8px; } .\$settings-theme-toggle-badge { margin-left: auto; background-color: var(--rhpz-orange); color: #111; font-size: 0.65rem; font-weight: 700; padding: 2px 6px; } .\$settings-perpage { display: flex; gap: 6px; } .\$settings-perpage-btn { flex: 1; padding: 6px 4px; background-color: var(--bg3); border: 1px solid var(--border); color: var(--text2); font-size: 0.85rem; cursor: pointer; font-family: var(--typography); transition: all 0.1s; &:hover { background-color: var(--bg4); color: var(--text); } .\$active { background-color: var(--rhpz-orange); border-color: var(--rhpz-orange); color: var(--text3); font-weight: 600; } } .\$settings-link { display: flex; align-items: center; gap: 9px; padding: 8px 10px; color: var(--text); text-decoration: none; font-size: 0.88rem; transition: background-color 0.1s; border: 1px solid transparent; &:hover { background-color: var(--bg3); border-color: var(--border); text-decoration: none; } } .\$settings-link--danger { color: var(--error); &:hover { background-color: rgba(229, 115, 115, 0.08); border-color: rgba(229, 115, 115, 0.3); } } /* File: resources/css/components/tools.css */ .\$patcher-container { background-color: var(--bg2); border: 1px solid var(--border); padding: 25px; margin-bottom: 20px; } .\$patcher-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; } @media (max-width: 768px) { .\$patcher-grid { grid-template-columns: 1fr; } } .\$patcher-dropzone { border: 2px dashed var(--border); background-color: var(--bg3); padding: 55px 20px; text-align: center; cursor: pointer; transition: all 0.2s ease; display: flex; flex-direction: column; align-items: center; gap: 15px; } .\$patcher-dropzone:hover, .\$patcher-dropzone.dragover { border-color: var(--rhpz-orange); background-color: var(--bg4); } .\$patcher-dropzone.has-file { border-color: var(--success); background-color: rgba(129, 199, 132, 0.02); } .\$patcher-status-box { margin-top: 20px; padding: 15px; border: 1px solid var(--border); background-color: var(--bg3); font-size: 0.95rem; line-height: 1.4; } .\$btn:disabled { opacity: 0.4; cursor: not-allowed; background-color: var(--bg3); border-color: var(--border); color: var(--text2); } .\$embed-patch-box { border: 1px solid var(--border); background-color: var(--bg3); padding: 25px; height: 85%; display: flex; flex-direction: column; justify-content: center; gap: 15px; } .\$embed-patch-box-icon { display: flex; align-items: center; gap: 15px; } .\$embed-patch-box-icon-block { width: 48px; height: 48px; background-color: var(--bg2); border: 1px solid var(--border); display: flex; align-items: center; justify-content: center; } /* File: resources/css/layout/activity.css */ .\$activity-hero-excerpt { font-size: 0.9rem; color: rgba(255,255,255,0.75); margin-bottom: 12px; line-height: 1.5; max-width: 600px; } .\$activity-tl-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; padding-bottom: 15px; border-bottom: 1px solid var(--border); gap: 15px; flex-wrap: wrap; } .\$activity-tl-title { display: flex; align-items: center; gap: 10px; font-size: 1.15rem; font-weight: 600; color: var(--text); margin: 0; } .\$activity-tl-filters { display: flex; gap: 5px; flex-wrap: wrap; } .\$activity-tl-filter { display: inline-flex; align-items: center; gap: 5px; padding: 5px 12px; background: none; border: 1px solid var(--border); color: var(--text2); font-size: 0.8rem; cursor: pointer; font-family: var(--typography); transition: all 0.1s; } .activity-tl-filter:hover { background-color: var(--bg3); color: var(--text); } .\$activity-tl-filter.active { background-color: var(--bg3); border-color: var(--rhpz-orange); color: var(--rhpz-orange); } .\$activity-day-sep { display: flex; align-items: center; gap: 10px; padding-left: 54px; margin: 20px 0 12px; } .\$activity-day-label { font-size: 0.72rem; font-weight: 600; color: var(--text2); text-transform: uppercase; letter-spacing: 0.8px; white-space: nowrap; } .\$activity-day-line { flex: 1; height: 1px; background-color: var(--border); } .\$activity-tl-item { display: flex; gap: 0; margin-bottom: 2px; } .\$activity-tl-left { width: 54px; flex-shrink: 0; display: flex; flex-direction: column; align-items: center; padding-top: 12px; } .\$activity-tl-dot { width: 32px; height: 32px; border-radius: 50%; border: 1px solid var(--border); background-color: var(--bg2); display: flex; align-items: center; justify-content: center; flex-shrink: 0; z-index: 1; } .\$activity-tl-dot--entry { background-color: rgba(255,115,0,0.1); border-color: rgba(255,115,0,0.4); color: var(--rhpz-orange); } .\$activity-tl-dot--news { background-color: rgba(129,199,132,0.1); border-color: rgba(129,199,132,0.4); color: var(--success); } .\$activity-tl-dot--message, .\$activity-tl-dot--thread, .\$activity-tl-dot--club { background-color: rgba(25,118,210,0.1); border-color: rgba(25,118,210,0.4); color: var(--info); } .\$activity-tl-line { width: 1px; flex: 1; background-color: var(--border); margin-top: 4px; min-height: 16px; } .activity-tl-item:last-of-type .activity-tl-line { display: none; } .\$activity-tl-card { flex: 1; display: flex; align-items: center; gap: 12px; background-color: var(--bg2); border: 1px solid var(--border); padding: 10px 14px; margin-bottom: 8px; text-decoration: none; transition: border-color 0.15s, background-color 0.1s; min-width: 0; } .\$activity-tl-card:hover { border-color: var(--rhpz-orange); background-color: var(--bg3); text-decoration: none; } .\$activity-tl-thumb { width: 52px; height: 52px; flex-shrink: 0; overflow: hidden; display: flex; align-items: center; justify-content: center; background-color: var(--bg3); border: 1px solid var(--border); } .\$activity-tl-thumb img { width: 100%; height: 100%; object-fit: cover; } .\$activity-tl-body { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 4px; } .\$activity-tl-badge { display: inline-flex; align-items: center; gap: 4px; font-size: 0.68rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.6px; padding: 2px 7px; width: fit-content; } .\$activity-tl-badge--entry { background-color: rgba(255,115,0,0.1); color: var(--rhpz-orange); border: 1px solid rgba(255,115,0,0.25); } .\$activity-tl-badge--news { background-color: rgba(129,199,132,0.1); color: var(--success); border: 1px solid rgba(129,199,132,0.25); } .\$activity-tl-badge--message, .\$activity-tl-badge--thread, .\$activity-tl-dot--club { background-color: rgba(25,118,210,0.1); color: var(--info); border: 1px solid rgba(25,118,210,0.25); } .\$activity-tl-card-title { font-size: 0.92rem; font-weight: 600; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; line-height: 1.3; } .\$activity-tl-card-description { font-size: 0.8rem; color: var(--text2); white-space: nowrap; text-overflow: ellipsis; line-height: 1.3; } .\$activity-tl-meta { display: flex; align-items: center; gap: 10px; font-size: 0.75rem; color: var(--text2); flex-wrap: wrap; } .\$activity-tl-meta span { display: flex; align-items: center; gap: 3px; } .\$activity-tl-time { font-size: 0.72rem; color: var(--text2); white-space: nowrap; flex-shrink: 0; align-self: center; } .\$activity-tl-empty { display: flex; flex-direction: column; align-items: center; gap: 12px; padding: 60px; color: var(--text2); text-align: center; padding-left: 54px; } @media (max-width: 600px) { .activity-tl-header { flex-direction: column; align-items: flex-start; } .activity-tl-thumb { display: none; } .activity-day-sep { padding-left: 44px; } .activity-tl-left { width: 44px; } } .\$home-section { margin-bottom: 30px; } .\$home-section-header { display: flex; align-items: center; justify-content: space-between; padding-bottom: 12px; border-bottom: 1px solid var(--border); margin-bottom: 14px; } .\$home-section-title { display: flex; align-items: center; gap: 8px; font-size: 1.05rem; font-weight: 600; color: var(--text); margin: 0; } .\$home-section-more { display: inline-flex; align-items: center; gap: 4px; font-size: 0.75rem; color: var(--text2); border: 1px solid var(--border); padding: 4px 10px; text-decoration: none; transition: color 0.1s, border-color 0.1s; } .\$home-section-more:hover { color: var(--rhpz-orange); border-color: var(--rhpz-orange); } .\$news-strip { display: grid; grid-template-columns: repeat(5, 1fr); gap: 10px; } .\$news-strip-card { display: flex; flex-direction: column; background-color: var(--bg2); border: 1px solid var(--border); text-decoration: none; overflow: hidden; transition: border-color 0.15s; } .news-strip-card:hover { border-color: var(--rhpz-orange); text-decoration: none; } .\$news-strip-cover { height: 110px; background-color: var(--bg3); background-size: cover; background-position: center; position: relative; flex-shrink: 0; } .\$news-strip-date { position: absolute; bottom: 6px; left: 8px; font-size: 0.68rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; color: rgba(255,255,255,0.8); background: rgba(0,0,0,0.55); padding: 2px 6px; border: 1px solid rgba(255,255,255,0.07); } .\$news-strip-body { padding: 10px 12px; display: flex; flex-direction: column; gap: 5px; flex: 1; } .\$news-strip-badge { font-size: 0.65rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; color: var(--success); background: rgba(129,199,132,0.1); border: 1px solid rgba(129,199,132,0.25); padding: 1px 6px; width: fit-content; } .\$news-strip-title { font-size: 0.85rem; font-weight: 600; color: var(--text); line-height: 1.35; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; margin: 0; } .\$news-strip-meta { font-size: 0.72rem; color: var(--text2); margin-top: auto; } .\$featured-entries-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; } .\$featured-entry-card { display: flex; flex-direction: column; background-color: var(--bg2); border: 1px solid var(--border); text-decoration: none; overflow: hidden; transition: border-color 0.15s; } .featured-entry-card:hover { border-color: var(--rhpz-orange); text-decoration: none; } .\$featured-entry-cover { height: 80px; background-color: var(--bg3); position: relative; flex-shrink: 0; overflow: hidden; } .\$featured-entry-cover img { width: 100%; height: 100%; object-fit: cover; opacity: 0.85; } .\$featured-entry-star { position: absolute; top: 6px; right: 6px; font-size: 0.65rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; background: rgba(255,115,0,0.9); color: #111; padding: 2px 6px; border: 1px solid rgba(255,115,0,0.5); display: flex; align-items: center; gap: 3px; } .\$featured-entry-body { padding: 10px 12px; display: flex; flex-direction: column; gap: 5px; flex: 1; } .\$featured-entry-platform { font-size: 0.65rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; color: var(--rhpz-orange); background: rgba(255,115,0,0.1); border: 1px solid rgba(255,115,0,0.25); padding: 1px 6px; width: fit-content; } .\$featured-entry-title { font-size: 0.88rem; font-weight: 600; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } .\$featured-entry-meta { font-size: 0.72rem; color: var(--text2); margin-top: auto; } @media (max-width: 900px) { .news-strip { grid-template-columns: repeat(3, 1fr); } .featured-entries-grid { grid-template-columns: repeat(2, 1fr); } } @media (max-width: 600px) { .news-strip { grid-template-columns: repeat(2, 1fr); } .featured-entries-grid { grid-template-columns: repeat(2, 1fr); } .news-strip-cover { height: 80px; } } /* File: resources/css/layout/content.css */ #main-wrapper { flex-grow: 1; display: flex; flex-direction: column; overflow: hidden; } #topbar { height: 60px; background-color: var(--bg2); border-bottom: 1px solid var(--border); display: flex; align-items: center; padding: 0 20px; justify-content: space-between; .\$mobile-toggle { display: none; background: none; border: none; color: var(--text); cursor: pointer; } .\$topbar-actions { display: flex; gap: 8px; } .\$vertical-separator { align-items: center; border-left: 1px solid var(--border); } } .\$search-bar { display: flex; align-items: center; background-color: var(--bg); border: 1px solid var(--border); border-radius: 2px; padding: 5px 10px; width: 300px; input { background: none; border: none; color: var(--text); outline: none; margin-left: 8px; width: 100%; } } #content { flex-grow: 1; padding: 30px; overflow-y: auto; position: relative; } /* File: resources/css/layout/entry.css */ #entry-container, #comments-section, #reviews-section { background-color: var(--bg2); border: 1px solid var(--border); display: flex; flex-direction: column; } .\$entry-header { display: flex; padding: 30px; border-bottom: 1px solid var(--border); background: linear-gradient(to right, rgba(255,115,0,0.05), transparent); gap: 30px; .\$entry-cover { width: 220px; height: 220px; background-color: var(--bg); border: 1px solid var(--border); display: flex; align-items: center; justify-content: center; flex-shrink: 0; box-shadow: 0 4px 15px rgba(0,0,0,0.3); position: relative; overflow: hidden; img { width: 100%; height: 100%; object-fit: contain; padding: 8px; } } .\$entry-info { flex-grow: 1; display: flex; flex-direction: column; .\$entry-title { font-size: 2.2rem; font-weight: 600; margin-bottom: 5px; color: var(--text); } .\$entry-authors { color: var(--rhpz-orange); font-size: 1.1rem; margin-bottom: 20px; } .\$entry-meta-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 15px; margin-bottom: 25px; background-color: var(--bg); padding: 15px; border: 1px solid var(--border); } .\$entry-meta-item { display: flex; flex-direction: column; } .\$entry-meta-label { font-size: 0.75rem; color: var(--text2); text-transform: uppercase; } .\$entry-actions { margin-top: auto; display: flex; gap: 15px; } } } .\$entry-content { padding: 30px; .\$entry-section-title { font-size: 1.2rem; border-bottom: 1px solid var(--border); padding-bottom: 10px; margin-bottom: 20px; color: var(--text); display: flex; align-items: center; gap: 10px; } .\$entry-description { line-height: 1.6; color: var(--text); margin-bottom: 30px; } .\$entry-gallery { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 15px; margin-bottom: 30px; } .\$entry-gallery-item { aspect-ratio: 4/3; background-color: var(--bg); border: 1px solid var(--border); display: flex; align-items: center; justify-content: center; cursor: pointer; overflow: hidden; transition: border-color 0.2s; &:hover { border-color: var(--rhpz-orange); img { transform: scale(1.05); } } img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.3s ease; } } } .\$gallery-modal { position: fixed; z-index: 3000; top: 0; left: 0; width: 100%; height: 100%; background-color: rgba(0, 0, 0, 0.85); display: flex; align-items: center; justify-content: center; .\$gallery-modal-content { max-width: 90%; max-height: 90%; position: relative; img { max-width: 100%; max-height: 90vh; object-fit: contain; border: 2px solid var(--border); background-color: var(--bg); box-shadow: 0 10px 25px rgba(0,0,0,0.5); } } .\$gallery-modal-close { position: absolute; top: 20px; right: 30px; color: #fff; font-size: 40px; font-weight: bold; cursor: pointer; user-select: none; &:hover { color: var(--rhpz-orange); } } .\$gallery-modal-video { width: 90%; max-width: 960px; aspect-ratio: 16/9; box-shadow: 0 10px 30px rgba(0,0,0,0.6); border: 1px solid var(--border); background-color: #000; iframe { width: 100%; height: 100%; border: none; display: block; } } } .\$entry-cover-placeholder { text-align: center; color: var( --text2 ); } .\$comment-block { display: flex; gap: 16px; padding: 20px 0; border-bottom: 1px solid var(--border); &:last-child { border-bottom: none; } .\$comment-avatar { flex-shrink: 0; width: 48px; height: 48px; border-radius: 50%; overflow: hidden; background-color: var(--bg4); border: 1px solid var(--border); img { width: 100%; height: 100%; object-fit: cover; display: block; } } .\$comment-content { flex: 1; min-width: 0; .\$comment-meta { font-size: 0.88rem; color: var(--text2); margin-bottom: 6px; display: flex; align-items: center; flex-wrap: wrap; gap: 8px; .\$comment-author { font-weight: 600; color: var(--text); text-decoration: none; transition: color 0.2s; &:hover { color: var(--rhpz-orange); } } .\$comment-date { color: var(--text2); } .\$comment-separator { color: var(--border); user-select: none; } } .\$comment-body { font-size: 0.95rem; color: var(--text); line-height: 1.5; word-wrap: break-word; p { margin-bottom: 10px; &:last-child { margin-bottom: 0; } } a { color: var(--rhpz-orange); &:hover { color: var(--rhpz-orange-hover); text-decoration: underline; } } blockquote, .\$bbCodeBlock-blockquote { background-color: var(--bg); border-left: 3px solid var(--info); padding: 12px 16px; margin: 12px 0; font-style: italic; color: var(--text2); } code { font-family: monospace; background-color: var(--bg3); border: 1px solid var(--border); padding: 2px 5px; font-size: 0.9rem; } } } } .\$comments-empty { text-align: center; padding: 40px 20px; color: var(--text2); font-style: italic; background-color: var(--bg); border: 1px dashed var(--border); } .\$entry-video-section { margin-bottom: 30px; } .\$video-thumbnail-wrapper { position: relative; width: 100%; max-width: 500px; aspect-ratio: 16/9; background-color: #000; border: 1px solid var(--border); cursor: pointer; overflow: hidden; border-radius: 4px; img { width: 100%; height: 100%; object-fit: cover; opacity: 0.8; transition: transform 0.3s ease, opacity 0.3s ease; } .\$play-trigger { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 65px; height: 65px; background-color: rgba(0, 0, 0, 0.7); border: 2px solid #fff; border-radius: 50%; display: flex; align-items: center; justify-content: center; color: #fff; font-size: 1.5rem; transition: background-color 0.2s, transform 0.2s ease-out; i { margin-left: 4px; } } &:hover { img { transform: scale(1.03); opacity: 1; } .\$play-trigger { background-color: var(--rhpz-orange); border-color: var(--rhpz-orange); transform: translate(-50%, -50%) scale(1.1); box-shadow: 0 0 15px rgba(255, 115, 0, 0.5); } } } .\$entry-submission-byline { font-size: 0.85rem; color: var(--text2); margin-bottom: 20px; display: flex; align-items: center; gap: 15px; i { vertical-align: middle; margin-right: 4px; } } /* File: resources/css/layout/menu.css */ #menu { width: var(--menu-size); background-color: var(--bg2); border-right: 1px solid var(--border); display: flex; flex-direction: column; flex-shrink: 0; transition: transform 0.3s ease; z-index: 100; .\$menu-header { padding: 10px; display: flex; align-items: center; gap: 12px; border-bottom: 1px solid var(--border); img { width: 100%; height: 100%; object-fit: contain; } .\$menu-logo { width: 32px; height: 32px; background-color: var(--rhpz-orange); color: var(--text3); display: flex; align-items: center; justify-content: center; border-radius: 4px; font-weight: bold; font-size: 18px; } .\$menu-title { font-size: 1.2rem; font-weight: 600; letter-spacing: 0.5px; color: #fff; /* TODO Change */ } } .\$menu-navigation { flex-grow: 1; padding: 10px 0; overflow-y: auto; .\$menu-group { margin-bottom: 20px; .\$menu-group-title { padding: 0 20px; font-size: 0.75rem; text-transform: uppercase; color: var(--text2); margin-bottom: 8px; font-weight: 600; letter-spacing: 1px; } .\$menu-item { display: flex; align-items: center; padding: 10px 20px; color: var(--text); text-decoration: none; gap: 12px; border-left: 3px solid transparent; cursor: pointer; transition: background-color 0.1s, border-color 0.1s; &:hover { background-color: var(--bg4); text-decoration: none; } .\$active { background-color: var(--bg3); border-left-color: var(--rhpz-orange); font-weight: 600; } i { width: 20px; height: 20px; color: var(--text2); } .\$active i, &:hover i { color: var( --rhpz-orange ); } } } } .\$menu-user { padding: 15px 20px; border-top: 1px solid var(--border); display: flex; align-items: center; gap: 12px; background-color: var(--bg3); cursor: pointer; &:hover { background-color: var(--bg4); } .\$menu-user-avatar { width: 36px; height: 36px; border-radius: 50%; background-color: var( --menu-user-avatar-bg ); display: flex; align-items: center; justify-content: center; } .\$menu-user-info { display: flex; flex-direction: column; &.\$username { font-size: 0.9rem; font-weight: 600; } &.\$user_role { font-size: 0.75rem; color: var(--rhpz-orange); } } } } /* File: resources/css/layout/news.css */ .\$news-header { width: 100%; height: 250px; background-color: #333; background-image: linear-gradient(rgba(0,0,0,0.2), rgba(30,30,30,1)); display: flex; align-items: flex-end; padding: 30px; border: 1px solid var(--border); border-bottom: none; position: relative; .\$news-header-content { position: relative; z-index: 2; .\$news-title { font-size: 2.5rem; font-weight: 300; color: var(--text); margin-bottom: 10px; } .\$news-meta { color: var(--text2); display: flex; gap: 15px; font-size: 0.9rem; } } } .\$news-content { background-color: var(--bg2); border: 1px solid var(--border); padding: 40px; line-height: 1.7; color: var(--text); font-size: 1.05rem; p { margin-bottom: 20px; } } #news-container { background-color: var(--bg2); border: 1px solid var(--border); display: flex; flex-direction: column; } .\$news-header { width: 100%; height: 300px; background-size: cover; background-position: center; display: flex; align-items: flex-end; padding: 40px 30px; border-bottom: 1px solid var(--border); position: relative; } .\$news-header-content { position: relative; z-index: 2; } .\$news-header .\$news-title { font-size: 2.5rem; font-weight: 600; color: var(--text); margin-bottom: 12px; text-shadow: 0 2px 4px rgba(0,0,0,0.6); } .\$news-header .\$news-meta { color: var(--text2); display: flex; gap: 20px; font-size: 0.9rem; align-items: center; } .\$news-header .\$meta-item { display: flex; align-items: center; gap: 6px; background-color: rgba(0, 0, 0, 0.4); padding: 4px 10px; border-radius: 2px; border: 1px solid rgba(255,255,255,0.05); } .\$news-layout { display: flex; flex-direction: row; gap: 30px; padding: 30px; } @media (max-width: 992px) { .\$news-layout { flex-direction: column; } } .\$news-main-content { flex-grow: 1; flex-basis: 0; min-width: 0; } .\$news-body-text { line-height: 1.75; color: var(--text); font-size: 1.05rem; margin-bottom: 15px; } .\$news-body-text p { margin-bottom: 20px; } .\$news-sidebar { width: 320px; flex-shrink: 0; display: flex; flex-direction: column; gap: 25px; } @media (max-width: 992px) { .\$news-sidebar { width: 100%; } } .\$sidebar-block { background-color: var(--bg); border: 1px solid var(--border); padding: 20px; border-radius: 4px; } .\$sidebar-title { font-size: 1rem; text-transform: uppercase; letter-spacing: 0.5px; color: var(--text); margin-bottom: 15px; display: flex; align-items: center; gap: 8px; border-bottom: 1px solid var(--border); padding-bottom: 8px; } .\$btn-sidebar { display: flex; align-items: center; justify-content: center; gap: 8px; width: 100%; padding: 10px 15px; font-size: 0.95rem; font-weight: 500; text-decoration: none; cursor: pointer; border-radius: 2px; transition: background-color 0.2s ease, border-color 0.2s ease; text-align: center; } .\$btn-orange { background-color: var(--rhpz-orange); color: #fff; border: 1px solid transparent; } .\$btn-orange:hover { background-color: var(--rhpz-orange-hover); } .\$related-card { display: flex; flex-direction: column; gap: 12px; } .\$related-card-cover { width: 100%; height: 150px; background-color: var(--bg2); border: 1px solid var(--border); overflow: hidden; border-radius: 2px; } .\$related-card-cover img { width: 100%; height: 100%; object-fit: contain; padding: 5px; } .\$related-card-info h4 { font-size: 1.1rem; color: var(--text); margin-bottom: 10px; font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } .\$news-sidebar .\$video-thumbnail-wrapper { position: relative; width: 100%; aspect-ratio: 16/9; background-color: #000; border: 1px solid var(--border); cursor: pointer; overflow: hidden; border-radius: 2px; } .\$news-sidebar .\$video-thumbnail-wrapper img { width: 100%; height: 100%; object-fit: cover; opacity: 0.7; transition: transform 0.3s ease, opacity 0.3s ease; } .\$news-sidebar .\$video-thumbnail-wrapper:hover img { transform: scale(1.03); opacity: 0.9; } .\$news-sidebar .\$play-trigger { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 50px; height: 50px; background-color: rgba(0, 0, 0, 0.75); border: 2px solid #fff; border-radius: 50%; display: flex; align-items: center; justify-content: center; color: #fff; transition: background-color 0.2s, transform 0.2s ease-out; } .\$news-sidebar .\$video-thumbnail-wrapper:hover .\$play-trigger { background-color: var(--rhpz-orange); transform: translate(-50%, -50%) scale(1.1); } .\$news-actions { display: flex; align-items: center; gap: 8px; margin-top: 15px; flex-wrap: wrap; } .\$news-header .\$news-actions .\$btn { background-color: rgba(0, 0, 0, 0.5); border-color: rgba(255, 255, 255, 0.15); backdrop-filter: blur(4px); color: var(--text); transition: background-color 0.15s, border-color 0.15s; } .\$news-header .\$news-actions .\$btn:hover { background-color: rgba(0, 0, 0, 0.7); border-color: rgba(255, 255, 255, 0.3); } .\$news-header .\$news-actions .\$btn.success { background-color: rgba(56, 142, 60, 0.6); border-color: rgba(129, 199, 132, 0.4); color: #81c784; } .\$news-header .\$news-actions .\$btn.danger { background-color: rgba(183, 28, 28, 0.5); border-color: rgba(229, 115, 115, 0.4); color: #e57373; } /* ── Hero ────────────────────────────────────────────────── */ .\$news-hero { display: block; position: relative; width: 100%; height: 360px; margin-bottom: 20px; border: 1px solid var(--border); overflow: hidden; text-decoration: none; transition: border-color 0.2s; } .\$news-hero:hover { border-color: var(--rhpz-orange); text-decoration: none; } .\$news-hero-bg { position: absolute; inset: 0; background-size: cover; background-position: center; background-color: var(--bg3); transition: transform 0.4s ease; } .\$news-hero:hover .\$news-hero-bg { transform: scale(1.02); } .\$news-hero-content { position: absolute; bottom: 0; left: 0; right: 0; padding: 30px; z-index: 2; } .\$news-hero-badge { display: inline-flex; align-items: center; gap: 5px; background-color: var(--rhpz-orange); color: #111; font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.8px; padding: 4px 10px; margin-bottom: 12px; } .\$news-hero-title { font-size: 2rem; font-weight: 600; color: #fff; margin-bottom: 12px; text-shadow: 0 2px 8px rgba(0,0,0,0.5); line-height: 1.2; } .\$news-hero-meta { display: flex; align-items: center; gap: 15px; font-size: 0.85rem; color: rgba(255,255,255,0.75); } .\$news-hero-meta span { display: flex; align-items: center; gap: 5px; background-color: rgba(0,0,0,0.4); padding: 3px 10px; border: 1px solid rgba(255,255,255,0.08); } .\$news-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 15px; margin-bottom: 20px; } .\$news-card { display: flex; flex-direction: column; background-color: var(--bg2); border: 1px solid var(--border); text-decoration: none; overflow: hidden; transition: border-color 0.15s, transform 0.15s; } .\$news-card:hover { border-color: var(--rhpz-orange); transform: translateY(-2px); text-decoration: none; } .\$news-card-cover { height: 160px; background-size: cover; background-position: center; background-color: var(--bg3); position: relative; flex-shrink: 0; transition: transform 0.3s ease; } .\$news-card:hover .\$news-card-cover { transform: scale(1.03); } .\$news-card-state-badge { position: absolute; top: 10px; right: 10px; display: inline-flex; align-items: center; gap: 4px; background-color: rgba(0,0,0,0.7); color: var(--rhpz-orange); font-size: 0.72rem; font-weight: 600; padding: 3px 8px; border: 1px solid rgba(255,115,0,0.3); } .\$news-card-body { padding: 16px; display: flex; flex-direction: column; flex: 1; gap: 8px; } .\$news-card-title { font-size: 1rem; font-weight: 600; color: var(--text); line-height: 1.3; margin: 0; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; } .\$news-card-excerpt { font-size: 0.82rem; color: var(--text2); line-height: 1.5; margin: 0; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; flex: 1; } .\$news-card-meta { display: flex; align-items: center; gap: 12px; font-size: 0.75rem; color: var(--text2); margin-top: auto; padding-top: 8px; border-top: 1px solid var(--border); } .\$news-card-meta span { display: flex; align-items: center; gap: 4px; } @media (max-width: 600px) { .news-hero { height: 240px; } .news-hero-title { font-size: 1.4rem; } .news-grid { grid-template-columns: 1fr; } } /* File: resources/css/layout/submit.css */ .\$submit-hero { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; background-color: var(--bg2); border-bottom: 1px solid var(--border); padding: 40px 36px 32px; } .\$submit-eyebrow { display: inline-flex; align-items: center; gap: 6px; font-size: 0.68rem; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: var(--rhpz-orange); background: rgba(255,115,0,.1); border: 1px solid rgba(255,115,0,.3); padding: 3px 10px; margin-bottom: 16px; } .\$submit-hero-title { font-size: 1.9rem; font-weight: 300; color: var(--text); margin-bottom: 10px; line-height: 1.25; } .\$submit-hero-sub { font-size: 0.9rem; color: var(--text2); max-width: 460px; line-height: 1.65; } .\$submit-review-note { font-size: 0.8rem; color: var(--text2); border: 1px solid var(--border); background: var(--bg3); padding: 14px 18px; max-width: 210px; line-height: 1.6; flex-shrink: 0; } .submit-review-note strong { color: var(--rhpz-orange); } .submit-body { padding: 28px 36px 40px; } .\$submit-section-label { font-size: 0.68rem; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: var(--text2); display: flex; align-items: center; gap: 10px; margin-bottom: 14px; } .\$submit-section-label::after { content: ''; flex: 1; height: 1px; background: var(--border); } .\$submit-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-bottom: 30px; } .\$submit-card { display: flex; flex-direction: column; background: var(--bg2); border: 1px solid var(--border); text-decoration: none; transition: border-color .15s, background .1s; } .\$submit-card:hover { border-color: var(--card-color); background: var(--bg3); text-decoration: none; } .\$submit-card-top { display: flex; align-items: flex-start; gap: 14px; padding: 20px 20px 16px; border-bottom: 1px solid var(--border); } .\$submit-card-icon { width: 38px; height: 38px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; background: var(--card-bg); border: 1px solid var(--card-border); color: var(--card-color); } .\$submit-card-title { font-size: 0.95rem; font-weight: 600; color: var(--text); margin-bottom: 4px; } .\$submit-card-desc { font-size: 0.78rem; color: var(--text2); line-height: 1.55; } .\$submit-card-bottom { display: flex; align-items: center; justify-content: space-between; padding: 10px 20px; } .\$submit-card-tag { font-size: 0.65rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; color: var(--card-color); background: var(--card-bg); border: 1px solid var(--card-border); padding: 2px 7px; } .\$submit-card-cta { font-size: 0.75rem; color: var(--text2); display: flex; align-items: center; gap: 4px; transition: color .15s; } .submit-card:hover .submit-card-cta { color: var(--card-color); } .\$submit-news-row { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 28px; } .\$submit-news-card { display: flex; align-items: center; gap: 14px; background: var(--bg2); border: 1px solid var(--border); padding: 18px 22px; text-decoration: none; transition: border-color .15s, background .1s; } .\$submit-news-card:hover { border-color: var(--success); background: var(--bg3); } .submit-news-card--disabled { opacity: .5; cursor: not-allowed; } .submit-news-card--disabled:hover { border-color: var(--border); background: var(--bg2); } .\$submit-news-icon { width: 38px; height: 38px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; background: rgba(129,199,132,.1); border: 1px solid rgba(129,199,132,.3); color: var(--success); } .\$submit-news-title { font-size: 0.95rem; font-weight: 600; color: var(--text); margin-bottom: 3px; } .submit-news-desc { font-size: 0.78rem; color: var(--text2); line-height: 1.55; } .\$submit-news-cta { flex-shrink: 0; font-size: 0.75rem; color: var(--text2); display: flex; align-items: center; gap: 4px; transition: color .15s; } .submit-news-card:hover .submit-news-cta { color: var(--success); } .\$submit-news-staff-note { background: var(--bg2); border: 1px solid var(--border); padding: 18px 22px; font-size: 0.8rem; color: var(--text2); line-height: 1.65; display: flex; flex-direction: column; gap: 10px; } .\$submit-news-staff-badge { display: inline-flex; align-items: center; gap: 5px; font-size: 0.65rem; font-weight: 700; text-transform: uppercase; letter-spacing: .6px; color: var(--rhpz-orange); background: rgba(255,115,0,.1); border: 1px solid rgba(255,115,0,.3); padding: 2px 8px; width: fit-content; } .submit-news-staff-note a { color: var(--text2); text-decoration: underline; } .submit-news-staff-note a:hover { color: var(--text); } .\$submit-rules { display: flex; gap: 0; background: var(--bg2); border: 1px solid var(--border); } .\$submit-rule { flex: 1; display: flex; align-items: flex-start; gap: 12px; padding: 18px 22px; border-right: 1px solid var(--border); font-size: 0.8rem; color: var(--text2); line-height: 1.6; } .submit-rule:last-child { border-right: none; } .submit-rule strong { color: var(--text); } .\$submit-rule-num { width: 22px; height: 22px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; background: rgba(255,115,0,.1); border: 1px solid rgba(255,115,0,.3); color: var(--rhpz-orange); font-size: 0.72rem; font-weight: 700; } @media (max-width: 900px) { .submit-hero { flex-direction: column; align-items: flex-start; } .submit-grid { grid-template-columns: repeat(2, 1fr); } .submit-rules { flex-direction: column; } .submit-rule { border-right: none; border-bottom: 1px solid var(--border); } .submit-rule:last-child { border-bottom: none; } } @media (max-width: 600px) { .submit-hero, .submit-body { padding-left: 20px; padding-right: 20px; } .submit-grid { grid-template-columns: 1fr; } .submit-news-row { grid-template-columns: 1fr; } .submit-review-note { max-width: 100%; } } /* File: resources/css/xenforo.css */ .\$xf-menu-user-avatar-fix { width: 40px !important; height: 40px !important; }