/* ===================================================
   Wentworth Global Advisors — styles.css
   =================================================== */

/* --- Custom Properties --- */
:root {
  --bg:           #09090f;
  --surface:      #0f0f18;
  --card:         #131320;
  --border:       rgba(201,168,76,.12);
  --border-hover: rgba(201,168,76,.28);
  --gold:         #c9a84c;
  --gold-light:   #e8c97a;
  --gold-subtle:  rgba(201,168,76,.08);
  --text:         #f0ece6;
  --text-muted:   #8a899a;
  --text-dim:     #52515f;

  --serif: 'Cormorant Garamond', Georgia, serif;
  --sans:  'DM Sans', system-ui, sans-serif;

  --max-w:    1200px;
  --nav-h:    124px;
  --ease-out: cubic-bezier(.16,1,.3,1);
  --ease:     cubic-bezier(.4,0,.2,1);
}

/* --- Reset --- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%}
body{background:var(--bg);color:var(--text);font-family:var(--sans);font-weight:300;
  line-height:1.7;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;
  -webkit-tap-highlight-color:transparent;touch-action:manipulation}
input,select,textarea{font-family:inherit;font-size:16px}

/* --- Typography --- */
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;line-height:1.12;letter-spacing:-.01em}
h1{font-size:clamp(2.6rem,5.5vw,4.75rem)}
h2{font-size:clamp(2rem,4vw,3.25rem)}
h3{font-size:clamp(1.35rem,2.5vw,1.875rem)}
h4{font-size:1.25rem}
p{font-size:1.0625rem}

.eyebrow{
  font-family:var(--sans);font-size:.7rem;font-weight:500;
  letter-spacing:.22em;text-transform:uppercase;color:var(--gold);
  display:inline-flex;align-items:center;gap:.625rem;
}
.eyebrow::before{content:'';width:28px;height:1px;background:var(--gold)}

/* --- Layout --- */
.container{max-width:var(--max-w);margin:0 auto;padding:0 2rem}
section{padding:6rem 0}

.section-head{margin-bottom:3.5rem}
.section-head .eyebrow{margin-bottom:1rem}
.section-head h2{margin-bottom:1.125rem}
.section-head p{color:var(--text-muted);font-size:1.1rem;max-width:560px}
.section-head.centered{text-align:center}
.section-head.centered p{margin-left:auto;margin-right:auto}
.section-head.centered .eyebrow{justify-content:center}
.section-head.centered .eyebrow::before{display:none}

.divider{width:44px;height:1px;background:var(--gold);margin:1.5rem 0}

