/* ═══════════════════════════════════════════════
   BEST AMERICAN TOWING v2
   Editorial / Magazine — Photo-Oriented
   Palette: Red · White · Black
   ═══════════════════════════════════════════════ */

/* ── THEME VARS ── */
:root {
  --red:      #cc1a1a;
  --red-h:    #e82020;
  --red-d:    #8a0e0e;
  --red-15:   rgba(204,26,26,0.15);
  --red-08:   rgba(204,26,26,0.08);
  --red-30:   rgba(204,26,26,0.30);

  /* Dark */
  --bg:       #0c0c0c;
  --bg2:      #141414;
  --bg3:      #1c1c1c;
  --bg4:      #242424;
  --text:     #f0f0f0;
  --text2:    rgba(240,240,240,0.7);
  --text3:    rgba(240,240,240,0.45);
  --border:   rgba(255,255,255,0.09);
  --border2:  rgba(255,255,255,0.05);
  --card:     rgba(255,255,255,0.04);
  --inp:      rgba(255,255,255,0.06);
  --inp-b:    rgba(255,255,255,0.12);
  --nav-bg:   rgba(12,12,12,0.96);
  --sel-bg:   #1c1c1c;
  --shadow:   0 20px 60px rgba(0,0,0,0.5);
  --shadow-s: 0 4px 20px rgba(0,0,0,0.3);
}

[data-theme="light"] {
  --bg:       #f9f9f9;
  --bg2:      #ffffff;
  --bg3:      #f2f2f2;
  --bg4:      #e8e8e8;
  --text:     #0f0f0f;
  --text2:    rgba(15,15,15,0.68);
  --text3:    rgba(15,15,15,0.45);
  --border:   rgba(0,0,0,0.1);
  --border2:  rgba(0,0,0,0.06);
  --card:     rgba(0,0,0,0.03);
  --inp:      rgba(0,0,0,0.04);
  --inp-b:    rgba(0,0,0,0.14);
  --nav-bg:   rgba(249,249,249,0.97);
  --sel-bg:   #f2f2f2;
  --shadow:   0 20px 60px rgba(0,0,0,0.12);
  --shadow-s: 0 4px 20px rgba(0,0,0,0.08);
}

/* ── RESET & BASE ── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; font-size:16px; }

body {
  font-family:'DM Sans',system-ui,sans-serif;
  background:var(--bg);
  color:var(--text);
  overflow-x:hidden;
  cursor:none;
  transition:background .3s,color .3s;
}
@media(pointer:coarse){ body{ cursor:auto; } }

img { max-width:100%; display:block; }
a   { text-decoration:none; color:inherit; }
ul  { list-style:none; }

/* ── CURSOR ── */
#cur {
  position:fixed; width:36px; height:36px;
  border:2px solid var(--red); border-radius:50%;
  pointer-events:none; z-index:9999;
  transform:translate(-50%,-50%);
  transition:transform .12s, border-color .2s, width .2s, height .2s;
  mix-blend-mode:normal;
}
#cur-dot {
  position:fixed; width:6px; height:6px;
  background:var(--red); border-radius:50%;
  pointer-events:none; z-index:9999;
  transform:translate(-50%,-50%);
}
body:has(a:hover,button:hover) #cur { width:52px; height:52px; background:var(--red-15); }

/* ── SCROLLBAR ── */
::-webkit-scrollbar{ width:5px; }
::-webkit-scrollbar-track{ background:var(--bg); }
::-webkit-scrollbar-thumb{ background:var(--red); border-radius:3px; }

/* ── SELECTION ── */
::selection{ background:var(--red-30); }

/* ── PROGRESS BAR ── */
#progress-bar {
  position:fixed; top:0; left:0; height:3px;
  background:linear-gradient(90deg,var(--red-d),var(--red),var(--red-h));
  z-index:9999; width:0; transition:width .1s;
}

/* ── PRELOADER ── */
#preloader {
  position:fixed; inset:0; z-index:10000;
  background:var(--bg);
  display:flex; align-items:center; justify-content:center;
  flex-direction:column; gap:2rem;
  transition:opacity .6s, visibility .6s;
}
#preloader.out { opacity:0; visibility:hidden; pointer-events:none; }
.pre-inner { display:flex; flex-direction:column; align-items:center; gap:1.5rem; }
.pre-logo { height:80px; width:auto; animation:preFloat 1.5s ease-in-out infinite; }
@keyframes preFloat {
  0%,100%{ transform:translateY(0); }
  50%{ transform:translateY(-10px); }
}
.pre-bar {
  width:200px; height:3px; background:var(--border);
  border-radius:2px; overflow:hidden;
}
.pre-fill {
  height:100%; width:0;
  background:linear-gradient(90deg,var(--red-d),var(--red));
  animation:preLoad 1.5s ease forwards;
}
@keyframes preLoad { to{ width:100%; } }
.pre-text {
  font-family:'Barlow Condensed',sans-serif;
  font-size:.75rem; letter-spacing:.4em;
  color:var(--text3); animation:blink 1s infinite;
}
@keyframes blink{ 0%,100%{opacity:.4} 50%{opacity:1} }

