:root{--paper:#fffdf8;--field:#f5f1e8;--panel:#fffdf8db;--ink:#26231f;--text:#605c55;--muted:#837c71;--line:#37302824;--line-strong:#3730284d;--sage:#d8e5df;--moss:#707b4e;--clay:#9f6246;--indigo:#58647a;--soft-shadow:0 18px 45px #2f292117;color:var(--text);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:16px;font-weight:400;line-height:1.5}*{box-sizing:border-box}body{background:linear-gradient(135deg, #d8e5dfb3, #fffdf8cc 42%, #d9dde2b8), radial-gradient(circle at 20% 10%, #9f62461f, transparent 32%), var(--paper);min-width:320px;margin:0}a{color:inherit}::selection{background:#527d8b3d}.app-shell{min-height:100vh;padding:28px}.topbar{justify-content:space-between;align-items:center;gap:20px;max-width:1440px;margin:0 auto 22px;display:flex}.sync-badge{border:1px solid var(--line);color:var(--muted);background:#fffdf8ad;border-radius:999px;min-width:max-content;margin:0;padding:8px 11px;font-size:12px;font-weight:700}.eyebrow{color:var(--muted);text-transform:uppercase;margin:0 0 4px;font-size:12px;font-weight:700}h1,h2,h3{color:var(--ink);letter-spacing:0;margin:0}h1{font-size:36px;line-height:1.05}h2{font-size:22px;line-height:1.18}h3{font-size:17px;line-height:1.25}p{margin:0}button,input,select,textarea{font:inherit}button{cursor:pointer;border:0;justify-content:center;align-items:center;gap:8px;display:inline-flex}button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,a:focus-visible{outline-offset:2px;outline:3px solid #527d8b59}.view-tabs{background:var(--panel);border:1px solid var(--line);box-shadow:var(--soft-shadow);border-radius:999px;gap:4px;padding:5px;display:flex}.view-tabs button{color:var(--muted);background:0 0;border-radius:999px;min-height:40px;padding:0 14px}.view-tabs button.active{background:var(--ink);color:var(--paper)}.workspace,.records-layout,.deck-view{max-width:1440px;margin:0 auto}.workspace{grid-template-columns:minmax(360px,440px) minmax(0,1fr);align-items:start;gap:20px;display:grid}.reading-panel,.result-panel,.records-panel,.thread-list,.deck-view{border:1px solid var(--line);box-shadow:var(--soft-shadow);background:#fffdf8c7;border-radius:8px}.reading-panel{gap:18px;padding:18px;display:grid}.prompt-block{gap:8px;display:grid}label,.section-heading{color:var(--ink);font-size:14px;font-weight:700}textarea,input,select{background:var(--field);border:1px solid var(--line);box-sizing:border-box;color:var(--ink);border-radius:8px;width:100%;min-width:0}textarea{resize:vertical;min-height:132px;padding:13px 14px;line-height:1.5}input,select{min-height:42px;padding:0 12px}.panel-section{border-top:1px solid var(--line);gap:12px;padding-top:16px;display:grid}.section-heading{align-items:center;gap:8px;display:flex}.section-heading small{color:var(--muted);margin-left:auto;font-size:12px;font-weight:600}.people-actions{grid-template-columns:minmax(0,1fr) auto;gap:8px;display:grid}.people-actions button,.candidate-row button,.primary-action,.ghost-button{border-radius:8px;min-height:42px;padding:0 13px}.people-actions button,.candidate-row button{background:var(--sage);color:var(--ink)}.candidate-row{flex-wrap:wrap;gap:8px;display:flex}.candidate-row button{min-height:34px;padding:0 10px}.notice{color:#71412d;background:#9f62461f;border:1px solid #9f624638;border-radius:8px;padding:9px 10px;font-size:13px}.people-grid{flex-wrap:wrap;gap:8px;max-height:184px;padding-right:2px;display:flex;overflow:auto}.person-chip{background:var(--field);border:1px solid var(--line);border-radius:999px;align-items:stretch;min-height:36px;display:inline-flex;overflow:hidden}.person-chip>button:first-child{color:var(--ink);background:0 0;gap:6px;padding:0 0 0 12px}.person-chip small{color:var(--muted);font-size:12px}.person-chip.selected{background:#26372f;border-color:#26372f}.person-chip.selected span,.person-chip.selected small,.person-chip.selected .icon-button{color:var(--paper)}.icon-button{color:var(--muted);background:0 0;min-width:32px;padding:0}.empty-state{background:var(--field);border:1px dashed var(--line-strong);color:var(--muted);text-align:center;border-radius:8px;width:100%;padding:18px;font-size:14px}.recommendations{gap:8px;display:grid}.recommendations button{background:var(--field);border:1px solid var(--line);color:var(--ink);text-align:left;border-radius:8px;flex-direction:column;align-items:start;gap:4px;min-height:64px;padding:12px}.recommendations button.active{color:var(--paper);background:#26372f;border-color:#26372f}.recommendations span{color:var(--muted);font-size:13px}.recommendations button.active span{color:#fffdf8bf}.spread-detail{background:#d8e5df6b;border:1px solid #707b4e2e;border-radius:8px;gap:12px;padding:14px;display:grid}.spread-detail h2{margin-bottom:5px;font-size:18px}.spread-detail p,.spread-detail a{color:var(--muted);font-size:13px;line-height:1.5}.spread-detail a{text-decoration:none}.positions{flex-wrap:wrap;gap:7px;display:flex}.positions span{border:1px solid var(--line);color:var(--ink);background:#fffdf8b8;border-radius:999px;padding:5px 9px;font-size:12px}.primary-action{background:var(--clay);color:#fffdf8;width:100%;min-height:50px;font-weight:800}.result-panel{min-height:760px;padding:20px}.result-head,.records-head,.deck-head{justify-content:space-between;align-items:center;gap:16px;margin-bottom:18px;display:flex}.result-head>span,.deck-head>span{background:var(--field);border:1px solid var(--line);color:var(--muted);border-radius:999px;padding:7px 11px;font-size:13px}.spread-board{grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px;display:grid}.spread-board.count-3{grid-template-columns:repeat(3,minmax(0,1fr))}.spread-board.count-5{grid-template-columns:repeat(5,minmax(0,1fr))}.drawn-card{border:1px solid var(--line);background:#fffdf8d6;border-radius:8px;gap:12px;padding:12px;display:grid}.position-label{min-height:48px}.position-label span,.meaning strong{color:var(--ink);font-size:14px;font-weight:800;display:block}.position-label small,.meaning small{color:var(--muted);margin-top:3px;font-size:12px;line-height:1.4;display:block}.meaning{gap:5px;display:grid}.meaning p{color:var(--text);font-size:13px;line-height:1.48}.summary-box{color:#fffdf8db;background:#26372f;border-radius:8px;margin-top:16px;padding:18px}.summary-title{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px 12px;margin-bottom:8px;display:flex}.summary-title h2{color:#fffdf8;font-size:18px}.summary-title span{color:#fffdf8b8;border:1px solid #fffdf833;border-radius:999px;padding:4px 9px;font-size:12px}.summary-box p{line-height:1.65}.result-placeholder{justify-content:center;align-items:center;min-height:700px;display:flex}.tarot-card{aspect-ratio:220/340;background:#f9f7ef;border:1px solid #2d28202e;border-radius:12px;grid-template-rows:minmax(0,1fr) auto;width:100%;min-width:0;max-width:236px;margin:0 auto;padding:8px;display:grid;overflow:hidden;box-shadow:0 10px 22px #2b251d21}.tarot-card.compact{max-width:none}.card-illustration{border-radius:8px;overflow:hidden}.card-illustration.is-reversed{transform:rotate(180deg)}.tarot-card svg{width:100%;height:100%;display:block}.paper{fill:#fbf6ea;stroke:var(--card-ink);stroke-dasharray:8 5 2 5;stroke-linecap:round;stroke-width:1.2px}.paper-grain{fill:#4b413433;mix-blend-mode:multiply;opacity:.36;pointer-events:none}.deckle-line{fill:none;opacity:.32;stroke:var(--card-ink);stroke-linecap:round;stroke-width:1.2px}.tea-stain{fill:var(--card-wash);opacity:.58}.minor-wash{opacity:.36}.court-wash{opacity:.42}.steam,.symbol-line{fill:none;stroke:var(--card-accent);stroke-linecap:round;stroke-width:4px}.tea-shadow{fill:#333d2429}.tea-cup{fill:#fffdf8d1;stroke:var(--card-ink);stroke-linecap:round;stroke-linejoin:round;stroke-width:4.6px}.cat-head,.cat-body{fill:var(--card-accent);opacity:.92}.cat-ear,.cat-tail,.cat-face{fill:none;stroke:var(--card-ink);stroke-linecap:round;stroke-linejoin:round;stroke-width:5px}.cat-face{stroke-width:4px}.small-moon,.tea-dot{fill:var(--card-ink);opacity:.58}.rank-mark{fill:var(--card-ink);text-anchor:middle;font-family:Georgia,Times New Roman,serif;font-size:19px;font-weight:700}.rank-mark.bottom{transform-box:fill-box;transform-origin:50%;transform:rotate(180deg)}.suit-label{fill:var(--muted);text-anchor:middle;font-size:9px;font-weight:700}.pip-field{filter:drop-shadow(0 5px 7px #2f29211a)}.suit-glyph,.suit-glyph.quiet{opacity:.9}.suit-glyph path,.suit-glyph circle,.suit-glyph ellipse{stroke:var(--card-ink);stroke-linecap:round;stroke-linejoin:round;stroke-width:3.6px}.suit-cups .cup-bowl{fill:#fffdf8d1}.suit-cups .cup-handle,.suit-cups .cup-cat-ear,.suit-cups .cup-cat-face,.suit-cups .tea-splash{fill:none}.suit-cups .cup-tea{fill:var(--card-wash);opacity:.78}.suit-cups .cup-cat-head{fill:var(--card-accent);opacity:.92}.suit-cups .tea-drop{fill:var(--card-accent);stroke-width:0}.suit-cups.spilled{opacity:.95}.suit-swords .sword-cat-head,.suit-swords .sword-cat-body{fill:var(--card-accent);opacity:.92}.suit-swords .sword-cat-ear,.suit-swords .sword-hilt,.suit-swords .sword-cat-face{fill:none}.suit-swords .sword-blade{fill:#fffdf8b3}.suit-pentacles .coin-body{fill:#e6c46b}.suit-pentacles .coin-cat,.suit-pentacles .coin-face,.suit-pentacles .coin-star{fill:none}.suit-pentacles .sugar-cube{fill:#fffdf8cc}.suit-pentacles .coin-dot{fill:var(--card-accent);stroke-width:0}.suit-wands .spoon-bowl{fill:#fffdf8b8}.suit-wands .spoon-handle,.suit-wands .spoon-shine{fill:none}.tea-cat{filter:drop-shadow(0 7px 9px #2f29211a)}.court-role{filter:drop-shadow(0 8px 11px #2f29211f)}.court-throne{fill:#fffdf8c7;stroke:var(--card-ink);stroke-linejoin:round;stroke-width:5px}.court-mount{fill:#fffdf8bf;stroke:var(--card-ink);stroke-linecap:round;stroke-linejoin:round;stroke-width:5px}.court-scroll{fill:#fffdf8d1;stroke:var(--card-ink);stroke-linecap:round;stroke-linejoin:round;stroke-width:4px}.court-crown{fill:var(--card-wash);stroke:var(--card-ink);stroke-linejoin:round;stroke-width:4px}.court-cat,.court-body{fill:var(--card-accent);opacity:.92}.court-ear,.court-tail,.court-face{fill:none;stroke:var(--card-ink);stroke-linecap:round;stroke-linejoin:round;stroke-width:5px}.court-face{stroke-width:4px}.court-line{opacity:.82}.sketch-texture{fill:var(--card-ink);opacity:.58;pointer-events:none}.sketch-texture path{fill:none;stroke:var(--card-ink);stroke-linecap:round;stroke-width:.9px}.sketch-texture circle{fill:var(--card-ink);opacity:.28}.card-caption{text-align:center;align-items:center;min-height:47px;padding:7px 4px 2px;display:grid}.card-caption span{color:var(--ink);font-size:14px;font-weight:800;line-height:1.12}.card-caption small{color:var(--muted);font-size:10px;line-height:1.2}.card-back{background:#26372f}.back-paper{fill:#26372f;stroke:#fbf8ef;stroke-dasharray:9 5;stroke-width:1.6px}.back-ring,.back-cup,.back-paw,.back-steam{fill:none;stroke:#fbf8ef;stroke-linecap:round;stroke-linejoin:round;stroke-width:5px}.back-paw{fill:#fbf8ef24}.back-dot{fill:#c78b66}.card-back .card-caption span,.card-back .card-caption small{color:#fffdf8}.records-layout{grid-template-columns:260px minmax(0,1fr);align-items:start;gap:18px;display:grid}.thread-list{gap:8px;padding:16px;display:grid}.thread-list button{background:var(--field);border:1px solid var(--line);color:var(--ink);border-radius:8px;justify-content:space-between;min-height:42px;padding:0 12px}.thread-list button.active{color:var(--paper);background:#26372f}.thread-list small{color:var(--muted);font-size:12px}.thread-list button.active small{color:#fffdf8c2}.records-panel{min-height:720px;padding:18px}.ghost-button{background:var(--field);border:1px solid var(--line);color:var(--ink)}.record-list{gap:10px;display:grid}.record-item{border:1px solid var(--line);cursor:pointer;background:#fffdf8d1;border-radius:8px;grid-template-columns:minmax(0,1fr) 190px;gap:12px;padding:14px;display:grid}.record-item time{color:var(--muted);margin-bottom:5px;font-size:12px;font-weight:700;display:block}.record-item p{color:var(--text);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-top:7px;font-size:13px;line-height:1.5;display:-webkit-box;overflow:hidden}.record-meta{align-content:start;justify-items:end;gap:7px;display:grid}.record-meta span{background:var(--field);border:1px solid var(--line);color:var(--muted);text-align:right;border-radius:999px;padding:5px 9px;font-size:12px}.deck-view{padding:20px}.deck-grid{grid-template-columns:repeat(auto-fill,minmax(132px,1fr));gap:14px;display:grid}.deck-grid .tarot-card{box-shadow:0 8px 18px #2b251d1a}@media (width<=1180px){.workspace,.records-layout{grid-template-columns:1fr}.thread-list{grid-template-columns:repeat(auto-fit,minmax(130px,1fr))}.thread-list .section-heading{grid-column:1/-1}.spread-board.count-5,.spread-board.count-3{grid-template-columns:repeat(auto-fit,minmax(190px,1fr))}}@media (width<=720px){.app-shell{padding:14px}.topbar,.result-head,.records-head,.deck-head{flex-direction:column;align-items:stretch}.view-tabs{border-radius:8px;grid-template-columns:repeat(3,minmax(0,1fr));display:grid}.view-tabs button{border-radius:6px;padding:0 8px}h1{font-size:30px}.people-actions,.record-item{grid-template-columns:1fr}.record-meta{justify-items:start}.result-panel{padding:14px}.deck-grid{grid-template-columns:repeat(auto-fill,minmax(118px,1fr))}}
