/* ============================================================
   Beachspot.ca — flat cartoon meets deadpan field-ops dossier
   ============================================================ */

:root {
  --sand:      #F7ECD2;
  --sand-deep: #ECD9AF;
  --paper:     #FFFDF7;
  --sea:       #0E7C8B;
  --sea-deep:  #0A5A66;
  --surf:      #36BECE;
  --sun:       #FFC93C;
  --coral:     #FF6B4A;
  --ink:       #14283D;
  --ink-soft:  #3a4f66;

  --r:   18px;
  --maxw: 1120px;
  --shadow: 0 14px 34px -18px rgba(20,40,61,.45);
  --line: 3px solid var(--ink);
}

* { box-sizing: border-box; margin: 0; }

html { scroll-behavior: smooth; }

body {
  font-family: "Nunito Sans", system-ui, sans-serif;
  color: var(--ink);
  background: var(--sand);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

h1, h2, h3, .wordmark, .footer-mark {
  font-family: "Fredoka", system-ui, sans-serif;
  line-height: 1.04;
  letter-spacing: -.01em;
}

img { max-width: 100%; display: block; height: auto; }

/* ---- The signature device: mono "ops tags" ---- */
.ops-tag {
  font-family: "Space Mono", monospace;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--coral);
  display: inline-block;
}
.ops-tag.light { color: var(--sun); }

/* ---- Buttons ---- */
.btn {
  --bg: var(--ink); --fg: #fff;
  font-family: "Fredoka", sans-serif;
  font-weight: 600;
  background: var(--bg);
  color: var(--fg);
  border: var(--line);
  border-radius: 999px;
  padding: .7em 1.4em;
  text-decoration: none;
  display: inline-block;
  box-shadow: 4px 4px 0 var(--ink);
  transition: transform .12s ease, box-shadow .12s ease;
  white-space: nowrap;
}
.btn:hover { transform: translate(-2px,-2px); box-shadow: 6px 6px 0 var(--ink); }
.btn:active { transform: translate(2px,2px); box-shadow: 1px 1px 0 var(--ink); }
.btn:focus-visible { outline: 4px solid var(--surf); outline-offset: 3px; }
.btn-lg  { font-size: 1.05rem; padding: .8em 1.6em; }
.btn-xl  { font-size: 1.25rem; padding: .9em 2em; --bg: var(--coral); }
.btn-sm  { font-size: .85rem; padding: .45em 1.1em; box-shadow: 3px 3px 0 var(--ink); }
.btn-ghost { --bg: transparent; --fg: var(--ink); }

/* ============================================================
   Top bar
   ============================================================ */
.topbar {
  position: sticky; top: 0; z-index: 50;
  display: flex; align-items: center; gap: 1rem;
  padding: .7rem clamp(1rem, 4vw, 2.5rem);
  background: var(--sand);
  border-bottom: var(--line);
}
.wordmark {
  font-size: 1.6rem; font-weight: 700; color: var(--ink);
  text-decoration: none; letter-spacing: -.02em;
}
.wordmark span { color: var(--coral); }
.topbar-tag {
  font-family: "Space Mono", monospace;
  font-size: .68rem; letter-spacing: .14em; color: var(--ink-soft);
  margin-left: auto;
}
.topbar .btn { margin-left: 0; }
@media (max-width: 620px) { .topbar-tag { display: none; } .topbar .btn { margin-left: auto; } }

/* ============================================================
   Hero
   ============================================================ */
.hero {
  max-width: var(--maxw);
  margin: clamp(2rem, 6vw, 4.5rem) auto clamp(1rem,4vw,2rem);
  padding: 0 clamp(1rem, 4vw, 2.5rem);
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: clamp(1.5rem, 4vw, 3rem);
  align-items: center;
}
.hero-copy .ops-tag { margin-bottom: 1rem; }
.hero h1 {
  font-size: clamp(2.1rem, 5.2vw, 3.7rem);
  font-weight: 700;
  margin-bottom: 1.1rem;
}
.slogan {
  font-family: "Fredoka", sans-serif; font-weight: 700;
  font-size: clamp(1.15rem, 2.4vw, 1.5rem);
  color: var(--coral); margin-bottom: 1rem;
  display: inline-block; rotate: -1.5deg;
  border-bottom: 4px solid var(--sun); padding-bottom: 2px;
}
.lede { font-size: 1.15rem; color: var(--ink-soft); max-width: 34ch; margin-bottom: 1.6rem; }
.hero-actions { display: flex; flex-wrap: wrap; gap: .8rem; margin-bottom: 1rem; }
.hero-fine {
  font-family: "Space Mono", monospace;
  font-size: .72rem; color: var(--ink-soft); letter-spacing: .04em;
}

