/* =========================================================================
   Alderney Children's Centre — Design System
   Warm & polished. Built from scratch.
   Palette: sage/forest green + warm terracotta + golden + cream
   Type: Fraunces (display) + Nunito Sans (body)
   ========================================================================= */

/* ---------- Design tokens ---------- */
:root {
  /* Brand */
  --forest:      #1f4d3f;
  --sage:        #3a7a64;
  --sage-soft:   #e7f0ea;
  --terracotta:  #d96f4c;
  --terracotta-d:#c25a39;
  --gold:        #e9a93c;
  --plum:        #7d5a78;
  --sky:         #5b8aa6;

  /* Neutrals */
  --ink:         #20302b;
  --ink-soft:    #4a5a53;
  --cream:       #fbf6ee;
  --cream-2:     #f4ead9;
  --paper:       #ffffff;
  --line:        #e7ddcd;
  --grain: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23g)' opacity='0.07'/%3E%3C/svg%3E");

  /* Functional */
  --shadow-sm: 0 2px 8px rgba(31,77,63,.06), 0 1px 2px rgba(31,77,63,.06);
  --shadow-md: 0 14px 36px -12px rgba(31,77,63,.20), 0 4px 12px -6px rgba(31,77,63,.12);
  --shadow-lg: 0 30px 70px -24px rgba(31,77,63,.30);
  --ring: 0 0 0 3px rgba(58,122,100,.35);

  --radius-sm: 12px;
  --radius:    20px;
  --radius-lg: 30px;
  --radius-xl: 44px;

  --maxw: 1200px;
  --gutter: clamp(1.25rem, 4vw, 2.5rem);

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

  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset / base ---------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; }
}

