/* BMPF Theme v1.0.0 | Simplix Tech Labs */

/* ════════════════════════════════════════════
   THEME TOKENS — DARK (default)
════════════════════════════════════════════ */
:root {
  --gold:        #C8A84B;
  --gold-lt:     #E8D080;
  --gold-glow:   rgba(200,168,75,0.28);
  --blue:        #1A3C6E;
  --blue-mid:    #2452A0;
  --blue-deep:   #0D2244;
  --r-sm: 10px; --r-md: 18px; --r-lg: 28px; --r-xl: 40px; --r-full: 999px;

  /* surface */
  --bg:          #06101C;
  --bg-2:        #0C1A2D;
  --bg-3:        #132338;
  --bg-card:     #0F1E33;
  --bg-nav:      rgba(6,16,28,.93);
  --bg-input:    rgba(255,255,255,0.04);

  /* text */
  --txt:         #FFFFFF;
  --txt-2:       #A8BCCC;
  --txt-3:       #7A8FA8;

  /* border */
  --bdr:         rgba(200,168,75,0.15);
  --bdr-soft:    rgba(255,255,255,0.07);
  --bdr-input:   rgba(255,255,255,0.12);

  /* badge bg */
  --badge-bg:    rgba(26,60,110,0.22);
  --badge-bdr:   rgba(200,168,75,0.22);

  /* hero form */
  --form-bg:     #0C1A2D;
  --form-bdr:    rgba(200,168,75,0.15);

  /* stats hover */
  --stat-hover:  rgba(26,60,110,0.18);

  /* why card */
  --why-bg:      #0F1E33;
  --why-icon-bg: rgba(200,168,75,0.10);

  /* testimonial */
  --t-bg:        rgba(255,255,255,0.05);
  --t-bdr:       rgba(255,255,255,0.10);
  --t-sec-bg:    #0D2244;

  /* step hover */
  --step-hover:  rgba(26,60,110,0.12);

  /* case card */
  --case-bg:     #0F1E33;

  /* footer */
  --footer-bg:   #0C1A2D;

  /* orbs */
  --orb1: rgba(26,60,110,0.35);
  --orb2: rgba(200,168,75,0.06);
  --orb3: rgba(36,82,160,0.20);

  /* cta bg */
  --cta-overlay: rgba(26,60,110,0.50);

  /* ghost btn */
  --ghost-clr:   #FFFFFF;
  --ghost-bdr:   rgba(255,255,255,0.18);

  /* logo row */
  --logo-row-bg: transparent;
  --logo-pill-c: #7A8FA8;

  /* about img */
  --img-bg:      #0F1E33;

  /* how panel */
  --panel-bg:    #0F1E33;

  /* social sidebar */
  --social-bg:   rgba(12,26,45,0.95);
  --social-bdr:  rgba(200,168,75,0.2);
  --social-icon: rgba(200,168,75,0.15);
  --social-hover:#C8A84B;

  /* scroll bar */
  --scrollbar-track: #0C1A2D;
  --scrollbar-thumb: #1A3C6E;

  transition: background .4s, color .4s;
}

/* ════════════════════════════════════════════
   LIGHT MODE OVERRIDES
════════════════════════════════════════════ */
[data-theme="light"] {
  --bg:          #F4F6FA;
  --bg-2:        #FFFFFF;
  --bg-3:        #EDF0F7;
  --bg-card:     #FFFFFF;
  --bg-nav:      rgba(255,255,255,0.94);
  --bg-input:    #F4F6FA;

  --txt:         #0D1B2A;
  --txt-2:       #3A5070;
  --txt-3:       #6B80A0;

  --bdr:         rgba(26,60,110,0.14);
  --bdr-soft:    rgba(26,60,110,0.10);
  --bdr-input:   rgba(26,60,110,0.18);

  --badge-bg:    rgba(26,60,110,0.07);
  --badge-bdr:   rgba(26,60,110,0.18);

  --form-bg:     #FFFFFF;
  --form-bdr:    rgba(26,60,110,0.14);

  --stat-hover:  rgba(26,60,110,0.06);

  --why-bg:      #FFFFFF;
  --why-icon-bg: rgba(26,60,110,0.08);

  --t-bg:        #FFFFFF;
  --t-bdr:       rgba(26,60,110,0.12);
  --t-sec-bg:    #1A3C6E;

  --step-hover:  rgba(26,60,110,0.06);

  --case-bg:     #FFFFFF;

  --footer-bg:   #0D1B2A;

  --orb1: rgba(26,60,110,0.12);
  --orb2: rgba(200,168,75,0.08);
  --orb3: rgba(36,82,160,0.08);

  --cta-overlay: rgba(26,60,110,0.08);

  --ghost-clr:   #1A3C6E;
  --ghost-bdr:   rgba(26,60,110,0.3);

  --logo-row-bg: #EDF0F7;
  --logo-pill-c: #4A6080;

  --img-bg:      #EDF0F7;
  --panel-bg:    #FFFFFF;

  --social-bg:   rgba(255,255,255,0.96);
  --social-bdr:  rgba(26,60,110,0.15);
  --social-icon: rgba(26,60,110,0.08);
  --social-hover:#1A3C6E;

  --scrollbar-track: #EDF0F7;
  --scrollbar-thumb: #1A3C6E;
}

/* ════════════════════════════════════════════
   RESET & BASE
════════════════════════════════════════════ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
::-webkit-scrollbar{width:6px;}
::-webkit-scrollbar-track{background:var(--scrollbar-track);}
::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:3px;}
body{
  font-family:'DM Sans',sans-serif;
  background:var(--bg);
  color:var(--txt);
  overflow-x:hidden;
  cursor:none;
  transition:background .45s ease,color .45s ease;
}
a{text-decoration:none;color:inherit;}

/* ════════════════════════════════════════════
   CURSOR
════════════════════════════════════════════ */
.cursor{position:fixed;width:12px;height:12px;border-radius:50%;background:var(--gold);pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .3s,height .3s;mix-blend-mode:difference;}
.cursor-ring{position:fixed;width:40px;height:40px;border-radius:50%;border:1.5px solid rgba(200,168,75,.5);pointer-events:none;z-index:9998;transform:translate(-50%,-50%);}

/* ════════════════════════════════════════════
   SCROLL REVEAL
════════════════════════════════════════════ */
.reveal{opacity:0;transform:translateY(50px);transition:opacity .85s cubic-bezier(.22,1,.36,1),transform .85s cubic-bezier(.22,1,.36,1);}
.reveal.visible{opacity:1;transform:translateY(0);}
.reveal-left{opacity:0;transform:translateX(-60px);transition:opacity .85s cubic-bezier(.22,1,.36,1),transform .85s cubic-bezier(.22,1,.36,1);}
.reveal-left.visible{opacity:1;transform:translateX(0);}
.reveal-right{opacity:0;transform:translateX(60px);transition:opacity .85s cubic-bezier(.22,1,.36,1),transform .85s cubic-bezier(.22,1,.36,1);}
.reveal-right.visible{opacity:1;transform:translateX(0);}
.delay-1{transition-delay:.1s!important;} .delay-2{transition-delay:.2s!important;}
.delay-3{transition-delay:.3s!important;} .delay-4{transition-delay:.4s!important;}
.delay-5{transition-delay:.5s!important;} .delay-6{transition-delay:.6s!important;}

/* ════════════════════════════════════════════
   KEYFRAMES
════════════════════════════════════════════ */
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(32px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideRight{from{transform:scaleX(0)}to{transform:scaleX(1)}}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.85)}}
@keyframes glow{0%,100%{box-shadow:0 0 20px var(--gold-glow)}50%{box-shadow:0 0 60px rgba(200,168,75,.5)}}
@keyframes orb1{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(40px,-30px) scale(1.1)}66%{transform:translate(-20px,20px) scale(.95)}}
@keyframes orb2{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(-50px,20px) scale(1.05)}66%{transform:translate(30px,-40px) scale(.9)}}
@keyframes logoScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@keyframes slideDown{from{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}
@keyframes toggleSlide{0%{transform:translateX(0)}100%{transform:translateX(24px)}}
@keyframes socialIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}
@keyframes themeFade{from{opacity:0}to{opacity:1}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}

