/* ====================================================
   TODAY'S THOUGHT IN ENGLISH — site.css
   Locked design system: "Sanctuary of Light"
   ==================================================== */
:root{
  --void:#04040a;--abyss:#080814;--ink-glass:rgba(11,11,22,0.46);
  --hairline:rgba(255,255,255,0.08);--hairline-soft:rgba(255,255,255,0.05);
  --cyan:#5fe3ff;--violet:#8b5cf6;--magenta:#d946ef;--lumen:#ffc987;--lumen-bright:#ffe2b8;
  --text-bright:#f4f2fb;--text-mid:#a8a6bd;--text-dim:#73718c;
  --ease-out:cubic-bezier(0.16,1,0.3,1);--ease-snap:cubic-bezier(0.25,0.8,0.25,1);--glass-blur:blur(26px);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{min-height:100vh;background:var(--void);color:var(--text-mid);
  font-family:'Outfit',-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  overflow-x:hidden;-webkit-font-smoothing:antialiased;line-height:1.6}
::selection{background:rgba(255,201,135,0.22);color:var(--text-bright)}
::-webkit-scrollbar{width:9px}::-webkit-scrollbar-track{background:var(--void)}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.08);border-radius:5px;border:2px solid var(--void)}
::-webkit-scrollbar-thumb:hover{background:var(--lumen)}
:focus-visible{outline:2px solid var(--lumen);outline-offset:3px;border-radius:6px}
a{color:inherit;text-decoration:none}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* ---- cosmos ---- */
#cosmos,#constellation{position:fixed;inset:0;pointer-events:none}
#cosmos{z-index:1}#constellation{z-index:1}
.nebula{position:fixed;border-radius:50%;filter:blur(150px);opacity:.15;pointer-events:none;z-index:0;mix-blend-mode:screen}
.nebula.a{width:60vw;height:60vw;top:-22%;left:-12%;background:radial-gradient(circle,var(--cyan),transparent 70%);animation:drift 34s ease-in-out infinite}
.nebula.b{width:62vw;height:62vw;bottom:-24%;right:-12%;background:radial-gradient(circle,var(--violet),transparent 70%);animation:drift 46s ease-in-out infinite reverse}
.nebula.c{width:38vw;height:38vw;top:34%;left:42%;opacity:.10;background:radial-gradient(circle,var(--lumen),transparent 70%);animation:drift 40s ease-in-out infinite}
.grain{position:fixed;inset:0;z-index:2;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.vignette{position:fixed;inset:0;z-index:3;pointer-events:none;background:radial-gradient(ellipse at 50% 35%,transparent 42%,rgba(2,2,7,0.55) 100%)}

/* ---- header / nav ---- */
.hdr{position:sticky;top:0;z-index:100;height:74px;padding:0 5%;display:flex;align-items:center;justify-content:space-between;
  background:linear-gradient(to bottom,rgba(4,4,10,0.9),transparent);backdrop-filter:blur(8px)}
.logo{font-size:1rem;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:var(--text-bright)}
.logo .accent{background:linear-gradient(90deg,var(--cyan),var(--lumen));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;font-weight:700}
.nav{display:flex;gap:26px}
.nav a{font-size:.74rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-mid);position:relative;transition:color .3s}
.nav a::after{content:'';position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--lumen);transition:width .35s var(--ease-out)}
.nav a:hover,.nav a.active{color:var(--text-bright)}.nav a:hover::after,.nav a.active::after{width:100%}
@media(max-width:820px){.nav{gap:18px}}

/* ---- generic layout ---- */
.wrap{position:relative;z-index:10;max-width:760px;margin:0 auto;padding:60px 24px 0}
.wrap-wide{max-width:1180px}
.crumb{font-size:.72rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-dim);margin-bottom:30px}
.crumb a{color:var(--text-mid)}.crumb a:hover{color:var(--lumen)}.crumb span{margin:0 8px;opacity:.5}
.eyebrow{display:flex;align-items:center;gap:12px;font-size:.72rem;letter-spacing:3px;text-transform:uppercase;color:var(--lumen);margin-bottom:22px}
.eyebrow::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--lumen);box-shadow:0 0 10px var(--lumen)}
.sec-head{text-align:center;margin-bottom:56px}
.sec-title{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:3rem;color:var(--text-bright);line-height:1.1;letter-spacing:1px}
.sec-title em{font-style:italic;background:linear-gradient(90deg,var(--cyan),var(--lumen));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.sec-sub{margin-top:14px;font-size:.96rem;color:var(--text-dim)}

/* ---- HOME hero ---- */
.hero{position:relative;z-index:10;min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:120px 5% 80px}
.hero-eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:28px;font-size:.72rem;letter-spacing:4px;text-transform:uppercase;color:var(--text-mid)}
.hero-eyebrow .star{width:7px;height:7px;background:var(--lumen);border-radius:50%;box-shadow:0 0 12px var(--lumen)}
.hero-eyebrow .rule{width:46px;height:1px;background:linear-gradient(90deg,var(--lumen),transparent)}
.card-stage{width:100%;max-width:740px;perspective:1400px;z-index:12}

