/* ============================================================
   PETROLIX — "Machina Viridis" Design System
   Acid Lime · Amber Ember · Void Black
   Fonts: Bebas Neue + IBM Plex Mono + DM Sans
   ============================================================ */
:root {
  --void:        #0a0e08;
  --surface:     #0d1209;
  --surface2:    #101408;
  --edge:        #1e2e18;
  --edge2:       #243820;
  --lime:        #b4ff32;
  --lime-dim:    #88cc1a;
  --amber:       #ff8c00;
  --amber-dim:   #cc6a00;
  --white:       #f2f8ee;
  --light:       #edf5e6;
  --sand:        #f8f4ec;
  --text-dark:   #1a1f15;
  --text-mid:    #3d5230;
  --text-muted:  #6a7a60;
  --font-head:   'Bebas Neue','Arial Narrow',Arial,sans-serif;
  --font-mono:   'IBM Plex Mono','Courier New',monospace;
  --font-body:   'DM Sans','Segoe UI',sans-serif;
  --ease:        cubic-bezier(.22,.68,0,1.2);
  --trans:       all .26s var(--ease);
  --sh-lime:     0 0 36px rgba(180,255,50,.18);
  --sh-amber:    0 0 36px rgba(255,140,0,.2);
  --r:           0px;
}

/* ---------- RESET ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:hidden;width:100%}
body{font-family:var(--font-body);font-size:16px;line-height:1.75;color:var(--text-dark);background:var(--white);overflow-x:hidden;width:100%;position:relative}

h1,h2,h3,h4,h5,h6{font-family:var(--font-head);line-height:1.05;color:var(--void);letter-spacing:.04em}
h1{font-size:clamp(3.2rem,8vw,6.5rem)}
h2{font-size:clamp(2.2rem,5vw,4rem)}
h3{font-size:clamp(1.4rem,3vw,2rem)}
h4{font-size:clamp(1.1rem,2.5vw,1.5rem)}
p{font-size:16px;margin-bottom:1rem}
a{text-decoration:none;color:inherit;transition:var(--trans)}
img{max-width:100%;height:auto;display:block}

/* ---------- LAYOUT HELPERS ---------- */
.sp{padding:96px 0}
.sp-sm{padding:64px 0}

.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-mono);font-size:10px;font-weight:500;
  text-transform:uppercase;letter-spacing:3px;color:var(--lime);
  margin-bottom:18px;
}
.eyebrow::before{content:'';width:24px;height:1px;background:var(--lime)}
.eyebrow.amber{color:var(--amber)}
.eyebrow.amber::before{background:var(--amber)}
.eyebrow.dark{color:var(--text-mid)}
.eyebrow.dark::before{background:var(--amber)}

.rule{width:48px;height:3px;background:var(--lime);margin:12px 0 26px}
.rule.amber{background:var(--amber)}
.rule.center{margin:12px auto 26px}
/* backwards compat */
.divider-gold{width:48px;height:3px;background:var(--amber);margin:12px 0 26px;border-radius:0}
.divider-gold.center{margin:12px auto 26px}
.section-label{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-mono);font-size:10px;
  text-transform:uppercase;letter-spacing:3px;color:var(--amber);
}
.section-label::before{content:'';width:22px;height:1px;background:var(--amber)}

