:root{--bg:#f7faf9;--bg-elevated:#fff;--surface:#f1f5f9;--border:#d7e0e6;--text:#0f172a;--muted:#475569;--primary:#10b981;--primary-dark:#059669;--field-line:#0f172a14;--accent:#f97316;--accent-glow:#f9731638;--danger:#ef4444;--success:#16a34a;--font:system-ui, "Segoe UI", Roboto, "Helvetica Neue", sans-serif;--radius:12px;--max-card:min(100%, 440px);--touch-min:44px}@media (prefers-color-scheme:dark){:root{--bg:#060a10;--bg-elevated:#0f172a;--surface:#1e293b;--border:#334155;--text:#f8fafc;--muted:#94a3b8;--primary:#10b981;--primary-dark:#059669;--field-line:#f8fafc1f;--accent:#f97316;--accent-glow:#f9731659;--danger:#f87171;--success:#34d399}}*,:before,:after{box-sizing:border-box}html{-webkit-text-size-adjust:100%;font-size:16px}body{min-height:100svh;font-family:var(--font);color:var(--text);background:radial-gradient(120% 80% at 50% -20%, #10b9812e 0%, var(--bg) 48%);margin:0;line-height:1.45}#root{flex-direction:column;min-height:100svh;display:flex}.auth-shell{padding:1rem;padding-bottom:max(1rem, env(safe-area-inset-bottom));padding-top:max(1rem, env(safe-area-inset-top));flex:1;justify-content:center;align-items:center;display:flex}.auth-card{width:100%;max-width:var(--max-card);background:var(--bg-elevated);border:1px solid var(--border);border-radius:16px;padding:1.5rem 1.25rem}@media (width>=480px){.auth-card{padding:1.75rem 1.5rem}}.auth-badge{letter-spacing:.05em;text-transform:uppercase;color:var(--accent);margin:0 0 .5rem;font-size:.75rem;font-weight:600}.auth-badge-ok{color:var(--success)}.auth-title{margin:0 0 .5rem;font-size:clamp(1.5rem,5vw,1.75rem);font-weight:800;line-height:1.2}.auth-sub{color:var(--muted);margin:0 0 1.25rem;font-size:.95rem;line-height:1.5}.auth-strong{color:var(--text);font-weight:700}.auth-form{flex-direction:column;gap:0;display:flex}.auth-label{color:var(--muted);margin-bottom:.35rem;font-size:.8125rem;font-weight:600;display:block}.auth-input{width:100%;color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);outline:none;padding:.75rem .875rem;font-size:1.05rem}.auth-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #0d948840}.auth-input:disabled{opacity:.65}.auth-input-code{letter-spacing:.35em;text-align:center;font-size:1.5rem}.auth-error{color:var(--danger);margin:.625rem 0 0;font-size:.875rem}.auth-btn{border-radius:var(--radius);cursor:pointer;border:none;justify-content:center;align-items:center;width:100%;margin-top:1rem;padding:.85rem 1rem;font-family:inherit;font-size:1rem;font-weight:700;transition:opacity .15s;display:inline-flex}.auth-btn:disabled{opacity:.55;cursor:not-allowed}.auth-btn-primary{color:#fff;background:var(--primary);margin-top:1.25rem}.auth-btn-primary:hover:not(:disabled){background:var(--primary-dark)}.auth-btn-secondary{color:var(--accent);background:var(--surface);border:1px solid var(--border);margin-top:.75rem}.auth-btn-ghost{color:var(--text);border:1px solid var(--border);background:0 0;margin-top:1.5rem}.auth-btn-ghost:hover:not(:disabled){background:var(--surface)}.auth-link{text-align:center;color:var(--muted);margin-top:1rem;font-size:.9375rem;text-decoration:none;display:block}.auth-link:hover{color:var(--text);text-decoration:underline}.auth-muted{color:var(--muted);text-align:center}.landing-shell{width:100%;max-width:100%;padding:0 0 max(2.5rem, env(safe-area-inset-bottom));color:#111827;background:#f9fafb;margin:0 auto}.landing-hero{text-align:center;max-width:none;padding:max(5rem, calc(env(safe-area-inset-top) + 3rem)) 1.5rem 5rem;color:#fff;background:#16a34a;margin:0;position:relative;overflow:hidden}.landing-field-stripes{opacity:.2;pointer-events:none;background-image:linear-gradient(#0000 50%,#fff3 50%);background-size:100% 40px;position:absolute;inset:0}.landing-field-line{opacity:.3;pointer-events:none;background:#fff;width:2px;height:100%;position:absolute;top:0;left:50%;transform:translate(-50%)}.landing-title{margin:0 0 1.5rem;font-size:clamp(2.25rem,6vw,3.75rem);font-weight:800;line-height:1.12;position:relative}.landing-subtitle{color:#ffffffe6;max-width:42rem;margin:0 auto 2rem;font-size:clamp(1.05rem,2.5vw,1.25rem);line-height:1.55;position:relative}.landing-actions{gap:1rem;margin-top:0;display:grid;position:relative}.landing-cta{margin-top:0}.landing-link-btn{text-decoration:none}.landing-section{margin-top:0;border-radius:0;max-width:64rem;margin-inline:auto;padding:4rem 1.5rem}.landing-section h2{text-align:center;margin:0;margin-bottom:2.5rem;font-size:clamp(1.5rem,4vw,1.875rem);font-weight:600}.landing-section-problem,.landing-section-feed{background:#f9fafb}.landing-section-white{background:#fff}.landing-section-white h2{margin-bottom:3rem}.landing-section-solution{background:#f3f4f6}.landing-section-benefits{background:#f9fafb}.landing-grid{gap:1.5rem;margin-top:0;display:grid}.landing-grid-tight{margin-top:0}.landing-pill{color:#374151;background:#f3f4f6;border-radius:1rem;padding:1.5rem;font-size:1rem;line-height:1.5}.landing-pill-card{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem}.landing-how{gap:2.5rem;max-width:64rem;margin:0 auto;display:grid}.landing-how-block h3{color:#111827;margin:0 0 1rem;font-size:1.25rem;font-weight:700}.landing-how-card{background:#fff;border:1px solid #e5e7eb;border-radius:1rem;padding:1.5rem}.landing-how-list{color:#4b5563;margin:0;padding-left:0;list-style:none}.landing-how-list li+li{margin-top:.75rem}.landing-feed-card{background:#fff;border:1px solid #e5e7eb;border-radius:1rem;flex-direction:column;gap:.7rem;padding:1.25rem;display:flex}.landing-feed-row{justify-content:space-between;align-items:center;gap:.6rem;display:flex}.landing-feed-local{font-weight:600}.landing-feed-time{color:#6b7280;font-size:.85rem}.landing-feed-slots{color:#4b5563;font-size:.9rem}.landing-feed-detail-btn{color:#16a34a;cursor:pointer;background:0 0;border:0;font-size:.88rem;font-weight:600}.landing-grid-2,.landing-grid-3{grid-template-columns:1fr}.landing-cta-final{text-align:center;color:#fff;background:#15803d;border-radius:0;margin-top:0;padding:5rem 1.5rem;position:relative;overflow:hidden}.landing-cta-final h2{margin:0 0 1.5rem;font-size:clamp(1.75rem,4.8vw,2.25rem);position:relative}.landing-cta-final p{color:#d1d5db;max-width:36rem;margin:0 auto 2rem;font-size:1.125rem;position:relative}.landing-cta-white{color:#0b1220;background:#fff}.landing-cta-white:hover:not(:disabled){background:#e2e8f0}.landing-btn{color:#15803d;background:#fff;margin-top:0}.landing-btn:hover:not(:disabled){background:#f3f4f6}.landing-btn-outline{color:#fff;background:0 0;border:1px solid #ffffffd9;margin-top:0}.landing-cta-outline-light{color:#fff;background:0 0;border:1px solid #9ca3af;margin-top:0}.landing-cta-outline-light:hover:not(:disabled){background:#ffffff14}@media (width>=680px){.landing-actions{grid-template-columns:repeat(2,minmax(0,260px));justify-content:center}.landing-grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.landing-grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.landing-how{grid-template-columns:repeat(2,minmax(0,1fr));gap:2.5rem}}.app-layout{background:var(--bg);flex-direction:column;min-height:100svh;display:flex}.app-loading{color:var(--muted);flex:1;justify-content:center;align-items:center;padding:1.5rem;display:flex}.app-header{z-index:10;padding:max(.75rem, env(safe-area-inset-top)) 1rem .75rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);background:#f7faf9eb;position:sticky;top:0}@media (prefers-color-scheme:dark){.app-header{background:#060a10eb}}.app-header-inner{justify-content:space-between;align-items:center;gap:1rem;max-width:800px;margin:0 auto;display:flex}.app-logo{letter-spacing:-.02em;background:linear-gradient(135deg, var(--primary) 0%, #5eead4 100%);color:#0000;-webkit-background-clip:text;background-clip:text;font-size:clamp(1.05rem,4vw,1.2rem);font-weight:800}.app-btn-logout{min-height:var(--touch-min);color:var(--muted);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;padding:0 1rem;font-family:inherit;font-size:.9rem;font-weight:600}.app-btn-logout:active{transform:scale(.98)}.app-main{width:100%;max-width:800px;padding:1.25rem 1.15rem max(2rem, env(safe-area-inset-bottom));flex:1;margin:0 auto}.app-hero{text-align:center;padding:1.5rem 0 1rem}.app-kicker{letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin:0 0 .35rem;font-size:.72rem;font-weight:700}.app-headline{margin:0 0 .5rem;font-size:clamp(1.65rem,6vw,2rem);font-weight:800;line-height:1.15}.app-lead{color:var(--muted);margin:0;max-width:28rem;margin-inline:auto;font-size:.95rem;line-height:1.55}.app-lead strong{color:var(--text)}.app-placeholder-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:.5rem;margin-top:1.75rem;display:grid}@media (width<=520px){.app-placeholder-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width>=480px){.app-placeholder-grid{gap:1rem}}.app-placeholder-card{background:var(--bg-elevated);border:1px solid var(--border);text-align:center;border-radius:16px;min-height:120px;padding:0;box-shadow:0 4px 24px #0003}.menu-card-btn{width:100%;min-height:120px;color:inherit;font:inherit;cursor:pointer;background:0 0;border:0;border-radius:16px;padding:1.1rem}.menu-card-btn:active{transform:scale(.99)}.app-placeholder-card h2{margin:.35rem 0 .15rem;font-size:1rem;font-weight:700}.app-placeholder-card p{color:var(--muted);margin:0;font-size:.8rem}.app-placeholder-icon{filter:grayscale(.2);font-size:1.75rem;line-height:1}@media (width<=479px){.app-placeholder-grid{gap:.35rem;margin-top:1.25rem}.app-placeholder-card{border-radius:12px;min-height:0;box-shadow:0 2px 12px #0000002e}.menu-card-btn{min-height:var(--touch-min);flex-direction:column;justify-content:center;align-items:center;gap:.2rem;padding:.5rem .25rem;display:flex}.app-placeholder-card h2{margin:0;font-size:.72rem;font-weight:700;line-height:1.15}.app-placeholder-card p{display:none}.app-placeholder-icon{font-size:1.35rem}}.auth-btn-primary,.auth-btn-secondary{min-height:var(--touch-min)}.profile-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:16px;margin-top:1rem;padding:1rem}.profile-form{gap:.5rem;display:grid}.profile-section-title{margin:0 0 .75rem;font-size:1rem;font-weight:700}.profile-ok{color:var(--success);margin:.4rem 0 0;font-size:.9rem}.places-list{gap:.65rem;margin:.75rem 0 1rem;display:grid}.place-item{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:.75rem}.place-item h3{margin:0;font-size:.98rem}.place-item p{color:var(--muted);margin:.3rem 0 0;font-size:.86rem}.place-item--clickable{cursor:pointer;transition:background .15s,border-color .15s}.place-item--clickable:hover{background:#10b9810f;border-color:#10b98159}.place-item--clickable:active{background:#10b9811a}.place-item-hint{font-weight:600;color:var(--accent)!important;margin-top:.5rem!important;font-size:.8rem!important}.app-btn-back{min-height:var(--touch-min);color:var(--muted);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;padding:0 .75rem;font-family:inherit;font-size:.85rem;font-weight:600}.app-btn-home{min-height:var(--touch-min);color:var(--text);border-radius:var(--radius);cursor:pointer;white-space:nowrap;background:#10b9811a;border:1px solid #10b98159;padding:0 .85rem;font-family:inherit;font-size:.85rem;font-weight:700}.games-filter-form{gap:.5rem;margin-bottom:1rem;display:grid}.games-filter-toggle-wrap{justify-content:flex-end;margin:.75rem 0 .85rem;display:flex}.games-filter-toggle-btn{min-height:var(--touch-min);color:var(--muted);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;padding:0 .85rem;font-family:inherit;font-size:.9rem;font-weight:600}.games-btn-create{margin-top:1rem}.games-table-wrap{-webkit-overflow-scrolling:touch;margin:.75rem 0 1rem;overflow-x:auto}.games-table{border-collapse:collapse;width:100%;min-width:640px;font-size:.9rem}.games-table th,.games-table td{text-align:left;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle;padding:.7rem .65rem}.games-table tbody tr{min-height:var(--touch-min)}.games-table th{color:var(--muted);font-size:.82rem;font-weight:600}.games-table-cell-date{white-space:nowrap;font-variant-numeric:tabular-nums}.games-table-row-click{cursor:pointer}.games-table-row-click:hover{background:#10b98114}.games-table-row-click:active{background:#10b98124}.auth-textarea{resize:vertical;min-height:4.5rem}.game-detail-card{margin-bottom:1rem}.game-detail-title{margin:0 0 .35rem;font-size:1.15rem}.game-detail-meta{color:var(--muted);margin:.25rem 0;font-size:.9rem}.game-detail-datetime{color:var(--text);font-variant-numeric:tabular-nums;font-size:1.05rem;font-weight:600}.game-detail-notes{color:var(--text);white-space:pre-wrap;margin:.5rem 0;font-size:.9rem}.game-slots-banner{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-wrap:wrap;gap:1rem;margin:1rem 0;padding:.75rem;font-size:.92rem;display:flex}.game-join-actions{flex-direction:column;gap:.75rem;display:flex}.game-share-row{flex-direction:column;gap:.35rem;margin:.75rem 0 .25rem;display:flex}.game-share-hint{margin:0;font-size:.8rem}.game-join-blocked{border-radius:var(--radius);background:#f8717114;border:1px solid #f8717159;padding:.65rem .75rem;font-size:.88rem}.game-join-blocked-title{color:var(--danger);margin:0 0 .35rem;font-weight:600}.game-join-blocked ul{color:var(--muted);margin:0;padding-left:1.1rem}.game-participants-section .game-participants-wrap{margin:.5rem 0 0;overflow:visible}.game-participants-section .game-participants-table{table-layout:fixed;width:100%;min-width:0}.game-participants-section .game-participants-table th:first-child,.game-participants-section .game-participants-table td:first-child{word-break:break-word;width:auto;padding-right:.85rem}.game-participants-section .game-participants-table th:last-child,.game-participants-section .game-participants-table td:last-child{white-space:nowrap;text-align:right;vertical-align:middle;width:6.5rem}@media (width<=640px){.games-table-wrap--mobile-stacked{overflow:visible hidden}.games-table--mobile-stacked{table-layout:fixed;border-collapse:separate;border-spacing:0;width:100%;min-width:0}.games-table--mobile-stacked thead{display:none}.games-table--mobile-stacked tbody tr{background:var(--surface);border:1px solid var(--border);border-radius:10px;margin-bottom:.65rem;padding:.55rem .6rem;display:block}.games-table--mobile-stacked tbody td{white-space:normal;border-bottom:0;grid-template-columns:6.2rem minmax(0,1fr);align-items:center;gap:.45rem;padding:.28rem 0;display:grid}.games-table--mobile-stacked tbody td:before{content:attr(data-label);color:var(--muted);font-size:.78rem;font-weight:600}.games-table--mobile-stacked .games-table-cell-date{white-space:normal}.game-participants-section .game-participants-table tbody tr{min-height:var(--touch-min)}.game-participants-section .game-participants-table th,.game-participants-section .game-participants-table td{padding-top:.65rem;padding-bottom:.65rem}.games-table-wrap--confirmed-home{overflow:visible hidden}.games-table--confirmed-home{table-layout:fixed;width:100%;min-width:0;font-size:.88rem}.games-table--confirmed-home th,.games-table--confirmed-home td{overflow-wrap:anywhere;word-break:break-word;padding:.65rem .45rem}.games-table-wrap--place-public{overflow:visible hidden}.games-table--place-public{table-layout:fixed;width:100%;min-width:0;font-size:.88rem}.games-table--place-public th,.games-table--place-public td{overflow-wrap:anywhere;word-break:break-word;padding:.65rem .45rem}}