/* ---- thought card (home + thought page) ---- */
.thought-card{position:relative;border-radius:30px;padding:52px 52px;background:var(--ink-glass);backdrop-filter:var(--glass-blur);
  border:1px solid var(--hairline);box-shadow:0 1px 0 rgba(255,255,255,0.08) inset,0 30px 80px rgba(0,0,0,0.55);transform-style:preserve-3d;transition:border-color .6s ease}
.thought-card:hover{border-color:rgba(95,227,255,0.22)}
.spec{position:absolute;inset:0;border-radius:30px;pointer-events:none;z-index:1;opacity:0;transition:opacity .5s ease;
  background:radial-gradient(380px circle at var(--mx,50%) var(--my,0%),rgba(255,201,135,0.10),rgba(95,227,255,0.05) 35%,transparent 60%)}
.thought-card:hover .spec{opacity:1}
.t-meta{display:flex;align-items:center;gap:14px;margin-bottom:28px;transform:translateZ(40px)}
.t-date{font-size:.74rem;letter-spacing:2px;text-transform:uppercase;color:var(--cyan);text-shadow:0 0 12px rgba(95,227,255,.3)}
.t-sep{width:5px;height:5px;border-radius:50%;background:var(--text-dim)}
.t-topic{font-size:.72rem;letter-spacing:3px;text-transform:uppercase;color:var(--text-dim)}
.qmark{font-family:'Cormorant Garamond',serif;font-size:5rem;line-height:.4;color:rgba(255,255,255,0.05);display:block;height:34px}
.quote{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:2.5rem;line-height:1.42;color:var(--text-bright);margin:8px 0 22px;transform:translateZ(60px)}
.quote.lit{background:linear-gradient(100deg,var(--text-bright) 30%,var(--lumen-bright) 50%,var(--text-bright) 70%);background-size:220% 100%;
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:sweep 7s ease-in-out infinite}
.quote .w{display:inline-block;transform-origin:bottom}
.author{font-size:.86rem;letter-spacing:2px;text-transform:uppercase;color:var(--text-mid);font-style:normal;display:block;transform:translateZ(40px)}
.author::before{content:'— '}
.cite-src{margin-top:6px;font-size:.78rem;color:var(--text-dim);letter-spacing:.5px;transform:translateZ(30px)}

/* ---- share bar ---- */
.share{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:28px;padding-top:24px;border-top:1px solid var(--hairline-soft);transform:translateZ(40px)}
.share-label{font-size:.7rem;letter-spacing:2px;text-transform:uppercase;color:var(--text-dim);margin-right:4px}
.sbtn{width:42px;height:42px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;
  background:rgba(255,255,255,0.03);border:1px solid var(--hairline);color:var(--text-mid);transition:.25s var(--ease-snap)}
.sbtn svg{width:18px;height:18px}
.sbtn:hover{transform:translateY(-2px);color:var(--text-bright);border-color:var(--lumen);box-shadow:0 8px 18px rgba(0,0,0,0.4)}
.sbtn.img:hover{border-color:var(--cyan);color:var(--cyan)}
.sbtn.native{display:none}
@media(max-width:600px){.sbtn.native{display:inline-flex}}

/* ---- home tools ---- */
.card-tools{display:flex;gap:12px;margin-top:30px;transform:translateZ(46px);flex-wrap:wrap}
.tool{flex:1;min-width:120px;background:rgba(255,255,255,0.03);border:1px solid var(--hairline);border-radius:16px;padding:13px 16px;
  display:inline-flex;align-items:center;justify-content:center;gap:9px;cursor:pointer;color:var(--text-mid);font-size:.8rem;font-weight:500;letter-spacing:1px;transition:.3s var(--ease-snap)}
.tool svg{width:16px;height:16px;transition:transform .3s}
.tool:hover{background:rgba(255,255,255,0.07);color:var(--text-bright);transform:translateY(-1px)}
.tool:hover svg{transform:scale(1.12)}
.tool.full-link{flex:1 0 100%;background:linear-gradient(135deg,rgba(95,227,255,.12),rgba(255,201,135,.12));border-color:rgba(255,201,135,.3);color:var(--text-bright)}
.scroll-cue{margin-top:60px;display:flex;flex-direction:column;align-items:center;gap:10px;cursor:pointer;color:var(--text-dim);transition:color .3s}
.scroll-cue:hover{color:var(--text-mid)}
.scroll-cue span{font-size:.68rem;letter-spacing:3px;text-transform:uppercase}
.scroll-cue svg{width:20px;height:20px;animation:bob 2.4s ease-in-out infinite}

/* ---- content blocks (thought page) ---- */
.block{margin:60px 0}
.block h2{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:2rem;color:var(--text-bright);margin-bottom:18px;line-height:1.2}
.prose p{font-size:1.06rem;line-height:1.85;color:var(--text-mid);margin-bottom:18px}
.prose p strong{color:var(--text-bright);font-weight:500}

