/* Arizona Structural Experts — Shared Stylesheet */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Cormorant+Garamond:ital,wght@0,400;0,600;1,400;1,600&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  /* Exact client palette: color-hex.com/color-palette/7232 */
  --teal:     #638e99;   /* steel teal / lighter blue */
  --blue:     #366780;   /* deep slate blue — primary */
  --gray:     #777777;   /* mid gray */
  --cream:    #edeae8;   /* warm cream — main bg */
  --terra:    #b25b30;   /* terra cotta — desert accent */

  /* Surface colors */
  --bg:       #edeae8;   /* warm cream body */
  --bg-warm:  #e4dfdb;   /* slightly deeper cream for alt sections */
  --bg-card:  #ffffff;   /* white cards */
  --bg-card-hover: #f7f4f1;

  /* Text */
  --text:     #1c2c33;   /* very dark blue-gray for headings */
  --text-body:#3a4a50;   /* body text */
  --text-muted:#777777;  /* muted / captions */

  /* Green remapped to blue — no forest green */
  --green:    var(--blue);
  --green-light:var(--blue-light);
  --green-glow:var(--blue-glow);
  --green-border:var(--blue-border);

  /* Blue variants */
  --blue-light:  #4a8299;
  --blue-glow:   rgba(54,103,128,0.10);
  --blue-border: rgba(54,103,128,0.22);

  /* Terra cotta variants */
  --terra-glow:  rgba(178,91,48,0.10);
  --terra-border:rgba(178,91,48,0.25);

  /* Borders / dividers */
  --border:   rgba(99,142,153,0.18);
  --border-dark: rgba(54,103,128,0.2);

  --ease:     cubic-bezier(0.4,0,0.2,1);
  --bounce:   cubic-bezier(0.34,1.56,0.64,1);
}

html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--text-body);
  font-family:'Inter',sans-serif;
  font-size:16px;
  line-height:1.6;
  overflow-x:hidden;
}

/* Subtle noise on light bg */
body::after{
  content:'';
  position:fixed;
  inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events:none;
  z-index:9999;
  opacity:0.035;
}

/* ─── ANNOUNCEMENT BAR ─── */
.ann-bar{
  background:var(--blue);
  color:#fff;
  text-align:center;
  font-size:12px;
  font-weight:600;
  letter-spacing:0.08em;
  text-transform:uppercase;
  padding:8px 16px;
  position:relative;
  z-index:200;
}

/* ─── NAV ─── */
nav#navbar{
  position:fixed;
  top:40px;
  left:50%;
  transform:translateX(-50%);
  z-index:100;
  width:max-content;
  max-width:calc(100vw - 32px);
  transition:top 0.4s var(--ease);
}
nav#navbar.scrolled{top:8px}

.nav-inner{
  display:flex;
  align-items:center;
  gap:6px;
  padding:10px 18px;
  border-radius:100px;
  background:rgba(237,234,232,0.75);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(99,142,153,0.25);
  transition:all 0.4s var(--ease);
  box-shadow:0 2px 16px rgba(54,103,128,0.08);
}
nav#navbar.scrolled .nav-inner{
  background:rgba(237,234,232,0.97);
  border-color:var(--blue-border);
  box-shadow:0 4px 28px rgba(54,103,128,0.15);
}

.nav-logo{
  display:flex;
  align-items:center;
  gap:9px;
  text-decoration:none;
  margin-right:12px;
}
.nav-logo-icon{width:30px;height:30px;flex-shrink:0}
.nav-logo-text{display:flex;flex-direction:column;line-height:1.1}
.nav-logo-main{font-size:13px;font-weight:800;letter-spacing:0.1em;color:var(--blue);text-transform:uppercase}
.nav-logo-sub{font-size:9px;font-weight:500;letter-spacing:0.12em;color:var(--terra);text-transform:uppercase}
.nav-logo-icon polygon,.nav-logo-icon line{stroke:var(--teal)}

.nav-links{
  display:flex;
  align-items:center;
  gap:2px;
  list-style:none;
  margin-right:8px;
}
.nav-links a{
  color:var(--text-muted);
  text-decoration:none;
  font-size:13px;
  font-weight:500;
  padding:6px 12px;
  border-radius:100px;
  transition:color 0.2s,background 0.2s;
  white-space:nowrap;
}
.nav-links a:hover,.nav-links a.active{color:var(--blue);background:rgba(54,103,128,0.08)}

