/* ============================================================
   GAMA — General Arabian Medical & Allied Services Limited
   Premium static stylesheet (vanilla CSS, no build step)
   ============================================================ */

/* ---------- Design Tokens ---------- */
:root{
  --bg: #FFFFFF;
  --bg-elev: #F6FAFB;
  --bg-cream: #F1F0EB;
  --text: #0B1220;
  --text-muted: #475569;
  --heading: #0B3A66;
  --border: #D7E3E8;

  --primary: #2B869D;
  --primary-deep: #25788C;
  --primary-2: #60A5B6;
  --primary-weak: #95C3CE;
  --hero-blue: #0074C7;
  --navy: #0B3A66;
  --accent: #FFB666;
  --accent-deep: #E89B3F;

  --link: #0B3A66;
  --focus: #FFB666;

  --success: #0F766E;
  --danger: #B91C1C;

  --shadow-sm: 0 1px 2px rgba(11,18,32,.06);
  --shadow-md: 0 10px 30px rgba(11,18,32,.10);
  --shadow-lg: 0 24px 60px rgba(11,18,32,.16);

  --radius-sm: 10px;
  --radius-md: 16px;
  --radius-lg: 22px;
  --radius-pill: 999px;

  --container: 1160px;
  --gutter: 22px;

  --ff-head: "Space Grotesk", system-ui, sans-serif;
  --ff-body: "IBM Plex Sans", system-ui, sans-serif;
  --ff-mono: "IBM Plex Mono", ui-monospace, monospace;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--ff-body);
  font-size:1rem;
  line-height:1.65;
  color:var(--text);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:var(--link);text-decoration:none}
ul{margin:0;padding:0;list-style:none}
h1,h2,h3,h4{font-family:var(--ff-head);color:var(--heading);line-height:1.1;letter-spacing:-.02em;margin:0 0 .5em}
h1{font-size:clamp(2.3rem,4.4vw,3.9rem);font-weight:600}
h2{font-size:clamp(1.7rem,2.6vw,2.5rem);font-weight:600}
h3{font-size:1.3rem;font-weight:600}
p{margin:0 0 1rem}
::selection{background:var(--primary-weak);color:var(--navy)}

/* ---------- Helpers ---------- */
.container{max-width:var(--container);margin:0 auto;padding:0 var(--gutter)}
.section{padding:clamp(56px,8vw,104px) 0}
.section-tight{padding:clamp(40px,5vw,64px) 0}
.bg-elev{background:var(--bg-elev)}
.bg-cream{background:var(--bg-cream)}
.bg-navy{background:var(--navy);color:#fff}
.text-center{text-align:center}
.eyebrow{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--ff-mono);font-size:.78rem;font-weight:500;
  letter-spacing:.16em;text-transform:uppercase;color:var(--primary);
  margin-bottom:1rem;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--accent);border-radius:2px}
