/* ===========================================================================
   Holistic Return — website styles (consumes ../styles.css design tokens)
   Antique desert aesthetic. Responsive for desktop + mobile.
   =========================================================================== */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--surface-page);color:var(--text-body);
     font-family:var(--font-body);font-size:18px;line-height:1.7;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}

/* layout ------------------------------------------------------------------ */
.wrap{max-width:72rem;margin:0 auto;padding:0 40px}
.narrow{max-width:46rem;margin-left:auto;margin-right:auto}
section{position:relative}

/* type -------------------------------------------------------------------- */
.eyebrow{display:inline-flex;align-items:center;gap:14px;font-family:var(--font-label);
     font-size:13px;letter-spacing:.3em;text-transform:uppercase;color:var(--clay-600)}
.eyebrow::before{content:"";width:34px;height:1px;background:var(--clay-400);opacity:.8}
.eyebrow.center::after{content:"";width:34px;height:1px;background:var(--clay-400);opacity:.8}
.eyebrow.light{color:var(--ochre-400)}
.eyebrow.light::before,.eyebrow.light.center::after{background:var(--ochre-400)}

h1,h2,h3{font-family:var(--font-display);font-weight:500;letter-spacing:-.01em;color:var(--umber-700);margin:0}
.h-display{font-size:clamp(3rem,7vw,5.6rem);line-height:1.0}
.h1{font-size:clamp(2.4rem,5vw,4rem);line-height:1.04}
.h2{font-size:clamp(2rem,3.6vw,3rem);line-height:1.08}
.h3{font-size:1.6rem;line-height:1.2;font-weight:600}
em.accent{font-style:italic;color:var(--clay-500)}
.lede{font-size:clamp(1.15rem,1.6vw,1.4rem);line-height:1.6;color:var(--text-muted);text-wrap:pretty}
.muted{color:var(--text-muted)}

/* buttons ----------------------------------------------------------------- */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-label);font-size:14px;
     letter-spacing:.16em;text-transform:uppercase;padding:15px 30px;border-radius:var(--radius-pill);white-space:nowrap;
     background:var(--clay-500);color:var(--sand-50);border:1.5px solid var(--clay-500);
     transition:background var(--dur-base) var(--ease-out),transform var(--dur-fast) var(--ease-out);cursor:pointer}
.btn:hover{background:var(--clay-600);border-color:var(--clay-600)}
.btn:active{transform:translateY(1px)}
.btn.ghost{background:transparent;color:var(--clay-600);border-color:var(--border-strong)}
.btn.ghost:hover{background:rgba(181,102,60,.08);color:var(--clay-700)}
.btn.light{background:var(--sand-50);color:var(--umber-700);border-color:var(--sand-50)}
.btn.light:hover{background:var(--sand-100);border-color:var(--sand-100)}
.btn.lightghost{background:transparent;color:var(--sand-100);border-color:rgba(245,236,219,.45)}
.btn.lightghost:hover{background:rgba(245,236,219,.10)}
.textlink{font-family:var(--font-label);font-size:13px;letter-spacing:.18em;text-transform:uppercase;
     color:var(--clay-600);display:inline-flex;align-items:center;gap:8px;transition:gap var(--dur-base) var(--ease-out)}
.textlink:hover{gap:14px;color:var(--clay-700)}

/* antique photo + placeholder -------------------------------------------- */
.photo{position:relative;overflow:hidden;background:var(--umber-600)}
.photo img{width:100%;height:100%;object-fit:cover;filter:sepia(.32) saturate(1.05) contrast(.92) brightness(1.03)}
.photo::after{content:"";position:absolute;inset:0;background-image:var(--grain-url);background-size:240px;
     opacity:.42;mix-blend-mode:overlay;pointer-events:none}
.photo .wash{position:absolute;inset:0;mix-blend-mode:multiply;
     background:radial-gradient(120% 100% at 30% 70%, rgba(214,150,70,.22), transparent 62%), linear-gradient(180deg, rgba(245,236,219,.04), rgba(58,42,28,.34))}

.ph{position:relative;display:flex;align-items:center;justify-content:center;text-align:center;padding:24px;
     background:repeating-linear-gradient(135deg, var(--sand-200) 0 13px, var(--sand-300) 13px 26px);
     border:1px solid var(--border-soft);color:var(--text-faint);
     font-family:var(--font-typewriter);font-size:12.5px;letter-spacing:.03em;line-height:1.5}
.ph span{background:var(--surface-raised-solid);padding:7px 14px;border:1px solid var(--border-soft);border-radius:3px}
.mounted{padding:14px;background:var(--surface-raised-solid);box-shadow:var(--shadow-photo);border:1px solid var(--border-soft)}
.arch{border-radius:50% 50% var(--radius-lg) var(--radius-lg) / 30% 30% 0 0;overflow:hidden}

