@font-face{font-family:__Nunito_Sans_aecbf6;font-style:normal;font-weight:200 1000;font-stretch:100%;font-display:swap;src:url(/_next/static/media/aa1b27f9e325731f.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:__Nunito_Sans_aecbf6;font-style:normal;font-weight:200 1000;font-stretch:100%;font-display:swap;src:url(/_next/static/media/c126d80dc21dff90.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:__Nunito_Sans_aecbf6;font-style:normal;font-weight:200 1000;font-stretch:100%;font-display:swap;src:url(/_next/static/media/e850464f9dfbb75b.p.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:__Nunito_Sans_aecbf6;font-style:normal;font-weight:200 1000;font-stretch:100%;font-display:swap;src:url(/_next/static/media/357067f10075d686.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:__Nunito_Sans_aecbf6;font-style:normal;font-weight:200 1000;font-stretch:100%;font-display:swap;src:url(/_next/static/media/68180864d7f93f02.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}.__className_aecbf6{font-family:__Nunito_Sans_aecbf6;font-style:normal}:root{--primary:#2563eb;--primary-dark:#1d4ed8;--primary-light:#60a5fa;--secondary:#10b981;--secondary-dark:#059669;--accent:#f59e0b;--danger:#ef4444;--danger-dark:#dc2626;--bg-primary:#0a0a0a;--bg-secondary:#111;--bg-card:#111;--bg-card-hover:#1a1a1a;--bg-input:#111;--bg-overlay:rgba(0,0,0,.8);--text-primary:#ededed;--text-secondary:#a1a1aa;--text-muted:#71717a;--text-inverse:#0a0a0a;--border:#27272a;--border-light:#3f3f46;--shadow-sm:none;--shadow-md:none;--shadow-lg:0 4px 6px -1px rgba(0,0,0,.5);--shadow-glow:none;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-full:9999px;--transition-fast:150ms ease;--transition-normal:250ms ease;--transition-slow:400ms cubic-bezier(0.16,1,0.3,1);--bottom-nav-height:72px;--safe-bottom:env(safe-area-inset-bottom,0px)}[data-theme=light]{--bg-primary:#fafafa;--bg-secondary:#fff;--bg-card:#fff;--bg-card-hover:#f4f4f5;--bg-input:#fff;--bg-overlay:rgba(0,0,0,.4);--text-primary:#171717;--text-secondary:#52525b;--text-muted:#71717a;--text-inverse:#f4f4f5;--border:#e4e4e7;--border-light:#d4d4d8;--shadow-sm:none;--shadow-md:none;--shadow-lg:0 4px 6px -1px rgba(0,0,0,.1);--shadow-glow:none;--primary-light:#2563eb}.theme-pill{position:relative;width:56px;height:28px;border-radius:9999px;border:none;cursor:pointer;padding:0;overflow:hidden;background:linear-gradient(135deg,#87ceeb,#60a5fa 50%,#38bdf8);box-shadow:inset 0 1px 3px rgba(0,0,0,.1),0 1px 2px rgba(0,0,0,.05);transition:background .6s cubic-bezier(.16,1,.3,1),box-shadow .4s;-webkit-tap-highlight-color:transparent;flex-shrink:0}.theme-pill--dark{background:linear-gradient(135deg,#0f172a,#1e293b 50%,#334155);box-shadow:inset 0 1px 3px rgba(0,0,0,.4),0 0 8px rgba(99,102,241,.15)}.theme-pill__bg{position:absolute;inset:0;pointer-events:none}.theme-pill__clouds,.theme-pill__stars{position:absolute;inset:0;width:100%;height:100%}.theme-pill__stars circle{animation:twinkle 2s ease-in-out infinite alternate}.theme-pill__stars circle:nth-child(2){animation-delay:.3s}.theme-pill__stars circle:nth-child(3){animation-delay:.7s}.theme-pill__stars circle:nth-child(4){animation-delay:1.1s}.theme-pill__stars circle:nth-child(5){animation-delay:.5s}.theme-pill__stars circle:nth-child(6){animation-delay:1.4s}.theme-pill__stars circle:nth-child(7){animation-delay:.9s}@keyframes twinkle{0%{opacity:.3}to{opacity:1}}.theme-pill__knob{position:absolute;top:2px;left:2px;width:24px;height:24px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 4px rgba(0,0,0,.2);transition:transform .5s cubic-bezier(.34,1.56,.64,1),background .4s;z-index:2}.theme-pill--dark .theme-pill__knob{transform:translateX(28px);background:#1e293b;box-shadow:0 0 6px rgba(148,163,184,.3),0 1px 4px rgba(0,0,0,.3)}.theme-pill__icon{transition:transform .5s cubic-bezier(.16,1,.3,1)}.theme-pill--dark .theme-pill__icon{transform:rotate(-30deg)}.theme-pill:hover .theme-pill__knob{box-shadow:0 2px 8px rgba(0,0,0,.25)}.theme-pill:active .theme-pill__knob{transform:scale(.92)}.theme-pill--dark:active .theme-pill__knob{transform:translateX(28px) scale(.92)}[data-theme=light] .login-page:after,[data-theme=light] .login-page:before{display:none}[data-theme=light] .login-card{box-shadow:none}[data-theme=light] .bottom-nav{background:hsla(0,0%,100%,.98);border-top:1px solid var(--border)}[data-theme=light] .card-glass{background:#f4f4f5;border:1px solid var(--border)}[data-theme=light] .stat-card{box-shadow:none}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;scroll-behavior:smooth}body{font-family:inherit;background:var(--bg-primary);color:var(--text-primary);line-height:1.7;min-height:100dvh;overflow-x:hidden}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}[data-theme=light] .logo-image{filter:invert(1) hue-rotate(180deg) brightness(.8) contrast(1.2)}button{font-family:inherit;cursor:pointer;border:none;background:none;font-size:inherit;color:inherit}input,select,textarea{font-family:inherit;font-size:16px;color:var(--text-primary)}.hide-on-desktop{display:flex}@media (min-width:768px){.hide-on-desktop{display:none!important}.hide-on-mobile{display:flex!important}}.hide-on-mobile{display:none}.container{width:100%;max-width:600px;margin:0 auto;padding:0 var(--space-md)}@media (min-width:768px){.container{max-width:100%;padding:0 var(--space-xl)}}@media (min-width:1200px){.container{max-width:1200px}}.page-content{padding-bottom:calc(var(--bottom-nav-height) + var(--safe-bottom) + var(--space-lg));padding-top:var(--space-lg);min-height:100dvh}@media (min-width:768px){.page-content{padding-bottom:var(--space-xl);padding-top:var(--space-xl)}}.card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border);padding:var(--space-lg);transition:all var(--transition-normal)}.card:hover{border-color:var(--border-light)}.card-glass{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-md)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:12px 20px;border-radius:var(--radius-md);font-weight:500;font-size:14px;transition:all var(--transition-fast);white-space:nowrap;min-height:44px;touch-action:manipulation;-webkit-user-select:none;-moz-user-select:none;user-select:none;position:relative;overflow:hidden;border:1px solid transparent}.btn:after{content:"";position:absolute;inset:0;background:transparent;transition:background var(--transition-fast)}.btn:active:after{background:rgba(0,0,0,.05)}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(37,99,235,.5)}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.btn-secondary{background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg-card-hover);border-color:var(--border-light)}.btn-success{background:var(--secondary);color:#fff;box-shadow:0 4px 14px rgba(16,185,129,.4)}.btn-success:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(16,185,129,.5)}.btn-danger{background:var(--danger);color:#fff;box-shadow:0 4px 14px rgba(239,68,68,.4)}.btn-danger:hover{transform:translateY(-1px)}.btn-warning{background:var(--accent);color:#fff;box-shadow:0 4px 14px rgba(245,158,11,.4)}.btn-outline{background:transparent;border:2px solid var(--primary);color:var(--primary-light)}.btn-outline:hover{background:rgba(37,99,235,.1)}.btn-block{width:100%}.btn-sm{padding:8px 16px;min-height:36px;font-size:13px}.btn-lg{padding:16px 32px;min-height:56px;font-size:17px}.input-group{display:flex;flex-direction:column;gap:var(--space-sm)}.input-label{font-size:14px;font-weight:500;color:var(--text-secondary)}.input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);padding:14px 16px;color:var(--text-primary);transition:all var(--transition-normal);min-height:48px;width:100%;line-height:1.5}.input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(37,99,235,.15)}.input::placeholder{color:var(--text-muted)}.textarea{resize:vertical;min-height:100px}.select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%2394a3b8' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right 12px center;background-repeat:no-repeat;background-size:20px;padding-right:40px}.search-bar{position:relative}.search-bar .search-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:18px;pointer-events:none}.search-bar .input{padding-left:48px;padding-right:48px;border-radius:var(--radius-lg);background:var(--bg-secondary);border:1px solid var(--border);font-size:15px}.search-bar .input:focus{border-color:var(--primary);background:var(--bg-input);box-shadow:0 0 0 3px rgba(37,99,235,.1)}.search-bar .search-clear{position:absolute;right:12px;top:50%;transform:translateY(-50%);width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:14px}.search-bar .search-clear:hover{background:var(--bg-card-hover);color:var(--text-primary)}.badge{display:inline-flex;align-items:center;padding:4px 8px;border-radius:var(--radius-sm);font-size:11px;font-weight:500;border:1px solid transparent}.badge-primary{background:var(--bg-secondary);color:var(--text-secondary);border-color:var(--border)}.badge-success{background:rgba(16,185,129,.1);color:#10b981}.badge-warning{background:rgba(245,158,11,.1);color:#f59e0b}.badge-danger{background:rgba(239,68,68,.1);color:#ef4444}.badge-info{background:rgba(59,130,246,.1);color:#3b82f6}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:var(--space-md);gap:var(--space-md)}.stat-card{background:var(--bg-card);border-radius:var(--radius-md);padding:var(--space-lg);border:1px solid var(--border);text-align:center}.stat-card .stat-value{font-size:32px;font-weight:800;line-height:1.2;margin-bottom:var(--space-xs)}.stat-card .stat-label{font-size:13px;color:var(--text-secondary);font-weight:500}.stat-card .stat-icon{font-size:28px;margin-bottom:var(--space-sm)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.section-title{font-size:18px;font-weight:700}.section-link{font-size:14px;color:var(--primary-light);font-weight:500}.books-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:var(--space-md);gap:var(--space-md)}@media (min-width:640px){.books-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width:1024px){.books-grid{grid-template-columns:repeat(4,1fr)}}.book-card{display:flex;flex-direction:column;background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border);transition:all var(--transition-fast);text-decoration:none;color:inherit;overflow:hidden}.book-card:hover{border-color:var(--primary);transform:translateY(-2px)}.book-card:active{transform:translateY(0)}.book-cover{position:relative;width:100%;aspect-ratio:3/4;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;border-bottom:1px solid var(--border)}.book-cover img{width:100%;height:100%;object-fit:cover}.book-info{flex:1 1;display:flex;flex-direction:column;gap:var(--space-xs);padding:var(--space-md)}.book-title{font-size:15px;font-weight:600;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.book-author{font-size:13px;color:var(--text-secondary)}.book-meta{flex-wrap:wrap;margin-top:auto;padding-top:var(--space-sm)}.book-meta,.empty-state{display:flex;gap:var(--space-sm);align-items:center}.empty-state{flex-direction:column;justify-content:center;padding:var(--space-2xl) var(--space-lg);text-align:center;border:1px dashed var(--border);border-radius:var(--radius-lg);background:var(--bg-card)}.empty-state .empty-icon{font-size:32px;opacity:.5;margin-bottom:var(--space-xs)}.empty-state .empty-title{font-size:16px;font-weight:600}.empty-state .empty-text{font-size:13px;color:var(--text-secondary);max-width:280px}.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.loading-center{display:flex;align-items:center;justify-content:center;padding:var(--space-2xl)}.skeleton{background:linear-gradient(90deg,var(--bg-input) 25%,var(--bg-card-hover) 50%,var(--bg-input) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.book-card-hot{border:1.5px solid rgba(239,68,68,.3);box-shadow:0 0 16px rgba(239,68,68,.08)}.hot-badge{position:absolute;top:8px;right:8px;background:linear-gradient(135deg,#ef4444,#f97316);color:#fff;font-size:10px;font-weight:800;padding:3px 8px;border-radius:6px;letter-spacing:.5px;z-index:2;box-shadow:0 2px 8px rgba(239,68,68,.35)}.ranking-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:var(--space-lg);overflow:hidden}.ranking-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--space-md) var(--space-lg);background:transparent;border:none;cursor:pointer;color:var(--text-primary)}.ranking-header:hover{background:var(--bg-secondary)}.ranking-header-title{font-size:15px;font-weight:700}.ranking-trophy-icon{color:#f59e0b}.ranking-list{padding:0 var(--space-md) var(--space-md);display:flex;flex-direction:column;gap:6px}.ranking-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-md);background:var(--bg-secondary);transition:all .15s ease}.ranking-item:hover{background:var(--bg-tertiary,var(--bg-secondary));transform:translateX(2px)}.ranking-item.rank-gold{background:linear-gradient(135deg,rgba(251,191,36,.1),rgba(245,158,11,.05));border:1px solid rgba(251,191,36,.25)}.ranking-item.rank-silver{background:linear-gradient(135deg,rgba(156,163,175,.12),hsla(220,9%,46%,.05));border:1px solid rgba(156,163,175,.3)}.ranking-item.rank-bronze{background:linear-gradient(135deg,rgba(217,119,6,.1),rgba(180,83,9,.05));border:1px solid rgba(217,119,6,.2)}.ranking-rank{width:32px;flex-shrink:0}.rank-medal,.ranking-rank{display:flex;align-items:center;justify-content:center}.rank-medal{width:28px;height:28px;border-radius:50%;font-size:13px;font-weight:800;color:#fff}.rank-medal.rank-gold{background:linear-gradient(135deg,#fbbf24,#f59e0b);box-shadow:0 2px 8px rgba(245,158,11,.4)}.rank-medal.rank-silver{background:linear-gradient(135deg,#9ca3af,#6b7280);box-shadow:0 2px 8px hsla(220,9%,46%,.35)}.rank-medal.rank-bronze{background:linear-gradient(135deg,#d97706,#b45309);box-shadow:0 2px 8px rgba(180,83,9,.35)}.rank-number{font-size:14px;font-weight:700;color:var(--text-muted)}.ranking-cover{width:36px;height:48px;border-radius:4px;overflow:hidden;flex-shrink:0;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;border:1px solid var(--border)}.ranking-cover img{width:100%;height:100%;object-fit:cover}.ranking-info{flex:1 1;min-width:0}.ranking-book-title{font-size:13px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.5}.ranking-book-author{font-size:11px;color:var(--text-muted);margin-bottom:4px}.ranking-bar-track{height:4px;background:var(--border);border-radius:2px;overflow:hidden}.ranking-bar-fill{height:100%;border-radius:2px;background:var(--primary);transition:width .5s ease}.ranking-bar-fill.rank-gold{background:linear-gradient(90deg,#fbbf24,#f59e0b)}.ranking-bar-fill.rank-silver{background:linear-gradient(90deg,#9ca3af,#6b7280)}.ranking-bar-fill.rank-bronze{background:linear-gradient(90deg,#d97706,#b45309)}.ranking-views{display:flex;align-items:center;gap:4px;font-size:13px;font-weight:700;color:var(--text-secondary);flex-shrink:0;min-width:48px;justify-content:flex-end}.views-stats{display:grid;grid-template-columns:1fr 1fr;grid-gap:var(--space-md);gap:var(--space-md);margin-bottom:var(--space-lg)}.views-stat-card{display:flex;align-items:center;gap:12px;padding:var(--space-md) var(--space-lg);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg)}.views-stat-value{font-size:22px;font-weight:800;line-height:1.2}.views-stat-label{font-size:12px;color:var(--text-muted);font-weight:500}.modal-overlay{position:fixed;inset:0;background:var(--bg-overlay);display:flex;align-items:flex-end;justify-content:center;z-index:1000;animation:fadeIn var(--transition-fast) ease;padding:0}@media (min-width:768px){.modal-overlay{align-items:center;padding:var(--space-lg)}}.modal{background:var(--bg-card);border-radius:var(--radius-xl) var(--radius-xl) 0 0;padding:var(--space-xl) var(--space-lg) calc(var(--safe-bottom) + var(--space-lg));width:100%;max-width:480px;max-height:90dvh;overflow-y:auto;animation:slideUp var(--transition-fast);border:1px solid var(--border)}@media (min-width:768px){.modal{border-radius:var(--radius-lg);padding:var(--space-xl)}}.modal-handle{width:36px;height:4px;background:var(--border-light);border-radius:var(--radius-full);margin:0 auto var(--space-lg)}.modal-title{font-size:18px;font-weight:700;margin-bottom:var(--space-md)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.app-layout{display:flex;min-height:100dvh;width:100%}.sidebar{display:none;width:260px;background:var(--bg-card);border-right:1px solid var(--border);flex-direction:column;position:-webkit-sticky;position:sticky;top:0;height:100dvh;z-index:100}.sidebar-header{padding:var(--space-xl) var(--space-md) var(--space-lg)}.sidebar-logo{flex-direction:column}.sidebar-nav{flex:1 1;padding:0 var(--space-md);overflow-y:auto}.sidebar-link.active{background:rgba(37,99,235,.1);font-weight:600}.sidebar-footer{padding:var(--space-lg) var(--space-md);border-top:1px solid var(--border)}.main-content{flex:1 1;width:100%;min-width:0}@media (min-width:768px){.sidebar{display:flex}}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:calc(var(--bottom-nav-height) + var(--safe-bottom));padding-bottom:var(--safe-bottom);background:var(--bg-card);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-around;z-index:100}@media (min-width:768px){.bottom-nav{display:none}}.nav-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 16px;border-radius:var(--radius-md);transition:all var(--transition-fast);min-width:64px;color:var(--text-muted);text-decoration:none}.nav-item:hover{color:var(--text-secondary)}.nav-item.active{color:var(--primary-light)}.nav-item .nav-icon{font-size:22px;line-height:1}.nav-item .nav-label{font-size:11px;font-weight:600;letter-spacing:.02em}.page-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) 0;gap:var(--space-md)}.page-header .header-title{font-size:22px;font-weight:800}.user-avatar{width:36px;height:36px;border-radius:50%;overflow:hidden;border:2px solid var(--primary)}.user-avatar img{width:100%;height:100%;object-fit:cover}.tabs{display:flex;gap:var(--space-xs);background:var(--bg-secondary);padding:4px;margin-bottom:var(--space-lg)}.tab,.tabs{border-radius:var(--radius-full)}.tab{flex:1 1;padding:10px 16px;font-size:14px;font-weight:600;text-align:center;transition:all var(--transition-fast);color:var(--text-muted)}.tab.active{background:var(--primary);color:#fff;box-shadow:var(--shadow-sm)}.tab:hover:not(.active){color:var(--text-primary)}.table-wrapper{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--border)}.table{width:100%;border-collapse:collapse}.table th{text-align:left;font-size:13px;font-weight:600;color:var(--text-secondary);background:var(--bg-secondary);white-space:nowrap}.table td,.table th{padding:12px 16px;border-bottom:1px solid var(--border)}.table td{font-size:14px}.table tr:last-child td{border-bottom:none}.table tr:hover td{background:rgba(37,99,235,.05)}.toast{position:fixed;top:var(--space-lg);left:50%;transform:translateX(-50%) translateY(-100px);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-md) var(--space-lg);box-shadow:var(--shadow-lg);z-index:2000;animation:toastIn var(--transition-slow) forwards;font-size:14px;font-weight:500;display:flex;align-items:center;gap:var(--space-sm);max-width:90vw}.toast.toast-success{border-left:4px solid var(--secondary)}.toast.toast-error{border-left:4px solid var(--danger)}@keyframes toastIn{0%{transform:translateX(-50%) translateY(-100px);opacity:0}to{transform:translateX(-50%) translateY(0);opacity:1}}.login-page{min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-lg);background:var(--bg-primary);position:relative;overflow:hidden}.login-page:before{width:500px;height:500px;background:radial-gradient(circle,rgba(37,99,235,.12) 0,transparent 70%);top:-200px;right:-200px}.login-page:after,.login-page:before{content:"";position:absolute;pointer-events:none}.login-page:after{width:400px;height:400px;background:radial-gradient(circle,rgba(37,99,235,.08) 0,transparent 70%);bottom:-150px;left:-150px}.login-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-2xl) var(--space-lg);width:100%;max-width:400px;text-align:center;position:relative;z-index:1}.login-logo{font-size:56px;margin-bottom:var(--space-md)}.login-title{font-size:24px;font-weight:800;margin-bottom:var(--space-sm);color:var(--primary-light)}.login-subtitle{color:var(--text-secondary);font-size:14px;margin-bottom:var(--space-xl);line-height:1.5}.login-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-md);width:100%;padding:16px 24px;background:#fff;color:#333;border-radius:var(--radius-md);font-weight:600;font-size:16px;transition:all var(--transition-normal);min-height:56px;border:none;cursor:pointer}.login-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px hsla(0,0%,100%,.15)}.login-btn:active{transform:translateY(0)}.login-btn img{width:24px;height:24px}.login-note{margin-top:var(--space-lg);font-size:12px;color:var(--text-muted);line-height:1.5}.login-error{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-sm);padding:var(--space-md);margin-bottom:var(--space-lg);color:#fca5a5;font-size:14px}.scanner-container{position:relative;width:100%;max-width:360px;aspect-ratio:1;margin:0 auto;border-radius:var(--radius-lg);overflow:hidden;border:3px solid var(--primary)}.scanner-container video{width:100%;height:100%;object-fit:cover}.scanner-corners{position:absolute;inset:16px;border:2px solid hsla(0,0%,100%,.6);border-radius:var(--radius-sm);pointer-events:none}@media (min-width:1024px){.admin-layout{display:grid;grid-template-columns:260px 1fr;min-height:100dvh}.admin-sidebar{background:var(--bg-secondary);border-right:1px solid var(--border);padding:var(--space-lg);position:-webkit-sticky;position:sticky;top:0;height:100dvh;overflow-y:auto}.admin-main{padding:var(--space-lg) var(--space-xl);overflow-y:auto}.admin-layout .bottom-nav{display:none}}.sidebar-logo{display:flex;align-items:center;gap:var(--space-sm);font-size:18px;font-weight:800;margin-bottom:var(--space-xl);padding:var(--space-sm) 0}.sidebar-nav{display:flex;flex-direction:column;gap:var(--space-xs)}.sidebar-link{display:flex;align-items:center;gap:var(--space-md);padding:12px 16px;border-radius:var(--radius-md);font-size:14px;font-weight:500;color:var(--text-secondary);transition:all var(--transition-fast)}.sidebar-link:hover{background:var(--bg-card-hover);color:var(--text-primary)}.sidebar-link.active{background:rgba(37,99,235,.15);color:var(--primary-light)}.chart-container{background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border);padding:var(--space-lg)}.chart-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg)}.chart-title{font-size:16px;font-weight:600}.list{display:flex;flex-direction:column;gap:var(--space-sm)}.list-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border);transition:all var(--transition-fast)}.list-item:hover{border-color:var(--border-light)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.animate-in{animation:fadeInUp .5s cubic-bezier(.16,1,.3,1) backwards}.animate-in:first-child{animation-delay:0ms}.animate-in:nth-child(2){animation-delay:60ms}.animate-in:nth-child(3){animation-delay:.12s}.animate-in:nth-child(4){animation-delay:.18s}.animate-in:nth-child(5){animation-delay:.24s}.animate-in:nth-child(6){animation-delay:.3s}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-light)}.user-footer{margin-top:var(--space-xl);padding:var(--space-lg) 0;border-top:1px solid var(--border);text-align:center;font-size:12px;color:var(--text-muted);line-height:1.6}.user-footer p{margin:0 0 var(--space-xs) 0}.user-footer-credits{font-size:11px;color:var(--text-muted);opacity:.8}.desktop-only{display:none!important}@media (min-width:1024px){.desktop-only{display:flex!important}.mobile-only{display:none!important}}