.lead{font-size:1.15rem;color:var(--text-muted);max-width:62ch}
.muted{color:var(--text-muted)}
.section-head{max-width:760px;margin-bottom:clamp(32px,4vw,56px)}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}
.grain{position:relative}
.skip-link{position:absolute;left:-999px;top:0;background:var(--navy);color:#fff;padding:10px 16px;border-radius:0 0 8px 0;z-index:200}
.skip-link:focus{left:0}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  border-radius:var(--radius-pill);padding:.9rem 1.5rem;
  font:600 .95rem/1 var(--ff-body);letter-spacing:.01em;
  border:1px solid transparent;cursor:pointer;white-space:nowrap;
  transition:background-color .2s ease,border-color .2s ease,box-shadow .2s ease,color .2s ease,transform .12s ease;
}
.btn i{font-size:.9em}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--primary);color:#fff;box-shadow:0 10px 24px rgba(43,134,157,.26)}
.btn-primary:hover{background:var(--primary-deep);box-shadow:0 14px 30px rgba(43,134,157,.32)}
.btn-accent{background:var(--accent);color:#3a2606;box-shadow:0 10px 24px rgba(255,182,102,.34)}
.btn-accent:hover{background:var(--accent-deep);color:#2a1c04}
.btn-secondary{background:#fff;border-color:rgba(43,134,157,.4);color:var(--heading)}
.btn-secondary:hover{border-color:var(--primary);box-shadow:var(--shadow-sm)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.4)}
.btn-ghost:hover{background:rgba(255,255,255,.12)}
.btn:focus-visible{outline:none;box-shadow:0 0 0 4px rgba(255,182,102,.5)}
.btn-lg{padding:1.05rem 1.9rem;font-size:1.02rem}

/* ---------- Header / Nav ---------- */
.site-header{
  position:sticky;top:0;z-index:80;
  background:rgba(255,255,255,.82);
  backdrop-filter:saturate(150%) blur(12px);
  -webkit-backdrop-filter:saturate(150%) blur(12px);
  border-bottom:1px solid rgba(215,227,232,.8);
  transition:box-shadow .25s ease,background-color .25s ease;
}
.site-header.is-scrolled{background:rgba(255,255,255,.95);box-shadow:var(--shadow-sm)}
.header-inner{display:flex;align-items:center;gap:1.2rem;height:74px}
.brand{display:flex;align-items:center;flex-shrink:0}
.brand-logo{height:56px;width:auto}
.main-nav{margin-left:auto}
.main-nav ul{display:flex;align-items:center;gap:.35rem}
.main-nav a{
  position:relative;display:inline-block;padding:.55rem .8rem;
  font-weight:500;font-size:.95rem;color:var(--text);border-radius:8px;
  transition:color .18s ease,background-color .18s ease;
}
.main-nav a::after{
  content:"";position:absolute;left:.8rem;right:.8rem;bottom:.32rem;height:2px;
  background:var(--accent);border-radius:2px;transform:scaleX(0);transform-origin:left;
  transition:transform .25s cubic-bezier(.2,.8,.2,1);
}
.main-nav a:hover{color:var(--primary)}
.main-nav a:hover::after,.main-nav a.is-active::after{transform:scaleX(1)}
.main-nav a.is-active{color:var(--navy)}
.nav-cta{margin-left:.6rem}
.nav-toggle{
  display:none;margin-left:auto;width:46px;height:46px;border-radius:12px;
  border:1px solid var(--border);background:#fff;cursor:pointer;
  flex-direction:column;gap:5px;align-items:center;justify-content:center;
}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--navy);border-radius:2px;transition:transform .25s ease,opacity .2s ease}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Drawer */
.nav-drawer{
  position:fixed;inset:0 0 0 auto;width:min(86vw,360px);background:#fff;z-index:90;
  transform:translateX(100%);transition:transform .35s cubic-bezier(.2,.8,.2,1);
  box-shadow:var(--shadow-lg);padding:90px 26px 30px;display:flex;flex-direction:column;gap:.4rem;
}
.nav-drawer.is-open{transform:translateX(0)}
.nav-drawer a{padding:.85rem .4rem;font-size:1.05rem;font-weight:500;color:var(--text);border-bottom:1px solid var(--bg-elev)}
.nav-drawer .btn{margin-top:1rem}
.nav-overlay{position:fixed;inset:0;background:rgba(11,18,32,.42);opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease;z-index:85}
.nav-overlay.is-open{opacity:1;visibility:visible}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;padding:clamp(60px,9vw,120px) 0 clamp(56px,7vw,96px);isolation:isolate}
.hero-backdrop{
  position:absolute;inset:0;z-index:-2;
  background:
    radial-gradient(1100px 560px at 18% 8%, rgba(96,165,182,.34), transparent 60%),
    radial-gradient(820px 480px at 86% 0%, rgba(255,182,102,.20), transparent 55%),
    linear-gradient(180deg,#F6FAFB 0%,#FFFFFF 56%,#F1F0EB 100%);
}
.hero-orb{position:absolute;border-radius:50%;filter:blur(2px);z-index:-1;opacity:.5;pointer-events:none}
.hero-orb.o1{width:240px;height:240px;left:6%;top:30%;background:radial-gradient(circle at 30% 30%,rgba(96,165,182,.5),transparent 70%)}
.hero-orb.o2{width:180px;height:180px;right:14%;bottom:8%;background:radial-gradient(circle at 40% 40%,rgba(255,182,102,.45),transparent 70%)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,4vw,56px);align-items:center}
.hero-copy h1{margin-bottom:1rem}
.hero-copy .lead{margin-bottom:1.8rem;font-size:1.22rem}
.hero-actions{display:flex;flex-wrap:wrap;gap:.9rem;margin-bottom:1.8rem}
.hero-badges{display:flex;flex-wrap:wrap;gap:1.4rem;color:var(--text-muted);font-size:.92rem}
.hero-badges span{display:inline-flex;align-items:center;gap:.5rem}
.hero-badges i{color:var(--primary)}
.hero-visual{position:relative}
.hero-card{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow-lg);border:1px solid rgba(255,255,255,.6);
  aspect-ratio:4/4.4;
}
.hero-card img{width:100%;height:100%;object-fit:cover}
.hero-card::after{content:"";position:absolute;inset:0;background:linear-gradient(160deg,rgba(11,58,102,.05),rgba(11,58,102,.28))}
.hero-float{
  position:absolute;left:-26px;bottom:34px;z-index:3;background:#fff;border-radius:var(--radius-md);
  box-shadow:var(--shadow-md);padding:1rem 1.2rem;display:flex;align-items:center;gap:.9rem;border:1px solid var(--border);
}
.hero-float .hf-num{font-family:var(--ff-head);font-size:1.7rem;font-weight:600;color:var(--primary)}
.hero-float .hf-label{font-size:.82rem;color:var(--text-muted);line-height:1.3}
.hero-canvas{position:absolute;inset:0;z-index:-1;width:100%;height:100%;pointer-events:none;opacity:.55}

