/* Holiday-In-Waikato — base.css : design tokens, reset, shared atoms (shared by v1/v2/v3) */

:root {
  --green-900:#16301F;
  --green-800:#1F3B2C;
  --green-700:#2D5238;
  --green-600:#3E6B4A;
  --moss:#5C8A5E;
  --gold:#BE7C24;
  --gold-light:#E0A94B;
  --gold-ink:#8C5A17;   /* gold text on light backgrounds (AA) */
  --on-gold:#11100A;    /* text on gold backgrounds (AA) */
  --cream:#F2EADB;
  --paper:#FBF7EE;
  --ink:#211F1A;
  --slate:#586259;
  --line:rgba(33,31,26,.14);
  --line-light:rgba(255,255,255,.18);

  --font-display:"Fraunces", Georgia, "Times New Roman", serif;
  --font-body:"Inter", system-ui, -apple-system, "Segoe UI", sans-serif;

  --shadow-card:0 12px 32px rgba(22,48,31,.10);
  --shadow-lift:0 20px 48px rgba(22,48,31,.18);

  --maxw:1200px;
  --radius:8px;
  --radius-sm:4px;
}

*,*::before,*::after{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto;}}

body{
  margin:0;
  font-family:var(--font-body);
  font-size:1.0625rem;
  line-height:1.65;
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

h1,h2,h3,h4{
  font-family:var(--font-display);
  font-weight:500;
  line-height:1.08;
  margin:0 0 .5em;
  color:var(--green-900);
  font-optical-sizing:auto;
  letter-spacing:-0.01em;
}
p{margin:0 0 1.1em;}
img{max-width:100%;height:auto;display:block;}

a{color:var(--green-600);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1.5px;text-decoration-color:rgba(62,107,74,.4);transition:text-decoration-color .2s,color .2s;}
a:hover{text-decoration-color:var(--gold);color:var(--green-800);}

:focus-visible{outline:3px solid var(--gold);outline-offset:3px;border-radius:2px;}

/* ---- shared atoms ---- */
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(20px,5vw,48px);}
.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;}

.kicker{
  display:inline-block;
  font-family:var(--font-body);
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--gold-ink);
  margin:0 0 .9rem;
}
.kicker--light{color:var(--gold-light);}

.lede{font-size:clamp(1.1rem,2vw,1.3rem);line-height:1.6;color:var(--slate);}

.btn{
  display:inline-flex;align-items:center;gap:.55em;
  font-family:var(--font-body);font-weight:600;font-size:1rem;
  padding:.85em 1.6em;border-radius:var(--radius-sm);
  text-decoration:none;cursor:pointer;border:2px solid transparent;
  transition:transform .18s ease, background .2s, color .2s, border-color .2s, box-shadow .2s;
  min-height:48px;
}
.btn--primary{background:var(--gold);color:var(--on-gold);}
.btn--primary:hover{background:var(--gold-light);color:var(--on-gold);transform:translateY(-2px);box-shadow:0 10px 24px rgba(190,124,36,.32);}
.btn--ghost{background:transparent;color:var(--green-800);border-color:var(--green-800);}
.btn--ghost:hover{background:var(--green-800);color:var(--paper);transform:translateY(-2px);}
.btn--on-dark{background:var(--gold);color:var(--on-gold);}
.btn--on-dark:hover{background:var(--gold-light);color:var(--on-gold);transform:translateY(-2px);box-shadow:0 10px 24px rgba(0,0,0,.3);}
.btn--ghost-light{background:transparent;color:var(--paper);border-color:rgba(255,255,255,.5);}
.btn--ghost-light:hover{background:rgba(255,255,255,.12);border-color:var(--paper);transform:translateY(-2px);}

/* Cookie banner */
.cookie-banner{position:fixed;left:0;right:0;bottom:0;z-index:9999;background:var(--green-900);color:var(--paper);padding:1rem clamp(16px,4vw,32px);display:flex;flex-wrap:wrap;gap:1rem;align-items:center;justify-content:space-between;box-shadow:0 -6px 24px rgba(0,0,0,.25);border-top:2px solid rgba(224,169,75,.4);}
.cookie-banner__text{margin:0;font-size:.92rem;max-width:62ch;color:rgba(255,255,255,.9);}
.cookie-banner__text a{color:var(--gold-light);}
.cookie-banner__actions{display:flex;flex-wrap:wrap;gap:.6rem;}
.cookie-btn{font-family:var(--font-body);font-weight:600;font-size:.9rem;padding:.6em 1.1em;border-radius:4px;cursor:pointer;border:2px solid transparent;min-height:44px;transition:background .2s,color .2s,border-color .2s,transform .15s;}
.cookie-btn--accept{background:var(--gold);color:var(--on-gold);}
.cookie-btn--accept:hover{background:var(--gold-light);transform:translateY(-1px);}
.cookie-btn--ghost{background:transparent;color:var(--paper);border-color:rgba(255,255,255,.45);}
.cookie-btn--ghost:hover{border-color:var(--paper);background:rgba(255,255,255,.1);}
.cookie-modal{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;padding:1rem;}
.cookie-modal[hidden]{display:none;}
.cookie-modal__backdrop{position:absolute;inset:0;background:rgba(10,20,14,.6);}
.cookie-modal__panel{position:relative;background:var(--paper);color:var(--ink);max-width:520px;width:100%;border-radius:var(--radius);padding:clamp(1.5rem,4vw,2.2rem);box-shadow:var(--shadow-lift);max-height:90vh;overflow:auto;}
.cookie-modal__panel h2{font-size:1.5rem;margin-bottom:.4em;}
.cookie-modal__panel>p{color:var(--slate);font-size:.95rem;}
.cookie-cats{list-style:none;margin:1.2rem 0;padding:0;display:flex;flex-direction:column;gap:.4rem;}
.cookie-cat label{display:flex;gap:.8rem;align-items:flex-start;padding:.9rem;border:1px solid var(--line);border-radius:6px;cursor:pointer;}
.cookie-cat input{margin-top:.25rem;width:18px;height:18px;accent-color:var(--green-600);flex:none;}
.cookie-cat span{display:flex;flex-direction:column;}
.cookie-cat small{color:var(--slate);font-size:.85rem;margin-top:.15rem;}
.cookie-modal__actions{display:flex;gap:.6rem;justify-content:flex-end;flex-wrap:wrap;}
.cookie-modal__actions .cookie-btn--ghost{color:var(--green-800);border-color:var(--green-800);}
.cookie-modal__actions .cookie-btn--ghost:hover{background:var(--green-800);color:var(--paper);}
body.cookie-lock{overflow:hidden;}

.js .reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease, transform .7s ease;}
.js .reveal.is-visible{opacity:1;transform:none;}
@media (prefers-reduced-motion:reduce){.js .reveal{opacity:1;transform:none;transition:none;}}
