/*
Theme Name: Mocha Moizelle
Theme URI: https://mochamoizelle.com
Author: Mocha Moizelle
Description: Custom theme for Mocha Moizelle — spiritual reconnection for Black women. Tropical, afrocentric, editorial. Built to match the approved design exactly, with hero and photos editable in the Customizer.
Version: 1.0
License: GNU General Public License v2 or later
Text Domain: mochamoizelle
*/

:root{
    --plum:#2B1A42; --plum-deep:#1E1230; --marigold:#E8641C; --marigold-lift:#F5772E;
    --coral:#F0506C; --berry:#8E2A54; --mauve:#9E7E88; --cream:#F6EFE6; --tan:#E7D9CC;
    --ink:#2B1A42; --ink-soft:#4A3A44; --on-plum:#F6EFE6; --on-plum-soft:#D9C9D6;
    --display:'Bodoni Moda',serif; --body:'Jost',sans-serif; --script:'Pinyon Script',cursive;
    --maxw:1180px;
  }
  *{margin:0;padding:0;box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{font-family:var(--body);font-weight:400;color:var(--ink);background:var(--cream);line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden}
  a{color:inherit;text-decoration:none}
  img{max-width:100%;display:block}
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 7vw}
  .eyebrow{font-size:.78rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase}
  h1,h2,h3{font-family:var(--display);font-weight:600;line-height:1.12;letter-spacing:.01em}
  .script{font-family:var(--script);font-weight:400}
  .btn{font-family:var(--body);font-weight:500;font-size:.95rem;letter-spacing:.02em;display:inline-block;
    background:var(--marigold);color:var(--plum);padding:.95rem 2.1rem;border-radius:2px;border:none;cursor:pointer;
    transition:background .25s ease,transform .12s ease}
  .btn:hover{background:var(--marigold-lift)}
  .btn:active{transform:scale(.98)}
  .tlink{font-weight:500;color:var(--marigold);letter-spacing:.02em;border-bottom:1px solid transparent;transition:border-color .25s}
  .tlink:hover{border-color:var(--marigold)}

  /* batik-suggesting lattice for plum bands */
  .lattice{position:relative}
  .lattice::before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.9;
    background-image:
      repeating-linear-gradient(45deg, rgba(232,100,28,.05) 0 1px, transparent 1px 30px),
      repeating-linear-gradient(-45deg, rgba(240,80,108,.045) 0 1px, transparent 1px 30px);}

  /* ---- NAV ---- */
  header{position:fixed;top:0;left:0;right:0;z-index:50;transition:background .35s ease,padding .35s ease;padding:1.5rem 0}
  header.scrolled{background:rgba(30,18,48,.92);backdrop-filter:blur(8px);padding:.85rem 0;box-shadow:0 1px 0 rgba(246,239,230,.08)}
  .nav{display:flex;align-items:center;justify-content:space-between}
  .brand{font-family:var(--display);font-weight:700;font-size:1.35rem;letter-spacing:.04em;color:var(--cream)}
  .brand .mz{font-family:var(--script);font-weight:400;font-size:1.7rem;color:var(--coral);margin-left:.15em}
  .navlinks{display:flex;align-items:center;gap:2rem;list-style:none}
  .navlinks a{font-size:.9rem;font-weight:400;letter-spacing:.04em;color:var(--on-plum-soft);transition:color .2s}
  .navlinks a:hover{color:var(--cream)}
  .nav .btn{padding:.6rem 1.4rem;font-size:.85rem}
  .menu-btn{display:none;background:none;border:none;cursor:pointer;color:var(--cream);font-family:var(--body);font-size:1.6rem;line-height:1}

  /* ---- shared section ---- */
  section{position:relative;overflow:hidden}
  .band-plum{background:var(--plum);color:var(--on-plum)}
  .band-cream{background:var(--cream);color:var(--ink)}
  .band-coral{background:var(--coral);color:#3a0f20}
  .pad{padding:7rem 0}
  .split{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}

  /* reveal */
  .reveal{opacity:0;transform:translateY(26px);transition:opacity .9s ease,transform .9s ease}
  .reveal.in{opacity:1;transform:none}
  .d1{transition-delay:.12s}.d2{transition-delay:.24s}.d3{transition-delay:.36s}.d4{transition-delay:.48s}

  /* ---- HERO ---- */
  .hero{min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;
    background:var(--plum);color:var(--on-plum);padding:7rem 7vw 5rem}
  .hero-inner{position:relative;z-index:3;max-width:760px}
  .motif{margin:0 auto 1.6rem}
  .wordmark{line-height:.86}
  .wordmark .mc{font-family:var(--display);font-weight:700;font-size:clamp(3rem,9vw,5.5rem);letter-spacing:.06em;color:var(--cream)}
  .wordmark .mz{font-family:var(--script);font-weight:400;font-size:clamp(3.4rem,10vw,6rem);color:var(--coral);display:block;margin-top:-.18em}
  .hero h1{font-style:italic;font-weight:500;font-size:clamp(1.4rem,3.2vw,2rem);max-width:600px;margin:2rem auto 0;color:var(--cream)}
  .hero .sub{font-family:var(--body);font-weight:300;font-size:1.05rem;color:var(--on-plum-soft);max-width:520px;margin:1.2rem auto 0}
  .hero .micro{font-size:.85rem;color:var(--mauve);margin-top:1.1rem;letter-spacing:.02em}
  .hero .btn{margin-top:2rem}
  .flora{position:absolute;z-index:1;opacity:0;animation:fadein 1.6s ease forwards}
  .palm-bl{left:-2vw;bottom:-3vh;width:min(34vw,360px);animation-delay:.6s;transform-origin:bottom left;animation:fadein 1.6s ease .6s forwards, sway 9s ease-in-out 2.2s infinite}
  .bird-tr{right:-2vw;top:8vh;width:min(26vw,260px);animation-delay:.9s;transform-origin:top right;animation:fadein 1.6s ease .9s forwards, sway 11s ease-in-out 2.6s infinite}
  @keyframes fadein{to{opacity:1}}
  @keyframes sway{0%,100%{transform:rotate(-2deg)}50%{transform:rotate(2deg)}}
  .hero .load{opacity:0;animation:rise 1s ease forwards}
  .l1{animation-delay:.15s}.l2{animation-delay:.3s}.l3{animation-delay:.5s}.l4{animation-delay:.65s}.l5{animation-delay:.8s}.l6{animation-delay:.95s}
  @keyframes rise{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}

  /* ---- ESSENCE / STORY photos ---- */
  .photo{position:relative;background:var(--tan);border:1px solid #cdb6a3;border-radius:4px;min-height:440px;
    display:flex;align-items:center;justify-content:center;text-align:center;color:#6B5560}
  .photo .lbl{font-weight:500}.photo .sm{font-size:.85rem;color:#8E7A82;margin-top:.3rem;max-width:200px;margin-inline:auto}
  .badge{position:absolute;top:-22px;right:-22px}
  h2.section-h{font-size:clamp(1.9rem,4vw,2.9rem)}
  .lede{font-size:1.06rem;color:var(--ink-soft);margin:1.3rem 0 1.6rem;max-width:34rem}
  .band-plum .lede{color:var(--on-plum-soft)}
  .band-coral .lede{color:#5a1830}
  .script-accent{font-family:var(--script);font-size:2.2rem;color:var(--berry);line-height:1;margin:.4rem 0 0}
  .band-plum .eyebrow,.band-plum .script-accent{color:var(--coral)}
  .band-cream .eyebrow{color:var(--berry)}
  .band-coral .eyebrow{color:#3a0f20}

  /* ---- MISSION ---- */
  .mission{text-align:center;padding:8rem 0}
  .mission .wrap{max-width:780px}
  .watermark{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:0;opacity:.07;width:min(70vw,560px)}
  .mission .inner{position:relative;z-index:2}
  .mission h2{font-size:clamp(2.1rem,5vw,3.4rem);margin-bottom:1.4rem}

  /* ---- BOOK / APP feature ---- */
  .feature-img{position:relative;display:flex;align-items:center;justify-content:center;min-height:430px}
  .book-cover{width:280px;height:420px;background:linear-gradient(150deg,#3a2456,#2B1A42);border-radius:3px;
    box-shadow:0 30px 60px -25px rgba(0,0,0,.6),-12px 0 0 -6px rgba(246,239,230,.06);
    display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem;color:var(--cream)}
  .book-cover .bt{font-family:var(--display);font-weight:600;font-size:1.7rem;line-height:1.1}
  .book-cover .ba{font-family:var(--script);font-size:1.6rem;color:var(--coral);margin-top:1rem}
  .book-cover .tagph{font-size:.75rem;color:var(--mauve);margin-top:1.6rem;letter-spacing:.18em;text-transform:uppercase}
  .phone{width:230px;height:460px;background:var(--plum);border-radius:30px;border:8px solid #20132f;
    box-shadow:0 30px 60px -28px rgba(43,26,66,.5);display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--cream);padding:2rem;text-align:center}
  .phone .pt{font-family:var(--display);font-weight:600;font-size:1.3rem}
  .phone .ps{font-family:var(--script);font-size:1.4rem;color:var(--coral);margin-top:.6rem}
  .phone .pn{font-size:.78rem;color:var(--mauve);margin-top:1.4rem}

  /* ---- JOIN ---- */
  .join{text-align:center;padding:8rem 0}
  .join .wrap{max-width:640px}
  .join h2{font-size:clamp(2.1rem,5vw,3.2rem)}
  .form{display:flex;gap:.6rem;max-width:440px;margin:2rem auto 0}
  .form input{flex:1;font-family:var(--body);font-size:1rem;padding:.95rem 1.1rem;border:1px solid rgba(246,239,230,.3);
    background:rgba(246,239,230,.05);color:var(--cream);border-radius:2px}
  .form input::placeholder{color:var(--mauve)}
  .form input:focus{outline:none;border-color:var(--marigold)}
  .join .micro{font-size:.85rem;color:var(--mauve);margin-top:1.1rem}

  /* ---- FEATURED ROW ---- */
  .featured-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:1.6rem 2.4rem;margin-top:1.8rem}
  .featured-row .logo-slot{flex:0 0 auto;width:150px;height:64px;display:flex;align-items:center;justify-content:center;
    border:1px dashed rgba(246,239,230,.3);border-radius:6px;color:var(--mauve);font-size:.85rem;letter-spacing:.04em}
  .featured-row img{width:150px;height:64px;object-fit:contain;opacity:.85;
    filter:brightness(0) invert(1);transition:opacity .25s}
  .featured-row img:hover{opacity:1}
  @media(max-width:680px){.featured-row .logo-slot,.featured-row img{width:120px;height:52px}}

  /* ---- BLOG ---- */
  .blog-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.6rem;margin-top:2.6rem;text-align:left}
  .post{background:#fff;border:1px solid #e7d9cc;border-radius:8px;overflow:hidden;transition:transform .25s,box-shadow .25s}
  .post:hover{transform:translateY(-4px);box-shadow:0 18px 40px -24px rgba(43,26,66,.4)}
  .post .pthumb{aspect-ratio:16/10;background:linear-gradient(150deg,#3a2456,#8E2A54)}
  .post .pbody{padding:1.2rem 1.3rem 1.4rem}
  .post .ptag{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--berry);font-weight:500}
  .post .pt{font-family:var(--display);font-weight:600;font-size:1.2rem;color:var(--plum);margin:.5rem 0 .4rem;line-height:1.2}
  .post .pex{font-size:.92rem;color:var(--ink-soft)}

  /* ---- FOOTER ---- */
  footer{background:var(--plum-deep);color:var(--on-plum-soft);padding:4.5rem 0 2.2rem}
  .foot-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:2.4rem;padding-bottom:3rem;border-bottom:1px solid rgba(246,239,230,.1)}
  .foot-brand .brand{font-size:1.6rem}
  .foot-brand p{font-size:.92rem;color:var(--mauve);margin-top:1rem;max-width:22rem}
  .foot-col h4{font-family:var(--body);font-weight:500;font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--coral);margin-bottom:1.1rem}
  .foot-col a{display:block;font-size:.92rem;color:var(--on-plum-soft);margin-bottom:.7rem;transition:color .2s}
  .foot-col a:hover{color:var(--cream)}
  .foot-bottom{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;padding-top:2rem;font-size:.82rem;color:var(--mauve)}

  /* ---- RESPONSIVE ---- */
  @media (max-width:880px){
    .split{grid-template-columns:1fr;gap:3rem}
    .photo{min-height:340px}
    .pad{padding:5rem 0}
    .navlinks{position:absolute;top:100%;left:0;right:0;background:rgba(30,18,48,.98);flex-direction:column;
      align-items:flex-start;gap:0;padding:1rem 7vw 1.5rem;display:none}
    .navlinks.open{display:flex}
    .navlinks a{padding:.7rem 0;width:100%}
    .nav .btn{display:none}
    .menu-btn{display:block}
    .foot-top{grid-template-columns:1fr;gap:2.2rem}
    .feature-img{min-height:340px}
  }
  @media (prefers-reduced-motion:reduce){
    .reveal,.hero .load,.flora{opacity:1!important;transform:none!important;animation:none!important}
    html{scroll-behavior:auto}
  }


/* ===== Page-specific component styles (about, mission, experiences, watch, blog, legal, thank-you) ===== */
h1,h2,h3{font-family:var(--display);font-weight:600;line-height:1.13;letter-spacing:.01em}
.btn{font-family:var(--body);font-weight:500;font-size:.95rem;letter-spacing:.02em;display:inline-block;
    background:var(--marigold);color:var(--plum);padding:.95rem 2.1rem;border-radius:2px;border:none;cursor:pointer;transition:background .25s,transform .12s}
.lattice::before{content:"";position:absolute;inset:0;pointer-events:none;
    background-image:repeating-linear-gradient(45deg,rgba(232,100,28,.05) 0 1px,transparent 1px 30px),repeating-linear-gradient(-45deg,rgba(240,80,108,.045) 0 1px,transparent 1px 30px)}
header{position:fixed;top:0;left:0;right:0;z-index:50;transition:background .35s,padding .35s;padding:1.5rem 0}
.navlinks a{font-size:.9rem;letter-spacing:.04em;color:var(--on-plum-soft);transition:color .2s}
.navlinks a:hover,.navlinks a.active{color:var(--cream)}
.menu-btn{display:none;background:none;border:none;cursor:pointer;color:var(--cream);font-size:1.6rem;line-height:1}
.pad{padding:6.5rem 0}
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s,transform .9s}
.page-hero{background:var(--plum);color:var(--on-plum);padding:12rem 0 6rem;text-align:center}
.page-hero h1{font-size:clamp(2.2rem,5.6vw,3.7rem);max-width:16ch;margin:1rem auto 0;font-style:italic;font-weight:500;color:var(--cream)}
.page-hero .sub{font-family:var(--body);font-weight:300;color:var(--on-plum-soft);max-width:42ch;margin:1.4rem auto 0}
.page-hero .eyebrow{color:var(--coral)}
.story-h{font-size:clamp(1.6rem,3.6vw,2.4rem);margin-bottom:1.2rem}
.prose p{font-size:1.06rem;margin-bottom:1.15rem;max-width:38rem}
.band-cream .prose p{color:var(--ink-soft)}
.band-plum .prose p{color:var(--on-plum-soft)}
.band-plum .eyebrow{color:var(--coral)}
.photo{position:relative;background:var(--tan);border:1px solid #cdb6a3;border-radius:4px;min-height:420px;display:flex;align-items:center;justify-content:center;text-align:center;color:#6B5560}
.photo .sm{font-size:.85rem;color:#8E7A82;margin-top:.3rem}
.pull{text-align:center;padding:6rem 0}
.pull .q{font-family:var(--display);font-style:italic;font-size:clamp(1.7rem,4.2vw,2.6rem);max-width:22ch;margin:0 auto;line-height:1.2;color:var(--cream)}
.pull .sig{font-family:var(--script);font-size:2rem;color:var(--coral);margin-top:1.4rem}
.cta{text-align:center;padding:7rem 0}
.cta h2{font-size:clamp(1.9rem,4.5vw,2.8rem);margin-bottom:1.6rem;color:var(--cream)}
@media (max-width:880px){
    .split{grid-template-columns:1fr;gap:3rem}.photo{min-height:320px}.pad{padding:4.5rem 0}
    .page-hero{padding:9rem 0 4.5rem}
    .navlinks{position:absolute;top:100%;left:0;right:0;background:rgba(30,18,48,.98);flex-direction:column;align-items:flex-start;gap:0;padding:1rem 7vw 1.5rem;display:none}
    .navlinks.open{display:flex}.navlinks a{padding:.7rem 0;width:100%}
    .nav .btn{display:none}.menu-btn{display:block}
    .foot-top{grid-template-columns:1fr 1fr;gap:2.2rem}
  }
@media (max-width:520px){.foot-top{grid-template-columns:1fr}}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1!important;transform:none!important}html{scroll-behavior:auto}}
.btn.ghost{background:transparent;color:var(--cream);border:1px solid rgba(246,239,230,.4)}
.btn.ghost:hover{background:rgba(246,239,230,.08)}
.tlink{font-weight:500;color:var(--marigold);border-bottom:1px solid transparent;transition:border-color .25s}
.d1{transition-delay:.1s}
.d2{transition-delay:.2s}
.d3{transition-delay:.3s}
.page-hero h1{font-size:clamp(2.2rem,5.8vw,3.9rem);max-width:15ch;margin:1rem auto 0;color:var(--cream)}
.page-hero .sub{font-family:var(--body);font-weight:300;color:var(--on-plum-soft);max-width:44ch;margin:1.4rem auto 0}
.intro{max-width:42rem;margin:0 auto}
.intro .eyebrow{color:var(--berry)}
.intro p{font-size:1.12rem;color:var(--ink-soft);margin-top:1.3rem}
.intro .lead{font-family:var(--display);font-style:italic;font-size:1.4rem;color:var(--ink);line-height:1.4}
.tenets{max-width:46rem;margin:0 auto}
.tenets .eyebrow{color:var(--coral);text-align:center;display:block;margin-bottom:.6rem}
.tenets-h{text-align:center;font-size:clamp(1.8rem,4vw,2.6rem);margin-bottom:2.5rem;color:var(--cream)}
.pillar{display:grid;grid-template-columns:auto 1fr;gap:1.8rem;padding:2.1rem 0;border-top:1px solid rgba(246,239,230,.14);align-items:start}
.pillar .num{font-family:var(--display);font-weight:600;font-size:2.3rem;color:var(--marigold);line-height:.9}
.pillar h3{font-size:1.45rem;margin-bottom:.5rem;color:var(--cream)}
.pillar p{font-size:1.04rem;color:var(--on-plum-soft)}
.forwhom{max-width:40rem;margin:0 auto;text-align:center}
.forwhom .eyebrow{color:var(--berry)}
.forwhom h2{font-size:clamp(1.7rem,3.8vw,2.4rem);margin:.8rem 0 1.2rem}
.forwhom p{font-size:1.08rem;color:var(--ink-soft)}
.pull .q{font-family:var(--display);font-style:italic;font-size:clamp(1.7rem,4.2vw,2.5rem);max-width:20ch;margin:0 auto;line-height:1.2;color:var(--cream)}
.cta h2{font-size:clamp(1.9rem,4.5vw,2.8rem);margin-bottom:1rem;color:var(--cream)}
.cta p{color:var(--on-plum-soft);max-width:36rem;margin:0 auto 1.8rem}
.cta .btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
@media (max-width:880px){
    .pad{padding:4.5rem 0}.page-hero{padding:9rem 0 4.5rem}
    .navlinks{position:absolute;top:100%;left:0;right:0;background:rgba(30,18,48,.98);flex-direction:column;align-items:flex-start;gap:0;padding:1rem 7vw 1.5rem;display:none}
    .navlinks.open{display:flex}.navlinks a{padding:.7rem 0;width:100%}
    .nav .btn{display:none}.menu-btn{display:block}
    .foot-top{grid-template-columns:1fr 1fr;gap:2.2rem}
  }
@media (max-width:520px){.foot-top{grid-template-columns:1fr}.pillar{grid-template-columns:1fr;gap:.4rem}}
.pad{padding:6rem 0}
.page-hero{background:var(--plum);color:var(--on-plum);padding:12rem 0 5rem;text-align:center}
.page-hero h1{font-size:clamp(2.2rem,5.6vw,3.7rem);margin:1rem auto 0;color:var(--cream)}
.page-hero .sub{font-family:var(--body);font-weight:300;color:var(--on-plum-soft);max-width:44ch;margin:1.3rem auto 0}
.duo{display:grid;grid-template-columns:1fr 1fr;gap:2rem;max-width:64rem;margin:0 auto}
.offer{border-radius:12px;padding:2.6rem 2.2rem;display:flex;flex-direction:column}
.offer.now{background:#fff;border:1px solid #e7d9cc}
.offer.soon{background:var(--plum);color:var(--on-plum);position:relative;overflow:hidden}
.offer .tag{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;font-weight:500;margin-bottom:.9rem}
.offer.now .tag{color:var(--berry)}
.offer.soon .tag{color:var(--coral)}
.offer h2{font-size:1.7rem;margin-bottom:.3rem}
.offer.now h2{color:var(--plum)}
.offer.soon h2{color:var(--cream)}
.offer .price{font-family:var(--script);font-size:1.7rem;margin-bottom:1rem}
.offer.now .price{color:var(--berry)}
.offer.soon .price{color:var(--coral)}
.offer p{font-size:1rem;margin-bottom:1.1rem}
.offer.now p{color:var(--ink-soft)}
.offer.soon p{color:var(--on-plum-soft)}
.offer ul{list-style:none;margin:0 0 1.6rem;padding:0}
.offer li{position:relative;padding-left:1.5rem;margin-bottom:.6rem;font-size:.96rem}
.offer.now li{color:var(--ink-soft)}
.offer.soon li{color:var(--on-plum-soft)}
.offer li::before{content:"";position:absolute;left:0;top:.6em;width:8px;height:8px;border-radius:50%;background:var(--marigold)}
.offer .foot-cta{margin-top:auto}
@media(max-width:780px){.duo{grid-template-columns:1fr}}
.how{max-width:46rem;margin:0 auto;text-align:center}
.how .eyebrow{color:var(--coral)}
.how h2{font-size:clamp(1.7rem,3.8vw,2.4rem);margin:.7rem 0 2.4rem;color:var(--cream)}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1.8rem;text-align:left}
.step .n{font-family:var(--display);font-weight:600;font-size:2rem;color:var(--marigold)}
.step h3{font-size:1.15rem;color:var(--cream);margin:.3rem 0 .4rem}
.step p{font-size:.94rem;color:var(--on-plum-soft)}
@media(max-width:680px){.steps{grid-template-columns:1fr;gap:1.4rem}}
.join{text-align:center;padding:7rem 0}
.join .wrap{max-width:620px}
.join h2{font-size:clamp(1.9rem,4.5vw,2.8rem);color:var(--cream)}
@media (max-width:880px){
    .pad{padding:4.5rem 0}.page-hero{padding:9rem 0 4rem}
    .navlinks{position:absolute;top:100%;left:0;right:0;background:rgba(30,18,48,.98);flex-direction:column;align-items:flex-start;gap:0;padding:1rem 7vw 1.5rem;display:none}
    .navlinks.open{display:flex}.navlinks a{padding:.7rem 0;width:100%}
    .nav .btn{display:none}.menu-btn{display:block}
    .foot-top{grid-template-columns:1fr 1fr;gap:2.2rem}
  }
.page-hero h1{font-size:clamp(2.2rem,5.6vw,3.6rem);margin:1rem auto 0;color:var(--cream)}
.page-hero .sub{font-family:var(--body);font-weight:300;color:var(--on-plum-soft);max-width:42ch;margin:1.3rem auto 0}
.slot{border:2px dashed var(--mauve);border-radius:10px;padding:3.2rem 2rem;text-align:center;background:#fffaf2}
.slot .eyebrow{color:var(--marigold)}
.slot h2{font-size:clamp(1.8rem,4vw,2.6rem);margin:.6rem 0 .4rem}
.slot p{color:var(--ink-soft);max-width:34rem;margin:0 auto 1.6rem}
.slot .ghostplay{width:74px;height:74px;border-radius:50%;border:2px solid var(--marigold);display:flex;align-items:center;justify-content:center;margin:0 auto 1.4rem}
.archive-intro{max-width:40rem}
.archive-intro .eyebrow{color:var(--coral)}
.archive-intro h2{font-size:clamp(1.7rem,3.8vw,2.4rem);margin:.7rem 0 1rem;color:var(--cream)}
.archive-intro p{color:var(--on-plum-soft);font-size:1.05rem}
.vgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.6rem;margin-top:2.6rem}
.vcard{background:rgba(246,239,230,.05);border:1px solid rgba(246,239,230,.12);border-radius:8px;overflow:hidden;transition:transform .25s,border-color .25s}
.vcard:hover{transform:translateY(-4px);border-color:rgba(232,100,28,.5)}
.vthumb{aspect-ratio:16/9;background:#3a2456;display:flex;align-items:center;justify-content:center;position:relative}
.vthumb .play{width:54px;height:54px;border-radius:50%;background:rgba(43,26,66,.55);display:flex;align-items:center;justify-content:center}
.vmeta{padding:.95rem 1.1rem}
.vmeta .t{font-family:var(--display);font-weight:600;font-size:1.05rem;color:var(--cream)}
.vmeta .s{font-size:.82rem;color:var(--mauve);margin-top:.2rem}
.cta{text-align:center;padding:6.5rem 0}
.cta h2{font-size:clamp(1.8rem,4.2vw,2.6rem);margin-bottom:1.4rem;color:var(--cream)}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1!important;transform:none!important}html{scroll-behavior:auto}.vcard:hover{transform:none}}
h1,h2,h3{font-family:var(--display);font-weight:600;line-height:1.15;letter-spacing:.01em}
.pad{padding:5.5rem 0}
.cats{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;margin-bottom:3rem}
.cats a{font-size:.85rem;padding:.4rem 1rem;border:1px solid #d9c6b6;border-radius:50px;color:var(--ink-soft);transition:.2s}
.cats a:hover,.cats a.on{background:var(--plum);color:var(--cream);border-color:var(--plum)}
.feature-post{display:grid;grid-template-columns:1.1fr 1fr;gap:0;border-radius:12px;overflow:hidden;border:1px solid #e7d9cc;background:#fff;margin-bottom:3rem}
.feature-post .img{background:linear-gradient(150deg,#3a2456,#8E2A54);min-height:300px}
.feature-post .body{padding:2.6rem 2.4rem;display:flex;flex-direction:column;justify-content:center}
.feature-post .ptag{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--berry);font-weight:500}
.feature-post h2{font-size:1.9rem;color:var(--plum);margin:.6rem 0 .7rem;line-height:1.15}
.feature-post p{color:var(--ink-soft);margin-bottom:1.2rem}
@media(max-width:780px){.feature-post{grid-template-columns:1fr}.feature-post .img{min-height:200px}}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.8rem}
.post{background:#fff;border:1px solid #e7d9cc;border-radius:10px;overflow:hidden;transition:transform .25s,box-shadow .25s}
.post .pbody{padding:1.3rem 1.4rem 1.6rem}
.post h3{font-family:var(--display);font-weight:600;font-size:1.3rem;color:var(--plum);margin:.5rem 0 .5rem;line-height:1.2}
.post p{font-size:.93rem;color:var(--ink-soft);margin-bottom:.8rem}
.post .date{font-size:.8rem;color:var(--mauve)}
.empty{text-align:center;color:var(--mauve);font-style:italic;font-family:var(--display);margin-top:2rem}
.join{text-align:center;padding:6.5rem 0}
.join .wrap{max-width:600px}
.join h2{font-size:clamp(1.9rem,4.5vw,2.6rem);color:var(--cream)}
.page-hero{background:var(--plum);color:var(--on-plum);padding:11rem 0 4rem;text-align:center;position:relative;overflow:hidden}
.page-hero h1{font-size:clamp(2rem,5vw,3.2rem);margin:.8rem auto 0;color:var(--cream)}
.page-hero .upd{font-size:.85rem;color:var(--mauve);margin-top:1rem}
.legal{padding:5rem 0 6rem}
.legal .wrap{max-width:50rem}
.notice{background:#fff3e6;border:1px solid #f3c79a;border-radius:8px;padding:1.1rem 1.3rem;font-size:.92rem;color:#7a4a17;margin-bottom:2.6rem}
.legal h2{font-size:1.4rem;color:var(--plum);margin:2.4rem 0 .8rem}
.legal h2:first-of-type{margin-top:0}
.legal p{color:var(--ink-soft);margin-bottom:1rem}
.legal ul{margin:0 0 1rem 1.2rem;color:var(--ink-soft)}
.legal li{margin-bottom:.5rem}
.legal .toc{background:rgba(142,42,84,.05);border-radius:8px;padding:1.4rem 1.6rem;margin-bottom:2.6rem}
.legal .toc h3{font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;color:var(--berry);margin-bottom:.8rem;font-family:var(--body);font-weight:500}
.legal .toc a{display:block;color:var(--ink-soft);margin-bottom:.45rem;font-size:.95rem}
.legal .toc a:hover{color:var(--marigold)}
@media (max-width:880px){
    .page-hero{padding:9rem 0 3.5rem}
    .navlinks{position:absolute;top:100%;left:0;right:0;background:rgba(30,18,48,.98);flex-direction:column;align-items:flex-start;gap:0;padding:1rem 7vw 1.5rem;display:none}
    .navlinks.open{display:flex}.navlinks a{padding:.7rem 0;width:100%}
    .nav .btn{display:none}.menu-btn{display:block}
    .foot-top{grid-template-columns:1fr 1fr;gap:2.2rem}
  }
table{width:100%;border-collapse:collapse;margin:1rem 0 1.5rem;font-size:.95rem}
th,td{text-align:left;padding:.7rem .8rem;border:1px solid #e3d4c4;color:var(--ink-soft)}
th{background:rgba(142,42,84,.06);font-family:var(--body);font-weight:500;color:var(--berry)}
@media (max-width:520px){.foot-top{grid-template-columns:1fr}table,thead,tbody,th,td,tr{display:block}th{display:none}td{border:none;border-bottom:1px solid #e3d4c4;padding-left:0}}
.crisis{background:rgba(142,42,84,.06);border-left:3px solid var(--berry);border-radius:0 8px 8px 0;padding:1.2rem 1.4rem;margin:1.4rem 0}
.crisis p{margin:0;color:var(--plum)}
.ty{min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;background:var(--plum);color:var(--on-plum);padding:9rem 7vw 5rem;position:relative;overflow:hidden}
.ty-inner{position:relative;z-index:3;max-width:680px}
.seal{margin:0 auto 1.8rem;opacity:0;animation:pop .8s cubic-bezier(.2,.8,.3,1) .1s forwards}
.ty .eyebrow{color:var(--coral);opacity:0;animation:rise .9s ease .35s forwards}
.ty h1{font-family:var(--display);font-style:italic;font-weight:500;font-size:clamp(2rem,5.5vw,3.4rem);color:var(--cream);margin:1rem 0 0;opacity:0;animation:rise .9s ease .5s forwards}
.ty .lead{font-size:1.1rem;color:var(--on-plum-soft);max-width:30rem;margin:1.4rem auto 0;opacity:0;animation:rise .9s ease .68s forwards}
.ty .script{font-family:var(--script);font-size:2rem;color:var(--coral);margin-top:1.4rem;opacity:0;animation:rise .9s ease .85s forwards}
@keyframes rise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
@keyframes pop{from{opacity:0;transform:scale(.7)}to{opacity:1;transform:scale(1)}}
.palm-bl{left:-2vw;bottom:-3vh;width:min(30vw,320px);transform-origin:bottom left;animation:fadein 1.6s ease .6s forwards,sway 9s ease-in-out 2.2s infinite}
.bird-tr{right:-2vw;top:10vh;width:min(22vw,230px);transform-origin:top right;animation:fadein 1.6s ease .9s forwards,sway 11s ease-in-out 2.6s infinite}
.next{padding:6rem 0}
.next .wrap{max-width:780px}
.next .eyebrow{color:var(--berry);text-align:center;display:block}
.next h2{text-align:center;font-size:clamp(1.8rem,4vw,2.5rem);color:var(--plum);margin:.7rem 0 2.6rem}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1.8rem}
.step{background:#fff;border:1px solid #e7d9cc;border-radius:10px;padding:1.8rem 1.5rem;text-align:left}
.step .n{font-family:var(--display);font-weight:600;font-size:1.9rem;color:var(--marigold);line-height:1}
.step h3{font-size:1.12rem;color:var(--plum);margin:.5rem 0 .4rem}
.step p{font-size:.93rem;color:var(--ink-soft)}
@media(max-width:680px){.steps{grid-template-columns:1fr;gap:1.2rem}}
.note{max-width:620px;margin:2.8rem auto 0;background:rgba(142,42,84,.05);border-left:3px solid var(--berry);border-radius:0 8px 8px 0;padding:1.2rem 1.4rem}
.note p{margin:0;color:var(--ink-soft);font-size:.96rem}
.deepen{padding:5.5rem 0;text-align:center}
.deepen .eyebrow{color:var(--coral)}
.deepen h2{font-size:clamp(1.7rem,3.8vw,2.3rem);color:var(--cream);margin:.7rem 0 1rem}
.deepen p{color:var(--on-plum-soft);max-width:34rem;margin:0 auto 1.8rem}
.deepen .btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
@media (max-width:880px){
    .next,.deepen{padding:4.5rem 0}
    .navlinks{position:absolute;top:100%;left:0;right:0;background:rgba(30,18,48,.98);flex-direction:column;align-items:flex-start;gap:0;padding:1rem 7vw 1.5rem;display:none}
    .navlinks.open{display:flex}.navlinks a{padding:.7rem 0;width:100%}
    .nav .btn{display:none}.menu-btn{display:block}
    .foot-top{grid-template-columns:1fr 1fr;gap:2.2rem}
  }
@media (prefers-reduced-motion:reduce){.seal,.ty .eyebrow,.ty h1,.ty .lead,.ty .script,.flora{opacity:1!important;transform:none!important;animation:none!important}}