/* ---- vocabulary ---- */
.vocab{display:grid;gap:16px}
.v-card{background:rgba(11,11,22,0.4);backdrop-filter:blur(12px);border:1px solid var(--hairline);border-radius:18px;padding:24px 26px;transition:.4s var(--ease-out)}
.v-card:hover{border-color:rgba(95,227,255,0.25);transform:translateY(-3px)}
.v-top{display:flex;align-items:center;gap:14px;margin-bottom:10px;flex-wrap:wrap}
.v-word{font-family:'Cormorant Garamond',serif;font-size:1.7rem;color:var(--text-bright)}
.v-ipa{font-size:.9rem;color:var(--cyan);letter-spacing:.5px}
.v-pos{font-size:.66rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-dim);border:1px solid var(--hairline);border-radius:20px;padding:3px 10px}
.v-hear,.v-save{background:rgba(255,255,255,0.03);border:1px solid var(--hairline);border-radius:10px;width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-mid);transition:.25s}
.v-hear{margin-left:auto}
.v-hear:hover{color:var(--cyan);border-color:var(--cyan)}
.v-save:hover{color:var(--lumen);border-color:var(--lumen)}
.v-save.saved{color:var(--lumen);border-color:var(--lumen);background:rgba(255,201,135,0.08)}
.v-hear svg,.v-save svg{width:15px;height:15px}
.v-def{color:var(--text-mid);margin-bottom:8px}
.v-syn{font-size:.86rem;color:var(--text-dim)}.v-syn b{color:var(--text-mid);font-weight:500}
.v-ex{font-family:'Cormorant Garamond',serif;font-style:italic;color:var(--text-mid);margin-top:10px;padding-left:14px;border-left:2px solid var(--hairline)}

/* ---- FAQ ---- */
.faq-item{border-bottom:1px solid var(--hairline-soft)}
.faq-q{width:100%;text-align:left;background:none;border:none;cursor:pointer;padding:22px 0;display:flex;justify-content:space-between;gap:16px;align-items:center;font-size:1.08rem;color:var(--text-bright);font-weight:500;font-family:'Outfit'}
.faq-q .chev{transition:transform .35s var(--ease-out);color:var(--lumen);flex-shrink:0}
.faq-item.open .chev{transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .45s var(--ease-out)}
.faq-a p{padding:0 0 22px;color:var(--text-mid);line-height:1.8}

/* ---- related / node grids ---- */
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px}
.r-card{display:block;background:rgba(11,11,22,0.4);backdrop-filter:blur(12px);border:1px solid var(--hairline);border-radius:20px;padding:28px;transition:.4s var(--ease-out);position:relative;overflow:hidden}
.r-card::before{content:'';position:absolute;top:22px;right:24px;width:8px;height:8px;border-radius:50%;background:var(--lumen);box-shadow:0 0 12px var(--lumen);opacity:.4;transition:.4s}
.r-card:hover{transform:translateY(-6px);border-color:rgba(255,201,135,0.3);box-shadow:0 22px 46px rgba(0,0,0,0.5)}
.r-card:hover::before{opacity:1;transform:scale(1.3)}
.r-card .rdate{font-size:.68rem;letter-spacing:2px;text-transform:uppercase;color:var(--cyan);opacity:.8}
.r-card .rq{font-family:'Cormorant Garamond',serif;font-size:1.3rem;color:var(--text-bright);line-height:1.4;margin:12px 0 14px}
.r-card .ra{font-size:.72rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-dim)}

/* ---- collections ---- */
.col-card{display:block;background:rgba(11,11,22,0.4);backdrop-filter:blur(12px);border:1px solid var(--hairline);border-radius:24px;padding:36px;transition:.45s var(--ease-out)}
.col-card:hover{transform:translateY(-6px);border-color:rgba(95,227,255,0.3);box-shadow:0 24px 50px rgba(0,0,0,0.5)}
.col-card h3{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:1.9rem;color:var(--text-bright);margin-bottom:10px}
.col-card .cb{color:var(--text-mid);font-size:.96rem;margin-bottom:18px}
.col-card .cc{font-size:.72rem;letter-spacing:2px;text-transform:uppercase;color:var(--lumen)}
.col-group{margin-bottom:64px}
.col-group .ch{display:flex;align-items:baseline;gap:14px;margin-bottom:24px}
.col-group .ch h2{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:2.2rem;color:var(--text-bright)}
.col-group .ch span{font-size:.74rem;letter-spacing:2px;text-transform:uppercase;color:var(--text-dim)}

