
:root{--navy:#071827;--navy2:#0b2742;--blue:#0e3a63;--gold:#ffc400;--orange:#ff9f1a;--white:#fff;--ink:#0b1622;--muted:#65758a;--light:#f4f7fb;--border:#dfe7ef}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,Montserrat,Arial,sans-serif;color:var(--ink);background:#fff}a{text-decoration:none;color:inherit}img{max-width:100%;display:block}.container{width:min(1180px,92%);margin:auto}.topbar{background:#071827;color:#d6e5f3;font-size:13px}.topbar .container{display:flex;justify-content:space-between;gap:16px;align-items:center;padding:9px 0}.topbar a{color:#fff}.social-mini{display:flex;gap:10px}.social-mini a{border:1px solid rgba(255,255,255,.22);padding:5px 8px;border-radius:999px}.header{position:sticky;top:0;background:#fff;z-index:90;border-bottom:1px solid #e8edf3;box-shadow:0 8px 25px rgba(7,24,39,.06)}.nav{height:88px;display:flex;align-items:center;justify-content:space-between;gap:24px}.logo img{height:62px;width:auto}.menu{display:flex;align-items:center;gap:26px;font-size:13px;text-transform:uppercase;font-weight:900;letter-spacing:.04em;color:#0b2742}.menu a:hover{color:#e79d00}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:6px;padding:14px 21px;font-weight:900;text-transform:uppercase;border:0;cursor:pointer}.btn-gold{background:linear-gradient(135deg,var(--gold),var(--orange));color:#071827;box-shadow:0 14px 30px rgba(255,196,0,.24)}.btn-dark{background:#071827;color:#fff}.btn-outline{border:1px solid rgba(255,255,255,.48);color:#fff;background:rgba(255,255,255,.04)}.hamb{display:none;font-size:30px;background:transparent;border:0}.hero{position:relative;min-height:720px;color:#fff;background:
  linear-gradient(90deg,rgba(3,13,22,.95) 0%,rgba(7,24,39,.83) 42%,rgba(7,24,39,.30) 100%),
  url('../images/hero-casa-van.jpg') center right/cover no-repeat;overflow:hidden}.hero:before{content:'';position:absolute;inset:0;background:linear-gradient(125deg,transparent 0 44%,rgba(255,196,0,.22) 44.2%,transparent 45.2%),radial-gradient(circle at 17% 28%,rgba(255,196,0,.18),transparent 180px)}.hero .container{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center;min-height:720px}.badge{display:inline-flex;gap:10px;align-items:center;color:var(--gold);font-size:13px;font-weight:900;letter-spacing:.18em;text-transform:uppercase;margin-bottom:18px}.hero h1{font-size:clamp(42px,6.4vw,82px);line-height:.94;margin:0 0 18px;text-transform:uppercase;letter-spacing:-.055em}.hero h1 span{color:var(--gold)}.hero p{font-size:20px;line-height:1.62;color:#d9e7f5;max-width:650px}.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}.hero-card{align-self:end;margin-bottom:58px;background:rgba(255,255,255,.94);color:#071827;border-radius:18px;overflow:hidden;box-shadow:0 35px 90px rgba(0,0,0,.35);border:1px solid rgba(255,196,0,.35);max-width:460px;justify-self:end}.hero-card img{height:265px;width:100%;object-fit:cover}.hero-card div{padding:20px}.hero-card h3{margin:0 0 8px;text-transform:uppercase}.hero-card p{font-size:14px;color:#536477;margin:0}.stats{position:relative;margin-top:-58px;z-index:10}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);background:#fff;border-radius:14px;box-shadow:0 25px 70px rgba(7,24,39,.18);overflow:hidden;border:1px solid #e6edf5}.stat{padding:26px;border-right:1px solid #edf2f6}.stat:last-child{border-right:0}.stat b{display:block;font-size:30px;color:#0b2742}.stat span{font-size:13px;color:#65758a;text-transform:uppercase;font-weight:900}.section{padding:88px 0}.section.dark{background:linear-gradient(180deg,#071827,#0b2742);color:#fff}.section-head{display:flex;align-items:end;justify-content:space-between;gap:24px;margin-bottom:34px}.section-head h2{font-size:38px;margin:0;text-transform:uppercase;letter-spacing:-.035em}.section-head h2:after{content:'';display:block;width:82px;height:4px;background:linear-gradient(90deg,var(--gold),var(--orange));margin-top:13px}.section-head p{max-width:560px;color:#66758a;line-height:1.7;margin:0}.dark .section-head p{color:#bfd0df}.services{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}.service{background:#fff;border:1px solid var(--border);border-radius:16px;overflow:hidden;box-shadow:0 15px 35px rgba(7,24,39,.08);transition:.25s}.service:hover{transform:translateY(-8px);box-shadow:0 28px 60px rgba(7,24,39,.16)}.service img{height:190px;width:100%;object-fit:cover}.service .body{padding:22px}.icon{width:52px;height:52px;border-radius:50%;display:grid;place-items:center;background:#fff8d6;color:#c88900;font-size:25px;margin-bottom:14px;border:1px solid #ffe28c}.service h3{margin:0 0 10px;text-transform:uppercase;font-size:18px}.service ul{margin:14px 0 0;padding-left:18px;color:#56677a;line-height:1.75}.split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}.photo-frame{position:relative}.photo-frame:after{content:'';position:absolute;right:-18px;bottom:-18px;width:70%;height:70%;border:5px solid var(--gold);border-radius:18px;z-index:0}.photo-frame img{position:relative;z-index:1;border-radius:18px;height:465px;width:100%;object-fit:cover;box-shadow:0 25px 70px rgba(0,0,0,.25)}.checks{display:grid;gap:14px;margin:22px 0}.check{display:flex;gap:12px;line-height:1.55;color:#d7e5f3}.check b{color:var(--gold)}.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.project{height:225px;position:relative;overflow:hidden;border-radius:14px;background:#000}.project img{height:100%;width:100%;object-fit:cover;transition:.32s}.project:hover img{transform:scale(1.06);opacity:.74}.project span{position:absolute;left:13px;bottom:13px;background:rgba(7,24,39,.92);color:#fff;padding:11px 14px;border-left:4px solid var(--gold);border-radius:6px;text-transform:uppercase;font-size:12px;font-weight:900}.conversion{background:linear-gradient(100deg,#071827,#0b2742);color:#fff;padding:40px 0;border-top:1px solid rgba(255,196,0,.22);border-bottom:1px solid rgba(255,196,0,.22)}.conversion .container{display:flex;align-items:center;justify-content:space-between;gap:24px}.conversion h2{margin:0 0 6px;font-size:30px;text-transform:uppercase}.conversion p{margin:0;color:#c7d7e7}.contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:30px}.card,.form{background:#fff;border:1px solid var(--border);border-radius:16px;padding:28px;box-shadow:0 15px 35px rgba(7,24,39,.08)}.contact-line{display:flex;gap:12px;margin:18px 0;color:#58697b;line-height:1.5}.contact-line strong{display:block;color:#071827}.form input,.form select,.form textarea{width:100%;border:1px solid #d8e2ec;border-radius:8px;padding:14px 15px;margin-bottom:12px;font:inherit}.form button{width:100%}.footer{background:#020b14;color:#b8c8d9;padding:40px 0}.footer-grid{display:grid;grid-template-columns:1.2fr .8fr .8fr .8fr;gap:30px}.footer img{height:70px;width:auto}.footer h4{color:#fff;text-transform:uppercase}.footer a{display:block;margin:9px 0;color:#b8c8d9}.float-actions{position:fixed;right:18px;bottom:18px;z-index:120;display:grid;gap:12px}.float-actions a{width:58px;height:58px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:23px;font-weight:900;box-shadow:0 18px 35px rgba(0,0,0,.24)}.wa{background:#25d366}.call{background:#0b2742}.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}.reveal.show{opacity:1;transform:none}@media(max-width:960px){.hamb{display:block}.menu{display:none;position:absolute;top:88px;left:0;right:0;background:#fff;flex-direction:column;align-items:flex-start;padding:24px 6%;box-shadow:0 20px 40px rgba(7,24,39,.12)}.menu.open{display:flex}.hero .container,.split,.contact-grid{grid-template-columns:1fr}.hero-card{justify-self:start}.stats-grid,.services,.gallery,.footer-grid{grid-template-columns:1fr 1fr}.conversion .container{flex-direction:column;text-align:center}}@media(max-width:560px){.topbar .container{align-items:flex-start;flex-direction:column}.nav{height:76px}.logo img{height:50px}.hero,.hero .container{min-height:auto}.hero .container{padding:92px 0}.hero h1{font-size:40px}.hero p{font-size:16px}.hero-card{margin-bottom:0}.stats{margin-top:0}.stats-grid,.services,.gallery,.footer-grid{grid-template-columns:1fr}.section-head{display:block}.section-head h2{font-size:31px}.conversion h2{font-size:24px}}

.wa-icon{width:30px;height:30px;display:block}.contact-icon{width:24px;height:24px;color:#25d366;display:grid;place-items:center;flex:0 0 24px}.contact-icon .wa-icon{width:24px;height:24px}.mvg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}.mvg-card{background:#fff;border:1px solid var(--border);border-radius:18px;padding:28px;box-shadow:0 16px 40px rgba(7,24,39,.08);position:relative;overflow:hidden}.mvg-card:before{content:'';position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,var(--gold),var(--orange))}.mvg-icon{width:54px;height:54px;border-radius:50%;display:grid;place-items:center;background:#fff8d6;border:1px solid #ffe28c;font-size:25px;margin-bottom:14px}.mvg-card h3{margin:0 0 12px;text-transform:uppercase;color:#071827}.mvg-card p{margin:0;color:#56677a;line-height:1.7}@media(max-width:960px){.mvg-grid{grid-template-columns:1fr}}

/* =========================================================
   RESPONSIVE OPTIMIZATION ONLY - MOBILE & TABLET FIXES
   Added without changing site content, structure or assets.
   ========================================================= */

/* Prevent horizontal overflow on all devices */
html,body{width:100%;max-width:100%;overflow-x:hidden}.container{max-width:1180px}.header,.topbar,.hero,.section,.conversion,.footer{max-width:100%;overflow-x:hidden}

/* Better tap behavior */
a,button{touch-action:manipulation}.btn{white-space:normal;text-align:center;line-height:1.15}.menu .btn{white-space:nowrap}

/* Large tablets / small laptops */
@media (max-width:1100px){
  .container{width:min(100% - 36px,1180px)}
  .nav{gap:14px}.menu{gap:16px;font-size:12px}.logo img{height:56px}
  .hero{min-height:650px;background-position:center center}
  .hero .container{grid-template-columns:1fr .82fr;min-height:650px;gap:24px}
  .hero h1{font-size:clamp(38px,6vw,64px)}.hero p{font-size:18px;max-width:560px}
  .services{grid-template-columns:repeat(2,1fr)}.gallery{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1.2fr 1fr 1fr 1fr}
}

/* Tablets */
@media (max-width:960px){
  body{font-size:16px}.container{width:min(100% - 32px,1180px)}
  .topbar .container{display:flex;justify-content:center;text-align:center;flex-wrap:wrap;gap:10px}.social-mini{justify-content:center;flex-wrap:wrap}
  .header{position:sticky;top:0}.nav{height:78px}.logo img{height:54px}
  .hamb{display:block;color:#071827;line-height:1;padding:6px 0;cursor:pointer;z-index:102}
  .menu{display:none;position:absolute;top:78px;left:0;right:0;width:100%;background:#fff;flex-direction:column;align-items:stretch;gap:0;padding:10px 20px 20px;box-shadow:0 24px 45px rgba(7,24,39,.16);border-bottom:1px solid #e8edf3;z-index:101}
  .menu.open{display:flex}.menu a{display:block;padding:14px 0;border-bottom:1px solid #eef3f7;color:#0b2742}.menu a:last-child{border-bottom:0}.menu .btn{display:flex;margin-top:10px;padding:14px 18px;width:100%}
  .hero{min-height:auto;background-position:center right;background-size:cover}.hero:before{opacity:.8}
  .hero .container{display:block;min-height:auto;padding:82px 0 58px}.hero h1{font-size:clamp(36px,8vw,56px);line-height:1.02;letter-spacing:-.04em}.hero p{font-size:17px;max-width:100%}
  .hero-actions{gap:10px}.hero-actions .btn{flex:1 1 210px;min-height:48px}
  .hero-card{display:none}
  .stats{margin-top:0}.stats-grid{grid-template-columns:repeat(2,1fr);border-radius:0}.stat{padding:22px;text-align:center}.stat:nth-child(2){border-right:0}.stat b{font-size:26px}
  .section{padding:64px 0}.section-head{display:block;margin-bottom:26px}.section-head h2{font-size:34px}.section-head p{margin-top:16px;max-width:100%}
  .split,.contact-grid{grid-template-columns:1fr;gap:34px}.photo-frame:after{display:none}.photo-frame img{height:auto;max-height:420px}
  .services{grid-template-columns:repeat(2,1fr);gap:18px}.service img{height:210px}.gallery{grid-template-columns:repeat(2,1fr)}.project{height:220px}
  .mvg-grid{grid-template-columns:1fr}.conversion .container{flex-direction:column;text-align:center}.conversion .hero-actions{width:100%;justify-content:center}
  .footer-grid{grid-template-columns:repeat(2,1fr);gap:26px}.footer img{height:58px}
}

/* Phones */
@media (max-width:640px){
  .container{width:min(100% - 24px,1180px)}
  .topbar{font-size:12px}.topbar .container{align-items:center}.topbar a{word-break:break-word}
  .nav{height:72px}.logo img{height:46px;max-width:190px;object-fit:contain}.menu{top:72px;padding-left:16px;padding-right:16px}
  .hero{background-position:58% center}.hero .container{padding:70px 0 42px}.badge{font-size:11px;letter-spacing:.12em;margin-bottom:12px}.hero h1{font-size:38px;line-height:1.04;margin-bottom:14px}.hero p{font-size:16px;line-height:1.55;color:#edf5ff}
  .hero-actions{display:grid;grid-template-columns:1fr;gap:10px}.hero-actions .btn{width:100%;min-height:50px;padding:14px 16px}
  .stats-grid{grid-template-columns:1fr}.stat{border-right:0;border-bottom:1px solid #edf2f6}.stat:last-child{border-bottom:0}.stat b{font-size:25px}
  .section{padding:52px 0}.section-head h2{font-size:29px;line-height:1.08}.section-head h2:after{width:64px;height:3px}.section-head p{font-size:15px;line-height:1.65}
  .services,.gallery,.footer-grid{grid-template-columns:1fr}.service .body{padding:20px}.service img{height:205px}.project{height:220px}.project span{font-size:11px;padding:10px 12px}
  .photo-frame img{height:auto;max-height:none}.card,.form,.mvg-card{padding:22px;border-radius:14px}.contact-line{align-items:flex-start}.form input,.form select,.form textarea{font-size:16px}
  .conversion{padding:34px 0}.conversion h2{font-size:24px}.conversion p{font-size:15px}.conversion .hero-actions{display:grid;grid-template-columns:1fr}
  .float-actions{right:14px;bottom:14px;gap:10px}.float-actions a{width:52px;height:52px;font-size:20px}.wa-icon{width:27px;height:27px}
}

/* Very small phones */
@media (max-width:390px){
  .logo img{height:40px;max-width:165px}.hero h1{font-size:32px}.hero p{font-size:15px}.btn{font-size:13px}.section-head h2{font-size:26px}.service img,.project{height:190px}.float-actions a{width:48px;height:48px}
}
