:root{color-scheme:dark;--bg: #101014;--bg-soft: #171720;--surface: rgba(255, 255, 255, .075);--surface-strong: rgba(255, 255, 255, .13);--border: rgba(255, 255, 255, .16);--text: #f6f0e6;--muted: #b9b2a9;--accent: #d7b56d;--accent-strong: #f4d58d;--danger: #cc6c6c;--shadow: 0 24px 80px rgba(0, 0, 0, .38);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Microsoft YaHei,sans-serif;background:var(--bg);color:var(--text)}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:radial-gradient(circle at 18% 12%,rgba(215,181,109,.14),transparent 26rem),radial-gradient(circle at 86% 4%,rgba(80,119,173,.15),transparent 24rem),linear-gradient(145deg,#0d0d12,#17141b 56%,#101014)}button,input{font:inherit}button{color:inherit}.app-shell{min-height:100vh;padding-bottom:86px}.screen{width:min(1180px,calc(100vw - 32px));margin:0 auto;padding:32px 0}.hero-panel,.recent-panel,.selection-panel,.ritual-panel,.result-summary,.advice-panel,.settings-panel,.empty-state{border:1px solid var(--border);background:linear-gradient(145deg,#ffffff1c,#ffffff0b);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.hero-panel{display:grid;grid-template-columns:minmax(0,1fr) minmax(340px,480px);gap:36px;align-items:center;min-height:560px;padding:44px;border-radius:8px;overflow:hidden}.hero-copy h1,.section-header h1{margin:0;font-size:clamp(38px,7vw,86px);line-height:.95;letter-spacing:0}.hero-copy p,.section-header p,.recent-panel p,.result-summary p,.advice-panel p,.settings-panel p{color:var(--muted);line-height:1.75}.hero-copy p{max-width:520px;margin:22px 0 0;font-size:18px}.hero-actions,.ritual-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px}.primary-button,.secondary-button,.ghost-button,.icon-text-button{display:inline-flex;align-items:center;justify-content:center;gap:9px;min-height:44px;padding:0 18px;border-radius:8px;border:1px solid transparent;cursor:pointer;transition:transform .16s ease,border-color .16s ease,background .16s ease}.primary-button{background:linear-gradient(135deg,#f0ce85,#a47a35);color:#1d160d;font-weight:760}.primary-button:disabled,.secondary-button:disabled,.ghost-button:disabled{cursor:not-allowed;opacity:.42}.secondary-button,.icon-text-button{background:var(--surface-strong);border-color:var(--border);color:var(--text)}.ghost-button{background:transparent;border-color:var(--border);color:var(--text)}.primary-button:not(:disabled):hover,.secondary-button:not(:disabled):hover,.ghost-button:not(:disabled):hover,.icon-text-button:hover,.bottom-nav button:hover,.topic-tile:hover,.history-item:hover{transform:translateY(-1px)}.full-width{width:100%}.hero-deck{position:relative;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;align-items:center}.hero-deck .tarot-card:nth-child(1){transform:rotate(-8deg) translateY(22px)}.hero-deck .tarot-card:nth-child(2){transform:translateY(-18px);z-index:2}.hero-deck .tarot-card:nth-child(3){transform:rotate(8deg) translateY(22px)}.tarot-card{position:relative;display:block;width:100%;aspect-ratio:4 / 7;padding:0;border:0;border-radius:8px;background:#1a1614;overflow:hidden;cursor:default;box-shadow:0 18px 40px #0000005c}button.tarot-card{cursor:pointer}.tarot-card img{width:100%;height:100%;object-fit:cover;transition:transform .24s ease}.tarot-card__back-image{display:block}.tarot-card:hover img{transform:scale(1.025)}.tarot-card.is-reversed img{transform:rotate(180deg)}.tarot-card__frame{position:absolute;top:10px;right:10px;bottom:10px;left:10px;z-index:2;border:1px solid rgba(245,211,136,.78);border-radius:6px;pointer-events:none;box-shadow:inset 0 0 0 1px #ffffff1f,0 0 18px #d7b56d2e}.tarot-card__meta{position:absolute;left:50%;bottom:14px;z-index:3;display:flex;align-items:center;justify-content:center;width:fit-content;min-width:min(74px,calc(100% - 28px));max-width:calc(100% - 28px);height:34px;padding:0 12px;border-radius:6px;background:#0a0a0cad;color:var(--text);transform:translate(-50%);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.tarot-card__meta strong{display:block;max-width:100%;overflow:hidden;font-size:clamp(12px,1.8vw,15px);line-height:1;text-align:center;text-overflow:ellipsis;white-space:nowrap}.tarot-card__numeral{position:absolute;top:16px;left:50%;z-index:3;min-width:42px;padding:5px 10px;border:1px solid rgba(245,211,136,.78);border-radius:999px;background:#0a0a0ca8;color:#f6dfaa;font-family:Georgia,Times New Roman,serif;font-size:clamp(13px,2.1vw,18px);font-weight:700;line-height:1;text-align:center;letter-spacing:.08em;transform:translate(-50%);box-shadow:0 8px 18px #0000004d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.tarot-card__orientation{position:absolute;top:14px;right:14px;z-index:3;display:grid;place-items:center;width:28px;height:28px;border:1px solid rgba(244,213,141,.74);border-radius:999px;background:#0a0a0cad;color:var(--accent-strong);font-size:13px;font-weight:800;line-height:1;box-shadow:0 8px 18px #0000004d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.tarot-card__orientation.is-reversed{border-color:#92b1ffb8;color:#cdd9ff}.tarot-card__back{display:grid;place-items:center;width:100%;height:100%;background:radial-gradient(circle,rgba(244,213,141,.16),transparent 34%),linear-gradient(145deg,#151927,#2b1e32 48%,#111116)}.tarot-card__sigil{width:42%;aspect-ratio:1;border:1px solid rgba(244,213,141,.65);border-radius:50%;box-shadow:inset 0 0 0 14px #f4d58d14,0 0 30px #f4d58d33}.recent-panel{display:flex;justify-content:space-between;gap:24px;margin-top:22px;padding:24px;border-radius:8px}.recent-panel h2,.selection-panel h2,.ritual-copy h2,.result-summary h2,.advice-panel h2{margin:0;font-size:24px;letter-spacing:0}.section-header{display:flex;justify-content:space-between;gap:24px;align-items:flex-start;margin-bottom:22px}.section-header p{max-width:680px;margin:14px 0 0}.reading-layout{display:grid;grid-template-columns:minmax(260px,.85fr) minmax(0,1.15fr);gap:18px}.topic-grid{display:grid;gap:12px}.topic-tile,.history-item,.library-card,.segmented-list button,.choice-row button{border:1px solid var(--border);background:var(--surface);color:var(--text)}.topic-tile{display:grid;grid-template-columns:auto 1fr;gap:8px 12px;align-items:center;padding:16px;border-radius:8px;text-align:left;cursor:pointer}.topic-tile span{grid-column:2;color:var(--muted);font-size:13px;line-height:1.5}.topic-tile.is-selected,.segmented-list button.is-selected,.choice-row button.is-selected{border-color:#f4d58db8;background:#f4d58d21}.selection-panel,.ritual-panel,.result-summary,.advice-panel,.settings-panel,.empty-state{padding:24px;border-radius:8px}.panel-title{display:flex;gap:12px;align-items:flex-start;margin-bottom:22px}.panel-title p{margin:6px 0 0;color:var(--muted)}.field-group{display:grid;gap:10px;margin-top:18px}.custom-question-field textarea{width:100%;min-height:104px;resize:vertical;padding:12px 14px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text);font:inherit;line-height:1.6}.custom-question-field textarea:focus{outline:2px solid rgba(244,213,141,.2);border-color:#f4d58db8}.custom-question-actions{display:flex;align-items:center;justify-content:space-between;gap:12px}.custom-question-actions>span,.question-generation-message{color:var(--muted);font-size:12px}.question-generation-message{margin:0}.question-generation-message.is-error{color:#f2a5a5}.is-spinning{animation:spin 1.1s linear infinite}.field-group label,.question-preview span,.result-summary span,.drawn-card-row span,.library-card span,.history-item span{color:var(--accent-strong);font-size:12px;font-weight:760}.segmented-list,.choice-row{display:flex;flex-wrap:wrap;gap:8px}.segmented-list button,.choice-row button{min-height:38px;padding:0 12px;border-radius:8px;cursor:pointer}.spread-option-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px}.spread-option-grid button{display:grid;gap:6px;min-height:112px;padding:14px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text);text-align:left;cursor:pointer}.spread-option-grid button.is-selected{border-color:#f4d58db8;background:#f4d58d21}.spread-option-grid button strong{font-size:16px}.spread-option-grid button span,.spread-option-grid button em{color:var(--muted);font-size:12px;font-style:normal;line-height:1.55}.question-preview{display:grid;gap:8px;margin:22px 0;padding:16px;border:1px solid rgba(244,213,141,.22);border-radius:8px;background:#00000038}.question-preview em{color:var(--muted);font-size:12px;font-style:normal}.question-preview small{color:var(--muted);font-size:12px;line-height:1.5}.entertainment-notice{margin:-10px 0 18px;color:var(--muted);font-size:12px;line-height:1.6}.result-notice{margin:-6px 2px 14px}.ritual-panel{position:relative;min-height:620px;display:grid;align-content:center;gap:28px}.ritual-back-button{position:absolute;top:18px;left:18px;z-index:4;display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:38px;padding:0 12px;border:1px solid var(--border);border-radius:8px;background:#ffffff14;color:var(--text);cursor:pointer}.ritual-back-button:disabled{cursor:default;opacity:.45}.ritual-copy{text-align:center}.ritual-copy p{color:var(--muted)}.focus-ritual{width:min(560px,100%);margin:0 auto;padding:28px;border:1px solid rgba(244,213,141,.24);border-radius:8px;background:#0000002e;text-align:center}.focus-ritual__symbol{display:block;margin-bottom:12px;color:var(--accent-strong);font-size:38px}.focus-ritual>p{margin:0;color:var(--text);font-size:18px;font-weight:720;line-height:1.7}.focus-ritual ol{display:grid;gap:8px;margin:20px 0;padding-left:22px;color:var(--muted);text-align:left;line-height:1.6}.ritual-progress{display:flex;justify-content:center;gap:10px}.ritual-progress span{width:42px;height:4px;border-radius:999px;background:#ffffff24;transition:background .18s ease,box-shadow .18s ease}.ritual-progress span.is-complete{background:var(--accent);box-shadow:0 0 14px #f4d58d4d}.ritual-deck{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,170px));justify-content:center;gap:18px}.shuffle-deck{min-height:300px;align-items:center}.shuffle-gesture{display:grid;justify-items:center;gap:24px;width:min(560px,100%);margin:0 auto;padding:26px 18px 22px;border:1px solid rgba(244,213,141,.22);border-radius:8px;background:radial-gradient(circle at 50% 38%,rgba(244,213,141,.1),transparent 46%),#00000029;cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none;outline:none}.shuffle-gesture:focus-visible{border-color:#f4d58dc7;box-shadow:0 0 0 4px #f4d58d14}.shuffle-gesture:active{cursor:grabbing}.shuffle-gesture__deck{position:relative;width:150px;aspect-ratio:4 / 7;isolation:isolate}.shuffle-gesture__card{position:absolute;top:0;right:0;bottom:0;left:0;overflow:visible;transform-origin:50% 90%;transition:transform .62s cubic-bezier(.2,.82,.2,1);will-change:transform;pointer-events:none}.shuffle-gesture__card .tarot-card{height:100%;isolation:isolate}.shuffle-gesture:not(.is-resolving) .shuffle-gesture__card{transition-duration:45ms;transition-timing-function:linear}.shuffle-gesture__hint{display:grid;grid-template-columns:auto 1fr auto;gap:8px 12px;align-items:center;color:var(--accent-strong);text-align:center}.shuffle-gesture__hint strong{font-size:14px}.shuffle-gesture__hint>span{font-size:20px;opacity:.72}.shuffle-gesture__hint small{grid-column:1 / -1;color:var(--muted);font-size:12px}.shuffle-card-button{min-width:0;padding:0;border:0;background:transparent;color:inherit;cursor:pointer;perspective:900px}.shuffle-card-button .tarot-card{pointer-events:none;transform-origin:50% 85%;will-change:transform,opacity,filter}.shuffle-card-button:hover .tarot-card{box-shadow:0 22px 48px #0000006b,0 0 0 1px #f4d58d59}.ritual-panel.is-shuffle .shuffle-card-button .tarot-card{animation:shuffle-enter .52s cubic-bezier(.2,.8,.2,1) both,shuffle-card 1.15s .52s ease-in-out infinite alternate}.ritual-panel.is-shuffle .shuffle-card-button:nth-child(2n) .tarot-card{animation-delay:.11s,.63s}.ritual-panel.is-shuffle .shuffle-card-button:nth-child(3n) .tarot-card{animation-delay:.22s,.74s}.shuffle-deck.is-resolving .shuffle-card-button .tarot-card{animation:shuffle-sweep-away .72s cubic-bezier(.5,0,.8,.2) both}.shuffle-deck.is-resolving .shuffle-card-button.is-chosen .tarot-card{animation:shuffle-card-chosen .84s cubic-bezier(.2,.85,.2,1) both}.shuffle-card-button:disabled{cursor:default}.ritual-actions{justify-content:center}.cut-deck{--cut-gap: 18px;display:grid;grid-template-columns:repeat(3,minmax(130px,170px));justify-content:center;gap:18px}.cut-ritual{display:grid;gap:18px}.cut-ritual>p{max-width:560px;margin:0 auto;color:var(--muted);font-size:13px;line-height:1.65;text-align:center}.cut-pile,.draw-slot{display:grid;gap:10px;justify-items:center;border:1px solid transparent;border-radius:8px;background:transparent;color:var(--text);cursor:pointer}.cut-pile{position:relative;padding:12px;animation:cut-pile-enter .52s cubic-bezier(.2,.8,.2,1) both;perspective:900px}.cut-pile:before,.cut-pile:after{position:absolute;inset:16px 12px auto;z-index:-1;height:calc(100% - 54px);border:1px solid rgba(244,213,141,.18);border-radius:8px;background:#18161ce6;content:""}.cut-pile:before{transform:translate(-5px,5px) rotate(-1.5deg)}.cut-pile:after{transform:translate(5px,8px) rotate(1.5deg)}.cut-pile.is-chosen:not(:disabled){border-color:#f4d58d6b}.cut-order{position:absolute;top:4px;right:4px;z-index:5;display:grid;place-items:center;width:28px;height:28px;border-radius:999px;background:var(--accent);color:#17130d;font-size:13px}.cut-pile:nth-child(2){animation-delay:90ms}.cut-pile:nth-child(3){animation-delay:.18s}.cut-pile:hover,.draw-slot:hover:not(:disabled){border-color:#f4d58d6b;background:#f4d58d14}.cut-pile .tarot-card,.draw-slot .tarot-card{pointer-events:none}.cut-pile .tarot-card{will-change:transform,opacity,filter}.cut-deck.is-resolving .cut-pile{z-index:var(--cut-layer);animation:cut-pile-merge 1.4s cubic-bezier(.2,.8,.2,1) both;pointer-events:none}.cut-deck.is-resolving .cut-pile .tarot-card{animation:none}.cut-deck.is-resolving .cut-pile span,.cut-deck.is-resolving .cut-order{animation:fade-out .24s ease both}.cut-pile span,.draw-slot span{color:var(--accent-strong);font-size:12px;font-weight:760}.manual-draw-area{display:grid;gap:18px}.draw-ready{display:grid;justify-items:center;width:min(480px,100%);margin:0 auto;padding:34px 22px;border:1px solid rgba(244,213,141,.32);border-radius:8px;background:radial-gradient(circle at 50% 20%,rgba(244,213,141,.12),transparent 46%),#0003;text-align:center;animation:draw-ready-enter .42s cubic-bezier(.2,.8,.2,1) both}.draw-ready__symbol{color:var(--accent-strong);font-size:36px}.draw-ready strong{margin-top:8px;font-family:Georgia,Times New Roman,Microsoft YaHei,serif;font-size:24px;font-weight:500}.draw-ready p{max-width:360px;margin:10px 0 22px;color:var(--muted);line-height:1.65}.draw-slots{display:grid;grid-template-columns:repeat(auto-fit,minmax(92px,128px));justify-content:center;gap:12px}.draw-slot{min-width:0;padding:8px;perspective:900px}.draw-slot .tarot-card__meta{right:14px;left:14px;width:auto;min-width:0;max-width:none;padding:0 8px;transform:none}.draw-slot:disabled{cursor:default;opacity:.42}.draw-slot.is-picked{border-color:#f4d58d61;background:#ffffff0f}.draw-slot.is-picked .tarot-card{animation:select-card-back .44s cubic-bezier(.2,.8,.2,1) both;will-change:transform,opacity,filter}.draw-slot.is-picked span{animation:draw-label-enter .46s .18s ease both}.reveal-button{justify-self:center}.reveal-spread{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,160px));justify-content:center;gap:18px}.spread-layout{align-items:end}.spread-layout--single{grid-template-columns:minmax(130px,180px);grid-template-areas:"center"}.spread-layout--line{grid-template-columns:repeat(3,minmax(120px,160px));grid-template-areas:"past present future"}.spread-layout--triangle{grid-template-columns:repeat(3,minmax(120px,160px));grid-template-areas:". spirit ." "body . mind"}.spread-layout--relationship{grid-template-columns:repeat(3,minmax(110px,150px));grid-template-areas:"self block other" ". trend ." ". advice ."}.spread-layout--choice{grid-template-columns:repeat(auto-fit,minmax(112px,150px))}.spread-layout--horseshoe{grid-template-columns:repeat(7,minmax(82px,128px));grid-template-areas:"past present hidden obstacle outside advice outcome"}.spread-layout--celtic{grid-template-columns:repeat(6,minmax(82px,124px));grid-template-areas:". crowning crowning . environment outcome" "past core cross near-future self hope-fear" ". root root . . ."}.reveal-position{display:grid;gap:10px;justify-items:center}.reveal-position>span{color:var(--accent-strong);font-size:12px;font-weight:760}.reveal-position.is-revealed .tarot-card{animation:reveal-card .66s cubic-bezier(.2,.8,.2,1) both;transform-style:preserve-3d;will-change:transform,opacity,filter}.draw-complete-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:grid;place-items:start center;padding:86px 18px 112px;background:#050508a3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:overlay-enter .26s ease both}.draw-complete-panel{display:grid;grid-template-rows:minmax(0,1fr) auto;width:min(820px,100%);max-height:min(620px,calc(100vh - 220px));overflow:hidden;border:1px solid var(--border);border-radius:8px;background:linear-gradient(145deg,#292830fa,#121218fa),var(--bg-soft);box-shadow:0 28px 90px #0000008c;animation:complete-panel-enter .42s cubic-bezier(.2,.8,.2,1) both}.draw-complete-scroll{min-height:0;overflow:auto;padding:22px 22px 8px;overscroll-behavior:contain}.draw-complete-actions{position:relative;z-index:2;margin:0;padding:14px 22px 22px;border-top:1px solid var(--border);background:linear-gradient(180deg,#1c1c23f5,#111117fc)}.draw-complete-copy{text-align:center}.draw-complete-copy span,.draw-complete-cards span{color:var(--accent-strong);font-size:12px;font-weight:760}.draw-complete-copy h2{margin:6px 0 8px;font-size:28px}.draw-complete-copy p{margin:0;color:var(--muted);line-height:1.65}.draw-complete-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(88px,116px));justify-content:center;gap:14px;margin:16px 0}.draw-complete-cards.spread-layout{grid-template-columns:repeat(auto-fit,minmax(76px,104px));align-items:end}.draw-complete-cards.spread-layout--single{grid-template-columns:minmax(76px,108px)}.draw-complete-cards.spread-layout--line,.draw-complete-cards.spread-layout--triangle,.draw-complete-cards.spread-layout--relationship{grid-template-columns:repeat(3,minmax(76px,104px))}.draw-complete-cards.spread-layout--horseshoe{grid-template-columns:repeat(7,minmax(62px,86px))}.draw-complete-cards.spread-layout--celtic{grid-template-columns:repeat(6,minmax(58px,82px))}.draw-complete-cards article{display:grid;gap:8px;justify-items:center}.result-summary{display:flex;align-items:center;justify-content:space-between;gap:22px;margin-bottom:18px}.llm-status-panel{display:flex;align-items:center;gap:10px;margin-bottom:18px;padding:12px 14px;border:1px solid var(--border);border-radius:8px;background:#ffffff0f;color:var(--muted)}.llm-status-panel span{flex:1}.llm-status-panel.is-ready{border-color:#f4d58d6b;color:var(--accent-strong)}.llm-status-panel.is-loading svg{animation:spin 1.1s linear infinite}.llm-retry-button{min-height:34px;padding:0 12px;border:1px solid rgba(244,213,141,.32);border-radius:8px;background:#f4d58d1f;color:var(--accent-strong);cursor:pointer;white-space:nowrap}.llm-retry-button:hover{background:#f4d58d2e}.drawn-card-list{display:grid;gap:16px}.drawn-card-row{display:grid;grid-template-columns:150px minmax(0,1fr);gap:18px;align-items:center;padding:16px;border:1px solid var(--border);border-radius:8px;background:#ffffff0f}.drawn-card-row h3{margin:6px 0 8px;font-size:22px}.drawn-card-row p{margin:0 0 10px;color:var(--muted);line-height:1.65}.drawn-card-row strong{display:block;line-height:1.75}.advice-panel{margin-top:18px}.advice-panel>.primary-button{justify-self:start;margin-top:18px}.advice-list{display:grid;gap:10px;margin:14px 0 0;padding:0;list-style:none;counter-reset:advice}.advice-list li{position:relative;padding:13px 14px 13px 48px;border:1px solid rgba(244,213,141,.16);border-radius:8px;background:#00000024;color:var(--text);line-height:1.7;counter-increment:advice}.advice-list li:before{position:absolute;top:13px;left:14px;color:var(--accent-strong);font-weight:760;content:counter(advice,decimal-leading-zero)}.llm-extra{display:grid;gap:12px;margin:18px 0}.llm-extra article{padding:14px;border:1px solid rgba(255,255,255,.1);border-radius:8px;background:#00000029}.llm-extra h3{margin:0 0 8px;color:var(--accent-strong);font-size:15px}.history-list{display:grid;gap:12px}.history-item{display:grid;gap:8px;padding:18px;border-radius:8px;text-align:left;cursor:pointer}.history-item strong{font-size:18px}.history-item em{color:var(--muted);font-style:normal}.empty-state{text-align:center}.search-box{display:flex;align-items:center;gap:10px;width:min(320px,100%);height:44px;padding:0 12px;border:1px solid var(--border);border-radius:8px;background:var(--surface)}.search-box input{min-width:0;width:100%;border:0;outline:0;background:transparent;color:var(--text)}.settings-panel{max-width:860px}.toggle-row{display:inline-flex;align-items:center;gap:10px;min-height:42px;margin:8px 0 18px;color:var(--text);cursor:pointer}.toggle-row input{width:18px;height:18px;accent-color:var(--accent)}.settings-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.settings-field{display:grid;gap:8px}.settings-field span{color:var(--accent-strong);font-size:12px;font-weight:760}.settings-field input,.settings-field select{width:100%;min-height:42px;padding:0 12px;border:1px solid var(--border);border-radius:8px;background:#0000002e;color:var(--text)}.choice-options-field{gap:12px}.choice-option-inputs{display:grid;gap:10px}.choice-option-input{display:grid;gap:7px}.choice-option-input input{width:100%;min-height:42px;padding:0 12px;border:1px solid var(--border);border-radius:8px;outline:0;background:#0000002e;color:var(--text)}.choice-option-input input:focus{border-color:#f4d58db8;box-shadow:0 0 0 2px #f4d58d21}.settings-field select{color-scheme:dark;cursor:pointer}.settings-field select option{background:#1f1d24;color:var(--text)}.settings-field select option:checked{background:#3a3327;color:var(--accent-strong)}.settings-field input[type=range]{padding:0;accent-color:var(--accent)}.settings-saved{align-self:center;color:var(--accent-strong);font-weight:760}.disclaimer-panel{max-width:860px;margin-top:18px;padding:22px;border:1px solid rgba(244,213,141,.22);border-radius:8px;background:#00000029}.disclaimer-panel .panel-title{margin-bottom:12px}.disclaimer-panel p{margin:8px 0 0;color:var(--muted);font-size:13px;line-height:1.7}.settings-test-result{margin-top:16px;padding:14px;border:1px solid var(--border);border-radius:8px;background:#ffffff0f}.settings-test-result strong{color:var(--accent-strong)}.settings-test-result p{margin:6px 0 0}.settings-test-result code{display:block;margin-top:10px;padding:10px;border-radius:8px;background:#00000038;color:var(--text);white-space:pre-wrap;word-break:break-word}.settings-test-result.is-success{border-color:#95d5b285}.settings-test-result.is-error{border-color:#ff8b8b8a}.settings-test-result.is-error strong{color:#ffb3b3}.library-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px}.library-groups{display:grid;gap:22px}.library-group{display:grid;gap:14px;padding:18px;border:1px solid var(--border);border-radius:8px;background:#ffffff0b}.library-group__header{display:flex;justify-content:space-between;gap:18px;align-items:flex-start}.library-group__header h2{margin:0;font-size:24px}.library-group__header p{margin:8px 0 0;color:var(--muted);line-height:1.65}.library-group__header>span{flex:0 0 auto;padding:6px 10px;border:1px solid rgba(244,213,141,.26);border-radius:999px;background:#f4d58d1a;color:var(--accent-strong);font-size:12px;font-weight:760}.library-detail{display:grid;grid-template-columns:minmax(180px,.5fr) minmax(0,1.5fr);gap:18px;margin-bottom:18px;padding:20px;border:1px solid var(--border);border-radius:8px;background:#ffffff0f}.library-detail span,.library-meanings strong{color:var(--accent-strong);font-size:12px;font-weight:760}.library-detail h2{margin:8px 0 6px;font-size:28px}.library-detail p,.library-meanings p{margin:0;color:var(--muted);line-height:1.65}.library-meanings{display:grid;gap:12px}.library-meanings article{padding:12px;border:1px solid rgba(255,255,255,.1);border-radius:8px;background:#00000029}.library-card{padding:10px;border-radius:8px;transition:border-color .16s ease,background .16s ease}.library-card.is-selected{border-color:#f4d58dad;background:#f4d58d1a}.library-detail-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;display:grid;place-items:end center;padding:18px;background:#05050894;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.library-detail-drawer{position:relative;width:min(720px,100%);max-height:min(78vh,680px);overflow:auto;padding:22px;border:1px solid var(--border);border-radius:8px;background:linear-gradient(145deg,#292830fa,#121218fa),var(--bg-soft);box-shadow:0 28px 90px #0000008c}.library-detail-drawer>div:first-of-type{padding-right:48px}.library-detail-drawer span{color:var(--accent-strong);font-size:12px;font-weight:760}.library-detail-drawer h2{margin:8px 0 6px;font-size:30px}.library-detail-drawer p{margin:0;color:var(--muted);line-height:1.65}.detail-close-button{position:absolute;top:14px;right:14px;display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border:1px solid var(--border);border-radius:8px;background:#ffffff14;color:var(--text);cursor:pointer}.detail-close-button span{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}.library-card h2{margin:8px 0 4px;font-size:18px}.library-card p{margin:0;color:var(--muted);font-size:13px;line-height:1.5}.bottom-nav{position:fixed;left:50%;bottom:16px;z-index:20;display:grid;grid-template-columns:repeat(5,1fr);gap:6px;width:min(640px,calc(100vw - 32px));padding:8px;border:1px solid var(--border);border-radius:8px;background:#121218db;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);transform:translate(-50%)}.bottom-nav button{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;height:52px;border:0;border-radius:8px;background:transparent;color:var(--muted);cursor:pointer}.bottom-nav button.is-active{background:#f4d58d21;color:var(--accent-strong)}.bottom-nav span{font-size:12px}@keyframes shuffle-card{0%{transform:translateY(0) rotate(-4deg)}to{transform:translateY(-22px) rotate(5deg)}}@keyframes shuffle-enter{0%{opacity:0;transform:translateY(44px) rotate(-12deg) scale(.9)}to{opacity:1;transform:translateY(0) rotate(-4deg) scale(1)}}@keyframes shuffle-sweep-away{0%{opacity:1;transform:translateY(0) rotate(0) scale(1)}to{opacity:0;transform:translateY(70px) rotate(14deg) scale(.82);filter:blur(5px)}}@keyframes shuffle-card-chosen{0%{transform:translateY(-12px) rotate(0) scale(1)}45%{transform:translateY(-54px) rotateY(12deg) scale(1.12);filter:drop-shadow(0 22px 28px rgba(244,213,141,.2))}to{opacity:0;transform:translateY(-12px) rotateY(78deg) scale(.86);filter:blur(3px)}}@keyframes draw-ready-enter{0%{opacity:0;transform:translateY(18px) scale(.97)}}@keyframes cut-pile-enter{0%{opacity:0;transform:translateY(42px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes cut-pile-dismiss{to{opacity:0;transform:translateY(36px) scale(.82);filter:blur(4px)}}@keyframes cut-pile-chosen{0%{transform:translateY(0) scale(1)}48%{transform:translateY(-34px) scale(1.12);filter:drop-shadow(0 22px 30px rgba(244,213,141,.24))}to{opacity:0;transform:translateY(-62px) rotateY(72deg) scale(.9)}}@keyframes cut-pile-merge{0%{transform:translate(0) translateY(0) scale(1)}28%{transform:translate(0) translateY(-24px) scale(1.04);filter:drop-shadow(0 18px 24px rgba(244,213,141,.18))}72%,to{transform:translate(var(--cut-merge-x)) translateY(-10px) scale(.98);filter:drop-shadow(0 22px 30px rgba(0,0,0,.42))}}@keyframes reveal-card{0%{opacity:.3;transform:rotateY(92deg) translateY(20px) scale(.86);filter:brightness(1.5) blur(3px)}62%{opacity:1;transform:rotateY(-8deg) translateY(-10px) scale(1.06);filter:brightness(1.18) blur(0)}to{opacity:1;transform:rotateY(0) translateY(0) scale(1);filter:brightness(1)}}@keyframes select-card-back{0%{transform:translateY(0) scale(1)}55%{transform:translateY(-14px) scale(1.05);filter:brightness(1.16)}to{transform:translateY(0) scale(1);filter:brightness(1)}}@keyframes draw-label-enter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-out{to{opacity:0}}@keyframes overlay-enter{0%{opacity:0;-webkit-backdrop-filter:blur(0);backdrop-filter:blur(0)}}@keyframes complete-panel-enter{0%{opacity:0;transform:translateY(30px) scale(.96)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 860px){.screen{width:min(100vw - 24px,680px);padding-top:18px}.hero-panel,.reading-layout,.library-detail,.result-summary{grid-template-columns:1fr}.reading-screen .section-header{margin-bottom:14px}.reading-screen .section-header h1{font-size:38px}.reading-screen .section-header p{margin-top:8px;line-height:1.55}.topic-scroll-wrapper{width:100%;min-width:0}.topic-grid{display:flex;gap:8px;width:calc(100vw - 24px);overflow-x:auto;padding:2px 2px 8px;scroll-padding-inline:2px;scroll-snap-type:x mandatory;scrollbar-width:none}.topic-grid::-webkit-scrollbar{display:none}.topic-tile{display:inline-flex;flex:0 0 auto;gap:7px;min-height:44px;padding:0 13px;scroll-snap-align:start;white-space:nowrap}.topic-tile svg{width:18px;height:18px}.topic-tile span{display:none}.selection-panel{padding:18px}.panel-title{margin-bottom:12px}.panel-title p{font-size:13px;line-height:1.5}.hero-panel{padding:24px;min-height:auto}.hero-deck{max-width:420px;margin:10px auto 0}.section-header,.recent-panel,.library-group__header,.result-summary{flex-direction:column;align-items:stretch}.drawn-card-row{grid-template-columns:112px minmax(0,1fr)}.spread-layout--triangle,.spread-layout--relationship,.spread-layout--horseshoe,.spread-layout--celtic{grid-template-columns:repeat(auto-fit,minmax(110px,150px));grid-template-areas:none}.reveal-spread.spread-layout{width:100%;grid-template-areas:none;grid-template-columns:repeat(auto-fit,minmax(82px,1fr));gap:10px}.reveal-spread.spread-layout>*{min-width:0;grid-area:auto!important}.reveal-spread .tarot-card{width:min(100%,116px)}.spread-layout--triangle>*,.spread-layout--relationship>*,.spread-layout--horseshoe>*,.spread-layout--celtic>*{grid-area:auto!important}.draw-complete-overlay{place-items:end center;padding:12px 12px calc(92px + env(safe-area-inset-bottom))}.draw-complete-panel{width:100%;max-height:calc(100dvh - 116px - env(safe-area-inset-bottom))}.draw-complete-scroll{padding:18px 16px 8px}.draw-complete-actions{display:grid;grid-template-columns:minmax(0,.8fr) minmax(0,1.2fr);gap:10px;padding:12px 16px calc(14px + env(safe-area-inset-bottom))}.draw-complete-actions button{min-height:48px;padding-inline:10px}.draw-complete-cards.spread-layout--horseshoe,.draw-complete-cards.spread-layout--celtic{grid-template-columns:repeat(3,minmax(66px,92px))}}@media (max-width: 540px){.hero-copy h1,.section-header h1{font-size:42px}.hero-deck{gap:4px}.ritual-deck{grid-template-columns:repeat(auto-fit,minmax(96px,1fr));gap:10px}.ritual-panel{min-height:calc(100dvh - 150px);padding:72px 12px 26px}.shuffle-gesture{padding:24px 14px 18px}.shuffle-gesture__deck{width:132px}.cut-deck{--cut-gap: 8px;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.draw-slots{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.draw-slot{padding:4px}.draw-ready{min-height:310px;align-content:center}.reveal-spread.spread-layout{grid-template-columns:repeat(3,minmax(0,1fr))}.reveal-position{min-width:0}.reveal-position>span{max-width:100%;overflow-wrap:anywhere;text-align:center}.drawn-card-row{grid-template-columns:1fr}.drawn-card-row .tarot-card{width:min(180px,70vw)}.settings-grid{grid-template-columns:1fr}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}}.home-search-screen{width:min(1080px,calc(100vw - 40px));min-height:calc(100vh - 86px);padding-top:24px}.home-search-header{display:flex;align-items:center;justify-content:space-between;gap:20px}.home-brand,.home-history-link,.change-question-button,.home-search-footer button{display:inline-flex;align-items:center;gap:9px;padding:0;border:0;background:transparent;color:var(--text);cursor:pointer}.home-brand span{display:grid;place-items:center;width:30px;height:30px;border:1px solid rgba(244,213,141,.5);border-radius:50%;color:var(--accent-strong);font-family:Georgia,Times New Roman,serif}.home-brand strong{font-family:Georgia,Times New Roman,Microsoft YaHei,serif;font-size:17px;letter-spacing:.08em}.home-history-link,.change-question-button{min-height:40px;color:var(--muted);font-size:14px}.home-history-link:hover,.change-question-button:hover,.home-search-footer button:hover{color:var(--accent-strong)}.question-search{display:grid;justify-items:center;width:min(850px,100%);margin:clamp(100px,17vh,180px) auto 0;transition:margin .32s ease}.question-search.has-results{margin-top:68px}.question-search-copy{text-align:center}.question-search-copy h1{margin:0;font-family:Georgia,Times New Roman,Microsoft YaHei,serif;font-size:clamp(42px,7vw,72px);font-weight:500;line-height:1.08;letter-spacing:-.04em}.question-search-copy p{margin:18px 0 0;color:var(--muted);font-size:16px;line-height:1.7}.question-search-form{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:14px;align-items:center;width:100%;min-height:76px;margin-top:34px;padding:10px 11px 10px 22px;border:1px solid rgba(244,213,141,.34);border-radius:10px;background:#101014d1;box-shadow:0 26px 80px #0000006b,inset 0 1px #ffffff0d;-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px);transition:border-color .18s ease,box-shadow .18s ease}.question-search-form:focus-within{border-color:#f4d58dc7;box-shadow:0 30px 90px #00000075,0 0 0 4px #f4d58d12}.question-search-form>svg{color:var(--accent-strong)}.question-search-form textarea{width:100%;min-height:32px;max-height:112px;padding:5px 0;overflow-y:auto;resize:none;border:0;outline:0;background:transparent;color:var(--text);font:inherit;font-size:17px;line-height:1.45}.question-search-form textarea::placeholder{color:#817b75}.question-submit-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:54px;padding:0 20px;border:1px solid rgba(244,213,141,.5);border-radius:8px;background:linear-gradient(135deg,#f0ce85,#a47a35);color:#1d160d;font-size:14px;font-weight:800;cursor:pointer}.question-submit-button:disabled{cursor:not-allowed;filter:saturate(.5);opacity:.48}.question-search-meta{display:flex;justify-content:space-between;width:100%;padding:9px 4px 0;color:#88817a;font-size:11px}.question-search-error{width:100%;margin:12px 0 0;color:#f2a5a5;font-size:13px}.question-analysis-loading{display:flex;align-items:center;gap:16px;width:min(460px,100%);margin-top:34px;padding:16px 18px;border-top:1px solid rgba(244,213,141,.2)}.question-analysis-loading>span{width:9px;height:9px;border-radius:50%;background:var(--accent-strong);box-shadow:0 0 20px #f4d58dbf;animation:analysis-pulse 1.2s ease-in-out infinite}.question-analysis-loading strong{font-size:14px}.question-analysis-loading p{margin:5px 0 0;color:var(--muted);font-size:12px}.flow-recommendations{width:min(980px,100%);margin:56px auto 24px;animation:flow-results-enter .42s ease both}.flow-recommendations-header{display:flex;align-items:flex-start;justify-content:space-between;gap:28px;margin-bottom:24px}.analysis-category{display:flex;align-items:center;gap:10px;margin:0 0 10px;color:var(--accent-strong);font-size:13px;font-weight:760}.analysis-category span{padding-left:10px;border-left:1px solid var(--border);color:var(--muted);font-size:11px;font-weight:600}.flow-recommendations h2{margin:0;font-family:Georgia,Times New Roman,Microsoft YaHei,serif;font-size:clamp(28px,4vw,40px);font-weight:500}.flow-recommendations blockquote{max-width:720px;margin:13px 0 0;color:var(--muted);font-size:14px;line-height:1.65}.flow-option-list{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.flow-option{position:relative;display:grid;grid-template-rows:auto 1fr auto;gap:20px;min-height:240px;padding:20px;overflow:hidden;border:1px solid var(--border);border-radius:8px;background:#ffffff0b;color:var(--text);text-align:left;cursor:pointer;transition:transform .18s ease,border-color .18s ease,background .18s ease}.flow-option:hover{transform:translateY(-2px);border-color:#f4d58d6b}.flow-option.is-selected{border-color:#f4d58dcc;background:linear-gradient(150deg,#f4d58d21,#ffffff0a);box-shadow:inset 0 0 0 1px #f4d58d1a}.flow-option-index{color:var(--accent-strong);font-family:Georgia,Times New Roman,serif;font-size:12px;letter-spacing:.12em}.flow-option-copy{display:grid;align-content:start;gap:10px}.flow-option-copy strong{font-family:Georgia,Times New Roman,Microsoft YaHei,serif;font-size:21px;font-weight:500}.flow-option-copy>span{color:var(--muted);font-size:13px;line-height:1.65}.flow-option-meta{display:flex;flex-wrap:wrap;gap:7px 14px;padding-top:14px;border-top:1px solid rgba(255,255,255,.1);color:#aaa39a;font-size:11px}.flow-option-check{position:absolute;top:18px;right:18px;width:16px;height:16px;border:1px solid rgba(255,255,255,.28);border-radius:50%}.flow-option.is-selected .flow-option-check{border:5px solid var(--accent-strong);background:#1c1812}.flow-confirmation{display:flex;align-items:center;justify-content:space-between;gap:24px;margin-top:18px;padding-top:18px;border-top:1px solid var(--border)}.flow-confirmation p{margin:0;color:var(--muted);font-size:13px}.flow-confirmation .primary-button{min-width:178px}.home-search-footer{display:grid;gap:12px;justify-items:center;width:min(720px,100%);margin:clamp(90px,16vh,150px) auto 0;color:#7f7973;text-align:center}.home-search-footer p{margin:0;font-size:11px;line-height:1.6}.home-search-footer button{max-width:100%;color:var(--muted);font-size:12px}@keyframes analysis-pulse{50%{opacity:.45;transform:scale(.72)}}@keyframes flow-results-enter{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 760px){.home-search-screen{width:min(100% - 28px,1080px);padding-top:18px}.question-search,.question-search.has-results{margin-top:70px}.question-search-copy h1{font-size:clamp(38px,12vw,54px)}.question-search-copy p{max-width:360px;font-size:14px}.question-search-form{grid-template-columns:auto minmax(0,1fr);gap:12px;padding:15px}.question-search-form textarea{font-size:16px}.question-submit-button{grid-column:1 / -1;width:100%}.question-search-meta span:last-child{display:none}.flow-recommendations{margin-top:42px}.flow-recommendations-header{display:grid;gap:8px}.change-question-button{justify-self:start}.flow-option-list{grid-template-columns:1fr}.flow-option{grid-template-columns:auto minmax(0,1fr);grid-template-rows:auto auto;gap:8px 14px;min-height:0;padding:18px}.flow-option-index{grid-row:1 / 3;padding-top:4px}.flow-option-copy{padding-right:20px}.flow-option-meta{padding-top:10px}.flow-confirmation{align-items:stretch;flex-direction:column;gap:12px}.flow-confirmation .primary-button{width:100%}}@media (max-width: 420px){.home-search-header{align-items:flex-start}.home-history-link{font-size:0}.home-history-link svg{width:20px;height:20px}.question-search,.question-search.has-results{margin-top:54px}.question-search-copy h1{letter-spacing:-.06em}.question-search-form{margin-top:26px}.flow-option-copy strong{font-size:19px}}.ambient-music-control{position:fixed;right:max(18px,env(safe-area-inset-right));bottom:calc(98px + env(safe-area-inset-bottom));z-index:42;display:flex;align-items:center;min-height:42px;border:1px solid rgba(244,213,141,.28);border-radius:8px;background:#111117e6;box-shadow:0 14px 36px #00000057;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.ambient-toggle{display:grid;place-items:center;width:42px;min-height:42px;padding:0;border:0;background:transparent;color:var(--accent-strong);cursor:pointer}.ambient-volume-row{display:flex;align-items:center;gap:6px;width:142px;padding:0 10px 0 2px;color:var(--muted)}.ambient-volume{width:100%;height:28px;accent-color:var(--accent)}@media (max-width: 540px){.ambient-music-control{right:12px;bottom:calc(88px + env(safe-area-inset-bottom))}.ambient-volume-row{width:112px}}
