/* =============================================
   BB Partners — Pixel-perfect Figma styles
   ============================================= */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400&family=Inter:wght@400;500;600;700&display=swap');

:root{
  --bg:#FAFAF7;
  --dark:#1A1A1A;
  --white:#fff;
  --card:#fff;
  --beige:#F0EAD6;
  --gold:#C5A572;
  --gold-d:#B08D55;
  --gold-dd:#967340;
  --gold-l:#E6D9B8;
  --border:#EDE9E0;
  --txt:#1A1A1A;
  --txt2:#525252;
  --txt3:#737373;
  --txt4:#A3A3A3;
  --sans:'Inter',sans-serif;
  --serif:'Cormorant Garamond','Georgia',serif;
  --r:8px;
  --rl:12px;
  --tr:.3s ease;
  --mw:1100px;
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:var(--sans);color:var(--txt);background:var(--bg);line-height:1.6;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit;transition:var(--tr)}
button{font-family:inherit;cursor:pointer;border:none;outline:none}

.container{width:100%;max-width:var(--mw);margin:0 auto;padding:0 40px}
.section{padding:80px 0}

/* ---- Typography ---- */
.label-line{
  display:inline-flex;align-items:center;gap:12px;
  font-size:.6875rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;
  color:var(--gold-d);margin-bottom:16px;
}
.label-line::after{content:'';width:40px;height:1px;background:var(--gold-d)}
.label-line--center::before{content:'';width:40px;height:1px;background:var(--gold-d)}
.center-label{display:flex;justify-content:center;margin-bottom:0}

.heading-serif{
  font-family:var(--serif);font-size:2.25rem;font-weight:400;line-height:1.25;
  color:var(--txt);margin-bottom:20px;
}
.heading-center{text-align:center}
.text-body{font-size:.9375rem;color:var(--txt2);line-height:1.75}
.text-center{text-align:center}

