/* ===================================================================
   Red Mountain Community School — Book a Tour
   Literary direct-response landing page.

   System (carried over from the ad campaign):
   - Type:  Source Serif 4 (literary headlines/quotes) + Hanken Grotesk (quiet supporting text)
   - Color: brick / oxblood red, warm cream, sage-taupe green, acorn taupe, ochre accent
   - Texture: paper grain over everything, soft watercolor washes, the acorn as a quiet motif
   Header (#f6f5f1) and footer (#bcbba9) are matched to the school's live site.
   =================================================================== */

:root{
  --brick:#9a3724;
  --brick-bright:#b0473b;
  --oxblood:#5d231a;
  --cream:#f4ead6;
  --cream-deep:#ecdfc5;
  --paper:#f7efde;
  --ink:#2c241d;
  --ink-soft:#5b5043;
  --sage:#8f9277;
  --sage-deep:#6b6f55;
  --acorn:#b58a63;
  --ochre:#c4882c;
  --header:#f6f5f1;
  --footer:#bcbba9;
  --maxw:1180px;
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  background:var(--cream);
  color:var(--ink);
  font-family:"Hanken Grotesk",system-ui,sans-serif;
  -webkit-font-smoothing:antialiased;
  line-height:1.5;
  overflow-x:hidden;
}
/* paper grain over everything */
body::after{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:200;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix type='saturate' values='0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.4'/></svg>");
  mix-blend-mode:multiply;opacity:.07;
}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}

/* ---------------- STICKY HEADER ---------------- */
header.bar{
  position:sticky;top:0;z-index:100;
  background:color-mix(in srgb, var(--header) 92%, transparent);
  backdrop-filter:blur(10px);
  border-bottom:1px solid color-mix(in srgb, var(--ink) 12%, transparent);
}
.bar-inner{
  max-width:var(--maxw);margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 22px;gap:16px;
}
.bar img{height:38px;width:auto;}
.btn{
  display:inline-flex;align-items:center;gap:11px;
  font-family:"Hanken Grotesk",sans-serif;font-weight:700;
  letter-spacing:.01em;cursor:pointer;border:none;white-space:nowrap;
  background:var(--brick);color:var(--cream);
  border-radius:999px;
  transition:background .18s ease, transform .18s ease;
}
.btn:hover{background:var(--oxblood);transform:translateY(-1px);}
.btn svg{display:block;}
.btn-sm{font-size:16px;padding:12px 22px;}
.btn-lg{font-size:20px;padding:18px 34px;}
.btn-ghost{
  background:transparent;color:var(--brick);
  box-shadow:inset 0 0 0 2px color-mix(in srgb, var(--brick) 40%, transparent);
}
.btn-ghost:hover{background:transparent;color:var(--oxblood);box-shadow:inset 0 0 0 2px var(--oxblood);}

/* ---------------- HERO ---------------- */
.hero{
  position:relative;
  max-width:var(--maxw);margin:0 auto;
  padding:clamp(40px,7vw,86px) 22px clamp(30px,5vw,60px);
  text-align:center;
}
/* soft watercolor washes */
.wash{position:absolute;border-radius:50%;filter:blur(20px);pointer-events:none;z-index:0;opacity:.5;}
.wash-1{width:520px;height:440px;left:-160px;top:20px;
  background:radial-gradient(50% 50% at 50% 50%, color-mix(in srgb,var(--sage) 55%, transparent), transparent 70%);}
.wash-2{width:480px;height:420px;right:-150px;top:120px;
  background:radial-gradient(50% 50% at 50% 50%, color-mix(in srgb,var(--ochre) 40%, transparent), transparent 70%);}

