@import "https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@500;600;700&family=Noto+Sans+SC:wght@300;400;500;700&family=Noto+Serif+SC:wght@400;500;600;700&display=swap";:root{--bg:#f6efe2;--bg-soft:#fbf6ed;--surface:#fffaf1d1;--surface-strong:#fffcf7f5;--surface-dark:#171411;--surface-dark-2:#0f0d0c;--ink:#1f1914;--ink-soft:#43382d;--ink-muted:#756758;--ink-faint:#9a8d7f;--gold:#c89c48;--gold-deep:#7b5921;--gold-light:#e9c77b;--plum:#8a80aa;--rose:#a85139;--line:#271f171f;--line-strong:#271f1733;--shadow:0 16px 34px #2d21111a;--shadow-strong:0 22px 46px #1c150d29;--shadow-dark:0 24px 42px #00000052;--radius-xl:28px;--radius-lg:22px;--radius-md:18px;--radius-sm:14px;--font-serif:"Noto Serif SC", serif;--font-sans:"Noto Sans SC", sans-serif;--font-display:"Cormorant Garamond", serif}*{box-sizing:border-box}html,body,#root{min-height:100%}html{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}body{color:var(--ink);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;background:radial-gradient(circle at 18% 6%,#c99c481f,#0000 28%),radial-gradient(circle at 82% 12%,#70582e1a,#0000 24%),linear-gradient(#faf4e7 0%,#f5ebda 34%,#efe0c8 100%);margin:0}body:before{content:"";pointer-events:none;mix-blend-mode:soft-light;background:linear-gradient(#0000 0%,#ffffff14 100%),radial-gradient(circle at 50% 0,#ffffff42,#0000 35%),radial-gradient(circle at 0 100%,#946f3214,#0000 30%);position:fixed;inset:0}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit;color:inherit}button{cursor:pointer}img,svg{max-width:100%;display:block}#root{min-height:100dvh;position:relative}.app-shell{z-index:1;min-height:100dvh;position:relative}.mobile-shell{flex-direction:column;display:flex}.mobile-topbar{z-index:40;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#fbf6ecb8;border-bottom:1px solid #3a2d2014;justify-content:space-between;align-items:center;gap:12px;padding:10px 14px;display:flex;position:sticky;top:0}.brand-block{align-items:center;gap:12px;min-width:0;display:flex}.brand-mark{color:#744f17;letter-spacing:.12em;background:radial-gradient(circle at 32% 28%,#ffffffb3,#0000 34%),linear-gradient(#e9c77b 0%,#c18e37 100%);border:1px solid #78592847;border-radius:50%;flex:none;place-items:center;width:40px;height:40px;font-size:.88rem;font-weight:700;display:grid;box-shadow:inset 0 0 0 5px #ffffff47,0 10px 24px #996d1d3d}.brand-title{font-family:var(--font-serif);letter-spacing:.08em;font-size:1.08rem;font-weight:600}.brand-sub{color:var(--ink-muted);letter-spacing:.16em;text-transform:uppercase;margin-top:2px;font-size:.74rem}.topbar-actions{flex:none;align-items:center;gap:8px;display:flex}.topbar-chip,.topbar-ghost{letter-spacing:.06em;white-space:nowrap;-webkit-tap-highlight-color:transparent;border:1px solid #271f171a;border-radius:999px;justify-content:center;align-items:center;min-height:38px;padding:0 14px;font-size:.86rem;font-weight:600;transition:transform .16s,box-shadow .16s,border-color .16s,background-color .16s,color .16s,filter .16s;display:inline-flex}.topbar-chip{color:var(--gold-deep);background:radial-gradient(circle at 28% 24%,#ffffffa3,#0000 30%),linear-gradient(#f7e3b0 0%,#e2bb5e 100%);border-color:#855f1f2e;box-shadow:0 10px 20px #b1832c33,inset 0 1px #ffffff80}.topbar-account-chip{text-overflow:ellipsis;max-width:110px;overflow:hidden}.topbar-ghost{color:var(--ink-soft);background:#ffffff75;border-color:#271f171f}.shell-main{width:min(100%,560px);padding:12px 16px calc(112px + env(safe-area-inset-bottom));flex-direction:column;gap:14px;margin:0 auto;display:flex}.shell-banner,.shell-status-strip,.shell-meta-strip,.shell-inline-alert{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.shell-banner{justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;display:flex}.shell-banner strong{font-family:var(--font-serif);margin-top:4px;font-size:1.05rem;line-height:1.25;display:block}.shell-banner p{color:var(--ink-muted);margin:4px 0 0;font-size:.9rem;line-height:1.6}.shell-banner-label,.section-caption,.section-label,.eyebrow,.muted-small{color:var(--gold);font-family:var(--font-display);letter-spacing:.24em;text-transform:uppercase;font-size:.7rem;font-style:italic;display:inline-block}.shell-banner-arrow{color:var(--gold);font-size:2rem;line-height:1}.shell-status-strip{gap:10px;padding:14px 16px;display:grid}.shell-status-strip strong{font-family:var(--font-serif);margin-top:4px;font-size:1.1rem;display:block}.shell-status-strip p{color:var(--ink-muted);margin:0;font-size:.92rem;line-height:1.7}.shell-meta-strip{color:var(--ink-soft);flex-wrap:wrap;gap:8px 14px;padding:12px 16px;font-size:.84rem;display:flex}.shell-meta-strip span+span{border-left:1px solid #271f171f;padding-left:14px}.shell-inline-alert{gap:4px;padding:12px 16px;display:grid}.shell-inline-alert strong{font-size:.95rem;font-weight:700}.shell-inline-alert span{color:var(--ink-muted);font-size:.88rem;line-height:1.6}.shell-inline-alert.busy{border-color:#c89c4838}.shell-inline-alert.error{border-color:#a8513938}.bottom-nav{z-index:45;width:min(100% - 12px,560px);padding:10px 10px calc(10px + env(safe-area-inset-bottom));-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#f9f3e8db;border-top:1px solid #2b21171a;border-radius:22px 22px 0 0;grid-template-columns:repeat(4,1fr);gap:8px;display:grid;position:fixed;bottom:0;left:50%;transform:translate(-50%);box-shadow:0 -12px 30px #3f2e161f}.bottom-nav-link{min-height:52px;color:var(--ink-muted);letter-spacing:.08em;-webkit-tap-highlight-color:transparent;border-radius:16px;place-items:center;padding:8px 6px;font-size:.9rem;font-weight:600;transition:transform .16s,box-shadow .16s,background-color .16s,color .16s,filter .16s;display:grid}.bottom-nav-link.active{color:var(--gold-deep);background:linear-gradient(#f8e0aae6 0%,#e5c16df2 100%);box-shadow:inset 0 1px #ffffff61,0 8px 18px #a47b291f}.bottom-nav-link:hover{transform:translateY(-1px)}.bottom-nav-link:active{transform:translateY(0)}.page{flex-direction:column;gap:14px;min-height:100%;display:flex}.not-found{align-items:flex-start;padding-top:24px}.page-heading{flex-direction:column;align-items:flex-start;gap:10px;display:flex}.page-heading h1{font-family:var(--font-serif);letter-spacing:.02em;margin:0;font-size:clamp(1.9rem,7vw,2.55rem);line-height:1.1}.page-heading p{color:var(--ink-muted);margin:0;font-size:.96rem;line-height:1.8}.page-actions{align-self:flex-end}.text-link,.button-link{color:var(--gold-deep);font-size:.92rem;font-weight:600}.button-link{justify-content:center;align-items:center;display:inline-flex}.button-primary,.button-secondary{letter-spacing:.02em;-webkit-tap-highlight-color:transparent;border:1px solid #0000;border-radius:18px;min-height:52px;padding:0 18px;font-size:.96rem;font-weight:700;line-height:1;transition:transform .16s,box-shadow .16s,border-color .16s,background-color .16s,color .16s,filter .16s}.button-primary{color:#704d17;background:radial-gradient(circle at 28% 24%,#ffffff9e,#0000 32%),linear-gradient(#f6dda0 0%,#d5a44c 52%,#bd8730 100%);border-color:#7d5a1e38;box-shadow:0 12px 26px #b2812842,inset 0 1px #ffffff52}.button-secondary{color:var(--ink-soft);background:linear-gradient(#fffc 0%,#fff8e8bd 100%);border-color:#271f171f;box-shadow:inset 0 1px #ffffff94}.button-primary:disabled,.button-secondary:disabled{opacity:.56;cursor:not-allowed}.button-primary:not(:disabled):hover,.button-secondary:not(:disabled):hover,.topbar-chip:hover,.topbar-ghost:hover,.chip-button:hover{transform:translateY(-1px)}.button-primary:not(:disabled):active,.button-secondary:not(:disabled):active,.topbar-chip:active,.topbar-ghost:active,.chip-button:active{transform:translateY(0)}.button-primary:focus-visible,.button-secondary:focus-visible,.topbar-chip:focus-visible,.topbar-ghost:focus-visible,.chip-button:focus-visible,.bottom-nav-link:focus-visible{outline:none;box-shadow:0 0 0 4px #c89c482e,0 12px 26px #b281282e}.text-input,textarea,select{width:100%;min-height:48px;color:var(--ink);background:#fffcf7eb;border:1px solid #2b211724;border-radius:16px;padding:12px 14px;box-shadow:inset 0 1px #ffffff6b}textarea{resize:vertical;min-height:124px;line-height:1.75}.text-input:focus,textarea:focus,select:focus{border-color:#c89c4885;outline:none;box-shadow:0 0 0 4px #c89c481f,inset 0 1px #ffffff6b}.field-block{gap:10px;display:grid}.field-block>span{color:var(--ink-soft);font-size:.92rem;font-weight:600}.field-block small{color:var(--ink-faint);font-size:.78rem}.chip-grid{flex-wrap:wrap;gap:10px;display:flex}.chip-grid.compact{gap:8px}.chip-button{min-height:42px;color:var(--ink-soft);-webkit-tap-highlight-color:transparent;background:#ffffff8f;border:1px solid #2b21171f;border-radius:999px;padding:0 14px;font-size:.9rem;font-weight:600;transition:transform .16s,box-shadow .16s,border-color .16s,background-color .16s,color .16s,filter .16s}.chip-button.active{color:var(--gold-deep);background:linear-gradient(#f8e0aaf0 0%,#e0b85bfa 100%);box-shadow:0 8px 18px #a47b2929}.tag-row{flex-wrap:wrap;gap:8px;display:flex}.pill-tag{min-height:28px;color:var(--ink-soft);background:#ffffff8f;border:1px solid #2b211714;border-radius:999px;align-items:center;padding:0 10px;font-size:.8rem;line-height:1;display:inline-flex}.pill-tag.active{color:var(--gold-deep);background:#c99c4824;border-color:#c99c483d}.section-block{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow);padding:16px}.section-title{font-family:var(--font-serif);margin-top:6px;font-size:1.18rem;line-height:1.35}.section-body{margin-top:12px}.body-copy{color:var(--ink-soft);margin:0;font-size:.96rem;line-height:1.85}.note-list{color:var(--ink-soft);margin:0;padding-left:1.1rem;line-height:1.8}.dual-actions{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.home-page{gap:16px}.hero-card{border-radius:var(--radius-xl);box-shadow:var(--shadow-dark);border:1px solid #271f1724;overflow:hidden}.hero-surface{color:#f2dfb7;background:radial-gradient(circle at 86% 16%,#f2e0b2f5 0 8%,#f4e9c48f 12%,#0000 22%),radial-gradient(circle at 84% 20%,#ffffff2e,#0000 24%),linear-gradient(#1b1815 0%,#0d0c0b 100%);flex-direction:column;min-height:260px;padding:20px 18px 16px;display:flex;position:relative;overflow:hidden}.hero-surface:before{content:"";opacity:.38;pointer-events:none;background:radial-gradient(circle at 18% 20%,#ffffff14,#0000 22%),radial-gradient(circle at 80% 90%,#ffffff0f,#0000 26%),linear-gradient(135deg,#ffffff14 0 1px,#0000 1px 100%);position:absolute;inset:0}.hero-surface:after{content:"";pointer-events:none;background:linear-gradient(#0000,#0000003d),radial-gradient(circle at 50% 100%,#ffffff14,#0000 28%);height:50%;position:absolute;inset:auto 0 0}.hero-moon{opacity:.92;background:radial-gradient(circle at 38% 32%,#fff6,#0000 34%),radial-gradient(circle,#f4e2a6 0 56%,#ddbf72 75%,#b68b34 100%);border-radius:50%;width:92px;height:92px;position:absolute;top:16px;right:14px;box-shadow:inset -10px -14px 16px #84601e2e,0 10px 24px #00000029}.hero-bamboo{opacity:.58;pointer-events:none;background:linear-gradient(115deg,#0000 56%,#151210f5 57% 60%,#0000 61%),linear-gradient(120deg,#0000 63%,#151210e6 64% 67%,#0000 68%),linear-gradient(128deg,#0000 72%,#151210e0 73% 75%,#0000 76%),linear-gradient(136deg,#0000 79%,#151210db 80% 82%,#0000 83%);width:132px;height:168px;position:absolute;top:0;right:-6px;transform:rotate(3deg)}.hero-copy{z-index:1;max-width:20rem;position:relative}.hero-copy h1{font-family:var(--font-serif);letter-spacing:.02em;margin:0;font-size:clamp(2.2rem,10vw,3.1rem);line-height:1.02}.hero-copy p{color:#f5e5c1db;max-width:17ch;margin:14px 0 0;font-size:.9rem;line-height:1.85}.hero-cta{z-index:1;color:#2b1d0c;letter-spacing:.03em;background:radial-gradient(circle at 28% 26%,#ffffffa3,#0000 32%),linear-gradient(#f7e0a7 0%,#d2a24d 56%,#bf8932 100%);border:1px solid #7a581d2e;border-radius:999px;align-self:flex-start;align-items:center;gap:10px;min-height:52px;margin-top:22px;padding:0 24px;font-size:.98rem;font-weight:700;transition:transform .16s,box-shadow .16s,filter .16s;display:inline-flex;position:relative;box-shadow:0 14px 28px #ac7d2447,inset 0 1px #ffffff6b}.hero-cta:hover{transform:translateY(-1px)}.hero-cta:active{transform:translateY(0)}.hero-points{z-index:1;color:#f3deb5e6;letter-spacing:.2em;flex-wrap:wrap;gap:10px 14px;margin-top:auto;font-size:.76rem;display:flex;position:relative}.hero-points span+span{border-left:1px solid #ffffff29;padding-left:14px}.entry-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.entry-card{border-radius:var(--radius-lg);min-height:150px;box-shadow:var(--shadow);border:1px solid #2b211714;grid-template-rows:auto 1fr auto;grid-template-columns:1fr auto;gap:10px;padding:14px 12px 12px;transition:transform .18s,box-shadow .18s;display:grid;overflow:hidden}.entry-card:hover{box-shadow:var(--shadow-strong);transform:translateY(-1px)}.entry-card-liuyao{background:radial-gradient(circle at 84% 26%,#c59b4c1f,#0000 36%),linear-gradient(#fff8ebf2 0%,#f8f0e0f2 100%)}.entry-card-tarot{background:radial-gradient(circle at 82% 26%,#847cad24,#0000 36%),linear-gradient(#fffcfaf5 0%,#f5f1faf5 100%)}.entry-copy{grid-area:1/1/span 2}.entry-title{font-family:var(--font-serif);font-size:1.48rem;line-height:1.08}.entry-copy p{color:var(--ink-muted);margin:10px 0 0;font-size:.8rem;line-height:1.7}.entry-art{width:70px;height:70px;color:var(--gold-deep);font-family:var(--font-serif);background:#ffffffb3;border:1px solid #2b211714;border-radius:28px;grid-area:1/2/span 2;place-self:center end;place-items:center;font-size:1.2rem;font-weight:700;display:grid;box-shadow:inset 0 1px #ffffffb3}.entry-art-liuyao{background:radial-gradient(circle,#fff6 0 10%,#0000 11%),#edd5a46b}.entry-art-tarot{color:#5d5580;background:linear-gradient(#ffffffb8,#e6ddf7b3);gap:2px}.entry-art-tarot span:first-child{font-size:1.15rem}.entry-action{color:#fbf4e8;letter-spacing:.04em;background:linear-gradient(#372c22f5 0%,#1b1612f5 100%);border:1px solid #00000014;border-radius:999px;grid-column:1/span 2;justify-self:start;align-items:center;gap:8px;min-height:36px;padding:0 15px 0 14px;font-size:.82rem;font-weight:700;display:inline-flex;box-shadow:0 10px 18px #1c140d24,inset 0 1px #ffffff1a}.entry-action:after{content:"→";color:#fbf4e8db;font-size:.9rem;line-height:1}.current-reading-card{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow);grid-template-columns:42px 1fr auto;align-items:center;gap:12px;padding:14px 16px;display:grid}.current-reading-icon{width:42px;height:42px;color:var(--gold-deep);background:linear-gradient(#f4dfabf0,#cc9d48f0);border-radius:50%;place-items:center;font-size:.7rem;font-weight:700;display:grid}.current-reading-copy strong{font-family:var(--font-serif);margin-top:4px;font-size:1rem;display:block}.current-reading-copy p{color:var(--ink-muted);margin:4px 0 0;font-size:.88rem;line-height:1.6}.current-reading-arrow{width:38px;height:38px;color:var(--gold-deep);background:radial-gradient(circle at 28% 24%,#ffffffa8,#0000 32%),linear-gradient(#f6ddb0 0%,#dfb25b 100%);border:1px solid #7e5a1e2e;border-radius:50%;place-items:center;font-size:1.35rem;line-height:1;display:grid;box-shadow:0 10px 20px #a47b292e,inset 0 1px #ffffff6b}.today-strip{border-radius:var(--radius-lg);box-shadow:var(--shadow);background:linear-gradient(#fff9efeb,#f6ecdaf5);border:1px solid #2b21171a;grid-template-columns:54px 1fr auto;align-items:center;gap:12px;padding:12px 14px;display:grid}.today-icon{width:54px;height:54px;color:var(--gold-deep);font-family:var(--font-serif);background:radial-gradient(circle at 34% 32%,#fff9,#0000 34%),linear-gradient(#f7e0a4fa,#d2a13efa);border-radius:50%;place-items:center;font-size:1rem;font-weight:700;display:grid}.today-copy strong{font-family:var(--font-serif);margin-top:4px;font-size:1.12rem;display:block}.today-copy p{color:var(--ink-soft);margin:4px 0 0;font-size:.9rem;line-height:1.7}.today-meta{color:var(--ink-soft);text-align:right;border-left:1px solid #271f171a;gap:8px;padding-left:12px;font-size:.8rem;display:grid}.recent-section{gap:12px;display:grid}.section-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.section-row h2{font-family:var(--font-serif);margin:0;font-size:1.34rem}.section-row a{color:var(--gold-deep);font-size:.9rem;font-weight:600}.recent-list{gap:10px;display:grid}.recent-item{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow);grid-template-columns:44px 1fr auto;align-items:center;gap:12px;padding:12px 14px;display:grid}.recent-icon{width:44px;height:44px;font-family:var(--font-serif);color:var(--gold-deep);border-radius:50%;place-items:center;font-size:1rem;font-weight:700;display:grid}.recent-icon.liuyao{background:#c59b4c2e}.recent-icon.tarot{color:#5c557f;background:#877ead2e}.recent-copy strong{font-size:.96rem;line-height:1.5;display:block}.recent-copy p{color:var(--ink-muted);margin:4px 0 0;font-size:.86rem;line-height:1.6}.recent-time{color:var(--ink-muted);white-space:nowrap;align-self:flex-start;font-size:.8rem}.empty-state{border-radius:var(--radius-lg);background:#ffffff6b;border:1px dashed #271f1729;padding:18px 16px}.empty-state strong{font-size:1rem;display:block}.empty-state p{color:var(--ink-muted);margin:6px 0 0;font-size:.9rem;line-height:1.7}.fortune-center{text-align:center;border:1px solid var(--line);border-radius:var(--radius-xl);background:var(--surface);box-shadow:var(--shadow);justify-items:center;gap:14px;padding:18px 16px;display:grid}.fortune-ring{width:154px;height:154px;color:var(--gold-deep);background:radial-gradient(circle at 34% 32%,#ffffffb8,#0000 30%),linear-gradient(#f8e2aaf2 0%,#d0a246f5 100%);border:1px solid #2b21171a;border-radius:50%;place-items:center;display:grid;box-shadow:inset 0 0 0 10px #ffffff2e,0 14px 28px #9e701f2e}.fortune-ring span{font-family:var(--font-serif);font-size:1.8rem;font-weight:700}.fortune-center p{color:var(--ink-soft);margin:0;font-size:.98rem;line-height:1.9}.fortune-center small{color:var(--ink-muted);font-size:.84rem}.today-card-copy{justify-items:center;gap:8px;display:grid}.today-card-copy p{color:var(--ink-soft);margin:0;font-size:.98rem;line-height:1.9}.today-card-copy small{color:var(--ink-muted);font-size:.84rem}.today-actions{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.today-action-card{border-radius:var(--radius-lg);box-shadow:var(--shadow);background:radial-gradient(circle at 86% 18%,#c99c481a,#0000 28%),#ffffffa3;border:1px solid #2b21171a;padding:14px 14px 16px}.today-action-card strong{font-family:var(--font-serif);font-size:1.05rem;display:block}.today-action-card p{color:var(--ink-muted);margin:6px 0 0;font-size:.86rem;line-height:1.7}.history-page .field-block{margin-bottom:2px}.history-list{gap:10px;display:grid}.history-item{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow);padding:14px 14px 12px}.history-meta{color:var(--ink-muted);justify-content:space-between;align-items:center;gap:12px;font-size:.8rem;display:flex}.history-item strong{margin-top:8px;font-size:1rem;line-height:1.6;display:block}.history-item p{color:var(--ink-soft);margin:6px 0 0;font-size:.9rem;line-height:1.8}.history-item .tag-row{margin-top:10px}.history-actions{flex-wrap:wrap;gap:10px;margin-top:12px}.history-item .button-link{border-radius:999px;min-height:42px;padding:0 14px;font-size:.86rem}.history-delete-button{color:var(--rose);border-color:#a8513929}.history-delete-button:disabled{color:#a851396b}.history-delete-button:hover:not(:disabled){background:#a8513914}.history-summary{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow);grid-template-columns:repeat(2,minmax(0,1fr)) auto;align-items:center;gap:12px;padding:14px 16px;display:grid}.history-summary strong{font-family:var(--font-serif);margin-top:4px;font-size:1.28rem;display:block}.history-summary a{color:var(--gold-deep);background:radial-gradient(circle at 28% 24%,#ffffff9e,#0000 32%),linear-gradient(#f8e2a9f5,#e0b85bf5);border-radius:999px;justify-self:end;padding:10px 14px;font-weight:700;box-shadow:0 10px 20px #a47b2929,inset 0 1px #ffffff7a}.empty-state-card{border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow);border:1px solid #2b21171a;gap:12px;padding:18px 16px;display:grid}.empty-state-card strong{font-family:var(--font-serif);font-size:1.08rem;display:block}.empty-state-card p{color:var(--ink-muted);margin:0;font-size:.9rem;line-height:1.8}.reading-page{gap:12px}.result-hero,.result-switch{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow);gap:14px;padding:16px;display:grid}.result-hero.liuyao{background:radial-gradient(circle at 84% 20%,#c89c481f,#0000 30%),linear-gradient(#fffaf3f5,#f7eedff5)}.result-hero h2,.result-switch strong{font-family:var(--font-serif);margin-top:4px;font-size:1.38rem;line-height:1.3;display:block}.result-hero p,.result-switch p{color:var(--ink-muted);margin:6px 0 0;font-size:.92rem;line-height:1.7}.result-summary-card,.chat-summary-card{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow);padding:16px}.result-summary-card{gap:8px;display:grid}.result-summary-label{color:var(--gold);font-family:var(--font-display);letter-spacing:.24em;text-transform:uppercase;font-size:.7rem;font-style:italic}.result-summary-card strong{font-family:var(--font-serif);font-size:1.06rem;line-height:1.6}.result-summary-card p,.chat-summary-card p{color:var(--ink-muted);margin:0;font-size:.9rem;line-height:1.8}.chat-summary-card{gap:8px;display:grid}.hexagram{gap:8px;padding:8px 0;display:grid}.hexagram.compact{gap:6px}.hexagram-line{justify-content:center;gap:8px;height:14px;display:flex;position:relative}.hexagram-solid,.hexagram-broken{background:#1b1510;border-radius:999px;height:14px;display:block}.hexagram-solid{width:min(220px,88%)}.hexagram-broken{width:min(104px,41%)}.hexagram-line.moving em{background:linear-gradient(#c8953b,#8b6423);border-radius:999px;width:12px;position:absolute;inset:0 auto}.result-switch{grid-template-columns:1fr auto;align-items:center}.tarot-grid{gap:10px;display:grid}.tarot-card{border-radius:var(--radius-lg);box-shadow:var(--shadow);background:radial-gradient(circle at 78% 18%,#847cad14,#0000 24%),linear-gradient(#fffffff5,#f6f1f9f5);border:1px solid #2b211714;padding:14px}.tarot-card.reversed{background:radial-gradient(circle at 78% 18%,#c0795c1f,#0000 24%),linear-gradient(#fffcf9fa,#fbf3eaf5)}.tarot-card-top{color:var(--ink-muted);letter-spacing:.08em;text-transform:uppercase;justify-content:space-between;align-items:center;gap:12px;font-size:.78rem;display:flex}.tarot-card-core{grid-template-columns:44px 1fr;align-items:center;gap:12px;margin-top:12px;display:grid}.tarot-card-symbol{width:44px;height:44px;color:var(--gold-deep);background:linear-gradient(#f5e0abf5,#cd9f43f5);border-radius:50%;place-items:center;font-size:1.1rem;font-weight:700;display:grid}.tarot-card-core strong{font-size:1rem;display:block}.tarot-card-core small{color:var(--ink-muted);font-size:.82rem}.tarot-card-copy{color:var(--ink-soft);margin-top:10px;font-size:.9rem;line-height:1.75}.message-list{gap:10px;display:grid}.message-row{grid-template-columns:1fr;gap:8px;display:grid}.message-row.user{justify-items:end}.message-row.assistant{grid-template-columns:32px 1fr;align-items:start}.ai-avatar{width:32px;height:32px;color:var(--gold-deep);letter-spacing:.12em;text-transform:uppercase;background:linear-gradient(#edd399,#c8943f);border-radius:50%;place-items:center;font-size:.62rem;font-weight:700;display:grid}.message-bubble{box-shadow:var(--shadow);background:#ffffffb3;border:1px solid #271f1714;border-radius:18px;padding:12px 14px}.message-bubble.assistant{background:#fffaf2eb}.message-bubble.user{background:linear-gradient(#f4e0ade6,#deb762f2);justify-self:end;max-width:86%}.message-title{color:var(--gold-deep);letter-spacing:.18em;text-transform:uppercase;font-size:.72rem}.message-body{color:var(--ink-soft);white-space:pre-wrap;margin-top:6px;font-size:.92rem;line-height:1.8}.message-supporting{gap:10px;margin-top:10px;display:flex}.accent-bar{background:linear-gradient(#c99c48e6,#845c1fe6);border-radius:999px;flex:0 0 4px;width:4px}.message-supporting p{color:var(--ink-muted);margin:0;font-size:.86rem;line-height:1.75}.chat-page{gap:12px}.chat-context{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow);padding:14px 16px}.chat-context strong{font-size:1rem;display:block}.chat-context p{color:var(--ink-muted);margin:6px 0 0;font-size:.9rem;line-height:1.7}.suggested-questions{flex-wrap:wrap;gap:8px;display:flex}.suggested-questions button{min-height:42px;color:var(--ink-soft);-webkit-tap-highlight-color:transparent;background:linear-gradient(#ffffffd1,#f9f3e8db);border:1px solid #2b21171a;border-radius:999px;padding:0 14px;font-size:.86rem;font-weight:600;line-height:1;transition:transform .16s,box-shadow .16s,border-color .16s,background-color .16s,color .16s}.suggested-questions button:hover{transform:translateY(-1px)}.suggested-questions button:active{transform:translateY(0)}.suggested-questions button:focus-visible{outline:none;box-shadow:0 0 0 4px #c89c4829,0 10px 18px #a47b291f}.chat-composer{gap:10px;display:grid}.chat-composer textarea{min-height:116px}.oracle-form{gap:14px;display:grid}.flow-intro-card{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow);gap:12px;padding:16px;display:grid}.flow-intro-card strong{font-family:var(--font-serif);margin-top:4px;font-size:1.08rem;display:block}.flow-intro-card p{color:var(--ink-muted);margin:6px 0 0;font-size:.9rem;line-height:1.8}.flow-intro-card ul{color:var(--ink-soft);margin:0;padding-left:1.1rem;font-size:.88rem;line-height:1.8}.flow-intro-card.tarot{background:radial-gradient(circle at 84% 18%, #847cad14, transparent 28%), var(--surface)}.ritual-strip{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow);gap:14px;padding:16px;display:grid}.ritual-strip h3{font-family:var(--font-serif);margin:4px 0 0;font-size:1.1rem}.ritual-strip p{color:var(--ink-muted);margin:6px 0 0;font-size:.9rem;line-height:1.7}.spread-list{gap:10px;display:grid}.spread-item{border-radius:var(--radius-lg);text-align:left;background:#ffffff9e;border:1px solid #2b21171a;padding:14px}.spread-item.active{background:linear-gradient(#f8e2a9f5,#ebc258e6);border-color:#b1832c3d}.spread-item strong{font-size:.96rem;display:block}.spread-item p{color:var(--ink-muted);margin:6px 0 0;font-size:.88rem;line-height:1.7}.membership-page{gap:12px}.membership-hero,.membership-order,.membership-status-card,.feature-item,.plan-item{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow)}.membership-hero{padding:16px}.membership-hero strong{font-family:var(--font-serif);font-size:1.24rem;display:block}.membership-hero p{color:var(--ink-muted);margin:6px 0 0;font-size:.92rem;line-height:1.7}.membership-summary{gap:10px;display:grid}.membership-summary-item{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow);padding:14px 16px}.membership-summary-item strong{font-family:var(--font-serif);margin-top:4px;font-size:1.05rem;display:block}.membership-summary-item p{color:var(--ink-muted);margin:6px 0 0;font-size:.88rem;line-height:1.7}.account-summary{gap:10px;display:grid}.account-summary-card{width:100%}.account-actions{justify-content:flex-start;display:flex}.membership-order{padding:16px}.membership-order strong{font-family:var(--font-serif);font-size:1.05rem;display:block}.membership-order p{color:var(--ink-muted);margin:6px 0 0;font-size:.9rem;line-height:1.75}.membership-status-grid,.plan-grid,.feature-list{gap:10px;display:grid}.membership-status-card,.feature-item,.plan-item{padding:14px}.membership-status-card strong,.feature-item strong,.plan-item strong{font-size:1rem;display:block}.membership-status-card p,.feature-item p,.plan-item p,.plan-copy{color:var(--ink-muted);margin:6px 0 0;font-size:.9rem;line-height:1.75}.plan-item.recommended{background:linear-gradient(#fff9ecfa,#f6ecd9f5);border-color:#c89c484d}.plan-features{flex-wrap:wrap;gap:8px;margin-top:10px;display:flex}.plan-features span{min-height:28px;color:var(--ink-soft);background:#ffffffa3;border:1px solid #2b211714;border-radius:999px;align-items:center;padding:0 10px;font-size:.78rem;display:inline-flex}.plan-note{color:var(--rose);margin-top:10px;font-size:.82rem}.plan-item .button-primary{width:100%;margin-top:12px}.login-page{gap:12px}.login-account-card,.login-panel,.login-guest{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow)}.login-account-card{padding:16px}.login-account-card strong,.login-guest strong{font-family:var(--font-serif);margin-top:4px;font-size:1.08rem;display:block}.login-account-card p,.login-guest p{color:var(--ink-muted);margin:8px 0 0;font-size:.9rem;line-height:1.75}.login-panel{gap:14px;padding:14px;display:grid}.login-mode-row{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;display:grid}.login-mode-button{min-height:44px;color:var(--ink-soft);letter-spacing:.03em;-webkit-tap-highlight-color:transparent;background:#ffffff8f;border:1px solid #2b21171f;border-radius:14px;padding:0 12px;font-size:.88rem;font-weight:700;transition:transform .16s,box-shadow .16s,border-color .16s,background-color .16s,color .16s,filter .16s}.login-mode-button.active{color:var(--gold-deep);background:radial-gradient(circle at 28% 24%,#ffffff9e,#0000 32%),linear-gradient(#f9e4b5fa 0%,#e0b95afa 100%);border-color:#825f1f2e;box-shadow:0 8px 18px #a47b2929,inset 0 1px #ffffff80}.login-mode-button:not(.active):hover{transform:translateY(-1px)}.login-mode-button:active{transform:translateY(0)}.login-form,.login-guest{gap:14px;display:grid}.login-actions{gap:10px;display:grid}.login-actions .button-primary,.login-actions .button-secondary{width:100%}.login-guest{padding:6px 2px 2px}.login-feedback{border-radius:var(--radius-lg);border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow);padding:14px 16px}.login-feedback strong{font-size:.98rem;display:block}.login-feedback p{color:var(--ink-muted);margin:6px 0 0;font-size:.9rem;line-height:1.75}.login-feedback.error{border-color:#a8513933}.config-page{gap:12px}.config-toolbar{gap:10px;display:grid}.config-search{width:100%}.config-feedback{border-radius:var(--radius-md);border:1px solid var(--line);padding:12px 14px;font-size:.9rem}.config-feedback.success{color:#40642f;background:#76aa601f}.config-feedback.error{color:#8d3f2b;background:#a851391f}.config-empty{border-radius:var(--radius-lg);color:var(--ink-muted);background:#fff6;border:1px dashed #271f1724;padding:20px 16px}.config-admin-grid{gap:12px;display:grid}.config-list{gap:8px;display:grid}.config-list-item{text-align:left;width:100%;box-shadow:var(--shadow);-webkit-tap-highlight-color:transparent;background:linear-gradient(#ffffffc7 0%,#f9f3e8cc 100%);border:1px solid #2b21171a;border-radius:18px;gap:4px;padding:14px 14px 13px;transition:transform .16s,box-shadow .16s,border-color .16s,background-color .16s,color .16s;display:grid}.config-list-item:hover{transform:translateY(-1px)}.config-list-item:active{transform:translateY(0)}.config-list-item.active{background:radial-gradient(circle at 28% 22%,#ffffff94,#0000 34%),linear-gradient(#f9e5bbfa,#e6c05ff5);border-color:#b1832c3d;box-shadow:0 12px 26px #a47b2929,inset 0 1px #ffffff85}.config-list-item strong{font-size:.98rem;line-height:1.45;display:block}.config-list-item small{color:var(--ink-muted);margin-top:4px;font-size:.78rem;line-height:1.4;display:block}.config-list-item.active strong{color:var(--gold-deep)}.config-list-item.active small{color:#563c14bd}.config-editor{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow);gap:12px;padding:16px;display:grid}.config-editor-header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.config-editor-header strong{font-family:var(--font-serif);margin-top:4px;font-size:1.08rem;display:block}.config-editor-header small{color:var(--ink-muted);text-align:right;font-size:.78rem}.config-form-grid{gap:10px;display:grid}.config-textarea.tall{min-height:220px}.config-page .dual-actions{margin-top:2px}.watch-page{gap:12px}.watch-summary-card{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow);gap:12px;padding:16px;display:grid}.watch-summary-card strong{font-family:var(--font-serif);margin-top:4px;font-size:1.06rem;display:block}.watch-summary-card p{color:var(--ink-muted);margin:6px 0 0;font-size:.9rem;line-height:1.8}.watch-page .section-block{background:var(--surface)}@media (width>=560px){.hero-surface{min-height:360px}.entry-card{min-height:220px}.config-form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.section-block{padding:18px}.membership-status-grid,.membership-summary,.plan-grid,.today-actions{grid-template-columns:repeat(2,minmax(0,1fr))}.history-summary{grid-template-columns:repeat(2,minmax(0,1fr)) auto}}@media (width<=420px){.shell-main{padding-inline:12px}.entry-grid{grid-template-columns:1fr}.entry-card{min-height:188px}.today-strip{grid-template-columns:46px 1fr;grid-template-areas:"icon copy""meta meta"}.today-icon{grid-area:icon;width:46px;height:46px}.today-copy{grid-area:copy}.today-meta{text-align:left;border-top:1px solid #271f171a;border-left:0;grid-area:meta;grid-auto-flow:column;justify-content:start;padding-top:10px;padding-left:0}.recent-item{grid-template-columns:40px 1fr}.recent-time{grid-column:2;margin-top:-4px}.result-switch,.dual-actions,.today-actions{grid-template-columns:1fr}.history-summary{grid-template-columns:1fr 1fr}.history-summary a{grid-column:1/-1;justify-self:start}.message-bubble.user{max-width:100%}.bottom-nav-link{font-size:.84rem}}