/* ---- Buttons ---- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:12px 24px;font-size:.8125rem;font-weight:500;border-radius:4px;
  transition:var(--tr);letter-spacing:.02em;
}
.btn-gold{background:var(--gold);color:var(--white)}
.btn-gold:hover{background:var(--gold-d)}
.btn-outline{background:transparent;color:var(--txt);border:1px solid var(--border)}
.btn-outline:hover{border-color:var(--gold);color:var(--gold-d)}

.link-arrow{
  display:inline-flex;align-items:center;gap:6px;
  font-size:.8125rem;font-weight:500;color:var(--gold-d);
}
.link-arrow:hover{color:var(--gold-dd)}
.link-arrow::after{content:'\2192'}
.link-arrow--sm{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}
.link-arrow--sm svg{stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}

/* ---- Animations ---- */
.fade-in{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.fade-in.visible{opacity:1;transform:translateY(0)}

/* =============================================
   Header
   ============================================= */
.header{
  position:fixed;top:0;left:0;width:100%;z-index:1000;
  padding:14px 0;background:rgba(255,255,255,.97);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--border);transition:var(--tr);
}
.header.scrolled{padding:10px 0;border-bottom-color:var(--border)}
.header-inner{display:flex;align-items:center;max-width:1280px}
.logo{display:flex;align-items:center;flex-shrink:0;margin-right:auto}
.logo-img{height:56px;width:auto}
.nav{display:flex;align-items:center;gap:28px;margin:0 auto}
.nav a{font-size:.8125rem;color:var(--txt2);font-weight:400}
.nav a:hover{color:var(--gold-d)}
.header-right{display:flex;align-items:center;gap:16px;flex-shrink:0;margin-left:auto}
.header-divider{width:1px;height:20px;background:var(--border);flex-shrink:0}
.header-contact{
  display:inline-flex;align-items:center;gap:6px;
  font-size:.8125rem;color:var(--txt2);font-weight:400;
}
.header-contact svg{stroke:var(--gold);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.header-contact:hover{color:var(--gold-d)}

.burger{display:none;flex-direction:column;gap:5px;background:none;padding:4px;margin-left:auto}
.burger span{display:block;width:22px;height:1.5px;background:var(--txt);transition:var(--tr)}

.mobile-nav{
  display:none;position:fixed;top:0;left:0;width:100%;height:100vh;
  background:rgba(250,250,247,.98);z-index:999;
  flex-direction:column;align-items:center;justify-content:center;gap:24px;
}
.mobile-nav.open{display:flex}
.mobile-nav a{font-size:1.125rem;color:var(--txt)}

/* =============================================
   Hero
   ============================================= */
.hero{padding:110px 0 40px;background:var(--bg)}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;max-width:1280px;padding:0 40px}
.hero-label{
  display:inline-flex;align-items:center;gap:10px;
  font-size:.6875rem;letter-spacing:.15em;text-transform:uppercase;
  color:var(--gold-d);margin-bottom:16px;font-weight:500;
}
.hero-label::after{content:'';width:30px;height:1px;background:var(--gold-d)}
.hero h1{font-family:var(--serif);font-size:2.6rem;font-weight:400;line-height:1.18;color:var(--txt);margin-bottom:20px}
.hero-desc{font-size:.875rem;color:var(--txt2);line-height:1.7;margin-bottom:12px}
.hero-desc-sm{font-size:.8rem;color:var(--txt3);line-height:1.7;margin-bottom:28px}
.hero-btns{display:grid;grid-template-columns:1fr 1fr;gap:10px;max-width:420px}
.btn-with-arrow{justify-content:space-between;padding:12px 16px}
.btn-arr{font-size:1.1rem;line-height:1;opacity:.6}
.btn-outline-dark{background:var(--dark);color:var(--white);border:1px solid var(--dark)}
.btn-outline-dark:hover{background:#333;border-color:#333}
.hero-code{font-size:.6875rem;color:var(--txt4);letter-spacing:.08em;margin-top:8px}

.hero-right{display:flex;flex-direction:column;gap:16px;align-items:flex-end}
.hero-img{width:100%;max-width:320px;border-radius:var(--rl)}

/* Hero info cards v2 — matching Figma layout */
.hero-info-v2{display:flex;flex-direction:column;gap:10px;width:100%}
.hi2-big{
  padding:18px 20px;border:1px solid var(--border);border-radius:var(--r);
  background:var(--card);position:relative;
}
.hi2-dot{position:absolute;top:18px;right:20px;width:8px;height:8px;border-radius:50%;background:var(--gold)}
.hi2-label{font-size:.6875rem;text-transform:uppercase;letter-spacing:.08em;color:var(--txt4);display:block;margin-bottom:4px}
.hi2-val{font-size:1.125rem;font-weight:700;color:var(--txt);display:block}
.hi2-sub{font-size:.8rem;color:var(--txt3);display:block;margin-top:2px}
.hi2-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.hi2-card{
  padding:16px 18px;border:1px solid var(--border);border-radius:var(--r);
  background:var(--card);
}
.hi2-card--dark{background:var(--dark);border-color:var(--dark)}
.hi2-card--dark .hi2-label{color:rgba(255,255,255,.5)}
.hi2-card--dark .hi2-val{color:#fff}
.hi2-card--dark .hi2-sub{color:rgba(255,255,255,.45)}

/* =============================================
   Stats bar
   ============================================= */
.stats-bar{padding:32px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.stats-bar-inner{display:flex;align-items:center;justify-content:center;gap:0}
.stat{text-align:center;padding:0 36px}
.stat-num{font-family:var(--serif);font-size:1.15rem;font-weight:400;color:var(--gold-d);font-style:italic;display:block}
.stat-label{font-size:.6875rem;text-transform:uppercase;letter-spacing:.1em;color:var(--txt3);margin-top:2px;display:block}
.stat-divider{width:1px;height:36px;background:var(--border);flex-shrink:0}

/* =============================================
   Map
   ============================================= */
.map-section{padding-top:20px}
.map-wrapper{position:relative;margin-bottom:24px}
.map-container{width:100%;max-width:960px;margin:0 auto}
.map-container svg{width:100%;height:auto;display:block}

/* Region styling */
.map-container .region-path{
  fill:var(--gold-l);stroke:var(--gold);stroke-width:.5;
  cursor:pointer;transition:fill .25s ease,filter .25s ease;
}
.map-container .region-path.industrial{fill:var(--gold-d)}
.map-container .region-path:hover{filter:brightness(1.08) drop-shadow(0 2px 6px rgba(0,0,0,.12))}
.map-container .region-path.industrial:hover{fill:var(--gold)}

/* Labels on map */
.map-container .map-label{pointer-events:none;font-family:var(--sans)}
.map-container .ml-name{font-size:7.5px;font-weight:600;fill:var(--txt2)}
.map-container .ml-val{font-size:9px;font-weight:700;fill:var(--txt)}
.map-container .ml-name-w{fill:#fff}
.map-container .ml-val-w{fill:#fff}

/* City dots */
.map-container .city-dot{fill:var(--gold);pointer-events:none}

/* Tooltip */
.map-tooltip{
  position:absolute;pointer-events:none;z-index:100;
  background:#fff;border:1px solid var(--gold-l);border-radius:10px;
  padding:14px 18px;min-width:200px;
  opacity:0;transform:translateY(6px);
  transition:opacity .2s ease,transform .2s ease;
  box-shadow:0 4px 20px rgba(0,0,0,.08);
}
.map-tooltip.show{opacity:1;transform:translateY(0)}
.tt-name{font-size:.9375rem;font-weight:600;color:var(--txt);margin-bottom:4px}
.tt-count{font-size:.8125rem;color:var(--txt2);margin-bottom:4px;display:flex;align-items:center;gap:6px}
.tt-count svg{width:16px;height:16px;stroke:var(--gold);fill:none;stroke-width:1.8}
.tt-count strong{color:var(--gold-d);font-weight:600}
.tt-badge{
  display:none;align-items:center;gap:5px;
  padding:3px 8px;background:rgba(176,141,85,.1);border:1px solid rgba(176,141,85,.25);
  border-radius:100px;font-size:.6875rem;font-weight:600;color:var(--gold-d);
}
.tt-badge.show{display:inline-flex}
.tt-badge::before{content:'';width:5px;height:5px;background:var(--gold-d);border-radius:50%}

/* Mobile popup */
.map-popup-overlay{
  display:none;position:fixed;top:0;left:0;width:100%;height:100%;
  background:rgba(0,0,0,.4);z-index:2000;align-items:center;justify-content:center;padding:20px;
}
.map-popup-overlay.open{display:flex}
.map-popup{
  background:#fff;border:1px solid var(--gold-l);border-radius:14px;
  padding:24px;max-width:300px;width:100%;text-align:center;position:relative;
  animation:popIn .25s ease;
}
@keyframes popIn{from{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}
.popup-close{
  position:absolute;top:10px;right:10px;width:28px;height:28px;
  background:var(--beige);border-radius:50%;color:var(--txt2);font-size:1rem;
  display:flex;align-items:center;justify-content:center;transition:var(--tr);
}
.popup-close:hover{background:var(--gold-l)}

/* Map note */
.map-note{
  font-size:.8125rem;font-style:italic;color:var(--txt3);line-height:1.7;
  border-left:3px solid var(--border);padding:16px 20px;margin:24px 0;
  background:var(--card);border-radius:0 var(--r) var(--r) 0;
}

/* Region table */
.region-table{
  display:grid;grid-template-columns:repeat(5,1fr);
  border:1px solid var(--border);border-radius:var(--r);overflow:hidden;margin-top:32px;
}
.rt-cell{
  padding:16px 18px;border-right:1px solid var(--border);border-bottom:1px solid var(--border);
  display:flex;flex-direction:column;gap:4px;
}
.rt-cell:nth-child(5n){border-right:none}
.rt-cell:nth-last-child(-n+5){border-bottom:none}
.rt-name{font-size:.8125rem;font-weight:600;color:var(--txt);display:flex;align-items:center;justify-content:space-between}
.rt-dot{width:6px;height:6px;border-radius:50%;background:var(--gold);flex-shrink:0;margin-left:6px}
.rt-num{font-size:.8125rem;color:var(--gold-d);font-weight:500}

/* =============================================
   About
   ============================================= */
.about{border-top:1px solid var(--border)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.about-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.acard{
  background:var(--card);border:1px solid var(--border);border-radius:var(--rl);
  padding:24px 20px;transition:var(--tr);
}
.acard:hover{box-shadow:0 4px 20px rgba(0,0,0,.04);border-color:var(--gold-l)}
.acard-icon{width:36px;height:36px;margin-bottom:14px;display:flex;align-items:center;justify-content:center}
.acard-icon svg{width:24px;height:24px;stroke:var(--gold);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.acard h4{font-family:var(--serif);font-size:1.125rem;font-weight:500;color:var(--txt);margin-bottom:8px;line-height:1.3}
.acard p{font-size:.8125rem;color:var(--txt3);line-height:1.6}

/* =============================================
   Partners
   ============================================= */
.partners{border-top:1px solid var(--border)}
.partners-sub{
  font-family:var(--serif);font-size:1rem;font-weight:500;color:var(--txt);
  margin:32px 0 24px;padding-left:16px;border-left:2px solid var(--gold);
}
.partners-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px;max-width:500px}
.pcard{
  background:var(--card);border:1px solid var(--border);border-radius:var(--rl);
  padding:24px;text-align:center;transition:var(--tr);
}
.pcard:hover{border-color:var(--gold-l)}
.pcard h4{font-size:.9375rem;font-weight:600;color:var(--txt);margin-bottom:6px}
.pcard p{font-size:.6875rem;text-transform:uppercase;letter-spacing:.08em;color:var(--txt3)}

/* =============================================
   Products
   ============================================= */
.products{border-top:1px solid var(--border)}
.products-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.prod-card{
  background:var(--card);border:1px solid var(--border);border-radius:var(--rl);
  overflow:hidden;transition:var(--tr);
}
.prod-card:hover{box-shadow:0 4px 24px rgba(0,0,0,.05)}
.prod-img{width:100%;height:260px;overflow:hidden;background:var(--bg)}
.prod-img img{width:100%;height:100%;object-fit:cover}
.prod-body{padding:24px}
.prod-cat{font-size:.6875rem;text-transform:uppercase;letter-spacing:.12em;color:var(--gold-d);margin-bottom:6px;display:block}
.prod-card h3{font-family:var(--serif);font-size:1.375rem;font-weight:400;color:var(--txt);margin-bottom:10px}
.prod-card p{font-size:.8125rem;color:var(--txt3);line-height:1.65;margin-bottom:16px}

/* =============================================
   Certs
   ============================================= */
.certs{border-top:1px solid var(--border)}
.cert-hero{
  display:flex;gap:28px;align-items:center;
  background:var(--beige);border:1px solid var(--gold-l);border-radius:var(--rl);
  padding:28px;margin-bottom:24px;
}
.cert-hero-img{width:140px;flex-shrink:0;border-radius:var(--r);box-shadow:0 2px 12px rgba(0,0,0,.08)}
.cert-badge{
  display:inline-block;background:var(--gold);color:#fff;
  font-size:.6875rem;text-transform:uppercase;letter-spacing:.08em;
  padding:4px 10px;border-radius:4px;margin-bottom:10px;font-weight:500;
}
.cert-hero-body h3{font-family:var(--serif);font-size:1.25rem;font-weight:500;color:var(--txt);margin-bottom:8px}
.cert-hero-body p{font-size:.875rem;color:var(--txt2);line-height:1.6;margin-bottom:14px}
.cert-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.cert-card{
  background:var(--card);border:1px solid var(--border);border-radius:var(--rl);
  padding:20px;transition:var(--tr);
}
.cert-card:hover{border-color:var(--gold-l)}
.cc-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.cc-top svg{width:20px;height:20px;stroke:var(--txt4);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.cc-top span{font-size:.75rem;color:var(--txt4)}
.cert-card h4{font-size:.9375rem;font-weight:600;color:var(--txt);margin-bottom:6px}
.cert-card p{font-size:.75rem;color:var(--txt3);line-height:1.5;margin-bottom:12px}

/* =============================================
   News
   ============================================= */
.news{border-top:1px solid var(--border)}
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.ncard{
  border:1px solid var(--border);border-radius:var(--rl);padding:24px;
  background:var(--card);transition:var(--tr);display:flex;flex-direction:column;
}
.ncard:hover{border-color:var(--gold-l)}
.ncard-tag{
  display:inline-flex;align-items:center;gap:6px;
  font-size:.6875rem;text-transform:uppercase;letter-spacing:.08em;color:var(--txt3);margin-bottom:12px;
}
.ncard-tag::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--gold)}
.ncard h3{font-family:var(--serif);font-size:1.0625rem;font-weight:500;color:var(--txt);margin-bottom:10px;line-height:1.35}
.ncard p{font-size:.8125rem;color:var(--txt3);line-height:1.6;margin-bottom:16px;flex:1}

/* =============================================
   CTA
   ============================================= */
.cta{padding:80px 0;background:var(--dark);text-align:center}
.cta-form{max-width:620px;margin:0 auto}
.cta-form-inner{
  background:#fff;border-radius:var(--rl);padding:32px 36px;
}
.cta-row{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px}
.cta-form input{
  width:100%;padding:14px 0;background:transparent;border:none;
  border-bottom:1px solid var(--border);color:var(--txt);
  font-family:var(--sans);font-size:.875rem;outline:none;transition:var(--tr);
}
.cta-form input::placeholder{color:var(--txt4);text-transform:uppercase;font-size:.75rem;letter-spacing:.05em}
.cta-form input:focus{border-bottom-color:var(--gold)}
.cta-bottom{display:flex;flex-direction:column;align-items:center;gap:16px;margin-top:24px}
.cta-disclaimer{font-size:.6875rem;color:var(--txt3);max-width:100%;text-align:center;line-height:1.4}
.btn-cta-submit{text-transform:uppercase;letter-spacing:.1em;font-size:.75rem;padding:14px 28px}

/* =============================================
   Contacts
   ============================================= */
.contacts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:40px}
.contact-card{
  background:var(--card);border:1px solid var(--border);border-radius:var(--rl);
  padding:32px 24px;text-align:center;transition:var(--tr);
}
.contact-card:hover{border-color:var(--gold-l)}
.cc-icon{width:40px;height:40px;margin:0 auto 16px;display:flex;align-items:center;justify-content:center}
.cc-icon svg{width:24px;height:24px;stroke:var(--gold);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.cc-label{font-size:.6875rem;text-transform:uppercase;letter-spacing:.1em;color:var(--gold-d);margin-bottom:8px;display:block}
.contact-card h4{font-family:var(--serif);font-size:1.125rem;font-weight:500;color:var(--txt);margin-bottom:6px}
.contact-card p{font-size:.8125rem;color:var(--txt3);line-height:1.6}

/* =============================================
   Footer
   ============================================= */
.footer{background:var(--dark);padding:48px 0 24px}
.footer-top{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:40px;padding-bottom:32px;border-bottom:1px solid rgba(255,255,255,.08)}
.footer-brand .footer-logo{height:40px;width:auto;margin-bottom:16px;border-radius:0;filter:brightness(0) invert(1)}
.footer-brand p{font-size:.8125rem;color:rgba(255,255,255,.5);line-height:1.6}
.footer-title{font-size:.6875rem;text-transform:uppercase;letter-spacing:.12em;color:var(--gold);margin-bottom:16px;font-weight:500}
.footer-nav{display:grid;grid-template-columns:1fr 1fr;gap:10px 24px}
.footer-nav a{font-size:.8125rem;color:rgba(255,255,255,.5)}
.footer-nav a:hover{color:var(--gold)}
.footer-links a{font-size:.8125rem;color:rgba(255,255,255,.5);display:block;margin-bottom:8px}
.footer-links a:hover{color:var(--gold)}
.footer-bottom{display:flex;justify-content:space-between;padding-top:20px;font-size:.75rem;color:rgba(255,255,255,.3)}

/* =============================================
   Responsive
   ============================================= */
@media(max-width:1024px){
  .container{padding:0 24px}
  .hero-grid{grid-template-columns:1fr;padding:0}
  .hero h1{font-size:2.1rem}
  .about-grid{grid-template-columns:1fr}
  .cert-cards{grid-template-columns:1fr 1fr}
  .news-grid{grid-template-columns:1fr 1fr}
  .region-table{grid-template-columns:repeat(4,1fr)}
  .rt-cell:nth-child(5n){border-right:1px solid var(--border)}
  .rt-cell:nth-child(4n){border-right:none}
  .rt-cell:nth-last-child(-n+5){border-bottom:1px solid var(--border)}
  .rt-cell:nth-last-child(-n+4){border-bottom:none}
  .header-right{display:none}
  .footer-top{grid-template-columns:1fr 1fr}
  .stats-bar-inner{flex-wrap:wrap;gap:20px}
  .stat-divider{display:none}
}

@media(max-width:768px){
  .nav{display:none}
  .header-right{display:none}
  .burger{display:flex}
  .hero{padding:90px 0 30px}
  .hero-grid{padding:0}
  .hero h1{font-size:1.7rem}
  .heading-serif{font-size:1.75rem}
  .hero-info{grid-template-columns:1fr}
  /* Hero: image after buttons on mobile, centered */
  .hero-left{display:flex;flex-direction:column}
  .hero-right{align-items:center}
  .hero-img{max-width:300px;margin:0 auto}
  .hero-right .hero-info-v2{display:none}
  .products-grid{grid-template-columns:1fr}
  .cert-hero{flex-direction:column;text-align:center}
  .cert-hero-img{width:120px}
  .cert-cards{grid-template-columns:1fr 1fr}
  .news-grid{grid-template-columns:1fr}
  .contacts-grid{grid-template-columns:1fr}
  /* Region table: 2 columns on mobile */
  .region-table{grid-template-columns:repeat(2,1fr)}
  .rt-cell:nth-child(4n){border-right:1px solid var(--border)}
  .rt-cell:nth-child(2n){border-right:none}
  .rt-cell:nth-last-child(-n+4){border-bottom:1px solid var(--border)}
  .rt-cell:nth-last-child(-n+2){border-bottom:none}
  /* Map: ensure visible on mobile */
  .map-container{min-height:250px;overflow-x:auto;-webkit-overflow-scrolling:touch}
  .map-container svg{min-width:600px}
  .partners-cards{grid-template-columns:1fr}
  .about-cards{grid-template-columns:1fr}
  .cta-row{grid-template-columns:1fr}
  .cta-form-inner{padding:24px 20px}
  .cta-bottom{flex-direction:column;gap:16px}
  .cta-disclaimer{text-align:center;max-width:100%}
  .footer-top{grid-template-columns:1fr;gap:24px}
  .footer-bottom{flex-direction:column;gap:8px;text-align:center}
  .hero-btns{grid-template-columns:1fr}
  .hero-info-v2 .hi2-row{grid-template-columns:1fr}
  .section{padding:60px 0}
  .stats-bar-inner{gap:16px}
}

@media(max-width:480px){
  .cert-cards{grid-template-columns:1fr}
  /* Keep 2 columns for region table per design */
  .region-table{grid-template-columns:repeat(2,1fr)}
  .rt-cell:nth-child(2n){border-right:none}
  .rt-cell:nth-child(2n+1){border-right:1px solid var(--border)}
  .rt-cell:last-child{border-bottom:none}
  .rt-cell:nth-last-child(2):nth-child(odd){border-bottom:none}
  .rt-name{font-size:.75rem}
  .rt-num{font-size:.75rem}
}

/* Tooltip on mobile: hide desktop, show popup */
@media(max-width:768px){
  .map-tooltip{display:none!important}
}
@media(min-width:769px){
  .map-popup-overlay{display:none!important}
}

/* ---- Modal Overlay ---- */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:9999;display:none;align-items:center;justify-content:center;padding:20px}
.modal-overlay.open{display:flex}
.modal-form{background:#1a1a1a;border-radius:16px;padding:40px 36px;max-width:460px;width:100%;position:relative;border:1px solid rgba(255,255,255,.08)}
.modal-form h3{font-family:'Cormorant Garamond',serif;font-size:1.5rem;color:#fff;margin-bottom:8px}
.modal-close{position:absolute;top:16px;right:20px;background:none;border:none;color:#fff;font-size:1.75rem;cursor:pointer;opacity:.6;transition:opacity .2s}
.modal-close:hover{opacity:1}
.modal-field{margin-bottom:14px}
.modal-field input{width:100%;padding:12px 16px;border-radius:8px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.05);color:#fff;font-size:.875rem;font-family:'Inter',sans-serif;outline:none;transition:border-color .2s}
.modal-field input:focus{border-color:var(--gold,#C5A572)}
.modal-field input::placeholder{color:rgba(255,255,255,.4)}
