
:root {
  --black:#080808;
  --charcoal:#141414;
  --red:#d71920;
  --red-dark:#a70f15;
  --gray:#f3f4f6;
  --text:#171717;
  --muted:#666;
  --white:#fff;
}
* { box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { margin:0; font-family: Arial, Helvetica, sans-serif; color:var(--text); background:var(--white); line-height:1.6; }
a { color:inherit; }
img { max-width:100%; display:block; }
.top-bar { display:flex; justify-content:center; gap:28px; flex-wrap:wrap; padding:9px 6%; background:var(--red); color:white; font-weight:800; font-size:14px; }
.top-bar a { text-decoration:none; }
.site-header { position:sticky; top:0; z-index:99; display:flex; align-items:center; justify-content:space-between; gap:24px; padding:16px 6%; background:rgba(8,8,8,.96); color:white; backdrop-filter: blur(10px); border-bottom:1px solid rgba(255,255,255,.08); }
.logo { display:flex; align-items:center; gap:12px; text-decoration:none; text-transform:uppercase; font-weight:900; letter-spacing:.5px; }
.logo small { display:block; color:#ddd; font-size:11px; letter-spacing:1.8px; margin-top:-3px; }
.logo strong { color:var(--red); }
.mark { width:46px; height:46px; display:grid; place-items:center; background:var(--red); border-radius:12px; font-size:16px; }
.nav { display:flex; gap:22px; align-items:center; }
.nav a { text-decoration:none; font-weight:800; opacity:.9; }
.nav a:hover { color:var(--red); }
.menu-btn { display:none; background:transparent; color:white; border:1px solid rgba(255,255,255,.3); padding:8px 12px; border-radius:8px; font-size:22px; }
.hero { min-height:82vh; background-size:cover; background-position:center; display:flex; align-items:center; color:white; padding:90px 6%; }
.hero-inner { max-width:920px; }
.eyebrow { text-transform:uppercase; font-weight:900; letter-spacing:2px; font-size:13px; margin:0 0 10px; }
.red { color:var(--red); }
h1 { font-size:clamp(44px, 7vw, 86px); line-height:.95; margin:0 0 22px; letter-spacing:-2px; }
h2 { font-size:clamp(30px, 4.5vw, 52px); line-height:1.05; margin:0 0 18px; letter-spacing:-1px; }
h3 { font-size:22px; line-height:1.15; margin:0 0 10px; }
.lead { font-size:21px; max-width:760px; color:#f1f1f1; }
.btn { display:inline-block; padding:14px 22px; border-radius:999px; text-decoration:none; font-weight:900; border:0; cursor:pointer; font-size:16px; }
.primary { background:linear-gradient(135deg,var(--red),var(--red-dark)); color:white; box-shadow:0 10px 26px rgba(215,25,32,.32); }
.secondary { color:white; border:2px solid rgba(255,255,255,.9); }
.darkbtn { color:var(--black); border-color:var(--black); }
.hero-actions { display:flex; flex-wrap:wrap; gap:14px; margin:28px 0; }
.trust-row { display:flex; gap:12px; flex-wrap:wrap; margin-top:28px; }
.trust-row span { background:rgba(255,255,255,.14); border:1px solid rgba(255,255,255,.18); padding:10px 14px; border-radius:999px; font-weight:800; }
.quick-contact { display:grid; grid-template-columns:repeat(3,1fr); background:var(--charcoal); color:white; }
.quick-contact a { padding:24px 6%; text-align:center; text-decoration:none; border-right:1px solid rgba(255,255,255,.1); }
.quick-contact span { display:block; color:#fff; font-size:19px; font-weight:900; }
.section { padding:86px 6%; }
.section-head { max-width:900px; margin-bottom:36px; }
.section-head p { color:var(--muted); font-size:18px; }
.center { text-align:center; margin-left:auto; margin-right:auto; }
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.service-card { background:white; border:1px solid #e6e6e6; border-radius:22px; padding:30px; box-shadow:0 10px 30px rgba(0,0,0,.07); transition:transform .2s ease, box-shadow .2s ease; }
.service-card:hover { transform:translateY(-4px); box-shadow:0 16px 40px rgba(0,0,0,.12); }
.icon { width:54px; height:54px; border-radius:16px; display:grid; place-items:center; background:#fff0f1; font-size:26px; margin-bottom:18px; }
.feature { display:grid; grid-template-columns:1fr 1fr; gap:45px; align-items:center; }
.dark { background:var(--black); color:white; }
.feature img { border-radius:24px; height:520px; width:100%; object-fit:cover; box-shadow:0 20px 60px rgba(0,0,0,.35); }
.feature-text p { color:#ddd; font-size:18px; }
.checklist { padding:0; margin:24px 0 0; list-style:none; }
.checklist li { margin:12px 0; padding-left:30px; position:relative; font-weight:800; }
.checklist li:before { content:"✓"; position:absolute; left:0; color:var(--red); }
.process { background:var(--gray); }
.steps { display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.steps div { background:white; padding:26px; border-radius:20px; border:1px solid #e8e8e8; }
.steps span { display:grid; place-items:center; width:44px; height:44px; background:var(--red); color:white; font-weight:900; border-radius:50%; margin-bottom:18px; }
.filters { display:flex; flex-wrap:wrap; gap:10px; margin-bottom:24px; }
.filters button { border:1px solid #ddd; background:white; padding:10px 15px; border-radius:999px; font-weight:900; cursor:pointer; }
.filters button.active, .filters button:hover { background:var(--red); color:white; border-color:var(--red); }
.gallery-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.gallery-item { position:relative; border:0; padding:0; background:transparent; cursor:pointer; border-radius:16px; overflow:hidden; aspect-ratio:1 / .78; }
.gallery-item img { width:100%; height:100%; object-fit:cover; transition:transform .25s ease; }
.gallery-item:hover img { transform:scale(1.05); }
.gallery-item span { position:absolute; left:10px; bottom:10px; right:10px; background:rgba(0,0,0,.7); color:white; padding:8px 10px; border-radius:10px; font-weight:900; text-align:left; }
.testimonials { background:#fff; }
.testimonial-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
blockquote { margin:0; padding:30px; border-radius:22px; background:var(--gray); font-size:20px; font-weight:800; }
cite { display:block; margin-top:18px; color:var(--red); font-style:normal; font-size:15px; }
.quote-section { background:linear-gradient(135deg,#111,#2a0507); }
.quote-card { display:grid; grid-template-columns:.9fr 1.1fr; gap:38px; background:white; border-radius:28px; padding:38px; box-shadow:0 20px 60px rgba(0,0,0,.25); }
.contact-mini a { color:var(--red); font-weight:900; }
form { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
form label { display:grid; gap:6px; font-weight:900; }
input, select, textarea { width:100%; padding:13px 14px; border:1px solid #ddd; border-radius:12px; font:inherit; }
textarea, form button { grid-column:1 / -1; }
.faq { background:var(--gray); }
details { max-width:900px; margin:12px auto; background:white; padding:20px 24px; border-radius:16px; border:1px solid #e5e5e5; }
summary { font-weight:900; cursor:pointer; font-size:18px; }
.contact-final { text-align:center; background:var(--red); color:white; }
.contact-final p { max-width:760px; margin-left:auto; margin-right:auto; font-size:20px; }
.final-actions { display:flex; justify-content:center; gap:14px; flex-wrap:wrap; margin-top:26px; }
.contact-final .primary { background:white; color:var(--red); box-shadow:none; }
footer { background:var(--black); color:white; display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap; padding:34px 6%; }
footer a { color:white; font-weight:900; }
.hidden { display:none !important; }
@media (max-width: 980px) {
  .menu-btn { display:block; }
  .nav { display:none; position:absolute; left:0; right:0; top:78px; background:var(--black); padding:18px 6%; flex-direction:column; align-items:flex-start; }
  .nav.open { display:flex; }
  .quick-contact, .services-grid, .feature, .steps, .gallery-grid, .testimonial-grid, .quote-card { grid-template-columns:1fr; }
  .hero { min-height:78vh; }
  .feature img { height:360px; }
  form { grid-template-columns:1fr; }
  .top-bar { gap:12px; font-size:13px; }
}
