:root{--red1: #B80000; --red2: #E10600; --black: #0f0f10; --green: #00E676; --yellow: #FFD400; --cream: #151515;}
*{box-sizing: border-box;}
html, body{margin: 0; padding: 0; font-family: system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,'Helvetica Neue',Arial,sans-serif; background: var(--cream); color: #f2f2f2;}
.container{max-width: 1100px; margin: 0 auto; padding: 0 16px;}
.topbar{background: var(--black); color: white; position: fixed; top: 0; left: 0; right: 0; z-index: 80;}
.topbar__inner{display: flex; align-items: center; gap: 10px; justify-content: space-between; padding: 10px 16px; flex-wrap: wrap;}
.topbar-spacer{height: 72px;}
.logo-small{width: 40px; height: 40px; border-radius: 50%;}
.nav{display: flex; align-items: center; gap: 14px; flex-wrap: wrap;}
.nav a{color: white; text-decoration: none; font-weight: 700; white-space: nowrap;}
.btn--topcall{background: var(--green); color: #000; border-radius: 999px; box-shadow: 0 4px 12px rgba(0,0,0,.25); border: 1px solid rgba(0,0,0,.25); padding: 8px 14px;}
.lang-switch{display: flex; gap: 8px;}
.lang-btn{background: transparent; border: 1px solid #fff; color: #fff; border-radius: 8px; padding: 6px 10px; font-weight: 700; cursor: pointer; white-space: nowrap;}
.lang-btn.active{background: #fff; color: #000;}
.hero{background: linear-gradient(135deg,var(--red1),var(--red2)); padding: 48px 0;}
.hero__grid{display: grid; grid-template-columns: 1.2fr .8fr; gap: 24px; align-items: center;}
.hero__brand{max-width: 640px; width: 100%; height: auto; display: block; border-radius: 12px;}
.hero h1{font-size: 44px; margin: 16px 0 10px;}
.lead{font-size: 18px; opacity: .95;}
.accent{color: var(--black); background: var(--yellow); padding: 0 8px; border-radius: 8px;}
.btn{display: inline-block; font-weight: 800; text-decoration: none; padding: 14px 18px; border-radius: 12px; border: 0; cursor: pointer; font-size: 16px; line-height: 1;}
button.btn{appearance: none; -webkit-appearance: none; background: transparent;}
.cta-block{display: grid; gap: 12px; margin: 18px 0;}
.cta-primary .btn--call-main{background: var(--green); color: #000; border-radius: 999px; box-shadow: 0 10px 24px rgba(0,0,0,.25); border: 2px solid rgba(0,0,0,.35); display: inline-block; padding: 14px 18px; font-weight: 900;}
.cta-grid{display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 12px;}
.cta-grid .btn{width: 100%; text-align: center; border-radius: 999px; box-shadow: 0 10px 24px rgba(0,0,0,.25); border: 2px solid rgba(0,0,0,.35); font-weight: 900; min-height: 48px; display: flex; align-items: center; justify-content: center;}
.cta-grid .btn--whatsapp{background: #25D366; color: #000;}
.cta-grid .btn--sms{background: #FFDDE1; color: #000;}
.cta-grid .btn--contact{background: var(--yellow); color: #000;}
.cta-grid .btn--loc{background: #FFC36A; color: #000;}
.badges{display: flex; gap: 12px; flex-wrap: wrap; margin: 12px 0 0; padding: 0; list-style: none;}
.phone-card{background: white; border-radius: 16px; padding: 20px; box-shadow: 0 10px 24px rgba(0,0,0,.12);}
.card__title{font-weight: 700; margin: 0 0 6px;}
.phone-big{font-size: 28px; margin: 0 0 4px;}
.muted{color: rgba(255,255,255,.75);}
.center{text-align: center;}
.section{color: #f2f2f2;}
.cards{display: grid; grid-template-columns: repeat(3,1fr); gap: 18px;}
.card{background: #fff; border-radius: 16px; padding: 18px; box-shadow: 0 6px 16px rgba(0,0,0,.08) color:#222;}
.card .price{color: var(--yellow) !important;}
.contacto{background: linear-gradient(135deg,var(--blue),var(--mint)); padding: 48px 0;}
.contact__box{display: grid; grid-template-columns: 1.2fr .8fr; gap: 24px; align-items: center;}
.contact__logo{width: 300px; max-width: 100%; filter: drop-shadow(0 6px 12px rgba(0,0,0,.2));}
.footer{background: var(--black); color: white;}
.footer__grid{display: flex; align-items: center; justify-content: center; gap: 16px; padding: 16px 0; flex-wrap: nowrap;}
.footer a{color: white; text-decoration: none;}
.foot-social{display: flex; gap: 16px; align-items: center; flex-wrap: wrap; margin-right: 12px;}
.icon{width: 22px; height: 22px; display: inline-block;}
.icon-link{transition: transform .12s ease, opacity .12s ease;}
.icon-link:hover{transform: scale(1.05); opacity: 1;}
.section h2, .section h3{color: #ffffff;}
.footer p, .footer a{color: #ffffff;}
.version-line{margin: 0;}
.cards .card, .cards .card *{color: #222 !important;}
.cards .card p{opacity: 1 !important;}
.phone-card, .phone-card *{color: #222 !important;}
.card .muted{color: #666 !important; opacity: 1 !important;}
.section:not(.alt){color: #f2f2f2;}
.section:not(.alt) h2, .section:not(.alt) h3{color: #ffffff;}
.footer .logo-small{width: 40px; height: 40px; border-radius: 50%;}
.footer .version-line{color: #fff; margin: 0 8px 0 0; font-weight: 600; white-space: nowrap;}
.footer .icon{width: 40px; height: 40px; display: inline-block;}
.footer .icon-link{display: inline-flex; align-items: center; justify-content: center;}
.footer .icon-link span{display: none;}
.btn--call-main, .cta-grid .btn--whatsapp, .cta-grid .btn--sms{line-height: 1.15; text-align: center;}
.btn--call-main strong{display: block; font-weight: 700;}
.phone-card .phone{line-height: 1.25;}
.btn--call-main strong, .cta-grid .btn--whatsapp strong, .cta-grid .btn--sms strong{display: block; font-weight: 700;}
.btn--call-main span[data-i18n], .cta-grid a span[data-i18n]{display: inline-block;}
.cta-primary{display: flex; gap: 12px; flex-wrap: wrap; align-items: stretch;}
.cta-primary .btn--call-main, .cta-primary .btn--whatsapp{flex: 1 1 calc(50% - 12px); display: flex; align-items: center; justify-content: center; min-height: 120px; text-align: center; padding: 8px;}
.btn-square{display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 6px; width: 100%;}
.btn-square .ico{width: 34px; height: 34px;}
.btn-square .lbl{font-weight: 700;}
.btn-square strong{display: block; line-height: 1.15;}
@media (max-width:700px){.cta-primary .btn--call-main{width: 100%; text-align: center;}.cta-grid{grid-template-columns: 1fr 1fr;}}
@media (max-width:900px){.hero__grid, .contact__box{grid-template-columns: 1fr;}.cards{grid-template-columns: 1fr 1fr;}}
@media (max-width:600px){.logo-small{width: 34px; height: 34px;}.cards{grid-template-columns: 1fr;}.hero h1{font-size: 32px;}}
@media (max-width:720px){.footer__grid{flex-direction: column; align-items: center; text-align: center;}.foot-right{display: flex; flex-direction: column; align-items: center; gap: 10px;}.foot-social{justify-content: center; margin-right: 0;}}
@media (max-width:420px){.footer__grid{gap: 10px; flex-wrap: wrap;}.footer .logo-small, .footer .icon{width: 34px; height: 34px;}.footer .version-line{font-size: 14px;}.cta-primary .btn--call-main, .cta-primary .btn--whatsapp{min-height: 110px;}.btn-square .ico{width: 30px; height: 30px;}}
@media (max-width:480px){.hero__brand{max-width: 100%;}}
@media (max-width: 768px){.hero .hero__brand{order: 2; margin: 12px auto 4px auto; display: block; max-width: 520px; width: 100%; height: auto;}.hero .badge{order: 1;}.hero h1, .hero h2{order: 3;}.hero p{order: 4;}}
