/* ============================================================
   COUNTRY EQUIPMENT RENTALS — shared stylesheet
   All-blue brand · dark hero · light readable content
   ============================================================ */

/* ---------- TOKENS ---------- */
:root{
  --brand:#2456E8; --brand-ink:#1B45C7; --brand-bright:#5B8CFF; --brand-deep:#0A1B66;
  --brand-glow:rgba(91,140,255,.45);
  --ink:#0A0E16; --ink-2:#0F1524; --ink-3:#161E30;
  --on-ink:#EEF3FB; --on-ink-mut:#9DAAC0; --line-dark:rgba(255,255,255,.10);
  --steel-50:#F5F8FC; --steel-100:#EAEFF6; --steel-200:#D9E1EC; --steel-300:#C0CBDA;
  --steel-500:#8493A8; --steel-700:#475467; --steel-900:#1A2435;
  --paper:#FFFFFF; --paper-2:#F4F7FB; --text:#131A26; --text-mut:#5A6677; --line:#E4EAF2;
  --focus:#5B8CFF; --ok:#1F9D55;
  --r-sm:8px; --r:14px; --r-lg:22px; --r-pill:999px;
  --sh-1:0 1px 2px rgba(16,26,44,.06),0 2px 8px rgba(16,26,44,.06);
  --sh-2:0 10px 30px rgba(16,26,44,.10),0 4px 10px rgba(16,26,44,.06);
  --sh-blue:0 12px 40px rgba(36,86,232,.30);
  --ease:cubic-bezier(.16,1,.3,1); --t:.28s var(--ease);
  --maxw:1200px; --gut:clamp(20px,5vw,40px);
  --nav-h:74px;
  --fs-hero:clamp(2.6rem,7vw,5rem); --fs-h1:clamp(2.1rem,4.5vw,3.4rem);
  --fs-h2:clamp(1.7rem,3.2vw,2.5rem); --fs-h3:clamp(1.2rem,2vw,1.5rem);
  --fs-lead:clamp(1.05rem,1.6vw,1.275rem); --fs-body:1.0625rem; --fs-sm:.9375rem; --fs-xs:.8125rem;
}

/* ---------- RESET ---------- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,sans-serif;font-size:var(--fs-body);line-height:1.65;
  color:var(--text);background:var(--paper);-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;overflow-x:hidden;
}
img,svg,video{display:block;max-width:100%}
img{height:auto}
a{color:var(--brand-ink);text-decoration:none}
a:hover{color:var(--brand)}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
ul{list-style:none;padding:0}
h1,h2,h3,h4{font-family:'Space Grotesk',sans-serif;font-weight:700;line-height:1.08;letter-spacing:-.02em;color:var(--text)}
:focus-visible{outline:3px solid var(--focus);outline-offset:3px;border-radius:4px}
::selection{background:var(--brand);color:#fff}

.skip-link{position:absolute;left:12px;top:-60px;z-index:200;background:var(--brand);color:#fff;
  padding:10px 16px;border-radius:0 0 var(--r-sm) var(--r-sm);transition:top .2s}
.skip-link:focus{top:0;color:#fff}

/* ---------- LAYOUT ---------- */
.container{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gut);width:100%}
.container--wide{max-width:1340px}
.section{padding-block:clamp(64px,9vw,128px);position:relative}
.section--alt{background:var(--paper-2)}
.section--dark{background:var(--ink);color:var(--on-ink)}
.section--dark h1,.section--dark h2,.section--dark h3{color:#fff}
.section[id],section[id]{scroll-margin-top:calc(var(--nav-h) + 16px)}
.section-head{max-width:760px;margin-bottom:clamp(36px,5vw,60px)}
.section-head.center{margin-inline:auto;text-align:center}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:'Space Grotesk',sans-serif;
  font-weight:600;text-transform:uppercase;letter-spacing:.14em;font-size:.78rem;color:var(--brand-ink);margin-bottom:14px}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--brand);border-radius:2px}
