/* ---------- Tokens ---------- */
:root{
  --ink:#0f1b2d;          /* deep navy */
  --ink-2:#1c2a44;
  --paper:#f6f1e7;        /* warm cream */
  --paper-2:#efe7d5;
  --white:#ffffff;
  --rule:#e6dcc6;
  --muted:#5b6577;
  --sun:#f3b829;          /* mustard from logo */
  --sun-deep:#d99c12;
  --sky:#2a7adf;          /* cobalt from logo */
  --sky-deep:#1c5fbf;
  --rose:#c54a3a;         /* warm contrast accent */
  --shadow: 0 30px 60px -30px rgba(15,27,45,.35);
  --serif:'Fraunces', ui-serif, Georgia, serif;
  --sans:'Inter', system-ui, sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--sans);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* ---------- Layout helpers ---------- */
.wrap{max-width:1240px;margin:0 auto;padding:0 28px}
.eyebrow{
  font-family:var(--sans);
  font-weight:500;
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--muted);
  display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:28px;height:1px;background:currentColor;display:inline-block}
h1,h2,h3,h4{font-family:var(--serif);font-weight:400;letter-spacing:-.02em;line-height:1.05;margin:0}
h1{font-size:clamp(48px,7vw,108px);font-variation-settings:"opsz" 144, "SOFT" 30}
h2{font-size:clamp(36px,4.6vw,68px);font-variation-settings:"opsz" 144, "SOFT" 30}
h3{font-size:clamp(22px,2vw,28px);font-variation-settings:"opsz" 60}
em{font-style:italic;font-variation-settings:"opsz" 144, "SOFT" 100;color:var(--sun-deep)}

.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 22px;border-radius:999px;
  font-weight:500;font-size:15px;
  border:1px solid transparent;
  transition:transform .25s ease, background .25s ease, color .25s ease, box-shadow .25s ease;
  white-space:nowrap;
}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--ink);color:var(--paper)}
.btn-primary:hover{background:var(--sky-deep);box-shadow:var(--shadow)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}
.btn-sun{background:var(--sun);color:var(--ink)}
.btn-sun:hover{background:var(--sun-deep);box-shadow:var(--shadow)}
.arrow{transition:transform .25s ease}
.btn:hover .arrow{transform:translateX(4px)}

/* ---------- Top utility bar ---------- */
.topbar{
  background:var(--ink);color:var(--paper);
  font-size:13px;
}
.topbar .wrap{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:10px;padding-bottom:10px;gap:18px;flex-wrap:wrap;
}
.topbar a:hover{color:var(--sun)}
.topbar .left{display:flex;gap:24px;flex-wrap:wrap;align-items:center}
.topbar .left span{display:inline-flex;align-items:center;gap:8px;opacity:.9}
.dot{width:6px;height:6px;border-radius:50%;background:var(--sun);display:inline-block}
.topbar .right{display:flex;gap:18px;align-items:center}

/* ---------- Header / Nav ---------- */
.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(246,241,231,.85);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom:1px solid var(--rule);
}
.nav .wrap{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:18px;padding-bottom:18px;gap:24px;
}
.brand{display:flex;align-items:center;gap:12px}
.brand img{height:42px;width:auto}
.nav ul{
  list-style:none;margin:0;padding:0;
  display:flex;gap:34px;
}
.nav ul a{
  font-size:15px;font-weight:500;color:var(--ink);
  position:relative;padding:6px 0;
}
.nav ul a::after{
  content:"";position:absolute;left:0;right:0;bottom:0;
  height:1px;background:var(--ink);
  transform:scaleX(0);transform-origin:left;
  transition:transform .3s ease;
}
.nav ul a:hover::after{transform:scaleX(1)}
.nav-cta{display:flex;gap:12px;align-items:center}
.burger{display:none;background:none;border:0;cursor:pointer;padding:8px}
.burger span{display:block;width:24px;height:2px;background:var(--ink);margin:5px 0;transition:.3s}

@media (max-width:960px){
  .nav ul{display:none}
  .burger{display:block}
  .nav-cta .btn-ghost{display:none}
}

