:root{--brand: #6b46c1;--brand-600: #5333a2;--brand-700: #432a86;--brand-800: #36226d;--bg: #f4f6fb;--bg-rgb: 244, 246, 251;--bg-soft: #edf0f7;--bg-elevated: #ffffff;--card: #ffffff;--ink: #0c1322;--ink-strong: #0a0f1c;--ink-soft: #3a4657;--muted: #6b7280;--border: #d9deea;--border-strong: #c6ccdb;--success: #16a34a;--danger: #d61f40;--warning: #b45309;--thead: #eee9ff;--row-hover: #efeaff;--focus: rgba(107, 70, 193, .45);--ring: 0 0 0 4px rgba(107, 70, 193, .2);--shadow-sm: 0 1px 2px rgba(2, 8, 23, .08);--shadow-md: 0 8px 24px rgba(2, 8, 23, .1);--shadow-lg: 0 18px 48px rgba(2, 8, 23, .12);--radius-sm: 10px;--radius-md: 14px;--radius-lg: 18px;--gap: 16px}html{scrollbar-gutter:stable;overflow-y:scroll;color-scheme:light}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--ink-strong);font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}a{color:var(--brand-700);text-decoration:none}a:hover{text-decoration:underline}img,svg{display:block}:focus-visible{outline:none;box-shadow:var(--ring);border-radius:8px}html{scroll-behavior:smooth}*{scrollbar-width:thin;scrollbar-color:rgba(17,24,39,.3) transparent}*::-webkit-scrollbar{height:10px;width:10px}*::-webkit-scrollbar-thumb{background:#1118274d;border-radius:999px}*::-webkit-scrollbar-track{background:transparent}.login-page{min-height:100vh;display:flex;justify-content:center;align-items:center}.container{max-width:1200px;margin:0 auto;padding:24px}.page-gap{padding:24px}.hide-scrollbar{scrollbar-width:none}.hide-scrollbar::-webkit-scrollbar{display:none}h1,h2,h3{color:var(--ink-strong);letter-spacing:-.01em}input,textarea,select{color:var(--ink-strong)}input::placeholder,textarea::placeholder{color:var(--muted)}input:focus,textarea:focus,select:focus{outline:none;box-shadow:0 0 0 4px var(--focus);border-color:var(--brand-600)!important}.modal-overlay{position:fixed;inset:0;background:linear-gradient(0deg,#0c111c8c,#0c111c8c);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.text-muted{color:var(--ink-soft)}.text-strong{color:var(--ink-strong)}:root{--violet-50: #f3e8ff;--violet-100: #e9d5ff;--violet-200: #d8b4fe;--violet-300: #c084fc;--violet-400: #a78bfa;--violet-500: #8b5cf6;--violet-600: #7c3aed;--violet-700: #6d28d9;--violet-800: #5b21b6;--accent: var(--violet-500);--accent-hi: var(--violet-400);--accent-lo: var(--violet-600);--ink: var(--violet-50);--ink-dim: var(--violet-100);--glass-border: rgba(216, 180, 254, .45);--glass-fill: rgba(216, 180, 254, .12);--glass-fill-hi:rgba(216, 180, 254, .18);--neon-shadow: 0 0 0px rgba(139,92,246,0), 0 6px 22px rgba(139,92,246,.35), 0 0 38px rgba(124,58,237,.3);--neon-shadow-strong: 0 0 0px rgba(139,92,246,0), 0 8px 26px rgba(139,92,246,.45), 0 0 48px rgba(124,58,237,.4)}.login-page{position:relative;overflow:hidden;height:100vh;display:flex;justify-content:center;align-items:center;background:transparent}.login-page:before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;background:var(--login-bg-image, url(/auth-bg.jpg)) center / cover no-repeat fixed;filter:saturate(1.03) contrast(1.04)}.login-container{position:relative;z-index:1;background:var(--glass-fill);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--glass-border);border-radius:20px;background-clip:padding-box;box-shadow:0 8px 28px #5c16ba59,0 0 34px #7c3aed47;padding:80px 40px 40px;width:100%;max-width:400px;text-align:center;color:var(--ink);text-shadow:0 1px 0 rgba(0,0,0,.25)}.login-container:focus-within{border-color:#d8b4fea6;box-shadow:var(--neon-shadow-strong)}.login-page,.login-container{animation:none!important;transition:none!important}.brand-badge{display:inline-block;padding:10px 34px;background:linear-gradient(145deg,#d8b4fe59,#7c3aed4d);border:1px solid rgba(216,180,254,.55);border-radius:0 0 20px 20px;font-size:22px;font-weight:800;color:var(--ink);letter-spacing:.3px;box-shadow:var(--neon-shadow);position:absolute;top:0;left:50%;transform:translate(-50%);text-shadow:0 2px 12px rgba(139,92,246,.55)}.brand-subtitle{font-size:15px;color:var(--ink-dim);margin-bottom:25px;text-shadow:0 0 18px rgba(168,85,247,.35)}.login-form{display:flex;flex-direction:column;gap:18px;margin-top:10px}.input-group{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:14px;color:var(--accent-hi);opacity:.95;filter:drop-shadow(0 0 8px rgba(139,92,246,.55))}.login-input{width:100%;padding:12px 14px 12px 40px;border:1px solid rgba(216,180,254,.55);border-radius:30px;background:#d8b4fe1f;font-size:14px;color:var(--ink);outline:none;transition:.25s ease;box-shadow:inset 0 0 #0000}.login-input::placeholder{color:#f3e8ffb3}.login-input:focus{border-color:var(--accent-hi);background:var(--glass-fill-hi);box-shadow:0 0 0 3px #8b5cf638,0 0 22px #8b5cf659}.login-button{margin-top:15px;padding:12px;border-radius:30px;border:1px solid rgba(216,180,254,.6);background:linear-gradient(135deg,var(--accent-hi),var(--accent-lo));color:#fff;font-weight:700;font-size:15px;cursor:pointer;transition:transform .15s ease,box-shadow .2s ease,filter .2s ease;box-shadow:0 8px 22px #8b5cf659,0 0 36px #7c3aed59;text-shadow:0 1px 0 rgba(0,0,0,.2)}.login-button:hover{filter:brightness(1.05);transform:translateY(-2px);box-shadow:0 10px 28px #8b5cf673,0 0 44px #7c3aed73}.login-button:active{transform:translateY(0);filter:brightness(.98)}.login-button:disabled{background:linear-gradient(135deg,#8b5cf673,#7c3aed73);color:#ffffffb3;cursor:not-allowed;box-shadow:none}.forgot-password-link{font-size:13px;color:var(--accent-hi);text-align:right;cursor:pointer;transition:.2s ease;text-shadow:0 0 10px rgba(139,92,246,.45)}.forgot-password-link:hover{color:#fff;text-decoration:underline}.register-text{margin-top:20px;font-size:13px;color:var(--ink-dim)}.register-text span{color:var(--accent-hi);cursor:pointer;font-weight:700;transition:.2s ease;text-shadow:0 0 10px rgba(139,92,246,.45)}.register-text span:hover{color:#fff;text-decoration:underline}.login-error{font-size:13px;color:#ff6b6b;margin-top:-10px}.mfa-toggle-tabs{display:flex;justify-content:space-between;margin:20px 0;gap:8px}.mfa-tab{flex:1;margin:0;padding:10px;border-radius:20px;border:1px solid rgba(216,180,254,.55);background:#d8b4fe1a;color:var(--ink);cursor:pointer;transition:.2s ease}.mfa-tab:hover{box-shadow:0 0 0 2px #8b5cf638}.mfa-tab.active{background:linear-gradient(135deg,var(--accent-hi),var(--accent-lo));color:#fff;font-weight:700;box-shadow:0 6px 18px #8b5cf659}.qr-box{background:#d8b4fe1a;padding:15px;border-radius:12px;margin:10px auto;display:inline-block;border:1px solid rgba(216,180,254,.35);box-shadow:0 0 24px #8b5cf640}.qr-box img{width:150px;height:150px}.mfa-secret-key{background:#d8b4fe2e;padding:8px 12px;border-radius:8px;font-family:monospace;margin:8px 0;display:inline-block;color:var(--ink);border:1px solid rgba(216,180,254,.45)}.mfa-steps{padding-left:18px;text-align:left;margin-bottom:10px;color:var(--ink-dim)}.mfa-steps li b{color:var(--ink)}.password-checklist{list-style:none;padding:0;margin-top:15px;text-align:left}.password-checklist li{font-size:13px;margin-bottom:6px}.password-checklist li.valid{color:#4caf50}.password-checklist li.invalid{color:#ff6b6b}.snackbar-error{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background:#f44;color:#fff;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:500;box-shadow:0 6px 18px #0006;animation:fadeIn .3s,fadeOut .3s 2.7s}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeOut{0%{opacity:1;transform:translate(-50%)}to{opacity:0;transform:translate(-50%,20px)}}.login-label{display:block;text-align:left;font-size:14px;margin:8px 0 4px 4px;color:var(--ink-dim);text-shadow:0 0 14px rgba(139,92,246,.35)}.button-row{display:flex;justify-content:space-between;gap:12px;margin-top:20px}@media(max-width:720px){.login-page:before{background:var(--login-bg-image, url(/auth-bg.jpg)) center / cover no-repeat fixed}}@media(prefers-reduced-motion:reduce){.login-page:before{background:var(--login-bg-image, url(/auth-bg.jpg)) center / cover no-repeat}}a.skip-link,a[href="#main"],a[href="#content"],a[href="#skip-to-content"],a[href="#skip"]{position:absolute!important;left:-9999px!important;top:auto!important;width:1px!important;height:1px!important;overflow:hidden!important}.sidebar{display:flex;flex-direction:column;justify-content:space-between;height:100vh;background:radial-gradient(800px 300px at 100% 0%,#2a2b48 0%,transparent 60%),#1a1b2e;color:#fff;overflow:hidden;transition:width .3s ease;width:230px;box-shadow:2px 0 10px #00000040}.sidebar.collapsed{width:74px}.sidebar-header{display:flex;align-items:center;padding:16px;border-bottom:1px solid rgba(255,255,255,.07);position:relative}.sidebar-title{font-size:20px;font-weight:800;margin-left:14px;letter-spacing:.02em;transition:opacity .3s ease,transform .3s ease;color:#fff}.sidebar-logo-highlight{color:var(--brand, #6b46c1);font-weight:900}.sidebar-logo-core{color:#fff}.sidebar.collapsed .sidebar-title{opacity:0;visibility:hidden;transform:translate(-10px)}.sidebar-toggle{width:36px;height:36px;background:linear-gradient(180deg,#3a3b5a,#2c2d49);color:#fff;border-radius:10px;cursor:pointer;font-size:16px;display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.08);transition:transform .1s ease,box-shadow .2s ease,filter .2s ease}.sidebar-toggle:hover{transform:translateY(-1px);box-shadow:0 6px 18px #00000040;filter:brightness(1.05)}.sidebar-toggle:active{transform:translateY(0)}.sidebar-nav{flex-grow:1;padding:10px 0}.sidebar-nav ul{list-style:none;padding:0;margin:0}.sidebar-nav-item{margin:4px 10px}.sidebar-link-wrapper{display:flex;align-items:center;gap:12px;color:inherit;text-decoration:none;width:100%;padding:10px 12px;border-radius:12px;position:relative;transition:background-color .2s ease,transform .06s ease,box-shadow .2s ease,color .2s ease;border:1px solid transparent}.sidebar-link-wrapper:hover{background-color:#ffffff0f;transform:translateY(-1px);box-shadow:0 6px 20px #0000002e}.sidebar-link-wrapper.active{background:linear-gradient(180deg,#ffffff17,#ffffff0f);border:1px solid rgba(255,255,255,.14);box-shadow:inset 0 0 0 1px #ffffff0f,0 10px 30px #00000040}.sidebar-link-wrapper.active:before{content:"";position:absolute;left:-2px;top:8px;bottom:8px;width:4px;border-radius:999px;background:linear-gradient(180deg,var(--brand, #6b46c1) 0%,#5a3bab 100%)}.sidebar-icon{font-size:18px;inline-size:28px;display:inline-grid;place-items:center}.sidebar-link{font-size:15px;font-weight:700;color:#f8fafc;transition:opacity .3s ease,transform .3s ease,color .2s ease}.sidebar.collapsed .sidebar-icon{margin-right:0}.sidebar.collapsed .sidebar-link{opacity:0;visibility:hidden;transform:translate(-10px)}.sidebar.collapsed .sidebar-nav-item .sidebar-link-wrapper{justify-content:center;padding:10px}.sidebar-footer{padding:14px;border-top:1px solid rgba(255,255,255,.07);display:flex;flex-direction:column;gap:10px}.sidebar-profile{display:flex;align-items:center;border-radius:12px;padding:8px 10px;background:linear-gradient(180deg,#ffffff0d,#ffffff08);border:1px solid rgba(255,255,255,.08)}.sidebar-profile-icon{width:36px;height:36px;background:linear-gradient(180deg,#3a3b5a,#2c2d49);border-radius:10px;display:grid;place-items:center;font-size:16px;border:1px solid rgba(255,255,255,.08)}.sidebar-profile-text{margin-left:10px;transition:opacity .3s ease,transform .3s ease}.sidebar-profile-name{font-size:14px;font-weight:800;color:#fff}.sidebar-profile-subtext{font-size:12px;color:#c8cbe8}.sidebar.collapsed .sidebar-profile-text{opacity:0;visibility:hidden;transform:translate(-10px)}.sidebar-logout-btn{display:flex;align-items:center;gap:10px;border:1px solid rgba(239,68,68,.25);background:linear-gradient(180deg,#ef444426,#ef44441a);color:#fee2e2;padding:10px 12px;border-radius:12px;font-weight:800;cursor:pointer;transition:transform .06s ease,box-shadow .2s ease,background .2s ease,border-color .2s ease}.sidebar-logout-btn:hover{transform:translateY(-1px);box-shadow:0 8px 24px #ef444440;background:linear-gradient(180deg,#ef44442e,#ef44441f);border-color:#ef444473}.sidebar-logout-btn:active{transform:translateY(0)}.logout-icon{font-size:16px}.logout-text{font-size:14px}.hidden{display:inline-block;width:0;height:0;overflow:hidden;opacity:0}.main-layout{display:grid;grid-template-columns:280px 1fr;min-height:100vh;background:radial-gradient(900px 420px at 100% 0%,rgba(111,76,217,.12) 0%,transparent 45%),var(--bg);color:var(--ink-strong);overflow:hidden;position:relative}.skip-link{position:absolute;left:12px;top:-40px;z-index:1000;padding:10px 14px;background:#fff;border:2px solid var(--brand-700);border-radius:10px;color:var(--brand-800);font-weight:800;box-shadow:var(--shadow-sm);transition:top .15s ease}.skip-link:focus{top:12px;box-shadow:var(--shadow-md)}.main-layout .main-content{position:relative;min-width:0;min-height:0;padding:24px;overflow:auto;color:var(--ink-strong);background:linear-gradient(90deg,rgba(var(--bg-rgb),1),rgba(var(--bg-rgb),.85),rgba(var(--bg-rgb),.35) 36px,rgba(var(--bg-rgb),0) 72px),radial-gradient(1000px 640px at 6% -10%,#7c6ef94d,#7c6ef900 62%),radial-gradient(900px 620px at 106% -12%,#60a5fa42,#60a5fa00 64%),radial-gradient(820px 560px at 104% 106%,#34d39938,#34d39900 66%),linear-gradient(180deg,#fffffff0,#fffffff7,#fff)}.main-layout .main-content>*{position:relative;z-index:1}#content:focus{outline:none;box-shadow:var(--ring);border-radius:12px}.otp-inputs{display:grid;grid-auto-flow:column;gap:10px;justify-content:center}.otp-box{width:44px;height:50px;text-align:center;font-size:20px;font-weight:700;border-radius:12px;border:1px solid var(--border-strong, #d1d5db);background:linear-gradient(180deg,#fff,#f9fafb);color:var(--ink-strong, #0b1324);outline:none;transition:box-shadow .15s ease,transform .06s ease}.otp-box:focus{box-shadow:0 0 0 3px #6b46c140;border-color:#6b46c1}.login-page .otp-box{background:var(--bg-elevated, #fff)}.core-shell{position:relative;max-width:1200px;margin:0 auto;padding:8px 24px 24px;display:grid;grid-template-rows:240px 1fr;gap:16px;overflow:hidden;min-height:min(680px,calc(100vh - 120px));border-radius:var(--radius-lg)}.core-bg{position:absolute;inset:0;pointer-events:none;z-index:0;border-radius:inherit;-webkit-mask-image:radial-gradient(120% 120% at 50% 50%,#000 72%,rgba(0,0,0,0) 100%);mask-image:radial-gradient(120% 120% at 50% 50%,#000 72%,#0000);-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}.core-shell>*:not(.core-bg){position:relative;z-index:1}.aurora{position:absolute;inset:auto;filter:blur(48px);opacity:.7;pointer-events:none}.aurora.a1{width:540px;height:540px;left:-140px;top:-80px;background:radial-gradient(50% 50% at 50% 50%,#7c6ef9,#7c6ef900 70%),radial-gradient(50% 50% at 70% 60%,#d18dfd,#d18dfd00 60%);mix-blend-mode:multiply}.aurora.a2{width:560px;height:560px;right:-160px;bottom:-120px;background:radial-gradient(50% 50% at 50% 50%,#60a5fa,#60a5fa00 70%),radial-gradient(50% 50% at 40% 40%,#34d399,#34d39900 60%);mix-blend-mode:multiply}.grain{position:absolute;inset:-50px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140' viewBox='0 0 100 100'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.95' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3CfeComponentTransfer%3E%3CfeFuncA type='table' tableValues='0 0 .03 .06 .03 0'/%3E%3C/feComponentTransfer%3E%3CfeBlend mode='overlay'/%3E%3C/filter%3E%3Crect filter='url(%23n)' width='100%' height='100%'/%3E%3C/svg%3E");opacity:.15;pointer-events:none}.card{position:relative;border-radius:var(--radius-lg);border:1px solid var(--border-strong);background:linear-gradient(180deg,#fffc,#fff 30%) padding-box,#0000;box-shadow:var(--shadow-lg)}.hero{display:grid;grid-template-columns:1.2fr .8fr;align-items:center;padding:22px 24px;overflow:hidden}.hero-text .eyebrow{display:inline-block;font-size:13px;font-weight:900;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft)}.hero-title{margin:6px 0;font-weight:1000;letter-spacing:-.02em;line-height:1.02;font-size:clamp(28px,3.2vw,44px);background:linear-gradient(92deg,#111827 0%,#3f3f46 38%,var(--brand-700) 100%);-webkit-background-clip:text;background-clip:text;color:transparent}.hero-sub{margin:4px 0 0;color:var(--ink-strong);opacity:.85;font-weight:600}.hero-orb{position:relative;height:180px}.orb{position:absolute;border-radius:50%;filter:blur(10px);opacity:.9}.orb.o1{width:140px;height:140px;right:14px;top:10px;background:radial-gradient(50% 50% at 50% 50%,#8b5cf6,#8b5cf600 70%)}.orb.o2{width:110px;height:110px;right:120px;bottom:18px;background:radial-gradient(50% 50% at 50% 50%,#60a5fa,#60a5fa00 70%)}.ring{position:absolute;border-radius:999px;border:1px dashed rgba(107,70,193,.4)}.ring.r1{width:160px;height:160px;right:6px;top:2px;animation:spin 14s linear infinite}.ring.r2{width:196px;height:196px;right:90px;bottom:-6px;animation:spin 22s linear infinite reverse}@keyframes spin{to{transform:rotate(360deg)}}.module-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.module-card{position:relative;display:grid;grid-template-rows:42px auto auto;align-content:start;gap:6px;padding:16px;border-radius:16px;text-decoration:none;color:var(--ink-strong);background:linear-gradient(180deg,#fff,#f6f7ff);border:1px solid var(--border-strong);box-shadow:var(--shadow-md);transition:transform .08s ease,box-shadow .2s ease,filter .2s ease;overflow:hidden;isolation:isolate}.module-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);filter:brightness(1.01)}.module-icon{display:grid;place-items:center;inline-size:42px;block-size:42px;border-radius:12px;background:#fff;border:1px solid rgba(107,70,193,.28);font-size:18px;color:var(--brand-700);font-weight:900}.module-title{font-weight:1000;letter-spacing:-.01em}.module-sub{color:var(--ink-soft);font-weight:700}.module-border{content:"";position:absolute;inset:-1px;border-radius:18px;background:conic-gradient(from 180deg,#8b5cf6,#60a5fa,#34d399,#8b5cf6);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;padding:1px;opacity:0;transition:opacity .2s ease;z-index:-1}.module-glow{content:"";position:absolute;inset:-30%;background:radial-gradient(40% 40% at 70% 20%,rgba(139,92,246,.2),transparent 60%),radial-gradient(40% 40% at 20% 80%,rgba(96,165,250,.18),transparent 60%);filter:blur(12px);opacity:0;transition:opacity .2s ease;z-index:-2}.module-card:hover .module-border{opacity:.45}.module-card:hover .module-glow{opacity:1}@media(max-width:1100px){.hero{grid-template-columns:1fr}.hero-orb{display:none}}@media(max-width:980px){.module-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:560px){.core-shell{grid-template-rows:auto auto}.module-grid{grid-template-columns:1fr}}.article-table-section{padding:24px;background:transparent}.article-table-container{max-width:1200px;margin:0 auto}.article-table-wrapper{width:100%}.article-table-content{width:100%;overflow:auto;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:1px solid var(--border-strong);background:linear-gradient(180deg,#fffffff2,#fff 60%),var(--card)}.article-table{width:100%;border-collapse:separate;border-spacing:0;background:transparent;table-layout:auto}.article-table thead th{position:-webkit-sticky;position:sticky;top:0;z-index:2;background:linear-gradient(0deg,#fffffff0,#fffffff0),linear-gradient(180deg,var(--thead) 0%,#fff 100%);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);text-align:left;font-weight:900;letter-spacing:.01em;color:#0f172a;border-bottom:1px solid var(--border-strong);padding:14px 16px;font-size:13px;white-space:nowrap;box-shadow:inset 0 -1px #0000000a}.article-table td{padding:14px 16px;font-size:14px;color:var(--ink-strong);border-bottom:1px solid var(--border);background:#fff}.article-table tbody tr:nth-child(odd) td{background:#f7f6ff}.article-table tbody tr:hover td{background:var(--row-hover)}.article-table thead th:first-child,.article-table tbody td:first-child{border-left:1px solid var(--border-strong)}.article-table thead th:last-child,.article-table tbody td:last-child{border-right:1px solid var(--border-strong)}.article-table .empty-state{text-align:center;color:var(--ink-soft);background:linear-gradient(180deg,#fff,#f4f1ff);font-weight:600}.lightbox-content{background:#fff;color:var(--ink-strong);padding:24px;border-radius:16px;width:420px;max-width:92%;text-align:center;position:relative;border:1px solid var(--border-strong);box-shadow:var(--shadow-lg);animation:reveal-up .28s ease-out both;max-height:calc(100vh - 80px);overflow:auto}.lightbox-title{font-size:20px;font-weight:900;margin-bottom:16px}.lightbox-close-button{position:absolute;top:12px;right:16px;background:none;border:none;font-size:24px;cursor:pointer;color:inherit}.lightbox-form{display:flex;flex-direction:column;align-items:center;gap:12px}.lightbox-label{font-weight:800}.lightbox-input{width:160px;padding:10px 12px;font-size:16px;text-align:center;border:1px solid var(--border-strong);border-radius:10px;background:#fff}.lightbox-input.dark{background:#111827;border-color:#374151;color:#f8fafc}.create-button{background:linear-gradient(180deg,var(--brand) 0%,var(--brand-600) 100%);color:#fff;padding:10px 16px;border:none;border-radius:12px;font-weight:800;cursor:pointer;box-shadow:var(--shadow-md)}.lexoffice-sync-container{display:flex;justify-content:center;margin-top:8px}.lexoffice-sync-button{display:inline-flex;align-items:center;gap:10px;background:linear-gradient(180deg,var(--brand) 0%,var(--brand-600) 100%);color:#fff;border:none;border-radius:12px;padding:12px 20px;font-weight:800;box-shadow:var(--shadow-md);cursor:pointer}.lexoffice-sync-button:hover{filter:brightness(1.03);transform:translateY(-1px);box-shadow:var(--shadow-lg);transition:all .2s ease}.spinner-slot{font-size:14px;opacity:.9}.loading-bar{position:relative;width:100%;height:0;overflow:hidden;border-radius:999px}.loading-bar.active{height:var(--lb-height, 3px);background:linear-gradient(90deg,#432a861a,#6b46c129);box-shadow:inset 0 1px #ffffff59}.loading-bar.active:before{content:"";position:absolute;inset:0;width:40%;transform:translate(-60%);background:linear-gradient(90deg,transparent 0%,#6b46c1 45%,#7a56d1 55%,transparent 100%);filter:drop-shadow(0 0 8px rgba(107,70,193,.35));animation:lb-move 1.05s cubic-bezier(.4,0,.2,1) infinite;border-radius:inherit}.loading-bar.active:after{content:"";position:absolute;top:50%;left:-10%;width:20px;height:20px;transform:translate(-50%,-50%);background:radial-gradient(circle,#7b56d2e6,#7b56d200 70%);animation:lb-peg 1.05s cubic-bezier(.4,0,.2,1) infinite;pointer-events:none}@keyframes lb-move{0%{transform:translate(-60%);opacity:.9}50%{transform:translate(15%);opacity:1}to{transform:translate(120%);opacity:.95}}@keyframes lb-peg{0%{left:-10%;opacity:.55}50%{left:45%;opacity:.85}to{left:110%;opacity:.65}}.content-dim{transition:opacity .25s ease,filter .25s ease,transform .25s ease}.content-dim[data-loading=true]{opacity:.45;filter:saturate(.9) contrast(.95);pointer-events:none}.content-dim[data-loading=false]{opacity:1;filter:none}.page-header{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin:8px auto 20px;padding:0 24px;max-width:1200px}.page-title{font-weight:900;letter-spacing:-.02em;line-height:1.05;margin:0;font-size:clamp(28px,3.2vw,44px);background:linear-gradient(92deg,#0f172a,#2b2f48 40%,#6b46c1);-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:0 .4px 0 rgba(0,0,0,.25)}@media(prefers-contrast:more){.page-title{background:none;color:var(--ink-strong);text-shadow:none}}.page-subtitle{margin:6px 0 0;color:#334155;font-size:14px}.header-actions{display:flex;align-items:center;gap:10px}.card,.table-card{background:var(--card);border:1px solid var(--border-strong);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}.toolbar{display:flex;align-items:center;gap:12px;padding:16px 18px;border-bottom:1px solid var(--border-strong);background:linear-gradient(0deg,#f8f7ffe6,#f8f7ffe6);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.btn{-webkit-appearance:none;appearance:none;border:1px solid var(--border-strong);background:#fff;color:var(--ink-strong);padding:11px 16px;border-radius:12px;font-weight:800;font-size:14px;line-height:1;cursor:pointer;transition:transform .05s ease,box-shadow .2s ease,filter .15s ease,border-color .2s ease;box-shadow:var(--shadow-sm)}.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn:active{transform:translateY(0);box-shadow:var(--shadow-sm)}.btn-primary{border:1px solid transparent;color:#fff;background:linear-gradient(180deg,var(--brand-700) 0%,var(--brand) 100%);text-shadow:0 .5px 0 rgba(0,0,0,.2)}.btn-primary:hover{filter:brightness(1.02)}.btn-ghost{color:var(--brand-800);border:1px solid rgba(67,42,134,.55);background:linear-gradient(180deg,#fff,#f4f3ff);font-weight:800}.btn-danger{border:1px solid transparent;color:#fff;background:linear-gradient(180deg,#b91c1c,#991b1b)}.icon-btn{inline-size:36px;block-size:36px;display:grid;place-items:center;border-radius:999px;background:#f8fafc;border:1px solid var(--border-strong);box-shadow:var(--shadow-sm);color:var(--ink-strong);cursor:pointer;transition:transform .06s ease,box-shadow .2s ease,filter .15s ease,border-color .2s ease}.icon-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.icon-btn.primary{color:var(--brand-700)}.icon-btn.danger{color:#b91c1c}.input{background:#fff;border:1px solid var(--border-strong);border-radius:12px;padding:10px 14px;font-size:14px;color:var(--ink-strong)}.input::placeholder{color:#7b8794}.article-table-button{display:inline-block;padding:12px 18px;border:1px solid transparent;color:#fff;border-radius:12px;font-weight:900;text-decoration:none;letter-spacing:.01em;background:linear-gradient(180deg,var(--brand-700) 0%,var(--brand) 100%);box-shadow:var(--shadow-md);transition:transform .06s ease,box-shadow .2s ease,filter .15s ease}.article-table-button:hover{transform:translateY(-1px);box-shadow:var(--shadow-lg);filter:brightness(1.02)}.index-chip{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:28px;padding:0 8px;font-weight:900;font-size:12px;letter-spacing:.02em;color:#1f2937;background:#f1efff;border:1px solid rgba(67,42,134,.35);border-radius:999px}.qty-chip{display:inline-flex;align-items:center;padding:6px 10px;font-weight:900;color:#111827;background:linear-gradient(180deg,#fff,#f2f3ff);border:1px solid rgba(67,42,134,.3);border-radius:10px}.badge{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;font-weight:900;letter-spacing:.02em;border:1px solid transparent}.badge-success{background:#ecfdf5;color:#065f46;border-color:#a7f3d0}.badge-muted{background:#eef2f7;color:#334155;border-color:#d1d5db}.pagination{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:16px;padding:0 2px}.pagination-info{color:var(--ink-soft);font-size:13px}.pagination-controls{display:flex;gap:8px}.pagination-button{border:1px solid rgba(67,42,134,.55);background:linear-gradient(180deg,#fff,#f2f1ff);color:var(--brand-800);padding:9px 14px;border-radius:999px;font-weight:900;cursor:pointer;transition:transform .06s ease,box-shadow .2s ease,background .2s ease}.pagination-button:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}.pagination-button:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.reveal-up{animation:reveal-up .35s ease-out both}@keyframes reveal-up{0%{opacity:0;transform:translateY(10px) scale(.995)}to{opacity:1;transform:translateY(0) scale(1)}}.table-card,.article-table-content,.customer-table-content,.project-table-content,.restaurant-table-content{border-color:var(--border-strong)}.lightbox-content{width:520px}:root{--purple: var(--brand);--purple-hover: var(--brand-600);--light-bg: #f9f9ff;--dark-bg: #0b1324;--dark-input: #111827;--gray-border: var(--border-strong);--tile-radius: 999px}.button-container{display:flex;justify-content:center;margin-top:10px}.open-button{background:linear-gradient(180deg,var(--purple) 0%,var(--purple-hover) 100%);border:none;border-radius:12px;padding:12px 28px;color:#fff;font-weight:800;cursor:pointer;box-shadow:var(--shadow-md)}.custadd-card{background:var(--bg-elevated);color:var(--ink-strong);padding:24px;border-radius:16px;width:700px;max-width:95%;border:1px solid var(--border-strong);box-shadow:var(--shadow-lg);position:relative;text-align:left;animation:reveal-up .28s ease-out both;max-height:calc(100vh - 80px);overflow:auto}.custadd-card.dark{background:var(--dark-bg);color:#f8fafc;border-color:#374151}.field{margin-bottom:16px}.input{width:100%;padding:10px 12px;border:1px solid var(--gray-border);border-radius:10px;font-size:14px;background:#fff}.custadd-card.dark .input{background:#111827;border-color:#374151;color:#f8fafc}.project-list{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px;padding:12px;background:var(--light-bg);border:1px solid var(--gray-border);border-radius:12px}.custadd-card.dark .project-list{background:#0f172a;border-color:#374151}.project-tile{padding:8px 16px;background:#fff;border:1px solid var(--gray-border);border-radius:var(--tile-radius);font-size:14px;cursor:pointer;font-weight:800;color:#374151;transition:transform .06s ease,box-shadow .2s ease}.project-tile:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}.project-tile.selected{background:linear-gradient(180deg,var(--purple) 0%,var(--purple-hover) 100%);color:#fff;border-color:transparent}.project-add-tile{background:linear-gradient(180deg,var(--purple) 0%,var(--purple-hover) 100%);color:#fff;border:none;font-size:20px;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow-sm)}.actions{display:flex;gap:10px;justify-content:flex-end;margin-top:12px}.addtodo-card{background:#fff;color:var(--ink-strong);padding:24px;border-radius:16px;width:480px;max-width:96%;border:1px solid var(--border-strong);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:12px;max-height:calc(100vh - 80px);overflow:auto;animation:reveal-up .28s ease-out both}.lightbox-title{font-size:20px;font-weight:900;text-align:center;margin:0 0 6px}.addtodo-card .input{width:100%;padding:12px;font-size:14px;border:1px solid var(--border-strong);border-radius:10px;background:#fff}.addtodo-card textarea.input{min-height:96px;resize:vertical}.user-chip-group{display:flex;flex-direction:column;gap:8px}.user-chip-container{display:flex;gap:10px;flex-wrap:wrap}.user-chip{padding:8px 14px;border-radius:999px;border:1px solid rgba(107,70,193,.35);background:#fff;color:var(--brand-700);font-weight:800;cursor:pointer;transition:transform .06s ease,box-shadow .2s ease,filter .15s ease}.user-chip:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}.user-chip.selected{background:linear-gradient(180deg,var(--brand) 0%,var(--brand-600) 100%);color:#fff;border-color:transparent}.button-row{display:flex;gap:10px;justify-content:flex-end;margin-top:8px}.links-lb.links-card{background:#fff;color:var(--ink-strong);padding:20px;border-radius:16px;width:560px;max-width:96%;border:1px solid var(--border-strong);box-shadow:var(--shadow-lg);animation:reveal-up .28s ease-out both;max-height:calc(100vh - 80px);overflow:auto}.links-card .lightbox-title{font-size:20px;font-weight:900;margin:0 0 10px}.links-card .link-list{list-style:none;padding:0;margin:0 0 12px;display:flex;flex-direction:column;gap:8px}.links-card .link-list li{display:flex;align-items:center;justify-content:space-between;gap:10px;background:#f8f9ff;border:1px solid var(--border-strong);border-radius:10px;padding:8px 10px}.links-card .link-list li a{color:var(--brand-700);font-weight:800}.links-card .link-list .empty{text-align:center;color:var(--ink-soft);background:#fff}.links-card .link-inputs{display:grid;grid-template-columns:1fr 1fr auto;gap:10px;align-items:center}.links-card .link-inputs .input{padding:10px 12px;border-radius:10px;border:1px solid var(--border-strong)}.links-card .button-row{display:flex;gap:10px;justify-content:flex-end;margin-top:12px}.pm-lightbox{background:var(--bg-elevated);color:var(--ink-strong);padding:24px;border-radius:16px;width:760px;max-width:96%;border:1px solid var(--border-strong);box-shadow:var(--shadow-lg);max-height:calc(100vh - 80px);overflow-y:auto;position:relative;animation:reveal-up .28s ease-out both}.pm-lightbox.dark{background:#0f172a;color:#f8fafc;border-color:#374151}.close-button{position:absolute;top:16px;right:20px;background:none;border:none;font-size:26px;cursor:pointer;color:inherit}.label{display:block;font-weight:800;font-size:13px;margin:12px 0 6px}.pm-lightbox.dark .input{background:#111827;border-color:#374151;color:#f8fafc}.input:focus{border-color:var(--brand-600);box-shadow:0 0 0 3px var(--focus)}textarea.input{min-height:96px;resize:vertical}.link-section{margin-top:12px}.todo-section{margin-top:22px}.todo-header{display:flex;align-items:center;justify-content:space-between}.todo-table-wrapper{margin-top:12px;max-height:280px;overflow:auto;border:1px solid var(--border-strong);border-radius:12px;background:#fff}.pm-lightbox.dark .todo-table-wrapper{background:#0b1324;border-color:#374151}.todo-table{width:100%;border-collapse:separate;border-spacing:0}.todo-table thead th{position:-webkit-sticky;position:sticky;top:0;z-index:1;background:linear-gradient(180deg,#faf7ff,#fff);text-align:left;padding:12px 14px;font-weight:900;border-bottom:1px solid var(--border-strong)}.todo-table td{padding:12px 14px;border-bottom:1px solid var(--border-strong)}.todo-table tbody tr:nth-child(odd) td{background:#fcfcff}.badge{display:inline-block;padding:4px 8px;border-radius:999px;background:#eef2ff;border:1px solid rgba(107,70,193,.25);font-weight:800}.actions-cell{white-space:nowrap;text-align:center}.mini-lightbox{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000}.mini-content{background:#fff;color:var(--ink-strong);padding:18px;border-radius:12px;width:420px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:10px}.button-row{display:flex;gap:10px;justify-content:flex-end}.error-message{color:var(--danger);font-weight:800;margin-top:12px}.save-button{margin-top:16px}.mini-lightbox{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:24px;z-index:10050}.mini-content{width:520px;max-width:96%;background:var(--bg-elevated);color:var(--ink-strong);border:1px solid var(--border-strong);border-radius:16px;box-shadow:var(--shadow-lg);padding:20px;display:grid;gap:10px;max-height:calc(100vh - 80px);overflow:auto;animation:reveal-up .28s ease-out both}.mini-lightbox.dark .mini-content{background:#0b1324;color:#f8fafc;border-color:#374151}.mini-lightbox.dark .mini-content .input,.mini-lightbox.dark .mini-content select,.mini-lightbox.dark .mini-content textarea{background:#111827;border-color:#374151;color:#f8fafc}.mini-title{margin:0 0 6px;font-weight:900;font-size:18px}.mini-content .input,.mini-content select{width:100%;padding:10px 12px;font-size:14px;border:1px solid var(--border-strong);border-radius:10px;background:#fff}.mini-content textarea.input{min-height:96px;resize:vertical}.mini-content .button-row{display:flex;gap:10px;justify-content:flex-end;margin-top:6px}.actions-cell .icon-btn{vertical-align:middle}.actions-cell .icon-btn svg{width:16px;height:16px}.lightbox-content{background:var(--bg-elevated);color:var(--ink-strong);padding:24px;border-radius:16px;width:720px;max-width:96%;text-align:left;position:relative;border:1px solid var(--border-strong);box-shadow:var(--shadow-lg);animation:reveal-up .28s ease-out both;max-height:calc(100vh - 80px);overflow:auto}.lightbox-content.dark{background:#0b1324;color:#f8fafc;border-color:#374151}.close-button{position:absolute;top:12px;right:12px;background:none;border:none;font-size:24px;cursor:pointer;color:inherit}.label{display:block;font-weight:800;font-size:13px;margin-bottom:6px}.input{width:100%;padding:10px 12px;border:1px solid var(--border-strong);border-radius:10px;background:#fff}.lightbox-content.dark .input{background:#111827;border-color:#374151;color:#f8fafc}.project-list{display:flex;flex-wrap:wrap;gap:8px}.project-tile{padding:8px 12px;border-radius:999px;border:1px solid rgba(107,70,193,.35);background:linear-gradient(180deg,#fff,#f8f8ff);color:var(--brand-700);font-weight:800;cursor:pointer}.project-tile.selected{background:linear-gradient(180deg,var(--brand) 0%,var(--brand-600) 100%);color:#fff;border-color:transparent}.actions{display:flex;gap:8px;justify-content:flex-end;margin:4px 0 12px}.activity-log-title{margin:10px 0 6px;font-size:16px;font-weight:900}.activity-log-table{width:100%;border-collapse:collapse;font-size:14px}.activity-log-table th,.activity-log-table td{border:1px solid var(--border-strong);padding:8px 10px}.activity-log-table thead th{background:#faf7ff;text-align:left}.empty{text-align:center;color:var(--ink-soft)}.confirm-overlay{position:fixed;inset:0;display:grid;place-items:center;padding:24px;z-index:10050}.confirm-card{width:460px;max-width:96%;background:var(--bg-elevated, #fff);color:var(--ink-strong, #0b1324);border:1px solid var(--border-strong, #d1d5db);border-radius:16px;box-shadow:var(--shadow-lg, 0 16px 40px rgba(2,8,23,.1));padding:20px 18px 16px;text-align:left;animation:reveal-up .28s ease-out both}.confirm-card.dark{background:#0b1324;color:#f8fafc;border-color:#374151}.confirm-icon{font-size:22px;line-height:1;width:36px;height:36px;display:grid;place-items:center;border-radius:12px;background:linear-gradient(180deg,#fff,#f6f7ff);border:1px solid rgba(107,70,193,.25);margin-bottom:10px}.confirm-title{margin:0 0 6px;font-weight:900;font-size:18px;letter-spacing:.01em}.confirm-message{margin:0 0 14px;color:var(--ink-soft, #475569);font-size:14px}.confirm-actions{display:flex;gap:10px;justify-content:flex-end}.customer-table-section{padding:24px;background:transparent}.customer-table-container{max-width:1200px;margin:0 auto}.customer-table-wrapper{width:100%}.customer-table-content{width:100%;overflow:auto;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:1px solid var(--border-strong);background:linear-gradient(180deg,#fffffff2,#fff 60%),var(--card)}.customer-table{width:100%;border-collapse:separate;border-spacing:0;background:transparent}.customer-table thead th{position:-webkit-sticky;position:sticky;top:0;z-index:2;background:linear-gradient(0deg,#fffffff0,#fffffff0),linear-gradient(180deg,var(--thead) 0%,#fff 100%);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);text-align:left;font-weight:900;color:#0f172a;border-bottom:1px solid var(--border-strong);padding:14px 16px;font-size:13px;white-space:nowrap;box-shadow:inset 0 -1px #0000000a}.customer-table td{padding:14px 16px;font-size:14px;color:var(--ink-strong);border-bottom:1px solid var(--border);background:#fff}.customer-table tbody tr:nth-child(odd) td{background:#f7f6ff}.customer-table tbody tr:hover td{background:var(--row-hover)}.customer-table thead th:first-child,.customer-table tbody td:first-child{border-left:1px solid var(--border-strong)}.customer-table thead th:last-child,.customer-table tbody td:last-child{border-right:1px solid var(--border-strong)}.project-link{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;background:linear-gradient(180deg,#fff,#f2f3ff);border:1px solid rgba(67,42,134,.35);border-radius:999px;color:var(--brand-800);font-weight:900;cursor:pointer;transition:transform .06s ease,box-shadow .2s ease}.project-link:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}.customer-table .empty-state{text-align:center;color:var(--ink-soft);background:linear-gradient(180deg,#fff,#f4f1ff);font-weight:600}.project-table-section{padding:24px;background:transparent}.project-table-container{max-width:1200px;margin:0 auto}.project-table-wrapper{width:100%}.project-table-content{width:100%;overflow:auto;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:1px solid var(--border-strong);background:linear-gradient(180deg,#fffffff2,#fff 60%),var(--card)}.project-table{width:100%;border-collapse:separate;border-spacing:0}.project-table thead th{position:-webkit-sticky;position:sticky;top:0;z-index:2;background:linear-gradient(0deg,#fffffff0,#fffffff0),linear-gradient(180deg,var(--thead) 0%,#fff 100%);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);text-align:left;font-weight:900;color:#0f172a;border-bottom:1px solid var(--border-strong);padding:14px 16px;font-size:13px;white-space:nowrap;box-shadow:inset 0 -1px #0000000a}.project-table td{padding:14px 16px;font-size:14px;color:var(--ink-strong);border-bottom:1px solid var(--border);background:#fff}.project-table tbody tr:nth-child(odd) td{background:#f7f6ff}.project-table tbody tr:hover td{background:var(--row-hover)}.project-table thead th:first-child,.project-table tbody td:first-child{border-left:1px solid var(--border-strong)}.project-table thead th:last-child,.project-table tbody td:last-child{border-right:1px solid var(--border-strong)}.project-name-button{background:linear-gradient(180deg,#fff,#f2f3ff);color:var(--brand-800);border:1px solid rgba(67,42,134,.45);border-radius:10px;padding:6px 10px;cursor:pointer;font-weight:900;transition:transform .06s ease,box-shadow .2s ease}.project-name-button:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}.center-add-project-btn{display:flex;justify-content:center;margin:20px 0 0}.project-table .empty-state{text-align:center;color:var(--ink-soft);background:linear-gradient(180deg,#fff,#f4f1ff);font-weight:600}.lightbox-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:24px;z-index:10000}.lightbox-content{background:var(--bg-elevated);color:var(--ink-strong);padding:24px;border-radius:16px;width:540px;max-width:95%;text-align:left;position:relative;border:1px solid var(--border-strong);box-shadow:var(--shadow-lg);animation:reveal-up .28s ease-out both;max-height:calc(100vh - 80px);overflow:auto}.lightbox-content.strong{width:600px}.lightbox-content.dark{background:#111827;color:#f8fafc;border-color:#374151}.lightbox-title{font-size:22px;font-weight:900;margin:0 0 14px}.close-button{position:absolute;top:14px;right:16px;background:transparent;border:none;font-size:24px;cursor:pointer;color:inherit;padding:2px 6px;border-radius:8px}.close-button:hover{filter:brightness(1.1)}.field{margin-bottom:14px}.field.two-col{display:grid;grid-template-columns:1fr 1fr;gap:12px}.label{display:block;font-weight:800;font-size:13px;margin-bottom:6px;color:var(--ink-strong)}.input{width:100%;padding:10px 12px;font-size:14px;border:1px solid var(--border-strong);border-radius:10px;background:#fff}.lightbox-content.dark .input{background:#1f2937;border-color:#374151;color:#f8fafc}.input::placeholder{color:var(--muted)}.switch{display:inline-flex;align-items:center;gap:10px;cursor:pointer}.switch input{display:none}.switch .track{position:relative;flex:0 0 42px;inline-size:42px;block-size:24px;border-radius:999px;background:#e5e7eb;border:1px solid var(--border-strong);z-index:1}.switch .thumb{position:absolute;inset-block:2px;inset-inline-start:2px;inline-size:20px;block-size:20px;background:#fff;border-radius:50%;box-shadow:var(--shadow-sm);transition:transform .2s ease}.switch.small .track{inline-size:42px;block-size:24px}.switch.small .thumb{inline-size:20px;block-size:20px}.switch input:checked+.track{background:var(--brand);border-color:var(--brand-600)}.switch input:checked+.track .thumb{transform:translate(18px)}.switch-text{position:relative;z-index:2;-webkit-user-select:none;user-select:none;font-weight:700}.create-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;border-radius:12px;border:none;font-weight:800;cursor:pointer;background:linear-gradient(180deg,var(--brand) 0%,var(--brand-600) 100%);color:#fff;box-shadow:var(--shadow-md)}.create-button:disabled{opacity:.6;cursor:not-allowed}.info-block{display:block;padding:12px;border:1px solid var(--border-strong);border-radius:10px;background:#fff}.lightbox-content.dark .info-block{background:#1f2937;border-color:#374151}.meta-note{margin-top:8px;font-size:12px;color:var(--ink-soft)}.restaurant-table-section{padding:24px;background:transparent}.restaurant-table-container{max-width:1200px;margin:0 auto}.restaurant-table-wrapper{width:100%}.restaurant-table-content{width:100%;overflow:auto;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:1px solid var(--border-strong);background:linear-gradient(180deg,#fffffff2,#fff 60%),var(--card)}.restaurant-table{width:100%;border-collapse:separate;border-spacing:0}.restaurant-table thead th{position:-webkit-sticky;position:sticky;top:0;z-index:2;background:linear-gradient(0deg,#fffffff0,#fffffff0),linear-gradient(180deg,var(--thead) 0%,#fff 100%);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);text-align:left;font-weight:900;color:#0f172a;border-bottom:1px solid var(--border-strong);padding:14px 16px;font-size:13px;white-space:nowrap;box-shadow:inset 0 -1px #0000000a}.restaurant-table td{padding:14px 16px;font-size:14px;color:var(--ink-strong);border-bottom:1px solid var(--border);background:#fff}.restaurant-table tbody tr:nth-child(odd) td{background:#f7f6ff}.restaurant-table tbody tr:hover td{background:var(--row-hover)}.restaurant-table thead th:first-child,.restaurant-table tbody td:first-child{border-left:1px solid var(--border-strong)}.restaurant-table thead th:last-child,.restaurant-table tbody td:last-child{border-right:1px solid var(--border-strong)}.restaurant-table .empty-state{text-align:center;color:var(--ink-soft);background:linear-gradient(180deg,#fff,#f4f1ff);font-weight:600}.center-add-restaurant-btn{display:flex;justify-content:center;margin:20px 0 0}.toast-center{position:fixed;right:16px;bottom:16px;display:flex;flex-direction:column-reverse;gap:10px;z-index:10060;pointer-events:none}.toast-card{min-width:320px;max-width:460px;background:var(--bg-elevated, #fff);color:var(--ink-strong, #0b1324);border:1px solid var(--border-strong, #d1d5db);border-left:6px solid #ef4444;border-radius:14px;box-shadow:var(--shadow-lg, 0 16px 40px rgba(2,8,23,.1));padding:12px 12px 10px;pointer-events:auto;animation:reveal-up .28s ease-out both}.toast-card.dark{background:#0b1324;color:#f8fafc;border-color:#374151;border-left-color:#f87171}.toast-head{display:flex;align-items:center;gap:8px;margin-bottom:6px}.toast-badge{font-size:11px;font-weight:700;letter-spacing:.05em;padding:2px 6px;border-radius:999px;color:#991b1b;background:#fee2e2;border:1px solid #fecaca}.toast-card.dark .toast-badge{color:#fecaca;background:#f8717114;border-color:#f8717140}.toast-title{flex:1;font-weight:900;font-size:14px}.toast-actions{display:flex;align-items:center;gap:6px}.toast-btn{-webkit-appearance:none;appearance:none;border:1px solid var(--border-strong, #d1d5db);background:linear-gradient(180deg,#fff,#f9fafb);color:inherit;font-size:12px;padding:4px 8px;border-radius:8px;cursor:pointer}.toast-btn:hover{filter:brightness(.98)}.toast-close{-webkit-appearance:none;appearance:none;width:28px;height:28px;display:grid;place-items:center;border-radius:8px;border:1px solid var(--border-strong, #d1d5db);background:transparent;color:inherit;cursor:pointer}.toast-close:hover{background:#0208170a}.toast-card.dark .toast-close{border-color:#374151}.toast-card.dark .toast-close:hover{background:#ffffff0f}.toast-body{font-size:12px;line-height:1.4;color:var(--ink-soft, #475569)}.toast-card.dark .toast-body{color:#cbd5e1}.toast-meta{margin-top:6px;font-size:11px;color:var(--ink-softer, #64748b)}.toast-pre{margin:6px 0 0;max-height:140px;overflow:auto;padding:8px;background:#02081708;border:1px dashed var(--border-strong, #e5e7eb);border-radius:10px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:11px}.toast-card.dark .toast-pre{background:#ffffff0d;border-color:#ffffff1f}