/* ---------- BUTTONS ---------- */
.btn-lime{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 34px;background:var(--lime);color:var(--void);
  font-family:var(--font-head);font-size:1.15rem;letter-spacing:2px;
  border:none;cursor:pointer;
  clip-path:polygon(0 0,calc(100% - 14px) 0,100% 100%,14px 100%);
  transition:var(--trans);
}
.btn-lime:hover{background:#ccff44;transform:translateY(-2px);box-shadow:var(--sh-lime)}
.btn-lime:hover{color:var(--void)}

.btn-ghost{
  display:inline-flex;align-items:center;gap:10px;
  padding:13px 32px;background:transparent;color:var(--lime);
  font-family:var(--font-head);font-size:1.15rem;letter-spacing:2px;
  border:1px solid var(--lime);cursor:pointer;
  clip-path:polygon(0 0,calc(100% - 12px) 0,100% 100%,12px 100%);
  transition:var(--trans);
}
.btn-ghost:hover{background:var(--lime);color:var(--void)}

.btn-amber{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 34px;background:var(--amber);color:var(--void);
  font-family:var(--font-head);font-size:1.15rem;letter-spacing:2px;
  border:none;cursor:pointer;
  clip-path:polygon(0 0,calc(100% - 14px) 0,100% 100%,14px 100%);
  transition:var(--trans);
}
.btn-amber:hover{background:#ffaa33;transform:translateY(-2px);box-shadow:var(--sh-amber)}
.btn-amber:hover{color:var(--void)}

/* legacy aliases */
.btn-gold,.btn-fire{@extend .btn-amber}
.btn-signal{background:var(--lime);color:var(--void)}
.btn-fire-outline{border:1px solid var(--amber);color:var(--amber);background:transparent;padding:8px 20px;font-family:var(--font-head);font-size:.9rem;letter-spacing:1px;cursor:pointer;transition:var(--trans)}
.btn-fire-outline:hover{background:var(--amber);color:var(--void)}

/* ---------- NAVBAR ---------- */
.site-header{position:relative;z-index:100}
.navbar{padding:0;background:transparent;transition:background .3s}
.navbar.transparent{position:fixed;top:0;left:0;right:0;z-index:100}
.navbar.scrolled,.navbar-solid{
  background:rgba(10,14,8,.97)!important;
  border-bottom:1px solid var(--edge);
  backdrop-filter:blur(12px);
  box-shadow:0 2px 24px rgba(0,0,0,.5);
}
/* Always dark on mobile (hamburger mode) */
@media(max-width:991px){
  .navbar.transparent{
    background:rgba(10,14,8,.95)!important;
    border-bottom:1px solid var(--edge);
  }
}
.navbar .container{display:flex;align-items:stretch;min-height:72px}
.navbar-brand{display:flex;align-items:center;padding:0}
.logo-img{height:40px;width:auto}
.brand-name{font-family:var(--font-head);font-size:1.7rem;color:white;letter-spacing:3px;margin-left:10px}
.brand-dot{color:var(--lime)}

.navbar-nav{gap:0}
.nav-link{
  color:rgba(255,255,255,.65)!important;
  font-family:var(--font-mono);font-size:.75rem;font-weight:500;
  text-transform:uppercase;letter-spacing:2.5px;
  padding:0 18px!important;height:72px;
  display:flex;align-items:center;position:relative;transition:var(--trans);
}
.nav-link::after{content:'';position:absolute;bottom:0;left:18px;right:18px;height:2px;background:var(--lime);transform:scaleX(0);transition:transform .2s}
.nav-link:hover{color:white!important}
.nav-link:hover::after{transform:scaleX(1)}

.navbar-toggler{border:1px solid var(--edge);padding:8px 10px;border-radius:0}
.navbar-toggler-icon{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255,255,255,0.8%29' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e")}

/* ---------- HERO ---------- */
.hero-section{
  position:relative;background:var(--void);
  min-height:100vh;display:flex;align-items:center;
  padding-top:72px;overflow:hidden;
}
/* animated scan line */
.hero-section::before{
  content:'';position:absolute;inset:0;
  background:repeating-linear-gradient(0deg,transparent,transparent 32px,rgba(30,46,24,.35) 32px,rgba(30,46,24,.35) 33px);
  z-index:0;animation:scanSlide 8s linear infinite;
}
@keyframes scanSlide{to{background-position:0 33px}}
/* right diagonal accent - hidden on mobile to prevent overflow */
.hero-section::after{
  content:'';position:absolute;top:0;right:0;width:46%;height:100%;
  background:linear-gradient(168deg,rgba(14,20,10,.7) 0%,transparent 65%);
  clip-path:polygon(80px 0,100% 0,100% 100%,0 100%);z-index:0;
  pointer-events:none;
}

.hero-content{position:relative;z-index:2}

.hero-title{color:white;line-height:.95;margin-bottom:26px}
.hero-title .accent{color:var(--lime)}
.hero-title .accent-a{color:var(--amber)}
.hero-desc{font-size:17px;color:rgba(255,255,255,.6);max-width:500px;margin-bottom:36px;line-height:1.78}
.hero-cta-row{display:flex;flex-wrap:wrap;gap:14px;align-items:center}

/* hero image wrapper */
.hero-img-wrap{position:relative;z-index:1}
.hero-img-main{
  width:100%;border:1px solid var(--edge);
  box-shadow:-20px 20px 0 var(--amber),.0 28px 80px rgba(0,0,0,.65);
}
.hero-tag{
  position:absolute;top:-18px;right:18px;
  background:var(--lime);color:var(--void);
  font-family:var(--font-mono);font-size:.7rem;font-weight:500;
  text-transform:uppercase;letter-spacing:2px;
  padding:7px 18px;
  clip-path:polygon(0 0,calc(100% - 8px) 0,100% 100%,8px 100%);
}

/* hero counters */
.hero-stats{display:flex;margin-top:52px;border-top:1px solid var(--edge)}
.hero-stat{flex:1;padding:20px 22px;border-right:1px solid var(--edge)}
.hero-stat:last-child{border-right:none}
.hero-stat-num{font-family:var(--font-head);font-size:2.6rem;color:white;line-height:1}
.hero-stat-num span{color:var(--lime)}
.hero-stat-label{font-family:var(--font-mono);font-size:.65rem;text-transform:uppercase;letter-spacing:2px;color:var(--text-muted);margin-top:4px}

/* scroll indicator */
.scroll-hint{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:6px;z-index:2}
.scroll-hint span{font-family:var(--font-mono);font-size:.6rem;text-transform:uppercase;letter-spacing:3px;color:rgba(255,255,255,.25)}
.scroll-line{width:1px;height:44px;background:linear-gradient(to bottom,rgba(180,255,50,.4),transparent);animation:sp 2s ease-in-out infinite}
@keyframes sp{0%,100%{opacity:.3;transform:scaleY(.7)}50%{opacity:1;transform:scaleY(1)}}

/* ---------- TICKER ---------- */
.ticker-bar{
  background:var(--lime);padding:10px 0;overflow:hidden;
  border-top:1px solid var(--lime-dim);
}
.ticker-track{
  display:flex;gap:0;white-space:nowrap;
  animation:ticker 22s linear infinite;
}
@keyframes ticker{to{transform:translateX(-50%)}}
.ticker-item{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-mono);font-size:.72rem;font-weight:500;
  text-transform:uppercase;letter-spacing:2px;color:var(--void);
  padding:0 32px;border-right:2px solid rgba(10,14,8,.2);
}
.ticker-item i{font-size:.65rem}

/* ---------- ABOUT ---------- */
.about-section{
  background:var(--white);padding:0;
  display:grid;grid-template-columns:1fr 1fr;
  min-height:600px;
  width:100%;overflow:hidden;
}
.about-img-col{
  position:relative;overflow:hidden;
  background:var(--void);
}
.about-img-col img{width:100%;height:100%;object-fit:cover;object-position:center;opacity:.88}
.about-counter-badge{
  position:absolute;bottom:0;right:0;
  background:var(--amber);color:var(--void);
  padding:22px 28px;min-width:150px;
  clip-path:polygon(20px 0,100% 0,100% 100%,0 100%);
}
.about-counter-num{font-family:var(--font-head);font-size:3rem;line-height:1}
.about-counter-label{font-family:var(--font-mono);font-size:.65rem;text-transform:uppercase;letter-spacing:2px;margin-top:4px}

.about-text-col{
  background:var(--sand);padding:80px 64px;
  display:flex;flex-direction:column;justify-content:center;
}
.feature-list{list-style:none;padding:0;margin:24px 0;display:flex;flex-direction:column;gap:10px}
.feature-list li{display:flex;align-items:flex-start;gap:14px;font-size:15px;color:var(--text-mid);padding:10px 0;border-bottom:1px solid rgba(30,46,24,.08)}
.feature-list li:last-child{border-bottom:none}
.feature-list li i{color:var(--amber);margin-top:2px;width:16px;flex-shrink:0}

/* ---------- SERVICES ---------- */
.services-section{
  background:var(--void);padding:96px 0;position:relative;overflow:hidden;
}
.services-section::before{
  content:'';position:absolute;inset:0;
  background-image:
    repeating-linear-gradient(-45deg,transparent,transparent 36px,rgba(30,46,24,.18) 36px,rgba(30,46,24,.18) 37px);
}
.svc-card{
  background:var(--surface);border:1px solid var(--edge);
  padding:38px 30px;height:100%;position:relative;
  overflow:hidden;transition:var(--trans);
  clip-path:polygon(0 0,calc(100% - 16px) 0,100% 16px,100% 100%,16px 100%,0 calc(100% - 16px));
}
.svc-card::after{content:'';position:absolute;top:0;left:0;width:100%;height:2px;background:var(--lime);transform:scaleX(0);transform-origin:left;transition:transform .3s}
.svc-card:hover{border-color:var(--lime);transform:translateY(-5px);box-shadow:var(--sh-lime)}
.svc-card:hover::after{transform:scaleX(1)}
.svc-icon{
  width:52px;height:52px;background:rgba(180,255,50,.1);border:1px solid rgba(180,255,50,.25);
  display:flex;align-items:center;justify-content:center;font-size:22px;color:var(--lime);
  margin-bottom:22px;
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);
}
.svc-card h3{color:white;margin-bottom:10px;font-size:1.45rem}
.svc-card p{color:var(--text-muted);font-size:14.5px;line-height:1.72;margin:0}
.svc-num{
  position:absolute;top:16px;right:22px;
  font-family:var(--font-head);font-size:4.5rem;color:rgba(255,255,255,.03);
  line-height:1;user-select:none;
}

/* ---------- PROCESS ---------- */
.process-section{background:var(--light);padding:96px 0}
.process-steps{display:grid;grid-template-columns:repeat(4,1fr);position:relative}
.process-step{text-align:center;padding:0 20px;position:relative}
.process-step::after{
  content:'';position:absolute;top:36px;
  left:calc(50% + 40px);width:calc(100% - 80px);height:1px;
  background:linear-gradient(90deg,var(--amber),var(--edge));
}
.process-step:last-child::after{display:none}
.step-circle{
  width:72px;height:72px;background:var(--void);
  border:1px solid var(--amber);display:flex;align-items:center;justify-content:center;
  margin:0 auto 20px;position:relative;
  clip-path:polygon(10px 0,100% 0,100% calc(100% - 10px),calc(100% - 10px) 100%,0 100%,0 10px);
}
.step-circle i{font-size:24px;color:var(--amber)}
.step-num{
  position:absolute;top:-10px;right:-10px;
  width:22px;height:22px;background:var(--lime);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-mono);font-size:11px;font-weight:700;color:var(--void);
}
.process-step h4{color:var(--void);font-size:1.1rem;margin-bottom:8px}
.process-step p{font-size:14px;color:var(--text-muted);margin:0}