/* ---------- HERO ---------- */
.hero{
  position:relative;overflow:hidden;
  padding:80px 0 60px;
}
.hero-grid{
  display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center;
}
.hero h1 .stroke{
  -webkit-text-stroke:1.5px var(--ink);
  color:transparent;
  font-style:italic;
  font-variation-settings:"opsz" 144, "SOFT" 100;
}
.hero h1 .sun{color:var(--sun-deep);font-style:italic}
.hero p.lede{
  font-size:18px;max-width:520px;color:var(--ink-2);
  margin:28px 0 36px;
}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-meta{
  display:flex;gap:36px;flex-wrap:wrap;
  margin-top:54px;padding-top:30px;border-top:1px solid var(--rule);
}
.hero-meta div{display:flex;flex-direction:column}
.hero-meta strong{font-family:var(--serif);font-size:38px;font-weight:400;line-height:1}
.hero-meta span{font-size:13px;letter-spacing:.06em;color:var(--muted);text-transform:uppercase;margin-top:6px}

.hero-figure{
  position:relative;
}
.hero-figure .blob{
  position:absolute;inset:auto -10% -6% -6%;
  width:115%;aspect-ratio:1/1;
  background:radial-gradient(closest-side, rgba(42,122,223,.35), rgba(42,122,223,0) 70%);
  filter:blur(6px);
  z-index:0;
}
.hero-figure .frame{
  position:relative;z-index:1;
  border-radius:32px;overflow:hidden;
  background:linear-gradient(180deg, #cfe1f7 0%, #e9f0fa 100%);
  aspect-ratio:5/6;
  box-shadow:var(--shadow);
}
.hero-figure .frame img{
  width:100%;height:100%;object-fit:cover;object-position:center top;
}
.hero-figure .tag{
  position:absolute;z-index:2;
  background:var(--white);
  border:1px solid var(--rule);
  border-radius:20px;
  padding:16px 18px;
  display:flex;align-items:center;gap:12px;
  box-shadow:var(--shadow);
}
.tag-tl{top:24px;left:-30px;animation:float 6s ease-in-out infinite}
.tag-br{bottom:34px;right:-22px;animation:float 7s ease-in-out -2s infinite}
.tag .ico{
  width:42px;height:42px;border-radius:12px;
  background:var(--sun);display:grid;place-items:center;color:var(--ink);
  font-family:var(--serif);font-size:22px;
}
.tag .ico.blue{background:var(--sky);color:var(--white)}
.tag b{display:block;font-size:14px;font-weight:600}
.tag em{font-size:12px;color:var(--muted);font-style:normal}

@keyframes float{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-8px)}
}

@media (max-width:900px){
  .hero{padding:50px 0 30px}
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .hero h1{font-size:54px}
  .hero-meta{gap:26px}
  .hero-meta strong{font-size:30px}
  .tag-tl{left:0}
  .tag-br{right:0}
}