/* --- Buttons --- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.875rem 2rem;font-size:.8125rem;font-weight:500;
  letter-spacing:.1em;text-transform:uppercase;border-radius:2px;
  transition:all .3s var(--ease-out);cursor:pointer;white-space:nowrap;
}
.btn-gold{background:var(--gold);color:#09090f}
.btn-gold:hover{background:var(--gold-light);transform:translateY(-2px);
  box-shadow:0 8px 32px rgba(201,168,76,.28)}
.btn-outline{background:transparent;color:var(--text);border:1px solid rgba(240,236,230,.2)}
.btn-outline:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-2px)}

/* --- Navigation --- */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  height:var(--nav-h);
  transition:background .4s var(--ease),backdrop-filter .4s var(--ease),
    box-shadow .4s var(--ease);
}
.site-header.scrolled{
  background:rgba(9,9,15,.9);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  box-shadow:0 1px 0 var(--border);
}
.nav{
  max-width:var(--max-w);margin:0 auto;padding:0 2rem;
  height:100%;display:flex;align-items:center;gap:1.5rem;
}
.nav-brand img{height:54px;width:auto}
.nav-links{display:flex;align-items:center;gap:.125rem;margin-left:auto}
.nav-links a{
  font-size:.9375rem;font-weight:400;letter-spacing:.1em;text-transform:uppercase;
  color:var(--text-muted);padding:.625rem 1.125rem;border-radius:2px;
  transition:color .2s var(--ease);position:relative;min-height:44px;
  display:inline-flex;align-items:center;
}
.nav-links a::after{
  content:'';position:absolute;bottom:2px;left:.875rem;right:.875rem;
  height:1px;background:var(--gold);
  transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease-out);
}
.nav-links a:hover,.nav-links a.active{color:var(--text)}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}
.nav-cta{
  font-size:.9375rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;
  color:var(--gold);padding:.875rem 1.75rem;border:1px solid var(--border-hover);
  border-radius:2px;transition:all .2s var(--ease);white-space:nowrap;
  min-height:44px;display:inline-flex;align-items:center;
}
.nav-cta:hover{background:var(--gold);color:#09090f}
.nav-toggle{display:none;flex-direction:column;gap:5px;padding:.5rem;margin-left:auto}
.nav-toggle span{display:block;width:22px;height:1.5px;background:var(--text);
  transition:all .25s var(--ease);transform-origin:center}
.nav-toggle.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-toggle.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* --- Hero --- */
.hero{
  min-height:100vh;min-height:100dvh;display:flex;align-items:center;
  padding-top:var(--nav-h);position:relative;overflow:hidden;
}
.hero-bg{
  position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 80% 60% at 50% 0%,rgba(201,168,76,.07) 0%,transparent 70%),
    radial-gradient(ellipse 50% 80% at 95% 50%,rgba(201,168,76,.04) 0%,transparent 60%);
}
.hero-grid{
  position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(201,168,76,.035) 1px,transparent 1px),
    linear-gradient(90deg,rgba(201,168,76,.035) 1px,transparent 1px);
  background-size:72px 72px;
  mask-image:radial-gradient(ellipse 90% 90% at 50% 50%,black 20%,transparent 100%);
  -webkit-mask-image:radial-gradient(ellipse 90% 90% at 50% 50%,black 20%,transparent 100%);
}
.hero .container{position:relative;z-index:1;padding-top:5rem;padding-bottom:5rem}
.hero-eyebrow{
  margin-bottom:2rem;
  opacity:0;transform:translateY(16px);
  animation:fadeUp .7s var(--ease-out) .15s forwards;
}
.hero h1{
  max-width:800px;margin-bottom:1.625rem;
  opacity:0;transform:translateY(20px);
  animation:fadeUp .8s var(--ease-out) .3s forwards;
}
.hero h1 em{font-style:italic;color:var(--gold)}
.hero-lede{
  max-width:520px;color:var(--text-muted);font-size:1.125rem;
  line-height:1.85;margin-bottom:2.5rem;
  opacity:0;transform:translateY(20px);
  animation:fadeUp .8s var(--ease-out) .45s forwards;
}
.hero-actions{
  display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:4.5rem;
  opacity:0;transform:translateY(20px);
  animation:fadeUp .8s var(--ease-out) .58s forwards;
}
.hero-stats{
  display:grid;grid-template-columns:repeat(4,1fr);
  border-top:1px solid var(--border);border-left:1px solid var(--border);
  opacity:0;transform:translateY(20px);
  animation:fadeUp .8s var(--ease-out) .72s forwards;
}
.stat{
  padding:1.75rem 1.5rem;border-right:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.stat-value{
  font-family:var(--serif);font-size:clamp(1.75rem,3vw,2.5rem);
  font-weight:500;color:var(--gold);line-height:1;margin-bottom:.4rem;
}
.stat-label{font-size:.75rem;color:var(--text-muted);letter-spacing:.06em}

/* --- Services grid --- */
.services-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1px;background:var(--border);
  border:1px solid var(--border);border-radius:4px;overflow:hidden;
}
.service-card{
  background:var(--surface);padding:2.5rem;position:relative;overflow:hidden;
  transition:background .35s var(--ease-out);
}
.service-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  transform:scaleX(0);transition:transform .5s var(--ease-out);
}
.service-card:hover{background:var(--card)}
.service-card:hover::before{transform:scaleX(1)}
.service-num{
  font-family:var(--serif);font-size:3rem;font-weight:300;
  color:rgba(201,168,76,.12);line-height:1;margin-bottom:1.5rem;
  transition:color .35s var(--ease-out);
}
.service-card:hover .service-num{color:rgba(201,168,76,.25)}
.service-card h3{font-size:1.25rem;margin-bottom:.75rem}
.service-card p{color:var(--text-muted);font-size:.9375rem;line-height:1.7;margin-bottom:1.5rem}
.arrow-link{
  display:inline-flex;align-items:center;gap:.5rem;
  font-size:.75rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;
  color:var(--gold);transition:gap .2s var(--ease);
}
.arrow-link:hover{gap:.875rem}
.arrow-link::after{content:'→'}

