
:root{
  --bg:#07070a; --bg2:#101015; --panel:#15151c; --panel2:#1d1d25; --text:#f5f5f7; --muted:#b7b7c3;
  --red:#ed1c24; --red2:#ff3a33; --yellow:#ffc400; --white:#fff; --line:rgba(255,255,255,.12);
  --shadow:0 28px 80px rgba(0,0,0,.48); --radius:26px; --max:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--text);font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:min(var(--max),calc(100% - 34px));margin-inline:auto}
.site-noise{position:fixed;inset:0;pointer-events:none;opacity:.08;z-index:-1;background-image:radial-gradient(rgba(255,255,255,.15) 1px,transparent 1px);background-size:18px 18px}
.topbar{position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:22px;padding:12px 24px;background:rgba(7,7,10,.9);border-bottom:1px solid var(--line);backdrop-filter:blur(18px)}
.brand img{width:190px;height:62px;object-fit:contain}
.nav{display:flex;align-items:center;gap:4px;flex:1;justify-content:center}
.nav a{font-size:14px;font-weight:800;color:#d8d8df;padding:12px 13px;border-radius:999px;transition:background .2s,color .2s}
.nav a:hover,.nav a.active{background:rgba(237,28,36,.15);color:#fff}
.top-actions{display:flex;gap:10px;align-items:center}
.phone-link{font-weight:900;font-size:14px;color:#fff}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;border-radius:999px;padding:14px 20px;font-weight:900;letter-spacing:.01em;border:1px solid transparent;transition:transform .2s,filter .2s;cursor:pointer}
.btn:hover{transform:translateY(-2px);filter:brightness(1.05)}
.btn-red{background:linear-gradient(135deg,var(--red),#8e080e);box-shadow:0 18px 40px rgba(237,28,36,.25)}
.btn-dark{background:rgba(255,255,255,.08);border-color:var(--line)}
.btn-yellow{background:linear-gradient(135deg,var(--yellow),#f08b00);color:#131313;box-shadow:0 18px 40px rgba(255,196,0,.18)}
.btn-small{padding:10px 15px;font-size:13px}
.nav-toggle{display:none;background:transparent;border:0;gap:5px;flex-direction:column}
.nav-toggle span{width:28px;height:3px;background:#fff;border-radius:10px}

h1,h2,h3{margin:0;line-height:.98;font-family:Rajdhani,Inter,sans-serif}
h1{font-size:clamp(46px,7.6vw,98px);letter-spacing:-.055em}
h2{font-size:clamp(38px,5vw,66px);letter-spacing:-.045em}
h3{letter-spacing:-.025em}
h1 span,.red{color:var(--red)}
.lead{font-size:clamp(17px,2vw,22px);line-height:1.65;color:#d6d6df;max-width:720px;margin:22px 0 0}
.kicker{display:inline-flex;align-items:center;gap:10px;color:#fff;background:rgba(255,255,255,.08);border:1px solid var(--line);border-radius:999px;padding:8px 13px;font-size:13px;font-weight:900;text-transform:uppercase;letter-spacing:.08em;margin-bottom:18px}
.kicker:before{content:"";width:10px;height:10px;border-radius:50%;background:var(--red);box-shadow:0 0 22px var(--red)}

.hero-v3{position:relative;min-height:calc(100vh - 87px);display:grid;align-items:center;overflow:hidden;padding:76px 0;background:#050506}
.hero-v3-bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:contrast(1.08) saturate(1.05)}
.hero-v3-bg:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(5,5,6,.97),rgba(5,5,6,.76) 38%,rgba(5,5,6,.32) 68%,rgba(5,5,6,.82)),radial-gradient(circle at 68% 43%,rgba(237,28,36,.28),transparent 35%)}
.hero-v3-content{position:relative;z-index:2;max-width:790px}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}
.trust-strip{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.trust-strip span{padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.07em}
.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:13px;margin-top:34px;max-width:720px}
.stat{border:1px solid var(--line);background:linear-gradient(180deg,rgba(255,255,255,.09),rgba(255,255,255,.04));padding:20px;border-radius:20px;box-shadow:var(--shadow)}
.stat strong{display:block;font-size:32px;color:#fff;font-family:Rajdhani}
.stat span{color:var(--muted);font-size:13px;font-weight:700}

.section{padding:88px 0;position:relative}
.section-head{display:flex;justify-content:space-between;gap:24px;align-items:end;margin-bottom:34px}
.section-head p{max-width:520px;color:var(--muted);line-height:1.7;margin:0}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.card{position:relative;overflow:hidden;border:1px solid var(--line);background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.035));border-radius:var(--radius);min-height:250px;box-shadow:var(--shadow);transition:transform .22s,border-color .22s}
.card:hover{transform:translateY(-5px);border-color:rgba(237,28,36,.45)}
.card-pad{padding:24px}
.photo-card .photo{height:250px;background:#111;overflow:hidden}
.photo-card .photo img{width:100%;height:100%;object-fit:cover}
.photo-card .body{padding:23px}
.card-icon{width:54px;height:54px;border-radius:17px;display:grid;place-items:center;background:rgba(237,28,36,.16);color:#fff;font-weight:900;margin-bottom:18px}
.card h3{font-size:30px;margin-bottom:10px}
.card p{color:var(--muted);line-height:1.65;margin:0}
.card-link{display:inline-flex;margin-top:18px;font-weight:900;color:#fff}

.split{display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:center}
.media-panel{position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);background:#111;min-height:440px}
.media-panel img{width:100%;height:100%;min-height:440px;object-fit:cover}
.media-panel:after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.72),rgba(0,0,0,.06))}
.media-badge{position:absolute;left:18px;bottom:18px;background:rgba(0,0,0,.68);border:1px solid var(--line);backdrop-filter:blur(13px);border-radius:18px;padding:14px 16px;font-weight:900;z-index:2}
.checks{display:grid;gap:13px;margin-top:25px}
.check{display:flex;gap:12px;align-items:flex-start;color:#d6d6df;line-height:1.6}
.check:before{content:"✓";flex:0 0 24px;height:24px;border-radius:50%;display:grid;place-items:center;background:var(--red);color:#fff;font-weight:900}

.feature-wall{display:grid;grid-template-columns:1.15fr .85fr;gap:20px;align-items:stretch}
.feature-big{position:relative;min-height:560px;border-radius:34px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);background:#111}
.feature-big img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.feature-big:after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.9),rgba(0,0,0,.18) 58%,rgba(0,0,0,.55))}
.feature-content{position:absolute;left:26px;right:26px;bottom:26px;z-index:2}
.feature-content p{color:#e9e9ef;line-height:1.65;max-width:650px}
.feature-stack{display:grid;gap:20px}
.mini-photo{position:relative;min-height:270px;border-radius:30px;overflow:hidden;border:1px solid var(--line);background:#111;box-shadow:var(--shadow)}
.mini-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.mini-photo:after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.82),rgba(0,0,0,.12))}
.mini-photo h3{position:absolute;left:20px;right:20px;bottom:20px;z-index:2;font-size:34px}

.process{counter-reset:step;display:grid;grid-template-columns:repeat(4,1fr);gap:15px}
.step{counter-increment:step;padding:22px;border-radius:24px;border:1px solid var(--line);background:rgba(255,255,255,.055)}
.step:before{content:"0" counter(step);font-family:Rajdhani;font-weight:900;color:var(--red);font-size:34px}
.step h3{font-size:24px;margin:7px 0}
.step p{color:var(--muted);line-height:1.6;margin:0;font-size:14px}

.before-after{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.ba-card{position:relative;border-radius:30px;overflow:hidden;border:1px solid var(--line);min-height:420px;background:#111;box-shadow:var(--shadow)}
.ba-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.ba-card:after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.82),rgba(0,0,0,.16))}
.ba-label{position:absolute;top:18px;left:18px;z-index:2;background:var(--red);color:#fff;border-radius:999px;padding:9px 13px;font-weight:900}
.ba-card h3{position:absolute;left:22px;right:22px;bottom:22px;z-index:2;font-size:34px}

.cta-band{border-radius:34px;padding:48px;background:linear-gradient(110deg,rgba(237,28,36,.95),rgba(10,10,12,.94));border:1px solid rgba(255,255,255,.2);box-shadow:var(--shadow)}
.cta-band p{max-width:760px;color:#fff;opacity:.92;line-height:1.65}
.page-hero{padding:82px 0 58px;background:radial-gradient(circle at 80% 20%,rgba(237,28,36,.26),transparent 28%),linear-gradient(145deg,#07070a,#15151b)}
.page-hero h1{font-size:clamp(44px,6.5vw,82px)}
.breadcrumb{color:var(--muted);font-weight:800;margin-bottom:16px}

.form-wrap{display:grid;grid-template-columns:.9fr 1.1fr;gap:24px;align-items:start}
.form-card{border:1px solid var(--line);background:rgba(255,255,255,.06);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-field{display:grid;gap:7px}
.form-field.full{grid-column:1/-1}
label{font-weight:800;color:#fff;font-size:14px}
input,select,textarea{width:100%;border:1px solid rgba(255,255,255,.16);background:#0f0f15;color:#fff;border-radius:15px;padding:14px 14px;font:inherit;outline:none;transition:.2s}
input:focus,select:focus,textarea:focus{border-color:var(--red);box-shadow:0 0 0 4px rgba(237,28,36,.14)}
textarea{min-height:145px;resize:vertical}

.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.gallery-item{position:relative;border-radius:24px;overflow:hidden;border:1px solid var(--line);background:#111;min-height:270px}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:.35s}
.gallery-item:hover img{transform:scale(1.04)}
.gallery-caption{position:absolute;left:12px;right:12px;bottom:12px;background:rgba(0,0,0,.65);border:1px solid var(--line);border-radius:16px;padding:11px 13px;font-weight:900;backdrop-filter:blur(12px)}
.notice{padding:15px 17px;border-radius:18px;border:1px solid var(--line);background:rgba(255,255,255,.06);color:#d7d7df;line-height:1.6}
.success{border-color:rgba(20,220,120,.35)}
.error{border-color:rgba(237,28,36,.55)}

.footer{padding:64px 0 26px;background:#050506;border-top:1px solid var(--line)}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:28px}
.footer-logo{width:210px;height:70px;object-fit:contain;margin-bottom:14px}
.footer p{color:var(--muted);line-height:1.7}
.footer h3{font-size:24px;margin-bottom:14px}
.footer a{display:block;color:#d8d8df;margin:10px 0;font-weight:700}
.footer-bottom{display:flex;justify-content:space-between;gap:20px;margin-top:38px;padding-top:22px;border-top:1px solid var(--line);color:#858593;font-size:13px}
.floating-cta{position:fixed;right:18px;bottom:18px;z-index:60;display:flex;gap:10px}
.floating-cta a{padding:13px 16px;border-radius:999px;font-weight:900;box-shadow:0 18px 40px rgba(0,0,0,.35)}
.float-whatsapp{background:#18b957}
.float-call{background:var(--red)}

@media(max-width:980px){
  .nav-toggle{display:flex}
  .nav{position:fixed;left:14px;right:14px;top:88px;display:none;flex-direction:column;background:rgba(8,8,11,.96);border:1px solid var(--line);border-radius:24px;padding:14px;backdrop-filter:blur(18px)}
  .nav.open{display:flex}
  .nav a{width:100%;text-align:center}
  .top-actions{display:none}
  .brand img{width:160px}
  .split,.form-wrap,.feature-wall,.before-after{grid-template-columns:1fr}
  .hero-v3{min-height:auto;padding:64px 0}
  .cards,.process,.gallery-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  .topbar{padding:10px 15px}
  .brand img{width:142px;height:52px}
  .hero-stats,.cards,.process,.gallery-grid,.footer-grid,.form-grid{grid-template-columns:1fr}
  .section{padding:66px 0}
  .section-head{display:block}
  .footer-bottom{display:block}
  .floating-cta{left:14px;right:14px}
  .floating-cta a{flex:1;text-align:center}
  .feature-big{min-height:440px}
  .mini-photo,.ba-card,.media-panel,.media-panel img{min-height:340px}
}

.service-tabs{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.service-tabs a{padding:10px 14px;border-radius:999px;background:rgba(255,255,255,.08);border:1px solid var(--line);font-weight:900}

.import-model-note{font-size:13px;color:var(--muted);margin-top:10px}
.photo-card .photo{position:relative}
.photo-card .photo:after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.28),rgba(0,0,0,0))}


/* V9.3: full clickable cards */
.card-click{
  display:block;
  color:inherit;
  text-decoration:none;
  cursor:pointer;
}
.card-click .card-link{
  pointer-events:none;
}
.card-click:focus-visible{
  outline:3px solid var(--yellow);
  outline-offset:4px;
}
.card-click:hover{
  color:inherit;
}


/* V9.4: all public cards can be full clickable links where appropriate */
a.card,
a.step,
a.gallery-item{
  color:inherit;
  text-decoration:none;
  cursor:pointer;
}
a.card:hover,
a.step:hover,
a.gallery-item:hover{
  color:inherit;
}
a.card:focus-visible,
a.step:focus-visible,
a.gallery-item:focus-visible{
  outline:3px solid var(--yellow);
  outline-offset:4px;
}
a.card .card-link,
a.step .card-link{
  pointer-events:none;
}

.article-body{max-width:880px;margin:0 auto}
.article-body p{font-size:18px;line-height:1.85;color:#e7e7ee;margin:0 0 22px}


/* V13 homepage manager clickable media panels */
a.media-panel,
a.mini-photo,
a.ba-card{
  color:inherit;
  text-decoration:none;
  cursor:pointer;
}
a.media-panel:focus-visible,
a.mini-photo:focus-visible,
a.ba-card:focus-visible{
  outline:3px solid var(--yellow);
  outline-offset:4px;
}


/* V14 Trust section */
.trust-section{background:linear-gradient(180deg,rgba(255,255,255,.02),rgba(255,255,255,.04))}
.trust-badges{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:48px}
.trust-badge{border:1px solid var(--line);background:rgba(255,255,255,.06);border-radius:22px;padding:18px;box-shadow:var(--shadow)}
.trust-badge strong{display:block;font-family:Rajdhani;font-size:24px;margin-bottom:8px}
.trust-badge span{display:block;color:var(--muted);line-height:1.55}
.trust-subhead{margin-top:42px}
.testimonial-card{padding:22px}
.testimonial-top{display:flex;gap:14px;align-items:center;margin-bottom:14px}
.testimonial-top img{width:64px;height:64px;border-radius:18px;object-fit:cover;border:1px solid var(--line)}
.testimonial-top h3{font-size:24px;margin:0}
.testimonial-top p{margin:4px 0 0;color:var(--muted)}
.stars{color:var(--yellow);font-size:20px;letter-spacing:2px;margin-bottom:12px}
.faq-list{display:grid;gap:12px}
.faq-list details{border:1px solid var(--line);background:rgba(255,255,255,.06);border-radius:20px;padding:18px}
.faq-list summary{cursor:pointer;font-weight:900;font-size:18px}
.faq-list p{color:var(--muted);line-height:1.7;margin:12px 0 0}
@media(max-width:900px){.trust-badges{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.trust-badges{grid-template-columns:1fr}}

.quote-public{border:1px solid var(--line);background:rgba(255,255,255,.06);border-radius:28px;padding:28px;box-shadow:var(--shadow)}
.quote-public-head{display:flex;justify-content:space-between;gap:24px;align-items:flex-start;border-bottom:1px solid var(--line);padding-bottom:20px;margin-bottom:22px}
.quote-public-head img{width:190px;height:62px;object-fit:contain}
.quote-public-head p{color:var(--muted);line-height:1.6}
.quote-public-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:22px}
.quote-public-grid h3{font-size:26px;margin-bottom:8px}
.quote-public-grid p{color:#e5e5ee;line-height:1.7}
.quote-table{width:100%;border-collapse:collapse;margin:20px 0}
.quote-table th,.quote-table td{border-bottom:1px solid var(--line);padding:14px;text-align:left}
.quote-table th{color:var(--yellow);text-transform:uppercase;font-size:13px;letter-spacing:.06em}
.quote-total{text-align:right;margin:20px 0}
.quote-total p{color:var(--muted);margin:7px 0}
.quote-total h2{color:#fff}
.quote-actions{justify-content:flex-end}
@media(max-width:720px){.quote-public-head,.quote-public-grid{display:block}.quote-total{text-align:left}.quote-table{font-size:13px}}
@media print{.topbar,.footer,.floating-cta,.quote-actions{display:none!important}.quote-public{box-shadow:none;border:1px solid #ccc;color:#111;background:#fff}.quote-table th,.quote-total h2{color:#111}body{background:#fff;color:#111}}

.quote-response-actions{border:1px solid var(--line);background:rgba(255,255,255,.05);border-radius:24px;padding:22px;margin:24px 0}
.quote-response-actions h2{font-size:34px;margin-bottom:8px}
.quote-response-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:16px}
.quote-response-grid form{border:1px solid var(--line);border-radius:18px;padding:16px;background:rgba(0,0,0,.18)}
.quote-response-grid textarea{width:100%;min-height:95px;border:1px solid rgba(255,255,255,.16);background:#0f0f15;color:#fff;border-radius:15px;padding:14px;font:inherit;margin:8px 0 12px}
.quote-response-message{padding-bottom:0}
.customer-response-box{margin:24px 0}
@media(max-width:720px){.quote-response-grid{grid-template-columns:1fr}}
@media print{.quote-response-actions,.quote-response-message{display:none!important}}

.job-public{border:1px solid var(--line);background:rgba(255,255,255,.06);border-radius:28px;padding:28px;box-shadow:var(--shadow)}
.job-steps{display:grid;grid-template-columns:repeat(7,1fr);gap:10px;margin:26px 0}
.job-step{border:1px solid var(--line);background:rgba(255,255,255,.05);border-radius:18px;padding:14px;text-align:center;min-height:110px}
.job-step span{width:32px;height:32px;border-radius:50%;display:grid;place-items:center;margin:0 auto 8px;background:rgba(255,255,255,.12);font-weight:900}
.job-step strong{font-size:13px;line-height:1.25;display:block}
.job-step.done{border-color:rgba(237,28,36,.55);background:rgba(237,28,36,.14)}
.job-step.done span{background:var(--red);color:#fff}
.job-timeline{display:grid;gap:12px;margin:18px 0}
.job-time-item{border:1px solid var(--line);background:rgba(255,255,255,.05);border-radius:18px;padding:16px}
.job-time-item strong{display:block;font-size:18px}
.job-time-item span{display:block;color:var(--muted);font-size:13px;margin:5px 0}
.job-time-item p{color:#e6e6ee;line-height:1.6;margin:0}
@media(max-width:1000px){.job-steps{grid-template-columns:repeat(3,1fr)}}
@media(max-width:600px){.job-steps{grid-template-columns:1fr 1fr}.job-public{padding:18px}}

.job-photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:18px 0 30px}
.job-photo-card{border:1px solid var(--line);background:rgba(255,255,255,.05);border-radius:20px;overflow:hidden;color:inherit;text-decoration:none;box-shadow:var(--shadow)}
.job-photo-card img{width:100%;height:230px;object-fit:cover;transition:.3s}
.job-photo-card:hover img{transform:scale(1.04)}
.job-photo-card div{padding:14px}
.job-photo-card strong{display:block;font-size:18px;margin-bottom:5px}
.job-photo-card span{display:block;color:var(--muted);font-size:13px}
@media(max-width:900px){.job-photo-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.job-photo-grid{grid-template-columns:1fr}}
@media print{.job-photo-grid{display:none!important}}

.payment-summary-public{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:18px 0}
.payment-summary-public div{border:1px solid var(--line);background:rgba(255,255,255,.06);border-radius:18px;padding:16px}
.payment-summary-public strong{display:block;font-family:Rajdhani;font-size:28px}
.payment-summary-public span{display:block;color:var(--muted);font-size:13px;margin-top:4px}
.payment-history-public{display:grid;gap:8px;margin:10px 0 26px}
.payment-history-public div{border:1px solid var(--line);background:rgba(255,255,255,.04);border-radius:14px;padding:12px;color:#e6e6ee}
.payment-history-public span{color:var(--muted);float:right}
@media(max-width:850px){.payment-summary-public{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.payment-summary-public{grid-template-columns:1fr}.payment-history-public span{float:none;display:block;margin-top:4px}}


/* V23 front landing pages */
.landing-hero .kicker{margin-bottom:12px}
.landing-hero h1{max-width:980px}
.landing-hero .hero-actions{margin-top:24px}


/* V24 project showcase */
.project-before-after{display:grid;grid-template-columns:1fr 1fr;position:relative;height:245px;overflow:hidden}
.project-before-after img{width:100%;height:245px;object-fit:cover;transition:.35s}
.project-card:hover .project-before-after img{transform:scale(1.04)}
.project-before-after span{position:absolute;bottom:12px;background:rgba(0,0,0,.7);color:#fff;border:1px solid rgba(255,255,255,.2);border-radius:999px;padding:7px 12px;font-weight:900;font-size:12px}
.project-before-after span:nth-of-type(1){left:12px}
.project-before-after span:nth-of-type(2){right:12px}
.project-compare{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.compare-box{position:relative;border:1px solid var(--line);border-radius:28px;overflow:hidden;box-shadow:var(--shadow);background:rgba(255,255,255,.06)}
.compare-box img{width:100%;height:470px;object-fit:cover}
.compare-box span{position:absolute;left:18px;bottom:18px;background:var(--red);color:#fff;border-radius:999px;padding:9px 16px;font-weight:900}
@media(max-width:800px){.project-compare{grid-template-columns:1fr}.compare-box img{height:320px}}


/* V30 Mobile navigation and quick actions */
.mobile-nav-head,
.mobile-nav-label,
.mobile-quick-grid {
  display: none;
}

.quick-services-panel,
.floating-service-button {
  display: none;
}

.service-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 24px;
}

.service-tabs a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  border: 1px solid var(--line);
  font-weight: 900;
  line-height: 1.1;
}

@media(max-width: 980px) {
  .nav {
    left: 18px;
    right: 18px;
    top: 84px;
    max-height: calc(100vh - 120px);
    overflow-y: auto;
    padding: 20px;
    gap: 8px;
    border-radius: 28px;
    background:
      linear-gradient(180deg, rgba(18,18,22,.98), rgba(5,5,7,.98));
    box-shadow: 0 30px 90px rgba(0,0,0,.65);
  }

  .mobile-nav-head {
    display: block;
    text-align: center;
    padding: 4px 6px 10px;
  }

  .mobile-nav-head strong {
    display: block;
    font-family: Rajdhani, Inter, sans-serif;
    font-size: 26px;
    line-height: 1;
  }

  .mobile-nav-head span {
    display: block;
    margin-top: 4px;
    color: var(--muted);
    font-size: 13px;
  }

  .mobile-nav-label {
    display: block;
    width: 100%;
    margin: 12px 0 4px;
    color: #8f8f9c;
    font-size: 11px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: .16em;
    text-align: center;
  }

  .mobile-quick-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 9px;
    width: 100%;
    margin-bottom: 8px;
  }

  .mobile-quick-grid a {
    width: 100%;
    padding: 14px 16px !important;
    border-radius: 18px !important;
    text-align: center;
    font-weight: 950;
    border: 1px solid rgba(255,255,255,.14);
  }

  .mobile-quick-grid .quick-import {
    background: linear-gradient(135deg, var(--yellow), #f08b00) !important;
    color: #151515 !important;
  }

  .mobile-quick-grid .quick-body {
    background: linear-gradient(135deg, var(--red), #8e080e) !important;
    color: #fff !important;
  }

  .mobile-quick-grid .quick-estimate {
    background: rgba(255,255,255,.10) !important;
    color: #fff !important;
  }

  .nav a {
    padding: 13px 14px;
    border: 1px solid rgba(255,255,255,.08);
    background: rgba(255,255,255,.045);
    border-radius: 16px;
  }

  .nav a.active {
    background: linear-gradient(135deg, rgba(237,28,36,.9), rgba(105,8,12,.85));
  }

  .nav-toggle {
    width: 52px;
    height: 48px;
    align-items: center;
    justify-content: center;
    border-radius: 16px;
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.10);
  }

  .nav-toggle span {
    width: 29px;
    height: 4px;
  }
}

@media(max-width: 640px) {
  body {
    padding-bottom: 96px;
  }

  .service-tabs {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 9px;
    margin-top: 20px;
  }

  .service-tabs a {
    min-height: 42px;
    font-size: 13px;
    padding: 10px 8px;
    text-align: center;
  }

  .floating-service-button {
    display: block;
    position: fixed;
    right: 18px;
    bottom: 86px;
    z-index: 66;
  }

  .floating-service-button button {
    border: 1px solid rgba(255,255,255,.16);
    background: linear-gradient(135deg, rgba(255,212,0,.98), #f08b00);
    color: #111;
    border-radius: 999px;
    padding: 11px 16px;
    font-weight: 950;
    box-shadow: 0 18px 45px rgba(0,0,0,.35);
  }

  .quick-services-panel {
    display: block;
    position: fixed;
    inset: 0;
    z-index: 90;
    background: rgba(0,0,0,.62);
    opacity: 0;
    pointer-events: none;
    transition: .2s ease;
    backdrop-filter: blur(8px);
  }

  body.quick-services-open .quick-services-panel {
    opacity: 1;
    pointer-events: auto;
  }

  .quick-services-card {
    position: absolute;
    left: 14px;
    right: 14px;
    bottom: 104px;
    background:
      linear-gradient(180deg, rgba(18,18,22,.98), rgba(5,5,7,.98));
    border: 1px solid rgba(255,255,255,.14);
    border-radius: 28px;
    padding: 18px;
    box-shadow: 0 30px 90px rgba(0,0,0,.65);
    transform: translateY(16px);
    transition: .22s ease;
  }

  body.quick-services-open .quick-services-card {
    transform: translateY(0);
  }

  .quick-services-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 14px;
  }

  .quick-services-head strong {
    display: block;
    font-family: Rajdhani, Inter, sans-serif;
    font-size: 26px;
    line-height: 1;
  }

  .quick-services-head span {
    display: block;
    margin-top: 4px;
    color: var(--muted);
    font-size: 13px;
  }

  .quick-services-close {
    width: 42px;
    height: 42px;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.12);
    background: rgba(255,255,255,.08);
    color: #fff;
    font-size: 26px;
    font-weight: 800;
  }

  .quick-services-links {
    display: grid;
    grid-template-columns: 1fr;
    gap: 9px;
  }

  .quick-services-links a {
    display: block;
    padding: 14px 15px;
    border-radius: 17px;
    background: rgba(255,255,255,.065);
    border: 1px solid rgba(255,255,255,.09);
    color: #fff;
    font-weight: 900;
    text-decoration: none;
  }

  .quick-services-links a:first-child {
    background: linear-gradient(135deg, var(--yellow), #f08b00);
    color: #111;
  }

  .quick-services-links a:nth-child(2) {
    background: linear-gradient(135deg, var(--red), #8e080e);
    color: #fff;
  }

  .floating-cta {
    left: 14px;
    right: 14px;
    bottom: 14px;
    z-index: 65;
  }

  .floating-cta a {
    min-height: 58px;
  }
}


/* V30.1 mobile navigation visual fixes */
@media(max-width: 980px) {
  .nav {
    top: 108px !important;
    max-height: calc(100vh - 190px) !important;
    padding: 18px 16px 22px !important;
    gap: 9px !important;
  }

  .mobile-quick-grid {
    margin-top: 2px !important;
  }

  .mobile-quick-grid a {
    min-height: 54px;
    display: flex !important;
    align-items: center;
    justify-content: center;
    line-height: 1.15;
  }

  body.nav-open .floating-cta,
  body.nav-open .floating-service-button {
    opacity: 0 !important;
    pointer-events: none !important;
    transform: translateY(18px);
  }
}

@media(max-width: 640px) {
  body {
    padding-bottom: 112px;
  }

  .floating-cta {
    left: 18px !important;
    right: 18px !important;
    bottom: 14px !important;
    gap: 12px !important;
    align-items: center;
  }

  .floating-cta a {
    min-height: 52px !important;
    padding: 12px 14px !important;
    border-radius: 22px !important;
    font-size: 18px !important;
    flex: 1;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 14px 36px rgba(0,0,0,.36) !important;
  }

  .float-whatsapp {
    background: linear-gradient(135deg, #20c063, #06863b) !important;
  }

  .float-call {
    background: linear-gradient(135deg, #ff202b, #b70b13) !important;
  }

  .floating-service-button {
    right: 18px !important;
    bottom: 78px !important;
  }

  .floating-service-button button {
    min-height: 46px;
    padding: 10px 17px !important;
    border-radius: 18px !important;
    box-shadow: 0 12px 32px rgba(0,0,0,.32) !important;
  }

  .quick-services-card {
    bottom: 92px !important;
  }

  .quick-services-links a {
    min-height: 50px;
    display: flex !important;
    align-items: center;
    justify-content: center;
    text-align: center;
    font-size: 15px;
  }

  .quick-services-links a:nth-child(1) {
    background: linear-gradient(135deg, #ffd400, #f08b00) !important;
    color: #111 !important;
  }

  .quick-services-links a:nth-child(2) {
    background: linear-gradient(135deg, #ed1c24, #8e080e) !important;
    color: #fff !important;
  }

  .quick-services-links a:nth-child(3) {
    background: linear-gradient(135deg, #ff5a1f, #b3350b) !important;
    color: #fff !important;
  }

  .quick-services-links a:nth-child(4) {
    background: linear-gradient(135deg, #7c3aed, #3b1d82) !important;
    color: #fff !important;
  }

  .quick-services-links a:nth-child(5) {
    background: linear-gradient(135deg, #2563eb, #0b3a9a) !important;
    color: #fff !important;
  }

  .quick-services-links a:nth-child(6) {
    background: linear-gradient(135deg, #16a34a, #056b2b) !important;
    color: #fff !important;
  }
}


/* V30.2 mobile navigation reset: cleaner full-screen menu and 3-button bottom action bar */
@media(max-width: 980px) {
  .nav {
    position: fixed !important;
    inset: 0 !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    width: 100vw !important;
    height: 100vh !important;
    max-height: 100vh !important;
    overflow-y: auto !important;
    z-index: 999 !important;
    display: none;
    flex-direction: column;
    justify-content: flex-start;
    padding: 92px 22px 34px !important;
    border-radius: 0 !important;
    border: 0 !important;
    background:
      radial-gradient(circle at 20% 0%, rgba(237,28,36,.30), transparent 28%),
      linear-gradient(180deg, rgba(6,6,8,.98), rgba(0,0,0,.98)) !important;
    box-shadow: none !important;
    backdrop-filter: blur(18px);
  }

  .nav.open {
    display: flex !important;
  }

  .nav:before {
    content: "Autodoc Ghana";
    position: absolute;
    top: 24px;
    left: 24px;
    font-family: Rajdhani, Inter, sans-serif;
    font-size: 28px;
    font-weight: 900;
    letter-spacing: .02em;
  }

  .nav:after {
    content: "Tap a service to continue";
    position: absolute;
    top: 56px;
    left: 24px;
    color: var(--muted);
    font-size: 13px;
    font-weight: 700;
  }

  body.nav-open {
    overflow: hidden;
  }

  body.nav-open .topbar {
    z-index: 1000;
    background: transparent;
    border-bottom-color: transparent;
    backdrop-filter: none;
  }

  body.nav-open .brand {
    opacity: 0;
    pointer-events: none;
  }

  body.nav-open .nav-toggle {
    position: fixed;
    top: 18px;
    right: 18px;
    z-index: 1002;
    background: rgba(255,255,255,.10);
    border-color: rgba(255,255,255,.18);
  }

  body.nav-open .nav-toggle span:nth-child(1) {
    transform: translateY(9px) rotate(45deg);
  }

  body.nav-open .nav-toggle span:nth-child(2) {
    opacity: 0;
  }

  body.nav-open .nav-toggle span:nth-child(3) {
    transform: translateY(-9px) rotate(-45deg);
  }

  .mobile-nav-head {
    display: none !important;
  }

  .mobile-quick-grid {
    display: grid !important;
    grid-template-columns: 1fr;
    gap: 12px !important;
    width: 100%;
    margin: 0 0 22px !important;
  }

  .mobile-quick-grid a {
    min-height: 58px !important;
    border-radius: 22px !important;
    display: flex !important;
    align-items: center;
    justify-content: center;
    font-size: 18px !important;
    box-shadow: 0 16px 42px rgba(0,0,0,.30);
  }

  .mobile-nav-label {
    display: block !important;
    margin: 2px 0 10px !important;
    text-align: left !important;
    letter-spacing: .18em;
    padding-left: 4px;
  }

  .nav > a {
    width: 100%;
    min-height: 50px;
    padding: 14px 15px !important;
    border-radius: 18px !important;
    margin: 0 0 9px !important;
    background: rgba(255,255,255,.065) !important;
    border: 1px solid rgba(255,255,255,.10) !important;
    text-align: left !important;
    font-size: 16px !important;
  }

  .nav > a.active {
    background: linear-gradient(135deg, rgba(237,28,36,.95), rgba(130,10,15,.90)) !important;
  }
}

@media(max-width: 640px) {
  body {
    padding-bottom: 92px !important;
  }

  .hero-v3 {
    padding-bottom: 112px !important;
  }

  .hero-actions {
    gap: 12px !important;
  }

  .hero-actions .btn {
    width: 100%;
    min-height: 56px;
  }

  .hero-actions .btn-dark {
    display: none !important;
  }

  .floating-service-button {
    display: block !important;
    position: fixed !important;
    left: 12px !important;
    right: auto !important;
    bottom: 12px !important;
    z-index: 70 !important;
    width: calc(33.333% - 12px);
  }

  .floating-service-button button {
    width: 100% !important;
    min-height: 54px !important;
    padding: 8px 6px !important;
    border-radius: 18px !important;
    font-size: 15px !important;
    box-shadow: 0 14px 34px rgba(0,0,0,.35) !important;
  }

  .floating-cta {
    left: calc(33.333% + 4px) !important;
    right: 12px !important;
    bottom: 12px !important;
    gap: 8px !important;
    z-index: 70 !important;
  }

  .floating-cta a {
    min-height: 54px !important;
    border-radius: 18px !important;
    font-size: 16px !important;
    padding: 8px 6px !important;
    box-shadow: 0 14px 34px rgba(0,0,0,.35) !important;
  }

  body.nav-open .floating-cta,
  body.nav-open .floating-service-button {
    display: none !important;
  }

  .quick-services-card {
    bottom: 84px !important;
    left: 12px !important;
    right: 12px !important;
    max-height: calc(100vh - 120px);
    overflow-y: auto;
  }

  .quick-services-links {
    gap: 10px !important;
  }

  .quick-services-links a {
    min-height: 52px;
    border-radius: 18px;
  }
}


/* V30.3 header and hero navigation polish */
.hero-service-pills {
  align-items: center;
}

.hero-service-pills a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  text-decoration: none;
  padding: 10px 15px;
  border-radius: 999px;
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.16);
  font-weight: 950;
  font-size: 13px;
  letter-spacing: .04em;
  text-transform: uppercase;
  line-height: 1.1;
  box-shadow: 0 12px 30px rgba(0,0,0,.20);
  transition: .18s ease;
}

.hero-service-pills a:hover {
  transform: translateY(-2px);
  background: rgba(237,28,36,.26);
  border-color: rgba(237,28,36,.55);
}

/* Desktop header: more premium, logo left + nav center + CTA right */
@media(min-width: 981px) {
  .topbar {
    justify-content: space-between;
    padding: 10px 28px;
    gap: 18px;
  }

  .brand {
    flex: 0 0 auto;
  }

  .brand img {
    width: 170px;
    height: 56px;
  }

  .nav {
    flex: 1 1 auto;
    justify-content: center;
    max-width: 920px;
    margin: 0 auto;
    background: rgba(255,255,255,.035);
    border: 1px solid rgba(255,255,255,.07);
    border-radius: 999px;
    padding: 5px;
    backdrop-filter: blur(12px);
  }

  .nav a {
    padding: 10px 12px;
    font-size: 13px;
    white-space: nowrap;
  }

  .top-actions {
    flex: 0 0 auto;
  }

  .top-actions .phone-link {
    display: none;
  }

  .top-actions .btn-small {
    padding: 11px 16px;
  }

  .top-actions:before {
    content: "Estimate";
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 39px;
    padding: 9px 15px;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--yellow), #f08b00);
    color: #151515;
    font-weight: 950;
    font-size: 13px;
  }
}

/* Mobile header: logo left, menu right */
@media(max-width: 980px) {
  .topbar {
    justify-content: space-between !important;
    gap: 12px !important;
  }

  .brand {
    margin-right: auto;
  }

  .nav-toggle {
    margin-left: auto;
  }

  .mobile-quick-grid .quick-estimate {
    background: linear-gradient(135deg, #16c65f, #057936) !important;
    color: #fff !important;
    border-color: rgba(255,255,255,.16) !important;
    box-shadow: 0 16px 42px rgba(22,198,95,.22) !important;
  }
}

@media(max-width: 640px) {
  .hero-service-pills {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 9px !important;
    margin-top: 22px;
  }

  .hero-service-pills a {
    min-height: 42px;
    font-size: 12px;
    padding: 10px 8px;
    text-align: center;
  }

  .hero-service-pills a:nth-child(5) {
    grid-column: 1 / -1;
  }
}


/* V30.4 desktop header CTA and spacing fix */
@media(min-width: 981px) {
  .nav {
    max-width: 980px !important;
    padding: 6px 10px !important;
    gap: 6px !important;
  }

  .nav a {
    padding: 11px 15px !important;
  }

  .top-actions {
    gap: 10px !important;
  }

  .top-actions:before {
    display: none !important;
    content: none !important;
  }

  .top-actions .top-estimate {
    display: inline-flex !important;
    background: linear-gradient(135deg, var(--yellow), #f08b00) !important;
    color: #151515 !important;
    box-shadow: 0 14px 34px rgba(255,196,0,.20);
    border-color: rgba(255,255,255,.12);
  }

  .top-actions .btn-small {
    min-height: 44px;
    padding: 12px 18px !important;
    border-radius: 999px;
  }
}

@media(max-width: 1180px) and (min-width: 981px) {
  .brand img {
    width: 145px !important;
  }

  .nav {
    max-width: 780px !important;
  }

  .nav a {
    font-size: 12px !important;
    padding: 10px 10px !important;
  }

  .top-actions .btn-small {
    padding: 11px 14px !important;
  }
}


/* V31 header CTA + gallery video upgrade */
@media(min-width: 981px) {
  .nav {
    padding: 6px 18px !important;
    gap: 8px !important;
    overflow: hidden;
  }

  .nav a:first-of-type {
    margin-left: 4px;
  }

  .nav a:last-of-type {
    margin-right: 4px;
  }

  .top-actions .top-phone {
    display: inline-flex !important;
    background: rgba(255,255,255,.08) !important;
    border-color: rgba(255,255,255,.16) !important;
    color: #fff !important;
    white-space: nowrap;
  }
}

.video-gallery-item {
  appearance: none;
  border: 0;
  padding: 0;
  text-align: left;
  color: inherit;
  cursor: pointer;
  width: 100%;
  font: inherit;
}

.video-thumb {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 260px;
  overflow: hidden;
  border-radius: inherit;
  background: linear-gradient(135deg, rgba(237,28,36,.22), rgba(255,212,0,.12));
}

.video-thumb img {
  width: 100%;
  height: 100%;
  min-height: 260px;
  object-fit: cover;
  display: block;
  transition: transform .35s ease;
}

.video-gallery-item:hover .video-thumb img {
  transform: scale(1.04);
}

.video-placeholder {
  min-height: 260px;
  display: grid;
  place-items: center;
  text-align: center;
  font-family: Rajdhani, Inter, sans-serif;
  font-size: 42px;
  font-weight: 900;
  line-height: .9;
  color: rgba(255,255,255,.9);
}

.play-badge {
  position: absolute;
  inset: 50% auto auto 50%;
  transform: translate(-50%, -50%);
  width: 74px;
  height: 74px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, var(--red), #8e080e);
  color: #fff;
  font-size: 28px;
  box-shadow: 0 20px 60px rgba(0,0,0,.45);
  border: 2px solid rgba(255,255,255,.35);
}

.gallery-caption span {
  display: block;
  color: var(--muted);
  font-size: 13px;
  margin-top: 4px;
}

.video-modal {
  position: fixed;
  inset: 0;
  z-index: 200;
  background: rgba(0,0,0,.82);
  backdrop-filter: blur(10px);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 22px;
}

.video-modal.open {
  display: flex;
}

.video-modal-card {
  width: min(980px, 100%);
  background: linear-gradient(180deg, rgba(20,20,24,.98), rgba(5,5,7,.98));
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 28px;
  padding: 18px;
  position: relative;
  box-shadow: 0 35px 120px rgba(0,0,0,.70);
}

.video-modal-card h3 {
  font-size: 28px;
  margin: 0 54px 14px 2px;
}

.video-modal-card video {
  width: 100%;
  max-height: 72vh;
  border-radius: 20px;
  background: #000;
  display: block;
}

.video-modal-close {
  position: absolute;
  right: 16px;
  top: 14px;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.08);
  color: #fff;
  font-size: 28px;
  font-weight: 800;
  cursor: pointer;
}

@media(max-width: 640px) {
  .video-thumb,
  .video-thumb img,
  .video-placeholder {
    min-height: 300px;
  }

  .video-modal {
    padding: 12px;
  }

  .video-modal-card {
    border-radius: 22px;
    padding: 14px;
  }

  .video-modal-card h3 {
    font-size: 23px;
  }
}


/* V31.1 Desktop header polish */
@media(min-width: 981px) {
  .topbar {
    padding: 10px 24px !important;
    gap: 20px !important;
  }

  .brand img {
    width: 165px !important;
    height: 56px !important;
  }

  .nav {
    max-width: 760px !important;
    width: auto !important;
    flex: 0 1 auto !important;
    justify-content: center !important;
    padding: 7px 18px !important;
    gap: 6px !important;
    overflow: visible !important;
    border-radius: 999px !important;
    background: rgba(255,255,255,.045) !important;
    border: 1px solid rgba(255,255,255,.11) !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.05), 0 12px 36px rgba(0,0,0,.18);
  }

  .nav .desktop-hide {
    display: none !important;
  }

  .nav a {
    padding: 11px 14px !important;
    font-size: 13px !important;
    border-radius: 999px !important;
    white-space: nowrap !important;
  }

  .nav a:first-of-type,
  .nav a:last-of-type {
    margin: 0 !important;
  }

  .nav a.active {
    background: linear-gradient(135deg, rgba(237,28,36,.78), rgba(92,7,11,.80)) !important;
    box-shadow: 0 10px 26px rgba(237,28,36,.18);
  }

  .top-actions {
    display: flex !important;
    gap: 10px !important;
    align-items: center !important;
    flex: 0 0 auto !important;
  }

  .top-actions .top-estimate {
    min-height: 45px !important;
    padding: 12px 19px !important;
    font-size: 14px !important;
    background: linear-gradient(135deg, var(--yellow), #f08b00) !important;
    color: #111 !important;
    box-shadow: 0 14px 34px rgba(255,196,0,.22) !important;
  }

  .top-actions .top-phone {
    min-height: 45px !important;
    padding: 12px 19px !important;
    font-size: 14px !important;
    background: linear-gradient(135deg, rgba(255,255,255,.17), rgba(255,255,255,.075)) !important;
    border: 1px solid rgba(255,255,255,.24) !important;
    color: #fff !important;
    box-shadow: 0 14px 34px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.08) !important;
  }

  .top-actions .top-phone:before {
    content: "☎";
    margin-right: 7px;
    font-size: 14px;
  }
}

@media(max-width: 1180px) and (min-width: 981px) {
  .brand img {
    width: 135px !important;
  }

  .nav {
    max-width: 690px !important;
    padding-left: 14px !important;
    padding-right: 14px !important;
  }

  .nav a {
    padding: 10px 11px !important;
    font-size: 12px !important;
  }

  .top-actions .top-estimate,
  .top-actions .top-phone {
    padding: 11px 14px !important;
    font-size: 13px !important;
  }
}
/* Hero call button polish */
.hero-actions .btn-dark {
  background: linear-gradient(135deg, rgba(255,255,255,.18), rgba(255,255,255,.07)) !important;
  border: 1px solid rgba(255,255,255,.28) !important;
  color: #fff !important;
  box-shadow: 0 14px 34px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.10) !important;
}

.hero-actions .btn-dark:hover {
  background: linear-gradient(135deg, rgba(255,255,255,.24), rgba(255,255,255,.10)) !important;
  border-color: rgba(255,255,255,.42) !important;
}
@media(min-width: 981px) {
  .nav {
    max-width: 830px !important;
  }

  .nav a {
    padding-left: 12px !important;
    padding-right: 12px !important;
  }
}
/* Hero call button - green action style */
.hero-actions .btn-dark {
  background: linear-gradient(135deg, #20c063, #06863b) !important;
  border: 1px solid rgba(255,255,255,.18) !important;
  color: #fff !important;
  box-shadow: 0 16px 40px rgba(6,134,59,.28) !important;
  text-shadow: none !important;
}

.hero-actions .btn-dark::before {
  content: none !important;
  display: none !important;
}

.hero-actions .btn-dark:hover {
  background: linear-gradient(135deg, #27d873, #079344) !important;
  border-color: rgba(255,255,255,.28) !important;
  transform: translateY(-2px);
}

/* V32 Cinematic Hero Background + Admin Control */
.hero-v3.hero-motion {
  isolation: isolate;
}

.hero-v3.hero-motion .hero-v3-bg {
  transform: scale(1.045);
  will-change: transform, filter;
  animation: autodocHeroPanSlow 24s ease-in-out infinite alternate;
}

.hero-v3.hero-motion-medium .hero-v3-bg {
  animation-duration: 17s;
}

.hero-v3.hero-motion-fast .hero-v3-bg {
  animation-duration: 12s;
}

.hero-v3.hero-motion-zoom .hero-v3-bg {
  animation-name: autodocHeroZoom;
}

.hero-v3.hero-motion-glow .hero-v3-bg {
  animation-name: autodocHeroGlowOnly;
}

@keyframes autodocHeroPanSlow {
  0% {
    transform: scale(1.045) translate3d(-1.2%, -0.6%, 0);
    filter: contrast(1.08) saturate(1.05) brightness(.98);
  }
  50% {
    transform: scale(1.075) translate3d(1.1%, .5%, 0);
    filter: contrast(1.12) saturate(1.12) brightness(1.03);
  }
  100% {
    transform: scale(1.055) translate3d(-.4%, .9%, 0);
    filter: contrast(1.09) saturate(1.08) brightness(1);
  }
}

@keyframes autodocHeroZoom {
  0% {
    transform: scale(1.035);
    filter: contrast(1.08) saturate(1.05);
  }
  100% {
    transform: scale(1.095);
    filter: contrast(1.12) saturate(1.13);
  }
}

@keyframes autodocHeroGlowOnly {
  0%, 100% {
    filter: contrast(1.08) saturate(1.05) brightness(.98);
  }
  50% {
    filter: contrast(1.12) saturate(1.13) brightness(1.04);
  }
}

.hero-light-sweep {
  position: absolute;
  inset: -20% -45%;
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(115deg, transparent 0%, transparent 42%, rgba(255,255,255,.13) 49%, rgba(255,212,0,.10) 52%, transparent 61%, transparent 100%);
  mix-blend-mode: screen;
  transform: translateX(-44%) rotate(0.001deg);
  opacity: .52;
  animation: autodocHeroSweep 8.5s ease-in-out infinite;
}

.hero-motion-medium .hero-light-sweep {
  animation-duration: 6.5s;
}

.hero-motion-fast .hero-light-sweep {
  animation-duration: 4.8s;
}

.hero-motion-glow .hero-light-sweep {
  display: none;
}

@keyframes autodocHeroSweep {
  0%, 18% {
    transform: translateX(-48%);
    opacity: 0;
  }
  38% {
    opacity: .50;
  }
  56% {
    transform: translateX(42%);
    opacity: .18;
  }
  100% {
    transform: translateX(56%);
    opacity: 0;
  }
}

.hero-red-glow {
  position: absolute;
  width: 42vw;
  height: 42vw;
  min-width: 360px;
  min-height: 360px;
  right: 5%;
  bottom: 0;
  z-index: 1;
  pointer-events: none;
  background: radial-gradient(circle, rgba(237,28,36,.22), rgba(255,212,0,.08) 35%, transparent 66%);
  filter: blur(6px);
  opacity: .62;
  animation: autodocHeroGlow 7.5s ease-in-out infinite alternate;
}

@keyframes autodocHeroGlow {
  0% {
    transform: translate3d(-2%, 2%, 0) scale(.96);
    opacity: .42;
  }
  100% {
    transform: translate3d(2%, -1%, 0) scale(1.06);
    opacity: .70;
  }
}

/* Keep text above motion layers */
.hero-v3-content {
  z-index: 3;
}

@media(max-width: 640px) {
  .hero-v3.hero-motion-mobile-light .hero-v3-bg {
    animation-duration: 28s;
    transform: scale(1.03);
  }

  .hero-v3.hero-motion-mobile-static .hero-v3-bg,
  .hero-v3.hero-motion-mobile-static .hero-light-sweep,
  .hero-v3.hero-motion-mobile-static .hero-red-glow {
    animation: none !important;
  }

  .hero-v3.hero-motion-mobile-static .hero-light-sweep,
  .hero-v3.hero-motion-mobile-static .hero-red-glow {
    display: none !important;
  }

  .hero-light-sweep {
    opacity: .28;
  }

  .hero-red-glow {
    width: 70vw;
    height: 70vw;
    right: -20%;
    opacity: .35;
  }
}

@media(prefers-reduced-motion: reduce) {
  .hero-v3.hero-motion .hero-v3-bg,
  .hero-light-sweep,
  .hero-red-glow {
    animation: none !important;
  }
}


/* V33 SEO + service areas polish */
.card-pad .kicker {
  margin-bottom: 14px;
}

.article-body h2,
.article-body h3 {
  margin-top: 24px;
}

@media(max-width: 640px) {
  .cards .card-pad {
    min-height: auto;
  }
}

/* V33.1 homepage service areas fix */
.service-areas-home {
  padding-top: 72px;
  padding-bottom: 72px;
  background: radial-gradient(circle at 10% 0%, rgba(237,28,36,.08), transparent 28%);
}

.service-areas-home .card .kicker {
  margin-bottom: 14px;
}


/* V36 Blog image/video upgrade */
.article-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}

.article-meta span {
  display: inline-flex;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.08);
  border-radius: 999px;
  padding: 8px 12px;
  font-weight: 900;
  font-size: 12px;
  color: #fff;
}

.article-main-media video {
  width: 100%;
  min-height: 360px;
  max-height: 520px;
  object-fit: cover;
  display: block;
  border-radius: 22px;
  background: #000;
}

.article-gallery-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}

.article-gallery-grid a {
  display: block;
  border-radius: 20px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
}

.article-gallery-grid img {
  width: 100%;
  height: 230px;
  object-fit: cover;
  display: block;
  transition: transform .25s ease;
}

.article-gallery-grid a:hover img {
  transform: scale(1.04);
}

.article-card-photo {
  position: relative;
}

.video-mini-badge {
  position: absolute;
  left: 14px;
  top: 14px;
  background: linear-gradient(135deg, #ed1c24, #8e080e);
  color: #fff;
  border-radius: 999px;
  padding: 7px 11px;
  font-weight: 950;
  font-size: 12px;
  box-shadow: 0 12px 32px rgba(0,0,0,.35);
}

.admin-video-preview {
  width: 100%;
  max-height: 220px;
  border-radius: 16px;
  background: #000;
  border: 1px solid rgba(255,255,255,.12);
  margin-bottom: 10px;
}

.article-admin-gallery {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  margin-bottom: 12px;
}

.article-admin-gallery img {
  width: 100%;
  height: 110px;
  object-fit: cover;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.12);
}

.article-admin-gallery form {
  margin-top: 6px;
}

@media(max-width: 820px) {
  .article-gallery-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .article-admin-gallery {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media(max-width: 560px) {
  .article-gallery-grid {
    grid-template-columns: 1fr;
  }

  .article-gallery-grid img {
    height: 260px;
  }

  .article-main-media video {
    min-height: 260px;
  }
}


/* V36.3 Article multi-video player */
.article-video-player {
  position: relative;
  border-radius: 22px;
  overflow: hidden;
  background: #000;
}

.article-video-player video {
  width: 100%;
  min-height: 360px;
  max-height: 520px;
  object-fit: cover;
  display: block;
  background: #000;
}

.article-video-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 5;
  width: 46px;
  height: 70px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.22);
  background: rgba(0,0,0,.45);
  color: #fff;
  font-size: 46px;
  line-height: 1;
  display: grid;
  place-items: center;
  cursor: pointer;
  opacity: 0;
  transition: opacity .2s ease, background .2s ease, transform .2s ease;
  backdrop-filter: blur(8px);
}

.article-video-player:hover .article-video-nav {
  opacity: 1;
}

.article-video-prev {
  left: 14px;
}

.article-video-next {
  right: 14px;
}

.article-video-nav:hover {
  background: rgba(237,28,36,.82);
  transform: translateY(-50%) scale(1.04);
}

.article-big-play {
  position: absolute;
  inset: 0;
  margin: auto;
  z-index: 4;
  width: 82px;
  height: 82px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.30);
  background: rgba(237,28,36,.90);
  color: #fff;
  font-size: 34px;
  padding-left: 6px;
  cursor: pointer;
  box-shadow: 0 18px 50px rgba(0,0,0,.42);
  transition: opacity .2s ease, transform .2s ease;
}

.article-big-play:hover {
  transform: scale(1.05);
}

.article-big-play.hidden {
  opacity: 0;
  pointer-events: none;
}

.article-video-thumbs {
  display: flex;
  gap: 10px;
  overflow-x: auto;
  padding: 12px 2px 2px;
}

.article-video-thumbs button {
  min-width: 126px;
  border: 1px solid rgba(255,255,255,.13);
  background: rgba(255,255,255,.05);
  border-radius: 16px;
  padding: 7px;
  color: #fff;
  cursor: pointer;
  text-align: left;
}

.article-video-thumbs button.active {
  border-color: rgba(237,28,36,.72);
  background: rgba(237,28,36,.14);
}

.article-video-thumbs img {
  width: 100%;
  height: 70px;
  object-fit: cover;
  border-radius: 10px;
  display: block;
  margin-bottom: 6px;
}

.article-video-thumbs span {
  display: block;
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

@media(max-width: 640px) {
  .article-video-player video {
    min-height: 260px;
  }
  .article-video-nav {
    opacity: 1;
    width: 40px;
    height: 58px;
    font-size: 36px;
  }
}


/* V36.4 cleaner article video player */
.article-main-media .article-video-thumbs {
  display: flex !important;
  flex-wrap: nowrap !important;
  gap: 8px !important;
  overflow-x: auto !important;
  padding: 10px 2px 0 !important;
  max-width: 100% !important;
}

.article-main-media .article-video-thumbs button {
  flex: 0 0 92px !important;
  min-width: 92px !important;
  max-width: 92px !important;
  border-radius: 14px !important;
  padding: 5px !important;
}

.article-main-media .article-video-thumbs img {
  width: 100% !important;
  height: 52px !important;
  object-fit: cover !important;
  border-radius: 9px !important;
  display: block !important;
}

.article-main-media .article-video-thumbs span {
  font-size: 10px !important;
  line-height: 1.15 !important;
}

.article-big-play.is-playing {
  opacity: 0;
  background: rgba(0,0,0,.55);
  font-size: 26px;
  padding-left: 0;
}

.article-video-player:hover .article-big-play.is-playing {
  opacity: 1;
}

.article-video-player:hover .article-big-play {
  opacity: 1;
}

.article-video-player video {
  cursor: pointer;
}

@media(max-width: 640px) {
  .article-main-media .article-video-thumbs button {
    flex-basis: 82px !important;
    min-width: 82px !important;
    max-width: 82px !important;
  }
}


/* V36.5 clean compact article video selector */
.article-main-media {
  align-self: start;
}

.article-main-media .article-video-player {
  border-radius: 22px 22px 14px 14px;
}

.article-main-media .article-video-thumbs {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(78px, 96px)) !important;
  gap: 8px !important;
  padding: 10px !important;
  margin: 0 !important;
  background: rgba(0,0,0,.72) !important;
  border: 1px solid rgba(255,255,255,.10) !important;
  border-top: 0 !important;
  border-radius: 0 0 22px 22px !important;
  max-height: 92px !important;
  overflow-x: auto !important;
  overflow-y: hidden !important;
  align-items: start !important;
}

.article-main-media .article-video-thumbs button {
  width: 100% !important;
  min-width: 0 !important;
  max-width: 96px !important;
  height: 72px !important;
  min-height: 72px !important;
  max-height: 72px !important;
  padding: 4px !important;
  margin: 0 !important;
  border-radius: 12px !important;
  background: rgba(255,255,255,.055) !important;
  overflow: hidden !important;
}

.article-main-media .article-video-thumbs img {
  display: block !important;
  width: 100% !important;
  height: 44px !important;
  min-height: 44px !important;
  max-height: 44px !important;
  aspect-ratio: 16 / 9 !important;
  object-fit: cover !important;
  border-radius: 8px !important;
  margin: 0 0 4px !important;
}

.article-main-media .article-video-thumbs span {
  display: block !important;
  height: 14px !important;
  line-height: 14px !important;
  font-size: 9px !important;
  font-weight: 900 !important;
  color: rgba(255,255,255,.78) !important;
  overflow: hidden !important;
  white-space: nowrap !important;
  text-overflow: ellipsis !important;
}

.article-main-media .article-video-thumbs button.active {
  border-color: #ed1c24 !important;
  background: rgba(237,28,36,.18) !important;
}

/* Do not let the pause overlay cover mobile videos while playing. Native controls remain usable. */
@media (hover: none), (max-width: 700px) {
  .article-big-play.is-playing {
    display: none !important;
  }

  .article-video-player:hover .article-big-play.is-playing {
    display: none !important;
  }

  .article-main-media .article-video-thumbs {
    grid-template-columns: repeat(auto-fit, minmax(70px, 84px)) !important;
    max-height: 86px !important;
  }

  .article-main-media .article-video-thumbs button {
    height: 66px !important;
    min-height: 66px !important;
    max-height: 66px !important;
  }

  .article-main-media .article-video-thumbs img {
    height: 39px !important;
    min-height: 39px !important;
    max-height: 39px !important;
  }
}


/* V36.6 video thumbnails click + mobile pause fix */
.article-main-media .article-video-thumbs {
  position: relative !important;
  z-index: 20 !important;
  pointer-events: auto !important;
}

.article-main-media .article-video-thumbs button,
.article-main-media .article-video-thumbs button * {
  pointer-events: auto !important;
}

.article-main-media .article-video-thumbs button {
  cursor: pointer !important;
}

.article-main-media .article-video-thumbs button:hover {
  transform: translateY(-1px);
  border-color: rgba(255,255,255,.35) !important;
}

.article-main-media .article-video-thumbs button.active:hover {
  border-color: #ed1c24 !important;
}

.article-video-player .article-video-el {
  position: relative;
  z-index: 1;
}

.article-video-player .article-big-play {
  z-index: 6;
}

/* On mobile, the overlay hides while playing, and tapping the video pauses/plays. */
@media (hover: none), (max-width: 700px) {
  .article-video-player .article-video-el {
    cursor: pointer;
  }

  .article-video-player .article-big-play.is-playing {
    opacity: 0 !important;
    pointer-events: none !important;
    display: none !important;
  }
}


/* V39 organized footer */
.footer-v39 .footer-grid-v39 {
  grid-template-columns: minmax(240px, 1.4fr) repeat(5, minmax(130px, 1fr));
  gap: 28px;
  align-items: start;
}

.footer-brand-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 16px;
}

.footer-mini-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 9px 13px;
  border-radius: 999px;
  background: rgba(237, 28, 36, .16);
  border: 1px solid rgba(237, 28, 36, .34);
  color: #fff;
  font-weight: 900;
  text-decoration: none;
}

.footer-mini-btn.yellow {
  background: linear-gradient(135deg, #ffd400, #f0a000);
  color: #111;
  border: 0;
}

.footer-link-group a {
  line-height: 1.35;
  margin-bottom: 9px;
}

.footer-contact p {
  margin-bottom: 12px;
}

@media (max-width: 1180px) {
  .footer-v39 .footer-grid-v39 {
    grid-template-columns: repeat(3, 1fr);
  }
  .footer-brand {
    grid-column: 1 / -1;
  }
}

@media (max-width: 760px) {
  .footer-v39 .footer-grid-v39 {
    grid-template-columns: 1fr 1fr;
    gap: 22px;
  }
  .footer-brand,
  .footer-contact {
    grid-column: 1 / -1;
  }
}

@media (max-width: 480px) {
  .footer-v39 .footer-grid-v39 {
    grid-template-columns: 1fr;
  }
}


/* V40 footer social icons */
.footer-social-links {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 16px;
}

.footer-social-links a {
  width: 42px;
  height: 42px;
  display: inline-grid;
  place-items: center;
  border-radius: 999px;
  background: rgba(255,255,255,.075);
  border: 1px solid rgba(255,255,255,.14);
  color: #fff;
  transition: transform .2s ease, background .2s ease, border-color .2s ease;
}

.footer-social-links a:hover {
  transform: translateY(-2px);
  background: rgba(237,28,36,.18);
  border-color: rgba(237,28,36,.45);
}

.footer-social-links svg {
  width: 20px;
  height: 20px;
  fill: currentColor;
  display: block;
}

.footer-social-links span {
  font-weight: 950;
  font-size: 16px;
}


/* V46 Blog SEO + Related Articles */
.article-quick-links,
.blog-topic-links {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
  margin: 18px 0 20px;
}

.article-quick-links a,
.blog-topic-links a {
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  padding: 8px 13px;
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.13);
  color: #fff;
  text-decoration: none;
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .04em;
}

.article-quick-links a:hover,
.blog-topic-links a:hover {
  border-color: rgba(237,28,36,.45);
  background: rgba(237,28,36,.16);
}

.related-articles-section {
  padding-top: 40px;
}

.related-articles-section .photo-card .kicker {
  margin-bottom: 10px;
}

@media(max-width: 640px) {
  .article-quick-links a,
  .blog-topic-links a {
    font-size: 11px;
    padding: 8px 11px;
  }
}

/* V48 restore mobile service areas combined card */
.mobile-service-area-card{display:none}
@media(max-width:760px){.service-areas-home{padding-top:48px;padding-bottom:48px}.service-areas-desktop-cards{display:none!important}.mobile-service-area-card{display:block}.mobile-service-area-card-inner{padding:24px;border-radius:26px;background:radial-gradient(circle at top left,rgba(237,28,36,.16),transparent 38%),linear-gradient(135deg,rgba(255,255,255,.085),rgba(255,255,255,.035));border:1px solid rgba(255,255,255,.14);box-shadow:0 22px 70px rgba(0,0,0,.28)}.mobile-service-area-card h3{margin:14px 0 12px;font-size:clamp(27px,8vw,38px);line-height:.98}.mobile-service-area-card p{color:var(--muted);font-size:15.5px;line-height:1.6;margin:0 0 18px}.area-pills{display:flex;flex-wrap:wrap;gap:9px;margin:16px 0 20px}.area-pills a{display:inline-flex;align-items:center;min-height:34px;padding:8px 13px;border-radius:999px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.13);color:#fff;font-size:12px;font-weight:950;text-transform:uppercase;letter-spacing:.04em;text-decoration:none}.area-pills a:before{content:"";width:8px;height:8px;border-radius:99px;background:var(--red);margin-right:8px;box-shadow:0 0 0 4px rgba(237,28,36,.16)}.mobile-area-actions{display:grid;grid-template-columns:1fr;gap:10px}.mobile-area-actions .btn{width:100%;justify-content:center}}
