/* ════════════════════════════════════════════════════════════════
   JEROMA SMILES — stylesheet  (v2 — "warm cinematic")
   ----------------------------------------------------------------
   Direction: warm, photographic, editorial. The brand trio
   (red / gold / blue) lives as confident accents on a paper-white
   base with deep-ink text; the hero and the values sequence are
   cinematic and dark so the children's photographs carry the warmth.
   Refined, human, international — not childish.
   Fonts: Fraunces (display) + Plus Jakarta Sans (body).
   ════════════════════════════════════════════════════════════════ */

:root{
  /* brand */
  --red:#d81e27;     --red-2:#ef3d3d;     --red-deep:#a8141b;
  --gold:#ffd200;    --gold-2:#ffdf4d;    --gold-deep:#e0a000;
  --blue:#1e5fa8;    --blue-2:#3a83d6;    --blue-deep:#123f73;
  /* paper / ink */
  --paper:#fbf6ec;   --paper-2:#f3ead9;   --paper-3:#efe3cd;
  --ink:#191820;     --ink-2:#3a3946;     --muted:#6c6b79;
  /* night (dark sections) */
  --night:#0d1014;   --night-2:#141a24;   --night-3:#1d2533;
  /* lines / glass */
  --line:rgba(25,24,32,.09);
  --line-2:rgba(25,24,32,.16);
  /* type */
  --display:'Fraunces',Georgia,'Times New Roman',serif;
  --body:'Plus Jakarta Sans',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  /* shape + motion */
  --radius:22px; --radius-sm:14px; --radius-xs:9px;
  --maxw:1200px;
  --ease:cubic-bezier(.22,1,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
  --shadow-1:0 1px 3px rgba(25,24,32,.05),0 14px 34px rgba(25,24,32,.09);
  --shadow-2:0 30px 70px rgba(25,24,32,.16);
  --shadow-blue:0 24px 60px rgba(30,95,168,.22);
}

*{box-sizing:border-box;}
html{font-size:90%;scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  margin:0;font-family:var(--body);color:var(--ink);background:var(--paper);
  line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;overflow-wrap:break-word;
}
h1,h2,h3,h4,.display{
  font-family:var(--display);font-optical-sizing:auto;line-height:1.04;margin:0;
  font-weight:600;letter-spacing:-.012em;
}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
p{margin:0 0 1rem;}
::selection{background:var(--gold);color:#3a2a00;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 26px;}
.center{text-align:center;}
.eyebrow{
  display:inline-flex;align-items:center;gap:9px;font-family:var(--body);
  font-weight:700;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--red);
}
.eyebrow .ln{width:26px;height:1px;background:currentColor;opacity:.5;}

/* ── Atmospheric fixed background (light pages) ───────────────── */
.bg-atmos{
  position:fixed;inset:0;z-index:-3;
  background:
    radial-gradient(70% 50% at 82% -8%, rgba(255,210,0,.16), transparent 60%),
    radial-gradient(60% 50% at -5% 8%, rgba(216,30,39,.08), transparent 55%),
    radial-gradient(70% 60% at 50% 120%, rgba(30,95,168,.07), transparent 60%),
    linear-gradient(180deg,#fdfaf3 0%, var(--paper) 55%, var(--paper-2) 100%);
}
/* faint grain for tactility */
.bg-grain{
  position:fixed;inset:0;z-index:-2;pointer-events:none;opacity:.4;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.5'/%3E%3C/svg%3E");
  mix-blend-mode:multiply;
}

/* ════════════════════════════════════════════════════════════════
   NAV
   ════════════════════════════════════════════════════════════════ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:80;
  transition:background .35s var(--ease),box-shadow .35s var(--ease),border-color .35s;
  background:rgba(251,246,236,.86);backdrop-filter:saturate(1.4) blur(14px);
  -webkit-backdrop-filter:saturate(1.4) blur(14px);
  border-bottom:1px solid var(--line);
}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:74px;gap:18px;}
.brand{display:flex;align-items:center;gap:12px;}
.brand .logo-mark{height:46px;width:auto;display:block;}
.brand .brand-tx{display:flex;flex-direction:column;line-height:1;}
.brand .brand-tx b{font-family:var(--display);font-weight:600;font-size:1.12rem;letter-spacing:-.01em;color:var(--ink);}
.brand .brand-tx span{font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);font-weight:700;margin-top:3px;}
.nav-links{display:flex;align-items:center;gap:4px;}
.nav-links a{
  position:relative;padding:10px 15px;border-radius:99px;font-weight:600;font-size:.93rem;
  color:var(--ink-2);transition:color .2s,background .2s;
}
.nav-links a:not(.nav-cta)::after{
  content:"";position:absolute;left:15px;right:15px;bottom:6px;height:2px;border-radius:2px;
  background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .28s var(--ease);
}
.nav-links a:not(.nav-cta):hover::after,.nav-links a.active:not(.nav-cta)::after{transform:scaleX(1);}
.nav-links a:hover,.nav-links a.active{color:var(--ink);}
.nav-cta{
  margin-left:8px;background:var(--ink);color:#fff !important;font-weight:700;
  padding:10px 20px;box-shadow:0 10px 24px rgba(25,24,32,.22);
  transition:transform .2s var(--ease),box-shadow .2s var(--ease),background .2s;
}
.nav-cta:hover{transform:translateY(-2px);background:var(--red);box-shadow:0 14px 30px rgba(216,30,39,.3);}
.burger{display:none;background:none;border:none;font-size:1.4rem;cursor:pointer;color:var(--ink);padding:6px;}

/* transparent over the dark hero (homepage, before scroll) */
.page-home .nav:not(.scrolled){
  background:linear-gradient(180deg,rgba(8,10,14,.55),transparent);
  backdrop-filter:none;-webkit-backdrop-filter:none;border-bottom-color:transparent;
}
.page-home .nav:not(.scrolled) .brand .brand-tx b{color:#fff;}
.page-home .nav:not(.scrolled) .brand .brand-tx span{color:rgba(255,255,255,.7);}
.page-home .nav:not(.scrolled) .nav-links a{color:rgba(255,255,255,.86);}
.page-home .nav:not(.scrolled) .nav-links a:hover,
.page-home .nav:not(.scrolled) .nav-links a.active{color:#fff;}
.page-home .nav:not(.scrolled) .nav-cta{background:#fff;color:var(--ink) !important;}
.page-home .nav:not(.scrolled) .nav-cta:hover{background:var(--gold);}
.page-home .nav:not(.scrolled) .brand .logo-mark{filter:drop-shadow(0 3px 8px rgba(0,0,0,.4));}
.page-home .nav:not(.scrolled) .burger{color:#fff;}

/* ════════════════════════════════════════════════════════════════
   BUTTONS
   ════════════════════════════════════════════════════════════════ */
.btn{
  display:inline-flex;align-items:center;gap:10px;border:none;cursor:pointer;
  font-family:var(--body);font-weight:700;font-size:.98rem;letter-spacing:.01em;
  padding:15px 28px;border-radius:99px;line-height:1;
  transition:transform .2s var(--ease),box-shadow .2s var(--ease),background .2s,color .2s;
}
.btn i{font-size:.95em;}
.btn:hover{transform:translateY(-3px);}
.btn:active{transform:translateY(-1px);}
.btn-red{background:var(--red);color:#fff;box-shadow:0 14px 30px rgba(216,30,39,.32);}
.btn-red:hover{background:var(--red-2);box-shadow:0 18px 38px rgba(216,30,39,.4);}
.btn-blue{background:var(--blue);color:#fff;box-shadow:var(--shadow-blue);}
.btn-blue:hover{background:var(--blue-2);}
.btn-gold,.btn-yellow{background:var(--gold);color:#3a2a00;box-shadow:0 14px 30px rgba(224,160,0,.34);}
.btn-gold:hover,.btn-yellow:hover{background:var(--gold-2);}
.btn-ink{background:var(--ink);color:#fff;box-shadow:0 14px 30px rgba(25,24,32,.26);}
.btn-ink:hover{background:#000;}
.btn-ghost{background:transparent;color:#fff;box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.55);}
.btn-ghost:hover{background:rgba(255,255,255,.12);box-shadow:inset 0 0 0 1.5px #fff;}
.btn-ghost-ink{background:#fff;color:var(--ink);box-shadow:var(--shadow-1);}
.btn-ghost-ink:hover{box-shadow:var(--shadow-2);}
.btn-lg{padding:18px 34px;font-size:1.05rem;}

/* ════════════════════════════════════════════════════════════════
   HERO — cinematic framed-photo collage (Netflix "get started" feel)
   ════════════════════════════════════════════════════════════════ */
.hero{
  position:relative;min-height:100svh;display:flex;align-items:center;
  background:var(--night);overflow:hidden;isolation:isolate;
}
.hero-canvas{position:absolute;inset:0;z-index:0;}
/* picture frames */
.hframe{
  position:absolute;overflow:hidden;border-radius:6px;
  border:6px solid rgba(255,255,255,.92);
  box-shadow:0 30px 60px rgba(0,0,0,.55),0 6px 16px rgba(0,0,0,.4);
  background:#222;will-change:transform;
  transition:transform .6s var(--ease);
}
.hframe::after{content:"";position:absolute;inset:0;box-shadow:inset 0 0 0 1px rgba(0,0,0,.08);border-radius:2px;}
.hframe img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  opacity:0;transition:opacity 1.1s ease;
}
.hframe img.show{opacity:1;}
/* desktop composition — a loose gallery wall, slightly tilted */
.hf1{width:23%;aspect-ratio:3/4;  top:8%;   left:4%;   transform:rotate(-5deg);}
.hf2{width:27%;aspect-ratio:4/3;  top:2%;   left:30%;  transform:rotate(2.5deg);}
.hf3{width:22%;aspect-ratio:3/4;  top:6%;   right:5%;  transform:rotate(5deg);}
.hf4{width:24%;aspect-ratio:4/3;  bottom:5%;left:7%;   transform:rotate(3deg);}
.hf5{width:21%;aspect-ratio:3/4;  bottom:4%;right:7%;  transform:rotate(-4deg);}
.hf6{width:25%;aspect-ratio:4/3;  bottom:8%;left:37%;  transform:rotate(-2deg);}

/* cinematic scrim so the words read */
.hero-scrim{
  position:absolute;inset:0;z-index:1;
  background:
    radial-gradient(120% 95% at 50% 42%, rgba(10,12,16,.34) 0%, rgba(10,12,16,.66) 55%, rgba(10,12,16,.9) 100%),
    linear-gradient(180deg, rgba(10,12,16,.55) 0%, rgba(10,12,16,.32) 26%, rgba(10,12,16,.55) 64%, rgba(10,12,16,.96) 100%);
}
.hero-inner{position:relative;z-index:2;width:100%;}
.hero-copy{max-width:760px;margin:0 auto;text-align:center;color:#fff;padding:90px 0 40px;}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:9px;color:var(--gold-2);
  font-weight:700;font-size:.74rem;letter-spacing:.24em;text-transform:uppercase;
  margin-bottom:22px;
}
.hero-eyebrow .ln{width:30px;height:1px;background:currentColor;opacity:.7;}
.hero h1{
  font-size:clamp(2.7rem,6.4vw,5.2rem);font-weight:500;color:#fff;
  text-shadow:0 4px 40px rgba(0,0,0,.4);line-height:1.02;
}
.hero h1 em{font-style:italic;font-weight:500;}
.hero h1 .gold{color:var(--gold);}
.hero p.lead{
  font-size:clamp(1.05rem,1.6vw,1.28rem);color:rgba(255,255,255,.88);
  max-width:56ch;margin:22px auto 32px;font-weight:400;
}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;}
/* scroll cue */
.hero-cue{
  position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:2;
  color:rgba(255,255,255,.7);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;
  display:flex;flex-direction:column;align-items:center;gap:10px;font-weight:700;
}
.hero-cue .mouse{
  width:24px;height:38px;border:2px solid rgba(255,255,255,.5);border-radius:14px;position:relative;
}
.hero-cue .mouse::before{
  content:"";position:absolute;left:50%;top:7px;width:3px;height:7px;border-radius:3px;background:#fff;
  transform:translateX(-50%);animation:wheel 1.7s var(--ease) infinite;
}
@keyframes wheel{0%{opacity:0;transform:translate(-50%,0);}30%{opacity:1;}70%{opacity:1;transform:translate(-50%,9px);}100%{opacity:0;transform:translate(-50%,12px);}}

/* the hero melts into the values section — no hard edge */
.hero::after{
  content:"";position:absolute;left:0;right:0;bottom:-1px;height:32%;z-index:1;pointer-events:none;
  background:linear-gradient(180deg,transparent,var(--night) 92%);
}

/* ════════════════════════════════════════════════════════════════
   VALUES ORBIT — logo centred, values reveal around it on scroll.
   The stage is sticky inside a tall section, so the viewer "stays"
   while the values appear one by one. Replaces the old marquee.
   ════════════════════════════════════════════════════════════════ */
.orbit-section{position:relative;background:var(--night);height:300vh;}
.orbit-section::before{ /* top blend from hero */
  content:"";position:absolute;top:0;left:0;right:0;height:14vh;
  background:linear-gradient(180deg,var(--night),transparent);
}
.orbit-section::after{ /* a slim settle into the light content (desktop) */
  content:"";position:absolute;bottom:0;left:0;right:0;height:11vh;pointer-events:none;
  background:linear-gradient(180deg,transparent,var(--paper));
}
.orbit-stage{
  position:sticky;top:0;height:100svh;overflow:hidden;
  display:flex;flex-direction:column;align-items:center;
}
.orbit-aura{
  position:absolute;top:54%;left:50%;transform:translate(-50%,-50%);
  width:min(70vmin,640px);aspect-ratio:1;border-radius:50%;pointer-events:none;
  background:radial-gradient(circle at 50% 45%, rgba(255,210,0,.16), rgba(30,95,168,.10) 45%, transparent 70%);
  filter:blur(8px);
}
/* heading lives in normal flow at the top, so the ring below can never cover it */
.orbit-head{
  flex:0 0 auto;text-align:center;color:#fff;padding:clamp(92px,12vh,132px) 22px 0;
  opacity:0;transform:translateY(16px);transition:opacity .7s var(--ease),transform .7s var(--ease);
}
.orbit-head.in{opacity:1;transform:none;}
.orbit-head .eyebrow{color:var(--gold-2);}
.orbit-head h2{font-size:clamp(1.5rem,2.8vw,2.2rem);font-weight:500;margin-top:10px;color:#fff;}
/* the ring is centred in the space that remains under the heading */
.orbit-body{flex:1 1 auto;min-height:0;width:100%;display:grid;place-items:center;}
.orbit-ring{
  position:relative;width:min(94vw,920px);
  display:grid;grid-template-columns:1fr auto 1fr;grid-template-rows:repeat(3,auto);
  align-items:center;gap:clamp(16px,2.4vh,26px) clamp(40px,5vw,78px);
}

/* tree lines drawn from the logo out to each value (built by JS) */
.orbit-links{position:absolute;inset:0;width:100%;height:100%;overflow:visible;pointer-events:none;z-index:1;}
.orbit-links .olink{stroke:rgba(255,255,255,.24);stroke-width:1.3;opacity:0;transition:opacity .7s var(--ease);}
.orbit-links .olink.on{opacity:1;}

/* centre medallion + logo */
.orbit-logo{
  grid-column:2;grid-row:1 / span 3;align-self:center;justify-self:center;
  position:relative;z-index:4;width:clamp(132px,20vmin,190px);aspect-ratio:1;border-radius:50%;
  background:radial-gradient(circle at 50% 38%,#fff,#fbf2da);
  display:grid;place-items:center;
  box-shadow:0 0 0 1px rgba(255,255,255,.5),0 30px 70px rgba(0,0,0,.55),0 0 90px rgba(255,210,0,.25);
  transform:scale(.86);transition:transform 1s var(--ease);
}
.orbit-logo.in{transform:scale(1);}
.orbit-logo img{width:74%;height:auto;filter:drop-shadow(0 6px 14px rgba(0,0,0,.12));}
.orbit-logo::before{
  content:"";position:absolute;inset:-14px;border-radius:50%;border:1px dashed rgba(255,255,255,.22);
  animation:spin 60s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg);}}

/* value chips: name + a short persuasive line, placed around the centre */
.vchip{
  z-index:3;display:flex;align-items:center;gap:13px;min-height:70px;
  padding:14px 18px;border-radius:16px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.15);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  color:#fff;text-align:left;box-shadow:0 16px 38px rgba(0,0,0,.4);
  opacity:0;transform:translate(var(--tx,0),var(--ty,0)) scale(.97);
  transition:opacity .55s var(--ease),transform .65s var(--ease);
}
.vchip.in{opacity:1;transform:translate(0,0) scale(1);}
.vchip .vi{
  width:36px;height:36px;border-radius:50%;display:grid;place-items:center;flex:0 0 auto;
  color:#fff;font-size:.92rem;box-shadow:0 6px 16px rgba(0,0,0,.3);
}
.vc-tx{display:flex;flex-direction:column;line-height:1.22;text-align:left;}
.vc-tx b{font-weight:600;font-size:clamp(.86rem,1.1vw,1rem);}
.vc-sub{font-weight:400;font-size:.76em;color:rgba(255,255,255,.6);margin-top:3px;}

/* six positions — three per side; mid row pushed out to clear the logo */
.vp1{grid-column:1;grid-row:1; --tx:-20px;--ty:-14px;}  /* Excellence — top-left */
.vp2{grid-column:3;grid-row:1; --tx:20px;--ty:-14px;}   /* Christ-Centredness — top-right */
.vp3{grid-column:3;grid-row:2; --tx:26px;--ty:0;}       /* Integrity — mid-right */
.vp4{grid-column:3;grid-row:3; --tx:20px;--ty:14px;}    /* Care — bottom-right */
.vp5{grid-column:1;grid-row:3; --tx:-20px;--ty:14px;}   /* Service — bottom-left */
.vp6{grid-column:1;grid-row:2; --tx:-26px;--ty:0;}      /* Discipline — mid-left */

/* ════════════════════════════════════════════════════════════════
   SECTIONS (light content)
   ════════════════════════════════════════════════════════════════ */
section{position:relative;padding:90px 0;}
.sec-head{max-width:64ch;}
.center .sec-head{margin-inline:auto;}
.kicker{
  font-family:var(--body);font-weight:700;letter-spacing:.22em;text-transform:uppercase;
  font-size:.74rem;color:var(--red);display:inline-flex;align-items:center;gap:9px;
}
.kicker::before{content:"";width:24px;height:1px;background:currentColor;opacity:.55;}
.center .kicker{justify-content:center;}
.sec-title{font-size:clamp(2.1rem,4.2vw,3.2rem);font-weight:500;margin:16px 0 14px;}
.sec-title em{font-style:italic;}
.sec-sub{color:var(--muted);font-size:1.1rem;max-width:60ch;}
.center .sec-sub{margin-inline:auto;}

/* About cards (Vision / Mission / Goal) */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:54px;}
.card{
  background:#fff;border-radius:var(--radius);padding:34px 30px;box-shadow:var(--shadow-1);
  border:1px solid var(--line);position:relative;overflow:hidden;text-align:left;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease);
}
.card:hover{transform:translateY(-7px);box-shadow:var(--shadow-2);}
.card .ic{
  width:60px;height:60px;border-radius:16px;display:grid;place-items:center;font-size:1.5rem;
  color:#fff;margin-bottom:20px;
}
.card.c-red .ic{background:linear-gradient(140deg,var(--red),var(--red-2));}
.card.c-yellow .ic,.card.c-gold .ic{background:linear-gradient(140deg,var(--gold-deep),var(--gold));color:#3a2a00;}
.card.c-blue .ic{background:linear-gradient(140deg,var(--blue),var(--blue-2));}
.card h3{font-size:1.45rem;font-weight:600;margin-bottom:10px;}
.card p{color:var(--muted);margin:0;}
.card .card-no{
  position:absolute;top:24px;right:26px;font-family:var(--display);font-style:italic;
  font-size:2.4rem;color:var(--line-2);line-height:1;
}

/* Core values grid (used on standalone pages if present) */
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:46px;}
.value{
  display:flex;align-items:center;gap:14px;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius-sm);padding:18px 20px;box-shadow:var(--shadow-1);font-weight:600;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease);
}
.value:hover{transform:translateY(-4px);box-shadow:var(--shadow-2);}
.value .vi{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;color:#fff;flex:0 0 auto;}

/* ════════════════════════════════════════════════════════════════
   PARALLAX MOTTO BAND — fixed photograph behind a quote
   ════════════════════════════════════════════════════════════════ */
.band{
  position:relative;padding:104px 0;overflow:hidden;color:#fff;text-align:center;
  background:var(--night-2);
}
.band-bg{
  position:absolute;inset:-12% 0;z-index:0;background-size:cover;background-position:center;
  will-change:transform;
}
.band-scrim{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(8,12,18,.78),rgba(11,16,26,.62) 40%,rgba(8,12,18,.84));
}
.band .wrap{position:relative;z-index:2;}
.band .quote-mark{font-family:var(--display);font-style:italic;font-size:3.4rem;color:var(--gold);line-height:0;opacity:.9;}
.band h2{font-size:clamp(2rem,4.6vw,3.6rem);font-weight:500;max-width:18ch;margin:26px auto 0;line-height:1.08;}
.band h2 em{font-style:italic;color:var(--gold-2);}
.band p{margin-top:20px;color:rgba(255,255,255,.82);font-size:1.1rem;max-width:52ch;margin-inline:auto;}

/* ════════════════════════════════════════════════════════════════
   PAPER-SLIDE REVEAL — image enters like a sheet sliding over another
   ════════════════════════════════════════════════════════════════ */
.paper{position:relative;}
.paper .paper-sheet{
  position:relative;overflow:hidden;border-radius:var(--radius-sm);
  box-shadow:var(--shadow-1);background:var(--paper-3);
  clip-path:inset(0 100% 0 0 round var(--radius-sm));
  transition:clip-path 1.05s var(--ease);
}
.paper.from-left .paper-sheet{clip-path:inset(0 0 0 100% round var(--radius-sm));}
.paper.from-bottom .paper-sheet{clip-path:inset(100% 0 0 0 round var(--radius-sm));}
.paper.in .paper-sheet{clip-path:inset(0 0 0 0 round var(--radius-sm));}
.paper .paper-sheet img{width:100%;height:100%;object-fit:cover;display:block;transform:scale(1.08);transition:transform 1.4s var(--ease);}
.paper.in .paper-sheet img{transform:scale(1);}
/* the "sheet beneath" — a soft offset shadow that sells the stacking */
.paper::before{
  content:"";position:absolute;inset:14px -14px -14px 14px;z-index:-1;border-radius:var(--radius-sm);
  background:linear-gradient(135deg,var(--paper-2),var(--paper-3));box-shadow:var(--shadow-1);
  opacity:0;transform:translate(-10px,-10px);transition:opacity .8s var(--ease) .2s,transform .8s var(--ease) .2s;
}
.paper.in::before{opacity:1;transform:none;}

/* ════════════════════════════════════════════════════════════════
   GALLERY — grid + hover details + lightbox
   ════════════════════════════════════════════════════════════════ */
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:50px;}
.gallery-grid.gallery-full{grid-template-columns:repeat(3,1fr);gap:18px;}
.gallery-grid .gi{
  position:relative;border-radius:var(--radius-sm);overflow:hidden;aspect-ratio:1/1;
  box-shadow:var(--shadow-1);background:var(--paper-3);cursor:zoom-in;display:block;
  padding:0;border:none;font-family:inherit;color:inherit;
  transition:transform .4s var(--ease),box-shadow .4s var(--ease);
}
.gallery-grid .gi img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease),filter .4s;}
.gallery-grid .gi:hover{transform:translateY(-6px);z-index:2;box-shadow:var(--shadow-2);}
.gallery-grid .gi:hover img{transform:scale(1.07);}
/* reveal overlay */
.gi-veil{
  position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;
  padding:18px 16px 16px;text-align:left;color:#fff;
  background:linear-gradient(to top,rgba(8,10,14,.82) 0%,rgba(8,10,14,.35) 48%,transparent 78%);
  opacity:0;transition:opacity .35s var(--ease);
}
.gallery-grid .gi:hover .gi-veil,.gallery-grid .gi:focus-visible .gi-veil{opacity:1;}
.gi-veil .gi-tag{
  font-size:.64rem;letter-spacing:.18em;text-transform:uppercase;font-weight:700;color:var(--gold-2);
  transform:translateY(8px);transition:transform .4s var(--ease);
}
.gi-veil .gi-cap{
  font-family:var(--display);font-weight:600;font-size:1.02rem;line-height:1.25;margin-top:5px;
  transform:translateY(10px);transition:transform .42s var(--ease) .04s;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.gi-veil .gi-zoom{
  position:absolute;top:14px;right:14px;width:38px;height:38px;border-radius:50%;
  background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.3);
  display:grid;place-items:center;font-size:.9rem;backdrop-filter:blur(6px);
  transform:scale(.6);transition:transform .4s var(--ease);
}
.gallery-grid .gi:hover .gi-tag,.gallery-grid .gi:hover .gi-cap{transform:translateY(0);}
.gallery-grid .gi:hover .gi-zoom{transform:scale(1);}
.gallery-empty{grid-column:1/-1;text-align:center;color:var(--muted);padding:60px 20px;font-size:1.05rem;}
.gallery-empty i{display:block;font-size:2rem;margin-bottom:12px;color:var(--gold-deep);}

/* ════════════════════════════════════════════════════════════════
   SUPPORT (was "help/donate")
   ════════════════════════════════════════════════════════════════ */
.support{
  position:relative;background:linear-gradient(155deg,var(--blue-deep),var(--blue) 60%,#1a4f8c);
  color:#eaf2ff;border-radius:var(--radius);padding:52px 44px;max-width:var(--maxw);margin:0 auto;
  box-shadow:var(--shadow-blue);overflow:hidden;
}
.support::before{content:"";position:absolute;top:-40%;right:-10%;width:55%;aspect-ratio:1;border-radius:50%;
  background:radial-gradient(circle,rgba(255,210,0,.18),transparent 70%);}
.support .s-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:46px;align-items:center;position:relative;}
.support .kicker{color:var(--gold-2);}
.support h2{color:#fff;font-size:clamp(2rem,4vw,2.9rem);font-weight:500;margin:14px 0 12px;}
.support p{color:#d6e4f8;max-width:50ch;}
.support-ways{display:grid;gap:12px;margin-top:6px;}
.way{
  display:flex;gap:14px;align-items:flex-start;background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.14);border-radius:14px;padding:15px 18px;
  transition:background .25s,transform .25s var(--ease);
}
.way:hover{background:rgba(255,255,255,.12);transform:translateX(4px);}
.way .wi{width:44px;height:44px;border-radius:12px;background:var(--gold);color:#3a2a00;display:grid;place-items:center;flex:0 0 auto;font-size:1.1rem;}
.way h4{color:#fff;font-size:1.06rem;font-weight:600;margin:0;}
.way p{margin:3px 0 0;font-size:.92rem;color:#c8dbf3;}
.support-cta{display:flex;flex-direction:column;gap:16px;align-items:flex-start;}
.support-cta .big{font-family:var(--display);font-style:italic;font-size:1.5rem;color:#fff;margin:0;line-height:1.2;}

/* ════════════════════════════════════════════════════════════════
   FORMS
   ════════════════════════════════════════════════════════════════ */
.form{display:grid;gap:15px;}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:15px;}
.field label{display:block;font-weight:700;font-size:.86rem;margin-bottom:7px;color:var(--ink-2);}
.input,select.input,textarea.input{
  width:100%;padding:14px 16px;border-radius:12px;border:1.5px solid var(--line-2);
  font-family:var(--body);font-size:1rem;background:#fff;color:var(--ink);
  transition:border-color .2s,box-shadow .2s;
}
.input::placeholder{color:#a7a5b2;}
.input:focus,textarea.input:focus,select.input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 4px rgba(30,95,168,.14);}
textarea.input{resize:vertical;min-height:120px;}
.support .field label{color:#dbe7ff;}
.support .input,.support textarea.input,.support select.input{background:rgba(255,255,255,.96);border-color:transparent;}

/* Contact + subscribe */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-top:48px;}
.info-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:34px;box-shadow:var(--shadow-1);}
.info-row{display:flex;gap:15px;align-items:center;margin-bottom:18px;}
.info-row .ii{width:48px;height:48px;border-radius:13px;display:grid;place-items:center;color:#fff;font-size:1.15rem;flex:0 0 auto;}
.subscribe{
  background:linear-gradient(150deg,var(--ink),#2a2935);border-radius:var(--radius);padding:40px;
  color:#fff;box-shadow:var(--shadow-2);max-width:var(--maxw);margin:0 auto;
}
.subscribe h3{font-size:1.6rem;font-weight:600;}
.subscribe p{color:rgba(255,255,255,.78);}
.subscribe .input{border:none;}
.sub-grid{display:grid;grid-template-columns:1fr 1fr;gap:34px;align-items:center;}

/* ════════════════════════════════════════════════════════════════
   FOOTER
   ════════════════════════════════════════════════════════════════ */
footer{background:var(--ink);color:#b9b8c6;padding:60px 0 32px;margin-top:0;position:relative;}
footer .wrap{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:40px;}
footer .f-brand img{width:120px;border-radius:14px;background:#fff;padding:8px;margin-bottom:16px;}
footer .f-brand p{max-width:36ch;color:#9b9aa8;}
footer h4{color:#fff;margin-bottom:16px;font-size:1.02rem;font-weight:600;font-family:var(--body);letter-spacing:.02em;}
footer a{color:#b9b8c6;transition:color .2s;}
footer a:hover{color:var(--gold-2);}
footer .f-links a{display:block;padding:4px 0;}
footer .f-contact p{display:flex;gap:11px;align-items:flex-start;margin:0 0 10px;color:#9b9aa8;}
footer .f-contact i{color:var(--gold-deep);margin-top:4px;}
.f-staff{margin-top:18px;}
.f-staff a{font-size:.84rem;color:#6e6d7d;display:inline-flex;align-items:center;gap:7px;}
.f-staff a:hover{color:#b9b8c6;}
footer .copy{
  text-align:center;margin-top:48px;padding-top:24px;border-top:1px solid rgba(255,255,255,.08);
  color:#75748340;font-size:.86rem;
}
footer .copy{color:#7a7988;}

/* ════════════════════════════════════════════════════════════════
   TOAST
   ════════════════════════════════════════════════════════════════ */
#toast{
  position:fixed;left:50%;bottom:28px;transform:translateX(-50%) translateY(140px);z-index:999;
  background:#fff;color:var(--ink);padding:15px 22px;border-radius:14px;box-shadow:var(--shadow-2);
  font-weight:700;max-width:90vw;opacity:0;transition:transform .45s var(--ease),opacity .3s;
  display:flex;gap:10px;align-items:center;border-left:5px solid var(--gold);
}
#toast.show{transform:translateX(-50%) translateY(0);opacity:1;}
#toast.err{border-left-color:var(--red);}
#toast.ok{border-left-color:#1aa06b;}

/* ════════════════════════════════════════════════════════════════
   REVEAL UTILITY
   ════════════════════════════════════════════════════════════════ */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease),transform .8s var(--ease);}
.reveal.in{opacity:1;transform:none;}
.reveal.d1{transition-delay:.08s;}.reveal.d2{transition-delay:.16s;}
.reveal.d3{transition-delay:.24s;}.reveal.d4{transition-delay:.32s;}

/* ════════════════════════════════════════════════════════════════
   STANDALONE PAGE HEROES + ABOUT STORY (kept, restyled)
   ════════════════════════════════════════════════════════════════ */
.page-hero{position:relative;padding:148px 0 40px;overflow:hidden;text-align:center;}
.page-hero .eyebrow,.page-hero .hero-eyebrow{justify-content:center;color:var(--red);margin-bottom:8px;}
.page-title{
  font-size:clamp(2.4rem,5.4vw,3.8rem);font-weight:500;margin:14px 0 8px;
  background:linear-gradient(115deg,var(--red),var(--gold-deep) 48%,var(--blue));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.page-title em{font-style:italic;}

.prose-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:44px 40px;box-shadow:var(--shadow-1);max-width:980px;margin:0 auto;}
.prose-card p{color:var(--muted);font-size:1.08rem;}
.pillars{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:28px;}
.pillar{display:flex;gap:14px;align-items:flex-start;background:var(--paper-2);border-radius:var(--radius-sm);padding:18px 20px;}
.pillar .pi{width:48px;height:48px;border-radius:13px;display:grid;place-items:center;color:#fff;flex:0 0 auto;font-size:1.1rem;}
.pillar h4{font-size:1.08rem;margin-bottom:3px;font-weight:600;}.pillar p{margin:0;font-size:.94rem;color:var(--muted);}

.motto{
  background:linear-gradient(140deg,var(--gold-deep),var(--gold));text-align:center;border-radius:var(--radius);
  padding:64px 34px;margin:0 auto;max-width:var(--maxw);box-shadow:0 24px 60px rgba(224,160,0,.3);
  position:relative;overflow:hidden;
}
.motto h2{font-size:clamp(2rem,5vw,3.2rem);color:#3a2a00;font-weight:500;}
.motto h2 em{font-style:italic;}
.motto .quote{font-size:1.1rem;color:#5a4200;font-weight:600;margin-top:10px;}

/* founder + pupil + facts (about) */
.story-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:48px 44px;box-shadow:var(--shadow-1);max-width:var(--maxw);margin:0 auto;position:relative;overflow:hidden;}
.story-card::before{content:"";position:absolute;top:0;left:0;right:0;height:6px;background:linear-gradient(90deg,var(--red),var(--gold),var(--blue));}
.story-grid{display:grid;grid-template-columns:280px 1fr;gap:44px;align-items:center;}
.story-portrait{position:relative;display:flex;justify-content:center;}
.story-portrait-img{width:240px;height:240px;border-radius:50%;background:linear-gradient(140deg,var(--paper-2),var(--paper-3));display:grid;place-items:center;font-size:5rem;color:var(--blue);box-shadow:var(--shadow-blue);border:6px solid #fff;overflow:hidden;}
.story-portrait-img img{width:100%;height:100%;object-fit:cover;}
.story-badge{position:absolute;bottom:14px;right:10px;width:54px;height:54px;border-radius:50%;background:linear-gradient(140deg,var(--gold-deep),var(--gold));color:#3a2a00;display:grid;place-items:center;font-size:1.2rem;box-shadow:0 8px 20px rgba(224,160,0,.4);}
.story-text .kicker{margin-bottom:10px;display:inline-flex;}
.story-lead{font-family:var(--display);font-style:italic;font-weight:500;font-size:1.28rem;color:var(--ink);line-height:1.5;margin:14px 0 18px;padding:6px 0 6px 20px;border-left:3px solid var(--gold-deep);}
.story-text p{color:var(--muted);font-size:1.04rem;line-height:1.75;margin:0 0 14px;}
.story-sign{font-family:var(--display);font-style:italic;color:var(--ink) !important;margin-top:18px !important;}
.pupil-card{background:linear-gradient(140deg,#eef4fd,#fff 55%,var(--paper));border:1px solid var(--line);border-radius:var(--radius);padding:50px 44px;max-width:980px;margin:0 auto;position:relative;overflow:hidden;box-shadow:var(--shadow-1);}
.pupil-quote-mark{position:absolute;top:20px;right:34px;font-size:5rem;color:rgba(30,95,168,.1);line-height:1;font-family:var(--display);font-style:italic;}
.pupil-card .kicker{margin-bottom:8px;display:inline-flex;}
.pupil-body{color:var(--ink-2);font-size:1.08rem;line-height:1.8;margin:0 0 14px;}
.pupil-body em{color:var(--blue);font-style:italic;font-weight:600;}
.pupil-meta{display:flex;flex-wrap:wrap;gap:18px;margin-top:24px;padding-top:18px;border-top:1px solid var(--line-2);color:var(--blue);font-weight:700;font-size:.9rem;}
.pupil-meta span{display:inline-flex;align-items:center;gap:7px;}.pupil-meta i{color:var(--gold-deep);}
.facts{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:38px;}
.fact{background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);padding:28px 24px;box-shadow:var(--shadow-1);text-align:left;transition:transform .25s var(--ease),box-shadow .25s var(--ease);}
.fact:hover{transform:translateY(-5px);box-shadow:var(--shadow-2);}
.fact-ico{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;color:#fff;font-size:1.25rem;margin-bottom:16px;}
.fact-n{font-family:var(--display);font-weight:600;font-size:1.12rem;color:var(--ink);margin-bottom:6px;}
.fact-l{color:var(--muted);font-size:.94rem;line-height:1.55;margin:0;}

/* lightbox (kept; restyled lightly) */
.lightbox{position:fixed;inset:0;z-index:200;background:rgba(8,9,12,.95);display:none;opacity:0;padding:0;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:opacity .25s ease;height:100dvh;}
.lightbox.open{display:flex;opacity:1;flex-direction:column;}
.lb-stage{flex:1;min-height:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:24px 64px 26px;cursor:zoom-out;}
.lb-img-wrap{flex:1;min-height:0;width:100%;display:flex;align-items:center;justify-content:center;cursor:default;}
.lightbox img{max-width:min(94vw,1280px);max-height:100%;height:auto;width:auto;border-radius:10px;box-shadow:0 30px 90px rgba(0,0,0,.6);background:#1a1a1a url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='40' height='40' viewBox='0 0 40 40'><circle cx='20' cy='20' r='14' stroke='%23fff' stroke-width='3' fill='none' stroke-dasharray='40' stroke-dashoffset='0' opacity='.5'><animateTransform attributeName='transform' type='rotate' from='0 20 20' to='360 20 20' dur='1s' repeatCount='indefinite'/></circle></svg>") center/40px no-repeat;transition:opacity .25s ease;display:block;user-select:none;-webkit-user-drag:none;}
.lightbox img.loading{opacity:.5;}
.lb-caption{max-width:min(94vw,1080px);color:#fff;text-align:center;font-family:var(--display);font-style:italic;font-weight:500;font-size:1.15rem;line-height:1.5;padding:4px 12px;display:none;text-shadow:0 2px 12px rgba(0,0,0,.5);}
.lb-caption.show{display:block;}
.lb-counter{color:rgba(255,255,255,.7);font-family:var(--body);font-weight:600;font-size:.82rem;letter-spacing:.1em;}
.lb-close{position:absolute;top:16px;right:18px;background:rgba(255,255,255,.96);border:none;width:50px;height:50px;border-radius:50%;font-size:1.2rem;cursor:pointer;color:var(--ink);display:grid;place-items:center;box-shadow:0 8px 24px rgba(0,0,0,.35);transition:transform .15s var(--ease),background .15s;z-index:3;}
.lb-close:hover{transform:scale(1.06);background:#fff;}.lb-close:active{transform:scale(.96);}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.16);border:none;width:54px;height:54px;border-radius:50%;color:#fff;font-size:1.15rem;cursor:pointer;display:grid;place-items:center;backdrop-filter:blur(8px);transition:background .15s,transform .15s var(--ease);z-index:3;}
.lb-nav:hover{background:rgba(255,255,255,.3);transform:translateY(-50%) scale(1.06);}
.lb-nav:active{transform:translateY(-50%) scale(.94);}
.lb-prev{left:16px;}.lb-next{right:16px;}
@keyframes fade{from{opacity:0}to{opacity:1}}

/* ════════════════════════════════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════════════════════════════════ */
@media(max-width:1024px){
  .support .s-grid{grid-template-columns:1fr;gap:30px;}
}
@media(max-width:900px){
  section{padding:80px 0;}
  .cards{grid-template-columns:1fr;gap:18px;}
  .values{grid-template-columns:1fr 1fr;}
  .contact-grid,.sub-grid,footer .wrap{grid-template-columns:1fr;gap:30px;}
  .facts{grid-template-columns:1fr 1fr;}
  .gallery-grid{grid-template-columns:repeat(2,1fr);}
  .gallery-grid.gallery-full{grid-template-columns:repeat(2,1fr);}
  /* nav → mobile drawer */
  .burger{display:block;}
  .nav-links{
    position:fixed;inset:74px 12px auto 12px;flex-direction:column;align-items:stretch;
    background:rgba(251,246,236,.98);backdrop-filter:blur(16px);border:1px solid var(--line);
    border-radius:18px;padding:14px;gap:4px;box-shadow:var(--shadow-2);
    transform:translateY(-130%) scale(.98);opacity:0;pointer-events:none;
    transition:transform .35s var(--ease),opacity .25s;
  }
  .nav-links.open{transform:none;opacity:1;pointer-events:auto;}
  .nav-links a{width:100%;color:var(--ink-2) !important;padding:13px 16px;}
  .nav-links a::after{display:none;}
  .nav-cta{margin-left:0;text-align:center;justify-content:center;background:var(--red) !important;color:#fff !important;margin-top:6px;}
  .page-home .nav:not(.scrolled) .nav-links a{color:var(--ink-2) !important;}

  /* hero collage simplifies */
  .hero{min-height:100svh;}
  .hf2,.hf6{display:none;}
  .hf1{width:42%;top:9%;left:5%;}
  .hf3{width:40%;top:7%;right:5%;}
  .hf4{width:44%;bottom:6%;left:6%;}
  .hf5{width:38%;bottom:7%;right:6%;}
  .hero-copy{padding:80px 0 30px;}

  /* orbit → static, naturally-flowing stack (no pin); reveals on scroll */
  .orbit-section{height:auto;}
  .orbit-section::before,.orbit-section::after{display:none;}   /* clean edge, not a fade */
  .orbit-stage{position:static;height:auto;min-height:0;overflow:visible;
    display:flex;flex-direction:column;align-items:center;padding:72px 20px 80px;}
  .orbit-head{position:static;top:auto;padding:0;margin-bottom:28px;}
  .orbit-body{display:block;width:100%;}
  .orbit-ring{position:relative;width:100%;max-width:430px;margin:0 auto;aspect-ratio:auto;
    display:flex;flex-direction:column;align-items:center;gap:12px;}
  .orbit-links{display:none;}
  .orbit-logo{position:relative;width:clamp(120px,30vmin,158px);margin:0 auto 10px;transform:scale(1);}
  .orbit-logo::before{inset:-9px;}
  .vchip{position:static;inset:auto;grid-column:auto;grid-row:auto;margin:0 !important;
    width:100%;max-width:100%;min-height:0;justify-content:flex-start;
    --tx:0;--ty:16px;transform:translateY(16px) scale(1);}
  .vchip.in{transform:none;}
  .orbit-aura{top:36%;width:min(72vmin,360px);}
}
@media(max-width:640px){
  .wrap{padding:0 18px;}
  section{padding:64px 0;}
  .values{grid-template-columns:1fr;}
  .facts{grid-template-columns:1fr;}
  .gallery-grid,.gallery-grid.gallery-full{grid-template-columns:1fr 1fr;gap:10px;}
  .form .row{grid-template-columns:1fr;}
  .pillars{grid-template-columns:1fr;}
  .support{padding:40px 24px;border-radius:18px;}
  .motto,.prose-card,.story-card,.pupil-card,.subscribe{padding:34px 22px;}
  .story-grid{grid-template-columns:1fr;gap:24px;}
  .band{padding:90px 0;}
  .page-hero{padding:120px 0 24px;}

  /* hero: a single soft scene behind the words on the smallest screens */
  .hframe{border-width:4px;}
  .hf1{width:54%;top:8%;left:6%;transform:rotate(-4deg);}
  .hf3{width:50%;top:6%;right:5%;transform:rotate(4deg);}
  .hf4{width:56%;bottom:7%;left:7%;transform:rotate(3deg);}
  .hf5{display:none;}
  .hero-scrim{background:
    radial-gradient(130% 90% at 50% 45%, rgba(10,12,16,.45), rgba(10,12,16,.82) 70%),
    linear-gradient(180deg, rgba(10,12,16,.5), rgba(10,12,16,.45) 40%, rgba(10,12,16,.96));}

  /* orbit (stacked) — compact chips */
  .orbit-ring{max-width:360px;}
  .vchip{padding:10px 16px 10px 9px;gap:10px;}
  .vchip .vi{width:32px;height:32px;font-size:.82rem;}
  .vc-tx b{font-size:.92rem;}
  .vc-sub{font-size:.74rem;}
  /* phones: just the logo mark + hamburger (the wordmark squeezes) */
  .brand .brand-tx{display:none;}
  .brand .logo-mark{height:44px;}
}

/* ════════════════════════════════════════════════════════════════
   REDUCED MOTION
   ════════════════════════════════════════════════════════════════ */
@media(prefers-reduced-motion:reduce){
  *{animation:none !important;scroll-behavior:auto !important;}
  .reveal,.orbit-head,.orbit-logo{opacity:1 !important;transform:none !important;}
  .vchip{opacity:1 !important;transform:none !important;}
  .orbit-links .olink{opacity:1 !important;}
  .paper .paper-sheet{clip-path:none !important;}
  .paper .paper-sheet img{transform:none !important;}
  .paper::before{opacity:1 !important;transform:none !important;}
  .band-bg{transform:none !important;}
}