.section--dark .eyebrow{color:var(--brand-bright)}
.section--dark .eyebrow::before{background:var(--brand-bright)}
h2{font-size:var(--fs-h2)} h3{font-size:var(--fs-h3)}
.section-head h2{margin-bottom:14px}
.section-sub{font-size:var(--fs-lead);color:var(--text-mut)}
.section--dark .section-sub{color:var(--on-ink-mut)}
.lead{font-size:var(--fs-lead);color:var(--text-mut)}

/* ---------- BUTTONS ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;
  min-height:48px;padding:0 24px;border-radius:var(--r-pill);font-weight:600;font-size:.975rem;
  transition:transform var(--t),box-shadow var(--t),background var(--t),color var(--t);
  white-space:nowrap;cursor:pointer;line-height:1;max-width:100%}
.btn svg{width:19px;height:19px;flex:none}
.btn--primary{background:var(--brand);color:#fff;box-shadow:0 4px 14px rgba(36,86,232,.28)}
.btn--primary:hover{background:#1B47CF;color:#fff;transform:translateY(-2px);box-shadow:var(--sh-blue)}
.btn--call{background:var(--brand);color:#fff;box-shadow:0 4px 14px rgba(36,86,232,.28)}
.btn--call:hover{background:#1B47CF;color:#fff;transform:translateY(-2px);box-shadow:var(--sh-blue)}
.btn--ghost{background:transparent;color:var(--brand-ink);box-shadow:inset 0 0 0 1.5px #6e7b8f}
.btn--ghost:hover{box-shadow:inset 0 0 0 1.5px var(--brand);color:var(--brand);transform:translateY(-2px)}
.section--dark .btn--ghost,.hero .btn--ghost{color:#fff;box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.5)}
.section--dark .btn--ghost:hover,.hero .btn--ghost:hover{box-shadow:inset 0 0 0 1.5px var(--brand-bright);color:#fff}
.btn--lg{min-height:56px;padding:0 32px;font-size:1.05rem}
.btn--block{display:flex;width:100%}

/* ---------- NAV ---------- */
.nav{position:fixed;inset:0 0 auto;z-index:100;height:var(--nav-h);display:flex;align-items:center;
  transition:background var(--t),box-shadow var(--t),height var(--t);background:transparent}
.nav__inner{display:flex;align-items:center;gap:18px;width:100%}
.nav__brand{display:flex;align-items:center;flex:none;margin-right:auto}
.nav__brand img{height:44px;width:auto;transition:height var(--t)}
/* transparent over dark hero, solid when scrolled or on light pages */
.nav.scrolled,.nav--solid{background:rgba(10,14,22,.86);backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--line-dark),0 8px 30px rgba(0,0,0,.28);height:64px}
.nav__links{display:flex;align-items:center;gap:4px}
.nav__links>a,.nav__dropbtn{display:inline-flex;align-items:center;gap:5px;padding:10px 14px;border-radius:var(--r-sm);
  color:rgba(255,255,255,.92);font-weight:500;font-size:.97rem;transition:background .2s,color .2s}