/* ---- newsletter / footer ---- */
.subscribe{position:relative;z-index:10;text-align:center;padding:100px 5% 60px}
.subscribe .glow{position:absolute;top:0;left:50%;transform:translateX(-50%);width:600px;height:300px;background:radial-gradient(ellipse,rgba(255,201,135,0.06),transparent 70%);pointer-events:none}
.sub-title{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:2.4rem;color:var(--text-bright)}
.sub-sub{max-width:460px;margin:14px auto 30px;font-size:.95rem;line-height:1.6;color:var(--text-dim)}
.sub-form{display:flex;gap:10px;max-width:480px;margin:0 auto;background:rgba(255,255,255,0.03);border:1px solid var(--hairline);border-radius:18px;padding:7px}
.sub-form input{flex:1;background:transparent;border:none;outline:none;padding:12px 16px;color:var(--text-bright);font-size:.92rem;font-family:'Outfit'}
.sub-form input::placeholder{color:var(--text-dim)}
.sub-btn{background:linear-gradient(135deg,var(--cyan),var(--lumen));border:none;border-radius:13px;padding:12px 22px;color:#08121a;font-weight:700;font-size:.82rem;letter-spacing:1px;text-transform:uppercase;cursor:pointer;transition:.3s var(--ease-snap);font-family:'Outfit'}
.sub-btn:hover{transform:translateY(-1px);box-shadow:0 10px 24px rgba(95,227,255,0.25)}
.sub-success{color:var(--lumen);font-size:.92rem;margin-top:10px;min-height:1.2em}
@media(max-width:560px){.sub-form{flex-direction:column;background:none;border:none;padding:0;gap:12px}
  .sub-form input{background:rgba(255,255,255,0.03);border:1px solid var(--hairline);border-radius:14px}
  .sub-btn{border-radius:14px;padding:15px}}
.footer{position:relative;z-index:10;text-align:center;padding:70px 5% 50px;border-top:1px solid var(--hairline-soft)}
.f-links{display:flex;justify-content:center;gap:24px;flex-wrap:wrap;margin-bottom:24px}
.f-links a{font-size:.78rem;letter-spacing:1px;color:var(--text-mid)}.f-links a:hover{color:var(--lumen)}
.eco-title{font-size:.7rem;letter-spacing:3px;text-transform:uppercase;color:var(--text-dim);margin-bottom:16px}
.eco-links{display:flex;justify-content:center;gap:26px;flex-wrap:wrap;margin-bottom:28px}
.eco-links a{color:var(--text-mid);font-size:.84rem;letter-spacing:1px}.eco-links a:hover{color:var(--text-bright)}
.legal{font-size:.74rem;color:var(--text-dim)}

/* ---- stub pages ---- */
.stub{position:relative;z-index:10;min-height:80vh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:120px 24px}
.stub .badge{font-size:.7rem;letter-spacing:3px;text-transform:uppercase;color:var(--lumen);border:1px solid rgba(255,201,135,.3);border-radius:30px;padding:7px 16px;margin-bottom:26px}
.stub h1{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:3.2rem;color:var(--text-bright);margin-bottom:18px}
.stub p{max-width:460px;color:var(--text-mid);font-size:1.05rem;line-height:1.7;margin-bottom:14px}
.stub .count{font-family:'Cormorant Garamond',serif;font-size:3rem;color:var(--lumen)}

/* ---- toast ---- */
.toast{position:fixed;bottom:30px;left:50%;transform:translateX(-50%) translateY(20px);background:rgba(11,11,22,0.92);backdrop-filter:blur(14px);
  border:1px solid var(--hairline);border-radius:14px;padding:13px 24px;color:var(--text-bright);font-size:.85rem;z-index:500;opacity:0;pointer-events:none;transition:.4s var(--ease-out)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ---- animations ---- */
@keyframes drift{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(5%,8%) scale(1.08)}66%{transform:translate(-7%,-4%) scale(.94)}}
@keyframes sweep{0%,100%{background-position:200% 0}50%{background-position:0 0}}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(8px)}}

@media(max-width:600px){.thought-card{padding:36px 26px;border-radius:24px}.quote{font-size:1.85rem}.block h2{font-size:1.6rem}.sec-title{font-size:2.3rem}.stub h1{font-size:2.4rem}}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none !important;transition-duration:.001ms !important}
  html{scroll-behavior:auto}
  .quote.lit{-webkit-text-fill-color:var(--text-bright);background:none}
  .quote .w{opacity:1 !important;transform:none !important}
}

/* ====================================================
   WAVE 3 — favorites constellation, pin, sanctuary, lexicon
   ==================================================== */

/* ---- pin button ---- */
.t-pin{margin-left:auto;background:rgba(255,255,255,0.03);border:1px solid var(--hairline);border-radius:20px;padding:7px 14px;display:inline-flex;gap:7px;align-items:center;color:var(--text-mid);cursor:pointer;font-size:.68rem;letter-spacing:1.5px;text-transform:uppercase;font-family:'Outfit';transition:.25s var(--ease-snap)}
.t-pin svg{width:14px;height:14px;transition:.25s}
.t-pin:hover{border-color:var(--lumen);color:var(--lumen)}
.t-pin.pinned{color:var(--lumen);border-color:var(--lumen);background:rgba(255,201,135,0.08)}
.t-pin.pinned svg{fill:var(--lumen)}