.hero > *:not(.wash){position:relative;z-index:1;}
.eyebrow{
  font-family:"Hanken Grotesk",sans-serif;
  font-size:clamp(12px,2.6vw,14px);font-weight:600;
  letter-spacing:.24em;text-transform:uppercase;color:var(--brick);
  display:inline-flex;align-items:center;gap:14px;margin-bottom:24px;
}
.eyebrow::before,.eyebrow::after{content:"";width:30px;height:1.5px;background:currentColor;opacity:.5;}
h1.hero-title{
  font-family:"Source Serif 4",Georgia,serif;font-weight:600;
  color:var(--oxblood);
  font-size:clamp(34px,5.6vw,62px);line-height:1.07;letter-spacing:-.018em;
  text-wrap:balance;
  margin:0 auto;max-width:19ch;
}
h1 .hand{font-style:italic;position:relative;white-space:nowrap;color:var(--brick);}
h1 .hand::after{
  content:"";position:absolute;left:-2px;right:-4px;bottom:.02em;height:.22em;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 320 26'><path d='M6 16 C 70 6 130 22 190 12 S 300 8 314 15' fill='none' stroke='%23c4882c' stroke-width='9' stroke-linecap='round' opacity='0.9'/></svg>");
  background-repeat:no-repeat;background-size:100% 100%;
}
.subline{
  font-family:"Source Serif 4",Georgia,serif;
  font-size:clamp(18px,3.2vw,23px);line-height:1.5;color:var(--ink-soft);
  max-width:40ch;margin:26px auto 0;text-wrap:pretty;
}
.hero-cta{margin-top:34px;display:flex;flex-direction:column;align-items:center;gap:14px;}
.hero-note{font-size:14px;color:var(--ink-soft);letter-spacing:.02em;}

/* ---------------- VIDEO PLAYER (vertical 9:16) ---------------- */
.player{
  position:relative;width:100%;max-width:392px;margin:clamp(34px,5vw,52px) auto 0;
  aspect-ratio:9/16;border-radius:12px;overflow:hidden;
  background:#2c241d;cursor:pointer;
  box-shadow:0 30px 70px -28px rgba(44,20,12,.6), 0 2px 0 rgba(255,255,255,.25) inset;
  z-index:1;
}
.player img{width:100%;height:100%;object-fit:cover;object-position:center 42%;}
.player .veil{position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(40,20,12,.18), rgba(40,20,12,.42));}
.player .play{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:84px;height:84px;border-radius:50%;
  background:color-mix(in srgb, var(--cream) 92%, transparent);
  display:grid;place-items:center;
  box-shadow:0 10px 30px rgba(0,0,0,.3);transition:transform .18s ease, background .18s ease;
}
.player:hover .play{transform:translate(-50%,-50%) scale(1.06);background:var(--cream);}
.player .play svg{margin-left:5px;}
.player .ph-label{
  position:absolute;left:0;right:0;bottom:0;
  padding:34px 24px 18px;color:var(--cream);
  font-family:"Hanken Grotesk",sans-serif;font-size:14px;letter-spacing:.14em;text-transform:uppercase;
  display:flex;align-items:center;gap:10px;
  background:linear-gradient(0deg, rgba(40,20,12,.6), transparent);
}
.player .ph-label .dot{width:8px;height:8px;border-radius:50%;background:var(--ochre);}
.player[data-placeholder]::before{
  content:"VIDEO";position:absolute;top:16px;right:18px;z-index:3;
  font-family:"Hanken Grotesk",sans-serif;font-size:11px;font-weight:700;letter-spacing:.18em;
  color:var(--cream);opacity:.55;
}
/* Vimeo player injected on click into a .player[data-vimeo] facade */
.player[data-vimeo]:focus-visible{outline:3px solid var(--ochre);outline-offset:3px;}
.player video,.player iframe{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;border:0;background:#2c241d;}
.player.is-playing{cursor:default;}

/* ---------------- PROMISE BAND ---------------- */
.promise{
  background:var(--oxblood);color:var(--cream);
  position:relative;margin-top:clamp(50px,7vw,90px);overflow:hidden;
}
.promise::before{content:"";position:absolute;left:0;right:0;top:0;height:5px;background:var(--ochre);opacity:.85;}
.promise-inner{
  max-width:920px;margin:0 auto;padding:clamp(54px,8vw,96px) 24px;text-align:center;position:relative;
}
.promise .acorn{width:42px;height:auto;margin:0 auto 26px;opacity:.9;}
.promise p{
  font-family:"Source Serif 4",Georgia,serif;font-weight:400;
  font-size:clamp(23px,3.8vw,34px);line-height:1.45;letter-spacing:-.005em;
  text-wrap:pretty;
}
.promise p .em{font-style:italic;color:#f0cf96;}
.promise .motto{
  display:block;margin-top:30px;
  font-family:"Hanken Grotesk",sans-serif;font-weight:600;
  font-size:14px;letter-spacing:.22em;text-transform:uppercase;color:color-mix(in srgb,var(--cream) 72%, transparent);
}

/* ---------------- GENERIC SECTION ---------------- */
section.band{max-width:var(--maxw);margin:0 auto;padding:clamp(56px,8vw,108px) 22px;}
.sec-head{text-align:center;max-width:46ch;margin:0 auto clamp(36px,5vw,58px);}
.sec-eyebrow{
  font-family:"Hanken Grotesk",sans-serif;font-size:13px;font-weight:600;
  letter-spacing:.24em;text-transform:uppercase;color:var(--brick);
  display:inline-flex;align-items:center;gap:13px;margin-bottom:18px;
}
.sec-eyebrow::before,.sec-eyebrow::after{content:"";width:26px;height:1.5px;background:currentColor;opacity:.5;}
.sec-title{
  font-family:"Source Serif 4",Georgia,serif;font-weight:600;color:var(--oxblood);
  font-size:clamp(30px,4.6vw,50px);line-height:1.08;letter-spacing:-.015em;text-wrap:balance;
}
.sec-intro{
  font-family:"Source Serif 4",Georgia,serif;font-size:clamp(18px,2.6vw,22px);
  line-height:1.5;color:var(--ink-soft);margin-top:18px;text-wrap:pretty;
}

/* ---------------- FAMILY STORIES ---------------- */
.stories-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.4vw,28px);}
.story{display:flex;flex-direction:column;gap:16px;}
.story .player{margin:0;max-width:none;box-shadow:0 18px 44px -22px rgba(44,20,12,.5), 0 2px 0 rgba(255,255,255,.25) inset;}
.story .play{width:62px;height:62px;}
.story .play svg{width:22px;height:25px;}
.story-cap{display:flex;flex-direction:column;gap:3px;padding:0 2px;}
.story-cap .fam{font-family:"Source Serif 4",serif;font-style:italic;font-weight:600;font-size:21px;color:var(--oxblood);}
.story-cap .why{font-family:"Hanken Grotesk",sans-serif;font-size:15px;color:var(--ink-soft);letter-spacing:.01em;}

