/* ============================================================
   MCSC — v2 "premium vibrant cultural" design system
   ============================================================ */
:root{
  --red:#9e2b25; --coral:#e8583c; --orange:#d4622a; --gold:#c79a3b; --gold-b:#e0a93f;
  --green:#3f6e3a; --teal:#1d6e75; --teal-b:#2a98a1; --plum:#5e3566; --navy:#1f3a5f;
  --ink:#16130f; --ink-soft:#5a4f47;
  --paper:#faf6ee; --paper-2:#f2ebdc; --card:#fffdf9; --line:#e7ddca;
  --deep:#101d33;            /* premium dark base */
  --deep-2:#16263f;
  --maxw:1180px; --radius:20px;
  --shadow-sm:0 2px 8px rgba(20,16,12,.06);
  --shadow:0 18px 50px -22px rgba(20,16,12,.45);
  --shadow-c:0 22px 60px -20px rgba(0,0,0,.5);
  --serif:"Fraunces",Georgia,serif;
  --sans:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--sans);color:var(--ink);background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{animation:none!important;transition:none!important}}
img{max-width:100%;display:block}
a{color:var(--teal);text-decoration:none}
a:hover{text-decoration:underline}

h1,h2,h3{font-family:var(--serif);font-weight:600;line-height:1.08;letter-spacing:-.015em;margin:0}
h1{font-size:clamp(2.6rem,6vw,5rem);font-weight:600}
h2{font-size:clamp(2rem,4vw,3.2rem)}
h3{font-size:1.25rem}
p{margin:0 0 1rem}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 26px}
.eyebrow{font-weight:700;font-size:.76rem;letter-spacing:.2em;text-transform:uppercase;margin:0 0 .8rem;color:var(--coral)}
.lead{font-size:clamp(1.05rem,1.6vw,1.3rem);color:var(--ink-soft);max-width:60ch;line-height:1.6}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;font-size:1rem;
  padding:.95rem 1.8rem;border-radius:999px;border:2px solid transparent;cursor:pointer;
  transition:transform .18s ease,box-shadow .18s ease,background .18s ease}