/* --- Sectors --- */
.sectors-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1px;background:var(--border);
  border:1px solid var(--border);border-radius:4px;overflow:hidden;
}
.sector{
  background:var(--surface);padding:1.625rem 2rem;
  display:flex;align-items:center;gap:1rem;
  transition:background .2s var(--ease);
}
.sector:hover{background:var(--card)}
.sector-mark{
  width:5px;height:5px;min-width:5px;border-radius:50%;
  background:var(--gold);opacity:.55;
}
.sector span{font-size:.9375rem;color:var(--text-muted);transition:color .2s var(--ease)}
.sector:hover span{color:var(--text)}

/* --- Case study cards --- */
.case-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1px;background:var(--border);
  border:1px solid var(--border);border-radius:4px;overflow:hidden;
}
.case-card{
  background:var(--surface);padding:2.5rem;position:relative;overflow:hidden;
  transition:background .35s var(--ease-out);
}
.case-card::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(201,168,76,.04) 0%,transparent 60%);
  opacity:0;transition:opacity .35s var(--ease-out);
}
.case-card:hover{background:var(--card)}
.case-card:hover::after{opacity:1}
.case-tag{
  display:inline-block;font-size:.65rem;font-weight:500;letter-spacing:.16em;
  text-transform:uppercase;color:var(--gold);background:rgba(201,168,76,.1);
  padding:.3rem .75rem;border-radius:2px;margin-bottom:1.5rem;
}
.case-card h3{font-size:1.4rem;margin-bottom:.875rem;line-height:1.2}
.case-card p{color:var(--text-muted);font-size:.9375rem;line-height:1.7;margin-bottom:2rem}
.case-metrics{
  display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;
  padding-top:1.5rem;border-top:1px solid var(--border);
}
.case-metric-val{
  font-family:var(--serif);font-size:1.625rem;font-weight:500;
  color:var(--gold);line-height:1.15;
}
.case-metric-lbl{font-size:.7rem;color:var(--text-dim);letter-spacing:.06em;margin-top:.2rem}

/* --- About split --- */
.about-split{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.about-content .eyebrow{margin-bottom:1rem}
.about-content h2{margin-bottom:1.25rem}
.about-content p{color:var(--text-muted);line-height:1.85;margin-bottom:1.125rem}
.creds{display:flex;flex-direction:column;gap:.75rem;margin-top:2rem}
.cred{display:flex;align-items:flex-start;gap:.875rem;font-size:.9375rem;color:var(--text-muted)}
.cred::before{content:'—';color:var(--gold);flex-shrink:0;margin-top:.1em}

.about-frame{
  background:var(--surface);border:1px solid var(--border);border-radius:4px;
  padding:3rem;position:relative;overflow:hidden;
}
.about-frame::before{
  content:'';position:absolute;top:0;left:2rem;right:2rem;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
}
.about-quote{
  font-family:var(--serif);font-size:1.625rem;font-style:italic;
  line-height:1.45;margin-bottom:1.5rem;
}
.about-attr{font-size:.8125rem;color:var(--text-dim);letter-spacing:.06em}

/* --- CTA section --- */
.cta-section{
  background:var(--surface);
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  text-align:center;padding:7rem 0;position:relative;overflow:hidden;
}
.cta-section::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 80% at 50% 50%,rgba(201,168,76,.06) 0%,transparent 70%);
  pointer-events:none;
}
.cta-section .container{position:relative;z-index:1}
.cta-section h2{max-width:600px;margin:0 auto 1.25rem}
.cta-section p{color:var(--text-muted);max-width:480px;margin:0 auto 2.5rem;font-size:1.0625rem}
.cta-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* --- Page hero (inner pages) --- */
.page-hero{
  padding-top:calc(var(--nav-h) + 5rem);padding-bottom:5rem;
  border-bottom:1px solid var(--border);position:relative;overflow:hidden;
}
.page-hero::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 70% 100% at 0% 60%,rgba(201,168,76,.05) 0%,transparent 60%);
  pointer-events:none;
}
.page-hero .container{position:relative;z-index:1}
.page-hero .eyebrow{margin-bottom:1.25rem}
.page-hero h1{max-width:720px;margin-bottom:1.5rem}
.page-hero .lede{max-width:560px;color:var(--text-muted);font-size:1.125rem;line-height:1.85}

