@font-face{font-family:Fraunces;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/fraunces-vietnamese-400-normal-CvGt0Ybw.woff2) format("woff2"),url(/assets/fraunces-vietnamese-400-normal-B65MOf9T.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Fraunces;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/fraunces-latin-ext-400-normal-D8gbi3Gu.woff2) format("woff2"),url(/assets/fraunces-latin-ext-400-normal-UihxqfOe.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Fraunces;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/fraunces-latin-400-normal-6IfK1voy.woff2) format("woff2"),url(/assets/fraunces-latin-400-normal-NUPT2cO8.woff) format("woff");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:Fraunces;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/fraunces-vietnamese-600-normal-BjlAJixd.woff2) format("woff2"),url(/assets/fraunces-vietnamese-600-normal-DlAl5EAR.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Fraunces;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/fraunces-latin-ext-600-normal-BtzmzP0X.woff2) format("woff2"),url(/assets/fraunces-latin-ext-600-normal-B0Dy4lqi.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Fraunces;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/fraunces-latin-600-normal-BFCDtZfi.woff2) format("woff2"),url(/assets/fraunces-latin-600-normal-DL5QCzvS.woff) format("woff");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:Work Sans;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/work-sans-vietnamese-400-normal-BxGuknnG.woff2) format("woff2"),url(/assets/work-sans-vietnamese-400-normal-DFZk_KN_.woff) format("woff");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:Work Sans;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/work-sans-latin-ext-400-normal-zfQnhXzv.woff2) format("woff2"),url(/assets/work-sans-latin-ext-400-normal-j7TZlk-s.woff) format("woff");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:Work Sans;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/work-sans-latin-400-normal-jUejSri3.woff2) format("woff2"),url(/assets/work-sans-latin-400-normal-DE1_0GuN.woff) format("woff");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:Work Sans;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/work-sans-vietnamese-500-normal-Czn2Xkog.woff2) format("woff2"),url(/assets/work-sans-vietnamese-500-normal-90nhZfxs.woff) format("woff");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:Work Sans;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/work-sans-latin-ext-500-normal-CAKEIVkc.woff2) format("woff2"),url(/assets/work-sans-latin-ext-500-normal-CW9ss9Cz.woff) format("woff");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:Work Sans;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/work-sans-latin-500-normal-BKGnScDy.woff2) format("woff2"),url(/assets/work-sans-latin-500-normal-BmdXWF6_.woff) format("woff");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:Work Sans;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/work-sans-vietnamese-600-normal-DizFELYt.woff2) format("woff2"),url(/assets/work-sans-vietnamese-600-normal-ue5fzGW6.woff) format("woff");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:Work Sans;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/work-sans-latin-ext-600-normal-DNiHHggD.woff2) format("woff2"),url(/assets/work-sans-latin-ext-600-normal-B1NFRnx8.woff) format("woff");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:Work Sans;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/work-sans-latin-600-normal-DB-2V89X.woff2) format("woff2"),url(/assets/work-sans-latin-600-normal-Cg-NlmS7.woff) format("woff");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{color-scheme:light;--bg: #f3e9df;--bg-deep: #e7d4c2;--surface: rgba(255, 251, 247, .84);--surface-strong: rgba(255, 247, 240, .96);--border: rgba(120, 90, 69, .14);--text: #2f221a;--text-soft: #6d584a;--text-faint: #8a7566;--accent: #8b5d44;--accent-soft: #e7c6ad;--accent-deep: #5d3c2c;--moss: #5a6c53;--gold: #b98c54;--shadow: 0 24px 60px rgba(94, 63, 44, .12);--shadow-soft: 0 14px 30px rgba(112, 76, 54, .08);--radius-xl: 32px;--radius-lg: 24px;--radius-md: 18px}*{box-sizing:border-box}html{min-height:100%}body{margin:0;min-height:100vh;font-family:Work Sans,sans-serif;color:var(--text);background:radial-gradient(circle at top left,rgba(255,255,255,.78),transparent 36%),radial-gradient(circle at bottom right,rgba(185,140,84,.14),transparent 30%),linear-gradient(180deg,#f8f1ea 0%,var(--bg) 38%,var(--bg-deep) 100%)}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(255,255,255,.18) 0%,transparent 40%),radial-gradient(circle at 20% 20%,rgba(139,93,68,.05),transparent 22%);pointer-events:none}a{color:inherit;text-decoration:none}button,input,textarea{font:inherit}button{cursor:pointer}#root{min-height:100vh}.page-enter{animation:rise-in .5s ease both}@keyframes rise-in{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes breathe{0%,to{transform:scale(.96)}50%{transform:scale(1.04)}}.app-shell{min-height:100vh;padding:24px;position:relative;z-index:1}.shell-header,.card-surface,.auth-card,.session-card,.recommendation-card,.preference-card{backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px)}.shell-header{max-width:1220px;margin:0 auto 24px;padding:22px 24px;display:grid;grid-template-columns:1.2fr auto 1fr;gap:18px;align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-soft)}.brand-link{display:inline-flex;align-items:center;gap:14px}.brand-link strong{display:block;font-family:Fraunces,serif;font-size:1.18rem;font-weight:600}.brand-link small{display:block;color:var(--text-soft)}.brand-mark{width:46px;height:46px;display:grid;place-items:center;border-radius:16px;background:linear-gradient(135deg,#8b5d442e,#b98c5447);border:1px solid rgba(139,93,68,.12);font-family:Fraunces,serif;font-size:1.35rem}.shell-nav{display:inline-flex;flex-wrap:wrap;gap:10px;justify-content:center}.nav-link{padding:12px 16px;border-radius:999px;color:var(--text-soft);transition:all .2s ease}.nav-link:hover,.nav-link.is-active{color:var(--accent-deep);background:#8b5d441f}.shell-meta{display:flex;gap:16px;justify-content:flex-end;align-items:center}.meta-stack{display:grid;gap:4px;text-align:right}.meta-stack strong{font-size:.98rem}.meta-stack small,.muted-copy,.support-copy,.state-card-summary,.step-item small,.step-cue,.recommendation-reason{color:var(--text-soft)}.shell-main{max-width:1220px;margin:0 auto}.page-stack,.completion-shell{display:grid;gap:24px}.hero-grid,.detail-layout,.recommendation-layout,.data-grid{display:grid;gap:24px;grid-template-columns:minmax(0,1.4fr) minmax(320px,.9fr)}.hero-side,.detail-aside,.alt-grid{display:grid;gap:18px}.card-surface,.auth-card,.empty-card,.session-card,.notice-card,.favorite-card,.history-card,.recommendation-card,.preference-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow)}.card-surface,.session-card,.recommendation-card,.preference-card,.empty-card,.auth-card,.favorite-card,.history-card,.notice-card{padding:28px}.hero-copy h1,.detail-main h1,.session-card h1,.completion-card h1,.auth-card h1,.card-surface h1{margin:0 0 12px;font-family:Fraunces,serif;font-size:clamp(2rem,4vw,3.3rem);line-height:1.05;letter-spacing:-.04em}.lead{margin:0;font-size:1.05rem;line-height:1.7;color:var(--text-soft)}.eyebrow{margin:0 0 10px;text-transform:uppercase;letter-spacing:.18em;font-size:.73rem;color:var(--text-faint)}.state-grid{display:grid;gap:14px;grid-template-columns:repeat(3,minmax(0,1fr));margin-top:28px}.state-card{border:1px solid rgba(139,93,68,.12);background:#fffaf5b8;border-radius:var(--radius-lg);padding:20px;min-height:128px;display:grid;gap:10px;text-align:left;transition:transform .22s ease,background .22s ease,border-color .22s ease,box-shadow .22s ease}.state-card:hover,.state-card.is-active{transform:translateY(-2px);border-color:#8b5d443d;background:linear-gradient(180deg,#fffcf8fa,#ecd6c2eb);box-shadow:var(--shadow-soft)}.state-card-label{font-weight:600;font-size:1rem}.quiet-note{background:linear-gradient(180deg,#f6ebe0e6,#f1dfcfb8)}.recommendation-card{display:grid;gap:18px;background:linear-gradient(180deg,#fffaf6f5,#f1e3d5e0)}.alt-card{padding:22px;border-radius:var(--radius-lg);background:#fffaf6d1;border:1px solid var(--border)}.alt-card h3,.favorite-card h3,.history-card h3,.detail-aside h2,.notice-card h2{margin:6px 0 10px;font-family:Fraunces,serif;font-size:1.45rem}.badge-row,.button-row,.summary-chips,.info-row,.section-heading{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.badge,.summary-chip,.info-chip{display:inline-flex;align-items:center;gap:8px;padding:9px 12px;border-radius:999px;background:#5b3e2d14;color:var(--accent-deep);font-size:.88rem}.badge-soft,.summary-chip{background:#b98c541f}.button-row{margin-top:12px}.primary-button,.secondary-button,.text-button,.toggle-button,.danger-button{border-radius:999px;border:1px solid transparent;padding:13px 18px;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:transform .18s ease,background .18s ease,border-color .18s ease,color .18s ease}.primary-button{background:linear-gradient(135deg,var(--accent) 0%,var(--gold) 100%);color:#fff;box-shadow:0 14px 28px #8b5d4433}.primary-button:hover,.secondary-button:hover,.text-button:hover,.toggle-button:hover,.danger-button:hover{transform:translateY(-1px)}.secondary-button{background:#fff8f0eb;border-color:#8b5d4429;color:var(--accent-deep)}.text-button{background:transparent;color:var(--accent-deep);padding-inline:0}.field-label{display:block;margin:16px 0 8px;font-weight:600}.text-area,.text-input{width:100%;padding:16px 18px;border-radius:var(--radius-md);border:1px solid rgba(139,93,68,.14);background:#fffcf8e6;color:var(--text);resize:vertical;min-height:56px}.text-area{min-height:132px}.text-area:focus,.text-input:focus{outline:2px solid rgba(139,93,68,.18);outline-offset:2px}.detail-main,.detail-aside,.completion-card,.notice-card,.favorite-card,.history-card,.preference-card{display:grid;gap:16px}.info-panel,.session-note{padding:18px;border-radius:var(--radius-lg);background:#fff6eed1;border:1px solid rgba(139,93,68,.12)}.companion-panel{display:grid;gap:14px;padding:18px;border-radius:var(--radius-lg);background:linear-gradient(180deg,#fff9f4eb,#f1e5d8d1);border:1px solid rgba(139,93,68,.14)}.companion-body{display:grid;gap:14px}.suggestion-grid{display:grid;gap:10px}.suggestion-chip{width:100%;text-align:left;padding:14px 16px;border-radius:var(--radius-md);border:1px solid rgba(139,93,68,.12);background:#fffcf8eb;color:var(--accent-deep);transition:transform .18s ease,border-color .18s ease,background .18s ease}.suggestion-chip:hover{transform:translateY(-1px);border-color:#8b5d4438;background:#fff7effa}.companion-prompt{padding:14px 16px;border-radius:var(--radius-md);background:#fffcf7bd;border-left:3px solid rgba(185,140,84,.64);color:var(--text-soft)}.step-list{list-style:none;margin:0;padding:0;display:grid;gap:16px}.step-item{display:grid;gap:12px;grid-template-columns:42px 1fr}.step-item h3{margin:0 0 8px;font-size:1.02rem}.step-item p,.alt-card p,.favorite-card p,.history-card p,.auth-card p,.card-surface p{margin:0;line-height:1.65}.step-number{width:42px;height:42px;border-radius:14px;display:grid;place-items:center;background:#8b5d441f;font-weight:600}.session-shell{display:flex;justify-content:center}.session-card{width:min(720px,100%);display:grid;gap:20px;background:linear-gradient(180deg,#fffcf7fa,#eeddceeb)}.progress-track{width:100%;height:10px;border-radius:999px;background:#8b5d441a;overflow:hidden}.progress-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--moss),var(--gold));transition:width .3s ease}.step-cue{font-style:italic}.session-note{display:flex;gap:12px;align-items:flex-start}.session-nav{display:flex;gap:12px;flex-wrap:wrap;justify-content:space-between}.completion-note{margin:0;padding:18px 20px;border-radius:var(--radius-lg);background:#fff8f1f0;border-left:4px solid var(--gold);color:var(--text);line-height:1.7}.history-list,.favorites-grid{display:grid;gap:18px}.favorites-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.history-card-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start}.empty-card,.auth-gate,.loading-shell{min-height:62vh;display:grid;place-items:center;text-align:center}.empty-card{gap:14px}.auth-card{max-width:620px;width:100%;display:grid;gap:16px}.loading-shell{gap:12px}.loading-shell h1{margin:0;font-family:Fraunces,serif;font-size:2rem}.loading-shell p{margin:0;color:var(--text-soft)}.loading-orb{width:72px;height:72px;border-radius:999px;background:radial-gradient(circle at 30% 30%,#ffffffc7,#8b5d442e,#5a6c533d);box-shadow:0 0 0 12px #ffffff3d;animation:breathe 2.2s ease-in-out infinite}.inline-error{padding:14px 16px;border-radius:var(--radius-md);background:#b9545414;border:1px solid rgba(185,84,84,.14);color:#854848}.toggle-button{width:fit-content;padding:10px 14px;border-color:#8b5d442e;background:#fff8f0f0;color:var(--accent-deep)}.toggle-button.is-on{background:#5a6c531f}.toggle-pill{width:28px;height:16px;border-radius:999px;background:linear-gradient(90deg,var(--accent-soft),var(--gold))}.danger-button{background:linear-gradient(135deg,#8f4a42,#b35b50);color:#fff;box-shadow:0 14px 28px #8f4a4238}.stat-grid{display:grid;gap:12px;grid-template-columns:repeat(2,minmax(0,1fr))}.stat-card{display:grid;gap:6px;padding:16px 18px;border-radius:var(--radius-lg);background:#fff9f3e0;border:1px solid rgba(139,93,68,.12)}.stat-card strong{font-family:Fraunces,serif;font-size:1.5rem}.stat-card span{color:var(--text-soft);word-break:break-word}.danger-card{background:linear-gradient(180deg,#fff6f4f5,#f5e1dde6)}@media(max-width:980px){.shell-header,.hero-grid,.detail-layout,.recommendation-layout,.data-grid{grid-template-columns:1fr}.shell-header{justify-items:start}.shell-nav,.shell-meta{justify-content:flex-start}.meta-stack{text-align:left}.favorites-grid,.state-grid,.stat-grid{grid-template-columns:1fr 1fr}}@media(max-width:640px){.app-shell{padding:16px}.shell-header,.card-surface,.session-card,.auth-card,.favorite-card,.history-card,.notice-card{padding:22px}.state-grid,.favorites-grid,.stat-grid{grid-template-columns:1fr}.history-card-head,.session-nav,.button-row{flex-direction:column;align-items:stretch}}