/* ── CONTAINER ── */
.container { max-width:1280px; margin:0 auto; padding:0 2rem; }

/* ── TYPOGRAPHY HELPERS ── */
.sec-label {
  display:inline-block;
  font-family:'DM Sans',sans-serif;
  font-size:.7rem; font-weight:500;
  letter-spacing:.35em; text-transform:uppercase;
  color:var(--red); margin-bottom:.75rem;
}
.sec-title {
  font-family:'Oswald',sans-serif;
  font-size:clamp(2rem,4vw,3.5rem);
  font-weight:700; line-height:1.05;
  color:var(--text); letter-spacing:-.01em;
  text-transform:uppercase;
}
.sec-head { margin-bottom:3.5rem; }

/* ── BUTTONS ── */
.btn-primary {
  display:inline-flex; align-items:center; gap:.5rem;
  background:var(--red); color:#fff;
  font-family:'Barlow Condensed',sans-serif;
  font-weight:700; font-size:1rem; letter-spacing:.08em;
  text-transform:uppercase;
  padding:.85rem 2rem; border-radius:3px;
  border:none; cursor:pointer;
  transition:background .25s, transform .2s, box-shadow .25s;
  position:relative; overflow:hidden;
}
.btn-primary::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.15),transparent);
  opacity:0; transition:opacity .25s;
}
.btn-primary:hover { background:var(--red-h); transform:translateY(-2px); box-shadow:0 8px 30px var(--red-30); }
.btn-primary:hover::after { opacity:1; }
.btn-primary:active { transform:translateY(0); }

.btn-ghost {
  display:inline-flex; align-items:center; gap:.5rem;
  background:transparent; color:#fff;
  font-family:'Barlow Condensed',sans-serif;
  font-weight:700; font-size:1rem; letter-spacing:.08em;
  text-transform:uppercase;
  padding:.85rem 2rem; border-radius:3px;
  border:2px solid rgba(255,255,255,0.5);
  cursor:pointer; transition:all .25s;
}
.btn-ghost:hover { border-color:#fff; background:rgba(255,255,255,.08); }

.btn-full { width:100%; justify-content:center; }

/* ── NAVBAR ── */
#nav {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  padding:.8rem 0; transition:background .3s, box-shadow .3s, padding .3s;
}
#nav.scrolled {
  background:var(--nav-bg);
  backdrop-filter:blur(20px);
  box-shadow:0 1px 0 var(--border), 0 4px 20px rgba(0,0,0,.2);
  padding:.5rem 0;
}
.nav-inner {
  max-width:1280px; margin:0 auto; padding:0 2rem;
  display:flex; align-items:center; justify-content:space-between;
}
.nav-logo img { height:48px; width:auto; }
.logo-fallback {
  display:none;
  font-family:'Oswald',sans-serif; font-weight:700; font-size:1.4rem;
  color:var(--red); letter-spacing:.1em;
}
.nav-links {
  display:flex; gap:2.5rem;
}
.nav-links a {
  font-family:'DM Sans',sans-serif; font-weight:500;
  font-size:.85rem; letter-spacing:.06em; text-transform:uppercase;
  color:var(--text2); transition:color .2s;
  position:relative;
}
.nav-links a::after {
  content:''; position:absolute; bottom:-3px; left:0;
  width:0; height:2px; background:var(--red);
  transition:width .3s;
}
.nav-links a:hover { color:var(--text); }
.nav-links a:hover::after { width:100%; }

.nav-actions { display:flex; align-items:center; gap:1rem; }
#theme-btn {
  width:36px; height:36px; border-radius:50%;
  background:var(--card); border:1px solid var(--border);
  color:var(--text2); font-size:1rem; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition:all .2s;
}
#theme-btn:hover { background:var(--red-15); border-color:var(--red); color:var(--red); }
.nav-cta {
  background:var(--red); color:#fff !important;
  font-family:'Barlow Condensed',sans-serif;
  font-weight:700; font-size:.85rem; letter-spacing:.1em;
  text-transform:uppercase; padding:.55rem 1.4rem;
  border-radius:3px; transition:background .2s, transform .2s;
}
.nav-cta:hover { background:var(--red-h); transform:translateY(-1px); }
#burger {
  display:none; flex-direction:column; gap:5px;
  background:none; border:none; cursor:pointer; padding:4px;
}
#burger span {
  display:block; width:24px; height:2px;
  background:var(--text); border-radius:2px;
  transition:all .3s;
}
#burger.open span:nth-child(1){ transform:rotate(45deg) translate(5px,5px); }
#burger.open span:nth-child(2){ opacity:0; }
#burger.open span:nth-child(3){ transform:rotate(-45deg) translate(5px,-5px); }

