:root{--bg-base: #0f172a;--bg-surface: #1e293b;--bg-card: #243044;--bg-hover: #2d3f58;--bg-input: #162032;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--shadow: 0 4px 16px rgba(0, 0, 0, .4);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);color-scheme:dark}[data-theme=light]{--bg-base: #f1f5f9;--bg-surface: #ffffff;--bg-card: #f8fafc;--bg-hover: #e2e8f0;--bg-input: #f8fafc;--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #94a3b8;--border: #cbd5e1;--border-light: #e2e8f0;--shadow: 0 4px 16px rgba(0, 0, 0, .1);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .08);color-scheme:light}:root{--accent-green: #22c55e;--accent-green-hover: #16a34a;--accent-green-dim: rgba(34, 197, 94, .15);--accent-red: #ef4444;--accent-red-hover: #dc2626;--accent-blue: #3b82f6;--accent-yellow: #f59e0b;--accent-orange: #f97316;--gold: #ffd700;--silver: #c0c0c0;--bronze: #cd7f32;--border: #334155;--border-light: #475569;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;font-family:Inter,system-ui,-apple-system,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;min-height:100vh}body{background-color:var(--bg-base);color:var(--text-primary);font-size:16px;line-height:1.5;min-width:320px}h1,h2,h3,h4{line-height:1.2;color:var(--text-primary)}a{color:var(--accent-green);text-decoration:none}.app{display:flex;flex-direction:column;min-height:100vh}.navbar{display:flex;align-items:center;gap:1rem;background:var(--bg-surface);border-bottom:1px solid var(--border);padding:0 1.5rem;height:60px;position:sticky;top:0;z-index:100;box-shadow:var(--shadow-sm);flex-wrap:wrap}.navbar-brand{display:flex;align-items:center;gap:.5rem;font-size:1.25rem;font-weight:700;color:var(--text-primary);white-space:nowrap}.brand-logo{height:2rem;width:auto;filter:brightness(0) invert(1);transition:filter .2s}[data-theme=light] .brand-logo{filter:none}.tab-nav{display:flex;gap:.25rem;flex:1;justify-content:center}.tab-btn{display:flex;align-items:center;gap:.4rem;padding:.5rem 1.25rem;border-radius:var(--radius-sm);border:1px solid transparent;background:transparent;color:var(--text-secondary);font-size:.95rem;font-weight:500;font-family:inherit;cursor:pointer;transition:background .15s,color .15s,border-color .15s;white-space:nowrap}.tab-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border)}.tab-btn-active,.tab-btn-active:hover{background:var(--accent-green-dim);color:var(--accent-green);border-color:var(--accent-green)}.tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:10px;background:var(--border);color:var(--text-primary);font-size:.75rem;font-weight:600}.tab-badge-active{background:var(--accent-green);color:#000}[data-theme=light] .tab-badge:not(.tab-badge-active){background:#64748b;color:#fff}.navbar-status{display:flex;align-items:center;gap:.4rem;font-size:.8rem;font-weight:600;color:var(--accent-green);white-space:nowrap}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--accent-green);box-shadow:0 0 6px var(--accent-green);animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.main-content{flex:1;padding:1.5rem;max-width:1100px;margin:0 auto;width:100%}button{cursor:pointer;font-family:inherit;border:none;outline:none;transition:background .15s,opacity .15s,transform .1s}button:active:not(:disabled){transform:scale(.97)}button:disabled{opacity:.4;cursor:not-allowed}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1.1rem;border-radius:var(--radius-sm);font-size:.9rem;font-weight:600;white-space:nowrap}.btn-primary{background:var(--accent-green);color:#000}.btn-primary:hover{background:var(--accent-green-hover)}.btn-secondary{background:var(--bg-hover);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--border-light);background:var(--border)}.btn-danger{background:var(--accent-red);color:#fff}.btn-danger:hover{background:var(--accent-red-hover)}.btn-warning-outline{background:none;border:1px solid var(--accent-yellow);color:var(--accent-yellow)}.btn-warning-outline:hover,.btn-warning{background:var(--accent-yellow);color:#000}.btn-warning:hover{background:#d97706}.btn-export{background:var(--accent-blue);color:#fff}.btn-export:hover{background:#2563eb}.btn-sm{padding:.35rem .75rem;font-size:.82rem}.btn-tab{padding:.45rem 1rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-surface);color:var(--text-secondary);font-size:.9rem;font-weight:500}.btn-tab:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-tab-active{background:var(--accent-green-dim);color:var(--accent-green);border-color:var(--accent-green)}.btn-tab-active:hover{background:var(--accent-green-dim);color:var(--accent-green)}.badge{display:inline-flex;align-items:center;padding:.2rem .6rem;border-radius:20px;font-size:.78rem;font-weight:600}.badge-green{background:var(--accent-green-dim);color:var(--accent-green);border:1px solid var(--accent-green)}.badge-muted{background:var(--bg-hover);color:var(--text-secondary);border:1px solid var(--border)}.dorsal-badge{display:inline-block;padding:.1rem .5rem;background:var(--bg-hover);border:1px solid var(--border-light);border-radius:var(--radius-sm);font-family:monospace;font-size:.9rem;font-weight:700;color:var(--text-primary)}.gender-badge{display:inline-block;padding:.1rem .5rem;border-radius:var(--radius-sm);font-weight:700;font-size:.85rem}.gender-m{background:#3b82f626;color:#60a5fa;border:1px solid rgba(59,130,246,.3)}.gender-f{background:#ec489926;color:#f472b6;border:1px solid rgba(236,72,153,.3)}.category-tag{display:inline-block;padding:.1rem .5rem;background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);border-radius:var(--radius-sm);font-size:.8rem;color:var(--accent-yellow);font-weight:500;white-space:nowrap}.text-muted{color:var(--text-muted)}.text-center{text-align:center}.table-wrapper{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--border)}.data-table{width:100%;border-collapse:collapse;font-size:.9rem}.data-table thead{background:var(--bg-hover)}.data-table th{padding:.65rem .85rem;text-align:left;font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary);border-bottom:1px solid var(--border);white-space:nowrap}.data-table td{padding:.6rem .85rem;border-bottom:1px solid var(--border);vertical-align:middle}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:var(--bg-hover)}.sample-table{width:100%;border-collapse:collapse;font-size:.875rem}.sample-table th{padding:.5rem .75rem;text-align:left;background:var(--bg-hover);color:var(--accent-green);font-size:.8rem;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border)}.sample-table td{padding:.45rem .75rem;border-bottom:1px solid var(--border);color:var(--text-secondary);font-family:monospace}.sample-table tbody tr:last-child td{border-bottom:none}.time-cell{font-family:monospace;font-size:.95rem;color:var(--accent-green);font-weight:600}.name-cell{font-weight:500}.upload-container{display:flex;flex-direction:column;gap:1.5rem}.section-header{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.section-header h2{font-size:1.4rem;font-weight:700}.drop-zone{border:2px dashed var(--border-light);border-radius:var(--radius-lg);padding:2.5rem 2rem;text-align:center;cursor:pointer;background:var(--bg-surface);transition:border-color .2s,background .2s;-webkit-user-select:none;user-select:none}.drop-zone:hover,.drop-zone:focus{border-color:var(--accent-green);background:var(--accent-green-dim);outline:none}.drop-zone.drag-over{border-color:var(--accent-green);background:var(--accent-green-dim);box-shadow:0 0 0 4px #22c55e26}.drop-zone.drop-zone-loaded{border-color:var(--accent-green);border-style:solid}.drop-icon{font-size:2.5rem;margin-bottom:.75rem}.drop-title{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.drop-subtitle{font-size:.9rem;color:var(--text-secondary);margin-bottom:.25rem}.drop-hint{font-size:.8rem;color:var(--text-muted)}.error-panel{background:#ef444414;border:1px solid rgba(239,68,68,.35);border-radius:var(--radius-md);padding:1rem 1.25rem}.error-title{font-size:.95rem;font-weight:600;color:var(--accent-red);margin-bottom:.5rem}.error-list{list-style:none;display:flex;flex-direction:column;gap:.3rem;font-size:.875rem;color:#fca5a5;max-height:200px;overflow-y:auto}.error-row{font-weight:600}.format-guide{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:1.25rem}.format-guide h3{font-size:.95rem;font-weight:600;margin-bottom:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.format-note{margin-top:.75rem;font-size:.82rem;color:var(--text-muted);line-height:1.6}.format-note strong{color:var(--text-secondary)}.preview-section{display:flex;flex-direction:column;gap:.75rem}.preview-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem}.preview-header h3{font-size:.95rem;font-weight:600;color:var(--text-secondary)}.finish-container{display:flex;flex-direction:column;gap:1.25rem}.pre-race{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:4rem 2rem;gap:1rem}.pre-race-icon{font-size:4rem}.pre-race-title{font-size:1.75rem;font-weight:700}.pre-race-subtitle{color:var(--text-secondary);font-size:1rem}.warning-box{background:#f59e0b1a;border:1px solid rgba(245,158,11,.35);border-radius:var(--radius-md);padding:1rem 1.5rem;color:var(--accent-yellow);max-width:400px}.btn-start{background:var(--accent-green);color:#000;font-size:1.4rem;font-weight:800;padding:1.1rem 3rem;border-radius:var(--radius-lg);letter-spacing:.05em;box-shadow:0 4px 20px #22c55e59;margin-top:.5rem}.btn-start:hover{background:var(--accent-green-hover);box-shadow:0 6px 24px #22c55e73}.finish-active{display:flex;flex-direction:column;gap:1.25rem}.finish-main-grid{display:grid;grid-template-columns:minmax(320px,.95fr) minmax(0,1.35fr);gap:1rem;align-items:start}.race-clock-wrapper{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:1.5rem 2rem;text-align:center;position:relative}.race-clock-label{font-size:.72rem;font-weight:700;letter-spacing:.12em;color:var(--accent-green);text-transform:uppercase;margin-bottom:.5rem}.race-clock{font-size:5rem;font-weight:900;font-family:Courier New,monospace;color:var(--text-primary);letter-spacing:.04em;line-height:1}.race-clock-meta{display:flex;align-items:baseline;justify-content:center;gap:.4rem;margin-top:.6rem}.race-clock-count{font-size:1.6rem;font-weight:800;color:var(--accent-green)}.race-clock-count-label{font-size:.85rem;color:var(--text-secondary)}.finish-header,.race-info,.race-label,.race-timer{display:none}.finisher-count{text-align:right;display:flex;flex-direction:column;align-items:flex-end}.count-number{font-size:2.5rem;font-weight:800;color:var(--accent-green);line-height:1}.count-label{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.numpad{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;margin-top:1rem}.numpad-key{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:1.6rem;font-weight:700;padding:.9rem 0;cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:manipulation;transition:background .08s,transform .08s;line-height:1}.numpad-key:active{background:var(--bg-hover);transform:scale(.95)}.numpad-del{color:var(--accent-red);font-size:1.4rem}.numpad-enter{background:var(--accent-green);border-color:var(--accent-green);color:#000;font-size:1.6rem}.numpad-enter:active{background:var(--accent-green-hover)}.dorsal-input-section{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;transition:box-shadow .2s}.dorsal-input-section.flash-success{box-shadow:0 0 0 3px var(--accent-green),0 4px 16px #22c55e33}.dorsal-form{display:flex;flex-direction:column;gap:.75rem}.dorsal-helper{font-size:.84rem;color:var(--text-muted)}.dorsal-label{font-size:.75rem;font-weight:700;letter-spacing:.1em;color:var(--text-secondary);text-transform:uppercase}.dorsal-input-row{display:flex;gap:.75rem;align-items:stretch}.dorsal-input{flex:1;background:var(--bg-card);border:2px solid var(--border-light);border-radius:var(--radius-md);padding:.75rem 1rem;font-size:2rem;font-weight:700;font-family:Courier New,monospace;color:var(--text-primary);text-align:center;transition:border-color .15s;min-width:0}.dorsal-input:focus{border-color:var(--accent-green);outline:none;box-shadow:0 0 0 3px #22c55e26}.dorsal-input.input-error{border-color:var(--accent-red)}.dorsal-input::-webkit-outer-spin-button,.dorsal-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.dorsal-input[type=number]{-moz-appearance:textfield}.btn-register{background:var(--accent-green);color:#000;font-size:1rem;font-weight:800;padding:.75rem 1.75rem;border-radius:var(--radius-md);letter-spacing:.05em}.btn-register:hover{background:var(--accent-green-hover)}.btn-register{min-height:56px}.mobile-register-bar{display:none}.input-error-msg{color:#fca5a5;font-size:.875rem;background:#ef444414;border:1px solid rgba(239,68,68,.25);border-radius:var(--radius-sm);padding:.5rem .75rem}.success-flash{margin-top:.75rem;padding:.6rem 1rem;background:#22c55e26;border:1px solid var(--accent-green);border-radius:var(--radius-sm);color:var(--accent-green);font-weight:600;font-size:.95rem;text-align:center;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.recent-finishers{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:1rem 1.25rem;min-height:100%}.recent-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.75rem}.recent-title{font-size:.8rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted)}.recent-total{display:flex;align-items:baseline;gap:.35rem}.recent-total-number{font-size:1.35rem;font-weight:800;color:var(--accent-green)}.recent-total-label{font-size:.78rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em}.recent-highlight{border:1px solid rgba(34,197,94,.35);background:linear-gradient(135deg,#22c55e24,#0f172a26);border-radius:var(--radius-md);padding:.9rem 1rem;margin-bottom:.85rem}.recent-highlight-top{display:flex;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.6rem}.recent-highlight-badge{font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-green)}.recent-highlight-time{font-family:monospace;font-size:1rem;font-weight:700;color:var(--text-primary)}.recent-highlight-main{display:flex;align-items:center;gap:.85rem}.recent-highlight-pos{min-width:3rem;height:3rem;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:#22c55e33;color:var(--accent-green);font-size:1rem;font-weight:800}.recent-highlight-body{display:flex;flex-direction:column;gap:.2rem;min-width:0}.recent-highlight-body strong{font-size:1rem;color:var(--text-primary)}.recent-highlight-body span{color:var(--text-secondary);font-size:.85rem}.finisher-list{list-style:none;display:flex;flex-direction:column;gap:.35rem}.finisher-item{display:flex;align-items:center;gap:.6rem;padding:.55rem .75rem;border-radius:var(--radius-sm);background:var(--bg-card);border:1px solid var(--border);font-size:.88rem;transition:background .15s}.finisher-item-latest{border-color:var(--accent-green);background:#22c55e12}.finisher-pos{min-width:2.5rem;font-weight:700;color:var(--text-secondary);font-size:.85rem}.finisher-dorsal{font-family:monospace;font-weight:700;min-width:2.5rem;color:var(--text-primary)}.finisher-name{flex:1;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.finisher-category{font-size:.75rem;color:var(--accent-yellow);min-width:7rem;text-align:right}.finisher-time{font-family:monospace;font-size:.88rem;color:var(--accent-green);font-weight:600;min-width:4.5rem;text-align:right}@media (max-width: 1024px){.finish-main-grid{grid-template-columns:1fr}}.btn-remove{background:transparent;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);font-size:.8rem;padding:.2rem .45rem;line-height:1;transition:background .15s,color .15s,border-color .15s}.btn-remove:hover{background:var(--accent-red);border-color:var(--accent-red);color:#fff}.results-container{display:flex;flex-direction:column;gap:1.25rem}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:5rem 2rem;text-align:center;gap:1rem}.empty-icon{font-size:3.5rem}.empty-state h2{font-size:1.5rem}.results-toolbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem}.view-toggle{display:flex;gap:.25rem}.results-actions{display:flex;gap:.5rem;flex-wrap:wrap}.edit-mode-banner{background:#f59e0b1a;border:1px solid rgba(245,158,11,.35);border-radius:var(--radius-sm);padding:.6rem 1rem;font-size:.85rem;color:var(--accent-yellow);font-weight:500}.missed-finisher-panel{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:1rem 1.25rem}.missed-finisher-title{font-size:.82rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:.75rem}.missed-finisher-form{display:flex;align-items:flex-end;gap:.75rem;flex-wrap:wrap}.missed-field{display:flex;flex-direction:column;gap:.3rem}.missed-label{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em}.missed-input{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);padding:.55rem .85rem;font-size:1rem;font-family:Courier New,monospace;font-weight:600}.missed-input:focus{outline:none;border-color:var(--accent-green)}.missed-input-dorsal{width:6rem}.missed-input-time{width:9rem}.missed-btn{padding:.55rem 1.25rem;white-space:nowrap}.missed-preview{margin-top:.5rem;font-size:.85rem;color:var(--accent-green);font-weight:500}.position-badge{display:inline-flex;align-items:center;justify-content:center;min-width:2rem;height:2rem;border-radius:50%;font-weight:700;font-size:.85rem;background:var(--bg-hover);color:var(--text-secondary)}.pos-1{background:#ffd70026;color:var(--gold);border:1px solid rgba(255,215,0,.4)}.pos-2{background:#c0c0c026;color:var(--silver);border:1px solid rgba(192,192,192,.4)}.pos-3{background:#cd7f3226;color:var(--bronze);border:1px solid rgba(205,127,50,.4)}.results-table .row-top-1{background:#ffd7000a}.results-table .row-top-2{background:#c0c0c00a}.results-table .row-top-3{background:#cd7f320a}.reorder-cell{display:flex;gap:2px;align-items:center;padding:.4rem .5rem!important}.reorder-btn{background:var(--bg-hover);border:1px solid var(--border);border-radius:4px;color:var(--text-secondary);padding:.2rem .4rem;font-size:.75rem;line-height:1;transition:background .12s,color .12s}.reorder-btn:hover:not(:disabled){background:var(--accent-green-dim);color:var(--accent-green);border-color:var(--accent-green)}.dq-btn{color:var(--text-secondary);border-color:var(--border)}.dq-btn:hover:not(:disabled){background:#ef444426;color:#ef4444;border-color:#ef4444}.undo-dq-btn:hover:not(:disabled){background:var(--accent-green-dim);color:var(--accent-green);border-color:var(--accent-green)}.row-dq{opacity:.55}.row-dq td{text-decoration:line-through}.row-dq .dq-badge{background:#ef444426;color:#ef4444;border:1px solid rgba(239,68,68,.4);text-decoration:none}.row-dq .dq-reason-inline{font-size:.78rem;color:#ef4444;text-decoration:none;opacity:.85}.dq-panel{border-left:3px solid #ef4444!important}.time-input-group{display:inline-flex;align-items:center;gap:0;background:var(--bg-surface);border:1px solid var(--border);border-radius:6px;padding:.15rem .35rem;transition:border-color .15s}.time-input-group:focus-within{border-color:var(--accent-green)}.time-input-segment{display:inline-flex;align-items:center}.time-segment-input{background:transparent;border:none;outline:none;color:var(--text-primary);font-family:var(--font-mono, monospace);font-size:.95rem;font-weight:600;width:2ch;text-align:center;padding:0;caret-color:var(--accent-green)}.time-segment-input:disabled{opacity:.5}.time-sep{color:var(--text-secondary);font-weight:700;font-size:.95rem;margin:0 1px;-webkit-user-select:none;user-select:none}.time-cell-editable{cursor:pointer;border-radius:4px;padding:.1rem .3rem;transition:background .12s;display:inline-flex;align-items:center;gap:.3rem}.time-cell-editable:hover{background:var(--bg-hover)}.time-edit-icon{font-size:.7rem;opacity:.45}.time-edit-cell{display:flex;align-items:center;gap:4px;flex-wrap:wrap}.time-confirm-btn:hover:not(:disabled){background:var(--accent-green-dim);color:var(--accent-green);border-color:var(--accent-green)}.time-edit-error{font-size:.72rem;color:#ef4444;width:100%}.distance-section{margin-bottom:2rem}.distance-section-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid var(--accent-green)}.absolute-winners{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem 1.5rem;margin-bottom:1.25rem}.absolute-winners-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.absolute-winners-badge{font-size:.7rem;font-weight:700;background:#f59e0b26;color:var(--accent-yellow);border-radius:99px;padding:.2rem .6rem;text-transform:uppercase;letter-spacing:.06em}.absolute-winners-title{font-size:1rem;font-weight:700;color:var(--text-primary)}.absolute-gender-group{margin-bottom:1rem}.absolute-gender-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);margin-bottom:.6rem}.category-section-divider{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);display:flex;align-items:center;gap:.75rem;margin:1.5rem 0 1rem}.category-section-divider:before,.category-section-divider:after{content:"";flex:1;height:1px;background:var(--border)}.distance-badge{background:var(--accent-green);color:#000;font-weight:800;font-size:1.1rem;padding:.25rem .9rem;border-radius:999px;letter-spacing:.05em}.category-view{display:flex;flex-direction:column;gap:1.5rem}.category-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem}.category-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.category-name{font-size:1.1rem;font-weight:700}.podium-row{display:flex;gap:.75rem;flex-wrap:wrap}.podium-card{flex:1;min-width:140px;max-width:220px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:1rem .75rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:.25rem;transition:transform .15s}.podium-card:hover{transform:translateY(-2px)}.podium-gold{border-color:#ffd70080;background:#ffd7000f}.podium-silver{border-color:#c0c0c066;background:#c0c0c00d}.podium-bronze{border-color:#cd7f3266;background:#cd7f320d}.podium-icon{font-size:1.75rem}.podium-position{font-size:.75rem;font-weight:700;letter-spacing:.06em;color:var(--text-muted);text-transform:uppercase}.podium-dorsal{font-family:monospace;font-size:.85rem;color:var(--text-secondary);font-weight:600}.podium-athlete-name{font-size:.9rem;font-weight:700;color:var(--text-primary);margin-top:.1rem;word-break:break-word}.podium-gold .podium-athlete-name{color:var(--gold)}.podium-silver .podium-athlete-name{color:var(--silver)}.podium-bronze .podium-athlete-name{color:var(--bronze)}.podium-time{font-family:monospace;font-size:1rem;font-weight:700;color:var(--accent-green)}.podium-overall{font-size:.72rem;color:var(--text-muted)}.acred-container{display:flex;flex-direction:column;gap:2rem}.acred-section{display:flex;flex-direction:column;gap:1rem}.acred-search-wrapper{position:relative}.acred-search-input{width:100%;background:var(--bg-surface);border:2px solid var(--border-light);border-radius:var(--radius-md);padding:.85rem 3rem .85rem 1.1rem;font-size:1.1rem;font-family:inherit;color:var(--text-primary);transition:border-color .15s,box-shadow .15s}.acred-search-input:focus{border-color:var(--accent-green);outline:none;box-shadow:0 0 0 3px #22c55e26}.acred-search-input::placeholder{color:var(--text-muted)}.acred-search-clear{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:transparent;border:none;color:var(--text-muted);font-size:1rem;padding:.25rem .4rem;line-height:1;border-radius:var(--radius-sm);transition:color .15s,background .15s}.acred-search-clear:hover{color:var(--text-primary);background:var(--bg-hover)}.acred-search-results{display:flex;flex-direction:column;gap:.75rem}.acred-searching,.acred-no-results{padding:1rem 1.25rem;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-muted);font-size:.9rem}.acred-add-btn{margin-top:.75rem;width:100%}.acred-add-form{margin-top:.75rem;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:1rem 1.25rem}.acred-add-form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.acred-add-form-title{font-weight:600;font-size:.95rem;color:var(--text-primary)}.acred-add-close{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:1rem;padding:.2rem .4rem;border-radius:4px}.acred-add-close:hover{background:var(--bg-hover);color:var(--text-primary)}.acred-add-fields{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:.75rem}.acred-add-field{display:flex;flex-direction:column;gap:.3rem;flex:1 1 200px}.acred-add-field-nombre{flex:2 1 300px}.acred-add-field-sm{flex:0 1 100px}.acred-add-label{font-size:.78rem;color:var(--text-secondary);font-weight:500}.acred-add-input{background:var(--bg-main);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);font-size:.9rem;padding:.4rem .6rem;outline:none;transition:border-color .15s}.acred-add-input:focus{border-color:var(--accent-green)}.acred-add-input:disabled{opacity:.5}.acred-add-actions{display:flex;gap:.5rem;margin-top:.75rem}.dni-lookup-status{font-size:.72rem;font-weight:400;margin-left:.4rem;color:var(--text-muted)}.dni-lookup-ok{color:var(--accent-green)}.dni-lookup-warn{color:#f59e0b}.acred-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.85rem;transition:border-color .15s}.acred-card:hover{border-color:var(--border-light)}.acred-card-busy{opacity:.7;pointer-events:none}.acred-card-identity{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;flex-wrap:wrap}.acred-card-info{display:flex;flex-direction:column;gap:.3rem;flex:1;min-width:0}.acred-documento{font-family:monospace;font-size:.85rem;color:var(--text-muted);font-weight:600}.acred-nombre{font-size:1.15rem;font-weight:700;color:var(--text-primary)}.acred-meta{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.acred-age{font-size:.85rem;color:var(--text-secondary)}.acred-dorsal-section{display:flex;flex-direction:column;align-items:flex-end;gap:.4rem;flex-shrink:0}.acred-dorsal-assigned{display:flex;flex-direction:column;align-items:flex-end;gap:.2rem}.acred-dorsal-label{font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted)}.acred-dorsal-num{font-size:1.2rem;padding:.2rem .65rem}.acred-dorsal-assign{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap;justify-content:flex-end}.acred-dorsal-input{width:90px;background:var(--bg-card);border:2px solid var(--border-light);border-radius:var(--radius-sm);padding:.5rem .6rem;font-size:1rem;font-family:monospace;font-weight:700;color:var(--text-primary);text-align:center;transition:border-color .15s}.acred-dorsal-input:focus{border-color:var(--accent-green);outline:none}.acred-no-dorsal{font-size:.875rem}.acred-assign-error{font-size:.8rem;color:#fca5a5;text-align:right;max-width:200px}.acred-toggles{display:flex;gap:.75rem}.acred-toggle-btn{display:flex;align-items:center;gap:.5rem;padding:.65rem 1.25rem;border-radius:var(--radius-md);border:2px solid transparent;font-size:.9rem;font-weight:600;min-height:48px;transition:background .15s,border-color .15s,color .15s;flex:1;justify-content:center}.acred-toggle-on{background:var(--accent-green-dim);border-color:var(--accent-green);color:var(--accent-green)}.acred-toggle-on:hover{background:#22c55e40}.acred-toggle-off{background:var(--bg-card);border-color:var(--border);color:var(--text-muted)}.acred-toggle-off:hover{border-color:var(--border-light);color:var(--text-secondary)}.acred-toggle-icon{font-size:1.1rem;font-weight:700;min-width:1.1rem;text-align:center}.acred-toggle-label{font-size:.875rem}.acred-btn-touch{min-height:48px;padding-left:1.25rem;padding-right:1.25rem}.acred-stats-bar{display:flex;align-items:center;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:1rem 1.5rem;gap:0;flex-wrap:wrap}.acred-stat{display:flex;flex-direction:column;align-items:center;gap:.15rem;flex:1;min-width:80px}.acred-stat-num{font-size:1.75rem;font-weight:800;color:var(--text-primary);line-height:1}.acred-stat-green{color:var(--accent-green)}.acred-stat-blue{color:var(--accent-blue)}.acred-stat-yellow{color:var(--accent-yellow)}.acred-stat-label{font-size:.75rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.acred-stat-divider{width:1px;height:40px;background:var(--border);flex-shrink:0}.acred-autoassign-row{display:flex}.acred-filter-tabs{display:flex;gap:.35rem;flex-wrap:wrap}.acred-table-doc{font-family:monospace;font-size:.875rem;color:var(--text-secondary)}.acred-table-toggle{display:inline-flex;align-items:center;justify-content:center;min-width:2.2rem;height:2.2rem;border-radius:var(--radius-sm);border:1px solid transparent;font-size:.9rem;font-weight:700;transition:background .12s,border-color .12s,color .12s}.acred-table-toggle-on{background:var(--accent-green-dim);border-color:var(--accent-green);color:var(--accent-green)}.acred-table-toggle-on:hover{background:#22c55e40}.acred-table-toggle-off{background:var(--bg-hover);border-color:var(--border);color:var(--text-muted)}.acred-table-toggle-off:hover{border-color:var(--border-light);color:var(--text-secondary)}.acred-dorsal-cell{min-width:110px}.acred-dorsal-edit-trigger{background:none;border:none;cursor:pointer;padding:.15rem .3rem;border-radius:.3rem;display:inline-flex;align-items:center}.acred-dorsal-edit-trigger:hover{background:var(--bg-hover)}.acred-dorsal-empty{font-size:.8rem;color:var(--accent-blue);font-weight:500}.acred-dorsal-edit{display:flex;align-items:center;gap:.25rem;flex-wrap:wrap}.acred-dorsal-input{width:70px;padding:.25rem .4rem;font-size:.85rem;background:var(--bg-input);border:1px solid var(--accent-blue);border-radius:.3rem;color:var(--text-primary);outline:none}.acred-dorsal-confirm{background:var(--accent-green);color:#000;border:none;border-radius:.3rem;padding:.2rem .45rem;font-size:.8rem;font-weight:700;cursor:pointer}.acred-dorsal-confirm:disabled{opacity:.5;cursor:not-allowed}.acred-dorsal-cancel{background:var(--bg-hover);color:var(--text-muted);border:1px solid var(--border);border-radius:.3rem;padding:.2rem .45rem;font-size:.8rem;cursor:pointer}.acred-dorsal-cancel:hover{color:var(--accent-red);border-color:var(--accent-red)}.acred-dorsal-err{font-size:.75rem;color:var(--accent-red);width:100%}.acred-empty{padding:2rem;text-align:center;color:var(--text-muted);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md)}@media (max-width: 768px){.navbar{height:auto;padding:.5rem .75rem;gap:.5rem;flex-wrap:nowrap}.navbar-brand{gap:.35rem}.brand-logo{height:1.6rem}.tab-nav{gap:.15rem}.tab-btn{padding:.5rem .65rem;font-size:.82rem}.navbar-status .status-text{display:none}.main-content{padding:.75rem}.table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.race-clock{font-size:3.8rem}.dorsal-input{font-size:2rem}.btn-register{font-size:1rem;padding:0 1rem}.numpad{gap:.6rem}.numpad-key{font-size:1.8rem;padding:1rem 0}.finisher-category{display:none}.acred-card-identity{flex-direction:column;gap:.75rem}.acred-dorsal-section{align-self:flex-start}.results-toolbar{flex-direction:column;align-items:stretch;gap:.5rem}.results-actions{justify-content:flex-end}.podium-row{gap:.5rem}.podium-card{padding:.75rem .5rem;min-width:90px}.podium-athlete-name{font-size:.75rem}.acred-stats-bar{flex-wrap:wrap;gap:.5rem}.acred-stat-divider{display:none}.acred-stat{min-width:calc(50% - .5rem);background:var(--bg-card);border-radius:var(--radius-sm);padding:.6rem}.missed-finisher-form{flex-direction:column;align-items:stretch}.missed-input-dorsal,.missed-input-time{width:100%}.missed-btn{width:100%;justify-content:center}.drop-zone{padding:1.5rem 1rem}.format-guide{font-size:.85rem}.preview-header{flex-direction:column;align-items:flex-start;gap:.5rem}}@media (max-width: 480px){.brand-logo{height:1.4rem}.tab-btn{padding:.45rem .5rem;font-size:.78rem}.tab-badge{min-width:16px;height:16px;font-size:.65rem}.main-content{padding:.5rem}.race-clock{font-size:3rem}.race-clock-wrapper{padding:1rem}.finish-main-grid{grid-template-columns:1fr;gap:.75rem}.numpad{gap:.4rem}.numpad-key{font-size:1.6rem;padding:1.1rem 0;border-radius:var(--radius-sm)}.dorsal-input-section{padding:.75rem}.dorsal-input-row{flex-direction:column;gap:.6rem}.dorsal-input{font-size:2rem;min-height:64px}.dorsal-label{font-size:.7rem}.dorsal-helper{font-size:.8rem}.btn-register{width:100%;min-height:64px;font-size:1.1rem}.btn-register-inline{display:none}.mobile-register-bar{display:block;position:sticky;bottom:max(.5rem,env(safe-area-inset-bottom));z-index:40;padding-top:.25rem}.mobile-register-btn{width:100%;min-height:68px;border-radius:calc(var(--radius-lg) + 2px);box-shadow:0 10px 26px #22c55e40}.success-flash{font-size:.9rem;padding:.6rem .75rem}.recent-finishers{padding:.85rem}.recent-header{align-items:flex-start}.recent-highlight{padding:.8rem}.recent-highlight-main{align-items:flex-start}.finisher-item{gap:.3rem;font-size:.82rem;padding:.5rem .4rem}.finisher-pos{font-size:.9rem;min-width:28px}.finisher-time{font-size:.8rem}.results-table th:nth-child(4),.results-table td:nth-child(4){display:none}.podium-row{flex-direction:column;align-items:center}.podium-card{width:100%;max-width:260px;flex-direction:row;padding:.75rem 1rem;gap:.75rem}.podium-icon{font-size:1.5rem}.podium-position{font-size:1.1rem}.acred-search-input{font-size:1rem}.acred-container{gap:1rem}.acred-section{padding:.75rem}.acred-stat-num{font-size:1.4rem}.acred-toggle-btn{min-height:52px;font-size:.9rem}.acred-btn-touch{min-height:52px}.acred-table th:first-child,.acred-table td:first-child{display:none}.sample-table th,.sample-table td{padding:.35rem .4rem;font-size:.78rem}.distance-badge{font-size:.95rem}}.theme-toggle{position:fixed;bottom:1.25rem;right:1.25rem;z-index:200;width:2.75rem;height:2.75rem;border-radius:50%;border:none;cursor:pointer;background:var(--bg-surface);color:var(--text-primary);box-shadow:var(--shadow);border:1px solid var(--border);font-size:1.25rem;display:flex;align-items:center;justify-content:center;transition:background .2s,transform .15s}.theme-toggle:hover{background:var(--bg-hover);transform:scale(1.08)}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-base);padding:1rem}.login-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2.5rem 2rem;width:100%;max-width:380px;box-shadow:var(--shadow);display:flex;flex-direction:column;align-items:center;gap:1.25rem}.login-logo{height:3rem;width:auto;filter:brightness(0) invert(1)}[data-theme=light] .login-logo{filter:none}.login-title{font-size:1rem;font-weight:600;color:var(--text-secondary);text-align:center}.login-form{width:100%;display:flex;flex-direction:column;gap:1rem}.login-field{display:flex;flex-direction:column;gap:.35rem}.login-label{font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.login-input{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);padding:.65rem .85rem;font-size:1rem;outline:none;transition:border-color .15s}.login-input:focus{border-color:var(--accent-green)}.login-error{color:var(--accent-red);font-size:.85rem;text-align:center}.login-btn{background:var(--accent-green);color:#fff;border:none;border-radius:var(--radius-sm);padding:.75rem;font-size:1rem;font-weight:600;cursor:pointer;transition:background .15s;margin-top:.25rem}.login-btn:hover:not(:disabled){background:var(--accent-green-hover)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.navbar-user{display:flex;align-items:center;gap:.5rem}.navbar-username{font-size:.8rem;color:var(--text-secondary);font-weight:500}.reconnect-btn{background:none;border:1px solid var(--accent-yellow);color:var(--accent-yellow);border-radius:var(--radius-sm);padding:.25rem .65rem;font-size:.78rem;font-weight:600;cursor:pointer;transition:background .15s,color .15s}.reconnect-btn:hover{background:var(--accent-yellow);color:#000}.logout-btn{background:none;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);padding:.25rem .5rem;cursor:pointer;font-size:.9rem;transition:background .15s,color .15s}.logout-btn:hover{background:var(--accent-red);color:#fff;border-color:var(--accent-red)}.users-container{max-width:900px;margin:0 auto;display:flex;flex-direction:column;gap:1.5rem}.users-grid{display:grid;grid-template-columns:320px 1fr;gap:1.5rem;align-items:start}.users-form{display:flex;flex-direction:column;gap:.85rem}.users-success{color:var(--accent-green);font-size:.85rem;text-align:center}.users-table{width:100%;border-collapse:collapse;font-size:.9rem}.users-table th{text-align:left;padding:.5rem .75rem;color:var(--text-secondary);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border)}.users-table td{padding:.65rem .75rem;border-bottom:1px solid var(--border);color:var(--text-primary)}.role-badge{font-size:.72rem;font-weight:700;padding:.2rem .55rem;border-radius:99px;text-transform:uppercase;letter-spacing:.05em}.role-master{background:#f59e0b26;color:var(--accent-yellow)}.role-user{background:var(--accent-green-dim);color:var(--accent-green)}.btn-danger-sm{background:none;border:1px solid var(--accent-red);color:var(--accent-red);border-radius:var(--radius-sm);padding:.25rem .6rem;font-size:.78rem;cursor:pointer;transition:background .15s,color .15s}.btn-danger-sm:hover{background:var(--accent-red);color:#fff}@media (max-width: 600px){.users-grid{grid-template-columns:1fr}.navbar-username{display:none}}.swal-popup{background:var(--bg-surface)!important;border:1px solid var(--border)!important;border-radius:var(--radius-lg)!important;box-shadow:var(--shadow)!important;font-family:Inter,system-ui,sans-serif!important;padding:2rem!important}.swal-title{color:var(--text-primary)!important;font-size:1.15rem!important;font-weight:700!important}.swal-html{color:var(--text-secondary)!important;font-size:.9rem!important}.swal-icon{border-color:transparent!important}.swal-btn-confirm{background:var(--accent-red)!important;color:#fff!important;border:none!important;border-radius:var(--radius-sm)!important;padding:.6rem 1.25rem!important;font-size:.9rem!important;font-weight:600!important;cursor:pointer!important;transition:background .15s!important}.swal-btn-confirm:hover{background:var(--accent-red-hover)!important}.swal-btn-cancel{background:var(--bg-card)!important;color:var(--text-secondary)!important;border:1px solid var(--border)!important;border-radius:var(--radius-sm)!important;padding:.6rem 1.25rem!important;font-size:.9rem!important;font-weight:600!important;cursor:pointer!important;transition:background .15s!important}.swal-btn-cancel:hover{background:var(--bg-hover)!important}.btn-close-race{background:none;border:1px solid var(--accent-red);color:var(--accent-red);border-radius:var(--radius-sm);padding:.25rem .75rem;font-size:.75rem;font-weight:600;cursor:pointer;margin-left:1rem;transition:background .15s,color .15s}.btn-close-race:hover{background:var(--accent-red);color:#fff}.race-clock-closed{color:var(--text-secondary)}.race-closed-banner{background:#ef44441a;border:1px solid var(--accent-red);border-radius:var(--radius-md);color:var(--accent-red);font-weight:600;padding:1rem 1.5rem;text-align:center;font-size:1rem}.crono-tab{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1.5rem}.crono-clock-closed{color:var(--text-secondary)}.crono-clock{font-size:clamp(4rem,18vw,9rem);font-weight:800;font-family:Courier New,monospace;font-variant-numeric:tabular-nums;letter-spacing:.02em;color:var(--accent-green);line-height:1;white-space:nowrap}.crono-meta{display:flex;align-items:baseline;gap:.5rem}.crono-count{font-size:2.5rem;font-weight:700;color:var(--text-primary)}.crono-count-label{font-size:1rem;color:var(--text-secondary)}.public-view{min-height:100vh;background:var(--bg-base);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem;padding:2rem}.public-logo-wrap{opacity:.85}.public-logo{height:3.5rem;width:auto;filter:brightness(0) invert(1)}[data-theme=light] .public-logo{filter:none}.public-clock-wrap{text-align:center}.public-clock{font-size:clamp(4rem,15vw,10rem);font-weight:800;font-variant-numeric:tabular-nums;letter-spacing:-.02em;color:var(--accent-green);line-height:1}.public-clock-closed{color:var(--text-secondary)}.public-sub{margin-top:.75rem;font-size:clamp(1rem,3vw,1.75rem);color:var(--text-secondary);font-weight:500}.public-top{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem 2rem;width:100%;max-width:480px}.public-top-title{font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);margin-bottom:1rem}.public-top-list{list-style:none;display:flex;flex-direction:column;gap:.6rem}.public-top-item{display:flex;align-items:center;gap:1rem;font-size:1.1rem}.public-top-pos{color:var(--text-muted);font-size:.85rem;min-width:2rem}.public-top-dorsal{font-weight:700;color:var(--text-primary);flex:1}.public-top-time{font-variant-numeric:tabular-nums;color:var(--accent-green);font-weight:600}@media (max-height: 500px) and (orientation: landscape){.race-clock{font-size:2rem}.race-clock-wrapper{padding:.5rem 1rem}.numpad-key{padding:.6rem 0;font-size:1.3rem}.finish-active{gap:.5rem}.finish-main-grid{grid-template-columns:1fr}}.upload-mode-toggle{display:flex;gap:.25rem;margin-bottom:1.5rem;background:var(--bg-surface);border:1px solid var(--border);border-radius:.5rem;padding:.25rem;width:fit-content}.manual-entry-panel{background:var(--bg-surface);border:1px solid var(--border);border-radius:.75rem;padding:1.5rem;margin-bottom:1.5rem}.manual-entry-title{margin:0 0 1rem;font-size:1rem;font-weight:600;color:var(--text-primary)}.manual-entry-grid{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1rem}.manual-field{display:flex;flex-direction:column;gap:.25rem}.manual-field-nombre{flex:1;min-width:200px}.manual-label{font-size:.75rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em}.manual-input{background:var(--bg-input);border:1px solid var(--border);border-radius:.4rem;color:var(--text-primary);padding:.45rem .65rem;font-size:.9rem;min-width:0}.manual-input:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 2px #3b82f633}.manual-input-short{width:100px}.manual-success{color:var(--accent-green);font-size:.875rem;font-weight:500;margin-bottom:.75rem}.config-container{max-width:800px;margin:0 auto;padding:1.5rem 1rem}.config-desc{color:var(--text-muted);font-size:.9rem;margin-bottom:1.5rem;line-height:1.6}.config-table-wrapper{overflow-x:auto;margin-bottom:1rem}.config-cat-table{width:100%}.config-input{background:var(--bg-input);border:1px solid var(--border);border-radius:.4rem;color:var(--text-primary);padding:.4rem .6rem;font-size:.875rem;width:100%}.config-input:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 2px #3b82f633}.config-input-age{width:90px}.config-actions{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:1rem}.config-msg{padding:.6rem 1rem;border-radius:.4rem;font-size:.875rem;font-weight:500;margin-bottom:1.5rem}.config-msg-ok{background:#22c55e1f;color:var(--accent-green);border:1px solid var(--accent-green)}.config-msg-error{background:#ef44441f;color:var(--accent-red);border:1px solid var(--accent-red)}.config-preview{background:var(--bg-surface);border:1px solid var(--border);border-radius:.75rem;padding:1rem 1.25rem}.config-preview h3{font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin:0 0 .75rem}.config-preview-chips{display:flex;flex-wrap:wrap;gap:.5rem}
