/* ============================================================
   Nazirsons Global — Design System (Navy + Gold), PHP build
   ============================================================ */
:root {
  --navy-50:#eef2f8; --navy-100:#d4ddee; --navy-200:#a9bbdc; --navy-300:#7e98ca;
  --navy-400:#4f6da8; --navy-500:#2c4a82; --navy-600:#14315c; --navy-700:#0b1f3d;
  --navy-800:#081730; --navy-900:#050f20;
  --gold-50:#fbf6e8; --gold-100:#f4e8c2; --gold-200:#e9d088; --gold-300:#ddb84e;
  --gold-400:#d0a52f; --gold-500:#c9a227; --gold-600:#a8861b; --gold-700:#826514;
  --ink:#0f172a; --cloud:#f6f8fb; --slate:#475569; --slate-light:#94a3b8;
  --font-sans:'Inter',ui-sans-serif,system-ui,sans-serif;
  --font-display:'Plus Jakarta Sans','Inter',ui-sans-serif,sans-serif;
  --shadow-card:0 10px 30px -12px rgba(11,31,61,.18);
  --shadow-soft:0 4px 20px -8px rgba(11,31,61,.14);
  --radius:1rem;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;background:#fff;color:var(--ink);font-family:var(--font-sans);
  font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img,svg{display:inline-block;vertical-align:middle;max-width:100%}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4,h5{font-family:var(--font-display);letter-spacing:-.02em;line-height:1.1;margin:0}
p{margin:0}
ul{margin:0;padding:0;list-style:none}
button{font:inherit;cursor:pointer;border:0;background:none}
input,select,textarea{font:inherit}

/* ---------- Layout ---------- */
.container-x{width:100%;max-width:80rem;margin-inline:auto;padding-inline:1.25rem}
@media(min-width:1024px){.container-x{padding-inline:2rem}}
.section{padding-block:4rem}
@media(min-width:768px){.section{padding-block:6rem}}
.grid{display:grid;gap:1.5rem}
@media(min-width:640px){.sm-2{grid-template-columns:repeat(2,1fr)}}
@media(min-width:768px){.md-2{grid-template-columns:repeat(2,1fr)}.md-3{grid-template-columns:repeat(3,1fr)}.md-4{grid-template-columns:repeat(4,1fr)}}
@media(min-width:1024px){.lg-3{grid-template-columns:repeat(3,1fr)}.lg-4{grid-template-columns:repeat(4,1fr)}}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  border-radius:.625rem;font-weight:600;font-size:.95rem;padding:.75rem 1.5rem;
  transition:all .2s ease;line-height:1;border:1.5px solid transparent}
