/* ============================================================
   JThree Analytics Consulting — design tokens
   ============================================================ */
:root{
  --navy:        #0b1f3a;
  --navy-soft:   #12294d;
  --blue:        #2563eb;
  --blue-deep:   #1d4fc4;
  --teal:        #14b8a6;
  --teal-deep:   #0e9284;
  --ink:         #0b1f3a;
  --slate:       #4b5768;
  --slate-light: #8993a4;
  --paper:       #f8fafc;
  --paper-alt:   #eef1f6;
  --white:       #ffffff;
  --line:        #e4e8f0;

  --font-display: "Poppins", -apple-system, sans-serif;
  --font-body: "Poppins", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  --wrap: 1220px;
  --radius: 16px;
  --ease: cubic-bezier(.22,.7,.24,1);
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  *,*::before,*::after{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; scroll-behavior:auto !important; }
}

body{
  margin:0;
  font-family:var(--font-body);
  color:var(--slate);
  background:var(--white);
  -webkit-font-smoothing:antialiased;
  line-height:1.6;
}

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }

.wrap{ max-width:var(--wrap); margin:0 auto; padding:0 32px; }

.display{
  font-family:var(--font-display);
  font-weight:800;
  line-height:1.12;
  letter-spacing:-.02em;
  margin:0;
  color:var(--navy);
}

.skip-link{
  position:absolute; left:-999px; top:0;
  background:var(--blue); color:var(--white); padding:12px 18px; z-index:999;
  border-radius:0 0 8px 0;
}
.skip-link:focus{ left:0; }

.eyebrow{
  font-family:var(--font-display);
  font-size:.72rem;
  font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--teal-deep);
  margin:0 0 16px;
  display:inline-flex; align-items:center; gap:8px;
}
.eyebrow::before{ content:""; width:22px; height:2px; background:var(--teal); display:inline-block; }

.icon-sm{ width:16px; height:16px; vertical-align:-3px; margin-right:6px; }
.section-lede{ font-size:1.05rem; color:var(--slate); max-width:60ch; margin:0; }

/* ============================================================
   Buttons
   ============================================================ */
.btn{
  display:inline-flex; align-items:center; gap:8px;
  padding:15px 28px; border-radius:8px;
  font-family:var(--font-display);
  font-weight:700; font-size:.94rem;
  transition:transform .25s var(--ease), background .25s var(--ease), border-color .25s var(--ease), color .25s var(--ease), box-shadow .25s var(--ease);
  border:1.5px solid transparent;
  cursor:pointer;
}
.btn-primary{ background:var(--blue); color:var(--white); box-shadow:0 14px 28px -14px rgba(30,78,216,.45); }
.btn-primary:hover{ background:var(--blue-deep); transform:translateY(-2px); }
.btn-outline{ border-color:var(--line); color:var(--navy); background:var(--white); }
.btn-outline:hover{ border-color:var(--blue); color:var(--blue); transform:translateY(-2px); }
.btn-ghost{ border-color:var(--line); color:var(--navy); padding:11px 20px; font-size:.88rem; }
.btn-ghost:hover{ border-color:var(--blue); color:var(--blue); }
.btn-teal{ background:var(--teal); color:var(--navy); box-shadow:0 14px 28px -14px rgba(20,184,166,.45); }
.btn-teal:hover{ background:var(--teal-deep); color:var(--white); transform:translateY(-2px); }
:focus-visible{ outline:2.5px solid var(--blue); outline-offset:3px; }

/* ============================================================
   Header / nav
   ============================================================ */
