/* ============================================================
   Gardens of the Galaxy — shared styles
   Tokens copied verbatim from the brand manifesto
============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;500;600&family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400;1,500&family=EB+Garamond:ital,wght@0,400;0,500;0,600;1,400;1,500&family=Jost:wght@300;400;500&display=swap');

:root{
  --paper:#f4f1e8;
  --paper-2:#efeadd;
  --panel:#eae4d4;
  --ink:#2f3d2a;          /* deep forest */
  --ink-soft:#475139;
  --ink-dim:#6c7359;
  --mute:#9a9c87;
  --sage:#7d9162;
  --sage-deep:#5b6f44;
  --sage-soft:#9aab7c;
  --gold:#b08d57;
  --line:rgba(47,61,42,0.22);
  --line-soft:rgba(47,61,42,0.12);
  --display:'Cinzel',serif;
  --cormorant:'Cormorant Garamond',serif;
  --body:'EB Garamond',serif;
  --sans:'Jost',sans-serif;
  --maxw:1200px;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{background:var(--paper);color:var(--ink);font-family:var(--body);font-size:18px;line-height:1.7;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;}
a{color:inherit;text-decoration:none;}
img,svg{display:block;}
::selection{background:rgba(125,145,98,0.28);}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px;}
.label{font-family:var(--sans);font-weight:400;letter-spacing:0.4em;text-transform:uppercase;font-size:11px;color:var(--sage);}
.label-g{font-family:var(--sans);font-weight:300;letter-spacing:0.4em;text-transform:uppercase;font-size:11px;color:var(--gold);}
.eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:24px;}
.eyebrow .dash{height:0.5px;width:40px;background:var(--sage);}
.rule{display:flex;align-items:center;justify-content:center;gap:10px;}
.rule .ln{height:1px;width:46px;background:linear-gradient(90deg,transparent,var(--sage));}
.rule .ln.r{background:linear-gradient(90deg,var(--sage),transparent);}
.rule .dia{color:var(--sage);font-size:9px;}

h1,h2,h3,h4{font-weight:normal;}
.display{font-family:var(--cormorant);}
em{font-style:italic;}

/* ---------- buttons ---------- */
.btn{display:inline-block;font-family:var(--sans);font-weight:400;letter-spacing:0.16em;text-transform:uppercase;
  font-size:11px;padding:13px 24px;border:0.5px solid var(--sage-deep);color:var(--sage-deep);border-radius:2px;
  background:transparent;cursor:pointer;transition:all .35s ease;}
.btn:hover{background:var(--sage-deep);color:var(--paper);}
.btn-solid{background:var(--sage-deep);color:var(--paper);border-color:var(--sage-deep);}
.btn-solid:hover{background:var(--ink);border-color:var(--ink);}
.btn-gold{border-color:var(--gold);color:var(--gold);}
.btn-gold:hover{background:var(--gold);color:var(--paper);}

/* ---------- NAV ---------- */
header{position:fixed;top:0;left:0;right:0;z-index:60;transition:all .4s ease;border-bottom:0.5px solid transparent;}
header.scrolled{background:rgba(244,241,232,0.86);backdrop-filter:blur(12px);border-bottom:0.5px solid var(--line-soft);}
.nav{max-width:var(--maxw);margin:0 auto;padding:16px 32px;display:flex;align-items:center;justify-content:space-between;gap:20px;}
.brand{display:flex;align-items:center;gap:12px;flex:none;}
.brand .lf{width:40px;height:40px;flex:none;}
.brand .bt{display:flex;flex-direction:column;line-height:1;}
.brand .bt .b1{font-family:var(--display);font-weight:500;letter-spacing:0.14em;font-size:13px;color:var(--ink);}
.brand .bt .b2{font-family:var(--sans);font-weight:300;letter-spacing:0.3em;font-size:7px;color:var(--sage-deep);text-transform:uppercase;margin-top:5px;}
.nav-links{display:flex;align-items:center;gap:26px;}
.nav-links a{font-family:var(--sans);font-weight:300;letter-spacing:0.16em;text-transform:uppercase;font-size:11px;color:var(--ink-soft);position:relative;padding:4px 0;}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--sage-deep);transition:width .35s ease;}
.nav-links a:hover,.nav-links a.active{color:var(--ink);}
.nav-links a:hover::after,.nav-links a.active::after{width:100%;}
.nav-cta{display:flex;align-items:center;gap:14px;flex:none;}
.cartlink{position:relative;font-family:var(--sans);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink-soft);cursor:pointer;display:flex;align-items:center;gap:6px;}
.cartlink .cc{background:var(--sage-deep);color:var(--paper);border-radius:20px;font-size:9px;padding:1px 6px;min-width:16px;text-align:center;}
.menu-toggle{display:none;background:none;border:none;color:var(--ink);font-size:22px;cursor:pointer;line-height:1;}
.mpanel{display:none;}