.hero-art { position: relative; }
.hero-art img {
  border: var(--line);
  border-radius: var(--r);
  box-shadow: var(--shadow);
  background: var(--surf);
  width: 100%;
  rotate: 1.5deg;
}
.art-stamp {
  position: absolute; bottom: -14px; left: -10px;
  font-family: "Space Mono", monospace; font-weight: 700;
  font-size: .68rem; letter-spacing: .1em;
  background: var(--sun); color: var(--ink);
  border: var(--line); border-radius: 6px;
  padding: .3em .7em;
  rotate: -4deg;
}

/* ============================================================
   Wave dividers
   ============================================================ */
.wave { line-height: 0; }
.wave svg { width: 100%; height: clamp(50px, 7vw, 90px); display: block; }
.wave-sea svg path { fill: var(--sea); }
.wave-sand svg path { fill: var(--sand); }

/* ============================================================
   Section scaffolding
   ============================================================ */
.section-head { max-width: var(--maxw); margin: 0 auto; padding: 0 clamp(1rem,4vw,2.5rem) 2.2rem; }
.section-head h2 { font-size: clamp(1.7rem, 4vw, 2.7rem); margin-top: .5rem; }
.section-sub { color: var(--ink-soft); margin-top: .7rem; font-size: 1.05rem; }

/* ---- How it works (on sea) ---- */
.how { background: var(--sea); color: var(--paper); padding: clamp(2.5rem,6vw,4rem) 0; }
.how .section-head h2 { color: var(--paper); }
.steps {
  list-style: none; padding: 0 clamp(1rem,4vw,2.5rem); margin: 0 auto;
  max-width: var(--maxw);
  display: grid; grid-template-columns: repeat(3,1fr); gap: 1.4rem;
}
.steps li {
  background: rgba(255,255,255,.07);
  border: 3px solid rgba(255,255,255,.25);
  border-radius: var(--r);
  padding: 1.6rem;
}
.step-no {
  font-family: "Space Mono", monospace; font-weight: 700;
  font-size: 1.1rem; color: var(--sun);
  display: inline-block; margin-bottom: .6rem;
  border: 2px solid var(--sun); border-radius: 8px; padding: .1em .5em;
}
.steps h3 { font-size: 1.4rem; margin-bottom: .4rem; }
.steps p { color: rgba(255,255,255,.85); }
.steps em { color: var(--sun); font-style: normal; font-weight: 700; }

/* ---- Service tiers (on sand) ---- */
.tiers { padding: clamp(2.5rem,6vw,4rem) 0 clamp(2rem,5vw,3rem); }
.tier-grid {
  max-width: var(--maxw); margin: 0 auto; padding: 0 clamp(1rem,4vw,2.5rem);
  display: grid; grid-template-columns: 1fr 1fr; gap: 1.6rem; align-items: start;
}
.tier {
  background: var(--paper); border: var(--line); border-radius: var(--r);
  padding: 1.8rem; box-shadow: var(--shadow);
}
.tier-label {
  font-family: "Space Mono", monospace; font-weight: 700; font-size: .7rem;
  letter-spacing: .14em; color: var(--ink-soft);
}
.tier h3 { font-size: 1.8rem; margin: .3rem 0 .6rem; }
.tier p { color: var(--ink-soft); }
.tier-list { list-style: none; padding: 0; margin: 1.1rem 0 0; }
.tier-list li { padding: .35rem 0 .35rem 1.7rem; position: relative; }
.tier-list li::before {
  content: "⛱"; position: absolute; left: 0; top: .35rem;
  font-size: .95rem;
}
.tier-feature { background: var(--sun); }
.tier-feature .tier-label { color: var(--ink); }
.tier-feature p { color: var(--ink); }
.tier-art {
  margin-top: 1.4rem; border: var(--line); border-radius: 14px;
  background: var(--paper); rotate: -1.5deg;
}