.site-header{
  position:sticky; top:0; z-index:100;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
  transition:box-shadow .3s;
}
.site-header.scrolled{ box-shadow:0 8px 24px -18px rgba(11,31,58,.25); }
.header-row{ display:flex; align-items:center; gap:26px; padding:14px 32px; }
.brand-logo{ height:32px; width:auto; }
.main-nav{ display:flex; gap:24px; margin-left:auto; }
.main-nav a{
  color:var(--slate); font-size:.9rem; font-weight:600;
  position:relative; padding:4px 0; transition:color .2s;
}
.main-nav a:hover{ color:var(--navy); }
.main-nav a::after{
  content:""; position:absolute; left:0; right:0; bottom:-2px; height:2px;
  background:var(--blue); transform:scaleX(0); transform-origin:left;
  transition:transform .25s var(--ease);
}
.main-nav a:hover::after{ transform:scaleX(1); }
.main-nav a.active{ color:var(--navy); }
.main-nav a.active::after{ transform:scaleX(1); }
.nav-cta{ margin-left:4px; white-space:nowrap; }
.nav-toggle{ display:none; flex-direction:column; gap:5px; background:none; border:none; padding:8px; margin-left:auto; cursor:pointer; }
.nav-toggle span{ width:22px; height:2px; background:var(--navy); border-radius:2px; }
.mobile-nav{ display:none; flex-direction:column; padding:6px 32px 18px; }
.mobile-nav a{ color:var(--slate); padding:10px 0; font-size:.98rem; font-weight:600; border-top:1px solid var(--line); }
.mobile-nav a.active{ color:var(--navy); }

@media (max-width:960px){
  .main-nav, .nav-cta{ display:none; }
  .nav-toggle{ display:flex; }
  .mobile-nav.open{ display:flex; }
}

/* ============================================================
   Hero (parallax)
   ============================================================ */
.hero{
  position:relative; overflow:hidden;
  min-height:88vh; display:flex; align-items:center;
  background:var(--navy);
}
.hero-bg{
  position:absolute; inset:-8% -8%; z-index:0;
  background-size:cover; background-position:center;
  will-change:transform;
}
.hero-bg img{ width:100%; height:100%; object-fit:cover; }
.hero-scrim{
  position:absolute; inset:0; z-index:1;
  background:linear-gradient(180deg, rgba(11,31,58,.86) 0%, rgba(11,31,58,.78) 45%, rgba(11,31,58,.94) 100%);
}
.hero-content{ position:relative; z-index:2; padding:120px 0 90px; }
.hero-eyebrow{ color:var(--teal); }
.hero-eyebrow::before{ background:var(--teal); }
.hero h1{ color:var(--white); font-size:clamp(2.6rem,5.4vw,4.4rem); max-width:16ch; }
.hero-lede{ color:rgba(255,255,255,.82); font-size:1.2rem; max-width:52ch; margin:24px 0 36px; }
.hero-actions{ display:flex; gap:16px; flex-wrap:wrap; }
.hero .btn-outline{ border-color:rgba(255,255,255,.4); color:var(--white); background:transparent; }
.hero .btn-outline:hover{ border-color:var(--white); background:rgba(255,255,255,.1); }

.scroll-cue{ position:relative; z-index:2; display:flex; justify-content:center; padding-bottom:26px; }
.scroll-cue span{ width:22px; height:36px; border:1.5px solid rgba(255,255,255,.35); border-radius:14px; position:relative; display:block; }
.scroll-cue span::before{
  content:""; position:absolute; left:50%; top:7px; width:4px; height:8px; margin-left:-2px;
  background:var(--teal); border-radius:3px; animation:scrollDot 1.8s ease-in-out infinite;
}
@keyframes scrollDot{ 0%{opacity:1; transform:translateY(0);} 70%{opacity:0; transform:translateY(10px);} 100%{opacity:0;} }

.quote-band{
  max-width:820px; margin:0 auto; text-align:center; padding:0 20px;
}
.quote-mark{ width:38px; height:38px; color:var(--teal); margin:0 auto 20px; opacity:.85; }
.quote-text{
  font-family:var(--font-display); font-weight:700; color:var(--navy);
  font-size:clamp(1.4rem,2.6vw,2rem); line-height:1.4; margin:0 0 18px; letter-spacing:-.01em;
}
.quote-attribution{ font-size:.86rem; color:var(--slate-light); font-weight:600; margin:0; }
.quote-attribution::before{ content:""; display:block; width:32px; height:2px; background:var(--line); margin:0 auto 14px; }

