body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif}.auth-card{background:#fff;border-radius:16px;box-shadow:0 20px 40px #0000001a;padding:40px;width:100%;max-width:440px;animation:slideUp .6s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.auth-header{text-align:center;margin-bottom:32px}.auth-header h1{color:#2d3748;font-size:28px;font-weight:700;margin:0 0 8px}.brand{display:inline-flex;align-items:center;gap:10px}.brand-logo{width:32px;height:32px}.auth-header p{color:#718096;font-size:16px;margin:0}.auth-form{margin-bottom:24px}.form-group{margin-bottom:20px}.form-group label{display:block;color:#4a5568;font-size:14px;font-weight:600;margin-bottom:8px}.form-group input:not([type=checkbox]):not([type=radio]),.form-group select{width:100%;padding:12px 16px;border:2px solid #e2e8f0;border-radius:8px;font-size:16px;transition:all .2s ease;box-sizing:border-box}.form-group input:not([type=checkbox]):not([type=radio]):focus,.form-group select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:not([type=checkbox]):not([type=radio]):disabled,.form-group select:disabled{background-color:#f7fafc;cursor:not-allowed}.form-group input:not([type=checkbox]):not([type=radio])::placeholder{color:#a0aec0}.form-group input[type=checkbox],.form-group input[type=radio]{width:auto;padding:0;border:none;border-radius:0;box-shadow:none}.password-input{position:relative}.password-input input{padding-right:40px}.toggle-password{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer}.remember-credentials label{display:inline-flex;align-items:center;gap:8px;margin-bottom:0}.remember-credentials input[type=checkbox]{margin:0}.auth-button{width:100%;padding:14px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:8px}.auth-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 20px #667eea4d}.auth-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.login-mode-tabs{display:grid;grid-template-columns:repeat(2,1fr);gap:4px;margin-bottom:20px;padding:4px;background:#edf2f7;border-radius:8px}.login-mode-button{min-height:40px;border:0;border-radius:6px;background:transparent;color:#4a5568;cursor:pointer;font-size:14px;font-weight:700}.login-mode-button.is-active{background:#fff;color:#2d3748;box-shadow:0 1px 4px #0000001f}.login-mode-button:disabled{cursor:not-allowed;opacity:.7}.error-message{background-color:#fed7d7;color:#c53030;padding:12px 16px;border-radius:8px;font-size:14px;margin-bottom:20px;border-left:4px solid #e53e3e}.auth-footer{text-align:center;color:#718096;font-size:14px}.auth-link{color:#667eea;text-decoration:none;font-weight:600;transition:color .2s ease}.auth-link:hover{color:#5a67d8;text-decoration:underline}.auth-link-button{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:transparent;cursor:pointer;font:inherit;padding:0}.auth-register-modal{max-width:520px;width:min(520px,calc(100vw - 32px))}.login-register-form{margin-top:4px}.auth-register-note,.auth-register-field-note{color:#4a5568;font-size:13px;line-height:1.6;margin:0 0 16px}.auth-register-field-note{margin:8px 0 0}.auth-modal-actions{margin-top:16px;text-align:center}.auth-error{color:#c53030;font-size:14px;line-height:1.6;margin-top:8px}.lp-link{color:#fff;text-decoration:none;font-weight:600;transition:color .2s ease}.lp-link:hover{color:#fff;text-decoration:underline}@media(max-width:480px){.auth-card{padding:24px;margin:10px}.auth-header h1{font-size:24px}.auth-header p{font-size:14px}}*{box-sizing:border-box}body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.6;color:#2d3748}.container{max-width:1200px;margin:0 auto;padding:0 20px}.page-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:2rem 0;margin-bottom:2rem}.page-header h1{margin:0;font-size:2rem;font-weight:700}.brand{display:inline-flex;align-items:center;gap:12px}.brand-logo{width:36px;height:36px}.brand-title{line-height:1}.page-header p{margin:0;margin-top:.5rem;font-size:1rem}.page-header-actions{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center;justify-content:flex-end;margin-top:1rem}.mode-switch-link{display:inline-flex;align-items:center;justify-content:center;min-height:40px;padding:.6rem 1rem;border:1px solid rgba(255,255,255,.48);border-radius:6px;background:#0f172a2e;color:#fff;font-size:.9rem;font-weight:700;line-height:1.2;text-decoration:none;cursor:pointer}.mode-switch-link:hover{background:#0f172a47;text-decoration:none}.mode-switch-link:disabled{opacity:.62;cursor:wait}.page-header-mode-switch{margin-top:1rem}.admin-participant-gm-controls{display:inline-flex;align-items:center;gap:10px;width:fit-content;max-width:100%;margin-top:1rem;padding:8px;border:1px solid rgba(255,255,255,.24);border-radius:8px;background:#0f172a2e;box-shadow:inset 0 1px #ffffff24}.admin-participant-gm-controls .user-info,.admin-participant-gm-controls .crosstalk-caption{margin:0;color:#ffffffd6;font-size:.82rem;font-weight:700;white-space:nowrap}.admin-participant-gm-controls>.gm-actions,.admin-participant-gm-controls .gm-panel--compact .gm-actions{display:inline-flex;align-items:center;gap:6px;margin:0}.admin-participant-gm-controls .button,.gm-panel.gm-panel--compact .button{min-height:32px;padding:.42rem .78rem;border:1px solid rgba(255,255,255,.22);border-radius:6px;background:#ffffff29;box-shadow:none;color:#fff;font-size:.86rem;line-height:1.2}.admin-participant-gm-controls .button:hover,.gm-panel.gm-panel--compact .button:hover{background:#ffffff3d;box-shadow:none;transform:none}.admin-participant-gm-controls .button:disabled,.gm-panel.gm-panel--compact .button:disabled{opacity:.5}.gm-panel.gm-panel--compact{display:inline-flex;align-items:center;gap:8px;margin:0;padding:0;border:0;border-radius:0;background:transparent;box-shadow:none}.gm-panel.gm-panel--compact h2,.gm-panel.gm-panel--compact p{display:none}.gm-panel.gm-panel--compact .gm-actions+.gm-actions{display:none}.page-content{padding:2rem 0}.card{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;padding:1.5rem;margin-bottom:1rem}.button{display:inline-block;padding:.75rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;text-decoration:none;border-radius:6px;font-weight:600;border:none;cursor:pointer;transition:all .2s ease}.button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.button:disabled{opacity:.6;cursor:not-allowed;transform:none}.button-secondary{background:#e2e8f0;color:#4a5568}.button-secondary:hover{background:#cbd5e0}.text-center{text-align:center}.mt-2{margin-top:1rem}.mb-2{margin-bottom:1rem}.p-2{padding:1rem}.timer{font-size:2rem;font-weight:700;text-align:center;margin:1rem 0}.justify-center{justify-content:center}.role-card{text-align:center}.role-image{max-width:200px;width:100%;height:auto;border-radius:8px;margin-top:1rem}.player-select{width:100%;padding:.5rem;border:1px solid #cbd5e0;border-radius:6px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a99;display:flex;align-items:center;justify-content:center;padding:16px;z-index:1000}.modal-content{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0f172a40;max-width:520px;width:100%;padding:24px}.modal-title{margin:0 0 12px;font-size:1.4rem;font-weight:700;text-align:center}.modal-result-image{width:100%;height:auto;display:block;border-radius:8px}.viewer-password-tool{display:inline-flex;gap:10px;align-items:center;flex-wrap:wrap;justify-content:flex-end}.viewer-password-display{display:inline-flex;gap:4px;align-items:center;flex-wrap:wrap;font-size:.95rem;color:#1f2937}.viewer-password-value{min-width:3.6rem;letter-spacing:0}.viewer-password-toggle{display:inline-flex;align-items:center;justify-content:center;width:1.75rem;height:1.75rem;padding:0;border:none;border-radius:6px;background:transparent;color:currentColor;cursor:pointer}.viewer-password-toggle:hover,.viewer-password-toggle:focus-visible{background:transparent;color:currentColor}.viewer-password-toggle:focus-visible{outline:2px solid currentColor;outline-offset:2px}@media(max-width:768px){.container{padding:0 15px}.page-header h1{font-size:1.5rem}.admin-participant-gm-controls{display:flex;flex-wrap:wrap;width:100%}.gm-panel.gm-panel--compact{flex-wrap:wrap}}.home-page{--home-bg: #f5efe3;--home-surface: rgba(255, 255, 255, .88);--home-card-border: rgba(148, 163, 184, .22);--home-ink: #142132;--home-muted: #566577;--home-line: rgba(148, 163, 184, .26);--home-accent: #0f766e;min-height:100vh;background:radial-gradient(circle at top left,rgba(255,255,255,.88),transparent 32%),radial-gradient(circle at bottom right,rgba(15,118,110,.12),transparent 28%),linear-gradient(180deg,#f9f3e8 0%,var(--home-bg) 54%,#ece4d6 100%);color:var(--home-ink);font-family:Avenir Next,Hiragino Sans,Yu Gothic,sans-serif}.home-hero{position:relative;overflow:hidden;color:#f8fafc;padding:2rem 0 1.4rem;background:linear-gradient(135deg,#16233d,#145c6a 48%,#0f766e)}.home-hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 15% 15%,rgba(255,255,255,.2),transparent 18%),radial-gradient(circle at 85% 0%,rgba(191,219,254,.18),transparent 24%),linear-gradient(135deg,#0f172a1a,#0f172a00);pointer-events:none}.home-hero-surface{position:relative;display:grid;gap:18px;grid-template-columns:minmax(0,1.35fr) minmax(280px,.8fr);padding:2.2rem;border:1px solid rgba(255,255,255,.18);border-radius:28px;background:#0f172a33;box-shadow:0 24px 60px #0f172a3d;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.home-hero-main{display:grid;gap:.9rem;align-content:start}.home-kicker,.home-section-kicker{display:inline-flex;align-items:center;gap:.5rem;margin-bottom:.75rem;font-size:.78rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase}.home-brand{margin:0;color:inherit}.home-brand-logo{width:44px;height:44px}.home-stat-row{display:grid;gap:12px;grid-template-columns:repeat(2,minmax(0,1fr));margin-top:0}.home-stat-card{min-height:104px;padding:1rem 1.1rem;border:1px solid rgba(255,255,255,.14);border-radius:22px;background:#ffffff1f;box-shadow:inset 0 1px #ffffff14}.home-stat-label{display:block;font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;color:#e2e8f0d6}.home-stat-card strong{display:block;margin-top:.45rem;font-size:clamp(1.4rem,3vw,2.2rem);line-height:1}.home-account-panel{display:grid;gap:.9rem;align-content:start;justify-items:start;padding:1.25rem;border:1px solid rgba(255,255,255,.14);border-radius:24px;background:#ffffff1f}.home-account-meta{display:grid;gap:.75rem}.home-header-links{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.home-version,.home-header-link{font-size:.82rem;color:#e2e8f0eb;text-decoration:none}.home-header-link:hover{text-decoration:underline}.home-header-button{padding:0;border:0;background:transparent;cursor:pointer;font:inherit}.home-account-label{display:inline-flex;width:fit-content;padding:.28rem .65rem;border-radius:999px;background:#ffffff29;font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.home-layout{display:grid;gap:18px;grid-template-columns:minmax(0,1.2fr) minmax(320px,.9fr);align-items:start}.home-main-column{display:grid;gap:18px}.home-entry-card,.home-groups-card,.home-guide-card,.home-dev-card{border:1px solid var(--home-card-border);border-radius:26px;box-shadow:0 24px 48px #0f172a14;background:var(--home-surface);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.home-entry-card{padding:1.55rem}.home-sidebar{display:grid;gap:18px}.home-section-head{display:flex;gap:16px;justify-content:space-between;align-items:flex-start}.home-section-head h2,.home-section-head h3{margin:0}.home-section-head p{margin:.45rem 0 0;color:var(--home-muted);line-height:1.75}.home-section-head--compact{align-items:center}.home-game-badge{min-width:180px;padding:.9rem 1rem;border-radius:20px;color:#f8fafc;box-shadow:inset 0 1px #ffffff14}.home-game-badge span{display:block;font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;opacity:.88}.home-game-badge strong{display:block;margin-top:.35rem;font-size:1.1rem}.home-game-badge--werewolf{background:linear-gradient(135deg,#1f2937,#7f1d1d)}.home-game-badge--wordwolf{background:linear-gradient(135deg,#172554,#2563eb)}.home-game-badge--drawing-werewolf{background:linear-gradient(135deg,#064e3b,#7c3aed)}.home-game-badge--crosstalk{background:linear-gradient(135deg,#3b0764,#db2777)}.home-game-badge--neutral{background:linear-gradient(135deg,#334155,#475569)}.home-form-group{margin-top:1.4rem}.home-form-group label{display:block;margin-bottom:.45rem;font-weight:700}.home-form-group input,.home-form-group select{width:100%;min-height:54px;padding:.85rem 1rem;border:1px solid rgba(148,163,184,.34);border-radius:16px;background:#fffffff2;color:var(--home-ink);font:inherit}.home-form-group input:focus,.home-form-group select:focus{outline:none;border-color:#0f766e85;box-shadow:0 0 0 4px #0f766e24}.home-join-layout{display:grid;grid-template-columns:minmax(0,.92fr) minmax(280px,1.08fr);gap:18px;align-items:start}.home-join-form,.home-join-preview{display:grid;gap:14px}.home-join-note,.home-action-panel{padding:1rem 1.05rem;border-radius:18px;border:1px solid var(--home-line);background:#f8fafcdb}.home-action-panel{display:grid;gap:.85rem}.home-join-note{display:grid;gap:4px}.home-join-note strong{font-size:.9rem}.home-join-note span{color:var(--home-muted);line-height:1.7}.home-join-note.is-ready{background:#ecfdf5e6;border-color:#0f766e33}.home-selected-panel{padding:1.15rem;border:1px solid var(--home-line);border-radius:22px;background:radial-gradient(circle at top left,rgba(255,255,255,.82),transparent 42%),linear-gradient(180deg,#ffffffe6,#f8fafcb8)}.home-selected-topline{display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between;align-items:center}.home-selected-group{font-size:.9rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#0f766e}.home-selected-status{display:inline-flex;align-items:center;gap:.35rem;padding:.28rem .65rem;border-radius:999px;background:#0f766e1a;color:#0f766e;font-size:.78rem;font-weight:700}.home-selected-panel h3{margin:.55rem 0 0;font-size:1.35rem}.home-selected-panel p{margin:.55rem 0 0;color:var(--home-muted);line-height:1.78}.home-selected-meta{display:grid;gap:12px;grid-template-columns:repeat(2,minmax(0,1fr));margin:1rem 0 0}.home-selected-meta div{padding-top:.8rem;border-top:1px solid var(--home-line)}.home-selected-meta dt{font-size:.76rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--home-muted)}.home-selected-meta dd{margin:.35rem 0 0;font-size:1rem;font-weight:700}.home-entry-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:0}.home-start-button,.home-logout-button{min-height:50px;border-radius:16px}.home-start-button{min-width:210px}.home-group-count{display:inline-flex;align-items:center;min-height:34px;padding:.3rem .8rem;border-radius:999px;background:#ecfdf5;color:#0f766e;font-size:.85rem;font-weight:700}.home-group-list{display:grid;gap:12px;margin-top:1rem}.home-group-item{position:relative;display:grid;grid-template-columns:6px minmax(0,1fr);gap:12px;width:100%;padding:0;border:1px solid rgba(148,163,184,.2);border-radius:20px;background:#ffffffdb;text-align:left;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.home-group-item:hover{transform:translateY(-2px);border-color:#0f766e4d;box-shadow:0 18px 36px #0f172a14}.home-group-item.is-selected{border-color:#0f766e80;box-shadow:0 18px 38px #0f766e24}.home-group-accent{border-radius:20px 0 0 20px}.home-group-accent--werewolf{background:linear-gradient(180deg,#b91c1c,#7f1d1d)}.home-group-accent--wordwolf{background:linear-gradient(180deg,#38bdf8,#1d4ed8)}.home-group-accent--drawing-werewolf{background:linear-gradient(180deg,#10b981,#7c3aed)}.home-group-accent--crosstalk{background:linear-gradient(180deg,#db2777,#7c3aed)}.home-group-accent--neutral{background:linear-gradient(180deg,#64748b,#334155)}.home-group-item-body{padding:.95rem 1rem 1rem 0}.home-group-item-top{display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between;align-items:center}.home-group-item-top strong{font-size:1rem}.home-group-item-top span{color:var(--home-muted);font-size:.9rem;font-weight:700}.home-group-item p{margin:.45rem 0 0;color:var(--home-muted);line-height:1.68}.home-group-item-meta{display:flex;flex-wrap:wrap;gap:12px;margin-top:.75rem;color:#0f766e;font-size:.84rem;font-weight:700}.home-empty-state{margin-top:1rem;padding:1.2rem;border:1px dashed rgba(148,163,184,.4);border-radius:20px;background:#f8fafcb3}.home-empty-state strong{display:block}.home-empty-state p{margin:.4rem 0 0;color:var(--home-muted)}.home-guide-card h3,.home-dev-card h3{margin:0}.home-guide-list,.home-dev-list{display:grid;gap:10px;margin:1rem 0 0;padding-left:1.2rem}.home-guide-list li,.home-dev-list li{color:var(--home-muted)}.home-dev-card{grid-column:1 / -1}@media(max-width:980px){.home-hero-surface,.home-layout,.home-join-layout{grid-template-columns:1fr}.home-account-panel{order:-1}.home-selected-meta{grid-template-columns:1fr}}@media(max-width:640px){.home-hero{padding-top:1.2rem}.home-hero-surface{padding:1.35rem;border-radius:24px}.home-stat-row{grid-template-columns:1fr}.home-entry-card,.home-groups-card,.home-guide-card,.home-dev-card{padding:1.15rem;border-radius:22px}.home-section-head{flex-direction:column}.home-game-badge{width:100%;min-width:0}.home-entry-actions{flex-direction:column}.home-selected-meta{grid-template-columns:1fr}.home-start-button,.home-logout-button{width:100%}}.landing-page{--landing-bg: #f3efe6;--landing-surface: rgba(255, 255, 255, .9);--landing-card-border: rgba(148, 163, 184, .24);--landing-ink: #142132;--landing-muted: #516173;--landing-accent: #0f766e;--landing-accent-soft: #d5f3ee;min-height:100vh;padding-bottom:4rem;background:radial-gradient(circle at top left,rgba(255,255,255,.8),transparent 38%),radial-gradient(circle at bottom right,rgba(15,118,110,.12),transparent 28%),linear-gradient(180deg,#f7f2e8 0%,var(--landing-bg) 55%,#ebe5d8 100%);color:var(--landing-ink);font-family:Avenir Next,Hiragino Sans,Yu Gothic,sans-serif}.landing-hero{position:relative;overflow:hidden;color:#f8fafc;padding:2rem 0 1.5rem}.landing-hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 20% 20%,rgba(255,255,255,.22),transparent 20%),radial-gradient(circle at 80% 0%,rgba(191,219,254,.22),transparent 22%),linear-gradient(135deg,#0f172a1a,#0f172a00);pointer-events:none}.landing-hero--index{background:linear-gradient(135deg,#16233d,#145c6a 52%,#0f766e)}.landing-hero--werewolf{background:linear-gradient(135deg,#1f2937,#7f1d1d 56%,#b91c1c)}.landing-hero--wordwolf{background:linear-gradient(135deg,#172554,#1d4ed8 48%,#38bdf8)}.landing-hero--drawing-werewolf{background:linear-gradient(135deg,#064e3b,#4c1d95 48%,#7c3aed)}.landing-hero--crosstalk{background:linear-gradient(135deg,#442163,#7c3aed 46%,#db2777)}.landing-hero-surface{position:relative;display:grid;gap:1.25rem;padding:2.8rem;border:1px solid rgba(255,255,255,.18);border-radius:30px;background:#0f172a38;box-shadow:0 24px 60px #0f172a38;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.landing-kicker{display:inline-flex;align-items:center;gap:.5rem;margin-bottom:.9rem;font-size:.78rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase}.landing-brand{display:grid;grid-template-columns:auto 1fr;gap:1.25rem;align-items:start}.landing-brand-copy{display:grid;gap:.75rem}.landing-brand-mark{width:88px;height:88px;border-radius:24px;background:#ffffff2e;padding:14px}.landing-hero h1{margin:0;font-size:clamp(2.4rem,6vw,4.4rem);line-height:.95;letter-spacing:-.04em}.landing-hero p{margin:0;max-width:760px;font-size:1.02rem;line-height:1.8;color:#f8fafce6}.landing-actions{margin-top:1.5rem;display:flex;flex-wrap:wrap;gap:12px;align-items:center}.landing-pill-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:1.1rem}.landing-chip{display:inline-flex;align-items:center;min-height:36px;padding:.45rem .9rem;border-radius:999px;background:#ffffff2e;color:#f8fafc;font-size:.9rem;font-weight:700;text-decoration:none}.landing-section{margin-top:2rem}.landing-section-head{margin-bottom:1rem}.landing-section-head h2{margin:0;font-size:clamp(1.8rem,3vw,2.5rem);line-height:1.05}.landing-section-head p{margin:.5rem 0 0;color:var(--landing-muted);line-height:1.8}.landing-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.landing-grid--showcase{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.landing-card{background:var(--landing-surface);border:1px solid var(--landing-card-border);border-radius:24px;box-shadow:0 20px 40px #0f172a14;padding:1.25rem}.landing-card h3{margin:0;font-size:1.25rem}.landing-card p{margin:0;color:var(--landing-muted);line-height:1.75}.landing-card-eyebrow{font-size:.8rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--landing-accent)}.landing-game-card{display:grid;gap:1rem;text-decoration:none;color:inherit;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.landing-game-card:hover{transform:translateY(-4px);border-color:#0f766e52;box-shadow:0 26px 52px #0f172a1f}.landing-inline-link{color:var(--landing-accent);font-weight:700}.landing-plan-list{display:grid;gap:.65rem;margin:1rem 0 0}.landing-plan-list div{display:grid;gap:.2rem;padding-top:.65rem;border-top:1px solid rgba(148,163,184,.22)}.landing-plan-list dt{color:var(--landing-muted);font-size:.78rem;font-weight:700}.landing-plan-list dd{margin:0;color:var(--landing-ink);font-weight:700}.landing-section--split{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.landing-card--tint{background:linear-gradient(180deg,#fffaf0,#fff)}.landing-card--accent{background:linear-gradient(180deg,#ecfdf5,#f8fffc)}.landing-card--quickstart{max-width:760px;margin:0 auto}.landing-drawing-preview{display:grid;grid-template-columns:minmax(0,1fr) minmax(260px,420px);gap:1.25rem;align-items:center}.landing-drawing-board{position:relative;min-height:220px;border:1px solid rgba(124,58,237,.18);border-radius:18px;background:linear-gradient(90deg,rgba(148,163,184,.16) 1px,transparent 1px),linear-gradient(180deg,rgba(148,163,184,.16) 1px,transparent 1px),#fff;background-size:32px 32px;overflow:hidden}.landing-drawing-line,.landing-drawing-dot{position:absolute;display:block}.landing-drawing-line{height:8px;border-radius:999px;transform-origin:left center}.landing-drawing-line--one{left:42px;top:118px;width:150px;background:#111827;transform:rotate(-22deg)}.landing-drawing-line--two{left:155px;top:82px;width:140px;background:#7c3aed;transform:rotate(30deg)}.landing-drawing-line--three{left:270px;top:150px;width:96px;background:#0f766e;transform:rotate(-42deg)}.landing-drawing-dot{width:18px;height:18px;border-radius:999px}.landing-drawing-dot--one{left:214px;top:118px;background:#dc2626}.landing-drawing-dot--two{left:328px;top:98px;background:#f59e0b}.landing-guide-callout{display:grid;gap:.75rem;margin-bottom:1rem}.landing-guide-callout--compact{justify-items:start}.landing-steps{display:grid;gap:12px}.landing-steps div{border-radius:16px;background:#edf2f7;padding:.9rem 1rem;line-height:1.7}.landing-steps p{margin-top:.25rem}.landing-meta{color:#718096;font-size:.9rem}.landing-link{color:#f0fdfa;font-weight:700;text-decoration:none}.landing-link:hover{text-decoration:underline}.landing-guide-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.landing-guide-step-card{display:grid;gap:.85rem}.landing-guide-step-number{display:inline-flex;align-items:center;justify-content:center;width:fit-content;min-width:80px;padding:.35rem .7rem;border-radius:999px;background:var(--landing-accent-soft);color:var(--landing-accent);font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.landing-guide-link{display:inline-flex;width:fit-content;align-items:center;justify-content:center;min-height:46px;padding:.7rem 1rem;border-radius:16px;background:#0f766e1f;color:var(--landing-accent);font-weight:700;text-decoration:none;transition:background-color .18s ease,transform .18s ease}.landing-guide-link:hover{background:#0f766e2e;text-decoration:none;transform:translateY(-1px)}.landing-guide-list{display:grid;gap:10px;margin:0;padding-left:1.2rem;color:var(--landing-muted)}.landing-guide-list li{line-height:1.7}.landing-guide-note{border-radius:18px;background:#eef6ff;padding:1rem 1.1rem;color:#28536b}.landing-guide-note strong{display:block;margin-bottom:.4rem;color:var(--landing-ink)}.landing-role-button .role-image{max-width:140px;width:auto;margin-left:auto;margin-right:auto}.modal-role-image{max-width:160px;margin:.5rem auto 1rem;display:block}.landing-role-button{border:none;cursor:pointer;padding:.85rem;text-align:center;width:100%;transition:transform .15s ease,box-shadow .15s ease}.landing-role-button:hover{transform:translateY(-2px);box-shadow:0 12px 24px #0f172a1f}.landing-role-button:focus-visible{outline:3px solid #2c7a7b;outline-offset:2px}.landing-role-modal{position:relative;text-align:center}.modal-close-button{position:absolute;top:12px;right:12px;border:none;background:transparent;font-size:2.1rem;line-height:1;color:#4a5568;cursor:pointer;padding:4px}.modal-close-button:hover{color:#1a202c}.modal-close-button:focus-visible{outline:3px solid #2c7a7b;outline-offset:2px}@media(max-width:720px){.landing-page{padding-bottom:2.5rem}.landing-hero{padding-top:1rem}.landing-hero-surface{padding:1.4rem;border-radius:22px}.landing-brand,.landing-drawing-preview{grid-template-columns:1fr}.landing-brand-mark{width:70px;height:70px}.landing-hero h1{line-height:1.02}}.log-viewer-toggle{position:fixed;bottom:20px;right:20px;width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;font-size:20px;cursor:pointer;box-shadow:0 4px 12px #00000026;z-index:1000;transition:all .2s ease}.log-viewer-toggle:hover{transform:scale(1.1);box-shadow:0 6px 16px #0003}.log-viewer{position:fixed;bottom:20px;right:20px;width:600px;height:400px;background:#fff;border-radius:12px;box-shadow:0 10px 30px #0003;z-index:1001;display:flex;flex-direction:column;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:12px}.log-viewer-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:12px 16px;border-radius:12px 12px 0 0;display:flex;justify-content:space-between;align-items:center}.log-viewer-header h3{margin:0;font-size:14px;font-weight:600}.log-viewer-controls{display:flex;align-items:center;gap:8px}.log-filter{padding:4px 8px;border:none;border-radius:4px;font-size:11px;background:#fff3;color:#fff}.log-filter option{background:#fff;color:#333}.auto-scroll-label{display:flex;align-items:center;gap:4px;font-size:11px;color:#fff}.auto-scroll-label input{margin:0}.log-button{padding:4px 8px;border:none;border-radius:4px;font-size:11px;background:#fff3;color:#fff;cursor:pointer;transition:background .2s ease}.log-button:hover{background:#ffffff4d}.close-button{background:#ffffff1a;font-size:14px;padding:4px 6px}.close-button:hover{background:#fff3}.log-container{flex:1;overflow-y:auto;padding:8px;background:#1e1e1e;color:#d4d4d4;border-radius:0 0 12px 12px}.log-entry{display:flex;align-items:flex-start;gap:8px;padding:4px 0;border-bottom:1px solid #333;word-break:break-word}.log-entry:last-child{border-bottom:none}.log-timestamp{color:#888;font-size:10px;min-width:60px;flex-shrink:0}.log-level{padding:2px 6px;border-radius:3px;font-size:10px;font-weight:700;min-width:50px;text-align:center;flex-shrink:0}.log-level-debug{background:#4a5568;color:#fff}.log-level-info{background:#3182ce;color:#fff}.log-level-warn{background:#d69e2e;color:#fff}.log-level-error{background:#e53e3e;color:#fff}.log-message{flex:1;line-height:1.4}.log-data{margin-top:4px;width:100%}.log-data summary{cursor:pointer;color:#888;font-size:10px;margin-bottom:4px}.log-data pre{background:#2d3748;padding:8px;border-radius:4px;font-size:10px;overflow-x:auto;margin:0}.no-logs{text-align:center;color:#888;padding:20px;font-style:italic}@media(max-width:768px){.log-viewer{width:calc(100vw - 40px);height:300px;bottom:10px;right:10px}.log-viewer-controls{flex-wrap:wrap;gap:4px}.log-filter,.log-button{font-size:10px;padding:2px 6px}}