/* Dropdown */
.nav-dropdown{position:relative}
.nav-dropdown > a{display:flex;align-items:center;gap:4px;cursor:pointer}
.nav-dropdown > a::after{content:'▾';font-size:10px;transition:transform 0.2s}
.nav-dropdown:hover > a::after{transform:rotate(180deg)}

/* Invisible bridge fills the gap so mouse can travel to dropdown without losing hover */
.nav-dropdown-menu::before{content:'';position:absolute;top:-14px;left:0;right:0;height:14px}

.nav-dropdown-menu{
  position:absolute;
  top:calc(100% + 12px);
  left:50%;
  transform:translateX(-50%) translateY(-4px);
  min-width:210px;
  background:#fff;
  border:1px solid var(--blue-border);
  border-radius:14px;
  padding:8px 6px;
  opacity:0;
  pointer-events:none;
  transition:opacity 0.2s var(--ease),transform 0.2s var(--ease);
  box-shadow:0 12px 40px rgba(54,103,128,0.14);
}
.nav-dropdown:hover .nav-dropdown-menu{
  opacity:1;
  pointer-events:all;
  transform:translateX(-50%) translateY(0);
}
.nav-dropdown-menu a{
  display:block;
  color:var(--text-body);
  text-decoration:none;
  font-size:13px;
  font-weight:500;
  padding:9px 14px;
  border-radius:8px;
  transition:color 0.15s,background 0.15s;
  white-space:nowrap;
}
.nav-dropdown-menu a:hover{color:var(--blue);background:rgba(54,103,128,0.07)}

