/* ============================================================
   Work with AI — site styles
   Palette & type mirror the printed guides.
   ============================================================ */
:root{
  --paper:#FAF5EC; --paper2:#F3EADA; --ink:#211F1C; --ink2:#4B463F; --muted:#6b6155;
  --teal:#11675A; --teal-d:#0C4D43; --teal-t:#DCEAE5;
  --terra:#D25B36; --terra-t:#F6E0D6;
  --gold:#E2A33C; --gold-d:#b9831f; --gold-t:#F7EBD4;
  --plum:#6A3F62; --plum-t:#EADFE8;
  --blue:#2C5E7E; --blue-t:#DCE7EE;
  --line:#EAdfce; --line2:#D9CcB5;
  --radius:16px; --shadow:0 14px 40px -22px rgba(33,31,28,.45);
  --serif:"Fraunces",Georgia,serif; --sans:"Plus Jakarta Sans",system-ui,sans-serif; --mono:"JetBrains Mono",monospace;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--sans);font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased}
img,svg{display:block;max-width:100%}
a{color:var(--teal);text-decoration:none}
.wrap{width:min(1080px,92vw);margin:0 auto}
.center{text-align:center}
.muted{color:var(--muted)}
.eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--terra);font-weight:600;margin:0 0 6px}
.eyebrow.gold{color:var(--gold)}
.h2{font-family:var(--serif);font-weight:600;font-size:clamp(28px,4.4vw,42px);line-height:1.08;margin:6px 0 14px;letter-spacing:-.01em}
.lead{font-size:clamp(16px,2vw,19px);color:var(--ink2);max-width:60ch}
.center .lead{margin-inline:auto}
.light{color:var(--paper)} .band--ink .lead{color:#cfc7b6}
.ink-teal{color:var(--teal)}
.strike{text-decoration:line-through;text-decoration-color:var(--terra);text-decoration-thickness:3px;opacity:.65}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--sans);font-weight:700;
  font-size:16px;border:none;border-radius:12px;padding:13px 22px;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,filter .15s ease;
  text-decoration:none;line-height:1}