/* ---------- AUDIENCE ---------- */
.audience-section{background:white;padding:96px 0}
.aud-card{
  background:var(--void);border:1px solid var(--edge);
  padding:32px 26px;height:100%;position:relative;overflow:hidden;transition:var(--trans);
}
.aud-card::before{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--lime),var(--amber));transform:scaleX(0);transform-origin:left;transition:transform .3s}
.aud-card:hover{transform:translateY(-5px);border-color:var(--lime)}
.aud-card:hover::before{transform:scaleX(1)}
.aud-icon{
  width:50px;height:50px;background:rgba(180,255,50,.08);border:1px solid rgba(180,255,50,.2);
  display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--lime);
  margin-bottom:18px;
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);
}
.aud-card h4{color:white;font-size:1.2rem;margin-bottom:10px}
.aud-card p{color:var(--text-muted);font-size:14.5px;margin:0;line-height:1.7}

/* ---------- ADVANTAGES ---------- */
.advantages-section{
  background:var(--void);padding:96px 0;position:relative;overflow:hidden;
}
.advantages-section::before{
  content:'';position:absolute;inset:0;
  background-image:linear-gradient(var(--edge) 1px,transparent 1px),linear-gradient(90deg,var(--edge) 1px,transparent 1px);
  background-size:56px 56px;opacity:.25;
}
.advantages-img{width:100%;border:1px solid var(--edge);position:relative;z-index:1}
.adv-row{
  display:flex;align-items:flex-start;gap:18px;
  padding:20px 0;border-bottom:1px solid var(--edge);
  position:relative;z-index:1;transition:padding .2s;
}
.adv-row:last-child{border-bottom:none}
.adv-row:hover{padding-left:10px}
.adv-ico{
  flex-shrink:0;width:44px;height:44px;
  background:rgba(180,255,50,.08);border:1px solid rgba(180,255,50,.2);
  display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--lime);
  clip-path:polygon(6px 0,100% 0,100% calc(100% - 6px),calc(100% - 6px) 100%,0 100%,0 6px);
}
.adv-body h4{color:white;font-size:1.1rem;margin-bottom:4px}
.adv-body p{color:var(--text-muted);font-size:14.5px;margin:0;line-height:1.65}

