@font-face{font-family:Be Vietnam Pro;font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/be-vietnam-pro-400-normal-vietnamese.woff2) format("woff2");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:Be Vietnam Pro;font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/be-vietnam-pro-400-normal-latin-ext.woff2) format("woff2");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:Be Vietnam Pro;font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/be-vietnam-pro-400-normal-latin.woff2) format("woff2");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:Be Vietnam Pro;font-style:normal;font-weight:500;font-display:swap;src:url(/fonts/be-vietnam-pro-500-normal-vietnamese.woff2) format("woff2");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:Be Vietnam Pro;font-style:normal;font-weight:500;font-display:swap;src:url(/fonts/be-vietnam-pro-500-normal-latin-ext.woff2) format("woff2");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:Be Vietnam Pro;font-style:normal;font-weight:500;font-display:swap;src:url(/fonts/be-vietnam-pro-500-normal-latin.woff2) format("woff2");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:Be Vietnam Pro;font-style:normal;font-weight:600;font-display:swap;src:url(/fonts/be-vietnam-pro-600-normal-vietnamese.woff2) format("woff2");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:Be Vietnam Pro;font-style:normal;font-weight:600;font-display:swap;src:url(/fonts/be-vietnam-pro-600-normal-latin-ext.woff2) format("woff2");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:Be Vietnam Pro;font-style:normal;font-weight:600;font-display:swap;src:url(/fonts/be-vietnam-pro-600-normal-latin.woff2) format("woff2");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:Be Vietnam Pro;font-style:normal;font-weight:700;font-display:swap;src:url(/fonts/be-vietnam-pro-700-normal-vietnamese.woff2) format("woff2");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:Be Vietnam Pro;font-style:normal;font-weight:700;font-display:swap;src:url(/fonts/be-vietnam-pro-700-normal-latin-ext.woff2) format("woff2");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:Be Vietnam Pro;font-style:normal;font-weight:700;font-display:swap;src:url(/fonts/be-vietnam-pro-700-normal-latin.woff2) format("woff2");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:"Noto Serif";font-style:italic;font-weight:500;font-display:swap;src:url(/fonts/noto-serif-500-italic-vietnamese.woff2) format("woff2");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:"Noto Serif";font-style:italic;font-weight:500;font-display:swap;src:url(/fonts/noto-serif-500-italic-latin-ext.woff2) format("woff2");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:"Noto Serif";font-style:italic;font-weight:500;font-display:swap;src:url(/fonts/noto-serif-500-italic-latin.woff2) format("woff2");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:"Noto Serif";font-style:italic;font-weight:600;font-display:swap;src:url(/fonts/noto-serif-600-italic-vietnamese.woff2) format("woff2");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:"Noto Serif";font-style:italic;font-weight:600;font-display:swap;src:url(/fonts/noto-serif-600-italic-latin-ext.woff2) format("woff2");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:"Noto Serif";font-style:italic;font-weight:600;font-display:swap;src:url(/fonts/noto-serif-600-italic-latin.woff2) format("woff2");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:"Noto Serif";font-style:normal;font-weight:500;font-display:swap;src:url(/fonts/noto-serif-500-normal-vietnamese.woff2) format("woff2");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:"Noto Serif";font-style:normal;font-weight:500;font-display:swap;src:url(/fonts/noto-serif-500-normal-latin-ext.woff2) format("woff2");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:"Noto Serif";font-style:normal;font-weight:500;font-display:swap;src:url(/fonts/noto-serif-500-normal-latin.woff2) format("woff2");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:"Noto Serif";font-style:normal;font-weight:600;font-display:swap;src:url(/fonts/noto-serif-600-normal-vietnamese.woff2) format("woff2");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:"Noto Serif";font-style:normal;font-weight:600;font-display:swap;src:url(/fonts/noto-serif-600-normal-latin-ext.woff2) format("woff2");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:"Noto Serif";font-style:normal;font-weight:600;font-display:swap;src:url(/fonts/noto-serif-600-normal-latin.woff2) format("woff2");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:"Noto Serif";font-style:normal;font-weight:700;font-display:swap;src:url(/fonts/noto-serif-700-normal-vietnamese.woff2) format("woff2");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:"Noto Serif";font-style:normal;font-weight:700;font-display:swap;src:url(/fonts/noto-serif-700-normal-latin-ext.woff2) format("woff2");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:"Noto Serif";font-style:normal;font-weight:700;font-display:swap;src:url(/fonts/noto-serif-700-normal-latin.woff2) format("woff2");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{--surface: #fbf9f8;--surface-lowest: #ffffff;--surface-low: #f5f3f3;--surface-mid: #efeded;--surface-high: #e4e2e2;--ink: #00162a;--ink-soft: #0d2b45;--text: #1b1c1c;--muted: #43474d;--outline: #c3c6ce;--stone: #605e57;--paper: #e6e2d8;--cinnabar: #5b0005;--cinnabar-bright: #92030f;--jade: #466f5d;--success: #1f6f43;--danger: #ba1a1a;--shadow: 0 12px 48px -12px rgba(45, 31, 21, .16), 0 2px 8px rgba(45, 31, 21, .06)}*{box-sizing:border-box}body{margin:0;min-height:100vh;color:var(--text);background-color:var(--surface);background-image:url("data:image/svg+xml,%3Csvg width='120' height='120' viewBox='0 0 120 120' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='120' height='120' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");font-family:Be Vietnam Pro,sans-serif}button,input,select,textarea{font:inherit}button,a{-webkit-tap-highlight-color:transparent}button{cursor:pointer}.material-symbols-outlined{font-family:Material Symbols Outlined;font-weight:400;font-style:normal;font-size:22px;line-height:1;display:inline-block;font-feature-settings:"liga";-webkit-font-feature-settings:"liga"}.app-shell{min-height:100vh}.side-nav{position:fixed;inset:0 auto 0 0;width:320px;display:none;flex-direction:column;padding:128px 28px 24px;background:var(--surface-low);border-right:1px solid var(--outline);z-index:20}.brand{margin-bottom:32px}.brand-title{margin:0;color:var(--cinnabar);font:700 32px/1.1 "Noto Serif",serif}.brand-subtitle{margin:6px 0 0;color:var(--muted);font-size:18px}.nav-links{display:grid;gap:12px}.nav-link{display:flex;align-items:center;gap:18px;min-height:58px;padding:14px 20px;color:var(--muted);text-decoration:none;border-radius:8px;font-size:20px}.nav-link.active{color:var(--ink);background:var(--paper);font-weight:700}.main{min-height:100vh;padding:86px 18px 112px}.topbar{position:fixed;inset:0 0 auto;min-height:80px;display:flex;align-items:center;justify-content:flex-end;padding:12px 18px;background:#fbf9f8eb;border-bottom:1px solid var(--outline);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);z-index:18}.topbar-metrics{display:flex;align-items:center;gap:10px}.topbar-actions{display:flex;align-items:center;gap:10px;min-width:0}.topbar>div:first-child{display:none}.global-sound-toggle{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px;min-width:44px;padding:10px 14px;border-radius:999px;white-space:nowrap}.metric{display:inline-flex;align-items:center;gap:6px;min-height:48px;padding:10px 20px;border:1px solid var(--outline);border-radius:999px;background:var(--surface-lowest);color:var(--ink);font-size:15px;font-weight:700}.metric .material-symbols-outlined{color:var(--cinnabar)}@media (max-width: 520px){.global-sound-toggle span{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.topbar-actions,.topbar-metrics{gap:8px}.metric{padding:10px 12px}}.page{width:min(1120px,100%);margin:0 auto}.page.narrow{width:min(760px,100%)}.kicker{margin:0 0 8px;color:var(--cinnabar);font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}h1,h2,h3{margin:0;color:var(--ink);font-family:"Noto Serif",serif}.headline-xl{font-size:clamp(34px,6vw,54px);line-height:1.04}.headline-lg{font-size:clamp(28px,4vw,42px);line-height:1.1}.lead{margin:12px 0 0;color:var(--muted);font-size:17px;line-height:1.65}.card{background:var(--surface-lowest);border:1px solid var(--outline);border-radius:8px;box-shadow:var(--shadow)}.panel{background:var(--surface-low);border:1px solid var(--outline);border-radius:8px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px;padding:0 18px;border:1px solid transparent;border-radius:6px;background:var(--surface-lowest);color:var(--ink);font-weight:700;text-decoration:none}.btn.primary{background:var(--cinnabar);color:#fff}.btn.secondary{border-color:var(--ink)}.btn.ghost{border-color:var(--outline);background:transparent}.btn.circle{width:58px;height:58px;min-height:58px;padding:0;border-radius:50%;font-size:24px}.btn:disabled{cursor:not-allowed;opacity:.55}.choice-row{display:flex;flex-wrap:wrap;gap:10px}.chip{min-height:52px;padding:11px 20px;border:1px solid var(--outline);border-radius:999px;background:var(--surface-lowest);color:var(--muted);font-size:20px;font-weight:700}.chip.active{border-color:var(--cinnabar);background:#ffdad6;color:var(--cinnabar)}.deck-layout{display:grid;gap:22px;align-items:start}.reference-discover{width:min(980px,100%);padding-top:8px}.reference-discover .deck-side{display:none}.deck-card{position:relative;width:min(840px,100%);max-height:none;margin:0 auto;overflow:hidden;touch-action:pan-y;transform-origin:50% 92%;transition:transform .18s ease,opacity .18s ease;will-change:transform;-webkit-user-select:none;-moz-user-select:none;user-select:none}.deck-card.is-dragging{cursor:grabbing;transition:none}.deck-card.throw-left{opacity:0;transform:translate(-120vw) rotate(-18deg)!important}.deck-card.throw-right{opacity:0;transform:translate(120vw) rotate(18deg)!important}.swipe-stamp{position:absolute;top:28px;z-index:6;padding:8px 12px;border:3px solid currentColor;border-radius:4px;background:#fbf9f8d1;font-size:18px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;opacity:0;transform:rotate(-9deg) scale(.9);transition:opacity .12s ease,transform .12s ease;pointer-events:none}.swipe-stamp-left{left:26px;color:var(--danger)}.swipe-stamp-right{right:26px;color:var(--success);transform:rotate(9deg) scale(.9)}.deck-card.swipe-left .swipe-stamp-left,.deck-card.swipe-right .swipe-stamp-right{opacity:1;transform:rotate(-9deg) scale(1)}.deck-card.swipe-right .swipe-stamp-right{transform:rotate(9deg) scale(1)}.art{position:relative;min-height:260px;overflow:hidden;background:radial-gradient(circle at 72% 18%,rgba(255,255,255,.55),transparent 28%),linear-gradient(135deg,var(--art-a),var(--art-b))}.art:before{content:"";position:absolute;top:18px;right:18px;bottom:18px;left:18px;border:1px solid rgba(255,255,255,.5)}.art:after{content:attr(data-initial);position:absolute;right:26px;bottom:-20px;color:#ffffff38;font:700 180px/.8 "Noto Serif",serif}.image-art{min-height:430px;background:var(--surface-mid)}.image-art img{width:100%;height:100%;min-height:430px;display:block;-o-object-fit:cover;object-fit:cover;-o-object-position:center 35%;object-position:center 35%}.gallery-track{--active-image: 0;display:flex;width:100%;height:100%;min-height:430px;transform:translate(calc(var(--active-image) * -100%));transition:transform .26s cubic-bezier(.2,.8,.2,1)}.gallery-track img{flex:0 0 100%}.profile-gallery .gallery-zone{position:absolute;top:0;bottom:0;z-index:4;width:34%;min-height:0;padding:0;border:0;background:transparent}.gallery-zone-left{left:0}.gallery-zone-right{right:0}.gallery-controls{position:absolute;left:18px;right:18px;bottom:18px;z-index:5;display:flex;align-items:center;justify-content:space-between;gap:16px;pointer-events:none;transition:opacity .24s ease}.gallery-arrow{display:grid;place-items:center;width:42px;height:42px;border:1px solid rgba(255,255,255,.7);border-radius:50%;background:#00000052;color:#fff;box-shadow:0 8px 18px #0000003d;pointer-events:auto}.gallery-dots{display:flex;align-items:center;justify-content:center;flex:1;gap:7px;pointer-events:auto}.gallery-dots button{width:38px;height:5px;min-height:5px;padding:0;border:0;border-radius:999px;background:#ffffff85;box-shadow:0 1px 4px #00000038}.gallery-dots button.active{background:#fff}.image-art:before{inset:auto 0 0;height:170px;border:0;background:linear-gradient(to bottom,transparent,var(--surface-lowest) 82%);z-index:1;pointer-events:none}.image-art:after{content:""}.art-scene{position:absolute;inset:auto 24px 24px;z-index:2;max-width:78%;color:#fff;text-shadow:0 2px 18px rgba(0,0,0,.35)}.art-scene strong{display:block;font:700 30px/1.08 "Noto Serif",serif}.art-scene span{display:block;margin-top:8px;font-size:13px;line-height:1.5}.tag{position:absolute;top:24px;left:24px;z-index:3;padding:6px 10px;background:var(--cinnabar);color:#fff;border-radius:3px;font-size:11px;font-weight:700;letter-spacing:.08em}.deck-body{padding:34px 64px 38px;text-align:center}.deck-title{text-align:center}.deck-title p{margin:6px 0 0;color:var(--muted);font-style:italic}.quote{margin:24px 0;padding:22px 56px;border-left:8px solid var(--ink);border-radius:14px;background:var(--surface-low);color:var(--text);font:600 22px/1.55 "Noto Serif",serif}.deck-bio{width:min(680px,100%);margin:0 auto 26px;color:var(--text);font-size:19px;line-height:1.55}.conflict-tile{width:min(260px,100%);margin:0 auto 22px;padding:14px 16px;border:1px solid var(--outline);border-radius:8px;background:var(--surface-lowest);box-shadow:0 2px 8px #2d1f150f;text-align:left}.conflict-tile span{color:var(--muted);font-size:12px;letter-spacing:.06em;text-transform:uppercase}.conflict-tile strong{display:flex;align-items:center;gap:8px;margin-top:8px;color:var(--cinnabar);font-weight:600}.trait-row{display:flex;justify-content:center;flex-wrap:wrap;gap:10px}.trait-row span{min-height:36px;padding:8px 16px;border-radius:999px;background:var(--paper);color:var(--ink-soft);font-size:13px}.info-stack{display:grid;gap:12px}.info-block{padding:14px;border:1px solid var(--outline);border-radius:6px;background:var(--surface)}.info-block h3{margin-bottom:6px;color:var(--cinnabar);font:700 12px/1.3 Be Vietnam Pro,sans-serif;letter-spacing:.06em;text-transform:uppercase}.info-block p{margin:0;color:var(--muted);line-height:1.55}.swipe-actions{display:flex;justify-content:center;gap:42px;margin-top:0;padding:24px;border-top:1px solid var(--surface-high);background:var(--surface-lowest)}.deck-side{display:grid;gap:14px}.stat-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.stat{padding:14px;text-align:center}.stat strong{display:block;color:var(--ink);font:700 24px/1 "Noto Serif",serif}.stat span{display:block;margin-top:5px;color:var(--muted);font-size:12px}.grid{display:grid;gap:18px}.collection-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:30px}.collection-card{position:relative;overflow:hidden;padding:20px;border-radius:0;box-shadow:0 8px 24px #2d1f150f}.collection-card .art{min-height:310px}.collection-body{padding:22px 0 0}.collection-head{display:flex;align-items:end;justify-content:space-between;gap:24px;margin-bottom:64px}.sort-control{display:flex;align-items:center;gap:18px}.sort-control>span{color:var(--muted);font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase}.collection-image{position:relative;aspect-ratio:3 / 4;overflow:hidden;background:var(--surface-mid)}.collection-image>img{width:100%;height:100%;display:block;-o-object-fit:cover;object-fit:cover}.collection-status{position:absolute;top:-1px;right:-1px;display:inline-flex;align-items:center;gap:6px;min-height:34px;padding:7px 12px;border:1px solid var(--outline);background:var(--surface-lowest);color:var(--cinnabar);font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.collection-body h2{font-size:30px}.collection-body p{margin:6px 0 14px;padding-left:12px;border-left:3px solid var(--outline);color:var(--muted);font-style:italic}.collection-progress{height:4px;overflow:hidden;background:var(--surface-high);border-radius:999px}.collection-progress span{display:block;height:100%;background:var(--ink)}.collection-body small{display:block;margin-top:8px;color:var(--muted);text-align:right;font-weight:700;letter-spacing:.04em}.badge{display:inline-flex;align-items:center;gap:6px;min-height:30px;padding:5px 9px;border:1px solid var(--outline);border-radius:999px;color:var(--muted);background:var(--surface-lowest);font-size:12px;font-weight:700}.badge.done{color:var(--success);border-color:#1f6f4359;background:#1f6f4314}.badge.pending{color:var(--cinnabar);border-color:#5b000533;background:#ffdad6}.actions-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}.empty-state{padding:36px;text-align:center}.chat-layout{display:grid;gap:18px}.reference-chat{width:min(1280px,100%)}.chat-card{min-height:calc(100vh - 128px);display:grid;grid-template-rows:auto 1fr auto;overflow:hidden;background:var(--surface-lowest);border-right:1px solid var(--outline);border-left:1px solid var(--outline)}.chat-header{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:28px 32px;border-bottom:1px solid var(--outline)}.avatar{width:52px;height:52px;display:grid;place-items:center;flex:0 0 auto;border-radius:50%;background:linear-gradient(135deg,var(--art-a),var(--art-b));color:#fff;font:700 23px/1 "Noto Serif",serif}.image-avatar{-o-object-fit:cover;object-fit:cover;border:1px solid var(--outline);background:var(--surface-low)}.online-dot{display:inline-block;width:9px;height:9px;margin-right:5px;border-radius:50%;background:var(--ink)}.work-pill{display:inline-flex;align-items:center;gap:8px;min-height:36px;padding:6px 14px;border:1px solid var(--surface-high);border-radius:999px;color:var(--ink);background:var(--surface-lowest);font-weight:700}.chat-thread{display:grid;align-content:start;gap:30px;padding:60px 32px 40px;overflow-y:auto}.chapter-pill{justify-self:center;padding:8px 24px;border:1px solid var(--surface-high);border-radius:999px;background:var(--surface-low);color:var(--muted);font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.message{width:-moz-fit-content;width:fit-content;max-width:min(640px,88%);padding:22px 28px;border-radius:18px;line-height:1.55;font-size:18px}.message.bot{background:var(--surface-low);border:1px solid var(--outline);box-shadow:0 8px 26px #2d1f150d}.message.user{justify-self:end;background:var(--ink);color:#fff;border-radius:18px 18px 4px}.message-row{display:flex;gap:16px;align-items:flex-start}.message-row.user{display:grid;justify-items:end}.message-row.user small{color:var(--muted);font-size:12px}.message-avatar{width:36px;height:36px;flex:0 0 auto;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:1px solid var(--outline)}.message-avatar.fallback{display:grid;place-items:center;background:var(--paper);color:var(--ink);font-weight:700}.typing-line{display:flex;align-items:center;gap:8px;margin-left:52px;color:var(--outline)}.typing-bubble{display:inline-flex;align-items:center;gap:8px;padding:18px 24px;min-height:48px}.typing-bubble-dot{width:8px;height:8px;border-radius:50%;background:var(--ink-soft, var(--muted));opacity:.35;animation:typing-bubble-pulse 1.2s ease-in-out infinite}.typing-bubble-dot:nth-child(2){animation-delay:.18s}.typing-bubble-dot:nth-child(3){animation-delay:.36s}@keyframes typing-bubble-pulse{0%,60%,to{transform:translateY(0);opacity:.35}30%{transform:translateY(-3px);opacity:.95}}@media (prefers-reduced-motion: reduce){.typing-bubble-dot{animation:typing-bubble-fade 1.4s ease-in-out infinite;transform:none!important}@keyframes typing-bubble-fade{0%,to{opacity:.35}50%{opacity:.85}}}.chat-form{display:grid;grid-template-columns:1fr auto auto;gap:12px;padding:28px 32px;border-top:1px solid var(--outline);background:var(--surface-low)}.quick-row{grid-column:1 / -1;display:flex;gap:10px}.chat-form input,.chat-form textarea{flex:1;min-width:0;min-height:48px;padding:12px 14px;border:1px solid var(--outline);border-radius:6px;background:#fff}.source-panel{padding:30px 24px;align-self:start;box-shadow:var(--shadow)}.understanding{position:relative;display:grid;grid-template-columns:1fr auto;gap:14px;margin:22px 0 28px;padding-bottom:14px;color:var(--ink);font-weight:700}.understanding:after{content:"";position:absolute;left:0;right:0;bottom:0;height:6px;border-radius:999px;background:var(--surface-high)}.understanding i{position:absolute;left:0;bottom:0;height:6px;border-radius:999px;background:var(--ink);z-index:1}.source-book{display:flex;gap:14px;align-items:center;margin:12px 0 26px;padding:16px;border:1px solid var(--surface-high);border-radius:4px;background:var(--surface-lowest)}.source-book>span{display:grid;place-items:center;width:48px;height:48px;background:var(--paper);color:var(--stone)}.source-book small{display:block;margin-top:4px;color:var(--muted)}.source-list{display:grid;gap:10px;margin-top:12px}.source-item{padding:12px;border-left:4px solid var(--jade);background:var(--surface);color:var(--muted);line-height:1.5}.challenge-card{padding:70px 62px}.reference-challenge{width:min(960px,100%);padding-top:40px;text-align:center}.challenge-progress-top{height:5px;margin-bottom:32px;overflow:hidden;border-radius:999px;background:var(--surface-high)}.challenge-progress-top span{display:block;height:100%;background:var(--ink)}.progress{height:8px;overflow:hidden;border-radius:999px;background:var(--surface-high)}.progress>span{display:block;height:100%;background:var(--ink-soft);transition:width .18s ease}.question{margin:0 0 42px;text-align:left;font:600 30px/1.45 "Noto Serif",serif;color:var(--ink)}.option{display:flex;gap:22px;align-items:center;width:100%;min-height:76px;padding:18px 22px;border:1px solid var(--outline);border-radius:6px;background:var(--surface);text-align:left;color:var(--text);font-size:21px}.option strong{display:grid;place-items:center;width:30px;height:30px;flex:0 0 auto;border:1px solid var(--outline);border-radius:50%}.option .material-symbols-outlined{margin-left:auto;color:var(--ink)}.option.active{border:2px solid var(--ink);background:#eef5ff;font-weight:700}.option.active strong{background:var(--ink);color:#fff;border-color:var(--ink)}.challenge-actions{display:flex;justify-content:space-between;gap:16px;margin-top:40px}.option.correct{border-color:#1f6f4373;background:#1f6f4317}.option.wrong{border-color:#ba1a1a73;background:#ba1a1a14}.result-list{display:grid;gap:12px;margin-top:18px}.leaderboard{overflow:hidden;margin-top:56px}.leader-row{display:grid;grid-template-columns:80px minmax(220px,1fr) 1fr 120px;gap:12px;align-items:center;padding:24px 30px;border-bottom:1px solid var(--surface-high)}.leader-row.header{background:var(--surface-low);color:var(--muted);font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.leader-row.current{background:#b8d7f5;border-top:3px solid var(--ink);border-bottom:3px solid var(--ink)}.rank{color:var(--ink);font:700 25px/1 "Noto Serif",serif}.reference-leaderboard{padding-top:100px}.reference-leaderboard .headline-lg{font-size:clamp(42px,5vw,56px)}.leader-tabs{display:flex;gap:34px;margin-top:70px;border-bottom:1px solid var(--outline)}.leader-tabs button{padding:0 22px 14px;border:0;border-bottom:2px solid transparent;background:transparent;color:var(--text);font-weight:700}.leader-tabs button.active{border-color:var(--ink)}.leader-name{display:flex;align-items:center;gap:18px}.leader-avatar{display:grid;place-items:center;width:48px;height:48px;border:1px solid var(--outline);border-radius:12px;background:var(--surface-high);color:var(--ink)}.profile-card{padding:22px}.profile-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-top:20px}.mobile-nav{position:fixed;inset:auto 0 0;display:grid;grid-template-columns:repeat(3,1fr);gap:4px;padding:9px 10px 12px;background:#fbf9f8f0;border-top:1px solid var(--outline);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);z-index:22}.mobile-nav a{display:grid;place-items:center;gap:3px;min-height:54px;color:var(--muted);text-decoration:none;border-radius:8px;font-size:11px;font-weight:700}.mobile-nav a.active{color:var(--ink);background:var(--paper)}@media (min-width: 860px){.side-nav{display:flex}.main{margin-left:320px;padding:104px 30px 48px}.topbar{left:320px;padding:12px 28px}.mobile-nav{display:none}.deck-layout{grid-template-columns:minmax(0,1fr)}.chat-layout{grid-template-columns:minmax(0,1fr) 340px}}@media (max-width: 859px){.chip{min-height:46px;font-size:16px}}:root{--surface: #efe1bd;--surface-lowest: #faf0d2;--surface-low: #e7d3a4;--surface-mid: #d6bd86;--surface-high: #b89b65;--paper: #ead7a7;--ink: #2c1c0d;--ink-soft: #4d3a22;--text: #2c1c0d;--muted: #6b5634;--outline: #b89b65;--cinnabar: #7a1c1c;--cinnabar-bright: #a52222;--cinnabar-deep: #5b0005;--gold: #c69a3e;--gold-soft: #d8b66a;--gold-bright: #e6c87c;--wood: #5a3a1f;--wood-light: #7a4f2c;--wood-dark: #3a2412;--jade: #4f6b58;--ink-15: rgba(44, 28, 13, .18);--ink-25: rgba(44, 28, 13, .28);--ink-40: rgba(44, 28, 13, .42);--shadow: 0 8px 24px -8px rgba(74, 51, 28, .32), 0 2px 4px rgba(74, 51, 28, .16);--shadow-deep: 0 16px 40px -12px rgba(58, 36, 18, .45), 0 4px 8px rgba(58, 36, 18, .18);--paper-grain: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180' viewBox='0 0 180 180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.92' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.3  0 0 0 0 0.18  0 0 0 0 0.05  0 0 0 0.5 0'/></filter><rect width='180' height='180' filter='url(%23n)' opacity='0.18'/></svg>")}.material-symbols-outlined{font-family:Material Symbols Outlined!important;letter-spacing:0!important;text-transform:none!important;font-style:normal!important;font-feature-settings:"liga";font-variant-ligatures:normal}body{background-color:var(--surface);background-image:radial-gradient(ellipse at center,transparent 0%,rgba(122,79,44,.06) 55%,rgba(74,51,28,.18) 100%),repeating-linear-gradient(90deg,rgba(122,79,44,.012) 0 2px,transparent 2px 5px),var(--paper-grain);background-attachment:fixed,fixed,fixed;font-family:Be Vietnam Pro,"Noto Serif",serif;color:var(--ink)}h1,h2,h3,.headline-lg,.brand-title{font-family:"Noto Serif",serif;color:var(--cinnabar);letter-spacing:.01em}.headline-lg{font-weight:700;letter-spacing:.04em;text-shadow:0 1px 0 rgba(255,244,214,.4)}.kicker{color:var(--cinnabar-bright);font-family:"Noto Serif",serif;font-size:12px;letter-spacing:.22em;text-transform:uppercase;font-weight:600}.lead{color:var(--ink-soft);font-family:Be Vietnam Pro,sans-serif;line-height:1.6}small,.collection-body small{color:var(--muted)}.side-nav{background:linear-gradient(180deg,#d6bd868c,#efe1bdf2 18%,#efe1bdf2 82%,#d6bd868c);border-right:1px solid var(--wood);box-shadow:inset -4px 0 0 -2px var(--gold-soft);padding-top:96px}.side-nav:before{content:"";position:absolute;top:18px;left:28px;right:28px;height:1px;background:linear-gradient(to right,transparent,var(--wood-light) 12%,var(--wood) 50%,var(--wood-light) 88%,transparent)}.brand{margin-bottom:28px;position:relative}.brand-title{font-family:"Noto Serif",serif;font-weight:700;font-size:32px;color:var(--cinnabar-deep);letter-spacing:.05em;margin:0;position:relative;display:inline-block}.brand-title:after{content:"印";position:absolute;right:-28px;top:4px;width:22px;height:22px;background:var(--cinnabar-bright);color:var(--surface-lowest);font-family:"Noto Serif",serif;font-size:13px;font-weight:700;display:grid;place-items:center;border-radius:3px;transform:rotate(-4deg);box-shadow:0 1px #0003}.brand-subtitle{color:var(--wood);font-family:"Noto Serif",serif;font-style:italic;font-weight:500;letter-spacing:.04em;margin:6px 0 0}.nav-link{font-family:Be Vietnam Pro,sans-serif;color:var(--ink-soft);font-weight:500;border-radius:8px;padding:10px 14px;transition:background .16s ease,color .16s ease}.nav-link:hover{background:#7a4f2c14;color:var(--cinnabar)}.nav-link.active{background:linear-gradient(90deg,#a6292924,#a629290a 80%);color:var(--cinnabar);font-weight:600;box-shadow:inset 3px 0 0 var(--cinnabar-bright);border-radius:4px 8px 8px 4px}.nav-link .material-symbols-outlined{color:var(--gold)}.nav-link.active .material-symbols-outlined{color:var(--cinnabar-bright)}.topbar{background:linear-gradient(180deg,#faf0d2e0,#e7d3a4e0);border-bottom:1px solid var(--wood-light);box-shadow:0 1px 0 var(--gold-soft),0 4px 12px -8px #3a241240}.global-sound-toggle{background:linear-gradient(180deg,var(--surface-lowest),var(--surface-low));border:1px solid var(--wood-light);color:var(--cinnabar);font-family:"Noto Serif",serif;font-weight:700;box-shadow:inset 0 1px #fff8dce6,0 2px 4px #3a24121f;transition:background .16s ease,color .16s ease,transform .16s ease}.global-sound-toggle:hover{transform:translateY(-1px);background:linear-gradient(180deg,#fff6db,var(--surface-low))}.global-sound-toggle.is-on{border-color:#4f6b58ad;color:var(--jade);box-shadow:inset 0 1px #fff8dce6,0 0 0 3px #4f6b581a,0 2px 4px #3a24121f}.global-sound-toggle:focus-visible{outline:2px solid var(--gold);outline-offset:3px}.topbar-metrics .metric{background:var(--surface-lowest);border:1px solid var(--wood-light);border-radius:999px;padding:8px 16px;font-family:"Noto Serif",serif;font-weight:600;color:var(--cinnabar);box-shadow:inset 0 1px #fff8dce6,0 2px 4px #3a24121f}.topbar-metrics .metric .material-symbols-outlined{color:var(--gold);font-size:20px}.card{background:linear-gradient(180deg,var(--surface-lowest),var(--paper));background-blend-mode:multiply;border:1px solid var(--wood-light);box-shadow:inset 0 0 0 1px #e7d3a4b3,inset 0 0 0 5px var(--surface-lowest),inset 0 0 0 6px var(--gold-soft),var(--shadow);border-radius:8px;position:relative}.card:before,.card:after{content:"";position:absolute;width:14px;height:14px;border:2px solid var(--cinnabar);pointer-events:none}.card:before{top:10px;left:10px;border-right:none;border-bottom:none}.card:after{bottom:10px;right:10px;border-left:none;border-top:none}.deck-card .deck-body{background:transparent;padding-top:22px}.deck-card .quote{font-family:"Noto Serif",serif;font-style:italic;color:var(--cinnabar-deep);border-left:3px double var(--cinnabar);padding-left:16px;background:linear-gradient(90deg,rgba(166,41,41,.06),transparent 80%)}.deck-card .deck-bio{color:var(--ink-soft);font-family:Be Vietnam Pro,sans-serif}.conflict-tile{background:linear-gradient(180deg,var(--surface-lowest),var(--surface-low));border:1px solid var(--wood-light);border-radius:6px;box-shadow:inset 0 0 0 1px var(--gold-soft)}.conflict-tile>span{font-family:"Noto Serif",serif;letter-spacing:.18em;color:var(--gold);text-transform:uppercase}.conflict-tile strong{color:var(--cinnabar);font-family:"Noto Serif",serif}.conflict-tile .material-symbols-outlined{color:var(--cinnabar-bright);text-transform:none;letter-spacing:0;font-family:Material Symbols Outlined}.trait-row span{background:var(--surface-lowest);border:1px solid var(--wood-light);color:var(--ink-soft);font-family:"Noto Serif",serif;font-style:italic;padding:4px 12px;box-shadow:0 1px 0 var(--gold-soft)}.art.image-art img{filter:sepia(.18) saturate(1.05) contrast(1.04)}.profile-gallery:before{height:150px;background:linear-gradient(to bottom,transparent,rgba(44,28,13,.34) 68%,rgba(44,28,13,.58))}.profile-gallery .tag{left:auto;right:24px}.gallery-arrow{background:linear-gradient(180deg,#faf0d2db,#d6bd86c7);border-color:var(--wood-light);color:var(--cinnabar);box-shadow:inset 0 1px #fff8dcd1,0 8px 18px #2c1c0d47}.gallery-arrow:hover{background:var(--surface-lowest)}.gallery-dots{padding:8px 12px;border:1px solid rgba(250,240,210,.5);border-radius:999px;background:#2c1c0d61;box-shadow:0 8px 18px #2c1c0d33}.gallery-dots button{background:#faf0d27a}.gallery-dots button.active{background:var(--gold-bright)}.art.image-art:after{content:"";position:absolute;top:8px;right:8px;bottom:8px;left:8px;border:1px solid var(--gold-soft);pointer-events:none;z-index:2}.art .tag{background:var(--cinnabar-bright);color:var(--surface-lowest);font-family:"Noto Serif",serif;font-weight:700;letter-spacing:.16em;text-transform:uppercase;border:1px solid var(--surface-lowest);box-shadow:0 0 0 1px var(--cinnabar)}.btn{font-family:"Noto Serif",serif;letter-spacing:.04em;border-radius:6px;transition:transform .12s ease,box-shadow .12s ease,background .16s ease,color .16s ease}.btn.primary{background:linear-gradient(180deg,var(--cinnabar-bright),var(--cinnabar-deep));color:var(--surface-lowest);border:1px solid var(--cinnabar-deep);box-shadow:inset 0 1px #ffdcb459,inset 0 -2px #0000002e,0 2px 6px #5b000559;font-weight:600}.btn.primary:hover{background:linear-gradient(180deg,#c33333,var(--cinnabar));transform:translateY(-1px)}.btn.secondary{background:linear-gradient(180deg,var(--surface-lowest),var(--surface-low));color:var(--cinnabar);border:1px solid var(--wood-light);box-shadow:inset 0 0 0 1px var(--gold-soft)}.btn.secondary:hover{background:linear-gradient(180deg,var(--surface-low),var(--surface-mid))}.btn.ghost{background:transparent;color:var(--ink-soft);border:1px dashed var(--wood-light)}.btn.ghost:hover{background:#7a4f2c14;color:var(--cinnabar)}.btn.circle{border-radius:999px;width:60px;height:60px}.btn.circle.primary{box-shadow:inset 0 2px #ffdcb466,inset 0 -3px #0003,0 4px 12px #5b000566}.btn.circle.ghost{background:var(--surface-lowest);border:1px solid var(--wood-light)}.panel.stat{background:linear-gradient(180deg,var(--surface-lowest),var(--paper));border:1px solid var(--wood-light);box-shadow:inset 0 0 0 1px var(--gold-soft);border-radius:6px;text-align:center}.panel.stat strong{font-family:"Noto Serif",serif;color:var(--cinnabar);font-size:28px}.panel.stat span{font-family:"Noto Serif",serif;color:var(--muted);font-style:italic;letter-spacing:.06em}.source-panel{background:linear-gradient(180deg,#faf0d2f2,#e7d3a4d9);border:1px solid var(--wood-light);box-shadow:inset 0 0 0 1px var(--gold-soft),var(--shadow)}.source-panel h2{color:var(--cinnabar);font-family:"Noto Serif",serif}.source-book{background:var(--surface-lowest);border:1px solid var(--wood-light);box-shadow:inset 0 0 0 1px var(--gold-soft)}.source-book strong{color:var(--cinnabar);font-family:"Noto Serif",serif}.source-book .material-symbols-outlined{color:var(--gold)}.source-list .source-item{background:linear-gradient(90deg,rgba(166,41,41,.05),transparent);border-left:2px solid var(--cinnabar);color:var(--ink-soft);font-family:Be Vietnam Pro,sans-serif;font-size:14px;padding:10px 12px}.collection-card{border-radius:6px}.collection-card .collection-image{background:var(--wood-dark);border-bottom:1px solid var(--wood)}.collection-card .collection-image img{filter:sepia(.15) contrast(1.05)}.collection-status{background:var(--surface-lowest);border:1px solid var(--wood-light);color:var(--cinnabar);font-family:"Noto Serif",serif;font-weight:600;letter-spacing:.12em;text-transform:uppercase;padding:3px 8px;font-size:9.5px}.collection-status .material-symbols-outlined{color:var(--gold)}.collection-status svg{color:var(--gold);width:12px;height:12px}.collection-status.level-1{background:linear-gradient(180deg,var(--surface-lowest),var(--paper));border-color:var(--wood-light);color:var(--cinnabar)}.collection-status.level-2{background:linear-gradient(180deg,var(--gold-bright),var(--gold));border-color:var(--cinnabar);color:var(--cinnabar-deep)}.collection-status.level-2 svg{color:var(--cinnabar-deep)}.collection-status.level-3{background:linear-gradient(180deg,var(--cinnabar-bright),var(--cinnabar-deep));border-color:var(--gold-bright);color:var(--gold-bright);font-weight:700;box-shadow:inset 0 0 0 1px #e6c87c59,0 2px 8px #5b00054d}.collection-status.level-3 svg{color:var(--gold-bright)}.collection-progress{background:#7a4f2c2e;height:6px;border-radius:3px;border:1px solid var(--wood-light)}.collection-progress span{background:linear-gradient(90deg,var(--gold),var(--cinnabar-bright));border-radius:3px;height:100%;display:block}.badge{background:var(--surface-lowest);border:1px solid var(--wood-light);font-family:"Noto Serif",serif;font-style:italic;font-size:12px;letter-spacing:.04em;color:var(--ink-soft)}.badge.done{background:linear-gradient(180deg,#f3d777,var(--gold));border-color:var(--cinnabar);color:var(--cinnabar-deep);font-weight:600}.badge.pending{background:var(--surface-lowest);color:var(--muted)}.chat-card{background:linear-gradient(180deg,var(--surface-lowest),var(--paper));border:1px solid var(--wood-light);box-shadow:inset 0 0 0 1px var(--gold-soft),var(--shadow)}.chat-header{border-bottom:1px dashed var(--wood-light)}.chat-thread{gap:24px;padding:48px 40px 44px}.chat-identity{display:flex;align-items:center;gap:14px;min-width:0}.chat-identity h1{font-size:30px;line-height:1.08}.chat-identity p{display:flex;align-items:center;margin:6px 0 0;color:var(--muted);font-family:Be Vietnam Pro,sans-serif;font-weight:600}.character-profile-card{display:inline-flex;align-items:center;gap:10px;max-width:220px;min-height:44px;padding:8px 14px;border:1px solid var(--wood-light);border-radius:999px;background:linear-gradient(180deg,#faf0d2f5,#e7d3a4c7);box-shadow:inset 0 0 0 1px var(--gold-soft);color:var(--gold)}.character-profile-card span{display:grid;gap:1px;min-width:0}.character-profile-card strong{overflow:hidden;color:var(--cinnabar);font-family:"Noto Serif",serif;font-style:italic;line-height:1.1;text-overflow:ellipsis;white-space:nowrap}.character-profile-card small{overflow:hidden;color:var(--muted);font-size:11px;line-height:1.1;text-overflow:ellipsis;white-space:nowrap}.chapter-pill{background:linear-gradient(180deg,var(--surface-lowest),var(--surface-low));border:1px solid var(--wood-light);box-shadow:inset 0 0 0 1px var(--gold-soft);color:var(--cinnabar);font-family:"Noto Serif",serif;font-style:italic;letter-spacing:.16em;text-transform:uppercase;font-size:11px;padding:6px 16px;border-radius:999px}.message.user{background:linear-gradient(180deg,var(--cinnabar),var(--cinnabar-deep));color:var(--surface-lowest);border:1px solid var(--cinnabar-deep);box-shadow:inset 0 1px #ffdcb440,0 2px 4px #5b000533;font-family:"Noto Serif",serif}.message.bot{background:var(--surface-lowest);border:1px solid var(--wood-light);box-shadow:inset 0 0 0 1px var(--gold-soft);color:var(--ink);font-family:"Noto Serif",serif}.work-pill{background:var(--surface-lowest);border:1px solid var(--wood-light);color:var(--cinnabar);font-family:"Noto Serif",serif;font-style:italic;font-weight:600}.work-pill .material-symbols-outlined{color:var(--gold)}.chat-form{background:linear-gradient(180deg,transparent,rgba(231,211,164,.4));border-top:1px dashed var(--wood-light)}.chat-form input,.chat-form textarea{background:var(--surface-lowest);border:1px solid var(--wood-light);box-shadow:inset 0 1px 2px #3a24121f;font-family:"Noto Serif",serif;color:var(--ink)}.chat-form textarea{max-height:132px;line-height:1.45;overflow-y:auto;resize:vertical;white-space:pre-wrap}.chat-form input::-moz-placeholder,.chat-form textarea::-moz-placeholder{color:var(--muted);font-style:italic}.chat-form input::placeholder,.chat-form textarea::placeholder{color:var(--muted);font-style:italic}.literary-chat-form{align-items:center}.literary-chat-form .quick-row{align-items:center;flex-wrap:wrap;gap:8px}.chip{background:linear-gradient(180deg,var(--surface-lowest),var(--surface-low));border:1px solid var(--wood-light);color:var(--cinnabar);font-family:"Noto Serif",serif;font-style:italic;letter-spacing:.04em}.literary-chip{min-height:36px;padding:7px 14px;border-radius:999px;font-size:14px;line-height:1.25;text-align:left;white-space:normal}.chip:hover,.chip.active{background:linear-gradient(180deg,var(--gold-bright),var(--gold));border-color:var(--cinnabar);color:var(--cinnabar-deep)}.online-dot{background:var(--cinnabar-bright);box-shadow:0 0 0 3px #a5222240}.typing-line{color:var(--muted);font-family:"Noto Serif",serif;font-style:italic}.deeper-button,.send-button{min-height:48px;white-space:nowrap}.send-button{padding-inline:16px;border-style:solid;background:#faf0d273}.insight-panel{display:grid;gap:28px;padding:28px 24px}.insight-panel section{display:grid;gap:14px}.insight-panel h2{font-size:22px;line-height:1.18}.theme-tags{display:flex;flex-wrap:wrap;gap:8px}.theme-tags button,.symbol-list button{border:1px solid var(--wood-light);background:#faf0d2b8;color:var(--ink-soft);cursor:pointer;font:inherit;transition:background .16s ease,border-color .16s ease,color .16s ease,transform .12s ease}.theme-tags button:hover,.symbol-list button:hover{border-color:var(--cinnabar);background:#e6c87c6b;color:var(--cinnabar-deep);transform:translateY(-1px)}.theme-tags button{min-height:32px;padding:6px 11px;border-radius:999px;font-family:"Noto Serif",serif;font-size:14px;font-weight:700}.symbol-list{display:grid;gap:9px}.symbol-list button{display:flex;align-items:center;justify-content:space-between;min-height:42px;padding:9px 12px;border-radius:6px;font-family:Be Vietnam Pro,sans-serif;text-align:left}.symbol-list button:after{content:"→";color:var(--gold);font-family:"Noto Serif",serif}@media (max-width: 859px){.chat-card{min-height:auto}.chat-header{align-items:flex-start;flex-direction:column;padding:22px}.character-profile-card{max-width:100%}.chat-thread{gap:20px;padding:32px 20px}.message{max-width:100%;padding:18px 20px;font-size:16px}.literary-chat-form{grid-template-columns:1fr;padding:22px}.deeper-button,.send-button{width:100%}.insight-panel{padding:24px 20px}}.understanding{background:linear-gradient(90deg,var(--surface-low),var(--surface-lowest));border:1px solid var(--wood-light);color:var(--ink-soft);font-family:"Noto Serif",serif}.understanding strong{color:var(--cinnabar)}.understanding i{background:linear-gradient(90deg,var(--gold),var(--cinnabar-bright))}.challenge-progress-top{background:#7a4f2c2e;border:1px solid var(--wood-light)}.challenge-progress-top span{background:linear-gradient(90deg,var(--gold),var(--cinnabar-bright))}.reference-challenge .headline-lg{margin:0 0 clamp(24px,3.2vw,42px)}.challenge-card{padding-block:clamp(54px,6vw,76px)}.challenge-card .question{font-family:"Noto Serif",serif;color:var(--cinnabar-deep);font-weight:600;margin-bottom:clamp(34px,4vw,48px)}.challenge-phase-copy{margin-top:6px;color:var(--muted)}.challenge-level-preview{display:flex;align-items:center;gap:14px;width:-moz-fit-content;width:fit-content;max-width:100%;margin:-22px auto 28px;padding:10px 14px 10px 10px;border:1px solid var(--wood-light);border-radius:8px;background:linear-gradient(180deg,var(--surface-lowest),var(--paper));box-shadow:inset 0 0 0 1px var(--gold-soft);color:var(--cinnabar-deep);font-family:"Noto Serif",serif;font-weight:700}.challenge-level-preview img{width:58px;height:58px;flex:0 0 auto;border-radius:6px;-o-object-fit:cover;object-fit:cover;-o-object-position:top center;object-position:top center;border:1px solid var(--gold-soft)}.question-progress{display:flex;flex-direction:column;align-items:center;gap:8px;margin:0 auto clamp(20px,2.6vw,28px)}.question-pips{list-style:none;display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin:0;padding:0}.question-pip{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;border:1px solid var(--wood-light);background:linear-gradient(180deg,var(--surface-lowest),var(--paper));box-shadow:inset 0 0 0 1px var(--gold-soft);color:var(--muted);font-family:"Noto Serif",serif;font-weight:800;font-size:15px;line-height:1;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}.question-pip:hover{transform:translateY(-1px);border-color:var(--cinnabar-bright)}.question-pip:focus-visible{outline:2px solid var(--gold);outline-offset:2px}.question-pip.answered{border-color:var(--cinnabar);background:linear-gradient(180deg,#f3d777,var(--gold));color:var(--cinnabar-deep)}.question-pip.current{border-color:var(--cinnabar-deep);background:linear-gradient(180deg,var(--cinnabar-bright),var(--cinnabar-deep));color:var(--surface-lowest);box-shadow:inset 0 0 0 1px #fff6,0 4px 12px #5b00052e}.question-progress-caption{margin:0;font-family:"Noto Serif",serif;font-size:13px;letter-spacing:.04em;color:var(--muted)}.open-answer-block{display:grid;gap:14px}.open-answer-block textarea{width:100%;min-height:150px;resize:vertical;border:1px solid var(--wood-light);border-radius:8px;background:var(--surface-lowest);color:var(--ink);padding:18px 20px;font:500 18px/1.6 "Noto Serif",serif;box-shadow:inset 0 0 0 1px var(--gold-soft)}.open-answer-block textarea:focus{outline:2px solid var(--gold);outline-offset:2px}.form-error{max-width:820px;margin:-14px auto 18px;color:var(--cinnabar-deep);font-weight:700;text-align:center}.level-up-banner{display:flex;align-items:center;justify-content:center;gap:10px;margin:18px auto;width:-moz-fit-content;width:fit-content;max-width:100%;padding:12px 18px;border:1px solid var(--cinnabar);border-radius:8px;background:linear-gradient(180deg,#fff4cf,var(--gold-soft));color:var(--cinnabar-deep);font-family:"Noto Serif",serif;font-weight:800;box-shadow:inset 0 0 0 1px #ffffff8c,0 8px 24px #5b000529;animation:level-up-rise .56s ease-out both}@keyframes level-up-rise{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.option{background:linear-gradient(180deg,var(--surface-lowest),var(--paper));border:1px solid var(--wood-light);box-shadow:inset 0 0 0 1px var(--gold-soft);color:var(--ink);font-family:"Noto Serif",serif;transition:transform .12s ease,box-shadow .12s ease}.option strong{background:linear-gradient(180deg,var(--gold),var(--gold-soft));color:var(--cinnabar-deep);border:1px solid var(--cinnabar);font-family:"Noto Serif",serif}.option:hover{transform:translate(2px);border-color:var(--cinnabar-bright)}.option.active{background:linear-gradient(180deg,#fce6b8,var(--gold-soft));border-color:var(--cinnabar);box-shadow:inset 0 0 0 1px var(--cinnabar),0 2px 6px #5b00052e}.option.active strong{background:linear-gradient(180deg,var(--cinnabar-bright),var(--cinnabar-deep));color:var(--surface-lowest)}.option .material-symbols-outlined{color:var(--cinnabar-bright)}.challenge-stage{position:relative;isolation:isolate;display:grid;align-items:center;width:auto;max-width:none;min-height:100dvh;margin:-86px -18px -112px;padding:clamp(116px,14vh,152px) 18px 96px;overflow:hidden;text-align:left}.challenge-stage:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:-3;background-image:var(--challenge-bg-image);background-position:center center;background-size:cover;filter:blur(22px) saturate(1.08);transform:scale(1.08)}.challenge-stage-art{position:absolute;top:0;right:0;bottom:0;left:0;z-index:-2;pointer-events:none;background-image:var(--challenge-bg-image);background-position:center center;background-repeat:no-repeat;background-size:auto 100%}.challenge-stage:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:-1;background:linear-gradient(180deg,#140f0a47,#140f0a2e 42%,#140f0a99),linear-gradient(90deg,#140f0a8f,#2f221542 44%,#f6e8c138)}.challenge-stage-inner{width:min(680px,100%);margin:0 auto;color:var(--surface-lowest)}.challenge-hero{display:grid;gap:10px;margin-bottom:clamp(18px,3vw,28px);text-align:left;text-shadow:0 2px 18px rgba(0,0,0,.42)}.challenge-eyebrow{margin:0;color:#fff8e2d1;font-family:Be Vietnam Pro,sans-serif;font-size:12px;font-weight:700;letter-spacing:0;text-transform:uppercase}.challenge-stage .headline-lg{margin:0;color:var(--surface-lowest);font-size:clamp(42px,5vw,64px);line-height:1.05}.challenge-level-strip{display:flex;align-items:center;justify-content:space-between;gap:16px;width:-moz-fit-content;width:fit-content;max-width:100%;padding:8px 10px 8px 14px;border:1px solid rgba(246,232,193,.34);border-radius:999px;background:#18120c5c;box-shadow:inset 0 1px #ffffff29;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.challenge-level-strip p{margin:0;color:#fff8e2f0;font-family:"Noto Serif",serif;font-size:14px;font-weight:700;line-height:1.25}.challenge-level-strip .level-progress.compact{margin:0}.challenge-question-meta{display:grid;grid-template-columns:auto minmax(120px,1fr);align-items:center;gap:14px;margin:0 0 12px;color:#fff8e2e6;font-family:Be Vietnam Pro,sans-serif;font-size:13px;font-weight:700;text-shadow:0 1px 12px rgba(0,0,0,.36)}.challenge-stage .challenge-progress-top{height:4px;min-width:0;overflow:hidden;border:0;border-radius:999px;background:#fff8e247}.challenge-stage .challenge-progress-top span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#ffe08a,#b92e2e)}.challenge-question-card{padding:clamp(26px,4vw,38px);border-color:#fff8e280;background:linear-gradient(180deg,#fff8e2e6,#efddaad6);box-shadow:inset 0 1px #ffffff8a,0 24px 70px #140f0a5c;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.challenge-question-card.card:before,.challenge-question-card.card:after{display:none}.challenge-question-card .question{margin-bottom:clamp(22px,3vw,30px);color:#661f1c;font-size:clamp(26px,3vw,34px);line-height:1.34}.challenge-stage .info-stack{gap:10px}.challenge-stage .option{min-height:64px;gap:16px;padding:15px 16px;border-color:#74522952;border-radius:8px;background:#fffcf09e;box-shadow:none;color:var(--ink);font-size:clamp(17px,1.7vw,20px);line-height:1.45}.challenge-stage .option span{flex:1 1 auto}.challenge-stage .option strong{width:32px;height:32px;background:#7a4f2c17;border-color:#7a4f2c5c;color:#661f1c}.challenge-stage .option:hover{transform:translateY(-1px);border-color:#a6292980;background:#fffcf0d1}.challenge-stage .option.active{border-color:#a62929d1;background:#ffe8b7c2;box-shadow:0 8px 24px #5b00051f}.challenge-stage .option.active strong{background:linear-gradient(180deg,var(--cinnabar-bright),var(--cinnabar-deep));border-color:var(--cinnabar-deep);color:var(--surface-lowest)}.challenge-stage .option svg{flex:0 0 auto;margin-left:auto;color:var(--cinnabar)}.challenge-stage .open-answer-block textarea{background:#fffcf0b8;box-shadow:none}.challenge-stage .form-error{margin:14px 0 0;color:#fff4cf;text-align:left;text-shadow:0 1px 10px rgba(0,0,0,.45)}.challenge-stage .challenge-actions{justify-content:flex-end;margin-top:18px}.challenge-result-stage{align-items:start;overflow-y:auto}.challenge-result-stage:after{background:linear-gradient(180deg,#140f0a57,#140f0a33 34%,#140f0ab8),linear-gradient(90deg,#140f0a9e,#2f221552 48%,#f6e8c12e)}.challenge-result-stage .result-stage-inner{display:grid;gap:16px;width:min(1080px,100%)}.result-hero{margin-bottom:0}.result-hero .headline-lg{max-width:980px}.result-phase-copy,.result-message{max-width:780px;margin:0;color:#fff8e2e0;text-shadow:0 1px 12px rgba(0,0,0,.42)}.result-phase-copy{font-family:"Noto Serif",serif;font-size:clamp(18px,2vw,22px);font-weight:600;line-height:1.35}.result-message{font-size:16px}.result-level-progress{width:min(860px,100%);margin:4px 0 0}.result-level-progress .level-step{border-color:#f6e8c16b;background:linear-gradient(180deg,#fff8e2e6,#efddaac7);box-shadow:inset 0 1px #ffffff80,0 10px 24px #140f0a2e}.result-unlock-banner{width:-moz-fit-content;width:fit-content;max-width:100%;margin:0;border-color:#ffe08a9e;background:linear-gradient(180deg,#ffeeb8e0,#e2b958b8);box-shadow:inset 0 1px #ffffff7a,0 14px 34px #140f0a42}.result-stat-grid{grid-template-columns:repeat(3,minmax(0,1fr));margin-top:0}.result-stat{border-color:#fff8e275;background:linear-gradient(180deg,#fff8e2e6,#efddaac7);box-shadow:inset 0 1px #ffffff8a,0 14px 34px #140f0a33}.result-stat strong{color:var(--cinnabar-deep);font-size:clamp(26px,3vw,34px)}.result-stat span{color:var(--muted);font-family:"Noto Serif",serif;font-size:13px;font-style:italic}.result-question-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(128px,1fr));gap:10px}.result-question-tab{display:grid;align-content:center;gap:7px;min-height:86px;min-width:0;padding:12px;border:1px solid rgba(255,248,226,.44);border-radius:8px;background:linear-gradient(180deg,#fff8e2cc,#efddaa9e);box-shadow:inset 0 1px #ffffff7a,0 10px 24px #140f0a2e;color:var(--ink);text-align:left;transition:transform .16s ease,border-color .16s ease,background .16s ease,box-shadow .16s ease}.result-question-tab:hover{transform:translateY(-1px);border-color:#ffe08ab8}.result-question-tab span{color:var(--muted);font-family:Be Vietnam Pro,sans-serif;font-size:12px;font-weight:800;letter-spacing:0;text-transform:uppercase}.result-question-tab strong{min-width:0;color:var(--cinnabar-deep);font-family:"Noto Serif",serif;font-size:clamp(17px,1.7vw,22px);line-height:1.15}.result-question-tab.needs-review{background:linear-gradient(180deg,#fff4e5db,#8f1d202e)}.result-question-tab.active{border-color:#ffe08adb;background:linear-gradient(180deg,#ffe8b7f0,#d8b66ad6);box-shadow:inset 0 0 0 1px #8f1d206b,0 18px 42px #140f0a47}.result-question-tab.active strong{color:var(--cinnabar)}.result-review-panel{padding:clamp(22px,3vw,32px);border-color:#fff8e285;background:linear-gradient(180deg,#fff8e2f0,#efddaadb);box-shadow:inset 0 1px #ffffff8a,0 24px 70px #140f0a57;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.result-review-panel h3{margin-top:0}.result-review-panel>p{margin-top:0;color:var(--ink-soft);font-size:clamp(18px,2vw,22px);line-height:1.45}.result-actions{justify-content:flex-end;margin-top:2px}.result-actions .btn.ghost{border-color:#fff8e25c;color:var(--surface-lowest)}.result-actions .btn.secondary{border-color:#fff8e270;background:#fff8e2c7}.info-block{background:linear-gradient(180deg,var(--surface-lowest),var(--paper));border:1px solid var(--wood-light);box-shadow:inset 0 0 0 1px var(--gold-soft);border-radius:6px}.info-block h3{color:var(--cinnabar);font-family:"Noto Serif",serif;letter-spacing:.06em}.result-list .info-block p{color:var(--ink-soft)}.answer-review-options{display:grid;gap:8px;margin:12px 0 10px;padding:0;list-style:none}.answer-review-option{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:10px;padding:10px 12px;border:1px solid rgba(122,79,44,.28);border-radius:6px;background:linear-gradient(180deg,#fffbeeeb,#f4e0ad57);color:var(--ink-soft);font-family:"Noto Serif",serif;line-height:1.45}.answer-review-option strong{display:grid;place-items:center;width:28px;height:28px;border:1px solid var(--wood-light);border-radius:50%;background:var(--surface-lowest);color:var(--cinnabar-deep);font-size:14px;line-height:1}.answer-review-option.correct{border-color:var(--cinnabar);background:linear-gradient(180deg,#fff4cf,#e6b94d4d);box-shadow:inset 0 0 0 1px #8f1d202e}.answer-review-option.correct strong{border-color:var(--cinnabar);background:linear-gradient(180deg,var(--cinnabar-bright),var(--cinnabar-deep));color:var(--surface-lowest)}.answer-review-option.picked-wrong{border-color:#8f1d206b;background:linear-gradient(180deg,#fff4e5f0,#8f1d2014)}.answer-review-text{min-width:0}.answer-review-badges{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:6px}.answer-review-badge{display:inline-flex;align-items:center;gap:4px;min-height:24px;padding:3px 8px;border-radius:999px;font-family:Be Vietnam Pro,sans-serif;font-size:11px;font-weight:800;line-height:1;white-space:nowrap}.answer-review-badge.picked{border:1px solid rgba(122,79,44,.34);background:#fffbeed1;color:var(--ink-soft)}.answer-review-badge.correct{border:1px solid var(--cinnabar);background:var(--cinnabar-deep);color:var(--surface-lowest)}.result-review-panel>.answer-review-note,.result-review-panel>.answer-review-evidence{margin-top:8px;font-family:"Noto Serif",serif;font-size:clamp(16px,1.55vw,18px);font-weight:500;line-height:1.5}.open-grade-summary{display:grid;gap:10px;margin:0}.open-grade-row{display:grid;gap:3px}.open-grade-row dt{color:var(--cinnabar);font-family:Be Vietnam Pro,sans-serif;font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.open-grade-row dd{margin:0;color:var(--ink-soft);line-height:1.55}@media (max-width: 720px){.reference-challenge .headline-lg{margin-bottom:24px}.challenge-card{padding-block:46px}.challenge-result-stage .result-stage-inner{gap:14px}.result-hero .headline-lg{margin-bottom:0}.result-stat-grid{grid-template-columns:1fr}.result-stat{padding:12px}.result-question-strip{grid-template-columns:repeat(2,minmax(0,1fr))}.result-question-tab{min-height:74px;padding:10px}.result-question-tab strong{font-size:17px}.result-review-panel{padding:20px 14px}.result-actions{flex-direction:column;align-items:stretch}.result-actions .btn{width:100%}.answer-review-option{grid-template-columns:auto minmax(0,1fr)}.answer-review-badges{grid-column:2;justify-content:flex-start}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}.level-progress{list-style:none;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin:0 0 clamp(22px,3vw,32px);padding:0}.level-step{display:flex;align-items:center;gap:10px;min-width:0;padding:10px 12px;border:1px solid var(--wood-light);border-radius:8px;background:linear-gradient(180deg,var(--surface-lowest),var(--paper));box-shadow:inset 0 0 0 1px var(--gold-soft);text-align:left}.level-step-dot{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;border:1px solid var(--wood-light);background:var(--surface-lowest);color:var(--muted);font-family:"Noto Serif",serif;font-weight:800;font-size:15px;line-height:1}.level-step-body{display:flex;flex-direction:column;min-width:0}.level-step-kicker{font-family:"Noto Serif",serif;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}.level-step-title{font-family:"Noto Serif",serif;font-weight:600;font-size:13px;line-height:1.3;color:var(--ink);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.level-step.done{border-color:var(--cinnabar)}.level-step.done .level-step-dot{background:linear-gradient(180deg,#f3d777,var(--gold));border-color:var(--cinnabar);color:var(--cinnabar-deep)}.level-step.done .level-step-title{color:var(--cinnabar-deep)}.level-step.active{border-color:var(--cinnabar-bright);box-shadow:inset 0 0 0 1px var(--cinnabar),0 4px 14px #5b00051f}.level-step.active .level-step-dot{background:linear-gradient(180deg,var(--cinnabar-bright),var(--cinnabar-deep));border-color:var(--cinnabar-deep);color:var(--surface-lowest);animation:level-step-pulse 2.4s ease-in-out infinite}.level-step.locked{opacity:.7}@keyframes level-step-pulse{0%,to{box-shadow:0 0 #5b000500}50%{box-shadow:0 0 0 4px #5b000524}}.level-progress.compact{display:flex;gap:8px;margin:6px 0 8px}.level-progress.compact .level-step{flex:0 0 auto;gap:0;padding:2px;border:none;background:none;box-shadow:none}.level-progress.compact .level-step-dot{width:24px;height:24px;font-size:12px}.challenge-level-progress{margin-top:clamp(-8px,0vw,0px)}.challenge-stage .challenge-level-progress{margin:0}.profile-level-progress{margin:4px 0 clamp(18px,2.4vw,26px)}@media (min-width: 860px){.challenge-stage{min-height:100dvh;margin:-104px -30px -48px;padding:clamp(130px,14vh,168px) 30px 76px}}@media (prefers-reduced-motion: reduce){.level-step.active .level-step-dot{animation:none}}@media (max-width: 720px){.challenge-stage{align-items:start}.challenge-stage-inner{width:100%}.challenge-stage .headline-lg{font-size:40px}.challenge-level-strip{align-items:flex-start;border-radius:14px;flex-direction:column;gap:8px}.challenge-question-meta{grid-template-columns:1fr;gap:8px}.challenge-question-card{padding:24px 18px}.challenge-question-card .question{font-size:25px}.challenge-stage .option{align-items:flex-start;min-height:0;padding:14px;font-size:17px}.challenge-stage .challenge-actions .btn{width:100%}.level-progress:not(.compact){gap:8px}.level-progress:not(.compact) .level-step{flex-direction:column;align-items:center;text-align:center;gap:6px;padding:10px 6px}.level-progress:not(.compact) .level-step-kicker{font-size:9px}.level-progress:not(.compact) .level-step-title{font-size:11px}}.levelup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;display:flex;align-items:center;justify-content:center;padding:24px}.levelup-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(120% 90% at 50% 32%,#5b00056b,#180c04db);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:lu-backdrop .32s ease-out both}.levelup-panel{position:relative;width:min(420px,100%);padding:clamp(22px,4vw,32px);text-align:center;border-radius:14px;border:1px solid var(--cinnabar);background:linear-gradient(180deg,var(--surface-lowest),var(--paper));box-shadow:inset 0 0 0 1px var(--gold-soft),inset 0 0 0 6px #c69a3e29,0 24px 70px #1408028c;animation:lu-panel .46s cubic-bezier(.2,.9,.3,1) both}.levelup-kicker{display:flex;align-items:center;justify-content:center;gap:8px;margin:0 0 16px;color:var(--cinnabar-bright);font-family:"Noto Serif",serif;font-weight:700;letter-spacing:.32em;text-transform:uppercase;font-size:13px}.levelup-kicker svg{color:var(--gold);animation:lu-twinkle 1.6s ease-in-out infinite}.levelup-portrait{position:relative;width:clamp(160px,52vw,230px);aspect-ratio:1 / 1;margin:0 auto 20px;border-radius:10px;overflow:hidden;border:2px solid var(--gold);box-shadow:inset 0 0 0 1px #fff4d666,0 10px 28px #14080280}.levelup-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover;-o-object-position:top center;object-position:top center}.levelup-img.from{z-index:2;animation:lu-from 1.7s ease-in-out both}.levelup-img.to{z-index:1;opacity:0;animation:lu-to 1.7s ease-in-out both}.levelup-flare{position:absolute;top:-20%;right:-20%;bottom:-20%;left:-20%;z-index:3;pointer-events:none;background:radial-gradient(circle at 50% 46%,rgba(255,248,220,.95),rgba(230,200,124,.35) 38%,transparent 66%);mix-blend-mode:screen;opacity:0;animation:lu-flare 1.2s ease-out .32s both}.levelup-stars{display:flex;align-items:center;justify-content:center;gap:14px;margin:0 0 16px}.levelup-star{position:relative;display:inline-flex;color:var(--surface-mid);line-height:0}.levelup-star.filled{color:var(--gold);filter:drop-shadow(0 2px 4px rgba(91,0,5,.3))}.levelup-star.gained{color:var(--gold-bright);opacity:0;animation:lu-star-pop .64s cubic-bezier(.2,1.5,.35,1) 1.48s both}.levelup-star.gained:after{content:"";position:absolute;top:-10px;right:-10px;bottom:-10px;left:-10px;border-radius:50%;border:2px solid var(--gold-bright);opacity:0;animation:lu-burst .76s ease-out 1.5s both}.levelup-title{margin:0 0 6px;font-family:"Noto Serif",serif;color:var(--cinnabar);font-size:clamp(20px,3.2vw,25px)}.levelup-sub{margin:0 0 22px;color:var(--muted);font-size:14px;line-height:1.6}.levelup-continue{width:100%;animation:lu-cta 1.9s ease-in-out infinite}@keyframes lu-backdrop{0%{opacity:0}to{opacity:1}}@keyframes lu-panel{0%{opacity:0;transform:translateY(14px) scale(.94)}to{opacity:1;transform:none}}@keyframes lu-from{0%{opacity:1;filter:brightness(1) saturate(1)}34%{opacity:1;filter:brightness(1.7) saturate(1.25) drop-shadow(0 0 18px var(--gold-bright))}52%{opacity:1;filter:brightness(2.6) saturate(1.05)}to{opacity:0;filter:brightness(1.5) saturate(1)}}@keyframes lu-to{0%,55%{opacity:0}to{opacity:1}}@keyframes lu-flare{0%,18%{opacity:0;transform:scale(.6)}50%{opacity:.9;transform:scale(1.12)}to{opacity:0;transform:scale(1.5)}}@keyframes lu-star-pop{0%{opacity:0;transform:scale(0) rotate(-45deg)}60%{opacity:1;transform:scale(1.35) rotate(8deg)}to{opacity:1;transform:scale(1) rotate(0)}}@keyframes lu-burst{0%{opacity:.85;transform:scale(.4)}to{opacity:0;transform:scale(2.3)}}@keyframes lu-twinkle{0%,to{opacity:.55;transform:scale(.85)}50%{opacity:1;transform:scale(1.1)}}@keyframes lu-cta{0%,to{box-shadow:0 0 #c69a3e00}50%{box-shadow:0 0 0 4px #c69a3e47}}@media (prefers-reduced-motion: reduce){.levelup-backdrop,.levelup-panel,.levelup-kicker svg,.levelup-continue{animation:none}.levelup-img.from,.levelup-flare{display:none}.levelup-img.to,.levelup-star.gained{opacity:1;animation:none}.levelup-star.gained:after{display:none}}.leader-tabs button{font-family:"Noto Serif",serif;font-style:italic;color:var(--ink-soft);background:transparent;border:none;padding:8px 18px;border-bottom:2px solid transparent;letter-spacing:.04em}.leader-tabs button.active{color:var(--cinnabar);font-weight:700;border-bottom-color:var(--cinnabar-bright)}.leaderboard{padding:0;overflow:hidden}.leader-row{border-bottom:1px solid var(--wood-light);font-family:"Noto Serif",serif}.leader-row.header{background:linear-gradient(180deg,var(--wood-light),var(--wood));color:var(--surface-lowest);font-family:"Noto Serif",serif;letter-spacing:.16em;text-transform:uppercase;font-weight:600;font-size:12px}.leader-row.current{background:linear-gradient(90deg,#c69a3e40,#a6292914);font-weight:600;color:var(--cinnabar-deep)}.leader-row .rank{color:var(--cinnabar);font-family:"Noto Serif",serif;font-weight:700}.leader-avatar{background:linear-gradient(180deg,var(--gold),var(--gold-soft));border:1px solid var(--cinnabar);color:var(--cinnabar-deep);font-family:"Noto Serif",serif;font-weight:700}.onboarding-screen{background:radial-gradient(ellipse at center,var(--surface) 0%,rgba(184,155,101,.4) 100%),var(--paper-grain);background-attachment:fixed,fixed}.onboarding-card{background:linear-gradient(180deg,var(--surface-lowest),var(--paper));border:1px solid var(--wood-light);box-shadow:inset 0 0 0 1px var(--gold-soft),inset 0 0 0 6px var(--surface-lowest),inset 0 0 0 7px var(--gold-soft),var(--shadow-deep);position:relative}.onboarding-card:before,.onboarding-card:after{content:"";position:absolute;width:18px;height:18px;border:2px solid var(--cinnabar)}.onboarding-card:before{top:12px;left:12px;border-right:none;border-bottom:none}.onboarding-card:after{bottom:12px;right:12px;border-left:none;border-top:none}.onboarding-card .kicker{display:block;text-align:center;margin-bottom:6px}.onboarding-card .headline-lg{text-align:center;margin:4px 0 12px}.onboarding-card .lead{text-align:center}.onboarding-form input{background:var(--surface-lowest);border:1px solid var(--wood-light);box-shadow:inset 0 1px 2px #3a24121a;font-family:"Noto Serif",serif}.onboarding-form input:focus-visible{outline:2px solid var(--cinnabar-bright);outline-offset:2px}.onboarding-form .field>span{color:var(--cinnabar);font-family:"Noto Serif",serif;font-weight:600;letter-spacing:.06em}.sort-control span{color:var(--cinnabar);font-family:"Noto Serif",serif;font-style:italic;letter-spacing:.06em}.sort-options{background:var(--surface-lowest);border:1px solid var(--wood-light);box-shadow:inset 0 0 0 1px var(--gold-soft),var(--shadow)}.sort-options button{font-family:"Noto Serif",serif;color:var(--ink)}.sort-options button:hover{background:#a6292914;color:var(--cinnabar)}.sort-options button.active{background:linear-gradient(90deg,rgba(198,154,62,.35),transparent);color:var(--cinnabar-deep)}.mobile-nav{background:linear-gradient(180deg,#faf0d2f2,#e7d3a4f2);border-top:1px solid var(--wood-light);box-shadow:0 -1px 0 var(--gold-soft)}.mobile-nav .nav-link{color:var(--ink-soft)}.mobile-nav .nav-link.active{color:var(--cinnabar);background:transparent;box-shadow:inset 0 -3px 0 var(--cinnabar-bright);border-radius:0}.avatar.image-avatar{filter:sepia(.15) contrast(1.04);border:1px solid var(--gold-soft);box-shadow:0 2px 4px #3a24122e}.message-avatar.fallback{background:linear-gradient(180deg,var(--gold),var(--cinnabar-bright));color:var(--surface-lowest);font-family:"Noto Serif",serif;font-weight:700;border:1px solid var(--cinnabar-deep)}.profile-card .headline-lg{color:var(--cinnabar-deep)}.chat-error{background:linear-gradient(180deg,#f7d7c8,#ecbcaa);color:var(--cinnabar-deep);border:1px solid var(--cinnabar);font-family:"Noto Serif",serif}.ornament-divider{display:flex;align-items:center;gap:12px;color:var(--gold);font-family:"Noto Serif",serif;letter-spacing:.16em;font-size:11px;text-transform:uppercase;margin:12px 0}.ornament-divider:before,.ornament-divider:after{content:"";flex:1;height:1px;background:linear-gradient(to right,transparent,var(--gold-soft),transparent)}.page{position:relative}.quote-row{position:relative;display:block}.quote-row .quote{margin:0;padding-right:72px}.quote-row .voice-play-button{position:absolute;right:14px;top:50%;transform:translateY(-50%)}.quote-row .voice-play-button:hover{transform:translateY(-50%) scale(1.06)}.voice-play-button{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;background:var(--surface-lowest);border:1.5px solid var(--cinnabar);color:var(--cinnabar);border-radius:50%;cursor:pointer;padding:0;transition:background .18s ease,color .18s ease,transform .18s ease;box-shadow:0 2px 6px #4a331c2e}.voice-play-button.md{width:44px;height:44px}.voice-play-button.sm{width:36px;height:36px}.voice-play-button .material-symbols-outlined{font-size:26px;font-variation-settings:"FILL" 0,"wght" 400}.voice-play-button.sm .material-symbols-outlined{font-size:22px}.voice-play-button:hover{background:var(--cinnabar);color:var(--surface-lowest);transform:scale(1.04)}.voice-play-button.playing{background:var(--cinnabar);color:var(--surface-lowest);animation:voice-pulse 1.6s ease-in-out infinite}@keyframes voice-pulse{0%,to{box-shadow:0 2px 6px #4a331c2e,0 0 #7a1c1c59}50%{box-shadow:0 2px 6px #4a331c2e,0 0 0 8px #7a1c1c00}}.voice-play-button:focus-visible{outline:2px solid var(--gold);outline-offset:2px}.collection-image-link{display:block;position:relative;cursor:pointer}.collection-image-link:hover img{filter:sepia(.05) contrast(1.08) brightness(1.04)}.collection-name-link{color:inherit;text-decoration:none;border-bottom:1px dashed transparent;transition:border-color .18s ease,color .18s ease}.collection-name-link:hover,.collection-name-link:focus-visible{color:var(--cinnabar);border-bottom-color:var(--gold-soft)}.reference-character-profile{display:flex;flex-direction:column;gap:20px}.reference-character-profile .back-link{align-self:flex-start;font-family:Be Vietnam Pro,sans-serif;font-weight:600;letter-spacing:0}.reference-character-profile .back-link .material-symbols-outlined{margin-right:4px;font-size:18px}.character-profile{padding:clamp(28px,5vw,48px);display:flex;flex-direction:column;gap:34px}.character-profile-hero{display:grid;grid-template-columns:minmax(190px,240px) minmax(0,1fr);gap:clamp(28px,5vw,54px);align-items:center}.character-profile-portrait{border:1px solid var(--wood-light);border-radius:4px;overflow:hidden;background:var(--wood-dark);aspect-ratio:3 / 4;position:relative;box-shadow:0 18px 34px -18px #3a241294,0 0 0 8px #faf0d285}.character-profile-portrait:after{content:"";position:absolute;top:7px;right:7px;bottom:7px;left:7px;border:1px solid var(--gold-soft);pointer-events:none;border-radius:2px;opacity:.7}.character-profile-portrait img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;filter:sepia(.15) contrast(1.05)}.character-profile-heading .kicker{color:var(--muted);font-family:Be Vietnam Pro,sans-serif;font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin:0 0 10px}.character-profile-heading .headline-lg{margin:0;color:var(--cinnabar);font-size:clamp(46px,8vw,78px);line-height:.98;letter-spacing:.01em}.profile-location{display:inline-flex;align-items:center;gap:7px;margin:20px 0 0;color:var(--ink-soft);font-family:Be Vietnam Pro,sans-serif;font-size:14px;font-weight:600}.profile-location .material-symbols-outlined{color:var(--cinnabar);font-size:18px}.profile-summary{max-width:620px;margin:18px 0 0;color:var(--ink-soft);font-family:Be Vietnam Pro,sans-serif;font-size:clamp(16px,2vw,19px);line-height:1.72}.profile-quote-card{max-width:780px;min-height:0;margin:0;padding:22px 76px 22px 28px;border-left:4px solid var(--cinnabar);border-radius:6px;background:linear-gradient(90deg,#a629290e,#fff8dc6b 72%),#faf0d26b;box-shadow:inset 0 0 0 1px #b89b6538}.profile-quote{margin:0;padding-right:0;color:var(--cinnabar-deep);font-family:"Noto Serif",serif;font-size:clamp(19px,2.2vw,25px);font-weight:600;line-height:1.55;letter-spacing:0}.character-profile-grid{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(220px,.75fr);gap:34px 46px}.character-profile-grid .profile-section:first-child,.profile-section-featured{grid-column:1 / -1}.profile-section h2{font-family:Be Vietnam Pro,sans-serif;font-size:12px;font-weight:700;letter-spacing:.11em;text-transform:uppercase;color:var(--cinnabar);margin:0 0 10px}.profile-section p{margin:0;color:var(--ink-soft);font-family:Be Vietnam Pro,sans-serif;font-size:16px;line-height:1.78}.profile-traits{justify-content:flex-start;gap:10px}.profile-traits span,.profile-analysis-tags span{min-height:34px;padding:7px 14px;background:#faf0d28a;border:1px solid rgba(122,79,44,.34);box-shadow:none;color:var(--ink-soft);font-family:Be Vietnam Pro,sans-serif;font-size:13px;font-style:normal;font-weight:600}.profile-analysis-tags{justify-content:flex-start;align-items:flex-start;gap:12px 14px}.profile-analysis{border-top:1px solid rgba(184,155,101,.48);border-bottom:1px solid rgba(184,155,101,.34);padding:4px 0}.profile-analysis summary{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 0;color:var(--cinnabar);cursor:pointer;font-family:Be Vietnam Pro,sans-serif;font-size:13px;font-weight:700;letter-spacing:.08em;list-style:none;text-transform:uppercase}.profile-analysis summary::-webkit-details-marker{display:none}.profile-analysis summary .material-symbols-outlined{color:var(--gold);font-size:22px;transition:transform .16s ease}.profile-analysis[open] summary .material-symbols-outlined{transform:rotate(180deg)}.profile-analysis-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px 42px;padding:10px 0 22px}.profile-analysis-grid .profile-section:first-child,.profile-analysis-grid .profile-section:nth-child(3){grid-column:1 / -1}.profile-sources{margin:0;padding-left:0;display:flex;flex-direction:column;gap:9px;list-style:none;color:var(--ink-soft);font-family:Be Vietnam Pro,sans-serif;font-size:14px;line-height:1.7}.profile-sources li::marker{color:var(--cinnabar)}.character-profile-actions{border-top:0;padding-top:0;display:flex;flex-wrap:wrap;gap:12px;align-items:center}.character-profile-actions .btn{font-family:Be Vietnam Pro,sans-serif;min-height:48px;letter-spacing:0}.character-profile-actions .btn.primary{padding-inline:22px;box-shadow:inset 0 1px #ffdcb457,0 10px 18px -12px #5b0005b8}.character-profile-actions .btn.secondary{background:#faf0d252;box-shadow:none;color:var(--cinnabar)}.character-profile-actions .material-symbols-outlined{margin-right:4px;font-size:18px}.profile-progress-note{flex-basis:100%;margin:2px 0 0;color:var(--muted);font-family:Be Vietnam Pro,sans-serif;font-size:12px}@media (max-width: 720px){.character-profile{padding:28px 20px;gap:28px}.character-profile-hero{grid-template-columns:1fr;gap:24px}.character-profile-portrait{width:min(72%,260px);margin:0 auto}.character-profile-heading{text-align:left}.character-profile-heading .headline-lg{font-size:clamp(40px,14vw,56px)}.profile-quote-card{padding:20px 66px 20px 20px}.character-profile-grid{grid-template-columns:1fr;gap:28px}.character-profile-grid .profile-section:nth-child(n),.profile-analysis-grid .profile-section:nth-child(n){grid-column:1 / -1}.profile-analysis-grid{grid-template-columns:1fr;gap:24px}.character-profile-actions{align-items:stretch}.character-profile-actions .btn{width:100%}}.music-settings{margin-top:22px;padding:18px 24px;position:relative;overflow:hidden;transition:padding .22s ease}.music-settings.is-expanded{padding:26px 32px 30px}.music-settings:before,.music-settings:after{border-color:var(--cinnabar-bright)}.music-settings-head{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:28px;align-items:center}.music-settings-summary{display:flex;align-items:center;gap:28px;background:none;border:0;padding:6px 16px 6px 4px;margin:0;text-align:left;cursor:pointer;font:inherit;color:inherit;border-radius:4px;transition:background .18s ease;min-width:0}.music-settings-summary:hover{background:#a629290d}.music-settings-summary:focus-visible{outline:2px solid var(--gold);outline-offset:4px}.music-settings-intro{display:grid;grid-template-columns:1fr;gap:2px;min-width:0;flex:1}.music-settings-intro .kicker{margin:0;display:block}.music-settings-title{font-family:"Noto Serif",serif;color:var(--cinnabar-deep);font-size:22px;font-weight:700;letter-spacing:.03em;margin:0;position:relative;display:inline-block;padding-right:18px;line-height:1.15;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.music-settings.is-expanded .music-settings-title{font-size:26px}.music-settings-title:after{content:"♪";position:absolute;right:-2px;top:-4px;font-size:13px;color:var(--gold);letter-spacing:0;transform:rotate(8deg)}.music-settings-status{font-family:"Noto Serif",serif;font-style:italic;color:var(--muted);font-size:12px;letter-spacing:.04em;margin-top:2px}.music-settings.is-expanded .music-settings-status{display:none}.music-settings-chevron{flex-shrink:0;width:30px;height:30px;display:grid;place-items:center;border-radius:50%;background:var(--surface-lowest);border:1px solid var(--wood-light);box-shadow:inset 0 0 0 1px var(--gold-soft);color:var(--cinnabar);transition:transform .22s cubic-bezier(.4,.2,.2,1.2),background .18s ease}.music-settings-summary:hover .music-settings-chevron{background:var(--surface)}.music-settings.is-expanded .music-settings-chevron{transform:rotate(180deg)}.music-settings-lead{margin:0 0 4px;font-size:14px;max-width:56ch}.music-settings-body{display:flex;flex-direction:column;gap:0;animation:music-body-reveal .28s cubic-bezier(.32,.04,.32,1.02)}@keyframes music-body-reveal{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.music-lamp-switch{display:inline-flex;align-items:center;gap:12px;background:none;border:0;padding:0;font-family:"Noto Serif",serif;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.music-lamp-switch:focus-visible{outline:2px solid var(--gold);outline-offset:6px;border-radius:6px}.music-lamp-track{position:relative;width:78px;height:34px;border-radius:999px;background:linear-gradient(180deg,var(--surface-mid),var(--surface-low) 60%,var(--surface-lowest));border:1px solid var(--wood);box-shadow:inset 0 1px 2px #3a24126b,inset 0 0 0 1px #e7d3a48c,0 1px #fff8dcb3;transition:background .22s ease,box-shadow .22s ease;flex-shrink:0}.music-lamp-glyph{position:absolute;top:50%;transform:translateY(-50%);pointer-events:none;transition:opacity .22s ease,color .22s ease}.music-lamp-glyph--off{left:11px;color:var(--wood-light);opacity:.85}.music-lamp-glyph--on{right:11px;color:var(--cinnabar-bright);opacity:.45}.music-lamp-knob{position:absolute;top:50%;left:3px;width:28px;height:28px;border-radius:999px;transform:translateY(-50%);background:radial-gradient(circle at 32% 30%,var(--gold-bright),var(--gold) 55%,var(--wood-light) 102%);border:1px solid var(--wood);box-shadow:0 2px 4px #3a24126b,inset 0 1px #fff4d6c7,inset 0 -2px 2px #3a241252;transition:left .24s cubic-bezier(.55,.04,.32,1.16),box-shadow .22s ease,transform .22s ease,background .22s ease}.music-lamp-knob-inset{position:absolute;top:6px;right:6px;bottom:6px;left:6px;border-radius:999px;border:1px solid rgba(58,36,18,.32);background:radial-gradient(circle at 50% 38%,rgba(255,244,214,.5),transparent 70%)}.music-lamp-switch.is-on .music-lamp-track{background:linear-gradient(180deg,#f4d6a6,#ecc683 55%,#d8a55b);border-color:var(--cinnabar-deep);box-shadow:inset 0 1px 2px #5b000552,inset 0 0 0 1px #fff4d6c7,0 0 0 3px #c69a3e26}.music-lamp-switch.is-on .music-lamp-knob{left:calc(100% - 31px);background:radial-gradient(circle at 30% 32%,#ffeac6,#e6c87c 55%,var(--cinnabar-bright) 102%);box-shadow:0 2px 6px #5b000580,inset 0 1px #fff4d6d9,inset 0 -2px 2px #5b000552,0 0 0 3px #a629292e}.music-lamp-switch.is-on .music-lamp-glyph--off{opacity:.25}.music-lamp-switch.is-on .music-lamp-glyph--on{opacity:1;filter:drop-shadow(0 0 6px rgba(166,41,41,.55));animation:lamp-flicker 2.4s ease-in-out infinite}@keyframes lamp-flicker{0%,to{transform:translateY(-50%) scale(1);opacity:1}44%{transform:translateY(-52%) scale(1.05);opacity:.92}64%{transform:translateY(-48%) scale(.97);opacity:.86}}.music-lamp-switch:hover .music-lamp-knob{transform:translateY(-50%) scale(1.04)}.music-lamp-switch:active .music-lamp-knob{transform:translateY(-50%) scale(.96)}.music-lamp-label{display:flex;flex-direction:column;text-align:left;line-height:1.15;min-width:92px}.music-lamp-label strong{font-family:"Noto Serif",serif;color:var(--cinnabar-deep);font-size:15px;letter-spacing:.16em;text-transform:uppercase;font-weight:700}.music-lamp-label small{font-family:"Noto Serif",serif;font-style:italic;color:var(--muted);font-size:12px;letter-spacing:.04em;margin-top:3px}.music-lamp-switch.is-off .music-lamp-label strong{color:var(--muted)}.music-divider{display:flex;align-items:center;gap:14px;margin:22px 0 14px}.music-divider:before,.music-divider:after{content:"";flex:1;height:1px;background:linear-gradient(to right,transparent,var(--gold-soft),transparent)}.music-divider-mark{font-family:"Noto Serif",serif;font-style:italic;color:var(--cinnabar);font-size:12px;letter-spacing:.32em;text-transform:uppercase;padding:4px 12px;border:1px solid var(--gold-soft);border-radius:2px;background:var(--surface-lowest);box-shadow:inset 0 0 0 2px var(--surface-lowest),0 1px #fff4d699;position:relative}.music-divider-mark:before,.music-divider-mark:after{content:"❖";color:var(--gold);font-size:9px;margin:0 6px;vertical-align:2px}.music-track-group{border:0;padding:0;margin:0;display:grid;grid-template-columns:1fr;gap:12px}.music-track-card{position:relative;display:grid;grid-template-columns:56px minmax(0,1fr) auto;align-items:center;gap:18px;padding:16px 22px 16px 18px;background:linear-gradient(180deg,var(--surface-lowest),var(--paper));border:1px solid var(--wood-light);border-radius:6px;box-shadow:inset 0 0 0 1px var(--surface-lowest),inset 0 0 0 2px var(--gold-soft),0 2px 6px #4a331c1f;cursor:pointer;transition:transform .18s ease,box-shadow .22s ease,border-color .22s ease,background .22s ease;overflow:hidden}.music-track-card input[type=radio]{position:absolute;opacity:0;pointer-events:none}.music-track-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(18deg,rgba(122,79,44,.04) 0 1px,transparent 1px 14px);pointer-events:none;opacity:.6}.music-track-card:hover{transform:translateY(-1px);border-color:var(--gold);box-shadow:inset 0 0 0 1px var(--surface-lowest),inset 0 0 0 2px var(--gold),0 4px 10px #4a331c2e}.music-track-card.selected{border-color:var(--cinnabar);background:linear-gradient(180deg,#faecc8,#efd8a8);box-shadow:inset 0 0 0 1px var(--surface-lowest),inset 0 0 0 2px var(--cinnabar-bright),0 6px 14px #5b00052e}.music-track-card.selected:after{content:"";position:absolute;top:6px;left:6px;width:12px;height:12px;border-top:2px solid var(--cinnabar);border-left:2px solid var(--cinnabar);pointer-events:none}.music-track-card input[type=radio]:focus-visible~.music-track-numeral{outline:2px solid var(--gold);outline-offset:4px}.music-track-numeral{display:grid;place-items:center;width:56px;height:56px;border-radius:50%;background:radial-gradient(circle at 32% 30%,var(--surface-lowest),var(--surface-low) 75%);border:1px solid var(--wood-light);box-shadow:inset 0 0 0 1px var(--gold-soft),inset 0 -2px #3a24121f;font-family:"Noto Serif",serif;font-style:italic;color:var(--cinnabar);font-size:18px;font-weight:700;letter-spacing:.02em;position:relative;z-index:1}.music-track-card.selected .music-track-numeral{background:radial-gradient(circle at 32% 30%,var(--gold-bright),var(--gold) 80%);color:var(--cinnabar-deep);border-color:var(--cinnabar);box-shadow:inset 0 0 0 1px var(--surface-lowest),inset 0 -2px #5b000538}.music-track-text{display:flex;flex-direction:column;gap:4px;position:relative;z-index:1;min-width:0}.music-track-title{font-family:"Noto Serif",serif;color:var(--cinnabar-deep);font-size:17px;font-weight:700;letter-spacing:.02em;line-height:1.2}.music-track-mood{font-family:"Noto Serif",serif;font-style:italic;color:var(--ink-soft);font-size:13px;line-height:1.4;letter-spacing:.01em}.music-track-card.selected .music-track-mood{color:var(--ink)}.music-track-stamp{position:absolute;top:10px;right:14px;width:26px;height:26px;display:grid;place-items:center;background:var(--cinnabar-bright);color:var(--surface-lowest);font-family:"Noto Serif",serif;font-weight:700;font-size:13px;border:1px solid var(--surface-lowest);box-shadow:0 0 0 1px var(--cinnabar-deep),0 1px 2px #00000040;border-radius:3px;transform:rotate(-7deg) scale(.6);opacity:0;transition:opacity .22s ease,transform .24s cubic-bezier(.4,.2,.2,1.4);pointer-events:none}.music-track-card.selected .music-track-stamp{opacity:1;transform:rotate(-7deg) scale(1)}.music-track-preview{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;background:var(--surface-lowest);border:1.5px solid var(--cinnabar);color:var(--cinnabar);cursor:pointer;padding:0;position:relative;z-index:2;transition:background .18s ease,color .18s ease,transform .18s ease,box-shadow .18s ease;box-shadow:0 2px 6px #4a331c2e}.music-track-preview .material-symbols-outlined{font-size:26px;font-variation-settings:"FILL" 0,"wght" 400}.music-track-preview:hover{background:var(--cinnabar);color:var(--surface-lowest);transform:scale(1.05)}.music-track-preview.playing{background:var(--cinnabar);color:var(--surface-lowest);animation:voice-pulse 1.6s ease-in-out infinite}.music-track-preview:focus-visible{outline:2px solid var(--gold);outline-offset:2px}.music-track-group.is-disabled .music-track-card{cursor:not-allowed;filter:saturate(.55);opacity:.6}.music-track-group.is-disabled .music-track-card:hover{transform:none;border-color:var(--wood-light);box-shadow:inset 0 0 0 1px var(--surface-lowest),inset 0 0 0 2px var(--gold-soft),0 2px 6px #4a331c1f}.music-track-group.is-disabled .music-track-preview{opacity:.5;cursor:not-allowed}.music-track-group.is-disabled .music-track-preview:hover{background:var(--surface-lowest);color:var(--cinnabar);transform:none}.music-volume{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:16px;padding:12px 4px 4px}.music-volume-icon{display:grid;place-items:center;width:38px;height:38px;border-radius:50%;background:var(--surface-lowest);border:1px solid var(--wood-light);box-shadow:inset 0 0 0 1px var(--gold-soft);color:var(--cinnabar)}.music-volume-icon .material-symbols-outlined{font-size:22px}.music-volume-track{position:relative;height:22px;display:flex;align-items:center;--music-volume-fill: 20%}.music-volume-track:before{content:"";position:absolute;top:8px;right:0;bottom:8px;left:0;border-radius:999px;background:linear-gradient(180deg,#3a24122e,#7a4f2c0f);border:1px solid var(--wood-light);box-shadow:inset 0 1px 2px #3a241252;pointer-events:none}.music-volume-track:after{content:"";position:absolute;left:0;top:8px;bottom:8px;width:var(--music-volume-fill);background:linear-gradient(180deg,var(--gold-bright),var(--gold));border-radius:999px;box-shadow:inset 0 1px #fff4d6d9,inset 0 -1px #5b000529;pointer-events:none;transition:width 80ms ease-out}.music-volume-ticks{position:absolute;top:8px;right:14px;bottom:8px;left:14px;pointer-events:none;display:flex;justify-content:space-between;align-items:center}.music-volume-ticks span{width:1px;height:8px;background:#3a241252}.music-volume-slider{position:relative;width:100%;height:22px;background:transparent;-moz-appearance:none;appearance:none;-webkit-appearance:none;margin:0;cursor:pointer;z-index:1}.music-volume-slider:focus{outline:none}.music-volume-slider::-webkit-slider-thumb{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:22px;height:22px;border-radius:50%;background:radial-gradient(circle at 32% 30%,#ffeac6,var(--gold) 50%,var(--cinnabar-bright) 95%);border:1.5px solid var(--cinnabar-deep);box-shadow:0 2px 5px #5b000573,inset 0 1px #fff4d6c7,inset 0 -1px 1px #5b000552;cursor:grab;-webkit-transition:transform .14s ease,box-shadow .14s ease;transition:transform .14s ease,box-shadow .14s ease}.music-volume-slider::-webkit-slider-thumb:hover{transform:scale(1.1)}.music-volume-slider:active::-webkit-slider-thumb{cursor:grabbing;transform:scale(1.06);box-shadow:0 2px 8px #5b00058c,inset 0 1px #fff4d6c7}.music-volume-slider:focus-visible::-webkit-slider-thumb{outline:2px solid var(--gold);outline-offset:2px}.music-volume-slider::-webkit-slider-runnable-track{height:22px;background:transparent}.music-volume-slider::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:radial-gradient(circle at 32% 30%,#ffeac6,var(--gold) 50%,var(--cinnabar-bright) 95%);border:1.5px solid var(--cinnabar-deep);box-shadow:0 2px 5px #5b000573,inset 0 1px #fff4d6c7;cursor:grab}.music-volume-slider::-moz-range-track{height:22px;background:transparent;border:0}.music-volume-cartouche{display:inline-flex;align-items:baseline;gap:2px;background:linear-gradient(180deg,var(--surface-lowest),var(--paper));border:1px solid var(--wood-light);box-shadow:inset 0 0 0 1px var(--gold-soft),0 1px 2px #4a331c2e;padding:6px 12px;border-radius:4px;font-family:"Noto Serif",serif;color:var(--cinnabar);min-width:64px;justify-content:center}.music-volume-cartouche strong{font-weight:700;font-size:18px;letter-spacing:.02em}.music-volume-cartouche small{color:var(--muted);font-size:12px;font-style:italic}.music-volume.is-disabled{opacity:.5;filter:saturate(.55);pointer-events:none}@media (max-width: 720px){.music-settings{padding:22px 18px 20px}.music-settings-head{grid-template-columns:1fr;gap:16px}.music-lamp-switch{align-self:flex-start}.music-track-card{grid-template-columns:44px minmax(0,1fr) auto;gap:12px;padding:14px 16px}.music-track-numeral{width:44px;height:44px;font-size:15px}.music-track-title{font-size:15px}.music-track-mood{font-size:12px}.music-volume{gap:12px}}.chat-sources{list-style:none;margin:10px 0 0;padding:0;display:flex;flex-wrap:wrap;gap:6px}.chat-source-chip{display:inline-flex;align-items:baseline;gap:6px;padding:4px 10px;border-radius:4px;background:var(--surface-lowest);border:1px solid var(--gold-soft);box-shadow:inset 0 0 0 1px #fff4d68c;font-family:"Noto Serif",serif;font-size:11.5px;line-height:1.3;color:var(--cinnabar-deep);max-width:100%}.chat-source-chip:before{content:"❖";color:var(--gold);font-size:9px;line-height:1}.chat-source-title{font-style:italic;font-weight:600}.chat-source-snippet{color:var(--muted);font-size:10.5px;letter-spacing:.02em}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Be Vietnam Pro,system-ui,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.\!container{width:100%!important}.container{width:100%}@media (min-width: 640px){.\!container{max-width:640px!important}.container{max-width:640px}}@media (min-width: 768px){.\!container{max-width:768px!important}.container{max-width:768px}}@media (min-width: 1024px){.\!container{max-width:1024px!important}.container{max-width:1024px}}@media (min-width: 1280px){.\!container{max-width:1280px!important}.container{max-width:1280px}}@media (min-width: 1536px){.\!container{max-width:1536px!important}.container{max-width:1536px}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.static{position:static}.inline{display:inline}.grid{display:grid}.hidden{display:none}.bg-surface{--tw-bg-opacity: 1;background-color:rgb(251 249 248 / var(--tw-bg-opacity, 1))}.px-4{padding-left:1rem;padding-right:1rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.font-sans{font-family:Be Vietnam Pro,system-ui,sans-serif}.text-ink{--tw-text-opacity: 1;color:rgb(0 22 42 / var(--tw-text-opacity, 1))}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.onboarding-screen{min-height:100dvh;position:relative;display:grid;place-items:center;overflow:hidden;padding:72px 20px 40px;background:radial-gradient(circle at 18% 22%,rgba(166,41,41,.12),transparent 26%),radial-gradient(circle at 82% 74%,rgba(79,107,88,.18),transparent 30%),linear-gradient(135deg,#faf0d2e0,#d6bd86d1),var(--paper-grain),var(--surface);isolation:isolate}.onboarding-screen:before,.onboarding-screen:after{content:"";position:absolute;pointer-events:none;z-index:0}.onboarding-screen:before{top:22px;right:22px;bottom:22px;left:22px;border:1px solid rgba(122,28,28,.18);box-shadow:inset 0 0 0 6px #faf0d238}.onboarding-screen:after{top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at center,transparent 32%,rgba(58,36,18,.18) 100%),repeating-linear-gradient(90deg,rgba(122,79,44,.035) 0 1px,transparent 1px 7px);mix-blend-mode:multiply}.onboarding-stage{position:relative;z-index:2;width:min(100%,480px);display:grid;place-items:center}.onboarding-gallery{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:none}.onboarding-gallery-card{position:absolute;width:clamp(150px,17vw,250px);aspect-ratio:.72;overflow:hidden;border-radius:8px;background:linear-gradient(180deg,var(--surface-lowest),var(--paper));border:1px solid var(--wood-light);box-shadow:inset 0 0 0 1px #e7d3a4bf,inset 0 0 0 6px var(--surface-lowest),inset 0 0 0 7px var(--gold-soft),0 24px 52px #3a24123d;opacity:.9}.onboarding-gallery-card:before,.onboarding-gallery-card:after{content:"";position:absolute;z-index:2;width:18px;height:18px;border:2px solid rgba(122,28,28,.76)}.onboarding-gallery-card:before{top:12px;left:12px;border-right:0;border-bottom:0}.onboarding-gallery-card:after{right:12px;bottom:12px;border-left:0;border-top:0}.onboarding-gallery-card img{width:100%;height:100%;display:block;-o-object-fit:cover;object-fit:cover;-o-object-position:center 35%;object-position:center 35%;filter:saturate(.92) sepia(.08) contrast(.96)}.onboarding-gallery-card.card-1{left:max(28px,calc(50% - 660px));top:13%;transform:rotate(-9deg)}.onboarding-gallery-card.card-2{right:max(36px,calc(50% - 650px));top:10%;transform:rotate(8deg)}.onboarding-gallery-card.card-3{left:max(88px,calc(50% - 570px));bottom:8%;transform:rotate(7deg)}.onboarding-gallery-card.card-4{right:max(92px,calc(50% - 575px));bottom:9%;transform:rotate(-7deg)}.onboarding-gallery-caption{position:absolute;left:16px;right:16px;bottom:16px;z-index:3;display:grid;gap:2px;padding:10px 12px;border:1px solid rgba(250,240,210,.55);background:#2c1c0da3;color:var(--surface-lowest);text-shadow:0 1px 8px rgba(0,0,0,.32)}.onboarding-gallery-caption strong{font-family:"Noto Serif",serif;font-size:16px;line-height:1.1}.onboarding-gallery-caption span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:11px;color:#faf0d2d1}.onboarding-music-toggle{position:fixed;top:max(18px,env(safe-area-inset-top));right:max(18px,env(safe-area-inset-right));z-index:4;display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;padding:0;border:1px solid rgba(122,79,44,.48);border-radius:50%;background:linear-gradient(180deg,#faf0d2f0,#e7d3a4e6);color:var(--cinnabar);box-shadow:inset 0 0 0 1px #fff9e6bf,0 10px 28px #3a24122e;font-family:Be Vietnam Pro,sans-serif;font-size:13px;font-weight:700;cursor:pointer}.onboarding-music-toggle svg{flex:0 0 auto}.onboarding-music-toggle:hover{transform:translateY(-1px);box-shadow:inset 0 0 0 1px #fff9e6d9,0 14px 32px #3a241238}.onboarding-music-toggle:focus-visible{outline:2px solid var(--cinnabar-bright);outline-offset:3px}.onboarding-music-toggle.is-on{background:linear-gradient(180deg,var(--surface-lowest),var(--surface-low));border-color:#4f6b589e;color:var(--jade);box-shadow:inset 0 0 0 1px #fff9e6db,0 0 0 4px #4f6b581f,0 14px 34px #3a24122e}.onboarding-card{width:100%;max-width:480px;position:relative;overflow:hidden;background:linear-gradient(180deg,#faf0d2fa,#ead7a7fa);border:1px solid var(--wood-light);border-radius:8px;padding:clamp(34px,5vw,46px) clamp(26px,5vw,42px);box-shadow:inset 0 0 0 1px #e7d3a4cc,inset 0 0 0 6px var(--surface-lowest),inset 0 0 0 7px var(--gold-soft),0 30px 72px #3a241257}.onboarding-card:before,.onboarding-card:after{width:20px;height:20px}.onboarding-card:before{top:14px;left:14px}.onboarding-card:after{right:14px;bottom:14px}.onboarding-card .onboarding-brand{margin:0;font-size:clamp(58px,8vw,92px);line-height:.92;letter-spacing:.035em}.onboarding-tagline{margin:14px auto 0;max-width:24rem;color:var(--ink-soft);font-family:"Noto Serif",serif;font-size:clamp(22px,3.6vw,34px);font-weight:700;line-height:1.18;text-align:center}.onboarding-card .lead{max-width:36rem;margin-inline:auto}.onboarding-form{display:flex;flex-direction:column;gap:18px;margin-top:20px}.onboarding-form .field{display:flex;flex-direction:column;gap:8px;font-size:14px}.onboarding-form .field>span{font-weight:600;color:var(--ink, #2b2622)}.onboarding-form input{font:inherit;padding:12px 14px;border-radius:12px;border:1px solid var(--ink-15, rgba(0, 0, 0, .12));background:var(--surface);color:var(--ink, #2b2622)}.onboarding-form input:focus-visible{outline:2px solid var(--cinnabar);outline-offset:2px}.error-text{color:#b3261e;font-size:12px}.onboarding-actions{display:flex;flex-direction:column;gap:12px;margin-top:24px}.onboarding-actions .btn{width:100%}.google-login-button{min-height:48px;display:inline-flex;align-items:center;justify-content:center;gap:12px;padding:12px 18px;border:1px solid rgba(60,64,67,.22);background:#fff;color:#3c4043;box-shadow:inset 0 0 0 1px #fffc,0 2px 8px #3c404329;font-family:Be Vietnam Pro,sans-serif;font-weight:700;letter-spacing:0}.google-login-button:hover{background:#f8fafd;border-color:#3c404352;color:#202124;transform:translateY(-1px);box-shadow:inset 0 0 0 1px #ffffffe6,0 5px 14px #3c40432e}.google-login-button:focus-visible{outline:2px solid #4285f4;outline-offset:3px}.google-g-icon{flex:0 0 20px}@media (max-width: 820px){.onboarding-screen{padding:88px 18px 34px}.onboarding-screen:before{top:12px;right:12px;bottom:12px;left:12px}.onboarding-stage{width:min(100%,440px)}.onboarding-gallery-card{width:clamp(118px,31vw,160px);opacity:.42}.onboarding-gallery-card.card-1{left:-30px;top:9%}.onboarding-gallery-card.card-2{right:-34px;top:12%}.onboarding-gallery-card.card-3{left:-22px;bottom:4%}.onboarding-gallery-card.card-4{right:-28px;bottom:5%}.onboarding-gallery-caption{display:none}.onboarding-music-toggle{top:max(14px,env(safe-area-inset-top));right:max(14px,env(safe-area-inset-right));width:46px;height:46px}}.sort-menu{position:relative}.sort-options{position:absolute;top:calc(100% + 6px);right:0;margin:0;padding:6px;list-style:none;background:var(--surface-lowest);border:1px solid var(--ink-15, rgba(0, 0, 0, .12));border-radius:12px;box-shadow:0 12px 24px #14121014;z-index:5;min-width:220px}.sort-options li{margin:0}.sort-options button{display:block;width:100%;text-align:left;padding:8px 10px;border:none;background:transparent;border-radius:8px;font:inherit;color:var(--ink, #2b2622);cursor:pointer}.sort-options button:hover{background:var(--surface)}.sort-options button.active{background:var(--surface);font-weight:600}.chat-error{display:flex;align-items:center;gap:8px;margin:8px 0 0;padding:10px 12px;border-radius:12px;background:#fdecea;color:#b3261e;font-size:14px}.chat-error .material-symbols-outlined{font-size:18px}.deck-stack{position:relative;display:block}.deck-tinder{display:block;touch-action:none}.deck-tinder>*{width:100%}