/* ════════════════════════════════════════════
   TICKER
════════════════════════════════════════════ */
.ticker-bar{height:42px;background:linear-gradient(90deg,var(--gold),#B8973A,var(--gold));overflow:hidden;display:flex;align-items:center;position:relative;z-index:300;}
.ticker-track{display:flex;white-space:nowrap;animation:ticker 30s linear infinite;}
.ticker-item{display:inline-flex;align-items:center;gap:18px;padding:0 40px;font-size:11px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:#06101C;}
.ticker-sep{font-size:7px;opacity:.5;}

/* ════════════════════════════════════════════
   NAV
════════════════════════════════════════════ */
nav{
  position:sticky;top:0;z-index:200;height:74px;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 80px 0 64px;
  background:var(--bg-nav);
  backdrop-filter:blur(24px);
  border-bottom:1px solid var(--bdr);
  transition:height .3s,background .45s,border-color .45s;
}
nav.scrolled{height:62px;}

.logo-wrap{display:flex;align-items:center;gap:14px;}
.logo-icon{width:46px;height:46px;border-radius:var(--r-sm);background:linear-gradient(135deg,var(--blue),var(--blue-mid));border:1.5px solid var(--gold);display:flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',serif;font-size:18px;font-weight:700;color:var(--gold);transition:all .3s;flex-shrink:0;}
.logo-icon:hover{animation:glow 1.5s ease infinite;}
.logo-text{line-height:1.1;}
.logo-top{display:block;font-size:14px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--txt);transition:color .45s;}
.logo-bot{display:block;font-family:'Cormorant Garamond',serif;font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);}

.nav-links{display:flex;gap:32px;list-style:none;}
.nav-links a{font-size:13px;font-weight:500;color:var(--txt-2);transition:color .2s;position:relative;}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;background:var(--gold);transition:width .3s;}
.nav-links a:hover{color:var(--txt);}
.nav-links a:hover::after{width:100%;}

.nav-right{display:flex;align-items:center;gap:16px;}

/* theme toggle */
.theme-toggle{
  display:flex;align-items:center;gap:8px;
  cursor:pointer;padding:6px 12px;
  border-radius:var(--r-full);
  border:1px solid var(--bdr);
  background:var(--bg-card);
  transition:all .3s;
  font-size:12px;font-weight:600;color:var(--txt-2);
  letter-spacing:.5px;
}
.theme-toggle:hover{border-color:var(--gold);color:var(--txt);}
.toggle-track{width:40px;height:22px;border-radius:var(--r-full);background:var(--bdr-input);position:relative;transition:background .3s;flex-shrink:0;}
[data-theme="light"] .toggle-track{background:var(--gold);}
.toggle-thumb{width:16px;height:16px;border-radius:50%;background:var(--txt-3);position:absolute;top:3px;left:3px;transition:transform .3s,background .3s;}
[data-theme="light"] .toggle-thumb{transform:translateX(18px);background:#fff;}
.toggle-icon{font-size:14px;}

.nav-cta{background:transparent;border:1.5px solid var(--gold);color:var(--gold);padding:10px 26px;font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase;cursor:pointer;border-radius:var(--r-full);font-family:'DM Sans',sans-serif;transition:all .3s;}
.nav-cta:hover{background:var(--gold);color:#06101C;box-shadow:0 0 32px var(--gold-glow);}

/* ════════════════════════════════════════════
   SOCIAL SIDEBAR (fixed right)
════════════════════════════════════════════ */
.social-sidebar{
  position:fixed;right:0;top:50%;transform:translateY(-50%);
  z-index:150;
  display:flex;flex-direction:column;
  gap:3px;
  animation:socialIn .8s ease .5s both;
}
.social-link{
  width:52px;height:52px;
  display:flex;align-items:center;justify-content:center;
  background:var(--social-bg);
  border:1px solid var(--social-bdr);
  border-right:none;
  cursor:pointer;
  transition:all .3s cubic-bezier(.22,1,.36,1);
  position:relative;
  overflow:visible;
  text-decoration:none;
  color:var(--txt-3);
}
.social-link:first-child{border-radius:var(--r-md) 0 0 var(--r-md);}
.social-link:last-child{border-radius:var(--r-md) 0 0 var(--r-md);}

/* left accent bar */
.social-link::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:3px;
  transform:scaleY(0);transition:transform .3s;transform-origin:bottom;
  border-radius:2px 0 0 2px;
}
.social-link:hover::before{transform:scaleY(1);}
.social-link:hover{transform:translateX(-6px);box-shadow:-4px 0 20px rgba(0,0,0,.25);}

/* brand hover colors */
.soc-fb::before{background:#1877F2;}
.soc-fb:hover{background:#1877F2;border-color:#1877F2;color:#fff;}
.soc-x::before{background:#000;}
.soc-x:hover{background:#000;border-color:#333;color:#fff;}
[data-theme="light"] .soc-x::before{background:#0F1419;}
[data-theme="light"] .soc-x:hover{background:#0F1419;color:#fff;}
.soc-ig::before{background:linear-gradient(180deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);}
.soc-ig:hover{background:linear-gradient(135deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);border-color:#dc2743;color:#fff;}
.soc-wa::before{background:#25D366;}
.soc-wa:hover{background:#25D366;border-color:#25D366;color:#fff;}

/* SVG icon */
.s-svg{
  width:22px;height:22px;
  transition:transform .3s,color .2s;
  position:relative;z-index:1;
  flex-shrink:0;
}
.social-link:hover .s-svg{transform:scale(1.15);}

/* tooltip label */
.social-link::after{
  content:attr(data-tip);
  position:absolute;
  right:calc(100% + 14px);
  top:50%;transform:translateY(-50%) translateX(6px);
  background:var(--gold);color:#06101C;
  font-family:'DM Sans',sans-serif;
  font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;
  padding:6px 12px;border-radius:var(--r-full);white-space:nowrap;
  opacity:0;pointer-events:none;
  transition:opacity .25s,transform .25s;
  box-shadow:0 4px 16px rgba(0,0,0,.2);
}
.social-link:hover::after{
  opacity:1;
  transform:translateY(-50%) translateX(0);
}

/* ════════════════════════════════════════════
   HERO
════════════════════════════════════════════ */
.hero{min-height:100vh;display:grid;grid-template-columns:1fr 480px;position:relative;overflow:hidden;}
.orb{position:absolute;border-radius:50%;filter:blur(90px);pointer-events:none;}
.orb-1{width:600px;height:600px;background:var(--orb1);top:-100px;right:80px;animation:orb1 12s ease-in-out infinite;}
.orb-2{width:400px;height:400px;background:var(--orb2);bottom:-60px;left:180px;animation:orb2 16s ease-in-out infinite;}
.orb-3{width:280px;height:280px;background:var(--orb3);top:40%;left:-60px;animation:orb1 20s ease-in-out infinite reverse;}
.hero-mesh{position:absolute;inset:0;background-image:linear-gradient(rgba(200,168,75,0.04) 1px,transparent 1px),linear-gradient(90deg,rgba(200,168,75,0.04) 1px,transparent 1px);background-size:64px 64px;mask-image:radial-gradient(ellipse 80% 80% at 60% 50%,black,transparent 80%);pointer-events:none;transition:opacity .45s;}
[data-theme="light"] .hero-mesh{opacity:.4;}

.hero-left{padding:110px 64px 80px;display:flex;flex-direction:column;justify-content:center;position:relative;z-index:2;animation:fadeUp .9s ease .1s both;}
.hero-eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:32px;}
.eyebrow-line{width:48px;height:1px;background:linear-gradient(90deg,var(--gold),transparent);transform-origin:left;animation:slideRight .8s ease .5s both;}
.eyebrow-text{font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);font-weight:600;}
.hero h1{font-family:'Cormorant Garamond',serif;font-size:clamp(50px,6vw,86px);line-height:1.02;font-weight:700;color:var(--txt);}
.hero h1 .it{font-style:italic;color:var(--gold);display:block;}
.hero h1 .big{display:block;font-size:clamp(64px,8vw,108px);line-height:.92;}
.hero-sub{font-size:17px;line-height:1.8;color:var(--txt-3);margin:26px 0 40px;max-width:500px;}
.hero-badges{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:44px;}
.badge{display:inline-flex;align-items:center;gap:8px;background:var(--badge-bg);border:1px solid var(--badge-bdr);padding:9px 18px;border-radius:var(--r-full);font-size:12px;font-weight:500;color:var(--txt-2);transition:all .3s;cursor:default;}
.badge:hover{background:rgba(26,60,110,0.4);border-color:var(--gold);color:var(--txt);transform:translateY(-2px);}
[data-theme="light"] .badge:hover{background:rgba(26,60,110,0.12);}
.badge-dot{width:7px;height:7px;border-radius:50%;background:var(--gold);animation:pulse 2s ease infinite;flex-shrink:0;}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;}
.btn-gold{background:var(--gold);color:#06101C;padding:16px 44px;font-size:13px;font-weight:700;letter-spacing:2px;text-transform:uppercase;border:none;cursor:pointer;border-radius:var(--r-full);font-family:'DM Sans',sans-serif;transition:all .35s;position:relative;overflow:hidden;}
.btn-gold::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.35),transparent);transform:translateX(-100%);transition:transform .6s;}
.btn-gold:hover::before{transform:translateX(100%);}
.btn-gold:hover{background:var(--gold-lt);transform:translateY(-3px);box-shadow:0 16px 48px rgba(200,168,75,.4);}
.btn-ghost{background:transparent;color:var(--ghost-clr);padding:16px 36px;font-size:13px;font-weight:500;letter-spacing:1px;border:1px solid var(--ghost-bdr);cursor:pointer;border-radius:var(--r-full);font-family:'DM Sans',sans-serif;transition:all .3s;}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold);}

/* form */
.hero-right{background:var(--form-bg);border-left:1px solid var(--form-bdr);display:flex;flex-direction:column;justify-content:center;padding:64px 52px;position:relative;z-index:2;animation:fadeUp .9s ease .3s both;transition:background .45s,border-color .45s;}
.hero-right::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--gold),var(--blue-mid),var(--gold));}
.form-header{margin-bottom:34px;}
.form-header h2{font-family:'Cormorant Garamond',serif;font-size:28px;font-weight:700;margin-bottom:8px;color:var(--txt);}
.form-header p{font-size:13px;color:var(--txt-3);line-height:1.65;}
.form-field{margin-bottom:16px;}
.form-field label{display:block;font-size:10px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--txt-3);margin-bottom:8px;}
.form-field input{width:100%;padding:14px 18px;background:var(--bg-input);border:1px solid var(--bdr-input);border-radius:var(--r-sm);font-family:'DM Sans',sans-serif;font-size:14px;color:var(--txt);outline:none;transition:all .3s;}
.form-field input::placeholder{color:var(--txt-3);opacity:.6;}
.form-field input:focus{border-color:var(--gold);background:rgba(200,168,75,.05);box-shadow:0 0 0 3px rgba(200,168,75,.12);}
.form-submit{width:100%;padding:16px;background:var(--gold);color:#06101C;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:700;letter-spacing:2px;text-transform:uppercase;border:none;cursor:pointer;margin-top:8px;border-radius:var(--r-full);transition:all .3s;position:relative;overflow:hidden;}
.form-submit:hover{background:var(--gold-lt);box-shadow:0 8px 32px rgba(200,168,75,.45);transform:translateY(-2px);}
.form-note{text-align:center;margin-top:14px;font-size:11px;color:var(--txt-3);}

/* ════════════════════════════════════════════
   STATS STRIP
════════════════════════════════════════════ */
.stats-strip{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--bdr);border-bottom:1px solid var(--bdr);transition:border-color .45s;}
.stat-cell{padding:56px 40px;text-align:center;border-right:1px solid var(--bdr);position:relative;overflow:hidden;transition:background .4s,border-color .45s;cursor:default;}
.stat-cell:last-child{border-right:none;}
.stat-cell::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--gold),transparent);transform:scaleX(0);transition:transform .5s;transform-origin:center;}
.stat-cell:hover{background:var(--stat-hover);}
.stat-cell:hover::before{transform:scaleX(1);}
.stat-num{font-family:'Cormorant Garamond',serif;font-size:68px;font-weight:700;color:var(--gold);line-height:1;display:block;}
.stat-label{font-size:11px;letter-spacing:2.5px;text-transform:uppercase;color:var(--txt-3);margin-top:10px;display:block;}

