/* =========================
   0) FONTS (CDN)
   ========================= */
@import url('https://fonts.cdnfonts.com/css/product-sans');

/* =========================
   1) DESIGN TOKENS
   ========================= */
:root{
    --jx-green:#07A560;              /* CTA green */
    --jx-green-hover:#099C5C;
    --jx-green-press:#048551;
    --jx-dark:#181818;                /* Dark UI button/bg */
    --jx-dark-hover:#202020;
    --jx-dark-press:#0F0F0F;

    --jx-bg:#ffffff;
    --jx-text:#141414;
    --jx-muted:#6B6B6B;

    --jx-link:#07A560;
    --jx-link-hover:#0A8F59;

    --jx-max:1200px;
    --jx-radius-pill:9999px;
    --jx-radius:12px;

    --jx-shadow:0 1px 1px rgba(0,0,0,.06), 0 6px 16px rgba(0,0,0,.10);
    --jx-shadow-press:0 1px 0 rgba(0,0,0,.25) inset;
    --jx-ring:0 0 0 3px rgba(7,165,96,.35);
}

/* =========================
   2) BASE / RESET
   ========================= */
*{box-sizing:border-box}
html,body{height:100%}
body{
    margin:0;
    background:var(--jx-bg);
    color:var(--jx-text);
    font-family:"Product Sans", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
    line-height:1.6;
    text-rendering:optimizeLegibility;
    -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--jx-link);text-decoration:none}
a:hover{color:var(--jx-link-hover)}
.container{max-width:var(--jx-max);margin:0 auto;padding:0 16px}

/* =========================
   3) HEADER & NAV
   ========================= */
.site-header{
    position:sticky;top:0;z-index:1000;
    background:#000; color:#fff;
    border-bottom:1px solid rgba(255,255,255,.06);
}
.site-header .nav-wrap{
    display:flex;align-items:center;justify-content:space-between;
    padding:10px 0;
}
.site-logo img{height:42px;width:auto}

.primary-nav{display:flex;gap:24px;list-style:none;margin:0;padding:0}
.primary-nav a{
    color:#fff;font-weight:600;letter-spacing:.2px;position:relative
}
.primary-nav a:hover{color:var(--jx-green)}
/* Mobile */
.nav-toggle{
    display:none; background:none;border:0;color:#fff;font-size:28px;cursor:pointer
}
@media (max-width: 900px){
    .primary-nav{display:none;position:absolute;left:0;right:0;top:100%;background:#000;padding:12px 16px;flex-direction:column;border-bottom:1px solid rgba(255,255,255,.08)}
    .primary-nav.show{display:flex}
    .nav-toggle{display:block}
}




/* =========================
   5) BUTTON SYSTEM
   ========================= */
/* Kill WP legacy button styles */
button, .button, .btn, input[type=submit], input[type=button], input[type=reset], .wp-block-button__link{ all:unset }

/* Base */
.btn, .wp-block-button__link, button.button, input[type=submit], input[type=button], input[type=reset], a.button{
    display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
    min-height:44px;padding:0 20px;border-radius:var(--jx-radius-pill);
    font:500 16px/1 "Product Sans", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
    color:#fff; cursor:pointer; user-select:none; box-shadow:var(--jx-shadow);
    transition:transform .12s ease, background-color .15s ease, opacity .2s ease;
}

/* Variants */
.btn--dark{ background:var(--jx-dark); }
.btn--dark:hover{ background:var(--jx-dark-hover) }
.btn--dark:active{ background:var(--jx-dark-press); transform:translateY(1px); box-shadow:var(--jx-shadow-press) }
.btn--dark:focus-visible{ outline:none; box-shadow:var(--jx-shadow), var(--jx-ring) }

.btn--green{ background:var(--jx-green); }
.btn--green:hover{ background:var(--jx-green-hover) }
.btn--green:active{ background:var(--jx-green-press); transform:translateY(1px); box-shadow:var(--jx-shadow-press) }
.btn--green:focus-visible{ outline:none; box-shadow:var(--jx-shadow), var(--jx-ring) }

/* Sizes */
.btn--sm{min-height:36px;padding:0 14px;font-size:14px}
.btn--lg{min-height:52px;padding:0 26px;font-size:17px}
.btn--xl{min-height:58px;padding:0 30px;font-size:18px}
.btn--block{display:flex;width:100%}

/* Loading & Disabled */
.btn.is-loading{position:relative;color:transparent!important}
.btn.is-loading::after{
    content:""; position:absolute; inset:0; margin:auto; width:18px;height:18px;border-radius:50%;
    border:2px solid rgba(255,255,255,.55); border-top-color:#fff; animation:jx-spin .8s linear infinite;
}
@keyframes jx-spin{to{transform:rotate(360deg)}}
.btn[disabled], .btn.is-disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}

/* =========================
   6) SECTIONS / GRID / CARDS
   ========================= */
.section{padding:56px 0}
.section h2{font-size:clamp(22px,3vw,32px);margin:0 0 8px;text-align:center}
.section .lead{color:var(--jx-muted);text-align:center;margin:0 0 28px}

.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:24px}
.grid-3 > *{grid-column:span 4}
.grid-2 > *{grid-column:span 6}
@media (max-width: 900px){
    .grid-3 > *, .grid-2 > *{grid-column:1 / -1}
}

.card{
    background:#F7F7F7;border-radius:var(--jx-radius);padding:24px;box-shadow:0 1px 0 rgba(0,0,0,.04);
    transition:transform .2s ease, box-shadow .2s ease;
}
.card:hover{transform:translateY(-4px); box-shadow:0 10px 20px rgba(0,0,0,.12)}

/* =========================
   7) FORMS
   ========================= */
.form{
    max-width:720px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:16px
}
.form .full{grid-column:1 / -1}
@media (max-width: 700px){ .form{grid-template-columns:1fr} }
label{display:block;font-weight:600;margin:0 0 6px}
input, select, textarea{
    width:100%;padding:12px 14px;border:1px solid #D9D9D9;border-radius:10px;background:#fff;
    font:400 16px/1.3 "Product Sans", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
    transition:border-color .15s ease, box-shadow .15s ease;
}
textarea{min-height:140px;resize:vertical}
input:focus, select:focus, textarea:focus{outline:none;border-color:var(--jx-green); box-shadow:var(--jx-ring)}
.help{font-size:13px;color:var(--jx-muted);margin-top:6px}

/* =========================
   8) FOOTER
   ========================= */
.site-footer{
    background:#000;color:#fff;padding:32px 0;margin-top:40px
}
.footer-nav{display:flex;flex-wrap:wrap;gap:18px;justify-content:center;margin-bottom:10px}
.footer-nav a{color:#fff}
.footer-nav a:hover{color:var(--jx-green)}
.site-footer p{opacity:.8;text-align:center;margin:6px 0}

/* =========================
   9) UTILITIES
   ========================= */
.hidden{display:none!important}
.btn-group{display:flex;flex-wrap:wrap;gap:12px}
.mt-0{margin-top:0}.mb-0{margin-bottom:0}.mt-24{margin-top:24px}.mb-24{margin-bottom:24px}
/*
 * Jettex Theme v2 — Overrides
 * Mobile menu panel styled to match screenshot + global Product Sans.
 */


/* -------------------------------------------------------------
   Tokens
------------------------------------------------------------- */
:root{
  --header-bg:#0d0d0d;
  --accent-green:#43946c;        /* CTA green (as provided) */
  --accent-green-hover:#099C5C;
  --accent-green-press:#048551;

  --btn-dark:#1A1A1A;            /* dark button */
  --btn-dark-hover:#202020;
  --btn-dark-press:#111111;
  --btn-dark-border:#2A2A2A;

  --body-bg:#111;               /* default night background */
  --body-text:#fff;             /* default night text */
  --ring:0 0 0 3px rgba(7,165,96,.35);
  --shadow:0 1px 1px rgba(0,0,0,.06), 0 6px 16px rgba(0,0,0,.10);
  --shadow-press:0 1px 0 rgba(0,0,0,.25) inset;

  --pill:9999px;
  --header-h:59px;               /* adjust to your real header height */
}

/* -------------------------------------------------------------
   Global typography (force Product Sans)
------------------------------------------------------------- */
html, body{
  background:var(--body-bg);
  font-family:"Product Sans", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif !important;
  color:var(--body-text);
}

/* Day mode overrides */
body.theme-day{
  --body-bg:#f9f9f9;
  --body-text:#222;
}

/* Night mode explicit class */
body.theme-night{
  --body-bg:#111;
  --body-text:#fff;
}
body.theme-day .site-main :where(h1,h2,h3,h4,h5,h6,p,li,span,small,strong,em,label){
  color:var(--body-text);
}

/* Keep header and footer dark regardless of theme */
body.theme-day .site-header,
body.theme-day .site-footer{
  background:#000;
  color:#fff;
}
body.theme-day .site-header a,
body.theme-day .site-footer a{
  color:#fff;
}

/* Preserve hero styling across themes */
body.theme-day #hero :where(h1,h2,h3,h4,h5,h6,p,li,span,small,strong,em,label){
  color:inherit;
}