/* ---------- Trust strip / stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.stat{padding:1.2rem 0}
.stat .num{font-family:var(--ff-head);font-size:clamp(2rem,3vw,2.8rem);font-weight:600;color:var(--navy);line-height:1}
.stat .num .suffix{color:var(--primary)}
.stat .label{margin-top:.5rem;color:var(--text-muted);font-size:.95rem}
.divider-top{border-top:1px solid var(--border)}

/* ---------- Cards / bento ---------- */
.grid{display:grid;gap:24px}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}
.card{
  background:var(--bg);border:1px solid rgba(215,227,232,.9);border-radius:var(--radius-md);
  box-shadow:var(--shadow-sm);padding:1.7rem;transition:box-shadow .25s ease,border-color .25s ease,transform .25s ease;
}
.card:hover{box-shadow:var(--shadow-md);border-color:var(--primary-weak)}
.icon-badge{
  width:54px;height:54px;border-radius:14px;display:grid;place-items:center;margin-bottom:1.1rem;
  background:linear-gradient(160deg,rgba(43,134,157,.14),rgba(96,165,182,.18));color:var(--primary);font-size:1.35rem;
}
.icon-badge.amber{background:linear-gradient(160deg,rgba(255,182,102,.22),rgba(232,155,63,.22));color:var(--accent-deep)}
.card h3{margin-bottom:.5rem}
.card p{color:var(--text-muted);margin:0}

/* feature bento */
.bento{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:1fr;gap:22px}
.bento .card.span-2{grid-column:span 2}
@media(max-width:860px){.bento{grid-template-columns:1fr 1fr}.bento .card.span-2{grid-column:span 2}}

/* ---------- 3D Tilt project cards ---------- */
.tilt-card{
  position:relative;background:#fff;border:1px solid var(--border);border-radius:var(--radius-md);
  overflow:hidden;transform-style:preserve-3d;will-change:transform;
  transition:box-shadow .25s ease,border-color .25s ease,transform .35s cubic-bezier(.2,.8,.2,1);
  box-shadow:var(--shadow-sm);
}
.tilt-card:hover{box-shadow:var(--shadow-lg);border-color:var(--primary-weak)}
.tilt-media{position:relative;aspect-ratio:16/10;overflow:hidden}
.tilt-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.tilt-card:hover .tilt-media img{transform:scale(1.06)}
.tilt-year{
  position:absolute;top:14px;left:14px;z-index:3;font-family:var(--ff-mono);font-size:.78rem;font-weight:500;
  background:rgba(11,58,102,.86);color:#fff;padding:.4rem .7rem;border-radius:var(--radius-pill);letter-spacing:.04em;
}
.tilt-tag{
  position:absolute;top:14px;right:14px;z-index:3;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;
  background:rgba(255,255,255,.92);color:var(--primary);padding:.38rem .7rem;border-radius:var(--radius-pill);
}
.tilt-body{padding:1.4rem 1.5rem 1.6rem}
.tilt-body h3{margin-bottom:.35rem;font-size:1.18rem}
.tilt-body p{color:var(--text-muted);margin:0;font-size:.95rem}
.tilt-glare{pointer-events:none;position:absolute;inset:0;border-radius:inherit;background:radial-gradient(420px 180px at var(--mx,50%) var(--my,20%),rgba(255,255,255,.45),transparent 60%);opacity:0;transition:opacity .25s ease;mix-blend-mode:overlay}
.tilt-card:hover .tilt-glare{opacity:1}

