@font-face{font-family:Fraunces Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/fraunces-vietnamese-wght-normal-CnvboYUG.woff2) format("woff2-variations");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Fraunces Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/fraunces-latin-ext-wght-normal-Ca2vKHc0.woff2) format("woff2-variations");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Fraunces Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/fraunces-latin-wght-normal-ukD16Tqj.woff2) format("woff2-variations");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Hanken Grotesk Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(data:font/woff2;base64,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) format("woff2-variations");unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Hanken Grotesk Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/hanken-grotesk-vietnamese-wght-normal-CHiFlh_0.woff2) format("woff2-variations");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Hanken Grotesk Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/hanken-grotesk-latin-ext-wght-normal-Dg-wlmqe.woff2) format("woff2-variations");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Hanken Grotesk Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/hanken-grotesk-latin-wght-normal-CaVRRdDk.woff2) format("woff2-variations");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{--bg: oklch(96% .03 85);--bg-2: oklch(92% .06 70);--surface: oklch(99% .008 85);--surface-2: oklch(96.5% .02 80);--ink: oklch(30% .045 60);--ink-soft: oklch(47% .04 60);--accent: oklch(72% .16 62);--accent-2: oklch(64% .19 40);--on-accent: oklch(99% .008 85);--glow: oklch(82% .16 75);--line: oklch(87% .03 70);--font-display: "Fraunces Variable", Fraunces, serif;--font-text: "Hanken Grotesk Variable", "Hanken Grotesk", sans-serif;--radius: 22px;--radius-sm: 14px;--space-1: 6px;--space-2: 10px;--space-3: 16px;--space-4: 24px;--space-5: 36px;--ease-sky: 1.2s cubic-bezier(.4, 0, .2, 1)}.sky-ambient{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;pointer-events:none;overflow:hidden;background:linear-gradient(180deg,var(--bg-2),var(--bg) 70%);transition:background var(--ease-sky)}.precip-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2;pointer-events:none;overflow:hidden}.sky-ambient:before,.sky-ambient:after{content:"";position:absolute;top:-20%;right:-20%;bottom:-20%;left:-20%;will-change:transform,opacity}.sky-ambient[data-ambient=sun]{--sun-x: 68%;--sun-y: 22%;--sun-r: 58px;--sun-tint: var(--glow)}:root[data-phase=dawn] .sky-ambient[data-ambient=sun]{--sun-x: 24%;--sun-y: 72%;--sun-r: 46px}:root[data-phase=dusk] .sky-ambient[data-ambient=sun]{--sun-x: 76%;--sun-y: 70%;--sun-r: 52px}.sky-ambient[data-ambient=sun]:before{top:0;right:0;bottom:0;left:0;background:radial-gradient(circle var(--sun-r) at var(--sun-x) var(--sun-y),var(--sun-tint) 0 30%,color-mix(in oklab,var(--sun-tint) 62%,transparent) 55%,transparent 74%),radial-gradient(circle calc(var(--sun-r) * 5) at var(--sun-x) var(--sun-y),color-mix(in oklab,var(--glow) 42%,transparent),transparent 70%);opacity:.85;transform-origin:var(--sun-x) var(--sun-y);animation:sky-breathe 9s ease-in-out infinite}.sky-ambient[data-ambient=sun]:after{top:0;right:0;bottom:0;left:0;background:repeating-conic-gradient(from 0deg at var(--sun-x) var(--sun-y),transparent 0deg 9deg,color-mix(in oklab,var(--sun-tint) 42%,transparent) 9deg 10deg,transparent 10deg 19deg);mask-image:radial-gradient(circle calc(var(--sun-r) * 6) at var(--sun-x) var(--sun-y),black,transparent 78%);-webkit-mask-image:radial-gradient(circle calc(var(--sun-r) * 6) at var(--sun-x) var(--sun-y),black,transparent 78%);opacity:.16;transform-origin:var(--sun-x) var(--sun-y);animation:sky-rotate 140s linear infinite}.ambient-canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.sky-ambient[data-ambient=fog]:before,.sky-ambient[data-ambient=fog]:after{top:-10%;right:-25%;bottom:-10%;left:-25%;filter:blur(10px)}.sky-ambient[data-ambient=fog]:before{background:linear-gradient(180deg,transparent 18%,color-mix(in oklab,var(--surface) 62%,transparent) 44%,transparent 70%);opacity:.7;animation:sky-fog 26s ease-in-out infinite}.sky-ambient[data-ambient=fog]:after{background:linear-gradient(180deg,transparent 44%,color-mix(in oklab,var(--surface) 52%,transparent) 68%,transparent 92%);opacity:.55;animation:sky-fog 34s ease-in-out infinite reverse}@keyframes sky-breathe{0%,to{transform:scale(1);opacity:.86}50%{transform:scale(1.05);opacity:1}}@keyframes sky-rotate{to{transform:rotate(1turn)}}@keyframes sky-fog{0%,to{transform:translate(-4%);opacity:.45}50%{transform:translate(4%);opacity:.72}}@media(prefers-reduced-motion:reduce){.sky-ambient:before,.sky-ambient:after{animation:none!important}}*{box-sizing:border-box}html{color-scheme:light}body{margin:0;min-height:100dvh;color:var(--ink);background-color:var(--bg);font-family:var(--font-text);font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased;transition:background-color var(--ease-sky),color var(--ease-sky)}#root{position:relative;z-index:1;min-height:100dvh;max-width:480px;margin:0 auto;display:flex;flex-direction:column}h1,h2,h3{font-family:var(--font-display);font-weight:600;line-height:1.1;letter-spacing:-.01em;margin:0}a{color:var(--accent-2);text-underline-offset:3px}.app-header{position:sticky;top:0;z-index:3;display:flex;align-items:center;gap:var(--space-2);padding:10px var(--space-4) calc(10px + env(safe-area-inset-top,0px));padding-top:calc(10px + env(safe-area-inset-top,0px));padding-bottom:10px;background:color-mix(in oklab,var(--surface) 82%,transparent);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--line);color:var(--accent);transition:background-color var(--ease-sky),border-color var(--ease-sky)}.wordmark{font-family:var(--font-display);font-weight:600;font-size:1.25rem;letter-spacing:-.02em;color:var(--ink)}.app-main{flex:1;padding:0 0 calc(120px + env(safe-area-inset-bottom));display:flex;flex-direction:column}.tagline{margin:0;color:var(--ink-soft)}.card{background:var(--surface);border-bottom:1px solid var(--line);padding:var(--space-3) var(--space-4) var(--space-4);transition:background-color var(--ease-sky),border-color var(--ease-sky)}.card h2{font-size:1.2rem;margin-bottom:var(--space-2)}.card p{margin:0 0 var(--space-1);color:var(--ink-soft)}.stub-note{margin-top:var(--space-3);font-size:.8rem;font-weight:600;color:var(--accent)}.disclaimer{margin:auto 0 0;padding:var(--space-3) var(--space-4);font-size:.72rem;color:var(--ink-soft);text-align:center;opacity:.85}.btn-primary,.btn-ghost{border:none;border-radius:var(--radius-sm);padding:12px 20px;font-family:var(--font-text);font-size:.95rem;font-weight:600;cursor:pointer;transition:transform .12s ease,background-color var(--ease-sky)}.btn-primary{background:var(--accent);color:var(--on-accent)}.btn-primary:active{transform:scale(.97)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-ghost{background:transparent;color:var(--ink-soft);border:1.5px solid var(--line);padding:6px 14px;font-size:.85rem}.actions{display:flex;flex-wrap:wrap;gap:var(--space-2);align-items:center;margin-top:var(--space-3)}.fineprint{margin-top:var(--space-4);font-size:.74rem;color:var(--ink-soft);line-height:1.4;opacity:.85}.tabbar{position:fixed;bottom:0;left:50%;transform:translate(-50%);z-index:3;width:100%;max-width:480px;display:flex;justify-content:space-around;padding:8px 10px calc(8px + env(safe-area-inset-bottom));background:color-mix(in oklab,var(--surface) 78%,transparent);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-top:1px solid var(--line)}.tabbar a{text-decoration:none;color:var(--ink-soft);opacity:.72;display:flex;flex-direction:column;align-items:center;gap:3px;font-weight:600;font-size:.66rem;letter-spacing:.02em;padding:4px 12px;border-radius:var(--radius-sm);min-width:58px;transition:color .15s ease,opacity .15s ease}.tabbar a svg{display:block}.tabbar a.active{opacity:1;color:var(--accent);font-weight:700}.scanner{display:flex;flex-direction:column;align-items:center}.camera-frame{position:relative;width:100%;aspect-ratio:3 / 4;max-height:56dvh;border-radius:var(--radius);overflow:hidden;background:var(--ink);display:grid;place-items:center}.camera-video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.camera-video-off{display:none}.camera-guide{position:relative;width:46%;aspect-ratio:1;border-radius:999px;border:3px solid var(--accent);box-shadow:0 0 0 9999px color-mix(in oklab,var(--ink) 34%,transparent),0 0 30px var(--glow)}.camera-status{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:var(--space-4);text-align:center;color:var(--on-accent)}.camera-hint{margin:var(--space-3) 0 0;color:var(--ink-soft);font-size:.9rem}.tone-hero{display:flex;align-items:center;gap:var(--space-3)}.tone-eyebrow{margin:0;font-size:.76rem;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);font-weight:700}.scan-result h2,.scan-saved h2{font-size:1.6rem;margin:2px 0}.tone-hex{margin:0;font-variant-numeric:tabular-nums;color:var(--ink-soft)}.confidence{margin-top:var(--space-3)}.confidence-bar{height:8px;border-radius:999px;background:var(--surface-2);overflow:hidden}.confidence-bar>span{display:block;height:100%;background:var(--accent-2);border-radius:999px;transition:width .4s ease}.confidence p{margin:var(--space-1) 0 0;font-size:.85rem;color:var(--ink-soft)}.field{display:block;margin-top:var(--space-4)}.field>span{display:block;font-size:.9rem;font-weight:600;margin-bottom:var(--space-1);color:var(--ink)}.field em{font-weight:400;font-style:italic;color:var(--ink-soft)}.field select{width:100%;padding:12px;border-radius:var(--radius-sm);border:1.5px solid var(--line);background:var(--surface);color:var(--ink);font-family:var(--font-text);font-size:1rem}.scan-saved{text-align:center}.scan-saved .actions{justify-content:center}.timer-top{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-3)}.timer-skin{margin:2px 0 0;font-weight:600;color:var(--ink)}.type-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-2);margin-top:var(--space-3)}.type-chip{display:flex;flex-direction:column;gap:2px;text-align:left;padding:12px 14px;border-radius:var(--radius-sm);border:1.5px solid var(--line);background:var(--surface);color:var(--ink);font-family:var(--font-text);cursor:pointer}.type-chip strong{font-family:var(--font-display);color:var(--accent)}.type-chip span{font-size:.78rem;color:var(--ink-soft)}.uv-badge{display:inline-flex;align-items:baseline;gap:var(--space-2);margin-top:var(--space-3);padding:8px 16px;border-radius:999px;font-weight:700;color:var(--on-accent)}.uv-badge .uv-index{font-family:var(--font-display);font-size:1.15rem}.uv-low{background:#4a9a5e}.uv-moderate{background:#ea8a18}.uv-high{background:#ea5b1e}.uv-very-high{background:#cc272e}.uv-extreme{background:#9a2a95}.safe-time{margin-top:var(--space-4)}.safe-big{font-family:var(--font-display);margin:2px 0;font-size:2.6rem;font-weight:600;color:var(--ink);letter-spacing:-.02em}.reapply{margin:0;color:var(--ink-soft);font-size:.9rem}.spf-chips{display:flex;flex-wrap:wrap;gap:var(--space-2)}.spf-chip{border:1.5px solid var(--line);background:var(--surface);color:var(--ink-soft);border-radius:999px;padding:8px 16px;font-family:var(--font-text);font-size:.9rem;font-weight:600;cursor:pointer}.spf-chip.active{background:var(--accent);border-color:var(--accent);color:var(--on-accent)}.demo-panel{position:fixed;z-index:4;left:50%;transform:translate(-50%);bottom:calc(84px + env(safe-area-inset-bottom));width:calc(100% - 24px);max-width:456px;display:flex;align-items:center;gap:var(--space-3);padding:12px 16px;border-radius:var(--radius);border:1px solid var(--line);background:color-mix(in oklab,var(--surface) 85%,transparent);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);box-shadow:0 12px 34px color-mix(in oklab,var(--ink) 22%,transparent)}.demo-play{flex-shrink:0;width:48px;height:48px;border:none;border-radius:999px;background:var(--accent);color:var(--on-accent);font-size:1.1rem;cursor:pointer}.demo-body{flex:1;display:flex;flex-direction:column;gap:6px}.demo-row{display:flex;justify-content:space-between;align-items:baseline}.demo-time{font-family:var(--font-display);font-weight:600;color:var(--ink);font-variant-numeric:tabular-nums}.demo-phase{font-size:.85rem;font-weight:600;color:var(--accent)}.demo-slider{width:100%;accent-color:var(--accent)}.demo-weather{display:flex;gap:6px}.demo-wx{flex:1;padding:6px 0;border:1px solid var(--line);border-radius:10px;background:transparent;color:var(--ink);font-size:.85rem;cursor:pointer}.demo-wx.active{background:var(--accent);border-color:var(--accent);color:var(--on-accent)}.session-start{margin-top:var(--space-3);width:100%}.session{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);margin-top:var(--space-2);text-align:center}.session-count{font-family:var(--font-display);font-weight:600;font-size:3.4rem;line-height:1;letter-spacing:-.02em;color:var(--ink);font-variant-numeric:tabular-nums}.session-count.over{font-size:2rem;color:var(--accent-2)}.session-alert{width:100%;display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-3);border-radius:var(--radius-sm);background:color-mix(in oklab,var(--accent) 16%,var(--surface));border:1px solid var(--accent);color:var(--ink)}.session-alert strong{font-size:1.05rem}.session-alert .btn-ghost{align-self:flex-end;padding:6px 14px;color:var(--accent-2)}.session-taps{display:flex;gap:var(--space-2);width:100%;margin-top:var(--space-2)}.tap-btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:var(--space-1);padding:12px;border-radius:var(--radius-sm);border:1px solid var(--line);background:var(--surface-2);color:var(--ink);font-family:var(--font-text);font-weight:700;cursor:pointer}.tap-btn span{min-width:22px;padding:1px 7px;border-radius:999px;background:var(--accent);color:var(--on-accent);font-size:.85rem}.session-stop{width:100%;margin-top:var(--space-2);background:var(--accent-2)}.recap{display:flex;flex-direction:column;gap:var(--space-2);margin-top:var(--space-2)}.recap-stats{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-2);margin:var(--space-2) 0}.recap-stats div{padding:var(--space-2);border-radius:var(--radius-sm);background:var(--surface-2);border:1px solid var(--line)}.recap-stats dt{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft)}.recap-stats dd{margin:2px 0 0;font-family:var(--font-display);font-weight:600;font-size:1.15rem;color:var(--ink)}.streak-copy{color:var(--ink-soft);text-align:center}.share-card{display:flex;flex-direction:column;gap:var(--space-2);align-items:center}.share-card-preview{width:min(78%,300px);border-radius:var(--radius-sm);background:linear-gradient(168deg,#5b8abb,#a1888c,#d97c50 55%,#7b4436);box-shadow:0 10px 30px color-mix(in oklab,var(--ink) 22%,transparent)}.share-card-actions{display:flex;flex-wrap:wrap;gap:var(--space-2);justify-content:center;width:100%}.share-card-hint{font-size:.85rem;color:var(--ink-soft);text-align:center}.share-coach{width:100%;padding:var(--space-2) var(--space-3);border:1px solid color-mix(in oklab,var(--accent) 35%,transparent);border-radius:var(--radius-sm);background:color-mix(in oklab,var(--accent) 8%,var(--surface));display:flex;flex-direction:column;gap:var(--space-1);text-align:left}.share-coach-title{margin:0;font-weight:700;font-size:.95rem;color:var(--ink)}.share-coach-steps{margin:0;padding-left:1.2em;display:flex;flex-direction:column;gap:2px;font-size:.9rem;color:var(--ink-soft)}.share-coach-done{align-self:flex-end}.btn-secondary{padding:12px 20px;border-radius:var(--radius-sm);border:1.5px solid var(--line);background:var(--surface);color:var(--ink);font-weight:600;font-size:.95rem}.session-chip{margin-left:auto;display:inline-flex;align-items:center;gap:var(--space-1);padding:6px 12px;border-radius:999px;background:color-mix(in oklab,var(--accent) 18%,var(--surface));border:1px solid var(--accent);color:var(--ink);font-weight:700;font-size:.95rem;text-decoration:none;font-variant-numeric:tabular-nums}.session-chip.over{background:color-mix(in oklab,var(--accent-2) 20%,var(--surface));border-color:var(--accent-2)}.weather-widget{margin-left:auto;display:inline-flex;align-items:center;gap:var(--space-2);padding:5px 12px;border-radius:999px;background:color-mix(in oklab,var(--surface) 70%,transparent);border:1px solid var(--line);color:var(--ink)}.weather-temp{font-weight:700;font-size:.9rem;font-variant-numeric:tabular-nums}.uv-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.sun-compass{text-align:center}.compass-wrap{display:flex;justify-content:center;margin-top:var(--space-3)}.compass-dial{width:min(220px,58vw);height:auto}.compass-ring{fill:color-mix(in oklab,var(--surface) 55%,transparent);stroke:var(--line);stroke-width:1.5}.compass-tick{stroke:var(--ink-soft);stroke-width:1.2;opacity:.55}.compass-cardinal{font-family:var(--font-display);font-size:15px;font-weight:600;fill:var(--ink-soft);text-anchor:middle;dominant-baseline:central}.compass-cardinal.north,.compass-sun{fill:var(--accent)}.compass-sun-ray{stroke:var(--accent);stroke-width:2;stroke-linecap:round}.compass-needle{fill:var(--ink)}.compass-coach{margin:var(--space-3) auto 0;max-width:340px;color:var(--ink);font-size:.98rem;line-height:1.5}.compass-reading{margin:var(--space-2) 0 0;color:var(--ink-soft);font-size:.9rem}.compass-height{color:var(--ink-soft);font-size:.9rem}.sun-compass .btn-ghost{margin-top:var(--space-3)}.tips-intro{color:var(--ink-soft);margin-top:var(--space-1)}.tips-filters{display:flex;flex-wrap:wrap;gap:var(--space-2);margin:var(--space-3) 0 var(--space-2)}.tips-chip{padding:6px 12px;border-radius:999px;border:1px solid var(--line);background:transparent;color:var(--ink-soft);font-size:.85rem;font-weight:600}.tips-chip.active{background:color-mix(in oklab,var(--accent) 16%,var(--surface));border-color:var(--accent);color:var(--ink)}.tips-group{margin-top:var(--space-4)}.tips-list{list-style:none;margin:var(--space-2) 0 0;padding:0}.tips-row{border-bottom:1px solid var(--line)}.tips-row-head{width:100%;display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) 0;background:none;border:none;text-align:left;color:var(--ink);font-size:1rem}.tips-row-text{display:flex;flex-direction:column;gap:2px}.tips-summary{color:var(--ink-soft);font-size:.88rem}.tips-caret{margin-left:auto;font-family:var(--font-display);font-size:1.3rem;color:var(--accent);flex-shrink:0}.tips-body{padding:0 0 var(--space-3)}.tips-body p{color:var(--ink);margin:0 0 var(--space-2);font-size:.95rem;line-height:1.55}.uv-sparkline{width:100%;max-width:340px;height:auto;display:block;margin:0 auto}.session-uv{margin-top:var(--space-3)}.session-uv-now,.recap-uv-stats{margin:var(--space-1) 0 0;text-align:center;color:var(--ink-soft);font-size:.88rem}.session-uv-now strong,.recap-uv-stats strong{color:var(--ink)}.recap-uv{margin-top:var(--space-3)}.welcome{position:relative;z-index:1;min-height:100dvh;max-width:480px;margin:0 auto;padding:calc(48px + env(safe-area-inset-top)) var(--space-4) calc(32px + env(safe-area-inset-bottom));display:flex;flex-direction:column;gap:var(--space-4)}.welcome-brand{text-align:center;margin-top:var(--space-4)}.welcome-title{font-size:2.2rem;margin-top:var(--space-2);color:var(--ink)}.welcome-tagline{color:var(--ink-soft);margin:var(--space-1) 0 0}.welcome-terms{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:var(--space-4)}.welcome-list{list-style:none;margin:var(--space-2) 0 0;padding:0;display:flex;flex-direction:column;gap:var(--space-3)}.welcome-list li{color:var(--ink-soft);font-size:.92rem;line-height:1.5}.welcome-list strong{color:var(--ink)}.welcome-accept{margin-top:auto;width:100%;padding:14px 20px;font-size:1rem}.welcome-fineprint{text-align:center;margin-top:var(--space-2)}
