| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744 |
- :root {
- --brand: #0a66ff;
- --brand-600: #0952cc;
- --text: #0b0c0f;
- --muted: #55637a;
- --border: #e6e8eb;
- --bg: #ffffff;
- --bg2: #f7f8fa;
- --bg-page: #f4f6fb;
- --danger: #e03131;
- --success: #2f9e44;
- --warning: #f08c00;
- --radius: 12px;
- --shadow: 0 1px 2px rgba(16, 24, 40, 0.06), 0 1px 3px rgba(16, 24, 40, 0.1);
- --shadow-lg: 0 8px 24px rgba(16, 24, 40, 0.12);
- --ring: 0 0 0 4px rgba(10, 102, 255, 0.16);
- --space-1: 4px;
- --space-2: 8px;
- --space-3: 12px;
- --space-4: 16px;
- --space-6: 24px;
- --space-8: 32px;
- }
- * {
- box-sizing: border-box;
- }
- html, body {
- height: 100%;
- }
- body {
- margin: 0;
- font-family: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial;
- color: var(--text);
- background: var(--bg-page);
- line-height: 1.5;
- }
- .container a {
- color: inherit;
- }
- .container a:hover {
- color: var(--text);
- }
- .container {
- max-width: 1180px;
- margin: 0 auto;
- padding: 0 var(--space-4);
- }
- .topbar {
- position: sticky;
- top: 0;
- z-index: 50;
- border-bottom: 1px solid var(--border);
- background: rgba(255,255,255,0.9);
- backdrop-filter: saturate(150%) blur(8px);
- box-shadow: 0 1px 0 rgba(16, 24, 40, 0.04);
- }
- .topbar-inner {
- display: flex;
- align-items: center;
- justify-content: space-between;
- height: 60px;
- }
- .brand {
- font-weight: 800;
- font-size: 18px;
- text-decoration: none;
- color: var(--text);
- display: flex;
- align-items: center;
- }
- .nav {
- display: flex;
- align-items: center;
- justify-content: space-between;
- gap: var(--space-3);
- flex: 1;
- min-width: 0;
- }
- .nav-group {
- display: flex;
- gap: var(--space-3);
- align-items: center;
- flex-wrap: wrap;
- }
- .nav-right {
- justify-content: flex-end;
- }
- .nav-auth {
- display: flex;
- gap: var(--space-2);
- align-items: center;
- }
- .nav-user {
- display: inline-flex;
- align-items: center;
- gap: var(--space-2);
- padding: 6px 10px;
- border-radius: 999px;
- border: 1px solid var(--border);
- background: var(--bg2);
- color: var(--text);
- }
- .nav-badge {
- display: inline-flex;
- align-items: center;
- padding: 2px 8px;
- border-radius: 999px;
- font-size: 12px;
- line-height: 18px;
- border: 1px solid var(--border);
- background: var(--bg);
- color: var(--muted);
- }
- .nav-badge-vip {
- color: #b45309;
- border-color: rgba(180, 83, 9, 0.25);
- background: rgba(180, 83, 9, 0.08);
- }
- .nav-msg {
- position: relative;
- display: inline-flex;
- align-items: center;
- justify-content: center;
- width: 36px;
- height: 36px;
- border-radius: 10px;
- }
- .nav-msg-badge {
- position: absolute;
- top: -4px;
- right: -4px;
- min-width: 18px;
- height: 18px;
- padding: 0 5px;
- border-radius: 999px;
- background: #ef4444;
- color: #fff;
- font-size: 12px;
- line-height: 18px;
- text-align: center;
- border: 2px solid var(--bg);
- display: none;
- }
- .nav-admin {
- color: var(--muted);
- }
- .nav a {
- text-decoration: none;
- color: var(--muted);
- padding: 6px 10px;
- border-radius: 8px;
- transition: all 0.2s ease;
- }
- .nav a:hover {
- background: var(--bg2);
- color: var(--text);
- transform: translateY(-1px);
- }
- .nav a.active {
- color: var(--brand);
- background: #eef4ff;
- }
- main.container {
- padding-top: var(--space-6);
- padding-bottom: var(--space-6);
- animation: pageFadeIn 0.4s ease-out;
- }
- @keyframes pageFadeIn {
- from { opacity: 0; transform: translateY(10px); }
- to { opacity: 1; transform: translateY(0); }
- }
- .container h1 {
- font-size: 28px;
- letter-spacing: -0.02em;
- margin: 0 0 var(--space-3);
- }
- .container h2 {
- font-size: 18px;
- margin: 0 0 var(--space-3);
- letter-spacing: -0.01em;
- }
- .container h3 {
- font-size: 16px;
- margin: 0 0 var(--space-2);
- }
- .section-title {
- font-weight: 700;
- color: var(--text);
- margin: 0 0 var(--space-2);
- }
- .footer {
- border-top: 1px solid var(--border);
- background: var(--bg);
- padding: var(--space-6) 0;
- color: var(--muted);
- font-size: 14px;
- }
- /* Admin page: remove container max-width limit */
- body[data-page="admin"] .container {
- max-width: none;
- }
- /* Hero & Swiper Styles */
- .hero-swiper {
- width: 100%;
- border-radius: 20px;
- overflow: hidden;
- box-shadow: var(--shadow-lg);
- margin-top: 16px;
- margin-bottom: 24px;
- }
- .hero {
- padding: 80px 20px;
- text-align: center;
- background-size: cover;
- background-position: center;
- position: relative;
- min-height: 400px;
- display: flex;
- align-items: center;
- justify-content: center;
- }
- .hero::before {
- content: "";
- position: absolute;
- top: 0; left: 0; right: 0; bottom: 0;
- background: linear-gradient(to bottom, rgba(244,246,251,0.9), rgba(244,246,251,0.6));
- z-index: 1;
- }
- .hero-slide-1 {
- background-image: url('/static/images/hero/hero-slide-1.jpg');
- }
- .hero-slide-2 {
- background-image: url('/static/images/hero/hero-slide-2.jpg');
- }
- .hero-slide-3 {
- background-image: url('/static/images/hero/hero-slide-3.jpg');
- }
- .hero-content {
- position: relative;
- z-index: 2;
- max-width: 800px;
- margin: 0 auto;
- }
- .hero-title {
- font-size: 2.8rem;
- font-weight: 800;
- margin-bottom: 20px;
- color: var(--text);
- text-shadow: 0 2px 4px rgba(255,255,255,0.8);
- }
- .hero-desc {
- font-size: 1.25rem;
- color: var(--text-muted);
- margin-bottom: 40px;
- font-weight: 500;
- }
- @media (max-width: 768px) {
- .hero {
- padding: 60px 20px;
- min-height: 320px;
- }
- .hero-title {
- font-size: 2rem;
- }
- .hero-desc {
- font-size: 1.1rem;
- }
- .hero-toolbar {
- flex-direction: column;
- gap: 12px;
- }
- }
- .hero-toolbar {
- justify-content: center;
- gap: 20px;
- }
- .swiper-button-next, .swiper-button-prev {
- color: var(--brand) !important;
- background: rgba(255,255,255,0.8);
- width: 48px !important;
- height: 48px !important;
- border-radius: 50%;
- backdrop-filter: blur(4px);
- }
- .swiper-button-next:after, .swiper-button-prev:after {
- font-size: 20px !important;
- font-weight: bold;
- }
- .swiper-pagination-bullet-active {
- background: var(--brand) !important;
- }
- .toolbar {
- display: flex;
- gap: var(--space-2);
- align-items: center;
- flex-wrap: wrap;
- margin: var(--space-3) 0;
- }
- .toolbar-tight {
- margin: 0;
- }
- .input {
- padding: 10px 12px;
- border: 1px solid var(--border);
- border-radius: 10px;
- background: var(--bg);
- min-width: 0;
- color: var(--text);
- transition: border-color 160ms ease, box-shadow 160ms ease;
- }
- input.input,
- select.input {
- height: 40px;
- }
- textarea.input {
- padding: 12px 12px;
- min-height: 120px;
- resize: vertical;
- }
- .form {
- max-width: 480px;
- width: 100%;
- }
- .form .input {
- width: 100%;
- }
- .form input.input,
- .form select.input {
- height: 48px;
- padding: 0 16px;
- border-radius: 12px;
- font-size: 15px;
- }
- .form textarea.input {
- border-radius: 12px;
- font-size: 14px;
- }
- .modal .input {
- width: 100%;
- }
- .input::placeholder {
- color: rgba(85, 99, 122, 0.88);
- opacity: 1;
- }
- .page-header .input::placeholder {
- color: rgba(255, 255, 255, 0.85);
- }
- .input:focus {
- outline: none;
- border-color: rgba(10, 102, 255, 0.45);
- box-shadow: var(--ring);
- }
- .btn, a.btn {
- padding: 10px 14px;
- border: 1px solid var(--border);
- border-radius: 10px;
- background: var(--bg2);
- color: var(--text);
- text-decoration: none;
- cursor: pointer;
- font-weight: 650;
- transition: transform 120ms ease, box-shadow 160ms ease, background 160ms ease, border-color 160ms ease, color 160ms ease;
- display: inline-flex;
- align-items: center;
- justify-content: center;
- }
- .btn[disabled], a.btn[disabled] {
- cursor: not-allowed;
- opacity: 0.6;
- }
- .btn:hover, a.btn:hover {
- background: #eef1f6;
- transform: translateY(-1px);
- color: var(--text);
- text-decoration: none;
- }
- .btn-primary, a.btn-primary {
- border-color: transparent;
- background: linear-gradient(180deg, #1a73ff 0%, var(--brand) 100%);
- color: #fff;
- text-decoration: none;
- box-shadow: 0 6px 16px rgba(10, 102, 255, 0.22);
- }
- .btn-primary:hover, a.btn-primary:hover {
- background: linear-gradient(180deg, #1468f0 0%, var(--brand-600) 100%);
- color: #fff;
- text-decoration: none;
- box-shadow: 0 10px 22px rgba(10, 102, 255, 0.26);
- }
- .btn-ghost, a.btn-ghost {
- background: transparent;
- border-color: transparent;
- color: var(--brand);
- text-decoration: none;
- }
- .btn-ghost:hover, a.btn-ghost:hover {
- background: rgba(10, 102, 255, 0.05);
- color: var(--brand);
- text-decoration: none;
- }
- .btn-danger, a.btn-danger {
- border-color: transparent;
- background: linear-gradient(180deg, #fa5252 0%, var(--danger) 100%);
- color: #fff;
- text-decoration: none;
- box-shadow: 0 6px 16px rgba(224, 49, 49, 0.22);
- }
- .btn-danger:hover, a.btn-danger:hover {
- background: linear-gradient(180deg, #f03e3e 0%, #c92a2a 100%);
- color: #fff;
- text-decoration: none;
- box-shadow: 0 10px 22px rgba(224, 49, 49, 0.26);
- }
- .btn-block {
- width: 100%;
- }
- .btn-lg {
- padding: 14px 24px;
- font-size: 1.1rem;
- border-radius: 12px;
- }
- .btn-sm, a.btn-sm {
- padding: 6px 10px;
- border-radius: 8px;
- font-size: 13px;
- }
- .btn-toggle.active {
- border-color: rgba(10, 102, 255, 0.35);
- background: rgba(10, 102, 255, 0.08);
- color: var(--brand);
- }
- .btn-group {
- display: inline-flex;
- gap: var(--space-2);
- align-items: center;
- flex-wrap: wrap;
- }
- .segmented {
- display: inline-flex;
- padding: 4px;
- gap: 4px;
- border: 1px solid var(--border);
- border-radius: 12px;
- background: var(--bg2);
- flex-wrap: wrap;
- }
- .segmented.nowrap {
- flex-wrap: nowrap;
- overflow-x: auto;
- }
- .segmented.nowrap .btn {
- white-space: nowrap;
- flex: 0 0 auto;
- }
- .segmented .btn {
- border-radius: 10px;
- }
- .segmented .btn.active {
- border-color: rgba(10, 102, 255, 0.35);
- background: rgba(10, 102, 255, 0.08);
- color: var(--brand);
- }
- .input.is-invalid,
- .modal .input.is-invalid {
- border-color: rgba(224, 49, 49, 0.7);
- box-shadow: 0 0 0 4px rgba(224, 49, 49, 0.12);
- }
- .segmented.is-invalid {
- border-color: rgba(224, 49, 49, 0.7);
- box-shadow: 0 0 0 4px rgba(224, 49, 49, 0.12);
- }
- .help {
- margin-top: 8px;
- color: rgba(85, 99, 122, 0.92);
- font-size: 13px;
- line-height: 1.35;
- }
- .checkbox-row {
- display: flex;
- gap: 8px;
- align-items: center;
- margin-top: 8px;
- }
- .collapse {
- border: 1px solid var(--border);
- background: var(--bg);
- border-radius: 12px;
- overflow: hidden;
- }
- .collapse + .collapse {
- margin-top: var(--space-3);
- }
- .collapse-head {
- display: flex;
- align-items: center;
- justify-content: space-between;
- width: 100%;
- padding: 12px 12px;
- background: var(--bg2);
- border: 0;
- cursor: pointer;
- font-weight: 750;
- text-align: left;
- }
- .collapse-body {
- padding: 12px;
- }
- .collapse[data-open="0"] .collapse-body {
- display: none;
- }
- .collapse-icon {
- transition: transform 160ms ease;
- }
- .collapse[data-open="0"] .collapse-icon {
- transform: rotate(-90deg);
- }
- .form-section {
- border: 1px solid var(--border);
- background: var(--bg);
- border-radius: 12px;
- padding: var(--space-3);
- }
- .form-section-title {
- font-weight: 700;
- margin: 0 0 var(--space-2);
- }
- .form-grid {
- display: grid;
- grid-template-columns: repeat(2, minmax(0, 1fr));
- gap: var(--space-3);
- }
- .form-grid .label {
- margin-top: 0;
- }
- .form-grid .input {
- min-width: 0;
- width: 100%;
- }
- .md-editor {
- border: 1px solid var(--border);
- border-radius: 12px;
- overflow: hidden;
- background: var(--bg);
- }
- .md-editor-toolbar {
- padding: 10px;
- background: var(--bg2);
- border-bottom: 1px solid var(--border);
- }
- .md-editor-body {
- display: grid;
- grid-template-columns: 1fr;
- gap: var(--space-3);
- padding: 12px;
- }
- .md-editor-preview {
- border: 1px solid var(--border);
- border-radius: 10px;
- padding: 12px;
- background: var(--bg);
- min-height: 220px;
- }
- .md-toc {
- border: 1px solid var(--border);
- background: var(--bg2);
- border-radius: 10px;
- padding: 10px 12px;
- margin-bottom: 10px;
- }
- .md-toc-title {
- font-weight: 750;
- margin-bottom: 6px;
- display: flex;
- align-items: center;
- justify-content: space-between;
- }
- .md-toc-items {
- display: grid;
- gap: 6px;
- }
- .md-toc-item {
- display: inline-flex;
- align-items: center;
- gap: 8px;
- padding: 6px 8px;
- border-radius: 10px;
- border: 1px solid transparent;
- background: transparent;
- cursor: pointer;
- color: var(--text);
- text-align: left;
- }
- .md-toc-item:hover {
- border-color: rgba(10, 102, 255, 0.18);
- background: rgba(10, 102, 255, 0.06);
- }
- .md-editor[data-view="edit"] .md-editor-preview {
- display: none;
- }
- .md-editor[data-view="preview"] .md-editor-input {
- display: none;
- }
- .md-editor[data-view="split"] .md-editor-body {
- grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
- }
- @media (max-width: 720px) {
- .md-editor[data-view="split"] .md-editor-body {
- grid-template-columns: 1fr;
- }
- }
- @media (max-width: 720px) {
- .form-grid {
- grid-template-columns: 1fr;
- }
- }
- .form-msg {
- padding: 10px 12px;
- border-radius: 12px;
- border: 1px solid var(--border);
- background: var(--bg2);
- margin-top: var(--space-2);
- white-space: pre-wrap;
- word-break: break-word;
- }
- .toast-error {
- position: fixed;
- left: 16px;
- right: 16px;
- bottom: 16px;
- z-index: 100;
- max-width: 560px;
- margin: 0 auto;
- padding: 12px 14px;
- border-radius: 14px;
- border: 1px solid rgba(224, 49, 49, 0.25);
- background: rgba(224, 49, 49, 0.06);
- color: var(--danger);
- box-shadow: var(--shadow);
- }
- .toast-success {
- position: fixed;
- left: 16px;
- right: 16px;
- bottom: 16px;
- z-index: 100;
- max-width: 560px;
- margin: 0 auto;
- padding: 12px 14px;
- border-radius: 14px;
- border: 1px solid rgba(47, 158, 68, 0.25);
- background: rgba(47, 158, 68, 0.06);
- color: var(--success);
- box-shadow: var(--shadow);
- }
- .section-label {
- margin-top: 16px;
- }
- .grid {
- display: grid;
- grid-template-columns: repeat(3, minmax(0, 1fr));
- gap: var(--space-4);
- }
- @media (max-width: 980px) {
- .grid {
- grid-template-columns: repeat(2, minmax(0, 1fr));
- }
- }
- @media (max-width: 768px) {
- .topbar-inner {
- flex-direction: column;
- height: auto;
- padding: 12px 0;
- gap: 12px;
- }
- .nav {
- width: 100%;
- justify-content: center;
- flex-wrap: wrap;
- gap: 12px;
- }
- .nav-group {
- justify-content: center;
- }
- .brand {
- margin-right: 0;
- }
- }
- @media (max-width: 640px) {
- .grid {
- grid-template-columns: 1fr;
- }
- }
- .card {
- border: 1px solid var(--border);
- border-radius: var(--radius);
- padding: var(--space-4);
- background: var(--bg);
- box-shadow: var(--shadow);
- transition: transform 140ms ease, box-shadow 160ms ease, border-color 160ms ease;
- }
- .card:hover {
- transform: translateY(-1px);
- box-shadow: var(--shadow-lg);
- border-color: rgba(10, 102, 255, 0.18);
- }
- body[data-page="admin"] .card:hover,
- body[data-page="admin_login"] .card:hover {
- transform: none;
- box-shadow: var(--shadow);
- border-color: var(--border);
- }
- .skeleton {
- background: linear-gradient(90deg, rgba(0,0,0,0.06) 0%, rgba(0,0,0,0.03) 20%, rgba(0,0,0,0.06) 40%);
- background-size: 200% 100%;
- animation: shimmer 1.2s ease-in-out infinite;
- }
- .skeleton-line {
- height: 14px;
- border-radius: 10px;
- margin: 10px 0;
- }
- .skeleton-pill {
- height: 18px;
- width: 88px;
- border-radius: 999px;
- }
- @keyframes shimmer {
- 0% { background-position: 200% 0; }
- 100% { background-position: -200% 0; }
- }
- .card h3 {
- margin: 0 0 var(--space-2);
- font-size: 18px;
- }
- .muted {
- color: var(--muted);
- }
- .list {
- display: grid;
- gap: var(--space-3);
- }
- .label {
- display: block;
- margin: 10px 0 6px;
- color: var(--muted);
- }
- .split {
- display: grid;
- grid-template-columns: 320px 1fr;
- gap: var(--space-4);
- }
- @media (max-width: 1000px) {
- .split {
- grid-template-columns: 1fr;
- }
- }
- .me-info-grid {
- display: grid;
- gap: 12px;
- }
- .me-info-row {
- display: grid;
- grid-template-columns: 120px 1fr;
- align-items: center;
- gap: 16px;
- padding: 12px 14px;
- border: 1px solid var(--border);
- border-radius: 12px;
- background: var(--bg2);
- }
- .me-info-label {
- display: inline-flex;
- align-items: center;
- gap: 8px;
- color: var(--muted);
- font-size: 0.95rem;
- }
- .me-info-label i {
- color: var(--muted);
- }
- .me-info-value {
- display: flex;
- align-items: center;
- gap: 10px;
- min-width: 0;
- font-weight: 600;
- }
- @media (max-width: 640px) {
- .me-info-row {
- grid-template-columns: 1fr;
- gap: 8px;
- }
- .me-info-value {
- font-weight: 550;
- }
- }
- .code {
- white-space: pre-wrap;
- border: 1px solid var(--border);
- border-radius: var(--radius);
- padding: var(--space-4);
- background: var(--bg2);
- min-height: 300px;
- overflow: auto;
- }
- .pager {
- display: flex;
- gap: var(--space-2);
- align-items: center;
- margin-top: var(--space-3);
- }
- .admin-layout .pager {
- justify-content: flex-end;
- }
- .breadcrumb {
- display: flex;
- gap: var(--space-2);
- flex-wrap: wrap;
- margin: var(--space-2) 0 var(--space-3);
- }
- .breadcrumb a {
- color: var(--muted);
- text-decoration: none;
- }
- .badge {
- display: inline-flex;
- align-items: center;
- padding: 2px 8px;
- border-radius: 999px;
- font-size: 12px;
- line-height: 18px;
- border: 1px solid var(--border);
- color: var(--muted);
- background: var(--bg2);
- }
- .badge-free {
- color: var(--success);
- border-color: rgba(47, 158, 68, 0.25);
- background: rgba(47, 158, 68, 0.06);
- }
- .badge-vip {
- color: #b45309;
- border-color: rgba(180, 83, 9, 0.25);
- background: rgba(180, 83, 9, 0.08);
- }
- .badge-success {
- color: var(--success);
- border-color: rgba(47, 158, 68, 0.25);
- background: rgba(47, 158, 68, 0.06);
- }
- .badge-danger {
- color: var(--danger);
- border-color: rgba(224, 49, 49, 0.25);
- background: rgba(224, 49, 49, 0.06);
- }
- .badge-warning {
- color: var(--warning);
- border-color: rgba(240, 140, 0, 0.25);
- background: rgba(240, 140, 0, 0.08);
- }
- .badge-info {
- color: var(--brand);
- border-color: rgba(10, 102, 255, 0.25);
- background: rgba(10, 102, 255, 0.06);
- }
- .table {
- width: 100%;
- min-width: 800px;
- border-collapse: separate;
- border-spacing: 0;
- table-layout: fixed;
- }
- .table th, .table td {
- padding: 10px 12px;
- border-bottom: 1px solid var(--border);
- text-align: left;
- vertical-align: top;
- white-space: nowrap;
- overflow: hidden;
- text-overflow: ellipsis;
- }
- .table td.table-empty {
- padding: 18px 12px;
- text-align: center;
- white-space: normal;
- }
- .table thead th {
- background: var(--bg2);
- color: var(--muted);
- font-weight: 600;
- position: sticky;
- top: 0;
- z-index: 1;
- }
- .table tbody tr {
- transition: background 160ms ease;
- }
- .table tbody tr:nth-child(even) {
- background: #fbfcfe;
- }
- .table tbody tr:hover {
- background: #f1f5f9;
- }
- .kpis {
- display: grid;
- grid-template-columns: repeat(4, minmax(0, 1fr));
- gap: var(--space-4);
- }
- .kpi {
- border: 1px solid var(--border);
- border-radius: var(--radius);
- padding: var(--space-4);
- background: var(--bg);
- box-shadow: var(--shadow);
- }
- .admin-layout {
- display: grid;
- grid-template-columns: 220px 1fr;
- gap: var(--space-4);
- }
- .table-wrap {
- width: 100%;
- overflow-x: auto;
- overflow-y: auto;
- border: 1px solid var(--border);
- border-radius: var(--radius);
- background: var(--bg);
- box-shadow: var(--shadow);
- }
- .sider {
- border: 1px solid var(--border);
- border-radius: var(--radius);
- background: var(--bg);
- padding: var(--space-4);
- height: fit-content;
- position: sticky;
- top: 80px;
- }
- @media (max-width: 980px) {
- .kpis {
- grid-template-columns: repeat(2, minmax(0, 1fr));
- }
- .admin-layout {
- grid-template-columns: 1fr;
- }
- .sider {
- position: static;
- top: 0;
- }
- }
- @media (max-width: 640px) {
- .kpis {
- grid-template-columns: 1fr;
- }
- }
- .sider-title {
- font-weight: 700;
- margin-bottom: var(--space-3);
- }
- .menu {
- display: grid;
- gap: var(--space-2);
- }
- .menu-item {
- display: block;
- text-decoration: none;
- color: var(--text);
- padding: 10px 12px;
- border-radius: 10px;
- }
- .menu-item:hover {
- background: var(--bg2);
- }
- .menu-item.active {
- background: #eef4ff;
- color: var(--brand);
- }
- .sider-footer {
- margin-top: var(--space-4);
- }
- .content {
- min-height: 60vh;
- }
- body[data-page="admin"] .content {
- min-height: 0;
- }
- body[data-page="admin"] .footer {
- display: none;
- }
- .admin-layout .content-section {
- border: 1px solid var(--border);
- border-radius: var(--radius);
- background: var(--bg);
- box-shadow: var(--shadow);
- padding: var(--space-4);
- }
- .admin-layout .content-section .toolbar {
- margin: 0 0 var(--space-3);
- }
- .admin-layout .content-section .table-wrap {
- box-shadow: none;
- }
- .admin-layout .content-section .card {
- box-shadow: none;
- }
- .admin-layout .metric-card {
- display: flex;
- flex-direction: column;
- gap: 6px;
- min-height: 96px;
- }
- .admin-layout .metric-label {
- font-size: 13px;
- }
- .admin-layout .metric-value {
- font-size: 28px;
- font-weight: 800;
- letter-spacing: -0.4px;
- }
- .admin-layout .metric-sub {
- font-size: 13px;
- }
- .admin-layout .settings-card {
- padding: var(--space-4);
- }
- .admin-layout .settings-toolbar {
- gap: var(--space-2);
- }
- .admin-layout .settings-search {
- flex: 1;
- min-width: 220px;
- }
- .admin-layout .settings-nav {
- width: 100%;
- }
- .admin-layout .settings-nav .btn {
- white-space: nowrap;
- }
- .admin-layout #settingsGroups.is-tabs .settings-group {
- display: none;
- }
- .admin-layout #settingsGroups.is-tabs .settings-group.is-active {
- display: block;
- }
- .admin-layout .collapse-head-left {
- display: flex;
- flex-direction: column;
- gap: 2px;
- min-width: 0;
- }
- .admin-layout .settings-group-title {
- font-weight: 800;
- }
- .admin-layout .settings-group-desc {
- font-weight: 550;
- font-size: 13px;
- overflow: hidden;
- text-overflow: ellipsis;
- white-space: nowrap;
- }
- .admin-layout .settings-group .collapse-head {
- gap: 10px;
- }
- .admin-layout .settings-checkbox {
- margin-top: 6px;
- }
- .admin-layout .settings-group-toolbar {
- margin: 0 0 var(--space-3);
- justify-content: flex-end;
- gap: var(--space-2);
- }
- .secret-textarea {
- font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
- -webkit-text-security: disc;
- }
- .secret-textarea.is-revealed {
- -webkit-text-security: none;
- }
- .table td.td-actions {
- white-space: nowrap;
- overflow: visible;
- }
- .td-actions .btn-group {
- justify-content: flex-end;
- flex-wrap: nowrap;
- }
- .admin-layout #userTable {
- min-width: 0;
- }
- .admin-layout #userTable td.td-actions {
- white-space: nowrap;
- }
- .admin-layout #userTable .td-actions .btn-group {
- flex-wrap: nowrap;
- }
- .admin-layout .table td .btn,
- .modal .table td .btn {
- padding: 6px 10px;
- border-radius: 8px;
- font-size: 13px;
- }
- .upload-thumb {
- width: 56px;
- height: 40px;
- object-fit: cover;
- border-radius: 10px;
- border: 1px solid var(--border);
- background: var(--bg2);
- }
- .upload-name {
- font-weight: 600;
- word-break: break-all;
- }
- .upload-url {
- font-size: 12px;
- word-break: break-all;
- }
- .auth-card {
- max-width: 520px;
- margin: 0 auto;
- }
- .auth-card-title {
- margin: 0 0 var(--space-3);
- font-size: 20px;
- }
- .auth-card-form {
- max-width: none;
- }
- .auth-card-actions {
- margin: var(--space-3) 0 0;
- }
- .auth-card-msg {
- margin-top: var(--space-2);
- }
- .content-header {
- display: flex;
- align-items: center;
- justify-content: space-between;
- margin-bottom: var(--space-3);
- }
- .md {
- color: var(--text);
- }
- .md h1, .md h2, .md h3 {
- margin: 0 0 var(--space-2);
- }
- .md p {
- margin: 0 0 var(--space-3);
- color: var(--text);
- }
- .md code {
- background: var(--bg2);
- border: 1px solid var(--border);
- border-radius: 8px;
- padding: 2px 6px;
- }
- .md .code code {
- background: transparent;
- border: none;
- padding: 0;
- }
- .md-img, .md-video {
- display: block;
- max-width: 100%;
- border-radius: 12px;
- border: 1px solid var(--border);
- background: var(--bg2);
- margin: var(--space-2) 0 var(--space-3);
- }
- .resource-card-cover {
- border-radius: 12px;
- border: 1px solid var(--border);
- background: var(--bg2);
- overflow: hidden;
- aspect-ratio: 16 / 9;
- margin-bottom: var(--space-3);
- }
- .resource-card-cover-img {
- width: 100%;
- height: 100%;
- object-fit: cover;
- display: block;
- }
- .resource-card-tags {
- display: flex;
- gap: var(--space-2);
- flex-wrap: wrap;
- margin: var(--space-2) 0 var(--space-2);
- }
- .resource-detail-head {
- display: flex;
- gap: var(--space-4);
- align-items: flex-start;
- flex-wrap: wrap;
- }
- .resource-detail-cover {
- width: min(280px, 100%);
- border-radius: 12px;
- border: 1px solid var(--border);
- background: var(--bg2);
- object-fit: cover;
- }
- .cover-picker-img {
- cursor: pointer;
- aspect-ratio: 16 / 9;
- }
- .cover-picker-img:hover {
- border-color: rgba(10, 102, 255, 0.35);
- box-shadow: 0 0 0 4px rgba(10, 102, 255, 0.12);
- }
- .cover-picker-img.is-placeholder {
- object-fit: contain;
- padding: 18px;
- }
- .resource-detail-meta {
- flex: 1 1 360px;
- min-width: 0;
- }
- .resource-detail-meta h1 {
- margin: 0 0 var(--space-2);
- }
- .resource-browser {
- padding-top: 0;
- }
- .resource-browser-toolbar {
- position: sticky;
- top: 0;
- z-index: 10;
- padding: var(--space-2);
- border: 1px solid var(--border);
- border-radius: 14px;
- background: rgba(255,255,255,0.92);
- backdrop-filter: blur(8px) saturate(140%);
- box-shadow: 0 6px 16px rgba(16, 24, 40, 0.08);
- }
- .resource-browser #tree .card {
- padding: 12px 16px;
- border-radius: 8px;
- display: flex;
- justify-content: space-between;
- align-items: center;
- gap: 12px;
- transition: background-color 0.2s ease 0s, border-color 0.2s ease 0s, transform 0.2s ease 0s;
- border: 1px solid transparent;
- cursor: pointer;
- height: 40px;
- box-shadow: none;
- }
- .resource-browser #tree.list {
- display: flex;
- flex-direction: column;
- gap: 8px;
- }
- .resource-browser #tree .card > div {
- min-width: 0;
- white-space: nowrap;
- }
- .resource-browser #tree .card > div:first-child {
- overflow: hidden;
- text-overflow: ellipsis;
- }
- .resource-browser #tree .card > .muted {
- max-width: 52%;
- overflow: hidden;
- text-overflow: ellipsis;
- text-align: right;
- }
- .resource-browser #tree .card:hover {
- transform: translateY(-1px);
- background-color: rgba(14, 165, 233, 0.05);
- border-color: rgba(14, 165, 233, 0.2);
- }
- .resource-browser #tree .card.is-locked {
- opacity: 0.7;
- }
- .resource-browser #tree .card.is-locked:hover {
- transform: none;
- }
- .resource-browser .split {
- height: 500px;
- max-height: 500px;
- overflow: hidden;
- }
- .resource-browser .split > div {
- min-width: 0;
- min-height: 0;
- display: flex;
- flex-direction: column;
- overflow: hidden;
- }
- .resource-browser #tree {
- flex: 1 1 auto;
- min-height: 0;
- overflow-y: auto;
- overflow-x: hidden;
- -webkit-overflow-scrolling: touch;
- }
- .resource-browser #fileContent {
- flex: 1 1 auto;
- min-height: 0;
- overflow-y: auto;
- overflow-x: hidden;
- -webkit-overflow-scrolling: touch;
- white-space: pre-wrap;
- overflow-wrap: anywhere;
- word-break: break-word;
- }
- .resource-browser #tree,
- .resource-browser #fileContent {
- scrollbar-width: thin;
- scrollbar-color: rgba(16, 24, 40, 0.28) transparent;
- }
- .resource-browser #tree::-webkit-scrollbar,
- .resource-browser #fileContent::-webkit-scrollbar {
- width: 10px;
- }
- .resource-browser #tree::-webkit-scrollbar-track,
- .resource-browser #fileContent::-webkit-scrollbar-track {
- background: transparent;
- }
- .resource-browser #tree::-webkit-scrollbar-thumb,
- .resource-browser #fileContent::-webkit-scrollbar-thumb {
- background: rgba(16, 24, 40, 0.28);
- border-radius: 999px;
- border: 3px solid transparent;
- background-clip: padding-box;
- }
- .resource-browser #tree:hover::-webkit-scrollbar-thumb,
- .resource-browser #fileContent:hover::-webkit-scrollbar-thumb {
- background: rgba(16, 24, 40, 0.38);
- border: 3px solid transparent;
- background-clip: padding-box;
- }
- @media (max-width: 1000px) {
- .resource-browser .split {
- height: auto;
- max-height: none;
- overflow: visible;
- }
- }
- .resource-browser .code {
- font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
- font-size: 13px;
- line-height: 1.6;
- }
- .toolbar .input {
- min-width: 160px;
- }
- @media (max-width: 1000px) {
- .admin-layout {
- grid-template-columns: 1fr;
- }
- .sider {
- position: static;
- top: auto;
- }
- .toolbar .input {
- flex: 1;
- min-width: 0;
- }
- }
- .modal {
- max-height: 80vh;
- }
- #adminModalBody {
- max-height: 60vh;
- overflow: auto;
- }
- .modal-backdrop {
- position: fixed;
- inset: 0;
- background: rgba(18, 24, 40, 0.6);
- backdrop-filter: blur(4px);
- display: grid;
- place-items: center;
- padding: var(--space-4);
- z-index: 1000;
- animation: fadeIn 0.2s ease-out;
- }
- @keyframes fadeIn {
- from { opacity: 0; }
- to { opacity: 1; }
- }
- @keyframes slideUp {
- from { transform: translateY(20px); opacity: 0; }
- to { transform: translateY(0); opacity: 1; }
- }
- .modal {
- width: min(720px, 100%);
- border: 1px solid rgba(255,255,255,0.8);
- border-radius: 20px;
- background: var(--bg);
- box-shadow: 0 20px 40px rgba(16, 24, 40, 0.2);
- padding: 32px;
- max-height: 85vh;
- display: flex;
- flex-direction: column;
- animation: slideUp 0.3s cubic-bezier(0.16, 1, 0.3, 1);
- }
- .modal[data-size="sm"] {
- width: min(640px, 100%);
- }
- .modal[data-size="lg"] {
- width: min(1180px, 100%);
- }
- .modal .table-wrap {
- box-shadow: none;
- }
- .modal-header {
- display: flex;
- align-items: center;
- justify-content: space-between;
- gap: var(--space-2);
- margin-bottom: 24px;
- padding-bottom: 16px;
- border-bottom: 1px solid var(--border);
- }
- .modal-header-right {
- display: flex;
- align-items: center;
- gap: var(--space-2);
- }
- .modal-title {
- font-weight: 700;
- font-size: 1.25rem;
- color: var(--text);
- display: flex;
- align-items: center;
- }
- .modal-title i {
- color: var(--brand);
- margin-right: 8px;
- }
- #adminModalBody, #repoModalBody {
- overflow: auto;
- flex: 1 1 auto;
- padding-right: 8px; /* for scrollbar */
- }
- /* Custom scrollbar for modal body */
- #adminModalBody::-webkit-scrollbar, #repoModalBody::-webkit-scrollbar {
- width: 6px;
- }
- #adminModalBody::-webkit-scrollbar-thumb, #repoModalBody::-webkit-scrollbar-thumb {
- background: #cbd5e1;
- border-radius: 4px;
- }
- .modal-footer {
- display: flex;
- justify-content: flex-end;
- gap: 12px;
- margin-top: 24px;
- padding-top: 16px;
- border-top: 1px solid var(--border);
- }
- .res-form-layout {
- display: grid;
- grid-template-columns: 1fr;
- gap: var(--space-3);
- }
- .modal[data-size="lg"] .res-form-layout {
- grid-template-columns: 360px minmax(0, 1fr);
- align-items: start;
- }
- .res-form-side,
- .res-form-main {
- min-width: 0;
- }
- .res-form-side {
- display: flex;
- flex-direction: column;
- gap: var(--space-3);
- }
- .collapse + .collapse {
- margin-top: 0;
- }
- .modal[data-size="sm"] .md-editor[data-view="split"] .md-editor-body {
- grid-template-columns: 1fr;
- }
|