.process-steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:28px; margin-top:8px; }
.process-step{ position:relative; padding-top:20px; border-top:2px solid var(--blue); }
.process-num{
  display:block; font-family:var(--font-display); font-weight:700;
  color:var(--blue); font-size:1.3rem; margin-bottom:10px;
}
.process-step h3{ color:var(--navy); font-size:1.02rem; margin:0 0 8px; }
.process-step p{ font-size:.9rem; color:var(--slate); margin:0; }
@media (max-width:900px){ .process-steps{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .process-steps{ grid-template-columns:1fr; } }

/* ============================================================
   Logo strip
   ============================================================ */
.logos-strip{ background:var(--paper); padding:44px 0; border-bottom:1px solid var(--line); }
.logos-label{ text-align:center; font-size:.78rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--slate-light); margin:0 0 24px; }
.logos-row{ display:flex; justify-content:center; align-items:center; gap:48px; flex-wrap:wrap; }
.logo-chip{
  font-family:var(--font-display); font-weight:800; font-size:1.05rem; color:var(--slate-light);
  letter-spacing:-.01em; opacity:.7; transition:opacity .2s;
}
.logo-chip:hover{ opacity:1; color:var(--navy); }

/* ============================================================
   Generic section helpers
   ============================================================ */
.section{ padding:110px 0; }
.section.on-paper{ background:var(--paper); }
.section-head{ max-width:70ch; margin-bottom:52px; }
.section-head.center{ margin-left:auto; margin-right:auto; text-align:center; }
.section-head .display{ font-size:clamp(1.9rem,3.4vw,2.7rem); margin-bottom:16px; }
.section-foot{ margin-top:44px; text-align:center; }

.link-arrow{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-display); font-weight:700; color:var(--blue); font-size:.94rem;
}
.link-arrow svg{ width:16px; height:16px; transition:transform .25s var(--ease); }
.link-arrow:hover svg{ transform:translateX(4px); }

/* ============================================================
   About preview / general split layout
   ============================================================ */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }
.split-media{ border-radius:var(--radius); overflow:hidden; box-shadow:0 30px 60px -32px rgba(11,31,58,.3); }
.split-media img{ width:100%; height:100%; object-fit:cover; aspect-ratio:4/3; }
@media (max-width:900px){ .split{ grid-template-columns:1fr; gap:36px; } }

.pillars{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:16px; }
.pillar{
  background:var(--white); border:1px solid var(--line); border-radius:var(--radius);
  padding:26px 22px; transition:transform .3s var(--ease), box-shadow .3s var(--ease);
}
.pillar:hover{ transform:translateY(-4px); box-shadow:0 18px 34px -22px rgba(11,31,58,.18); }
.pillar-icon{
  width:44px; height:44px; border-radius:12px; background:var(--paper-alt); color:var(--blue);
  display:flex; align-items:center; justify-content:center; margin-bottom:16px;
}
.pillar-icon svg{ width:22px; height:22px; }
.pillar h3{ font-family:var(--font-display); font-size:1.02rem; color:var(--navy); margin:0 0 8px; }
.pillar p{ font-size:.9rem; margin:0; color:var(--slate); }
@media (max-width:900px){ .pillars{ grid-template-columns:1fr; } }

/* ============================================================
   Service cards
   ============================================================ */