/* nav --------------------------------------------------------------------- */
.nav{position:sticky;top:0;z-index:40;background:rgba(245,236,219,.86);backdrop-filter:blur(10px);
     border-bottom:1.5px solid var(--border-soft)}
.nav .row{max-width:72rem;margin:0 auto;padding:16px 40px;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:12px}
.brand img{height:34px}
.brand .bnm{font-family:var(--font-display);font-weight:600;font-size:24px;line-height:1;color:var(--umber-700)}
.brand .bnm em{font-style:italic;color:var(--clay-500)}
.links{display:flex;align-items:center;gap:30px}
.links a{font-family:var(--font-label);font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--umber-500);
     padding:6px 0;position:relative;transition:color var(--dur-base) var(--ease-out)}
.links a:hover{color:var(--clay-600)}
.links a.active{color:var(--clay-600)}
.links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:1.5px;background:var(--clay-500)}

/* hero -------------------------------------------------------------------- */
.hero{position:relative;min-height:clamp(560px,90vh,920px);display:flex;align-items:center;background:var(--umber-700);overflow:hidden}
.hero .photo{position:absolute;inset:0}
.hero .photo img{opacity:.62}
.hero .veil{position:absolute;inset:0;background:radial-gradient(120% 110% at 28% 30%, rgba(214,150,70,.20), transparent 58%), linear-gradient(180deg, rgba(42,29,19,.42), rgba(42,29,19,.30) 45%, rgba(42,29,19,.74))}
.hero .inner{position:relative;z-index:2;width:100%;text-align:center;color:var(--sand-50);padding:120px 0}
.hero .lock{display:inline-flex;flex-direction:column;align-items:center;gap:8px;margin-bottom:8px}
.hero .lock img{width:54px;height:54px}
.hero .lock .s{font-family:var(--font-label);font-size:17px;letter-spacing:.46em;text-transform:uppercase;color:var(--ochre-400);padding-left:.46em}
.hero .lock .b{font-family:var(--font-display);font-weight:600;font-size:clamp(3.4rem,9vw,7rem);line-height:.94;color:var(--sand-50)}
.hero .htag{font-family:var(--font-display);font-style:italic;font-size:clamp(1.5rem,2.6vw,2.2rem);color:var(--ochre-300);margin:18px 0 0}
.hero .hsub{max-width:40rem;margin:22px auto 0;color:var(--sand-200);font-size:clamp(1.05rem,1.5vw,1.25rem)}
.hero .hbtns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:38px}

/* page header (interior pages) ------------------------------------------- */
.phead{padding:96px 0 0;text-align:center}
.phead .h1{margin-top:18px}
.phead .lede{margin:20px auto 0}

/* generic section padding */
.pad{padding:104px 0}
.pad-sm{padding:72px 0}

/* split (text + image) ---------------------------------------------------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.split.rev .col-img{order:2}
.col-img .ph,.col-img .photo{aspect-ratio:4/5;width:100%;height:auto}
.signoff{font-family:var(--font-display);font-style:italic;font-size:1.5rem;color:var(--umber-500);margin-top:24px}

/* cards ------------------------------------------------------------------- */
.cards{display:grid;gap:28px}
.cards.c3{grid-template-columns:repeat(3,1fr)}
.cards.c2{grid-template-columns:repeat(2,1fr)}
.card{background:var(--surface-raised);border:1.5px solid var(--border-soft);border-radius:var(--radius-lg);
     overflow:hidden;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;
     transition:transform var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out)}
a.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.card .media{aspect-ratio:3/2;width:100%}
.card .body{padding:28px 28px 30px;display:flex;flex-direction:column;gap:10px;flex:1}
.card .cat{font-family:var(--font-label);font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--clay-600)}
.card .ct{font-family:var(--font-display);font-weight:600;font-size:1.6rem;line-height:1.12;color:var(--umber-700)}
.card .ex{font-size:15.5px;line-height:1.55;color:var(--text-muted);margin:0}
.card .meta{font-family:var(--font-typewriter);font-size:12px;color:var(--text-faint);margin-top:auto}

/* featured post ----------------------------------------------------------- */
.feature{display:grid;grid-template-columns:1.15fr 1fr;gap:48px;align-items:center;
     background:var(--surface-raised);border:1.5px solid var(--border-soft);border-radius:var(--radius-xl);
     overflow:hidden;box-shadow:var(--shadow-sm)}
.feature .media{aspect-ratio:4/3;height:100%}
.feature .body{padding:48px 52px 48px 8px}
.feature .ct{font-family:var(--font-display);font-weight:500;font-size:clamp(2rem,3vw,2.8rem);line-height:1.06;margin:14px 0 0;color:var(--umber-700)}