/* ---------- Marquee strip ---------- */
.strip{
  background:var(--ink);color:var(--paper);
  overflow:hidden;border-top:1px solid var(--ink-2);
}
.strip-track{
  display:flex;gap:60px;align-items:center;
  padding:22px 0;
  animation:scroll 38s linear infinite;
  width:max-content;
  font-family:var(--serif);font-size:24px;font-style:italic;
  white-space:nowrap;
  font-variation-settings:"opsz" 144, "SOFT" 100;
}
.strip-track span{display:inline-flex;align-items:center;gap:60px}
.strip-track svg{flex-shrink:0}
@keyframes scroll{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* ---------- ABOUT section ---------- */
.about{padding:120px 0}
.about-grid{
  display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:center;
}
.about-figure{
  position:relative;
}
.about-figure .img-main{
  border-radius:24px;overflow:hidden;
  aspect-ratio:4/5;
  box-shadow:var(--shadow);
}
.about-figure .img-main img{width:100%;height:100%;object-fit:cover}
.badge-circle{
  position:absolute;bottom:-30px;right:-30px;
  width:170px;height:170px;border-radius:50%;
  background:var(--sun);
  display:grid;place-items:center;text-align:center;
  font-family:var(--serif);font-style:italic;
  line-height:1.1;font-size:15px;color:var(--ink);
  box-shadow:var(--shadow);
  animation:spin 30s linear infinite;
}
.badge-circle svg{
  position:absolute;inset:0;width:100%;height:100%;
}
.badge-circle .inner{
  font-family:var(--serif);font-style:normal;
  font-size:28px;line-height:1;font-variation-settings:"opsz" 144;
}
.badge-circle .inner small{display:block;font-size:11px;letter-spacing:.18em;margin-top:6px;text-transform:uppercase;font-family:var(--sans)}
@keyframes spin{from{transform:rotate(0)}to{transform:rotate(360deg)}}

.about-body p{font-size:17px;color:var(--ink-2);max-width:560px;margin:24px 0 32px}
.about-list{list-style:none;padding:0;margin:0;display:grid;gap:14px}
.about-list li{
  display:flex;gap:14px;align-items:flex-start;
  padding:14px 0;border-top:1px solid var(--rule);
}
.about-list li:last-child{border-bottom:1px solid var(--rule)}
.about-list .tick{
  width:28px;height:28px;border-radius:50%;
  background:var(--ink);color:var(--paper);
  display:grid;place-items:center;flex-shrink:0;
  font-size:14px;
}
.about-list strong{display:block;font-weight:600;font-size:16px;margin-bottom:2px}
.about-list span{font-size:14px;color:var(--muted)}

@media (max-width:900px){
  .about{padding:70px 0}
  .about-grid{grid-template-columns:1fr;gap:50px}
  .badge-circle{right:-10px;bottom:-20px;width:130px;height:130px;font-size:12px}
  .badge-circle .inner{font-size:22px}
}

/* ---------- SERVICES ---------- */
.services{
  padding:120px 0;
  background:var(--ink);color:var(--paper);
  position:relative;overflow:hidden;
}
.services::before{
  content:"";position:absolute;inset:0;
  background-image:
    radial-gradient(circle at 20% 30%, rgba(243,184,41,.10), transparent 50%),
    radial-gradient(circle at 80% 70%, rgba(42,122,223,.14), transparent 50%);
  pointer-events:none;
}
.services .wrap{position:relative}
.services-head{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;margin-bottom:60px;flex-wrap:wrap}
.services-head h2{max-width:680px;color:var(--paper)}
.services-head h2 em{color:var(--sun)}
.services-head .eyebrow{color:var(--paper);opacity:.7}
.services-head p{max-width:380px;color:rgba(246,241,231,.7);margin:0}

.service-list{
  display:grid;gap:0;
  border-top:1px solid rgba(246,241,231,.18);
}
.service{
  padding:32px 0;border-bottom:1px solid rgba(246,241,231,.18);
  display:grid;grid-template-columns:60px 1.4fr 2fr 60px;gap:24px;align-items:center;
  transition:padding .3s ease, background .3s ease;
  cursor:pointer;position:relative;
}
.service::before{
  content:"";position:absolute;left:-30px;right:-30px;top:0;bottom:0;
  background:linear-gradient(90deg, rgba(243,184,41,.10), rgba(243,184,41,0) 80%);
  opacity:0;transition:opacity .3s ease;border-radius:8px;
}
.service:hover::before{opacity:1}
.service:hover{padding-left:30px;padding-right:30px}
.service-num{
  font-family:var(--serif);font-size:28px;color:var(--sun);
  font-variation-settings:"opsz" 144;
}
.service-title{
  font-family:var(--serif);font-size:clamp(24px,2.4vw,36px);
  line-height:1.1;font-variation-settings:"opsz" 144, "SOFT" 30;
}
.service-desc{
  color:rgba(246,241,231,.75);font-size:15px;line-height:1.6;
}
.service-arrow{
  width:50px;height:50px;border-radius:50%;
  border:1px solid rgba(246,241,231,.4);
  display:grid;place-items:center;justify-self:end;
  transition:background .3s ease, border .3s ease, transform .3s ease;
}
.service:hover .service-arrow{background:var(--sun);border-color:var(--sun);color:var(--ink);transform:rotate(-45deg)}

@media (max-width:780px){
  .services{padding:70px 0}
  .service{grid-template-columns:40px 1fr 40px;gap:16px}
  .service-desc{grid-column:1/-1;padding-left:56px}
  .service-num{font-size:20px}
  .service-arrow{width:40px;height:40px}
}

/* ---------- WHY US (stat split) ---------- */
.why{padding:120px 0}
.why-head{max-width:760px;margin-bottom:60px}
.why-head p{color:var(--muted);font-size:18px;margin-top:20px}
.why-head h2 em{color:var(--sky-deep)}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.why-card{
  padding:40px 32px;border-right:1px solid var(--rule);
  display:flex;flex-direction:column;gap:16px;
  position:relative;background:transparent;
  transition:background .3s ease;
}
.why-card:last-child{border-right:0}
.why-card:hover{background:var(--paper-2)}
.why-card .num{
  font-family:var(--serif);font-size:64px;line-height:1;color:var(--ink);
  font-variation-settings:"opsz" 144, "SOFT" 30;
}
.why-card .num em{font-style:italic;color:var(--sun-deep)}
.why-card h3{font-size:22px}
.why-card p{color:var(--muted);font-size:15px;margin:0}

@media (max-width:900px){
  .why{padding:70px 0}
  .why-grid{grid-template-columns:1fr}
  .why-card{border-right:0;border-bottom:1px solid var(--rule)}
  .why-card:last-child{border-bottom:0}
}

/* ---------- PROCESS ---------- */
.process{
  padding:120px 0;background:var(--paper-2);
  position:relative;overflow:hidden;
}
.process .wrap{position:relative;z-index:1}
.process-head{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:end;margin-bottom:60px}
.process-head p{max-width:420px;color:var(--muted)}
.process h2 em{color:var(--rose)}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;position:relative}
.steps::before{
  content:"";position:absolute;left:24px;right:24px;top:36px;height:1px;
  background:repeating-linear-gradient(90deg, var(--ink) 0 4px, transparent 4px 12px);
  opacity:.25;
}
.step{
  background:var(--paper);border:1px solid var(--rule);
  border-radius:18px;padding:28px;display:flex;flex-direction:column;gap:14px;
  position:relative;
}
.step-num{
  width:54px;height:54px;border-radius:50%;
  background:var(--ink);color:var(--paper);
  display:grid;place-items:center;
  font-family:var(--serif);font-size:24px;
  font-variation-settings:"opsz" 144;
  z-index:1;
}
.step:nth-child(2) .step-num{background:var(--sky)}
.step:nth-child(3) .step-num{background:var(--sun);color:var(--ink)}
.step:nth-child(4) .step-num{background:var(--rose);color:var(--paper)}
.step h3{font-size:22px}
.step p{color:var(--muted);font-size:14px;margin:0}

