/* ============================================================
   Go Away, Gertie! — Marketing Site styles
   Builds on ../../colors_and_type.css. Component-scoped.
   ============================================================ */

/* ---------- shared utilities (used by JSX components) ---------- */
.btn{font-family:var(--font-body);font-weight:800;font-size:16px;padding:14px 22px;border-radius:var(--radius-pill);border:3px solid var(--gertie-ink);cursor:pointer;transition:transform .18s cubic-bezier(.34,1.56,.64,1),box-shadow .18s,background .18s;text-decoration:none;display:inline-flex;align-items:center;gap:8px;}
.btn-primary{background:var(--gertie-orange);color:var(--gertie-cream);box-shadow:0 4px 0 var(--gertie-ink);}
.btn-primary:hover{transform:translateY(-2px) rotate(-1deg);box-shadow:0 6px 0 var(--gertie-ink);background:var(--gertie-orange-deep);}
.btn-primary:active{transform:translateY(2px);box-shadow:0 1px 0 var(--gertie-ink);}
.btn-primary:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:0 4px 0 var(--gertie-ink);}
.btn-secondary{background:var(--gertie-cream);color:var(--gertie-green);box-shadow:0 4px 0 var(--gertie-ink);}
.btn-secondary:hover{background:#fff;transform:translateY(-2px) rotate(1deg);box-shadow:0 6px 0 var(--gertie-ink);}
.btn-secondary:active{transform:translateY(2px);box-shadow:0 1px 0 var(--gertie-ink);}
.btn-secondary:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:0 4px 0 var(--gertie-ink);}
.btn-tiny{font-size:13px;padding:8px 14px;}

