:root{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--bg:#091015;--bg-alt:#0d171f;--bg-panel:#12202a;--surface:#0f1c23f5;--surface-strong:#17303d;--surface-muted:#0f1b23;--surface-dark:#081015;--border:#6fb4c824;--border-strong:#86cddf3d;--text:#eef5f5;--muted:#a6b7bf;--primary:#49a6bb;--primary-strong:#7cd0b1;--accent:#214f68;--danger:#d97b74;--shadow:0 18px 42px #00000057;--radius-lg:18px;--radius-md:14px;--radius-sm:10px;--font-sans:"Bahnschrift", "Segoe UI", "Helvetica Neue", Arial, sans-serif}*{box-sizing:border-box}html{background:radial-gradient(circle at top left, #49a6bb24, transparent 28%), radial-gradient(circle at top right, #7cd0b11a, transparent 24%), linear-gradient(180deg, #0b1318 0%, var(--bg) 42%, #060c10 100%);min-height:100%}body{min-height:100vh;color:var(--text);font-family:var(--font-sans);background:0 0;margin:0}.site-shell{flex-direction:column;min-height:100vh;display:flex}.site-header{z-index:40;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:linear-gradient(#060e13db 0%,#081116db 100%),radial-gradient(circle at top,#49a6bb1f,#0000 48%);border-bottom:1px solid #6fb4c81f;position:sticky;top:0}.site-header-inner{justify-content:space-between;align-items:center;gap:16px;width:min(100%,1180px);margin:0 auto;padding:14px;display:flex}.site-header-stacked{flex-direction:column;justify-content:center;gap:12px}.site-header-brand{letter-spacing:.02em;font-weight:900}.site-header-brand-centered{text-align:center;font-size:1.15rem}.site-header-nav{color:var(--muted);flex-wrap:wrap;gap:14px;display:flex}.site-header-nav-centered{justify-content:center}.site-header-link{min-height:38px;color:var(--muted);border:1px solid #0000;border-radius:999px;justify-content:center;align-items:center;padding:0 14px;font-size:.94rem;font-weight:700;transition:color .14s,border-color .14s,background-color .14s;display:inline-flex}.site-header-link:hover{color:var(--text);background:#49a6bb14;border-color:#7cd0b124}.site-header-link-active{color:var(--text);background:linear-gradient(#1f4454f5 0%,#132832f5 100%);border-color:#7cd0b138}.site-content{flex:1}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:wait;opacity:.7}img{max-width:100%;display:block}.page-shell{width:min(100%,1180px);margin:0 auto;padding:16px 14px 56px}.marketing-shell{gap:18px;width:min(100%,1180px);margin:0 auto;padding:20px 14px 72px;display:grid}.marketing-hero,.marketing-card,.marketing-panel{box-shadow:var(--shadow);background:linear-gradient(#0c1e27fa 0%,#091218fa 100%);border:1px solid #6fb4c829;border-radius:22px;padding:24px}.marketing-hero h1{letter-spacing:-.05em;max-width:14ch;margin:0;font-size:clamp(2.4rem,8vw,5rem);line-height:.95}.marketing-hero{background:linear-gradient(#08141ac7 0%,#081218eb 100%),radial-gradient(circle at 0 0,#7cd0b129,#0000 26%);position:relative;overflow:hidden}.marketing-hero:after{content:"";pointer-events:none;background:linear-gradient(110deg,#081116d6 0%,#08111661 50%,#081116c7 100%);position:absolute;inset:0}.marketing-hero-spots,.marketing-hero-foiler,.marketing-hero-chat,.marketing-hero-game{background:linear-gradient(#0711168a 0%,#071116e0 100%),linear-gradient(110deg,#081116cc 0%,#0811164d 45%,#081116d9 100%),url(/landing-hero-lake.png) 50%/cover no-repeat}.marketing-hero-foiler{background:linear-gradient(#07111670 0%,#071116e0 100%),linear-gradient(115deg,#0a1920bd 0%,#09364a2e 44%,#081116d6 100%),url(/app-lake-atmosphere.png) 50%/cover no-repeat}.marketing-hero-chat{background:linear-gradient(#07111675 0%,#071116e6 100%),linear-gradient(115deg,#1236436b 0%,#2d889d1f 45%,#081116d1 100%),url(/app-lake-atmosphere.png) 50%/cover no-repeat}.marketing-hero-game{background:linear-gradient(#0711166b 0%,#071116e6 100%),linear-gradient(115deg,#7cd0b129 0%,#49a6bb14 38%,#081116d1 100%),url(/landing-hero-lake.png) 50%/cover no-repeat}.marketing-hero-grid{z-index:1;gap:18px;display:grid;position:relative}.marketing-hero-copy{gap:16px;display:grid}.marketing-hero-copy .marketing-copy{margin:0}.marketing-hero-visual{border:1px solid #7cd0b124;border-radius:20px;min-height:260px;overflow:hidden;box-shadow:0 20px 40px #00000047}.marketing-hero-image{object-fit:cover;object-position:center center;width:100%;height:100%;min-height:260px}.marketing-copy{max-width:44rem;color:var(--muted);font-size:1.05rem;line-height:1.65}.marketing-actions{flex-wrap:wrap;gap:12px;display:flex}.marketing-button{justify-content:center;align-items:center;min-width:190px;text-decoration:none;display:inline-flex}.marketing-grid,.marketing-showcase{gap:16px;display:grid}.seo-article-shell h2{margin:0}.seo-list-panel,.seo-links-panel,.seo-teaser-panel{gap:14px;display:grid}.seo-bullet-list{color:var(--muted);gap:8px;margin:0;padding-left:20px;line-height:1.55;display:grid}.seo-link-list{flex-wrap:wrap;gap:10px;display:flex}.seo-local-intro{color:var(--text)}.seo-faq-list{gap:12px;display:grid}.seo-faq-card{border-radius:var(--radius-md);background:#071116b8;border:1px solid #6fb4c814;gap:8px;padding:16px;display:grid}.seo-faq-card h3,.seo-faq-card p,.seo-city-grid h3{margin:0}.seo-link-button{min-width:200px;text-decoration:none}.app-entry-panel{background:linear-gradient(#122b37fa 0%,#0a161cfa 100%);border-color:#7cd0b12e;gap:14px;display:grid}.app-entry-actions{flex-wrap:wrap;gap:10px;display:flex}.app-entry-url-block{border-radius:var(--radius-md);background:#071116b8;border:1px solid #6fb4c814;gap:6px;padding:14px;display:grid}.app-entry-qr{align-items:center;gap:14px;display:grid}.app-entry-qr-image-wrap{background:#f4fbfb;border-radius:20px;width:100%;max-width:220px;padding:12px;box-shadow:inset 0 0 0 1px #08101514}.app-entry-qr-image{border-radius:10px;width:100%;height:auto}.app-entry-qr-copy{gap:8px;display:grid}.app-entry-qr-copy p{margin:0}.install-banner,.notice-banner{border-radius:var(--radius-lg);box-shadow:var(--shadow);background:linear-gradient(#152e3afa 0%,#0b181ffa 100%);border:1px solid #7cd0b133;gap:14px;margin-bottom:16px;padding:18px;display:grid}.install-banner-actions{flex-wrap:wrap;gap:10px;display:flex}.toast-stack{z-index:30;gap:10px;margin-bottom:16px;display:grid;position:sticky;top:14px}.toast-card{border-radius:var(--radius-md);box-shadow:var(--shadow);background:#0a151bf5;border:1px solid #7cd0b12e;gap:6px;padding:14px 16px;display:grid}.toast-card p{color:var(--muted);margin:0}.technique-list,.analysis-preview{gap:14px;display:grid}.technique-item,.analysis-preview-card{background:#0711169e;border:1px solid #6fb4c81a;border-radius:16px;gap:8px;padding:16px;display:grid}.technique-item h2,.analysis-preview-card strong{margin:0}.preview-list{color:var(--muted);gap:6px;margin:0;padding-left:18px;display:grid}.top-bar,.hero-card,.panel,.profile-bar,.day-card,.spot-card,.section-block,.spot-switch-card,.person-card,.chat-message{background:linear-gradient(180deg, var(--surface) 0%, var(--surface-muted) 100%);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:var(--radius-lg);padding:18px}.top-bar{background:linear-gradient(#06101573 0%,#09151ce0 100%),url(/app-lake-atmosphere.png) 50%/cover no-repeat,linear-gradient(#142e3afa 0%,#0c171efa 100%);border-color:#7cd0b12e;margin-bottom:16px;position:relative;overflow:hidden}.top-bar:after{content:"";pointer-events:none;background:linear-gradient(135deg,#08111629 0%,#0811168f 60%,#081116d1 100%);position:absolute;inset:0}.top-bar>*{z-index:1;position:relative}.top-bar h1,.hero-card h1{letter-spacing:-.04em;margin:0;font-size:clamp(2rem,7vw,3.8rem);font-weight:800;line-height:.96}.eyebrow{text-transform:uppercase;letter-spacing:.14em;color:var(--primary);margin:0 0 10px;font-size:.72rem;font-weight:800}.muted-copy,.hero-copy,.panel-header p,.field span,.empty-state,.chat-message-head span,.person-plan-row small{color:var(--muted)}.auth-shell,.auth-grid,.days-grid,.planner-form,.profile-actions,.inline-form,.attendance-section,.panel,.spot-card,.spot-image-form,.section-block,.spot-grid,.people-grid,.archive-grid,.chat-list,.chat-form,.spot-create-form{gap:14px;display:grid}.hero-card{background:linear-gradient(#142c39fa 0%,#0c1820fa 100%);border-color:#6fb4c838;position:relative;overflow:hidden}.hero-card:after{content:"";background:radial-gradient(circle,#49a6bb2e 0%,#0000 68%);border-radius:999px;width:180px;height:180px;position:absolute;bottom:-82px;right:-52px}.hero-copy{max-width:34rem;font-size:1rem;line-height:1.55}.hero-points{margin:16px 0 0;padding-left:18px}.panel-header h2,.section-headline h4,.profile-bar h2,.day-card h3,.section-title h2,.spot-overlay h2,.spot-switch-card h3,.person-card h3{margin:0}.panel-header p,.section-title p{margin:4px 0 0}.field{gap:8px;display:grid}.field span{font-size:.88rem;font-weight:700}.field-hint{color:var(--muted);margin:-2px 0 0;font-size:.84rem;line-height:1.45}.field input,.inline-form input,.field-select,.field-textarea{border-radius:var(--radius-sm);border:1px solid var(--border-strong);width:100%;min-height:52px;color:var(--text);background:#071116;padding:12px 14px}.field input::placeholder,.inline-form input::placeholder,.field-textarea::placeholder{color:#7d98a3}.field-textarea{resize:vertical;min-height:132px}.checkbox-row{color:var(--text);align-items:flex-start;gap:12px;display:flex}.checkbox-row input{margin-top:3px}.primary-button,.secondary-button,.ghost-button{letter-spacing:.01em;border-radius:12px;min-height:52px;padding:0 18px;font-weight:800}.submit-button-content{justify-content:center;align-items:center;gap:10px;display:inline-flex}.submit-spinner{border:2px solid #ffffff38;border-top-color:#fffffff5;border-radius:999px;width:16px;height:16px;animation:.8s linear infinite submit-spin}@keyframes submit-spin{to{transform:rotate(360deg)}}.primary-button{color:#f5f7f6;background:linear-gradient(#2d889d 0%,#246b78 100%);border:1px solid #7cd0b13d}.secondary-button{color:var(--text);background:#17303d;border:1px solid #6fb4c82e}.ghost-button{border:1px solid var(--border-strong);color:var(--text);background:0 0}.danger-button{color:var(--danger)}.flash-stack,.flash{margin-top:12px}.flash{border-radius:var(--radius-md);border:1px solid #0000;padding:12px 14px}.flash-error{color:#f2c1b8;background:#913e322e;border-color:#d97b7440}.flash-success{color:#dff8f0;background:#49a6bb24;border-color:#7cd0b13d}.error-state-card,.loading-state-card{align-content:center;min-height:260px}.spot-card,.profile-bar{margin-bottom:16px}.profile-summary{align-items:center;gap:14px;display:flex}.profile-avatar{object-fit:cover;background:#0b151b;border:1px solid #7cd0b138;border-radius:999px;flex:0 0 52px;width:52px;height:52px}.profile-avatar-empty{color:var(--text);justify-content:center;align-items:center;font-size:1rem;font-weight:800;display:flex}.profile-identity{min-width:0}.profile-identity .eyebrow{margin-bottom:6px}.profile-identity h2{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.spot-hero{aspect-ratio:1;background:linear-gradient(#163241 0%,#0a1319 100%);border:1px solid #6fb4c829;border-radius:14px;position:relative;overflow:hidden}.spot-image{object-fit:cover;filter:saturate(.92)contrast(1.05);width:100%;height:100%}.spot-image-empty{color:#ffffffdb;background:linear-gradient(135deg,#0e222df5,#081116f5),linear-gradient(#ffffff0a,#0000);justify-content:center;align-items:center;font-weight:700;display:flex}.spot-header-main,.spot-summary{gap:14px;display:grid}.spot-meta{flex-wrap:wrap;gap:8px;display:flex}.spot-meta span,.count-badge{background:#49a6bb1a;border:1px solid #7cd0b11f;border-radius:999px;justify-content:center;align-items:center;min-height:30px;padding:0 10px;font-size:.84rem;font-weight:700;display:inline-flex}.count-badge{color:var(--text)}.profile-bar{gap:16px}.section-title,.day-header,.section-headline,.chat-message-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.section-title{align-items:end}.spot-grid,.people-grid{grid-template-columns:1fr}.spot-switch-card{gap:10px;transition:border-color .2s,transform .2s;display:grid}.spot-switch-main-link{gap:10px;display:grid}.spot-switch-card:hover{border-color:#7cd0b13d;transform:translateY(-1px)}.spot-switch-card-active{background:linear-gradient(#163241fa,#0c171efa);border-color:#7cd0b157}.spot-switch-weather{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.spot-switch-links{flex-wrap:wrap;align-items:flex-start;gap:10px;display:flex}.spot-switch-link-button{min-height:42px}.spot-switch-head,.person-card-head,.chat-author,.spot-inline-label{align-items:center;gap:10px;display:flex}.spot-switch-thumb,.spot-inline-thumb{object-fit:cover;background:#0b151b;border:1px solid #7cd0b12e;border-radius:10px;flex:0 0 36px;width:36px;height:36px}.spot-switch-thumb-empty,.spot-inline-thumb-empty{color:var(--muted);justify-content:center;align-items:center;font-size:.78rem;font-weight:800;display:inline-flex}.spot-switch-weather strong,.spot-switch-weather small{margin:0}.days-grid{gap:16px}.day-card{background:linear-gradient(#0e1c23f0 0%,#091218f5 100%),radial-gradient(circle at 100% 0,#49a6bb1f,#0000 34%);gap:16px;position:relative;overflow:hidden}.day-card:before{content:"";pointer-events:none;background:linear-gradient(#ffffff05,#0000 38%),radial-gradient(circle at 0 100%,#7cd0b114,#0000 32%);position:absolute;inset:0}.day-card>*{z-index:1;position:relative}.weather-chip{text-align:right;background:#49a6bb1a;border:1px solid #49a6bb29;border-radius:12px;gap:2px;padding:10px 12px;display:grid}.weather-chip-title,.stat-value-with-symbol,.spot-weather-label{align-items:center;gap:6px;display:inline-flex}.weather-symbol{justify-content:center;align-items:center;min-width:1.1em;font-size:1.05rem;line-height:1;display:inline-flex}.avatar-badge{object-fit:cover;background:#0b151b;border:1px solid #7cd0b12e;border-radius:999px;flex:none;justify-content:center;align-items:center;display:inline-flex;overflow:hidden}.avatar-badge-sm{width:28px;height:28px}.avatar-badge-md{width:40px;height:40px}.avatar-badge-empty{color:var(--text);font-size:.82rem;font-weight:800}.weather-chip-muted{background:#ffffff0a;border-color:#ffffff14}.weather-grid{gap:10px;display:grid}.weather-grid-tight{grid-template-columns:repeat(3,minmax(0,1fr))}.stat-card{border-radius:var(--radius-md);background:linear-gradient(#09141af0,#071116eb);border:1px solid #6fb4c814;gap:4px;padding:12px;display:grid}.stat-card span,.stat-card small{color:var(--muted)}.attendee-list,.person-plan-list{gap:8px;margin:0;padding:0;list-style:none;display:grid}.attendee-row,.person-plan-row{border-radius:var(--radius-md);background:#071116db;border:1px solid #6fb4c80f;align-items:center;gap:12px;padding:12px 14px;display:flex}.attendee-row-own{background:#14313fe6;border-color:#7cd0b13d}.attendee-row strong,.person-plan-row strong{min-width:54px}.attendee-meta{gap:3px;min-width:0;display:grid}.attendee-meta span,.attendee-meta small{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.attendee-meta small{color:var(--muted)}.person-plan-row span{flex:1}.person-card-head{margin-bottom:8px}.report-summary-card,.archive-card{border-radius:var(--radius-md);background:#071116db;border:1px solid #6fb4c814;gap:12px;padding:14px;display:grid}.report-summary-grid,.stats-grid{gap:10px;display:grid}.analysis-history{gap:16px;display:grid}.analysis-history-card,.analysis-summary-card,.analysis-text-card,.analysis-points-card{gap:10px;display:grid}.analysis-history-card{border-radius:var(--radius-lg);box-shadow:var(--shadow);background:linear-gradient(#0d1b23fa,#091218fa);border:1px solid #6fb4c81f;padding:18px}.analysis-history-head,.analysis-columns{gap:14px;display:grid}.analysis-link-button{min-height:44px}.diagram-grid{gap:12px;display:grid}.metric-list,.phase-list{gap:10px;display:grid}.metric-row,.phase-card{gap:8px;display:grid}.metric-row-head{justify-content:space-between;align-items:center;gap:10px;display:flex}.metric-track{background:#ffffff14;border-radius:999px;height:8px;overflow:hidden}.metric-fill{border-radius:inherit;background:linear-gradient(90deg,#3b8ca3 0%,#7cd0b1 100%);height:100%}.phase-card{background:#071116b8;border:1px solid #6fb4c814;border-radius:14px;padding:12px}.phase-card p,.phase-card small{margin:0}.phase-card small{color:var(--muted)}.diagram-card{border-radius:var(--radius-md);background:#071116b8;border:1px solid #6fb4c814;gap:10px;padding:14px;display:grid}.diagram-card p{color:var(--muted);margin:0}.diagram-preview{--diagram-accent:#7ce0d8;background:linear-gradient(#142834e6,#081217f5);border-radius:14px;height:140px;position:relative;overflow:hidden}.diagram-board,.diagram-mast,.diagram-body,.diagram-arm-left,.diagram-arm-right{background:var(--diagram-accent);position:absolute}.diagram-board{border-radius:999px;width:92px;height:10px;bottom:26px;left:50%;transform:translate(-50%)rotate(-8deg)}.diagram-mast{border-radius:999px;width:10px;height:56px;bottom:34px;left:50%;transform:translate(-50%)}.diagram-body{border-radius:999px;width:20px;height:42px;bottom:78px;left:50%;transform:translate(-50%)}.diagram-arm-left,.diagram-arm-right{border-radius:999px;width:42px;height:8px;bottom:102px}.diagram-arm-left{transform-origin:100%;left:calc(50% - 34px);transform:rotate(-25deg)}.diagram-arm-right{transform-origin:0;left:50%;transform:rotate(18deg)}.archive-row{border-top:1px solid #6fb4c814;gap:10px;padding:12px 0;display:grid}.archive-row:first-child{border-top:0;padding-top:0}.archive-row-head{align-items:center;gap:10px;display:flex}.archive-metrics{flex-wrap:wrap;gap:8px;display:flex}.archive-metrics span{background:#49a6bb1a;border:1px solid #7cd0b11f;border-radius:999px;align-items:center;min-height:28px;padding:0 10px;font-size:.84rem;font-weight:700;display:inline-flex}.comparison-grid,.comparison-list,.comparison-card,.comparison-row,.trend-legend{gap:12px;display:grid}.comparison-card{border-radius:var(--radius-md);background:#071116b8;border:1px solid #6fb4c814;padding:16px}.comparison-row-head,.comparison-rider{align-items:center;gap:10px;display:flex}.comparison-row-head{justify-content:space-between}.comparison-row-head span{color:var(--text);white-space:nowrap;font-weight:800}.comparison-track{background:#ffffff14;border-radius:999px;height:8px;overflow:hidden}.comparison-fill{border-radius:inherit;background:linear-gradient(90deg,#3b8ca3 0%,#7cd0b1 100%);height:100%;display:block}.trend-chart-shell{width:100%;padding-bottom:4px;overflow-x:auto}.trend-chart{width:100%;min-width:720px;height:auto;display:block}.trend-grid-line{stroke:#ffffff1a;stroke-width:1px}.trend-grid-line-vertical{stroke-dasharray:4 6}.trend-axis-label{fill:var(--muted);font-size:12px;font-family:var(--font-sans)}.trend-legend{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.trend-legend-item{background:#49a6bb1a;border:1px solid #7cd0b11f;border-radius:999px;align-items:center;gap:10px;min-height:42px;padding:0 12px;display:flex}.trend-legend-item span:last-child{color:var(--muted);margin-left:auto;font-weight:700}.trend-legend-dot{border-radius:999px;flex:none;width:10px;height:10px}.person-plan-row small{align-items:center;gap:8px;display:inline-flex}.chat-list{max-height:420px;overflow:auto}.chat-page-toolbar,.chat-online-list{gap:12px;display:grid}.chat-spot-tabs{flex-wrap:wrap;gap:10px;display:flex}.chat-spot-tab{min-height:40px;color:var(--muted);background:#49a6bb14;border:1px solid #7cd0b11a;border-radius:999px;justify-content:center;align-items:center;padding:0 14px;font-weight:700;display:inline-flex}.chat-spot-tab-active{color:var(--text);background:linear-gradient(#1f4454f5 0%,#132832f5 100%);border-color:#7cd0b13d}.chat-online-box{border-radius:var(--radius-md);background:#071116b8;border:1px solid #6fb4c814;gap:10px;padding:14px;display:grid}.chat-online-user{background:#49a6bb1a;border:1px solid #7cd0b11f;border-radius:999px;align-items:center;gap:10px;min-height:36px;padding:0 10px;font-weight:700;display:inline-flex}.chat-message{padding:14px}.chat-message p{margin:10px 0 0;line-height:1.45}.foil-game-shell{overflow:hidden}.foil-game-layout{gap:16px;display:grid}.foil-game-panel,.foil-game-info-card,.foil-game-score-form{gap:14px;display:grid}.foil-game-scene{touch-action:manipulation;background:linear-gradient(#cae7ec1f 0%,#6cb0c114 24%,#0000 24%),linear-gradient(#17546cf5 0%,#0f3a4df5 38%,#0a2634fa 100%);border:1px solid #7cd0b12e;border-radius:18px;min-height:420px;position:relative;overflow:hidden}.foil-game-close-button{z-index:3;width:42px;height:42px;color:var(--text);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#081218b8;border:1px solid #7cd0b12e;border-radius:999px;font-size:1.5rem;line-height:1;position:absolute;top:12px;right:12px}.foil-game-sky{background:radial-gradient(circle at 18% 24%,#ffe8a447,#0000 24%),linear-gradient(#b1e0e829 0%,#49a6bb0f 100%);position:absolute;inset:0 0 76%}.foil-game-water{background:repeating-linear-gradient(#ffffff08 0 6px,#0000 6px 14px),linear-gradient(#3f8fad3d 0%,#0b2c3c1a 100%);position:absolute;inset:18% 0 0}.foil-game-overlay{z-index:2;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0812188f;border:1px solid #7cd0b11f;border-radius:16px;gap:6px;padding:10px 12px;display:grid;position:absolute}.foil-game-overlay-left{justify-items:center;top:14px;left:14px}.foil-game-overlay-right{justify-items:end;top:14px;right:14px}.foil-game-overlay-right strong{font-size:1.1rem}.foil-game-overlay-right small,.foil-game-overlay-left small{color:var(--muted)}.foil-game-touch-controls{z-index:2;grid-template-columns:64px 90px 64px;gap:10px;display:grid;position:absolute;bottom:16px;left:50%;transform:translate(-50%)}.foil-game-touch-button{min-height:58px;color:var(--text);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#081218b8;border:1px solid #7cd0b12e;border-radius:18px;font-size:1.35rem;font-weight:800}.foil-game-touch-button-primary{background:#2d889dd1;font-size:1rem}.foil-height-meter{justify-items:center;gap:6px;display:grid}.foil-height-meter-track{background:#ffffff14;border:1px solid #7cd0b12e;border-radius:999px;align-items:end;width:16px;height:110px;display:flex;position:relative;overflow:hidden}.foil-height-meter-track span{border-radius:inherit;background:linear-gradient(#7cd0b1 0%,#55afd0 100%);width:100%;display:block}.foil-game-track-lines span{border-left:1px dashed #ffffff1f;width:1px;position:absolute;top:0;bottom:0}.foil-rider,.foil-obstacle{position:absolute;transform:translate(-50%)}.foil-rider{transform-origin:bottom;justify-items:center;gap:1px;transition:left .12s,bottom .12s;display:grid;transform:translate(-50%)scale(.82)}.foil-rider-splash{background:radial-gradient(circle,#e6faff61 0%,#0000 70%);border-radius:999px;width:48px;height:12px}.foil-rider-body{filter:drop-shadow(0 8px 14px #00000047);z-index:2;width:22px;height:40px;margin-bottom:-2px;position:relative}.foil-rider-head,.foil-rider-torso,.foil-rider-arm,.foil-rider-leg{background:#10151a;display:block;position:absolute}.foil-rider-head{background:linear-gradient(#d3b493 0%,#a17b60 100%);border-radius:999px;width:8px;height:8px;top:1px;left:50%;transform:translate(-50%);box-shadow:0 0 0 2px #232d35}.foil-rider-torso{background:linear-gradient(#232d35 0%,#10171c 100%);border-radius:9px 9px 7px 7px;width:11px;height:16px;top:7px;left:50%;transform:translate(-50%);box-shadow:inset 0 -2px #637a8738,inset 0 2px #ffffff0a}.foil-rider-torso:after{content:"";background:#b6dee46b;border-radius:999px;width:3px;height:10px;position:absolute;top:2px;left:50%;transform:translate(-50%)}.foil-rider-arm{background:linear-gradient(90deg,#20282f 0%,#10161b 100%);border-radius:999px;width:8px;height:3px;top:11px}.foil-rider-arm-left{transform-origin:100%;left:1px;transform:rotate(34deg)}.foil-rider-arm-right{transform-origin:0;right:1px;transform:rotate(-34deg)}.foil-rider-leg{background:linear-gradient(#161d23 0%,#080c10 100%);border-radius:999px;width:4px;height:18px;top:20px}.foil-rider-leg-left{left:7px;transform:rotate(8deg)}.foil-rider-leg-right{right:7px;transform:rotate(-8deg)}.foil-rider-board{z-index:1;background:linear-gradient(90deg,#dceef4 0%,#8fe7ef 100%);border-radius:999px;width:42px;height:6px;transform:rotate(-4deg)}.foil-rider-mast{background:#d3f5ffc7;border-radius:999px;width:3px;height:20px;margin-top:-1px}.foil-rider-wing{background:linear-gradient(90deg,#afe8f024,#c9f8ffc7,#afe8f024);border-radius:999px;width:22px;height:6px;transform:translateY(-2px)}.foil-obstacle{filter:drop-shadow(0 6px 12px #0000003d);font-size:2rem}.foil-obstacle-angler{transform:translate(-50%)scale(1.16)}.foil-obstacle-toppled{opacity:.72;transform:translate(-50%)rotate(82deg)}.foil-obstacle-duck,.foil-obstacle-sup{display:block}.foil-obstacle-angler-graphic{width:28px;height:42px;display:block;position:relative}.foil-angler-head{background:#f4d3b0;border-radius:999px;width:10px;height:10px;position:absolute;top:0;left:9px}.foil-angler-body{background:#c76a2a;border-radius:8px;width:8px;height:20px;position:absolute;top:10px;left:10px}.foil-angler-rod{transform-origin:0;background:#f2f3f5;border-radius:999px;width:18px;height:3px;position:absolute;top:6px;left:14px;transform:rotate(-26deg)}.foil-projectile{background:radial-gradient(circle at 32% 32%,#c8a96d 0%,#8e6940 70%,#614226 100%);border-radius:999px;width:16px;height:16px;position:absolute;transform:translate(-50%);box-shadow:0 0 0 2px #0c13185c}.foil-game-stats,.foil-game-controls,.foil-game-actions{gap:12px;display:grid}.foil-game-meter{gap:6px;display:grid}.foil-game-meter-track{background:#ffffff14;border-radius:999px;height:10px;overflow:hidden}.foil-game-meter-track span{border-radius:inherit;background:linear-gradient(90deg,#55afd0 0%,#7cd0b1 100%);height:100%;display:block}.foil-game-score-row{border-radius:var(--radius-md);background:#071116b8;border:1px solid #6fb4c814;justify-content:space-between;align-items:center;gap:10px;padding:12px 14px;display:flex}.foil-game-controls-4{grid-template-columns:repeat(2,minmax(0,1fr))}.foil-game-sidepanel{gap:16px;display:grid}.foil-game-info-card{border-radius:var(--radius-md);background:linear-gradient(#081318db,#081116eb);border:1px solid #6fb4c81a;padding:16px}.foil-game-info-card h3,.foil-game-ranking{margin:0}.foil-game-ranking{gap:10px;padding-left:20px;display:grid}.foil-game-ranking li{grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:10px;display:grid}.empty-state{margin:0}.site-footer{padding:0 14px 18px}.site-footer-inner{border-top:1px solid var(--border);width:min(100%,1180px);color:var(--muted);justify-content:space-between;align-items:center;gap:14px;margin:0 auto;padding:16px 18px;display:flex}.site-footer-brand{color:var(--text);margin:0;font-weight:800}.site-footer-nav{flex-wrap:wrap;gap:16px;display:flex}.site-footer-nav a{color:var(--muted)}.site-footer-nav a:hover{color:var(--text)}.legal-page{padding-top:24px}.legal-card{gap:18px;max-width:860px}.legal-card h1{margin:0;font-size:clamp(2rem,6vw,3rem)}.legal-block{gap:8px;display:grid}.legal-block h2,.legal-block p{margin:0}.spot-link-button{width:fit-content}.spot-link-list{gap:10px;display:grid}.spot-link-card{border-radius:var(--radius-md);background:#071116b8;border:1px solid #6fb4c814;gap:8px;padding:12px;display:grid}.spot-link-card-compact{background:0 0;border:0;padding:0}.spot-link-label{color:var(--text);font-size:.92rem;font-weight:800}.spot-link-url{color:var(--primary-strong);word-break:break-word;font-size:.9rem;line-height:1.45}.spot-link-actions{flex-wrap:wrap;gap:10px;display:flex}.spot-detail-grid{gap:16px;display:grid}.spot-detail-block{gap:12px;display:grid}.spot-detail-image{aspect-ratio:1;object-fit:cover;border-radius:var(--radius-lg);border:1px solid var(--border);background:#071116b8;width:100%}.notification-permission-banner{z-index:20;background:#0d232df0;border:1px solid #6fb4c82e;border-radius:16px;justify-content:space-between;align-items:center;gap:12px;margin:0 16px 12px;padding:12px 14px;display:flex;position:sticky;top:88px}.notification-permission-banner span{color:var(--text);font-size:.95rem}.attendance-toast-stack{z-index:30;gap:10px;width:min(360px,100vw - 32px);display:grid;position:fixed;bottom:16px;right:16px}.attendance-toast{box-shadow:var(--shadow);background:#08181ff5;border:1px solid #6fb4c82e;border-radius:18px;padding:14px 16px}.attendance-toast strong,.attendance-toast p{margin:0}.attendance-toast p{color:var(--muted);margin-top:6px;line-height:1.45}@media (max-width:479px){.weather-grid-tight{grid-template-columns:1fr}.section-title,.day-header,.section-headline,.chat-message-head{flex-direction:column;align-items:start}.notification-permission-banner{flex-direction:column;align-items:start;top:76px}}@media (min-width:768px){.page-shell{padding:24px 20px 72px}.marketing-shell{padding:28px 20px 84px}.site-header-inner{padding:16px 20px}.auth-grid,.spot-grid,.people-grid,.archive-grid,.marketing-grid,.marketing-showcase{grid-template-columns:repeat(2,minmax(0,1fr))}.marketing-hero-grid{grid-template-columns:minmax(0,1.15fr) minmax(300px,.85fr);align-items:center}.comparison-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.analysis-columns,.analysis-history-head,.diagram-grid{grid-template-columns:repeat(2,minmax(0,1fr));align-items:start}.profile-bar{grid-template-columns:1.15fr 1fr;align-items:center}.days-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.spot-card{grid-template-columns:1.5fr 1fr;align-items:start}.app-entry-qr{grid-template-columns:minmax(0,220px) minmax(0,1fr)}.foil-game-layout{grid-template-columns:minmax(0,1.25fr) minmax(280px,.75fr);align-items:start}.spot-header-main{grid-template-columns:minmax(0,340px) minmax(0,1fr);align-items:start}.spot-detail-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width:1120px){.days-grid,.spot-grid,.people-grid,.archive-grid,.marketing-grid,.comparison-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.report-summary-grid,.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.diagram-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}
