:root{--bg: #f0f4f0;--surface: #ffffff;--primary: #2d6a4f;--primary-dark: #1b4332;--primary-light: #d8f3e8;--text: #111827;--text-muted: #6b7280;--border: #e5e7eb;--danger: #ef4444;--shadow: 0 1px 3px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 16px rgba(0, 0, 0, .1);--r: 12px;--r-sm: 8px;--safe-bottom: env(safe-area-inset-bottom, 0px)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{height:100%}body{height:100%;font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;-webkit-text-size-adjust:100%}#root{height:100%}button{cursor:pointer;border:none;background:none;font:inherit;color:inherit}input{font:inherit}.app-container{max-width:430px;margin:0 auto;min-height:100vh;background:var(--bg);position:relative}.screen{padding:20px 16px;padding-bottom:calc(88px + var(--safe-bottom));min-height:100vh}.card{background:var(--surface);border-radius:var(--r);padding:16px;box-shadow:var(--shadow);margin-bottom:12px}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;color:var(--text-muted);font-size:16px}.error-banner{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca;border-radius:var(--r-sm);padding:12px 16px;font-size:14px;margin-bottom:16px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 20px;border-radius:var(--r-sm);font-weight:600;font-size:16px;transition:opacity .12s,transform .1s;text-decoration:none;-webkit-user-select:none;user-select:none}.btn:active{transform:scale(.97);opacity:.9}.btn:disabled{opacity:.45;pointer-events:none}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-secondary{background:var(--primary-light);color:var(--primary-dark)}.btn-ghost{background:transparent;color:var(--text-muted)}.btn-ghost:hover{color:var(--text)}.btn-large{width:100%;padding:16px;font-size:17px;border-radius:var(--r)}.btn-sm{padding:8px 16px;font-size:14px}.btn-add-shot{width:100%;padding:14px;font-size:16px;font-weight:600;border:2px dashed var(--border);border-radius:var(--r);color:var(--primary);background:var(--surface);margin-top:4px;transition:background .12s,border-color .12s}.btn-add-shot:active{background:var(--primary-light);border-color:var(--primary)}.btn-back{color:var(--primary);font-size:15px;font-weight:500;padding:4px 0;display:flex;align-items:center;gap:4px;flex-shrink:0}.btn-trash{padding:6px 8px;color:var(--text-muted);font-size:17px;border-radius:6px;line-height:1;transition:color .12s,background .12s}.btn-trash:active{color:var(--danger);background:#fee2e2}.floating-btn{position:fixed;bottom:calc(24px + var(--safe-bottom));left:50%;transform:translate(-50%);background:var(--primary);color:#fff;font-weight:700;font-size:15px;padding:14px 28px;border-radius:100px;box-shadow:0 4px 20px #2d6a4f66;white-space:nowrap;z-index:100;cursor:pointer;border:none;transition:transform .1s,box-shadow .1s}.floating-btn:active{transform:translate(-50%) scale(.97);box-shadow:0 2px 12px #2d6a4f4d}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:12px;font-weight:600;color:var(--text-muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.06em}.input{width:100%;padding:14px 16px;font-size:16px;border:1.5px solid var(--border);border-radius:var(--r-sm);background:var(--surface);color:var(--text);outline:none;transition:border-color .15s;-webkit-appearance:none}.input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2d6a4f1f}.input::placeholder{color:#b0b8c1}.screen-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.screen-header h2{font-size:22px;font-weight:800;flex:1}.home-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:40px 24px;text-align:center}.home-logo{font-size:72px;line-height:1;margin-bottom:16px}.home-screen h1{font-size:34px;font-weight:900;color:var(--primary-dark);letter-spacing:-.02em;margin-bottom:6px}.home-subtitle{font-size:16px;color:var(--text-muted);margin-bottom:52px}.button-stack{width:100%;display:flex;flex-direction:column;gap:12px}.badge{font-size:11px;font-weight:500;background:#0000001f;padding:2px 8px;border-radius:100px;margin-left:4px}.setup-banner{background:#fffbeb;border:1.5px solid #fcd34d;border-radius:var(--r);padding:14px 16px;margin-bottom:28px;text-align:left;width:100%}.setup-banner strong{display:block;font-size:14px;color:#92400e;margin-bottom:6px}.setup-banner p{font-size:13px;color:#78350f;line-height:1.5;margin:0}.setup-banner code{background:#00000014;padding:1px 5px;border-radius:4px;font-size:12px;font-family:ui-monospace,SF Mono,monospace}.join-screen h2,.create-screen h2{font-size:28px;font-weight:900;color:var(--primary-dark);letter-spacing:-.02em;margin-bottom:6px}.back-btn{display:inline-block;color:var(--primary);font-size:15px;font-weight:600;margin-bottom:20px;padding:0;background:none;border:none;cursor:pointer}.section-label{font-size:13px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px}.course-group{margin-bottom:20px}.course-group-name{font-size:12px;font-weight:600;color:var(--text-muted);padding:0 4px;margin-bottom:6px}.course-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:13px 14px;background:var(--surface);border:2px solid var(--border);border-radius:var(--r-sm);margin-bottom:6px;text-align:left;transition:border-color .15s,background .15s}.course-item.is-selected{border-color:var(--primary);background:var(--primary-light)}.course-item-name{font-size:15px;font-weight:600;color:var(--text)}.course-item.is-selected .course-item-name{color:var(--primary-dark)}.course-item-holes{font-size:13px;color:var(--text-muted);white-space:nowrap}.tee-section{margin-top:24px;margin-bottom:8px}.tee-picker-hint{font-size:13px;color:var(--text-muted);margin-top:8px}.create-btn{margin-top:32px}.create-success{display:flex;flex-direction:column;align-items:center;text-align:center;padding-top:32px;gap:12px}.create-success h2{margin-bottom:0}.create-success-icon{font-size:52px;margin-bottom:4px}.game-code-badge{font-size:32px;font-weight:900;letter-spacing:.06em;color:var(--primary-dark);background:var(--primary-light);border-radius:var(--r);padding:16px 28px;margin:8px 0;width:100%;text-align:center}.create-success .btn{width:100%}.join-subtitle{font-size:15px;color:var(--text-muted);margin-bottom:28px}.returning-name{background:var(--primary-light);color:var(--primary-dark);font-size:16px;font-weight:600;padding:12px 16px;border-radius:var(--r-sm);margin-bottom:16px}.btn-new-player{display:block;width:100%;text-align:center;margin-top:16px;color:var(--primary);font-size:15px;font-weight:600;padding:12px;background:none;border:none;cursor:pointer}.tee-picker-section{margin-bottom:20px}.tee-picker-label{font-size:13px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px}.tee-default-hint{font-weight:400;text-transform:none;letter-spacing:0}.tee-picker{display:flex;gap:8px}.tee-btn{flex:1;padding:10px 0;border-radius:var(--r-sm);font-size:14px;font-weight:700;border:2px solid transparent;transition:opacity .15s,border-color .15s;opacity:.45;color:#fff}.tee-btn.is-selected{opacity:1;border-color:#00000040;box-shadow:0 2px 8px #0003}.tee-black{background:#1a1a1a}.tee-blue{background:#1d4ed8}.tee-white{background:#9ca3af}.tee-red{background:#dc2626}.tee-yellow{background:#d97706}.shots-card{padding:14px;overflow:hidden}.shots-scroll{display:flex;gap:10px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:2px}.shots-scroll::-webkit-scrollbar{display:none}.shot-col{flex:0 0 130px;display:flex;flex-direction:column;gap:8px;border-radius:var(--r-sm);padding:6px;cursor:pointer;transition:background .15s;-webkit-user-select:none;user-select:none}.shot-col.is-active{background:#2d6a4f12}.shot-col-header{display:flex;align-items:center;justify-content:space-between;min-height:26px}.shot-col-num{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;transition:color .15s}.shot-col.is-active .shot-col-num{color:var(--primary)}.shot-col-picker{border:1px solid var(--border);border-radius:var(--r-sm);overflow:hidden;background:#fafafa}.shot-landed-badge{text-align:center;font-size:11px;font-weight:700;padding:4px 6px;border-radius:100px;background:#f3f4f6;color:var(--text-muted);transition:background .15s,color .15s}.badge-fairway{background:#22c55e;color:#fff}.badge-green{background:#15803d;color:#fff}.badge-rough{background:#854d0e;color:#fff}.badge-bunker{background:#d97706;color:#fff}.badge-penalty{background:#ef4444;color:#fff}.badge-holed{background:var(--primary);color:#fff}.landing-row{margin-bottom:10px}.landing-row-label{font-size:13px;font-weight:700;color:var(--text);margin-bottom:10px}.landing-row-hint{font-weight:400;color:var(--text-muted)}.landing-tags-outer{display:flex;flex-wrap:wrap;gap:8px}.shot-add-col{flex:0 0 68px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;border:2px dashed var(--border);border-radius:var(--r);color:var(--primary);background:transparent;cursor:pointer;padding:12px 8px;align-self:stretch;transition:background .12s,border-color .12s;font-family:inherit}.shot-add-col:active{background:var(--primary-light);border-color:var(--primary)}.shot-add-icon{font-size:24px;font-weight:300;line-height:1}.shot-add-col span:last-child{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.hole-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--border)}.hole-info{display:flex;flex-direction:column;gap:2px}.hole-title{display:flex;align-items:baseline;gap:8px}.hole-number{font-size:22px;font-weight:900;color:var(--text);letter-spacing:-.01em}.hole-nine{font-size:13px;font-weight:500;color:var(--text-muted)}.hole-meta{display:flex;gap:0;font-size:13px;font-weight:500;color:var(--text-muted)}.hole-meta span+span:before{content:" · ";white-space:pre}.shots-list{display:flex;flex-direction:column;gap:10px;margin-bottom:10px}.shot-block{background:var(--surface);border-radius:var(--r);padding:14px;box-shadow:var(--shadow)}.shot-block-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.shot-number-label{font-size:12px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em}.picker-container{border-radius:var(--r-sm);overflow:hidden;border:1px solid var(--border);margin-bottom:12px;background:#fafafa}.picker-container li{font-size:17px!important;font-weight:500}.landing-tags{display:flex;flex-wrap:wrap;gap:7px}.tag{padding:7px 13px;border-radius:100px;font-size:13px;font-weight:600;border:1.5px solid transparent;background:#f3f4f6;color:#6b7280;transition:all .12s;-webkit-user-select:none;user-select:none}.tag:active{transform:scale(.94)}.tag-fairway.tag-active{background:#22c55e;color:#fff;border-color:#16a34a}.tag-green.tag-active{background:#15803d;color:#fff;border-color:#166534}.tag-rough.tag-active{background:#854d0e;color:#fff;border-color:#78350f}.tag-bunker.tag-active{background:#d97706;color:#fff;border-color:#b45309}.tag-penalty.tag-active{background:#ef4444;color:#fff;border-color:#dc2626}.tag-holed.tag-active{background:var(--primary);color:#fff;border-color:var(--primary-dark)}.btn-finish-ready{background:#16a34a;color:#fff;animation:pulse-ready 1.8s ease-in-out infinite}@keyframes pulse-ready{0%,to{box-shadow:0 0 #16a34a73}50%{box-shadow:0 0 0 7px #16a34a00}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);display:flex;align-items:flex-end;justify-content:center;z-index:200;padding:0 16px calc(32px + var(--safe-bottom))}.modal-card{background:var(--surface);border-radius:var(--r);padding:24px;width:100%;max-width:430px;box-shadow:0 -4px 32px #00000026}.modal-title{font-size:18px;font-weight:800;margin-bottom:8px}.modal-body{font-size:15px;color:var(--text-muted);margin-bottom:24px;line-height:1.5}.modal-actions{display:flex;gap:10px}.modal-actions .btn{flex:1}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#dc2626}.holed-prompt{background:var(--primary-light);color:var(--primary-dark);font-weight:700;font-size:15px;padding:14px 20px;border-radius:var(--r);text-align:center;margin:6px 0;cursor:pointer;border:1.5px solid #a7d7be;transition:background .12s}.holed-prompt:active{background:#b7e4cc}.hole-summary-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.hole-summary-header h2{font-size:28px;font-weight:900;letter-spacing:-.02em}.par-badge{background:var(--primary-light);color:var(--primary-dark);padding:4px 12px;border-radius:100px;font-size:13px;font-weight:700}.shot-recap-row{display:grid;grid-template-columns:46px 1fr 18px auto;align-items:center;gap:8px;padding:9px 0;border-bottom:1px solid var(--border);font-size:15px}.shot-recap-row:last-child{border-bottom:none;padding-bottom:0}.sr-num{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.sr-club{font-weight:500}.sr-arrow{color:var(--text-muted);text-align:center;font-size:13px}.sr-landed{font-weight:600;font-size:14px}.score-summary-card{display:flex;align-items:center;justify-content:space-between;gap:8px}.strokes-big{font-size:28px;font-weight:900;letter-spacing:-.02em}.hole-name{font-size:18px;font-weight:700;color:var(--primary);flex:1;text-align:center}.rel-badge{font-size:22px;font-weight:800}.section-label{font-size:12px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px}.action-buttons{display:flex;flex-direction:column;gap:10px;margin-top:4px}.leaderboard-list{display:flex;flex-direction:column;gap:8px}.lb-row{display:grid;grid-template-columns:28px 1fr auto;align-items:center;gap:12px;cursor:pointer;transition:opacity .12s}.lb-row:active{opacity:.75}.lb-row.is-me{background:var(--primary-light);border:1.5px solid #a7d7be}.lb-rank{font-size:13px;font-weight:700;color:var(--text-muted);text-align:center}.lb-name{font-size:16px;font-weight:600}.lb-scores{display:flex;flex-direction:column;align-items:flex-end;gap:1px}.lb-strokes{font-size:18px;font-weight:800;line-height:1.2}.lb-rel{font-size:13px;font-weight:700;line-height:1.2}.under-par{color:#16a34a}.over-par{color:#dc2626}.even-par{color:var(--text-muted)}.player-header{margin-bottom:16px}.player-header h2{font-size:26px;font-weight:900;letter-spacing:-.02em;margin-bottom:2px}.player-total-row{display:flex;align-items:baseline;gap:10px}.player-strokes{font-size:32px;font-weight:900;letter-spacing:-.02em}.player-rel{font-size:20px;font-weight:700}.holes-breakdown{display:flex;flex-direction:column;gap:10px}.hole-card-header{display:flex;align-items:baseline;gap:8px;padding-bottom:10px;border-bottom:1px solid var(--border);margin-bottom:8px;flex-wrap:wrap}.hc-hole{font-size:15px;font-weight:700;flex:1;min-width:60px}.hc-par{font-size:13px;color:var(--text-muted);font-weight:500}.hc-strokes{font-size:15px;font-weight:700}.hc-rel{font-size:14px;font-weight:700}.shots-detail{display:flex;flex-direction:column;gap:2px}.end-screen-title{font-size:28px;font-weight:900;color:var(--primary-dark);letter-spacing:-.02em;margin-bottom:4px}.end-screen-subtitle{font-size:15px;color:var(--text-muted);margin-bottom:24px}.save-round-card h3{font-size:17px;font-weight:700;margin-bottom:6px}.save-round-card p{font-size:14px;color:var(--text-muted);margin-bottom:16px}.save-round-card .btn{width:100%;margin-bottom:8px}.otp-hint{font-size:13px;color:var(--text-muted);margin-bottom:12px}.saved-confirm{text-align:center;padding:8px 0 16px;font-size:17px;font-weight:600;color:var(--primary)}