.service-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.service-grid.compact{ grid-template-columns:repeat(4,1fr); }
.service-card{
  background:var(--white); border:1px solid var(--line); border-radius:var(--radius);
  padding:30px 26px; transition:transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s;
  display:flex; flex-direction:column;
}
.service-card:hover{ transform:translateY(-6px); box-shadow:0 24px 44px -26px rgba(11,31,58,.22); border-color:transparent; }
.service-icon{
  width:50px; height:50px; border-radius:13px; background:var(--paper-alt); color:var(--blue);
  display:flex; align-items:center; justify-content:center; margin-bottom:18px;
}
.service-icon svg{ width:24px; height:24px; }
.service-card h3{ font-family:var(--font-display); color:var(--navy); font-size:1.08rem; margin:0 0 8px; }
.service-card p{ font-size:.88rem; margin:0 0 18px; flex:1; }
.service-card .link-arrow{ font-size:.86rem; }
.service-card-toggle{
  display:inline-flex; align-items:center; gap:6px;
  font-family:var(--font-display); font-weight:600; color:var(--blue); font-size:.86rem;
  background:none; border:none; padding:0; cursor:pointer; margin-top:auto;
}
.service-card-toggle svg{ width:15px; height:15px; transition:transform .3s var(--ease); }
.service-card-toggle[aria-expanded="true"] svg{ transform:rotate(180deg); }
.service-card-more{
  max-height:0; overflow:hidden; transition:max-height .35s var(--ease), margin-top .35s var(--ease);
  font-size:.86rem; color:var(--slate);
}
.service-card-more.open{ max-height:200px; margin-top:12px; }
@media (max-width:1100px){ .service-grid, .service-grid.compact{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:600px){ .service-grid, .service-grid.compact{ grid-template-columns:1fr; } }

/* ============================================================
   Why choose us / feature rows
   ============================================================ */
.feature-list{ display:grid; gap:0; }
.feature-row{ display:flex; gap:18px; padding:22px 0; border-top:1px solid var(--line); }
.feature-row:first-child{ border-top:none; padding-top:0; }
.feature-row:last-child{ padding-bottom:0; }
.feature-icon{
  flex:none; width:46px; height:46px; border-radius:12px; background:var(--paper-alt); color:var(--blue);
  display:flex; align-items:center; justify-content:center;
}
.feature-icon svg{ width:22px; height:22px; }
.feature-row h3{ font-family:var(--font-display); color:var(--navy); font-size:1.02rem; margin:0 0 6px; }
.feature-row p{ color:var(--slate); font-size:.9rem; margin:0; }

/* ============================================================
   Stats band
   ============================================================ */
.stats-band{ background:var(--navy); border-radius:24px; padding:52px 40px; position:relative; overflow:hidden; }
.stats-band::before{
  content:""; position:absolute; width:420px; height:420px; border-radius:50%;
  border:1px solid rgba(255,255,255,.08); right:-140px; top:-120px;
}
.stats-grid{ position:relative; z-index:1; display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.stat-item{ text-align:center; }
.stat-num{ display:block; font-family:var(--font-display); font-weight:800; font-size:clamp(1.9rem,3vw,2.6rem); color:var(--white); }
.stat-label{ display:block; margin-top:8px; color:rgba(255,255,255,.7); font-size:.86rem; }
@media (max-width:800px){ .stats-grid{ grid-template-columns:1fr 1fr; } }

/* ============================================================
   Team
   ============================================================ */
.team-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.team-card{ text-align:center; }
.team-avatar{
  width:100%; aspect-ratio:1; border-radius:16px; margin-bottom:16px;
  background:linear-gradient(150deg, var(--navy), var(--blue));
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-display); font-weight:800; font-size:2rem; color:var(--white);
}
.team-card h3{ font-family:var(--font-display); color:var(--navy); font-size:1rem; margin:0 0 4px; }
.team-card p{ font-size:.84rem; color:var(--slate-light); margin:0; }
@media (max-width:900px){ .team-grid{ grid-template-columns:repeat(2,1fr); } }

/* ============================================================
   Industries
   ============================================================ */
.industry-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.industry-card{
  background:var(--white); border:1px solid var(--line); border-radius:var(--radius);
  padding:28px 22px; transition:transform .3s var(--ease), box-shadow .3s var(--ease), background .3s;
}
.industry-card:hover{ transform:translateY(-4px); box-shadow:0 20px 38px -24px rgba(11,31,58,.2); background:var(--paper); }
.industry-icon{
  width:44px; height:44px; border-radius:12px; background:var(--paper-alt); color:var(--teal-deep);
  display:flex; align-items:center; justify-content:center; margin-bottom:14px;
}
.industry-icon svg{ width:22px; height:22px; }
.industry-card h3{ font-family:var(--font-display); color:var(--navy); font-size:.98rem; margin:0 0 6px; }
.industry-card p{ font-size:.84rem; margin:0; color:var(--slate); }
@media (max-width:1100px){ .industry-grid{ grid-template-columns:repeat(3,1fr); } }
@media (max-width:700px){ .industry-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:460px){ .industry-grid{ grid-template-columns:1fr; } }

/* ============================================================
   Projects
   ============================================================ */
.project-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:28px; }
.project-card{
  position:relative; border-radius:var(--radius); overflow:hidden;
  box-shadow:0 24px 46px -28px rgba(11,31,58,.28);
  aspect-ratio:5/4;
}
.project-card img{ width:100%; height:100%; object-fit:cover; transition:transform .5s var(--ease); }
.project-card:hover img{ transform:scale(1.06); }
.project-overlay{
  position:absolute; inset:0;
  background:linear-gradient(0deg, rgba(11,31,58,.92) 0%, rgba(11,31,58,.35) 55%, rgba(11,31,58,0) 100%);
  display:flex; flex-direction:column; justify-content:flex-end; padding:30px;
}
.project-sector{ color:var(--teal); font-family:var(--font-display); font-weight:700; font-size:.75rem; letter-spacing:.1em; text-transform:uppercase; margin-bottom:8px; }
.project-overlay h3{ font-family:var(--font-display); color:var(--white); font-size:1.3rem; margin:0 0 10px; }
.project-overlay p{ color:rgba(255,255,255,.8); font-size:.9rem; margin:0 0 14px; max-width:44ch; }
.project-overlay .link-arrow{ color:var(--white); }
@media (max-width:800px){ .project-grid{ grid-template-columns:1fr; } }