/* ---- favorites constellation rail ---- */
.fav-rail{position:fixed;right:14px;top:50%;transform:translateY(-50%);z-index:200}
.fav-rail-inner{position:relative;display:flex;flex-direction:column;align-items:center;gap:20px;padding:18px 12px;border-radius:34px;background:rgba(8,8,18,0.45);backdrop-filter:blur(10px);border:1px solid var(--hairline-soft)}
.fav-rail.empty .fav-rail-inner{background:transparent;border-color:transparent;gap:0}
.fav-head{font-size:.56rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--lumen);text-decoration:none;opacity:.85;transition:.25s}
.fav-head:hover{opacity:1}
.fav-line{position:absolute;top:42px;bottom:20px;left:50%;width:1px;transform:translateX(-50%);background:linear-gradient(var(--lumen),transparent);opacity:.3;pointer-events:none}
.fav-star{position:relative;width:12px;height:12px;border:none;cursor:pointer;border-radius:50%;background:radial-gradient(circle,var(--lumen-bright),var(--lumen));box-shadow:0 0 10px var(--lumen);transition:.25s var(--ease-snap)}
.fav-star:nth-child(odd){margin-left:-9px}
.fav-star:nth-child(even){margin-left:9px}
.fav-star:hover,.fav-star:focus-visible{transform:scale(1.6)}
.fav-star.placeholder{background:transparent;border:1px dashed var(--text-dim);box-shadow:none;cursor:default}
.fav-tip{position:absolute;right:26px;top:50%;transform:translateY(-50%) translateX(8px);opacity:0;pointer-events:none;width:210px;text-align:left;background:rgba(11,11,22,0.96);border:1px solid var(--hairline);border-radius:14px;padding:14px 16px;transition:.3s var(--ease-out);box-shadow:0 14px 36px rgba(0,0,0,0.55)}
.fav-star:hover .fav-tip,.fav-star:focus-visible .fav-tip{opacity:1;pointer-events:auto;transform:translateY(-50%) translateX(0)}
.fav-tip .fq{font-family:'Cormorant Garamond',serif;font-size:1rem;color:var(--text-bright);line-height:1.4;margin-bottom:6px}
.fav-tip .fa{font-size:.64rem;letter-spacing:1px;text-transform:uppercase;color:var(--text-dim)}
.fav-unpin{position:absolute;top:6px;right:9px;border:none;background:none;color:var(--text-dim);font-size:.85rem;cursor:pointer;line-height:1}
.fav-unpin:hover{color:var(--magenta)}
@media(max-width:760px){
  .fav-rail{right:12px;bottom:14px;top:auto;transform:none}
  .fav-line{display:none}
  .fav-rail-inner{flex-direction:row;padding:10px 14px}
  .fav-star:nth-child(odd),.fav-star:nth-child(even){margin-left:0}
  .fav-tip{right:auto;left:50%;top:auto;bottom:26px;transform:translateX(-50%) translateY(8px)}
  .fav-star:hover .fav-tip,.fav-star:focus-visible .fav-tip{transform:translateX(-50%) translateY(0)}
}

/* ---- sanctuary ---- */
.s-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;margin:36px 0}
.s-stat{background:rgba(11,11,22,0.4);border:1px solid var(--hairline);border-radius:18px;padding:26px 20px;text-align:center;transition:.4s var(--ease-out)}
.s-stat:hover{border-color:rgba(255,201,135,0.25);transform:translateY(-3px)}
.s-stat .num{font-family:'Cormorant Garamond',serif;font-size:2.7rem;color:var(--lumen);line-height:1}
.s-stat .lbl{font-size:.68rem;letter-spacing:2px;text-transform:uppercase;color:var(--text-dim);margin-top:8px}
#sanctuary-sky{width:100%;height:200px;display:block;border-radius:20px;border:1px solid var(--hairline-soft);background:rgba(4,4,12,0.4)}
.s-section{margin:54px 0}
.s-section h2{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:1.9rem;color:var(--text-bright);margin-bottom:8px}
.s-section .s-sub{color:var(--text-dim);font-size:.9rem;margin-bottom:22px}
.s-empty{color:var(--text-dim);font-style:italic}
.s-link{color:var(--lumen);font-size:.8rem;letter-spacing:1px}

/* ---- journal ---- */
.j-prompt{font-family:'Cormorant Garamond',serif;font-style:italic;color:var(--text-mid);margin-bottom:14px;font-size:1.1rem;line-height:1.6}
.journal-area textarea{width:100%;min-height:130px;background:rgba(0,0,0,0.2);border:1px solid var(--hairline);border-radius:16px;padding:18px;color:var(--text-bright);font-family:'Outfit';font-size:.96rem;line-height:1.7;resize:vertical}
.journal-area textarea:focus{outline:none;border-color:var(--lumen)}
.j-actions{display:flex;gap:12px;align-items:center;margin-top:14px;flex-wrap:wrap}
.glow-btn{background:linear-gradient(135deg,var(--cyan),var(--lumen));border:none;border-radius:14px;padding:13px 24px;color:#08121a;font-weight:700;letter-spacing:1px;text-transform:uppercase;font-size:.78rem;cursor:pointer;font-family:'Outfit';transition:.3s var(--ease-snap)}
.glow-btn:hover{transform:translateY(-1px);box-shadow:0 10px 24px rgba(95,227,255,0.25)}
.ghost-btn2{background:rgba(255,255,255,0.03);border:1px solid var(--hairline);border-radius:14px;padding:13px 20px;color:var(--text-mid);font-family:'Outfit';font-size:.74rem;letter-spacing:1px;text-transform:uppercase;cursor:pointer;transition:.25s}
.ghost-btn2:hover{color:var(--text-bright);border-color:var(--lumen)}
.j-entry{background:rgba(11,11,22,0.4);border:1px solid var(--hairline);border-radius:14px;padding:18px 20px;margin-top:14px;position:relative}
.j-entry .jd{font-size:.64rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-dim);margin-bottom:8px}
.j-entry p{color:var(--text-mid);line-height:1.75;white-space:pre-wrap}
.j-del{position:absolute;top:14px;right:16px;border:none;background:none;color:var(--text-dim);cursor:pointer;font-size:.9rem}
.j-del:hover{color:var(--magenta)}

