:root{--bg:#0c0c0b;--bg2:#141412;--bg3:#1c1c19;--gold:#c9a84c;--gold2:#e8c97a;--gold-dim:#6b5420;--cream:#f5f0e8;--cream2:#c8c2b4;--muted:#5a5750;--red:#8b3a3a;--green:#2e5e45;--blue:#2a3f6b;--border:rgba(201,168,76,.12);--border2:rgba(201,168,76,.25);--font-serif:"Cormorant Garamond", serif;--font-mono:"DM Mono", monospace;--radius-sm:3px;--radius-md:5px;--radius-lg:16px;--transition:.2s ease;--transition-slow:.5s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;height:100%}body{height:100%;min-height:100vh}img,svg{max-width:100%;display:block}input,button,textarea,select{font:inherit;color:inherit}a{color:inherit;text-decoration:none}ul,ol{list-style:none}html,body{background:var(--bg);color:var(--cream);font-family:var(--font-mono);letter-spacing:.03em;font-size:13px;line-height:1.5}h1,h2,h3,h4{font-family:var(--font-serif);letter-spacing:.02em;color:var(--cream);font-weight:300}h1{font-size:30px}h2{font-size:24px}h3{font-size:20px}h4{font-size:16px}.text-serif{font-family:var(--font-serif)}.text-mono{font-family:var(--font-mono)}.text-gold{color:var(--gold)}.text-muted{color:var(--muted)}.text-cream2{color:var(--cream2)}.label-xs{letter-spacing:.25em;text-transform:uppercase;color:var(--muted);font-size:8px}.label-sm{letter-spacing:.15em;text-transform:uppercase;color:var(--muted);font-size:9px}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:none}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes slideInRight{0%{opacity:0;transform:translate(10px)}to{opacity:1;transform:none}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.anim-fade-in{animation:.3s both fadeIn}.anim-slide-in{animation:.3s both slideInRight}.anim-pulse{animation:1.5s ease-in-out infinite pulse}.main-body::-webkit-scrollbar{width:3px}.task-list::-webkit-scrollbar{width:3px}.main-body::-webkit-scrollbar-track{background:0 0}.task-list::-webkit-scrollbar-track{background:0 0}.main-body::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}.task-list::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}.modal::-webkit-scrollbar{width:3px}.modal::-webkit-scrollbar-track{background:0 0}.modal::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}.main-body,.task-list,.modal{scrollbar-width:thin;scrollbar-color:var(--border2) transparent}.app-shell{grid-template-columns:240px 1fr;width:100%;height:100vh;display:grid;overflow:hidden}.app-shell--auth{justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}@media (width<=768px){.app-shell{grid-template-columns:1fr}.sidebar{display:none}.sidebar.open{z-index:100;width:240px;display:flex;position:fixed;inset:0}}.sidebar{background:var(--bg2);border-right:.5px solid var(--border);flex-direction:column;padding:28px 0;display:flex;overflow-y:auto}.sidebar__logo{border-bottom:.5px solid var(--border);padding:0 22px 28px}.sidebar__logo-title{font-family:var(--font-serif);color:var(--gold);letter-spacing:.08em;font-size:22px;font-weight:300}.sidebar__logo-sub{color:var(--muted);letter-spacing:.2em;text-transform:uppercase;margin-top:2px;font-size:9px}.sidebar__nav{flex:1;padding:20px 0}.sidebar__nav-label{letter-spacing:.25em;color:var(--muted);text-transform:uppercase;padding:0 22px 10px;font-size:8px}.sidebar__nav-item{cursor:pointer;transition:all var(--transition);color:var(--cream2);letter-spacing:.05em;-webkit-user-select:none;user-select:none;text-align:left;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:9px 22px;font-size:11px;display:flex;position:relative}.sidebar__nav-item:hover{color:var(--gold);background:rgba(201,168,76,.04)}.sidebar__nav-item.active{color:var(--gold);background:rgba(201,168,76,.08)}.sidebar__nav-item.active:before{content:"";background:var(--gold);width:2px;position:absolute;top:0;bottom:0;left:0}.sidebar__nav-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.sidebar__nav-count{color:var(--muted);background:var(--bg3);border-radius:var(--radius-sm);margin-left:auto;padding:1px 6px;font-size:9px}.sidebar__progress{border-top:.5px solid var(--border);padding:20px 22px 0}.sidebar__progress-label{letter-spacing:.15em;color:var(--muted);text-transform:uppercase;margin-bottom:8px;font-size:9px}.sidebar__progress-stats{justify-content:space-between;margin-bottom:8px;display:flex}.sidebar__progress-n{font-family:var(--font-serif);color:var(--gold);font-size:28px;font-weight:300;line-height:1}.sidebar__progress-total{color:var(--muted);align-self:flex-end;margin-bottom:3px;font-size:10px}.sidebar__progress-bar{background:var(--border);border-radius:2px;height:2px;overflow:hidden}.sidebar__progress-fill{background:linear-gradient(90deg, var(--gold-dim), var(--gold));height:100%;transition:width var(--transition-slow);border-radius:2px}.sidebar__user{border-top:.5px solid var(--border);flex-direction:column;gap:10px;margin-top:12px;padding:16px 22px;display:flex}.sidebar__user-info{align-items:center;gap:10px;display:flex}.sidebar__user-avatar{background:var(--bg3);border:1px solid var(--border2);width:28px;height:28px;color:var(--gold);font-size:11px;font-family:var(--font-serif);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar__user-details{flex-direction:column;gap:2px;min-width:0;display:flex}.sidebar__user-name{color:var(--cream2);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.sidebar__user-role{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;font-size:9px}.sidebar__user-logout{color:var(--muted);cursor:pointer;border:1px solid var(--border);transition:color var(--transition), background var(--transition), border-color var(--transition);background:0 0;border-radius:4px;justify-content:center;align-items:center;gap:6px;width:100%;padding:6px 12px;font-size:10px;display:flex}.sidebar__user-logout svg{flex-shrink:0;width:14px;height:14px}.sidebar__user-logout:hover{color:var(--red);border-color:var(--red);background:rgba(139,58,58,.1)}.main-content{background:var(--bg);flex-direction:column;display:flex;overflow:hidden}.main-header{border-bottom:.5px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:flex-end;padding:24px 30px 20px;display:flex}.main-header__title{font-family:var(--font-serif);letter-spacing:.02em;color:var(--cream);font-size:30px;font-weight:300;line-height:1}.main-header__date{color:var(--muted);letter-spacing:.15em;text-transform:uppercase;margin-top:5px;font-size:9px}.main-header__actions{align-items:center;gap:12px;display:flex}.main-header__search .form-input--search{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-md);width:220px;color:var(--cream);transition:var(--transition);padding:6px 12px;font-size:.85rem}.main-header__search .form-input--search::placeholder{color:var(--muted)}.main-header__search .form-input--search:focus{border-color:var(--gold-dim);outline:none;width:280px}.main-body{flex:1;padding:8px 0;overflow-y:auto}.filters{border-bottom:.5px solid var(--border);flex-shrink:0;padding:0 30px;display:flex;overflow-x:auto}.filters__tab{letter-spacing:.1em;color:var(--muted);cursor:pointer;transition:all var(--transition);text-transform:uppercase;-webkit-user-select:none;user-select:none;white-space:nowrap;background:0 0;border:none;border-bottom:1.5px solid transparent;padding:12px 16px;font-size:10px}.filters__tab:first-child{padding-left:0}.filters__tab:hover{color:var(--cream2)}.filters__tab.active{color:var(--gold);border-bottom-color:var(--gold)}.filters__toggle{flex-shrink:0;padding:4px 30px}.advanced-filters{border-bottom:.5px solid var(--border);padding:8px 30px 12px;animation:.15s fade-in}.advanced-filters__row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.form-select--sm{border:1px solid var(--border);background:var(--bg3);color:var(--cream);border-radius:var(--radius-sm);cursor:pointer;min-width:110px;padding:5px 8px;font-size:.8rem}.form-select--sm:focus{border-color:var(--gold-dim);outline:none}.export-bar{border-top:.5px solid var(--border);flex-shrink:0;justify-content:flex-end;align-items:center;gap:8px;padding:8px 30px;display:flex}.task-group-label{letter-spacing:.2em;color:var(--muted);text-transform:uppercase;padding:14px 30px 6px;font-size:8px}.task-item{cursor:pointer;border-bottom:.5px solid transparent;align-items:center;gap:14px;padding:13px 30px;transition:background .18s;animation:.3s both fadeIn;display:flex;position:relative}.task-item:hover{background:var(--bg2);border-bottom-color:var(--border)}.task-item.done .task-item__title{color:var(--muted);text-decoration:line-through}.task-item.done .task-item__meta{opacity:.5}.task-item__priority-line{opacity:0;width:2px;transition:opacity var(--transition);position:absolute;top:0;bottom:0;left:0}.task-item:hover .task-item__priority-line{opacity:1}.task-item__priority-line--critical{background:var(--red)}.task-item__priority-line--high{background:var(--gold)}.task-item__priority-line--normal{background:var(--cream2)}.task-item__priority-line--low{background:var(--green)}.task-item__check{border:1.5px solid var(--muted);cursor:pointer;width:18px;height:18px;transition:all var(--transition);background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:0;display:flex}.task-item:hover .task-item__check{border-color:var(--gold-dim)}.task-item.done .task-item__check{border-color:var(--gold);background:rgba(201,168,76,.12)}.task-item__check-tick{opacity:0;width:8px;height:8px;transition:opacity var(--transition)}.task-item.done .task-item__check-tick{opacity:1}.task-item__body{flex:1;min-width:0}.task-item__title{font-family:var(--font-serif);color:var(--cream);letter-spacing:.02em;white-space:nowrap;text-overflow:ellipsis;transition:color var(--transition);font-size:15px;font-weight:400;overflow:hidden}.task-item__meta{flex-wrap:wrap;align-items:center;gap:8px;margin-top:4px;display:flex}.task-item__sub{color:var(--muted);letter-spacing:.05em;font-size:9px}.task-item__progress{background:var(--border);border-radius:2px;width:40px;height:2px;margin-left:auto;overflow:hidden}.task-item__progress-fill{background:linear-gradient(90deg, var(--gold-dim), var(--gold));border-radius:2px;height:100%}.add-task-bar{border-top:.5px solid var(--border);background:var(--bg2);flex-shrink:0;align-items:center;gap:12px;padding:14px 30px;display:flex}.add-task-bar__input{font-family:var(--font-serif);color:var(--cream);letter-spacing:.02em;background:0 0;border:none;outline:none;flex:1;font-size:15px;font-weight:300}.add-task-bar__input::placeholder{color:var(--muted)}.add-task-bar__hint{color:var(--muted);letter-spacing:.08em;white-space:nowrap;font-size:9px}.task-detail-overlay{z-index:900;background:rgba(0,0,0,.55);animation:.2s fade-in;position:fixed;inset:0}.task-detail{background:var(--bg2);border-left:1px solid var(--border2);z-index:910;flex-direction:column;width:min(520px,90vw);height:100vh;animation:.25s slide-in-right;display:flex;position:fixed;top:0;right:0;overflow:hidden}.task-detail__header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.task-detail__header h2{font-family:var(--font-serif);color:var(--cream);text-overflow:ellipsis;white-space:nowrap;flex:1 1 0;margin:0;font-size:1.4rem;overflow:hidden}.task-detail__header-actions{flex-shrink:0;gap:.5rem;margin-left:1rem;display:flex}.task-detail__header-actions button{border:1px solid var(--border);color:var(--cream2);border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);background:0 0;padding:.35rem .65rem;font-size:.85rem}.task-detail__header-actions button:hover{border-color:var(--gold-dim);color:var(--gold2)}.task-detail__body{flex:1 1 0;padding:1.5rem;overflow-y:auto}.task-detail__section{margin-bottom:1.75rem}.task-detail__section h3{font-family:var(--font-serif);color:var(--gold);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.75rem;font-size:.85rem}.task-detail__description{color:var(--cream2);white-space:pre-wrap;font-size:.95rem;line-height:1.6}.task-detail__grid{grid-template-columns:1fr 1fr;gap:.65rem 1.25rem;display:grid}.task-detail__field{flex-direction:column;gap:.15rem;display:flex}.task-detail__field-label{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-size:.75rem}.task-detail__field-value{color:var(--cream);font-size:.9rem}.task-detail__field-value--muted{color:var(--muted);font-style:italic}.task-detail__dates{gap:1.5rem;display:flex}.task-detail__time-row{align-items:center;gap:.75rem;display:flex}.task-detail__time-row span{color:var(--cream);font-size:.9rem}.task-detail__time-row input[type=number]{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);width:5rem;color:var(--cream);padding:.3rem .5rem;font-size:.85rem}.task-detail__time-row input[type=number]:focus{border-color:var(--gold-dim);outline:none}.task-detail__progress{align-items:center;gap:.75rem;display:flex}.task-detail__progress input[type=range]{accent-color:var(--gold);flex:1 1 0}.task-detail__progress span{color:var(--cream2);text-align:right;min-width:3rem;font-size:.85rem}.task-detail__tags{flex-wrap:wrap;gap:.4rem;display:flex}.task-detail__private-note{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--cream2);white-space:pre-wrap;padding:.75rem 1rem;font-size:.9rem;position:relative}.task-detail__private-note:before{content:"🔒";font-size:.8rem;position:absolute;top:.5rem;right:.75rem}.task-detail__subtasks{flex-direction:column;gap:.4rem;display:flex}.task-detail__subtask{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);align-items:center;gap:.5rem;padding:.4rem .6rem;display:flex}.task-detail__subtask--done{opacity:.5}.task-detail__subtask--done .task-detail__subtask-title{text-decoration:line-through}.task-detail__subtask-title{color:var(--cream);text-overflow:ellipsis;white-space:nowrap;flex:1 1 0;font-size:.85rem;overflow:hidden}.task-detail__actions{border-top:1px solid var(--border);gap:.75rem;margin-top:.5rem;padding-top:.5rem;display:flex}.task-detail__actions button{border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);flex:1;padding:.6rem 1rem;font-size:.85rem}.task-detail__actions button.btn--danger{border:1px solid var(--red);color:var(--red);background:0 0}.task-detail__actions button.btn--danger:hover{background:rgba(139,58,58,.15)}.task-detail__actions button.btn--archive{border:1px solid var(--muted);color:var(--cream2);background:0 0}.task-detail__actions button.btn--archive:hover{border-color:var(--gold-dim);color:var(--gold2)}.form-tags{flex-wrap:wrap;align-items:center;gap:.35rem;display:flex}.form-tags__input-row{flex:1 0 120px;align-items:center;gap:.35rem;display:flex}.tag--removable{align-items:center;gap:.25rem;display:inline-flex}.tag--removable .tag__remove{color:inherit;cursor:pointer;opacity:.6;background:0 0;border:none;padding:0 .15rem;font-size:1rem;line-height:1}.tag--removable .tag__remove:hover{opacity:1}@keyframes slide-in-right{0%{transform:translate(100%)}to{transform:translate(0)}}.task-detail__deps{flex-direction:column;gap:6px;margin-top:6px;display:flex}.task-detail__dep{background:var(--bg2);border-radius:6px;justify-content:space-between;align-items:center;padding:6px 10px;font-size:.82rem;display:flex}.task-detail__dep-title{color:var(--text);font-weight:500}.task-item-wrapper{transition:opacity .15s,transform .15s}.task-item-wrapper[draggable=true]{cursor:grab}.task-item-wrapper:active{cursor:grabbing;opacity:.6}.task-item-wrapper.drag-over{border-top:2px solid var(--accent)}.tag{letter-spacing:.12em;text-transform:uppercase;border-radius:var(--radius-sm);font-size:8px;font-family:var(--font-mono);padding:2px 7px;display:inline-block}.tag--critical{color:#e08080;background:rgba(139,58,58,.25)}.tag--high{color:var(--gold);background:rgba(201,168,76,.15)}.tag--normal{color:var(--cream2);background:rgba(200,194,180,.12)}.tag--low{color:#6db890;background:rgba(46,94,69,.25)}.tag--cat{color:#7a9ed4;background:rgba(42,63,107,.35)}.tag--type{color:var(--gold-dim);background:rgba(201,168,76,.08)}.tag--horizon{color:var(--muted);background:rgba(90,87,80,.25)}.tag--done{color:#6db890;background:rgba(46,94,69,.25)}.tag--archived{color:var(--muted);background:rgba(90,87,80,.25)}.tag--outline{border:1px solid var(--border2);color:var(--cream2);background:0 0}.tag--xs{padding:1px 5px;font-size:7px}.btn{font-family:var(--font-mono);border-radius:var(--radius-md);cursor:pointer;letter-spacing:.08em;transition:all var(--transition);text-transform:uppercase;border:none;align-items:center;gap:6px;padding:8px 16px;font-size:10px;display:inline-flex}.btn:active{transform:translateY(0)}.btn--primary{background:var(--gold);color:var(--bg)}.btn--primary:hover{background:var(--gold2);transform:translateY(-1px)}.btn--secondary{color:var(--cream2);border:.5px solid var(--border2);background:0 0}.btn--secondary:hover{color:var(--gold);border-color:var(--gold)}.btn--danger{color:#e08080;background:rgba(139,58,58,.2)}.btn--ghost{color:var(--muted);background:0 0;padding:6px 10px}.btn--ghost:hover{color:var(--cream2)}.btn--sm{padding:5px 10px;font-size:9px}.btn--lg{padding:10px 24px;font-size:11px}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important}.form-group{margin-bottom:20px}.form-label{letter-spacing:.15em;text-transform:uppercase;color:var(--muted);margin-bottom:6px;font-size:9px;display:block}.form-input,.form-select,.form-textarea{background:var(--bg);border:.5px solid var(--border2);border-radius:var(--radius-md);width:100%;color:var(--cream);font-family:var(--font-mono);transition:border-color var(--transition);outline:none;padding:10px 14px;font-size:12px}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--gold)}.form-input::placeholder{color:var(--muted)}.form-textarea::placeholder{color:var(--muted)}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%235A5750'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:32px}.form-select option{background:var(--bg2);color:var(--cream)}.form-textarea{resize:vertical;min-height:80px}.form-hint{color:var(--muted);margin-top:4px;font-size:9px}.form-error{color:#e08080;margin-top:4px;font-size:9px}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-actions{border-top:.5px solid var(--border);justify-content:center;gap:10px;margin-top:24px;margin-bottom:1.5rem;padding-top:16px;display:flex}.form-checkbox{cursor:pointer;align-items:center;gap:8px;display:flex}.form-checkbox input[type=checkbox]{appearance:none;border:1.5px solid var(--muted);cursor:pointer;width:14px;height:14px;transition:all var(--transition);border-radius:3px;position:relative}.form-checkbox input[type=checkbox]:checked{border-color:var(--gold);background:rgba(201,168,76,.12)}.form-checkbox input[type=checkbox]:checked:after{content:"";border:solid var(--gold);border-width:0 1.5px 1.5px 0;width:5px;height:8px;position:absolute;top:1px;left:3px;transform:rotate(45deg)}.form-checkbox-label{color:var(--cream2);font-size:11px}.form-range{align-items:center;gap:12px;display:flex}.form-range input[type=range]{appearance:none;background:var(--border);border-radius:2px;outline:none;flex:1;height:2px}.form-range input[type=range]::-webkit-slider-thumb{appearance:none;background:var(--gold);cursor:pointer;border-radius:50%;width:12px;height:12px}.form-range__value{color:var(--gold);text-align:right;min-width:30px;font-size:11px}.auth-card{border:.5px solid var(--border2);border-radius:var(--radius-lg);background:var(--bg2);width:100%;max-width:400px;padding:48px 40px}.auth-card__logo{text-align:center;margin-bottom:40px}.auth-card__logo-title{font-family:var(--font-serif);color:var(--gold);letter-spacing:.08em;font-size:32px;font-weight:300}.auth-card__logo-sub{color:var(--muted);letter-spacing:.25em;text-transform:uppercase;margin-top:4px;font-size:9px}.auth-card__title{font-family:var(--font-serif);color:var(--cream);text-align:center;margin-bottom:24px;font-size:20px;font-weight:300}.auth-card__subtitle{color:var(--cream2);text-align:center;margin-bottom:24px;font-size:10px;line-height:1.6}.auth-card__error{color:#e08080;border-radius:var(--radius-md);text-align:center;background:rgba(139,58,58,.15);border:.5px solid rgba(139,58,58,.3);margin-bottom:20px;padding:10px 14px;font-size:10px}.auth-card .form-input{background:var(--bg)}.auth-card .btn--primary{justify-content:center;width:100%;padding:12px;font-size:11px}.auth-card__back{text-align:center;width:100%;margin-top:12px;font-size:10px}.form-input--totp{text-align:center;font-family:var(--font-mono);letter-spacing:.5em;padding:16px;font-size:24px}.totp-setup{background:var(--bg2);border:.5px solid var(--border2);border-radius:var(--radius-lg);max-width:520px;margin:60px auto;padding:40px}.totp-setup__title{font-family:var(--font-serif);color:var(--cream);margin-bottom:28px;font-size:22px;font-weight:300}.totp-setup__status{align-items:flex-start;gap:14px;margin-bottom:28px;display:flex}.totp-setup__status p{color:var(--cream2);font-size:10px;line-height:1.8}.totp-setup__badge{font-size:9px;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;border-radius:var(--radius-sm);flex-shrink:0;padding:4px 10px}.totp-setup__badge--on{color:#6db890;background:rgba(46,94,69,.25);border:.5px solid rgba(109,184,144,.4)}.totp-setup__badge--off{border:.5px solid var(--muted);color:var(--cream2);background:rgba(90,87,80,.25)}.totp-setup__qr{margin-bottom:32px}.totp-setup__step{font-family:var(--font-serif);color:var(--cream);margin-bottom:10px;font-size:15px;font-weight:400}.totp-setup__hint{color:var(--cream2);margin-bottom:16px;font-size:10px;line-height:1.6}.totp-setup__qr-img{border-radius:var(--radius-md);border:.5px solid var(--border2);background:#fff;width:200px;height:200px;margin:20px auto;padding:8px;display:block}.totp-setup__manual{margin-top:12px}.totp-setup__manual summary{color:var(--gold);cursor:pointer;letter-spacing:.05em;font-size:9px}.totp-setup__secret{font-family:var(--font-mono);color:var(--cream2);background:var(--bg);border-radius:var(--radius-sm);word-break:break-all;margin-top:8px;padding:10px;font-size:9px;display:block}.totp-setup__verify{margin-top:24px}.totp-setup__disable{margin-top:16px}.totp-setup__actions{gap:10px;display:flex}.totp-setup__msg{border-radius:var(--radius-md);text-align:center;margin-bottom:20px;padding:10px 14px;font-size:10px}.totp-setup__msg--ok{color:#6db890;background:rgba(46,94,69,.15);border:.5px solid rgba(109,184,144,.3)}.totp-setup__msg--err{color:#e08080;background:rgba(139,58,58,.15);border:.5px solid rgba(139,58,58,.3)}.btn--ghost{border:.5px solid var(--muted);color:var(--cream2);border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);background:0 0;padding:8px 16px;font-size:10px}.btn--ghost:hover{border-color:var(--gold);color:var(--cream)}.btn--danger{background:var(--red);color:var(--cream);border-radius:var(--radius-sm);cursor:pointer;border:none;padding:8px 16px;font-size:10px}.btn--danger:hover{filter:brightness(1.15)}.btn--danger-outline{border:.5px solid var(--red);color:#e08080;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);background:0 0;padding:8px 16px;font-size:10px}.btn--danger-outline:hover{background:rgba(139,58,58,.1)}.modal-overlay{z-index:1000;background:rgba(12,12,11,.8);justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--bg2);border:.5px solid var(--border2);border-radius:var(--radius-lg);width:100%;max-width:560px;max-height:85vh;padding:32px;animation:.2s modalIn;overflow-y:auto}.modal__header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.modal__title{font-family:var(--font-serif);font-size:22px;font-weight:300}.modal__close{color:var(--muted);cursor:pointer;transition:color var(--transition);background:0 0;border:none;padding:4px;font-size:18px}.modal__close:hover{color:var(--cream)}.modal__body{margin-bottom:24px}.modal__footer{justify-content:flex-end;gap:10px;display:flex}@keyframes modalIn{0%{opacity:0;transform:scale(.97)translateY(8px)}to{opacity:1;transform:none}}.toast-container{z-index:2000;flex-direction:column;gap:8px;display:flex;position:fixed;top:20px;right:20px}.toast{background:var(--bg2);border:.5px solid var(--border2);border-radius:var(--radius-md);color:var(--cream2);align-items:center;gap:10px;min-width:280px;max-width:400px;padding:12px 18px;font-size:11px;animation:.3s toastIn;display:flex}.toast--success{border-left:2px solid var(--green)}.toast--error{border-left:2px solid var(--red)}.toast--info{border-left:2px solid var(--gold)}.toast__close{color:var(--muted);cursor:pointer;background:0 0;border:none;margin-left:auto;font-size:14px}@keyframes toastIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:none}}.empty-state{height:100%;min-height:200px;color:var(--muted);flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:40px;display:flex}.empty-state__icon{opacity:.4;font-size:28px;font-family:var(--font-serif)}.empty-state__text{letter-spacing:.1em;font-size:11px}.empty-state__action{margin-top:12px}.loading{justify-content:center;align-items:center;height:100%;min-height:100px;display:flex}.loading__spinner{border:1.5px solid var(--border);border-top-color:var(--gold);border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.admin-layout{grid-template-columns:200px 1fr;height:100%;display:grid}.admin-sidebar{background:var(--bg2);border-right:.5px solid var(--border);padding:20px 0}.admin-sidebar__title{letter-spacing:.2em;text-transform:uppercase;color:var(--muted);padding:0 16px 12px;font-size:9px}.admin-sidebar__item{text-align:left;width:100%;color:var(--cream2);cursor:pointer;transition:all var(--transition);background:0 0;border:none;padding:8px 16px;font-size:11px;display:block}.admin-sidebar__item:hover{color:var(--gold);background:rgba(201,168,76,.04)}.admin-sidebar__item.active{color:var(--gold);background:rgba(201,168,76,.08)}.admin-content{padding:24px 30px;overflow-y:auto}.admin-content__header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.admin-content__title{font-family:var(--font-serif);font-size:24px;font-weight:300}.data-table{border-collapse:collapse;width:100%}.data-table th{letter-spacing:.2em;text-transform:uppercase;color:var(--muted);text-align:left;border-bottom:.5px solid var(--border2);padding:10px 12px;font-size:8px}.data-table td{color:var(--cream2);border-bottom:.5px solid var(--border);padding:10px 12px;font-size:11px}.data-table tr:hover td{background:rgba(201,168,76,.03)}.data-table__actions{gap:6px;display:flex}.data-table__badge{border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.1em;padding:2px 6px;font-size:8px}.data-table__badge--active{color:#6db890;background:rgba(46,94,69,.25)}.data-table__badge--inactive{color:#e08080;background:rgba(139,58,58,.2)}.admin-stats{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:24px;display:grid}.admin-stat-card{background:var(--bg2);border:.5px solid var(--border);border-radius:var(--radius-md);padding:16px}.admin-stat-card__label{letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:6px;font-size:8px}.admin-stat-card__value{font-family:var(--font-serif);color:var(--gold);font-size:28px;font-weight:300}.admin-whitelist__info{margin-bottom:20px}.admin-whitelist__hint{color:var(--cream2);margin-bottom:8px;font-size:11px;line-height:1.6}.admin-whitelist__hint strong{color:var(--gold)}.admin-whitelist__current-ip{color:var(--muted);font-size:11px}.admin-whitelist__current-ip code{font-family:var(--font-mono,"DM Mono", monospace);color:var(--cream);background:var(--bg3);border-radius:3px;padding:2px 6px}.admin-whitelist__form{margin-bottom:20px}.admin-whitelist__form-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.admin-whitelist__form-row .form-input{flex:1;min-width:160px}.admin-whitelist__error{color:var(--red);background:rgba(139,58,58,.1);border:1px solid rgba(139,58,58,.3);border-radius:4px;margin-bottom:16px;padding:8px 12px;font-size:11px}.admin-whitelist__success{color:var(--green,#6db890);background:rgba(109,184,144,.1);border:1px solid rgba(109,184,144,.3);border-radius:4px;margin-bottom:16px;padding:8px 12px;font-size:11px}.admin-whitelist__empty{color:var(--muted);text-align:center;border:1px dashed var(--border);border-radius:4px;padding:32px;font-size:11px}.btn--danger{color:var(--red)}.btn--danger:hover{background:rgba(139,58,58,.15)}