.btn:hover{text-decoration:none;transform:translateY(-2px)}
.btn-primary{background:linear-gradient(120deg,var(--coral),var(--orange));color:#fff;box-shadow:0 10px 26px -10px rgba(232,88,60,.7)}
.btn-primary:hover{box-shadow:0 16px 34px -10px rgba(232,88,60,.8)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.4)}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.08)}
.btn-dark{background:var(--deep);color:#fff}
.btn-dark:hover{background:var(--deep-2)}

/* ---- header ---- */
.site-header{position:sticky;top:0;z-index:60;background:rgba(16,29,51,.82);backdrop-filter:blur(14px) saturate(140%);border-bottom:1px solid rgba(255,255,255,.08)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;max-width:var(--maxw);margin:0 auto;padding:.7rem 26px}
.brand{display:flex;align-items:center;gap:.7rem;color:#fff}
.brand:hover{text-decoration:none}
.brand img{height:48px;background:#fff;border-radius:12px;padding:5px}
.brand b{font-family:var(--serif);font-size:1.1rem;line-height:1;color:#fff}
.brand small{display:block;font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:#b9c4d6;margin-top:4px}
.nav-links{display:flex;gap:1.6rem;list-style:none;margin:0;padding:0}
.nav-links a{color:#e4e9f1;font-size:.95rem;font-weight:500}
.nav-links a:hover,.nav-links a.active{color:var(--gold-b);text-decoration:none}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{display:block;width:24px;height:2px;background:#fff;margin:5px 0;transition:.2s}
@media(max-width:920px){
  .nav-links,.nav .btn{display:none}
  .nav-toggle{display:block}
  .nav.open .nav-links{display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:var(--deep);padding:1.2rem 26px;gap:1.1rem;border-bottom:1px solid rgba(255,255,255,.1)}
}

/* ---- HERO ---- */
.hero{position:relative;background:var(--deep);color:#fff;overflow:hidden;padding:clamp(3rem,7vw,6rem) 0 clamp(3.5rem,8vw,7rem)}
.hero .mesh{position:absolute;inset:0;z-index:0;opacity:.9;
  background:
   radial-gradient(40% 50% at 12% 18%,rgba(232,88,60,.55),transparent 60%),
   radial-gradient(38% 46% at 88% 12%,rgba(224,169,63,.5),transparent 62%),
   radial-gradient(44% 50% at 82% 88%,rgba(42,152,161,.5),transparent 60%),
   radial-gradient(40% 48% at 8% 90%,rgba(94,53,102,.55),transparent 62%);
  filter:blur(8px);animation:meshmove 18s ease-in-out infinite alternate}
@keyframes meshmove{0%{transform:scale(1) translate(0,0)}100%{transform:scale(1.12) translate(-2%,1%)}}
.hero .grain{position:absolute;inset:0;z-index:1;opacity:.5;
  background:radial-gradient(rgba(255,255,255,.04) 1px,transparent 1px);background-size:3px 3px}
.hero .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1.1fr .9fr;gap:2.5rem;align-items:center}
.hero h1{margin-bottom:1.2rem}
.hero h1 .accent{background:linear-gradient(100deg,var(--gold-b),var(--coral));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.motto{font-family:var(--serif);font-style:italic;font-size:1.1rem;color:var(--gold-b);margin:0 0 1.3rem;display:flex;flex-wrap:wrap;gap:.2rem .9rem}
.motto span{position:relative;padding-left:1.1rem}
.motto span::before{content:"";position:absolute;left:0;top:.55em;width:7px;height:7px;border-radius:50%}
.motto span:nth-child(1)::before{background:var(--coral)}
.motto span:nth-child(2)::before{background:var(--teal-b)}
.motto span:nth-child(3)::before{background:var(--gold-b)}
.hero .lead{color:#d3dbe8;margin-bottom:1.9rem}
.hero-cta{display:flex;flex-wrap:wrap;gap:.9rem}
.hero-art{display:flex;justify-content:center}
.hero-photo{position:relative;margin:0;width:min(480px,94%);border-radius:24px;overflow:hidden;box-shadow:0 30px 70px -25px rgba(0,0,0,.6);border:1px solid rgba(255,255,255,.12)}
.hero-photo img{width:100%;height:auto;display:block;aspect-ratio:9/8;object-fit:cover}
.hero-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(160deg,rgba(16,29,51,0) 45%,rgba(16,29,51,.55));pointer-events:none}
.hero-photo::before{content:"";position:absolute;left:0;right:0;bottom:0;height:5px;z-index:1;background:linear-gradient(90deg,var(--coral),var(--gold-b),var(--teal-b),var(--plum));pointer-events:none}
.hero-photo figcaption{position:absolute;right:8px;bottom:8px;z-index:2;font-size:.62rem;color:rgba(255,255,255,.6);background:rgba(0,0,0,.3);padding:.1rem .4rem;border-radius:5px}
@media(max-width:920px){.hero .wrap{grid-template-columns:1fr;text-align:center}.hero-art{order:-1}.motto{justify-content:center}.hero-cta{justify-content:center}.hero .lead{margin-left:auto;margin-right:auto}}

/* hero ring animation */
.ring-fig{transform-box:fill-box;transform-origin:center;animation:bob 5s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
.eye-core{animation:pulse 4s ease-in-out infinite}
@keyframes pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.12);opacity:.85}}

/* ---- section scaffolding ---- */
section{padding:clamp(3.5rem,7vw,6rem) 0}
.section-head{max-width:64ch;margin:0 0 2.6rem}
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ---- marquee strip of cultures/colours ---- */
.strip{background:var(--deep-2);overflow:hidden;padding:1rem 0;border-block:1px solid rgba(255,255,255,.07)}
.strip .track{display:flex;gap:3rem;white-space:nowrap;animation:scroll 26s linear infinite;width:max-content}
.strip span{font-family:var(--serif);font-style:italic;font-size:1.15rem;color:#cdd6e4;display:inline-flex;align-items:center;gap:1rem}
.strip span::after{content:"";width:8px;height:8px;border-radius:50%;background:var(--gold-b)}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ---- welcome split ---- */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:3rem;align-items:center}
@media(max-width:860px){.split{grid-template-columns:1fr;gap:2rem}}
.purpose-card{position:relative;background:linear-gradient(150deg,var(--plum),var(--navy));color:#fff;border-radius:var(--radius);padding:2.4rem;box-shadow:var(--shadow-c);overflow:hidden}
.purpose-card::after{content:"";position:absolute;right:-40px;bottom:-40px;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,rgba(224,169,63,.45),transparent 70%)}
.purpose-card .q{font-family:var(--serif);font-size:1.4rem;line-height:1.45;position:relative;z-index:1}
.purpose-card .eyebrow{color:var(--gold-b)}

/* ---- PROGRAM TILES: each owns a colour ---- */
.tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem}
@media(max-width:880px){.tiles{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.tiles{grid-template-columns:1fr}}
.tile{position:relative;border-radius:var(--radius);padding:2rem 1.7rem;color:#fff;overflow:hidden;min-height:230px;display:flex;flex-direction:column;justify-content:flex-end;box-shadow:var(--shadow);transition:transform .25s ease,box-shadow .25s ease;isolation:isolate}
.tile:hover{transform:translateY(-6px);box-shadow:0 30px 60px -20px rgba(0,0,0,.5);text-decoration:none}
.tile::before{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(160deg,var(--c1),var(--c2))}
.tile::after{content:"";position:absolute;right:-30px;top:-30px;width:150px;height:150px;border-radius:50%;background:rgba(255,255,255,.12);z-index:-1}
.tile .ic{width:48px;height:48px;border-radius:14px;background:rgba(255,255,255,.2);display:grid;place-items:center;margin-bottom:auto}
.tile .ic svg{width:26px;height:26px;stroke:#fff}
.tile h3{color:#fff;margin:1.2rem 0 .5rem;font-size:1.35rem}
.tile p{color:rgba(255,255,255,.92);font-size:.96rem;margin:0}
.tile .badge{position:absolute;top:1.2rem;right:1.2rem;background:#fff;color:var(--ink);font-size:.62rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:.25rem .6rem;border-radius:999px}
.t-orange{--c1:var(--coral);--c2:var(--orange)}
.t-teal{--c1:var(--teal-b);--c2:var(--teal)}
.t-navy{--c1:#2b4a73;--c2:var(--navy)}
.t-gold{--c1:var(--gold-b);--c2:var(--gold)}
.t-green{--c1:#5a9152;--c2:var(--green)}
.t-plum{--c1:#7a4886;--c2:var(--plum)}
.tile.big{grid-column:span 1}

/* ---- employment flagship ---- */
.flagship{background:linear-gradient(160deg,var(--deep),var(--deep-2));color:#fff}
.flagship .eyebrow{color:var(--gold-b)}
.flagship h2{color:#fff}
.flagship .lead{color:#cdd6e4}
.glass{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:var(--radius);padding:2rem;backdrop-filter:blur(6px)}
.checklist{list-style:none;margin:0;padding:0;display:grid;gap:.8rem}
.checklist li{position:relative;padding-left:2rem;color:#dde4ee;font-size:.98rem}
.checklist li::before{content:"";position:absolute;left:0;top:.35rem;width:14px;height:14px;border-radius:50%;background:linear-gradient(135deg,var(--coral),var(--gold-b))}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem;margin-top:2.5rem}
@media(max-width:760px){.steps{grid-template-columns:1fr}}
.step-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:16px;padding:1.6rem}
.step-card .n{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;font-family:var(--serif);font-size:1.3rem;font-weight:600;color:#fff;margin-bottom:1rem}
.step-card:nth-child(1) .n{background:linear-gradient(135deg,var(--coral),var(--orange))}
.step-card:nth-child(2) .n{background:linear-gradient(135deg,var(--gold-b),var(--gold))}
.step-card:nth-child(3) .n{background:linear-gradient(135deg,var(--teal-b),var(--teal))}
.step-card h3{color:#fff;margin:0 0 .4rem}
.step-card p{color:#cdd6e4;margin:0;font-size:.95rem}

/* ---- stats with counters ---- */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
@media(max-width:600px){.stats{grid-template-columns:1fr}}
.stat{text-align:center;padding:1.5rem}
.stat .n{font-family:var(--serif);font-size:clamp(2.4rem,5vw,3.4rem);line-height:1;background:linear-gradient(120deg,var(--gold-b),var(--coral));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.stat .l{color:#cdd6e4;margin-top:.6rem;font-size:.95rem}

/* ---- CTA ---- */
.cta-band{position:relative;background:linear-gradient(120deg,var(--coral),var(--plum));color:#fff;text-align:center;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(50% 80% at 50% 0%,rgba(255,255,255,.18),transparent 60%)}
.cta-band .wrap{position:relative;z-index:1}
.cta-band h2{color:#fff;margin-bottom:.7rem}
.cta-band .lead{color:rgba(255,255,255,.92);margin:0 auto 1.8rem}
.cta-row{display:flex;gap:.9rem;justify-content:center;flex-wrap:wrap}

/* ---- footer ---- */
.site-footer{background:var(--deep);color:#aebbcd;padding:3.5rem 0 1.8rem;font-size:.93rem}
.site-footer h4{color:#fff;font-family:var(--sans);font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;margin:0 0 1rem}
.foot-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr;gap:2.4rem}
@media(max-width:760px){.foot-grid{grid-template-columns:1fr;gap:1.8rem}}
.foot-grid a{color:#aebbcd;display:block;margin-bottom:.55rem}
.foot-grid a:hover{color:#fff}
.foot-brand{display:flex;align-items:center;gap:.7rem;margin-bottom:1rem}
.foot-brand img{height:56px;background:#fff;border-radius:12px;padding:6px}
.foot-brand b{color:#fff;font-family:var(--serif);font-size:1.1rem}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:2.2rem;padding-top:1.3rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:.6rem;color:#7e8ba0;font-size:.85rem}
.todo{background:rgba(224,169,63,.18);border:1px dashed var(--gold-b);color:#e0a93f;padding:.12rem .45rem;border-radius:6px;font-size:.85em}

/* ---- interior page hero ---- */
.page-hero{position:relative;background:var(--deep);color:#fff;overflow:hidden;padding:clamp(2.6rem,6vw,4.4rem) 0 clamp(2.4rem,5vw,3.6rem)}
.page-hero .mesh{position:absolute;inset:0;z-index:0;opacity:.8;background:radial-gradient(40% 60% at 15% 20%,rgba(232,88,60,.5),transparent 60%),radial-gradient(40% 60% at 85% 80%,rgba(42,152,161,.5),transparent 60%);filter:blur(10px);animation:meshmove 18s ease-in-out infinite alternate}
.page-hero .grain{position:absolute;inset:0;z-index:1;opacity:.4;background:radial-gradient(rgba(255,255,255,.04) 1px,transparent 1px);background-size:3px 3px}
.page-hero .wrap{position:relative;z-index:2}
.page-hero h1{margin:.2rem 0 .7rem;font-size:clamp(2.2rem,4.5vw,3.4rem)}
.page-hero .lead{color:#d3dbe8}
.page-hero .motto{margin-bottom:1rem}

/* ---- content blocks ---- */
.panel{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:2rem;box-shadow:var(--shadow-sm)}
.values{list-style:none;margin:0;padding:0;display:grid;gap:1.1rem}
.values li{display:flex;gap:1.1rem;align-items:flex-start}
.values .dot{flex:none;width:16px;height:16px;border-radius:50%;margin-top:.4rem}
.values b{display:block;font-family:var(--serif);font-size:1.15rem}
.values span{color:var(--ink-soft)}
.team{display:grid;grid-template-columns:repeat(4,1fr);gap:1.3rem}
@media(max-width:820px){.team{grid-template-columns:1fr 1fr}}
.member{text-align:center}
.member .av{width:92px;height:92px;border-radius:50%;margin:0 auto .8rem;display:grid;place-items:center;font-family:var(--serif);font-size:1.7rem;color:#fff;box-shadow:var(--shadow-sm)}
.member b{display:block;font-family:var(--serif);font-size:1.1rem}
.member span{font-size:.86rem;color:var(--ink-soft)}
.vm-card{background:linear-gradient(150deg,var(--c1),var(--c2));color:#fff;border-radius:var(--radius);padding:2.2rem;box-shadow:var(--shadow)}
.vm-card .eyebrow{color:rgba(255,255,255,.85)}
.vm-card .q{font-family:var(--serif);font-size:1.25rem;line-height:1.45}
.field{margin-bottom:1.1rem}
.field label{display:block;font-size:.9rem;font-weight:600;margin-bottom:.4rem}
.field input,.field select,.field textarea{width:100%;padding:.8rem .9rem;border:1.5px solid var(--line);border-radius:12px;font-family:inherit;font-size:.97rem;background:#fff;color:var(--ink)}
.field input:focus,.field select:focus,.field textarea:focus{outline:2px solid var(--teal-b);outline-offset:1px;border-color:var(--teal-b)}
.safe-note{border:1px solid var(--line);border-left:6px solid var(--coral);background:#fff;border-radius:var(--radius);padding:1.4rem 1.5rem;box-shadow:var(--shadow-sm)}
.safe-note h3{margin:0 0 .5rem;color:var(--red)}
.safe-note p{margin:0 0 .6rem;color:var(--ink-soft);font-size:.95rem}
.quick-exit{position:fixed;right:18px;bottom:18px;z-index:90;background:var(--coral);color:#fff;border:0;border-radius:999px;padding:.8rem 1.2rem;font-weight:600;font-size:.92rem;cursor:pointer;box-shadow:0 10px 28px -6px rgba(0,0,0,.45)}
.quick-exit:hover{background:var(--red)}
.svc-feature{display:grid;grid-template-columns:1.1fr .9fr;gap:2.4rem;align-items:start}
@media(max-width:860px){.svc-feature{grid-template-columns:1fr}}
.icard{position:relative;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:1.8rem;box-shadow:var(--shadow-sm);overflow:hidden}
.icard::before{content:"";position:absolute;left:0;top:0;bottom:0;width:6px;background:linear-gradient(var(--c1),var(--c2))}
.icard .ic{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;margin-bottom:1rem;background:linear-gradient(145deg,var(--c1),var(--c2))}
.icard .ic svg{width:24px;height:24px;stroke:#fff}
.icard h3{margin:.1rem 0 .5rem}
.icard p{color:var(--ink-soft);font-size:.96rem;margin:0}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem}
@media(max-width:700px){.grid2{grid-template-columns:1fr}}
.cta-band .btn-dark{background:#fff;color:var(--ink)}
.cta-band .btn-dark:hover{background:var(--paper-2)}

/* ---- Acknowledgement of Country ---- */
.acknowledgement{background:var(--deep-2);color:#cdd6e4;padding:2.2rem 0;border-top:1px solid rgba(255,255,255,.07)}
.acknowledgement .wrap{display:flex;gap:1.2rem;align-items:flex-start;max-width:880px}
.acknowledgement .bar{flex:none;width:6px;align-self:stretch;border-radius:6px;background:linear-gradient(var(--red),var(--gold-b),var(--green))}
.acknowledgement h4{color:#fff;font-family:var(--serif);font-size:1.05rem;letter-spacing:0;text-transform:none;margin:0 0 .5rem}
.acknowledgement p{margin:0;font-size:.95rem;line-height:1.6}

/* wide banner tile (JP/Notary) to fill the last row cleanly */
.tile.jp-wide{grid-column:1 / -1;min-height:auto;flex-direction:row;align-items:center;justify-content:flex-start;gap:1.6rem;padding:1.7rem 2rem}
.tile.jp-wide .ic{margin-bottom:0}
.tile.jp-wide>div.txt{display:flex;flex-direction:column}
.tile.jp-wide h3{margin:0 0 .3rem}
@media(max-width:880px){.tile.jp-wide{grid-column:1 / -1;flex-direction:column;align-items:flex-start}}
@media(max-width:560px){.tile.jp-wide{grid-column:auto}}

/* ============================================================
   PRINT / SAVE-AS-PDF STYLES (A4, ink-friendly)
   ============================================================ */
@media print{
  @page{ size:A4; margin:16mm 14mm; }
  *{ -webkit-print-color-adjust:exact; print-color-adjust:exact; box-shadow:none!important; text-shadow:none!important; animation:none!important; transition:none!important; }
  .reveal{ opacity:1!important; transform:none!important; }
  body{ background:#fff!important; color:#16130f!important; font-size:11pt; line-height:1.45; }
  /* hide screen-only chrome */
  .site-header, .nav-toggle, .quick-exit, .strip, .hero .mesh, .hero .grain,
  .page-hero .mesh, .page-hero .grain, .cta-band, .hero-cta, form .btn, .btn{ display:none!important; }
  /* neutralise dark sections so they print on white with dark text */
  .hero, .page-hero, .flagship, .acknowledgement, .bg-ink, .bg-deep,
  section[style*="var(--deep"], section[style*="var(--paper-2)"]{
    background:#fff!important; color:#16130f!important; padding:10pt 0!important;
  }
  .hero h1, .hero h1 .accent, .hero .lead, .page-hero h1, .page-hero .lead,
  .flagship h2, .flagship .lead, .flagship .eyebrow, .acknowledgement h4, .acknowledgement p,
  .step-card h3, .step-card p, .checklist li, .glass .eyebrow,
  h1, h2, h3, p, li, .lead, .eyebrow, .motto, .stat .l{
    color:#16130f!important; -webkit-text-fill-color:#16130f!important;
  }
  .eyebrow, .motto{ color:#9e2b25!important; -webkit-text-fill-color:#9e2b25!important; }
  .hero h1 .accent{ color:#d4622a!important; -webkit-text-fill-color:#d4622a!important; }
  /* program tiles -> bordered white cards, keep a colour accent bar */
  .tile, .tile.jp-wide{ background:#fff!important; color:#16130f!important; border:1px solid #ccc!important; border-left:4px solid #9e2b25!important; min-height:auto!important; padding:10pt!important; page-break-inside:avoid; }
  .tile h3, .tile p, .tile .badge{ color:#16130f!important; }
  .tile .ic, .tile::before, .tile::after, .icard .ic{ display:none!important; }
  .tile .badge{ background:#eee!important; border:1px solid #ccc; }
  /* glass / panels / cards -> plain bordered */
  .glass, .panel, .icard, .purpose-card, .vm-card, .safe-note, .step-card{
    background:#fff!important; color:#16130f!important; border:1px solid #ccc!important; padding:10pt!important; page-break-inside:avoid;
  }
  .icard::before{ display:none!important; }
  .purpose-card::after, .cta-band::before, .tile::after, .tile::before{ display:none!important; }
  .checklist li::before{ background:#9e2b25!important; }
  /* hero photo: keep but constrain */
  .hero-photo{ box-shadow:none!important; border:1px solid #ccc!important; max-width:70mm; }
  .hero-photo::after, .hero-photo::before, .hero-photo figcaption{ display:none!important; }
  /* layout: collapse multi-col grids to stack so nothing clips on A4 */
  .hero .wrap, .split, .svc-feature, .tiles, .grid2, .steps, .team, .foot-grid, .stats{
    display:block!important;
  }
  .tiles > *, .grid2 > *, .steps > *{ margin-bottom:8pt; }
  /* stats numbers print dark */
  .stat .n{ color:#9e2b25!important; -webkit-text-fill-color:#9e2b25!important; font-size:20pt; }
  /* footer -> simple */
  .site-footer{ background:#fff!important; color:#16130f!important; border-top:1px solid #ccc; padding:10pt 0!important; }
  .site-footer h4, .site-footer a, .foot-bottom span, .foot-brand b{ color:#16130f!important; }
  .foot-brand img, .brand img{ background:#fff!important; }
  a{ color:#16130f!important; text-decoration:none; }
  /* show full URL after important links so a printed copy is useful */
  .site-footer a[href^="mailto"]::after{ content:" (" attr(href) ")"; }
  section{ page-break-inside:auto; }
  h2, h3{ page-break-after:avoid; }
  .todo{ background:#fff!important; border:1px dashed #999; color:#555!important; }
}

/* ============================================================
   REGISTRATION / CAPTURE FORM + CTA
   ============================================================ */
.reg-cta{background:linear-gradient(135deg,var(--coral),var(--plum));color:#fff;text-align:center;position:relative;overflow:hidden}
.reg-cta::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 90% at 50% 0%,rgba(255,255,255,.18),transparent 60%)}
.reg-cta .wrap{position:relative;z-index:1}
.reg-cta h2{color:#fff;margin-bottom:.6rem}
.reg-cta .lead{color:rgba(255,255,255,.94);margin:0 auto 1.6rem}
.reg-form-wrap{max-width:840px;margin:0 auto}
.reg-form{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:2.2rem;box-shadow:var(--shadow);text-align:left}
.reg-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
@media(max-width:640px){.reg-grid{grid-template-columns:1fr}}
.reg-form .field-full{grid-column:1 / -1}
.reg-form label{display:block;font-size:.88rem;font-weight:600;margin-bottom:.35rem;color:var(--ink)}
.reg-form label .req{color:var(--coral)}
.reg-form input,.reg-form select,.reg-form textarea{width:100%;padding:.75rem .85rem;border:1.5px solid var(--line);border-radius:11px;font-family:inherit;font-size:.96rem;background:#fff;color:var(--ink)}
.reg-form input:focus,.reg-form select:focus,.reg-form textarea:focus{outline:2px solid var(--teal-b);outline-offset:1px;border-color:var(--teal-b)}
.reg-form .hint{font-size:.82rem;color:var(--ink-soft);margin:.3rem 0 0}
.reg-actions{margin-top:1.4rem;display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.reg-msg{font-size:.92rem;margin:0;color:var(--teal)}
.reg-msg.error{color:var(--red)}
.consent{display:flex;gap:.6rem;align-items:flex-start;margin-top:1.1rem;font-size:.88rem;color:var(--ink-soft)}
.consent input{width:auto;margin-top:.2rem;flex:none}
.section-divider{grid-column:1 / -1;border:0;border-top:1px solid var(--line);margin:.6rem 0 .2rem}
.section-divider+*{margin-top:0}
.form-section-label{grid-column:1 / -1;font-family:var(--serif);font-size:1.05rem;color:var(--ink);margin:.4rem 0 0}
.it-note{grid-column:1 / -1;background:rgba(224,169,63,.12);border:1px dashed var(--gold-b);border-radius:10px;padding:.7rem .9rem;font-size:.84rem;color:#8a6a1e}
.btn-light{background:#fff;color:var(--ink)}
.btn-light:hover{background:var(--paper-2);text-decoration:none}

/* ---- optional webcam photo capture ---- */
.photo-capture{grid-column:1 / -1;background:#fff;border:1.5px solid var(--line);border-radius:14px;padding:1.2rem;margin-top:.2rem}
.photo-capture .pc-head{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}
.photo-capture h4{margin:0;font-family:var(--serif);font-size:1.05rem}
.photo-capture .pc-opt{font-size:.8rem;color:var(--ink-soft);font-weight:400}
.photo-capture p.pc-why{font-size:.86rem;color:var(--ink-soft);margin:.5rem 0 0}
.pc-stage{margin-top:.9rem;display:none}
.pc-stage.on{display:block}
.pc-video,.pc-shot{width:100%;max-width:320px;aspect-ratio:4/3;object-fit:cover;background:var(--paper-2);border-radius:12px;border:1px solid var(--line)}
.pc-shot{display:none}
.pc-btns{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:.8rem}
.pc-mini{font-size:.9rem;padding:.55rem 1.1rem;border-radius:999px;border:1.5px solid var(--line);background:#fff;color:var(--ink);font-weight:600;cursor:pointer}
.pc-mini:hover{border-color:var(--ink)}
.pc-mini.primary{background:var(--teal-b);color:#fff;border-color:var(--teal-b)}
.pc-mini.primary:hover{background:var(--teal)}
.pc-status{font-size:.85rem;color:var(--ink-soft);margin:.6rem 0 0}
.pc-status.err{color:var(--red)}
