:root{--bg: #0b0f14;--bg-elevated: #121820;--surface: #161f2c;--surface-hover: #1c2736;--border: #2a3648;--border-subtle: #1f2a3a;--text: #eef4fa;--muted: #8fa3b8;--accent: #4d9bff;--accent-dim: #2d6fd4;--accent-glow: rgba(77, 155, 255, .18);--success: #34d399;--success-bg: rgba(52, 211, 153, .1);--danger: #f87171;--danger-bg: rgba(248, 113, 113, .12);--radius: 12px;--radius-sm: 8px;--font: "DM Sans", system-ui, sans-serif;--shadow-card: 0 16px 48px rgba(0, 0, 0, .45);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .25);--sidebar-width: 260px;--space-xs: .35rem;--space-sm: .65rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem}*{box-sizing:border-box}body{margin:0;min-height:100vh;font-family:var(--font);background:radial-gradient(ellipse 900px 500px at 15% -5%,rgba(45,111,212,.22) 0%,transparent 55%),radial-gradient(ellipse 700px 400px at 95% 10%,rgba(30,58,95,.35) 0%,transparent 50%),linear-gradient(180deg,var(--bg) 0%,#0d1218 100%);color:var(--text);line-height:1.55;-webkit-font-smoothing:antialiased}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}a:focus-visible,button:focus-visible,input:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.shell{max-width:1040px;margin:0 auto;padding:var(--space-xl) var(--space-lg) 4rem}.topbar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);padding-bottom:var(--space-lg);border-bottom:1px solid var(--border);margin-bottom:var(--space-xl)}.brand{font-weight:700;font-size:1.2rem;letter-spacing:-.03em}.brand-sub{display:block;font-size:.78rem;font-weight:500;color:var(--muted);letter-spacing:0;margin-top:.15rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:var(--space-lg) 1.85rem;box-shadow:var(--shadow-card)}.card+.card{margin-top:var(--space-lg)}h1{font-size:1.7rem;font-weight:700;margin:0 0 .65rem;letter-spacing:-.035em}h2{font-size:1.12rem;font-weight:600;margin:1.5rem 0 .65rem}p.lead{color:var(--muted);margin:0 0 var(--space-lg);max-width:56ch;font-size:.95rem}label{display:block;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);margin-bottom:var(--space-xs)}select.select-input{width:100%;padding:.7rem .9rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-elevated);color:var(--text);font:inherit;margin-bottom:var(--space-md)}select.select-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}input:not([type=checkbox]):not([type=radio]){width:100%;padding:.7rem .9rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-elevated);color:var(--text);font:inherit;margin-bottom:var(--space-md);transition:border-color .15s ease,box-shadow .15s ease}input[type=checkbox]{width:1.1rem;height:1.1rem;margin:0;accent-color:var(--accent);cursor:pointer}input:focus:not([type=checkbox]){outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}button{font:inherit;font-weight:600;cursor:pointer;border:none;border-radius:var(--radius-sm);padding:.7rem 1.25rem;background:linear-gradient(180deg,var(--accent) 0%,var(--accent-dim) 100%);color:#fff;transition:opacity .15s ease,transform .1s ease}button:hover:not(:disabled){filter:brightness(1.06)}button.secondary{background:var(--bg-elevated);color:var(--text);border:1px solid var(--border)}button:disabled{opacity:.5;cursor:not-allowed}.row{display:flex;flex-wrap:wrap;gap:var(--space-md);align-items:center}.banner{background:var(--danger-bg);border:1px solid rgba(248,113,113,.35);color:#fecaca;padding:.8rem 1rem;border-radius:var(--radius-sm);margin-bottom:var(--space-md);font-size:.92rem}.banner-success{background:var(--success-bg);border:1px solid rgba(52,211,153,.35);color:#a7f3d0;padding:.8rem 1rem;border-radius:var(--radius-sm);margin-bottom:var(--space-md);font-size:.92rem;line-height:1.45}.muted{color:var(--muted)}.caption{font-size:.78rem;color:var(--muted)}.table-wrap{overflow-x:auto;margin:0 -.25rem;padding:0 .25rem}table{width:100%;border-collapse:collapse;font-size:.88rem}th,td{text-align:left;padding:.65rem .8rem;border-bottom:1px solid var(--border-subtle)}th{color:var(--muted);font-weight:600;font-size:.7rem;text-transform:uppercase;letter-spacing:.06em}tbody tr:hover{background:#ffffff05}.steps{display:flex;gap:.5rem;margin-bottom:var(--space-lg);flex-wrap:wrap}.step-pill{padding:.4rem .75rem;border-radius:999px;font-size:.78rem;font-weight:600;background:var(--bg-elevated);border:1px solid var(--border);color:var(--muted)}.step-pill.active{border-color:var(--accent);color:var(--accent);background:var(--accent-glow)}.onboarding-guide{margin:var(--space-md) 0 var(--space-lg);padding:var(--space-md) var(--space-lg);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm)}.onboarding-guide-title{margin:0 0 var(--space-sm);font-weight:600;font-size:.95rem}.onboarding-steps{margin:0;padding-left:1.25rem;color:var(--muted);font-size:.9rem}.onboarding-steps li{margin-bottom:.45rem}.onboarding-steps li:last-child{margin-bottom:0}.field-hint{margin:.35rem 0 var(--space-md);font-size:.85rem;line-height:1.45}.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--space-md);margin-bottom:var(--space-lg)}.stat-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);padding:var(--space-md) var(--space-lg)}.stat-card-label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:.35rem}.stat-card-value{font-size:1.5rem;font-weight:700;letter-spacing:-.03em}.stat-card-hint{font-size:.75rem;color:var(--muted);margin-top:.25rem}.spinner-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-md);padding:var(--space-xl)}.spinner{width:2rem;height:2rem;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.auth-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-lg) var(--space-md) 3rem;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:48px 48px}.auth-page-inner{width:100%;max-width:440px}.auth-brand{display:flex;align-items:center;justify-content:center;gap:.875rem;margin-bottom:var(--space-xl)}.auth-brand-text{display:flex;flex-direction:column;align-items:flex-start;gap:.125rem;text-align:left}.auth-brand .brand{font-size:1.5rem;line-height:1.2}.auth-brand-mark{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:3rem;height:3rem;border-radius:14px;background:linear-gradient(145deg,var(--accent) 0%,var(--accent-dim) 100%);font-size:1.35rem;box-shadow:0 8px 24px var(--accent-glow)}.auth-tagline{display:block;font-size:.92rem;color:var(--muted);font-weight:500;line-height:1.3}.auth-badge{display:inline-block;margin-top:.5rem;padding:.25rem .6rem;border-radius:6px;font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#c4b5fd;background:#8b5cf626;border:1px solid rgba(139,92,246,.35)}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:calc(var(--radius) + 2px);padding:1.85rem 2rem 1.75rem;box-shadow:var(--shadow-card)}.auth-card h1{font-size:1.5rem;margin-bottom:.45rem}.auth-subtitle{color:var(--muted);font-size:.94rem;line-height:1.5;margin:0 0 var(--space-lg)}.auth-segment-wrap{display:flex;padding:4px;gap:4px;border-radius:12px;background:var(--bg-elevated);border:1px solid var(--border);margin-bottom:var(--space-lg)}.auth-segment{flex:1;margin:0;padding:.6rem .75rem;border-radius:9px;font-size:.9rem;font-weight:600;border:none;cursor:pointer;background:transparent;color:var(--muted);transition:background .15s ease,color .15s ease,box-shadow .15s ease}.auth-segment:hover:not(:disabled){color:var(--text)}.auth-segment-active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.auth-form-actions button[type=submit]{width:100%;padding:.8rem 1rem;margin-top:.15rem}.auth-footer{margin-top:var(--space-lg);padding-top:var(--space-md);border-top:1px solid var(--border);text-align:center;font-size:.88rem;color:var(--muted)}.auth-footer a{font-weight:600}.auth-dev-hint{margin-top:var(--space-md);font-size:.78rem;color:var(--muted);opacity:.9}.auth-dev-hint summary{cursor:pointer;-webkit-user-select:none;user-select:none}.auth-staff-card{max-width:460px;margin:0 auto}.auth-sql-pre{margin:0 0 var(--space-md);padding:.85rem 1rem;border-radius:var(--radius-sm);background:var(--bg-elevated);border:1px solid var(--border);font-size:.78rem;overflow:auto;line-height:1.45}.admin-layout{display:flex;min-height:100vh}.admin-sidebar{width:var(--sidebar-width);flex-shrink:0;background:linear-gradient(180deg,#141c28,#0f141c);border-right:1px solid var(--border);padding:var(--space-lg) 0;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto}.admin-sidebar-brand{display:flex;align-items:center;gap:.75rem;padding:0 var(--space-lg) var(--space-lg);border-bottom:1px solid var(--border-subtle);margin-bottom:var(--space-sm)}.admin-brand-mark{display:flex;align-items:center;justify-content:center;width:2.25rem;height:2.25rem;border-radius:10px;background:var(--accent-glow);border:1px solid rgba(77,155,255,.35);font-size:1.1rem;line-height:1}.admin-sidebar-brand .brand{font-size:1.08rem;display:block}.admin-nav{display:flex;flex-direction:column;gap:.15rem;padding:0 var(--space-sm);flex:1;overflow-y:auto}.admin-nav-section{margin-bottom:.85rem}.admin-nav-section-title{padding:.35rem .85rem .4rem;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);opacity:.85}.admin-nav-link{display:flex;align-items:center;gap:.6rem;padding:.55rem .85rem;border-radius:var(--radius-sm);font-size:.9rem;font-weight:500;color:var(--muted);text-decoration:none;transition:background .12s ease,color .12s ease,border-color .12s ease;border:1px solid transparent}.admin-nav-icon{width:1.25rem;text-align:center;font-size:1rem;line-height:1;flex-shrink:0}.admin-nav-link:hover{color:var(--text);background:var(--surface-hover);text-decoration:none}.admin-nav-link-active{color:var(--text);background:var(--accent-glow);border-color:#4d9bff59;font-weight:600}.admin-sidebar-footer{padding:var(--space-md) var(--space-lg) var(--space-sm);border-top:1px solid var(--border-subtle);margin-top:auto}.admin-user-email{margin:0 0 .65rem;font-size:.78rem;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-sign-out{width:100%}.admin-main{flex:1;min-width:0;background:transparent}.admin-main-inner{max-width:1280px;margin:0 auto;padding:var(--space-xl) var(--space-xl) 4rem}.admin-page-header{margin-bottom:var(--space-lg);padding-bottom:var(--space-md);border-bottom:1px solid var(--border-subtle)}.admin-page-header h1{margin-bottom:.35rem;font-size:1.85rem}.admin-page-content{display:flex;flex-direction:column;gap:var(--space-md)}button.danger{background:var(--danger-bg);border-color:#f8717173;color:#fecaca}button.danger:hover:not(:disabled){background:#f8717138;border-color:#f871718c}.client-layout{max-width:720px;margin:0 auto;padding:var(--space-lg) var(--space-lg) 3rem;min-height:100vh}.client-topbar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);margin-bottom:var(--space-md)}.client-nav{display:flex;gap:.35rem;margin-bottom:var(--space-lg);padding:.25rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius)}.client-nav-link{flex:1;text-align:center;padding:.55rem .75rem;border-radius:var(--radius-sm);font-size:.9rem;font-weight:600;color:var(--muted);text-decoration:none}.client-nav-link:hover{color:var(--text);background:var(--surface-hover);text-decoration:none}.client-nav-link-active{color:var(--text);background:var(--surface);box-shadow:var(--shadow-sm)}.client-main{min-height:200px}.message-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-md)}.message-item{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:var(--space-md) 1rem}.message-item-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);margin-bottom:.5rem}.message-kind{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--accent)}.message-time{font-size:.78rem;color:var(--muted)}.message-body{margin:0;white-space:pre-wrap;word-break:break-word;font-size:.95rem}.message-channel{margin:.5rem 0 0;font-size:.8rem;color:var(--muted)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;padding:var(--space-lg);z-index:100}.modal-panel{max-width:480px;width:100%;max-height:85vh;overflow:auto}.exclusion-list{list-style:none;margin:0 0 var(--space-md);padding:0}.exclusion-row{display:flex;align-items:center;gap:var(--space-sm);padding:.35rem 0;cursor:pointer}.posts-layout{display:grid;grid-template-columns:1fr minmax(260px,360px);gap:var(--space-lg);margin-top:var(--space-md)}.posts-detail{margin:0;align-self:start;position:sticky;top:var(--space-md)}.posts-detail-empty{display:flex;align-items:center;justify-content:center;min-height:12rem;border:1px dashed var(--border);background:transparent}.posts-row-selected{background:var(--accent-glow)}.posts-message-full{white-space:pre-wrap;word-break:break-word;font-family:inherit;font-size:.9rem;margin:0;padding:var(--space-md);background:var(--bg-elevated);border-radius:var(--radius-sm);border:1px solid var(--border-subtle);max-height:50vh;overflow:auto}.detail-list{display:grid;grid-template-columns:auto 1fr;gap:.35rem 1rem;margin:0 0 var(--space-md);font-size:.9rem}.detail-list dt{color:var(--muted);margin:0}.detail-list dd{margin:0}@media(max-width:768px){.posts-layout{grid-template-columns:1fr}.posts-detail{position:static}}@media(max-width:768px){.admin-layout{flex-direction:column}.admin-sidebar{width:100%;border-right:none;border-bottom:1px solid var(--border);padding-bottom:var(--space-md)}.admin-nav{flex-direction:row;flex-wrap:wrap;padding:0 var(--space-md)}.admin-main-inner{padding:var(--space-lg)}.admin-sidebar{position:static;height:auto}}
