/* ============================================================================
   MATRIA, women-centred knowledge atlas. Shared styles.
   Palette: deep midnight navy ground · warm cream paper · gold + tan accents.
   ============================================================================ */

/* Design tokens (palette, type families, radii) now live in matria-tokens.css,
   loaded before this file. See DESIGN-SYSTEM.md. */

*{box-sizing:border-box;}
html{color-scheme:light dark;}
html,body{margin:0;padding:0;}
button,input,textarea,[role="button"]{touch-action:manipulation;}
button:focus-visible,input:focus-visible,textarea:focus-visible,[tabindex]:focus-visible{
  outline:2px solid var(--gold);
  outline-offset:3px;
}

/* ── Phone shell ─────────────────────────────────────────── */
.phone{
  width:300px;height:650px;border-radius:48px;
  background:#0c0c10;padding:7px;
  box-shadow:0 1px 0 1px #2b2c34, 0 26px 50px -20px rgba(12,12,18,.6), 0 10px 22px -12px rgba(12,12,18,.5);
  flex:none;
}
.screen{
  position:relative;width:100%;height:100%;border-radius:41px;overflow:hidden;
  background:var(--cream);display:flex;flex-direction:column;font-family:var(--font-body);
  color:var(--ink);
}
.screen.dark{background:var(--night-grad);color:var(--ctext);}
.screen.dark.today-route{background:#050508;}

/* Matria editorial rollout primitives */
.screen.matria-dark{
  background:
    radial-gradient(ellipse 90% 48% at 82% 6%, rgba(201,143,106,.08), transparent 56%),
    linear-gradient(180deg,#050508 0%,#07070a 62%,#030305 100%);
  color:var(--ctext);
}
.screen.matria-cream,
.screen.has-womb-sky{
  background:
    radial-gradient(ellipse 90% 42% at 50% -6%, rgba(217,181,133,.26), transparent 64%),
    linear-gradient(180deg,#fbf3e2 0%,#f4ead6 34%,#efe1c7 100%);
  color:var(--ink);
}
.matria-page{
  padding-top:8px;
  padding-bottom:calc(14px + env(safe-area-inset-bottom));
}
.matria-head{position:relative;margin-bottom:15px;}
.matria-head--rail{padding-left:28px;}
.matria-head--rail::before{
  content:'';position:absolute;left:9px;top:7px;width:15px;height:15px;
  background:center/contain no-repeat url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 3.5v17M3.5 12h17M6.2 6.2l11.6 11.6M17.8 6.2L6.2 17.8' stroke='%23c98f6a' stroke-width='1' stroke-linecap='round'/%3E%3Ccircle cx='12' cy='12' r='6.2' stroke='%23c98f6a' stroke-width='.8' opacity='.72'/%3E%3C/svg%3E");
  opacity:.7;
}
.matria-head--rail::after{
  content:'';position:absolute;left:16px;top:29px;bottom:0;width:1px;
  background:linear-gradient(180deg,rgba(201,143,106,.45),transparent);
}
.matria-title{
  font-family:var(--font-display);font-size:30px;line-height:1.06;
  letter-spacing:-.018em;font-weight:600;margin:0;text-wrap:balance;
}
.screen.matria-dark .matria-title{color:#d9a184;}
.screen.matria-cream .matria-title,
.screen.has-womb-sky .matria-title{color:#33281f;}
.matria-lead{
  margin:8px 0 0;font-family:var(--font-body);font-size:12.2px;line-height:1.48;
  letter-spacing:.005em;
}
.screen.matria-dark .matria-lead{color:rgba(231,224,210,.68);}
.screen.matria-cream .matria-lead,
.screen.has-womb-sky .matria-lead{color:#6b5f50;}
.matria-rule{
  display:flex;align-items:center;gap:10px;color:var(--gold);opacity:.62;margin:14px 0;
}
.matria-rule::before,.matria-rule::after{
  content:'';height:1px;flex:1;background:linear-gradient(90deg,transparent,rgba(201,143,106,.5));
}
.matria-rule::after{background:linear-gradient(90deg,rgba(201,143,106,.5),transparent);}
.matria-section-label{
  font-family:var(--font-body);font-size:9px;font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;line-height:1.2;color:var(--gold);
}
.matria-card{
  border-radius:16px;overflow:hidden;
  border:1px solid rgba(201,143,106,.16);
  box-shadow:0 16px 38px -32px rgba(0,0,0,.75), inset 0 1px 0 rgba(255,255,255,.035);
}
.screen.matria-dark .matria-card,
.screen.matria-dark .card,
.screen.matria-dark .dcard{
  background:linear-gradient(155deg,rgba(28,28,34,.88),rgba(13,13,16,.9));
  border-color:rgba(201,143,106,.16);
}
.screen.matria-cream .matria-card,
.screen.has-womb-sky .matria-card,
.screen.matria-cream .card,
.screen.has-womb-sky .card{
  background:linear-gradient(180deg,rgba(255,248,234,.92),rgba(244,231,205,.9));
  border-color:rgba(184,147,90,.24);
  box-shadow:0 12px 30px -24px rgba(122,90,46,.35), inset 0 1px 0 rgba(255,255,255,.42);
}
.screen.matria-dark .lrow{
  background:linear-gradient(155deg,rgba(28,28,34,.82),rgba(13,13,16,.88));
  border:1px solid rgba(201,143,106,.14);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.035);
}
.screen.matria-cream .lrow,
.screen.has-womb-sky .lrow{
  background:linear-gradient(180deg,rgba(255,248,234,.88),rgba(244,231,205,.86));
  border:1px solid rgba(184,147,90,.22);
}
.screen.matria-dark .lrow__slot{
  color:#c98f6a;background:rgba(201,143,106,.08);border-color:rgba(201,143,106,.22);
}
.screen.matria-cream .lrow__slot,
.screen.has-womb-sky .lrow__slot{
  color:#a36f4d;background:rgba(201,143,106,.1);border-color:rgba(184,147,90,.26);
}
.matria-cta{
  background:linear-gradient(180deg,#e8bc98 0%,#d49b70 100%)!important;
  color:#2b2118!important;border:none!important;
  box-shadow:0 10px 28px rgba(201,143,106,.28), inset 0 1px 0 rgba(255,255,255,.36)!important;
}
.screen.matria-dark .tag,
.screen.matria-dark .chip.on{border-color:rgba(201,143,106,.28);}
.screen.matria-dark .scrollfade{background:linear-gradient(transparent,#030305);}

/* status bar */
.status{height:44px;flex:none;display:flex;align-items:center;justify-content:space-between;padding:0 26px 0 28px;}
.status .clock{font-size:14px;font-weight:700;letter-spacing:.01em;}
.status .sig{display:flex;align-items:center;gap:6px;}
.screen.dark .status{color:var(--ctext);}
.status svg{display:block;}

/* scroll body */
.s-body{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;position:relative;-webkit-overflow-scrolling:touch;}
.s-body::-webkit-scrollbar{width:0;background:transparent;}
.pad{padding-left:24px;padding-right:24px;}

/* tab bar */
.tabbar{
  flex:none;height:66px;display:flex;align-items:flex-start;justify-content:space-around;
  padding:7px 10px calc(8px + env(safe-area-inset-bottom));
  border-top:1px solid var(--line-cream-soft);
  backdrop-filter:blur(14px);
}
.screen.dark .tabbar{border-top-color:var(--line-dark);}
.tab{
  position:relative;display:flex;flex-direction:column;align-items:center;gap:4px;flex:1;
  min-width:0;cursor:pointer;background:none;border:none;padding:0 2px;
  font-family:var(--font-body);-webkit-tap-highlight-color:transparent;
}
.tab__icon{
  position:relative;display:inline-flex;align-items:center;justify-content:center;
  width:28px;height:28px;border-radius:50%;
}
.tab > span:last-child{font-size:9.8px;letter-spacing:.005em;font-weight:650;line-height:1.1;}
.tab-badge{position:absolute;top:-3px;right:-5px;min-width:14px;height:14px;padding:0 4px;border-radius:8px;background:var(--gold);color:#1a1c29;font-size:8.5px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1;box-shadow:0 0 0 2px var(--night);}

.tab svg{display:block;}
.tab.on::after{
  content:'';position:absolute;left:50%;top:29px;width:14px;height:2px;
  transform:translateX(-50%);border-radius:2px;
}
.screen.dark .tabbar{
  background:linear-gradient(180deg,rgba(5,5,8,0),rgba(5,5,8,.82));
}
.screen.dark .tab{color:rgba(231,224,210,.45);}
.screen.dark .tab svg{stroke:rgba(231,224,210,.45);}
.screen.dark .tab.on{color:var(--gold);}
.screen.dark .tab.on svg{stroke:var(--gold);}
.screen.dark .tab.on .tab__icon{
  background:rgba(201,143,106,.08);
  box-shadow:inset 0 0 0 1px rgba(201,143,106,.18);
}
.screen.dark .tab.on::after{
  background:var(--gold);
  box-shadow:0 0 10px rgba(201,143,106,.28);
}
.screen:not(.dark) .tabbar{
  background:linear-gradient(180deg,rgba(244,239,227,0),rgba(244,239,227,.86));
}
.screen:not(.dark) .tab{color:rgba(38,38,45,.48);}
.screen:not(.dark) .tab svg{stroke:rgba(38,38,45,.48);}
.screen:not(.dark) .tab.on{color:#7a4e36;}
.screen:not(.dark) .tab.on svg{stroke:#7a4e36;}
.screen:not(.dark) .tab.on .tab__icon{
  background:rgba(201,143,106,.1);
  box-shadow:inset 0 0 0 1px rgba(184,147,90,.2);
}
.screen:not(.dark) .tab.on::after{background:#a36f4d;}
.tab:focus-visible,.chip:focus-visible,.btn:focus-visible,.sheet-close:focus-visible{
  outline:2px solid var(--gold);
  outline-offset:3px;
}

/* type */
.wordmark{
  font-family:var(--font-word);font-size:var(--type-wordmark);line-height:1;
  letter-spacing:.16em;font-weight:600;
}
.title{font-family:var(--font-display);font-size:var(--type-h1);font-weight:600;letter-spacing:-.012em;margin:0;line-height:1.06;}
.display-title{font-size:var(--type-display);line-height:1.08;}
.section-title{font-size:var(--type-h2);line-height:1.15;}
.quote-text{font-family:var(--font-display);font-size:var(--type-quote);line-height:1.4;font-style:italic;font-weight:500;}
.screen.dark .title{color:var(--gold-display);}
.label{font-family:var(--font-body);font-size:var(--type-label);font-weight:700;letter-spacing:.16em;text-transform:uppercase;line-height:1;}
.screen.dark .label{color:var(--gold-bright);}
.screen:not(.dark) .label{color:var(--ink-soft);}
.lead{font-size:var(--type-lead);line-height:1.5;}
.screen.dark .lead{color:var(--ctext-soft);}
.screen:not(.dark) .lead{color:var(--ink-soft);}
.bodytext{font-size:var(--type-body);line-height:1.62;}
.screen.dark .bodytext{color:var(--ctext);}
.screen:not(.dark) .bodytext{color:#46433d;}
/* long reading on night: sans, softer, never full-brightness blocks */
.screen.dark .dark-prose .bodytext{
  font-family:var(--font-body);font-size:12.5px;line-height:1.58;
  color:var(--ctext-reading);font-weight:400;letter-spacing:.01em;margin:0;
}
.screen.dark .dark-prose .bodytext+.bodytext{margin-top:10px;}
.screen.dark .dark-lead{
  font-family:var(--font-display);font-size:14px;line-height:1.52;
  color:var(--ctext-soft);font-weight:500;margin:0;
}
.screen.dark .dark-prose .dark-lead+.bodytext{margin-top:10px;}
.meta{font-size:var(--type-caption);line-height:1.4;font-weight:600;}
.screen.dark .meta{color:var(--ctext-soft);}
.screen:not(.dark) .meta{color:var(--ink-faint);}
.section-stack{display:flex;flex-direction:column;gap:var(--space-4);}
.reading-measure{max-width:62ch;}

/* buttons, tactile and quiet */
.btn{position:relative;display:flex;align-items:center;justify-content:center;gap:9px;border-radius:30px;font-size:15px;font-weight:700;cursor:pointer;border:none;font-family:var(--font-body);width:100%;min-height:44px;height:54px;letter-spacing:.015em;transition:transform .14s cubic-bezier(.2,.8,.2,1), box-shadow .2s ease, filter .2s, background .2s, border-color .2s;-webkit-tap-highlight-color:transparent;user-select:none;}
.btn:active{transform:scale(.975);}
.btn-tan{background:linear-gradient(180deg,#dbc095 0%,#caa370 100%);color:#332719;box-shadow:inset 0 1px 0 rgba(255,255,255,.38), inset 0 -1px 0 rgba(122,90,46,.2), 0 8px 20px -12px rgba(140,104,56,.52);}
.btn-tan:hover{filter:brightness(1.04);}
.btn-navy{background:linear-gradient(180deg,#272939 0%,#191b27 100%);color:#efe7d6;box-shadow:inset 0 1px 0 rgba(255,255,255,.08), 0 10px 24px -14px rgba(22,24,38,.68);}
.btn-navy::after{content:'';position:absolute;inset:0;border-radius:inherit;border:1px solid rgba(200,160,100,.22);pointer-events:none;}
.btn-navy:hover{filter:brightness(1.12);}
.btn-ghost-dark{background:rgba(200,160,100,.06);border:1px solid var(--line-gold);color:var(--gold);height:48px;backdrop-filter:blur(4px);}
.btn-ghost-dark:hover{background:rgba(200,160,100,.12);}
.btn .btn-arrow{display:inline-flex;transition:transform .2s cubic-bezier(.2,.8,.2,1);}
.btn:hover .btn-arrow{transform:translateX(3px);}

/* horizontal chip scroller, no scrollbar, right-edge fade as affordance */
.hscroll{display:flex;gap:7px;flex-wrap:nowrap;overflow-x:auto;flex:none;scrollbar-width:none;-ms-overflow-style:none;
  -webkit-mask-image:linear-gradient(90deg,#000 calc(100% - 28px),transparent);mask-image:linear-gradient(90deg,#000 calc(100% - 28px),transparent);}
.hscroll::-webkit-scrollbar{display:none;height:0;}

/* bottom sheet, handle, sticky header, hidden scrollbar, edge fades */
@keyframes sheetUp{from{transform:translateY(46px);}to{transform:none;}}
.map-caption{animation:map-caption-fade 4s ease forwards;}
@keyframes map-caption-fade{0%{opacity:0;transform:translateX(-50%) translateY(8px);}14%{opacity:1;transform:translateX(-50%) translateY(0);}70%{opacity:1;transform:translateX(-50%) translateY(0);}100%{opacity:0;}}
@media (prefers-reduced-motion:reduce){.map-caption{animation:none;opacity:1;}}
.sheet-backdrop{position:absolute;inset:0;background:rgba(8,9,14,.55);backdrop-filter:blur(3px);z-index:6;display:flex;align-items:flex-end;}
.sheet{width:100%;max-height:64%;display:flex;flex-direction:column;background:linear-gradient(180deg,#1d1f2b,#171922);border-top:1px solid var(--line-gold);border-radius:22px 22px 0 0;box-shadow:0 -18px 50px -20px rgba(0,0,0,.7);overflow:hidden;}
@media (prefers-reduced-motion:no-preference){.sheet{animation:sheetUp .32s cubic-bezier(.2,.8,.2,1);}}
.sheet-handle{width:38px;height:4px;border-radius:3px;background:rgba(231,224,210,.22);margin:9px auto 0;flex:none;}
.sheet-head{flex:none;display:flex;align-items:center;justify-content:space-between;padding:12px 22px 11px;border-bottom:1px solid var(--line-dark);}
.sheet-close{width:28px;height:28px;border-radius:50%;background:rgba(231,224,210,.08);border:none;color:var(--ctext-soft);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:13px;line-height:1;}
.sheet-scroll{flex:1;min-height:0;overflow-y:auto;padding:4px 22px 8px;scrollbar-width:none;-ms-overflow-style:none;-webkit-mask-image:linear-gradient(180deg,#000 calc(100% - 34px),transparent);mask-image:linear-gradient(180deg,#000 calc(100% - 34px),transparent);}
.sheet-scroll::-webkit-scrollbar{display:none;width:0;}
.sheet-foot{flex:none;padding:9px 22px 16px;}

/* hairline */
.rule{height:1px;background:var(--line-cream);border:0;margin:0;}
.screen.dark .rule, .rule.d{height:1px;background:var(--line-dark);border:0;margin:0;}

/* dots */
.dots{display:flex;gap:8px;justify-content:center;}
.dots i{width:7px;height:7px;border-radius:50%;background:currentColor;opacity:.26;transition:opacity .3s;}
.dots i.on{opacity:1;}

/* chips */
.chip{display:inline-flex;align-items:center;justify-content:center;min-height:30px;padding:0 14px;border-radius:var(--r-chip);font-size:12.5px;font-weight:600;cursor:pointer;border:1px solid transparent;font-family:var(--font-body);background:none;transition:background .15s,color .15s,border-color .15s,transform .12s;-webkit-tap-highlight-color:transparent;}
.chip:active{transform:scale(.95);}
.screen:not(.dark) .chip{background:var(--chip-sand);color:#5a5246;}
.screen:not(.dark) .chip.on{background:var(--tan);color:#3a2d1b;}
.screen.dark .chip{background:rgba(255,255,255,.025);border-color:var(--line-dark);color:var(--ctext-soft);}
.screen.dark .chip.on{background:rgba(200,160,100,.13);color:var(--gold-bright);border-color:var(--line-gold);}

/* tag (idea pill) */
.tag{display:inline-flex;align-items:center;height:28px;padding:0 12px;border-radius:8px;font-size:11.5px;font-weight:600;font-family:var(--font-body);}
.screen.dark .tag{background:rgba(255,255,255,.035);border:1px solid var(--line-dark);color:var(--gold-bright);}
.screen:not(.dark) .tag{background:#efe6d6;border:1px solid var(--line-cream);color:#5a5246;}

/* portraits */
.portrait{object-fit:cover;display:block;background:#cfc8ba;}
.portrait.round{border-radius:50%;}
.portrait--collage{object-fit:cover;object-position:center 22%;background:#0f1016;}
.source-detail-portrait{
  width:100px;height:100px;flex:none;border-radius:12px;overflow:hidden;
  border:1px solid var(--line-gold);background:#0f1016;
  box-shadow:0 10px 24px -14px rgba(0,0,0,.35);
}
.source-detail-portrait .portrait{width:100%;height:100%;}
.source-detail-portrait--dark{border-color:rgba(200,160,100,.35);background:#0a0a0f;}
.abstract-portrait{
  position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;
  color:rgba(240,217,168,.86);background:#171923;isolation:isolate;
  box-shadow:inset 0 0 18px rgba(5,5,8,.62), 0 10px 26px -18px rgba(0,0,0,.72);
}
.abstract-portrait.round{border-radius:50%;}
.abstract-portrait::before{
  content:'';position:absolute;inset:-18%;z-index:0;
  background:
    radial-gradient(circle at var(--ap-x1) var(--ap-y1), rgba(220,186,132,.56) 0 2px, transparent 6px),
    radial-gradient(circle at var(--ap-x2) var(--ap-y2), rgba(201,143,106,.44) 0 1.5px, transparent 5px),
    linear-gradient(142deg, transparent 20%, rgba(220,186,132,.16) 48%, transparent 74%),
    radial-gradient(ellipse at 50% 58%, rgba(201,143,106,.18), transparent 58%),
    linear-gradient(150deg,#242633,#11121a 72%);
}
.abstract-portrait-1::before{filter:hue-rotate(8deg) saturate(1.05);}
.abstract-portrait-2::before{filter:hue-rotate(-12deg) saturate(.95);}
.abstract-portrait-3::before{filter:hue-rotate(18deg) saturate(.9);}
.abstract-portrait-4::before{filter:hue-rotate(-22deg) saturate(.9);}
.abstract-portrait__veil{
  position:absolute;inset:16% 20% 8%;z-index:1;border-radius:48% 52% 42% 58%;
  background:radial-gradient(ellipse at 50% 40%, rgba(231,224,210,.14), rgba(231,224,210,.04) 44%, transparent 70%);
  opacity:.72;
}
.abstract-portrait__thread{
  position:absolute;left:18%;right:16%;top:52%;height:1px;z-index:2;
  background:linear-gradient(90deg, transparent, rgba(220,186,132,.62), transparent);
  transform:rotate(-24deg);
}
.abstract-portrait__star{
  position:absolute;width:3px;height:3px;border-radius:50%;z-index:2;background:#dcba84;
  box-shadow:0 0 10px rgba(220,186,132,.8);
}
.abstract-portrait__star.s1{left:28%;top:30%;}
.abstract-portrait__star.s2{right:26%;bottom:28%;opacity:.75;}
.abstract-portrait__mark{
  position:relative;z-index:3;font-family:var(--font-display);font-size:calc(var(--ap-size) * .26);
  letter-spacing:.03em;text-shadow:0 1px 10px rgba(0,0,0,.82);
}
.type-medallion{
  position:relative;display:inline-flex;align-items:center;justify-content:center;flex:none;
  border-radius:14px;color:var(--gold);background:rgba(200,160,100,.1);
  border:1px solid var(--line-gold);overflow:hidden;isolation:isolate;
}
.type-medallion__halo{
  position:absolute;inset:9%;border-radius:50%;background:radial-gradient(circle, rgba(220,186,132,.2), transparent 68%);
}
.type-medallion svg{position:relative;z-index:1;}
.type-medallion-person{color:#d9b585;}
.type-medallion-myth{color:#c89bb0;}
.type-medallion-political,.type-medallion-power{color:#cf8f6a;}
.type-medallion-history{color:#9bb8c8;}
.type-medallion-science,.type-medallion-cosmos{color:#9cc2a6;}
.type-medallion-tradition{color:#c9b07a;}
.type-medallion-idea{color:#a99bc8;}
@media (prefers-reduced-motion:no-preference){
  .abstract-portrait::before{animation:portrait-glow 7s ease-in-out infinite;}
  .abstract-portrait__thread{animation:portrait-thread 5.6s ease-in-out infinite;}
}
@keyframes portrait-glow{0%,100%{transform:scale(1);opacity:.92;}50%{transform:scale(1.04);opacity:1;}}
@keyframes portrait-thread{0%,100%{opacity:.35;}50%{opacity:.85;}}

/* cards */
.card,.dcard{border-radius:var(--r-card);}
.card--touch{cursor:pointer;transition:transform .12s cubic-bezier(.2,.8,.2,1), box-shadow .2s ease;}
.card--touch:active{transform:scale(.992);}
.card-pad{padding:13px 14px;}
.screen:not(.dark) .card,.screen:not(.dark) .dcard{
  background:linear-gradient(180deg,var(--cream-card-2),var(--cream-card));
  border:.5px solid var(--line-cream);
  box-shadow:0 12px 30px -28px rgba(38,38,45,.45);
}
.screen.dark .card,.screen.dark .dcard{
  background:rgba(255,255,255,.032);
  border:.5px solid var(--line-dark);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.025);
}

/* list row (cream) */
.lrow{display:flex;align-items:center;gap:13px;border-radius:14px;cursor:pointer;transition:background .15s,border-color .15s,transform .12s;min-height:48px;padding:13px 14px;}
.lrow:active{transform:scale(.992);}
.lrow__slot{
  width:40px;height:40px;flex:none;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
}
.screen:not(.dark) .lrow__slot{border:1px solid var(--line-cream);color:var(--ink-soft);background:rgba(255,255,255,.35);}
.screen.dark .lrow__slot{border:1px solid var(--line-dark);color:var(--gold);background:rgba(200,160,100,.08);}
.screen:not(.dark) .lrow{background:linear-gradient(180deg,var(--cream-card-2),var(--cream-card));border:.5px solid var(--line-cream);}
.screen:not(.dark) .lrow:hover{background:var(--cream-card-2);}
.screen.dark .lrow{background:rgba(255,255,255,.032);border:.5px solid var(--line-dark);}

.empty-state{
  text-align:center;padding:46px 0 0;
}
.empty-state__art{display:flex;justify-content:center;opacity:.9;}
.empty-state__copy{
  font-size:var(--type-body);line-height:1.62;max-width:232px;margin:14px auto 18px;color:var(--ink-soft);
}
.screen.dark .empty-state__copy{color:var(--ctext-soft);}
.empty-state .btn{width:190px;margin:0 auto;height:44px;}

/* fade at scroll bottom */
.scrollfade{position:sticky;bottom:0;left:0;right:0;height:26px;pointer-events:none;margin-top:-26px;}
.screen:not(.dark) .scrollfade{background:linear-gradient(transparent,var(--cream));}
.screen.dark .scrollfade{background:linear-gradient(transparent,#10111800);}

/* entrance */
@keyframes fadeUp{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:none;}}
@keyframes riseIn{from{transform:translateY(10px);}to{transform:none;}}
.screen-host{height:100%;}
@media (prefers-reduced-motion:no-preference){
  .anim-up{animation:riseIn .5s cubic-bezier(.2,.8,.2,1);}
  .screen-host{animation:riseIn .3s cubic-bezier(.2,.8,.2,1);}
}

@keyframes spin{to{transform:rotate(360deg);}}
@keyframes pulse{0%,100%{opacity:.5;}50%{opacity:1;}}
@keyframes draw{to{stroke-dashoffset:0;}}
@keyframes m-float{0%,100%{transform:translateY(0);}50%{transform:translateY(-7px);}}
@media (prefers-reduced-motion:no-preference){
  .m-float{animation:m-float 7s ease-in-out infinite;}
  .m-rotate{animation:spin 36s linear infinite;}
}

/* dock foot: primary CTA pinned at screen bottom, scroll body above */
.matria-dock-foot{
  flex:none;position:relative;z-index:2;
  padding:10px 24px calc(10px + env(safe-area-inset-bottom));
  border-top:1px solid rgba(201,143,106,.14);
  background:linear-gradient(180deg,rgba(5,5,8,0),rgba(5,5,8,.92) 24%,#050508);
  backdrop-filter:blur(12px);
}
.screen.splash-v2 .matria-dock-foot{
  padding-left:22px;padding-right:22px;
  border-top-color:rgba(201,143,106,.12);
  background:linear-gradient(180deg,rgba(3,3,5,0),rgba(3,3,5,.9) 24%,#030305);
}
.screen.onboard-v2 .matria-dock-foot{padding-left:26px;padding-right:26px;}
.screen.matria-cream .matria-dock-foot{
  border-top-color:rgba(184,147,90,.18);
  background:linear-gradient(180deg,rgba(244,231,205,0),rgba(244,231,205,.94) 22%,rgba(244,231,205,.98));
}

/* onboarding v2: title + side art, pillar panel, privacy lock */
.screen.onboard-v2{background:#050508;}
.onboard-v2__scroll{
  flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
  padding:calc(5px + env(safe-area-inset-top)) 26px 14px;
}
.onboard-v2__hero{
  position:relative;min-height:192px;margin-bottom:0;
}
.onboard-v2__rail{
  position:absolute;left:2px;top:26px;width:20px;height:108px;
  display:flex;flex-direction:column;align-items:center;color:var(--gold-bright);
  opacity:.72;z-index:3;
}
.onboard-v2__rail span{
  width:1px;flex:1;margin-top:9px;
  background:linear-gradient(180deg,rgba(201,143,106,.55),transparent);
}
.onboard-v2__title-wrap{
  position:relative;z-index:3;max-width:56%;padding-top:26px;padding-left:28px;
}
.onboard-v2__star{display:none;}
.onboard-v2__title{
  font-family:var(--font-display);font-size:28.5px;line-height:1.06;
  font-weight:600;color:var(--gold-display);margin:0;letter-spacing:-.018em;text-wrap:balance;
  text-shadow:0 1px 14px rgba(0,0,0,.42);
}
.onboard-v2__art{
  position:absolute;right:-30px;top:4px;width:76%;max-width:none;height:190px;
  pointer-events:none;z-index:1;overflow:hidden;
}
.onboard-v2__art img{
  width:100%;height:100%;object-fit:cover;object-position:62% 48%;
  filter:brightness(.9) contrast(1.08) saturate(1.03);
  mix-blend-mode:screen;
  -webkit-mask-image:
    radial-gradient(ellipse 74% 70% at 68% 46%, #000 38%, transparent 74%),
    linear-gradient(90deg, transparent 0%, #000 24%, #000 88%, transparent 100%);
  mask-image:
    radial-gradient(ellipse 74% 70% at 68% 46%, #000 38%, transparent 74%),
    linear-gradient(90deg, transparent 0%, #000 24%, #000 88%, transparent 100%);
}
.onboard-v2__rule{
  display:flex;justify-content:flex-start;align-items:center;margin:0 0 12px;color:var(--gold-bright);opacity:.78;
  gap:10px;
}
.onboard-v2__rule::after{content:'';width:86px;height:1px;background:linear-gradient(90deg,rgba(201,143,106,.52),transparent);}
.onboard-v2__copy{margin-bottom:4px;}
.onboard-v2__prose{
  font-family:var(--font-body);font-size:10.9px;line-height:1.48;
  color:rgba(231,224,210,.7);margin:0;letter-spacing:.005em;
}
.onboard-v2__highlight{
  font-family:var(--font-body);font-size:10.9px;line-height:1.48;
  color:var(--ctext);margin:4px 0 0;font-weight:600;
}
.onboard-v2__pillars{
  margin-top:12px;border:1px solid rgba(231,224,210,.12);border-radius:14px;
  background:linear-gradient(180deg,rgba(255,255,255,.02),rgba(255,255,255,.01));overflow:hidden;
}
.onboard-v2__pillar{
  display:flex;align-items:flex-start;gap:13px;padding:5px 14px;
  border-bottom:1px solid rgba(231,224,210,.09);
}
.onboard-v2__pillar--last{border-bottom:0;}
.onboard-v2__pillar-icon{
  flex:none;width:33px;min-height:27px;display:flex;align-items:center;justify-content:flex-start;
  color:var(--gold-bright);opacity:.92;margin-top:1px;border-right:1px solid rgba(201,143,106,.16);
}
.onboard-v2__pillar-copy{min-width:0;}
.onboard-v2__pillar-title{
  display:block;font-family:var(--font-body);font-size:9px;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;color:var(--gold-bright);line-height:1.25;
}
.onboard-v2__pillar-sub{
  display:block;margin-top:2px;font-size:9px;line-height:1.28;
  color:rgba(231,224,210,.55);
}
.onboard-v2__foot{
  display:flex;flex-direction:column;align-items:stretch;
}
.onboard-v2__cta{
  width:100%;min-height:50px;height:50px;border-radius:28px;
  font-size:16px;font-weight:700;
  background:linear-gradient(180deg,#e8bc98 0%,#d49b70 100%);
  box-shadow:0 10px 28px rgba(201,143,106,.28), inset 0 1px 0 rgba(255,255,255,.36);
}
.onboard-v2__privacy{
  display:flex;align-items:center;justify-content:center;gap:8px;
  margin:11px 0 0;font-size:10px;line-height:1;color:rgba(231,224,210,.48);
  font-family:var(--font-body);letter-spacing:.04em;
}
.onboard-v2__privacy svg{color:rgba(231,224,210,.55);flex:none;opacity:.85;}
.onboard-v2__privacy-line{
  flex:1;max-width:72px;height:1px;background:rgba(231,224,210,.12);
}
.onboard-v2 .dots{display:none;}

/* legacy onboard beats (preview, attune) */
.screen.onboard-beat{background:#050508;}
.onboard-screen{
  --onboard-pad:24px;
  display:flex;flex-direction:column;min-height:100%;
  padding:calc(10px + env(safe-area-inset-top)) var(--onboard-pad) calc(16px + env(safe-area-inset-bottom));
}
.onboard-beat-title{
  font-family:var(--font-display);font-size:32px;line-height:1.05;font-weight:600;
  color:var(--tan);letter-spacing:-.018em;margin:0;
  text-wrap:balance;
}
.onboard-screen__title{max-width:12ch;}
.onboard-screen__copy{margin:20px 0 0;max-width:34ch;}
.onboard-screen__copy .bodytext{
  font-family:var(--font-body);font-size:13.5px;line-height:1.62;
  color:var(--ctext-reading);letter-spacing:.015em;
}
.onboard-screen__foot{
  margin-top:0;display:flex;flex-direction:column;gap:0;width:100%;
}
.onboard-screen__foot .dots{margin-top:12px;align-self:center;}
.onboard-screen__scroll{
  flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
  padding:calc(10px + env(safe-area-inset-top)) 24px 16px;
}
.onboard-screen__cta{
  width:100%;min-height:52px;height:52px;font-size:15px;font-weight:700;
  border-radius:26px;box-shadow:0 10px 28px rgba(201,143,106,.22);
}

/* onboarding cosmos art: full-bleed inside equal pad, melts into #050508 */
.onboard-cosmos-art{
  align-self:stretch;flex:none;width:calc(100% + (var(--onboard-pad) * 2));margin:20px calc(var(--onboard-pad) * -1) 20px;
  height:min(38vh,248px);min-height:200px;
  position:relative;overflow:hidden;background:#050508;border:0;box-shadow:none;
  display:flex;align-items:center;justify-content:center;
}
.onboard-cosmos-art::after{
  content:'';position:absolute;inset:0;pointer-events:none;z-index:2;
  background:
    radial-gradient(ellipse 82% 72% at 50% 48%, transparent 38%, rgba(5,5,8,.62) 70%, #050508 100%),
    linear-gradient(180deg, #050508 0%, transparent 16%, transparent 76%, #050508 100%),
    linear-gradient(90deg, #050508 0%, transparent 10%, transparent 90%, #050508 100%);
}
.onboard-cosmos-art__glow{
  position:absolute;inset:24% 18%;border-radius:50%;pointer-events:none;z-index:1;
  background:radial-gradient(circle, rgba(224,170,96,.12) 0%, transparent 68%);
}
.onboard-cosmos-art__img{
  position:relative;z-index:0;display:block;width:100%;height:100%;
  object-fit:contain;object-position:center 52%;
  mix-blend-mode:normal;pointer-events:none;user-select:none;
  filter:brightness(.94) contrast(1.05);
  background:transparent;
}

/* constellation background: photographic field + canvas particles */
.has-constellation-bg{background:#050508;}
.constellation-bg{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0;}
.constellation-bg__photo{
  position:absolute;inset:-8%;background-size:cover;background-position:50% 38%;
  filter:saturate(1.05) contrast(1.04);
  opacity:var(--constellation-dim, .72);
  transform:scale(1.08);
}
.constellation-bg__canvas{position:absolute;inset:0;width:100%;height:100%;display:block;mix-blend-mode:screen;opacity:.92;}
.constellation-bg__veil{
  position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(8,8,12,.18) 0%, rgba(8,8,12,.42) 55%, rgba(8,8,12,.72) 100%);
}
.constellation-bg__vignette{
  position:absolute;inset:0;
  background:radial-gradient(ellipse 85% 70% at 50% 42%, transparent 35%, rgba(5,5,8,.55) 100%);
}
.constellation-bg__grain{
  position:absolute;inset:0;opacity:.07;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:180px 180px;
}
.constellation-foreground{position:relative;z-index:1;}
.has-constellation-bg .status{position:relative;z-index:2;}
@media (prefers-reduced-motion:no-preference){
  .constellation-bg__photo{animation:constellation-drift 28s ease-in-out infinite alternate;}
}
@keyframes constellation-drift{
  0%{transform:scale(1.08) translate(0,0);}
  100%{transform:scale(1.12) translate(-1.2%,-0.8%);}
}
@media (prefers-reduced-motion:reduce){
  .constellation-bg__photo{animation:none;transform:scale(1.08);}
}

/* Today home: greeting, ask bar, suggested prompts, cream fragment */
.today-screen{padding-bottom:8px;}
.today-hero{padding-top:6px;}
.today-hero__row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;}
.today-hero__title{font-size:28px;line-height:1.08;color:var(--gold-display);font-family:var(--font-display);font-weight:600;letter-spacing:-.012em;}
.today-hero__lead{margin-top:6px;font-size:13px;line-height:1.45;color:var(--ctext-soft);}
.today-hero__lead--link{cursor:pointer;}
.today-hero__carry{color:var(--gold);border-bottom:1px solid rgba(200,160,100,.4);}
.today-hero__bell{
  flex:none;margin-top:4px;background:none;border:none;padding:4px;cursor:pointer;
  color:var(--gold);display:flex;align-items:center;justify-content:center;
}
.today-hero__bell:focus-visible{outline:2px solid var(--gold);outline-offset:2px;border-radius:8px;}
.today-hero__category{margin-top:8px;color:var(--ctext-faint);font-size:11px;line-height:1.45;}

.today-ask{margin-top:18px;}
.today-ask__prompt{
  display:flex;align-items:center;gap:7px;margin:0 0 10px;
  font-size:12.5px;line-height:1.4;color:var(--ctext-soft);font-family:var(--font-body);
}
.today-ask__prompt svg{color:var(--gold);flex:none;}
.today-ask__bar{
  display:flex;align-items:center;gap:8px;
  border:1px solid var(--line-dark);border-radius:28px;
  background:rgba(255,255,255,.03);padding:6px 6px 6px 16px;
}
.today-ask__input{
  flex:1;min-width:0;border:none;background:transparent;
  font-family:var(--font-body);font-size:13.5px;line-height:1.4;color:var(--ctext);
  outline:none;
}
.today-ask__input::placeholder{color:var(--ctext-faint);}
.today-ask__submit{
  flex:none;width:40px;height:40px;border-radius:50%;border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(180deg,#dbc095 0%,#caa370 100%);
  color:#332719;box-shadow:0 6px 16px -8px rgba(140,104,56,.55);
  transition:filter .15s, transform .12s;
}
.today-ask__submit:hover{filter:brightness(1.05);}
.today-ask__submit:active{transform:scale(.96);}
.today-ask__submit:focus-visible{outline:2px solid var(--gold);outline-offset:2px;}
.today-ask__submit svg{transform:rotate(-90deg);}

.today-suggested{margin-top:16px;}
.today-suggested__label{
  font-size:11px;line-height:1.4;color:var(--ctext-faint);
  font-family:var(--font-body);letter-spacing:.04em;margin:0;
}
.today-suggested__list{display:flex;flex-direction:column;gap:var(--gap-list);margin-top:0;}
.today-suggested__pill{
  display:flex;align-items:center;gap:10px;width:100%;
  border:1px solid var(--line-dark);border-radius:24px;
  background:rgba(255,255,255,.025);padding:11px 14px;
  cursor:pointer;text-align:left;
  font-family:var(--font-body);font-size:12.5px;line-height:1.35;color:var(--ctext-soft);
  transition:border-color .15s, background .15s, transform .12s;
  -webkit-tap-highlight-color:transparent;
}
.today-suggested__pill:hover{border-color:rgba(200,160,100,.28);background:rgba(200,160,100,.06);}
.today-suggested__pill:active{transform:scale(.992);}
.today-suggested__pill:focus-visible{outline:2px solid var(--gold);outline-offset:2px;}
.today-suggested__icon{
  flex:none;width:22px;height:22px;display:flex;align-items:center;justify-content:center;
  color:var(--gold);
}
.today-suggested__text{flex:1;min-width:0;}

.today-fragment-wrap{margin-top:18px;}
.today-fragment{
  background:var(--cream-card);border-radius:18px;overflow:hidden;position:relative;
  box-shadow:0 18px 40px -28px rgba(0,0,0,.55);
}
.today-fragment--editorial{
  padding:16px 16px 18px;cursor:pointer;min-height:148px;
  transition:transform .12s cubic-bezier(.2,.8,.2,1);
}
.today-fragment--editorial:active{transform:scale(.992);}
.today-fragment__sprig{position:absolute;right:4px;top:4px;opacity:.45;pointer-events:none;}
.today-fragment__label{color:var(--ink-soft)!important;margin-bottom:10px;}
.today-fragment--editorial .quote-text,
.today-fragment--editorial p{
  max-width:17em;margin:0;font-style:italic;color:var(--ink)!important;
  font-family:var(--font-display)!important;font-weight:500!important;
  line-height:1.38!important;
}
.today-fragment .label{color:var(--ink-soft)!important;}
.today-fragment__body{padding:15px 16px 14px;position:relative;cursor:pointer;}
.today-fragment__foot{display:flex;border-top:1px solid rgba(122,90,46,.18);}
.today-fragment__action{
  display:flex;align-items:center;cursor:pointer;
  font-size:12px;color:#5a4326;font-weight:700;
}
.today-fragment__action--warm{
  flex:1;justify-content:space-between;padding:12px 14px;background:#e6cfa6;
}
.today-fragment__action--gold{
  flex:none;padding:12px 15px;gap:7;background:#dfc394;
  border-left:1px solid rgba(122,90,46,.14);
}

.onboard-preview__scroll{padding-top:calc(5px + env(safe-area-inset-top));}
.onboard-preview__head{position:relative;min-height:118px;}
.onboard-preview__head .onboard-v2__rail{top:18px;height:80px;}
.onboard-preview__title-wrap{
  max-width:82%;padding-top:19px;padding-left:28px;
}
.onboard-preview__title-wrap .onboard-v2__title{font-size:28px;line-height:1.04;}
.onboard-preview__intro{margin-bottom:0;}
.onboard-preview__answer{
  margin-top:9px;border:1px solid rgba(231,224,210,.12);border-radius:14px;
  background:linear-gradient(180deg,rgba(255,255,255,.025),rgba(255,255,255,.012));
  overflow:hidden;padding:10px 11px 0;
}
.onboard-preview__question{
  font-size:14.5px!important;line-height:1.18!important;margin:0 0 7px!important;
  color:var(--ctext)!important;
}
.onboard-preview__badge{font-size:9px;color:var(--gold-bright);letter-spacing:.14em;}
.onboard-preview .answer-screen__eyebrow{
  font-size:7.6px;line-height:1;letter-spacing:.13em;margin:0 0 5px;color:#c98f6a;
}
.onboard-preview .answer-screen__editorial-note{
  font-size:8.8px;line-height:1.28;color:rgba(231,224,210,.52);margin:0 0 6px;
}
.onboard-preview .answer-card{
  border:0;border-top:1px solid rgba(231,224,210,.1);border-radius:0;
  background:transparent;margin:0 -11px;padding:7px 11px 0;box-shadow:none;
}
.onboard-preview .answer-card__quote-mark{font-size:20px;margin:0 0 3px;color:#c98f6a;}
.onboard-preview .answer-card__lead{
  font-size:10.8px;line-height:1.3;margin:0 0 7px;
  display:-webkit-box;-webkit-line-clamp:5;-webkit-box-orient:vertical;overflow:hidden;
}
.onboard-preview .answer-card__rule{margin:0 0 7px;gap:7px;}
.onboard-preview .answer-card__body{display:none;}
.onboard-preview .answer-card__sources{
  width:calc(100% + 22px);margin:0 -11px;padding:7px 10px;
  border-top:1px solid rgba(201,143,106,.18);border-radius:0;background:rgba(201,143,106,.055);
}
.onboard-preview .answer-card__avatar img,
.onboard-preview .answer-card__avatar .portrait{width:22px!important;height:22px!important;}
.onboard-preview .answer-card__source-label{font-size:7.5px;margin-bottom:2px;}
.onboard-preview .answer-card__source-names{font-size:9px;line-height:1.2;}

/* Answer screen: editorial card layout */
.answer-screen__body{padding-top:4px;padding-bottom:16px;}
.answer-toolbar{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:4px;padding-bottom:8px;flex:none;
}
.answer-toolbar__actions{display:flex;align-items:center;gap:8px;}
.answer-toolbar__btn{
  width:36px;height:36px;border-radius:50%;border:1px solid var(--line-dark);
  background:rgba(255,255,255,.03);color:var(--ctext-soft);cursor:pointer;
  display:flex;align-items:center;justify-content:center;padding:0;
  transition:background .15s, border-color .15s, color .15s;
}
.answer-toolbar__btn:hover{border-color:rgba(200,160,100,.28);color:var(--gold);}
.answer-toolbar__btn:focus-visible{outline:2px solid var(--gold);outline-offset:2px;}
.answer-screen__question-block{margin-bottom:16px;}
.answer-screen__reflection-intro{margin-bottom:14px;}
.answer-screen__eyebrow{color:var(--gold-bright);letter-spacing:.14em;margin:0 0 8px;}
.answer-question{
  font-family:var(--font-display);font-size:24px;line-height:1.3;font-weight:500;
  color:var(--ctext);margin:0;letter-spacing:-.014em;text-wrap:balance;
}
.answer-screen__editorial-note{
  font-size:11.5px;line-height:1.5;color:var(--ctext-faint);margin:0;
}

/* Editorial answer card */
.answer-card{
  position:relative;border:1px solid rgba(200,160,100,.34);border-radius:18px;
  background:rgba(255,255,255,.02);padding:18px 16px 0;margin:0 0 20px;
  box-shadow:0 16px 36px -28px rgba(0,0,0,.65);
}
.answer-card--compact{margin-top:12px;}
.answer-card__quote-mark{
  display:block;font-family:var(--font-display);font-size:42px;line-height:.7;
  color:var(--gold);margin:0 0 10px;
}
.answer-card__lead{
  font-family:var(--font-display);font-size:16px;line-height:1.48;font-weight:500;
  color:var(--ctext);margin:0 0 14px;letter-spacing:-.01em;
}
.answer-card__rule{
  display:flex;align-items:center;gap:10px;margin:0 0 14px;
}
.answer-card__rule-line{
  flex:1;height:1px;background:linear-gradient(90deg, transparent, rgba(200,160,100,.35), transparent);
}
.answer-card__rule svg{color:var(--gold);opacity:.85;flex:none;}
.answer-card__body{
  font-family:var(--font-display);font-size:14px;line-height:1.56;font-weight:400;
  color:var(--ctext-reading);margin:0 0 12px;letter-spacing:.01em;
}
.answer-card__body:last-of-type{margin-bottom:16px;}
.answer-card__sources{
  display:flex;align-items:center;gap:11px;width:calc(100% + 32px);margin:0 -16px;
  padding:12px 14px;border:0;border-top:1px solid rgba(200,160,100,.22);
  border-radius:0 0 17px 17px;background:rgba(200,160,100,.06);
  cursor:pointer;text-align:left;
  transition:background .15s;
}
.answer-card__sources:hover{background:rgba(200,160,100,.1);}
.answer-card__sources:focus-visible{outline:2px solid var(--gold);outline-offset:-2px;}
.answer-card__sources:disabled{opacity:.72;cursor:default;}
.answer-card__avatars{display:flex;align-items:center;}
.answer-card__avatar{
  display:flex;border-radius:50%;border:1.5px solid rgba(200,160,100,.45);
  overflow:hidden;background:#1a1b24;
}
.answer-card__avatar+.answer-card__avatar{margin-left:-8px;}
.answer-card__source-copy{flex:1;min-width:0;}
.answer-card__source-label{
  display:block;font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ctext-faint);font-family:var(--font-body);margin-bottom:3px;
}
.answer-card__source-names{
  display:block;font-size:12px;line-height:1.35;color:var(--ctext-soft);
  font-family:var(--font-body);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.answer-card__source-chevron{color:var(--gold);flex:none;display:flex;align-items:center;}

.answer-deeper{margin-top:4px;}
.answer-deeper__prompt{
  display:flex;align-items:center;gap:7px;margin:0 0 12px;
  font-size:12.5px;line-height:1.4;color:var(--ctext-soft);font-family:var(--font-body);
}
.answer-deeper__prompt svg{color:var(--gold);flex:none;}
.answer-deeper__pills{margin-right:-24px;padding-right:24px;gap:8px;}
.answer-deeper__pill{
  flex:none;display:inline-flex;align-items:center;gap:7px;
  border:1px solid var(--line-dark);border-radius:22px;
  background:rgba(255,255,255,.025);padding:10px 14px;
  cursor:pointer;font-family:var(--font-body);font-size:12px;line-height:1;
  color:var(--ctext-soft);white-space:nowrap;
  transition:border-color .15s, background .15s, transform .12s;
  -webkit-tap-highlight-color:transparent;
}
.answer-deeper__pill svg{color:var(--gold);flex:none;}
.answer-deeper__pill:hover{border-color:rgba(200,160,100,.28);background:rgba(200,160,100,.06);}
.answer-deeper__pill:active{transform:scale(.992);}
.answer-deeper__pill:focus-visible{outline:2px solid var(--gold);outline-offset:2px;}

.answer-reflection{padding:0;border:0;background:none;}
.answer-reflection__p{
  font-family:var(--font-body);font-size:13px;line-height:1.62;
  color:var(--ctext-reading);margin:0;letter-spacing:.012em;
}
.answer-reflection__p+.answer-reflection__p{margin-top:11px;}
.answer-reflection__p--lead{
  font-family:var(--font-display);font-size:15px;line-height:1.52;
  color:var(--ctext-soft);font-weight:500;
}

/* Answer map carousel: peek next slide + progress dots */
.answer-map-carousel{
  width:calc(100% + 48px);margin:6px -24px 0;
}
.answer-map-carousel__track{
  display:flex;gap:10px;overflow-x:auto;scroll-snap-type:x mandatory;
  padding:0 24px 4px;scrollbar-width:none;-ms-overflow-style:none;
  -webkit-overflow-scrolling:touch;
}
.answer-map-carousel__track::-webkit-scrollbar{display:none;}
.answer-map-carousel__slide{
  flex:0 0 82%;scroll-snap-align:start;min-width:0;
}
.answer-map-preview{
  position:relative;display:block;width:100%;height:184px;
  border-radius:16px;overflow:hidden;border:1px solid var(--line-dark);
  background:#050508;cursor:pointer;padding:0;text-align:left;box-shadow:none;
}
.answer-map-preview__bg{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:50% 42%;
  opacity:.38;filter:saturate(.88) brightness(.68);
}
.answer-map-preview__veil{
  position:absolute;inset:0;pointer-events:none;
  background:
    linear-gradient(180deg, #050508 0%, transparent 18%, transparent 72%, #050508 100%),
    radial-gradient(ellipse 88% 72% at 50% 44%, rgba(24,20,14,.08), rgba(5,5,8,.55));
}
.answer-map-preview__map{position:absolute;inset:0;pointer-events:none;}
.answer-map-preview__label{
  position:absolute;left:14px;top:12px;z-index:2;
  font-size:9px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ctext-faint);font-family:var(--font-body);
}
.answer-map-preview__cta{
  position:absolute;right:12px;bottom:11px;z-index:2;
  display:inline-flex;align-items:center;gap:4px;
  font-size:11px;font-weight:700;color:var(--gold-bright);letter-spacing:.02em;
  text-shadow:0 1px 10px rgba(0,0,0,.85);
}
.answer-map-node{
  position:relative;display:flex;flex-direction:column;justify-content:flex-end;
  width:100%;height:184px;border-radius:16px;overflow:hidden;
  border:1px solid var(--line-dark);background:#050508;cursor:pointer;
  padding:14px;text-align:left;
}
.answer-map-node__bg{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:50% 42%;
  opacity:.28;filter:saturate(.82) brightness(.62);
}
.answer-map-node__veil{
  position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg, rgba(5,5,8,.2) 0%, rgba(5,5,8,.75) 68%, #050508 100%);
}
.answer-map-node__portrait{
  position:absolute;left:14px;top:14px;z-index:1;
  padding:3px;border-radius:50%;border:1px solid var(--line-gold);
  background:rgba(200,160,100,.08);
}
.answer-map-node__copy{position:relative;z-index:1;margin-top:auto;padding-top:52px;}
.answer-map-node__name{
  display:block;font-family:var(--font-display);font-size:17px;line-height:1.2;
  font-weight:600;color:var(--ctext);
}
.answer-map-node__role{
  display:block;margin-top:4px;font-size:11px;line-height:1.35;color:var(--ctext-soft);
}
.answer-map-node__cta{
  position:relative;z-index:1;display:inline-flex;align-items:center;gap:4px;
  margin-top:10px;font-size:11px;font-weight:700;color:var(--gold-bright);letter-spacing:.02em;
}
.answer-map-carousel__foot{
  display:flex;align-items:center;justify-content:center;gap:12px;
  margin-top:10px;padding:0 24px;
}
.answer-map-carousel__dots{display:flex;align-items:center;gap:6px;}
.answer-map-carousel__dots i{
  width:5px;height:5px;border-radius:50%;background:var(--ctext-faint);opacity:.45;
  transition:transform .2s, opacity .2s, background .2s;
}
.answer-map-carousel__dots i.on{
  opacity:1;background:var(--gold-bright);transform:scale(1.25);
}
.answer-map-carousel__count{
  font-size:10px;line-height:1;color:var(--ctext-faint);letter-spacing:.06em;
  font-family:var(--font-body);font-variant-numeric:tabular-nums;
}
.answer-screen__full{width:100%;margin:4px 0 6px;}
.voice-tab-note{font-size:11px;line-height:1.45;margin:0 0 10px;font-style:italic;}

/* Onboarding: read-only answer preview */
.onboard-preview{padding-bottom:calc(16px + env(safe-area-inset-bottom));}
.onboard-preview__badge{font-size:9px;color:var(--gold-bright);letter-spacing:.14em;}
.onboard-preview__card{padding:14px 15px 16px;margin:12px 0 0;border:1px solid var(--line-gold);}
.onboard-preview__card .bodytext{color:var(--ctext-reading);font-size:12.5px;line-height:1.56;}
.onboard-preview__card .quote-text{color:var(--ctext-soft);}
.onboard-preview__women{display:flex;gap:14px;margin-top:4px;}
.onboard-preview__person{display:flex;flex-direction:column;align-items:center;gap:6px;flex:1;min-width:0;}
.onboard-preview__name{font-size:10px;color:var(--ctext-soft);text-align:center;line-height:1.2;font-family:var(--font-display);}
.onboard-preview__skip{
  display:block;width:100%;margin-top:10px;background:none;border:none;
  color:var(--ctext-soft);font-size:12px;font-family:var(--font-body);cursor:pointer;padding:8px;
}
.onboard-preview__skip:focus-visible{outline:2px solid var(--gold);outline-offset:2px;border-radius:8px;}

.sanctuary-empty-hint{margin:0 0 4px;color:var(--ink-soft);line-height:1.5;font-size:13px;}
.letters-readonly-note{font-size:10px;color:var(--ctext-faint);letter-spacing:.06em;margin:8px 0 0;line-height:1.4;}
.letters-compose-teaser{opacity:.92;}
.today-screen__below{margin-top:22px;}
.today-screen__cards{display:flex;flex-direction:column;gap:12px;}
.today-screen__quote{margin-top:20px;padding-bottom:6px;}

/* Today: section headers */
.today-section-head{
  display:flex;align-items:baseline;justify-content:space-between;gap:12px;
  margin-bottom:14px;
}
.today-section-head__label{
  font-size:10px;line-height:1.35;letter-spacing:.16em;text-transform:uppercase;
  color:var(--gold);font-family:var(--font-body);font-weight:600;
}
.today-section-head__action{
  background:none;border:none;padding:4px 0;cursor:pointer;
  font-size:11px;line-height:1.35;color:var(--ctext-soft);font-family:var(--font-body);
  transition:color .15s;
}
.today-section-head__action:hover{color:var(--gold);}
.today-section-head__action:focus-visible{outline:2px solid var(--gold);outline-offset:2px;border-radius:6px;}

/* Today: in conversation with (glyph rows, no portrait rail) */
.today-convo-list{margin-top:0;}
.today-convo-row{
  width:100%;text-align:left;
  font:inherit;color:inherit;
  -webkit-appearance:none;appearance:none;
}
.today-convo-row__copy{flex:1;min-width:0;}
.today-convo-row__title{
  display:block;font-family:var(--font-display);font-size:15px;line-height:1.15;
  font-weight:600;color:var(--ctext);
}
.today-convo-row__meta{
  display:block;margin-top:2px;font-size:10.5px;line-height:1.35;color:var(--ctext-soft);
}
.today-convo-row__chev{color:var(--ctext-faint);flex:none;}
.today-convo-row--more .today-convo-row__title{color:var(--gold-bright);}

.today-screen--mockup{
  padding-top:0;overflow:hidden;
  background:
    radial-gradient(circle at 78% 42%, rgba(201,143,106,.06), transparent 28%),
    #050508;
}
.today-screen--mockup .pad{padding-left:16px;padding-right:16px;}
.today-screen--mockup .today-screen__below{margin-top:12px;}
.today-screen--mockup .today-screen__below:first-child{margin-top:4px;}
.today-screen--mockup .today-section-head{margin-bottom:8px;}
.today-screen--mockup .today-section-head__label{font-size:9.5px;letter-spacing:.17em;}
.today-screen--mockup .today-section-head__action{font-size:11px;padding:0;color:rgba(231,224,210,.55);}
.today-screen--mockup .today-convo-row{padding:10px 12px;}
.today-screen--mockup .today-convo-row__title{font-size:14.5px;}
.today-screen--mockup .today-screen__cards{gap:8px;}
.today-screen--mockup .today-card{min-height:76px;padding:9px 10px 9px 14px;border-radius:15px;}
.today-screen--mockup .today-card__icon{width:44px;height:44px;}
.today-screen--mockup .today-card__body{flex:0 0 176px;max-width:none;padding-right:0;}
.today-screen--mockup .today-card--letters .today-card__body{flex-basis:132px;}
.today-screen--mockup .today-card--paths .today-card__body{flex-basis:138px;}
.today-screen--mockup .today-card__title{font-size:15.2px;line-height:1.15;}
.today-screen--mockup .today-card__meta{font-size:10.4px;line-height:1.38;margin-top:4px;}
.today-screen--mockup .today-card__art{right:9px;transform:translateY(-50%) scale(.7);opacity:.74;}
.today-screen--mockup .today-card__chevron{margin-left:2px;}
.today-screen--mockup .today-screen__quote{margin-top:6px;padding-bottom:0;}
.today-screen--mockup .today-quote{min-height:48px;padding:10px 14px 10px 16px;border-radius:14px;}
.today-screen--mockup .today-quote__text{font-size:11.4px;line-height:1.42;max-width:none;}
.today-screen--mockup .today-quote__sprig{right:-8px;bottom:-24px;transform:scale(.82);}

/* Today: premium destination cards */
.today-card{
  position:relative;display:flex;align-items:center;gap:12px;width:100%;
  min-height:108px;padding:20px 12px 20px 14px;
  border:1px solid rgba(200,160,100,.14);border-radius:18px;
  background:linear-gradient(155deg,rgba(28,28,34,.92) 0%,rgba(18,18,22,.88) 100%);
  box-shadow:0 16px 40px -28px rgba(0,0,0,.9), inset 0 1px 0 rgba(255,255,255,.04);
  cursor:pointer;text-align:left;overflow:hidden;
  transition:border-color .15s, transform .12s cubic-bezier(.2,.8,.2,1), background .15s;
  -webkit-tap-highlight-color:transparent;
}
.today-card:hover{border-color:rgba(200,160,100,.28);}
.today-card:active{transform:scale(.992);}
.today-card:focus-visible{outline:2px solid var(--gold);outline-offset:2px;}
.today-card__icon{
  position:relative;z-index:2;
  width:50px;height:50px;flex:none;border-radius:50%;
  background:transparent;border:1px solid rgba(200,160,100,.38);
  display:flex;align-items:center;justify-content:center;
  color:var(--gold);
}
.today-card__body{position:relative;z-index:2;flex:1;min-width:0;max-width:11.5em;padding-right:4px;}
.today-card__title{
  display:block;font-family:var(--font-display);font-size:18px;line-height:1.2;
  color:var(--ctext);font-weight:600;letter-spacing:-.012em;
}
.today-card__meta{
  display:block;margin-top:6px;font-size:11.5px;line-height:1.45;
  color:var(--ctext-soft);font-family:var(--font-body);
}
.today-card__chevron{
  position:relative;z-index:2;color:var(--gold);flex:none;
  display:flex;align-items:center;opacity:.85;margin-left:auto;
}
.today-card__art{
  position:absolute;right:30px;top:50%;transform:translateY(-50%);
  z-index:1;pointer-events:none;opacity:.92;
  filter:drop-shadow(0 0 14px rgba(201,143,106,.22));
}
.today-card__art svg{display:block;}

/* Today: closing quote banner */
.today-quote{
  position:relative;overflow:hidden;display:flex;align-items:flex-start;gap:10px;
  padding:18px 16px 20px;border-radius:16px;
  border:1px solid rgba(200,160,100,.12);
  background:linear-gradient(160deg,rgba(24,24,28,.85) 0%,rgba(18,18,22,.9) 100%);
}
.today-quote__star{color:var(--gold);opacity:.8;flex:none;margin-top:3px;}
.today-quote__text{
  margin:0;flex:1;max-width:18em;
  font-family:var(--font-display);font-size:14.5px;line-height:1.48;
  font-style:italic;font-weight:500;color:var(--ctext);
}
.today-quote__sprig{
  position:absolute;right:-2px;bottom:-10px;opacity:.65;pointer-events:none;
}

/* Sanctuary: your constellation entry */
.sanctuary-constellation{
  position:relative;overflow:hidden;cursor:pointer;
  border-radius:16px;border:1px solid var(--line-gold);
  background:var(--night-grad);padding:14px 14px 15px;
  display:flex;align-items:center;gap:13px;min-height:88px;
}
.sanctuary-constellation__sky{
  position:absolute;inset:0;opacity:.42;pointer-events:none;
  background:url('uploads/matria-constellation-bg.png') center 40%/cover no-repeat;
  mix-blend-mode:screen;
}
.sanctuary-constellation__veil{
  position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(90deg, rgba(15,16,22,.92) 0%, rgba(15,16,22,.55) 55%, rgba(15,16,22,.78) 100%);
}
.sanctuary-constellation__icon{
  position:relative;z-index:1;width:44px;height:44px;flex:none;border-radius:50%;
  background:rgba(200,160,100,.16);border:1px solid rgba(200,160,100,.28);
  display:flex;align-items:center;justify-content:center;color:var(--gold-bright);
  box-shadow:0 0 22px rgba(201,143,106,.22);
}
.sanctuary-constellation__body{position:relative;z-index:1;flex:1;min-width:0;}
.sanctuary-constellation__title{
  font-family:var(--font-display);font-size:17px;line-height:1.15;
  color:var(--gold);font-weight:600;
}
.sanctuary-constellation__meta{
  font-size:12px;line-height:1.4;color:var(--ctext-soft);margin-top:5px;max-width:230px;
}
.sanctuary-constellation__chevron{
  position:relative;z-index:1;color:var(--ctext-soft);flex:none;display:flex;
}

/* Your constellation empty: universe hero */
.constellation-empty-art{
  position:relative;width:min(240px,72vw);height:min(240px,72vw);
  margin:8px auto 0;flex:none;
}
.constellation-empty-art__glow{
  position:absolute;inset:8%;border-radius:50%;pointer-events:none;
  background:radial-gradient(circle, rgba(224,170,96,.24) 0%, rgba(224,170,96,.08) 42%, transparent 70%);
}
.constellation-empty-art__planet{
  position:relative;width:100%;height:100%;object-fit:contain;display:block;
  mix-blend-mode:screen;
  -webkit-mask-image:radial-gradient(circle at 50% 50%, #000 58%, transparent 82%);
  mask-image:radial-gradient(circle at 50% 50%, #000 58%, transparent 82%);
}

/* cream pages: womb field + constellation (sanctuary pattern) */
.screen.has-womb-sky{background:linear-gradient(180deg,#faf5eb 0%,var(--cream) 28%,var(--cream) 100%);}
.womb-field{
  position:relative;overflow:hidden;isolation:isolate;
  border-radius:var(--r-card);
  background:linear-gradient(145deg,#faf3e4,#efe4cf 58%,#e8d9bc);
  border:.5px solid rgba(184,147,90,.28);
  box-shadow:0 16px 36px -28px rgba(122,90,46,.35), inset 0 1px 0 rgba(255,255,255,.42);
}
.womb-field__photo{
  position:absolute;inset:-14%;background-size:cover;background-position:50% 40%;
  filter:saturate(1.08) contrast(1.04) sepia(.12);
  opacity:.62;transform:scale(1.06);
}
.womb-field__veil{
  position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 78% 72% at 50% 38%, rgba(251,246,236,.55) 0%, rgba(244,239,227,.82) 52%, rgba(244,239,227,.96) 100%),
    linear-gradient(180deg, rgba(244,239,227,.08), rgba(244,239,227,.92) 88%);
}
.womb-field__signal{
  position:absolute;inset:0;pointer-events:none;mix-blend-mode:multiply;opacity:.72;
  background:
    radial-gradient(circle at 52% 62%, var(--womb-glow), transparent 22%),
    radial-gradient(ellipse 58% 80% at 50% 50%, transparent 46%, var(--womb-gold) 68%, transparent 76%),
    radial-gradient(circle at 34% 74%, rgba(224,176,108,.18) 0 2px, transparent 5px),
    radial-gradient(circle at 66% 55%, rgba(224,176,108,.16) 0 2px, transparent 5px);
}
.womb-field__grain{
  position:absolute;inset:0;opacity:.06;mix-blend-mode:multiply;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:180px 180px;
}
.womb-field__inner{position:relative;z-index:2;}
.womb-field--banner{min-height:104px;margin-bottom:12px;}
.womb-field--banner .womb-field__inner{padding:14px 16px 13px;}
.womb-field--card{min-height:108px;}
.womb-field--card .womb-field__inner{padding:14px 14px 12px;display:flex;align-items:center;justify-content:center;min-height:108px;}
.womb-field--strip{
  height:44px;min-height:44px;max-height:44px;
  border-radius:12px;margin-bottom:12px;
}
.womb-field--strip .womb-field__photo{opacity:.5;inset:-24%;}
.womb-field--strip .womb-field__veil{
  background:
    radial-gradient(ellipse 90% 120% at 50% 50%, rgba(251,246,236,.35) 0%, rgba(244,239,227,.88) 100%),
    linear-gradient(180deg, rgba(244,239,227,.12), rgba(244,239,227,.94));
}
.womb-field__kicker{font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);margin:0 0 4px;}
.womb-field__title{font-family:var(--font-display);font-size:15px;line-height:1.25;color:#46371f;font-weight:600;margin:0;max-width:none;}
.womb-field__copy{font-size:11px;line-height:1.4;color:#6a5736;margin:4px 0 0;max-width:none;}
@media (prefers-reduced-motion:no-preference){
  .womb-field__photo{animation:womb-breathe 12s ease-in-out infinite alternate;}
  .womb-field__signal{animation:sanctuary-hold 6.2s ease-in-out infinite;}
}
@keyframes womb-breathe{0%{transform:scale(1.06);opacity:.58;}100%{transform:scale(1.1);opacity:.68;}}
@keyframes sanctuary-hold{0%,100%{opacity:.42;transform:scale(.98);}50%{opacity:.84;transform:scale(1.03);}}

.lineage-collage{display:flex;align-items:center;justify-content:center;padding:4px 0;}
.lineage-collage__cell{
  width:58px;height:58px;border-radius:50%;overflow:hidden;flex:none;margin-left:-14px;
  border:2px solid rgba(251,246,236,.92);
  box-shadow:0 8px 22px -12px rgba(122,90,46,.45), 0 0 0 1px rgba(184,147,90,.24);
  background:linear-gradient(145deg,#f6edda,#e8d9bc);
}
.lineage-collage__cell:first-child{margin-left:0;}
.lineage-collage__cell img{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(.92) contrast(1.02);}
.lineage-collage__fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--gold-line);background:rgba(201,143,106,.12);}

.saved-answer-card{
  border-radius:var(--r-card);overflow:hidden;cursor:pointer;
  background:linear-gradient(180deg,var(--cream-card-2),var(--cream-card));
  border:.5px solid var(--line-cream);
  box-shadow:0 14px 32px -26px rgba(38,38,45,.42);
  transition:transform .14s cubic-bezier(.2,.8,.2,1), box-shadow .2s ease;
}
.saved-answer-card:active{transform:scale(.992);}
.saved-answer-card__body{padding:13px 14px 14px;}
.saved-answer-card__title{font-family:var(--font-display);font-size:15px;line-height:1.28;color:var(--ink);font-weight:600;margin:0;}
.saved-answer-card__meta{font-size:10.5px;color:var(--ink-faint);margin-top:4px;}
.saved-answer-card__foot{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  margin-top:11px;padding-top:11px;border-top:1px solid var(--line-cream-soft);
}
.saved-answer-card__cta{
  display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:700;
  color:#5a4326;font-family:var(--font-body);
}

.cream-row{
  display:flex;align-items:center;gap:13px;border-radius:14px;cursor:pointer;
  min-height:56px;padding:12px 13px;
  background:linear-gradient(180deg,var(--cream-card-2),var(--cream-card));
  border:.5px solid var(--line-cream);
  transition:background .15s,transform .12s,border-color .15s;
}
.cream-row:active{transform:scale(.992);}
.cream-row:hover{background:var(--cream-card-2);}
.cream-row__icon{
  width:44px;height:44px;flex:none;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(201,143,106,.1);border:1px solid rgba(184,147,90,.22);color:var(--gold-line);
}
.cream-row__body{flex:1;min-width:0;}
.cream-row__title{font-family:var(--font-display);font-size:15px;line-height:1.22;color:var(--ink);font-weight:600;}
.cream-row__meta{font-size:11px;color:var(--ink-faint);margin-top:2px;line-height:1.35;}
.cream-row__chevron{color:var(--ink-faint);flex:none;display:flex;}

.btn-cream{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  min-height:44px;height:44px;padding:0 16px;border-radius:22px;
  font-size:13px;font-weight:700;font-family:var(--font-body);cursor:pointer;
  border:1px solid rgba(184,147,90,.34);
  background:linear-gradient(180deg,#efe2cb,#e4d3b4);
  color:#46371f;box-shadow:inset 0 1px 0 rgba(255,255,255,.36), 0 8px 18px -14px rgba(122,90,46,.4);
  transition:transform .14s,filter .2s;
}
.btn-cream:active{transform:scale(.975);}
.btn-cream:hover{filter:brightness(1.03);}
.btn-cream--ghost{background:rgba(251,246,236,.72);color:var(--gold-line);}

.cream-page-head{margin-bottom:var(--space-3);}
.cream-page-head .title{color:var(--ink);}
.cream-page-head .lead{margin-top:6px;color:#5a5246;font-size:12.5px;line-height:1.45;}

/* Journal: tight header, no banner stack */
.journal-screen .title{margin:0 0 4px;font-size:23px;line-height:1.15;}
.journal-lead{margin:0 0 14px;font-size:12px;color:var(--ink-soft);line-height:1.4;}
.journal-linked{padding:12px 14px;margin-bottom:12px;border-color:rgba(184,147,90,.28);background:var(--cream-card);}
.journal-linked__q{margin:0;font-family:var(--font-display);font-size:14px;line-height:1.38;color:var(--ink);font-weight:600;}
.journal-prompt{
  display:flex;align-items:flex-start;gap:11px;
  background:var(--cream-card-2);border:1px solid var(--gold-line);
  border-radius:13px;padding:12px 14px;margin-bottom:11px;
}
.journal-prompt__body{flex:1;min-width:0;}
.journal-prompt__text{color:#46433d;margin:0;line-height:1.45;font-size:12.5px;}
.journal-prompt__shuffle{
  background:none;border:none;cursor:pointer;color:var(--ink-faint);
  font-size:10.5px;padding:2px 0;font-family:var(--font-body);flex:none;
}
.journal-field{position:relative;}
.journal-field textarea{
  width:100%;border:1px solid var(--line-cream);border-radius:13px;
  background:var(--cream-card-2);height:132px;padding:12px 14px 26px;
  font-size:13.5;color:var(--ink);font-family:var(--font-body);
  resize:none;line-height:1.5;box-sizing:border-box;
}
.journal-field__meta{
  position:absolute;right:12px;bottom:10px;font-size:9.5px;color:var(--ink-faint);
}
.journal-saved{
  display:flex;align-items:center;gap:11px;margin-top:11px;
  background:#eaf0ea;border:1px solid rgba(76,168,160,.35);
  border-radius:13px;padding:11px 13px;
}
.journal-saved__icon{
  width:24px;height:24px;border-radius:50%;background:#4ca8a0;
  display:flex;align-items:center;justify-content:center;flex:none;color:#fff;
}
.journal-saved__body{flex:1;min-width:0;}
.journal-saved__title{font-size:12px;color:#234b46;font-weight:700;}
.journal-saved__meta{font-size:10.5px;color:#3d6b65;margin-top:1px;}
.journal-saved__btn{min-height:32px;height:32px;padding:0 12px;font-size:11px;flex:none;}

/* Knowledge Map, mobile and tablet */
.kmap-hint{
  position:absolute;left:0;right:0;text-align:center;font-size:11px;line-height:1.35;
  color:var(--ctext-faint);pointer-events:none;letter-spacing:.01em;
}
.kmap-stage{
  flex:1;
  position:relative;
  min-height:0;
}
.kmap-toolbelt{
  position:absolute;
  left:50%;
  bottom:calc(14px + env(safe-area-inset-bottom));
  z-index:5;
  transform:translateX(-50%);
  display:inline-flex;
  align-items:center;
  gap:7px;
  max-width:calc(100% - 28px);
  padding:6px;
  border-radius:999px;
  border:1px solid rgba(201,143,106,.22);
  background:rgba(7,7,10,.76);
  box-shadow:0 18px 42px -28px rgba(0,0,0,.86), inset 0 1px 0 rgba(255,255,255,.05);
  backdrop-filter:blur(14px);
}
.kmap-tool{
  min-width:64px;
  height:44px;
  padding:0 11px;
  border:1px solid rgba(201,143,106,.18);
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  background:rgba(201,143,106,.06);
  color:rgba(231,224,210,.78);
  font-family:var(--font-body);
  font-size:11.5px;
  font-weight:700;
  line-height:1;
  white-space:nowrap;
  cursor:pointer;
  -webkit-tap-highlight-color:transparent;
  transition:transform .12s, border-color .15s, background .15s, color .15s;
}
.kmap-tool svg{
  flex:none;
  color:var(--gold);
  stroke:currentColor;
}
.kmap-tool:active{transform:scale(.97);}
.kmap-tool:hover{
  border-color:rgba(201,143,106,.34);
  background:rgba(201,143,106,.1);
  color:var(--ctext);
}
.kmap-tool:focus-visible{
  outline:2px solid var(--gold);
  outline-offset:3px;
}
.kmap-tool span{display:block;}
.kmap-tool--on{
  border-color:rgba(233,200,135,.55);
  background:rgba(201,143,106,.18);
  color:var(--gold-bright);
}
.kmap-zoom{
  position:absolute;
  top:calc(env(safe-area-inset-top) + 8px);
  right:12px;
  z-index:5;
  display:flex;
  flex-direction:column;
  gap:4px;
  padding:5px;
  border-radius:14px;
  border:1px solid rgba(201,143,106,.22);
  background:rgba(7,7,10,.76);
  box-shadow:0 18px 42px -28px rgba(0,0,0,.86), inset 0 1px 0 rgba(255,255,255,.05);
  backdrop-filter:blur(14px);
}
.kmap-zoom__btn{
  width:40px;
  height:36px;
  border:1px solid rgba(201,143,106,.18);
  border-radius:10px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(201,143,106,.06);
  color:var(--gold);
  font-family:var(--font-body);
  font-size:11px;
  font-weight:700;
  cursor:pointer;
  -webkit-tap-highlight-color:transparent;
  transition:transform .12s, border-color .15s, background .15s;
}
.kmap-zoom__btn--fit{
  width:40px;
  height:32px;
  font-size:10px;
  letter-spacing:.02em;
}
.kmap-zoom__btn:active{transform:scale(.97);}
.kmap-zoom__btn:hover{
  border-color:rgba(201,143,106,.34);
  background:rgba(201,143,106,.1);
}
.kmap-zoom__btn:focus-visible{
  outline:2px solid var(--gold);
  outline-offset:2px;
}
.kmap-legend-panel{
  position:absolute;
  left:16px;
  bottom:16px;
  background:rgba(20,21,28,.92);
  border:1px solid var(--line-gold);
  border-radius:14px;
  padding:12px 14px;
  backdrop-filter:blur(6px);
  z-index:4;
  max-width:min(280px, calc(100% - 32px));
}
.kmap-edge-legend{
  margin-top:14px;
  padding-top:12px;
  border-top:1px solid rgba(201,143,106,.16);
}
.kmap-edge-legend__row{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:7px;
}
.kmap-edge-legend__row:last-child{margin-bottom:0;}
.kmap-edge-legend__swatch{
  flex:none;
  width:28px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.kmap-edge-legend__label{
  font-size:11px;
  line-height:1.3;
  color:var(--ctext-soft);
  font-family:var(--font-body);
}
.ipad-map-shell{
  position:fixed;inset:0;z-index:40;display:grid;grid-template-columns:minmax(0,1fr) 380px;
}
.ipad-map-stage{position:relative;min-width:0;overflow:hidden;}
.ipad-map-head{
  position:absolute;top:0;left:0;right:0;z-index:5;display:flex;align-items:flex-start;gap:12px;
  padding:calc(env(safe-area-inset-top) + 18px) 24px 0;pointer-events:none;
}
.ipad-map-head > *{pointer-events:auto;}
.ipad-map-back{
  background:rgba(12,12,18,.52);border:.5px solid var(--line-dark);border-radius:50%;
  width:42px;height:42px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--ctext);flex:none;
  backdrop-filter:blur(6px);
}
.ipad-map-panel{
  background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.025));
  border-left:.5px solid var(--line-dark);min-width:0;
}
@media (min-width:900px){
  .ipad-map-shell{grid-template-columns:minmax(0,1fr) minmax(360px,28vw);}
}
@media (max-width:820px){
  .ipad-map-shell{grid-template-columns:1fr;}
  .ipad-map-panel{display:none;}
}

/* splash v2: reference portrait field, book emblem, pillar icons */
.splash-v2{position:relative;background:#030305;overflow:hidden;}
.splash-v2__bg{
  position:absolute;left:0;top:0;width:100%;height:59%;object-fit:cover;object-position:50% 0%;
  pointer-events:none;opacity:.98;filter:saturate(1.04) contrast(1.04) brightness(.96);
}
.splash-v2__veil{
  position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 76% 42% at 50% 30%, rgba(224,158,96,.05), transparent 60%),
    linear-gradient(180deg, rgba(3,3,5,.06) 0%, rgba(3,3,5,.08) 30%, rgba(3,3,5,.78) 57%, #030305 69%, #030305 100%),
    radial-gradient(ellipse 106% 62% at 50% 20%, transparent 38%, rgba(3,3,5,.62) 78%);
}
.splash-v2__scroll{
  position:relative;z-index:2;flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;
  -webkit-overflow-scrolling:touch;padding:0 22px;
}
.splash-v2__center{
  flex:none;min-height:0;display:flex;flex-direction:column;align-items:center;
  justify-content:flex-start;text-align:center;padding:36px 4px 0;
}
.splash-v2__emblem-wrap{width:202px;height:196px;margin:0 0 -6px;flex:none;overflow:visible;}
.splash-v2__emblem{
  display:block;width:100%;height:100%;object-fit:contain;object-position:50% 50%;
  filter:brightness(1.04) saturate(1.02);
  opacity:1;
}
.splash-v2__wordmark{
  font-family:var(--font-word);font-size:42px;line-height:1;
  letter-spacing:.145em;font-weight:500;margin:0 0 0 8px;
  background:linear-gradient(180deg,#dfa985 0%,#c98f6a 54%,#9d6048 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  text-shadow:none;
}
.splash-v2__wordmark-a{letter-spacing:.08em;}
.splash-v2__divider{
  display:flex;align-items:center;justify-content:center;gap:9px;
  width:154px;margin:10px 0 8px;color:var(--gold-bright);opacity:.72;
}
.splash-v2__divider span{height:1px;flex:1;background:linear-gradient(90deg,transparent,rgba(201,143,106,.62));}
.splash-v2__divider span:last-child{background:linear-gradient(90deg,rgba(201,143,106,.62),transparent);}
.splash-v2__claim{
  font-family:var(--font-display);font-size:17.5px;line-height:1.2;font-weight:500;
  color:var(--gold-display);margin:0;max-width:18ch;text-wrap:balance;
}
.splash-v2__pillars{
  display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:0;
  width:100%;max-width:258px;margin:16px 0 0;
}
.splash-v2__pillar{
  display:flex;flex-direction:column;align-items:center;gap:8px;min-width:0;
  padding:0 7px;border-right:1px solid rgba(201,143,106,.2);
}
.splash-v2__pillar:last-child{border-right:0;}
.splash-v2__pillar-icon{
  width:28px;height:28px;display:flex;align-items:center;justify-content:center;
  color:#b98467;opacity:.86;
}
.splash-v2__pillar-label{
  font-family:var(--font-body);font-size:7px;line-height:1.14;letter-spacing:.105em;
  text-transform:uppercase;color:var(--ctext-faint);text-align:center;
}
.splash-v2__privacy{
  font-family:var(--font-body);font-size:10.5px;line-height:1.45;
  color:rgba(231,224,210,.42);margin:13px 0 0;letter-spacing:.01em;
}
.splash-v2__foot{
  display:flex;flex-direction:column;align-items:center;gap:8px;
}
.splash-v2__begin{
  width:214px;height:52px;border-radius:28px;
  font-size:16px;font-weight:700;
  background:linear-gradient(180deg,#e8bc98 0%,#d49b70 100%);
  box-shadow:0 12px 30px rgba(201,143,106,.3), inset 0 1px 0 rgba(255,255,255,.36);
}
.splash-v2__sanctuary{
  margin:0;font-family:var(--font-body);font-size:10.5px;line-height:1.4;
  color:rgba(231,224,210,.36);font-style:normal;letter-spacing:.01em;
}
.splash-v2__moon{
  color:var(--gold);opacity:.62;display:flex;justify-content:center;position:relative;
  width:150px;margin-top:1px;
}
.splash-v2__moon::before,.splash-v2__moon::after{
  content:'';position:absolute;top:5px;width:58px;height:1px;background:linear-gradient(90deg,transparent,rgba(201,143,106,.3));
}
.splash-v2__moon::before{right:50%;margin-right:16px;}
.splash-v2__moon::after{left:50%;margin-left:16px;transform:scaleX(-1);}

/* Ask screen: cream form rhythm */
.ask-screen{
  display:flex;flex-direction:column;min-height:100%;
}
.ask-screen__body{
  display:flex;flex-direction:column;min-height:100%;
  padding-top:8px;padding-bottom:calc(8px + env(safe-area-inset-bottom));
  gap:var(--gap-section);
}
.ask-screen__head{position:relative;margin-bottom:14px;}
.ask-screen__glyph{
  position:absolute;right:-8px;top:-6px;color:rgba(201,143,106,.14);pointer-events:none;
}
.ask-screen__title{
  margin:0;font-family:var(--font-display);font-size:30px;line-height:1.06;
  letter-spacing:-.018em;font-weight:600;text-wrap:balance;
}
.ask-screen__title-a{color:#33281f;}
.ask-screen__title-b{color:#c98f6a;font-size:1.12em;}
.ask-screen__lead{margin:9px 0 0;max-width:22em;}
.ask-screen__rule{margin:0;opacity:.72;}
.ask-screen__rule--star{justify-content:center;}
.ask-screen__rule--star::before,
.ask-screen__rule--star::after{flex:1;}
.ask-screen__chips{margin-right:-24px;padding-right:24px;}
  display:inline-flex;align-items:center;gap:6px;height:32px;padding:0 13px;
  font-size:11.5px;flex:none;
}
.ask-chip svg{flex:none;opacity:.82;}
.ask-chip.on svg{opacity:1;color:#f8ead8;}
.ask-compose{
  display:flex;align-items:center;gap:10px;
  border:1px solid rgba(184,147,90,.28);border-radius:16px;
  background:linear-gradient(180deg,rgba(255,248,234,.92),rgba(244,231,205,.9));
  padding:8px 8px 8px 14px;
  box-shadow:0 12px 30px -24px rgba(122,90,46,.35), inset 0 1px 0 rgba(255,255,255,.42);
}
.ask-compose__input{
  flex:1;min-width:0;border:none;background:transparent;
  min-height:44px;font-family:var(--font-body);font-size:13.5px;line-height:1.45;
  color:#33281f;outline:none;
}
.ask-compose__input::placeholder{color:#9a8d7d;}
.ask-compose__submit{
  flex:none;width:44px;height:44px;border-radius:50%;border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(180deg,#d8ad82,#bf845a);
  color:#fff8ef;
  box-shadow:0 10px 22px -14px rgba(150,96,48,.75), inset 0 1px 0 rgba(255,255,255,.32);
  transition:filter .15s, transform .12s;
}
.ask-compose__submit:hover{filter:brightness(1.04);}
.ask-compose__submit:active{transform:scale(.96);}
.ask-compose__submit:focus-visible{outline:2px solid #a36f4d;outline-offset:2px;}
.ask-screen__chips{margin-right:-24px;padding-right:24px;}
.ask-question-list{display:flex;flex-direction:column;gap:var(--gap-list);flex:none;}
.ask-question-row{
  display:flex;align-items:center;gap:10px;width:100%;text-align:left;
  border:1px solid rgba(184,147,90,.24);border-radius:14px;
  background:linear-gradient(180deg,rgba(255,248,234,.92),rgba(244,231,205,.9));
  padding:12px 12px 12px 13px;cursor:pointer;
  font-family:var(--font-body);font-size:12.5px;line-height:1.4;color:#46433d;
  min-height:48px;transition:transform .12s, border-color .15s, background .15s;
  -webkit-tap-highlight-color:transparent;
}
.ask-question-row:hover{border-color:rgba(184,147,90,.36);background:rgba(255,248,234,.96);}
.ask-question-row:active{transform:scale(.992);}
.ask-question-row:focus-visible{outline:2px solid #a36f4d;outline-offset:2px;}
.ask-question-row__star{
  flex:none;width:22px;height:22px;display:flex;align-items:center;justify-content:center;
  color:#c98f6a;
}
.ask-question-row__text{flex:1;min-width:0;display:flex;flex-wrap:wrap;align-items:center;gap:8px;}
.ask-question-row__tag{
  display:inline-flex;align-items:center;height:18px;padding:0 8px;border-radius:999px;
  font-size:9px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  color:#8f5f3f;background:rgba(201,143,106,.14);border:1px solid rgba(184,147,90,.22);
}
.ask-question-row__go{
  flex:none;width:30px;height:30px;border-radius:50%;
  border:1px solid rgba(184,147,90,.34);color:#a36f4d;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,248,234,.7);
}
.ask-screen__disclaimer{
  text-align:center;font-size:11px;color:var(--ink-faint);font-style:italic;
  margin:18px 0 4px;line-height:1.5;
}
.ask-field{
  border:1px solid var(--line-cream);border-radius:14px;background:var(--cream-card-2);
  min-height:96px;flex:none;padding:13px 15px;font-size:13.5;color:var(--ink);
  font-family:var(--font-body);resize:none;width:100%;line-height:1.5;
  transition:border-color .2s, box-shadow .2s;
}
.ask-field:focus{border-color:var(--gold-line);box-shadow:0 0 0 3px rgba(201,143,106,.14);outline:none;}
.ask-prompt-list{display:flex;flex-direction:column;gap:8px;flex:none;margin-top:2px;}
.prompt-card{
  text-align:left;background:linear-gradient(180deg,var(--cream-card-2),var(--cream-card));
  border:1px solid var(--line-cream);border-radius:12px;padding:12px 14px;
  font-size:12.5;color:#46433d;cursor:pointer;line-height:1.4;font-family:var(--font-body);
  min-height:44px;transition:transform .12s, border-color .15s, background .15s;
  -webkit-tap-highlight-color:transparent;
}
.prompt-card:hover{background:var(--cream-card-2);border-color:rgba(200,160,100,.28);}
.prompt-card:active{transform:scale(.992);}
.prompt-card:focus-visible{outline:2px solid var(--gold);outline-offset:2px;}
.ask-screen__foot{margin-top:auto;padding-top:16px;}

/* Explore screen: dark archive index */
.explore-screen__body{
  display:flex;flex-direction:column;
  padding-bottom:8px;gap:var(--gap-section);
}
.explore-screen__head{padding-top:8px;}
.explore-screen__title-row{
  display:flex;align-items:flex-start;justify-content:space-between;gap:12px;
}
.explore-screen__glyph{
  flex:none;width:34px;height:34px;display:flex;align-items:center;justify-content:center;
  color:rgba(217,161,132,.72);margin-top:4px;
}
.explore-screen__ways,
.explore-screen__browse{margin-top:0;padding-bottom:12px;}
.explore-screen__threads-rule{margin:0;}
.explore-search{
  display:flex;align-items:center;gap:8px;margin-top:0;
  border:1px solid rgba(201,143,106,.18);border-radius:14px;
  background:linear-gradient(155deg,rgba(28,28,34,.86),rgba(13,13,16,.9));
  padding:4px 6px 4px 12px;
  box-shadow:0 16px 38px -32px rgba(0,0,0,.8), inset 0 1px 0 rgba(255,255,255,.035);
}
.explore-search__icon{
  flex:none;color:rgba(217,161,132,.62);display:flex;align-items:center;
}
.explore-search__input{
  flex:1;min-width:0;border:none;background:transparent;height:40px;
  font-family:var(--font-body);font-size:13.5px;color:var(--ctext);outline:none;
}
.explore-search__input::placeholder{color:var(--ctext-faint);}
.explore-search__filter{
  flex:none;width:40px;height:40px;border-radius:12px;border:1px solid rgba(201,143,106,.14);
  background:rgba(201,143,106,.06);color:rgba(217,161,132,.78);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:border-color .15s, background .15s, transform .12s;
}
.explore-search__filter:hover{border-color:rgba(201,143,106,.28);background:rgba(201,143,106,.1);}
.explore-search__filter:active{transform:scale(.96);}
.explore-search__filter:focus-visible{outline:2px solid var(--gold);outline-offset:2px;}
.explore-results{display:flex;flex-direction:column;gap:var(--gap-list);margin-top:0;}
.explore-result{padding:9px 12px!important;align-items:center;}
.explore-result__copy{flex:1;min-width:0;}
.explore-empty{
  margin:0;font-size:11.5;line-height:1.45;color:var(--ctext-faint);font-style:italic;
}
.explore-dest-list,
.explore-browse-list{
  display:flex;flex-direction:column;gap:var(--gap-list);margin-top:0;
}
.explore-reassure{margin-top:0;}
.explore-dest-card{
  position:relative;display:flex;align-items:center;gap:11px;width:100%;text-align:left;
  border:1px solid rgba(201,143,106,.16)!important;border-radius:16px;overflow:hidden;
  background:linear-gradient(155deg,rgba(28,28,34,.88),rgba(13,13,16,.9))!important;
  padding:12px 38px 12px 12px;min-height:74px;cursor:pointer;
  box-shadow:0 16px 38px -32px rgba(0,0,0,.8), inset 0 1px 0 rgba(255,255,255,.035);
  transition:border-color .15s, transform .12s;
  -webkit-tap-highlight-color:transparent;
}
.explore-dest-card:hover{border-color:rgba(201,143,106,.28)!important;}
.explore-dest-card:active{transform:scale(.992);}
.explore-dest-card:focus-visible{outline:2px solid var(--gold);outline-offset:2px;}
.explore-dest-card__slot{
  flex:none;width:40px;height:40px;border-radius:12px;
  border:1px solid rgba(201,143,106,.22);background:rgba(201,143,106,.08);
  color:var(--gold);display:flex;align-items:center;justify-content:center;
}
.explore-dest-card__copy{flex:1;min-width:0;position:relative;z-index:1;}
.explore-dest-card__title{
  font-family:var(--font-display);font-size:15px;line-height:1.15;font-weight:600;
  color:var(--ctext);
}
.explore-dest-card__meta{
  margin-top:3px;font-size:10.5px;line-height:1.38;color:var(--ctext-soft);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.explore-dest-card__art{
  position:absolute;right:28px;top:50%;transform:translateY(-50%);
  opacity:.72;pointer-events:none;z-index:0;
}
.explore-dest-card__chev{
  position:absolute;right:12px;top:50%;transform:translateY(-50%);
  color:var(--ctext-faint);z-index:1;
}
.explore-reassure{
  display:flex;align-items:center;gap:12px;width:100%;margin-top:10px;
  border:1px solid rgba(201,143,106,.16);border-radius:16px;
  background:linear-gradient(155deg,rgba(28,28,34,.82),rgba(13,13,16,.86));
  padding:12px 14px;cursor:pointer;text-align:left;
  transition:border-color .15s, transform .12s;
  -webkit-tap-highlight-color:transparent;
}
.explore-reassure:hover{border-color:rgba(201,143,106,.28);}
.explore-reassure:active{transform:scale(.992);}
.explore-reassure:focus-visible{outline:2px solid var(--gold);outline-offset:2px;}
.explore-reassure__glyph{
  flex:none;color:rgba(217,161,132,.78);display:flex;align-items:center;
}
.explore-reassure__copy{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px;}
.explore-reassure__line{
  font-family:var(--font-display);font-size:13px;line-height:1.3;font-weight:600;
  color:rgba(217,161,132,.88);
}
.explore-reassure__cta{
  flex:none;display:inline-flex;align-items:center;gap:4px;
  font-size:11px;font-weight:600;color:var(--gold-bright);white-space:nowrap;
}
.explore-browse-list{display:flex;flex-direction:column;gap:8px;margin-top:4px;}
.explore-dest-card,
.explore-browse-row,
.explore-thread-card,
.explore-reassure{
  font:inherit;color:inherit;
  -webkit-appearance:none;appearance:none;
}
.explore-browse-row{
  padding:10px 12px!important;align-items:center;width:100%;text-align:left;cursor:pointer;
}
.explore-threads{
  display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-top:4px;
}
.explore-thread-card{
  border-radius:14px!important;padding:11px 12px!important;cursor:pointer;text-align:left;
  transition:transform .12s, border-color .15s;
}
.explore-thread-card:active{transform:scale(.992);}

/* Sanctuary journal card */
.sanctuary-write-card{
  border-radius:16px;overflow:hidden;position:relative;margin-top:4px;cursor:pointer;
  background:linear-gradient(120deg,#e7d6b8,#dcc8a4);padding:16px 16px 18px;min-height:120px;
  border:1px solid rgba(122,90,46,.16);box-shadow:0 14px 30px -22px rgba(70,55,31,.45);
  transition:transform .12s cubic-bezier(.2,.8,.2,1);
}
.sanctuary-write-card:active{transform:scale(.992);}
.sanctuary-write-card__title{font-family:var(--font-display);font-size:17px;color:#46371f;font-weight:600;}
.sanctuary-write-card__meta{font-size:12px;color:#6a5736;margin-top:5px;max-width:180px;line-height:1.45;}
.sanctuary-write-card__sprig{position:absolute;right:8px;bottom:-10px;opacity:.6;pointer-events:none;}

/* screen section spacing helper */
.screen-section{margin-top:var(--gap-section);}
.screen-section--loose{margin-top:18px;}
.pad-screen{padding-bottom:calc(12px + env(safe-area-inset-bottom));}

/* Section rhythm (app-wide): label/rule → controls → content */
.matria-flow{
  display:flex;flex-direction:column;gap:var(--gap-section);
}
.matria-section{
  display:flex;flex-direction:column;gap:var(--gap-section-inner);
}
.matria-section > .matria-rule,
.matria-section > .ask-screen__rule,
.matria-section > .explore-screen__threads-rule,
.matria-flow > .matria-rule,
.matria-flow > .ask-screen__rule{
  margin:0;
}
.matria-list{
  display:flex;flex-direction:column;gap:var(--gap-list);
}
.chip-row,
.section-controls{
  display:flex;flex-wrap:wrap;gap:7px;
}
.hscroll.section-controls,
.section-controls.hscroll{
  flex-wrap:nowrap;overflow-x:auto;
}
.chip-row--tight{gap:6px;}
.matria-section__content{min-width:0;}

/* Fallback: controls → list when not yet wrapped in .matria-section */
.hscroll + .ask-question-list,
.hscroll + .explore-dest-list,
.hscroll + .explore-results,
.hscroll + .explore-browse-list,
.hscroll + .matria-list,
.chip-row + .matria-list,
.chip-row + .section-content,
.section-controls + .matria-section__content,
.section-controls + .ask-question-list,
.section-controls + .explore-dest-list,
.section-controls + .explore-results,
.explore-search + .explore-results,
.explore-search + .explore-empty,
.matria-rule + .explore-dest-list,
.matria-rule + .explore-browse-list,
.matria-rule + .ask-question-list,
.matria-rule + .matria-list,
.today-suggested__label + .today-suggested__list{
  margin-top:var(--gap-section-inner);
}
.matria-section > .matria-section__content,
.matria-section > .ask-question-list,
.matria-section > .matria-list,
.matria-section > .explore-dest-list,
.matria-section > .explore-browse-list,
.matria-section > .explore-results,
.matria-section > .explore-empty,
.matria-section > .today-section-head{
  margin-top:0;
}
.matria-section > .today-section-head{margin-bottom:0;}
.matria-rule + .hscroll,
.matria-rule + .chip-row,
.matria-rule + .section-controls,
.label + .hscroll,
.label + .chip-row{
  margin-top:var(--gap-section-inner);
}

/* Archive primer: how lineage, notes and search work */
.archive-primer{padding-top:6px;padding-bottom:calc(18px + env(safe-area-inset-bottom));}
.archive-primer__lead{margin:8px 0 16px;color:var(--ink-soft);}
.archive-primer__sections{display:flex;flex-direction:column;gap:10px;}
.archive-primer__section{border:1px solid var(--line-cream);}
.archive-primer__foot{
  text-align:center;font-size:11.5;color:var(--ink-faint);font-style:italic;
  margin:14px 0 4px;line-height:1.5;
}

/* Visual System Rollout: final overrides */
.screen.matria-dark{
  --ink:var(--ctext);
  --ink-soft:rgba(231,224,210,.68);
  --ink-faint:rgba(231,224,210,.42);
}
.screen.matria-dark .title,
.screen.matria-dark .display-title{
  font-family:var(--font-display);
  color:#d9a184;
  letter-spacing:-.018em;
  font-weight:600;
}
.screen.matria-dark .lead,
.screen.matria-dark .bodytext{color:rgba(231,224,210,.68);}
.screen.matria-dark .label{
  color:var(--gold);
  letter-spacing:.14em;
  font-size:9px;
}
.screen.matria-dark .rule{
  border:0;
  height:1px;
  background:linear-gradient(90deg,transparent,rgba(201,143,106,.42),transparent);
}
.screen.matria-dark .card,
.screen.matria-dark .dcard,
.screen.matria-dark .lrow{
  border:1px solid rgba(201,143,106,.16)!important;
  background:linear-gradient(155deg,rgba(28,28,34,.88),rgba(13,13,16,.9))!important;
  box-shadow:0 16px 38px -32px rgba(0,0,0,.8), inset 0 1px 0 rgba(255,255,255,.035);
}
.screen.matria-dark .lrow:hover,
.screen.matria-dark .card:hover{border-color:rgba(201,143,106,.28)!important;}
.screen.matria-dark .tag,
.screen.matria-dark .chip{
  background:rgba(201,143,106,.08);
  border-color:rgba(201,143,106,.2);
}
.screen.matria-dark .chip.on{
  background:rgba(201,143,106,.16);
  color:var(--gold-bright);
  border-color:rgba(201,143,106,.4);
}
.screen.matria-dark .btn-tan,
.screen.matria-dark .today-ask__submit{
  background:linear-gradient(180deg,#e5b68e,#cf9468);
  color:#231a14;
  box-shadow:0 12px 28px rgba(201,143,106,.24), inset 0 1px 0 rgba(255,255,255,.3);
}
.screen.matria-dark .topbar{
  border-bottom-color:rgba(201,143,106,.12);
  background:linear-gradient(180deg,rgba(3,3,5,.8),rgba(3,3,5,.22));
}
.today-route .today-hero{
  position:relative;
  padding-top:10px;
}
.today-route .today-hero::before{
  content:'';position:absolute;left:14px;top:12px;width:16px;height:16px;
  background:center/contain no-repeat url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 4v16M4 12h16M7 7l10 10M17 7L7 17' stroke='%23c98f6a' stroke-width='1' stroke-linecap='round'/%3E%3Ccircle cx='12' cy='12' r='5.7' stroke='%23c98f6a' stroke-width='.8' opacity='.7'/%3E%3C/svg%3E");
  opacity:.62;
}
.today-route .today-hero__row{padding-left:28px;}
.today-route .today-ask__bar{
  border-color:rgba(201,143,106,.18);
  background:linear-gradient(155deg,rgba(28,28,34,.86),rgba(13,13,16,.9));
}
.today-route .today-suggest__chip{
  border-color:rgba(201,143,106,.18);
  background:rgba(201,143,106,.07);
}
.letters-compose-teaser{
  background:
    radial-gradient(circle at 88% 20%,rgba(201,143,106,.12),transparent 34%),
    linear-gradient(155deg,rgba(28,28,34,.9),rgba(13,13,16,.92))!important;
}
.screen.matria-cream .title,
.screen.has-womb-sky .title,
.screen.matria-cream .display-title,
.screen.has-womb-sky .display-title{
  font-family:var(--font-display);
  color:#33281f;
  letter-spacing:-.018em;
  font-weight:600;
}
.screen.matria-cream .lead,
.screen.has-womb-sky .lead,
.screen.matria-cream .bodytext,
.screen.has-womb-sky .bodytext{color:#665947;}
.screen.matria-cream .label,
.screen.has-womb-sky .label{
  color:#a36f4d;
  font-size:9px;
  letter-spacing:.14em;
}
.screen.matria-cream .rule,
.screen.has-womb-sky .rule{
  border:0;
  height:1px;
  background:linear-gradient(90deg,transparent,rgba(184,147,90,.42),transparent);
}
.screen.matria-cream .card,
.screen.has-womb-sky .card,
.screen.matria-cream .lrow,
.screen.has-womb-sky .lrow,
.screen.matria-cream .prompt-card,
.screen.has-womb-sky .prompt-card{
  background:linear-gradient(180deg,rgba(255,248,234,.92),rgba(244,231,205,.9))!important;
  border:1px solid rgba(184,147,90,.24)!important;
  box-shadow:0 12px 30px -24px rgba(122,90,46,.35), inset 0 1px 0 rgba(255,255,255,.42);
}
.screen.matria-cream .cream-row,
.screen.has-womb-sky .cream-row{
  background:linear-gradient(180deg,rgba(255,248,234,.9),rgba(244,231,205,.88));
  border-color:rgba(184,147,90,.24);
}
.screen.matria-cream .chip,
.screen.has-womb-sky .chip,
.screen.matria-cream .tag,
.screen.has-womb-sky .tag{
  background:rgba(201,143,106,.08);
  border-color:rgba(184,147,90,.22);
}
.screen.matria-cream .chip.on,
.screen.has-womb-sky .chip.on{
  background:rgba(201,143,106,.16);
  color:#7a4e36;
  border-color:rgba(184,147,90,.42);
}
.screen.matria-cream .btn-navy,
.screen.has-womb-sky .btn-navy{
  background:linear-gradient(180deg,#242535,#161824)!important;
  color:#f5ead5!important;
  box-shadow:0 12px 26px -18px rgba(22,24,36,.72), inset 0 1px 0 rgba(255,255,255,.08);
}
.screen.matria-cream .btn-tan,
.screen.has-womb-sky .btn-tan,
.cream-editorial-cta{
  background:linear-gradient(180deg,#d8ad82,#bf845a)!important;
  color:#241a12!important;
  box-shadow:0 12px 26px -18px rgba(150,96,48,.7), inset 0 1px 0 rgba(255,255,255,.35);
}
.screen.matria-cream input,
.screen.has-womb-sky input,
.screen.matria-cream textarea,
.screen.has-womb-sky textarea,
.ask-field{
  background:rgba(255,248,234,.82)!important;
  border-color:rgba(184,147,90,.28)!important;
}
.screen.matria-cream .topbar,
.screen.has-womb-sky .topbar{
  border-bottom-color:rgba(184,147,90,.18);
  background:linear-gradient(180deg,rgba(251,243,226,.82),rgba(251,243,226,.28));
}
.carrying-screen .lrow{
  min-height:54px;
  border-radius:15px;
}
.carrying-list{display:flex;flex-direction:column;gap:10px;}
.carrying-row{
  width:100%;text-align:left;font-family:var(--font-body);
  min-height:52px;cursor:pointer;border:1px solid var(--line-cream);
  background:var(--cream-card);transition:border-color .15s, background .15s;
  -webkit-tap-highlight-color:transparent;
}
.carrying-row--on{
  border-color:var(--gold-line);background:var(--cream-card-2);
}
.carrying-row--on .lrow__slot{
  background:rgba(201,143,106,.12);border-color:var(--gold-line);color:var(--gold-line);
}
.carrying-row__label{
  flex:1;font-size:13.5px;color:#3c3730;font-weight:500;line-height:1.35;
}
.carrying-row--on .carrying-row__label{font-weight:700;}
.carrying-row__check{color:var(--gold-line);flex:none;}
.carrying-row--skip{
  border-style:dashed;background:rgba(255,255,255,.2);
}
.carrying-row--skip .carrying-row__label{color:var(--ink-soft);font-weight:500;}
.carrying-row--skip.carrying-row--on .carrying-row__label{font-weight:600;}
.carrying-row__slot--skip{
  background:transparent!important;border-color:var(--line-cream)!important;
  color:var(--ink-faint)!important;font-size:16px;font-weight:400;
}
.carrying-toolbar{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:6px;padding-bottom:4px;flex:none;
}
.carrying-toolbar__back{
  background:none;border:none;padding:0;cursor:pointer;color:var(--ink);
}
.carrying-toolbar__title{flex:1;text-align:center;}
.carrying-toolbar__spacer{width:22px;flex:none;}
.reading-room__body{
  padding-bottom:12px;
}
.reading-room__suggest-foot .btn{
  height:48px;
}
.reading-room__suggest-foot p{
  margin:8px 0 0;
  text-align:center;
  font-size:10.5px;
  line-height:1.35;
  color:var(--ink-faint);
  font-style:italic;
}

/* Authored differentiators: Matria marks */
.screen.matria-dark::before,
.screen.matria-cream::before,
.screen.has-womb-sky::before{
  content:'';
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:0;
}
.screen.matria-dark::before{
  opacity:.5;
  background:
    radial-gradient(circle at 14% 18%,rgba(220,186,132,.18) 0 1px,transparent 1.4px),
    radial-gradient(circle at 86% 34%,rgba(201,143,106,.18) 0 .8px,transparent 1.2px),
    radial-gradient(circle at 76% 72%,rgba(231,224,210,.1) 0 .7px,transparent 1.1px);
  background-size:112px 112px,84px 84px,136px 136px;
}
.screen.matria-cream::before,
.screen.has-womb-sky::before{
  opacity:.46;
  background:
    radial-gradient(circle at 22% 18%,rgba(122,90,46,.16) 0 .55px,transparent .9px),
    radial-gradient(circle at 78% 64%,rgba(201,143,106,.13) 0 .6px,transparent 1px),
    linear-gradient(115deg,transparent 0 46%,rgba(184,147,90,.07) 47%,transparent 48% 100%);
  background-size:18px 18px,24px 24px,132px 132px;
  mix-blend-mode:multiply;
}
.screen.matria-dark .s-body,
.screen.matria-cream .s-body,
.screen.has-womb-sky .s-body,
.screen.matria-dark .status,
.screen.matria-cream .status,
.screen.has-womb-sky .status,
.screen.matria-dark .tabbar,
.screen.matria-cream .tabbar,
.screen.has-womb-sky .tabbar,
.screen.matria-dark .topbar,
.screen.matria-cream .topbar,
.screen.has-womb-sky .topbar{
  position:relative;
  z-index:1;
}
.screen.matria-dark .card,
.screen.matria-dark .dcard,
.screen.matria-dark .lrow,
.screen.matria-cream .card,
.screen.has-womb-sky .card,
.screen.matria-cream .lrow,
.screen.has-womb-sky .lrow,
.screen.matria-cream .prompt-card,
.screen.has-womb-sky .prompt-card{
  position:relative;
  overflow:hidden;
}
.screen.matria-dark .card::before,
.screen.matria-dark .dcard::before,
.screen.matria-cream .card::before,
.screen.has-womb-sky .card::before,
.screen.matria-cream .prompt-card::before,
.screen.has-womb-sky .prompt-card::before{
  content:'';
  position:absolute;
  left:12px;
  top:10px;
  width:18px;
  height:1px;
  background:linear-gradient(90deg,rgba(201,143,106,.58),transparent);
  opacity:.7;
  pointer-events:none;
}
.screen.matria-dark .lrow::after,
.screen.matria-cream .lrow::after,
.screen.has-womb-sky .lrow::after{
  content:'';
  position:absolute;
  left:10px;
  top:9px;
  width:5px;
  height:5px;
  border-left:1px solid rgba(201,143,106,.45);
  border-top:1px solid rgba(201,143,106,.45);
  opacity:.7;
  pointer-events:none;
}
.screen.matria-dark .btn-tan,
.screen.matria-cream .btn-navy,
.screen.has-womb-sky .btn-navy,
.screen.matria-cream .btn-tan,
.screen.has-womb-sky .btn-tan,
.cream-editorial-cta{
  position:relative;
  overflow:hidden;
}
.screen.matria-dark .btn-tan::after,
.screen.matria-cream .btn-navy::after,
.screen.has-womb-sky .btn-navy::after,
.screen.matria-cream .btn-tan::after,
.screen.has-womb-sky .btn-tan::after,
.cream-editorial-cta::after{
  content:'';
  position:absolute;
  right:18px;
  top:50%;
  width:18px;
  height:18px;
  transform:translateY(-50%);
  opacity:.18;
  background:center/contain no-repeat url("data:image/svg+xml,%3Csvg width='28' height='28' viewBox='0 0 28 28' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M14 3.5v21M3.5 14h21M7.2 7.2l13.6 13.6M20.8 7.2L7.2 20.8' stroke='%23241a12' stroke-width='1' stroke-linecap='round'/%3E%3Ccircle cx='14' cy='14' r='7.2' stroke='%23241a12' stroke-width='.9'/%3E%3C/svg%3E");
  pointer-events:none;
}
.screen.matria-dark .btn-tan::after{
  opacity:.2;
}
.matria-head--rail::before,
.today-route .today-hero::before{
  filter:drop-shadow(0 0 7px rgba(201,143,106,.22));
}
