.app{min-height:100vh;display:flex;flex-direction:column}.header{background:#fff;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}.header-inner{max-width:1100px;margin:0 auto;padding:0 1.5rem;height:56px;display:flex;align-items:center;justify-content:space-between;gap:1rem}.logo{display:flex;align-items:center;gap:8px;font-weight:700;font-size:15px;color:var(--text);text-decoration:none}.logo-icon{width:30px;height:30px;background:var(--blue);border-radius:7px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:700;flex-shrink:0}.logo-badge{font-size:12px;font-weight:500;color:var(--text-secondary);padding:2px 8px;background:var(--bg);border:1px solid var(--border);border-radius:20px}.header-right{display:flex;align-items:center;gap:10px}.last-updated{font-size:11px;color:var(--text-muted)}.refresh-btn{width:30px;height:30px;border-radius:6px;border:1px solid var(--border);background:var(--bg);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;font-size:14px;transition:all .15s}.refresh-btn:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-light)}.refresh-btn.spinning{animation:spin .6s linear infinite}.period-tabs{display:flex;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:3px;gap:2px}.period-tab{padding:5px 16px;border-radius:6px;font-size:13px;font-weight:500;color:var(--text-secondary);border:none;background:none;transition:all .15s}.period-tab.active{background:var(--blue);color:#fff;box-shadow:0 1px 2px #2563eb4d}.period-tab:hover:not(.active){color:var(--text);background:var(--card)}.main{max-width:1100px;margin:0 auto;padding:1.25rem 1.5rem 3rem;flex:1;width:100%;animation:fadeIn .3s ease}.top-row{display:grid;grid-template-columns:auto 1fr;gap:12px;margin-bottom:1.5rem;align-items:stretch}.stats-col{display:flex;flex-direction:column;gap:6px;min-width:200px}.stat-item{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:8px 14px;box-shadow:var(--shadow);display:flex;align-items:center;gap:10px;flex:1}.stat-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.stat-dot.blue{background:var(--blue)}.stat-dot.red{background:var(--red)}.stat-dot.green{background:var(--green)}.stat-label{font-size:12px;font-weight:500;color:var(--text-secondary);flex:1}.stat-value{font-size:18px;font-weight:700;color:var(--text);line-height:1}.stat-value.blue{color:var(--blue)}.stat-value.red{color:var(--red)}.stat-value.green{color:var(--green)}.stat-value.sm{font-size:14px;font-weight:600}.chart-card{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:12px 14px 10px;box-shadow:var(--shadow);display:flex;flex-direction:column}.chart-bars{display:flex;align-items:flex-end;gap:5px;flex:1;min-height:60px;margin-top:10px}.bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;height:100%;justify-content:flex-end}.bar-cnt{font-size:10px;color:var(--text-muted);font-weight:600}.bar{width:100%;border-radius:3px 3px 0 0;min-height:3px;background:var(--blue-mid);transition:background .15s}.bar.peak,.bar:hover{background:var(--blue)}.bar-dt{font-size:9px;color:var(--text-muted);white-space:nowrap}.section-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.section-title{font-size:13px;font-weight:600;color:var(--text)}.section-meta{font-size:12px;color:var(--text-muted)}.violators-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:14px}.v-card{background:var(--card);border:1px solid var(--border);border-radius:12px;overflow:hidden;box-shadow:var(--shadow);transition:box-shadow .15s,transform .15s,border-color .15s;cursor:pointer}.v-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:var(--border-strong)}.v-img-wrap{position:relative;aspect-ratio:16/10;background:#f3f4f6;overflow:hidden}.v-img-wrap img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s,opacity .3s}.v-card:hover .v-img-wrap img{transform:scale(1.03)}.v-img-wrap img.img-loading{opacity:0}.img-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#f3f4f6;color:#d1d5db;font-size:36px;transition:opacity .2s}.img-placeholder.hidden{opacity:0;pointer-events:none}.rank-badge{position:absolute;top:8px;left:8px;font-size:11px;font-weight:700;padding:3px 8px;border-radius:20px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.rank-1{background:#ffc800eb;color:#7a5800}.rank-2{background:#c8d2dceb;color:#3a4a5a}.rank-3{background:#c38c5aeb;color:#5a3010}.rank-n{background:#ffffffd1;color:var(--text-secondary)}.v-body{padding:10px 14px 12px;display:flex;align-items:center;justify-content:space-between}.plate{display:inline-flex;align-items:stretch;border:2px solid #1a1a1a;border-radius:5px;background:#fff;overflow:hidden;box-shadow:inset 0 0 0 1px #0000000d}.plate-ru-style{height:32px}.plate-main{display:flex;align-items:center;padding:0 7px;gap:1px}.plate-letter{font-size:17px;font-weight:800;color:#111;line-height:1;font-family:Arial Narrow,Arial,sans-serif}.plate-digits{font-size:17px;font-weight:800;color:#111;letter-spacing:.04em;padding:0 2px;line-height:1;font-family:Arial Narrow,Arial,sans-serif}.plate-divider{width:1px;background:#ccc;align-self:stretch;margin:4px 0}.plate-region{display:flex;align-items:center;padding:0 8px;font-size:13px;font-weight:700;color:#555;background:#f4f4f4;font-family:Arial Narrow,Arial,sans-serif}.plate-plain{height:32px;display:flex;align-items:center;padding:0 10px;font-size:15px;font-weight:700;color:#111;letter-spacing:.08em;font-family:Courier New,monospace}.violation-count{display:flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:var(--text-secondary)}.v-dot{width:7px;height:7px;border-radius:50%}.v-dot.many{background:var(--red)}.v-dot.some{background:var(--amber)}.v-dot.once{background:var(--blue)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:200;display:flex;align-items:center;justify-content:center;padding:1.5rem;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:fadeIn .15s ease}.modal{background:var(--card);border-radius:14px;max-width:960px;width:100%;overflow:hidden;box-shadow:var(--shadow-lg);animation:pop-in .18s ease;display:flex;flex-direction:column;max-height:calc(100vh - 3rem)}.modal-img-wrap{flex:1;min-height:0;background:#0d0d0d;display:flex;align-items:center;justify-content:center;overflow:hidden}.modal-img{width:100%;height:100%;max-height:calc(100vh - 3rem - 56px);object-fit:contain;display:block}.modal-footer{padding:12px 18px;display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--border);flex-shrink:0;gap:10px;background:#fff}.modal-close{font-size:12px;font-weight:500;color:var(--text-secondary);background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:6px 14px;transition:all .13s}.modal-close:hover{background:var(--border);color:var(--text)}.loading-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:5rem 2rem;gap:14px;color:var(--text-secondary);font-size:13px}.spinner{width:28px;height:28px;border:2.5px solid var(--border);border-top-color:var(--blue);border-radius:50%;animation:spin .75s linear infinite}.error-wrap{text-align:center;padding:4rem 2rem;color:var(--red);font-size:13px}.retry-btn{margin-top:12px;padding:7px 18px;background:var(--blue);color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:500;transition:background .15s}.retry-btn:hover{background:var(--blue-dark)}.empty-grid{grid-column:1/-1;text-align:center;padding:3rem;color:var(--text-muted);font-size:13px}@media (max-width: 700px){.top-row{grid-template-columns:1fr}.stats-col{flex-direction:row;flex-wrap:wrap;min-width:unset}.stat-item{flex:1;min-width:140px}.header-inner{padding:0 1rem}.main{padding:1rem 1rem 2rem}.period-tabs,.last-updated{display:none}}:root{--blue: #2563eb;--blue-dark: #1d4ed8;--blue-light: #eff6ff;--blue-mid: #bfdbfe;--green: #16a34a;--green-light: #f0fdf4;--red: #dc2626;--red-light: #fef2f2;--amber: #d97706;--amber-light: #fffbeb;--text: #111827;--text-secondary: #6b7280;--text-muted: #9ca3af;--border: #e5e7eb;--border-strong: #d1d5db;--bg: #f9fafb;--card: #ffffff;--shadow: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 6px rgba(0,0,0,.07), 0 2px 4px rgba(0,0,0,.05);--shadow-lg: 0 10px 25px rgba(0,0,0,.1), 0 4px 10px rgba(0,0,0,.06);--sans: "Inter", -apple-system, sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--sans);font-size:14px;line-height:1.5;min-height:100vh}button{cursor:pointer;font-family:var(--sans)}img{max-width:100%}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--blue)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pop-in{0%{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}