.btn--sm{padding:9px 15px;font-size:14px;border-radius:10px}
.btn--lg{padding:16px 28px;font-size:18px}
.btn--block{width:100%}
.btn--teal{background:var(--teal);color:#fff;box-shadow:0 8px 20px -10px var(--teal)}
.btn--terra{background:var(--terra);color:#fff;box-shadow:0 8px 20px -10px var(--terra)}
.btn--gold{background:var(--gold);color:var(--ink);box-shadow:0 8px 20px -10px var(--gold-d)}
.btn:hover{transform:translateY(-2px);filter:brightness(1.04)}
.btn:active{transform:translateY(0)}
.btn[disabled]{opacity:.6;cursor:not-allowed;transform:none}
.btn.is-on{background:var(--teal);color:#fff}

/* ---------- Brand / header ---------- */
.brand{display:inline-flex;align-items:center;gap:11px}
.brand-badge{flex:0 0 40px}
.brand-word{font-family:var(--serif);font-weight:600;font-size:21px;color:var(--ink);letter-spacing:-.01em}
.brand-word em{font-style:italic;color:var(--terra)}
.brand-word--dark{color:var(--paper)} .brand-word--dark em{color:var(--gold)}
.brand-link{display:inline-flex}
.site-head{position:sticky;top:0;z-index:50;background:rgba(250,245,236,.86);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.site-head__inner{display:flex;align-items:center;justify-content:space-between;padding:12px 0}
.site-nav{display:flex;align-items:center;gap:22px;font-weight:600;font-size:15px}
.site-nav a{color:var(--ink2)}
.site-nav a:hover{color:var(--ink)}
.site-nav .btn{color:#fff}
.nav-help{font-weight:600}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;padding:64px 0 72px}
.hero__bg{position:absolute;inset:0;z-index:0;
  background:
   radial-gradient(60% 50% at 8% 0%,var(--teal-t) 0%,transparent 60%),
   radial-gradient(50% 45% at 100% 100%,var(--gold-t) 0%,transparent 55%),
   radial-gradient(40% 40% at 92% 8%,var(--terra-t) 0%,transparent 60%);
  background-color:var(--paper)}
.hero__bg::after{content:"";position:absolute;inset:0;background-image:radial-gradient(var(--line2) .9px,transparent .9px);background-size:22px 22px;opacity:.35}
.hero__inner{position:relative;z-index:1;display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center}
.pill{display:inline-block;font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;
  background:#fff;border:1px solid var(--line2);border-radius:999px;padding:7px 14px;color:var(--ink2);font-weight:600}
.hero__title{font-family:var(--serif);font-weight:600;font-size:clamp(36px,6.2vw,62px);line-height:1.02;letter-spacing:-.02em;margin:18px 0 16px}
.hero__sub{font-size:clamp(16px,2.1vw,20px);color:var(--ink2);max-width:56ch;margin:0 0 26px}
.hero__cta{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.hero__meta{font-size:14px;color:var(--muted)}
.hero__ticks{list-style:none;display:flex;flex-wrap:wrap;gap:10px 22px;padding:0;margin:26px 0 0;font-weight:600;font-size:14.5px}
.hero__ticks li{position:relative;padding-left:24px}
.hero__ticks li::before{content:"✓";position:absolute;left:0;color:var(--teal);font-weight:800}

/* Hero "book" card */
.hero__art{display:flex;justify-content:center}
.bookcard{position:relative;width:min(330px,80vw);background:linear-gradient(160deg,#fff, #FBF6ED);
  border:1px solid var(--line);border-radius:22px;padding:30px 26px 22px;box-shadow:var(--shadow);transform:rotate(1.4deg)}
.bookcard__spark{position:absolute;top:-16px;right:22px;width:46px;height:46px;display:grid;place-items:center;border-radius:50%;
  background:var(--terra);color:#fff;font-size:20px;box-shadow:0 10px 22px -10px var(--terra)}
.bookcard__eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--terra);font-weight:600}
.bookcard__title{font-family:var(--serif);font-weight:600;font-size:34px;line-height:1.04;margin:12px 0 0;letter-spacing:-.01em}
.bookcard__title em{font-style:italic;color:var(--teal)}
.bookcard__tag{font-family:var(--serif);font-style:italic;color:var(--ink2);font-size:15px;margin:14px 0 0}
.bookcard__price{display:flex;align-items:baseline;gap:8px;margin:22px 0 0;border-top:1px dashed var(--line2);padding-top:14px}
.bookcard__price span{font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em}
.bookcard__price b{font-family:var(--serif);font-size:34px;color:var(--gold-d)}
.bookcard__foot{font-size:11px;color:var(--muted);margin-top:8px}

/* ---------- Bands ---------- */
.band{padding:64px 0}
.band--cream{background:var(--paper2)}
.band--ink{background:var(--ink);color:var(--paper)}

/* ---------- Reframe ---------- */
.reframe{display:grid;grid-template-columns:.8fr 1.2fr;gap:42px;align-items:center}
.bignum{font-family:var(--serif);font-weight:600;font-size:clamp(48px,9vw,86px);color:var(--terra);line-height:.9}
.reframe__stat p{font-size:16px;color:var(--ink2);margin-top:10px;max-width:30ch}
.reframe__line{margin-top:14px;font-size:18px}
.reframe__msg .h2 .strike{margin-right:4px}

/* ---------- Cards / grids ---------- */
.grid{display:grid;gap:18px}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:0 2px 0 var(--line)}
.parts{margin-top:34px}
.part__no{display:grid;place-items:center;width:34px;height:34px;border-radius:9px;background:var(--c,var(--teal));color:#fff;font-weight:800;font-family:var(--serif);margin-bottom:10px}
.part h3{font-family:var(--serif);font-weight:600;font-size:19px;margin:0 0 6px}
.part p{margin:0;font-size:14.5px;color:var(--ink2)}

.feature-row{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:26px}
.feature{display:flex;gap:14px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px}
.feature__ic{font-size:26px;flex:0 0 auto}
.feature h4{margin:0 0 4px;font-size:16px}
.feature p{margin:0;font-size:14px;color:var(--ink2)}

/* ---------- Tools / companions ---------- */
.tools{margin-top:34px}
.toolcard{position:relative;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.14);border-radius:var(--radius);
  padding:22px;border-top:4px solid var(--a,var(--gold))}
.toolcard__spark{color:var(--a,var(--gold));font-size:18px;margin-bottom:8px}
.toolcard h3{font-family:var(--serif);font-weight:600;font-size:21px;margin:0 0 4px;color:var(--paper)}
.toolcard p{margin:0;font-size:14.5px;color:#cfc7b6}

.upsell{margin-top:30px;background:rgba(226,163,60,.10);border:1px solid var(--gold);border-radius:20px;
  padding:26px;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.upsell__tag{display:inline-block;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  background:var(--gold);color:var(--ink);padding:4px 10px;border-radius:6px;font-weight:700}
.upsell h3{font-family:var(--serif);font-weight:600;font-size:24px;color:var(--paper);margin:10px 0 6px}
.upsell p{margin:0;color:#cfc7b6;font-size:15px;max-width:46ch}
.upsell__price{display:flex;align-items:baseline;gap:12px;margin-top:12px}
.upsell__price .was{color:#9a917f;text-decoration:line-through;font-size:18px}
.upsell__price .now{font-family:var(--serif);font-size:30px;color:var(--gold)}
.upsell__price .save{font-size:13px;font-weight:700;color:var(--ink);background:var(--gold);padding:3px 9px;border-radius:6px}
#toggle-companions.is-on{background:var(--teal);color:#fff}

/* ---------- Checkout ---------- */
.checkout{display:grid;grid-template-columns:1fr 1fr;gap:42px;align-items:start}
.checkout__intro .trust{list-style:none;padding:0;margin:20px 0 0;display:grid;gap:10px;font-weight:600;font-size:15px}
.order{background:#fff;border:1px solid var(--line);border-radius:20px;padding:26px;box-shadow:var(--shadow)}
.order__h{font-family:var(--serif);font-weight:600;font-size:22px;margin:0 0 14px}
.order__line{display:flex;justify-content:space-between;gap:14px;padding:14px 0;border-bottom:1px solid var(--line)}
.order__line span.muted{display:block;font-size:13px}
.order__line .price{font-family:var(--serif);font-size:20px;white-space:nowrap}
.order__line--companions{transition:opacity .2s ease}
.order__line--companions.is-off{display:none}
.chip{display:inline-block;font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;
  background:var(--teal-t);color:var(--teal-d);padding:2px 7px;border-radius:5px;vertical-align:1px;font-weight:700}
.addline{width:100%;margin:12px 0 0;background:var(--gold-t);border:1px dashed var(--gold-d);color:var(--gold-d);
  font-weight:700;font-family:var(--sans);border-radius:10px;padding:11px;cursor:pointer;font-size:14.5px}
.addline.is-hidden{display:none}
.order__total{display:flex;justify-content:space-between;align-items:baseline;margin:16px 0 18px;padding-top:14px;border-top:2px solid var(--ink);
  font-family:var(--serif);font-size:26px;font-weight:600}
.field{margin-bottom:14px}
.field label{display:block;font-weight:600;font-size:14px;margin-bottom:6px}
.field input{width:100%;font-family:var(--sans);font-size:16px;padding:12px 14px;border:1.5px solid var(--line2);border-radius:11px;background:#fffdf8}
.field input:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-t)}
.card-input{padding:13px 14px;border:1.5px solid var(--line2);border-radius:11px;background:#fffdf8}
.card-input.StripeElement--focus{border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-t)}
.card-input.StripeElement--invalid{border-color:var(--terra)}
.pay-msg{min-height:18px;margin:10px 0 0;font-size:14px;font-weight:600;color:var(--terra)}
.pay-msg.ok{color:var(--teal)}
.fineprint{font-size:12px;color:var(--muted);margin:12px 0 0;line-height:1.5}
.spin{width:18px;height:18px;border:2.5px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:sp .7s linear infinite}
@keyframes sp{to{transform:rotate(360deg)}}

/* ---------- Look-inside carousel ---------- */
.carousel{position:relative;width:min(1180px,96vw);margin:34px auto 0}
.car-track{display:flex;gap:18px;overflow-x:auto;scroll-snap-type:x mandatory;
  padding:8px 4px 18px;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--line2) transparent}
.car-track:focus-visible{outline:2px solid var(--teal);outline-offset:4px}
.car-slide{flex:0 0 auto;width:min(300px,72vw);margin:0;scroll-snap-align:center}
.car-slide img{width:100%;height:auto;aspect-ratio:827/1170;object-fit:cover;border:1px solid var(--line2);border-radius:12px;background:#fff;
  box-shadow:0 14px 32px -20px rgba(33,31,28,.55);transition:transform .2s ease}
.car-slide img:hover{transform:translateY(-4px)}
.car-slide figcaption{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--muted);margin-top:10px;text-align:center}
.car-slide figcaption b{color:var(--teal);font-weight:700}
.car-slide--ws figcaption b{color:var(--gold-d)}
.car-slide--comp figcaption b{color:var(--plum)}
.car-btn{position:absolute;top:42%;transform:translateY(-50%);z-index:2;width:46px;height:46px;border-radius:50%;
  border:1px solid var(--line2);background:#fff;color:var(--ink);font-size:28px;line-height:1;cursor:pointer;
  box-shadow:var(--shadow);display:grid;place-items:center;transition:background .15s ease,color .15s ease}
.car-btn:hover{background:var(--teal);color:#fff}
.car-btn--prev{left:-10px}
.car-btn--next{right:-10px}
@media (max-width:680px){
  .car-btn{display:none} /* swipe on touch */
  .car-slide{width:min(260px,76vw)}
}

/* ---------- FAQ ---------- */
.faq__grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:30px}
.faq details{background:#fff;border:1px solid var(--line);border-radius:12px;padding:6px 18px}
.faq summary{cursor:pointer;font-weight:700;padding:12px 0;list-style:none;font-size:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";float:right;color:var(--terra);font-weight:800}
.faq details[open] summary::after{content:"–"}
.faq details p{margin:0 0 14px;color:var(--ink2);font-size:15px}
.faq__cta{text-align:center;margin-top:30px}

/* ---------- Footer ---------- */
.site-foot{background:var(--ink);color:#cfc7b6;padding:26px 0}
.site-foot__inner{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap}
.site-foot .muted{color:#9a917f;font-size:13px;max-width:60ch}

/* ---------- Confirmation page ---------- */
.page-confirm{background:var(--paper2)}
.confirm{padding:48px 0 70px;min-height:60vh}
.confirm-card{background:#fff;border:1px solid var(--line);border-radius:22px;padding:36px;max-width:680px;margin:0 auto;box-shadow:var(--shadow)}
.confirm-badge{width:56px;height:56px;border-radius:50%;background:var(--teal);color:#fff;display:grid;place-items:center;font-size:28px;font-weight:800;margin:0 auto 14px}
.confirm-badge--wait{background:var(--gold);color:var(--ink)}
.confirm-title{font-family:var(--serif);font-weight:600;font-size:clamp(24px,3.4vw,32px);text-align:center;margin:6px 0 8px;line-height:1.12}
.confirm-sub{text-align:center;color:var(--ink2);max-width:48ch;margin:0 auto 24px}
.dl-list{display:grid;gap:10px}
.dl-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 16px;border:1px solid var(--line);border-radius:12px;background:#fffdf8}
.dl-title{font-weight:700}
.dl-desc{font-size:13px;color:var(--muted)}
.confirm-foot{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-top:22px;padding-top:18px;border-top:1px solid var(--line);font-size:14px}
.confirm-foot code{font-family:var(--mono);font-size:12px;background:var(--paper2);padding:3px 7px;border-radius:6px}

/* ============================================================
   Font theme: 'jobsite'  (set FONT_THEME = 'jobsite' in config.php)
   UK job-board look — Roboto body + bold Montserrat headings.
   Colours, layout and components stay identical.
   ============================================================ */
.theme-jobsite{
  --serif:"Montserrat",Arial,Helvetica,sans-serif;
  --sans:"Roboto",Arial,Helvetica,sans-serif;
  --mono:"Roboto",Arial,Helvetica,sans-serif;
}
.theme-jobsite .h2,.theme-jobsite .hero__title,.theme-jobsite .confirm-title,
.theme-jobsite .bookcard__title,.theme-jobsite .order__h,.theme-jobsite .upsell h3,
.theme-jobsite .toolcard h3,.theme-jobsite .part h3,.theme-jobsite .bignum,
.theme-jobsite .bookcard__price b,.theme-jobsite .order__total,
.theme-jobsite .upsell__price .now,.theme-jobsite .order__line .price{font-weight:800}
.theme-jobsite .hero__title{letter-spacing:-.02em}
.theme-jobsite .h2{letter-spacing:-.015em}
.theme-jobsite .brand-word{font-weight:800;font-size:20px;letter-spacing:-.01em}
.theme-jobsite .brand-word em,.theme-jobsite .bookcard__title em{font-style:normal}
.theme-jobsite .bookcard__tag{font-style:normal;font-family:var(--sans);font-size:14px;color:var(--ink2)}
.theme-jobsite .eyebrow{font-weight:700;letter-spacing:.14em}
.theme-jobsite .pill{font-weight:700;letter-spacing:.1em}
.theme-jobsite .car-slide figcaption{letter-spacing:.06em;font-weight:500}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width:920px){
  .hero__inner{grid-template-columns:1fr;gap:34px}
  .hero__art{order:-1}
  .reframe{grid-template-columns:1fr;gap:22px}
  .checkout{grid-template-columns:1fr;gap:28px}
  .grid-4{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:680px){
  body{font-size:16px}
  .site-nav a:not(.btn){display:none}
  .band{padding:46px 0}
  .hero{padding:40px 0 50px}
  .grid-3{grid-template-columns:1fr 1fr}
  .feature-row{grid-template-columns:1fr}
  .faq__grid{grid-template-columns:1fr}
  .upsell{flex-direction:column;align-items:flex-start}
  .upsell .btn{width:100%}
  .site-foot__inner{flex-direction:column;align-items:flex-start;text-align:left}
}
@media (max-width:420px){
  .grid-4,.grid-3{grid-template-columns:1fr}
  .brand-word{font-size:18px}
}