/* Drawer */
#drawer {
  display:none; flex-direction:column; gap:0;
  background:var(--nav-bg); backdrop-filter:blur(20px);
  border-top:1px solid var(--border); padding:1rem 2rem 1.5rem;
}
#drawer.open { display:flex; }
.d-link {
  font-family:'DM Sans',sans-serif; font-weight:500;
  font-size:1rem; letter-spacing:.05em;
  padding:.8rem 0; border-bottom:1px solid var(--border2);
  color:var(--text2); transition:color .2s, padding-left .2s;
}
.d-link:hover { color:var(--red); padding-left:.5rem; }
.d-cta {
  margin-top:.5rem; background:var(--red); color:#fff !important;
  text-align:center; padding:.85rem; border-radius:3px;
  font-family:'Barlow Condensed',sans-serif; font-weight:700;
  letter-spacing:.08em; text-transform:uppercase; border-bottom:none;
}
.d-phone {
  text-align:center; color:var(--red) !important;
  font-weight:600; border-bottom:none;
}

/* ── HERO ── */
.hero {
  position:relative; height:100vh; min-height:600px;
  display:flex; flex-direction:column;
  justify-content:flex-end; overflow:hidden;
}
.hero-slides { position:absolute; inset:0; }
.hero-slide {
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  opacity:0; transition:opacity 1.2s ease;
  transform:scale(1.05);
  animation:kenBurns 8s ease-in-out infinite alternate;
}
.hero-slide.active { opacity:1; }
@keyframes kenBurns {
  from{ transform:scale(1.05) translate(0,0); }
  to  { transform:scale(1) translate(-1%,-1%); }
}
.hero-overlay {
  position:absolute; inset:0;
  background:linear-gradient(
    180deg,
    rgba(0,0,0,.2) 0%,
    rgba(0,0,0,.1) 30%,
    rgba(0,0,0,.55) 65%,
    rgba(0,0,0,.92) 100%
  );
}
.hero-noise {
  position:absolute; inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");
  background-size:200px; opacity:.5; pointer-events:none;
}

.slide-dots {
  position:absolute; right:2rem; top:50%; transform:translateY(-50%);
  display:flex; flex-direction:column; gap:.6rem; z-index:10;
}
.dot {
  width:8px; height:8px; border-radius:50%;
  background:rgba(255,255,255,.4); cursor:pointer;
  transition:all .3s; border:1px solid rgba(255,255,255,.3);
}
.dot.active { background:var(--red); border-color:var(--red); transform:scale(1.3); }

.hero-body {
  position:relative; z-index:5;
  max-width:1280px; margin:0 auto; padding:0 2rem;
  padding-bottom:7rem; width:100%;
}
.hero-badge {
  display:inline-flex; align-items:center; gap:.6rem;
  background:rgba(255,255,255,.1); backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.2);
  border-radius:100px; padding:.35rem 1rem .35rem .5rem;
  margin-bottom:1.5rem;
  font-size:.75rem; font-weight:500; letter-spacing:.15em;
  text-transform:uppercase; color:#fff;
  animation:fadeSlideUp .8s .3s both;
}
.badge-pulse {
  width:8px; height:8px; border-radius:50%;
  background:var(--red); animation:pulse 1.5s infinite;
}
@keyframes pulse {
  0%,100%{ box-shadow:0 0 0 0 var(--red-30); }
  50%{ box-shadow:0 0 0 6px transparent; }
}

.hero-h1 {
  font-family:'Oswald',sans-serif;
  font-size:clamp(3.5rem,10vw,8.5rem);
  font-weight:700; line-height:.95;
  text-transform:uppercase; color:#fff;
  margin-bottom:1.5rem; overflow:hidden;
}
.h1-line {
  display:block;
  animation:heroLine .9s cubic-bezier(.16,1,.3,1) both;
}
.h1-line:nth-child(1){ animation-delay:.5s; }
.h1-line:nth-child(2){ animation-delay:.65s; }
.h1-line:nth-child(3){ animation-delay:.8s; }
.h1-line.accent { color:var(--red); }
@keyframes heroLine {
  from{ transform:translateY(100%); opacity:0; clip-path:inset(0 0 100% 0); }
  to  { transform:translateY(0); opacity:1; clip-path:inset(0 0 0% 0); }
}

