:root{--bg-primary:#0a0a0a;--bg-secondary:#141414;--bg-card:#1a1a1a;--bg-input:#222;--border:#2a2a2a;--border-focus:#555;--text-primary:#e8e8e8;--text-secondary:#aaa;--text-muted:#777;--accent:#c8c8c8;--accent-hover:#fff;--danger:#c44;--success:#4a4;--warning:#ca4;--radius:4px;--radius-lg:8px}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-webkit-user-select:none;user-select:none;background-image:linear-gradient(45deg,#78787866 1px,#0000 1px),linear-gradient(-45deg,#6464644d 1px,#0000 1px);background-size:25px 25px,30px 30px;min-height:100vh;font-family:-apple-system,SF Pro Text,Helvetica Neue,sans-serif}h1{letter-spacing:.05em;text-transform:uppercase;font-size:1.4rem;font-weight:700}h2{letter-spacing:.03em;text-transform:uppercase;font-size:1.1rem;font-weight:600}h3{font-size:.95rem;font-weight:600}.app{flex-direction:column;max-width:480px;min-height:100vh;margin:0 auto;display:flex}.header{padding:16px 20px;padding-top:calc(16px + env(safe-area-inset-top,0px));border-bottom:1px solid var(--border);justify-content:center;align-items:center;display:flex}.header h1{letter-spacing:.12em;font-family:Impact,Arial Black,sans-serif;font-size:1.1rem}.content{flex:1;padding:20px 20px 80px;overflow-y:auto}.nav{border-top:1px solid var(--border);background:var(--bg-secondary);z-index:50;max-width:480px;margin:0 auto;display:flex;position:fixed;bottom:0;left:0;right:0}.nav-item{text-align:center;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);cursor:pointer;flex-direction:column;flex:1;justify-content:center;align-items:center;min-height:44px;padding:16px 0;font-size:.7rem;font-weight:600;text-decoration:none;transition:color .15s;display:flex}.nav-item.active,.nav-item:hover{color:var(--text-primary)}.nav-item .icon{margin-bottom:4px;font-size:1.2rem;display:block}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;margin-bottom:12px;padding:16px;transition:border-color .15s}.card:hover{border-color:var(--border-focus)}.card-title{margin-bottom:4px;font-size:.95rem;font-weight:600}.card-meta{color:var(--text-secondary);font-size:.8rem}.btn{letter-spacing:.06em;text-transform:uppercase;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);color:var(--text-primary);cursor:pointer;justify-content:center;align-items:center;padding:10px 20px;font-size:.8rem;font-weight:600;transition:all .15s;display:inline-flex}.btn:hover{border-color:var(--accent)}.btn-primary{background:var(--text-primary);color:var(--bg-primary);border-color:var(--text-primary)}.btn-primary:hover{background:var(--accent-hover)}.btn-danger{border-color:var(--danger);color:var(--danger)}.btn-full{width:100%}input,select,textarea{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text-primary);outline:none;padding:10px 14px;font-size:.9rem;transition:border-color .15s}input:focus,select:focus,textarea:focus{border-color:var(--border-focus)}input::placeholder{color:var(--text-muted)}.check-item{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:12px 16px;display:flex}.check-item.checked{opacity:.4}.check-item .checkbox{cursor:pointer;border:2px solid #0000;border-radius:3px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex;position:relative}.check-item .checkbox:before{content:"";border:2px solid var(--border-focus);border-radius:3px;width:22px;height:22px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.check-item.checked .checkbox:before,.check-item.checked .checkbox{background:var(--text-primary);border-color:var(--text-primary)}.check-item .checkbox:after{content:"✓";color:var(--bg-primary);font-size:.8rem;font-weight:700;display:none;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.check-item.checked .checkbox:after{display:block}.check-item .item-photo{border-radius:var(--radius);object-fit:cover;background:var(--bg-input);width:64px;height:40px}.check-item .item-name{flex:1;font-size:.9rem;font-weight:500}.check-item .item-category{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.7rem}.progress-bar{background:var(--border);border-radius:2px;width:100%;height:3px;margin:12px 0;overflow:hidden}.progress-bar .fill{background:var(--text-primary);height:100%;transition:width .3s}.search-wrap{margin-bottom:16px;position:relative}.search-wrap input{padding-left:36px}.search-wrap .search-icon{color:var(--text-muted);font-size:.9rem;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.fab{background:var(--text-primary);width:52px;height:52px;color:var(--bg-primary);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:1.5rem;font-weight:300;display:flex;position:fixed;bottom:80px;right:20px;box-shadow:0 4px 12px #00000080}.modal-overlay{z-index:100;background:#000c;align-items:flex-end;display:flex;position:fixed;inset:0}.modal{background:var(--bg-secondary);border-radius:var(--radius-lg) var(--radius-lg) 0 0;width:100%;max-width:480px;max-height:85vh;margin:0 auto;padding:24px 20px;overflow-y:auto}.modal h2{margin-bottom:20px}.modal .field{margin-bottom:16px}.modal label{letter-spacing:.06em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:6px;font-size:.75rem;font-weight:600;display:block}.empty{text-align:center;color:var(--text-muted);padding:60px 20px}.empty .icon{margin-bottom:12px;font-size:2.5rem}.empty p{margin-bottom:20px;font-size:.85rem}.hidden{display:none!important}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.gap-8{gap:8px}.flex{display:flex}.flex-between{justify-content:space-between;align-items:center;display:flex}.header-logo{vertical-align:middle;clip-path:inset(8% round 4px);width:32px;height:32px;margin-right:8px}.empty .icon img{clip-path:inset(8% round 4px);width:56px;height:64px}.empty-illustration{opacity:.6;margin-bottom:24px}.empty-silhouette{filter:invert()opacity(.8);width:120px;height:80px}.empty-headline{color:var(--text-primary);letter-spacing:-.01em;margin-bottom:8px;font-size:1.25rem;font-weight:600}.empty-subtext{color:var(--text-secondary);max-width:280px;margin-bottom:28px;margin-left:auto;margin-right:auto;font-size:.9rem;line-height:1.5}.empty .btn-primary{min-width:180px;margin-bottom:12px}.empty-secondary{border:1px solid var(--border);color:var(--text-secondary);background:0 0;min-width:180px}.empty-secondary:hover{border-color:var(--accent);color:var(--text-primary)}.fps-input-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:16px;padding:20px}.fps-input-group{margin-bottom:16px}.fps-input-group:last-child{margin-bottom:0}.fps-input-group label{letter-spacing:.06em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:8px;font-size:.75rem;font-weight:600;display:block}.weight-select-wrapper{position:relative}.fps-result-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:center;margin-bottom:16px;padding:24px}.fps-result-main{border-bottom:1px solid var(--border);margin-bottom:20px;padding-bottom:20px}.fps-result-label{letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:8px;font-size:.7rem;font-weight:600}.fps-result-value{color:var(--text-primary);margin:8px 0;font-size:3rem;font-weight:700;line-height:1}.fps-result-value-sm{color:var(--text-primary);margin:8px 0;font-size:2rem;font-weight:700;line-height:1}.fps-result-unit{letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);font-size:.8rem;font-weight:600}.fps-result-secondary{margin-top:20px}.fps-limit-input-row{gap:8px;display:flex}.fps-limit-input-row select{flex:1}.fps-limit-input-row input{text-align:center;flex-shrink:0;width:90px;font-weight:600}.fps-limit-card{border-radius:var(--radius-lg);align-items:center;gap:12px;margin-bottom:16px;padding:14px 16px;font-size:.9rem;font-weight:600;display:flex}.fps-limit-card.pass{border:1px solid var(--success);color:var(--success);background:#44aa4426}.fps-limit-card.fail{border:1px solid var(--danger);color:var(--danger);background:#cc444426}.fps-limit-icon{font-size:1.2rem;font-weight:700}.fps-limit-text{flex:1;font-size:.85rem}.fps-table-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:16px;padding:16px}.fps-table-title{letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:12px;font-size:.75rem;font-weight:600}.fps-table-scroll{border-radius:var(--radius);max-height:400px;overflow-y:auto}.fps-table{border-collapse:collapse;width:100%}.fps-table thead{background:var(--bg-secondary);z-index:1;position:sticky;top:0}.fps-table th{text-align:left;letter-spacing:.06em;text-transform:uppercase;color:var(--text-secondary);border-bottom:1px solid var(--border);padding:10px 12px;font-size:.7rem;font-weight:600}.fps-table td{border-bottom:1px solid var(--border);padding:10px 12px;font-size:.85rem}.fps-table tbody tr:last-child td{border-bottom:none}.fps-table tbody tr.highlight{background:var(--bg-input);font-weight:600}.fps-table tbody tr:hover{background:var(--bg-secondary)}.nav{grid-template-columns:repeat(4,1fr);display:grid}.silhouette-cat-tabs{-webkit-overflow-scrolling:touch;gap:6px;margin-bottom:12px;padding-bottom:8px;display:flex;overflow-x:auto}.sil-cat-btn{letter-spacing:.06em;text-transform:uppercase;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;white-space:nowrap;flex-shrink:0;padding:6px 12px;font-size:.65rem;font-weight:600}.sil-cat-btn.active{border-color:var(--accent);color:var(--text-primary)}.silhouette-grid{grid-template-columns:repeat(3,1fr);gap:10px;max-height:50vh;padding:4px;display:grid;overflow-y:auto}.silhouette-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;flex-direction:column;align-items:center;gap:6px;padding:12px 8px;transition:border-color .15s;display:flex}.silhouette-item:hover,.silhouette-item:active{border-color:var(--accent)}.silhouette-item img{object-fit:contain;opacity:.9;width:56px;height:56px}.silhouette-label{letter-spacing:.04em;text-transform:uppercase;color:var(--text-secondary);text-align:center;font-size:.6rem;font-weight:600;line-height:1.2}.photo-actions{flex-direction:column;gap:8px;display:flex}.photo-action-btn{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);color:var(--text-primary);cursor:pointer;align-items:center;gap:12px;padding:14px 16px;font-size:.85rem;font-weight:500;transition:border-color .15s;display:flex}.photo-action-btn:hover,.photo-action-btn:active{border-color:var(--accent)}.photo-action-icon{text-align:center;width:28px;font-size:1.2rem}.suggest-type-row{gap:8px;display:flex}.suggest-type-btn{flex:1;padding:8px 6px!important;font-size:.7rem!important}.suggest-type-btn.active{border-color:var(--accent)!important;color:var(--text-primary)!important}.loadout-image-picker{flex-direction:column;gap:8px;display:flex}.image-preview{background:#1a1a1a;border:1px dashed #444;border-radius:8px;justify-content:center;align-items:center;width:100%;height:120px;display:flex;overflow:hidden}.image-preview img{object-fit:contain;max-width:100%;max-height:100%}.image-placeholder{color:#666;font-size:.85rem}.image-picker-btns{flex-wrap:wrap;gap:8px;display:flex}.btn-sm{padding:6px 12px!important;font-size:.8rem!important}.btn-danger-subtle{color:#e74c3c!important;border-color:#e74c3c!important}.loadout-card.has-image{background-position:100%;background-size:cover;min-height:80px}.loadout-card.has-image .card-title,.loadout-card.has-image .card-meta{text-shadow:0 1px 3px #000c}#badger-cropper-overlay{z-index:10000;background:#000000f2;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.cropper-container{flex-direction:column;gap:12px;width:100%;max-width:520px;padding:16px;display:flex}.cropper-header{justify-content:space-between;align-items:center;display:flex}.cropper-title{color:#fff;font-size:1rem;font-weight:600}.cropper-btn{color:#fff;cursor:pointer;background:0 0;border:1px solid #555;border-radius:6px;padding:8px 16px;font-size:.9rem;font-weight:600}.cropper-btn:active{background:#333}.cropper-confirm{background:var(--accent,#e8a317)!important;border-color:var(--accent,#e8a317)!important;color:#000!important}.cropper-canvas-wrap{background:#000;border-radius:8px;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.cropper-canvas{touch-action:none;display:block}.cropper-frame{pointer-events:none;border:2px solid #ffffff80;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.cropper-frame.cropper-circle{border-radius:50%}.cropper-controls{justify-content:center;align-items:center;gap:12px;display:flex}.cropper-zoom-btn{color:#fff;cursor:pointer;background:#222;border:1px solid #555;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.3rem;display:flex}.cropper-zoom-btn:active{background:#444}.cropper-slider{accent-color:var(--accent,#e8a317);flex:1;height:4px}.add-to-loadout-btn{width:32px;height:32px;color:var(--accent,#e8a317);cursor:pointer;background:#222;border:1px solid #444;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1.2rem;transition:background .15s;display:flex}.add-to-loadout-btn:active{background:#333}.toast-msg{color:#fff;z-index:9999;border:1px solid var(--accent,#e8a317);background:#222;border-radius:8px;padding:10px 20px;font-size:.85rem;font-weight:600;animation:.3s toastIn,.3s 1.7s forwards toastOut;position:fixed;bottom:80px;left:50%;transform:translate(-50%)}@keyframes toastIn{0%{opacity:0;transform:translate(-50%)translateY(20px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@keyframes toastOut{0%{opacity:1}to{opacity:0}}.loadout-thumb{background:#1a1a1a;border:1px solid #333;border-radius:8px;flex-shrink:0;width:48px;height:48px;overflow:hidden}.loadout-thumb img{object-fit:cover;width:100%;height:100%}.pack-item{margin-bottom:2px}.pack-item-row{background:var(--card-bg,#1a1a1a);cursor:pointer;border-radius:8px;align-items:center;gap:10px;padding:10px 12px;display:flex}.pack-item-row .checkbox{border:2px solid #555;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;transition:all .15s;display:flex}.pack-item-row .checkbox.checked{background:var(--accent,#e8a317);border-color:var(--accent,#e8a317)}.pack-item-row .checkbox.checked:after{content:"✓";color:#000;font-size:.8rem;font-weight:700}.line-through{opacity:.5;text-decoration:line-through}.note-btn{cursor:pointer;opacity:.5;flex-shrink:0;font-size:.85rem;transition:opacity .15s}.note-btn:hover,.note-btn:active{opacity:1}.item-note-preview{color:var(--accent,#e8a317);margin-top:2px;font-size:.75rem;font-style:italic}.pack-note-field{padding:4px 12px 8px 44px}.pack-note-field textarea{color:#fff;resize:vertical;background:#111;border:1px solid #333;border-radius:6px;width:100%;min-height:60px;padding:8px;font-family:inherit;font-size:.85rem}.loadout-item-wrap{margin-bottom:2px}.item-detail-panel{background:#111;border-radius:0 0 8px 8px;margin-top:-4px;padding:4px 12px 10px}.item-detail-note label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px;font-size:.7rem;display:block}.item-detail-note textarea{color:#fff;resize:vertical;background:#0a0a0a;border:1px solid #333;border-radius:6px;width:100%;min-height:50px;padding:8px;font-family:inherit;font-size:.85rem}.nav{padding-bottom:env(safe-area-inset-bottom,0px)!important}.app{padding-bottom:calc(70px + env(safe-area-inset-bottom,0px))!important}.fab{bottom:calc(80px + env(safe-area-inset-bottom,0px))!important}.nav-item{padding-top:8px!important;line-height:1.3!important;overflow:visible!important}.pack-item-row .item-photo{border-radius:var(--radius);object-fit:cover;flex-shrink:0;width:64px;height:40px}.loadout-item-wrap.dragging{opacity:.5;background:var(--accent);border-radius:var(--radius)}.loadout-item-wrap.drag-over{border-top:2px solid var(--accent)}.drag-handle{cursor:grab;color:var(--text-muted);-webkit-user-select:none;user-select:none;touch-action:none;flex-shrink:0;padding:8px 4px;font-size:1.2rem}.drag-handle:active{cursor:grabbing;color:var(--accent)}.loadout-drag-handle{cursor:grab;color:var(--text-muted);-webkit-user-select:none;user-select:none;touch-action:none;padding:8px 4px 8px 10px;font-size:1.1rem;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.loadout-drag-handle:active{cursor:grabbing;color:var(--accent)}.loadout-list-item{padding-right:36px;position:relative}.loadout-list-item.dragging{opacity:.45;background:var(--accent);border-radius:var(--radius)}.loadout-list-item.drag-over{border-top:2px solid var(--accent)}.loadout-drop-end-zone{text-align:center;color:var(--text-muted);opacity:.5;-webkit-user-select:none;user-select:none;padding:12px 0 8px;font-size:.75rem}.loadout-drop-end-zone.drag-over-end{opacity:1;color:var(--accent);border:1px dashed var(--accent);border-radius:var(--radius);background:#00ff000d;padding:14px 0}.pack-celebration{z-index:200;background:#0a0a0aeb;flex-direction:column;justify-content:center;align-items:center;animation:.3s celebrationFadeIn;display:flex;position:fixed;inset:0}.pack-celebration.hidden{display:none}.pack-celebration-content{text-align:center;animation:.6s celebrationBounce}.pack-celebration-icon{margin-bottom:16px;font-size:4rem;animation:1.2s ease-in-out infinite celebrationPulse}.pack-celebration-title{letter-spacing:.08em;text-transform:uppercase;color:var(--success);margin-bottom:8px;font-size:1.4rem;font-weight:700}.pack-celebration-subtitle{color:var(--text-secondary);margin-bottom:24px;font-size:.95rem}.pack-celebration-btn{background:var(--success);color:#000;border-radius:var(--radius);letter-spacing:.08em;text-transform:uppercase;cursor:pointer;border:none;padding:14px 32px;font-size:.85rem;font-weight:600;transition:transform .15s,opacity .15s}.pack-celebration-btn:hover{opacity:.9;transform:scale(1.05)}.pack-celebration-btn:active{transform:scale(.98)}@keyframes celebrationFadeIn{0%{opacity:0}to{opacity:1}}@keyframes celebrationBounce{0%{opacity:0;transform:scale(.8)}50%{transform:scale(1.05)}to{opacity:1;transform:scale(1)}}@keyframes celebrationPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.timer-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:16px;padding:24px 20px}.timer-display{text-align:center;color:var(--text-primary);letter-spacing:.05em;text-shadow:0 0 30px #c8c8c81a;margin-bottom:20px;font-family:SF Mono,Monaco,Inconsolata,monospace;font-size:4.5rem;font-weight:700;line-height:1;transition:color .3s,text-shadow .3s}.timer-display.timer-expired{color:var(--danger);text-shadow:0 0 40px #cc444480;animation:.5s ease-in-out infinite alternate timerExpiredPulse}@keyframes timerExpiredPulse{0%{opacity:1}to{opacity:.7}}.timer-progress{background:var(--border);border-radius:3px;width:100%;height:6px;margin-bottom:24px;overflow:hidden}.timer-progress-fill{background:linear-gradient(90deg, var(--accent), var(--text-primary));border-radius:3px;height:100%;transition:width .3s}.timer-presets{flex-wrap:wrap;justify-content:center;gap:8px;margin-bottom:24px;display:flex}.timer-preset-btn{letter-spacing:.06em;text-transform:uppercase;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-input);color:var(--text-secondary);cursor:pointer;padding:8px 14px;font-size:.75rem;font-weight:600;transition:all .15s}.timer-preset-btn:hover{border-color:var(--border-focus);color:var(--text-primary)}.timer-preset-btn.active{border-color:var(--accent);color:var(--text-primary);background:var(--bg-card)}.timer-controls{justify-content:center;gap:12px;margin-bottom:20px;display:flex}.timer-btn{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-input);min-width:80px;color:var(--text-primary);cursor:pointer;flex-direction:column;justify-content:center;align-items:center;padding:14px 20px;transition:all .15s;display:flex}.timer-btn:hover:not(:disabled){border-color:var(--accent)}.timer-btn:active:not(:disabled){transform:scale(.98)}.timer-btn:disabled{opacity:.4;cursor:not-allowed}.timer-btn-icon{margin-bottom:6px;font-size:1.4rem}.timer-btn-label{letter-spacing:.08em;text-transform:uppercase;font-size:.7rem;font-weight:600}.timer-start{border-color:var(--success);color:var(--success)}.timer-start:hover:not(:disabled){background:#44aa441a}.timer-pause{border-color:var(--warning);color:var(--warning)}.timer-pause:hover:not(:disabled){background:#ccaa441a}.timer-reset{border-color:var(--text-secondary)}.timer-info{text-align:center;color:var(--text-muted);border-top:1px solid var(--border);padding-top:12px;font-size:.8rem}.timer-info p{margin:0}.nav-item.timer-tab-alert{animation:.5s ease-in-out infinite alternate timerTabPulse;color:var(--accent)!important}.nav-item.timer-tab-alert .icon{animation:.3s ease-in-out infinite timerTabShake}@keyframes timerTabPulse{0%{opacity:1;text-shadow:0 0 #0000}to{opacity:1;text-shadow:0 0 8px var(--accent)}}@keyframes timerTabShake{0%,to{transform:rotate(0)}25%{transform:rotate(-10deg)}75%{transform:rotate(10deg)}}.nav{grid-template-columns:repeat(5,1fr)}.nav-item{padding:8px 2px;font-size:.6rem}.nav-item .icon{margin-bottom:2px;font-size:1rem}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}:focus-visible,.btn:focus-visible,.nav-item:focus-visible,.card:focus-visible,.fab:focus-visible{outline:2px solid var(--accent);outline-offset:2px}:focus:not(:focus-visible){outline:none}@media (prefers-reduced-motion:reduce){.pack-celebration,.pack-celebration-content,.pack-celebration-icon{transition:none!important;animation:none!important}.pack-celebration{opacity:1}}.shot-timer-card{background:var(--card-bg);max-width:500px;box-shadow:var(--shadow);border-radius:12px;margin:20px auto;padding:24px}.shot-timer-mode-selector{gap:8px;margin-bottom:20px;display:flex}.mode-btn{border:2px solid var(--border);background:var(--bg);cursor:pointer;border-radius:6px;flex:1;padding:8px 16px;font-weight:500;transition:all .2s}.mode-btn:hover{border-color:var(--accent)}.mode-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.par-time-selector{background:var(--bg-alt);border-radius:8px;margin-bottom:20px;padding:12px}.par-time-selector label{margin-bottom:8px;font-weight:500;display:block}.par-time-selector select{border:1px solid var(--border);background:var(--bg);border-radius:4px;width:100%;padding:8px}.sensitivity-control{background:var(--bg-alt);border-radius:8px;margin-bottom:20px;padding:12px}.sensitivity-control label{margin-bottom:8px;font-weight:500;display:block}.sensitivity-control input[type=range]{width:100%;margin:8px 0}.shot-timer-display{text-align:center;margin-bottom:24px}.shot-count{color:var(--accent);margin-bottom:20px;font-size:1.5em;font-weight:700}.shot-count .label{color:var(--text-secondary);margin-right:8px;font-size:.8em}.time-display{margin-bottom:20px}.time-row{background:var(--bg-alt);border-radius:6px;justify-content:space-between;align-items:center;margin-bottom:8px;padding:8px 12px;display:flex}.time-row .label{color:var(--text-secondary);font-weight:500}.time-row .value{color:var(--text);font-family:Courier New,monospace;font-weight:700}.par-time-display{background:var(--accent-light);border:2px solid var(--accent);border-radius:8px;margin-top:20px;padding:16px}.par-time-value{color:var(--accent);text-align:center;margin-bottom:8px;font-family:Courier New,monospace;font-size:1.8em;font-weight:700}.par-time-value.par-time-expired{animation:.5s ease-in-out infinite alternate timerExpiredPulse}.par-time-status{text-align:center;color:var(--text-secondary);font-size:.9em;font-weight:500}.shot-timer-controls{gap:12px;margin-bottom:20px;display:flex}.shot-timer-btn{cursor:pointer;border:none;border-radius:8px;flex-direction:column;flex:1;align-items:center;gap:4px;padding:16px;font-weight:600;transition:all .2s;display:flex}.shot-timer-btn.start{background:var(--success);color:#fff}.shot-timer-btn.stop{background:var(--danger);color:#fff}.shot-timer-btn.reset{background:var(--warning);color:#fff}.shot-timer-btn:disabled{opacity:.5;cursor:not-allowed}.shot-timer-btn:not(:disabled):hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.btn-icon{font-size:1.2em}.btn-label{font-size:.9em}.shot-timer-info{text-align:center;color:var(--text-secondary);font-size:.9em}.shot-timer-info p{margin:8px 0}.shot-timer-status{text-align:center;margin-bottom:20px}.status-ready,.status-running{border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:16px;font-weight:600;display:flex}.status-ready{background:var(--warning-light);border:2px solid var(--warning);color:var(--warning-dark)}.status-running{background:var(--success-light);border:2px solid var(--success);color:var(--success-dark)}.status-icon{font-size:1.2em}.status-text{font-size:1.1em}.competition-timer-container{background:linear-gradient(135deg,#1a1a1a 0%,#2d2d2d 100%);border:1px solid #404040;border-radius:16px;max-width:500px;margin:20px auto;padding:24px;box-shadow:0 8px 32px #0000004d}.competition-header{text-align:center;margin-bottom:24px}.competition-title{color:#4a9a4a;text-transform:uppercase;letter-spacing:2px;margin:0;font-family:Courier New,monospace;font-size:1.8rem;font-weight:700}.competition-subtitle{color:#888;margin:8px 0 0;font-size:.9rem}.competition-main-display{text-align:center;background:#000;border:2px solid #4a9a4a;border-radius:12px;margin-bottom:24px;padding:20px}.competition-main-time{color:#4a9a4a;letter-spacing:1px;text-shadow:0 0 10px #4a9a4a33;margin:0;font-family:Courier New,monospace;font-size:3.5rem;font-weight:700}.competition-shot-count{color:#fff;margin:12px 0 0;font-size:1.2rem;font-weight:600}.competition-shot-count .label{color:#888;margin-right:8px}.competition-visual-feedback{background:#333;border-radius:2px;height:4px;margin:16px 0;position:relative;overflow:hidden}.competition-visual-feedback:before{content:"";transform-origin:0;background:#4a9a4a;width:100%;height:100%;transition:transform .2s ease-out;position:absolute;top:0;left:0;transform:scaleX(0)}.competition-visual-feedback.shot-detected:before{animation:.2s ease-out shotFlash;transform:scaleX(1)}@keyframes shotFlash{0%{opacity:1;transform:scaleX(0)}50%{opacity:1;transform:scaleX(1)}to{opacity:0;transform:scaleX(1)}}.competition-splits-display{background:#2a2a2a;border-radius:8px;margin-bottom:20px;padding:16px}.competition-split-row{border-bottom:1px solid #404040;justify-content:space-between;align-items:center;padding:8px 0;display:flex}.competition-split-row:last-child{border-bottom:none}.competition-split-label{color:#888;font-size:.9rem;font-weight:500}.competition-split-value{color:#fff;font-family:Courier New,monospace;font-size:1rem;font-weight:600}.competition-sensitivity{margin-bottom:20px}.competition-sensitivity-label{color:#888;margin-bottom:8px;font-weight:500;display:block}.competition-sensitivity-control{align-items:center;gap:12px;display:flex}.competition-sensitivity-slider{-webkit-appearance:none;background:#404040;border-radius:3px;outline:none;flex:1;height:6px}.competition-sensitivity-slider::-webkit-slider-thumb{-webkit-appearance:none;cursor:pointer;background:#4a9a4a;border:2px solid #000;border-radius:50%;width:20px;height:20px}.competition-sensitivity-slider::-moz-range-thumb{cursor:pointer;background:#4a9a4a;border:2px solid #000;border-radius:50%;width:20px;height:20px}.competition-sensitivity-value{color:#4a9a4a;text-align:center;min-width:40px;font-family:Courier New,monospace;font-weight:600}.competition-controls{grid-template-columns:1fr 1fr 1fr;gap:12px;margin-bottom:20px;display:grid}.competition-btn{cursor:pointer;text-transform:uppercase;letter-spacing:1px;border:none;border-radius:8px;flex-direction:column;align-items:center;gap:4px;padding:16px;font-size:.9rem;font-weight:700;transition:all .2s;display:flex}.competition-btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.competition-btn:not(:disabled):hover{transform:translateY(-2px);box-shadow:0 4px 16px #0006}.competition-btn.start{color:#fff;background:linear-gradient(135deg,#2d5a2d 0%,#3d7a3d 100%)}.competition-btn.start:hover:not(:disabled){background:linear-gradient(135deg,#3d7a3d 0%,#4a9a4a 100%)}.competition-btn.stop{color:#fff;background:linear-gradient(135deg,#5a2d2d 0%,#7a3d3d 100%)}.competition-btn.stop:hover:not(:disabled){background:linear-gradient(135deg,#7a3d3d 0%,#9a4a4a 100%)}.competition-btn.reset{color:#fff;background:linear-gradient(135deg,#5a4a2d 0%,#7a6a3d 100%)}.competition-btn.reset:hover:not(:disabled){background:linear-gradient(135deg,#7a6a3d 0%,#9a8a4a 100%)}.competition-btn-icon{font-size:1.4rem}.competition-btn-label{font-size:.8rem}.competition-info{text-align:center;color:#666;font-size:.8rem;line-height:1.4}.competition-info p{margin:4px 0}.competition-ready-overlay{z-index:10000!important;color:#4a9a4a!important;text-transform:uppercase!important;letter-spacing:4px!important;background:#000000f2!important;justify-content:center!important;align-items:center!important;width:100%!important;height:100%!important;font-family:Courier New,monospace!important;font-size:4rem!important;font-weight:700!important;display:flex!important;position:fixed!important;top:0!important;left:0!important}@media (width<=480px){.competition-timer-container{margin:16px;padding:16px}.competition-main-time{font-size:2.8rem}.competition-controls{grid-template-columns:1fr;gap:8px}.competition-btn{padding:12px}}.competition-mode-selector{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px;display:grid}.mode-option{cursor:pointer;text-align:center;background:#2a2a2a;border:2px solid #404040;border-radius:8px;padding:12px;transition:all .2s}.mode-option:hover{border-color:#666}.mode-option.active{background:#4a9a4a1a;border-color:#4a9a4a}.mode-title{color:#fff;margin-bottom:4px;font-size:1rem;font-weight:700}.mode-option.active .mode-title{color:#4a9a4a}.mode-desc{color:#888;font-size:.75rem;line-height:1.3}.par-time-settings{background:#2a2a2a;border-radius:8px;align-items:center;gap:12px;margin-bottom:20px;padding:12px 16px;display:flex}.par-time-settings.hidden{display:none}.par-time-label{color:#888;font-size:.9rem;font-weight:500}.par-time-select{color:#fff;cursor:pointer;background:#1a1a1a;border:1px solid #404040;border-radius:6px;flex:1;padding:8px 12px;font-size:.9rem}.par-time-select:focus{border-color:#4a9a4a;outline:none}.mic-level-container{background:#2a2a2a;border-radius:8px;margin-bottom:20px;padding:12px 16px}.mic-level-label{justify-content:space-between;align-items:center;margin-bottom:8px;font-size:.85rem;display:flex}#mic-status-text{color:#888;font-weight:500}.mic-level-bar-bg{background:#1a1a1a;border:1px solid #404040;border-radius:6px;height:12px;position:relative;overflow:hidden}.mic-level-bar{background:linear-gradient(90deg,#2d5a2d 0%,#4a9a4a 70%,#cc7a00 85%,#c44 100%);border-radius:5px;min-width:2px;height:100%;transition:width 50ms ease-out}.mic-threshold-marker{opacity:.7;pointer-events:none;background:#fff;width:2px;position:absolute;top:0;bottom:0}.mic-level-hints{color:#666;justify-content:space-between;margin-top:4px;font-size:.7rem;display:flex}