/* ---------- generic section ---------- */
section{position:relative;}
.sec{padding:110px 0;}
.sec-sm{padding:72px 0;}
h2.head{font-family:var(--cormorant);font-weight:400;font-size:clamp(30px,4.4vw,50px);line-height:1.1;color:var(--ink);letter-spacing:0.004em;}
h2.head em{font-style:italic;color:var(--sage-deep);}
.lead{font-family:var(--cormorant);font-weight:300;font-size:clamp(20px,2.5vw,28px);line-height:1.5;color:var(--ink-soft);}
.prose p{font-size:17px;line-height:1.85;color:var(--ink-soft);margin-bottom:16px;}
.prose p em{font-style:italic;color:var(--sage-deep);}

/* page hero (interior pages) */
.phero{padding:160px 0 60px;border-bottom:0.5px solid var(--line-soft);position:relative;overflow:hidden;}
.phero .bot{position:absolute;right:-40px;top:-30px;width:340px;opacity:0.05;pointer-events:none;}
.phero h1{font-family:var(--cormorant);font-weight:300;font-size:clamp(40px,6vw,72px);line-height:1.02;color:var(--ink);}
.phero h1 em{font-style:italic;color:var(--sage-deep);}
.phero p{max-width:560px;margin-top:18px;font-size:18px;color:var(--ink-dim);}

/* ---------- footer ---------- */
footer{background:var(--paper-2);border-top:0.5px solid var(--line-soft);padding:70px 0 36px;margin-top:0;}
.f-values{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-bottom:0.5px solid var(--line-soft);padding-bottom:40px;margin-bottom:40px;}
.f-val{padding:0 20px;border-left:0.5px solid var(--line-soft);}
.f-val:first-child{border-left:none;padding-left:0;}
.f-val .vi{color:var(--sage);font-size:13px;}
.f-val .vt{font-family:var(--sans);font-weight:300;letter-spacing:0.22em;text-transform:uppercase;font-size:11px;color:var(--ink);margin:11px 0 7px;}
.f-val p{font-size:13.5px;color:var(--ink-dim);line-height:1.55;}
.fcols{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:28px;}
.fbrand .lf{width:44px;height:44px;margin-bottom:16px;}
.fbrand .nm{font-family:var(--display);font-weight:500;letter-spacing:0.13em;font-size:15px;color:var(--ink);}
.fbrand .tg{font-family:var(--sans);font-weight:300;letter-spacing:0.24em;text-transform:uppercase;font-size:9px;color:var(--sage-deep);margin-top:8px;}
.fbrand .dom{font-family:var(--sans);font-size:12px;letter-spacing:0.1em;color:var(--ink-dim);margin-top:16px;}
.fcol h5{font-family:var(--sans);font-weight:400;letter-spacing:0.2em;text-transform:uppercase;font-size:11px;color:var(--sage-deep);margin-bottom:16px;}
.fcol a{display:block;font-size:15px;color:var(--ink-dim);margin-bottom:10px;transition:color .3s;}
.fcol a:hover{color:var(--ink);}
.fbar{display:flex;justify-content:space-between;align-items:center;margin-top:46px;padding-top:22px;border-top:0.5px solid var(--line-soft);
  font-family:var(--sans);font-weight:300;letter-spacing:0.12em;font-size:11px;color:var(--mute);text-transform:uppercase;flex-wrap:wrap;gap:10px;}