.hero-sub {
  font-size:1.1rem; color:rgba(255,255,255,.75);
  max-width:520px; line-height:1.6; margin-bottom:2rem;
  animation:fadeSlideUp .8s 1s both;
}
.hero-btns {
  display:flex; gap:1rem; flex-wrap:wrap;
  animation:fadeSlideUp .8s 1.1s both;
}

/* Stats bar */
.hero-stats {
  position:absolute; bottom:0; left:0; right:0; z-index:5;
  background:var(--red);
  display:flex; align-items:center; justify-content:center;
  padding:1.1rem 2rem; gap:0; flex-wrap:wrap;
}
.hstat {
  display:flex; flex-direction:column; align-items:center;
  padding:0 3rem; text-align:center;
}
.hstat strong {
  font-family:'Oswald',sans-serif; font-size:2rem;
  font-weight:700; color:#fff; line-height:1;
}
.hstat span { font-size:.9rem; color:rgba(255,255,255,.8); font-weight:500; }
.hstat em { font-size:.7rem; color:rgba(255,255,255,.65); letter-spacing:.08em; text-transform:uppercase; font-style:normal; }
.hstat-div { width:1px; height:40px; background:rgba(255,255,255,.25); }

.scroll-cue {
  position:absolute; bottom:6rem; right:2rem; z-index:5;
  display:flex; flex-direction:column; align-items:center; gap:.5rem;
  animation:fadeSlideUp 1s 1.5s both;
}
.scroll-line {
  width:1px; height:50px;
  background:linear-gradient(180deg,transparent,rgba(255,255,255,.6));
  animation:scrollDrop 2s ease-in-out infinite;
}
@keyframes scrollDrop {
  0%{ transform:scaleY(0); transform-origin:top; }
  50%{ transform:scaleY(1); transform-origin:top; }
  51%{ transform-origin:bottom; }
  100%{ transform:scaleY(0); transform-origin:bottom; }
}
.scroll-cue span {
  font-size:.6rem; letter-spacing:.25em; color:rgba(255,255,255,.5);
  writing-mode:vertical-rl; text-transform:uppercase;
}

@keyframes fadeSlideUp {
  from{ opacity:0; transform:translateY(30px); }
  to  { opacity:1; transform:translateY(0); }
}

/* ── TICKER ── */
.ticker-bar {
  background:var(--bg2); border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:.8rem 0; overflow:hidden;
}
.ticker-track {
  display:inline-flex; white-space:nowrap;
  animation:tick 35s linear infinite;
}
.ticker-track span {
  font-family:'DM Sans',sans-serif; font-size:.8rem;
  font-weight:500; letter-spacing:.08em; text-transform:uppercase;
  color:var(--text3); padding:0 2.5rem;
}
.ticker-track span:nth-child(odd)  { color:var(--red); }
@keyframes tick { to{ transform:translateX(-25%); } }

/* ── SERVICES ── */
.services-sec {
  padding:7rem 0;
  background:var(--bg);
}
.services-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.5px;
  background:var(--border);
  border:1.5px solid var(--border);
}
.svc-card {
  background:var(--bg2);
  overflow:hidden; position:relative;
  cursor:pointer;
  transition:transform .4s cubic-bezier(.16,1,.3,1);
}
.svc-card:hover { z-index:2; transform:scale(1.02); }
.svc-img {
  width:100%; height:220px; overflow:hidden; position:relative;
}
.svc-img img {
  width:100%; height:100%; object-fit:cover;
  transition:transform .6s ease;
}
.svc-card:hover .svc-img img { transform:scale(1.08); }
.svc-img-overlay {
  position:absolute; inset:0;
  background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.7));
}
.svc-body {
  padding:1.75rem; position:relative;
}
.svc-tag {
  display:inline-block;
  background:var(--red); color:#fff;
  font-size:.6rem; font-weight:700;
  letter-spacing:.15em; text-transform:uppercase;
  padding:.2rem .6rem; border-radius:2px;
  margin-bottom:.75rem;
}
.svc-icon {
  font-size:1.75rem; margin-bottom:.75rem; display:block;
  color:var(--red);
}
.svc-icon i { font-size:inherit; }
.svc-body h3 {
  font-family:'Oswald',sans-serif; font-weight:600;
  font-size:1.2rem; text-transform:uppercase;
  color:var(--text); margin-bottom:.6rem; letter-spacing:.03em;
}
.svc-body p {
  font-size:.88rem; color:var(--text2);
  line-height:1.65; margin-bottom:1.2rem;
}
.svc-link {
  font-family:'Barlow Condensed',sans-serif;
  font-weight:700; font-size:.85rem; letter-spacing:.1em;
  text-transform:uppercase; color:var(--red);
  display:inline-flex; align-items:center; gap:.3rem;
  transition:gap .2s, color .2s;
}
.svc-link:hover { gap:.6rem; }