.btn-nav{
  background:var(--terra);
  color:#fff;
  text-decoration:none;
  font-size:13px;
  font-weight:600;
  padding:8px 18px;
  border-radius:100px;
  transition:background 0.2s,transform 0.15s var(--bounce),box-shadow 0.2s;
  white-space:nowrap;
}
.btn-nav:hover{background:#c8683a;transform:translateY(-1px);box-shadow:0 4px 16px rgba(178,91,48,0.3)}

/* ─── HERO ─── */
.hero{
  position:relative;
  height:100vh;
  min-height:600px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  overflow:hidden;
}
.hero-bg{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
}
.hero-bg::after{
  content:'';
  position:absolute;
  inset:0;
  /* Dark overlay for hero readability — gradient to cream bg at bottom */
  background:linear-gradient(180deg,rgba(28,44,51,0.55) 0%,rgba(28,44,51,0.70) 60%,var(--bg) 100%);
}
.hero-bg img{width:100%;height:100%;object-fit:cover}
.hero-content{
  position:relative;
  z-index:2;
  max-width:820px;
  padding:0 24px;
}
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:11px;
  font-weight:700;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--terra);
  margin-bottom:20px;
}
/* On dark hero backgrounds eyebrow needs lighter terra */
.hero .eyebrow{color:#d4836a}
.eyebrow::before,.eyebrow::after{content:'';display:block;width:28px;height:1px;background:currentColor;opacity:0.5}
.hero h1{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(3rem,7vw,5.5rem);
  font-weight:600;
  line-height:1.1;
  color:#ffffff;
  margin-bottom:20px;
}
.hero h1 em{color:#d4e8ef;font-style:italic}
.hero p{
  font-size:clamp(1rem,2vw,1.15rem);
  color:rgba(255,255,255,0.80);
  max-width:580px;
  margin:0 auto 36px;
  line-height:1.7;
}
.hero-ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* Short hero for inner pages */
.hero-short{
  height:52vh;
  min-height:360px;
}
.hero-short .hero-bg::after{
  background:linear-gradient(180deg,rgba(28,44,51,0.5) 0%,rgba(28,44,51,0.72) 70%,var(--bg) 100%);
}

/* ─── BUTTONS ─── */
.btn-primary{
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:var(--green);
  color:#fff;
  text-decoration:none;
  font-size:15px;
  font-weight:600;
  padding:14px 30px;
  border-radius:100px;
  border:none;
  cursor:pointer;
  transition:background 0.2s,transform 0.15s var(--bounce),box-shadow 0.2s;
}
.btn-primary:hover{background:var(--blue-light);transform:translateY(-2px);box-shadow:0 8px 24px rgba(54,103,128,0.3)}

.btn-secondary{
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:transparent;
  color:#fff;
  text-decoration:none;
  font-size:15px;
  font-weight:500;
  padding:13px 30px;
  border-radius:100px;
  border:1.5px solid rgba(255,255,255,0.4);
  cursor:pointer;
  transition:border-color 0.2s,background 0.2s,transform 0.15s var(--bounce);
}
.btn-secondary:hover{border-color:#fff;background:rgba(255,255,255,0.1);transform:translateY(-2px)}

.btn-blue{
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:var(--blue);
  color:#fff;
  text-decoration:none;
  font-size:15px;
  font-weight:600;
  padding:14px 30px;
  border-radius:100px;
  border:none;
  cursor:pointer;
  transition:background 0.2s,transform 0.15s var(--bounce),box-shadow 0.2s;
  flex-shrink:0;
}
.btn-blue:hover{background:var(--blue-light);transform:translateY(-2px);box-shadow:0 8px 24px rgba(54,103,128,0.3)}

.btn-outline{
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:transparent;
  color:var(--blue);
  text-decoration:none;
  font-size:15px;
  font-weight:600;
  padding:13px 30px;
  border-radius:100px;
  border:1.5px solid var(--blue-border);
  cursor:pointer;
  transition:border-color 0.2s,background 0.2s,transform 0.15s var(--bounce);
  flex-shrink:0;
}
.btn-outline:hover{border-color:var(--blue);background:var(--blue-glow);transform:translateY(-2px)}

/* ─── SECTIONS ─── */
.section{padding:96px 24px}
.section-sm{padding:64px 24px}
.section-alt{background:var(--bg-warm)}
.container{max-width:1180px;margin:0 auto}
.container-sm{max-width:860px;margin:0 auto}
.section-header{text-align:center;margin-bottom:60px}
.section-header .eyebrow{justify-content:center;color:var(--terra)}
.section-header h2{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2rem,4vw,3rem);
  font-weight:600;
  color:var(--text);
  margin-bottom:16px;
  line-height:1.15;
}
.section-header h2 em{color:var(--blue);font-style:italic}
.section-header p{
  font-size:1.05rem;
  color:var(--text-muted);
  max-width:560px;
  margin:0 auto;
  line-height:1.75;
}

/* ─── TRUST STRIP ─── */
.trust-strip{
  background:var(--blue);
  padding:22px 24px;
}
.trust-inner{
  max-width:1180px;
  margin:0 auto;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:40px;
  flex-wrap:wrap;
}
.trust-item{
  display:flex;
  align-items:center;
  gap:10px;
  font-size:12px;
  font-weight:600;
  letter-spacing:0.06em;
  text-transform:uppercase;
  color:rgba(255,255,255,0.80);
}
.trust-icon{
  width:32px;
  height:32px;
  background:rgba(255,255,255,0.12);
  border:1px solid rgba(255,255,255,0.2);
  border-radius:8px;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}
.trust-icon svg{width:16px;height:16px;fill:#fff}

/* ─── SERVICE CARDS ─── */
.services-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:3px;
  border-radius:20px;
  overflow:hidden;
  box-shadow:0 8px 40px rgba(54,103,128,0.12);
}
.service-card{
  position:relative;
  height:380px;
  overflow:hidden;
  cursor:pointer;
  text-decoration:none;
  display:block;
}
.service-card-bg{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
  transition:transform 0.6s var(--ease);
}
.service-card-bg::after{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(28,44,51,0.15) 0%,rgba(28,44,51,0.80) 100%);
  transition:background 0.4s;
}
.service-card:hover .service-card-bg{transform:scale(1.05)}
.service-card:hover .service-card-bg::after{background:linear-gradient(180deg,rgba(28,44,51,0.05) 0%,rgba(28,44,51,0.88) 100%)}
.service-card-content{
  position:absolute;
  bottom:0;left:0;right:0;
  padding:30px 28px;
  z-index:2;
}
.service-card-icon{
  width:44px;height:44px;
  background:rgba(178,91,48,0.2);
  border:1px solid rgba(178,91,48,0.4);
  border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:14px;
  transition:background 0.2s,border-color 0.2s;
}
.service-card:hover .service-card-icon{background:rgba(178,91,48,0.35);border-color:rgba(178,91,48,0.6)}
.service-card-icon svg{width:22px;height:22px;fill:#e07a50}
.service-card h3{
  font-family:'Cormorant Garamond',serif;
  font-size:1.8rem;font-weight:600;
  color:#fff;margin-bottom:8px;
}
.service-card p{font-size:0.88rem;color:rgba(255,255,255,0.75);margin-bottom:16px;line-height:1.55}
.service-card-link{
  font-size:13px;font-weight:600;
  color:#d4e8ef;
  letter-spacing:0.04em;
  display:flex;align-items:center;gap:6px;
  transition:gap 0.2s,color 0.2s;
}
.service-card:hover .service-card-link{gap:10px;color:#fff}

/* ─── MAP PLACEHOLDER ─── */
.map-section{background:var(--bg-warm);padding:80px 24px}
.map-placeholder{
  max-width:1180px;margin:0 auto;
  border:1.5px solid var(--blue-border);
  border-radius:16px;overflow:hidden;
  background:linear-gradient(135deg,rgba(99,142,153,0.06) 0%,rgba(54,103,128,0.04) 100%);
}
.map-placeholder-inner{
  height:420px;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  text-align:center;gap:16px;padding:40px;
}
.map-placeholder-sm .map-placeholder-inner{height:280px}
.map-icon{
  width:64px;height:64px;
  background:rgba(99,142,153,0.12);
  border:1.5px solid var(--blue-border);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
}
.map-icon svg{width:28px;height:28px;fill:var(--blue)}
.map-placeholder h3{
  font-family:'Cormorant Garamond',serif;
  font-size:1.7rem;color:var(--text);
}
.map-placeholder p{font-size:0.9rem;color:var(--text-muted);max-width:480px;line-height:1.65}
.map-badge{
  display:flex;align-items:center;gap:8px;
  background:#fff;
  border:1px solid var(--blue-border);
  padding:7px 16px;border-radius:100px;
  font-size:12px;font-weight:600;
  letter-spacing:0.06em;text-transform:uppercase;
  color:var(--blue);
}

/* ─── INTERACTIVE SERVICE MAP ─── */
.interactive-map{
  display:grid;
  grid-template-columns:240px 1fr;
  border:1.5px solid var(--blue-border);
  border-radius:20px;
  overflow:hidden;
  min-height:460px;
  box-shadow:0 8px 40px rgba(54,103,128,0.10);
}
.map-sidebar{
  background:#f7f5f2;
  border-right:1px solid var(--border);
  display:flex;flex-direction:column;
}
.map-state-tabs{display:flex;border-bottom:1px solid var(--border)}
.map-tab{
  flex:1;padding:14px 10px;background:transparent;
  border:none;border-bottom:2px solid transparent;margin-bottom:-1px;
  cursor:pointer;font-family:'Inter',sans-serif;font-size:13px;font-weight:600;
  color:var(--text-muted);transition:color 0.2s,border-color 0.2s,background 0.2s;
  display:flex;flex-direction:column;align-items:center;gap:3px;
}
.map-tab.active{color:var(--blue);border-bottom-color:var(--blue);background:#fff}
.tab-label{font-size:13px;font-weight:700}
.tab-count{font-size:10px;font-weight:500;opacity:0.6}
.city-list{padding:8px;overflow-y:auto;flex:1}
.city-list.hidden{display:none}
.city-item{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;border-radius:10px;
  cursor:pointer;font-size:14px;color:var(--text-body);
  transition:background 0.15s,color 0.15s;
}
.city-item:hover{background:rgba(54,103,128,0.06)}
.city-item.active{background:rgba(54,103,128,0.10);color:var(--blue)}
.city-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--teal);flex-shrink:0;transition:background 0.15s;
}
.city-item.active .city-dot{background:var(--blue)}
.city-tag{
  margin-left:auto;font-size:10px;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;
  color:var(--terra);background:rgba(178,91,48,0.10);padding:2px 8px;border-radius:100px;
}
.map-sidebar-cta{padding:16px;border-top:1px solid var(--border);text-align:center}
.map-sidebar-cta p{font-size:12px;color:var(--text-muted);margin-bottom:10px;line-height:1.5}
/* Map visual */
.map-visual{position:relative;overflow:hidden;background:#d0ccc4}
.map-bg-state{position:absolute;inset:0}
.map-bg-state[data-state="az"]{
  background:linear-gradient(160deg,#ccd8c8 0%,#d4c89e 55%,#c8b472 100%);
}
.map-bg-state[data-state="ut"]{
  background:linear-gradient(160deg,#b4c4d0 0%,#c0c8bc 50%,#ccc8b8 100%);
}
.map-bg-state.hidden{display:none}
/* Pins */
.map-pin{
  position:absolute;cursor:pointer;
  transform:translate(-50%,-50%);z-index:2;
}
.pin-marker{
  width:12px;height:12px;
  background:var(--blue);border:2.5px solid #fff;border-radius:50%;
  box-shadow:0 2px 8px rgba(54,103,128,0.5);
  transition:transform 0.2s var(--bounce),box-shadow 0.2s;
  margin:auto;
}
.map-pin.hq .pin-marker{
  width:16px;height:16px;
  background:var(--terra);
  box-shadow:0 2px 10px rgba(178,91,48,0.6);
}
.map-pin:hover .pin-marker,.map-pin.active .pin-marker{transform:scale(1.5)}
.pin-pulse{
  position:absolute;width:28px;height:28px;border-radius:50%;
  border:2px solid var(--terra);
  top:50%;left:50%;transform:translate(-50%,-50%);
  animation:mapPulse 2s ease-out infinite;pointer-events:none;
}
@keyframes mapPulse{
  0%{transform:translate(-50%,-50%) scale(0.6);opacity:0.8}
  100%{transform:translate(-50%,-50%) scale(1.9);opacity:0}
}
.pin-label{
  position:absolute;left:50%;top:calc(100% + 6px);
  transform:translateX(-50%);
  background:rgba(28,44,51,0.82);color:#fff;
  font-size:11px;font-weight:600;padding:3px 9px;border-radius:100px;
  white-space:nowrap;pointer-events:none;backdrop-filter:blur(4px);
}
.map-pin.hq .pin-label{top:calc(100% + 10px)}
/* Info card */
.map-info-card{
  position:absolute;bottom:16px;right:16px;
  background:rgba(255,255,255,0.95);backdrop-filter:blur(12px);
  border:1px solid var(--blue-border);border-radius:14px;
  padding:18px 20px;min-width:220px;max-width:280px;
  box-shadow:0 8px 32px rgba(54,103,128,0.14);z-index:3;
}
.map-info-city{font-size:16px;font-weight:700;color:var(--text);margin-bottom:3px}
.map-info-state{
  font-size:11px;font-weight:600;text-transform:uppercase;
  letter-spacing:0.08em;color:var(--terra);margin-bottom:12px;
}
.map-info-tags{display:flex;flex-wrap:wrap;gap:5px}
.map-info-tag{
  font-size:11px;font-weight:600;padding:3px 10px;border-radius:100px;
  background:rgba(54,103,128,0.10);color:var(--blue);
}
/* License badge */
.map-license-badge{
  position:absolute;top:14px;left:14px;
  background:rgba(28,44,51,0.72);color:#fff;
  font-size:10px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;
  padding:5px 12px;border-radius:100px;backdrop-filter:blur(6px);z-index:2;
}
@media(max-width:700px){
  .interactive-map{grid-template-columns:1fr}
  .map-visual{min-height:340px}
  .map-sidebar{max-height:260px}
}

/* ─── INTAKE FORM STRIP ─── */
.intake-strip{
  background:var(--bg-warm);
  border-top:1px solid var(--border);
  padding:80px 24px;
}
.intake-form{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:14px;margin-top:36px;
}
.form-group{display:flex;flex-direction:column;gap:7px}
.form-group label{
  font-size:12px;font-weight:600;
  letter-spacing:0.06em;text-transform:uppercase;
  color:var(--text-muted);
}
.form-input,.form-select,.form-textarea{
  background:#fff;
  border:1.5px solid rgba(99,142,153,0.3);
  border-radius:10px;
  padding:12px 16px;
  color:var(--text);
  font-family:'Inter',sans-serif;
  font-size:14px;
  transition:border-color 0.2s,box-shadow 0.2s;
  width:100%;
}
.form-input:focus,.form-select:focus,.form-textarea:focus{
  outline:none;
  border-color:var(--blue);
  box-shadow:0 0 0 3px rgba(54,103,128,0.10);
}
.form-input::placeholder,.form-textarea::placeholder{color:#aab8bc}
.form-select option{background:#fff;color:var(--text)}
.form-textarea{resize:vertical;min-height:100px;grid-column:1/-1}
.form-full{grid-column:1/-1}
.form-submit-row{grid-column:1/-1;display:flex;justify-content:flex-end;margin-top:8px}

/* ─── SPECIALTY CARDS ─── */
.specialty-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:20px;
}
.spec-card{
  background:#fff;
  border:1.5px solid var(--border);
  border-radius:16px;padding:28px 24px;
  transition:border-color 0.25s,box-shadow 0.25s,transform 0.25s var(--ease);
  box-shadow:0 2px 8px rgba(99,142,153,0.06);
}
.spec-card:hover{
  border-color:var(--blue-border);
  transform:translateY(-6px);
  box-shadow:0 12px 40px rgba(54,103,128,0.12);
}
.spec-card-icon{
  width:48px;height:48px;
  background:rgba(99,142,153,0.10);
  border:1.5px solid var(--blue-border);
  border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:18px;
}
.spec-card-icon svg{width:24px;height:24px;fill:var(--blue)}
.spec-card h3{font-size:1.05rem;font-weight:700;color:var(--text);margin-bottom:10px}
.spec-card p{font-size:0.9rem;color:var(--text-muted);line-height:1.65}
.spec-card ul{list-style:none;margin-top:14px;display:flex;flex-direction:column;gap:8px}
.spec-card ul li{
  font-size:0.88rem;color:var(--text-body);
  padding-left:18px;position:relative;line-height:1.5;
}
.spec-card ul li::before{
  content:'';position:absolute;left:0;top:8px;
  width:6px;height:6px;
  background:var(--terra);border-radius:50%;
}

/* ─── TEAM CARDS ─── */
.team-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:24px;
}
.team-card{
  background:#fff;
  border:1.5px solid var(--border);
  border-radius:20px;overflow:hidden;
  transition:transform 0.25s var(--ease),box-shadow 0.25s;
  box-shadow:0 2px 12px rgba(99,142,153,0.08);
}
.team-card:hover{transform:translateY(-6px);box-shadow:0 16px 48px rgba(54,103,128,0.14)}
.team-card-img{width:100%;aspect-ratio:1;object-fit:cover;object-position:top center}
.team-card-body{padding:22px 20px}
.team-card h3{font-size:1.1rem;font-weight:700;color:var(--text);margin-bottom:4px}
.team-card .role{font-size:13px;color:var(--teal);font-weight:600;margin-bottom:10px;letter-spacing:0.02em}
.team-card p{font-size:0.87rem;color:var(--text-muted);line-height:1.6}

/* ─── CONTENT SPLIT ─── */
.content-section{
  display:grid;grid-template-columns:1fr 1fr;
  gap:80px;align-items:center;
  padding:96px 24px;max-width:1180px;margin:0 auto;
}
.content-section.reverse{direction:rtl}
.content-section.reverse > *{direction:ltr}
.content-img{border-radius:20px;overflow:hidden;border:1.5px solid var(--border);box-shadow:0 8px 32px rgba(54,103,128,0.1)}
.content-img img{width:100%;height:420px;object-fit:cover;display:block}
.content-body .eyebrow{color:var(--terra)}
.content-body h2{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2rem,3.5vw,2.8rem);font-weight:600;
  color:var(--text);line-height:1.2;margin-bottom:20px;
}
.content-body h2 em{color:var(--blue);font-style:italic}
.content-body p{font-size:1rem;color:var(--text-body);line-height:1.75;margin-bottom:16px}
.content-body ul{list-style:none;margin:20px 0 28px;display:flex;flex-direction:column;gap:10px}
.content-body ul li{
  font-size:0.95rem;color:var(--text-body);
  padding-left:22px;position:relative;line-height:1.55;
}
.content-body ul li::before{
  content:'';position:absolute;left:0;top:9px;
  width:7px;height:7px;background:var(--terra);border-radius:50%;
}

/* ─── CONTACT CARDS ─── */
.contact-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:20px;margin-bottom:48px;
}
.contact-card{
  background:#fff;border:1.5px solid var(--border);
  border-radius:16px;padding:28px 24px;text-align:center;
  transition:border-color 0.2s,box-shadow 0.2s;
  box-shadow:0 2px 8px rgba(99,142,153,0.06);
}
.contact-card:hover{border-color:var(--blue-border);box-shadow:0 8px 28px rgba(54,103,128,0.10)}
.contact-card-icon{
  width:52px;height:52px;
  background:rgba(99,142,153,0.10);
  border:1.5px solid var(--blue-border);
  border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 16px;
}
.contact-card-icon svg{width:24px;height:24px;fill:var(--blue)}
.contact-card h3{font-size:0.8rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:8px}
.contact-card a,.contact-card p{font-size:1rem;font-weight:600;color:var(--text);text-decoration:none;line-height:1.5}
.contact-card a:hover{color:var(--blue)}

/* ─── FORENSIC BANNER ─── */
.forensic-banner{
  background:linear-gradient(135deg,rgba(54,103,128,0.08) 0%,rgba(99,142,153,0.06) 100%);
  border:1.5px solid var(--blue-border);
  border-radius:16px;padding:32px 36px;
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;flex-wrap:wrap;
}
.forensic-banner h3{font-family:'Cormorant Garamond',serif;font-size:1.6rem;color:var(--text);margin-bottom:6px}
.forensic-banner p{font-size:0.9rem;color:var(--text-muted)}

/* ─── CTA BAND ─── */
.cta-band{
  background:var(--blue);
  padding:80px 24px;text-align:center;
}
.cta-band h2{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2rem,4vw,3rem);
  color:#fff;margin-bottom:16px;
}
.cta-band h2 em{color:#d4e8ef;font-style:italic}
.cta-band p{font-size:1.05rem;color:rgba(255,255,255,0.8);margin-bottom:36px;max-width:520px;margin-left:auto;margin-right:auto}
.cta-band .eyebrow{color:rgba(212,232,239,0.8)}
.cta-band .hero-ctas{margin-top:0}
.cta-band .btn-primary{background:#fff;color:var(--blue)}
.cta-band .btn-primary:hover{background:var(--cream);box-shadow:0 8px 24px rgba(0,0,0,0.2)}
.cta-band .btn-secondary{border-color:rgba(255,255,255,0.4)}

/* ─── FOOTER ─── */
footer{
  background:var(--text);
  color:rgba(255,255,255,0.7);
  padding:60px 24px 32px;
}
.footer-inner{max-width:1180px;margin:0 auto}
.footer-top{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;
  gap:48px;
  padding-bottom:48px;
  border-bottom:1px solid rgba(255,255,255,0.1);
  margin-bottom:32px;
}
.footer-brand{max-width:280px}
.footer-logo{display:flex;align-items:center;gap:10px;text-decoration:none;margin-bottom:16px}
.footer-brand p{font-size:0.88rem;line-height:1.7;margin-bottom:20px}
.footer-col h4{
  font-size:11px;font-weight:700;
  letter-spacing:0.1em;text-transform:uppercase;
  color:var(--teal);margin-bottom:16px;
}
.footer-col a{
  display:block;font-size:14px;
  color:rgba(255,255,255,0.55);
  text-decoration:none;margin-bottom:10px;
  transition:color 0.2s;
}
.footer-col a:hover{color:#fff}
.footer-bottom{
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:12px;
}
.footer-bottom p,.footer-bottom a{font-size:13px;color:rgba(255,255,255,0.35);text-decoration:none;transition:color 0.2s}
.footer-bottom a:hover{color:#fff}

/* Footer logo colors on dark bg */
footer .nav-logo-main{color:#d4e8ef}
footer .nav-logo-sub{color:var(--terra)}
footer .nav-logo-icon polygon{stroke:#638e99}
footer .nav-logo-icon line{stroke:#638e99}

/* ─── FADE-IN ─── */
.fi{
  opacity:0;transform:translateY(22px);
  transition:opacity 0.55s var(--ease),transform 0.55s var(--ease);
}
.fi.v{opacity:1;transform:translateY(0)}

/* ─── RESPONSIVE ─── */
@media(max-width:900px){
  .services-grid{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr 1fr}
  .content-section{grid-template-columns:1fr;gap:40px}
  .content-section.reverse{direction:ltr}
  .content-img img{height:280px}
}
@media(max-width:640px){
  .nav-links .hide-mobile{display:none}
  .services-grid .service-card{height:300px}
  .footer-top{grid-template-columns:1fr}
  .hero h1{font-size:2.4rem}
  .trust-inner{gap:20px}
  .intake-form{grid-template-columns:1fr}
  .form-textarea,.form-full,.form-submit-row{grid-column:1}
}