/* ---------- STATS ---------- */
.stats-section{
  background:var(--lime);padding:60px 0;position:relative;overflow:hidden;
}
.stats-section::before{
  content:'';position:absolute;inset:0;
  background-image:repeating-linear-gradient(-45deg,transparent,transparent 18px,rgba(10,14,8,.06) 18px,rgba(10,14,8,.06) 20px);
}
.stat-item{text-align:center;padding:16px 20px;position:relative;z-index:1}
.stat-item+.stat-item::before{content:'';position:absolute;left:0;top:20%;bottom:20%;width:1px;background:rgba(10,14,8,.2)}
.stat-num{font-family:var(--font-head);font-size:clamp(3rem,5vw,4.5rem);color:var(--void);line-height:1;margin-bottom:6px}
.stat-label{font-family:var(--font-mono);font-size:.65rem;text-transform:uppercase;letter-spacing:2.5px;color:rgba(10,14,8,.65)}

/* ---------- GALLERY ---------- */
.gallery-section{background:var(--surface);padding:96px 0}
.gallery-grid{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  grid-template-rows:260px 260px;gap:14px;
}
.gi{overflow:hidden;position:relative;cursor:pointer;border:1px solid var(--edge)}
.gi:first-child{grid-column:1/2;grid-row:1/3}
.gi:nth-child(2){grid-column:2/3;grid-row:1}
.gi:nth-child(3){grid-column:3/4;grid-row:1}
.gi:nth-child(4){grid-column:2/3;grid-row:2}
.gi:nth-child(5){grid-column:3/4;grid-row:2}
.gi img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.gi:hover img{transform:scale(1.04)}
.gi-cap{
  position:absolute;bottom:0;left:0;right:0;
  background:linear-gradient(transparent,rgba(10,14,8,.9));
  padding:28px 14px 12px;
  font-family:var(--font-mono);font-size:.65rem;text-transform:uppercase;letter-spacing:2px;color:rgba(255,255,255,.65);
  opacity:0;transition:opacity .3s;
}
.gi:hover .gi-cap{opacity:1}
/* top-left corner marks on hover */
.gi::before{content:'';position:absolute;top:10px;left:10px;width:16px;height:16px;border-top:2px solid var(--lime);border-left:2px solid var(--lime);opacity:0;transition:opacity .3s;z-index:2}
.gi:hover::before{opacity:1}

