.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(ellipse 60% 40% at 50% 0%,rgba(147,51,234,.15),transparent),radial-gradient(ellipse 40% 30% at 80% 80%,rgba(59,130,246,.1),transparent),var(--bg-primary)}.login-card{width:100%;max-width:420px;display:flex;flex-direction:column;gap:16px;box-shadow:var(--shadow-card),var(--shadow-glow)}.login-card h1{text-align:center;font-size:26px;font-weight:700;margin-bottom:8px}.login-totp{letter-spacing:.2em;font-variant-numeric:tabular-nums;text-align:center}.login-totp-hint{font-size:12px;line-height:1.5;margin-top:-4px}.login-step-desc{text-align:center;font-size:14px;line-height:1.6}.login-step-desc strong{color:var(--text-primary)}.login-back-btn{width:100%;padding:10px;background:none;border:1px solid var(--border);border-radius:10px;color:var(--text-muted);font-size:14px;cursor:pointer;transition:border-color .2s ease,color .2s ease}.login-back-btn:hover:not(:disabled){border-color:var(--border-accent);color:var(--text-primary)}.login-back-btn:disabled{opacity:.6;cursor:not-allowed}.login-card input{margin-top:4px}.login-card .btn-primary{margin-top:8px;width:100%;padding:12px 24px;font-size:15px}.error{color:var(--danger);text-align:center;font-size:14px;padding:10px;border-radius:10px;background:#f8717114;border:1px solid rgba(248,113,113,.2)}.dashboard{display:flex;flex-direction:column;gap:24px}.dashboard-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.dashboard-header h2{font-size:26px;font-weight:700;margin-bottom:6px;letter-spacing:-.02em}.dashboard-header__badge{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:999px;border:1px solid var(--border);background:var(--bg-elevated);font-size:13px;color:var(--text-secondary);white-space:nowrap}.pulse-dot{width:8px;height:8px;border-radius:50%;background:var(--success);box-shadow:0 0 #4ade8099;animation:pulse 2s infinite}@keyframes pulse{0%{box-shadow:0 0 #4ade8080}70%{box-shadow:0 0 0 8px #4ade8000}to{box-shadow:0 0 #4ade8000}}.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;min-height:320px;color:var(--text-muted)}.dashboard-loading__spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.dashboard-error h3{margin-bottom:8px}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.stat-card{position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;opacity:.08;pointer-events:none;transition:opacity .3s ease}.stat-card:hover:before{opacity:.14}.stat-card--blue:before{background:linear-gradient(135deg,#3b82f6,transparent 70%)}.stat-card--purple:before{background:linear-gradient(135deg,#a855f7,transparent 70%)}.stat-card--pink:before{background:linear-gradient(135deg,#ec4899,transparent 70%)}.stat-card--cyan:before{background:linear-gradient(135deg,#00d4ff,transparent 70%)}.stat-card--amber:before{background:linear-gradient(135deg,#f59e0b,transparent 70%)}.stat-card__top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.stat-card__label{color:var(--text-muted);font-size:13px}.stat-card__icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;background:var(--bg-elevated);border:1px solid var(--border);color:var(--accent-primary)}.stat-card__value{display:block;font-size:32px;font-weight:700;line-height:1.1;background:var(--gradient-text);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.stat-card__hint{display:block;margin-top:8px;font-size:12px;color:var(--text-dim)}.dash-grid{display:grid;gap:16px}.dash-grid--charts{grid-template-columns:repeat(3,1fr)}.dash-grid--bottom{grid-template-columns:1fr 2fr}.dash-panel__head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:20px}.dash-panel__head h3{font-size:16px;font-weight:600}.dash-panel__tag{font-size:12px;padding:4px 10px;border-radius:999px;background:var(--gradient-brand-soft);color:var(--text-secondary);border:1px solid var(--border)}.bar-chart{display:flex;flex-direction:column;gap:16px}.bar-chart__row{display:flex;flex-direction:column;gap:8px}.bar-chart__meta{display:flex;justify-content:space-between;font-size:13px}.bar-chart__label{color:var(--text-secondary)}.bar-chart__value{font-weight:600;color:var(--text-primary)}.bar-chart__track{height:10px;border-radius:999px;background:var(--bg-elevated);overflow:hidden}.bar-chart__fill{height:100%;border-radius:999px;transition:width .6s ease}.donut-chart{display:flex;flex-direction:column;align-items:center;gap:20px}.donut-chart--empty{display:flex;align-items:center;justify-content:center;border-radius:50%;border:2px dashed var(--border)}.donut-chart__total{fill:var(--text-primary);font-size:22px;font-weight:700}.donut-chart__label{fill:var(--text-muted);font-size:11px}.donut-legend{list-style:none;width:100%;display:flex;flex-direction:column;gap:10px}.donut-legend li{display:flex;align-items:center;gap:8px;font-size:13px}.donut-legend__dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.donut-legend__name{flex:1;color:var(--text-secondary)}.donut-legend__value{color:var(--text-muted);font-size:12px}.metric-bars{display:flex;flex-direction:column;gap:18px}.metric-bars__row{display:flex;flex-direction:column;gap:8px}.metric-bars__meta{display:flex;justify-content:space-between;font-size:13px}.metric-bars__meta strong{color:var(--accent-primary)}.metric-bars__track{height:8px;border-radius:999px;background:var(--bg-elevated);overflow:hidden}.metric-bars__fill{height:100%;border-radius:999px;transition:width .6s ease}.site-overview{display:flex;flex-direction:column;gap:12px}.site-overview__item{display:flex;align-items:center;gap:14px;padding:12px;border-radius:12px;background:var(--bg-elevated);border:1px solid var(--border);transition:border-color .2s ease}.site-overview__item:hover{border-color:var(--border-accent)}.site-overview__icon{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:16px;flex-shrink:0}.site-overview__info{flex:1;display:flex;flex-direction:column;gap:2px}.site-overview__name{font-weight:600;font-size:14px}.site-overview__key{font-size:12px;color:var(--text-dim)}.site-overview__stats{text-align:right}.site-overview__stats strong{display:block;font-size:20px;background:var(--gradient-text);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.site-overview__stats span{font-size:11px;color:var(--text-muted)}.table-wrap{overflow-x:auto}.data-table--styled tbody tr:hover{background:var(--bg-elevated)}.user-avatar{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;margin-right:10px;border-radius:50%;background:var(--gradient-brand);color:#fff;font-size:12px;font-weight:600;vertical-align:middle}@media(max-width:1200px){.dash-grid--charts{grid-template-columns:1fr 1fr}.dash-grid--charts .dash-panel:last-child{grid-column:1 / -1}}@media(max-width:900px){.stat-grid{grid-template-columns:repeat(2,1fr)}.dash-grid--charts,.dash-grid--bottom{grid-template-columns:1fr}.dashboard-header{flex-direction:column}}@media(max-width:480px){.stat-grid{grid-template-columns:1fr}}@media(prefers-reduced-motion:reduce){.pulse-dot,.dashboard-loading__spinner{animation:none}}.users-page{display:flex;flex-direction:column;gap:16px}.users-header h2{font-size:26px;font-weight:700;margin-bottom:6px}.users-toolbar{display:flex;flex-wrap:wrap;gap:12px;align-items:center}.users-toolbar input{flex:1;min-width:240px}.users-table{min-width:1100px}.user-type-badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:12px;font-weight:500}.user-type-badge--vip{background:#f59e0b26;color:#f59e0b;border:1px solid rgba(245,158,11,.35)}.user-type-badge--user{background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border)}.users-pagination{display:flex;align-items:center;gap:12px}.users-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:24px;z-index:100}.users-modal{width:100%;max-width:640px;max-height:90vh;overflow-y:auto}.users-modal__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.users-modal__head h3{font-size:18px}.users-modal__close{width:32px;height:32px;border:1px solid var(--border);border-radius:8px;background:var(--bg-elevated);color:var(--text-muted);font-size:20px;line-height:1;cursor:pointer}.users-form{display:flex;flex-direction:column;gap:16px}.users-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.users-form-grid--3{grid-template-columns:repeat(3,1fr)}.users-form-section h4{margin-bottom:8px;font-size:15px}.users-form-hint{font-size:13px;line-height:1.6;margin-bottom:12px}.users-checkbox{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text-secondary);margin-top:4px}.users-checkbox input{width:auto}.users-login-info{display:flex;flex-direction:column;gap:4px;font-size:13px;padding:12px;border-radius:10px;background:var(--bg-elevated);border:1px solid var(--border)}.users-error{color:var(--danger);font-size:14px;padding:10px 12px;border-radius:10px;background:#f8717114;border:1px solid rgba(248,113,113,.2)}.users-success{color:var(--success);font-size:14px;padding:10px 12px;border-radius:10px;background:#4ade8014;border:1px solid rgba(74,222,128,.2)}.users-form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:8px}@media(max-width:768px){.users-form-grid,.users-form-grid--3{grid-template-columns:1fr}}.conversations-page{display:flex;flex-direction:column;gap:20px}.conversations-header h2{font-size:26px;font-weight:700;margin-bottom:6px}.conversations-tabs{display:inline-flex;gap:8px;padding:4px;border-radius:12px;background:var(--bg-elevated);border:1px solid var(--border);width:fit-content}.conversations-tabs button{padding:10px 18px;border:none;border-radius:10px;background:transparent;color:var(--text-secondary);font-size:14px;cursor:pointer;transition:background .2s ease,color .2s ease}.conversations-tabs button.active{background:var(--gradient-brand-soft);color:var(--text-primary);border:1px solid var(--border-accent)}.conversations-panel{display:flex;flex-direction:column;gap:16px}.conversations-toolbar{display:flex;flex-wrap:wrap;gap:12px;align-items:center}.conversations-toolbar input{flex:1;min-width:200px}.conversations-toolbar select{width:auto;min-width:140px}.conversations-count{font-size:13px}.conversations-table .content-cell{max-width:360px}.content-preview{background:none;border:none;padding:0;color:var(--text-primary);text-align:left;cursor:pointer;font-size:14px;line-height:1.5}.content-preview:hover{color:var(--accent-primary)}.content-image-link{margin-left:8px;font-size:12px;color:var(--accent-primary)}.role-badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:12px}.role-badge--user{background:#3b82f61f;color:#60a5fa}.role-badge--assistant{background:#a855f71f;color:#c084fc}.content-detail-row td{background:var(--bg-elevated);border-bottom:1px solid var(--border)}.content-detail{white-space:pre-wrap;word-break:break-word;line-height:1.6;font-size:14px;color:var(--text-secondary)}.conversations-pagination{display:flex;align-items:center;gap:12px}.blocked-intro p{line-height:1.7;color:var(--text-secondary)}.blocked-intro strong{color:var(--accent-primary)}.blocked-form h3{margin-bottom:14px;font-size:16px}.blocked-form-row{display:flex;flex-wrap:wrap;gap:12px;align-items:center}.blocked-form-row input{flex:1;min-width:180px}.blocked-form-row select{width:auto;min-width:140px}.blocked-error{margin-top:10px;color:var(--danger);font-size:14px}.blocked-word{padding:4px 8px;border-radius:6px;background:var(--bg-elevated);border:1px solid var(--border);font-family:ui-monospace,monospace;font-size:13px}@media(max-width:768px){.conversations-toolbar,.blocked-form-row{flex-direction:column;align-items:stretch}}.profile-page{display:flex;flex-direction:column;gap:24px}.profile-header h2{font-size:26px;font-weight:700;margin-bottom:6px}.profile-grid{display:grid;grid-template-columns:320px 1fr;gap:20px;align-items:start}.profile-stack{display:flex;flex-direction:column;gap:20px}.profile-alert{padding:14px 18px;border-radius:12px;border:1px solid rgba(245,158,11,.35);background:#f59e0b14;color:var(--text-secondary)}.profile-alert strong{display:block;color:var(--text-primary);margin-bottom:4px}.text-success{color:var(--success)!important}.text-warning{color:#f59e0b!important}.totp-status{display:flex;gap:14px;align-items:flex-start;padding:16px;border-radius:12px;border:1px solid var(--border);background:var(--bg-elevated)}.totp-status--enabled{border-color:#4ade8059;background:#4ade800f}.totp-status__icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--success);color:#fff;font-weight:700;flex-shrink:0}.totp-setup{display:flex;flex-direction:column;gap:16px}.totp-setup__qr{display:flex;justify-content:center}.totp-setup__qr img{border-radius:12px;border:1px solid var(--border);background:#fff;padding:8px}.totp-setup__secret{font-size:13px;word-break:break-all}.totp-setup__secret code{display:inline-block;margin-top:6px;padding:6px 10px;border-radius:8px;background:var(--bg-elevated);border:1px solid var(--border);font-family:ui-monospace,monospace;font-size:12px;color:var(--text-primary)}.totp-setup__actions{display:flex;gap:12px;align-items:center}.profile-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:32px 24px}.profile-avatar{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;color:#fff;background:var(--gradient-brand);margin-bottom:16px;box-shadow:0 8px 24px #9333ea40}.profile-card h3{font-size:20px;margin-bottom:4px}.profile-role{display:inline-block;margin-bottom:24px;padding:4px 12px;border-radius:999px;font-size:12px;color:var(--accent-primary);background:var(--gradient-brand-soft);border:1px solid var(--border)}.profile-meta{list-style:none;width:100%;display:flex;flex-direction:column;gap:12px}.profile-meta li{display:flex;justify-content:space-between;gap:12px;padding:12px 14px;border-radius:10px;background:var(--bg-elevated);border:1px solid var(--border);font-size:13px}.profile-meta span{color:var(--text-muted)}.profile-meta strong{color:var(--text-primary);font-weight:500;text-align:right;word-break:break-all}.profile-form-card h3{font-size:18px;margin-bottom:6px}.profile-form-desc{margin-bottom:24px}.profile-form{max-width:420px;display:flex;flex-direction:column;gap:4px}.profile-error{color:var(--danger);font-size:14px;padding:10px 12px;border-radius:10px;background:#f8717114;border:1px solid rgba(248,113,113,.2);margin-top:8px}.profile-success{color:var(--success);font-size:14px;padding:10px 12px;border-radius:10px;background:#4ade8014;border:1px solid rgba(74,222,128,.2);margin-top:8px}.profile-form .btn-primary{margin-top:16px;align-self:flex-start;min-width:140px}@media(max-width:900px){.profile-grid{grid-template-columns:1fr}}:root,[data-theme=dark]{color-scheme:dark;--bg-primary: #000000;--bg-secondary: rgba(255, 255, 255, .05);--bg-elevated: rgba(255, 255, 255, .08);--bg-glass: rgba(255, 255, 255, .05);--bg-glass-hover: rgba(255, 255, 255, .08);--bg-card-inner: rgba(0, 0, 0, .9);--bg-sidebar: rgba(0, 0, 0, .85);--accent-primary: #60a5fa;--accent-purple: #a855f7;--accent-pink: #ec4899;--accent-cyan: #00d4ff;--gradient-brand: linear-gradient(90deg, #2563eb, #9333ea, #db2777);--gradient-brand-soft: linear-gradient(90deg, rgba(37, 99, 235, .15), rgba(147, 51, 234, .15), rgba(219, 39, 119, .15));--gradient-text: linear-gradient(90deg, #3b82f6, #a855f7, #ec4899);--text-primary: #ffffff;--text-secondary: #d1d5db;--text-muted: #9ca3af;--text-dim: #6b7280;--border: rgba(255, 255, 255, .1);--border-strong: rgba(255, 255, 255, .2);--border-accent: rgba(96, 165, 250, .35);--shadow-card: 0 25px 50px -12px rgba(0, 0, 0, .5);--shadow-glow: 0 0 40px rgba(147, 51, 234, .15);--chart-1: #3b82f6;--chart-2: #a855f7;--chart-3: #ec4899;--chart-4: #00d4ff;--chart-5: #f59e0b;--success: #4ade80;--danger: #f87171;--nav-active-bg: rgba(255, 255, 255, .08)}[data-theme=light]{color-scheme:light;--bg-primary: #f8fafc;--bg-secondary: #ffffff;--bg-elevated: #f1f5f9;--bg-glass: rgba(255, 255, 255, .85);--bg-glass-hover: #ffffff;--bg-card-inner: #ffffff;--bg-sidebar: #ffffff;--accent-primary: #2563eb;--accent-purple: #7c3aed;--accent-pink: #db2777;--accent-cyan: #0891b2;--gradient-brand: linear-gradient(90deg, #2563eb, #7c3aed, #db2777);--gradient-brand-soft: linear-gradient(90deg, rgba(37, 99, 235, .08), rgba(124, 58, 237, .08), rgba(219, 39, 119, .08));--gradient-text: linear-gradient(90deg, #2563eb, #7c3aed, #db2777);--text-primary: #0f172a;--text-secondary: #334155;--text-muted: #64748b;--text-dim: #94a3b8;--border: #e2e8f0;--border-strong: #cbd5e1;--border-accent: rgba(37, 99, 235, .35);--shadow-card: 0 10px 40px -10px rgba(15, 23, 42, .12);--shadow-glow: 0 0 40px rgba(124, 58, 237, .08);--chart-1: #2563eb;--chart-2: #7c3aed;--chart-3: #db2777;--chart-4: #0891b2;--chart-5: #d97706;--success: #16a34a;--danger: #dc2626;--nav-active-bg: rgba(37, 99, 235, .08)}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{min-height:100vh;overflow-x:hidden}body{font-family:PingFang SC,Microsoft YaHei,system-ui,sans-serif;background:var(--bg-primary);color:var(--text-primary);transition:background-color .3s ease,color .3s ease}a{color:inherit}.gradient-text{background:var(--gradient-text);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.card{background:var(--bg-glass);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:16px;padding:20px;box-shadow:var(--shadow-card);transition:background .3s ease,border-color .3s ease,box-shadow .3s ease}.card:hover{background:var(--bg-glass-hover)}.gradient-border-card{position:relative;padding:1px;border-radius:16px;background:linear-gradient(90deg,#3b82f680,#a855f780,#ec489980);overflow:hidden}.gradient-border-card>.card-inner{background:var(--bg-card-inner);border-radius:15px;padding:20px;height:100%}.btn-primary{padding:10px 24px;background:var(--gradient-brand);color:#fff;border:none;border-radius:12px;cursor:pointer;font-size:14px;font-weight:500;transition:transform .2s ease,box-shadow .2s ease,opacity .2s ease}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 25px #9333ea40}.btn-primary:disabled{opacity:.65;cursor:not-allowed}.btn-sm{padding:4px 12px;background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-primary);border-radius:8px;cursor:pointer;font-size:13px;transition:background .2s ease,border-color .2s ease}.btn-sm:hover{border-color:var(--border-accent)}.btn-sm.danger{color:var(--danger);border-color:#f8717159}.btn-sm.primary{color:var(--accent-primary);border-color:var(--border-accent)}input,textarea,select{width:100%;padding:10px 14px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:10px;color:var(--text-primary);font-size:14px;outline:none;transition:border-color .2s ease,box-shadow .2s ease}input:focus,textarea:focus,select:focus{border-color:var(--border-accent);box-shadow:0 0 0 3px #60a5fa26}.muted{color:var(--text-muted);font-size:14px}.theme-toggle{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px 14px;margin-bottom:8px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:10px;color:var(--text-secondary);cursor:pointer;font-size:13px;transition:background .2s ease,border-color .2s ease,color .2s ease}.theme-toggle:hover{border-color:var(--border-accent);color:var(--text-primary)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.admin-layout{display:flex;min-height:100vh;background:var(--bg-primary)}.admin-sidebar{width:240px;flex-shrink:0;background:var(--bg-sidebar);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-right:1px solid var(--border);padding:24px 16px;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;box-shadow:var(--shadow-glow)}.admin-sidebar__brand{margin-bottom:28px;padding:0 6px}.admin-sidebar h1{font-size:20px;font-weight:700;letter-spacing:-.02em}.admin-sidebar__subtitle{margin-top:4px;font-size:12px;color:var(--text-dim)}.admin-sidebar nav{flex:1;display:flex;flex-direction:column;gap:4px}.admin-sidebar nav a{color:var(--text-secondary);padding:11px 14px;border-radius:10px;font-size:14px;text-decoration:none;transition:background .2s ease,color .2s ease;border:1px solid transparent}.admin-sidebar nav a:hover{background:var(--nav-active-bg);color:var(--text-primary)}.admin-sidebar nav a.active{background:var(--nav-active-bg);color:var(--accent-primary);border-color:var(--border-accent);font-weight:500}.admin-sidebar__footer{display:flex;flex-direction:column;gap:8px;padding-top:12px;border-top:1px solid var(--border)}.logout-btn{background:none;border:1px solid var(--border);color:var(--text-muted);padding:10px 14px;border-radius:10px;cursor:pointer;font-size:13px;transition:border-color .2s ease,color .2s ease,background .2s ease}.logout-btn:hover{border-color:#f8717166;color:var(--danger);background:#f871710f}.admin-main{flex:1;min-width:0;padding:28px 32px 40px;overflow-y:auto;background:radial-gradient(ellipse 80% 50% at 50% -20%,rgba(147,51,234,.08),transparent),var(--bg-primary)}.admin-main h2{font-size:22px;margin-bottom:16px}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--border);font-size:14px}.data-table th{color:var(--text-muted);font-weight:500}.table-input{width:100%;min-width:100px;padding:6px 10px;font-size:13px}.table-actions{display:flex;gap:8px;flex-wrap:wrap}.config-form{max-width:600px}.form-group{margin-bottom:16px}.form-group label{display:block;color:var(--text-muted);font-size:13px;margin-bottom:6px}.input-with-upload{display:flex;gap:8px;align-items:center}.input-with-upload input{flex:1;min-width:0}.btn-upload{flex-shrink:0;padding:10px 16px;background:var(--bg-elevated);border:1px solid var(--border);color:var(--accent-primary);border-radius:10px;cursor:pointer;font-size:13px;white-space:nowrap;transition:border-color .2s ease}.btn-upload:hover:not(:disabled){border-color:var(--border-accent)}.btn-upload:disabled{opacity:.6;cursor:not-allowed}.upload-error{color:var(--danger);font-size:12px;margin-top:6px}.upload-preview{margin-top:8px;max-width:200px;max-height:120px;object-fit:contain;border-radius:10px;border:1px solid var(--border);background:var(--bg-elevated)}.form-inline{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.form-inline input,.form-inline select{flex:1;min-width:120px}.saved-tip{color:var(--success);margin-left:12px;font-size:14px}.page-section-title{margin-top:32px;margin-bottom:8px}@media(max-width:768px){.admin-layout{flex-direction:column}.admin-sidebar{width:100%;height:auto;position:static}.admin-main{padding:20px 16px 32px}}