/* ---------- cards / grids ---------- */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line-soft);border:0.5px solid var(--line-soft);}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line-soft);border:0.5px solid var(--line-soft);}
.card{background:var(--paper);padding:36px 30px;transition:background .4s ease;display:flex;flex-direction:column;min-height:230px;}
.card:hover{background:var(--paper-2);}
.card .ic{color:var(--sage);font-size:18px;margin-bottom:18px;}
.card h3{font-family:var(--cormorant);font-weight:500;font-size:24px;color:var(--ink);margin-bottom:10px;}
.card p{font-size:15.5px;color:var(--ink-dim);line-height:1.65;flex:1;}
.card .more{font-family:var(--sans);font-weight:300;letter-spacing:0.18em;text-transform:uppercase;font-size:10px;color:var(--sage-deep);margin-top:18px;display:inline-flex;gap:8px;transition:gap .3s;}
.card:hover .more{gap:13px;}

/* reveal */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .9s cubic-bezier(.2,.6,.2,1),transform .9s cubic-bezier(.2,.6,.2,1);}
.reveal.in{opacity:1;transform:none;}

/* forms */
.field{margin-bottom:20px;}
.field label{display:block;font-family:var(--sans);font-weight:300;letter-spacing:0.14em;text-transform:uppercase;font-size:10.5px;color:var(--ink-dim);margin-bottom:8px;}
.field input,.field select,.field textarea{width:100%;background:var(--paper-2);border:0.5px solid var(--line);border-radius:2px;
  font-family:var(--body);font-size:16px;color:var(--ink);padding:13px 15px;outline:none;transition:border .3s,background .3s;}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--sage);background:#fff;}
.field textarea{resize:vertical;min-height:120px;}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
.formnote{font-family:var(--sans);font-size:11px;letter-spacing:0.06em;color:var(--mute);margin-top:8px;text-transform:uppercase;}
.success{background:rgba(125,145,98,0.12);border:0.5px solid var(--sage);border-radius:3px;padding:22px 24px;font-family:var(--cormorant);font-style:italic;font-size:20px;color:var(--sage-deep);}

@media(max-width:920px){
  .nav-links{display:none;}
  .nav-cta .btn{display:none;}
  .menu-toggle{display:block;}
  .grid-3,.grid-2{grid-template-columns:1fr;}
  .f-values{grid-template-columns:1fr 1fr;gap:26px 0;}
  .f-val:nth-child(3){border-left:none;padding-left:0;}
  .fcols{grid-template-columns:1fr 1fr;gap:30px;}
  .sec{padding:78px 0;}
  .mpanel.open{display:block;background:rgba(244,241,232,0.98);backdrop-filter:blur(12px);border-top:0.5px solid var(--line-soft);padding:18px 32px 26px;}
  .mpanel a{display:block;font-family:var(--sans);font-weight:300;letter-spacing:0.18em;text-transform:uppercase;font-size:13px;color:var(--ink-soft);padding:13px 0;border-bottom:0.5px solid var(--line-soft);}
  .mpanel a:last-child{border-bottom:none;}
}
@media(max-width:560px){
  .brand .bt .b2{display:none;}
  .field-row{grid-template-columns:1fr;}
  .f-values{grid-template-columns:1fr;}
  .f-val{border-left:none;padding-left:0;}
  .fcols{grid-template-columns:1fr;}
  .wrap,.nav{padding-left:22px;padding-right:22px;}
}

/* ---------- cart drawer ---------- */
.cart-scrim{position:fixed;inset:0;background:rgba(47,61,42,0.32);backdrop-filter:blur(2px);opacity:0;visibility:hidden;transition:all .35s;z-index:90;}
.cart-scrim.open{opacity:1;visibility:visible;}
.cart-drawer{position:fixed;top:0;right:0;height:100%;width:380px;max-width:88vw;background:var(--paper);z-index:100;
  transform:translateX(100%);transition:transform .4s cubic-bezier(.3,.7,.3,1);box-shadow:-20px 0 60px rgba(47,61,42,0.12);
  display:flex;flex-direction:column;border-left:0.5px solid var(--line);}