/* ════════════════════════════════════════════
   SECTION SHARED
════════════════════════════════════════════ */
.section{padding:120px 64px;}
.section-inner{max-width:1240px;margin:0 auto;}
.section-eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:16px;}
.section-eyebrow::before{content:'';display:block;width:36px;height:1px;background:linear-gradient(90deg,var(--gold),transparent);}
.section-eyebrow span{font-size:10px;letter-spacing:3.5px;text-transform:uppercase;color:var(--gold);font-weight:700;}
.section-h2{font-family:'Cormorant Garamond',serif;font-size:clamp(36px,4.5vw,60px);font-weight:700;line-height:1.08;margin-bottom:72px;color:var(--txt);}
.section-h2 em{font-style:italic;color:var(--gold);}

/* ════════════════════════════════════════════
   WHY CHOOSE US
════════════════════════════════════════════ */
.why-section{background:var(--bg-2);transition:background .45s;}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.why-card{padding:48px 40px;background:var(--why-bg);border:1px solid var(--bdr-soft);border-radius:var(--r-lg);position:relative;overflow:hidden;transition:all .4s,background .45s,border-color .45s;cursor:default;}
.why-card::before{content:'';position:absolute;inset:0;border-radius:var(--r-lg);background:linear-gradient(135deg,rgba(200,168,75,.06),transparent 60%);opacity:0;transition:opacity .4s;}
.why-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--gold),transparent);transform:scaleX(0);transition:transform .45s;border-radius:0 0 var(--r-lg) var(--r-lg);}
.why-card:hover{transform:translateY(-6px);border-color:rgba(200,168,75,.3);box-shadow:0 24px 72px rgba(0,0,0,.15);}
.why-card:hover::before{opacity:1;}
.why-card:hover::after{transform:scaleX(1);}
.why-icon{width:58px;height:58px;border-radius:var(--r-md);background:var(--why-icon-bg);border:1px solid rgba(200,168,75,.25);display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:28px;transition:all .4s;}
.why-card:hover .why-icon{background:rgba(200,168,75,.2);transform:scale(1.1) rotate(-5deg);}
.why-card h3{font-size:18px;font-weight:600;margin-bottom:14px;color:var(--txt);}
.why-card p{font-size:14px;color:var(--txt-3);line-height:1.75;}

/* ════════════════════════════════════════════
   HOW IT WORKS
════════════════════════════════════════════ */
.how-section{background:var(--bg);transition:background .45s;}
.how-wrap{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}
.steps-list{display:flex;flex-direction:column;}
.step-item{display:grid;grid-template-columns:72px 1fr;border-bottom:1px solid var(--bdr-soft);padding:36px 0;cursor:default;transition:all .35s;border-radius:0;}
.step-item:first-child{border-top:1px solid var(--bdr-soft);}
.step-item:hover{padding:36px 16px;background:var(--step-hover);border-radius:var(--r-md);border-color:transparent;margin:0 -16px;}
.step-num{font-family:'Cormorant Garamond',serif;font-size:52px;font-weight:700;color:rgba(200,168,75,.18);line-height:1;transition:color .35s;padding-top:4px;}
.step-item:hover .step-num{color:var(--gold);}
.step-content h3{font-size:18px;font-weight:600;margin-bottom:10px;color:var(--txt);}
.step-content p{font-size:14px;color:var(--txt-3);line-height:1.75;}
.how-panel{background:var(--panel-bg);border:1px solid var(--bdr);border-radius:var(--r-xl);padding:52px 48px;position:relative;transition:background .45s,border-color .45s;}
.how-panel-badge{position:absolute;top:-16px;left:36px;background:var(--gold);color:#06101C;font-size:9px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;padding:6px 16px;border-radius:var(--r-full);}
.panel-stats{display:flex;gap:0;margin-bottom:40px;border:1px solid var(--bdr-soft);border-radius:var(--r-md);overflow:hidden;}
.p-stat{flex:1;text-align:center;padding:24px 16px;border-right:1px solid var(--bdr-soft);}
.p-stat:last-child{border-right:none;}
.p-stat-num{font-family:'Cormorant Garamond',serif;font-size:40px;font-weight:700;color:var(--gold);display:block;line-height:1;}
.p-stat-lbl{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--txt-3);margin-top:6px;display:block;}
.divider{height:1px;background:var(--bdr-soft);margin:28px 0;}
.process-visual{display:grid;grid-template-columns:repeat(3,1fr);position:relative;margin-bottom:72px;}
.process-visual::before{content:'';position:absolute;top:32px;left:calc(16.66% + 32px);right:calc(16.66% + 32px);height:1px;background:linear-gradient(90deg,var(--gold),rgba(200,168,75,.3),var(--gold));z-index:0;}
.pv-item{text-align:center;padding:0 28px;position:relative;z-index:1;}
.pv-icon-wrap{width:64px;height:64px;border-radius:50%;background:var(--bg-card);border:2px solid var(--gold);display:flex;align-items:center;justify-content:center;margin:0 auto 24px;font-size:22px;position:relative;z-index:2;transition:all .4s;}
.pv-item:hover .pv-icon-wrap{background:var(--gold);transform:scale(1.1);}
.pv-num{position:absolute;top:-8px;right:-8px;width:22px;height:22px;border-radius:50%;background:var(--gold);color:#06101C;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;}
.pv-item h3{font-size:16px;font-weight:600;margin-bottom:8px;color:var(--txt);}
.pv-item p{font-size:13px;color:var(--txt-3);line-height:1.7;}

/* ════════════════════════════════════════════
   TESTIMONIALS CAROUSEL
════════════════════════════════════════════ */
.testimonials-section{background:var(--t-sec-bg);padding:100px 0;overflow:hidden;transition:background .45s;}
.testimonials-header{padding:0 64px;margin-bottom:60px;}
.carousel-wrap{position:relative;}
.carousel-track{display:flex;gap:24px;padding:0 64px;transition:transform .6s cubic-bezier(.22,1,.36,1);}
.testimonial-card{flex:0 0 420px;background:var(--t-bg);border:1px solid var(--t-bdr);border-radius:var(--r-xl);padding:44px 40px;transition:all .4s;}
.testimonial-card:hover{border-color:rgba(200,168,75,.35);transform:translateY(-5px);box-shadow:0 24px 60px rgba(0,0,0,.2);}
.t-stars{display:flex;gap:4px;margin-bottom:24px;}
.t-star{color:var(--gold);font-size:14px;}
.t-quote{font-family:'Cormorant Garamond',serif;font-size:20px;font-style:italic;line-height:1.65;color:var(--txt-2);margin-bottom:28px;}
.t-divider{height:1px;background:var(--bdr-soft);margin-bottom:24px;}
.t-author{display:flex;align-items:center;gap:14px;}
.t-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--blue-mid));border:2px solid var(--gold);display:flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',serif;font-size:19px;font-weight:700;color:var(--gold);flex-shrink:0;}
.t-name{font-size:14px;font-weight:600;margin-bottom:3px;color:var(--txt);}
.t-loc{font-size:12px;color:var(--gold);letter-spacing:.5px;}
.carousel-controls{display:flex;justify-content:center;gap:12px;margin-top:48px;padding:0 64px;align-items:center;}
.c-btn{width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);color:var(--txt);font-size:18px;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;}
[data-theme="light"] .c-btn{background:rgba(26,60,110,.08);border-color:rgba(26,60,110,.2);color:var(--txt);}
.c-btn:hover{background:var(--gold);border-color:var(--gold);color:#06101C;}
.c-dots{display:flex;gap:8px;align-items:center;}
.c-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.25);cursor:pointer;transition:all .3s;}
[data-theme="light"] .c-dot{background:rgba(26,60,110,.25);}
.c-dot.active{width:28px;border-radius:var(--r-full);background:var(--gold);}