body {
  font-family: var(--font-body);
  color: var(--ink);
  background: var(--cream);
  line-height: 1.65;
  font-size: clamp(1rem, .96rem + .25vw, 1.075rem);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

img { max-width: 100%; display: block; }
a { color: var(--sage); text-decoration: none; transition: color .2s var(--ease); }
a:hover { color: var(--terracotta); }

h1, h2, h3, h4 { font-family: var(--font-display); font-weight: 600; line-height: 1.08; color: var(--forest); letter-spacing: -.01em; }
h1 { font-size: clamp(2.4rem, 1.6rem + 3.6vw, 4.2rem); }
h2 { font-size: clamp(1.9rem, 1.4rem + 2vw, 2.9rem); }
h3 { font-size: clamp(1.25rem, 1.1rem + .6vw, 1.55rem); }
h4 { font-size: 1.05rem; letter-spacing: .02em; }
p { color: var(--ink-soft); }
strong { color: var(--ink); font-weight: 700; }

/* ---------- Layout helpers ---------- */
.container { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: var(--gutter); }
.section { padding-block: clamp(3.5rem, 2.5rem + 5vw, 7rem); position: relative; }
.section--tight { padding-block: clamp(2.5rem, 2rem + 3vw, 4.5rem); }
.center { text-align: center; }
.narrow { max-width: 680px; margin-inline: auto; }

.eyebrow {
  display: inline-flex; align-items: center; gap: .5rem;
  font-family: var(--font-body); font-weight: 800;
  font-size: .78rem; letter-spacing: .14em; text-transform: uppercase;
  color: var(--terracotta-d);
  margin-bottom: 1rem;
}
.eyebrow::before { content: ""; width: 1.6rem; height: 2px; border-radius: 2px; background: var(--terracotta); }
.center .eyebrow::before { display: none; }

.lead { font-size: clamp(1.1rem, 1rem + .5vw, 1.3rem); color: var(--ink-soft); line-height: 1.6; }

/* Background variants */
.bg-cream { background: var(--grain), radial-gradient(72% 92% at 100% -12%, rgba(233,169,60,.30), transparent 62%), radial-gradient(66% 86% at -8% 112%, rgba(58,122,100,.22), transparent 62%), linear-gradient(165deg, #fdf3de 0%, var(--cream) 52%, #f0e1cb 100%); }
.bg-cream-2 { background: var(--grain), radial-gradient(72% 92% at 0% -12%, rgba(217,111,76,.24), transparent 62%), radial-gradient(66% 86% at 100% 112%, rgba(233,169,60,.24), transparent 62%), linear-gradient(165deg, #f2e4cc 0%, var(--cream-2) 100%); }
.bg-paper { background: var(--grain), radial-gradient(62% 82% at 100% 0%, rgba(58,122,100,.16), transparent 58%), radial-gradient(56% 76% at 0% 100%, rgba(233,169,60,.15), transparent 58%), linear-gradient(180deg, #ffffff 0%, #f5eddd 100%); }
.bg-sage { background: var(--grain), radial-gradient(74% 96% at 100% -12%, rgba(58,122,100,.32), transparent 62%), radial-gradient(66% 86% at -8% 112%, rgba(233,169,60,.20), transparent 62%), linear-gradient(165deg, #e1efe5 0%, var(--sage-soft) 58%, #d4e9da 100%); }
.bg-forest { background: radial-gradient(120% 140% at 85% 0%, #2a6451 0%, var(--forest) 60%); color: #eaf3ee; }
.bg-forest h1, .bg-forest h2, .bg-forest h3, .bg-forest h4 { color: #fff; }
.bg-forest p { color: #cfe2d8; }
.bg-forest .eyebrow { color: var(--gold); }
.bg-forest .eyebrow::before { background: var(--gold); }

/* ---------- Buttons ---------- */
.btn {
  --btn-bg: var(--sage); --btn-fg: #fff;
  display: inline-flex; align-items: center; justify-content: center; gap: .55rem;
  font-family: var(--font-body); font-weight: 800; font-size: 1rem;
  padding: .92rem 1.7rem; border-radius: 999px;
  background: var(--btn-bg); color: var(--btn-fg);
  border: 2px solid transparent; cursor: pointer;
  transition: transform .25s var(--ease), box-shadow .25s var(--ease), background .2s var(--ease);
  box-shadow: var(--shadow-sm);
  text-align: center; white-space: nowrap;
}
.btn:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); color: #fff; }
.btn:active { transform: translateY(0); }
.btn svg { width: 1.1em; height: 1.1em; }
.btn--accent { --btn-bg: var(--terracotta); }
.btn--accent:hover { background: var(--terracotta-d); }
.btn--gold { --btn-bg: var(--gold); --btn-fg: #5a3d12; }
.btn--gold:hover { color: #5a3d12; }
.btn--ghost { background: transparent; color: var(--forest); border-color: var(--forest); box-shadow: none; }
.btn--ghost:hover { background: var(--forest); color: #fff; }
.btn--on-dark { background: #fff; color: var(--forest); }
.btn--on-dark:hover { background: var(--cream); color: var(--forest); }
.btn--outline-light { background: transparent; color: #fff; border-color: rgba(255,255,255,.6); box-shadow: none; }
.btn--outline-light:hover { background: rgba(255,255,255,.14); color: #fff; }
.btn--lg { padding: 1.05rem 2.2rem; font-size: 1.08rem; }
.btn-row { display: flex; flex-wrap: wrap; gap: .85rem; }
.center .btn-row { justify-content: center; }

.tlink { font-weight: 800; display: inline-flex; align-items: center; gap: .4rem; }
.tlink svg { width: 1.1em; height: 1.1em; transition: transform .25s var(--ease); }
.tlink:hover svg { transform: translateX(4px); }

/* ---------- Top bar ---------- */
.topbar { background: var(--forest); color: #d8e8df; font-size: .82rem; }
.topbar .container { display: flex; justify-content: space-between; align-items: center; gap: 1rem; padding-block: .5rem; flex-wrap: wrap; }
.topbar a { color: #eaf3ee; font-weight: 700; }
.topbar a:hover { color: var(--gold); }
.topbar-info { display: flex; gap: 1.4rem; flex-wrap: wrap; }
.topbar-info span { display: inline-flex; align-items: center; gap: .4rem; }
.topbar-info svg { width: .95rem; height: .95rem; opacity: .8; }

/* ---------- Header / nav ---------- */
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: rgba(251,246,238,.82);
  backdrop-filter: saturate(140%) blur(12px);
  -webkit-backdrop-filter: saturate(140%) blur(12px);
  border-bottom: 1px solid transparent;
  transition: box-shadow .3s var(--ease), border-color .3s var(--ease);
}
.site-header.scrolled { box-shadow: var(--shadow-sm); border-bottom-color: var(--line); }
.header-inner { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding-block: .85rem; }

.brand { display: inline-flex; align-items: center; gap: .7rem; }
.brand:hover { color: inherit; }
.brand-mark { flex: none; width: 46px; height: 46px; border-radius: 14px; display: grid; place-items: center; background: linear-gradient(140deg, var(--sage), var(--forest)); box-shadow: var(--shadow-sm); }
.brand-mark svg { width: 28px; height: 28px; }
.brand-text { display: flex; flex-direction: column; line-height: 1.05; }
.brand-text b { font-family: var(--font-display); font-weight: 600; font-size: 1.16rem; color: var(--forest); letter-spacing: -.01em; }
.brand-text span { font-size: .72rem; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; color: var(--terracotta-d); }

.main-nav { display: flex; align-items: center; gap: .35rem; }
.main-nav a:not(.btn) { font-weight: 800; color: var(--ink); padding: .55rem .85rem; border-radius: 999px; font-size: .98rem; position: relative; transition: color .2s var(--ease), background .2s var(--ease); }
.main-nav a:not(.btn):hover { color: var(--forest); background: var(--sage-soft); }
.main-nav a.active { color: var(--forest); }
.main-nav a.active::after { content: ""; position: absolute; left: .85rem; right: .85rem; bottom: .28rem; height: 3px; border-radius: 3px; background: var(--terracotta); }
.main-nav .btn { margin-left: .5rem; padding: .6rem 1.3rem; }

.nav-toggle { display: none; background: none; border: 0; cursor: pointer; padding: .4rem; border-radius: 10px; color: var(--forest); }
.nav-toggle svg { width: 28px; height: 28px; }

/* ---------- Hero ---------- */
.hero { position: relative; overflow: hidden; background: var(--cream); padding-block: clamp(3rem, 2rem + 6vw, 6.5rem); }
.hero-grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(2rem, 4vw, 4rem); align-items: center; position: relative; z-index: 1; }
.hero h1 span.hl { color: var(--terracotta); position: relative; white-space: nowrap; }
.hero h1 span.hl::after { content: ""; position: absolute; left: 0; right: 0; bottom: .04em; height: .28em; background: var(--gold); opacity: .35; border-radius: 6px; z-index: -1; }
.hero p.lead { margin-top: 1.25rem; max-width: 38ch; }
.hero .btn-row { margin-top: 2rem; }
.hero-trust { margin-top: 2.2rem; display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; color: var(--ink-soft); font-weight: 700; font-size: .9rem; }
.hero-trust .stars { color: var(--gold); letter-spacing: .1em; font-size: 1.05rem; }

.hero-art { position: relative; }
.hero-card { position: relative; aspect-ratio: 4/3.6; border-radius: var(--radius-xl); box-shadow: var(--shadow-lg); overflow: hidden; border: 6px solid #fff; background: linear-gradient(150deg, #fceede 0%, #f6dcc6 45%, #e7f0ea 100%); }
.hero-card svg { position: absolute; inset: 0; width: 100%; height: 100%; }
.hero-badge { position: absolute; background: #fff; border-radius: var(--radius); box-shadow: var(--shadow-md); padding: .8rem 1rem; display: flex; align-items: center; gap: .65rem; font-weight: 800; color: var(--forest); font-size: .95rem; z-index: 2; }
.hero-badge small { display: block; font-weight: 700; color: var(--ink-soft); font-size: .72rem; }
.hero-badge .ico { width: 34px; height: 34px; border-radius: 10px; display: grid; place-items: center; flex: none; color: #fff; }
.hero-badge .ico svg { width: 20px; height: 20px; }
.hero-badge--a { top: 7%; right: -3%; animation: float 6s ease-in-out infinite; }
.hero-badge--b { bottom: 6%; left: -4%; animation: float 7s ease-in-out infinite .6s; }
@keyframes float { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-10px); } }

.blob { position: absolute; border-radius: 50%; filter: blur(10px); opacity: .55; z-index: 0; pointer-events: none; }
.blob-1 { width: 320px; height: 320px; background: #f6d8a8; top: -90px; right: -60px; }
.blob-2 { width: 260px; height: 260px; background: var(--sage-soft); bottom: -120px; left: -70px; opacity: .9; }

/* ---------- Curve dividers ---------- */
.curve { display: block; width: 100%; line-height: 0; }
.curve svg { width: 100%; height: clamp(40px, 6vw, 80px); display: block; }

/* ---------- Grids & cards ---------- */
.grid { display: grid; gap: clamp(1.2rem, 2vw, 1.8rem); }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-4 { grid-template-columns: repeat(4, 1fr); }

.card { background: var(--paper); border-radius: var(--radius-lg); padding: 2rem; box-shadow: var(--shadow-sm); border: 1px solid var(--line); transition: transform .3s var(--ease), box-shadow .3s var(--ease); position: relative; overflow: hidden; }
.card:hover { transform: translateY(-6px); box-shadow: var(--shadow-md); }
.card .ico-tile { width: 60px; height: 60px; border-radius: 18px; display: grid; place-items: center; margin-bottom: 1.15rem; color: #fff; box-shadow: var(--shadow-sm); }
.card .ico-tile svg { width: 30px; height: 30px; }
.card h3 { margin-bottom: .5rem; }
.card p { font-size: .98rem; }
.card .card-link { margin-top: 1.1rem; display: inline-flex; }

.t-sage { background: linear-gradient(140deg, var(--sage), var(--forest)); }
.t-terra { background: linear-gradient(140deg, #e7855f, var(--terracotta-d)); }
.t-gold { background: linear-gradient(140deg, #f2bf5e, var(--gold)); color: #5a3d12 !important; }
.t-plum { background: linear-gradient(140deg, #9b7a96, var(--plum)); }
.t-sky { background: linear-gradient(140deg, #76a4be, var(--sky)); }

.card--feature::before { content: ""; position: absolute; inset: 0 0 auto 0; height: 5px; background: var(--accent, var(--sage)); }

/* ---------- Split rows ---------- */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 5vw, 4.5rem); align-items: center; }
.split--reverse .split-media { order: 2; }
.split-media { border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-md); aspect-ratio: 5/4; position: relative; border: 6px solid #fff; }
.split-media svg { position: absolute; inset: 0; width: 100%; height: 100%; }
.figure-cap { position: absolute; bottom: 1rem; left: 1rem; right: 1rem; background: rgba(255,255,255,.92); border-radius: 14px; padding: .7rem .9rem; font-weight: 800; color: var(--forest); font-size: .85rem; box-shadow: var(--shadow-sm); }

/* ---------- Tick list ---------- */
.ticks { list-style: none; padding: 0; display: grid; gap: .85rem; margin-top: 1.4rem; }
.ticks li { display: grid; grid-template-columns: 1.6rem 1fr; gap: .7rem; align-items: start; color: var(--ink); font-weight: 600; }
.ticks li svg { width: 1.5rem; height: 1.5rem; color: var(--sage); margin-top: .1rem; }

/* ---------- Stats ---------- */
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; }
.stat { text-align: center; }
.stat .num { font-family: var(--font-display); font-weight: 600; font-size: clamp(2.4rem, 1.6rem + 3vw, 3.6rem); color: #fff; line-height: 1; display: block; }
.stat .num .unit { color: var(--gold); }
.stat .lbl { font-weight: 700; font-size: .92rem; margin-top: .5rem; display: block; color: #cfe2d8; }

/* ---------- Timeline ---------- */
.timeline { display: grid; gap: 0; margin-top: 2rem; }
.tl-item { display: grid; grid-template-columns: 118px 1fr; gap: 1.4rem; padding: 1.3rem 0; border-top: 1px solid var(--line); align-items: start; }
.tl-item:last-child { border-bottom: 1px solid var(--line); }
.tl-time { font-family: var(--font-display); font-weight: 600; font-size: 1.2rem; color: var(--terracotta-d); white-space: nowrap; }
.tl-body h4 { font-family: var(--font-display); font-size: 1.2rem; color: var(--forest); margin-bottom: .25rem; letter-spacing: 0; }
.tl-body p { font-size: .96rem; }

/* ---------- Pills ---------- */
.pills { display: flex; flex-wrap: wrap; gap: .6rem; margin-top: 1.4rem; }
.pill { background: var(--sage-soft); color: var(--forest); font-weight: 800; font-size: .9rem; padding: .5rem 1rem; border-radius: 999px; border: 1px solid #d6e6dd; }

/* ---------- Testimonial ---------- */
.quote-card { background: var(--paper); border-radius: var(--radius-lg); padding: clamp(2rem, 4vw, 3.5rem); box-shadow: var(--shadow-md); border: 1px solid var(--line); position: relative; }
.quote-card .mark { font-family: var(--font-display); font-size: 5rem; line-height: .6; color: var(--gold); opacity: .55; }
.quote-card blockquote { font-family: var(--font-display); font-weight: 500; font-size: clamp(1.3rem, 1rem + 1.4vw, 1.9rem); color: var(--forest); line-height: 1.35; margin: .5rem 0 1.4rem; }
.quote-who { display: flex; align-items: center; gap: .9rem; }
.quote-who .av { width: 50px; height: 50px; border-radius: 50%; background: linear-gradient(140deg, var(--terracotta), var(--gold)); display: grid; place-items: center; color: #fff; font-weight: 800; font-family: var(--font-display); flex: none; }
.quote-who b { color: var(--ink); }
.quote-who span { color: var(--ink-soft); font-size: .9rem; display: block; }

/* ---------- Section heading ---------- */
.sec-head { max-width: 640px; margin-bottom: clamp(2rem, 3vw, 3rem); }
.sec-head.center { margin-inline: auto; }
.sec-head p { margin-top: .9rem; }

/* ---------- CTA band ---------- */
.cta-band { border-radius: var(--radius-xl); padding: clamp(2.5rem, 4vw, 4.5rem); position: relative; overflow: hidden; background: radial-gradient(120% 160% at 12% 10%, #2c6753 0%, var(--forest) 60%); color: #fff; text-align: center; box-shadow: var(--shadow-lg); }
.cta-band h2 { color: #fff; }
.cta-band p { color: #d3e6dc; max-width: 560px; margin: 1rem auto 2rem; }
.cta-band .btn-row { position: relative; z-index: 1; }
.cta-band .deco { position: absolute; border-radius: 50%; opacity: .14; }
.cta-band .deco.d1 { width: 240px; height: 240px; background: var(--gold); top: -80px; right: -50px; }
.cta-band .deco.d2 { width: 180px; height: 180px; background: var(--terracotta); bottom: -70px; left: -40px; opacity: .2; }

/* ---------- Hours table ---------- */
.hours { width: 100%; border-collapse: collapse; margin-top: 1.4rem; background: var(--paper); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-sm); border: 1px solid var(--line); }
.hours th, .hours td { text-align: left; padding: .95rem 1.2rem; }
.hours thead th { background: var(--forest); color: #fff; font-family: var(--font-body); font-weight: 800; font-size: .82rem; letter-spacing: .08em; text-transform: uppercase; }
.hours tbody tr + tr { border-top: 1px solid var(--line); }
.hours tbody tr:nth-child(even) { background: var(--cream); }
.hours td:last-child { font-weight: 800; color: var(--forest); }
.hours .closed { color: var(--terracotta-d); }

/* ---------- Fees ---------- */
.fees { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.4rem; }
.fee { background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 2rem; text-align: center; box-shadow: var(--shadow-sm); display: flex; flex-direction: column; }
.fee.featured { border: 2px solid var(--sage); box-shadow: var(--shadow-md); position: relative; }
.fee.featured .tag { position: absolute; top: -.85rem; left: 50%; transform: translateX(-50%); background: var(--terracotta); color: #fff; font-weight: 800; font-size: .72rem; letter-spacing: .08em; text-transform: uppercase; padding: .35rem .9rem; border-radius: 999px; white-space: nowrap; }
.fee h3 { color: var(--forest); }
.fee .price { font-family: var(--font-display); font-weight: 600; font-size: 2.6rem; color: var(--forest); margin: .5rem 0 .2rem; }
.fee .price small { font-size: .9rem; color: var(--ink-soft); font-family: var(--font-body); font-weight: 700; }
.fee ul { list-style: none; padding: 0; margin: 1.2rem 0; display: grid; gap: .6rem; text-align: left; }
.fee ul li { display: grid; grid-template-columns: 1.3rem 1fr; gap: .5rem; font-size: .95rem; color: var(--ink-soft); }
.fee ul li svg { width: 1.2rem; height: 1.2rem; color: var(--sage); margin-top: .15rem; }
.fee .btn { margin-top: auto; }

/* ---------- Forms ---------- */
.form-card { background: var(--paper); border-radius: var(--radius-lg); padding: clamp(1.6rem, 3vw, 2.6rem); box-shadow: var(--shadow-md); border: 1px solid var(--line); }
.field { margin-bottom: 1.2rem; }
.field label { display: block; font-weight: 800; color: var(--forest); margin-bottom: .4rem; font-size: .95rem; }
.field .req { color: var(--terracotta-d); }
.field input, .field select, .field textarea { width: 100%; font-family: var(--font-body); font-size: 1rem; color: var(--ink); padding: .85rem 1rem; border: 1.5px solid var(--line); border-radius: 14px; background: var(--cream); transition: border-color .2s var(--ease), box-shadow .2s var(--ease), background .2s var(--ease); }
.field textarea { resize: vertical; min-height: 140px; }
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: var(--sage); background: #fff; box-shadow: var(--ring); }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.2rem; }
.form-note { font-size: .85rem; color: var(--ink-soft); margin-top: .4rem; }

/* ---------- Contact info ---------- */
.info-list { display: grid; gap: 1.2rem; }
.info-item { display: grid; grid-template-columns: 54px 1fr; gap: 1rem; align-items: start; }
.info-item .ico { width: 54px; height: 54px; border-radius: 16px; display: grid; place-items: center; color: #fff; background: linear-gradient(140deg, var(--sage), var(--forest)); flex: none; }
.info-item .ico svg { width: 26px; height: 26px; }
.info-item h4 { font-family: var(--font-body); color: var(--forest); margin-bottom: .15rem; }
.info-item p, .info-item a { color: var(--ink-soft); font-size: .98rem; }

.map-wrap { border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-md); border: 6px solid #fff; aspect-ratio: 16/10; background: var(--sage-soft); position: relative; }
.map-wrap svg.map-bg { position: absolute; inset: 0; width: 100%; height: 100%; }
.map-pin { position: absolute; top: 44%; left: 50%; transform: translate(-50%,-100%); color: var(--terracotta); }
.map-pin svg { width: 44px; height: 44px; filter: drop-shadow(0 6px 8px rgba(0,0,0,.25)); }

/* ---------- Interior page hero ---------- */
.page-hero { position: relative; overflow: hidden; background: radial-gradient(120% 160% at 90% -10%, #2c6753 0%, var(--forest) 65%); color: #fff; padding-block: clamp(3rem, 2rem + 6vw, 5.5rem); }
.page-hero h1 { color: #fff; max-width: 18ch; }
.page-hero p { color: #d3e6dc; max-width: 56ch; margin-top: 1rem; font-size: 1.15rem; }
.page-hero .crumbs { color: #a9cebd; font-weight: 700; font-size: .9rem; margin-bottom: 1rem; }
.page-hero .crumbs a { color: #d8ece2; }
.page-hero .deco { position: absolute; border-radius: 50%; opacity: .14; pointer-events: none; }
.page-hero .deco.d1 { width: 300px; height: 300px; background: var(--gold); top: -120px; right: -60px; }
.page-hero .deco.d2 { width: 200px; height: 200px; background: var(--terracotta); bottom: -100px; right: 18%; opacity: .18; }

/* ---------- Team ---------- */
.team-card { text-align: center; background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 1.8rem; box-shadow: var(--shadow-sm); transition: transform .3s var(--ease), box-shadow .3s var(--ease); }
.team-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-md); }
.team-card .photo { width: 110px; height: 110px; border-radius: 50%; margin: 0 auto 1.1rem; display: grid; place-items: center; font-family: var(--font-display); font-weight: 600; font-size: 2.2rem; color: #fff; overflow: hidden; }
.team-card .photo img { width: 100%; height: 100%; object-fit: cover; }
.team-card h3 { font-size: 1.25rem; margin-bottom: .15rem; }
.team-card .role { color: var(--terracotta-d); font-weight: 800; font-size: .9rem; }
.team-card p { font-size: .92rem; margin-top: .7rem; }

/* ---------- Values ---------- */
.value { display: grid; grid-template-columns: 56px 1fr; gap: 1rem; align-items: start; }
.value .ico { width: 56px; height: 56px; border-radius: 16px; display: grid; place-items: center; color: #fff; flex: none; }
.value .ico svg { width: 28px; height: 28px; }
.value h3 { font-size: 1.2rem; margin-bottom: .3rem; }
.value p { font-size: .96rem; }

/* ---------- Donate ---------- */
.give-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.4rem; }
.give-card { background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 2rem; box-shadow: var(--shadow-sm); text-align: center; }
.give-card .amt { font-family: var(--font-display); font-weight: 600; font-size: 2.4rem; color: var(--terracotta-d); }
.give-card p { font-size: .96rem; margin-top: .4rem; }

/* ---------- Accordion ---------- */
.acc { border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; background: var(--paper); box-shadow: var(--shadow-sm); }
.acc + .acc { margin-top: .9rem; }
.acc summary { cursor: pointer; list-style: none; padding: 1.2rem 1.4rem; font-family: var(--font-display); font-weight: 600; font-size: 1.12rem; color: var(--forest); display: flex; justify-content: space-between; align-items: center; gap: 1rem; }
.acc summary::-webkit-details-marker { display: none; }
.acc summary .chev { width: 1.4rem; height: 1.4rem; transition: transform .25s var(--ease); color: var(--sage); flex: none; }
.acc[open] summary .chev { transform: rotate(180deg); }
.acc .acc-body { padding: 0 1.4rem 1.3rem; color: var(--ink-soft); }

/* ---------- Footer ---------- */
.site-footer { background: var(--forest); color: #cfe2d8; padding-top: clamp(3rem, 4vw, 4.5rem); }
.footer-top { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1.3fr; gap: 2rem; padding-bottom: 2.5rem; }
.site-footer h4 { color: #fff; font-family: var(--font-body); font-weight: 800; letter-spacing: .04em; text-transform: uppercase; font-size: .82rem; margin-bottom: 1.1rem; }
.site-footer a { color: #cfe2d8; }
.site-footer a:hover { color: var(--gold); }
.footer-brand .brand-text b { color: #fff; }
.footer-brand .brand-text span { color: var(--gold); }
.footer-brand p { color: #a9cebd; margin-top: 1rem; max-width: 32ch; font-size: .95rem; }
.foot-links { display: grid; gap: .6rem; }
.foot-contact p { color: #cfe2d8; font-size: .95rem; margin-bottom: .6rem; display: flex; gap: .6rem; align-items: flex-start; }
.foot-contact svg { width: 1.05rem; height: 1.05rem; margin-top: .2rem; color: var(--gold); flex: none; }
.socials { display: flex; gap: .6rem; margin-top: 1.2rem; }
.socials a { width: 40px; height: 40px; border-radius: 12px; display: grid; place-items: center; background: rgba(255,255,255,.08); color: #fff; transition: background .2s var(--ease), transform .2s var(--ease); }
.socials a:hover { background: var(--terracotta); transform: translateY(-2px); color: #fff; }
.socials svg { width: 20px; height: 20px; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.12); padding-block: 1.5rem; display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap; font-size: .85rem; color: #9cc0b1; }
.footer-bottom a { color: #9cc0b1; }
.footer-bottom a:hover { color: var(--gold); }
.newsletter { display: flex; gap: .5rem; margin-top: 1rem; }
.newsletter input { flex: 1; min-width: 0; padding: .7rem .9rem; border-radius: 12px; border: 1.5px solid rgba(255,255,255,.18); background: rgba(255,255,255,.06); color: #fff; font-family: var(--font-body); }
.newsletter input::placeholder { color: #9cc0b1; }
.newsletter input:focus { outline: none; border-color: var(--gold); }

/* ---------- Placeholder marker ---------- */
.ph { background: rgba(233,169,60,.18); border-bottom: 1px dashed var(--gold); padding: 0 .15em; border-radius: 3px; }

/* ---------- Scroll reveal ---------- */
.reveal { opacity: 0; transform: translateY(22px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in { opacity: 1; transform: none; }
.reveal-stagger > * { opacity: 0; transform: translateY(22px); transition: opacity .6s var(--ease), transform .6s var(--ease); }
.reveal-stagger.in > * { opacity: 1; transform: none; }
.reveal-stagger.in > *:nth-child(2) { transition-delay: .08s; }
.reveal-stagger.in > *:nth-child(3) { transition-delay: .16s; }
.reveal-stagger.in > *:nth-child(4) { transition-delay: .24s; }
.reveal-stagger.in > *:nth-child(5) { transition-delay: .32s; }
.reveal-stagger.in > *:nth-child(6) { transition-delay: .40s; }

/* ---------- A11y ---------- */
:focus-visible { outline: 3px solid var(--sage); outline-offset: 2px; border-radius: 4px; }
.skip-link { position: absolute; left: -999px; top: 0; background: var(--forest); color: #fff; padding: .8rem 1.2rem; border-radius: 0 0 12px 0; z-index: 200; font-weight: 800; }
.skip-link:focus { left: 0; color: #fff; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); border: 0; }

/* ---------- Real photos ---------- */
.hero-photo { position: relative; aspect-ratio: 4/4.4; border-radius: var(--radius-xl); overflow: hidden; border: 6px solid #fff; box-shadow: var(--shadow-lg); background: var(--sage-soft); }
.hero-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
.split-media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.photo-tile { border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-md); border: 6px solid #fff; aspect-ratio: 5/4; }
.photo-tile img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* Gallery (CSS masonry) */
.gallery { columns: 4 230px; column-gap: 1rem; }
.gallery figure { break-inside: avoid; margin: 0 0 1rem; border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-sm); position: relative; }
.gallery img { width: 100%; display: block; transition: transform .5s var(--ease); }
.gallery figure:hover img { transform: scale(1.05); }
.gallery figcaption { position: absolute; left: 0; right: 0; bottom: 0; padding: 1.4rem .9rem .7rem; color: #fff; font-weight: 700; font-size: .85rem; background: linear-gradient(transparent, rgba(20,40,33,.7)); opacity: 0; transition: opacity .3s var(--ease); }
.gallery figure:hover figcaption { opacity: 1; }
@media (max-width: 560px) { .gallery { columns: 2 140px; column-gap: .6rem; } .gallery figure { margin-bottom: .6rem; } }

/* Family events */
.events { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(1.2rem, 2vw, 1.8rem); }
.event-card { background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-sm); display: flex; flex-direction: column; transition: transform .3s var(--ease), box-shadow .3s var(--ease); }
.event-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-md); }
.event-poster { aspect-ratio: 4/5; overflow: hidden; background: var(--sage-soft); }
.event-poster img { width: 100%; height: 100%; object-fit: cover; display: block; }
.event-body { padding: 1.3rem 1.3rem 1.5rem; }
.event-body h3 { font-size: 1.2rem; margin-bottom: .35rem; }
.event-when { font-weight: 800; color: var(--terracotta-d); font-size: .85rem; margin-bottom: .5rem; }
.event-body p:last-child { font-size: .92rem; }
@media (max-width: 980px) { .events { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .events { grid-template-columns: 1fr; } }

/* Location maps */
.maps-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.map-card { border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-md); border: 6px solid #fff; background: var(--sage-soft); margin: 0; }
.map-card iframe { display: block; width: 100%; height: 190px; border: 0; }
.map-card figcaption { padding: .6rem .9rem; font-weight: 800; font-size: .85rem; color: var(--forest); background: #fff; text-align: center; }
.map-card figcaption a { color: var(--forest); }
@media (max-width: 560px) { .maps-grid { grid-template-columns: 1fr; } }

/* ---------- Responsive ---------- */
@media (max-width: 1024px) {
  .footer-top { grid-template-columns: 1fr 1fr; gap: 2rem 1.5rem; }
  .grid-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 880px) {
  .topbar { display: none; }
  .nav-toggle { display: inline-flex; }
  .main-nav { position: fixed; inset: 0 0 0 auto; width: min(82vw, 340px); background: var(--cream); flex-direction: column; align-items: stretch; justify-content: flex-start; padding: 5rem 1.4rem 2rem; gap: .3rem; box-shadow: var(--shadow-lg); transform: translateX(100%); transition: transform .35s var(--ease); z-index: 130; }
  .main-nav.open { transform: none; }
  .main-nav a:not(.btn) { padding: .9rem 1rem; font-size: 1.1rem; border-radius: 14px; }
  .main-nav a.active::after { display: none; }
  .main-nav a.active { background: var(--sage-soft); }
  .main-nav .btn { margin: .6rem 0 0; }
  .nav-backdrop { position: fixed; inset: 0; background: rgba(20,40,33,.4); opacity: 0; visibility: hidden; transition: opacity .3s var(--ease); z-index: 120; }
  .nav-backdrop.show { opacity: 1; visibility: visible; }
  .hero-grid { grid-template-columns: 1fr; }
  .hero-art { order: -1; max-width: 460px; margin-inline: auto; width: 100%; }
  .hero p.lead { max-width: none; }
  .split { grid-template-columns: 1fr; }
  .split--reverse .split-media { order: 0; }
  .stats { grid-template-columns: repeat(2, 1fr); gap: 2rem 1rem; }
  .grid-3 { grid-template-columns: 1fr; }
  .fees { grid-template-columns: 1fr; }
  .give-grid { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
  .grid-2, .grid-4 { grid-template-columns: 1fr; }
  .field-row { grid-template-columns: 1fr; }
  .hero-badge { display: none; }
  .tl-item { grid-template-columns: 92px 1fr; gap: 1rem; }
  .footer-top { grid-template-columns: 1fr; }
  .btn { width: 100%; }
  .hero .btn-row .btn, .center .btn-row .btn, .cta-band .btn-row .btn { width: auto; }
}

/* ===== Nursery World Awards 2026 finalist badge ===== */
.award-lockup { display: inline-flex; align-items: center; gap: .85rem; margin-top: 1.4rem; padding: .6rem .95rem .6rem .65rem; background: #fff; border: 1px solid var(--sage-soft); border-radius: var(--radius); box-shadow: var(--shadow-md); color: var(--forest); font-family: var(--font-body); font-weight: 800; font-size: .98rem; line-height: 1.2; transition: transform .2s var(--ease), box-shadow .2s var(--ease); }
.award-lockup:hover { transform: translateY(-2px); color: var(--forest); }
.award-lockup img { width: 52px; height: 60px; flex: none; }
.award-lockup span { display: flex; flex-direction: column; }
.award-lockup b { color: var(--sage); font-weight: 800; }
.award-lockup small { font-weight: 700; color: var(--ink-soft); font-size: .76rem; margin-top: .15rem; }

.footer-award { display: inline-flex; align-items: center; gap: .7rem; margin-top: 1.3rem; padding: .55rem .8rem .55rem .55rem; background: #fff; border-radius: 14px; box-shadow: var(--shadow-md); color: var(--forest); font-weight: 800; font-size: .9rem; line-height: 1.15; max-width: max-content; transition: transform .2s var(--ease); }
.footer-award:hover { transform: translateY(-2px); color: var(--forest); }
.footer-award img { width: 44px; height: 51px; flex: none; }
.footer-award span { display: flex; flex-direction: column; }
.footer-award small { font-weight: 700; color: var(--ink-soft); font-size: .72rem; margin-top: .15rem; max-width: 24ch; }

/* ===== Falling leaves (subtle, on-brand) ===== */
.leaf-field { position: fixed; inset: 0; pointer-events: none; overflow: hidden; z-index: 50; }
.leaf { position: absolute; top: -6vh; will-change: transform, opacity; opacity: 0; animation: leaf-fall linear infinite; }
.leaf svg { display: block; width: 100%; height: 100%; }
@keyframes leaf-fall {
  0%   { opacity: 0; transform: translate3d(0, -6vh, 0) rotate(0deg); }
  8%   { opacity: var(--leaf-op, .45); }
  92%  { opacity: var(--leaf-op, .45); }
  100% { opacity: 0; transform: translate3d(var(--leaf-x, 40px), 106vh, 0) rotate(var(--leaf-r, 360deg)); }
}
@media (prefers-reduced-motion: reduce) { .leaf-field { display: none !important; } }

/* ===== Farm critters strolling across the foot of the page ===== */
.critter-field { position: fixed; left: 0; right: 0; bottom: 0; height: 150px; pointer-events: none; overflow: hidden; z-index: 49; }
.critter { position: absolute; bottom: 6px; left: 0; will-change: transform; animation: critter-cross linear forwards; }
@keyframes critter-cross { from { transform: translateX(var(--from, -14vw)); } to { transform: translateX(var(--to, 104vw)); } }
.critter svg { display: block; }
.critter .body-grp { transform-box: fill-box; transform-origin: center bottom; animation: critter-bob .34s ease-in-out infinite; }
@keyframes critter-bob { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-2.6px); } }
.critter .leg { transform-box: fill-box; transform-origin: top center; animation: critter-step .34s ease-in-out infinite; }
.critter .leg.back { animation-delay: -.17s; }
@keyframes critter-step { 0%, 100% { transform: rotate(13deg); } 50% { transform: rotate(-13deg); } }
@media (prefers-reduced-motion: reduce) { .critter-field { display: none !important; } }
.critter-sprite { display: inline-flex; align-items: flex-end; gap: 2px; }
.feather-field { position: fixed; inset: 0; pointer-events: none; overflow: hidden; z-index: 52; }
.feather { position: absolute; will-change: transform, opacity; }
.feather svg { display: block; }