/* ── ABOUT ── */
.about-sec {
  display:grid; grid-template-columns:1fr 1fr;
  min-height:600px;
}
.about-img {
  position:relative; overflow:hidden;
  background:var(--bg3);
}
.about-img img {
  width:100%; height:100%; object-fit:cover;
  transition:transform .8s ease;
}
.about-img:hover img { transform:scale(1.04); }
.about-img-badge {
  position:absolute; bottom:2rem; right:2rem;
  background:var(--red); color:#fff;
  padding:1.25rem 1.5rem; text-align:center;
  border-radius:4px;
  box-shadow:0 10px 30px rgba(204,26,26,.4);
  animation:badgePulse 3s ease-in-out infinite;
}
@keyframes badgePulse {
  0%,100%{ transform:translateY(0); }
  50%{ transform:translateY(-5px); }
}
.about-img-badge strong {
  display:block; font-family:'Oswald',sans-serif;
  font-size:2.5rem; font-weight:700; line-height:1;
}
.about-img-badge span {
  font-size:.7rem; letter-spacing:.1em;
  text-transform:uppercase; opacity:.85;
}

.about-copy {
  background:var(--bg2);
  padding:5rem 4rem; display:flex;
  flex-direction:column; justify-content:center;
}
.about-lead {
  font-size:1.1rem; color:var(--text2);
  line-height:1.7; margin:1.5rem 0 2rem;
  font-style:italic;
}
.about-list { margin-bottom:2.5rem; }
.about-item {
  display:flex; align-items:center; gap:.85rem;
  padding:.75rem 0;
  border-bottom:1px solid var(--border2);
  font-size:.95rem; color:var(--text2);
}
.about-item:last-child { border-bottom:none; }
.af-check {
  width:24px; height:24px; border-radius:50%;
  background:var(--red); color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-size:.75rem; flex-shrink:0; font-weight:700;
}
.about-stats {
  display:flex; gap:2.5rem; margin-bottom:2.5rem;
}
.astat strong {
  display:block; font-family:'Oswald',sans-serif;
  font-size:1.6rem; font-weight:700; color:var(--red);
}
.astat span { font-size:.75rem; color:var(--text3); text-transform:uppercase; letter-spacing:.1em; }

/* ── PROCESS ── */
.process-sec {
  padding:7rem 0; background:var(--bg3);
}
.process-grid {
  display:grid; grid-template-columns:repeat(4,1fr);
  position:relative; gap:0;
}
.proc-card {
  padding:2.5rem 2rem; position:relative;
  border-right:1px solid var(--border);
  transition:background .3s;
}
.proc-card:last-child { border-right:none; }
.proc-card:hover { background:var(--card); }
.proc-num {
  font-family:'Oswald',sans-serif; font-size:4rem; font-weight:700;
  color:var(--border); line-height:1; margin-bottom:1rem;
  transition:color .3s;
}
.proc-card:hover .proc-num { color:var(--red-30); }
.proc-icon {
  font-size:2rem; margin-bottom:1rem;
  color:var(--red);
}
.proc-icon i { font-size:inherit; }
.proc-card h3 {
  font-family:'Oswald',sans-serif; font-weight:600;
  font-size:1.1rem; text-transform:uppercase;
  letter-spacing:.03em; color:var(--text); margin-bottom:.65rem;
}
.proc-card p { font-size:.875rem; color:var(--text2); line-height:1.65; }
.proc-arrow {
  position:absolute; top:2.5rem; right:-1rem;
  font-size:1.5rem; color:var(--red); z-index:2;
  background:var(--bg3); padding:.1rem;
  transition:background .3s;
}
.proc-arrow i { font-size:inherit; }

/* ── FA icon sizing helpers ── */
.ci-mini div { font-size:1.5rem; margin-bottom:.4rem; color:var(--red); }
.ci-mini div i { font-size:1.3rem; }
.footer-links a i { font-size:.6rem; opacity:.6; margin-right:.3rem; }
.footer-contact p i { margin-right:.4rem; color:var(--red); opacity:.8; }
.hstat span i { font-size:.9rem; }
.ticker-track span i { font-size:.75rem; vertical-align:middle; margin-right:.2rem; }