/* --- Services detail page --- */
.service-detail{padding:5rem 0;border-bottom:1px solid var(--border)}
.service-detail:last-child{border-bottom:none}
.sd-grid{display:grid;grid-template-columns:240px 1fr;gap:5rem;align-items:start}
.sd-aside{position:sticky;top:calc(var(--nav-h) + 2rem)}
.sd-num{font-family:var(--serif);font-size:5rem;font-weight:300;
  color:rgba(201,168,76,.15);line-height:1;margin-bottom:.5rem}
.sd-label{font-size:.7rem;font-weight:500;letter-spacing:.2em;
  text-transform:uppercase;color:var(--gold)}
.sd-content h2{font-size:clamp(1.5rem,3vw,2.25rem);margin-bottom:1.125rem}
.sd-content p{color:var(--text-muted);line-height:1.85;margin-bottom:1.25rem}
.sd-list{display:flex;flex-direction:column;gap:.625rem;margin-top:1.5rem}
.sd-list li{display:flex;align-items:flex-start;gap:.875rem;
  font-size:.9375rem;color:var(--text-muted)}
.sd-list li::before{content:'→';color:var(--gold);flex-shrink:0;margin-top:.1em}

/* --- Case study accordion --- */
.accordion-item{border-bottom:1px solid var(--border)}
.accordion-trigger{
  width:100%;display:flex;align-items:center;justify-content:space-between;
  padding:2rem 0;text-align:left;cursor:pointer;
  transition:color .2s var(--ease);gap:1rem;
}
.accordion-trigger:hover{color:var(--gold)}
.accordion-trigger h3{font-size:1.5rem}
.accordion-icon{
  width:28px;height:28px;min-width:28px;
  border:1px solid var(--border);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:1.125rem;color:var(--gold);
  transition:transform .35s var(--ease-out),background .2s var(--ease);
}
.accordion-item.open .accordion-icon{
  transform:rotate(45deg);background:var(--gold-subtle);
}
.accordion-body{max-height:0;overflow:hidden;transition:max-height .55s var(--ease-out)}
.accordion-inner{padding-bottom:2.5rem}
.accordion-inner p{color:var(--text-muted);line-height:1.85;margin-bottom:1.25rem}
.accordion-inner h4{font-family:var(--sans);font-size:.7rem;font-weight:500;
  letter-spacing:.2em;text-transform:uppercase;color:var(--text-dim);
  margin:1.75rem 0 .875rem}
.result-row{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:var(--border);border:1px solid var(--border);
  border-radius:4px;overflow:hidden;margin-bottom:1.5rem;
}
.result-cell{background:var(--surface);padding:1.5rem}
.result-val{font-family:var(--serif);font-size:2rem;font-weight:500;
  color:var(--gold);line-height:1;margin-bottom:.375rem}
.result-lbl{font-size:.7rem;color:var(--text-dim);letter-spacing:.06em}

/* --- Contact page --- */
.contact-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:5rem;align-items:start}
.contact-info h3{font-size:1.5rem;margin-bottom:1rem}
.contact-info p{color:var(--text-muted);line-height:1.85;margin-bottom:2.5rem}
.contact-item{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1.5rem}
.contact-icon{
  width:40px;height:40px;min-width:40px;
  border:1px solid var(--border);border-radius:2px;
  display:flex;align-items:center;justify-content:center;
  color:var(--gold);font-size:1.1rem;
}
.contact-item-text strong{display:block;font-size:.75rem;font-weight:500;
  letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);margin-bottom:.25rem}
.contact-item-text span{font-size:.9375rem;color:var(--text-muted)}
.form-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:4px;padding:2.5rem;
}
.form-card h3{font-size:1.375rem;margin-bottom:.625rem}
.form-card > p{color:var(--text-muted);font-size:.9375rem;margin-bottom:2rem}
.form-group{margin-bottom:1.375rem}
.form-group label{display:block;font-size:.7rem;font-weight:500;letter-spacing:.12em;
  text-transform:uppercase;color:var(--text-dim);margin-bottom:.5rem}