/* ---------- TESTIMONIALS ---------- */
.testimonials-section{background:var(--void);padding:96px 0}
.testi-card{
  background:var(--surface);border:1px solid var(--edge);
  padding:36px 30px;height:100%;position:relative;
  clip-path:polygon(0 0,calc(100% - 14px) 0,100% 14px,100% 100%,14px 100%,0 calc(100% - 14px));
  transition:var(--trans);
}
.testi-card:hover{border-color:var(--lime);transform:translateY(-4px)}
.testi-quote{
  position:absolute;top:14px;right:22px;
  font-size:5rem;font-family:Georgia,serif;
  color:rgba(180,255,50,.08);line-height:1;user-select:none;
}
.testi-stars{color:var(--lime);font-size:13px;letter-spacing:2px;margin-bottom:16px;font-family:var(--font-mono)}
.testi-text{color:rgba(255,255,255,.7);font-size:15px;line-height:1.82;margin-bottom:26px;font-style:italic}
.testi-author{display:flex;align-items:center;gap:14px}
.t-avatar{
  width:44px;height:44px;background:var(--amber);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-head);font-size:1.1rem;color:var(--void);
  flex-shrink:0;
  clip-path:polygon(6px 0,100% 0,100% calc(100% - 6px),calc(100% - 6px) 100%,0 100%,0 6px);
}
.t-name{font-family:var(--font-head);font-size:1.05rem;color:white;margin-bottom:2px}
.t-role{font-family:var(--font-mono);font-size:.65rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--lime)}

/* ---------- ORDER ---------- */
.order-section{background:var(--sand);padding:96px 0}
.order-form-box{
  background:var(--void);border:1px solid var(--edge);padding:48px;
  clip-path:polygon(0 0,calc(100% - 22px) 0,100% 22px,100% 100%,22px 100%,0 calc(100% - 22px));
}
.form-label{font-family:var(--font-mono);font-size:.65rem;text-transform:uppercase;letter-spacing:2px;color:var(--text-muted);margin-bottom:6px;display:block}
.form-control,.form-select{
  background:var(--surface);border:1px solid var(--edge);
  border-radius:0;color:white;padding:12px 16px;font-size:15px;font-family:var(--font-body);
  transition:border-color .2s;
}
.form-control:focus,.form-select:focus{background:var(--surface);border-color:var(--lime);box-shadow:0 0 0 3px rgba(180,255,50,.12);color:white;outline:none}
.form-control::placeholder{color:rgba(255,255,255,.22)}
.form-select option{background:var(--surface);color:white}
textarea.form-control{resize:vertical;min-height:110px}
.order-benefit{display:flex;align-items:flex-start;gap:14px;margin-bottom:22px}
.order-benefit i{color:var(--amber);font-size:17px;margin-top:2px;width:18px;flex-shrink:0}
.order-benefit h5{font-family:var(--font-head);font-size:1.05rem;color:var(--void);margin-bottom:3px}
.order-benefit p{font-size:14px;color:var(--text-muted);margin:0}

/* ---------- MAP ---------- */
.map-section{background:var(--surface2);border-top:1px solid var(--edge)}
.map-info-col{background:var(--void);padding:60px 48px;display:flex;flex-direction:column;justify-content:center;min-height:440px}
.map-section iframe{display:block;width:100%;height:100%;min-height:440px;border:none}
.cinfo-item{display:flex;align-items:flex-start;gap:14px;margin-bottom:18px}
.cinfo-icon{
  width:42px;height:42px;flex-shrink:0;
  background:rgba(255,140,0,.1);border:1px solid rgba(255,140,0,.25);
  display:flex;align-items:center;justify-content:center;color:var(--amber);font-size:15px;
  clip-path:polygon(6px 0,100% 0,100% calc(100% - 6px),calc(100% - 6px) 100%,0 100%,0 6px);
}
.cinfo-body strong{display:block;font-family:var(--font-mono);font-size:.6rem;text-transform:uppercase;letter-spacing:2px;color:var(--amber);margin-bottom:3px}
.cinfo-body span,.cinfo-body a{font-size:14.5px;color:rgba(255,255,255,.8)}
.cinfo-body a:hover{color:var(--lime)}
.schedule-table{width:100%;margin-top:14px}
.schedule-row{display:flex;justify-content:space-between;padding:7px 0;border-bottom:1px solid rgba(255,255,255,.07);font-size:14px}
.schedule-row:last-child{border:none}
.schedule-row .day{color:rgba(255,255,255,.6);font-weight:600}
.schedule-row .hours{font-family:var(--font-mono);font-size:.8rem;color:var(--lime)}

/* ---------- COOKIE ---------- */
#cookieNotice{position:fixed;bottom:0;left:0;right:0;background:rgba(10,14,8,.97);border-top:2px solid var(--lime);z-index:9999;display:none;padding:14px 0;backdrop-filter:blur(8px)}
#cookieNotice p{font-size:14px;color:rgba(255,255,255,.65);margin:0}
#cookieNotice a{color:var(--lime)}