/* ---- lexicon review (SRS) ---- */
.review-progress{font-size:.74rem;letter-spacing:2px;text-transform:uppercase;color:var(--text-dim);text-align:center;margin-bottom:18px}
.review-card{background:var(--ink-glass);backdrop-filter:var(--glass-blur);border:1px solid var(--hairline);border-radius:26px;padding:46px 40px;text-align:center;max-width:520px;margin:0 auto 30px;box-shadow:0 24px 60px rgba(0,0,0,0.5)}
.review-word{font-family:'Cormorant Garamond',serif;font-size:2.7rem;color:var(--text-bright)}
.review-ipa{color:var(--cyan);margin:8px 0 22px;letter-spacing:.5px}
.review-def{color:var(--text-mid);line-height:1.75;margin-bottom:26px;min-height:1.7em}
.review-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.review-btn{border:1px solid var(--hairline);background:rgba(255,255,255,0.03);color:var(--text-mid);border-radius:14px;padding:13px 26px;cursor:pointer;font-family:'Outfit';font-weight:600;letter-spacing:1px;transition:.25s var(--ease-snap)}
.review-btn.again:hover{border-color:var(--magenta);color:var(--magenta)}
.review-btn.good:hover{border-color:var(--cyan);color:var(--cyan)}
.review-done{text-align:center;color:var(--text-mid);font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.3rem;padding:30px}

/* ====================================================
   WAVE 4 — resources / wallpaper tool / monetization slots
   ==================================================== */

/* ---- resources hub ---- */
.res-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px}
.res-card{background:rgba(11,11,22,0.4);border:1px solid var(--hairline);border-radius:22px;padding:32px;transition:.45s var(--ease-out);display:flex;flex-direction:column}
.res-card:hover{transform:translateY(-6px);border-color:rgba(95,227,255,0.3);box-shadow:0 22px 46px rgba(0,0,0,0.5)}
.res-card .ricon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:rgba(255,201,135,0.1);color:var(--lumen);margin-bottom:18px}
.res-card .ricon svg{width:22px;height:22px}
.res-card .rtag{font-size:.6rem;letter-spacing:2px;text-transform:uppercase;color:var(--text-dim);border:1px solid var(--hairline);border-radius:20px;padding:4px 10px;align-self:flex-start;margin-bottom:14px}
.res-card .rtag.live{color:var(--cyan);border-color:rgba(95,227,255,0.3)}
.res-card .rtag.soon{color:var(--lumen);border-color:rgba(255,201,135,0.3)}
.res-card h3{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:1.55rem;color:var(--text-bright);margin-bottom:8px}
.res-card p{color:var(--text-mid);font-size:.92rem;flex:1;margin-bottom:18px}

/* ---- wallpaper tool ---- */
.wp-controls{display:flex;flex-wrap:wrap;gap:24px;align-items:flex-end;justify-content:center;margin-bottom:34px}
.wp-field label{display:block;font-size:.66rem;letter-spacing:2px;text-transform:uppercase;color:var(--text-dim);margin-bottom:8px}
.wp-field select{background:rgba(11,11,22,0.6);border:1px solid var(--hairline);border-radius:12px;padding:12px 16px;color:var(--text-bright);font-family:'Outfit';font-size:.9rem;min-width:230px;cursor:pointer}
.wp-field select:focus{outline:none;border-color:var(--lumen)}
.wp-formats{display:flex;gap:10px}
.wp-fmt{background:rgba(255,255,255,0.03);border:1px solid var(--hairline);border-radius:12px;padding:12px 18px;color:var(--text-mid);cursor:pointer;font-size:.76rem;letter-spacing:1px;font-family:'Outfit';transition:.25s var(--ease-snap)}
.wp-fmt.active{border-color:var(--lumen);color:var(--lumen);background:rgba(255,201,135,0.08)}
.wp-preview-wrap{display:flex;justify-content:center;margin-bottom:26px}
#wp-canvas{max-width:100%;max-height:62vh;border-radius:16px;border:1px solid var(--hairline);box-shadow:0 24px 60px rgba(0,0,0,0.5);background:#04040a}
.wp-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;align-items:center}