/* ============================================================
   Insights / blog
   ============================================================ */
.insight-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.insight-card{
  background:var(--white); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease); display:flex; flex-direction:column;
}
.insight-card:hover{ transform:translateY(-6px); box-shadow:0 24px 44px -26px rgba(11,31,58,.22); }
.insight-tag-block{
  height:140px; background:linear-gradient(150deg, var(--navy), var(--blue));
  display:flex; align-items:center; justify-content:center; position:relative;
}
.insight-tag-block svg{ width:38px; height:38px; color:rgba(255,255,255,.85); }
.insight-body{ padding:24px; display:flex; flex-direction:column; flex:1; }
.insight-category{ font-family:var(--font-display); font-weight:700; font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--teal-deep); margin-bottom:10px; }
.insight-body h3{ font-family:var(--font-display); color:var(--navy); font-size:1.05rem; margin:0 0 10px; }
.insight-body p{ font-size:.88rem; margin:0 0 18px; flex:1; }
@media (max-width:1000px){ .insight-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:640px){ .insight-grid{ grid-template-columns:1fr; } }

/* ============================================================
   CTA card
   ============================================================ */
.cta-band{ padding:0 0 110px; text-align:center; }
.cta-card{
  background:var(--navy); border-radius:24px; padding:64px 40px; position:relative; overflow:hidden;
}
.cta-card::before{
  content:""; position:absolute; width:460px; height:460px; border-radius:50%;
  background:radial-gradient(circle, rgba(30,78,216,.35), transparent 70%);
  right:-160px; top:-160px;
}
.cta-card .display{ color:var(--white); font-size:clamp(1.8rem,3vw,2.4rem); margin-bottom:16px; position:relative; z-index:1; }
.cta-card p{ color:rgba(255,255,255,.78); max-width:52ch; margin:0 auto 32px; font-size:1.02rem; position:relative; z-index:1; }
.cta-band-actions{ display:flex; gap:16px; justify-content:center; flex-wrap:wrap; position:relative; z-index:1; }
.cta-card .btn-outline{ border-color:rgba(255,255,255,.4); color:var(--white); background:transparent; }
.cta-card .btn-outline:hover{ border-color:var(--white); background:rgba(255,255,255,.1); }

