/* === Design tokens (brand-driven) === */
:root{
  --blue:#002B5B;           /* Brand dark blue */
  --gold:#D4A017;           /* Brand gold */
  --dark:#2A2B2D;
  --white:#FFFFFF;
  --bg:#F6F7F9;
  --radius:16px;
  --shadow:0 8px 24px rgba(0,0,0,.08);
}

/* === Reset & type === */
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family: "Raleway", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--dark);
  background:#fff;
  line-height:1.6;
  text-rendering:optimizeLegibility;
}

/* Headings use Codec Pro (local) */
h1,h2,h3{
  font-family: "Codec Pro", "Raleway", system-ui, -apple-system, Segoe UI, Arial, sans-serif;
  font-weight:400;
  letter-spacing:.2px;
  line-height:1.2;
  margin:0 0 .6rem 0;
  color:var(--blue);
}
h1{font-size:clamp(2rem,4.5vw,3.25rem)}
h2{font-size:clamp(1.5rem,2.5vw,2.2rem)}
h3{font-size:1.25rem}
p{margin:.5rem 0 1rem}
.lead{font-size:1.125rem}
.tagline{font-weight: 700;}
.accent{color:var(--gold)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skiplink{position:absolute;left:-9999px;top:auto}
.skiplink:focus{left:1rem;top:1rem;background:var(--blue);color:#fff;padding:.5rem 1rem;border-radius:.5rem;z-index:1000}

/* === Layout === */
.container{width:min(1100px, 92%); margin-inline:auto}
.section{padding:64px 0}
.section--tint{background:var(--bg)}
.grid-2{display:grid; gap:32px; grid-template-columns: 1.1fr .9fr}
@media (max-width:900px){ .grid-2{grid-template-columns:1fr} }

/* === Header === */
.site-header{position:static; top:0; z-index:50; background:#fff; border-bottom:1px solid #eee}
.header-inner{display:flex; align-items:center; justify-content:space-between; padding:14px 0}
.brand img{display:block}
.nav{display:flex; gap:20px; align-items:center}
.nav a{color:var(--dark); text-decoration:none; font-weight:600}
.nav a:hover{color:var(--blue)}
.nav .btn{margin-left:8px}
.nav-toggle{display:none; background:none; border:0; font-size:1.35rem}
@media (max-width:860px){
  .nav-toggle{display:block}
  .nav{position:fixed; inset:64px 0 auto 0; background:#fff; box-shadow:var(--shadow);
       flex-direction:column; padding:16px; transform:translateY(-120%); transition:.25s}
  .nav.open{transform:translateY(0)}
}

/* === Buttons === */
.btn{
  display:inline-block; padding:.8rem 1.1rem; border-radius:999px; text-decoration:none;
  font-weight:700; border:2px solid transparent; transition:.2s;
}
.btn--primary{background:var(--blue); color:#fff}
.btn--primary:hover{filter:brightness(1.1)}
.btn--gold{background:var(--gold); color:#fff}         /* gold with WHITE text (as requested) */
.btn--gold:hover{filter:brightness(1.05)}
.btn--outline{border-color:var(--blue); color:var(--blue); background:transparent}
.btn--outline:hover{background:rgba(0,43,91,.06)}

/* === Hero === */
.hero{position:relative; overflow:hidden}
.hero .container{padding:96px 0}
.hero .hero-cta{display:flex; gap:12px; margin-top:18px; flex-wrap:wrap}
.hero-image{
  position:absolute; inset:0;
  background:
    linear-gradient(0deg, rgba(255,255,255,.78), rgba(255,255,255,.78)),
    url("img/hero.jpg") center/cover no-repeat;
  z-index:-1;
}

/* === Cards, lists === */
.card{
  background:#fff; border-radius:var(--radius); padding:24px;
  box-shadow:var(--shadow);
}
.cards{display:grid; grid-template-columns:repeat(4,1fr); gap:20px; margin-top:18px}
@media (max-width:1100px){ .cards{grid-template-columns:repeat(2,1fr)} }
@media (max-width:600px){ .cards{grid-template-columns:1fr} }
.list{padding-left:1rem}
.list li{margin:.35rem 0}
.checklist{list-style:none; padding-left:0; margin:12px 0 0}
.checklist li{padding-left:28px; position:relative}
.checklist li::before{
  content:"\f00c"; font-family:"Font Awesome 6 Free"; font-weight:900;
  position:absolute; left:0; top:0; color:var(--gold)
}

/* Service icons */
.service-ic{font-size:1.6rem; color:var(--blue); margin-bottom:.25rem; display:inline-block}

/* === Modern timeline === */
.timeline{
  display:grid; grid-template-columns:repeat(4,1fr); gap:16px; align-items:stretch;
}
.t-item{
  background:#fff; border-radius:var(--radius); padding:20px; box-shadow:var(--shadow);
}
.t-icon{
  width:44px;height:44px; border-radius:50%; background:var(--gold); color:#fff;
  display:grid; place-items:center; margin-bottom:.5rem;
}
@media (max-width:900px){ .timeline{grid-template-columns:1fr 1fr} }
@media (max-width:600px){ .timeline{grid-template-columns:1fr} }

/* === Contact section (gold bg, white text) === */
.section--gold{ background:#ECBD3F; color:var(--blue); }
.section--gold h2, .section--gold .lead{color:var(--blue); }

.contact-grid{ align-items:center; }
.contact-info .label{ font-size:.85rem; opacity:.85; letter-spacing:.02em; }
.contact-list{ list-style:none; padding:0; margin:18px 0; display:grid; gap:12px; }
.contact-list li{ display:grid; grid-template-columns:28px 1fr; gap:12px; align-items:start; }
.contact-list i{ font-size:1.1rem; line-height:1.6; }
.section--gold a{ color:var(--blue); text-decoration:underline; text-underline-offset:2px; }
.section--gold a:hover{ opacity:.9; }

.contact-badges{ display:flex; gap:8px; flex-wrap:wrap; margin-top:8px; }
.contact-badges span{
  display:inline-flex; align-items:center; gap:8px;
  border-radius:999px; font-weight:600;
}
.contact-form .btn--primary{ background:var(--blue); color:#fff; }

/* === Footer (dark blue background, 3 columns) === */
.site-footer--dark{ background:var(--blue); color:#fff; }
.site-footer--dark .accent{ color:var(--gold); }
.footer-grid{
  display:grid; grid-template-columns:1.2fr 1fr 1fr; gap:28px;
  padding:36px 0 16px; align-items:start;
}
.footer-title{ margin:0 0 .6rem; font-size:1rem; text-transform:uppercase; letter-spacing:.04em; color:#fff; }
.footer-menu{ list-style:none; padding:0; margin:0; display:grid; gap:.45rem; }
.site-footer--dark a{ color:#fff; text-decoration:none; opacity:.9; }
.site-footer--dark a:hover{ opacity:1; text-decoration:underline; text-underline-offset:2px; }
.footer-address{ font-style:normal; line-height:1.6; }
.footer-tagline{ margin-top:.5rem; opacity:.9; }
.footer-bottom{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 0 24px; border-top:1px solid rgba(255,255,255,.18);
}
.footer-social{ display:flex; gap:10px; }
.footer-social a{
  display:inline-flex; width:36px; height:36px; align-items:center; justify-content:center;
  border:1px solid rgba(255,255,255,.35); border-radius:999px;
}
@media (max-width:800px){
  .footer-grid{ grid-template-columns:1fr; }
  .footer-bottom{ flex-direction:column; gap:10px; }
}

/* === Minor tweak: Contact button in header should be white on gold === */
.btn--gold{ background:var(--gold); color:#fff; }
.btn--gold:hover{ filter:brightness(1.05); }

/* === Forms === */
.form label{display:block; font-weight:600; margin:.25rem 0}
.form input,.form textarea{
  width:100%; margin:.35rem 0 1rem; padding:.75rem .9rem; border:1px solid #d9dee5; border-radius:10px}


  