@import "https://fonts.googleapis.com/css2?family=Sora:wght@300;400;500;600;700&family=DM+Mono:wght@400;500&display=swap";:root{--c-bg:#070d1a;--c-surface:#0d1528;--c-surface-2:#131e35;--c-surface-3:#182240;--c-border:#ffffff12;--c-border-2:#ffffff1f;--c-primary:#1d6ef5;--c-primary-lo:#1d6ef51f;--c-primary-hi:#4d8fff;--c-amber:#f5a623;--c-amber-lo:#f5a6231f;--c-text:#e8edf8;--c-text-2:#8a97b0;--c-text-3:#4a5568;--c-error:#f04040;--c-error-lo:#f040401f;--c-success:#22c55e;--c-success-lo:#22c55e1f;--badge-blue-bg:#1d6ef526;--badge-blue:#4d8fff;--badge-green-bg:#22c55e26;--badge-green:#22c55e;--badge-amber-bg:#f5a62326;--badge-amber:#f5a623;--badge-red-bg:#f0404026;--badge-red:#f04040;--badge-gray-bg:#ffffff14;--badge-gray:#8a97b0;--shadow-card:0 4px 24px #0006,0 1px 0 #ffffff0a inset;--shadow-glow:0 0 40px #1d6ef533;--sidebar-w:240px;--topbar-h:60px;--ease:cubic-bezier(.22,1,.36,1)}[data-theme=light]{--c-bg:#f0f4fb;--c-surface:#fff;--c-surface-2:#f5f8ff;--c-surface-3:#e8edf8;--c-border:#00000012;--c-border-2:#0000001f;--c-primary:#1d6ef5;--c-primary-lo:#1d6ef51a;--c-primary-hi:#1558cc;--c-amber:#d97706;--c-amber-lo:#d977061a;--c-text:#0f172a;--c-text-2:#475569;--c-text-3:#94a3b8;--c-error:#dc2626;--c-error-lo:#dc26261a;--c-success:#16a34a;--c-success-lo:#16a34a1a;--badge-blue-bg:#1d6ef51a;--badge-blue:#1558cc;--badge-green-bg:#16a34a1a;--badge-green:#16a34a;--badge-amber-bg:#d977061a;--badge-amber:#d97706;--badge-red-bg:#dc26261a;--badge-red:#dc2626;--badge-gray-bg:#0000000f;--badge-gray:#64748b;--shadow-card:0 2px 12px #00000014,0 1px 0 #fffc inset;--shadow-glow:0 0 40px #1d6ef514}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;height:100%}body{background:var(--c-bg);color:var(--c-text);-webkit-font-smoothing:antialiased;min-height:100dvh;font-family:Sora,sans-serif;font-size:14px;line-height:1.6;transition:background .25s,color .25s}#root{min-height:100dvh}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,select{font-family:inherit}a{color:var(--c-primary-hi);text-decoration:none}img{max-width:100%;display:block}@keyframes spin{to{transform:rotate(360deg)}}@keyframes card-in{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes orb-float{0%,to{transform:translateY(0)scale(1)}50%{transform:translateY(-30px)scale(1.05)}}.spin{animation:.8s linear infinite spin}.app-shell{min-height:100dvh;display:flex}.app-body{min-width:0;margin-left:var(--sidebar-w);min-height:100dvh;transition:margin-left .3s var(--ease);flex-direction:column;flex:1;display:flex}.app-main{flex:1;overflow-y:auto}.sidebar{width:var(--sidebar-w);background:var(--c-surface);border-right:1px solid var(--c-border);z-index:200;transition:transform .3s var(--ease),background .25s,border-color .25s;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;overflow:hidden}.sidebar-overlay{z-index:199;background:#00000080;animation:.2s both fade-in;display:none;position:fixed;inset:0}.sidebar__brand{border-bottom:1px solid var(--c-border);flex-shrink:0;align-items:center;gap:12px;padding:10px 18px;display:flex}.sidebar__logo{width:32px;height:32px;color:var(--c-primary-hi);filter:drop-shadow(0 0 8px #4d8fff59);flex-shrink:0}.sidebar__brand-text{flex-direction:column;min-width:0;line-height:1.2;display:flex}.sidebar__brand-title{letter-spacing:.12em;white-space:nowrap;font-size:13px;font-weight:700}.sidebar__brand-sub{letter-spacing:.1em;color:var(--c-primary-hi);font-size:10px;font-weight:500}.sidebar__section-label{letter-spacing:.1em;text-transform:uppercase;color:var(--c-text-3);flex-shrink:0;padding:16px 18px 6px;font-size:10px;font-weight:600}.sidebar__nav{flex-direction:column;flex:1;gap:2px;padding:0 10px;display:flex;overflow-y:auto}.sidebar__link{color:var(--c-text-2);white-space:nowrap;border-radius:8px;align-items:center;gap:10px;padding:10px 12px;font-size:13px;font-weight:500;text-decoration:none;transition:color .2s,background .2s;display:flex}.sidebar__link-icon{flex-shrink:0;width:18px;height:18px;display:flex}.sidebar__link-icon svg{width:100%;height:100%}.sidebar__link:hover{color:var(--c-text);background:var(--c-border)}.sidebar__link.active{color:var(--c-primary-hi);background:var(--c-primary-lo);font-weight:600}.sidebar__link.active .sidebar__link-icon{color:var(--c-primary-hi)}.sidebar__footer{border-top:1px solid var(--c-border);color:var(--c-text-3);flex-shrink:0;padding:14px 18px;font-size:11px}.topbar{height:var(--topbar-h);background:var(--c-surface);border-bottom:1px solid var(--c-border);z-index:100;flex-shrink:0;justify-content:space-between;align-items:center;padding:0 24px;transition:background .25s,border-color .25s;display:flex;position:sticky;top:0}.topbar__left{align-items:center;gap:12px;display:flex}.topbar__page-title{color:var(--c-text);font-size:15px;font-weight:600}.topbar__right{align-items:center;gap:8px;display:flex}.btn-hamburger{width:36px;height:36px;color:var(--c-text-2);border-radius:6px;justify-content:center;align-items:center;transition:color .2s,background .2s;display:none}.btn-hamburger svg{width:18px;height:18px}.btn-hamburger:hover{color:var(--c-text);background:var(--c-border)}.btn-icon{width:36px;height:36px;color:var(--c-text-2);border-radius:8px;justify-content:center;align-items:center;transition:color .2s,background .2s;display:flex}.btn-icon svg{width:17px;height:17px}.btn-icon:hover{color:var(--c-text);background:var(--c-border)}.avatar-wrap{position:relative}.topbar__avatar-btn{cursor:pointer;border-radius:8px;align-items:center;gap:6px;padding:4px 8px 4px 4px;transition:background .2s;display:flex}.topbar__avatar-btn:hover,.topbar__avatar-btn.active{background:var(--c-border)}.topbar__avatar{background:var(--c-primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:600;display:flex}.avatar-caret{width:14px;height:14px;color:var(--c-text-2)}.avatar-dropdown{background:var(--c-surface);border:1px solid var(--c-border-2);z-index:300;width:240px;animation:card-in .18s var(--ease) both;border-radius:12px;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden;box-shadow:0 8px 32px #0000004d}.avatar-dropdown__header{align-items:center;gap:12px;padding:14px 16px;display:flex}.avatar-dropdown__avatar{background:var(--c-primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:15px;font-weight:600;display:flex}.avatar-dropdown__info{flex-direction:column;min-width:0;display:flex}.avatar-dropdown__info strong{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.avatar-dropdown__info span{color:var(--c-text-2);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.avatar-dropdown__role{background:var(--c-primary-lo);color:var(--c-primary-hi);text-transform:capitalize;border-radius:20px;width:fit-content;margin-top:3px;padding:2px 7px;font-size:10px;font-weight:600;display:inline-flex}.avatar-dropdown__divider{background:var(--c-border);height:1px;margin:0 16px}.avatar-dropdown__meta{justify-content:space-between;align-items:center;padding:7px 16px;font-size:12px;display:flex}.avatar-dropdown__meta span:first-child{color:var(--c-text-2)}.avatar-dropdown__meta span:last-child{color:var(--c-text);font-weight:500}.avatar-dropdown__logout{width:100%;color:var(--c-error);text-align:left;align-items:center;gap:8px;padding:12px 16px;font-size:13px;font-weight:500;transition:background .2s;display:flex}.avatar-dropdown__logout svg{width:15px;height:15px}.avatar-dropdown__logout:hover{background:var(--c-error-lo)}.page-content{flex-direction:column;gap:24px;width:100%;max-width:1600px;margin:0 auto;padding:28px 28px 40px;display:flex}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.page-header__title{font-size:20px;font-weight:600}.page-header__title span{color:var(--c-primary-hi)}.page-header__sub{color:var(--c-text-2);margin-top:3px;font-size:13px}.alert-cpw{background:var(--c-amber-lo);color:var(--c-amber);border:1px solid #f5a62340;border-radius:6px;align-items:center;gap:8px;padding:10px 16px;font-size:13px;font-weight:500;display:flex}.alert-cpw svg{flex-shrink:0;width:15px;height:15px}.dash-cards{grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:14px;display:grid}.dash-card{background:var(--c-surface);border:1px solid var(--c-border);box-shadow:var(--shadow-card);animation:card-in .4s var(--ease) both;border-radius:12px;align-items:flex-start;gap:12px;padding:18px;transition:border-color .2s,background .25s;display:flex}.dash-card:hover{border-color:var(--c-border-2)}.dash-card--accent{background:linear-gradient(135deg,#1d6ef50f,var(--c-surface));border-color:#1d6ef533}.dash-card__icon{background:var(--c-primary-lo);width:34px;height:34px;color:var(--c-primary-hi);border:1px solid #1d6ef526;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.dash-card__icon svg{width:15px;height:15px}.dash-card__label{text-transform:uppercase;letter-spacing:.06em;color:var(--c-text-2);font-size:11px;font-weight:500}.dash-card__value{word-break:break-word;margin-top:3px;font-size:14px;font-weight:600}.dash-empty{flex:1;justify-content:center;align-items:center;min-height:180px;display:flex}.dash-empty__inner{text-align:center;flex-direction:column;align-items:center;gap:10px;display:flex}.dash-empty__inner svg{width:44px;height:44px;color:var(--c-text-3);opacity:.5}.dash-empty__inner p{color:var(--c-text-2);font-size:14px;font-weight:500}.dash-empty__inner span{color:var(--c-text-3);font-size:13px}.login-page{justify-content:center;align-items:center;min-height:100dvh;padding:24px;display:flex;position:relative;overflow:hidden}.login-bg{pointer-events:none;z-index:0;position:fixed;inset:0}.login-bg__orb{filter:blur(120px);border-radius:50%;position:absolute}.login-bg__orb--1{opacity:.28;background:radial-gradient(circle,#1d6ef5 0%,#0000 70%);width:600px;height:600px;animation:8s ease-in-out infinite orb-float;top:-200px;left:-100px}.login-bg__orb--2{opacity:.13;background:radial-gradient(circle,#f5a623 0%,#0000 70%);width:500px;height:500px;animation:10s ease-in-out infinite reverse orb-float;bottom:-150px;right:-50px}.login-bg__grid{background-image:linear-gradient(#ffffff06 1px,#0000 1px),linear-gradient(90deg,#ffffff06 1px,#0000 1px);background-size:40px 40px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(80% 80%,#000 0%,#0000 100%);mask-image:radial-gradient(80% 80%,#000 0%,#0000 100%)}[data-theme=light] .login-bg__grid{background-image:linear-gradient(#0000000a 1px,#0000 1px),linear-gradient(90deg,#0000000a 1px,#0000 1px)}.login-card{z-index:1;background:var(--c-surface);border:1px solid var(--c-border-2);width:100%;max-width:420px;box-shadow:var(--shadow-card),var(--shadow-glow);border-radius:20px;padding:40px;position:relative}.login-card--anim{animation:card-in .5s var(--ease) both}.login-card__brand{align-items:center;gap:16px;margin-bottom:28px;display:flex}.login-card__logo{width:48px;height:48px;color:var(--c-primary-hi);filter:drop-shadow(0 0 12px #4d8fff59);flex-shrink:0}.login-card__logo svg{width:100%;height:100%}.login-card__title{letter-spacing:.12em;font-size:18px;font-weight:700}.login-card__subtitle{letter-spacing:.08em;color:var(--c-text-2);text-transform:uppercase;margin-top:2px;font-size:11px}.login-card__divider{background:linear-gradient(90deg,transparent,var(--c-border-2),transparent);height:1px;margin-bottom:28px}.login-card__footer{color:var(--c-text-3);text-align:center;margin-top:24px;font-size:11px}.login-form{flex-direction:column;gap:20px;display:flex}.field{flex-direction:column;gap:6px;display:flex}.field__label{letter-spacing:.04em;color:var(--c-text-2);text-transform:uppercase;font-size:12px;font-weight:500}.field__wrap{align-items:center;display:flex;position:relative}.field__icon{width:16px;height:16px;color:var(--c-text-3);pointer-events:none;transition:color .2s;position:absolute;left:14px}.field__wrap:focus-within .field__icon{color:var(--c-primary-hi)}.field__input{background:var(--c-surface-2);border:1px solid var(--c-border-2);width:100%;color:var(--c-text);border-radius:6px;outline:none;padding:11px 44px 11px 42px;font-size:14px;transition:border-color .2s,box-shadow .2s,background .2s}.field__input::placeholder{color:var(--c-text-3)}.field__input:focus{border-color:var(--c-primary);box-shadow:0 0 0 3px var(--c-primary-lo);background:var(--c-surface)}.field--error .field__input{border-color:var(--c-error);box-shadow:0 0 0 3px var(--c-error-lo)}.field__error{color:var(--c-error);min-height:16px;font-size:12px}.field__toggle{width:28px;height:28px;color:var(--c-text-3);border-radius:4px;justify-content:center;align-items:center;transition:color .2s,background .2s;display:flex;position:absolute;right:12px}.field__toggle:hover{color:var(--c-text-2);background:var(--c-border)}.field__toggle svg{width:15px;height:15px}.btn-login{background:var(--c-primary);color:#fff;letter-spacing:.04em;border-radius:6px;justify-content:center;align-items:center;gap:8px;width:100%;margin-top:4px;padding:13px;font-size:14px;font-weight:600;transition:background .2s,transform .1s,box-shadow .2s;display:flex;position:relative}.btn-login:before{content:"";opacity:0;border-radius:inherit;background:linear-gradient(135deg,#ffffff1a,#0000);transition:opacity .2s;position:absolute;inset:0}.btn-login:hover:not(:disabled):before{opacity:1}.btn-login:hover:not(:disabled){background:var(--c-primary-hi);box-shadow:0 4px 20px #1d6ef580}.btn-login:active:not(:disabled){transform:scale(.98)}.btn-login:disabled{opacity:.7;cursor:not-allowed}.btn-login .spin{width:18px;height:18px}.toast-container{z-index:9999;pointer-events:none;flex-direction:column;align-items:center;gap:8px;display:flex;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}.toast{background:var(--c-surface-2);border:1px solid var(--c-border-2);white-space:nowrap;opacity:0;max-width:90vw;transition:opacity .25s,transform .3s var(--ease);border-radius:40px;align-items:center;gap:10px;padding:11px 18px;font-size:13px;font-weight:500;display:flex;transform:translateY(12px);box-shadow:0 8px 32px #00000040}.toast--visible{opacity:1;transform:translateY(0)}.toast--error{color:var(--c-error);border-color:#f040404d}.toast--success{color:var(--c-success);border-color:#22c55e4d}.filter-bar{background:var(--c-surface);border:1px solid var(--c-border);box-shadow:var(--shadow-card);border-radius:12px;flex-direction:column;gap:16px;padding:20px;transition:background .25s,border-color .25s;display:flex}.filter-grid{grid-template-columns:repeat(auto-fill,minmax(175px,1fr));gap:12px;display:grid}.filter-field{flex-direction:column;gap:5px;display:flex}.filter-field label{text-transform:uppercase;letter-spacing:.05em;color:var(--c-text-2);font-size:11px;font-weight:500}.filter-field input,.filter-select-wrap select{background:var(--c-surface-2);border:1px solid var(--c-border-2);color:var(--c-text);appearance:none;border-radius:6px;outline:none;width:100%;padding:8px 10px;font-size:13px;transition:border-color .2s,box-shadow .2s}.filter-field input:focus,.filter-select-wrap select:focus{border-color:var(--c-primary);box-shadow:0 0 0 3px var(--c-primary-lo)}.filter-select-wrap{position:relative}.filter-select-wrap svg{width:14px;height:14px;color:var(--c-text-3);pointer-events:none;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.filter-select-wrap select{padding-right:30px}.filter-select-wrap select:disabled{opacity:.45;cursor:not-allowed}.filter-actions{border-top:1px solid var(--c-border);justify-content:flex-end;gap:8px;padding-top:8px;display:flex}.btn-primary,.btn-secondary{border-radius:6px;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;transition:background .2s,box-shadow .2s,transform .1s,opacity .2s;display:flex}.btn-primary svg,.btn-secondary svg{width:14px;height:14px}.btn-primary{background:var(--c-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--c-primary-hi);box-shadow:0 3px 12px #1d6ef566}.btn-primary:active:not(:disabled){transform:scale(.97)}.btn-primary:disabled,.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--c-surface-2);border:1px solid var(--c-border-2);color:var(--c-text-2)}.btn-secondary:hover:not(:disabled){color:var(--c-text);background:var(--c-border)}.btn-back{background:var(--c-surface);border:1px solid var(--c-border-2);color:var(--c-text-2);border-radius:8px;align-self:flex-start;align-items:center;gap:6px;padding:7px 14px;font-size:13px;font-weight:500;transition:color .2s,border-color .2s,background .2s;display:inline-flex}.btn-back svg{width:16px;height:16px}.btn-back:hover{color:var(--c-primary-hi);border-color:var(--c-primary);background:var(--c-primary-lo)}.captures-card{background:var(--c-surface);border:1px solid var(--c-border);box-shadow:var(--shadow-card);border-radius:12px;transition:background .25s,border-color .25s;overflow:clip}.table-state{color:var(--c-text-2);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:60px 24px;font-size:14px;display:flex}.table-state svg{width:40px;height:40px;color:var(--c-text-3);opacity:.5}.table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.data-table{border-collapse:collapse;width:100%;min-width:700px;font-size:13px}.data-table th{text-align:left;background:var(--c-surface-2);border-bottom:1px solid var(--c-border);text-transform:uppercase;letter-spacing:.06em;color:var(--c-text-2);white-space:nowrap;padding:11px 14px;font-size:11px;font-weight:600}.data-table td{border-bottom:1px solid var(--c-border);color:var(--c-text);vertical-align:middle;padding:12px 14px;transition:background .15s}.data-table tr:last-child td{border-bottom:none}.tr--clickable{cursor:pointer}.tr--clickable:hover td{background:var(--c-surface-2)}.plate-no{background:var(--c-surface-2);border:1px solid var(--c-border-2);white-space:nowrap;letter-spacing:.06em;border-radius:4px;padding:3px 8px;font-family:DM Mono,monospace;font-size:12px;font-weight:500}.td-date{white-space:nowrap;color:var(--c-text-2);font-size:12px}.td-mono{color:var(--c-text-2);font-family:DM Mono,monospace;font-size:12px}.td-location{text-overflow:ellipsis;white-space:nowrap;max-width:200px;color:var(--c-text-2);font-size:12px;overflow:hidden}.violation-cell{flex-direction:column;gap:2px;display:flex}.violation-name{font-weight:500}.violation-code{color:var(--c-text-3);letter-spacing:.04em;font-family:DM Mono,monospace;font-size:10px}.badge{letter-spacing:.03em;white-space:nowrap;border-radius:20px;align-items:center;padding:3px 8px;font-size:11px;font-weight:600;display:inline-flex}.badge--lg{padding:4px 12px;font-size:12px}.badge--blue{background:var(--badge-blue-bg);color:var(--badge-blue)}.badge--green{background:var(--badge-green-bg);color:var(--badge-green)}.badge--amber{background:var(--badge-amber-bg);color:var(--badge-amber)}.badge--red{background:var(--badge-red-bg);color:var(--badge-red)}.badge--gray{background:var(--badge-gray-bg);color:var(--badge-gray)}.badge--source-manual{background:var(--c-primary-lo);color:var(--c-primary-hi)}.badge--source-hybrid{background:var(--c-amber-lo);color:var(--c-amber)}.badge--source-ai{color:#a78bfa;background:#8b5cf626}.badge--source-auto{background:var(--c-success-lo);color:var(--c-success)}.pagination{border-top:1px solid var(--c-border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;padding:12px 16px;display:flex}.pagination__info{color:var(--c-text-2);font-size:13px}.pagination__info strong{color:var(--c-text)}.pagination__btns{align-items:center;gap:8px;display:flex}.pagination__page{background:var(--c-primary-lo);min-width:32px;height:32px;color:var(--c-primary-hi);border-radius:6px;justify-content:center;align-items:center;font-size:13px;font-weight:600;display:flex}.btn-page{background:var(--c-surface-2);border:1px solid var(--c-border-2);color:var(--c-text-2);border-radius:6px;align-items:center;gap:5px;padding:7px 12px;font-size:13px;font-weight:500;transition:color .2s,background .2s,border-color .2s;display:flex}.btn-page svg{width:14px;height:14px}.btn-page:hover:not(:disabled){color:var(--c-text);border-color:var(--c-primary)}.btn-page:disabled{opacity:.4;cursor:not-allowed}.detail-loading{color:var(--c-text-2);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:80px 24px;display:flex}.detail-loading svg{width:36px;height:36px}.detail-layout{flex-direction:column;gap:20px;display:flex}.detail-hero{background:var(--c-surface);border:1px solid var(--c-border);box-shadow:var(--shadow-card);border-radius:14px;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:20px;padding:24px 28px;display:flex}.detail-hero__left{flex-direction:column;gap:10px;min-width:0;display:flex}.detail-hero__plate{letter-spacing:.12em;color:var(--c-text);font-family:DM Mono,monospace;font-size:32px;font-weight:700;line-height:1}.detail-hero__badges{flex-wrap:wrap;gap:6px;display:flex}.detail-hero__violation{color:var(--c-text-2);font-size:15px;font-weight:500}.detail-hero__date{color:var(--c-text-3);font-size:12px}.detail-hero__meta{flex-direction:column;flex-shrink:0;gap:8px;display:flex}.detail-hero__meta-item{flex-direction:column;align-items:flex-end;gap:1px;display:flex}.detail-hero__meta-item span{color:var(--c-text-3);font-size:11px}.detail-hero__meta-item strong{color:var(--c-text);font-size:13px}.text-success{color:var(--c-success)!important}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;padding:12px;display:grid}.photo-thumb{aspect-ratio:4/3;background:var(--c-surface-2);border:1px solid var(--c-border);cursor:zoom-in;border-radius:8px;position:relative;overflow:hidden}.photo-thumb img{object-fit:cover;width:100%;height:100%;transition:transform .3s}.photo-thumb__overlay{opacity:0;background:#0006;justify-content:center;align-items:center;transition:opacity .2s;display:flex;position:absolute;inset:0}.photo-thumb__overlay svg{color:#fff;width:22px;height:22px}.photo-thumb:hover img{transform:scale(1.04)}.photo-thumb:hover .photo-thumb__overlay{opacity:1}.lightbox{z-index:9998;background:#000000e6;justify-content:center;align-items:center;padding:24px;animation:.2s fade-in;display:flex;position:fixed;inset:0}.lightbox img{object-fit:contain;border-radius:8px;max-width:100%;max-height:90vh}.lightbox__close{color:#fff;background:#ffffff26;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;transition:background .2s;display:flex;position:absolute;top:20px;right:20px}.lightbox__close:hover{background:#ffffff40}.lightbox__close svg{width:18px;height:18px}.detail-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;display:grid}.detail-section{background:var(--c-surface);border:1px solid var(--c-border);box-shadow:var(--shadow-card);border-radius:12px;overflow:hidden}.detail-section__title{letter-spacing:.03em;border-bottom:1px solid var(--c-border);background:var(--c-surface-2);align-items:center;gap:8px;padding:14px 18px;font-size:13px;font-weight:600;display:flex}.detail-section__title svg{width:15px;height:15px;color:var(--c-primary-hi);flex-shrink:0}.detail-section__body{padding:4px 0}.info-row{border-bottom:1px solid var(--c-border);justify-content:space-between;align-items:flex-start;gap:12px;padding:10px 18px;display:flex}.info-row:last-child{border-bottom:none}.info-row__label{color:var(--c-text-2);flex-shrink:0;min-width:120px;padding-top:1px;font-size:12px}.info-row__value{color:var(--c-text);text-align:right;word-break:break-word;font-size:13px;font-weight:500}.info-row__value--mono{font-family:DM Mono,monospace;font-size:12px}.etlenas-log{flex-direction:column;gap:0;padding:16px 18px;display:flex}.etlenas-log__item{gap:14px;padding-bottom:16px;display:flex;position:relative}.etlenas-log__item:last-child{padding-bottom:0}.etlenas-log__item:not(:last-child):before{content:"";background:var(--c-border-2);width:1px;position:absolute;top:18px;bottom:0;left:7px}.etlenas-log__dot{background:var(--c-primary-lo);border:2px solid var(--c-primary);border-radius:50%;flex-shrink:0;width:15px;height:15px;margin-top:2px}.etlenas-log__content{flex:1;min-width:0}.etlenas-log__status{color:var(--c-text);font-size:13px;font-weight:500}.etlenas-log__time{color:var(--c-text-3);margin-top:2px;font-size:11px}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--c-border-2);border-radius:99px}@media (width<=1024px){:root{--sidebar-w:200px}.page-content{padding:24px 20px 36px}}@media (width<=768px){:root{--sidebar-w:240px}.sidebar{transform:translate(-100%)}.sidebar--open{transform:translate(0)}.sidebar-overlay{display:block}.app-body{margin-left:0}.btn-hamburger{display:flex}.topbar{padding:0 16px}.page-content{padding:20px 16px 32px}.filter-grid,.dash-cards{grid-template-columns:1fr 1fr}.detail-hero{padding:18px 20px}.detail-hero__plate{font-size:24px}.detail-grid{grid-template-columns:1fr}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}}@media (width<=520px){.login-card{padding:26px 18px}.filter-grid,.dash-cards{grid-template-columns:1fr}.pagination{flex-direction:column;align-items:flex-start}.detail-hero{flex-direction:column}.detail-hero__meta{flex-flow:wrap;align-items:flex-start;gap:12px}.detail-hero__meta-item{align-items:flex-start}.info-row{flex-direction:column;gap:3px}.info-row__value{text-align:left}.info-row__label{min-width:unset}}.etle-section{border-color:#1d6ef533}.detail-section__header{border-bottom:1px solid var(--c-border);background:var(--c-surface-2);justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.btn-etle-refresh{width:30px;height:30px;color:var(--c-text-2);border-radius:6px;justify-content:center;align-items:center;transition:color .2s,background .2s;display:flex}.btn-etle-refresh svg{width:14px;height:14px}.btn-etle-refresh:hover{color:var(--c-primary-hi);background:var(--c-primary-lo)}.etle-cta{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:18px 20px;display:flex}.etle-cta__info p{color:var(--c-text-2);font-size:13px}.etle-cta__info p+p{margin-top:4px}.etle-cta__meta{color:var(--c-text-3);font-size:12px}.etle-cta__meta strong{color:var(--c-text-2)}.btn-etle{white-space:nowrap;border-radius:8px;align-items:center;gap:8px;padding:10px 20px;font-size:13px;font-weight:600;transition:background .2s,box-shadow .2s,transform .1s;display:inline-flex}.btn-etle svg{flex-shrink:0;width:15px;height:15px}.btn-etle__id{opacity:.7;font-family:DM Mono,monospace;font-size:11px}.btn-etle--primary{background:var(--c-primary);color:#fff}.btn-etle--primary:hover{background:var(--c-primary-hi);box-shadow:0 3px 16px #1d6ef566}.btn-etle--primary:active{transform:scale(.97)}.btn-etle--secondary{background:var(--c-surface-2);border:1px solid var(--c-border-2);color:var(--c-text-2)}.btn-etle--secondary:hover{color:var(--c-primary-hi);border-color:var(--c-primary);background:var(--c-primary-lo)}.badge--source-resend{color:#c084fc;background:#8b5cf626}.etle-state{color:var(--c-text-2);align-items:center;gap:10px;padding:18px 20px;font-size:13px;display:flex}.etle-state svg{width:18px;height:18px}.etle-error{color:var(--c-error);background:var(--c-error-lo);align-items:center;gap:10px;padding:14px 20px;font-size:13px;display:flex}.etle-error svg{flex-shrink:0;width:16px;height:16px}.etle-retry{background:var(--c-error);color:#fff;border-radius:5px;margin-left:auto;padding:5px 12px;font-size:12px;font-weight:600}.etle-notfound{color:var(--c-text-2);align-items:center;gap:10px;padding:18px 20px;font-size:13px;display:flex}.etle-notfound svg{width:16px;height:16px;color:var(--c-text-3);flex-shrink:0}.etle-result{flex-direction:column;gap:0;display:flex}.etle-summary{border-bottom:1px solid var(--c-border);grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:0;display:grid}.etle-summary__item{border-right:1px solid var(--c-border);flex-direction:column;gap:3px;padding:14px 18px;display:flex}.etle-summary__item:last-child{border-right:none}.etle-summary__item span{color:var(--c-text-2);text-transform:uppercase;letter-spacing:.05em;font-size:11px;font-weight:500}.etle-summary__item strong{color:var(--c-text);font-size:13px;font-weight:600}.etle-summary__item .mono{font-family:DM Mono,monospace;font-size:12px}.etle-status-row{border-bottom:1px solid var(--c-border);flex-wrap:wrap;gap:0;display:flex}.etle-status-item{border-right:1px solid var(--c-border);flex-direction:column;flex:1;gap:4px;min-width:160px;padding:12px 18px;display:flex}.etle-status-item:last-child{border-right:none}.etle-status-item__label{color:var(--c-text-2);text-transform:uppercase;letter-spacing:.05em;font-size:11px;font-weight:500}.etle-status-item__meta{color:var(--c-text-3);font-size:11px}.etle-status-item__date{color:var(--c-text);font-size:13px;font-weight:500}.etle-chip{border-radius:20px;align-items:center;gap:4px;width:fit-content;padding:3px 9px;font-size:11px;font-weight:600;display:inline-flex}.etle-chip svg{width:11px;height:11px}.etle-chip--ok{background:var(--badge-green-bg);color:var(--badge-green)}.etle-chip--no{background:var(--badge-red-bg);color:var(--badge-red)}.etle-photos{border-bottom:1px solid var(--c-border);flex-wrap:wrap;gap:12px;padding:16px 18px;display:flex}.etle-photo{flex-direction:column;gap:6px;display:flex}.etle-photo span{color:var(--c-text-2);font-size:11px;font-weight:500}.etle-photo img{object-fit:cover;border:1px solid var(--c-border);border-radius:6px;width:180px;height:120px}.etle-wilayah{flex-direction:column;gap:12px;padding:16px 18px;display:flex}.wilayah-result{background:var(--c-surface-2);border:1px solid var(--c-border);border-radius:10px;overflow:hidden}.wilayah-result__header{background:var(--c-primary-lo);border-bottom:1px solid #1d6ef526;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;padding:12px 16px;display:flex}.wilayah-result__title{color:var(--c-text);font-size:13px;font-weight:600}.wilayah-result__badges{gap:6px;display:flex}.wilayah-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:0;display:grid}.wilayah-section{border-right:1px solid var(--c-border);border-bottom:1px solid var(--c-border);padding:12px 16px}.wilayah-section:nth-last-child(-n+2){border-bottom:none}.wilayah-section__label{text-transform:uppercase;letter-spacing:.06em;color:var(--c-text-3);margin-bottom:3px;font-size:10px;font-weight:600}.wilayah-section__value{color:var(--c-text);font-size:13px;font-weight:600}.wilayah-section__sub{color:var(--c-text-2);margin-top:2px;font-size:11px;line-height:1.4}@media (width<=768px){.etle-summary{grid-template-columns:1fr 1fr}.etle-summary__item{border-right:none;border-bottom:1px solid var(--c-border)}.etle-status-row{flex-direction:column}.etle-status-item{border-right:none;border-bottom:1px solid var(--c-border)}.etle-status-item:last-child{border-bottom:none}.etle-photos{flex-direction:column}.etle-photo img{width:100%;height:auto}.wilayah-grid{grid-template-columns:1fr}.wilayah-section{border-right:none}.wilayah-section:nth-last-child(-n+2){border-bottom:1px solid var(--c-border)}.wilayah-section:last-child{border-bottom:none}}@media (width<=480px){.etle-cta{flex-direction:column;align-items:flex-start}.etle-summary{grid-template-columns:1fr}}.ss-wrap{width:100%;position:relative}.ss-wrap--disabled{opacity:.45;pointer-events:none}.ss-trigger{background:var(--c-surface-2);border:1px solid var(--c-border-2);width:100%;color:var(--c-text);cursor:pointer;text-align:left;border-radius:6px;justify-content:space-between;align-items:center;gap:6px;padding:8px 10px;font-size:13px;transition:border-color .2s,box-shadow .2s;display:flex}.ss-trigger:focus,.ss-wrap--open .ss-trigger{border-color:var(--c-primary);box-shadow:0 0 0 3px var(--c-primary-lo);outline:none}.ss-trigger__label{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.ss-trigger__label--placeholder{color:var(--c-text-3)}.ss-trigger__right{flex-shrink:0;align-items:center;gap:4px;display:flex}.ss-clear{width:18px;height:18px;color:var(--c-text-3);border-radius:3px;flex-shrink:0;justify-content:center;align-items:center;transition:color .15s,background .15s;display:flex}.ss-clear svg{width:10px;height:10px}.ss-clear:hover{color:var(--c-error);background:var(--c-error-lo)}.ss-caret{width:14px;height:14px;color:var(--c-text-3);flex-shrink:0;transition:transform .2s}.ss-caret--open{transform:rotate(180deg)}.ss-dropdown{background:var(--c-surface);border:1px solid var(--c-border-2);z-index:500;animation:card-in .15s var(--ease) both;border-radius:8px;min-width:200px;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow:hidden;box-shadow:0 8px 24px #0000004d}.ss-search{border-bottom:1px solid var(--c-border);background:var(--c-surface);z-index:1;align-items:center;gap:8px;padding:8px 10px;display:flex;position:sticky;top:0}.ss-search svg{width:14px;height:14px;color:var(--c-text-3);flex-shrink:0}.ss-search input{color:var(--c-text);background:0 0;border:none;outline:none;flex:1;font-size:13px}.ss-search input::placeholder{color:var(--c-text-3)}.ss-search-clear{width:18px;height:18px;color:var(--c-text-3);border-radius:3px;justify-content:center;align-items:center;display:flex}.ss-search-clear svg{width:10px;height:10px}.ss-search-clear:hover{color:var(--c-error)}.ss-list{max-height:220px;padding:4px 0;overflow-y:auto}.ss-option{width:100%;color:var(--c-text);text-align:left;border-radius:0;justify-content:space-between;align-items:center;gap:8px;padding:8px 12px;font-size:13px;transition:background .12s;display:flex}.ss-option:hover{background:var(--c-border)}.ss-option--active{background:var(--c-primary-lo);color:var(--c-primary-hi);font-weight:500}.ss-option--active:hover{background:var(--c-primary-lo)}.ss-option__label{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.ss-option__label--all{color:var(--c-text-2);font-style:italic}.ss-option__check{width:13px;height:13px;color:var(--c-primary-hi);flex-shrink:0}.ss-empty{color:var(--c-text-3);text-align:center;flex-direction:column;align-items:center;gap:6px;padding:20px 16px;font-size:13px;display:flex}.ss-empty svg{opacity:.5;width:24px;height:24px}.ss-footer{border-top:1px solid var(--c-border);color:var(--c-text-3);padding:6px 12px;font-size:11px}.raw-data{border-top:1px solid var(--c-border)}.raw-data__toggle{width:100%;color:var(--c-text-3);text-align:left;align-items:center;gap:8px;padding:10px 18px;font-size:12px;font-weight:500;transition:color .2s,background .2s;display:flex}.raw-data__toggle svg:first-child{width:13px;height:13px;color:var(--c-primary-hi);flex-shrink:0}.raw-data__toggle:hover{color:var(--c-text-2);background:var(--c-border)}.raw-data__caret{width:14px;height:14px;margin-left:auto;transition:transform .2s}.raw-data__caret--open{transform:rotate(180deg)}.raw-data__pre{background:var(--c-bg);border-top:1px solid var(--c-border);color:var(--c-text-2);white-space:pre;max-height:360px;margin:0;padding:16px 18px;font-family:DM Mono,monospace;font-size:11px;line-height:1.6;overflow:auto}