/* ---------------- DISTINCTIVES ---------------- */
.distinctives{background:var(--paper);border-top:1px solid color-mix(in srgb,var(--ink) 9%,transparent);border-bottom:1px solid color-mix(in srgb,var(--ink) 9%,transparent);}
.dist-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:color-mix(in srgb,var(--ink) 11%,transparent);
  border:1px solid color-mix(in srgb,var(--ink) 11%,transparent);border-radius:6px;overflow:hidden;}
.dist{background:var(--cream);padding:clamp(28px,3.4vw,40px) clamp(24px,2.8vw,34px);display:flex;flex-direction:column;gap:16px;}
.dist .ic{width:46px;height:46px;color:var(--brick);}
.dist h3{font-family:"Source Serif 4",serif;font-weight:600;font-size:clamp(20px,2.6vw,25px);line-height:1.16;color:var(--oxblood);letter-spacing:-.01em;}
.dist p{font-family:"Hanken Grotesk",sans-serif;font-size:16px;line-height:1.5;color:var(--ink-soft);text-wrap:pretty;}

/* ---------------- AFFORDABILITY ---------------- */
.afford{background:var(--sage-deep);color:var(--cream);position:relative;overflow:hidden;}
.afford::before{content:"";position:absolute;left:0;right:0;top:0;height:5px;background:var(--ochre);opacity:.8;}
.afford-inner{max-width:880px;margin:0 auto;padding:clamp(54px,8vw,96px) 24px;text-align:center;}
.afford .amt{display:inline-block;font-family:"Source Serif 4",serif;font-style:italic;font-weight:600;
  font-size:clamp(15px,2.4vw,17px);letter-spacing:.16em;text-transform:uppercase;color:#f0cf96;margin-bottom:22px;}
.afford h2{font-family:"Source Serif 4",Georgia,serif;font-weight:600;font-size:clamp(28px,4.4vw,46px);line-height:1.1;letter-spacing:-.015em;color:var(--cream);text-wrap:balance;}
.afford p{font-family:"Source Serif 4",Georgia,serif;font-size:clamp(18px,2.8vw,23px);line-height:1.55;color:color-mix(in srgb,var(--cream) 88%,transparent);max-width:46ch;margin:22px auto 0;text-wrap:pretty;}

/* ---------------- BOOK A TOUR ---------------- */
.tour{background:var(--cream);}
.tour-inner{max-width:760px;margin:0 auto;padding:clamp(56px,8vw,104px) 22px;text-align:center;}
.tour p.lead{font-family:"Source Serif 4",Georgia,serif;font-size:clamp(18px,2.8vw,22px);line-height:1.55;color:var(--ink-soft);max-width:48ch;margin:18px auto 0;text-wrap:pretty;}
.form-embed{
  margin:clamp(34px,5vw,48px) auto 0;background:var(--paper);
  border:1.5px solid color-mix(in srgb,var(--brick) 30%,transparent);border-radius:10px;
  padding:clamp(34px,5vw,56px) clamp(24px,4vw,48px);position:relative;
  box-shadow:0 22px 50px -30px rgba(44,20,12,.4);
}
.form-embed .tag{position:absolute;top:14px;right:16px;font-family:"Hanken Grotesk",sans-serif;font-size:10px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:color-mix(in srgb,var(--brick) 55%,transparent);}
.form-embed .fe-title{font-family:"Source Serif 4",serif;font-style:italic;font-weight:600;font-size:clamp(20px,3vw,26px);color:var(--oxblood);}
.form-embed .fe-rows{display:flex;flex-direction:column;gap:14px;margin:26px auto 0;max-width:420px;text-align:left;}
.form-embed .fe-row{height:52px;border-radius:8px;background:var(--cream);border:1px solid color-mix(in srgb,var(--ink) 16%,transparent);display:flex;align-items:center;padding:0 16px;color:color-mix(in srgb,var(--ink) 42%,transparent);font-size:15px;}
.form-embed .fe-note{margin-top:24px;font-family:"Hanken Grotesk",sans-serif;font-size:13px;letter-spacing:.04em;color:var(--ink-soft);opacity:.8;}
.sampling{margin-top:30px;font-family:"Hanken Grotesk",sans-serif;font-size:15px;color:var(--ink-soft);}
.sampling b{color:var(--brick);font-weight:600;}

/* ---------------- FOOTER ---------------- */
footer.foot{background:var(--footer);color:color-mix(in srgb, var(--ink) 78%, transparent);}
.foot-inner{max-width:var(--maxw);margin:0 auto;padding:clamp(48px,6vw,72px) 22px clamp(30px,4vw,42px);
  display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px;align-items:start;}
.foot-logo{height:46px;width:auto;margin-bottom:18px;opacity:.95;filter:brightness(0) invert(1);}
.foot-brand p{font-family:"Source Serif 4",serif;font-size:16px;line-height:1.55;max-width:34ch;color:color-mix(in srgb,var(--ink) 66%,transparent);}
.foot-col h4{font-family:"Hanken Grotesk",sans-serif;font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--brick);margin-bottom:14px;}
.foot-col a,.foot-col p{display:block;font-family:"Hanken Grotesk",sans-serif;font-size:15px;line-height:1.9;color:color-mix(in srgb,var(--ink) 82%,transparent);}
.foot-col a{transition:color .15s ease;}
.foot-col a:hover{color:var(--brick);}
.foot-bottom{max-width:var(--maxw);margin:0 auto;padding:18px 22px 30px;border-top:1px solid color-mix(in srgb,var(--ink) 18%,transparent);
  display:flex;flex-wrap:wrap;gap:8px 18px;justify-content:space-between;font-family:"Hanken Grotesk",sans-serif;font-size:13px;color:color-mix(in srgb,var(--ink) 52%,transparent);}

@media (max-width:880px){
  .stories-grid{grid-template-columns:1fr;max-width:480px;margin-inline:auto;}
  .dist-grid{grid-template-columns:1fr 1fr;}
  .foot-inner{grid-template-columns:1fr 1fr;}
  .foot-brand{grid-column:1 / -1;}
}
@media (max-width:640px){
  .bar img{height:32px;}
  .wash{opacity:.4;}
  .dist-grid{grid-template-columns:1fr;}
  .foot-inner{grid-template-columns:1fr;gap:28px;}
  .player .play{width:64px;height:64px;}
}

/* Respect users who prefer reduced motion */
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto;}
  *{transition:none !important;}
}