/* ---- affiliate "go deeper" ---- */
.deeper{background:linear-gradient(135deg,rgba(95,227,255,0.06),rgba(255,201,135,0.06));border:1px solid var(--hairline);border-radius:20px;padding:28px 30px}
.deeper .dl{font-size:.64rem;letter-spacing:2px;text-transform:uppercase;color:var(--lumen);margin-bottom:10px}
.deeper h3{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:1.4rem;color:var(--text-bright);margin-bottom:8px}
.deeper p{color:var(--text-mid);margin-bottom:16px;font-size:.95rem;line-height:1.7}
.deeper .deeper-link{display:inline-flex;align-items:center;gap:8px;color:var(--cyan);font-size:.82rem;letter-spacing:1px;text-transform:uppercase}
.deeper .deeper-link svg{width:14px;height:14px}

/* ---- print-on-demand cta ---- */
.pod-cta{text-align:center;margin-top:18px;font-size:.86rem;color:var(--text-dim)}
.pod-cta a{color:var(--lumen)}

/* ---- ad slots (empty until AdSense code pasted) ---- */
.ad-slot{margin:46px auto;text-align:center;max-width:728px}
.ad-slot:empty{display:none}
.ad-label{font-size:.58rem;letter-spacing:2px;text-transform:uppercase;color:var(--text-dim);opacity:.45;margin-bottom:6px;display:block}

/* ---- wallpaper: your-own-words mode + my thoughts ---- */
.wp-modes{display:flex;gap:10px;justify-content:center;margin-bottom:26px}
.wp-mode{background:rgba(255,255,255,0.03);border:1px solid var(--hairline);border-radius:30px;padding:11px 22px;color:var(--text-mid);cursor:pointer;font-family:'Outfit';font-size:.78rem;letter-spacing:1px;transition:.25s var(--ease-snap)}
.wp-mode.active{border-color:var(--cyan);color:var(--cyan);background:rgba(95,227,255,0.08)}
.wp-panel{display:none}
.wp-panel.active{display:block}
.wp-own{max-width:560px;margin:0 auto}
.wp-own textarea{width:100%;min-height:120px;background:rgba(0,0,0,0.2);border:1px solid var(--hairline);border-radius:16px;padding:18px;color:var(--text-bright);font-family:'Cormorant Garamond',serif;font-size:1.3rem;line-height:1.5;resize:vertical}
.wp-own textarea:focus{outline:none;border-color:var(--lumen)}
.wp-own input{width:100%;margin-top:12px;background:rgba(0,0,0,0.2);border:1px solid var(--hairline);border-radius:12px;padding:12px 16px;color:var(--text-bright);font-family:'Outfit';font-size:.92rem}
.wp-own input:focus{outline:none;border-color:var(--lumen)}
.wp-own .wp-own-actions{display:flex;justify-content:center;margin-top:14px}
.wp-mynotes{max-width:760px;margin:48px auto 0}
.wp-mynotes h3{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:1.6rem;color:var(--text-bright);margin-bottom:18px;text-align:center}
.wp-note{display:flex;justify-content:space-between;align-items:center;gap:14px;background:rgba(11,11,22,0.4);border:1px solid var(--hairline);border-radius:14px;padding:14px 18px;margin-top:10px;cursor:pointer;transition:.25s var(--ease-out)}
.wp-note:hover{border-color:var(--lumen);transform:translateY(-2px)}
.wp-note p{font-family:'Cormorant Garamond',serif;color:var(--text-bright);font-size:1.05rem;line-height:1.4}
.wp-note .wn-a{font-size:.66rem;letter-spacing:1px;text-transform:uppercase;color:var(--text-dim);margin-top:4px}
.wp-note .wn-del{border:none;background:none;color:var(--text-dim);cursor:pointer;font-size:.95rem;flex-shrink:0}
.wp-note .wn-del:hover{color:var(--magenta)}
.wp-empty{color:var(--text-dim);font-style:italic;text-align:center}