/* quote band -------------------------------------------------------------- */
.qband{position:relative;background:var(--umber-700);color:var(--sand-50);overflow:hidden;text-align:center}
.qband .photo{position:absolute;inset:0}
.qband .photo img{opacity:.26}
.qband .veil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(42,29,19,.6),rgba(42,29,19,.72))}
.qband .inner{position:relative;z-index:2;padding:120px 0}
.qband blockquote{margin:0 auto;max-width:44rem;font-family:var(--font-display);font-style:italic;font-weight:500;
     font-size:clamp(1.9rem,3.4vw,3rem);line-height:1.25;color:var(--sand-50);text-wrap:balance}
.qband .qby{font-family:var(--font-label);font-size:13px;letter-spacing:.24em;text-transform:uppercase;color:var(--ochre-400);margin-top:30px}

/* values ------------------------------------------------------------------ */
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:40px}
.value .vn{font-family:var(--font-display);font-style:italic;font-size:2.4rem;color:var(--clay-400);line-height:1}
.value h3{margin:14px 0 8px}
.value p{margin:0;font-size:16px;line-height:1.6;color:var(--text-muted)}
.rule-top{border-top:1.5px solid var(--border-soft);padding-top:22px}

/* sun divider ------------------------------------------------------------- */
.sun{display:inline-flex;align-items:center;gap:16px}
.sun .r{width:60px;height:1px;background:var(--border-strong);opacity:.7}
.sun .dot{width:9px;height:9px;border-radius:50%;background:var(--ochre-500)}
.sun.light .r{background:var(--sand-400);opacity:.6}

/* footer ------------------------------------------------------------------ */
.foot{background:var(--surface-ink);color:var(--sand-200);position:relative;overflow:hidden}
.foot::before{content:"";position:absolute;inset:0;background-image:var(--grain-url);background-size:280px;opacity:.32;mix-blend-mode:overlay;pointer-events:none}
.foot .grid{position:relative;display:grid;grid-template-columns:1.4fr 1fr 1.3fr;gap:56px;padding:84px 40px 48px}
.foot .brand .bnm{color:var(--sand-50)}
.foot .brand .bnm em{color:var(--ochre-400)}
.foot .ftag{font-family:var(--font-display);font-style:italic;font-size:1.5rem;color:var(--ochre-300);margin:18px 0 8px}
.foot .fsmall{font-size:15px;line-height:1.6;color:var(--sand-300);max-width:24rem}
.foot h4{font-family:var(--font-label);font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:var(--ochre-400);margin:0 0 18px}
.foot .fcol a{display:block;padding:7px 0;font-size:16px;color:var(--sand-200);transition:color var(--dur-base) var(--ease-out)}
.foot .fcol a:hover{color:var(--sand-50)}
.foot .fcol p{font-size:15px;line-height:1.6;color:var(--sand-300);margin:0 0 16px}
.signup{display:flex;gap:8px;max-width:22rem}
.signup input{flex:1;background:rgba(245,236,219,.08);border:1.5px solid rgba(245,236,219,.22);border-radius:var(--radius-pill);
     padding:13px 20px;color:var(--sand-50);font-family:var(--font-body);font-size:15px}
.signup input::placeholder{color:var(--sand-400)}
.signup input:focus{outline:none;border-color:var(--ochre-400)}
.signup button{font-family:var(--font-label);font-size:12px;letter-spacing:.16em;text-transform:uppercase;
     background:var(--ochre-500);color:var(--umber-700);border:none;border-radius:var(--radius-pill);padding:0 22px;cursor:pointer}
.signup button:hover{background:var(--ochre-400)}
.handle{font-family:var(--font-label);font-size:13px;letter-spacing:.2em;text-transform:uppercase;color:var(--ochre-400);margin-top:18px}
.fbase{position:relative;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;
     padding:26px 40px;border-top:1px solid rgba(245,236,219,.14);font-family:var(--font-label);
     font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--sand-400)}

/* responsive -------------------------------------------------------------- */
@media (max-width:900px){
  .split{grid-template-columns:1fr;gap:40px}
  .split.rev .col-img{order:0}
  .feature{grid-template-columns:1fr}
  .feature .media{aspect-ratio:16/9}
  .feature .body{padding:36px 36px 40px}
  .cards.c3{grid-template-columns:1fr 1fr}
  .values{grid-template-columns:1fr;gap:28px}
  .foot .grid{grid-template-columns:1fr;gap:40px;padding:64px 40px 40px}
}
@media (max-width:620px){
  body{font-size:17px}
  .wrap,.nav .row,.foot .grid,.fbase{padding-left:24px;padding-right:24px}
  .nav .row{justify-content:center}
  .links{gap:18px;width:100%;justify-content:center}
  .cards.c3{grid-template-columns:1fr}
  .pad{padding:72px 0}
  .hero .inner{padding:96px 0}
}
