*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--green: #3FAD5D;--green-dk: #2F8A47;--oxford: #071F32;--charcoal: #32465C;--cultured: #F6F6F6;--burgundy: #7A0423;--white: #FFFFFF;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 20px}html,body{height:100%;overflow:hidden}body{font-family:Montserrat,sans-serif;background:var(--oxford);color:var(--white);height:100%}#root{height:100%;display:flex;flex-direction:column}.app{height:100%;display:flex;flex-direction:column;overflow:hidden}.header{background:var(--oxford);border-bottom:1px solid rgba(63,173,93,.25);padding:12px 20px;display:flex;align-items:center;gap:12px;flex-shrink:0;z-index:10}.header-logo{display:flex;align-items:center}.header-logo-img{height:36px;width:auto;display:block}.header-sub{margin-left:auto;font-size:11px;color:#fff6;font-weight:400}.page{flex:1;overflow-y:auto;display:flex;flex-direction:column}.home{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 24px;gap:32px;background:var(--oxford)}.home-hero{display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center}.home-logo{width:110px;height:auto}.home-title{font-size:26px;font-weight:700;letter-spacing:.04em;line-height:1.2}.home-title span{color:var(--green)}.home-subtitle{font-size:12px;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:#fff6}.rules-card{background:#ffffff0d;border:1px solid rgba(63,173,93,.2);border-radius:var(--radius-lg);padding:20px;width:100%;max-width:400px;display:flex;flex-direction:column;gap:14px}.rules-card h3{font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--green)}.rule-item{display:flex;align-items:flex-start;gap:12px}.rule-num{width:24px;height:24px;border-radius:50%;background:var(--green);color:var(--white);font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}.rule-text{font-size:13px;font-weight:400;line-height:1.5;color:#fffc}.target-preview{display:flex;align-items:center;gap:12px;background:#3fad5d1a;border:1px solid rgba(63,173,93,.3);border-radius:var(--radius-md);padding:12px 16px;width:100%;max-width:400px}.target-swatch{width:44px;height:44px;border-radius:var(--radius-sm);background:#3fad5d;flex-shrink:0;box-shadow:0 0 20px #3fad5d80}.target-info{display:flex;flex-direction:column;gap:2px}.target-label{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#ffffff80}.target-hex{font-size:20px;font-weight:700;letter-spacing:.05em;color:var(--green)}.btn{display:flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:var(--radius-md);font-family:Montserrat,sans-serif;font-weight:600;cursor:pointer;transition:opacity .15s,transform .1s;-webkit-tap-highlight-color:transparent;text-decoration:none}.btn:active{transform:scale(.97);opacity:.85}.btn-primary{background:var(--green);color:var(--white);font-size:15px;padding:16px 32px;letter-spacing:.04em;width:100%;max-width:400px;border-radius:var(--radius-lg)}.btn-secondary{background:#ffffff14;color:var(--white);font-size:14px;padding:14px 28px;border:1px solid rgba(255,255,255,.15);width:100%;max-width:400px;border-radius:var(--radius-lg)}.btn-danger{background:var(--burgundy);color:var(--white);font-size:14px;padding:14px 28px;width:100%;max-width:400px;border-radius:var(--radius-lg)}.capture-page{flex:1;position:relative;display:flex;flex-direction:column;background:#000;overflow:hidden}.camera-video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.camera-overlay{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none}.camera-ui{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column}.camera-top-bar{padding:16px 20px;display:flex;align-items:center;justify-content:center;background:linear-gradient(to bottom,rgba(0,0,0,.7),transparent)}.camera-player-badge{background:#3fad5de6;color:var(--white);font-size:13px;font-weight:700;letter-spacing:.08em;padding:6px 16px;border-radius:20px}.camera-bottom-bar{margin-top:auto;padding:20px 24px 36px;display:flex;flex-direction:column;align-items:center;gap:12px;background:linear-gradient(to top,rgba(0,0,0,.85),transparent)}.camera-hint{font-size:12px;color:#ffffffb3;text-align:center;line-height:1.4}.capture-btn{width:72px;height:72px;border-radius:50%;border:4px solid var(--white);background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;transition:transform .1s}.capture-btn:active{transform:scale(.93)}.capture-btn-inner{width:52px;height:52px;border-radius:50%;background:var(--white)}.camera-error{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:32px;text-align:center;background:var(--oxford)}.camera-error p{font-size:14px;color:#ffffffb3;line-height:1.5}.preview-page{flex:1;display:flex;flex-direction:column;background:var(--oxford);padding:20px 20px 32px;gap:20px;overflow-y:auto}.preview-photo{width:100%;max-width:400px;margin:0 auto;border-radius:var(--radius-lg);overflow:hidden;flex-shrink:0;max-height:240px;position:relative}.preview-photo img{width:100%;height:100%;object-fit:cover;display:block}.preview-photo-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.color-comparison{display:grid;grid-template-columns:1fr auto 1fr;gap:12px;align-items:center;width:100%;max-width:400px;margin:0 auto}.color-card{background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);padding:12px;display:flex;flex-direction:column;align-items:center;gap:8px}.color-swatch{width:52px;height:52px;border-radius:var(--radius-sm)}.color-card-label{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#ffffff73;text-align:center}.color-card-hex{font-size:13px;font-weight:700;letter-spacing:.05em;color:var(--white)}.vs-badge{font-size:11px;font-weight:700;color:#ffffff4d;letter-spacing:.1em}.score-section{width:100%;max-width:400px;margin:0 auto;display:flex;flex-direction:column;gap:10px}.score-label{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#fff6}.score-value{font-size:64px;font-weight:700;line-height:1;color:var(--white)}.score-value span{font-size:24px;font-weight:400;color:#fff6}.score-bar-track{height:8px;background:#ffffff1a;border-radius:4px;overflow:hidden}.score-bar-fill{height:100%;border-radius:4px;transition:width .8s cubic-bezier(.16,1,.3,1)}.score-message{font-size:13px;color:#fff9;line-height:1.4}.preview-actions{width:100%;max-width:400px;margin:auto auto 0;display:flex;flex-direction:column;gap:10px}.results-page{flex:1;display:flex;flex-direction:column;background:var(--oxford);padding:20px 20px 32px;gap:20px;overflow-y:auto}.winner-banner{background:linear-gradient(135deg,var(--green-dk),var(--green));border-radius:var(--radius-lg);padding:20px;display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center;width:100%;max-width:400px;margin:0 auto}.winner-banner.tie{background:linear-gradient(135deg,var(--charcoal),#4a5a6e)}.winner-label{font-size:10px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:#ffffffb3}.winner-name{font-size:28px;font-weight:700;color:var(--white)}.winner-score{font-size:13px;color:#ffffffbf}.players-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;width:100%;max-width:400px;margin:0 auto}.player-result-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);padding:14px;display:flex;flex-direction:column;gap:10px}.player-result-card.winner-card{border-color:var(--green);background:#3fad5d14}.player-result-photo{width:100%;aspect-ratio:1;border-radius:var(--radius-sm);overflow:hidden;background:#0000004d;position:relative}.player-result-photo img{width:100%;height:100%;object-fit:cover}.player-result-photo-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.player-result-name{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#ffffff80}.player-result-score{font-size:32px;font-weight:700;color:var(--white);line-height:1}.player-result-score span{font-size:14px;font-weight:400;color:#fff6}.player-result-color{display:flex;align-items:center;gap:6px}.player-result-swatch{width:20px;height:20px;border-radius:4px;flex-shrink:0}.player-result-hex{font-size:11px;font-weight:600;color:#ffffff80;letter-spacing:.04em}.winner-crown{position:absolute;top:-12px;right:-4px;font-size:22px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.4))}.results-actions{width:100%;max-width:400px;margin:auto auto 0;display:flex;flex-direction:column;gap:10px}.player-result-team{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--green);margin-top:-6px}.save-status{width:100%;max-width:400px;margin:0 auto;text-align:center;font-size:12px;padding:6px 12px;border-radius:var(--radius-sm)}.save-status-saving{color:#fff6}.save-status-saved{color:var(--green)}.save-status-error{color:#e05252;background:#e052521a}.registration-page{flex:1;display:flex;flex-direction:column;background:var(--oxford);padding:20px 20px 32px;gap:16px;overflow-y:auto}.registration-header{width:100%;max-width:400px;margin:0 auto}.registration-title{font-size:20px;font-weight:700;color:var(--white);margin-bottom:6px}.registration-sub{font-size:13px;color:#ffffff80}.candidate-form{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);padding:16px;display:flex;flex-direction:column;gap:14px;width:100%;max-width:400px;margin:0 auto}.candidate-form-title{font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--green)}.form-field{display:flex;flex-direction:column;gap:6px}.form-label{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#ffffff73}.form-input{background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-sm);padding:12px 14px;font-family:Montserrat,sans-serif;font-size:15px;color:var(--white);outline:none;transition:border-color .15s;-webkit-appearance:none}.form-input::placeholder{color:#ffffff4d}.form-input:focus{border-color:var(--green)}.team-buttons{display:flex;gap:8px}.team-btn{flex:1;padding:10px 8px;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-sm);background:transparent;color:#fff9;font-family:Montserrat,sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;-webkit-tap-highlight-color:transparent}.team-btn.active{background:var(--green);border-color:var(--green);color:var(--white)}.registration-actions{width:100%;max-width:400px;margin:auto auto 0}.registration-actions .btn:disabled{opacity:.35;cursor:not-allowed}.leaderboard-page{flex:1;display:flex;flex-direction:column;background:var(--oxford);padding:16px 16px 32px;gap:16px;overflow-y:auto}.lb-topbar{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:440px;margin:0 auto}.btn-back,.btn-refresh{background:transparent;border:none;color:#fff9;font-family:Montserrat,sans-serif;font-size:13px;font-weight:600;cursor:pointer;padding:6px 2px;-webkit-tap-highlight-color:transparent}.btn-back:hover,.btn-refresh:hover{color:var(--white)}.btn-refresh:disabled{opacity:.4}.lb-error{text-align:center;color:#e05252;font-size:13px;line-height:1.5;padding:16px}.lb-empty{text-align:center;color:#ffffff59;font-size:13px;padding:24px 0}.teams-podium{display:grid;grid-template-columns:1fr 1fr;gap:10px;width:100%;max-width:440px;margin:0 auto}.team-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);padding:14px;display:flex;flex-direction:column;gap:4px;position:relative}.team-card-leader{border-color:var(--green);background:#3fad5d14}.team-rank-badge{font-size:10px;font-weight:700;letter-spacing:.08em;color:var(--green);text-transform:uppercase}.team-rank-badge.second{color:#fff6}.team-card-name{font-size:15px;font-weight:700;color:var(--white)}.team-card-total{font-size:28px;font-weight:700;color:var(--white);line-height:1.1}.team-card-stats{display:flex;gap:4px;flex-wrap:wrap;font-size:10px;color:#fff6;margin-top:2px}.results-table-wrap{width:100%;max-width:440px;margin:0 auto;display:flex;flex-direction:column;gap:10px}.results-table-title{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#ffffff59}.results-list{display:flex;flex-direction:column;gap:8px}.result-row{display:flex;align-items:center;gap:10px;background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-md);padding:10px 12px;transition:opacity .2s}.result-row-invalid{opacity:.35}.result-row-swatch{width:32px;height:32px;border-radius:var(--radius-sm);flex-shrink:0}.result-row-info{flex:1;min-width:0}.result-row-name{font-size:14px;font-weight:600;color:var(--white);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.result-row-meta{display:flex;gap:8px;margin-top:2px}.result-row-team{font-size:10px;font-weight:700;color:var(--green);text-transform:uppercase;letter-spacing:.06em}.result-row-time{font-size:10px;color:#ffffff59}.result-row-score{font-size:18px;font-weight:700;color:var(--white);flex-shrink:0}.result-row-score span{font-size:10px;font-weight:400;color:#ffffff59}.result-toggle-btn{width:28px;height:28px;border-radius:50%;border:1px solid rgba(255,255,255,.2);background:transparent;color:#fff6;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;-webkit-tap-highlight-color:transparent;transition:all .15s}.result-toggle-btn:hover{border-color:#e05252;color:#e05252}.result-toggle-btn.invalid{border-color:var(--green);color:var(--green)}
