:root{--green: #1a5c3a;--green-light: #2d7a52;--green-dark: #0f3d26;--bg: #f5f3ef;--card: #ffffff;--text: #1a1a1a;--text-muted: #666;--border: #e0ddd8;--danger: #c0392b;--radius: 12px;--shadow: 0 2px 12px rgba(0, 0, 0, .08)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);min-height:100dvh;line-height:1.5}#root{min-height:100dvh}.app-shell{max-width:430px;margin:0 auto;min-height:100dvh;background:var(--bg);position:relative}@media(min-width:768px){body{background:#ddd}.app-shell{box-shadow:var(--shadow)}}.page{padding:16px 16px 100px;min-height:100dvh}.loading{text-align:center;padding:40px;color:var(--text-muted)}.loading-more{padding:16px;font-size:.85rem}.load-more-sentinel{height:1px}.load-more-done{padding:12px 0 0;font-size:.8rem}.error-msg{color:var(--danger);font-size:.875rem;text-align:center;margin:8px 0}.info-msg{color:var(--text-muted);font-size:.875rem;text-align:center;margin-bottom:12px;padding:8px;background:#fff8e1;border-radius:var(--radius)}.empty-msg{text-align:center;color:var(--text-muted);padding:32px 16px}.login-page{display:flex;align-items:center;justify-content:center;min-height:100dvh;padding:24px 16px}.login-card{background:var(--card);border-radius:20px;padding:32px 24px;width:100%;box-shadow:var(--shadow);text-align:center}.login-icon{font-size:2.5rem;margin-bottom:8px}.login-card h1{font-size:1.5rem;color:var(--green);margin-bottom:4px}.app-brand-title{font-size:16px;font-weight:700;color:var(--green);line-height:1.3;margin:0}.app-brand-subtitle{font-size:13px;font-weight:400;color:var(--text-muted);line-height:1.3;margin:0}.app-brand-center{text-align:center;margin-bottom:4px}.app-brand-center .app-brand-subtitle{margin-top:2px}.subtitle{color:var(--text-muted);font-size:.9rem;margin-bottom:24px}.active-game-status{margin:12px 0 16px;padding:12px;border-radius:var(--radius);text-align:center;font-size:.85rem;line-height:1.5}.active-game-status.loading-status{color:var(--text-muted);background:#f9f9f9}.active-game-status.no-active{color:var(--danger);background:#fdf2f2;border:1px dashed #e8b4b0;font-weight:600}.active-game-status.has-active{background:#e8f5e9;border:1px solid #a5d6a7}.active-game-label{font-weight:700;color:var(--green);margin-bottom:4px}.active-game-time{color:var(--text);font-size:.8rem;margin-bottom:4px}.active-game-meta{display:flex;flex-direction:column;gap:4px;margin-bottom:6px}.active-game-meta-item{color:var(--text);font-size:.82rem}.active-game-round{color:var(--danger);font-weight:600;font-size:.9rem}.active-game-elapsed{color:var(--text)}.elapsed-timer{font-variant-numeric:tabular-nums;letter-spacing:.5px}.active-game-players{color:var(--text-muted);font-size:.75rem}.pin-display{display:flex;justify-content:center;gap:16px;margin-bottom:16px}.pin-dot{width:16px;height:16px;border-radius:50%;border:2px solid var(--border);background:transparent}.pin-dot.filled{background:var(--green);border-color:var(--green)}.pin-pad{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:24px}.pin-btn{min-height:56px;font-size:1.25rem;font-weight:600;border:1px solid var(--border);border-radius:var(--radius);background:var(--card);cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.pin-btn:active{background:var(--bg)}.pin-btn-clear{font-size:1rem}.pin-pad-spacer{min-height:56px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;gap:8px}.page-header h1{font-size:1.25rem;color:var(--green)}.page-header .app-brand{flex:1}.back-link{color:var(--green);text-decoration:none;font-size:.9rem;min-height:44px;display:flex;align-items:center}.btn-primary,.btn-secondary,.btn-text,.btn-danger-sm,.btn-primary-sm{border:none;cursor:pointer;font-size:1rem;border-radius:var(--radius);min-height:48px;padding:0 20px;touch-action:manipulation;-webkit-tap-highlight-color:transparent;text-decoration:none;display:inline-flex;align-items:center;justify-content:center}.btn-primary{background:var(--green);color:#fff;font-weight:600}.btn-primary:disabled{opacity:.5}.btn-secondary{background:#fff;color:var(--green);border:2px solid var(--green);font-weight:600}.btn-block{width:100%}.btn-text{background:none;color:var(--green);min-height:44px;padding:0 8px}.btn-danger-sm{background:none;color:var(--danger);min-height:36px;padding:0 12px;font-size:.85rem}.btn-primary-sm{background:var(--green);color:#fff;min-height:40px;padding:0 16px;font-size:.9rem}.bottom-actions{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:430px;padding:12px 16px;background:var(--bg);border-top:1px solid var(--border);display:flex;flex-direction:column;gap:8px}.tabs{display:flex;gap:8px;margin-bottom:16px}.tab{flex:1;min-height:44px;border:1px solid var(--border);border-radius:var(--radius);background:#fff;font-size:.85rem;cursor:pointer}.tab.active{background:var(--green);color:#fff;border-color:var(--green)}.filter-tokens{display:flex;flex-wrap:wrap;gap:6px;margin:-4px 0 12px}.filter-token{flex:1 1 calc(50% - 3px);min-height:32px;padding:4px 8px;border-radius:999px;border:1px solid #e8dcc8;background:#fff;font-size:.68rem;font-weight:600;color:var(--text-muted);cursor:pointer;box-shadow:none;transition:background .15s,color .15s,border-color .15s}.filter-token.active{background:#fff3e0;color:#e65100;border-color:#ffb74d;box-shadow:none}.stats-list{list-style:none;display:flex;flex-direction:column;gap:10px}.stats-item{display:flex;align-items:center;gap:12px;background:#fff;border-radius:var(--radius);padding:12px;box-shadow:var(--shadow)}.stats-info{flex:1;min-width:0}.stats-metrics{display:flex;gap:16px;margin-top:6px}.stat-metric{display:flex;flex-direction:column;align-items:center;min-width:48px}.stat-metric-value{font-weight:700;font-size:1rem}.stat-metric-label{font-size:.7rem;color:var(--text-muted)}.game-list{list-style:none;display:flex;flex-direction:column;gap:10px}.game-card{display:block;background:#fff;border-radius:var(--radius);padding:14px 16px;text-decoration:none;color:inherit;box-shadow:var(--shadow);position:relative}.game-card-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px}.game-card-delete{margin:0;padding:0;min-height:auto;font-size:.78rem;flex-shrink:0;white-space:nowrap}.game-card-delete-spacer{flex-shrink:0;width:28px}.game-card-meta{display:flex;flex:1;flex-wrap:nowrap;align-items:center;justify-content:center;gap:10px;font-size:.72rem;min-width:0;overflow:hidden}.game-card-meta .game-date,.game-card-meta .game-card-time-item{white-space:nowrap;flex-shrink:0}.game-card-time-item strong{color:var(--text-muted);font-weight:600}.game-card-time-item .elapsed-timer{color:var(--green);font-weight:700;font-variant-numeric:tabular-nums}.game-date{font-size:.72rem;color:var(--text-muted);white-space:nowrap}.badge{font-size:.75rem;padding:2px 8px;border-radius:20px;font-weight:600;flex-shrink:0}.badge.active{background:#e8f5e9;color:var(--green)}.badge.finished{background:#f5f5f5;color:var(--text-muted)}.fateet-ring{display:inline-flex;padding:2px;border:2px solid #ff9800;border-radius:50%}.player-avatar-item.fateet-player{position:relative}.player-role-label{display:block;font-size:.62rem;font-weight:700;margin-top:1px;text-align:center}.player-role-label.role-winner{color:#2ecc71}.player-role-label.role-dandool{color:#5c6bc0}.player-role-label.role-akheer{color:#8d6e63}.player-role-label.role-fateet{color:#e65100}.game-card-roles{display:flex;flex-direction:column;gap:4px;margin-top:10px;padding-top:10px;border-top:1px solid var(--border);font-size:.78rem}.game-card-roles-row{display:flex;justify-content:space-between;align-items:center;gap:8px}.game-role-item{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.game-role-empty{visibility:hidden}.game-role-item strong{font-weight:700}.game-role-item.role-winner{color:#2ecc71}.game-role-item.role-dandool{color:#5c6bc0}.game-role-item.role-akheer{color:#8d6e63}.game-role-item.role-fateet{color:#e65100}.game-players{font-size:.9rem;color:var(--text-muted);line-height:1.4}.section{margin-bottom:24px}.section h2{font-size:1rem;margin-bottom:12px;color:var(--text-muted)}.count-toggle{display:flex;gap:12px}.count-btn{flex:1;min-height:56px;font-size:1.5rem;font-weight:700;border:2px solid var(--border);border-radius:var(--radius);background:#fff;cursor:pointer}.count-btn.active{border-color:var(--green);background:var(--green);color:#fff}.player-select-list{list-style:none;display:flex;flex-direction:column;gap:8px}.player-select-btn{width:100%;min-height:64px;display:flex;align-items:center;justify-content:flex-start;gap:12px;padding:8px 16px;border:2px solid var(--border);border-radius:var(--radius);background:#fff;font-size:1rem;cursor:pointer}.player-select-name{flex:1;text-align:right;font-weight:600;font-size:.95rem}.player-select-btn .check{margin-inline-start:auto}.player-avatars-row{display:flex;flex-wrap:wrap;justify-content:center;gap:10px}.player-avatar-item{display:flex;flex-direction:column;align-items:center;gap:4px}.active-game-avatars .player-header-total{color:var(--text);font-size:.8rem;font-weight:400}.active-game-avatars .player-header-total.total-highest{color:#ff3b30}.active-game-avatars .player-header-total.total-lowest{color:#2ecc71}.active-game-avatars{margin-top:8px}.game-card-avatars{margin-top:8px;justify-content:center}.game-card-avatars .player-header-total{color:var(--text);font-size:.85rem;font-weight:600;min-height:1.1rem}.game-card-avatars .player-header-total.total-highest{color:#ff3b30}.game-card-avatars .player-header-total.total-lowest{color:#2ecc71}.game-card-avatars .player-avatar-item{min-width:52px}.player-col-avatar{padding:6px 4px!important;vertical-align:middle}.player-header-cell{display:flex;flex-direction:column;align-items:center;gap:4px}.player-header-total{font-size:.85rem;font-weight:400;color:#fff;line-height:1}.player-header-total.total-highest{color:#ff3b30}.player-header-total.total-lowest{color:#4cd964}.player-col-avatar .player-avatar-img,.player-col-avatar .player-avatar-default{margin:0 auto}.player-avatar-default,.player-avatar-img{border-radius:50%;flex-shrink:0;object-fit:cover;display:inline-flex;align-items:center;justify-content:center;color:#fff;font-weight:700}.player-form-card{background:#fff;border-radius:var(--radius);padding:16px;margin-bottom:16px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:10px}.player-form-bottom{margin-top:20px;margin-bottom:24px}.player-form-preview{display:flex;align-items:center;gap:12px}.upload-label{font-size:.85rem;color:var(--green);cursor:pointer}.upload-label input[type=file]{display:block;margin-top:4px;font-size:.8rem}.player-row{gap:12px}.player-info{flex:1;display:flex;flex-direction:column;align-items:flex-start;min-width:0}.player-name{font-weight:600}.player-mobile{font-size:.8rem;color:var(--text-muted);direction:ltr}.edit-player-form{display:flex;flex-direction:column;gap:10px;width:100%}.player-select-btn.selected{border-color:var(--green);background:#e8f5e9}.player-select-btn.disabled{opacity:.4;cursor:not-allowed}.player-select-btn.guest{border-style:dashed}.add-guest-btn{border-style:dashed;border-color:var(--green);color:var(--green);font-weight:600}.add-guest-btn.disabled{border-color:var(--border);color:var(--text-muted)}.add-guest-icon{width:52px;height:52px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#1a5c3a14;font-size:1.6rem;font-weight:400;line-height:1;flex-shrink:0}.guest-badge{display:inline-block;margin-inline-start:6px;padding:2px 8px;border-radius:999px;background:#1a5c3a1f;color:var(--green);font-size:.75rem;font-weight:600;vertical-align:middle}.guest-modal{max-width:360px}.guest-modal form{display:flex;flex-direction:column;gap:12px}.guest-modal .field-label{font-weight:600;font-size:.9rem}.guest-modal .text-input{width:100%}.add-guest-standalone{margin-top:12px}.check{color:var(--green);font-weight:700}.scoreboard-page{padding-bottom:120px}.score-entry-btn{margin-bottom:12px}.scoreboard-header{position:relative;justify-content:center;min-height:52px;margin-bottom:16px}.scoreboard-header .back-link{position:absolute;left:0;top:50%;transform:translateY(-50%);z-index:1}.scoreboard-title-wrap{text-align:center;width:100%}.scoreboard-round-title{font-size:1.75rem;font-weight:700;color:var(--green);line-height:1.2;margin-bottom:4px}.current-round-num{color:var(--danger);font-weight:800;font-size:1.85rem}.scoreboard-title-wrap .badge{display:inline-block}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:flex-end;justify-content:center;z-index:1000;padding:16px}.modal-card{background:#fff;border-radius:var(--radius);width:100%;max-width:430px;max-height:90dvh;overflow-y:auto;box-shadow:0 -4px 24px #00000026;padding:16px}.confirm-overlay{align-items:center;z-index:1100}.confirm-dialog{text-align:center;padding:20px}.confirm-title{font-size:1.15rem;color:var(--green);margin-bottom:10px}.confirm-message{font-size:.9rem;color:var(--text-muted);margin-bottom:16px;line-height:1.5}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.modal-header h2{font-size:1.1rem}.modal-close{border:none;background:transparent;font-size:1.5rem;line-height:1;cursor:pointer;color:var(--text-muted);padding:4px 8px}.round-score-round-picker{display:flex;align-items:center;gap:10px;margin-bottom:8px}.round-score-round-picker label{font-weight:600;white-space:nowrap}.round-score-round-picker select{flex:1}.round-score-hint{font-size:.8rem;color:var(--text-muted);margin-bottom:12px}.round-outcome-preview{display:flex;flex-direction:column;gap:4px;margin-bottom:12px;font-size:.85rem;font-weight:600}.outcome-winner{color:#2d7a52}.outcome-loser{color:var(--danger)}.terra-badge{display:inline-block;font-size:.65rem;font-weight:700;color:#b8860b;background:#fff8e1;border:1px solid #ffc107;border-radius:6px;padding:1px 5px;margin-top:2px}.round-score-form{display:flex;flex-direction:column;gap:12px}.round-score-list{list-style:none;display:flex;flex-direction:column;gap:10px}.round-score-row{display:grid;grid-template-columns:40px 1fr 64px auto;align-items:center;gap:8px;background:var(--bg);border-radius:var(--radius);padding:8px}.round-score-name{font-weight:600;font-size:.9rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.round-score-input{min-height:40px;text-align:center;padding:6px}.penalty-btns{display:flex;gap:4px}.penalty-btn{min-width:40px;min-height:36px;border:1px solid var(--border);border-radius:8px;background:#fff;font-size:.75rem;font-weight:600;cursor:pointer;padding:0 4px}.penalty-btn.active{background:var(--danger);color:#fff;border-color:var(--danger)}.penalty-btn.clear{color:var(--text-muted)}.modal-actions{display:flex;gap:10px;margin-top:4px}.round-score-actions{margin-top:16px;padding-top:12px;border-top:1px solid var(--border)}.modal-actions-stack{flex-direction:column}.modal-actions-stack .btn-primary,.modal-actions-stack .btn-secondary{flex:none;width:100%}.save-indicator{text-align:center;font-size:.8rem;color:var(--text-muted);margin-bottom:8px}.scoreboard-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -16px;padding:0 16px}.score-table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);font-size:.85rem}.score-table th,.score-table td{border:1px solid var(--border);text-align:center;padding:4px 2px}.score-table th{background:var(--green);color:#fff;font-size:.75rem;padding:8px 4px;white-space:nowrap}.round-col{width:40px;font-weight:700;background:#f9f9f9}.round-error-row .score-cell{background:#fff5f5}.round-error-row .score-input{border-color:#ef9a9a}.round-error-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:#ff3b30;color:#fff;font-size:.75rem;font-weight:700;flex-shrink:0}.round-cell{display:flex;flex-direction:column;align-items:center;gap:2px}.row-edit-btn{border:none;background:transparent;color:var(--green);font-size:.85rem;cursor:pointer;padding:2px 4px;line-height:1;border-radius:4px}.row-edit-btn:hover,.row-edit-btn:focus{background:#e8f5e9;outline:none}.player-col{min-width:56px;max-width:72px;overflow:hidden;text-overflow:ellipsis}.total-col{width:44px;font-weight:700;background:#f0f7f3}.score-input{width:100%;min-width:44px;min-height:44px;border:none;text-align:center;font-size:1rem;background:transparent;-moz-appearance:textfield}.score-input::-webkit-outer-spin-button,.score-input::-webkit-inner-spin-button{-webkit-appearance:none}.score-input:focus{outline:2px solid var(--green-light);background:#f0fff4}.score-input:disabled{color:var(--text);opacity:.8}.set-end-row td{border-bottom-width:2px;border-bottom-color:var(--green)}.set-marker-row td{padding:0;border:none}.set-marker{text-align:center;font-size:.7rem;color:var(--green);font-weight:600;padding:6px 0;background:#e8f5e9;letter-spacing:1px}.totals-row td{background:var(--green-dark);color:#fff;font-weight:700;font-size:.95rem;padding:10px 4px}.player-total{background:var(--green-dark)!important;position:relative;vertical-align:middle}.highest-total-dot{display:block;width:8px;height:8px;background:#ff3b30;border-radius:50%;margin:0 auto 4px;box-shadow:0 0 0 2px #ffffff59}.add-player-form{display:flex;gap:8px;margin-bottom:16px}.text-input{flex:1;min-height:48px;padding:0 12px;border:1px solid var(--border);border-radius:var(--radius);font-size:1rem}.manage-list{list-style:none;display:flex;flex-direction:column;gap:8px}.manage-item{background:#fff;border-radius:var(--radius);padding:12px 16px;box-shadow:var(--shadow)}.manage-row,.edit-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.manage-actions{display:flex;gap:4px}.manage-list.inactive .manage-item{opacity:.5}.section-title{font-size:.9rem;color:var(--text-muted);margin:20px 0 8px}