/* ============================================================
   Contact / request form
   ============================================================ */
.contact-hero{ padding:150px 0 0; }
.contact-grid{ display:grid; grid-template-columns:1fr 1.05fr; gap:56px; align-items:start; padding-bottom:100px; }
.contact-copy .display{ font-size:clamp(2rem,3.6vw,2.8rem); margin-bottom:20px; }
.contact-lede{ color:var(--slate); max-width:48ch; margin:0 0 32px; font-size:1.02rem; }
.contact-list{ list-style:none; margin:0; padding:0; display:grid; gap:18px; }
.contact-list li{ display:flex; align-items:center; gap:16px; }
.contact-icon{
  flex:none; width:42px; height:42px; border-radius:50%; background:var(--paper-alt); color:var(--blue);
  display:flex; align-items:center; justify-content:center;
}
.contact-icon svg{ width:20px; height:20px; }
.contact-list a{ color:var(--navy); font-weight:600; transition:color .2s; }
.contact-list a:hover{ color:var(--blue); }
.contact-list span{ color:var(--navy); font-weight:600; }
.trust-notes{ margin-top:32px; display:grid; gap:10px; }
.trust-notes p{ display:flex; align-items:flex-start; gap:8px; font-size:.88rem; color:var(--slate); margin:0; }
.trust-notes .icon-sm{ color:var(--teal-deep); flex:none; margin-top:2px; }