@media (max-width:900px){
  .process{padding:70px 0}
  .process-head{grid-template-columns:1fr;gap:16px}
  .steps{grid-template-columns:1fr 1fr}
  .steps::before{display:none}
}
@media (max-width:560px){.steps{grid-template-columns:1fr}}

/* ---------- TESTIMONIAL ---------- */
.testimonial{padding:120px 0}
.tm-grid{display:grid;grid-template-columns:1fr 1.6fr;gap:80px;align-items:center}
.tm-mark{
  font-family:var(--serif);font-size:240px;line-height:.5;color:var(--sun);
  font-style:italic;
  font-variation-settings:"opsz" 144, "SOFT" 100;
}
.tm-body blockquote{
  margin:0;font-family:var(--serif);font-size:clamp(26px,2.6vw,40px);
  line-height:1.25;letter-spacing:-.01em;color:var(--ink);
  font-variation-settings:"opsz" 144, "SOFT" 30;
}
.tm-body blockquote em{color:var(--sun-deep)}
.tm-cite{margin-top:32px;display:flex;align-items:center;gap:14px;color:var(--muted);font-size:14px}
.tm-cite .av{width:46px;height:46px;border-radius:50%;background:var(--sky);color:var(--white);display:grid;place-items:center;font-family:var(--serif);font-size:20px}

@media (max-width:900px){
  .testimonial{padding:70px 0}
  .tm-grid{grid-template-columns:1fr;gap:30px}
  .tm-mark{font-size:160px;text-align:left}
}