/* ---------- MODAL ---------- */
.modal-content{background:var(--void);border:1px solid var(--edge);border-radius:0;clip-path:polygon(0 0,calc(100% - 18px) 0,100% 18px,100% 100%,18px 100%,0 calc(100% - 18px))}
.modal-body{padding:48px 38px;text-align:center}
.success-icon{width:80px;height:80px;background:rgba(180,255,50,.1);border:2px solid var(--lime);display:flex;align-items:center;justify-content:center;font-size:32px;color:var(--lime);margin:0 auto 22px;clip-path:polygon(10px 0,100% 0,100% calc(100% - 10px),calc(100% - 10px) 100%,0 100%,0 10px)}
.modal-title-text{font-family:var(--font-head);font-size:2rem;color:white;margin-bottom:10px;letter-spacing:2px}
.modal-body p{color:var(--text-muted);font-size:15px;margin-bottom:8px}
.modal-progress{width:100%;height:3px;background:var(--edge);margin-top:22px;overflow:hidden}
.modal-progress-fill{height:100%;background:var(--lime);width:0%;animation:fp 3.2s linear forwards}
@keyframes fp{to{width:100%}}

/* ---------- FOOTER ---------- */
.site-footer{background:var(--void);border-top:1px solid var(--edge);padding:64px 0 0}
.footer-logo-wrap{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.footer-logo-wrap img{height:38px}
.fname{font-family:var(--font-head);font-size:1.5rem;color:white;letter-spacing:2px}
.fname em{font-style:normal;color:var(--lime)}
.footer-desc{color:var(--text-muted);font-size:14px;line-height:1.75;max-width:280px}
.footer-heading{font-family:var(--font-mono);font-size:.62rem;text-transform:uppercase;letter-spacing:3px;color:var(--lime);margin-bottom:18px;padding-bottom:10px;border-bottom:1px solid var(--edge)}
.footer-links{list-style:none;padding:0;margin:0}
.footer-links li{margin-bottom:10px}
.footer-links a{color:var(--text-muted);font-size:14px;display:flex;align-items:center;gap:8px;transition:var(--trans)}
.footer-links a::before{content:'›';color:var(--lime);font-size:1.1rem;opacity:0;transition:opacity .2s}
.footer-links a:hover{color:white;padding-left:6px}
.footer-links a:hover::before{opacity:1}
.footer-contact-row{display:flex;align-items:flex-start;gap:12px;margin-bottom:12px;color:var(--text-muted);font-size:14px}
.footer-contact-row i{color:var(--amber);margin-top:3px;width:16px;flex-shrink:0}
.footer-contact-row a:hover{color:var(--lime)}
.footer-bottom{border-top:1px solid var(--edge);margin-top:48px;padding:20px 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.footer-bottom p{font-size:12px;color:rgba(255,255,255,.3);margin:0;font-family:var(--font-mono)}
.policy-links{display:flex;gap:22px;flex-wrap:wrap}
.policy-links a{font-family:var(--font-mono);font-size:.65rem;color:rgba(255,255,255,.3);text-transform:uppercase;letter-spacing:1.5px;transition:var(--trans)}
.policy-links a:hover{color:var(--lime)}

/* ---------- CONTACTS PAGE ---------- */
.contacts-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;min-height:540px}
.contacts-info-col{background:var(--void);padding:56px 48px;border:1px solid var(--edge);border-right:none}
.contacts-form-col{background:var(--surface);padding:56px 48px;border:1px solid var(--edge)}
.contact-info-block{color:white}
.contact-info-block h3{color:white;margin-bottom:24px}
.faq-item{border-bottom:1px solid rgba(30,46,24,.15);padding:16px 0}
.faq-item:last-child{border:none}
.faq-q{font-family:var(--font-head);font-size:1.15rem;color:var(--void);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:12px;user-select:none}
.faq-q i{color:var(--amber);transition:transform .2s;font-size:12px;flex-shrink:0}
.faq-item.open .faq-q i{transform:rotate(180deg)}
.faq-a{font-size:15px;color:var(--text-muted);line-height:1.75;display:none;padding-top:12px}
.faq-item.open .faq-a{display:block}

/* ---------- THANK YOU ---------- */
.thankyou-section{
  min-height:100vh;display:flex;align-items:center;
  background:var(--void);color:white;text-align:center;padding:80px 0;position:relative;overflow:hidden;
}
.thankyou-section::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 32px,rgba(30,46,24,.3) 32px,rgba(30,46,24,.3) 33px)}
.ty-icon{width:100px;height:100px;background:rgba(180,255,50,.1);border:2px solid var(--lime);display:flex;align-items:center;justify-content:center;font-size:42px;color:var(--lime);margin:0 auto 28px;position:relative;z-index:1;clip-path:polygon(12px 0,100% 0,100% calc(100% - 12px),calc(100% - 12px) 100%,0 100%,0 12px)}
.thankyou-section h1{color:white;position:relative;z-index:1}
.thankyou-section p{color:var(--text-muted);position:relative;z-index:1}
.ty-ref{font-family:var(--font-mono);font-size:13px;color:var(--lime);background:var(--surface);border:1px solid var(--lime);display:inline-block;padding:6px 16px;letter-spacing:2px;position:relative;z-index:1;margin:8px 0}

/* ================================================
   INNER PAGES
   ================================================ */