.cart-drawer.open{transform:none;}
.cart-head{display:flex;align-items:center;justify-content:space-between;padding:26px 26px 18px;border-bottom:0.5px solid var(--line-soft);}
.cart-x{background:none;border:none;font-size:16px;color:var(--ink-dim);cursor:pointer;}
.cart-body{flex:1;overflow-y:auto;padding:24px 26px;}
.citem{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;padding:16px 0;border-bottom:0.5px solid var(--line-soft);}
.citem .cn{font-family:var(--cormorant);font-size:19px;color:var(--ink);}
.citem .cp{font-family:var(--sans);font-size:11px;letter-spacing:.08em;color:var(--ink-dim);margin-top:4px;}
.cqty{display:flex;align-items:center;gap:8px;}
.cqty button{width:24px;height:24px;border:0.5px solid var(--line);background:var(--paper-2);color:var(--ink);cursor:pointer;border-radius:2px;font-size:13px;line-height:1;}
.cqty button:hover{border-color:var(--sage);}
.cqty span{font-family:var(--sans);font-size:13px;min-width:16px;text-align:center;}
.cqty .crm{margin-left:4px;color:var(--mute);border-color:transparent;background:none;}
.cart-foot{padding:22px 26px;border-top:0.5px solid var(--line);}
.cart-total{display:flex;justify-content:space-between;font-family:var(--cormorant);font-size:22px;color:var(--ink);}

/* product card */
.pcard{background:var(--paper);display:flex;flex-direction:column;}
.pcard .pimg{aspect-ratio:4/3;background:radial-gradient(120% 110% at 50% 20%,var(--paper-2),#e6e0cf);display:flex;align-items:center;justify-content:center;border-bottom:0.5px solid var(--line-soft);position:relative;}
.pcard .pimg .em{width:96px;height:96px;opacity:.92;}
.pcard .pimg .cat{position:absolute;top:14px;left:14px;font-family:var(--sans);font-weight:300;letter-spacing:.2em;text-transform:uppercase;font-size:9px;color:var(--sage-deep);}
.pcard .pbody{padding:24px 24px 26px;display:flex;flex-direction:column;flex:1;}
.pcard h3{font-family:var(--cormorant);font-weight:500;font-size:22px;color:var(--ink);margin-bottom:8px;}
.pcard p{font-size:14.5px;color:var(--ink-dim);line-height:1.6;flex:1;}
.pcard .prow{display:flex;align-items:center;justify-content:space-between;margin-top:18px;}
.pcard .price{font-family:var(--cormorant);font-size:24px;color:var(--sage-deep);}

/* resource card */
.rcard{background:var(--paper);padding:30px 28px;display:flex;flex-direction:column;cursor:pointer;transition:background .35s;min-height:210px;}
.rcard:hover{background:var(--paper-2);}
.rcard .rmeta{display:flex;justify-content:space-between;font-family:var(--sans);font-weight:300;letter-spacing:.16em;text-transform:uppercase;font-size:9.5px;color:var(--sage-deep);margin-bottom:16px;}
.rcard h3{font-family:var(--cormorant);font-weight:500;font-size:25px;color:var(--ink);margin-bottom:10px;line-height:1.15;}
.rcard p{font-size:15px;color:var(--ink-dim);line-height:1.6;flex:1;}
.rcard .read{font-family:var(--sans);font-weight:300;letter-spacing:.18em;text-transform:uppercase;font-size:10px;color:var(--sage-deep);margin-top:16px;}

/* article modal */
.amodal-scrim{position:fixed;inset:0;background:rgba(47,61,42,0.4);backdrop-filter:blur(3px);opacity:0;visibility:hidden;transition:.35s;z-index:110;display:flex;align-items:flex-start;justify-content:center;padding:60px 24px;overflow-y:auto;}
.amodal-scrim.open{opacity:1;visibility:visible;}
.amodal{background:var(--paper);max-width:640px;width:100%;border-radius:4px;padding:48px 52px;box-shadow:0 30px 80px rgba(47,61,42,0.25);transform:translateY(20px);transition:.4s;}
.amodal-scrim.open .amodal{transform:none;}
.amodal .ameta{font-family:var(--sans);font-weight:300;letter-spacing:.2em;text-transform:uppercase;font-size:10px;color:var(--sage-deep);margin-bottom:16px;display:flex;justify-content:space-between;}
.amodal h2{font-family:var(--cormorant);font-weight:400;font-size:38px;color:var(--ink);line-height:1.1;margin-bottom:24px;}
.amodal .abody p{font-size:17px;line-height:1.85;color:var(--ink-soft);margin-bottom:16px;}
.amodal .abody p em{font-style:italic;color:var(--sage-deep);}
.amodal .ax{float:right;background:none;border:none;font-size:18px;color:var(--ink-dim);cursor:pointer;margin:-20px -20px 0 0;}
@media(max-width:560px){.amodal{padding:34px 26px;}.amodal h2{font-size:30px;}}