.form-group input,.form-group select,.form-group textarea{
  width:100%;background:var(--card);border:1px solid var(--border);
  border-radius:2px;padding:.875rem 1.125rem;color:var(--text);
  font-size:.9375rem;transition:border-color .2s var(--ease);outline:none;
  -webkit-appearance:none;appearance:none;
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{
  border-color:var(--gold);
}
.form-group textarea{resize:vertical;min-height:130px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
.form-group select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238a899a' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem;
}
.form-group select option{background:var(--card)}

/* --- Footer --- */
.site-footer{
  background:var(--surface);border-top:1px solid var(--border);
  padding:4rem 0 2rem;
}
.footer-top{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;
  gap:3rem;padding-bottom:3rem;border-bottom:1px solid var(--border);
}
.footer-brand img{height:26px;margin-bottom:1.25rem}
.footer-brand p{font-size:.875rem;color:var(--text-dim);line-height:1.7;max-width:260px}
.footer-col h5{
  font-family:var(--sans);font-size:.7rem;font-weight:500;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--text-dim);margin-bottom:1.25rem;
}
.footer-col ul{display:flex;flex-direction:column;gap:.625rem}
.footer-col a{font-size:.875rem;color:var(--text-muted);transition:color .2s var(--ease)}
.footer-col a:hover{color:var(--gold)}
.footer-bottom{
  padding-top:2rem;display:flex;justify-content:space-between;
  align-items:center;gap:1rem;flex-wrap:wrap;
}
.footer-bottom p{font-size:.8125rem;color:var(--text-dim)}

/* ─── Image Slot System ──────────────────────────────────────────
   Slots maintain layout space and show a labeled placeholder until
   the real photo is dropped into images/. No JS required for layout;
   img-loaded class toggles visibility once the file exists.
   ─────────────────────────────────────────────────────────────── */

/* Hero background photo (homepage) */
.hero-photo {
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;object-position:center 40%;
  opacity:0;transition:opacity 1.2s ease;
  mix-blend-mode:luminosity;
  pointer-events:none;
}
.hero-photo.img-loaded { opacity:.16; }

/* Page-hero background photo (inner pages) */
.page-hero-photo {
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;object-position:center 30%;
  opacity:0;transition:opacity .8s ease;
  mix-blend-mode:luminosity;
  pointer-events:none;
}
.page-hero-photo.img-loaded { opacity:.1; }

/* Nick's portrait slot (about-frame rework) */
.about-frame--photo {
  padding:0;
  background:var(--bg);
}
.about-frame--photo::before { display:none; }

.about-photo-slot {
  aspect-ratio:3/4;
  min-height:360px;
  position:relative;
  overflow:hidden;
  background:var(--bg);
  border-radius:3px;
}
/* Placeholder label — visible until image loads */
.about-photo-slot::after {
  content:attr(data-slot-label);
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--sans);font-size:.625rem;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;
  color:rgba(201,168,76,.38);text-align:center;
  padding:2rem;white-space:pre-line;line-height:2;
  border:1px dashed rgba(201,168,76,.2);border-radius:3px;
  pointer-events:none;
}
.about-photo-slot.img-loaded::after { display:none; }

.about-photo-slot img.about-photo {
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;object-position:top center;
  display:block;
  opacity:0;transition:opacity .5s ease;
}
.about-photo-slot.img-loaded img.about-photo { opacity:1; }

.about-photo-overlay {
  position:absolute;bottom:0;left:0;right:0;
  padding:3rem 2.5rem 2rem;
  background:linear-gradient(0deg,rgba(9,9,15,.97) 0%,rgba(9,9,15,.65) 55%,transparent 100%);
}
.about-photo-overlay .about-quote {
  font-family:var(--serif);font-size:1.25rem;font-style:italic;
  line-height:1.5;margin-bottom:1rem;color:var(--text);
}
.about-photo-overlay .about-attr {
  font-size:.8125rem;color:var(--text-dim);letter-spacing:.06em;
}

/* Industry image break (full-width, between service blocks) */
.industry-break {
  position:relative;height:300px;overflow:hidden;
  background:var(--surface);
}
.industry-break img {
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;object-position:center;
  display:block;
  filter:brightness(.28) saturate(.5);
  opacity:0;transition:opacity .8s ease;
}
.industry-break.img-loaded img { opacity:1; }
/* Placeholder label */
.industry-break::before {
  content:attr(data-slot-label);
  position:absolute;inset:0;z-index:1;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--sans);font-size:.625rem;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;
  color:rgba(201,168,76,.3);text-align:center;
  padding:2rem;white-space:pre-line;line-height:2;
  border-top:1px dashed rgba(201,168,76,.15);
  border-bottom:1px dashed rgba(201,168,76,.15);
  pointer-events:none;
}
.industry-break.img-loaded::before { display:none; }
/* Gradient overlay — active once image loads */
.industry-break-overlay {
  position:absolute;inset:0;z-index:2;
  background:linear-gradient(
    90deg,
    rgba(9,9,15,.72) 0%,
    transparent 35%,
    transparent 65%,
    rgba(9,9,15,.72) 100%
  );
  opacity:0;transition:opacity .8s ease;
  pointer-events:none;
}
.industry-break.img-loaded .industry-break-overlay { opacity:1; }