/* project filters */
.filters{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:2rem}
.chip{
  font:600 .85rem/1 var(--ff-body);padding:.6rem 1.1rem;border-radius:var(--radius-pill);
  background:#fff;border:1px solid var(--border);color:var(--text-muted);cursor:pointer;
  transition:color .2s ease,background-color .2s ease,border-color .2s ease;
}
.chip:hover{border-color:var(--primary-weak);color:var(--primary)}
.chip.is-active{background:var(--primary);border-color:var(--primary);color:#fff}
.chip:focus-visible{outline:none;box-shadow:0 0 0 4px rgba(255,182,102,.5)}

/* ---------- Image-less portfolio (categorised) ---------- */
.pf-group{margin-bottom:2.6rem}
.pf-group:last-child{margin-bottom:0}
.pf-group-title{display:flex;align-items:center;gap:.75rem;font-family:var(--ff-head);color:var(--navy);font-size:1.18rem;margin:0 0 1.2rem;padding-bottom:.8rem;border-bottom:1px solid var(--border)}
.pf-group-title i{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;background:linear-gradient(160deg,rgba(43,134,157,.14),rgba(96,165,182,.2));color:var(--primary);font-size:1.05rem;flex-shrink:0}
.pf-group-title .pf-count{margin-left:auto;font-family:var(--ff-mono);font-size:.78rem;font-weight:500;color:var(--text-muted)}
.pf-card{position:relative;background:#fff;border:1px solid var(--border);border-radius:var(--radius-md);padding:1.25rem 1.35rem 1.25rem 1.5rem;box-shadow:var(--shadow-sm);overflow:hidden;transition:box-shadow .25s ease,border-color .25s ease,transform .25s ease}
.pf-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,var(--primary),var(--primary-2))}
.pf-card:hover{box-shadow:var(--shadow-md);border-color:var(--primary-weak);transform:translateY(-3px)}
.pf-year{display:inline-block;font-family:var(--ff-mono);font-size:.74rem;font-weight:600;color:var(--accent-deep);background:rgba(255,182,102,.18);padding:.26rem .62rem;border-radius:var(--radius-pill);margin-bottom:.7rem;letter-spacing:.04em}
.pf-card h4{font-family:var(--ff-head);color:var(--navy);font-size:1.02rem;line-height:1.3;margin:0 0 .4rem}
.pf-card .pf-loc{margin:0;color:var(--text-muted);font-size:.88rem;display:flex;align-items:center;gap:.45rem}
.pf-card .pf-loc i{color:var(--primary);font-size:.85em}