.inner-hero{background:var(--void);padding-top:80px;overflow:hidden;position:relative}
.inner-hero::before{
  content:'';position:absolute;inset:0;
  background:repeating-linear-gradient(0deg,transparent,transparent 30px,rgba(30,46,24,.25) 30px,rgba(30,46,24,.25) 31px);
}
.inner-hero-wrap{display:grid;grid-template-columns:1fr 280px;gap:0;min-height:230px;align-items:stretch;position:relative;z-index:1}
.inner-hero-left{padding:50px 36px 50px 0;display:flex;flex-direction:column;justify-content:center}
.inner-hero-right{background:var(--lime);display:flex;align-items:center;justify-content:center;padding:36px;clip-path:polygon(26px 0%,100% 0%,100% 100%,0% 100%)}
.inner-hero-badge i{font-size:54px;color:rgba(10,14,8,.2)}
.inner-hero h1{color:white;font-size:clamp(1.8rem,3.5vw,2.6rem);margin-bottom:8px}
.inner-hero .hero-sub{color:rgba(255,255,255,.5);font-family:var(--font-mono);font-size:.78rem;letter-spacing:1.5px}

.breadcrumb-nav{display:flex;gap:8px;align-items:center;font-family:var(--font-mono);font-size:.68rem;color:rgba(255,255,255,.35);margin-bottom:16px;letter-spacing:1px;text-transform:uppercase}
.breadcrumb-nav a{color:var(--lime)}
.breadcrumb-nav a:hover{color:var(--amber)}
.breadcrumb-nav .sep{color:rgba(255,255,255,.2)}

.policy-layout{padding:72px 0 80px;background:#fff}
.policy-sidebar{position:sticky;top:90px;align-self:start}
.toc-card{background:var(--void);border:1px solid var(--edge);padding:24px 20px;color:white;clip-path:polygon(0 0,calc(100% - 10px) 0,100% 10px,100% 100%,10px 100%,0 calc(100% - 10px))}
.toc-card-title{font-family:var(--font-mono);font-size:.62rem;text-transform:uppercase;letter-spacing:3px;color:var(--lime);margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--edge)}
.toc-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:1px}
.toc-list a{display:flex;align-items:flex-start;gap:10px;padding:7px 8px;text-decoration:none;font-size:13px;color:rgba(255,255,255,.55);transition:background .18s,color .18s;line-height:1.4;font-family:var(--font-body)}
.toc-list a:hover{background:rgba(180,255,50,.08);color:var(--lime)}
.toc-num{flex-shrink:0;width:20px;height:20px;background:rgba(180,255,50,.12);border:1px solid rgba(180,255,50,.3);font-family:var(--font-mono);font-size:10px;font-weight:700;color:var(--lime);display:flex;align-items:center;justify-content:center;margin-top:1px}
.meta-strip{display:flex;flex-wrap:wrap;gap:10px 22px;background:var(--light);border-left:3px solid var(--lime);padding:14px 18px;margin-bottom:38px;font-size:13px;color:var(--text-muted)}
.meta-strip span{display:flex;align-items:center;gap:7px}
.meta-strip i{color:var(--lime)}
.meta-strip a{color:var(--amber)}