.btn-gold{background:var(--gold-500);color:var(--navy-700)}
.btn-gold:hover{background:var(--gold-400);transform:translateY(-1px);box-shadow:0 8px 20px -8px rgba(201,162,39,.6)}
.btn-navy{background:var(--navy-700);color:#fff}
.btn-navy:hover{background:var(--navy-600);transform:translateY(-1px)}
.btn-outline{border-color:rgba(255,255,255,.5);color:#fff}
.btn-outline:hover{background:rgba(255,255,255,.1);border-color:#fff}
.btn-ghost-navy{border-color:var(--navy-200);color:var(--navy-700)}
.btn-ghost-navy:hover{background:var(--navy-50)}
.btn-block{width:100%}

/* ---------- Typography helpers ---------- */
.eyebrow{display:inline-flex;align-items:center;gap:.5rem;font-size:.8rem;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;color:var(--gold-600)}
.eyebrow.on-dark{color:var(--gold-400)}
.title-rule::after{content:"";display:block;width:64px;height:4px;border-radius:99px;
  background:linear-gradient(90deg,var(--gold-500),var(--gold-300));margin-top:1rem}
.title-rule.center::after{margin-inline:auto}
.section-head h2{font-size:1.875rem;font-weight:700;color:var(--navy-700);margin-top:.75rem}
@media(min-width:768px){.section-head h2{font-size:2.25rem}}
.section-head p{margin-top:1.25rem;color:var(--slate);max-width:42rem}
.section-head.center{text-align:center}
.section-head.center p{margin-inline:auto}
.muted{color:var(--slate)}

/* ---------- Cards ---------- */
.card{background:#fff;border-radius:var(--radius);border:1px solid var(--navy-50);
  box-shadow:var(--shadow-soft);transition:transform .25s ease,box-shadow .25s ease}
.card-hover:hover{transform:translateY(-4px);box-shadow:var(--shadow-card)}
.card-pad{padding:1.75rem}
.icon-tile{display:grid;place-items:center;width:3.5rem;height:3.5rem;border-radius:.75rem;
  background:var(--navy-700);color:var(--gold-400);flex-shrink:0}
.icon-tile.gold{background:var(--gold-50);color:var(--gold-600)}
.icon-tile.light{background:rgba(255,255,255,.1);color:var(--gold-400)}
.icon-tile.round{border-radius:999px;background:var(--gold-500);color:var(--navy-700)}
.icon-tile.sm{width:3rem;height:3rem;border-radius:.6rem}

/* ---------- Forms ---------- */
.input{width:100%;border-radius:.625rem;border:1px solid #d8dee9;background:#fff;
  padding:.7rem .9rem;font-size:.95rem;color:var(--ink);transition:border-color .15s,box-shadow .15s}
.input:focus{outline:none;border-color:var(--gold-400);box-shadow:0 0 0 3px rgba(201,162,39,.15)}
textarea.input{resize:vertical}
.label{display:block;font-size:.85rem;font-weight:600;color:var(--navy-700);margin-bottom:.35rem}
.field{margin-bottom:1rem}
.form-grid{display:grid;gap:1rem}
@media(min-width:640px){.form-grid{grid-template-columns:1fr 1fr}}
.form-grid .full{grid-column:1/-1}
fieldset{border:0;padding:0;margin:0 0 1.25rem}
legend{font-size:.85rem;font-weight:700;color:var(--gold-600);text-transform:uppercase;
  letter-spacing:.08em;padding:0;margin-bottom:1rem}
.alert{border-radius:.75rem;padding:1rem 1.25rem;font-size:.95rem;margin-bottom:1.25rem}
.alert.ok{background:var(--gold-50);border:1px solid var(--gold-200);color:var(--navy-700)}
.alert.err{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c}
.hp{position:absolute;left:-9999px;opacity:0;height:0;overflow:hidden}

/* ---------- Header ---------- */
.topbar{background:var(--navy-900);color:rgba(255,255,255,.8);font-size:13px}
.topbar-in{display:flex;align-items:center;justify-content:space-between;padding-block:.375rem}
.topbar a{display:inline-flex;align-items:center;gap:.375rem}
.topbar a:hover{color:var(--gold-300)}
.topbar .right{display:none;color:rgba(255,255,255,.5)}
@media(min-width:768px){.topbar .right{display:flex;gap:1rem;align-items:center}}
.topbar .left{display:flex;gap:1.25rem}
@media(max-width:767px){.topbar .left{width:100%;justify-content:center}}

.site-header{position:sticky;top:0;z-index:50}
.navbar{background:rgba(11,31,61,.97);border-bottom:1px solid rgba(255,255,255,.1)}
.navbar-in{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-block:.75rem}
.brand{display:flex;align-items:center;gap:.75rem;flex-shrink:0}
.brand img{height:2.5rem;width:auto}
.brand-name{line-height:1.15;display:none}
@media(min-width:640px){.brand-name{display:block}}
.brand-name b{display:block;font-family:var(--font-display);font-weight:800;color:#fff;letter-spacing:.05em}
.brand-name span{display:block;font-size:11px;font-weight:600;letter-spacing:.3em;color:var(--gold-400)}

.nav-desktop{display:none;align-items:center;gap:.25rem}
@media(min-width:1024px){.nav-desktop{display:flex}}
.nav-desktop>li{position:relative}
.nav-desktop a.nav-link{display:flex;align-items:center;gap:.25rem;padding:.5rem .75rem;
  font-size:.875rem;font-weight:600;color:rgba(255,255,255,.9)}
.nav-desktop a.nav-link:hover,.nav-desktop a.nav-link.active{color:var(--gold-300)}
.nav-desktop a.nav-link.active{color:var(--gold-500)}
.caret{transition:transform .2s}
.nav-desktop li:hover .caret{transform:rotate(180deg)}
.dropdown{position:absolute;left:0;top:100%;padding-top:.5rem;opacity:0;visibility:hidden;
  transform:translateY(4px);transition:all .2s}
.nav-desktop li:hover .dropdown,.nav-desktop li:focus-within .dropdown{opacity:1;visibility:visible;transform:none}
.dropdown-in{width:18rem;border-radius:.75rem;background:#fff;box-shadow:var(--shadow-card);
  border:1px solid var(--navy-50);padding:.5rem}
.dropdown-in a{display:flex;align-items:center;gap:.75rem;border-radius:.5rem;padding:.625rem .75rem}
.dropdown-in a:hover{background:var(--navy-50)}
.dropdown-in a .mini-tile{display:grid;place-items:center;width:2.25rem;height:2.25rem;
  border-radius:.5rem;background:var(--navy-700);color:var(--gold-400);flex-shrink:0}
.dropdown-in a span{font-size:.875rem;font-weight:600;color:var(--navy-700)}
.dropdown-in .view-all{display:block;padding:.5rem .75rem;margin-top:.25rem;font-size:.875rem;
  font-weight:600;color:var(--gold-600)}
.header-cta{display:none}
@media(min-width:640px){.header-cta{display:inline-flex}}

/* Mobile menu */
.burger{display:inline-flex;flex-direction:column;justify-content:center;gap:5px;
  width:2.5rem;height:2.5rem;padding:.5rem;color:#fff}
@media(min-width:1024px){.burger{display:none}}
.burger span{display:block;height:2px;width:100%;background:currentColor;transition:all .25s}
.mobile-drawer{position:fixed;inset:0;z-index:60;visibility:hidden}
.mobile-drawer .backdrop{position:absolute;inset:0;background:rgba(5,15,32,.6);opacity:0;transition:opacity .25s}
.mobile-drawer .panel{position:absolute;right:0;top:0;height:100%;width:86%;max-width:24rem;
  background:var(--navy-700);color:#fff;overflow-y:auto;transform:translateX(100%);transition:transform .3s}
.mobile-drawer.open{visibility:visible}
.mobile-drawer.open .backdrop{opacity:1}
.mobile-drawer.open .panel{transform:none}
.drawer-head{display:flex;align-items:center;justify-content:space-between;padding:1rem;
  border-bottom:1px solid rgba(255,255,255,.1);font-family:var(--font-display);font-weight:700}
.drawer-nav{padding:.5rem}
.drawer-nav a.item{display:block;padding:.75rem 1rem;font-weight:600;color:rgba(255,255,255,.9);border-radius:.5rem}
.drawer-nav a.item:hover{background:rgba(255,255,255,.05)}
.drawer-group summary{display:flex;align-items:center;justify-content:space-between;
  padding:.75rem 1rem;font-weight:600;color:rgba(255,255,255,.9);border-radius:.5rem;cursor:pointer;list-style:none}
.drawer-group summary::-webkit-details-marker{display:none}
.drawer-group[open] summary .caret{transform:rotate(180deg)}
.drawer-group .sub{padding:0 0 .5rem .75rem}
.drawer-group .sub a{display:flex;align-items:center;gap:.75rem;padding:.6rem 1rem;
  font-size:.875rem;color:rgba(255,255,255,.8)}
.drawer-group .sub a:hover{color:var(--gold-300)}
.drawer-nav .btn{margin:1rem;width:calc(100% - 2rem)}

/* ---------- Hero ---------- */
.hero{position:relative;background:linear-gradient(120deg,#0b1f3d 0%,#14315c 60%,#0b1f3d 100%);overflow:hidden}
.hero::before,.hero::after{content:"";position:absolute;border-radius:999px;filter:blur(64px)}
.hero::before{right:-8rem;top:0;width:34rem;height:34rem;background:rgba(201,162,39,.1)}
.hero::after{left:0;bottom:0;width:24rem;height:24rem;background:rgba(79,109,168,.2)}
.hero-in{position:relative;z-index:1;padding-block:5rem;display:grid;gap:3rem;align-items:center}
@media(min-width:768px){.hero-in{padding-block:7rem}}
@media(min-width:1024px){.hero-in{grid-template-columns:7fr 5fr}}
.hero-badge{display:inline-flex;align-items:center;gap:.5rem;border-radius:999px;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);
  padding:.375rem 1rem;font-size:.75rem;font-weight:600;letter-spacing:.02em;color:var(--gold-300)}
.hero h1{margin-top:1.25rem;font-size:2.5rem;font-weight:800;color:#fff;line-height:1.05}
@media(min-width:768px){.hero h1{font-size:3.75rem}}
.hero h1 .gold{color:var(--gold-400)}
.hero .lead{margin-top:1.5rem;font-size:1.125rem;color:rgba(255,255,255,.75);max-width:36rem}
.hero .actions{margin-top:2rem;display:flex;flex-wrap:wrap;gap:.75rem}
.hero .slogan{margin-top:1.5rem;font-size:.875rem;color:rgba(255,255,255,.5);
  font-family:var(--font-display);font-style:italic}
.hero-panel{border-radius:1rem;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);
  padding:2rem;text-align:center;backdrop-filter:blur(4px)}
.hero-panel img{height:10rem;width:auto;margin-inline:auto}
.hero-stats{margin-top:1.5rem;display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.hero-stats>div{border-radius:.75rem;background:rgba(255,255,255,.05);padding:1rem 0}
.hero-stats b{display:block;font-size:1.5rem;font-weight:800;color:var(--gold-400)}
.hero-stats span{display:block;font-size:.75rem;color:rgba(255,255,255,.6);margin-top:.25rem}
.trust-strip{position:relative;border-top:1px solid rgba(255,255,255,.1);background:rgba(8,23,48,.6)}
.trust-strip-in{padding-block:1rem;display:flex;flex-wrap:wrap;align-items:center;
  justify-content:center;column-gap:2rem;row-gap:.5rem;font-size:.875rem;color:rgba(255,255,255,.6)}
.trust-strip-in span{display:inline-flex;align-items:center;gap:.5rem}
.trust-strip-in svg{color:var(--gold-400)}

/* ---------- Page hero (inner pages) ---------- */
.page-hero{position:relative;background:var(--navy-700);overflow:hidden}
.page-hero::before{content:"";position:absolute;right:-6rem;top:-6rem;width:24rem;height:24rem;
  border-radius:999px;background:rgba(201,162,39,.1);filter:blur(64px)}
.page-hero-in{position:relative;padding-block:4rem}
@media(min-width:768px){.page-hero-in{padding-block:5rem}}
.breadcrumbs{font-size:.875rem;color:rgba(255,255,255,.6)}
.breadcrumbs ol{display:flex;flex-wrap:wrap;gap:.375rem;align-items:center}
.breadcrumbs a:hover{color:var(--gold-300)}
.breadcrumbs .sep{color:rgba(255,255,255,.3)}
.breadcrumbs .current{color:rgba(255,255,255,.9)}
.page-hero h1{margin-top:.75rem;font-size:1.875rem;font-weight:800;color:#fff;max-width:48rem}
@media(min-width:768px){.page-hero h1{font-size:3rem}}
.page-hero .sub{margin-top:1rem;font-size:1.125rem;color:rgba(255,255,255,.7);max-width:42rem}

/* ---------- Sections / feature blocks ---------- */
.bg-cloud{background:var(--cloud)}
.bg-navy{background:var(--navy-700);position:relative;overflow:hidden}
.bg-navy .section-head h2{color:#fff}
.dark-card{border-radius:1rem;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);
  padding:1.75rem;text-align:center;height:100%}
.dark-card h3{margin-top:1.25rem;font-size:1.125rem;font-weight:700;color:#fff}
.dark-card p{margin-top:.5rem;font-size:.875rem;color:rgba(255,255,255,.65)}
.dark-card .icon-tile{margin-inline:auto}
.feature-card h3{margin-top:1.25rem;font-size:1.25rem;font-weight:700;color:var(--navy-700)}
.feature-card p{margin-top:.5rem;color:var(--slate);font-size:.95rem}
.link-more{display:inline-flex;align-items:center;gap:.25rem;margin-top:1rem;
  font-size:.875rem;font-weight:600;color:var(--gold-600);transition:gap .2s}
a:hover .link-more,.link-more:hover{gap:.5rem}
.step-card{position:relative;border-radius:1rem;border:1px solid var(--navy-50);
  padding:1.75rem;box-shadow:var(--shadow-soft);height:100%}
.step-card .num{position:absolute;right:1.25rem;top:1rem;font-size:2.25rem;font-weight:800;color:var(--navy-50)}
.check-list{display:grid;gap:.5rem;margin-top:1.25rem}
@media(min-width:640px){.check-list.cols{grid-template-columns:1fr 1fr}}
.check-list li{display:flex;align-items:flex-start;gap:.5rem;font-size:.875rem;color:#334155}
.check-list svg{color:var(--gold-500);flex-shrink:0;margin-top:2px}
.chip{display:inline-flex;align-items:center;gap:.375rem;border-radius:999px;
  background:var(--gold-50);color:var(--gold-700);font-size:.875rem;font-weight:500;padding:.375rem .75rem}
.chips{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.5rem}

/* Testimonials */
.stars{display:flex;gap:.25rem;color:var(--gold-500)}
figure.testimonial{margin:0;display:flex;flex-direction:column;height:100%}
figure.testimonial blockquote{margin:1rem 0 0;color:#334155;flex:1}
figure.testimonial figcaption{margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid var(--navy-50)}
figure.testimonial figcaption b{color:var(--navy-700)}
figure.testimonial figcaption span{display:block;font-size:.875rem;color:var(--slate-light)}

/* CTA band */
.cta-band{position:relative;background:var(--navy-800);overflow:hidden;text-align:center}
.cta-band-in{position:relative;padding-block:4rem}
.cta-band h2{margin-top:.75rem;font-size:1.875rem;font-weight:700;color:#fff;max-width:42rem;margin-inline:auto}
@media(min-width:768px){.cta-band h2{font-size:2.25rem}}
.cta-band p{margin:1rem auto 0;color:rgba(255,255,255,.7);max-width:36rem}
.cta-band .actions{margin-top:2rem;display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center}

/* ---------- Sidebar layouts ---------- */
.split{display:grid;gap:2.5rem}
@media(min-width:1024px){.split{grid-template-columns:2fr 1fr}.split.rev{grid-template-columns:1fr 1fr}}
.sidebar{display:flex;flex-direction:column;gap:1.5rem}
@media(min-width:1024px){.sidebar.sticky{position:sticky;top:7rem;align-self:start}}
.side-nav a{display:flex;align-items:center;gap:.75rem;border-radius:.5rem;padding:.5rem;font-size:.875rem;
  font-weight:500;color:var(--navy-700)}
.side-nav a:hover{background:var(--navy-50)}
.side-nav svg{color:var(--gold-600)}
.card-navy{background:var(--navy-700);border-color:var(--navy-700)}
.card-navy h3{color:#fff}
.card-navy p{color:rgba(255,255,255,.7);font-size:.875rem;margin-top:.5rem}

/* Blog */
.post-card{overflow:hidden;display:flex;flex-direction:column;height:100%}
.post-card .thumb{height:10rem;background:var(--navy-700);display:grid;place-items:center;color:var(--gold-400);
  background-image:radial-gradient(rgba(255,255,255,.1) 1px,transparent 1px);background-size:18px 18px}
.post-card .body{padding:1.5rem;display:flex;flex-direction:column;flex:1}
.post-card .date{display:flex;align-items:center;gap:.375rem;font-size:.75rem;color:var(--slate-light)}
.post-card h2{margin-top:.75rem;font-size:1.05rem;font-weight:700;color:var(--navy-700);line-height:1.35}
.post-card h2 a:hover{color:var(--gold-600)}
.post-card .exc{margin-top:.5rem;font-size:.875rem;color:var(--slate);flex:1}
.prose h2{font-size:1.5rem;font-weight:700;color:var(--navy-700);margin:2rem 0 .75rem}
.prose p{margin-bottom:1rem;color:#334155}
.post-intro{font-size:1.125rem;color:#334155;border-left:4px solid var(--gold-500);padding-left:1rem;margin-top:1rem}

/* ---------- Contact ---------- */
.map-frame{border-radius:var(--radius);overflow:hidden;min-height:420px;height:100%;border:1px solid var(--navy-50)}
.map-frame iframe{width:100%;height:100%;min-height:420px;border:0;display:block}
.info-lines a:hover{color:var(--gold-600)}

/* ---------- Footer ---------- */
.site-footer{background:var(--navy-900);color:rgba(255,255,255,.7)}
.footer-grid{display:grid;gap:2.5rem;padding-block:3.5rem}
@media(min-width:768px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.footer-grid{grid-template-columns:2fr 1fr 1fr 1.2fr}}
.site-footer h2{font-size:1rem;font-weight:600;color:#fff;margin-bottom:1rem;font-family:var(--font-sans)}
.site-footer ul li{margin-bottom:.625rem;font-size:.875rem}
.site-footer ul a:hover{color:var(--gold-300)}
.footer-brand p{margin-top:1rem;font-size:.875rem;line-height:1.6;max-width:24rem}
.footer-brand .slogan{margin-top:.75rem;color:var(--gold-400);font-family:var(--font-display);font-style:italic}
.footer-brand .reg{margin-top:.75rem;font-size:.75rem;color:rgba(255,255,255,.5)}
.footer-contact li{display:flex;gap:.625rem;margin-bottom:.75rem}
.footer-contact svg{color:var(--gold-400);flex-shrink:0;margin-top:2px}
.newsletter{display:flex;gap:.5rem;margin-top:.5rem}
.newsletter input{flex:1;border-radius:.5rem;background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.2);padding:.5rem .75rem;font-size:.875rem;color:#fff}
.newsletter input::placeholder{color:rgba(255,255,255,.4)}
.newsletter input:focus{outline:none;border-color:var(--gold-400)}
.newsletter button{border-radius:.5rem;background:var(--gold-500);padding:.5rem .75rem;
  font-size:.875rem;font-weight:600;color:var(--navy-700)}
.newsletter button:hover{background:var(--gold-400)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1)}
.footer-bottom-in{padding-block:1.25rem;display:flex;flex-direction:column;gap:.75rem;
  align-items:center;justify-content:space-between;font-size:.75rem;color:rgba(255,255,255,.5)}
@media(min-width:640px){.footer-bottom-in{flex-direction:row}}
.footer-bottom-in .links{display:flex;gap:1.25rem}
.footer-bottom-in a:hover{color:var(--gold-300)}

/* ---------- Floating actions ---------- */
.floaters{position:fixed;right:1rem;bottom:1rem;z-index:40;display:flex;flex-direction:column;align-items:flex-end;gap:.75rem}
.wa-btn{display:grid;place-items:center;width:52px;height:52px;border-radius:999px;
  background:#25D366;color:#fff;box-shadow:0 8px 20px rgba(0,0,0,.2);transition:transform .2s}
.wa-btn:hover{transform:scale(1.05)}
.top-btn{display:none;place-items:center;width:44px;height:44px;border-radius:999px;
  background:var(--navy-700);color:#fff;box-shadow:0 8px 20px rgba(0,0,0,.15)}
.top-btn.show{display:grid}
.top-btn:hover{background:var(--navy-600)}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.reveal.is-visible{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}

/* ---------- Utility ---------- */
.flex-between{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:1rem}
.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.mt-6{margin-top:3rem}
.text-center{text-align:center}
.skip-link{position:absolute;left:-9999px;top:0;z-index:100;background:var(--gold-500);
  color:var(--navy-700);font-weight:600;padding:.5rem 1rem;border-radius:.5rem}
.skip-link:focus{left:.75rem;top:.75rem}
.notfound{background:var(--navy-700);min-height:70vh;display:grid;place-items:center;text-align:center;padding:1.5rem}
.notfound .code{font-size:5rem;font-weight:800;color:var(--gold-400)}
@media(min-width:768px){.notfound .code{font-size:6rem}}
.notfound h1{margin-top:1rem;font-size:1.75rem;color:#fff}
.notfound p{margin:.75rem auto 0;color:rgba(255,255,255,.7);max-width:28rem}
.notfound .actions{margin-top:2rem;display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}