/* ---------- Page hero (sub pages) ---------- */
.page-hero{position:relative;padding:clamp(60px,8vw,110px) 0 clamp(36px,5vw,64px);overflow:hidden;isolation:isolate}
.page-hero .hero-backdrop{background:
  radial-gradient(900px 460px at 80% -10%, rgba(255,182,102,.18), transparent 55%),
  radial-gradient(1000px 520px at 10% 0%, rgba(96,165,182,.28), transparent 60%),
  linear-gradient(180deg,#F6FAFB 0%,#FFFFFF 100%)}
.breadcrumb{font-size:.85rem;color:var(--text-muted);margin-bottom:1rem;display:flex;gap:.5rem;align-items:center}
.breadcrumb a{color:var(--primary)}
.breadcrumb i{font-size:.7rem;color:var(--primary-weak)}
.page-hero h1{margin-bottom:.6rem}

/* ---------- About / editorial ---------- */
.editorial{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,64px);align-items:center}
.portrait{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:4/4.6}
.portrait img{width:100%;height:100%;object-fit:cover}
.pullquote{
  border-left:4px solid var(--accent);background:var(--bg-elev);
  padding:1.4rem 1.6rem;border-radius:0 var(--radius-md) var(--radius-md) 0;margin:1.6rem 0;
  font-size:1.12rem;color:var(--navy);font-style:italic;
}
.signature{font-family:var(--ff-head);color:var(--navy);font-size:1.1rem;margin-top:1rem}
.signature small{display:block;font-family:var(--ff-body);color:var(--text-muted);font-style:normal;font-size:.85rem;margin-top:.2rem}

/* values grid */
.value{display:flex;gap:1rem;align-items:flex-start}
.value i{color:var(--primary);font-size:1.2rem;margin-top:.2rem}
.value h4{margin:0 0 .2rem;font-family:var(--ff-head);color:var(--navy)}
.value p{margin:0;color:var(--text-muted);font-size:.95rem}

/* mission split */
.split-cards{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.mv-card{position:relative;overflow:hidden;border-radius:var(--radius-lg);padding:2.2rem;border:1px solid var(--border);background:#fff;box-shadow:var(--shadow-sm)}
.mv-card.teal{background:linear-gradient(160deg,#fff, #F2F8F9);}
.mv-card .icon-badge{margin-bottom:1.3rem}

/* ---------- Timeline ---------- */
.timeline{position:relative;max-width:920px;margin:0 auto;padding:1rem 0}
.timeline::before{content:"";position:absolute;left:18px;top:0;bottom:0;width:2px;
  background:linear-gradient(180deg,rgba(43,134,157,0),rgba(43,134,157,.5),rgba(255,182,102,.45),rgba(43,134,157,0))}
.tl-item{position:relative;padding:0 0 2.4rem 58px}
.tl-node{position:absolute;left:10px;top:4px;width:18px;height:18px;border-radius:50%;background:#fff;border:3px solid var(--primary);z-index:2}
.tl-node::after{content:"";position:absolute;inset:-7px;border-radius:50%;border:2px solid rgba(43,134,157,.3);opacity:0}
.tl-item.is-in .tl-node::after{animation:pulse 1.4s ease-out 1}
@keyframes pulse{0%{opacity:.8;transform:scale(.6)}100%{opacity:0;transform:scale(1.5)}}
.tl-year{font-family:var(--ff-mono);font-size:.85rem;font-weight:600;color:var(--accent-deep);letter-spacing:.05em}
.tl-card{margin-top:.5rem;background:#fff;border:1px solid var(--border);border-radius:var(--radius-md);padding:1.4rem 1.5rem;box-shadow:var(--shadow-sm)}
.tl-card h3{margin:0 0 .35rem;font-size:1.15rem}
.tl-card p{margin:0;color:var(--text-muted);font-size:.95rem}
@media(min-width:900px){
  .timeline::before{left:50%;transform:translateX(-50%)}
  .tl-item{width:50%;padding:0 0 2.8rem 0}
  .tl-item:nth-child(odd){left:0;padding-right:48px;text-align:right}
  .tl-item:nth-child(even){left:50%;padding-left:48px}
  .tl-item:nth-child(odd) .tl-node{left:auto;right:-9px}
  .tl-item:nth-child(even) .tl-node{left:-9px}
}

/* ---------- Table (careers) ---------- */
.table-wrap{border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;background:#fff;box-shadow:var(--shadow-sm)}
.table{width:100%;border-collapse:collapse}
.table thead th{background:var(--bg-elev);text-align:left;font:600 .8rem/1.3 var(--ff-body);text-transform:uppercase;letter-spacing:.06em;color:var(--navy);padding:1rem 1.2rem;border-bottom:1px solid var(--border)}
.table td{padding:1.1rem 1.2rem;border-bottom:1px solid rgba(215,227,232,.6);color:var(--text);vertical-align:top;font-size:.95rem}
.table tbody tr:last-child td{border-bottom:none}
.table tbody tr:hover{background:rgba(96,165,182,.06)}
.table .role{font-weight:600;color:var(--navy)}
@media(max-width:760px){
  .table thead{display:none}
  .table,.table tbody,.table tr,.table td{display:block;width:100%}
  .table tr{border-bottom:1px solid var(--border);padding:.6rem 0}
  .table td{border:none;padding:.5rem 1.1rem}
  .table td::before{content:attr(data-label);display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--primary);font-weight:600;margin-bottom:.2rem}
}

/* ---------- Forms ---------- */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.field{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.1rem}
.field.full{grid-column:1/-1}
.field label{font-size:.88rem;font-weight:600;color:var(--navy)}
.field label .req{color:var(--danger)}
.input,.textarea{
  font:400 1rem/1.5 var(--ff-body);color:var(--text);
  border:1px solid var(--border);border-radius:12px;padding:.85rem 1rem;background:#fff;
  transition:border-color .18s ease,box-shadow .18s ease;width:100%;
}
.textarea{resize:vertical;min-height:140px}
.input:focus,.textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px rgba(149,195,206,.4)}
.input.invalid,.textarea.invalid{border-color:var(--danger);box-shadow:0 0 0 4px rgba(185,28,28,.12)}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-note{font-size:.85rem;color:var(--text-muted)}
.form-status{margin-top:1rem;padding:.95rem 1.1rem;border-radius:12px;font-size:.95rem;display:none}
.form-status.show{display:block}
.form-status.ok{background:rgba(15,118,110,.1);color:#0F766E;border:1px solid rgba(15,118,110,.3)}
.form-status.err{background:rgba(185,28,28,.08);color:#B91C1C;border:1px solid rgba(185,28,28,.25)}

/* contact details */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(28px,4vw,52px);align-items:start}
.contact-detail{display:flex;gap:1rem;padding:1.1rem 0;border-bottom:1px solid var(--border)}
.contact-detail:last-child{border-bottom:none}
.contact-detail .ci{width:46px;height:46px;border-radius:12px;background:linear-gradient(160deg,rgba(43,134,157,.14),rgba(96,165,182,.18));color:var(--primary);display:grid;place-items:center;font-size:1.1rem;flex-shrink:0}
.contact-detail h4{margin:0 0 .15rem;font-family:var(--ff-head);color:var(--navy);font-size:1rem}
.contact-detail p,.contact-detail a{margin:0;color:var(--text-muted);font-size:.95rem}
.contact-detail a:hover{color:var(--primary)}
.map-wrap{border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow-sm);margin-top:1.6rem}
.map-wrap iframe{display:block;width:100%;height:300px;border:0;filter:grayscale(.2) contrast(1.03)}

/* ---------- CTA band ---------- */
.cta-band{position:relative;overflow:hidden;border-radius:var(--radius-lg);isolation:isolate;background:var(--navy)}
.cta-band .cta-bg{position:absolute;inset:0;z-index:-2;opacity:.22;object-fit:cover;width:100%;height:100%}
.cta-band::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(120deg,rgba(11,58,102,.94),rgba(43,134,157,.82))}
.cta-inner{padding:clamp(40px,6vw,72px);color:#fff;display:grid;grid-template-columns:1.4fr .6fr;gap:2rem;align-items:center}
.cta-inner h2{color:#fff}
.cta-inner p{color:rgba(255,255,255,.85);margin:0}
.cta-actions{display:flex;justify-content:flex-end;gap:.9rem;flex-wrap:wrap}
@media(max-width:760px){.cta-inner{grid-template-columns:1fr}.cta-actions{justify-content:flex-start}}

/* ---------- Footer ---------- */
.site-footer{background:var(--navy);color:rgba(255,255,255,.82)}
.footer-top{padding:clamp(48px,6vw,72px) 0 2.2rem;display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:2rem}
.footer-brand .brand-logo{height:42px;margin-bottom:1.1rem;filter:brightness(0) invert(1);opacity:.95}
.footer-brand p{color:rgba(255,255,255,.7);font-size:.92rem;max-width:34ch}
.footer-col h4{color:#fff;font-family:var(--ff-head);font-size:.82rem;text-transform:uppercase;letter-spacing:.1em;margin-bottom:1rem}
.footer-col ul{display:flex;flex-direction:column;gap:.6rem}
.footer-col a{color:rgba(255,255,255,.78);font-size:.92rem}
.footer-col a:hover{color:#fff;text-decoration:underline}
.footer-col .fc-line{display:flex;gap:.6rem;color:rgba(255,255,255,.78);font-size:.92rem;margin-bottom:.7rem}
.footer-col .fc-line i{color:var(--accent);margin-top:.2rem}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding:1.4rem 0;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.85rem;color:rgba(255,255,255,.6)}
.footer-bottom a{color:rgba(255,255,255,.8)}

/* ---------- Reveal animation ---------- */
[data-reveal]{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .7s cubic-bezier(.2,.8,.2,1)}
[data-reveal].is-in{opacity:1;transform:none}
[data-reveal-delay="1"]{transition-delay:.08s}
[data-reveal-delay="2"]{transition-delay:.16s}
[data-reveal-delay="3"]{transition-delay:.24s}
[data-reveal-delay="4"]{transition-delay:.32s}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:2.4rem}
  .hero-visual{max-width:480px;margin:0 auto}
  .editorial{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .cols-4{grid-template-columns:repeat(2,1fr)}
  .stats{grid-template-columns:repeat(2,1fr);gap:1rem}
}
@media(max-width:860px){
  .main-nav,.nav-cta{display:none}
  .nav-toggle{display:flex}
  .cols-3,.split-cards,.bento{grid-template-columns:1fr}
  .bento .card.span-2{grid-column:auto}
  .form-grid{grid-template-columns:1fr}
}
@media(max-width:520px){
  .cols-2{grid-template-columns:1fr}
  .hero-float{left:8px;right:8px}
}

/* ---------- Reduced motion ---------- */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important}
  [data-reveal]{opacity:1;transform:none}
  .hero-canvas{display:none}
}