/* Light mode overrides for dark sections */
body.theme-day :is(.site-main[class*='-dark'], .site-main [class*='-dark']){
  background:var(--body-bg)!important;
  color:var(--body-text)!important;
}
body.theme-day :is(.site-main[class*='-dark'], .site-main [class*='-dark']) :where(h1,h2,h3,h4,h5,h6,p,li,span,small,strong,em,label){
  color:var(--body-text)!important;
}
body.theme-day :is(.site-main[class*='-dark'], .site-main [class*='-dark']) :is(.card,[class$='-card']){
  background:#fff!important;
  color:var(--body-text)!important;
  border:1px solid #D9D9D9!important;
  box-shadow:var(--shadow)!important;
}
body.theme-day :is(.site-main[class*='-dark'], .site-main [class*='-dark']) a{
  color:var(--accent-green)!important;
}
body.theme-day :is(.site-main[class*='-dark'], .site-main [class*='-dark']) a:hover{
  color:var(--accent-green-hover)!important;
}
body.theme-day :is(.site-main[class*='-dark'], .site-main [class*='-dark']) input,
body.theme-day :is(.site-main[class*='-dark'], .site-main [class*='-dark']) select,
body.theme-day :is(.site-main[class*='-dark'], .site-main [class*='-dark']) textarea{
  background:#fff!important;
  color:var(--body-text)!important;
  border:1px solid #D9D9D9!important;
}

body.theme-day :is(.site-main[class*='-dark'], .site-main [class*='-dark']) [class*='avatar'],
body.theme-day :is(.site-main[class*='-dark'], .site-main [class*='-dark']) [class*='shot']{
  background:#fff!important;
  border:1px solid #D9D9D9!important;
  box-shadow:var(--shadow)!important;
}

body.theme-day :is(.site-main[class*='-dark'], .site-main [class*='-dark']) .jtx-position{
  background:#fff!important;
  color:var(--body-text)!important;
  border:1px solid #D9D9D9!important;
  box-shadow:var(--shadow)!important;
}

body.theme-day :is(.site-main[class*='-dark'], .site-main [class*='-dark']) .ba-media,
body.theme-day :is(.site-main[class*='-dark'], .site-main [class*='-dark']) .ba-badge.before,
body.theme-day :is(.site-main[class*='-dark'], .site-main [class*='-dark']) .ba-btn,
body.theme-day :is(.site-main[class*='-dark'], .site-main [class*='-dark']) .contact-map{
  background:#fff!important;
  color:var(--body-text)!important;
  border:1px solid #D9D9D9!important;
  box-shadow:var(--shadow)!important;
}
body.theme-day :is(.site-main[class*='-dark'], .site-main [class*='-dark']) .contact-eyebrow{
  color:var(--accent-green)!important;
}

body.theme-day #before-after.ba-dark .ba-badge.before .dot{
  background:#6B6B6B!important;
}

body.theme-day #faq.faq-dark .faq-summary::after{
  background:#fff;
  color:var(--body-text);
  border:1px solid #D9D9D9;
}

body.theme-day #faq.faq-dark .faq-item[open] .faq-summary::after{
  color:var(--body-text);
}

/* Light mode tweaks for team page */
body.theme-day #team .team-eyebrow{
  color:var(--accent-green)!important;
}
body.theme-day #team .team-card,
body.theme-day #team .team-avatar{
  background:none!important;
  border:none!important;
  box-shadow:none!important;
}
/* Light mode overrides for Homepage hero */
body.theme-day #hero.hero-banner{
  background:var(--body-bg)!important;
  color:var(--body-text)!important;
}
body.theme-day #hero.hero-banner::before{
  background:
    radial-gradient(900px 500px at 50% 0%, rgba(67,148,108,.12), transparent 60%),
    radial-gradient(600px 400px at 15% 10%, rgba(67,148,108,.07), transparent 60%),
    radial-gradient(600px 400px at 85% 10%, rgba(67,148,108,.07), transparent 60%);
}
body.theme-day #hero .hero-eyebrow{
  color:var(--accent-green)!important;
}
body.theme-day #hero .hero-title{
  color:var(--body-text)!important;
}
body.theme-day #hero .hero-title .hero-accent{
  color:var(--accent-green)!important;
}
/* Light mode overrides for Homepage About block */
body.theme-day #about-v2{
  background:var(--body-bg)!important;
  color:var(--body-text)!important;
}
body.theme-day #about-v2 .about-eyebrow{
  color:var(--accent-green)!important;
}
body.theme-day #about-v2 .about-sub,
body.theme-day #about-v2 .benefits-sub,
body.theme-day #about-v2 .benefit-text,
body.theme-day #about-v2 .benefit-title{
  color:var(--body-text)!important;
}
body.theme-day #about-v2 .about-shot,
body.theme-day #about-v2 .benefit-card{
  background:#fff!important;
  color:var(--body-text)!important;
  border:1px solid #D9D9D9!important;
  box-shadow:var(--shadow)!important;
}

/* Light mode overrides for About page */
body.theme-day .about-hero,
body.theme-day .about-story-v2,
body.theme-day .about-section,
body.theme-day .jtx-section{
  background:var(--body-bg)!important;
  color:var(--body-text)!important;
}
body.theme-day .about-hero-grid{
  background-image:linear-gradient(rgba(0,0,0,.04) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(0,0,0,.04) 1px,transparent 1px)!important;
}
body.theme-day .about-stat-label,
body.theme-day .about-story-v2 .story-lead,
body.theme-day .about-story-v2 .story-col p,
body.theme-day .about-story-v2 em,
body.theme-day .about-story-v2 strong,
body.theme-day .about-section-content,
body.theme-day .jtx-difference .jtx-card-text,
body.theme-day .jtx-process .jtx-pos-meta{
  color:var(--body-text)!important;
}
body.theme-day .jtx-difference .jtx-card,
body.theme-day .jtx-process .jtx-position{
  background:#fff!important;
  color:var(--body-text)!important;
  border:1px solid #D9D9D9!important;
  box-shadow:var(--shadow)!important;
}
body.theme-day .jtx-difference .jtx-card-title,
body.theme-day .jtx-process .jtx-pos-title{
  color:var(--body-text)!important;
}

/* Service page */
body.theme-day .service-hero{
  color:var(--body-text)!important;
}
body.theme-day .service-title,
body.theme-day .service-sub,
body.theme-day .service-content h2,
body.theme-day .service-content h3,
body.theme-day .service-content h4{
  color:var(--body-text)!important;
}

/* Light mode overrides for quote modal */
body.theme-day .modal-quote .jx-card{
  background:#fff;
  color:var(--body-text);
  border:1px solid #D9D9D9;
  box-shadow:var(--shadow);
}
body.theme-day .modal-quote .jx-header{
  border-bottom:1px solid #D9D9D9;
  background:linear-gradient(180deg, rgba(0,0,0,.02), transparent);
}
body.theme-day .modal-quote .modal-title{
  color:var(--body-text);
}
body.theme-day .modal-quote .jx-close{
  filter:none;
  opacity:.6;
}
body.theme-day .modal-quote .jx-close:hover{opacity:1;}
body.theme-day .modal-quote .form-label{
  color:var(--body-text);
}
body.theme-day .modal-quote .form-control,
body.theme-day .modal-quote .form-select{
  background:#fff;
  color:var(--body-text);
  border:1px solid #D9D9D9;
}
body.theme-day .modal-quote .form-control::placeholder{
  color:var(--body-text);
  opacity:.6;
}

/* Theme selector */
.theme-select{
  background:var(--btn-dark);
  color:#fff;
  border:1px solid var(--btn-dark-border);
  border-radius:var(--pill);
  padding:0 22px;
  min-height:44px;
  margin-right:0.5rem;
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='white'%3E%3Cpath d='M1.5 5l6 6 6-6H1.5z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 12px center;
  background-size:12px;
  padding-right:40px;
  width: 105px;
}