/* ── GALLERY ── */
.gallery-sec { padding:5rem 0; background:var(--bg); }
.gal-header { max-width:1280px; margin:0 auto; padding:0 2rem 2.5rem; }
.gal-strip {
  display:flex; overflow-x:auto; gap:0;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.gal-strip::-webkit-scrollbar { display:none; }
.gal-item {
  flex:0 0 calc(100vw/3.5); min-width:280px;
  height:360px; scroll-snap-align:start;
  position:relative; overflow:hidden; cursor:pointer;
}
.gal-item img {
  width:100%; height:100%; object-fit:cover;
  transition:transform .6s ease;
}
.gal-item:hover img { transform:scale(1.08); }
.gal-hover {
  position:absolute; inset:0;
  background:rgba(204,26,26,.7);
  display:flex; align-items:center; justify-content:center;
  opacity:0; transition:opacity .3s;
}
.gal-hover span {
  font-family:'Oswald',sans-serif; font-size:2rem;
  font-weight:700; color:#fff; letter-spacing:.2em;
}
.gal-item:hover .gal-hover { opacity:1; }

/* ── REVIEWS ── */
.reviews-sec { padding:7rem 0; background:var(--bg2); }
.reviews-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:1.5rem;
}
.rev-card {
  background:var(--bg3); border:1px solid var(--border);
  border-radius:4px; padding:2rem;
  position:relative; overflow:hidden;
  transition:transform .3s, box-shadow .3s, border-color .3s;
}
.rev-card::before {
  content:'"'; position:absolute; top:.5rem; right:1.5rem;
  font-family:'Oswald',sans-serif; font-size:6rem; font-weight:700;
  color:var(--red-08); line-height:1;
}
.rev-card:hover {
  transform:translateY(-4px); border-color:var(--red-30);
  box-shadow:0 12px 40px rgba(204,26,26,.1);
}
.rev-stars {
  font-size:1rem; margin-bottom:1rem;
  color:#f59e0b; display:flex; gap:.15rem;
}
.rev-stars i { font-size:.95rem; }
.rev-card blockquote {
  font-size:.95rem; color:var(--text2); line-height:1.7;
  font-style:italic; margin-bottom:1.5rem;
}
.rev-author {
  display:flex; align-items:center; gap:.75rem;
}
.rev-author img {
  width:40px; height:40px; border-radius:50%; object-fit:cover;
}
.rev-avatar-fallback {
  display:none; width:40px; height:40px; border-radius:50%;
  background:var(--red); color:#fff;
  align-items:center; justify-content:center;
  font-weight:700; font-size:.85rem;
}
.rev-author strong { font-weight:600; font-size:.9rem; color:var(--text); }

/* ── CTA BAND ── */
.cta-band {
  position:relative; padding:8rem 2rem;
  display:flex; align-items:center; justify-content:center;
  overflow:hidden;
}
.cta-bg-img {
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; object-position:center;
}
.cta-band-overlay {
  position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(139,14,14,.9),rgba(0,0,0,.85));
}
.cta-band-body {
  position:relative; z-index:2;
  text-align:center; color:#fff; max-width:640px;
}
.cta-band-body .sec-label { color:rgba(255,255,255,.65); }
.cta-band-body h2 {
  font-family:'Oswald',sans-serif; font-size:clamp(2.5rem,6vw,5rem);
  font-weight:700; text-transform:uppercase;
  margin-bottom:1rem; line-height:1;
}
.cta-band-body p {
  font-size:1.1rem; color:rgba(255,255,255,.7);
  margin-bottom:2.5rem; line-height:1.6;
}
.cta-band-btns { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }

/* ── BOOKING SECTION ── */
.book-sec { padding:7rem 0; background:var(--bg); }
.book-grid {
  display:grid; grid-template-columns:1fr 1fr;
  gap:5rem; align-items:start;
}
.book-sub { font-size:.95rem; color:var(--text2); margin:1rem 0 2rem; line-height:1.6; }

/* ── CONTACT SECTION ── */
.contact-sec { padding:7rem 0; background:var(--bg2); }

/* Forms */
.bform { display:flex; flex-direction:column; gap:1rem; }
.fg { display:flex; flex-direction:column; gap:.4rem; }
.fg2 { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.fg label {
  font-size:.72rem; font-weight:600;
  letter-spacing:.12em; text-transform:uppercase;
  color:var(--text3);
}
.fg input,
.fg select,
.fg textarea {
  background:var(--inp);
  border:1px solid var(--inp-b);
  border-radius:3px; padding:.8rem 1rem;
  color:var(--text); font-family:'DM Sans',sans-serif;
  font-size:.9rem; outline:none; appearance:none;
  transition:border-color .2s, background .2s, box-shadow .2s;
}
.fg input::placeholder,
.fg textarea::placeholder { color:var(--text3); }
.fg input:focus,
.fg select:focus,
.fg textarea:focus {
  border-color:var(--red);
  background:var(--red-08);
  box-shadow:0 0 0 3px var(--red-15);
}
.fg select option { background:var(--sel-bg); color:var(--text); }
.fg textarea { resize:vertical; min-height:90px; }

.form-success {
  background:rgba(34,197,94,.1); border:1px solid rgba(34,197,94,.3);
  color:#4ade80; padding:1rem; border-radius:3px;
  font-size:.9rem; font-weight:500;
}
.form-error {
  background:rgba(239,68,68,.1); border:1px solid rgba(239,68,68,.3);
  color:#f87171; padding:1rem; border-radius:3px;
  font-size:.9rem; font-weight:500;
}

/* Contact wrap */
.contact-wrap { display:flex; flex-direction:column; gap:1.5rem; }
.ci-card {
  position:relative; height:220px; border-radius:4px;
  overflow:hidden; display:flex; align-items:flex-end;
}
.ci-bg-img {
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
}
.ci-overlay {
  position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(139,14,14,.85),rgba(0,0,0,.6));
}
.ci-body {
  position:relative; z-index:2; padding:1.5rem; color:#fff;
}
.ci-body span {
  font-size:.7rem; letter-spacing:.2em;
  text-transform:uppercase; opacity:.75; display:block;
  margin-bottom:.3rem;
}
.ci-body h3 {
  font-family:'Oswald',sans-serif; font-size:1.8rem;
  font-weight:700; text-transform:uppercase;
  margin-bottom:1rem;
}