.request-card{
  background:var(--white); border:1px solid var(--line); border-radius:24px; padding:40px;
  box-shadow:0 30px 60px -36px rgba(11,31,58,.22);
}
.request-intro{ margin-bottom:24px; }
.request-intro .display{ font-size:clamp(1.5rem,2.4vw,1.9rem); margin-bottom:8px; }
.request-form{ display:flex; flex-direction:column; gap:20px; }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.form-field{ display:flex; flex-direction:column; gap:8px; }
.form-field label{ font-size:.85rem; font-weight:700; color:var(--navy); font-family:var(--font-display); }
.form-field input, .form-field select, .form-field textarea{
  font-family:var(--font-body); font-size:.96rem; color:var(--navy); background:var(--paper);
  border:1.5px solid var(--line); border-radius:10px; padding:12px 14px;
  transition:border-color .2s, box-shadow .2s; width:100%;
}
.form-field textarea{ resize:vertical; min-height:110px; }
.form-field input:focus, .form-field select:focus, .form-field textarea:focus{
  outline:none; border-color:var(--blue); box-shadow:0 0 0 4px var(--paper-alt);
}
.hp-field{ position:absolute; left:-9999px; opacity:0; pointer-events:none; }
.request-form .btn-primary{ align-self:flex-start; }
.request-form .btn-primary:disabled{ opacity:.6; cursor:not-allowed; transform:none; }
.form-status{ margin:0; font-size:.9rem; font-weight:600; min-height:1.2em; }
.form-status.success{ color:#0a8a4b; }
.form-status.error{ color:#c92a2a; }
@media (max-width:640px){ .request-card{ padding:30px 22px; } .form-row{ grid-template-columns:1fr; } }
@media (max-width:900px){ .contact-grid{ grid-template-columns:1fr; } }

.map-frame{ border-radius:var(--radius); overflow:hidden; border:1px solid var(--line); margin-top:40px; }
.map-frame iframe{ width:100%; height:340px; border:0; display:block; }

/* ============================================================
   Footer (mega)
   ============================================================ */
.site-footer{ background:var(--navy); color:rgba(255,255,255,.7); padding:80px 0 0; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:40px; padding-bottom:56px; border-bottom:1px solid rgba(255,255,255,.1); }
.footer-brand-logo{ height:30px; width:auto; margin-bottom:18px; }
.footer-about p{ font-size:.9rem; line-height:1.7; max-width:34ch; color:rgba(255,255,255,.6); }
.footer-social{ display:flex; gap:12px; margin-top:20px; }
.footer-social a{
  width:38px; height:38px; border-radius:50%; border:1px solid rgba(255,255,255,.2);
  display:flex; align-items:center; justify-content:center; transition:background .2s, border-color .2s;
}
.footer-social a:hover{ background:var(--blue); border-color:var(--blue); }
.footer-social svg{ width:17px; height:17px; color:var(--white); }
.footer-col h4{ font-family:var(--font-display); color:var(--white); font-size:.86rem; letter-spacing:.06em; text-transform:uppercase; margin:0 0 20px; }
.footer-col ul{ list-style:none; margin:0; padding:0; display:grid; gap:12px; }
.footer-col a{ font-size:.9rem; color:rgba(255,255,255,.65); transition:color .2s; }
.footer-col a:hover{ color:var(--white); }
.footer-newsletter p{ font-size:.88rem; color:rgba(255,255,255,.6); margin:0 0 16px; }
.newsletter-form{ display:flex; gap:0; border:1px solid rgba(255,255,255,.22); border-radius:8px; overflow:hidden; }
.newsletter-form input{
  flex:1; border:none; background:transparent; padding:13px 14px; color:var(--white); font-size:.9rem; min-width:0;
}
.newsletter-form input::placeholder{ color:rgba(255,255,255,.45); }
.newsletter-form input:focus{ outline:none; }
.newsletter-form button{
  border:none; background:var(--blue); color:var(--white); padding:0 18px; font-weight:700;
  font-family:var(--font-display); font-size:.86rem; cursor:pointer; transition:background .2s;
}
.newsletter-form button:hover{ background:var(--blue-deep); }
.newsletter-status{ font-size:.82rem; margin:10px 0 0; min-height:1.2em; }
.newsletter-status.success{ color:var(--teal); }
.newsletter-status.error{ color:#ff9a9a; }
.footer-bottom{ display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:12px; padding:26px 0; font-size:.82rem; }
.footer-bottom a{ color:rgba(255,255,255,.6); }
.footer-bottom a:hover{ color:var(--white); }

@media (max-width:960px){
  .footer-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:600px){
  .footer-grid{ grid-template-columns:1fr; }
}

/* ============================================================
   Back to top
   ============================================================ */
.back-to-top{
  position:fixed; right:24px; bottom:24px; z-index:90;
  width:48px; height:48px; border-radius:50%;
  background:var(--navy); color:var(--white); border:none;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 14px 28px -12px rgba(11,31,58,.5);
  opacity:0; pointer-events:none; transform:translateY(12px);
  transition:opacity .3s var(--ease), transform .3s var(--ease), background .2s;
  cursor:pointer;
}
.back-to-top.visible{ opacity:1; pointer-events:auto; transform:translateY(0); }
.back-to-top:hover{ background:var(--blue); }
.back-to-top svg{ width:20px; height:20px; }

/* ============================================================
   Photo banner (reused across pages)
   ============================================================ */
.photo-banner{ position:relative; border-radius:var(--radius); overflow:hidden; box-shadow:0 30px 55px -30px rgba(11,31,58,.28); }
.photo-banner img{ width:100%; max-height:400px; object-fit:cover; }
.photo-banner-caption{
  position:absolute; left:0; right:0; bottom:0;
  background:linear-gradient(0deg, rgba(11,31,58,.8), rgba(11,31,58,0));
  color:var(--white); padding:30px 32px 22px; font-family:var(--font-display); font-size:1.2rem; font-weight:700;
}

/* ============================================================
   Scroll reveal
   ============================================================ */
.reveal{ opacity:0; transform:translateY(24px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in{ opacity:1; transform:translateY(0); }
.reveal-stagger.in > *{ transition-delay:calc(var(--i,0) * 70ms); }