/* ════════════════════════════════════════════
   ABOUT
════════════════════════════════════════════ */
.about-section{background:var(--bg-3);transition:background .45s;}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}
.about-imgs{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:240px 240px;gap:14px;}
.img-ph{border-radius:var(--r-lg);background:var(--img-bg);border:1px solid var(--bdr-soft);display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden;transition:all .4s,background .45s;}
.img-ph::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(26,60,110,.3),rgba(200,168,75,.06));transition:opacity .4s;}
.img-ph:hover{transform:scale(1.02);box-shadow:0 20px 60px rgba(0,0,0,.2);}
.img-ph.tall{grid-row:span 2;border-radius:var(--r-xl);}
.img-ph-icon{font-size:44px;opacity:.18;position:relative;z-index:1;}
.img-label{position:absolute;bottom:14px;left:14px;background:rgba(200,168,75,.88);color:#06101C;font-size:9px;font-weight:700;letter-spacing:2px;padding:5px 12px;border-radius:var(--r-full);z-index:2;}
.about-text p{font-size:15px;color:var(--txt-3);line-height:1.9;margin-bottom:24px;}
.about-text p strong{color:var(--txt);}
.about-points{display:flex;flex-direction:column;gap:12px;margin-top:36px;}
.about-point{display:flex;align-items:center;gap:16px;padding:18px 22px;background:var(--why-icon-bg);border:1px solid var(--bdr-soft);border-radius:var(--r-md);font-size:14px;color:var(--txt-2);transition:all .35s;cursor:default;}
.about-point:hover{background:rgba(26,60,110,.15);border-color:var(--gold);color:var(--txt);transform:translateX(6px);}
.about-point-icon{color:var(--gold);font-size:14px;flex-shrink:0;}

/* ════════════════════════════════════════════
   LOGO / CITY ROW
════════════════════════════════════════════ */
.logo-row{overflow:hidden;padding:36px 0;background:var(--logo-row-bg);border-top:1px solid var(--bdr-soft);border-bottom:1px solid var(--bdr-soft);transition:background .45s,border-color .45s;}
.logo-track{display:flex;animation:logoScroll 20s linear infinite;}
.logo-pill{display:inline-flex;align-items:center;gap:14px;padding:0 36px;font-size:12px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--logo-pill-c);white-space:nowrap;transition:color .45s;}
.logo-sep{width:4px;height:4px;border-radius:50%;background:var(--gold);opacity:.5;flex-shrink:0;}

/* ════════════════════════════════════════════
   CASE STUDIES CAROUSEL
════════════════════════════════════════════ */
.cases-section{background:var(--bg-2);transition:background .45s;}
.cases-carousel{display:flex;gap:20px;transition:transform .6s cubic-bezier(.22,1,.36,1);}
.case-card{flex:0 0 380px;background:var(--case-bg);border:1px solid var(--bdr-soft);border-radius:var(--r-xl);padding:44px 36px;cursor:pointer;position:relative;overflow:hidden;transition:all .45s,background .45s,border-color .45s;display:flex;flex-direction:column;}
.case-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,var(--gold),transparent);border-radius:var(--r-xl) 0 0 var(--r-xl);transform:scaleY(0);transform-origin:top;transition:transform .45s;}
.case-card:hover{transform:translateY(-6px) scale(1.01);border-color:rgba(200,168,75,.35);box-shadow:0 32px 80px rgba(0,0,0,.15);}
.case-card:hover::before{transform:scaleY(1);}
.case-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:18px;}
.case-city{font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);font-weight:700;display:block;margin-bottom:4px;}
.case-addr{font-size:11px;color:var(--txt-3);}
.sold-pill{background:rgba(200,168,75,.12);border:1px solid rgba(200,168,75,.35);color:var(--gold);font-size:9px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:5px 12px;border-radius:var(--r-full);}
.case-type{display:inline-block;margin-bottom:14px;font-size:10px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--txt-3);background:var(--why-icon-bg);padding:5px 12px;border-radius:var(--r-full);}
.case-card h3{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:700;line-height:1.25;margin-bottom:18px;color:var(--txt);}
.case-lbl{font-size:9px;letter-spacing:2px;text-transform:uppercase;margin-bottom:6px;display:block;}
.case-lbl.prob{color:var(--txt-3);}
.case-lbl.soln{color:var(--gold);}
.case-txt{font-size:13px;line-height:1.7;margin-bottom:16px;}
.case-txt.prob{color:var(--txt-3);}
.case-txt.soln{color:var(--txt-2);}
.case-footer{margin-top:auto;padding-top:18px;border-top:1px solid var(--bdr-soft);display:flex;align-items:flex-start;gap:10px;}
.case-footer-icon{color:var(--gold);font-size:11px;margin-top:3px;flex-shrink:0;}
.case-footer p{font-size:12px;color:var(--txt-2);font-style:italic;line-height:1.55;}

/* ════════════════════════════════════════════
   FINAL CTA
════════════════════════════════════════════ */
.cta-section{padding:130px 64px;background:var(--bg);position:relative;overflow:hidden;text-align:center;transition:background .45s;}
.cta-section::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 100% at 50% 60%,var(--cta-overlay),transparent 70%);}
.cta-grid-bg{position:absolute;inset:0;background-image:linear-gradient(rgba(200,168,75,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(200,168,75,.03) 1px,transparent 1px);background-size:80px 80px;mask-image:radial-gradient(ellipse 70% 70% at 50% 50%,black,transparent);}
.cta-inner{position:relative;z-index:1;max-width:720px;margin:0 auto;}
.cta-eyebrow{display:flex;align-items:center;justify-content:center;gap:14px;margin-bottom:24px;}
.cta-eyebrow::before,.cta-eyebrow::after{content:'';display:block;width:48px;height:1px;background:linear-gradient(90deg,transparent,var(--gold));}
.cta-eyebrow::after{background:linear-gradient(90deg,var(--gold),transparent);}
.cta-eyebrow span{font-size:10px;letter-spacing:3.5px;text-transform:uppercase;color:var(--gold);font-weight:700;}
.cta-section h2{font-family:'Cormorant Garamond',serif;font-size:clamp(44px,6vw,74px);font-weight:700;line-height:1.1;margin-bottom:22px;color:var(--txt);}
.cta-section h2 em{font-style:italic;color:var(--gold);}
.cta-section > .cta-inner > p{font-size:17px;color:var(--txt-3);line-height:1.8;margin-bottom:52px;}
.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}