.ci-grid {
  display:grid; grid-template-columns:1fr 1fr;
  gap:.75rem;
}
.ci-mini {
  background:var(--card); border:1px solid var(--border);
  border-radius:4px; padding:1rem;
  transition:border-color .2s, background .2s;
}
.ci-mini:hover { border-color:var(--red-30); background:var(--red-08); }
.ci-mini strong { display:block; font-size:.875rem; color:var(--text); margin-bottom:.2rem; }
.ci-mini span { font-size:.78rem; color:var(--text3); }

.contact-form-wrap {
  background:var(--card); border:1px solid var(--border);
  border-radius:4px; padding:1.75rem;
}
.contact-form-wrap h3 {
  font-family:'Oswald',sans-serif; font-weight:600;
  font-size:1.3rem; text-transform:uppercase;
  color:var(--text); margin-bottom:1.25rem; letter-spacing:.03em;
}

/* ── FOOTER ── */
#footer {
  background:var(--bg2);
  border-top:1px solid var(--border);
}
.footer-top {
  max-width:1280px; margin:0 auto; padding:4rem 2rem;
  display:grid; grid-template-columns:2fr 1fr 1fr 1.5fr;
  gap:3rem;
}
.footer-brand img { height:56px; width:auto; margin-bottom:1rem; }
.fb-fallback {
  display:none; font-family:'Oswald',sans-serif;
  font-weight:700; font-size:1.1rem; color:var(--red);
  letter-spacing:.1em; line-height:1.3; margin-bottom:1rem;
}
.fb-fallback small { font-size:.7rem; color:var(--text3); display:block; }
.footer-brand p { font-size:.875rem; color:var(--text2); line-height:1.7; max-width:260px; margin-bottom:1rem; }
.footer-phone {
  font-family:'Barlow Condensed',sans-serif; font-weight:700;
  font-size:1.1rem; letter-spacing:.06em; color:var(--red);
  transition:color .2s;
}
.footer-phone:hover { color:var(--red-h); }
.footer-links h4, .footer-contact h4 {
  font-family:'Oswald',sans-serif; font-weight:600;
  font-size:.85rem; text-transform:uppercase; letter-spacing:.1em;
  color:var(--text); margin-bottom:1.25rem;
}
.footer-links ul { display:flex; flex-direction:column; gap:.6rem; }
.footer-links a {
  font-size:.875rem; color:var(--text2);
  transition:color .2s, padding-left .2s;
}
.footer-links a:hover { color:var(--red); padding-left:.3rem; }
.footer-contact p { font-size:.875rem; color:var(--text2); margin-bottom:.6rem; line-height:1.5; }
.footer-badges {
  display:flex; gap:.5rem; margin-top:1rem;
}
.footer-badges span {
  font-size:.65rem; letter-spacing:.1em; text-transform:uppercase;
  background:var(--card); border:1px solid var(--border);
  color:var(--text3); padding:.25rem .6rem; border-radius:2px;
}
.footer-bottom {
  border-top:1px solid var(--border);
  max-width:1280px; margin:0 auto; padding:1.5rem 2rem;
  display:flex; align-items:center; justify-content:space-between;
}
.footer-bottom span { font-size:.8rem; color:var(--text3); }

