*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #fffbeb;--surface: #ffffff;--text: #292524;--text-muted: #78716c;--border: #d6d3d1;--primary: #d97706;--primary-hover: #b45309;--accent: #ca8a04;--accent-hover: #a16207;--danger: #dc2626;--success: #16a34a;--radius: 10px;--shadow-sm: 0 1px 3px rgba(120, 80, 0, .08);--shadow-md: 0 4px 12px -2px rgba(120, 80, 0, .12);--gold-gradient: linear-gradient(135deg, #fbbf24, #f59e0b, #d97706)}html{font-family:Inter,system-ui,-apple-system,sans-serif;font-size:16px;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}body{min-height:100dvh}.app{max-width:520px;margin:0 auto;min-height:100dvh;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;justify-content:space-between;padding:6px 12px;background:linear-gradient(135deg,#fffbeb,#fef3c7);border-bottom:1px solid #fde68a;position:sticky;top:0;z-index:50}.topbar-title{font-size:.95rem;font-weight:800;display:flex;align-items:center;gap:5px;color:#92400e}.topbar-star{color:#f59e0b;font-size:1.1rem;filter:drop-shadow(0 1px 2px rgba(245,158,11,.4))}.topbar-actions{display:flex;align-items:center;gap:6px}.btn-help{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:50%;background:#92400e14;color:#92400e;cursor:pointer;transition:background .15s;padding:0}.btn-help:hover{background:#92400e26}.nav{display:flex;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:37px;z-index:40}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 4px 5px;background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;color:var(--text-muted);font-size:.65rem;font-weight:600;transition:color .15s,border-color .15s}.nav-item--active{color:#b45309;border-bottom-color:#f59e0b}.nav-icon{font-size:1rem;display:flex;align-items:center;justify-content:center}.main{flex:1;padding:10px 12px}.page{display:flex;flex-direction:column;gap:10px}.game-view{display:flex;flex-direction:column;align-items:center;gap:8px}.game-header{text-align:center}.game-title{font-size:.92rem;font-weight:700;letter-spacing:-.01em}.game-subtitle{color:var(--text-muted);font-size:.72rem;margin-top:1px}.info-strip{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:min(420px,calc(100vw - 48px));padding:4px 12px;background:#fefce8;border:1px solid #fde68a;border-radius:999px;font-size:.75rem;font-weight:600;color:#92400e}.info-strip-meta{display:flex;align-items:center;gap:5px}.info-strip-stars{display:inline-flex;align-items:center;gap:1px}.info-strip-dot{opacity:.4;font-weight:400}.info-strip-timer{display:flex;align-items:center;gap:6px}.timer-display{font-size:1rem;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:.02em;color:var(--text)}.btn-timer{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:50%;background:#0000000f;color:var(--text-muted);cursor:pointer;transition:background .15s}.btn-timer:hover{background:#0000001a;color:var(--text)}.board-wrapper{position:relative;width:100%;max-width:min(420px,calc(100vw - 48px));display:flex;justify-content:center}.pause-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;background:#ffffffeb;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-radius:var(--radius);cursor:pointer;z-index:10;-webkit-user-select:none;user-select:none;transition:background .15s}.pause-overlay:hover{background:#fffffff5}.pause-overlay-icon{font-size:2.5rem;line-height:1}.pause-overlay-text{font-size:1.2rem;font-weight:700;color:var(--text)}.pause-overlay-hint{font-size:.8rem;color:var(--text-muted)}.cell{width:100%;height:100%;font-size:0;-webkit-tap-highlight-color:transparent;outline:none}.star-icon{display:flex;align-items:center;justify-content:center;width:100%;height:100%;filter:drop-shadow(0 1px 3px rgba(245,197,24,.5));line-height:1}.mark-icon{display:flex;align-items:center;justify-content:center;width:100%;height:100%;line-height:1}.cell--error{animation:shake .3s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-2px)}75%{transform:translate(2px)}}.game-controls{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;align-items:center}.game-controls-secondary{display:flex;gap:6px;align-items:center}.completion-banner{text-align:center;padding:20px 24px;background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #fbbf24;border-radius:var(--radius);display:flex;flex-direction:column;gap:8px;align-items:center;box-shadow:0 2px 12px #fbbf2433}.completion-banner h3{font-size:1.2rem}.validation-feedback{width:100%;max-width:400px}.feedback--ok{color:var(--success);font-weight:500;text-align:center}.feedback--errors{list-style:none;display:flex;flex-direction:column;gap:4px}.feedback--errors li{color:var(--danger);font-size:.85rem;padding:6px 10px;background:#fef2f2;border-radius:6px;border-left:3px solid var(--danger)}.instructions{color:var(--text-muted);font-size:.72rem;text-align:center;opacity:.7}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 18px;border:none;border-radius:var(--radius);font-size:.875rem;font-weight:600;cursor:pointer;transition:background .15s,color .15s,box-shadow .15s}.btn--primary{background:var(--primary);color:#fff}.btn--primary:hover{background:var(--primary-hover)}.btn--accent{background:var(--accent);color:#fff}.btn--accent:hover{background:var(--accent-hover)}.btn--ghost{background:transparent;color:var(--text-muted);border:1px solid var(--border)}.btn--ghost:hover{background:var(--bg);color:var(--text)}.btn--sm{padding:4px 12px;font-size:.8rem}.btn--icon{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;font-size:1.1rem;background:transparent;color:var(--text-muted);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:background .15s,color .15s}.btn--icon:hover:not(:disabled){background:var(--bg);color:var(--text)}.btn--icon:disabled{opacity:.35;cursor:default}.btn--danger{color:var(--danger)}.badge{display:inline-flex;align-items:center;gap:2px;padding:2px 8px;font-size:.75rem;font-weight:600;border-radius:999px;background:#fef3c7;color:#92400e;border:1px solid #fde68a}.practice-picker{display:flex;flex-direction:column;gap:6px;align-items:center;width:100%;max-width:420px;margin:0 auto}.picker-row{width:100%;display:flex;align-items:center;gap:6px}.picker-row-label{font-size:.72rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;min-width:36px;flex-shrink:0}.picker-options{display:flex;gap:4px;flex-wrap:wrap}.btn--chip{padding:4px 8px;border:1px solid var(--border);border-radius:999px;background:var(--surface);cursor:pointer;font-weight:600;font-size:.75rem;transition:border-color .15s,background .15s;line-height:1.2}.btn--chip:hover{border-color:var(--primary);background:#fef3c7}.btn--chip--active{border-color:#f59e0b;background:#fef3c7;color:#92400e;box-shadow:0 0 0 2px #f59e0b40}.picker-diff{width:100%;display:flex;align-items:center;gap:8px}.difficulty-bar-track{flex:1;height:6px;background:var(--border);border-radius:999px;overflow:hidden}.difficulty-bar-fill{height:100%;border-radius:999px;transition:width .35s ease,background-color .35s ease}.difficulty-label{font-size:.72rem;font-weight:700;transition:color .35s ease;white-space:nowrap;flex-shrink:0}.preset-grid{display:flex;flex-wrap:wrap;gap:6px;justify-content:center}.btn--preset{display:flex;flex-direction:column;padding:8px 14px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);cursor:pointer;font-weight:600;font-size:.85rem;transition:border-color .15s,box-shadow .15s}.btn--preset:hover{border-color:var(--primary)}.btn--preset--active{border-color:#f59e0b;box-shadow:0 0 0 2px #f59e0b40}.preset-diff{font-size:.7rem;font-weight:400;color:var(--text-muted)}.stats-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px;display:flex;flex-direction:column;align-items:center;gap:4px;box-shadow:var(--shadow-sm);border-top:3px solid #fbbf24}.stat-value{font-size:1.4rem;font-weight:700}.stat-label{font-size:.75rem;color:var(--text-muted);font-weight:500}.stats-table{width:100%;border-collapse:collapse;font-size:.82rem}.stats-table th{text-align:left;font-weight:600;padding:6px 8px;border-bottom:2px solid var(--border);color:var(--text-muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}.stats-table td{padding:6px 8px;border-bottom:1px solid var(--border)}.auth-area{position:relative}.auth-trigger{display:flex;align-items:center;gap:5px;padding:3px 8px}.auth-avatar{width:24px;height:24px;border-radius:50%;object-fit:cover}.auth-avatar-placeholder{width:24px;height:24px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700}.auth-name{font-size:.75rem;max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.auth-menu{position:absolute;right:0;top:calc(100% + 4px);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);padding:12px;min-width:220px;display:flex;flex-direction:column;gap:8px;z-index:100}.auth-menu-note,.auth-menu-email{font-size:.8rem;color:var(--text-muted)}.auth-name-edit{display:flex;gap:6px;align-items:center}.auth-name-edit input{flex:1;min-width:0}.group-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}.group-action-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px;display:flex;flex-direction:column;gap:8px;box-shadow:var(--shadow-sm)}.group-action-card h3{font-size:.85rem;font-weight:600}.group-action-card input{width:100%}.group-list{display:flex;flex-direction:column;gap:8px}.group-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px;cursor:pointer;transition:border-color .15s,box-shadow .15s;display:flex;flex-direction:column;gap:6px;box-shadow:var(--shadow-sm)}.group-card:hover{border-color:#f59e0b;box-shadow:0 1px 6px #f59e0b26}.group-card-header{display:flex;justify-content:space-between;align-items:center}.group-card-header h3{font-size:.95rem}.invite-code{font-family:monospace;font-weight:700;font-size:.85rem;color:#92400e;background:#fef3c7;padding:2px 8px;border-radius:4px;letter-spacing:.1em}.group-card p{font-size:.8rem;color:var(--text-muted)}.group-detail{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:12px}.group-detail h3{font-size:1rem}.group-detail-invite{font-size:.82rem;color:var(--text-muted)}.group-detail-invite code{font-weight:700;color:#92400e}.error-text{color:var(--danger);font-size:.85rem}.empty-state{color:var(--text-muted);font-size:.85rem;text-align:center;padding:20px 10px}.tabs{display:flex;gap:2px;border-bottom:1px solid var(--border)}.tab{padding:8px 14px;background:none;border:none;cursor:pointer;font-size:.82rem;font-weight:500;color:var(--text-muted);border-bottom:2px solid transparent;transition:color .15s,border-color .15s}.tab--active{color:#b45309;border-bottom-color:#f59e0b}.tab-content{padding-top:10px}.challenge-list{display:flex;flex-direction:column;gap:10px}.challenge-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:12px;display:flex;flex-direction:column;gap:8px;font-size:.85rem;transition:border-color .15s}.challenge-card--beat{border-color:#4ade80;background:#f0fdf4}.challenge-card--lost{border-color:#fbbf24;background:#fffbeb}.challenge-header{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}.challenge-header-left{display:flex;align-items:center;gap:6px}.challenge-time-to-beat{display:flex;align-items:center;gap:6px;font-size:.82rem}.challenge-time-label{color:var(--text-muted)}.challenge-time-value{font-weight:700;color:var(--text);font-size:.9rem}.challenge-status{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:6px;font-size:.82rem;font-weight:600}.challenge-status--beat{background:#dcfce7;color:#15803d}.challenge-status--lost{background:#fef3c7;color:#92400e}.challenge-status--new{background:#eff6ff;padding:8px 10px}.challenge-my-time{font-weight:500;opacity:.85}.challenge-results{font-size:.8rem;border-top:1px solid var(--border);padding-top:8px;margin-top:2px}.challenge-results-title{font-weight:600;margin-bottom:4px;font-size:.78rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.challenge-result-row{display:flex;align-items:center;gap:6px;padding:3px 0}.challenge-result-row.row--you{font-weight:600}.challenge-result-rank{width:24px;text-align:center;flex-shrink:0}.challenge-result-name{flex:1;display:flex;align-items:center;gap:4px}.challenge-result-time{font-weight:600;font-variant-numeric:tabular-nums}.challenge-beat-badge{font-size:.75rem}.challenge-play-banner{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 16px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:var(--radius);margin-bottom:12px;font-size:.85rem}.challenge-play-vs{font-size:.9rem}.challenge-play-target{font-size:.95rem;color:#1e40af}.member-list{list-style:none;display:flex;flex-direction:column;gap:8px}.member-item{display:flex;align-items:center;gap:8px;font-size:.85rem}.member-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover}.member-avatar--placeholder{display:flex;align-items:center;justify-content:center;background:#fef3c7;color:#92400e;font-weight:600;font-size:.8rem}.member-name{flex:1;display:flex;align-items:center;gap:4px}.member-kick{margin-left:auto}.admin-icon{color:#d97706;vertical-align:middle;margin-right:3px;flex-shrink:0}.grp-back-btn{margin-bottom:8px;display:inline-flex;align-items:center;gap:4px}.group-detail-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.group-detail-header h3{display:flex;align-items:center;gap:4px;font-size:1rem;margin:0}.group-meta{font-size:.8rem;color:var(--text-muted);white-space:nowrap}.group-card-footer{display:flex;align-items:center;justify-content:space-between}.group-member-count{display:flex;align-items:center;gap:4px;font-size:.8rem;color:var(--text-muted)}.btn-icon-inline{background:none;border:none;cursor:pointer;padding:2px 4px;color:var(--text-muted);border-radius:4px;transition:color .15s,background .15s;display:inline-flex;align-items:center}.btn-icon-inline:hover{color:#b45309;background:#fef3c7}.inline-edit{display:flex;align-items:center;gap:6px}.inline-edit input{font-size:.95rem;font-weight:600;padding:3px 8px;width:180px}.invite-section{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:10px 12px;display:flex;flex-direction:column;gap:8px}.invite-code-row{display:flex;align-items:center;gap:8px}.invite-label{font-size:.82rem;color:var(--text-muted)}.invite-share-row{display:flex;flex-direction:column;gap:6px}.invite-link-display{display:flex;align-items:center;gap:6px;font-size:.75rem;color:var(--text-muted);overflow:hidden}.invite-link-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.invite-share-actions{display:flex;gap:6px}.you-badge{display:inline-block;font-size:.65rem;font-weight:600;background:#dbeafe;color:#1e40af;padding:1px 5px;border-radius:3px;margin-left:4px;vertical-align:middle}.row--you{background:#fef3c7}.tab-subtitle{font-size:.78rem;color:var(--text-muted);margin-bottom:6px}.success-text{color:#16a34a;font-size:.85rem;font-weight:500}.settings-tab{display:flex;flex-direction:column;gap:16px}.settings-section{display:flex;flex-direction:column;gap:8px}.settings-section h4{font-size:.85rem;font-weight:600;margin:0}.settings-hint{font-size:.75rem;color:var(--text-muted)}.group-footer-actions{padding-top:8px;border-top:1px solid var(--border)}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:spin .8s linear infinite}input[type=text]{padding:6px 10px;border:1px solid var(--border);border-radius:6px;font-size:.85rem;font-family:inherit;outline:none;transition:border-color .15s}input[type=text]:focus{border-color:var(--primary);box-shadow:0 0 0 2px #d9770626}@media(max-width:400px){.group-actions{grid-template-columns:1fr}.stats-cards{grid-template-columns:1fr 1fr}}@media(display-mode:standalone){.topbar{padding-top:max(12px,env(safe-area-inset-top))}}.calendar{max-width:480px;margin:0 auto}.calendar h2{font-size:1.25rem;font-weight:700;text-align:center;margin-bottom:12px}.cal-nav{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:8px}.cal-nav-btn{font-size:1.4rem;padding:4px 10px;line-height:1}.cal-nav-title{font-size:1rem;font-weight:600;background:none;border:none;color:var(--text);cursor:pointer;padding:4px 8px;border-radius:var(--radius)}.cal-nav-title:hover{background:var(--border)}.cal-summary{text-align:center;font-size:.85rem;color:var(--text-muted);margin-bottom:12px}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.cal-header{text-align:center;font-size:.75rem;font-weight:600;color:var(--text-muted);padding:6px 0;text-transform:uppercase;letter-spacing:.5px}.cal-cell{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:6px 2px;border-radius:6px;background:var(--surface);border:1.5px solid var(--border);cursor:pointer;transition:all .15s ease;min-height:56px;gap:1px;font-family:inherit}.cal-cell:hover:not(.cal-cell--blank):not(.cal-cell--disabled){border-color:#f59e0b;box-shadow:var(--shadow-sm);transform:translateY(-1px)}.cal-cell--blank{background:transparent;border-color:transparent;cursor:default}.cal-cell--today{border-color:#f59e0b;border-width:2px;background:#fffbeb}.cal-cell--solved{background:#dcfce7;border-color:#4ade80}.cal-cell--solved .cal-check{color:#16a34a;line-height:1;display:flex;align-items:center;justify-content:center}.cal-cell--future{opacity:.35;cursor:default}.cal-cell--disabled{opacity:.3;cursor:default}.cal-day{font-size:.85rem;font-weight:600;color:var(--text);line-height:1}.cal-check{color:#16a34a;line-height:1;display:flex;align-items:center;justify-content:center}.cal-legend{display:flex;justify-content:center;gap:12px;margin-top:16px;font-size:.75rem;color:var(--text-muted);flex-wrap:wrap}.cal-legend-check{display:inline-flex;align-items:center;color:#16a34a;vertical-align:middle;margin-right:2px}.cal-legend-today{position:relative;padding-left:14px}.cal-legend-today:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:10px;height:10px;border:2px solid #f59e0b;border-radius:3px;box-sizing:border-box}.cal-back-btn{margin-bottom:12px}@media(max-width:420px){.nav-item{padding:5px 4px;font-size:.62rem}.nav-icon{font-size:1rem}.cal-cell{min-height:48px;padding:4px 1px}.cal-day{font-size:.78rem}}.tutorial{display:flex;flex-direction:column;height:calc(100dvh - 40px);padding:16px;max-width:480px;margin:0 auto;overflow:hidden;box-sizing:border-box}.tut-progress{display:flex;justify-content:center;gap:8px;margin-bottom:24px}.tut-dot{width:10px;height:10px;border-radius:50%;border:2px solid var(--border);background:transparent;cursor:pointer;padding:0;transition:background .2s,border-color .2s,transform .2s}.tut-dot--active{border-color:#f59e0b;background:#f59e0b;transform:scale(1.25)}.tut-dot--done{border-color:#d97706;background:#fde68a}.tut-content{flex:1;display:flex;align-items:flex-start;justify-content:center;overflow-y:auto;min-height:0}.tut-step{display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center;width:100%;animation:tutFadeIn .3s ease-out}@keyframes tutFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.tut-star-burst{display:flex;align-items:center;justify-content:center;width:88px;height:88px;border-radius:50%;background:linear-gradient(135deg,#fef3c7,#fde68a);box-shadow:0 4px 20px #f59e0b40;margin-bottom:4px}.tut-heading{font-size:1.3rem;font-weight:800;color:#92400e;letter-spacing:-.01em}.tut-text{font-size:.92rem;line-height:1.6;color:var(--text);max-width:380px}.tut-text--muted{color:var(--text-muted);font-size:.82rem}.tut-text--sm{font-size:.82rem;color:var(--text-muted)}.tut-board-wrap{display:flex;flex-direction:column;align-items:center;gap:6px}.tut-board{border-radius:4px;overflow:hidden;box-shadow:var(--shadow-sm)}.tut-board-caption{font-size:.78rem;color:var(--text-muted);font-weight:600}.tut-comparison{display:flex;gap:20px;flex-wrap:wrap;justify-content:center}.tut-cycle{display:flex;align-items:center;gap:6px;flex-wrap:wrap;justify-content:center;padding:10px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.tut-cycle-item{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:6px;font-size:.82rem;font-weight:600}.tut-cycle-empty{background:#f5f5f4;color:var(--text-muted)}.tut-cycle-mark{background:#f5f5f4;color:#a8a29e}.tut-cycle-star{background:#fef9e7;color:#92400e}.tut-cycle-arrow{color:var(--text-muted);flex-shrink:0}.tut-tips{display:flex;flex-direction:column;gap:10px;width:100%;max-width:380px;text-align:left}.tut-tip{display:flex;gap:10px;align-items:flex-start;padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);font-size:.85rem;line-height:1.5}.tut-tip-num{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:var(--gold-gradient);color:#fff;font-size:.75rem;font-weight:800;flex-shrink:0}.tut-solved-banner{display:flex;align-items:center;gap:8px;justify-content:center;padding:10px 16px;background:#fbbf241f;border:1px solid rgba(251,191,36,.3);border-radius:10px;font-weight:600;color:var(--text);font-size:.95rem}.tut-error{color:#ef4444;font-size:.85rem;text-align:center;margin-top:6px;font-weight:500}.tut-nav{display:flex;justify-content:space-between;align-items:center;padding-top:20px;margin-top:auto;border-top:1px solid var(--border)}