/* ---- Locations ---- */
.locations { padding: clamp(2.5rem,6vw,4rem) 0; }
.loc-grid {
  max-width: var(--maxw); margin: 0 auto; padding: 0 clamp(1rem,4vw,2.5rem);
  display: grid; grid-template-columns: 1fr 1fr; gap: 1.6rem;
}
.loc-card {
  font: inherit; text-align: left; cursor: pointer;
  background: var(--paper); border: var(--line); border-radius: var(--r);
  padding: 0 0 1.4rem; overflow: hidden;
  box-shadow: var(--shadow);
  transition: transform .14s ease, box-shadow .14s ease;
}
.loc-card img { border-bottom: var(--line); aspect-ratio: 16/10; object-fit: cover; width: 100%; }
.loc-card .ops-tag { margin: 1.1rem 1.4rem .2rem; }
.loc-card h3 { font-size: 1.7rem; margin: 0 1.4rem .3rem; }
.loc-card p { margin: 0 1.4rem; color: var(--ink-soft); }
.loc-pick {
  display: inline-block; margin: 1rem 1.4rem 0;
  font-family: "Space Mono", monospace; font-weight: 700; font-size: .78rem;
  letter-spacing: .06em; color: var(--sea);
}
.loc-pick::after { content: " →"; }
.loc-card:hover { transform: translateY(-4px); box-shadow: 0 22px 40px -20px rgba(20,40,61,.55); }
.loc-card:focus-visible { outline: 4px solid var(--surf); outline-offset: 3px; }
.loc-card.selected { border-color: var(--coral); background: #fff6f2; }
.loc-card.selected .loc-pick { color: var(--coral); }
.loc-card.selected .loc-pick::after { content: " ✓ DROP ZONE SET"; }

/* ---- Operatives (on sea) ---- */
.operatives { background: var(--sea); color: var(--paper); padding: clamp(2.5rem,6vw,4rem) 0; }
.operatives .section-head h2 { color: var(--paper); }
.op-grid {
  max-width: var(--maxw); margin: 0 auto; padding: 0 clamp(1rem,4vw,2.5rem);
  display: grid; grid-template-columns: repeat(3,1fr); gap: 1.4rem;
}
.op-card {
  background: var(--paper); color: var(--ink);
  border: var(--line); border-radius: var(--r);
  padding: 1.6rem; text-align: center; box-shadow: var(--shadow);
}
.op-card img {
  width: 132px; height: 132px; object-fit: cover; margin: 0 auto .9rem;
  border: var(--line); border-radius: 50%; background: var(--sand-deep);
}
.op-card h3 { font-size: 1.5rem; }
.op-meta {
  font-family: "Space Mono", monospace; font-weight: 700; font-size: .68rem;
  letter-spacing: .08em; color: var(--coral); margin: .2rem 0 .7rem;
}
.op-card p:last-child { color: var(--ink-soft); }

/* ---- CTA band ---- */
.cta-band {
  background: var(--coral); color: #fff;
  text-align: center; padding: clamp(3rem,7vw,4.5rem) clamp(1rem,4vw,2.5rem);
}
.cta-band h2 { font-size: clamp(1.9rem,4.5vw,3rem); margin: .6rem auto .8rem; max-width: 16ch; }
.cta-band p { max-width: 46ch; margin: 0 auto 1.8rem; font-size: 1.1rem; }
.cta-band .btn-xl { --bg: var(--ink); }
.cta-fine { font-family: "Space Mono", monospace; font-size: .75rem; margin-top: 1.1rem !important; opacity: .9; }

/* ---- Footer ---- */
.footer { background: var(--ink); color: #c5d2de; padding: clamp(2.5rem,5vw,3.5rem) clamp(1rem,4vw,2.5rem); text-align: center; }
.footer-mark { font-size: 1.8rem; color: #fff; margin-bottom: 1.1rem; }
.footer-mark span { color: var(--coral); }
.footer-slogan {
  font-family: "Fredoka", sans-serif; font-weight: 600;
  color: var(--sun); font-size: 1.05rem; margin-bottom: 1.4rem;
}
.disclaimer {
  font-family: "Space Mono", monospace; font-size: .76rem; line-height: 1.8;
  max-width: 70ch; margin: 0 auto 1.4rem; color: #8ea3b6;
}
.copyright { font-size: .85rem; }
.copyright a { color: var(--sun); }

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 860px) {
  .hero { grid-template-columns: 1fr; }
  .hero-art { order: -1; max-width: 460px; }
  .steps, .op-grid { grid-template-columns: 1fr; }
  .tier-grid, .loc-grid { grid-template-columns: 1fr; }
}

@media (prefers-reduced-motion: reduce) {
  * { scroll-behavior: auto; transition: none !important; }
  .hero-art img, .tier-art, .art-stamp { rotate: 0deg; }
}