/* ---------- AREAS / Coverage ---------- */
.areas{
  padding:100px 0;background:var(--ink);color:var(--paper);
  position:relative;overflow:hidden;
}
.areas::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(ellipse 600px 300px at 90% 0%, rgba(243,184,41,.18), transparent 60%),
    radial-gradient(ellipse 600px 300px at 0% 100%, rgba(42,122,223,.18), transparent 60%);
}
.areas .wrap{position:relative;display:grid;grid-template-columns:1fr 1.2fr;gap:60px;align-items:center}
.areas h2{color:var(--paper);max-width:480px}
.areas h2 em{color:var(--sun)}
.areas-text p{color:rgba(246,241,231,.75);max-width:460px;margin:24px 0 0}
.area-chips{display:flex;flex-wrap:wrap;gap:10px}
.chip{
  padding:10px 18px;border-radius:999px;
  border:1px solid rgba(246,241,231,.3);
  font-size:14px;font-weight:500;
  transition:background .25s ease, color .25s ease, border .25s ease;
}
.chip:hover{background:var(--sun);color:var(--ink);border-color:var(--sun)}
@media (max-width:900px){
  .areas .wrap{grid-template-columns:1fr;gap:40px}
}

/* ---------- FAQ ---------- */
.faq{padding:120px 0}
.faq-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:80px;align-items:start}
.faq h2 em{color:var(--sky-deep)}
.faq-side p{color:var(--muted);margin:20px 0 28px}
.faq-list{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--rule)}
.faq-item{border-bottom:1px solid var(--rule);padding:24px 0}
.faq-q{
  display:flex;justify-content:space-between;align-items:center;gap:24px;
  cursor:pointer;list-style:none;font-family:var(--serif);
  font-size:clamp(20px,1.6vw,26px);font-variation-settings:"opsz" 144;
  line-height:1.2;
}
.faq-q::-webkit-details-marker{display:none}
.faq-q .pm{
  width:38px;height:38px;border-radius:50%;border:1px solid var(--ink);
  display:grid;place-items:center;flex-shrink:0;
  transition:background .25s ease, transform .25s ease;
  position:relative;
}
.faq-q .pm::before,.faq-q .pm::after{
  content:"";position:absolute;background:var(--ink);transition:all .25s ease;
}
.faq-q .pm::before{width:14px;height:1.5px}
.faq-q .pm::after{width:1.5px;height:14px}
details[open] .faq-q .pm{background:var(--ink)}
details[open] .faq-q .pm::before,details[open] .faq-q .pm::after{background:var(--paper)}
details[open] .faq-q .pm::after{transform:scaleY(0)}
.faq-a{padding:16px 60px 4px 0;color:var(--muted);font-size:16px;line-height:1.7}

@media (max-width:900px){
  .faq{padding:70px 0}
  .faq-grid{grid-template-columns:1fr;gap:30px}
}

/* ---------- CTA ---------- */
.cta{padding:80px 0}
.cta-card{
  background:var(--sun);color:var(--ink);
  border-radius:32px;padding:80px 60px;
  display:grid;grid-template-columns:1.4fr 1fr;gap:40px;align-items:center;
  position:relative;overflow:hidden;
}
.cta-card::before{
  content:"";position:absolute;
  right:-80px;bottom:-80px;width:300px;height:300px;border-radius:50%;
  background:radial-gradient(closest-side, var(--sun-deep), transparent);
  opacity:.5;
}
.cta-card h2{font-size:clamp(34px,4.2vw,60px)}
.cta-card h2 em{color:var(--ink);text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:6px}
.cta-card p{margin:18px 0 0;font-size:17px;max-width:420px}
.cta-act{display:flex;flex-direction:column;gap:14px;align-items:flex-end;position:relative;z-index:1}
.cta-act .btn-primary{padding:16px 28px;font-size:16px}
.cta-act .tel{font-family:var(--serif);font-size:34px;font-variation-settings:"opsz" 144}
.cta-act small{font-size:13px;color:rgba(15,27,45,.7);letter-spacing:.06em;text-transform:uppercase}

@media (max-width:780px){
  .cta-card{grid-template-columns:1fr;padding:50px 28px;border-radius:24px}
  .cta-act{align-items:flex-start}
}