/* ── FLOATING CTA ── */
#float-cta {
  position:fixed; bottom:1.5rem; right:1.5rem; z-index:800;
  display:flex; flex-direction:column; gap:.5rem; align-items:flex-end;
  opacity:0; pointer-events:none; transition:opacity .4s;
}
#float-cta.visible { opacity:1; pointer-events:auto; }
.fcta-call {
  display:flex; align-items:center; gap:.5rem;
  background:var(--red); color:#fff;
  font-family:'Barlow Condensed',sans-serif; font-weight:700;
  font-size:.9rem; letter-spacing:.1em; text-transform:uppercase;
  padding:.7rem 1.4rem; border-radius:100px;
  box-shadow:0 6px 24px var(--red-30);
  transition:transform .2s, background .2s;
}
.fcta-call:hover { transform:scale(1.05) translateY(-2px); background:var(--red-h); }
.fcta-book {
  display:flex; align-items:center; gap:.5rem;
  background:var(--bg2); color:var(--red);
  border:1px solid var(--red-30);
  font-family:'Barlow Condensed',sans-serif; font-weight:700;
  font-size:.9rem; letter-spacing:.1em; text-transform:uppercase;
  padding:.7rem 1.4rem; border-radius:100px;
  box-shadow:var(--shadow-s);
  transition:transform .2s, border-color .2s;
}
.fcta-book:hover { transform:scale(1.05) translateY(-2px); border-color:var(--red); }

/* ── REVEAL ANIMATIONS ── */
.reveal, .reveal-left, .reveal-right {
  opacity:0; transition:opacity .7s ease, transform .7s ease;
  transition-delay:var(--d,0s);
}
.reveal         { transform:translateY(40px); }
.reveal-left    { transform:translateX(-50px); }
.reveal-right   { transform:translateX(50px); }
.reveal.in,
.reveal-left.in,
.reveal-right.in { opacity:1; transform:none; }

/* ═══ RESPONSIVE ═══ */
@media(max-width:1100px){
  .services-grid { grid-template-columns:repeat(2,1fr); }
  .process-grid  { grid-template-columns:repeat(2,1fr); }
  .proc-card:nth-child(2) .proc-arrow,
  .proc-card:nth-child(4) .proc-arrow { display:none; }
  .proc-card { border-right:none; border-bottom:1px solid var(--border); }
  .proc-card:last-child { border-bottom:none; }
  .footer-top { grid-template-columns:1fr 1fr; }
}
@media(max-width:900px){
  .about-sec    { grid-template-columns:1fr; }
  .about-copy   { padding:3rem 2rem; }
  .about-img    { height:400px; }
  .book-grid    { grid-template-columns:1fr; gap:3rem; }
  .reviews-grid { grid-template-columns:1fr; }
  .nav-links    { display:none; }
  #burger       { display:flex; }
  .hstat        { padding:0 1.5rem; }
  .footer-top   { grid-template-columns:1fr; gap:2rem; }
}
@media(max-width:640px){
  .hero-body    { padding:0 1.25rem; padding-bottom:7rem; }
  .hero-stats   { flex-direction:column; gap:.5rem; padding:1rem; }
  .hstat-div    { width:40px; height:1px; }
  .hstat        { flex-direction:row; gap:.5rem; padding:.25rem 0; }
  .services-grid{ grid-template-columns:1fr; }
  .process-grid { grid-template-columns:1fr; }
  .proc-card    { border-right:none; }
  .fg2          { grid-template-columns:1fr; }
  .ci-grid      { grid-template-columns:1fr 1fr; }
  .slide-dots   { right:.75rem; }
  .sec-title    { font-size:2rem; }
  .about-stats  { gap:1.5rem; }
  .container    { padding:0 1.25rem; }
  .footer-bottom{ flex-direction:column; gap:.5rem; text-align:center; }
}

/* ── FAQ SECTION ── */
.faq-sec { padding:6rem 0; background:var(--bg3); }
.faq-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:1rem; }
.faq-item {
  background:var(--card); border:1px solid var(--border);
  border-radius:4px; overflow:hidden;
  transition:border-color .2s; opacity:0; transform:translateY(24px);
}
.faq-item.in { opacity:1; transform:translateY(0); transition:opacity .6s ease var(--d,0s), transform .6s ease var(--d,0s); }
.faq-item[open] { border-color:var(--red-30); }
.faq-q {
  padding:1.25rem 1.5rem; font-family:'Oswald',sans-serif;
  font-weight:600; font-size:1rem; text-transform:uppercase;
  letter-spacing:.02em; color:var(--txt); cursor:pointer;
  list-style:none; display:flex; justify-content:space-between; align-items:center;
  transition:color .2s;
}
.faq-q::-webkit-details-marker { display:none; }
.faq-q::after { content:'\f067'; font-family:'Font Awesome 6 Free'; font-weight:900; font-size:.75rem; color:var(--red); transition:transform .3s; }
.faq-item[open] .faq-q::after { transform:rotate(45deg); }
.faq-item[open] .faq-q { color:var(--red); }
.faq-a { padding:0 1.5rem 1.25rem; font-size:.9rem; color:var(--txt2); line-height:1.7; }

@media(max-width:768px) {
  .faq-grid { grid-template-columns:1fr; }
}