.input{width:100%;font-family:var(--font-body);font-size:16px;padding:12px 14px;border:3px solid var(--gertie-ink);border-radius:14px;background:#fff;color:var(--fg-1);box-sizing:border-box;}
.input:focus{outline:3px solid var(--gertie-orange);outline-offset:2px;}

.badge{display:inline-flex;align-items:center;gap:6px;border:2px solid var(--gertie-ink);border-radius:999px;font-weight:800;font-size:12px;padding:5px 11px;letter-spacing:.04em;}
.b-stink{background:var(--stink-green);color:var(--gertie-ink);}

/* ---------- nav ---------- */
.gn-nav{position:sticky;top:0;z-index:30;display:flex;align-items:center;justify-content:space-between;padding:14px 28px;background:var(--gertie-cream);border-bottom:3px solid var(--gertie-ink);gap:18px;}
.gn-mark{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0;}
.gn-mark-img{width:38px;height:38px;border-radius:50%;border:2px solid var(--gertie-ink);background:var(--basset-tan);overflow:hidden;display:inline-block;position:relative;flex-shrink:0;}
.gn-mark-img img{width:100%;height:100%;display:block;object-fit:cover;}
.gn-mark-d1{font-family:var(--font-display-1);font-weight:700;color:var(--gertie-green);font-size:18px;transform:rotate(-2deg);}
.gn-mark-d2{font-family:var(--font-display-2);font-weight:700;color:var(--gertie-orange);font-size:24px;-webkit-text-stroke:2px var(--cloud-white);paint-order:stroke fill;transform:rotate(2deg);margin-left:-2px;}
.gn-list{list-style:none;margin:0;padding:0;display:flex;align-items:center;gap:8px;}
.gn-link{padding:8px 14px;border-radius:999px;color:var(--fg-1);text-decoration:none;font-weight:700;font-size:15px;white-space:nowrap;}
.gn-link:hover{background:rgba(23,46,23,.08);color:var(--gertie-green);}
.gn-link.is-active{background:var(--gertie-green);color:var(--gertie-cream);}
.gn-link.gn-link-cta{background:var(--gertie-orange);color:var(--gertie-cream);border:2px solid var(--gertie-ink);box-shadow:0 3px 0 var(--gertie-ink);padding:8px 16px;transition:transform .18s cubic-bezier(.34,1.56,.64,1), box-shadow .18s, background .18s;}
.gn-link.gn-link-cta:hover{background:var(--gertie-orange-deep);color:var(--gertie-cream);transform:translateY(-2px) rotate(-1deg);box-shadow:0 5px 0 var(--gertie-ink);}
.gn-link.gn-link-cta.is-active{background:var(--gertie-orange-deep);color:var(--gertie-cream);}

/* ---------- hero ---------- */
.gh-hero{position:relative;min-height:780px;display:grid;grid-template-rows:auto 1fr auto;overflow:hidden;border-bottom:3px solid var(--gertie-ink);}
.gh-bg{position:absolute;inset:0;}
.gh-bg-img{width:100%;height:100%;object-fit:cover;display:block;}
.gh-bg-tint{position:absolute;inset:0;background:linear-gradient(to bottom, rgba(0,0,0,0) 0%, rgba(0,0,0,0) 55%, rgba(0,0,0,0.35) 100%);}
.gh-bg-tint.scrim-strong{background:linear-gradient(to bottom, rgba(0,0,0,0) 0%, rgba(0,0,0,0) 35%, rgba(0,0,0,.55) 75%, rgba(0,0,0,.7) 100%);}
.gh-bg-tint.scrim-vignette{background:radial-gradient(120% 80% at 50% 100%, rgba(0,0,0,.7) 0%, rgba(0,0,0,.4) 35%, rgba(0,0,0,0) 70%);}
.gh-bg-tint.scrim-none{background:transparent;}
.gh-deck.deck-card{background:rgba(255,251,242,.96);color:var(--gertie-ink, #2a2018);text-shadow:none;border-radius:18px;padding:18px 22px;box-shadow:0 12px 32px rgba(0,0,0,.22);}
.gh-deck.deck-card-orange{background:rgba(220,90,40,.95);color:#fffbf2;text-shadow:none;border-radius:18px;padding:18px 22px;box-shadow:0 12px 32px rgba(0,0,0,.22);}
.gh-deck.deck-pill{background:rgba(0,0,0,.55);color:#fffbf2;text-shadow:none;border-radius:14px;padding:14px 20px;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);}
.gh-content{position:relative;text-align:center;padding:48px 24px 36px;display:contents;}
.gh-top{position:relative;text-align:center;padding:48px 24px 0;}
.gh-bottom{position:relative;text-align:center;padding:0 24px 48px;align-self:end;}
.gh-eyebrow{display:block;color:var(--gertie-cream);font-size:14px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;text-shadow:0 2px 0 rgba(0,0,0,.55),0 0 18px rgba(0,0,0,.4);margin-bottom:18px;}
.gh-title{margin:0 auto 24px;}
.gh-title .d1{font-size:clamp(48px,8vw,108px);}
.gh-title .d2{font-size:clamp(64px,11vw,148px);}
.gh-deck{max-width:560px;margin:0 auto 28px;font-size:20px;line-height:1.5;color:var(--gertie-cream);text-shadow:0 2px 0 rgba(0,0,0,.5);font-weight:600;}
.gh-ctas{display:flex;gap:14px;justify-content:center;margin-bottom:18px;flex-wrap:wrap;}
.gh-meta{color:var(--gertie-cream);font-size:14px;font-weight:700;letter-spacing:.04em;display:flex;gap:10px;justify-content:center;text-shadow:0 1px 0 rgba(0,0,0,.4);}
.gh-meta span{}

/* ---------- jacket ---------- */
.gj-section{background:var(--bg-page);padding:80px 24px;display:grid;place-items:center;}
.gj-card{background:var(--bg-spotlight);border:3px solid var(--gertie-ink);border-radius:22px;padding:36px 40px;max-width:640px;box-shadow:0 6px 0 var(--gertie-ink),0 18px 36px rgba(42,27,14,.18);transform:rotate(-.8deg);}
.gj-lead{font-family:var(--font-body);font-size:24px;line-height:1.5;font-weight:600;color:var(--fg-1);margin:18px 0 14px;text-wrap:balance;}
.gj-body{font-size:18px;line-height:1.6;color:var(--fg-1);margin:0 0 14px;text-align:justify;hyphens:auto;}

/* ---------- cast ---------- */
.gc-section{background:var(--sky-blue);background-image:linear-gradient(to bottom,var(--sky-blue) 0%,var(--sky-blue) 65%,var(--grass-bright) 65%,var(--grass-bright) 100%);padding:80px 24px;border-top:3px solid var(--gertie-ink);border-bottom:3px solid var(--gertie-ink);}
.gc-h2{text-align:center;font-family:var(--font-display-1);font-weight:700;color:var(--gertie-green);font-size:clamp(36px,5vw,56px);margin:0 0 8px;}
.gc-lead{text-align:center;color:var(--gertie-ink);font-size:18px;margin:0 0 36px;font-weight:600;}
.gc-grid{list-style:none;margin:0 auto;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:18px;max-width:1100px;}
.gc-colouring{max-width:680px;margin:48px auto 0;background:var(--gertie-cream);border:3px solid var(--gertie-ink);border-radius:22px;padding:22px 26px;display:flex;align-items:center;gap:22px;flex-wrap:wrap;justify-content:space-between;box-shadow:0 5px 0 var(--gertie-ink);transform:rotate(-.6deg);}
.gc-colouring-text{flex:1;min-width:240px;}
.gc-colouring-eyebrow{display:block;color:var(--gertie-orange);margin-bottom:4px;}
.gc-colouring-h3{font-family:var(--font-display-1);font-weight:700;color:var(--gertie-green);font-size:26px;margin:0 0 6px;}
.gc-colouring-p{color:var(--fg-1);font-size:15px;line-height:1.45;margin:0;font-weight:600;}
.gc-colouring-btn{flex-shrink:0;text-decoration:none;}
.gc-card{transition:transform .25s cubic-bezier(.34,1.56,.64,1);}
.gc-card.is-active{transform:rotate(0deg) scale(1.04) !important;}
.gc-card:hover:not(.is-active){animation:gc-wobble .55s ease-in-out;}
@keyframes gc-wobble{
  0%   {transform:rotate(var(--gc-tilt,0deg));}
  20%  {transform:rotate(calc(var(--gc-tilt,0deg) - 4deg)) translateY(-2px);}
  40%  {transform:rotate(calc(var(--gc-tilt,0deg) + 4deg)) translateY(-3px);}
  60%  {transform:rotate(calc(var(--gc-tilt,0deg) - 3deg)) translateY(-2px);}
  80%  {transform:rotate(calc(var(--gc-tilt,0deg) + 2deg)) translateY(-1px);}
  100% {transform:rotate(var(--gc-tilt,0deg));}
}
.gc-btn{width:100%;background:var(--gertie-orange);border:3px solid var(--gertie-ink);border-radius:18px;padding:16px;cursor:pointer;display:grid;place-items:center;text-align:center;box-shadow:0 4px 0 var(--gertie-ink);font-family:var(--font-body);transition:transform .18s,box-shadow .18s;}
.gc-btn:hover{transform:translateY(-3px);box-shadow:0 7px 0 var(--gertie-ink);}
.gc-portrait{width:140px;height:140px;border-radius:18px;border:3px solid var(--gertie-ink);overflow:visible;display:block;margin:0 auto 10px;position:relative;background:#fff;}
.gc-img{position:absolute;inset:6px;background-size:cover;background-repeat:no-repeat;background-position:center center;border-radius:12px;}
.gc-bubble{position:absolute;top:-14px;right:-22px;background:var(--cloud-white);border:3px solid var(--gertie-ink);border-radius:16px;padding:6px 12px;font-family:var(--font-display-2);font-weight:700;font-size:18px;color:var(--gertie-ink);transform:rotate(6deg) scale(.4);opacity:0;pointer-events:none;transition:transform .35s cubic-bezier(.34,1.56,.64,1), opacity .2s ease;white-space:nowrap;box-shadow:3px 3px 0 var(--gertie-ink);z-index:3;}
.gc-bubble::after{content:"";position:absolute;left:14px;bottom:-10px;width:14px;height:14px;background:var(--cloud-white);border-right:3px solid var(--gertie-ink);border-bottom:3px solid var(--gertie-ink);transform:rotate(45deg);}
.gc-card:hover .gc-bubble,.gc-bubble.is-on{opacity:1;transform:rotate(6deg) scale(1);}
.gc-name{display:block;font-family:var(--font-display-1);font-weight:700;color:var(--gertie-green);font-size:22px;margin-bottom:4px;}
.gc-role{display:block;font-size:13px;color:var(--gertie-ink);line-height:1.35;font-weight:600;}

/* ---------- music toggle ---------- */
.gm-wrap{position:fixed;right:20px;bottom:20px;z-index:50;display:flex;align-items:center;gap:10px;}
.gm-btn{width:54px;height:54px;border-radius:50%;border:3px solid var(--gertie-ink);background:var(--gertie-orange);color:var(--gertie-cream);cursor:pointer;display:grid;place-items:center;box-shadow:0 4px 0 var(--gertie-ink);transition:transform .18s cubic-bezier(.34,1.56,.64,1), box-shadow .18s;padding:0;}
.gm-btn:hover{transform:translateY(-2px) rotate(-4deg);box-shadow:0 6px 0 var(--gertie-ink);}
.gm-btn:active{transform:translateY(2px);box-shadow:0 1px 0 var(--gertie-ink);}
.gm-btn.is-playing{background:var(--gertie-green);}
.gm-icon{display:grid;place-items:center;}
.gm-bars{display:inline-flex;gap:3px;align-items:flex-end;height:22px;}
.gm-bars span{width:4px;background:var(--cloud-white);border-radius:2px;animation:gmBar 0.9s ease-in-out infinite;}
.gm-bars span:nth-child(1){height:60%;animation-delay:-.3s;}
.gm-bars span:nth-child(2){height:90%;animation-delay:-.1s;}
.gm-bars span:nth-child(3){height:50%;animation-delay:-.5s;}
.gm-bars span:nth-child(4){height:80%;animation-delay:0s;}
@keyframes gmBar{0%,100%{transform:scaleY(.4);}50%{transform:scaleY(1);}}
.gm-nudge{background:var(--cloud-white);border:3px solid var(--gertie-ink);border-radius:999px;padding:8px 12px 8px 16px;display:flex;align-items:center;gap:6px;box-shadow:3px 3px 0 var(--gertie-ink);font-family:var(--font-display-1);font-weight:700;color:var(--gertie-ink);font-size:14px;cursor:pointer;animation:gmNudge .5s cubic-bezier(.34,1.56,.64,1);transform:rotate(-2deg);}
.gm-nudge-text{white-space:nowrap;}
.gm-nudge-x{background:transparent;border:none;color:var(--gertie-ink);font-size:18px;cursor:pointer;line-height:1;padding:0 4px;font-weight:700;}
.gm-nudge-x:hover{color:var(--gertie-orange);}
@keyframes gmNudge{from{opacity:0;transform:rotate(-2deg) translateX(20px);}to{opacity:1;transform:rotate(-2deg) translateX(0);}}

/* ---------- sample ---------- */
.gs-section{background:var(--bg-page);padding:80px 24px;text-align:center;}
.gs-eyebrow{display:block;margin-bottom:18px;color:var(--gertie-orange-deep);}
.gs-spread{display:grid;grid-template-columns:1fr 1fr;max-width:920px;margin:0 auto 24px;background:var(--bg-spotlight);border:4px solid var(--gertie-ink);border-radius:18px;overflow:hidden;box-shadow:0 6px 0 var(--gertie-ink),0 16px 32px rgba(42,27,14,.18);min-height:320px;}
.gs-page{padding:40px 36px;display:grid;place-items:center;}
.gs-page-left{border-right:2px dashed rgba(42,27,14,.25);}
.gs-line{font-family:var(--font-story);font-size:26px;line-height:1.5;color:var(--fg-1);margin:0;text-wrap:balance;}
.gs-tease{display:flex;flex-direction:column;align-items:flex-start;gap:14px;text-align:left;}
.gs-tease-line{font-family:var(--font-story);font-size:22px;line-height:1.4;color:var(--fg-2);margin:0;text-wrap:balance;}
.gs-tease-punch{font-family:var(--font-display-2);font-weight:700;font-size:40px;line-height:1.05;color:var(--gertie-orange);-webkit-text-stroke:2px var(--gertie-ink);paint-order:stroke fill;margin:0;text-wrap:balance;transform:rotate(-1.5deg);}
.gs-tease-sub{font-family:var(--font-story);font-style:italic;font-size:16px;color:var(--fg-1);margin:0;}
.gs-tease-btn{align-self:flex-start;margin-top:6px;}
.gs-controls{display:flex;align-items:center;justify-content:center;gap:18px;}
.gs-counter{font-size:13px;color:var(--fg-3);font-weight:700;letter-spacing:.04em;text-transform:uppercase;}

/* ---------- author ---------- */
.ga-section{background:var(--sky-blue);background-image:linear-gradient(to bottom,#fff 0%,var(--sky-blue) 100%);padding:80px 24px;border-top:3px solid var(--gertie-ink);border-bottom:3px solid var(--gertie-ink);position:relative;overflow:hidden;}
.ga-section::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 18% 22%,var(--cloud-white) 0,var(--cloud-white) 28px,transparent 30px),radial-gradient(circle at 82% 18%,var(--cloud-white) 0,var(--cloud-white) 36px,transparent 38px),radial-gradient(circle at 92% 78%,var(--cloud-white) 0,var(--cloud-white) 24px,transparent 26px);opacity:.55;pointer-events:none;}
.ga-h2{position:relative;text-align:center;font-family:var(--font-display-1);font-weight:700;color:var(--gertie-green);font-size:clamp(34px,4.5vw,52px);margin:0 0 28px;text-wrap:balance;}
.ga-prose{position:relative;max-width:640px;margin:0 auto 48px;color:var(--gertie-ink);font-size:18px;line-height:1.6;font-weight:500;background:var(--gertie-cream);border:3px solid var(--gertie-ink);border-radius:18px;padding:28px 32px;box-shadow:0 5px 0 var(--gertie-ink);text-align:justify;hyphens:auto;}
.ga-prose p{margin:0 0 14px;}
.ga-prose p:last-child{margin-bottom:0;}
.ga-photos{position:relative;list-style:none;margin:0 auto;padding:24px 0 8px;display:flex;flex-wrap:wrap;justify-content:center;gap:34px;max-width:1000px;}
.ga-photo{background:var(--cloud-white);border:3px solid var(--gertie-ink);padding:14px 14px 18px;box-shadow:0 8px 0 var(--gertie-ink),0 18px 28px rgba(42,27,14,.18);transition:transform .25s cubic-bezier(.34,1.56,.64,1),box-shadow .25s;width:240px;display:flex;flex-direction:column;align-items:center;gap:12px;}
.ga-photo:hover{animation:ga-wobble .55s ease-in-out;box-shadow:0 11px 0 var(--gertie-ink),0 22px 32px rgba(42,27,14,.22);z-index:2;}
.ga-photo-img{display:block;width:100%;aspect-ratio:1/1;background:var(--bg-spotlight) center/cover no-repeat;border:2px solid rgba(42,27,14,.3);}
.ga-photo-caption{font-family:var(--font-display-1);font-weight:700;color:var(--gertie-green);font-size:18px;text-align:center;line-height:1.2;}
@keyframes ga-wobble{
  0%   {transform:rotate(var(--ga-tilt,0deg));}
  20%  {transform:rotate(calc(var(--ga-tilt,0deg) - 4deg)) translateY(-3px);}
  40%  {transform:rotate(calc(var(--ga-tilt,0deg) + 4deg)) translateY(-4px);}
  60%  {transform:rotate(calc(var(--ga-tilt,0deg) - 3deg)) translateY(-3px);}
  80%  {transform:rotate(calc(var(--ga-tilt,0deg) + 2deg)) translateY(-1px);}
  100% {transform:rotate(var(--ga-tilt,0deg));}
}
@media (max-width:560px){
  .ga-photo{width:200px;}
}

/* ---------- buy ---------- */
.gb-section{background:var(--gertie-green);color:var(--gertie-cream);padding:80px 24px;border-top:3px solid var(--gertie-ink);}
.gb-h2{text-align:center;font-family:var(--font-display-2);font-weight:700;color:var(--gertie-orange);-webkit-text-stroke:3px var(--gertie-cream);paint-order:stroke fill;font-size:clamp(40px,6vw,72px);margin:0 0 6px;line-height:1;}
.gb-lead{text-align:center;color:var(--gertie-cream);font-size:18px;margin:0 0 36px;}
.gb-grid{list-style:none;margin:0 auto 60px;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,260px));gap:18px;max-width:980px;justify-content:center;}
.gb-card{position:relative;background:var(--gertie-cream);color:var(--fg-1);border:3px solid var(--gertie-ink);border-radius:18px;padding:18px 18px 16px;display:grid;gap:6px;box-shadow:0 4px 0 var(--gertie-ink);transition:transform .25s cubic-bezier(.34,1.56,.64,1), box-shadow .25s;}
.gb-badge{position:absolute;top:-12px;right:-10px;background:var(--gertie-orange);color:var(--gertie-cream);font-family:var(--font-display-2,var(--font-body));font-weight:800;font-size:14px;letter-spacing:.02em;padding:6px 12px;border:2.5px solid var(--gertie-ink);border-radius:999px;box-shadow:0 3px 0 var(--gertie-ink);transform:rotate(10deg);white-space:nowrap;z-index:2;pointer-events:none;}
.gb-card:hover{animation:gb-wobble .55s ease-in-out;box-shadow:0 7px 0 var(--gertie-ink);}
@keyframes gb-wobble{
  0%   {transform:rotate(var(--gb-tilt,0deg));}
  20%  {transform:rotate(calc(var(--gb-tilt,0deg) - 4deg)) translateY(-2px);}
  40%  {transform:rotate(calc(var(--gb-tilt,0deg) + 4deg)) translateY(-3px);}
  60%  {transform:rotate(calc(var(--gb-tilt,0deg) - 3deg)) translateY(-2px);}
  80%  {transform:rotate(calc(var(--gb-tilt,0deg) + 2deg)) translateY(-1px);}
  100% {transform:rotate(var(--gb-tilt,0deg));}
}
.gb-name{font-family:var(--font-display-1);font-weight:700;color:var(--gertie-green);font-size:22px;}
.gb-hint{font-size:13px;color:var(--fg-2);}
.gb-price{font-family:var(--font-body);font-weight:800;font-size:18px;color:var(--gertie-orange-deep);margin-bottom:6px;}
.gb-card .btn{width:fit-content;}
.gb-newsletter{max-width:520px;margin:0 auto;text-align:center;background:rgba(255,246,225,.06);border:2px dashed rgba(255,246,225,.35);border-radius:18px;padding:32px;}
.gb-news-h3{font-family:var(--font-display-1);font-weight:700;color:var(--gertie-cream);font-size:28px;margin:0 0 8px;}
.gb-news-p{color:var(--gertie-cream);opacity:.85;font-size:15px;margin:0 0 18px;}
.gb-form{display:flex;gap:10px;align-items:stretch;}
.gb-form .input{flex:1;}
.gb-thanks{color:var(--stink-green);font-size:18px;font-weight:600;margin:0;}

/* ---------- footer ---------- */
.gf-foot{background:var(--gertie-ink);color:var(--gertie-cream);padding:28px 36px;font-size:13px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;}
.gf-foot a{color:var(--gertie-orange);}

/* curved hero title — replaces the straight .d1 in the hero */
.d1-curve{display:block;width:min(78vw,560px);height:auto;overflow:visible;margin-bottom:-12px;}
.d1-curve text{font-family:var(--font-display-1);font-weight:700;font-size:88px;fill:var(--gertie-green);paint-order:stroke fill;stroke:var(--cloud-white);stroke-width:6px;stroke-linejoin:round;}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;}
@media (max-width:680px){
  .d1-curve text{font-size:64px;}
}

/* responsive */
@media (max-width:680px){
  .gn-list li:nth-child(-n+5){display:none;}
  .gh-hero{min-height:560px;}
  .gs-spread{grid-template-columns:1fr;}
  .gs-page-left{border-right:none;border-bottom:2px dashed rgba(42,27,14,.25);}
}