/* ---------- FOOTER ---------- */
footer{
  background:var(--ink);color:var(--paper);
  padding:80px 0 32px;
}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:50px;margin-bottom:60px}
.foot-grid h4{font-family:var(--serif);font-size:18px;color:var(--paper);margin-bottom:18px;font-variation-settings:"opsz" 60}
.foot-grid ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.foot-grid a{color:rgba(246,241,231,.7);font-size:14px;transition:color .2s ease}
.foot-grid a:hover{color:var(--sun)}
.foot-about p{color:rgba(246,241,231,.7);font-size:14px;max-width:340px;margin:18px 0 0}
.foot-brand{display:flex;align-items:center;gap:12px;color:var(--paper)}
.foot-brand img{height:38px;filter:brightness(0) invert(1)}
.foot-contact{display:flex;flex-direction:column;gap:10px;color:rgba(246,241,231,.85);font-size:14px;margin-top:20px}
.foot-contact span{display:flex;gap:10px;align-items:flex-start}

/* NDIS badge in footer */
.ndis-badge{
  margin-top:24px;
  display:inline-flex;align-items:center;gap:14px;
  padding:12px 16px;
  background:rgba(246,241,231,.05);
  border:1px solid rgba(246,241,231,.15);
  border-radius:14px;
  transition:background .2s ease, border-color .2s ease;
}
.ndis-badge:hover{background:rgba(246,241,231,.08);border-color:rgba(246,241,231,.3)}
.ndis-badge img{height:54px;width:54px;flex-shrink:0}
.ndis-badge .nb-text{display:flex;flex-direction:column;gap:2px;line-height:1.3}
.ndis-badge .nb-text strong{color:var(--paper);font-size:13px;font-weight:600}
.ndis-badge .nb-text span{color:rgba(246,241,231,.6);font-size:12px}

/* Footer bottom + Acknowledgement */
.foot-bottom{
  border-top:1px solid rgba(246,241,231,.15);
  padding-top:28px;
  display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center;
  font-size:13px;color:rgba(246,241,231,.6);
}
.foot-bottom .ack-block{
  display:flex;align-items:flex-start;gap:18px;max-width:760px;
}
.foot-bottom .flags{
  display:flex;gap:8px;flex-shrink:0;margin-top:3px;
}
.foot-bottom .flags svg{
  width:34px;height:22px;border-radius:3px;
  box-shadow:0 0 0 1px rgba(246,241,231,.2);
  display:block;
}
.foot-bottom .ack{
  font-style:italic;font-family:var(--serif);
  font-variation-settings:"opsz" 144, "SOFT" 100;
  color:rgba(246,241,231,.8);
  font-size:14px;line-height:1.6;
}
.foot-bottom .copyright{text-align:right;font-size:12px;color:rgba(246,241,231,.5)}

@media (max-width:900px){
  .foot-bottom{grid-template-columns:1fr;gap:20px}
  .foot-bottom .copyright{text-align:left}
}

@media (max-width:900px){
  .foot-grid{grid-template-columns:1fr 1fr;gap:40px}
}
@media (max-width:560px){
  .foot-grid{grid-template-columns:1fr}
}

/* ---------- Subtle entrance for above-the-fold ---------- */
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.hero-text > *{animation:rise .8s ease both}
.hero-text > :nth-child(2){animation-delay:.1s}
.hero-text > :nth-child(3){animation-delay:.2s}
.hero-text > :nth-child(4){animation-delay:.3s}
.hero-text > :nth-child(5){animation-delay:.4s}
.hero-figure{animation:rise 1s .15s ease both}
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
}

/* ---------- Mobile menu ---------- */
.mmenu{
  position:fixed;inset:0;background:var(--paper);z-index:100;
  display:flex;flex-direction:column;padding:28px;
  transform:translateY(-100%);transition:transform .4s ease;
}
.mmenu.open{transform:translateY(0)}
.mmenu-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:40px}
.mmenu ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:24px}
.mmenu a{font-family:var(--serif);font-size:32px;font-variation-settings:"opsz" 144}
.mmenu .close{background:none;border:0;font-size:32px;cursor:pointer}