.theme-select:focus-visible{
  outline:none;
  box-shadow:var(--shadow),var(--ring);
}
h1, h2, h3, h4, h5, h6,
p, a, li, dt, dd, blockquote, figcaption,
small, strong, em, label, legend,
nav, .primary-nav a,
table, th, td, code, pre, kbd, samp,
button, .button, .btn,
input, select, textarea,
input[type=submit], input[type=button], input[type=reset],
.wp-block, .wp-block *, .widget, .widget *,
.site-header, .site-header *, .site-footer, .site-footer *{
  font-family:inherit !important;
}

/* -------------------------------------------------------------
   Header & desktop nav (unchanged)
------------------------------------------------------------- */
.site-header .nav-container{max-width:1200px;margin:0 auto;padding:0 1rem}
.site-header .primary-nav ul{margin:0;padding:0;list-style:none;display:flex;gap:1.5rem;align-items:center}
.site-header .primary-nav a{
  color:#fff; text-decoration:none; transition:color .3s ease; font-weight:100; font-size:18px;
}
.site-header .primary-nav a:hover{color:var(--accent-green)}
.site-header .nav-actions .icon-link{color:#fff;display:flex;align-items:center;transition:color .3s ease}
.site-header .nav-actions .icon-link:hover{color:var(--accent-green)}

/* Header CTA */
.site-header .btn-quote{
  background:var(--accent-green)!important; color:#fff!important;
  padding:.5rem 1.5rem; font-weight:400; text-decoration:none; border:0;
  border-radius:var(--pill); display:inline-flex; align-items:center; justify-content:center;
  box-shadow:var(--shadow); transition:transform .12s ease, background-color .15s ease, opacity .2s ease;
}
.site-header .btn-quote:hover{background:var(--accent-green-hover)!important}
.site-header .btn-quote:active{background:var(--accent-green-press)!important; transform:translateY(1px)}

/* -------------------------------------------------------------
   MOBILE MENU — full-screen panel like the screenshot
------------------------------------------------------------- */
/* The panel container */
.mobile-nav{
  display:none; flex-direction:column;
  position:fixed; left:0; right:0; top:var(--header-h); bottom:0;
  background:#0e0e0e;              /* deep charcoal */
  z-index:9999;
  padding:24px 20px 24px;
  overflow:auto;
  /* leave space for the fixed action buttons at the bottom */
  padding-bottom:140px;
}
/* thin divider under header */
.mobile-nav::before{
  content:""; position:absolute; left:0; right:0; top:0; height:1px;
  background:rgba(255,255,255,.08);
}
.mobile-nav.open{ display:flex !important; }
@media (min-width:768px){ .mobile-nav{ display:none !important; } }

/* List layout (WordPress menu output inside .mobile-nav) */
.mobile-nav ul, .mobile-nav .menu{
  list-style:none; margin:0; padding:0;
  display:flex; flex-direction:column; gap:28px;
}
.mobile-nav li{ margin:0; }

/* Big uppercase links */
.mobile-nav a{
  color:#fff; text-decoration:none; border:0;
  text-transform:uppercase;
  font-weight:400;
  letter-spacing:.02em;
  font-size:clamp(20px, 5.4vw, 28px);
  line-height:1.3;
  padding:0; /* clean lines; no dividers under items */
}
.mobile-nav a:hover{ color:var(--accent-green); }

/* Fixed bottom actions (Log in + Get a Quote) */
.mobile-nav .mobile-actions{
  position:fixed; left:16px; right:16px;
  bottom:calc(16px + env(safe-area-inset-bottom));
  display:flex; flex-direction:column; gap:14px;
}
.mobile-nav .mobile-actions .btn{
  width:100%; min-height:56px; font-size:18px; border-radius:var(--pill);
}

/* Make sure top has a fallback */
.mobile-nav{
  top: var(--header-h, 59px);
}

/* Make the toggle obviously clickable */
.menu-toggle{ cursor:pointer; border:0; background:#111; color:#fff; }
.menu-toggle:focus-visible{ outline: none; box-shadow: 0 0 0 3px rgba(7,165,96,.35); }

/* Lock scroll when menu is open */
body.nav-open { overflow: hidden; }

.menu-toggle {
    cursor: pointer;
    border: 0;
    background: #111;
    font-size: 26px;
    padding: 0px 10px 2px;
    border-radius: 5px;
    border: 1px solid #222;
    color: #fff;
}

/* -------------------------------------------------------------
   BUTTON SYSTEM (shared)
------------------------------------------------------------- */
/* reset legacy */
button, .button, .btn, input[type=submit], input[type=button], input[type=reset], .wp-block-button__link{ all:unset }

/* base */
.btn, .button, .wp-block-button__link, button.button,
input[type=submit], input[type=button], input[type=reset], a.button{
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  min-height:44px; padding:0 22px; border-radius:var(--pill);
  font:600 16px/1 inherit; letter-spacing:.2px; cursor:pointer; user-select:none;
  box-shadow:var(--shadow);
  transition:transform .12s ease, background-color .15s ease, opacity .2s ease, border-color .15s ease;
  color:#fff; /* variants set backgrounds */
}

/* GREEN CTA */
.btn--green, .button.is-cta, .wp-block-button .wp-block-button__link.is-cta, a.button.is-cta{
  background:var(--accent-green)!important; color:#fff!important; border:0!important;
}
.btn--green:hover{ background:var(--accent-green-hover)!important }
.btn--green:active{ background:var(--accent-green-press)!important; transform:translateY(1px) }
.btn--green:focus-visible{ outline:none; box-shadow:var(--shadow), var(--ring) }

/* DARK (normal) */
.btn--dark, .button.is-dark, .wp-block-button .wp-block-button__link.is-dark, a.button.is-dark{
  background:var(--btn-dark)!important; color:#fff!important; border:1px solid var(--btn-dark-border)!important;
}
.btn--dark:hover{ background:var(--btn-dark-hover)!important; border-color:#3A3A3A!important }
.btn--dark:active{ background:var(--btn-dark-press)!important; transform:translateY(1px); box-shadow:var(--shadow-press) }
.btn--dark:focus-visible{ outline:none; box-shadow:var(--shadow), 0 0 0 2px rgba(255,255,255,.06), var(--ring) }

/* sizes */
.btn--sm{ min-height:36px; padding:0 14px; font-size:14px; border-radius: 40px !important; }
.btn--lg{ min-height:52px; padding:0 26px; font-size:17px; border-radius: 40px !important; }
.btn--xl{ min-height:58px; padding:0 30px; font-size:18px; border-radius: 40px !important; }
.btn--block{ display:flex; width:100% }

/* Gutenberg outline mapped to green */
.wp-block-button.is-style-outline .wp-block-button__link{
  background:transparent!important; color:var(--accent-green)!important;
  border:2px solid var(--accent-green)!important; border-radius:var(--pill)!important;
}
.wp-block-button.is-style-outline .wp-block-button__link:hover{ background:var(--accent-green)!important; color:#fff!important }

/* disabled & loading */
.btn[disabled], .button[disabled], .wp-block-button__link[disabled],
.btn.is-disabled, .button.is-disabled{ opacity:.55; cursor:not-allowed; transform:none; box-shadow:none }
.btn.is-loading{ position:relative; color:transparent!important }
.btn.is-loading::after{
  content:""; position:absolute; inset:0; margin:auto; width:18px; height:18px; border-radius:50%;
  border:2px solid rgba(255,255,255,.55); border-top-color:#fff; animation:jx-spin .8s linear infinite;
}
@keyframes jx-spin{ to{ transform:rotate(360deg) } }

/* -------------------------------------------------------------
   Cards & niceties (unchanged)
------------------------------------------------------------- */
.card{ transition:transform .3s ease, box-shadow .3s ease }
.card:hover{ transform:translateY(-5px); box-shadow:0 8px 16px rgba(0,0,0,.2) }
@keyframes fadeInUp{ from{opacity:0; transform:translateY(30px)} to{opacity:1; transform:translateY(0)} }
section{ animation:fadeInUp .6s ease both }

/* Icons */
.icon, .service-icon, .about-icon, .contact-icon{
  width:2.5rem; height:2.5rem; fill:currentColor; color:var(--accent-green); display:inline-block; margin-bottom:.75rem
}
.contact-icon{ width:1.5rem; height:1.5rem; margin-right:.5rem; margin-bottom:0; vertical-align:middle }

/* Mobile menu fallback (WP’s default menu block id) */
@media (max-width:768px){ ul#menu-primary-menu-1{ display:block!important } }
ul#menu-primary-menu-1{ display:block }

/* Utilities */
.btn-group{ display:flex; flex-wrap:wrap; gap:12px }
.btn-group-vertical>.btn, .btn-group>.btn {
    position: relative;
    flex: 0.1 0.1 auto;
}

/* =========================
   HOMEPAGE HERO BANNER (scoped)
   ========================= */
.hero-banner{
  position:relative;
  color:#fff;
  background: radial-gradient(1200px 800px at 50% -10%, #101215 0%, #0b0c0e 45%, #090a0b 70%, #080808 100%);
  isolation:isolate;
  overflow:clip;
  min-height:72svh;
  max-height:92svh;
  padding-block: clamp(72px, 7vw, 120px) clamp(24px, 6vw, 56px);
  display:grid;
  grid-template-rows:auto 1fr;
}

/* soft green glows */
.hero-banner::before{
  content:"";
  position:absolute; inset:-20% -10% -30%;
  background:
    radial-gradient(900px 500px at 50% 0%, rgba(67,148,108,.12), transparent 60%),
    radial-gradient(600px 400px at 15% 10%, rgba(67,148,108,.07), transparent 60%),
    radial-gradient(600px 400px at 85% 10%, rgba(67,148,108,.07), transparent 60%);
  pointer-events:none;
  z-index:0;
}

.hero-inner{ position:relative; z-index:3; max-width:1120px; margin-inline:auto; }
.hero-eyebrow{
  margin:0 0 14px 2px;
  font-size: 20px;
  letter-spacing:.04em;
  color: #a3d442;
}
.hero-title{
  font-weight:100;
  letter-spacing:.03em;
  line-height:1.2;
  font-size:clamp(40px, 8vw, 72px);
  margin:0 0 clamp(22px, 3.2vw, 28px);
}
.hero-title .hero-accent{ color:#fff; }
.hero-ctas{ margin-top:6px; } /* uses your .btn-group layout */

/* ---------- Floating Honeycomb (particle layer) ---------- */
.honeycomb{
  position:absolute; inset:0; z-index:1; pointer-events:none;
}

/* Elements are positioned/animated by JS via transform+opacity */
.hex{ 
  position:absolute; left:0; top:0;
  transform:translate(-50%,-50%) rotate(0deg) scale(1);
  opacity:0;
  will-change: transform, opacity;
  filter: drop-shadow(0 8px 22px rgba(67,148,108,.35));
  contain: layout paint style; /* perf hint */
}

/* solid hexagon */
.hex.solid{
  aspect-ratio:1 / 1;
  background:#a3d442;
  clip-path:polygon(25% 6.7%, 75% 6.7%, 100% 50%, 75% 93.3%, 25% 93.3%, 0% 50%);
  opacity: 0.3;
}

/* ---------- Angled collage strip (above honeycomb) ---------- */
.hero-strip{
  position:relative; z-index:2;
  max-width:1400px;
  margin:clamp(28px, 6vw, 56px) auto 0;
  padding-inline:24px;
}
.strip-img{
  position:relative; display:block;
  transform-origin:center; transform:rotate(-0deg);
  border-radius:18px; overflow:hidden;
  border:1px solid rgba(255,255,255,.06);
  box-shadow:0 10px 30px rgba(0,0,0,.45), 0 40px 80px rgba(0,0,0,.35);
}
.strip-img img{
  width:100%; height:auto; display:block;
  -webkit-mask-image:linear-gradient(180deg, rgba(0,0,0,0) 0%, #000 10%, #000 90%, rgba(0,0,0,0) 100%);
          mask-image:linear-gradient(180deg, rgba(0,0,0,0) 0%, #000 10%, #000 90%, rgba(0,0,0,0) 100%);
}

/* Responsive */
@media (max-width:991.98px){
  .hero-title{ font-size:clamp(36px, 8.5vw, 56px); }
}
@media (max-width:767.98px){
  .hero-banner{ min-height:76svh; max-height:86svh !important; padding-block:72px 28px; }
  .strip-img{ transform:rotate(0deg); border-radius:16px; }
  .strip-img img{
    -webkit-mask-image:linear-gradient(180deg, rgba(0,0,0,0) 0%, #000 8%, #000 92%, rgba(0,0,0,0) 100%);
            mask-image:linear-gradient(180deg, rgba(0,0,0,0) 0%, #000 8%, #000 92%, rgba(0,0,0,0) 100%);
  }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .honeycomb{ display:none; }
  .strip-img{ transform:none; }
}

/* =========================
   FOOTER v2 (matches reference)
   ========================= */
.site-footer-v2{
  background: var(--header-bg, #0d0d0d);
  color:#eaeaea;
  border-top:1px solid rgba(255,255,255,.06);
  padding:48px 0 22px;
  font-synthesis-weight:none;
}
.site-footer-v2 a{ color:#dcdcdc; text-decoration:none; }
.site-footer-v2 a:hover{ color:#fff; }

/* Top */
.site-footer-v2 .footer-top{
  display:grid;
  grid-template-columns: minmax(280px, 1fr) minmax(340px, 520px);
  gap:48px;
  align-items:start;
}
@media (max-width: 900px){
  .site-footer-v2 .footer-top{ grid-template-columns: 1fr; gap:32px; }
}

/* Brand block */
.footer-brand .brand-lockup{
  display:inline-flex; align-items:center; gap:12px;
  padding:8px 14px;
  border-radius: 9999px;
  color:#fff;
}
.footer-brand .brand-lockup img{ height:28px; width:auto; display:block; }
.footer-brand .brand-wordmark{ font-weight:700; font-size:22px; letter-spacing:.2px; }

.footer-brand .brand-tagline{
  margin:10px 0 18px;
  color:#bdbdbd;
  font-size:15px;
}

/* Socials */
.footer-social{ display:flex; gap:14px; list-style:none; padding:0; margin:0; }
.footer-social .jx-ico{
  width:22px; height:22px; display:block;
  color:#cfcfcf;
  transition: transform .15s ease, color .15s ease, opacity .2s ease;
  opacity:.9;
}
.footer-social a:hover .jx-ico{ color:#fff; transform:translateY(-1px); }

/* Columns */
.footer-cols{ display:grid; grid-template-columns: 1fr 1fr; gap:36px; }
@media (max-width: 520px){ .footer-cols{ grid-template-columns: 1fr; } }

.footer-col-title{
  margin:0 0 10px; color:#fff; font-weight:700; letter-spacing:.02em; font-size:18px;
}
.footer-menu{ list-style:none; margin:0; padding:0; display:grid; gap:8px; }
.footer-menu a{ color:#d7d7d7; font-size:15px; }
.footer-menu a:hover{ color:#fff; }

/* Divider */
.footer-divider{
  margin:32px 0 18px;
  border:0; height:1px; background:rgba(255,255,255,.08);
}

/* Bottom bar */
.footer-bottom{
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  flex-wrap:wrap;
}
.copyright{ margin:0; font-size:14px; color:#cfcfcf; }
.copyright .brand-inline{ color:var(--jx-green, #07A560); }
.copyright .brand-inline:hover{ color:var(--jx-green-hover, #099C5C); }

.legal-menu{ list-style:none; display:flex; gap:24px; margin:0; padding:0; }
.legal-menu a{ color:#cfcfcf; font-size:14px; }
.legal-menu a:hover{ color:#fff; }

/* =========================
   QUOTE (Dark Card)
   ========================= */
.quote-dark{
  background: #0d0d0d; /* matches header/footer dark */
  color:#eaeaea;
  padding: clamp(48px, 6vw, 96px) 0;
}

.quote-dark .quote-grid{
  display:grid;
  grid-template-columns: minmax(240px, 1fr) minmax(420px, 640px);
  gap: clamp(28px, 5vw, 56px);
  align-items:start;
}
@media (max-width: 980px){
  .quote-dark .quote-grid{ grid-template-columns: 1fr; }
}

/* Left headline block */
.quote-dark .quote-eyebrow{
  margin:0 0 14px 2px;
  font-size: 20px;
  letter-spacing:.04em;
  color: #a3d442;
}
.quote-dark .quote-title{
  color:#fff;
  font-weight: 100;
  letter-spacing: 0px;
  line-height: 1.2;
  font-size: clamp(28px, 5.2vw, 48px);
  margin: 0 0 clamp(22px, 3.2vw, 28px);
}
.quote-dark .quote-sub{
  margin:0;
  color:#bdbdbd;
  font-size:16px;
}

/* Card */
.quote-dark .quote-card{
  background:#0f0f0f;
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px;
  box-shadow: 0 1px 0 rgba(255,255,255,.03) inset, 0 10px 24px rgba(0,0,0,.35);
  padding: clamp(16px, 2.6vw, 28px);
}

/* Grid form */
.quote-dark .quote-form{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.quote-dark .quote-form .field--full{ grid-column: 1 / -1; }
@media (max-width: 680px){
  .quote-dark .quote-form{ grid-template-columns: 1fr; }
}

/* Fields */
.quote-dark .field{ display:flex; flex-direction:column; gap:8px; }
.quote-dark label{
  color:#cfcfcf; font-weight:600; font-size:14px;
}
.quote-dark input,
.quote-dark select,
.quote-dark textarea{
  width:100%;
  color:#f0f0f0;
  background:#111;
  border:1px solid #232323;
  border-radius:10px;
  padding:14px 14px;
  font:400 16px/1.3 "Product Sans", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  transition: border-color .15s ease, box-shadow .15s ease, background-color .15s ease;
}
.quote-dark input::placeholder,
.quote-dark textarea::placeholder{ color:#7a7a7a; }

.quote-dark input:focus,
.quote-dark select:focus,
.quote-dark textarea:focus{
  outline:none;
  border-color: var(--jx-green, #07A560);
  box-shadow: var(--jx-ring, 0 0 0 3px rgba(7,165,96,.35));
}

/* Select tidy */
.quote-dark select{
  appearance:none; -moz-appearance:none; -webkit-appearance:none;
  background-image:
    linear-gradient(45deg, transparent 50%, #9a9a9a 50%),
    linear-gradient(135deg, #9a9a9a 50%, transparent 50%),
    linear-gradient(to right, transparent, transparent);
  background-position:
    calc(100% - 18px) calc(50% - 3px),
    calc(100% - 12px) calc(50% - 3px),
    100% 0;
  background-size: 6px 6px, 6px 6px, 2.5em 100%;
  background-repeat:no-repeat;
  padding-right:42px;
}

/* Button row + note */
.quote-dark .actions{ grid-column: 1 / -1; margin-top: 6px; text-align: center; }
.quote-dark .quote-note{
  grid-column: 1 / -1;
  text-align:center;
  margin: 10px 0 0;
  color:#a7a7a7;
  font-size: 13px;
}

/* Alert */
.quote-dark .quote-alert{
  margin-bottom:14px;
  border-radius:10px;
  padding:12px 14px;
  font-size:14px;
}
.quote-dark .quote-alert.success{
  background: rgba(7,165,96,.12);
  border:1px solid rgba(7,165,96,.35);
  color:#dfffe9;
}

/* =========================
   ACCORDION
   ========================= */

.accordion {
	overflow: hidden;
}

    /* =========================
       BEFORE & AFTER (Dark) — no reveal
       ========================= */
    #before-after.ba-dark{
        background:#0d0d0d; color:#fff;
        padding:clamp(56px,8vw,120px) 0;
    }
    #before-after .ba-wrap{
        display:grid; grid-template-columns:minmax(260px,400px) 1fr;
        gap:clamp(24px,5vw,56px); align-items:start;
    }
    @media (max-width:1024px){ #before-after .ba-wrap{ grid-template-columns:1fr; } }

    #before-after .ba-eyebrow {
		margin: 0 0 14px 2px;
		font-size: 20px;
		letter-spacing: .04em;
		color: #a3d442;
	}
    #before-after .ba-title {
		color: #fff;
		font-weight: 100;
		letter-spacing: 0px;
		line-height: 1.2;
		font-size: clamp(28px, 5.2vw, 48px);
		margin: 0 0 clamp(22px, 3.2vw, 28px);
	}
    #before-after .ba-sub{ margin:8px 0 0; color:#bdbdbd }

    /* Slider shell */
    #before-after .ba-slider{ position:relative }
    #before-after .ba-viewport{ padding-bottom:80px } /* space for nav */

    /* Cards */
    #before-after .ba-card{
        background:#101010; color:#eaeaea;
        border:1px solid rgba(255,255,255,.08);
        border-radius:14px; box-shadow:0 10px 24px rgba(0,0,0,.35);
        padding:0px !important;
    }
    #before-after .ba-media{
        position:relative; border-radius:12px; overflow:hidden;
        background:#0c0c0c; border:1px solid rgba(255,255,255,.06);
        aspect-ratio:16/10;
    }
    #before-after .ba-media img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover }
    #before-after .ba-media img.is-before{ filter:saturate(.85) brightness(.92) }

    #before-after .ba-badge{
        position:absolute; left:10px; top:10px;
        display:inline-flex; align-items:center; gap:8px;
        height:28px; padding:0 12px; border-radius:9999px;
        font-size:13px; font-weight:700; letter-spacing:.02em;
        border:1px solid; user-select:none;
    }
    #before-after .ba-badge .dot{ width:6px; height:6px; border-radius:50% }
    #before-after .ba-badge.before{
        background:#121212; color:#d9d9d9; border-color:#2a2a2a;
    }
    #before-after .ba-badge.before .dot{ background:#9e9e9e }
    #before-after .ba-badge.after{
        background:rgba(7,165,96,.12); color:#dfffe9; border-color:rgba(7,165,96,.35);
    }
    #before-after .ba-badge.after .dot{ background:#07A560 }

    #before-after .ba-caption{ margin:12px 4px 2px; color:#cfcfcf; font-size:14px }

    /* Nav buttons (wired to tiny-slider) */
    #before-after .ba-nav{ position:absolute; left:0; bottom:0; display:flex; gap:12px }
    #before-after .ba-btn{
        width:56px; height:56px; display:inline-flex; align-items:center; justify-content:center;
        border-radius:12px; background:#0f0f0f; border:1px solid rgba(255,255,255,.14);
        color:#bfbfbf; cursor:pointer;
        transition:transform .12s ease, border-color .15s ease, color .15s ease, background .15s ease, opacity .2s ease;
    }
    #before-after .ba-btn:hover{ color:#fff; border-color:rgba(255,255,255,.28); transform:translateY(-1px) }
    #before-after .ba-btn:active{ transform:translateY(1px) }
    #before-after .ba-btn[disabled]{ opacity:.35; cursor:not-allowed; transform:none }
    #before-after .chev{ width:22px; height:22px }
    #before-after .ba-btn:focus-visible{ outline:none; box-shadow:0 0 0 3px rgba(7,165,96,.35) }

/* =========================
   SERVICES — Dark grid look
   ========================= */
#services.services-dark{
  background:#0d0d0d;
  color:#fff;
  padding:clamp(56px, 8vw, 120px) 0;
}

#services.services-dark .services-title{
  margin:0 0 clamp(26px, 3vw, 38px);
  font-weight:100;
  letter-spacing:.02em;
  line-height:1.15;
  font-size:clamp(28px, 4.8vw, 48px);
  color:#fff;
}

/* make the row breathe on large screens */
#services.services-dark .services-grid{ row-gap:32px }

/* Card look */
#services.services-dark .card{
  background:#111111;
  border-radius:16px;
  box-shadow:none;
  padding:28px !important;
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

#services.services-dark .card:hover{
  transform:translateY(-4px);
  border-color:rgba(255,255,255,.22);
  box-shadow:0 10px 24px rgba(0,0,0,.35);
}

/* Icon */
#services.services-dark .service-icon{
  width:42px; height:42px;
  color:var(--accent-green, var(--jx-green, #07A560));
  margin-bottom:6px;
}

/* Titles & copy inside cards */
#services.services-dark .services-card-title{
  margin:6px 0 8px;
  font-weight:700;
  color:#fff;
}

#services.services-dark .services-card-text{
  margin:0 auto 6px;
  max-width:36ch;
  color:#cfcfcf;
  font-size:15px;
  line-height:1.6;
}

/* Link */
#services.services-dark .services-link{
  color:#b9f3d4; /* light mint on dark */
  text-decoration:none;
  font-weight:600;
}
#services.services-dark .services-link:hover{
  color:#fff;
  text-decoration:underline;
}

/* Services footer CTA */
#services.services-dark .services-actions{
  margin-top: clamp(16px, 4vw, 32px);
  text-align: center;
}

/* =========================
   Team (Dark)
   ========================= */
#team.team-dark{
  background:#0d0d0d;
  color:#fff;
  padding: clamp(56px, 8vw, 120px) 0;
}

#team .team-inner{ max-width:1120px; margin-inline:auto; }

#team .team-head{ text-align:left; max-width:820px; margin:0 auto clamp(28px, 5vw, 48px); }
@media (max-width: 860px){ #team .team-head{ text-align:center; } }

#team .team-eyebrow{
  margin:0 0 14px 2px;
  font-size:20px;
  letter-spacing:.04em;
  color:#a3d442;
}
#team .team-title{
  margin:0;
  font-weight:100;
  letter-spacing:.02em;
  line-height:1.15;
  font-size:clamp(28px, 4.8vw, 48px);
  color:#fff;
}
#team .team-sub{
  margin:10px 0 0;
  color:#bdbdbd;
  max-width:60ch;
}

/* Grid of people */
#team .team-grid{
  list-style:none; margin: clamp(22px, 5vw, 40px) 0 0; padding:0;
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: clamp(20px, 3vw, 36px);
  align-items:start; justify-items:center;
}

/* Card */
#team .team-card{ text-align:center; }

#team .team-figure{ display:flex; flex-direction:column; align-items:center; gap:14px; }

#team .team-avatar{
  width:128px; height:128px;
  border-radius:50%;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.12);
  box-shadow: 0 10px 24px rgba(0,0,0,.35);
  background:#0f0f0f;
}
@media (min-width:1200px){
  #team .team-avatar{ width:140px; height:140px; }
}
#team .team-avatar img{ width:100%; height:100%; object-fit:cover; display:block; }

#team .team-name{
  margin:0;
  font-weight:700;
  letter-spacing:.02em;
  color:#fff;
  font-size:18px;
}
#team .team-role{
  margin:2px 0 0;
  color:#cfcfcf;
  font-size:14px;
}



/* -------------------------------------------------------------
   Service (Dark)
------------------------------------------------------------- */
.service-dark{
  background:#0d0d0d;
  color:#dcdcdc;
}

.service-hero{
  position:relative;
  overflow:hidden;
  color:#fff;
}

.service-hero-media{
  position:absolute;
  inset:0;
  z-index:0;
}

.service-hero-media img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.service-hero-inner{
  position:relative;
  z-index:1;
  max-width:var(--jx-max);
  margin:0 auto;
  padding:clamp(80px,12vw,180px) 16px;
  text-align:center;
}

.service-eyebrow{
  margin:0 0 12px;
  letter-spacing:.05em;
  text-transform:uppercase;
  color:var(--jx-green);
  font-size:1rem;
  font-weight:600;
}

.service-title{
  margin:0 0 16px;
  font-weight:100;
  letter-spacing:.02em;
  font-size:clamp(32px,6vw,56px);
  color:#fff;
}

.service-sub{
  margin:0 auto 24px;
  max-width:640px;
  color:#dcdcdc;
  font-size:clamp(18px,2vw,22px);
  line-height:1.6;
}

.service-ctas{
  display:flex;
  flex-wrap:wrap;
  gap:16px;
  justify-content:center;
}

.service-body{
  padding:clamp(56px,8vw,120px) 0;
}

.service-body .narrow{
  max-width:820px;
}

.service-content{
  line-height:1.75;
}

.service-content h2,
.service-content h3,
.service-content h4{
  color:#fff;
  margin-top:2rem;
  margin-bottom:1rem;
}

.service-content a{color:var(--jx-green);}

/* ==============================
   Homepage — About / Why Jettex V2
   ============================== */
#about-v2.about-v2{
  background:#0d0d0d; color:#fff;
  padding: clamp(56px, 8vw, 120px) 0;
}
.about-v2-inner{ max-width:1120px; margin-inline:auto; }

/* Head */
.about-eyebrow{
  margin:0 0 14px 2px;
  font-size:20px; letter-spacing:.04em; color:#a3d442;
}
.about-title{
  margin:0 0 10px;
  font-weight:100; letter-spacing:.02em; line-height:1.2;
  font-size: clamp(28px, 5.2vw, 48px);
}
.about-sub{
  margin:10px 0 22px; color:#bdbdbd; max-width:60ch;
}

/* Gallery row */
.about-v2-gallery{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin: clamp(16px, 3vw, 26px) 0 clamp(30px, 4vw, 42px);
}
.about-shot{
  margin:0; border-radius:16px; overflow:hidden;
  border:1px solid rgba(255,255,255,.08);
  box-shadow: 0 10px 24px rgba(0,0,0,.35);
  background:#101010;
}
.about-shot img{ display:block; width:100%; height:100%; object-fit:cover; }

/* Benefits area */
.about-v2-benefits{
  display:grid;
  grid-template-columns: minmax(260px, 1fr) minmax(420px, 1.3fr);
  gap: clamp(22px, 5vw, 48px);
  align-items:start;
}
@media (max-width: 980px){
  .about-v2-benefits{ grid-template-columns: 1fr; }
}

.benefits-title{
  margin:0 0 8px; font-weight:100; letter-spacing:.02em;
  line-height:1.2; font-size: clamp(22px, 3.6vw, 34px);
}
.benefits-sub{ margin:0; color:#bdbdbd; }

/* Card grid */
.benefits-grid{
  list-style:none; padding:0; margin:0;
  display:grid; gap:16px;
  grid-template-columns: 1fr 1fr;
}
@media (max-width: 640px){
  .benefits-grid{ grid-template-columns: 1fr; }
}
.benefit-card{
  display:flex; gap:16px; align-items:flex-start;
  background:#101010;
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px;
  box-shadow: 0 1px 0 rgba(255,255,255,.03) inset, 0 10px 24px rgba(0,0,0,.35);
  padding:18px;
}
.benefit-ico{
  flex:0 0 40px; height:40px; display:grid; place-items:center;
  border-radius:10px;
  background: rgba(67,148,108,.10);
  border:1px solid rgba(67,148,108,.35);
  color: var(--accent-green, #43946c);
}
.benefit-ico svg{ width:20px; height:20px; }
.benefit-title{
  margin:0 0 .25rem; color:#fff; font-size:1.05rem; line-height:1.25;
}
.benefit-text{ margin:0; color:#bdbdbd; font-size:.95rem; line-height:1.55; }

/* CTA */
.about-v2-cta{ margin-top: clamp(20px, 4vw, 36px); text-align:center; }
.btn{ all:unset; display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  min-height:48px; padding:0 24px; border-radius:9999px; font:600 16px/1 "Product Sans", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  cursor:pointer; color:#fff; box-shadow:0 2px 0 rgba(0,0,0,.25);
}
.btn--lg{ min-height:54px; padding:0 28px; font-size:17px; }
.btn--green{ background: var(--accent-green, #43946c); }
.btn--green:hover{ background: var(--accent-green-hover, #099C5C); }
.btn--green:active{ background: var(--accent-green-press, #048551); transform: translateY(1px); }


/* ============================================================
   ABOUT v2 — Difference (Benefits cards) & Process (Positions list)
   ============================================================ */

.about-dark{background:#0d0d0d;color:#fff;}

.about-hero{position:relative;text-align:center;padding:clamp(80px,12vw,160px) 0;overflow:hidden;}
.about-hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:40px 40px;z-index:0;}
.about-hero-inner{position:relative;z-index:1;max-width:960px;margin:0 auto;}
.about-hero-title{font-size:clamp(32px,6vw,64px);font-weight:400;line-height:1.2;margin:0 auto;}

.about-stats{list-style:none;margin:clamp(48px,8vw,80px) 0 0;padding:0;display:flex;flex-wrap:wrap;justify-content:center;gap:clamp(32px,6vw,96px);}
.about-stat{text-align:center;}
.about-stat-num{display:block;color:var(--accent-green);font-size:clamp(28px,4vw,40px);font-weight:500;}
.about-stat-label{display:block;margin-top:8px;color:rgba(255,255,255,.6);font-size:.875rem;letter-spacing:.02em;}

.about-story,.about-section{padding:clamp(64px,10vw,120px) 0;}
.about-story-title,.about-section-title{font-size:clamp(24px,4vw,32px);font-weight:400;margin-bottom:1.5rem;}
.about-story-content,.about-section-content{color:rgba(255,255,255,.75);line-height:1.7;max-width:680px;}
.about-story-content p,.about-section-content p{margin-bottom:1.25rem;}
.about-section-content ul{margin-bottom:1.25rem;padding-left:1.25rem;}
.about-section-content li{margin-bottom:.5rem;}

/* Shared section wrapper */
.jtx-section{
  background: var(--header-bg, #0d0d0d);
  color:#eaeaea;
  padding: clamp(48px, 6vw, 96px) 0;
}

/* Eyebrow + Title (matches hero/quote styles) */
.jtx-eyebrow{
  margin:0 0 14px 2px;
  font-size:20px;
  letter-spacing:.04em;
  color:#a3d442;
}
.jtx-title{
  color:#fff;
  font-weight:100;
  letter-spacing:.02em;
  line-height:1.2;
  font-size:clamp(28px, 5.2vw, 48px);
  margin:0 0 clamp(18px, 2.8vw, 24px);
}

/* ---------- Difference: Benefits-style cards ---------- */
.jtx-difference .jtx-card-grid{
  list-style:none; margin:24px 0 0; padding:0;
  display:grid; gap:16px;
  grid-template-columns:1fr;
}
@media (min-width:640px){ .jtx-difference .jtx-card-grid{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:1024px){ .jtx-difference .jtx-card-grid{ grid-template-columns:repeat(3,1fr); } }

.jtx-difference .jtx-card{
  display:flex; gap:16px; align-items:flex-start;
  background:#0f0f0f;
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px;
  box-shadow: var(--shadow, 0 1px 1px rgba(0,0,0,.06), 0 6px 16px rgba(0,0,0,.10));
  padding:18px;
}

.jtx-difference .jtx-icon{
  flex:0 0 40px; height:40px; display:grid; place-items:center;
  border-radius:10px;
  background: rgba(67,148,108,.08);
  border:1px solid rgba(67,148,108,.35);
}
.jtx-difference .jtx-icon svg{
  width:20px; height:20px; stroke: var(--accent-green, #43946c);
  fill:none; stroke-width:2;
}

.jtx-difference .jtx-card-title{
  margin:0 0 .2rem; color:#fff; font-size:1.05rem; line-height:1.25;
}
.jtx-difference .jtx-card-text{
  margin:0; color:#bdbdbd; font-size:.95rem; line-height:1.55;
}

/* ---------- Process: Open-positions-style list ---------- */
.jtx-process .jtx-positions{
  list-style:none; margin:20px 0 0; padding:0;
  display:grid; gap:12px;
  grid-template-columns:1fr;
}
@media (min-width:900px){ .jtx-process .jtx-positions{ grid-template-columns:1fr 1fr; } }

.jtx-process .jtx-position{
  display:flex; align-items:center; justify-content:space-between; gap:14px;
  background:#101010;
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px;
  padding:16px 16px 16px 18px;
}

.jtx-process .jtx-pos-main{ min-width:0; }
.jtx-process .jtx-pos-title{
  margin:0 0 .35rem; color:#fff; font-size:1rem; line-height:1.2;
  display:flex; align-items:center; gap:10px;
}
.jtx-process .jtx-step{
  display:inline-block; font-weight:600; font-size:.8rem;
  color: var(--accent-green, #43946c);
  background: rgba(67,148,108,.10);
  border:1px solid rgba(67,148,108,.35);
  padding:4px 8px; border-radius:999px;
}
.jtx-process .jtx-pos-meta {
    margin: 0 0 0 43px;
    color: #bdbdbd;
    font-size: .92rem;
    line-height: 1.5;
}

/* CTA button — reuses your tokens; matches .btn--green look */
.jtx-process .jtx-btn{
  flex:0 0 auto;
  background: var(--accent-green, #43946c);
  color:#fff; text-decoration:none;
  border:1px solid rgba(255,255,255,.08);
  border-radius: var(--pill, 9999px);
  padding:10px 14px; font-weight:600; font-size:.92rem;
  transition: transform .08s ease, background-color .15s ease, box-shadow .12s ease;
  box-shadow: 0 2px 0 rgba(0,0,0,.25);
}
.jtx-process .jtx-btn:hover{ background: var(--accent-green-hover, #099C5C); }
.jtx-process .jtx-btn:active{ background: var(--accent-green-press, #048551); transform: translateY(1px); }
.jtx-process .jtx-btn:focus-visible{ outline:none; box-shadow: var(--ring, 0 0 0 3px rgba(7,165,96,.35)); }

/* ============================================================
   CONTACT page
   ============================================================ */

.contact-dark{ background:#0d0d0d; color:#fff; padding: clamp(56px, 8vw, 120px) 0; }
.contact-inner{ display:grid; grid-template-columns:minmax(280px, 560px) minmax(420px, 640px); gap: clamp(24px, 5vw, 56px); align-items:start; }
@media (max-width: 980px){ .contact-inner{ grid-template-columns:1fr; } }

.contact-eyebrow{ margin:0 0 14px 2px; font-size:20px; letter-spacing:.04em; color:#a3d442; }
.contact-title{ margin:0 0 10px; font-weight:100; letter-spacing:.02em; line-height:1.2; font-size: clamp(28px, 5.2vw, 48px); }
.contact-sub{ margin:10px 0 18px; color:#bdbdbd; max-width: 46ch; }

.contact-list{ list-style:none; padding:0; margin: 18px 0 0; display:grid; gap:12px; }
.contact-list li{ display:flex; align-items:center; gap:10px; }
.contact-ico{ width:20px; height:20px; color: var(--accent-green, #43946c); }
.contact-link{ color:#eaeaea; text-decoration:none; }
.contact-link:hover{ color:#fff; text-decoration:underline; }

.contact-card{
  background:#0f0f0f;
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px;
  box-shadow: 0 1px 0 rgba(255,255,255,.03) inset, 0 10px 24px rgba(0,0,0,.35);
  padding: clamp(14px, 2.2vw, 22px);
}

.contact-map{
  height: 280px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.10);
  overflow:hidden;
  margin-bottom: 14px;
}
@media (min-width: 1200px){ .contact-map{ height: 320px; } }

.contact-form{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.contact-form .field--full{ grid-column: 1 / -1; }

.contact-form label{
  color:#cfcfcf; font-weight:600; font-size:14px; margin:0 0 6px; display:block;
}
.contact-form input,
.contact-form textarea{
  width:100%;
  color:#f0f0f0;
  background:#111;
  border:1px solid #232323;
  border-radius:10px;
  padding:14px 14px;
  font:400 16px/1.3 "Product Sans", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  transition: border-color .15s ease, box-shadow .15s ease, background-color .15s ease;
}
.contact-form input::placeholder,
.contact-form textarea::placeholder{ color:#7a7a7a; }

.contact-form input:focus,
.contact-form textarea:focus{
  outline:none;
  border-color: var(--accent-green, #43946c);
  box-shadow: var(--ring, 0 0 0 3px rgba(7,165,96,.35));
}

.actions{ grid-column: 1 / -1; margin-top: 6px; }
.btn{ all:unset; display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  min-height:52px; padding:0 26px; border-radius:9999px; font:600 17px/1 "Product Sans", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  cursor:pointer; color:#fff; box-shadow:0 2px 0 rgba(0,0,0,.25);
}
.btn--green{ background: var(--accent-green, #43946c); }
.btn--green:hover{ background: var(--accent-green-hover, #099C5C); }
.btn--green:active{ background: var(--accent-green-press, #048551); transform: translateY(1px); }

.contact-alert{
  margin: 6px 0 12px; border-radius:10px; padding:12px 14px; font-size:14px;
  border:1px solid; 
}
.contact-alert.success{ background: rgba(7,165,96,.12); border-color: rgba(7,165,96,.35); color:#dfffe9; }
.contact-alert.error{ background: rgba(255,0,0,.08); border-color: rgba(255,0,0,.28); color:#ffd9d9; }


/* =========================
   About — Company Overview (Story v2)
   ========================= */
.about-story-v2{
  background:#0d0d0d; /* matches site dark */
  color:#fff;
  padding: clamp(56px, 8vw, 120px) 0;
  border-top:1px solid rgba(255,255,255,.06); /* subtle top rule like ref */
}
.about-story-v2 .story-inner{ max-width:1120px; margin-inline:auto; }

/* Headline + lead */
.about-story-v2 .story-title{
  margin:0 0 clamp(10px, 1.6vw, 14px);
  font-weight:100;
  letter-spacing:.02em;
  line-height:1.15;
  font-size: clamp(32px, 6vw, 56px); /* big like screenshot */
  color:#fff;
}
.about-story-v2 .story-lead{
  margin:0 0 clamp(28px, 4vw, 36px);
  color:#bdbdbd;
  font-size: clamp(16px, 2vw, 20px);
  max-width: 80ch;
}

/* Two balanced columns */
.about-story-v2 .story-cols{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(22px, 4vw, 40px);
}
@media (max-width: 980px){
  .about-story-v2 .story-cols{ grid-template-columns:1fr; }
}

.about-story-v2 .story-col p{
  margin:0 0 1rem;
  color:#cfcfcf;
  line-height:1.8;
  font-size:16px;
}

/* Minor typographic niceties */
.about-story-v2 em{ font-style:normal; color:#e8e8e8; }
.about-story-v2 strong{ font-weight:700; color:#fff; }

/* =========================
   FAQ — Dark veneer-style
   ========================= */

#faq.faq-dark{
  background:#0d0d0d; color:#fff;
  padding: clamp(56px, 8vw, 120px) 0;
  border-top:1px solid rgba(255,255,255,.06);
}

/* Center the section */
#faq .faq-inner{
  max-width: 880px;         /* nice readable width */
  margin: 0 auto;           /* << center it */
  padding-inline: 20px;
}

/* Heading */
#faq .faq-title{
  margin:0 0 clamp(18px, 2.8vw, 24px);
  font-weight:100; letter-spacing:.02em; line-height:1.15;
  font-size: clamp(28px, 5vw, 42px);
  color:#fff;
}

/* List + items */
#faq .faq-list{}

/* Each item gets a rule above; last gets a rule below */
#faq .faq-item{ border-top:1px solid rgba(255,255,255,.10); }
#faq .faq-item:last-of-type{ border-bottom:1px solid rgba(255,255,255,.10); }

/* Summary row */
#faq .faq-summary{
  display:flex; align-items:center; gap:12px;
  cursor:pointer; list-style:none;
  padding: 18px 0;
}
#faq .faq-summary::-webkit-details-marker{ display:none; }

/* Question text */
#faq .faq-q{
  flex:1 1 auto;
  color:#eaeaea; font-size:16px; line-height:1.5;
  transition: color .2s ease;
}
#faq .faq-item:hover .faq-q{ color:#fff; }

/* Plus / minus toggle (perfectly centered) */
#faq .faq-summary::after{
  content:"+";
  flex:0 0 auto;
  display:inline-flex;
  align-items:center; justify-content:center;
  width:26px; height:26px;           /* equal box ensures true vertical centering */
  border-radius:6px;
  line-height:1;                      /* avoid baseline shift */
  font-size:18px; font-weight:400;
  color:#a9a9a9;
  border:1px solid rgba(255,255,255,.18);
  background:#111;
}
#faq .faq-item[open] .faq-summary::after{
  content:"–";
  font-size:22px;
  color:#d7d7d7;
  border-color: rgba(255,255,255,.26);
}

/* Answer body */
#faq .faq-answer{
  padding: 0 0 18px 0;
  color:#bdbdbd; font-size:15px; line-height:1.75;
  max-width: 68ch;
}
#faq .faq-answer a{
  color: var(--accent-green, #43946c); text-decoration:none; font-weight:600;
}
#faq .faq-answer a:hover{ color:#fff; text-decoration:underline; }

/* Focus ring for accessibility */
#faq .faq-summary:focus-visible{
  outline:none; box-shadow: 0 0 0 3px rgba(7,165,96,.35);
  border-radius:8px;
}


/* =========================
   Quote Modal — Dark card styling
   ========================= */
.modal-quote .modal-backdrop,
.modal-backdrop.show{
  background:#000; opacity:.7;
}

/* Card container */
.modal-quote .jx-card{
  background:#0f0f0f;
  border:1px solid rgba(255,255,255,.10);
  border-radius:16px;
  box-shadow: 0 1px 0 rgba(255,255,255,.03) inset, 0 30px 60px rgba(0,0,0,.55);
  color:#eaeaea;
  overflow:hidden;
}

/* Header */
.modal-quote .jx-header{
  border-bottom:1px solid rgba(255,255,255,.08);
  padding:20px 22px;
  background: linear-gradient(180deg, rgba(255,255,255,.02), transparent);
}
.modal-quote .modal-title{
  margin:0;
  font-weight:100;
  letter-spacing:.02em;
  line-height:1.2;
  font-size: clamp(20px, 3.2vw, 28px);
  color:#fff;
}

/* Close button visible on dark */
.modal-quote .jx-close{
  filter: invert(1) grayscale(1);
  opacity:.8;
}
.modal-quote .jx-close:hover{ opacity:1; }

/* Body padding */
.modal-quote .jx-body{ padding: 22px; }

/* Grid form (2 cols on md+) */
.modal-quote .jx-form{
  display:grid;
  grid-template-columns: 1fr;
  gap: 16px;
}
@media (min-width: 768px){
  .modal-quote .jx-form{
    grid-template-columns: 1fr 1fr;
  }
}
.modal-quote .jx-field{ display:flex; flex-direction:column; gap:8px; }
.modal-quote .jx-full{ grid-column: 1 / -1; }

/* Labels */
.modal-quote .form-label{
  color:#cfcfcf; font-weight:600; font-size:14px; margin:0;
}

/* Inputs / selects / textarea */
.modal-quote .form-control,
.modal-quote .form-select{
  width:100%;
  color:#f0f0f0;
  background:#111;
  border:1px solid #232323;
  border-radius:12px;
  padding:14px 14px;
  min-height:52px;
  font:400 16px/1.3 "Product Sans", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  transition: border-color .15s ease, box-shadow .15s ease, background-color .15s ease;
}
.modal-quote .form-control::placeholder{ color:#7a7a7a; }
.modal-quote textarea.form-control{ min-height:130px; resize:vertical; }

/* Focus ring */
.modal-quote .form-control:focus,
.modal-quote .form-select:focus{
  outline:none;
  border-color: var(--accent-green, #43946c);
  box-shadow: var(--ring, 0 0 0 3px rgba(7,165,96,.35));
}

/* Custom select arrow */
.modal-quote .form-select{
  appearance:none; -webkit-appearance:none; -moz-appearance:none;
  background-image:
    linear-gradient(45deg, transparent 50%, #9a9a9a 50%),
    linear-gradient(135deg, #9a9a9a 50%, transparent 50%),
    linear-gradient(to right, transparent, transparent);
  background-position:
    calc(100% - 18px) calc(50% - 4px),
    calc(100% - 12px) calc(50% - 4px),
    100% 0;
  background-size: 6px 6px, 6px 6px, 2.5em 100%;
  background-repeat: no-repeat;
  padding-right:42px;
}

/* Actions */
.modal-quote .jx-actions{ margin-top: 4px; }
.btn--block{ width:100%; }

/* Optional: smooth open/close */
.modal.fade .modal-dialog{
  transition: transform .2s ease-out;
  transform: translate3d(0, 8px, 0);
}
.modal.show .modal-dialog{ transform: translate3d(0, 0, 0); }

/* =========================
   Services — Why choose Jettex
   ========================= */
#why-choose.why-dark{
  background:#0d0d0d;
  color:#fff;
  padding: clamp(56px, 8vw, 120px) 0;
}

/* Layout: left copy + right cards */
#why-choose .why-inner{
  max-width:1120px;
  margin-inline:auto;
  display:grid;
  grid-template-columns: minmax(260px, 420px) 1fr;
  gap: clamp(24px, 5vw, 56px);
  align-items:start;
}
@media (max-width: 980px){
  #why-choose .why-inner{ grid-template-columns: 1fr; }
}

/* Head block */
#why-choose .why-eyebrow{
  margin:0 0 14px 2px;
  font-size:20px;
  letter-spacing:.04em;
  color:#a3d442;
}
#why-choose .why-title{
  margin:0 0 10px;
  font-weight:100;
  letter-spacing:.02em;
  line-height:1.2;
  font-size: clamp(28px, 5.2vw, 48px);
  color:#fff;
}
#why-choose .why-sub{
  margin:10px 0 0;
  color:#bdbdbd;
  max-width: 44ch;
}

/* Card grid */
#why-choose .why-grid{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(16px, 3vw, 22px);
}
@media (max-width: 640px){
  #why-choose .why-grid{ grid-template-columns:1fr; }
}

/* Card look */
#why-choose .why-card{
  display:flex;
  gap:14px;
  align-items:flex-start;
  background:#101010;
  border:1px solid rgba(255,255,255,.10);
  border-radius:16px;
  padding: clamp(16px, 2.4vw, 22px);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
#why-choose .why-card:hover{
  transform: translateY(-3px);
  border-color: rgba(255,255,255,.22);
  box-shadow: 0 10px 24px rgba(0,0,0,.35);
}

/* Icon badge */
#why-choose .why-ico{
  flex:0 0 auto;
  width:42px; height:42px;
  display:inline-grid; place-items:center;
  border-radius:12px;
  color: var(--accent-green, #43946c);
  background: rgba(67,148,108,.10);
  border:1px solid rgba(67,148,108,.35);
  margin-top:2px;
}

/* Card text */
#why-choose .why-card-title{
  margin:2px 0 6px;
  color:#fff;
  font-weight:700;
  font-size: 18px;
  letter-spacing:.02em;
}
#why-choose .why-card-text{
  margin:0;
  color:#cfcfcf;
  font-size:15px;
  line-height:1.6;
  max-width: 44ch;
}