.policy-section{margin-bottom:42px;padding-bottom:42px;border-bottom:1px solid #e8ede4}
.policy-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.section-heading{display:flex;align-items:flex-start;gap:14px;margin-bottom:16px}
.section-num{flex-shrink:0;width:40px;height:40px;background:var(--lime);clip-path:polygon(6px 0,100% 0,100% calc(100% - 6px),calc(100% - 6px) 100%,0 100%,0 6px);display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-size:15px;color:var(--void);margin-top:2px}
.section-heading h2{font-size:1.15rem;color:var(--void);margin:0;padding-top:8px;border:none;text-transform:none;letter-spacing:0;font-family:var(--font-body);font-weight:700}
.policy-section p{font-size:16px;color:#4a5a40;line-height:1.82}
.policy-section ul{padding-left:0;list-style:none;margin-bottom:18px}
.policy-section li{padding:10px 14px 10px 38px;position:relative;margin-bottom:6px;background:var(--light);border-left:2px solid transparent;transition:border-color .2s;font-size:15.5px;color:#4a5a40}
.policy-section li:hover{border-left-color:var(--lime)}
.policy-section li::before{content:'';position:absolute;left:14px;top:50%;transform:translateY(-50%) rotate(45deg);width:6px;height:6px;background:var(--amber)}
.policy-section h3{font-size:.95rem;color:var(--void);margin-top:20px;margin-bottom:8px;font-family:var(--font-body);font-weight:600;text-transform:none;letter-spacing:0}

.inner-map-section{background:var(--void);padding:72px 0}
.inner-map-section h2{color:white}
.inner-map-section .divider-gold.center{background:var(--lime)}
.inner-map-card{overflow:hidden;height:100%;border:1px solid var(--edge)}
.inner-map-card iframe{display:block;width:100%;height:100%;min-height:380px;border:none}
.inner-contact-box{background:var(--surface);border:1px solid var(--edge);border-left:3px solid var(--lime);padding:34px 26px;color:white;height:100%}
.inner-contact-box h3{color:white;font-size:1.1rem;margin-bottom:22px;padding-bottom:12px;border-bottom:1px solid var(--edge);display:flex;align-items:center;gap:10px;text-transform:uppercase;letter-spacing:1px;font-size:1rem}

/* ─── MOBILE MENU DROPDOWN ─── */
@media(max-width:991px){
  .navbar-collapse{
    background:rgba(7,11,5,.98);
    border:1px solid var(--edge);
    border-top:2px solid var(--lime);
    padding:16px 20px 20px;
    margin-top:8px;
    backdrop-filter:blur(12px);
  }
  .navbar-collapse .nav-link{
    height:auto;padding:12px 8px!important;
    border-bottom:1px solid var(--edge);
    font-size:.8rem;
  }
  .navbar-collapse .nav-link::after{display:none}
  .navbar-collapse .nav-link:last-of-type{border-bottom:none}
  .navbar-collapse .btn-lime{
    display:flex;width:100%;justify-content:center;
    margin:14px 0 0!important;padding:14px!important;
    font-size:1rem!important;
  }
}

/* ---------- RESPONSIVE ---------- */
@media(max-width:1199px){.order-form-box{padding:36px 28px}}

@media(max-width:991px){
  h1{font-size:2.8rem}
  /* Fix: remove horizontal padding that causes overflow */
  .hero-section{min-height:auto;padding:120px 0 64px}
  .hero-img-main{margin-top:40px}
  .about-section{grid-template-columns:1fr;width:100%}
  .about-img-col{min-height:320px;width:100%}
  .about-text-col{padding:56px 40px;width:100%}
  .about-counter-badge{right:0}
  .process-steps{grid-template-columns:repeat(2,1fr);gap:40px}
  .process-step::after{display:none}
  .contacts-grid{grid-template-columns:1fr}
  .contacts-form-col{border-top:none}
  /* contacts page cols */
  .col-lg-5[style*="background:var(--void)"],
  .col-lg-7[style*="background:var(--surface)"]{
    padding:36px 28px!important;
  }
  .inner-hero-wrap{grid-template-columns:1fr;min-height:auto}
  .inner-hero-right{display:none}
  .inner-hero-left{padding:52px 0 40px}
  .policy-sidebar{position:static;margin-bottom:32px}
  .toc-card{display:none}
  .gallery-grid{grid-template-columns:1fr 1fr;grid-template-rows:220px 220px 220px}
  .gi:first-child{grid-column:1/3;grid-row:1}
  .gi:nth-child(2){grid-column:1;grid-row:2}
  .gi:nth-child(3){grid-column:2;grid-row:2}
  .gi:nth-child(4){grid-column:1;grid-row:3}
  .gi:nth-child(5){grid-column:2;grid-row:3}
  .map-section .row{flex-direction:column}
  .map-section .col-lg-4,.map-section .col-lg-8{width:100%!important;max-width:100%!important;flex:0 0 100%!important}
  .map-section iframe{min-height:300px}
}

@media(max-width:767px){
  /* Critical: prevent any element from exceeding viewport */
  *{max-width:100%;box-sizing:border-box}
  img,svg{max-width:100%!important}
  .sp{padding:60px 0}
  .map-info-col{padding:40px 24px}
  .hero-stats{flex-wrap:wrap}
  .hero-stat{min-width:50%}
  .about-text-col{padding:44px 24px}
  .order-form-box{clip-path:none;padding:28px 20px}
  .hero-desc{max-width:100%}
  /* Ticker: no overflow on mobile */
  .ticker-bar{overflow:hidden;width:100%}
  /* Stats */
  .stats-section .row>div+div .stat-item::before{display:none}
}

@media(max-width:575px){
  h2{font-size:2rem}
  h1{font-size:2.4rem}
  .contacts-info-col,.contacts-form-col{padding:32px 20px}
  .inner-contact-box{padding:26px 18px}
  .gallery-grid{grid-template-columns:1fr;grid-template-rows:repeat(5,200px)}
  .gi:first-child{grid-column:1;grid-row:1}
  .gi:nth-child(2){grid-column:1;grid-row:2}
  .gi:nth-child(3){grid-column:1;grid-row:3}
  .gi:nth-child(4){grid-column:1;grid-row:4}
  .gi:nth-child(5){grid-column:1;grid-row:5}
  .meta-strip{flex-direction:column;gap:8px}
  .section-num{width:36px;height:36px}
  .hero-stats{border-top:1px solid var(--edge)}
  .hero-stat{padding:14px 12px}
  .hero-stat-num{font-size:2rem}
  .about-text-col{padding:36px 20px}
  /* Process: single column on very small screens */
  .process-steps{grid-template-columns:1fr;gap:28px}
  .step-circle{margin-bottom:14px}
  .order-form-box{padding:24px 16px}
  .map-info-col{padding:32px 20px}
  .footer-bottom{flex-direction:column;text-align:center}
  .policy-links{justify-content:center}
  /* Fix hero overflow */
  .hero-section::after{display:none}
}