/* ════════════════════════════════════════════
   FOOTER
════════════════════════════════════════════ */
footer{background:var(--footer-bg);border-top:1px solid var(--bdr);padding:72px 64px 44px;transition:background .45s,border-color .45s;}
.footer-inner{max-width:1240px;margin:0 auto;}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;margin-bottom:56px;}
.footer-brand p{font-size:14px;color:#7A8FA8;line-height:1.8;margin-top:20px;max-width:260px;}
.footer-col h4{font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:20px;font-weight:700;}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:11px;}
.footer-col ul li{font-size:14px;color:#7A8FA8;cursor:pointer;transition:all .2s;}
.footer-col ul li:hover{color:#fff;padding-left:4px;}

/* footer social */
.footer-social{display:flex;gap:10px;margin-top:24px;}
.fsoc{width:38px;height:38px;border-radius:var(--r-sm);background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;color:rgba(255,255,255,.6);text-decoration:none;}
.fsoc:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,0,0,.3);}
.fsoc-fb:hover{background:#1877F2;border-color:#1877F2;color:#fff;}
.fsoc-x:hover{background:#0F1419;border-color:#333;color:#fff;}
.fsoc-ig:hover{background:linear-gradient(135deg,#f09433,#dc2743,#bc1888);border-color:#dc2743;color:#fff;}
.fsoc-wa:hover{background:#25D366;border-color:#25D366;color:#fff;}
.footer-bottom{border-top:1px solid rgba(255,255,255,.07);padding-top:28px;display:flex;justify-content:space-between;align-items:center;}
.footer-bottom p{font-size:12px;color:#7A8FA8;}
.footer-bottom span{color:var(--gold);}

/* ════════════════════════════════════════════
   HAMBURGER MENU
════════════════════════════════════════════ */
.hamburger{
  display:none;
  flex-direction:column;justify-content:center;
  gap:5px;width:40px;height:40px;
  background:none;border:1px solid var(--bdr);
  border-radius:var(--r-sm);cursor:pointer;
  padding:8px;transition:border-color .3s;
  flex-shrink:0;
}
.hamburger:hover{border-color:var(--gold);}
.hamburger span{
  display:block;width:100%;height:2px;
  background:var(--txt);border-radius:2px;
  transition:all .35s cubic-bezier(.22,1,.36,1);
  transform-origin:center;
}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0);}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* mobile nav drawer */
.mobile-nav{
  position:fixed;inset:0;z-index:190;
  background:var(--bg-nav);
  backdrop-filter:blur(24px);
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  gap:0;
  opacity:0;pointer-events:none;
  transition:opacity .4s cubic-bezier(.22,1,.36,1);
}
.mobile-nav.open{opacity:1;pointer-events:all;}
.mobile-nav ul{list-style:none;display:flex;flex-direction:column;align-items:center;gap:8px;width:100%;}
.mobile-nav ul li a{
  display:block;padding:16px 40px;
  font-size:clamp(22px,6vw,32px);
  font-family:'Cormorant Garamond',serif;font-weight:700;
  color:var(--txt);text-decoration:none;letter-spacing:1px;
  transition:color .2s;text-align:center;
}
.mobile-nav ul li a:hover{color:var(--gold);}
.mobile-nav-cta{
  margin-top:32px;
  background:var(--gold);color:#06101C;
  padding:16px 48px;font-size:15px;font-weight:700;
  letter-spacing:2px;text-transform:uppercase;
  border:none;cursor:pointer;border-radius:var(--r-full);
  font-family:'DM Sans',sans-serif;
}
.mobile-nav-social{
  display:flex;gap:16px;margin-top:32px;
}
.mobile-nav-social a{
  width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);
  display:flex;align-items:center;justify-content:center;
  color:var(--txt-2);transition:all .3s;
}
.mobile-nav-social a:hover{background:var(--gold);border-color:var(--gold);color:#06101C;}

/* ════════════════════════════════════════════
   RESPONSIVE — TABLET (≤1100px)
════════════════════════════════════════════ */
@media(max-width:1100px){
  /* nav */
  nav{padding:0 20px;height:66px;}
  .nav-links{display:none;}
  .hamburger{display:flex;}
  .social-sidebar{display:none;}

  /* hero */
  .hero{grid-template-columns:1fr;min-height:auto;}
  .hero-left{padding:90px 24px 48px;}
  .hero h1{font-size:clamp(44px,8vw,64px);}
  .hero h1 .big{font-size:clamp(56px,10vw,80px);}
  .hero-sub{font-size:16px;max-width:100%;}
  .hero-right{
    padding:48px 24px 56px;
    border-left:none;
    border-top:1px solid var(--form-bdr);
  }

  /* stats */
  .stats-strip{grid-template-columns:repeat(2,1fr);}
  .stat-cell:nth-child(2){border-right:none;}
  .stat-cell:nth-child(3){border-top:1px solid var(--bdr);}
  .stat-cell:nth-child(4){border-top:1px solid var(--bdr);border-right:none;}
  .stat-num{font-size:52px;}
  .stat-cell{padding:40px 24px;}

  /* sections */
  .section{padding:80px 24px;}

  /* why */
  .why-grid{grid-template-columns:1fr 1fr;gap:14px;}
  .why-card{padding:36px 28px;}

  /* how */
  .how-wrap{grid-template-columns:1fr;gap:48px;}
  .how-panel{border-radius:var(--r-lg);}
  .process-visual{grid-template-columns:repeat(3,1fr);}
  .process-visual::before{display:block;}

  /* testimonials */
  .testimonials-section{padding:80px 0;}
  .testimonials-header{padding:0 24px;}
  .carousel-track{padding:0 24px;}
  .testimonial-card{flex:0 0 340px;}
  .carousel-controls{padding:0 24px;}

  /* about */
  .about-grid{grid-template-columns:1fr;gap:48px;}
  .about-imgs{grid-template-rows:200px 200px;}

  /* cases */
  .case-card{flex:0 0 320px;}

  /* cta */
  .cta-section{padding:90px 24px;}

  /* footer */
  footer{padding:56px 24px 36px;}
  .footer-top{grid-template-columns:1fr 1fr;gap:36px;}
  .footer-bottom{flex-direction:column;gap:10px;text-align:center;}

  /* nav right layout */
  .nav-right{gap:10px;}
  .theme-toggle{padding:6px 10px;}
  #toggleLabel{display:none;}
}

/* ════════════════════════════════════════════
   RESPONSIVE — MOBILE (≤640px)
════════════════════════════════════════════ */
@media(max-width:640px){
  /* nav */
  nav{padding:0 16px;height:62px;}
  .nav-cta{display:none;}
  .theme-toggle{padding:6px 8px;}

  /* hero */
  .hero-left{padding:80px 16px 40px;}
  .hero h1{font-size:clamp(38px,10vw,54px);}
  .hero h1 .big{font-size:clamp(48px,12vw,68px);}
  .hero-sub{font-size:15px;}
  .hero-badges{gap:8px;}
  .badge{padding:7px 14px;font-size:11px;}
  .hero-actions{flex-direction:column;gap:10px;}
  .btn-gold,.btn-ghost{width:100%;text-align:center;padding:16px 24px;}
  .hero-right{padding:40px 16px 52px;}

  /* stats */
  .stats-strip{grid-template-columns:1fr 1fr;}
  .stat-num{font-size:44px;}
  .stat-cell{padding:32px 16px;}
  .stat-label{font-size:10px;letter-spacing:1.5px;}

  /* logo row */
  .logo-row{padding:28px 0;}

  /* sections */
  .section{padding:64px 16px;}
  .section-h2{font-size:clamp(30px,8vw,42px);margin-bottom:48px;}

  /* why */
  .why-grid{grid-template-columns:1fr;gap:12px;}
  .why-card{padding:32px 24px;}
  .why-icon{width:48px;height:48px;font-size:20px;margin-bottom:20px;}

  /* process visual */
  .process-visual{grid-template-columns:1fr;gap:32px;}
  .process-visual::before{display:none;}
  .pv-item{padding:0;}

  /* how steps */
  .step-item{grid-template-columns:52px 1fr;padding:28px 0;}
  .step-num{font-size:38px;}
  .step-item:hover{padding:28px 12px;margin:0 -12px;}
  .how-panel{padding:36px 24px;border-radius:var(--r-lg);}
  .panel-stats{flex-direction:row;}
  .p-stat-num{font-size:30px;}

  /* testimonials */
  .testimonials-section{padding:64px 0;}
  .testimonials-header{padding:0 16px;}
  .carousel-track{padding:0 16px;gap:16px;}
  .testimonial-card{flex:0 0 calc(100vw - 48px);padding:32px 28px;}
  .t-quote{font-size:17px;}
  .carousel-controls{padding:0 16px;margin-top:32px;}

  /* about */
  .about-imgs{
    display:grid;
    grid-template-columns:1fr 1fr;
    grid-template-rows:160px 160px;
    height:auto;
  }
  .img-ph.tall{grid-row:span 2;border-radius:var(--r-lg);}
  .img-ph{border-radius:var(--r-md);}

  /* cases */
  .case-card{flex:0 0 calc(100vw - 48px);padding:32px 24px;border-radius:var(--r-lg);}
  #cases .section-inner > div:first-of-type{flex-direction:column;align-items:flex-start;gap:16px;}

  /* cta */
  .cta-section{padding:72px 16px;}
  .cta-actions{flex-direction:column;align-items:center;}
  .cta-actions .btn-gold,.cta-actions .btn-ghost{width:100%;max-width:320px;text-align:center;}

  /* footer */
  footer{padding:48px 16px 32px;}
  .footer-top{grid-template-columns:1fr;gap:32px;}
  .footer-bottom{flex-direction:column;gap:10px;text-align:center;}
  .footer-brand p{max-width:100%;}

  /* step hover off on mobile */
  .step-item:hover{padding:28px 0;margin:0;background:none;border-color:transparent;}
}

/* ── WordPress form feedback ── */
.form-msg{padding:12px 16px;border-radius:var(--r-sm);font-size:13px;font-weight:500;margin-bottom:12px;display:none;}
.form-msg:not(:empty){display:block;}
.form-msg.success{background:rgba(34,197,94,.15);border:1px solid rgba(34,197,94,.4);color:#22C55E;}
.form-msg.error{background:rgba(239,68,68,.12);border:1px solid rgba(239,68,68,.35);color:#EF4444;}
/* WP admin bar compensation */
body.admin-bar nav{top:32px;}
@media screen and (max-width:782px){body.admin-bar nav{top:46px;}}
/* ── About image pair ── */
.img-ph-pair{display:flex;flex-direction:column;gap:14px;}
.img-ph[style*="background-image"]{background-color:var(--img-bg);}
/* ── footer link resets ── */
.footer-col ul li a{color:#7A8FA8;text-decoration:none;transition:color .2s;}
.footer-col ul li a:hover{color:#fff;}
/* ── form-msg ── */
.form-msg{padding:12px 16px;border-radius:var(--r-sm);font-size:13px;font-weight:500;margin-bottom:12px;display:none;}
.form-msg:not(:empty){display:block;}
.form-msg.success{background:rgba(34,197,94,.15);border:1px solid rgba(34,197,94,.4);color:#22C55E;}
.form-msg.error{background:rgba(239,68,68,.12);border:1px solid rgba(239,68,68,.35);color:#EF4444;}
/* WP admin bar */
body.admin-bar nav{top:32px;}
@media screen and (max-width:782px){body.admin-bar nav{top:46px;}}

/* ══════════════════════════════════════
   LOGO SYSTEM — dark/light switching
══════════════════════════════════════ */
.bmpf-logo-link{display:flex;align-items:center;text-decoration:none;}
.logo-img{height:52px;width:auto;display:block;transition:opacity .3s;}
.logo-img-light{display:none;}
.logo-img-dark{display:block;}
[data-theme="light"] .logo-img-dark{display:none;}
[data-theme="light"] .logo-img-light{display:block;}

/* ══════════════════════════════════════
   FAST in yellow — inline logo fallback
══════════════════════════════════════ */
.logo-fast{color:var(--gold)!important;font-style:italic;}

/* ══════════════════════════════════════
   CTA MINI BUTTON (after each section)
══════════════════════════════════════ */
.section-cta-wrap{text-align:center;margin-top:52px;}
.btn-gold-sm{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--gold);color:#06101C;
  padding:13px 36px;font-size:12px;font-weight:700;
  letter-spacing:2px;text-transform:uppercase;
  border:none;cursor:pointer;border-radius:var(--r-full);
  font-family:'DM Sans',sans-serif;text-decoration:none;
  transition:all .35s;position:relative;overflow:hidden;
}
.btn-gold-sm::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transform:translateX(-100%);transition:transform .5s;}
.btn-gold-sm:hover::before{transform:translateX(100%);}
.btn-gold-sm:hover{background:var(--gold-lt);transform:translateY(-2px);box-shadow:0 10px 32px rgba(200,168,75,.4);}

/* ══════════════════════════════════════
   EVERY PROPERTY — high contrast section
══════════════════════════════════════ */
/* Dark mode: gold gradient bg */
.cta-section{background:linear-gradient(135deg,var(--blue-deep) 0%,#0A1A35 100%);}
/* Light mode: bright white with strong blue border top */
[data-theme="light"] .cta-section{
  background:linear-gradient(135deg,#EEF3FB 0%,#FFFFFF 100%);
  border-top:4px solid var(--gold);
}
[data-theme="light"] .cta-section h2{color:var(--blue-deep)!important;}
[data-theme="light"] .cta-section h2 em{color:var(--gold)!important;}
[data-theme="light"] .cta-section > .cta-inner > p{color:#3A5070!important;}
[data-theme="light"] .cta-section::before{background:radial-gradient(ellipse 70% 80% at 50% 50%,rgba(26,60,110,0.07),transparent 70%);}
[data-theme="light"] .cta-eyebrow span{color:var(--gold);}
[data-theme="light"] .cta-eyebrow::before,[data-theme="light"] .cta-eyebrow::after{background:linear-gradient(90deg,transparent,var(--gold));}

/* ══════════════════════════════════════
   STATES display (full name on top, city below)
══════════════════════════════════════ */
.logo-pill .state-name{display:block;font-size:13px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;}
.logo-pill .city-name{display:block;font-size:10px;letter-spacing:1px;opacity:.7;margin-top:2px;}
.logo-pill{flex-direction:column;justify-content:center;padding:4px 36px;line-height:1.2;}

/* ══════════════════════════════════════
   NUMBER ANIMATION
══════════════════════════════════════ */
.stat-num.counting{
  background:linear-gradient(90deg,var(--gold),var(--gold-lt),var(--gold));
  background-size:200% auto;
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  animation:shimmer 2s linear infinite;
}
@keyframes shimmer{0%{background-position:0% 50%}100%{background-position:200% 50%}}

/* ══════════════════════════════════════
   EMAIL in nav / header area
══════════════════════════════════════ */
.nav-email{font-size:11px;color:var(--gold);letter-spacing:.5px;display:none;}
@media(min-width:1200px){.nav-email{display:block;}}

/* ── Stats strip: 3 columns (commissions removed) ── */
.stats-strip { grid-template-columns: repeat(3,1fr) !important; }
.stats-strip .stat-cell:nth-child(3){ border-right: none; }
.stats-strip .stat-cell:nth-child(4){ display: none; }

/* ── Logo 'Fast' gold italic — force override ── */
.logo-bot,
.logo-fast,
[data-bmpf="bmpf_logo_sub"] {
  color: #C8A84B !important;
  font-style: italic !important;
  font-family: 'Cormorant Garamond', serif !important;
}

/* ── Stat num zero guard — hide 0 values ── */
.stat-num:empty { visibility: hidden; }

/* ══════════════════════════════════════
   FIX: Hero "Fast" — yellow/gold always
══════════════════════════════════════ */
.hero h1 .hero-fast,
.hero h1 .big.hero-fast {
  color: #C8A84B !important;
  -webkit-text-fill-color: #C8A84B !important;
}

/* ══════════════════════════════════════
   FIX: Nav phone number
══════════════════════════════════════ */
.nav-phone {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 13px;
  font-weight: 600;
  color: var(--gold);
  text-decoration: none;
  letter-spacing: 0.3px;
  white-space: nowrap;
  transition: opacity .2s;
  padding: 6px 0;
}
.nav-phone:hover { opacity: 0.75; }
.nav-phone svg { flex-shrink: 0; }
/* Hide on small screens where space is tight */
@media (max-width: 1200px) { .nav-phone { display: none; } }

/* ══════════════════════════════════════
   FIX: Story/Case cards contrast
   Dark mode  → white card bg
   Light mode → blue card bg
══════════════════════════════════════ */
/* Dark mode — cards become bright white for contrast */
[data-theme="dark"] .case-card {
  background: #FFFFFF !important;
  border-color: rgba(255,255,255,0.15) !important;
  color: #0D1B2A !important;
}
[data-theme="dark"] .case-card h3           { color: #0D1B2A !important; }
[data-theme="dark"] .case-card .case-city   { color: #C8A84B !important; }
[data-theme="dark"] .case-card .case-addr   { color: #6B80A0 !important; }
[data-theme="dark"] .case-card .case-lbl.prob { color: #6B80A0 !important; }
[data-theme="dark"] .case-card .case-lbl.soln { color: #1A3C6E !important; }
[data-theme="dark"] .case-card .case-txt.prob { color: #3A5070 !important; }
[data-theme="dark"] .case-card .case-txt.soln { color: #0D1B2A !important; }
[data-theme="dark"] .case-card .case-type  { color: #6B80A0 !important; background: rgba(26,60,110,0.1) !important; }
[data-theme="dark"] .case-card .sold-pill  { background: rgba(200,168,75,0.15) !important; border-color: rgba(200,168,75,0.5) !important; color: #C8A84B !important; }
[data-theme="dark"] .case-card .case-footer { border-top-color: rgba(0,0,0,0.1) !important; }
[data-theme="dark"] .case-card .case-footer p { color: #3A5070 !important; }
[data-theme="dark"] .case-card .case-footer-icon { color: #C8A84B !important; }
[data-theme="dark"] .case-card::before { background: linear-gradient(180deg, #C8A84B, rgba(200,168,75,0.3)) !important; }
[data-theme="dark"] .case-card:hover {
  border-color: #C8A84B !important;
  box-shadow: 0 32px 80px rgba(0,0,0,0.3) !important;
  transform: translateY(-6px) scale(1.01) !important;
}

/* Light mode — cards become deep navy blue for contrast */
[data-theme="light"] .case-card {
  background: #1A3C6E !important;
  border-color: rgba(200,168,75,0.25) !important;
  color: #FFFFFF !important;
}
[data-theme="light"] .case-card h3           { color: #FFFFFF !important; }
[data-theme="light"] .case-card .case-city   { color: #C8A84B !important; }
[data-theme="light"] .case-card .case-addr   { color: rgba(255,255,255,0.6) !important; }
[data-theme="light"] .case-card .case-lbl.prob { color: rgba(255,255,255,0.55) !important; }
[data-theme="light"] .case-card .case-lbl.soln { color: #C8A84B !important; }
[data-theme="light"] .case-card .case-txt.prob { color: rgba(255,255,255,0.7) !important; }
[data-theme="light"] .case-card .case-txt.soln { color: rgba(255,255,255,0.85) !important; }
[data-theme="light"] .case-card .case-type  { color: rgba(255,255,255,0.6) !important; background: rgba(255,255,255,0.1) !important; }
[data-theme="light"] .case-card .sold-pill  { background: rgba(200,168,75,0.2) !important; border-color: rgba(200,168,75,0.5) !important; color: #C8A84B !important; }
[data-theme="light"] .case-card .case-footer { border-top-color: rgba(255,255,255,0.12) !important; }
[data-theme="light"] .case-card .case-footer p { color: rgba(255,255,255,0.8) !important; }
[data-theme="light"] .case-card .case-footer-icon { color: #C8A84B !important; }
[data-theme="light"] .case-card:hover {
  background: #234E8C !important;
  border-color: #C8A84B !important;
  box-shadow: 0 32px 80px rgba(26,60,110,0.3) !important;
}
/* Cases section background — light mode gets light bg so blue cards pop */
[data-theme="light"] .cases-section { background: #F4F6FA !important; }
[data-theme="dark"]  .cases-section { background: #0C1A2D !important; }

/* ══════════════════════════════════════
   FIX: How panel — remove $0 on old installs
   Force correct 3rd stat to show 40+
══════════════════════════════════════ */
.panel-stats .p-stat:nth-child(3) .p-stat-num::after { content: '' !important; }

/* ══════════════════════════════════════
   FIX: Stat numbers animation start visible
   (prevent flash of 0 before JS runs)
══════════════════════════════════════ */
.stat-num { min-width: 60px; display: inline-block; }

/* ══════════════════════════════════════
   STATS — centered, proper sizing
══════════════════════════════════════ */
.stats-strip {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  text-align: center !important;
}
.stat-cell {
  padding: 60px 24px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
}
.stat-num {
  display: block !important;
  font-family: 'Cormorant Garamond', serif !important;
  font-size: 72px !important;
  font-weight: 700 !important;
  color: var(--gold) !important;
  line-height: 1 !important;
  text-align: center !important;
  width: 100% !important;
  min-height: 80px !important;
}
.stat-label {
  display: block !important;
  text-align: center !important;
  margin-top: 12px !important;
  font-size: 11px !important;
  letter-spacing: 2.5px !important;
  text-transform: uppercase !important;
  color: var(--gray-1) !important;
}
/* Shimmer while counting */
.stat-num.counting {
  background: linear-gradient(90deg, var(--gold) 0%, #E8D080 50%, var(--gold) 100%) !important;
  background-size: 200% auto !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
  animation: statShimmer 1.5s linear infinite !important;
}
@keyframes statShimmer {
  0%   { background-position: 0% center; }
  100% { background-position: 200% center; }
}
/* Mobile */
@media (max-width: 640px) {
  .stats-strip { grid-template-columns: 1fr !important; }
  .stat-cell { border-right: none !important; border-bottom: 1px solid var(--bdr) !important; padding: 40px 24px !important; }
  .stat-num { font-size: 56px !important; }
}

/* ══════════════════════════════════════
   FIX: Remove black gap above mini CTA buttons
══════════════════════════════════════ */
.section-cta-wrap {
  margin: 0 !important;
  padding: 0 0 52px 0 !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  line-height: 1 !important;
}

/* ══════════════════════════════════════
   FIX: "Why Choose Us" cards — WHITE in dark mode
══════════════════════════════════════ */
[data-theme="dark"] .why-card {
  background: #FFFFFF !important;
  border-color: rgba(255,255,255,0.12) !important;
  box-shadow: 0 4px 24px rgba(0,0,0,0.25) !important;
}
[data-theme="dark"] .why-card h3 {
  color: #0D1B2A !important;
}
[data-theme="dark"] .why-card p {
  color: #4A6080 !important;
}
[data-theme="dark"] .why-card .why-icon {
  background: rgba(26,60,110,0.1) !important;
  border-color: rgba(26,60,110,0.2) !important;
}
[data-theme="dark"] .why-card:hover {
  background: #F7F9FF !important;
  border-color: rgba(200,168,75,0.5) !important;
  box-shadow: 0 20px 60px rgba(0,0,0,0.35) !important;
  transform: translateY(-6px) !important;
}
[data-theme="dark"] .why-card:hover h3 { color: #0D1B2A !important; }
[data-theme="dark"] .why-card:hover p  { color: #3A5070 !important; }
/* Light mode — keep cards as-is (already light) */
[data-theme="light"] .why-card {
  background: #FFFFFF !important;
  border-color: rgba(26,60,110,0.1) !important;
}
[data-theme="light"] .why-card h3 { color: #0D1B2A !important; }
[data-theme="light"] .why-card p  { color: #6B80A0 !important; }

/* ══════════════════════════════════════
   FIX: Testimonial cards — WHITE in dark mode
══════════════════════════════════════ */
[data-theme="dark"] .testimonial-card {
  background: #FFFFFF !important;
  border-color: rgba(255,255,255,0.15) !important;
  box-shadow: 0 4px 24px rgba(0,0,0,0.2) !important;
}
[data-theme="dark"] .testimonial-card .t-quote {
  color: #1A3C6E !important;
  font-style: italic !important;
}
[data-theme="dark"] .testimonial-card .t-name {
  color: #0D1B2A !important;
}
[data-theme="dark"] .testimonial-card .t-loc {
  color: #C8A84B !important;
}
[data-theme="dark"] .testimonial-card .t-divider {
  background: rgba(0,0,0,0.1) !important;
}
[data-theme="dark"] .testimonial-card .t-star {
  color: #C8A84B !important;
}
[data-theme="dark"] .testimonial-card:hover {
  background: #F7F9FF !important;
  border-color: rgba(200,168,75,0.4) !important;
  box-shadow: 0 20px 60px rgba(0,0,0,0.3) !important;
  transform: translateY(-4px) !important;
}
[data-theme="dark"] .t-avatar {
  background: linear-gradient(135deg,#1A3C6E,#2452A0) !important;
  border-color: #C8A84B !important;
  color: #C8A84B !important;
}
/* Testimonial section background — dark blue so white cards pop */
[data-theme="dark"] .testimonials-section {
  background: #06101C !important;
}
[data-theme="light"] .testimonials-section {
  background: #1A3C6E !important;
}
[data-theme="light"] .testimonial-card {
  background: #FFFFFF !important;
}
[data-theme="light"] .testimonial-card .t-quote { color: #1A3C6E !important; }
[data-theme="light"] .testimonial-card .t-name  { color: #0D1B2A !important; }

/* ══════════════════════════════════════
   FIX: Process steps — add arrows between steps
══════════════════════════════════════ */
.process-visual {
  position: relative !important;
}
/* Arrow between step icons */
.pv-item {
  position: relative !important;
}
.pv-item:not(:last-child)::after {
  content: '→';
  position: absolute;
  top: 30px; /* align with icon center */
  right: -18px;
  font-size: 22px;
  color: var(--gold);
  opacity: 0.8;
  font-weight: 300;
  z-index: 2;
  line-height: 1;
}
/* Hide arrows on mobile / single column */
@media (max-width: 640px) {
  .pv-item:not(:last-child)::after {
    content: '↓';
    top: auto;
    bottom: -28px;
    right: 50%;
    transform: translateX(50%);
    font-size: 20px;
  }
}

/* Steps LIST items — white cards in dark mode */
[data-theme="dark"] .step-item {
  border-bottom-color: rgba(255,255,255,0.1) !important;
}
[data-theme="dark"] .step-item:first-child {
  border-top-color: rgba(255,255,255,0.1) !important;
}
[data-theme="dark"] .step-item:hover {
  background: rgba(255,255,255,0.05) !important;
}
[data-theme="dark"] .step-content h3 { color: #FFFFFF !important; }
[data-theme="dark"] .step-content p  { color: rgba(255,255,255,0.65) !important; }

/* How panel — white in dark mode */
[data-theme="dark"] .how-panel {
  background: #FFFFFF !important;
  border-color: rgba(200,168,75,0.25) !important;
}
[data-theme="dark"] .how-panel p {
  color: #3A5070 !important;
}
[data-theme="dark"] .how-panel p strong {
  color: #0D1B2A !important;
}
[data-theme="dark"] .how-panel-badge {
  background: var(--gold) !important;
  color: #06101C !important;
}
[data-theme="dark"] .panel-stats {
  border-color: rgba(0,0,0,0.1) !important;
}
[data-theme="dark"] .p-stat {
  border-right-color: rgba(0,0,0,0.08) !important;
}
[data-theme="dark"] .p-stat-num   { color: #C8A84B !important; }
[data-theme="dark"] .p-stat-lbl   { color: #6B80A0 !important; }
[data-theme="dark"] .divider {
  background: rgba(0,0,0,0.1) !important;
}

/* ══════════════════════════════════════
   Why section bg — dark theme deep so white cards pop
══════════════════════════════════════ */
[data-theme="dark"] .why-section {
  background: #06101C !important;
}
[data-theme="light"] .why-section {
  background: #F4F6FA !important;
}

/* ══════════════════════════════════════
   REAL BMPF LOGO — dark/light switching
══════════════════════════════════════ */
.bmpf-logo-link {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  line-height: 1;
}
.bmpf-logo {
  height: 46px;
  width: auto;
  display: block;
}
/* Dark mode: show white logo, hide blue */
[data-theme="dark"]  .bmpf-logo-dark  { display: block; }
[data-theme="dark"]  .bmpf-logo-light { display: none;  }
/* Light mode: show blue logo, hide white */
[data-theme="light"] .bmpf-logo-light { display: block; }
[data-theme="light"] .bmpf-logo-dark  { display: none;  }
/* Default (before JS sets theme): show dark logo */
.bmpf-logo-dark  { display: block; }
.bmpf-logo-light { display: none;  }

/* Nav height — give logo room */
nav { height: 72px !important; }
nav.scrolled { height: 60px !important; }
nav.scrolled .bmpf-logo { height: 38px !important; }

/* ══ Logo sizing override v1.4 ══ */
.bmpf-logo {
  height: 52px !important;
  width: auto !important;
  max-width: 340px !important;
  display: block !important;
}
nav.scrolled .bmpf-logo {
  height: 42px !important;
}
@media (max-width: 768px) {
  .bmpf-logo { height: 38px !important; max-width: 240px !important; }
}
@media (max-width: 400px) {
  .bmpf-logo { height: 32px !important; max-width: 190px !important; }
}

/* ══ Logo final fix v1.5 ══ */
.bmpf-logo-link { display: inline-flex; align-items: center; text-decoration: none; }
.bmpf-logo {
  height: 50px !important;
  width: auto !important;
  max-width: 360px !important;
  display: block !important;
  object-fit: contain !important;
  object-position: left center !important;
}
/* Dark/light switching */
[data-theme="dark"]  .bmpf-logo-dark  { display: block !important; }
[data-theme="dark"]  .bmpf-logo-light { display: none  !important; }
[data-theme="light"] .bmpf-logo-light { display: block !important; }
[data-theme="light"] .bmpf-logo-dark  { display: none  !important; }
/* Default before JS: show dark logo */
.bmpf-logo-dark  { display: block !important; }
.bmpf-logo-light { display: none  !important; }
/* Scrolled nav */
nav.scrolled .bmpf-logo { height: 40px !important; }
/* Mobile */
@media (max-width: 768px) {
  .bmpf-logo { height: 36px !important; max-width: 220px !important; }
}
@media (max-width: 400px) {
  .bmpf-logo { height: 30px !important; max-width: 180px !important; }
}

/* ══ Real PNG Logo — final v1.6 ══ */
.bmpf-logo-link {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  line-height: 1;
}
.bmpf-logo {
  height: 56px !important;
  width: auto !important;
  max-width: 320px !important;
  display: block !important;
  object-fit: contain !important;
}

/* Dark mode: show white logo */
[data-theme="dark"]  .bmpf-logo-dark  { display: block !important; }
[data-theme="dark"]  .bmpf-logo-light { display: none  !important; }

/* Light mode: show blue logo */
[data-theme="light"] .bmpf-logo-light { display: block !important; }
[data-theme="light"] .bmpf-logo-dark  { display: none  !important; }

/* Default before JS runs — show white (dark theme is default) */
.bmpf-logo-dark  { display: block  !important; }
.bmpf-logo-light { display: none   !important; }

/* Scrolled nav */
nav.scrolled .bmpf-logo { height: 44px !important; }

/* Mobile */
@media (max-width: 768px) {
  .bmpf-logo { height: 40px !important; max-width: 220px !important; }
}
@media (max-width: 400px) {
  .bmpf-logo { height: 32px !important; max-width: 170px !important; }
}

/* Nav height to fit logo */
nav { min-height: 72px !important; height: auto !important; }
.logo-wrap { padding: 8px 0; }

/* ══════════════════════════════════════
   CASE STUDY CARDS WITH REAL PHOTOS
══════════════════════════════════════ */
.case-card {
  flex: 0 0 380px !important;
  display: flex !important;
  flex-direction: column !important;
  padding: 0 !important;
  overflow: hidden !important;
  border-radius: var(--r-xl) !important;
}

/* Photo area */
.case-photo-wrap {
  position: relative;
  flex-shrink: 0;
}
.case-photo {
  width: 100%;
  height: 220px;
  background-size: cover;
  background-position: center;
  background-color: var(--bg-3);
  position: relative;
  transition: transform .5s ease;
}
.case-card:hover .case-photo {
  transform: scale(1.03);
}
.case-photo-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, transparent 40%, rgba(0,0,0,0.5) 100%);
  display: flex;
  align-items: flex-end;
  padding: 14px 16px;
}
.sold-overlay {
  background: var(--gold);
  color: #06101C;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.5px;
  padding: 5px 12px;
  border-radius: var(--r-full);
}
/* Photo navigation dots */
.case-photo-dots {
  display: flex;
  gap: 6px;
  justify-content: center;
  padding: 10px 0 6px;
  background: var(--bg-card);
}
.case-pdot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: rgba(200,168,75,0.3);
  cursor: pointer;
  transition: all .3s;
  border: none;
}
.case-pdot.active {
  background: var(--gold);
  width: 20px;
  border-radius: var(--r-full);
}

/* Card body */
.case-body {
  padding: 28px 28px 32px;
  display: flex;
  flex-direction: column;
  flex: 1;
}

/* Dark mode cards */
[data-theme="dark"] .case-card { background: #FFFFFF !important; }
[data-theme="dark"] .case-body .case-city   { color: #C8A84B !important; }
[data-theme="dark"] .case-body .case-addr   { color: #6B80A0 !important; }
[data-theme="dark"] .case-body h3           { color: #0D1B2A !important; }
[data-theme="dark"] .case-body .case-lbl.prob { color: #6B80A0 !important; }
[data-theme="dark"] .case-body .case-lbl.soln { color: #1A3C6E !important; }
[data-theme="dark"] .case-body .case-txt.prob { color: #3A5070 !important; }
[data-theme="dark"] .case-body .case-txt.soln { color: #1A3C6E !important; }
[data-theme="dark"] .case-body .case-type  {
  color: #6B80A0 !important;
  background: rgba(26,60,110,0.08) !important;
}
[data-theme="dark"] .case-body .case-footer { border-top-color: rgba(0,0,0,0.08) !important; }
[data-theme="dark"] .case-body .case-footer p { color: #4A6080 !important; }
[data-theme="dark"] .case-body .case-footer-icon { color: #C8A84B !important; }
[data-theme="dark"] .case-photo-dots { background: #f5f5f5; }

/* Light mode cards — navy blue */
[data-theme="light"] .case-card { background: #1A3C6E !important; }
[data-theme="light"] .case-body .case-city   { color: #C8A84B !important; }
[data-theme="light"] .case-body .case-addr   { color: rgba(255,255,255,0.6) !important; }
[data-theme="light"] .case-body h3           { color: #FFFFFF !important; }
[data-theme="light"] .case-body .case-lbl.prob { color: rgba(255,255,255,0.55) !important; }
[data-theme="light"] .case-body .case-lbl.soln { color: #C8A84B !important; }
[data-theme="light"] .case-body .case-txt.prob { color: rgba(255,255,255,0.7) !important; }
[data-theme="light"] .case-body .case-txt.soln { color: rgba(255,255,255,0.85) !important; }
[data-theme="light"] .case-body .case-type  {
  color: rgba(255,255,255,0.65) !important;
  background: rgba(255,255,255,0.1) !important;
}
[data-theme="light"] .case-body .case-footer { border-top-color: rgba(255,255,255,0.12) !important; }
[data-theme="light"] .case-body .case-footer p { color: rgba(255,255,255,0.8) !important; }
[data-theme="light"] .case-photo-dots { background: #0D2244; }

/* Mobile */
@media (max-width: 640px) {
  .case-card { flex: 0 0 calc(100vw - 40px) !important; }
  .case-photo { height: 180px; }
}

/* ══ About images — show real photos ══ */
.img-ph[style*="background-image"] {
  background-size: cover !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
}
/* Hide the placeholder icon when a real photo is set */
.img-ph[style*="background-image"] .img-ph-icon {
  display: none !important;
}
/* Overlay gradient so label is readable */
.img-ph[style*="background-image"]::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    transparent 50%,
    rgba(0,0,0,0.55) 100%
  ) !important;
  z-index: 1;
}
.img-ph .img-label {
  z-index: 2;
  position: relative;
}

/* ══════════════════════════════════════
   ABOUT IMAGES — fix heights
   Tall left = full height, right pair = proper size
══════════════════════════════════════ */

/* Desktop: each row 280px → tall left = 280+280+14gap = 574px total */
.about-imgs {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  grid-template-rows: 280px 280px !important;
  gap: 16px !important;
  height: 574px !important;
}

/* Tall image fills both rows completely */
.img-ph.tall {
  grid-row: span 2 !important;
  height: 100% !important;
  border-radius: var(--r-xl) !important;
}

/* Right pair — each takes one row, full height of that row */
.img-ph-pair {
  display: contents !important; /* dissolve the wrapper — children go into grid directly */
}

/* Both right images fill their grid cell */
.img-ph-pair .img-ph {
  height: 100% !important;
  border-radius: var(--r-lg) !important;
}

/* Tablet */
@media (max-width: 1100px) {
  .about-imgs {
    grid-template-rows: 220px 220px !important;
    height: 456px !important;
  }
}

/* Mobile — stack vertically */
@media (max-width: 640px) {
  .about-imgs {
    grid-template-columns: 1fr !important;
    grid-template-rows: 260px 180px 180px !important;
    height: auto !important;
  }
  .img-ph.tall {
    grid-row: span 1 !important;
  }
  .img-ph-pair {
    display: contents !important;
  }
}