/* ---- personal note stars in rail ---- */
.fav-star.note{background:radial-gradient(circle,#bfefff,var(--cyan));box-shadow:0 0 10px var(--cyan)}
.fav-tip .ftype{display:block;font-size:.56rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--lumen);margin-top:8px}
.fav-tip .ftype.note{color:var(--cyan)}

/* ---- note actions + share ---- */
.wp-note .wn-actions{display:flex;gap:8px;align-items:center;flex-shrink:0}
.wp-note .wn-share{border:none;background:none;color:var(--text-dim);cursor:pointer;display:inline-flex;align-items:center}
.wp-note .wn-share svg{width:16px;height:16px}
.wp-note .wn-share:hover{color:var(--cyan)}

/* ---- share popover ---- */
.share-pop{position:fixed;inset:0;z-index:600;display:flex;align-items:center;justify-content:center;background:rgba(2,2,7,0.6);backdrop-filter:blur(6px);opacity:0;pointer-events:none;transition:.3s}
.share-pop.show{opacity:1;pointer-events:auto}
.share-pop-card{background:rgba(11,11,22,0.96);border:1px solid var(--hairline);border-radius:24px;padding:34px;max-width:440px;width:90%;text-align:center;box-shadow:0 30px 80px rgba(0,0,0,0.6);transform:translateY(14px);transition:.3s var(--ease-out)}
.share-pop.show .share-pop-card{transform:translateY(0)}
.share-pop-q{font-family:'Cormorant Garamond',serif;font-size:1.35rem;color:var(--text-bright);line-height:1.4;margin-bottom:6px}
.share-pop-a{font-size:.68rem;letter-spacing:1px;text-transform:uppercase;color:var(--text-dim);margin-bottom:22px}
.share-pop-row{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-bottom:20px}
.share-pop-close{border:none;background:none;color:var(--text-dim);cursor:pointer;font-size:.72rem;letter-spacing:2px;text-transform:uppercase}
.share-pop-close:hover{color:var(--text-bright)}

/* ---- subscribe note ---- */
.sub-note{font-size:.72rem;letter-spacing:.4px;color:var(--text-dim);margin-top:14px}
.sub-btn[href]{text-decoration:none}

/* ====================================================
   AUDIT PASS — skip link, mobile nav, responsive, perf
   ==================================================== */

/* skip link (keyboard a11y) */
.skip{position:fixed;top:-60px;left:14px;z-index:300;background:var(--lumen);color:#08121a;padding:10px 18px;border-radius:0 0 12px 12px;font-size:.8rem;font-weight:600;letter-spacing:.5px;transition:top .25s var(--ease-out)}
.skip:focus{top:0}

/* mobile nav toggle */
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:10px;z-index:101}
.nav-toggle span{width:24px;height:2px;background:var(--text-bright);border-radius:2px;transition:.3s var(--ease-out)}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media(max-width:760px){
  .nav-toggle{display:flex}
  .nav{position:fixed;top:74px;left:0;right:0;z-index:99;flex-direction:column;gap:0;background:rgba(6,6,14,0.98);backdrop-filter:blur(12px);border-bottom:1px solid var(--hairline);padding:8px 5% 16px;transform:translateY(-130%);transition:transform .4s var(--ease-out);max-height:calc(100vh - 74px);overflow:auto}
  .nav.open{transform:translateY(0)}
  .nav a{padding:16px 2px;font-size:.95rem;letter-spacing:1px;border-bottom:1px solid var(--hairline-soft)}
  .nav a:last-child{border-bottom:none}
  .nav a::after{display:none}
  .nav a.active{color:var(--lumen)}
}

/* favorites rail collapses to a single pill on phones (prevents overflow/overlap) */
@media(max-width:760px){
  .fav-rail .fav-line{display:none}
  .fav-rail .fav-star{display:none}
  .fav-rail .fav-rail-inner{flex-direction:row;padding:10px 16px;background:rgba(8,8,18,0.7);border-color:var(--hairline)}
  .fav-rail.empty{display:none}
  .fav-head{font-size:.72rem}
}

/* wallpaper select must not overflow tiny screens */
.wp-field select{max-width:100%}
@media(max-width:600px){.wp-field,.wp-field select{width:100%}.wp-controls{gap:16px}}

/* mobile performance: blur is GPU-heavy — soften it on small screens */
@media(max-width:760px){
  .nebula{filter:blur(90px);opacity:.12}
  .nebula.c{display:none}
  .thought-card,.v-card,.r-card,.col-card,.res-card,.node,.review-card,.s-stat,.j-entry,.wp-note{backdrop-filter:none;background:rgba(13,13,26,0.72)}
  .thought-card{background:rgba(13,13,26,0.8)}
  .quote{font-size:1.7rem}
}
@media(max-width:380px){
  .wrap{padding-left:18px;padding-right:18px}
  .thought-card{padding:30px 22px}
  .quote{font-size:1.55rem}
  .sec-title{font-size:2rem}
}

/* respect reduced-data / low-end: pause heavy ambient drift if user prefers reduced motion already covered */

/* ---- thought page: make-it-yours practice block ---- */
.practice{background:rgba(255,201,135,0.05);border:1px solid var(--hairline);border-left:2px solid var(--lumen);border-radius:14px;padding:22px 26px}
.practice-q{font-family:'Cormorant Garamond',serif;font-size:1.32rem;line-height:1.5;color:var(--text-bright);margin-bottom:18px}
.practice-actions{display:flex;gap:12px;flex-wrap:wrap}
@media(max-width:760px){.practice{background:rgba(255,201,135,0.06)}}

/* ---- collection pages ---- */
.col-more{margin-top:48px;padding-top:30px;border-top:1px solid var(--hairline-soft);text-align:center}
.col-more-label{display:block;font-size:.7rem;letter-spacing:2px;text-transform:uppercase;color:var(--text-dim);margin-bottom:16px}
.chips{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.chip{padding:9px 18px;border:1px solid var(--hairline);border-radius:30px;font-size:.82rem;color:var(--text-mid);transition:.25s var(--ease-snap)}
.chip:hover{border-color:var(--cyan);color:var(--cyan)}
.col-group .ch h2 a{color:inherit}
.col-group .ch h2 a:hover{color:var(--lumen)}