/* --- 404 --- */
.not-found{
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  text-align:center;padding:var(--nav-h) 2rem 4rem;
}
.not-found .eyebrow{justify-content:center;margin-bottom:1.5rem}
.not-found h1{font-size:clamp(1.8rem,4vw,3rem);margin-bottom:1.125rem}
.not-found p{color:var(--text-muted);max-width:420px;margin:0 auto 2.5rem}

/* --- Scroll reveal --- */
.reveal{opacity:0;transform:translateY(28px);
  transition:opacity .7s var(--ease-out),transform .7s var(--ease-out)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-d1{transition-delay:.1s}
.reveal-d2{transition-delay:.2s}
.reveal-d3{transition-delay:.3s}
.reveal-d4{transition-delay:.4s}

/* --- Keyframes --- */
@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}

/* --- Responsive --- */
@media(max-width:1024px){
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .case-grid{grid-template-columns:repeat(2,1fr)}
  .sectors-grid{grid-template-columns:repeat(2,1fr)}
  .footer-top{grid-template-columns:1fr 1fr;gap:2rem}
  .about-split{grid-template-columns:1fr;gap:3rem}
  .sd-grid{grid-template-columns:1fr;gap:1.5rem}
  .sd-aside{position:static}
  .hero-stats{grid-template-columns:repeat(2,1fr)}
  .contact-grid{grid-template-columns:1fr;gap:3rem}
}
@media(max-width:768px){
  :root{--nav-h:72px}
  section{padding:4rem 0}
  .container{padding:0 1.25rem}
  .services-grid,.case-grid,.sectors-grid{grid-template-columns:1fr}
  .result-row{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .nav-brand img{height:36px}
  .nav-links{
    position:fixed;top:var(--nav-h);left:0;right:0;
    height:calc(100dvh - var(--nav-h));
    background:rgba(9,9,15,.98);backdrop-filter:blur(20px);
    -webkit-backdrop-filter:blur(20px);
    flex-direction:column;justify-content:center;align-items:center;
    gap:0;padding:2rem;overflow-y:auto;
    transform:translateX(100%);transition:transform .35s var(--ease-out);
    z-index:99;
  }
  .nav-links.open{transform:translateX(0)}
  .nav-links li{width:100%}
  .nav-links a{
    font-size:1.5rem;padding:1.125rem 1rem;text-align:center;
    letter-spacing:.04em;min-height:56px;justify-content:center;
    display:flex;width:100%;
  }
  .nav-links a::after{display:none}
  .nav-cta{display:none}
  .nav-toggle{display:flex}
  .nav-toggle span{width:26px;height:2px}
  .footer-top{grid-template-columns:1fr;gap:2rem}
  .footer-bottom{flex-direction:column;text-align:center}
  .case-metrics{grid-template-columns:1fr}
  .hero .container{padding-top:3rem;padding-bottom:3rem}
  .about-frame{padding:2rem}
  .about-quote{font-size:1.25rem}
  .accordion-trigger h3{font-size:1.25rem}
  .sd-num{font-size:3.5rem}
  .cta-section{padding:5rem 0}
  .page-hero{padding-top:calc(var(--nav-h) + 3rem);padding-bottom:3rem}
}
@media(max-width:480px){
  .hero-stats{grid-template-columns:1fr}
  .hero-actions{flex-direction:column}
  .hero-actions .btn{width:100%;justify-content:center}
  .cta-actions{flex-direction:column;align-items:center}
  .cta-actions .btn{width:100%;max-width:320px}
  .contact-grid{gap:2rem}
  .form-card{padding:1.5rem}
  section{padding:3rem 0}
  .footer-brand img{height:32px}
  .btn{padding:.875rem 1.5rem}
}