.nav__links>a:hover,.nav__dropbtn:hover{background:rgba(255,255,255,.10);color:#fff}
.nav__links>a[aria-current="page"]{color:var(--brand-bright)}
.nav__dropbtn svg{width:15px;height:15px;transition:transform var(--t)}
.nav__drop{position:relative}
.nav__drop.open .nav__dropbtn svg{transform:rotate(180deg)}
.nav__menu{position:absolute;top:calc(100% + 10px);left:0;min-width:280px;background:var(--ink-2);
  border:1px solid var(--line-dark);border-radius:var(--r);box-shadow:0 24px 60px rgba(0,0,0,.5);
  padding:8px;opacity:0;visibility:hidden;transform:translateY(8px);transition:opacity var(--t),transform var(--t),visibility var(--t)}
.nav__drop.open .nav__menu{opacity:1;visibility:visible;transform:none}
.nav__menu a{display:block;padding:10px 14px;border-radius:var(--r-sm);color:rgba(255,255,255,.86);font-size:.94rem}
.nav__menu a:first-child{color:var(--brand-bright);font-weight:600}
.nav__menu a:hover{background:rgba(91,140,255,.16);color:#fff}
.nav__cta{height:44px;min-height:44px;padding:0 18px;flex:none;font-size:.92rem}
.nav__burger{display:none;width:46px;height:46px;align-items:center;justify-content:center;
  border-radius:var(--r-sm);color:#fff;background:rgba(255,255,255,.10)}
.nav__burger svg{width:24px;height:24px}
/* on light inner pages the un-scrolled nav text needs to be readable: handled by .nav--solid always-on */

/* mobile drawer */
.nav__mobile{position:fixed;inset:0;z-index:99;background:var(--ink);transform:translateX(100%);
  transition:transform .36s var(--ease);display:flex;flex-direction:column;padding:90px 24px 32px;overflow-y:auto;visibility:hidden}
.nav__mobile.open{transform:none;visibility:visible}
.nav__mobile a{color:#fff;font-family:'Space Grotesk',sans-serif;font-size:1.35rem;font-weight:600;padding:13px 0;border-bottom:1px solid var(--line-dark)}
.nav__mobile .m-sub a{font-family:'Inter',sans-serif;font-size:1.02rem;font-weight:500;color:var(--on-ink-mut);padding:11px 0 11px 16px;border:0;min-height:44px;display:flex;align-items:center}
.nav__mobile .m-label{color:var(--brand-bright);font-size:.8rem;text-transform:uppercase;letter-spacing:.14em;margin-top:18px}
.nav__mobile .btn{margin-top:24px}
body.menu-open{overflow:hidden}

/* ---------- HOME HERO (dark + 3D) ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;background:var(--ink);
  color:var(--on-ink);overflow:hidden;padding-top:var(--nav-h)}
.hero__bg{position:absolute;inset:0;z-index:0;
  background:radial-gradient(110% 80% at 75% 18%,#102a8a 0%,#0a1746 38%,var(--ink) 72%)}
.hero__photo{position:absolute;inset:0;z-index:0;overflow:hidden;background:var(--ink)}
.hero__photo img{width:100%;height:100%;object-fit:cover;object-position:68% center;animation:heroZoom 20s ease-out both}
@keyframes heroZoom{from{transform:scale(1.08)}to{transform:scale(1)}}
.hero__overlay{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(100deg,rgba(7,10,17,.94) 0%,rgba(7,10,17,.72) 36%,rgba(7,10,17,.32) 66%,rgba(7,10,17,.55) 100%),linear-gradient(0deg,rgba(7,10,17,.65),rgba(7,10,17,0) 42%)}
.hero__stage{position:relative;min-height:clamp(340px,42vw,520px);border-radius:var(--r-lg);overflow:hidden;background:radial-gradient(120% 100% at 58% 34%,rgba(36,86,232,.30),rgba(10,14,22,0) 68%);box-shadow:inset 0 0 0 1px var(--line-dark)}
#hero-canvas{position:absolute;inset:0;z-index:1;width:100%;height:100%;display:block}
.hero__stage-badge{position:absolute;left:16px;bottom:14px;z-index:2;font-family:'Space Grotesk',sans-serif;font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--brand-bright);background:rgba(10,14,22,.55);border:1px solid var(--line-dark);padding:6px 12px;border-radius:var(--r-pill);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}
.hero__veil{position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(105deg,rgba(10,14,22,.55) 0%,rgba(10,14,22,.12) 42%,rgba(10,14,22,0) 60%),linear-gradient(180deg,rgba(10,14,22,.2) 0%,rgba(10,14,22,0) 30%,rgba(10,14,22,.5) 100%)}
@media(max-width:760px){.hero__veil{background:linear-gradient(180deg,rgba(10,14,22,.74) 0%,rgba(10,14,22,.34) 50%,rgba(10,14,22,.82) 100%)}}
.hero .container{position:relative;z-index:3;width:100%}
.hero__content{max-width:600px;position:relative;z-index:3}
.hero__badge{position:absolute;right:clamp(16px,4vw,40px);bottom:20px;z-index:3;font-family:'Space Grotesk',sans-serif;font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--brand-bright);background:rgba(10,14,22,.5);border:1px solid var(--line-dark);padding:6px 12px;border-radius:var(--r-pill);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}
@media(max-width:760px){.hero__badge{display:none}}
.hero__grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(32px,5vw,64px);align-items:center;padding-block:48px}
.hero__eyebrow{display:inline-flex;align-items:center;gap:9px;background:rgba(91,140,255,.14);
  border:1px solid rgba(91,140,255,.28);color:#cfe0ff;padding:7px 15px;border-radius:var(--r-pill);
  font-size:.8rem;font-weight:600;letter-spacing:.04em;margin-bottom:22px}
.hero__eyebrow b{color:#fff;font-weight:700}
.hero h1{font-size:var(--fs-hero);color:#fff;margin-bottom:20px}
.hero h1 .accent{color:var(--brand-bright)}
.hero__sub{font-size:var(--fs-lead);color:var(--on-ink-mut);max-width:42ch;margin-bottom:30px}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:30px}
.hero__trust{display:flex;flex-wrap:wrap;gap:10px 22px;font-size:.9rem;color:var(--on-ink-mut)}
.hero__trust span{display:inline-flex;align-items:center;gap:7px}
.hero__trust svg{width:17px;height:17px;color:var(--brand-bright)}
/* hero quote card */
.hero-form{background:rgba(16,21,36,.72);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border:1px solid var(--line-dark);border-radius:var(--r-lg);padding:clamp(22px,3vw,30px);box-shadow:0 30px 70px rgba(0,0,0,.45)}
.hero-form h2{font-size:1.3rem;color:#fff;margin-bottom:4px}
.hero-form p{color:var(--on-ink-mut);font-size:.9rem;margin-bottom:18px}

/* ---------- INNER PAGE HERO BAND ---------- */
.pagehero{position:relative;background:var(--ink);color:var(--on-ink);padding:calc(var(--nav-h) + 56px) 0 64px;overflow:hidden}
.pagehero__bg{position:absolute;inset:0;z-index:0;opacity:.28}
.pagehero__bg img{width:100%;height:100%;object-fit:cover}
.pagehero::after{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(105deg,rgba(10,14,22,.94) 40%,rgba(10,23,70,.72) 100%)}
.pagehero .container{position:relative;z-index:2}
.pagehero .crumbs{font-size:.86rem;color:var(--on-ink-mut);margin-bottom:14px}
.pagehero .crumbs a{color:var(--brand-bright)}
.pagehero h1{font-size:var(--fs-h1);color:#fff;max-width:18ch;margin-bottom:14px}
.pagehero p{color:var(--on-ink-mut);font-size:var(--fs-lead);max-width:60ch}
.pagehero .btn{margin-top:26px}
.pagehero__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,5vw,56px);align-items:center}
.pagehero__col .btn{margin-top:24px}
.pagehero-form{background:rgba(16,21,36,.66);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--line-dark);border-radius:var(--r-lg);padding:clamp(20px,2.6vw,28px);box-shadow:0 24px 60px rgba(0,0,0,.4)}
.pagehero-form h2{font-size:1.18rem;color:#fff;margin-bottom:4px}
.pagehero-form p{color:var(--on-ink-mut);font-size:.88rem;margin-bottom:14px}
@media(max-width:880px){.pagehero__grid{grid-template-columns:1fr;gap:26px}}

/* ---------- TRUST BAR ---------- */
.trust-bar{background:var(--ink-2);border-block:1px solid var(--line-dark)}
.trust-bar .container{display:flex;flex-wrap:wrap;justify-content:space-between;gap:20px;padding-block:22px}
.trust-bar .chip{display:flex;align-items:center;gap:11px;color:var(--on-ink);font-weight:500;font-size:.95rem}
.trust-bar .chip svg{width:24px;height:24px;color:var(--brand-bright);flex:none}

/* ---------- GRIDS & CARDS ---------- */
.grid{display:grid;gap:24px;grid-template-columns:minmax(0,1fr)}
.grid--auto{grid-template-columns:repeat(auto-fill,minmax(266px,1fr))}
.grid--2{grid-template-columns:repeat(2,1fr)}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-1);
  transition:transform var(--t),box-shadow var(--t),border-color var(--t);overflow:hidden}
.card:hover{transform:translateY(-4px);box-shadow:var(--sh-2);border-color:var(--steel-200)}

/* category card */
.category-card{display:flex;flex-direction:column;height:100%}
.category-card__img{aspect-ratio:16/10;overflow:hidden;background:var(--steel-100)}
.category-card__img img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.category-card:hover .category-card__img img{transform:scale(1.06)}
.category-card__body{padding:22px 22px 24px;display:flex;flex-direction:column;flex:1}
.category-card h3{margin-bottom:7px}
.category-card p{color:var(--text-mut);font-size:.95rem;margin-bottom:16px;flex:1}
.category-card .more{display:inline-flex;align-items:center;gap:7px;font-weight:600;color:var(--brand-ink);font-size:.92rem}
.category-card .more svg{width:17px;height:17px;transition:transform var(--t)}
.category-card:hover .more svg{transform:translateX(4px)}
.category-card .from{font-size:.82rem;color:var(--text-mut);font-weight:600;text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px}
.category-card .from b{color:var(--text);font-size:1rem}

/* machine card */
.machine-card{display:grid;grid-template-columns:300px 1fr;gap:0;min-width:0}
.machine-card__body{min-width:0}
.machine-card__img{background:var(--steel-100);position:relative;min-height:230px;overflow:hidden}
.machine-card__img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.img-soon{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;text-align:center;padding:18px;background:radial-gradient(130% 110% at 50% 30%,rgba(36,86,232,.22),var(--ink-2));color:var(--brand-bright)}
.img-soon svg{width:48px;height:48px;opacity:.85}
.img-soon b{font-family:'Space Grotesk',sans-serif;font-size:1rem;color:#fff}
.img-soon span{font-size:.82rem;color:var(--on-ink-mut);max-width:24ch;line-height:1.4}
.machine-card__body{padding:clamp(20px,3vw,30px)}
.machine-card h3{margin-bottom:4px}
.machine-card .tag{display:inline-block;font-size:.74rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;
  color:var(--brand-ink);background:rgba(36,86,232,.09);padding:4px 10px;border-radius:var(--r-pill);margin-bottom:14px}
.spec{display:flex;flex-wrap:wrap;gap:8px 10px;margin:0 0 18px}
.spec li{display:inline-flex;align-items:center;gap:7px;background:var(--paper-2);border:1px solid var(--line);
  border-radius:var(--r-pill);padding:6px 13px;font-size:.86rem;color:var(--steel-700);font-variant-numeric:tabular-nums}
.spec li b{color:var(--text);font-weight:600}

/* rate table */
.rate-table{width:100%;table-layout:fixed;border-collapse:collapse;font-variant-numeric:tabular-nums}
.rate-table th,.rate-table td{text-align:center;padding:11px 8px;border:1px solid var(--line)}
.rate-table thead th{background:var(--ink-2);color:#fff;font-family:'Space Grotesk',sans-serif;font-weight:600;
  font-size:.74rem;text-transform:uppercase;letter-spacing:.08em}
.rate-table tbody td{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:1.18rem;color:var(--text)}
.rate-table tbody td .u{display:block;font-family:'Inter';font-weight:500;font-size:.72rem;color:var(--text-mut);letter-spacing:.02em}
.rate-note{font-size:.8rem;color:var(--text-mut);margin-top:9px}
.rate-extra{font-size:.84rem;color:var(--text-mut);margin-top:6px}
.rate-extra b{color:var(--text)}

/* simple price list (attachments/tools) */
.pricelist{columns:2;column-gap:32px}
.pricelist li{break-inside:avoid;display:flex;justify-content:space-between;gap:14px;padding:11px 0;border-bottom:1px solid var(--line)}
.pricelist li b{font-family:'Space Grotesk',sans-serif;color:var(--brand-ink);white-space:nowrap;font-variant-numeric:tabular-nums}
.pricelist li .req{display:block;font-size:.78rem;color:var(--text-mut)}
.hours-list li{display:flex;justify-content:space-between;gap:16px;padding:10px 0;border-bottom:1px solid var(--line);font-size:1rem}
.hours-list li:last-child{border-bottom:0}
.hours-list li span{color:var(--text-mut)}
.hours-list li b{font-weight:600;color:var(--text);font-variant-numeric:tabular-nums}

/* stats */
.stat{text-align:center;padding:8px}
.stat .num{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:clamp(2.2rem,5vw,3.2rem);
  color:var(--brand-bright);line-height:1;font-variant-numeric:tabular-nums}
.section:not(.section--dark) .stat .num{color:var(--brand-ink)}
.stat .lbl{margin-top:9px;color:var(--text-mut);font-size:.92rem}
.section--dark .stat .lbl{color:var(--on-ink-mut)}

/* value / icon feature */
.feature{padding:6px}
.feature .ic{width:54px;height:54px;border-radius:var(--r);display:grid;place-items:center;
  background:rgba(36,86,232,.10);color:var(--brand-ink);margin-bottom:16px}
.section--dark .feature .ic{background:rgba(91,140,255,.14);color:var(--brand-bright)}
.feature .ic svg{width:27px;height:27px}
.feature h3{font-size:1.16rem;margin-bottom:7px}
.feature p{color:var(--text-mut);font-size:.96rem}
.section--dark .feature p{color:var(--on-ink-mut)}

/* steps */
.steps{counter-reset:step}
.step{position:relative;padding-left:0}
.step .n{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:1.05rem;width:42px;height:42px;border-radius:50%;
  display:grid;place-items:center;background:var(--brand);color:#fff;margin-bottom:16px}
.step h3{font-size:1.16rem;margin-bottom:7px}
.step p{color:var(--text-mut);font-size:.96rem}
.section--dark .step p{color:var(--on-ink-mut)}

/* testimonial */
.testimonial{padding:28px 26px;display:flex;flex-direction:column;height:100%}
.testimonial .quote{font-size:1.06rem;line-height:1.6;color:var(--text);margin-bottom:18px;flex:1}
.section--dark .testimonial{background:var(--ink-3);border-color:var(--line-dark)}
.section--dark .testimonial .quote{color:#eef3fb}
.testimonial .stars{display:flex;gap:3px;margin-bottom:14px;color:var(--brand-bright)}
.testimonial .stars svg{width:18px;height:18px;fill:currentColor}
.testimonial .who{font-weight:600;color:var(--text)}
.section--dark .testimonial .who{color:#fff}
.testimonial .who span{display:block;font-weight:500;color:var(--text-mut);font-size:.86rem}
.section--dark .testimonial .who span{color:var(--on-ink-mut)}

/* FAQ */
.faq{max-width:820px;margin-inline:auto}
.faq-item{border:1px solid var(--line);border-radius:var(--r);margin-bottom:12px;background:var(--paper);overflow:hidden}
.faq-item summary{list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:16px;
  padding:18px 22px;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:1.05rem;color:var(--text)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary .pm{width:24px;height:24px;flex:none;position:relative;transition:transform var(--t)}
.faq-item summary .pm::before,.faq-item summary .pm::after{content:"";position:absolute;background:var(--brand);border-radius:2px;inset:0;margin:auto}
.faq-item summary .pm::before{width:14px;height:2px}
.faq-item summary .pm::after{width:2px;height:14px;transition:transform var(--t)}
.faq-item[open] summary .pm::after{transform:scaleY(0)}
.faq-item .ans{padding:0 22px 20px;color:var(--text-mut);font-size:1rem}

/* ---------- FORMS ---------- */
.quote-form{display:grid;gap:14px}
.field{display:grid;gap:6px}
.field.row2{grid-template-columns:1fr 1fr;gap:14px}
.field label,.quote-form .lbl{font-size:.82rem;font-weight:600;color:var(--on-ink-mut);letter-spacing:.02em}
.hero-form .field label{color:var(--on-ink-mut)}
.quote-form input,.quote-form select,.quote-form textarea{
  width:100%;padding:13px 15px;border-radius:var(--r-sm);border:1px solid var(--line-dark);
  background:rgba(255,255,255,.06);color:#fff;font:inherit;font-size:.97rem;transition:border-color .2s,background .2s}
.quote-form input::placeholder,.quote-form textarea::placeholder{color:#aab4c6}
.quote-form select{color:#fff}
.quote-form select option{color:#111}
.quote-form input:focus,.quote-form select:focus,.quote-form textarea:focus{
  outline:none;border-color:var(--brand-bright);background:rgba(255,255,255,.10)}
.quote-form textarea{min-height:92px;resize:vertical}
/* light form variant (contact page) */
.quote-form--light input,.quote-form--light select,.quote-form--light textarea{
  background:var(--paper);color:var(--text);border-color:var(--line)}
.quote-form--light input::placeholder,.quote-form--light textarea::placeholder{color:var(--text-mut)}
.quote-form--light label,.quote-form--light .lbl{color:var(--text-mut)}
.quote-form--light select{color:var(--text)}
.hp{position:absolute!important;left:-9999px}

/* ---------- CTA BAND ---------- */
.cta-band{background:linear-gradient(120deg,var(--brand-deep),#123,#0a1230);position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;width:520px;height:520px;border-radius:50%;
  background:radial-gradient(circle,var(--brand-glow),transparent 65%);top:-160px;right:-120px;filter:blur(12px);pointer-events:none}
.cta-band .container{position:relative;z-index:1;text-align:center;display:flex;flex-direction:column;align-items:center}
.cta-band h2{color:#fff;font-size:var(--fs-h2);max-width:20ch;margin-bottom:14px}
.cta-band p{color:#cfe0ff;font-size:var(--fs-lead);max-width:54ch;margin-bottom:28px}
.cta-band .btns{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}
.cta-phone{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:clamp(1.5rem,3vw,2rem);color:#fff;margin-top:8px;display:inline-flex;gap:10px;align-items:center}
.cta-phone svg{width:26px;height:26px;color:var(--brand-bright)}

/* ---------- FOOTER ---------- */
.footer{background:#070a11;color:var(--on-ink-mut);padding-top:clamp(56px,7vw,88px)}
.footer__grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.3fr;gap:40px 32px;padding-bottom:48px}
.footer__brand img{height:64px;width:auto;margin-bottom:18px}
.footer__brand p{font-size:.95rem;max-width:34ch;margin-bottom:18px}
.footer a{color:var(--on-ink-mut)}
.footer a:hover{color:#fff}
.footer h4{color:#fff;font-size:.82rem;text-transform:uppercase;letter-spacing:.12em;font-family:'Space Grotesk',sans-serif;margin-bottom:16px}
.footer__col li{margin-bottom:0;font-size:.94rem}
.footer__col li a{display:inline-flex;align-items:center;min-height:40px}
.footer__contact a{display:flex;gap:10px;align-items:flex-start;margin-bottom:10px;font-size:.94rem;min-height:40px}
.footer__contact svg{width:18px;height:18px;color:var(--brand-bright);flex:none;margin-top:3px}
.footer__hours{font-size:.9rem;line-height:1.9;margin-top:6px}
.footer__hours b{color:#fff}
.footer__bottom{border-top:1px solid var(--line-dark);padding-block:22px;display:flex;flex-wrap:wrap;
  justify-content:space-between;gap:12px;font-size:.84rem}
.footer__bottom a{color:var(--brand-bright)}

/* ---------- REVEAL ANIMATIONS ---------- */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.from-left{transform:translateX(-40px)}
.reveal.from-right{transform:translateX(40px)}
.reveal.scale-up{transform:scale(.94)}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.07s}.d2{transition-delay:.14s}.d3{transition-delay:.21s}
.d4{transition-delay:.28s}.d5{transition-delay:.35s}.d6{transition-delay:.42s}

/* ---------- UTILITIES ---------- */
.center{text-align:center}.mt-0{margin-top:0}.mb-0{margin-bottom:0}
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,64px);align-items:center}
.media-frame{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-2);aspect-ratio:4/3;background:var(--steel-100)}
.media-frame img{width:100%;height:100%;object-fit:cover}
.map-card{display:flex;align-items:center;gap:20px;padding:clamp(24px,4vw,44px);border-radius:var(--r-lg);box-shadow:var(--sh-2);color:#fff;
  background-image:linear-gradient(135deg,rgba(10,27,102,.95),rgba(10,14,22,.97)),repeating-linear-gradient(0deg,transparent 0 38px,rgba(91,140,255,.13) 38px 39px),repeating-linear-gradient(90deg,transparent 0 38px,rgba(91,140,255,.13) 38px 39px);
  transition:transform var(--t),box-shadow var(--t)}
.map-card:hover{transform:translateY(-3px);box-shadow:var(--sh-blue);color:#fff}
.map-card__pin{flex:none;width:62px;height:62px;border-radius:50%;display:grid;place-items:center;background:rgba(91,140,255,.18);color:var(--brand-bright)}
.map-card__pin svg{width:30px;height:30px}
.map-card__txt b{display:block;font-family:'Space Grotesk',sans-serif;font-size:1.18rem;margin-bottom:5px}
.map-card__txt span{color:var(--on-ink-mut);font-size:.95rem}
.prose p{margin-bottom:16px;color:var(--steel-700)}
.prose p:last-child{margin-bottom:0}

/* ---------- RESPONSIVE ---------- */
@media(max-width:1024px){
  .grid--4{grid-template-columns:repeat(2,1fr)}
  .footer__grid{grid-template-columns:1fr 1fr;gap:36px}
}
@media(max-width:900px){
  .nav__links,.nav__cta{display:none}
  .nav__burger{display:flex}
  .nav{height:64px}
  .hero__grid{grid-template-columns:1fr;gap:36px}
  .hero-form{order:2}
  .machine-card{grid-template-columns:1fr}
  .machine-card__img{height:210px;min-height:0}
}
@media(max-width:760px){
  .grid--2,.grid--3,.split{grid-template-columns:1fr}
  .pricelist{columns:1}
  .rate-table tbody td{font-size:1.05rem}
  .trust-bar .container{justify-content:flex-start}
}
@media(max-width:560px){
  .grid--4{grid-template-columns:1fr}
  .field.row2{grid-template-columns:1fr}
  .hero{min-height:auto;padding-bottom:48px}
  .footer__grid{grid-template-columns:1fr}
  .rate-table thead th{font-size:.66rem}
}

/* ---------- REDUCED MOTION ---------- */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
  .category-card:hover .category-card__img img{transform:none}
}
