:root{font-family:Space Grotesk,Segoe UI,sans-serif;color:#132238;background:radial-gradient(circle at top left,rgba(240,196,25,.18),transparent 32%),radial-gradient(circle at top right,rgba(31,74,102,.16),transparent 30%),linear-gradient(180deg,#f6f8fb,#edf3f7);--navy: #17324d;--navy-2: #254a68;--paper: #ffffff;--line: #d8e2ec;--muted: #60758a;--success: #208154;--warning: #d3a016;--danger: #c44032;--orange: #cb6a12;--gray: #708090;--shadow: 0 18px 42px rgba(17, 34, 52, .08)}*{box-sizing:border-box}body{margin:0;min-height:100vh}body,button,input,select,textarea{font:inherit}h1,h2,h3,h4,p{margin:0}button,.button-link{border:0;border-radius:14px;background:linear-gradient(135deg,var(--navy) 0%,var(--navy-2) 100%);color:#fff;cursor:pointer;padding:11px 16px;text-decoration:none;text-align:center;transition:transform .15s ease,box-shadow .15s ease,opacity .15s ease}button:hover,.button-link:hover{transform:translateY(-1px);box-shadow:0 10px 18px #17324d33}button:disabled,.button-link:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.ghost-button{background:#eef3f7;color:var(--navy)}.btn-like{border:0;border-radius:10px;background:#1f2937;color:#e5e7eb;padding:9px 14px;cursor:pointer}.btn-like:hover{background:#111827;box-shadow:none;transform:none}input,select,textarea{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:14px;background:#fff;color:inherit}textarea{resize:vertical}button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,.nav-link:focus-visible{outline:3px solid rgba(36,100,158,.25);outline-offset:2px}label,.eyebrow,.muted-text{color:var(--muted)}.eyebrow{font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase}.app-shell{display:grid;grid-template-columns:280px 1fr;min-height:100vh}.sandbox-banner{background:linear-gradient(90deg,#854d0e,#92400e,#854d0e);background-size:200% 100%;animation:banner-slide 4s linear infinite;color:#fef3c7;font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;text-align:center;padding:8px 16px;display:flex;align-items:center;justify-content:center;gap:10px;position:sticky;top:0;z-index:100}.sandbox-banner .dot{width:7px;height:7px;background:#fbbf24;border-radius:50%;animation:pulse-dot 1.5s ease-in-out infinite;flex-shrink:0}.sidebar{background:radial-gradient(circle at top,rgba(240,196,25,.22),transparent 25%),linear-gradient(180deg,#10243b,#17324d 60%,#1f4564);color:#fff;padding:28px 22px;display:grid;align-content:start;gap:22px}.brand-block p{margin-top:8px;color:#d8e9f5}.sidebar nav{display:grid;gap:10px}.sidebar-logout{margin-top:auto}.nav-link{color:#ebf3f8;text-decoration:none;display:flex;gap:12px;align-items:center;padding:12px 14px;border-radius:14px;border:1px solid rgba(255,255,255,.12);background:#ffffff0a}.nav-link:hover{background:#ffffff14}.nav-link--active{background:#f0c41929;border-color:#f0c41980;color:#fff8d8}.tooltip-wrap{position:relative}.tooltip-bubble{position:absolute;left:calc(100% + 8px);top:50%;transform:translateY(-50%);background:#10243b;color:#fff;padding:6px 9px;border-radius:10px;font-size:12px;white-space:nowrap;z-index:30}.content{padding:28px;display:grid;gap:18px}.page-grid{display:grid;gap:18px}.section-head{display:flex;justify-content:space-between;align-items:center;gap:14px}.section-head p{margin-top:6px;color:var(--muted)}.card{background:#fffffff0;border:1px solid rgba(216,226,236,.92);border-radius:22px;padding:18px;display:grid;gap:12px;box-shadow:var(--shadow)}.two-col{display:grid;grid-template-columns:1.15fr 1fr;gap:18px}.tab-row,.chip-row,.inline-actions{display:flex;flex-wrap:wrap;gap:10px}.quickstart-card{background:radial-gradient(circle at top right,rgba(74,222,128,.12),transparent 24%),linear-gradient(180deg,#10243b,#17324d);color:#eef6fb;border-color:#60a5fa40}.quickstart-card .eyebrow{color:#93c5fd}.steps{display:grid;gap:10px}.step{display:flex;gap:12px;align-items:flex-start}.step-num{background:#1e3a5fe6;color:#93c5fd;border-radius:999px;width:24px;height:24px;display:inline-grid;place-items:center;font-size:11px;font-weight:700;flex-shrink:0}.step-text{color:#d4e2ee;line-height:1.5;font-size:13px}.csv-strip{display:flex;gap:10px;flex-wrap:wrap}.csv-btn{display:inline-flex;align-items:center;gap:8px;border-radius:12px;padding:9px 14px;background:#10243b59;border:1px solid rgba(74,222,128,.45);color:#8af0b2}.csv-btn:hover{background:#14532de6}.csv-btn--muted{border-color:#93c5fd59;color:#c6def5}.csv-icon{font-size:15px}.demo-shell{min-height:100vh;background:#0f0f0f;color:#eee}.demo-main{max-width:960px;margin:0 auto;padding:28px 20px 48px}.demo-header{margin-bottom:24px}.demo-header h1{font-size:26px;font-weight:700;color:#4ade80;letter-spacing:-.5px}.demo-header p{color:#94a3b8;font-size:13px;margin-top:4px}.demo-card{background:#111827;border:1px solid #1f2937;border-radius:14px;padding:16px}.demo-drop{margin-bottom:8px;background:#111827;border-color:#4ade80}.demo-drop .drop-zone__title{color:#d1fae5}.demo-drop .drop-zone__hint{color:#94a3b8}.demo-msg{min-height:22px;font-size:13px;margin:6px 0 14px}.demo-msg--success{color:#4ade80}.demo-msg--error{color:#ef4444}.demo-msg--warning{color:#facc15}.demo-two-col{display:grid;grid-template-columns:1fr 340px;gap:20px;align-items:start}.demo-feed-wrap{position:relative;width:100%}.demo-feed{width:100%;border-radius:14px;border:2px solid #333;display:block;aspect-ratio:4 / 3;object-fit:contain;background:#111}.demo-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.demo-box{position:absolute;border:2px solid #f97316;box-shadow:inset 0 0 0 1px #0003}.demo-box--known{border-color:#4ade80}.demo-box__label{position:absolute;left:-2px;top:-30px;background:#f97316;color:#fff;font-size:12px;font-weight:700;padding:5px 8px;border-radius:8px;white-space:nowrap}.demo-box--known .demo-box__label{background:#15803d}.demo-feed-placeholder{width:100%;aspect-ratio:4 / 3;border-radius:14px;border:2px solid #333;background:#111;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:8px;color:#475569;font-size:13px}.demo-feed-emoji{font-size:32px}.demo-toolbar{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px;align-items:center}.cam-state{font-size:12px;color:#93c5fd;align-self:center}.cam-state.off{color:#fca5a5}.people-list{display:grid;gap:6px}.person-row{display:flex;align-items:center;justify-content:space-between;background:#1a2e1a;border:1px solid #166534;border-radius:8px;padding:6px 10px}.person-name{font-size:13px;color:#d1fae5}.person-del{background:none;border:none;color:#ef4444;cursor:pointer;font-size:14px;padding:2px 4px;line-height:1}.person-del:hover{box-shadow:none;transform:none;color:#f87171}.empty-roster{color:#475569;font-size:13px;text-align:center;padding:20px 0}.drop-zone{border:2px dashed rgba(32,129,84,.45);border-radius:18px;padding:18px;display:grid;gap:6px;text-align:center;cursor:pointer;background:#2081540a;transition:border-color .15s ease,background .15s ease,transform .15s ease}.drop-zone:hover,.drop-zone--active{background:#2081541a;border-color:var(--success);transform:translateY(-1px)}.drop-zone input{display:none}.drop-zone__title{font-weight:700;color:var(--navy)}.drop-zone__hint{color:var(--muted);font-size:13px}.photo-naming-guide{display:grid;gap:10px;padding:14px;border-radius:16px;background:#f6fbf7;border:1px solid rgba(32,129,84,.14)}.photo-naming-guide h4{margin:0;color:var(--navy);font-size:.96rem}.photo-naming-guide p{margin:0;color:var(--muted);line-height:1.5}.naming-examples{display:grid;gap:8px}.naming-example{display:grid;grid-template-columns:auto 1fr;gap:10px;align-items:start;padding:10px 12px;border-radius:12px}.naming-example--good{background:#20815414}.naming-example--bad{background:#c4403214}.naming-icon{font-weight:700}.naming-example code{display:inline-block;margin-bottom:4px}.naming-example small{display:block;color:var(--muted)}.tab-button,.choice-chip{background:#edf2f7;color:var(--navy)}.tab-button--active,.choice-chip--active{background:linear-gradient(135deg,#d49d17,#f0c419);color:#132238}.thumb-grid,.person-grid,.camera-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.thumb,.person-photo{width:100%;height:128px;object-fit:cover;border-radius:16px;background:#ecf2f8}.placeholder{display:block}.person-card,.list-row{display:grid;gap:10px;align-items:center;border:1px solid var(--line);border-radius:18px;padding:12px;background:#fff}.list-board{display:grid;gap:10px}.list-row{grid-template-columns:minmax(0,1.5fr) auto auto auto}.search-input{max-width:280px}.table{width:100%;border-collapse:collapse}.table th,.table td{text-align:left;padding:10px 8px;border-bottom:1px solid var(--line)}.inline-form{display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.row{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:10px 0;border-bottom:1px solid var(--line)}.badge{color:#fff;border-radius:999px;font-size:12px;padding:5px 10px;width:fit-content}.badge.online{background:var(--success)}.badge.offline{background:var(--danger)}.stat-strip{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px}.stat-chip{border-radius:18px;padding:14px;color:#fff;display:grid;gap:4px}.stat-chip--green{background:linear-gradient(135deg,#1d7d54,#2aa56f)}.stat-chip--yellow{background:linear-gradient(135deg,#b78b18,#d9ac19)}.stat-chip--orange{background:linear-gradient(135deg,#b96016,#d77f30)}.stat-chip--red{background:linear-gradient(135deg,#a5372b,#d54b3c)}.stat-chip--gray{background:linear-gradient(135deg,#5e6b77,#7f8b96)}.stat-chip-count{font-size:28px;font-weight:700}.stat-chip-label{font-size:13px;letter-spacing:.03em}.stat-chip--alert{animation:pulse 1.4s ease-in-out infinite}.quality-meter{display:grid;gap:8px}.quality-meter-head{display:flex;justify-content:space-between;font-size:13px;color:var(--muted)}.quality-meter-track{height:10px;border-radius:999px;background:#ebf1f6;overflow:hidden}.quality-meter-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,#d3a016,#1d7d54)}.empty-state{border:1px dashed var(--line);border-radius:16px;padding:20px;color:var(--muted);text-align:center}.skeleton{border-radius:14px;background:linear-gradient(90deg,#eef3f7 25%,#f7fafc,#eef3f7 75%);background-size:200% 100%;animation:shimmer 1.4s infinite linear}.skeleton-input{height:44px}.skeleton-row{height:58px}.skeleton-panel{min-height:280px}.modal-backdrop,.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:grid;place-items:center;padding:20px;z-index:50}.drawer-backdrop{place-items:stretch end}.modal-card,.drawer-card{background:#fff;border-radius:24px;width:min(520px,100%);padding:18px;display:grid;gap:14px;box-shadow:0 28px 70px #0f172a3d}.drawer-card{height:100%;max-width:460px;border-radius:24px 0 0 24px}.modal-head{display:flex;justify-content:space-between;gap:12px;align-items:start}.modal-form,.drawer-form,.auth-form{display:grid;gap:12px}.alert-list{margin:0;padding-left:18px;display:grid;gap:8px}.login-wrap{min-height:100vh;display:grid;place-items:center;padding:28px}.auth-panel{width:min(1080px,100%);display:grid;grid-template-columns:1.1fr .9fr;gap:22px;align-items:stretch}.auth-copy{padding:32px;border-radius:28px;color:#fff;background:radial-gradient(circle at top right,rgba(240,196,25,.26),transparent 24%),linear-gradient(135deg,#11253c,#17324d 55%,#275273);display:grid;gap:14px}.auth-copy h1{font-size:clamp(32px,4vw,54px);line-height:.95}.auth-copy p:last-child{color:#d9e7f3}.auth-card{align-content:start}.auth-loading{min-height:100vh;display:grid;place-items:center;color:var(--muted)}.error{color:var(--danger)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}@keyframes banner-slide{0%{background-position:0% 0}to{background-position:200% 0}}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}@media (max-width: 980px){.app-shell{grid-template-columns:1fr}.sidebar{gap:14px}.two-col,.demo-two-col,.auth-panel,.stat-strip{grid-template-columns:1fr}.list-row,.section-head,.row{grid-template-columns:1fr;display:grid}.tooltip-bubble{display:none}}.auth-card--enhanced{gap:18px}.auth-tabs{background:#eef4f8;border-radius:18px;padding:6px}.auth-form--rich>div{display:grid;gap:8px}.auth-form--rich label{font-size:.92rem;font-weight:700;color:var(--ink)}.field-hint{margin:0;color:var(--muted);font-size:.88rem}.field-hint--error{color:var(--danger)}.auth-error{margin:0;padding:12px 14px;border-radius:14px;background:#c6282814;color:var(--danger);border:1px solid rgba(198,40,40,.18)}.password-field{display:grid;grid-template-columns:1fr auto;align-items:center;gap:8px;padding-right:6px;border:1px solid rgba(16,42,67,.12);border-radius:16px;background:#fff}.password-field input{border:0;background:transparent}.password-field input:focus{box-shadow:none}.icon-button{border:0;background:transparent;color:var(--muted);display:inline-grid;place-items:center;width:36px;height:36px;border-radius:999px}.icon-button:hover{background:#102a4314}.password-strength{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center;color:var(--muted);font-size:.88rem}.password-strength__bar{--segments: 4;--width: calc((100% / var(--segments)) * var(--strength));height:8px;border-radius:999px;background:linear-gradient(90deg,var(--strength-color) var(--width),rgba(16,42,67,.08) var(--width))}.password-strength__bar--muted{--strength-color: #a0aec0}.password-strength__bar--danger{--strength-color: #d64545}.password-strength__bar--warning{--strength-color: #f0a202}.password-strength__bar--info{--strength-color: #2f7ed8}.password-strength__bar--success{--strength-color: #1f9d55}.dev-hint{justify-self:start;border:1px dashed rgba(255,255,255,.4);background:#ffffff14;color:#fff;border-radius:999px;padding:10px 14px}.spinner{animation:spin 1s linear infinite}.inline-actions{display:inline-flex;gap:8px;margin-left:10px}.ghost-button{background:transparent;color:var(--ink);border:1px solid rgba(16,42,67,.16)}.badge.warning{background:#f0a20224;color:#8b5e00}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 640px){.password-strength{grid-template-columns:1fr}.inline-actions{display:flex;margin:10px 0 0}}
