:root{--color-ink:#1e293b;--color-ink-light:#475569;--color-ink-muted:#94a3b8;--color-bg:#f1f5f9;--color-surface:#fff;--color-cream:#f8fafc;--color-border:#e2e8f0;--color-border-light:#f1f5f9;--color-white:#fff;--color-primary:#3b82f6;--color-primary-hover:#2563eb;--color-primary-light:#eff6ff;--color-primary-100:#dbeafe;--color-primary-700:#1d4ed8;--color-success:#22c55e;--color-success-light:#f0fdf4;--color-warning:#f59e0b;--color-warning-light:#fffbeb;--color-danger:#ef4444;--color-danger-light:#fef2f2;--color-info:#3b82f6;--color-info-light:#eff6ff;--color-purple:#8b5cf6;--color-purple-light:#f5f3ff;--color-orange:#f97316;--color-orange-light:#fff7ed;--color-teal:#14b8a6;--color-teal-light:#f0fdfa;--color-amber:#eab308;--font-body:"DM Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--text-xs:.75rem;--text-sm:.8125rem;--text-base:.875rem;--text-md:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:2rem;--leading-tight:1.25;--leading-normal:1.5;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--radius-full:9999px;--shadow-sm:0 1px 2px #0000000a;--shadow-md:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow-lg:0 4px 6px -1px #00000012, 0 2px 4px -2px #0000000d;--shadow-xl:0 10px 15px -3px #00000014, 0 4px 6px -4px #0000000d;--shadow-card:0 1px 3px #0000000a, 0 0 0 1px #00000005;--ease-out:cubic-bezier(.22, 1, .36, 1);--duration-fast:.15s;--duration-normal:.2s;--sidebar-width:250px;--header-height:60px}[data-theme=dark]{--color-ink:#e2e8f0;--color-ink-light:#94a3b8;--color-ink-muted:#64748b;--color-bg:#0f172a;--color-surface:#1e293b;--color-cream:#1a2332;--color-border:#334155;--color-border-light:#1e293b;--color-white:#1e293b;--color-primary-light:#3b82f626;--color-primary-100:#3b82f633;--color-success-light:#22c55e1f;--color-warning-light:#f59e0b1f;--color-danger-light:#ef44441f;--color-info-light:#3b82f61f;--color-purple-light:#8b5cf61f;--color-orange-light:#f973161f;--color-teal-light:#14b8a61f;--shadow-sm:0 1px 2px #0003;--shadow-md:0 1px 3px #0000004d, 0 1px 2px #0003;--shadow-lg:0 4px 6px -1px #00000059, 0 2px 4px -2px #0003;--shadow-xl:0 10px 15px -3px #0006, 0 4px 6px -4px #00000040;--shadow-card:0 1px 3px #0003, 0 0 0 1px #ffffff08}[data-theme=dark] .sidebar{background:linear-gradient(#0c1929 0%,#0a1423 100%)}[data-theme=dark] .sidebar-section-label{color:#475569}[data-theme=dark] .sidebar-link{color:#7c9ab8}[data-theme=dark] .sidebar-link:hover{color:#a3c4de;background:#ffffff0d}[data-theme=dark] .sidebar-brand .brand-sub{color:#4a6a82}[data-theme=dark] .sidebar-user-name{color:#cbd5e1}[data-theme=dark] .sidebar-user-email{color:#4a6a82}[data-theme=dark] .sidebar-signout{color:#5a7a96;border-color:#ffffff0f}[data-theme=dark] .sidebar-signout:hover{color:#8baac0;background:#ffffff08;border-color:#ffffff1f}[data-theme=dark] .sidebar-footer{border-top-color:#ffffff0a}[data-theme=dark] .topbar{background:#1e293b;border-bottom-color:#334155}[data-theme=dark] .notif-count{border-color:#1e293b}[data-theme=dark] .login-page{background:linear-gradient(135deg,#0f172a 0%,#1e293b 50%,#0f172a 100%)}[data-theme=dark] .login-page:before{background:radial-gradient(at 30% 20%,#3b82f61f 0%,#0000 50%),radial-gradient(at 70% 80%,#8b5cf614 0%,#0000 50%)}[data-theme=dark] .login-card{background:#1e293b;border-color:#334155}[data-theme=dark] .badge-neutral{color:#94a3b8;background:#334155}[data-theme=dark] .badge-neutral.badge-dot:before{background:#64748b}[data-theme=dark] .form-input::placeholder,[data-theme=dark] .form-textarea::placeholder{color:#475569}[data-theme=dark] .form-input:focus,[data-theme=dark] .form-select:focus,[data-theme=dark] .form-textarea:focus{box-shadow:0 0 0 3px #3b82f633}[data-theme=dark] ::-webkit-scrollbar-thumb{background:#475569}[data-theme=dark] ::-webkit-scrollbar-thumb:hover{background:#64748b}[data-theme=dark] .star-rating .star{color:#475569}[data-theme=dark] .welcome-banner .btn-banner-solid{color:#1e293b}[data-theme=dark] .welcome-banner .btn-banner-solid:hover{background:#e2e8f0}.theme-toggle{cursor:pointer;border-radius:var(--radius-full);transition:background var(--duration-fast) var(--ease-out);color:var(--color-ink-light);background:0 0;border:none;justify-content:center;align-items:center;padding:8px;font-size:1.2rem;line-height:1;display:flex}.theme-toggle:hover{background:var(--color-cream);color:var(--color-ink)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-body);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--color-ink);background-color:var(--color-bg)}h1,h2,h3,h4{font-family:var(--font-body);font-weight:700;line-height:var(--leading-tight);color:var(--color-ink)}h1{font-size:var(--text-2xl)}h2{font-size:var(--text-xl)}h3{font-size:var(--text-lg)}h4{font-size:var(--text-md)}a{color:var(--color-primary);transition:color var(--duration-fast) var(--ease-out);text-decoration:none}a:hover{color:var(--color-primary-hover)}img{max-width:100%;display:block}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{border-radius:var(--radius-full);background:#cbd5e1}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.app-shell{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);color:#cbd5e1;z-index:100;background:linear-gradient(#1e3a5f 0%,#1a2e4a 100%);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;overflow-y:auto}.sidebar-brand{padding:var(--space-5) var(--space-5);align-items:center;gap:var(--space-3);display:flex}.sidebar-brand-icon{border-radius:var(--radius-md);background:#ffffff26;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.1rem;display:flex}.sidebar-brand-logo{object-fit:cover;border-radius:50%;flex-shrink:0;width:40px;height:40px}.sidebar-brand h1{font-size:var(--text-md);color:var(--color-white);letter-spacing:-.01em;font-weight:700}.sidebar-brand .brand-sub{color:#7c9ab8;margin-top:1px;font-size:11px}.sidebar-nav{padding:var(--space-3) var(--space-3);flex-direction:column;flex:1;gap:2px;display:flex}.sidebar-section-label{text-transform:uppercase;letter-spacing:.08em;color:#5a7a96;padding:var(--space-5) var(--space-3) var(--space-2);font-size:11px;font-weight:600}.sidebar-link{align-items:center;gap:var(--space-3);border-radius:var(--radius-md);color:#93b1cc;font-size:var(--text-sm);transition:all var(--duration-fast) var(--ease-out);padding:9px 12px;font-weight:500;text-decoration:none;display:flex}.sidebar-link:hover{color:#d4e4f1;background:#ffffff12}.sidebar-link.active{background:var(--color-primary);color:var(--color-white);font-weight:600;box-shadow:0 2px 8px #3b82f659}.sidebar-link .link-icon{text-align:center;width:20px;font-size:var(--text-base);flex-shrink:0}.sidebar-badge-count{color:#fff;border-radius:var(--radius-full);background:#ef4444e6;margin-left:auto;padding:1px 7px;font-size:11px;font-weight:700;line-height:1.4}.sidebar-footer{padding:var(--space-4);border-top:1px solid #ffffff0f}.sidebar-user{align-items:center;gap:var(--space-3);padding:var(--space-2);display:flex}.sidebar-user-avatar{border-radius:var(--radius-full);width:36px;height:36px;color:var(--color-white);font-weight:700;font-size:var(--text-sm);background:linear-gradient(135deg,#3b82f6,#8b5cf6);flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{font-size:var(--text-sm);color:#e2e8f0;white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.sidebar-user-email{color:#6b8baa;white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.sidebar-signout{color:#7c9ab8;border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-xs);font-family:var(--font-body);transition:all var(--duration-fast) var(--ease-out);background:0 0;border:1px solid #ffffff1a;padding:6px 0;font-weight:500}.sidebar-signout:hover{color:#c4d8eb;background:#ffffff0a;border-color:#fff3}.main-area{margin-left:var(--sidebar-width);flex-direction:column;flex:1;min-height:100vh;display:flex}.topbar{height:var(--header-height);background:var(--color-white);border-bottom:1px solid var(--color-border);padding:0 var(--space-6);justify-content:flex-end;align-items:center;gap:var(--space-4);z-index:50;display:flex;position:sticky;top:0}.main-content{padding:var(--space-6) var(--space-8);flex:1;width:100%;max-width:1280px}.page-header{margin-bottom:var(--space-6);justify-content:space-between;align-items:flex-start;gap:var(--space-4);display:flex}.page-header h1{font-size:var(--text-2xl)}.page-header-subtitle{color:var(--color-ink-muted);font-size:var(--text-sm);margin-top:4px;font-weight:400}.page-header-actions{align-items:center;gap:var(--space-3);display:flex}.welcome-banner{border-radius:var(--radius-xl);padding:var(--space-6) var(--space-8);color:#fff;margin-bottom:var(--space-6);background:linear-gradient(135deg,#3b82f6 0%,#2563eb 50%,#1d4ed8 100%);justify-content:space-between;align-items:center;display:flex;position:relative;overflow:hidden}.welcome-banner:before{content:"";pointer-events:none;background:#ffffff0f;border-radius:50%;width:250px;height:250px;position:absolute;top:-30%;right:-5%}.welcome-banner:after{content:"";pointer-events:none;background:#ffffff0a;border-radius:50%;width:180px;height:180px;position:absolute;bottom:-40%;right:10%}.welcome-banner-text h2{color:#fff;font-size:var(--text-xl);margin-bottom:6px;font-weight:700}.welcome-banner-text p{color:#fffc;font-size:var(--text-sm)}.welcome-banner-actions{gap:var(--space-3);z-index:1;display:flex}.welcome-banner .btn-banner{color:#fff;border-radius:var(--radius-md);font-size:var(--text-sm);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);font-weight:600;font-family:var(--font-body);white-space:nowrap;background:#ffffff2e;border:1px solid #ffffff40;padding:8px 18px}.welcome-banner .btn-banner:hover{background:#ffffff47}.welcome-banner .btn-banner-solid{color:var(--color-primary);background:#fff;border-color:#fff}.welcome-banner .btn-banner-solid:hover{background:#f0f6ff}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--shadow-card)}.card-flush{padding:0}.card-header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.card-body{padding:var(--space-5)}.stat-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);gap:var(--space-2);transition:box-shadow var(--duration-normal) var(--ease-out);flex-direction:column;display:flex;position:relative;overflow:hidden}.stat-card:hover{box-shadow:var(--shadow-lg)}.stat-card-header{justify-content:space-between;align-items:center;display:flex}.stat-card-label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.04em;color:var(--color-ink-muted);font-weight:600}.stat-card-icon{border-radius:var(--radius-md);justify-content:center;align-items:center;width:40px;height:40px;font-size:1.2rem;display:flex}.stat-card-value{font-size:var(--text-3xl);color:var(--color-ink);letter-spacing:-.02em;font-weight:800;line-height:1}.stat-card-trend{border-radius:var(--radius-full);align-items:center;gap:4px;padding:2px 8px;font-size:12px;font-weight:600;display:inline-flex}.stat-card-trend.up{color:#16a34a;background:var(--color-success-light)}.stat-card-trend.down{color:var(--color-danger);background:var(--color-danger-light)}.stat-card-accent{border-radius:var(--radius-full);width:100%;height:3px;margin-bottom:var(--space-1)}.quick-actions{gap:var(--space-3);grid-template-columns:repeat(auto-fit,minmax(140px,1fr));display:grid}.quick-action-btn{align-items:center;gap:var(--space-2);padding:var(--space-5) var(--space-3);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);color:var(--color-ink);font-family:var(--font-body);flex-direction:column;text-decoration:none;display:flex}.quick-action-btn:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md);color:var(--color-primary)}.quick-action-icon{border-radius:var(--radius-lg);justify-content:center;align-items:center;width:44px;height:44px;font-size:1.25rem;display:flex}.quick-action-label{font-size:var(--text-sm);font-weight:600}.progress-row{align-items:center;gap:var(--space-3);padding:var(--space-2) 0;display:flex}.progress-label{font-size:var(--text-sm);color:var(--color-ink-light);min-width:120px}.progress-bar{background:var(--color-border-light);border-radius:var(--radius-full);flex:1;height:8px;overflow:hidden}.progress-fill{border-radius:var(--radius-full);height:100%;transition:width .5s var(--ease-out)}.progress-value{font-size:var(--text-sm);color:var(--color-ink);text-align:right;min-width:40px;font-weight:700}.table-wrapper{overflow-x:auto}table.data-table{border-collapse:collapse;width:100%;font-size:var(--text-sm)}table.data-table thead th{text-align:left;padding:var(--space-3) var(--space-4);text-transform:uppercase;letter-spacing:.05em;color:var(--color-ink-muted);border-bottom:1px solid var(--color-border);white-space:nowrap;background:var(--color-cream);font-size:11px;font-weight:600}table.data-table tbody td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border-light);vertical-align:middle}table.data-table tbody tr{transition:background var(--duration-fast) var(--ease-out)}table.data-table tbody tr:hover{background:var(--color-cream)}table.data-table tbody tr:last-child td{border-bottom:none}.badge{border-radius:var(--radius-full);white-space:nowrap;align-items:center;gap:5px;padding:3px 10px;font-size:12px;font-weight:600;line-height:1.5;display:inline-flex}.badge-dot:before{content:"";border-radius:50%;flex-shrink:0;width:6px;height:6px;display:inline-block}.badge-success{background:var(--color-success-light);color:#16a34a}.badge-success.badge-dot:before{background:#22c55e}.badge-warning{background:var(--color-warning-light);color:#b45309}.badge-warning.badge-dot:before{background:#f59e0b}.badge-danger{background:var(--color-danger-light);color:#dc2626}.badge-danger.badge-dot:before{background:#ef4444}.badge-info{background:var(--color-info-light);color:#2563eb}.badge-info.badge-dot:before{background:#3b82f6}.badge-neutral{color:#64748b;background:#f1f5f9}.badge-neutral.badge-dot:before{background:#94a3b8}.badge-plum{background:var(--color-purple-light);color:#7c3aed}.badge-plum.badge-dot:before{background:#8b5cf6}.badge-primary{background:var(--color-primary-light);color:var(--color-primary)}.badge-primary.badge-dot:before{background:var(--color-primary)}.badge-orange{background:var(--color-orange-light);color:#ea580c}.badge-teal{background:var(--color-teal-light);color:#0d9488}.btn{justify-content:center;align-items:center;gap:var(--space-2);border-radius:var(--radius-md);font-family:var(--font-body);font-size:var(--text-sm);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);white-space:nowrap;border:1px solid #0000;padding:8px 18px;font-weight:600;line-height:1.4;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:var(--color-white);border-color:var(--color-primary);box-shadow:0 1px 2px #3b82f64d}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover);border-color:var(--color-primary-hover);box-shadow:0 2px 4px #3b82f659}.btn-secondary{background:var(--color-white);color:var(--color-ink);border-color:var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-cream);border-color:#cbd5e1}.btn-ghost{color:var(--color-ink-light);background:0 0;border-color:#0000}.btn-ghost:hover:not(:disabled){background:var(--color-cream);color:var(--color-ink)}.btn-danger{background:var(--color-danger);color:var(--color-white);border-color:var(--color-danger)}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-sm{border-radius:var(--radius-sm);padding:5px 12px;font-size:12px}.btn-lg{font-size:var(--text-md);border-radius:var(--radius-md);padding:12px 28px}.btn-icon{padding:var(--space-2);border-radius:var(--radius-md)}.form-group{flex-direction:column;gap:6px;display:flex}.form-label{font-size:var(--text-sm);color:var(--color-ink);font-weight:600}.form-hint{font-size:var(--text-xs);color:var(--color-ink-muted)}.form-input,.form-select,.form-textarea{border:1px solid var(--color-border);border-radius:var(--radius-md);font-family:var(--font-body);font-size:var(--text-sm);color:var(--color-ink);background:var(--color-white);transition:border-color var(--duration-fast) var(--ease-out), box-shadow var(--duration-fast) var(--ease-out);outline:none;width:100%;padding:10px 14px}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f61f}.form-input::placeholder,.form-textarea::placeholder{color:#94a3b8}.form-textarea{resize:vertical;min-height:100px}.form-row{gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.form-actions{gap:var(--space-3);margin-top:var(--space-5);display:flex}.filter-bar{gap:var(--space-3);margin-bottom:var(--space-5);flex-wrap:wrap;display:flex}.filter-bar .form-input,.filter-bar .form-select{width:auto;min-width:200px}.empty-state{text-align:center;padding:var(--space-12) var(--space-8);color:var(--color-ink-muted)}.empty-state-icon{margin-bottom:var(--space-4);opacity:.4;font-size:2.5rem}.empty-state-text{font-size:var(--text-md)}.notif-btn{cursor:pointer;font-size:var(--text-lg);border-radius:var(--radius-full);transition:background var(--duration-fast) var(--ease-out);color:var(--color-ink-light);background:0 0;border:none;padding:8px;position:relative}.notif-btn:hover{background:var(--color-cream)}.notif-count{background:var(--color-danger);color:var(--color-white);border-radius:var(--radius-full);border:2px solid var(--color-white);justify-content:center;align-items:center;min-width:18px;height:18px;font-size:10px;font-weight:700;display:flex;position:absolute;top:2px;right:2px}.notif-dropdown{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:380px;max-height:460px;box-shadow:var(--shadow-xl);z-index:1000;position:absolute;top:calc(100% + 8px);right:0;overflow-y:auto}.notif-dropdown-header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;font-weight:700;display:flex}.notif-item{padding:var(--space-3) var(--space-5);border-bottom:1px solid var(--color-border-light);cursor:pointer;transition:background var(--duration-fast) var(--ease-out)}.notif-item:hover{background:var(--color-cream)}.notif-item-unread{background:var(--color-primary-light)}.notif-item-title{font-weight:600;font-size:var(--text-sm);color:var(--color-ink)}.notif-item-body{font-size:var(--text-xs);color:var(--color-ink-muted);text-overflow:ellipsis;white-space:nowrap;margin-top:2px;overflow:hidden}.notif-item-time{color:#94a3b8;margin-top:3px;font-size:11px}.notif-see-all{padding:var(--space-3) var(--space-5);text-align:center;color:var(--color-primary);cursor:pointer;font-size:var(--text-sm);border-top:1px solid var(--color-border);transition:background var(--duration-fast) var(--ease-out);font-weight:600}.notif-see-all:hover{background:var(--color-cream)}.login-page{background:linear-gradient(135deg,#eff6ff 0%,#f1f5f9 50%,#faf5ff 100%);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative}.login-page:before{content:"";pointer-events:none;background:radial-gradient(at 30% 20%,#3b82f614 0%,#0000 50%),radial-gradient(at 70% 80%,#8b5cf60f 0%,#0000 50%);position:absolute;inset:0}.login-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);width:100%;max-width:440px;padding:var(--space-10) var(--space-8);box-shadow:var(--shadow-xl);z-index:1;position:relative}.login-brand{text-align:center;margin-bottom:var(--space-8)}.login-brand-icon{border-radius:var(--radius-lg);width:48px;height:48px;margin-bottom:var(--space-4);color:#fff;background:linear-gradient(135deg,#3b82f6,#2563eb);justify-content:center;align-items:center;font-size:1.5rem;display:inline-flex}.login-brand-logo{object-fit:cover;width:120px;height:120px;margin-bottom:var(--space-4);border-radius:50%}.login-brand h1{font-size:var(--text-xl);color:var(--color-ink)}.login-brand p{color:var(--color-ink-muted);font-size:var(--text-sm);margin-top:var(--space-1)}.login-form{gap:var(--space-5);flex-direction:column;display:flex}.login-form .btn{margin-top:var(--space-2)}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:var(--color-surface);border-radius:var(--radius-xl);padding:var(--space-8);box-shadow:var(--shadow-xl);max-width:90vw;position:relative}.modal-close{color:var(--color-ink-muted);cursor:pointer;background:0 0;border:none;font-size:1.5rem;line-height:1;position:absolute;top:12px;right:16px}.modal-close:hover{color:var(--color-ink)}.qr-modal{text-align:center;min-width:300px}.qr-modal .qr-container{flex-direction:column;align-items:center;display:flex}.section-heading{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;gap:var(--space-4);display:flex}.section-heading h2{font-size:var(--text-lg)}.star-rating{gap:2px;display:inline-flex}.star-rating .star{cursor:pointer;color:#d1d5db;transition:color var(--duration-fast) var(--ease-out);background:0 0;border:none;padding:0;font-size:1.25rem;line-height:1}.star-rating .star.filled,.star-rating .star:hover{color:var(--color-amber)}.star-rating-readonly .star{cursor:default}.review-item{padding:var(--space-4) 0;border-bottom:1px solid var(--color-border-light)}.review-item:last-child{border-bottom:none}.review-header{align-items:center;gap:var(--space-3);margin-bottom:var(--space-2);display:flex}.review-author{font-weight:600;font-size:var(--text-sm)}.review-date{font-size:var(--text-xs);color:var(--color-ink-muted)}.review-comment{font-size:var(--text-sm);color:var(--color-ink-light);line-height:var(--leading-normal)}.detail-grid{gap:var(--space-8);grid-template-columns:220px 1fr;align-items:start;display:grid}.detail-cover{aspect-ratio:2/3;background:var(--color-cream);border-radius:var(--radius-lg);color:#cbd5e1;width:100%;font-size:var(--text-3xl);border:1px solid var(--color-border);justify-content:center;align-items:center;display:flex;overflow:hidden}.detail-cover img{object-fit:cover;width:100%;height:100%}.detail-meta{gap:var(--space-3) var(--space-6);margin:var(--space-5) 0;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));display:grid}.detail-meta-item{flex-direction:column;gap:3px;display:flex}.detail-meta-label{text-transform:uppercase;letter-spacing:.05em;color:var(--color-ink-muted);font-size:11px;font-weight:600}.detail-meta-value{font-size:var(--text-sm);color:var(--color-ink);font-weight:500}.toggle-row{padding:var(--space-3) 0;border-bottom:1px solid var(--color-border-light);justify-content:space-between;align-items:center;display:flex}.toggle-row:last-child{border-bottom:none}@media (width<=768px){:root{--sidebar-width:0px}.sidebar{transition:transform var(--duration-normal) var(--ease-out);transform:translate(-100%)}.sidebar.open{width:280px;transform:translate(0)}.main-area{margin-left:0}.main-content{padding:var(--space-4)}.detail-grid{grid-template-columns:1fr}.stat-grid{grid-template-columns:repeat(2,1fr)}.welcome-banner{align-items:flex-start;gap:var(--space-4);flex-direction:column}}.text-muted{color:var(--color-ink-muted)}.text-sm{font-size:var(--text-sm)}.text-xs{font-size:var(--text-xs)}.text-center{text-align:center}.text-right{text-align:right}.text-primary{color:var(--color-primary)}.font-bold{font-weight:700}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.w-full{width:100%}.inline-flex{display:inline-flex}.grid{display:grid}.error-text{color:var(--color-danger);font-size:var(--text-sm);font-weight:500}.loading-text{color:var(--color-ink-muted);font-size:var(--text-sm);padding:var(--space-8);text-align:center}.divider{border:none;border-top:1px solid var(--color-border);margin:var(--space-6) 0}.qr-container{align-items:center;gap:var(--space-3);padding:var(--space-4);flex-direction:column;display:flex}.sub-card{padding:var(--space-4) var(--space-5);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);justify-content:space-between;align-items:center;gap:var(--space-4);display:flex}
