*,*: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:12px 16px;background:linear-gradient(135deg,#fffbeb,#fef3c7);border-bottom:1px solid #fde68a;position:sticky;top:0;z-index:50}.topbar-title{font-size:1.25rem;font-weight:800;display:flex;align-items:center;gap:8px;color:#92400e}.topbar-star{color:#f59e0b;font-size:1.5rem;filter:drop-shadow(0 1px 2px rgba(245,158,11,.4))}.nav{display:flex;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:53px;z-index:40}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:10px 4px 8px;background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;color:var(--text-muted);font-size:.7rem;font-weight:600;transition:color .15s,border-color .15s}.nav-item--active{color:#b45309;border-bottom-color:#f59e0b}.nav-icon{font-size:1.1rem;display:flex;align-items:center;justify-content:center}.main{flex:1;padding:16px}.page{display:flex;flex-direction:column;gap:16px}.game-view{display:flex;flex-direction:column;align-items:center;gap:10px}.game-header{text-align:center}.game-title{font-size:1.05rem;font-weight:700;letter-spacing:-.01em}.game-subtitle{color:var(--text-muted);font-size:.78rem;margin-top:1px}.info-strip{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:420px;padding:6px 14px;background:#fefce8;border:1px solid #fde68a;border-radius:999px;font-size:.8rem;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}.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:10px;align-items:center;width:100%;max-width:420px;margin:0 auto}.picker-row{width:100%;display:flex;align-items:center;gap:10px}.picker-row-label{font-size:.78rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;min-width:40px;flex-shrink:0}.picker-options{display:flex;gap:4px;flex-wrap:wrap}.btn--chip{padding:5px 10px;border:1px solid var(--border);border-radius:999px;background:var(--surface);cursor:pointer;font-weight:600;font-size:.8rem;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;flex-direction:column;gap:3px;align-items:center}.difficulty-bar-track{width:100%;height:8px;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:.82rem;font-weight:700;transition:color .35s ease}.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:6px;padding:4px 10px}.auth-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover}.auth-avatar-placeholder{width:28px;height:28px;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:.82rem;max-width:100px;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;display:flex;flex-direction:column;gap:4px;box-shadow:var(--shadow-sm)}.group-card:hover,.group-card--active{border-color:#f59e0b}.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:6px;font-size:.85rem}.challenge-header{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.challenge-results{font-size:.8rem;padding-left:8px}.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}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:#fefce8;border-color:#fbbf24}.cal-cell--solved .cal-dot{color:#d97706;font-size:1rem}.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-dot{font-size:.65rem;line-height:1}.cal-time{font-size:.6rem;color:var(--text-muted);font-weight:500;letter-spacing:.3px;line-height:1}.cal-legend{display:flex;justify-content:center;gap:12px;margin-top:16px;font-size:.75rem;color:var(--text-muted);flex-wrap:wrap}.cal-legend-icon{margin-right:2px}.cal-back-btn{margin-bottom:12px}@media(max-width:420px){.nav-item{padding:8px 4px;font-size:.7rem}.nav-icon{font-size:1.1rem}.cal-cell{min-height:48px;padding:4px 1px}.cal-day{font-size:.78rem}}
