
:root{
  --bg:#f7f5f1;
  --surface:#ffffff;
  --surface-2:#ece7de;
  --ink:#171717;
  --muted:#6b655c;
  --line:#ddd6cc;
  --dark:#171717;
  --dark-2:#25211d;
  --accent:#18c2c0;
  --accent-dark:#0ea8a6;
  --radius:24px;
  --shadow:0 24px 70px rgba(23,23,23,.12);
  --shadow-soft:0 12px 34px rgba(23,23,23,.08);
  --max:1180px;
}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,Arial,sans-serif;color:var(--ink);background:var(--bg);line-height:1.6}a{text-decoration:none;color:inherit}img{max-width:100%;display:block}
.topbar{background:var(--dark);color:#fff;font-size:13px}.topbar .wrap{max-width:var(--max);margin:auto;padding:9px 20px;display:flex;justify-content:space-between;gap:16px;align-items:center}.topbar a{color:#fff;opacity:.9}
.header{position:sticky;top:0;z-index:50;background:rgba(247,245,241,.92);backdrop-filter:blur(18px);border-bottom:1px solid rgba(221,214,204,.85)}
.nav{max-width:var(--max);margin:auto;padding:14px 20px;display:flex;align-items:center;justify-content:space-between;gap:20px}
.brand{display:flex;align-items:center;gap:14px}.brand img{height:54px;width:auto}.brand-sub{font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--muted);margin-top:4px}
.nav-links{display:flex;gap:24px;font-size:14px;font-weight:650;color:#433d36}.nav-links a{position:relative}.nav-links a.active::after,.nav-links a:hover::after{content:"";position:absolute;left:0;right:0;bottom:-8px;height:2px;background:var(--accent);border-radius:999px}
.nav-actions{display:flex;gap:10px}.menu-btn{display:none;border:1px solid var(--line);background:#fff;border-radius:999px;width:44px;height:44px}.menu-btn span{display:block;width:18px;height:2px;background:var(--ink);margin:4px auto}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:46px;padding:12px 22px;border-radius:999px;border:1px solid transparent;font-weight:780;cursor:pointer;transition:.18s ease}.btn-dark{background:var(--dark);color:#fff}.btn-dark:hover{background:#000;transform:translateY(-1px)}.btn-outline{border-color:var(--line);background:transparent}.btn-outline:hover{background:#fff;transform:translateY(-1px)}.btn-accent{background:var(--accent);color:#fff}.btn-accent:hover{background:var(--accent-dark);transform:translateY(-1px)}
.container{max-width:var(--max);margin:auto;padding:0 20px}.section{padding:84px 0}.section-tight{padding:58px 0}.center{text-align:center}.eyebrow{font-size:12px;letter-spacing:.28em;text-transform:uppercase;color:var(--accent);font-weight:850;margin:0 0 14px}h1,h2,h3,p{margin-top:0}h1{font-size:clamp(40px,6vw,74px);line-height:1.02;letter-spacing:-.06em;margin-bottom:24px}h2{font-size:clamp(32px,4.2vw,54px);line-height:1.06;letter-spacing:-.045em;margin-bottom:18px}h3{font-size:22px;line-height:1.15;letter-spacing:-.02em;margin-bottom:10px}.lead{font-size:clamp(18px,2vw,21px);color:var(--muted);max-width:760px}.center .lead{margin-left:auto;margin-right:auto}.muted{color:var(--muted)}
.hero{padding:54px 0 84px}.hero-layout{display:grid;grid-template-columns:.95fr 1.05fr;gap:40px;align-items:center}.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin:32px 0}.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;max-width:620px}.stat{border-top:1px solid var(--line);padding-top:14px}.stat strong{display:block;font-size:30px;letter-spacing:-.04em}.stat span{display:block;color:var(--muted);font-size:14px}.photo-card{overflow:hidden;border-radius:36px;box-shadow:var(--shadow);background:#fff}.photo-card img{width:100%;height:100%;object-fit:cover}.hero .photo-card{height:560px}
.grid{display:grid;gap:24px}.three{grid-template-columns:repeat(3,1fr)}.four{grid-template-columns:repeat(4,1fr)}.two{grid-template-columns:1fr 1fr}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-soft)}.service-card{min-height:240px}.service-card:hover,.gallery-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}.icon{width:52px;height:52px;border-radius:18px;background:var(--dark);color:#fff;display:grid;place-items:center;font-size:23px;margin-bottom:18px}
.split-dark{background:var(--dark);color:#fff}.split-dark .muted,.split-dark .lead{color:#ddd6cc}.split-dark .eyebrow{color:#9af1ef}.split-dark .card{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.12);box-shadow:none}.split-dark .card p{color:#ddd6cc}
.feature-row{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.badge{display:inline-flex;padding:6px 11px;border:1px solid var(--line);border-radius:999px;background:#fbfaf8;font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#5e564d;margin-bottom:12px}
.gallery-card{padding:0;overflow:hidden;transition:.18s ease}.gallery-card .thumb{height:270px;overflow:hidden}.gallery-card .thumb img{width:100%;height:100%;object-fit:cover}.gallery-card .body{padding:22px}
.clients{display:grid;grid-template-columns:repeat(7,1fr);gap:12px;margin-top:34px}.client{background:#fff;border:1px solid var(--line);border-radius:18px;padding:18px 12px;text-align:center;font-weight:800;color:#444;text-transform:uppercase;letter-spacing:.05em;font-size:13px}
.cta{background:linear-gradient(135deg,#171717,#2a2723);color:#fff;border-radius:40px;padding:54px;box-shadow:var(--shadow)}.cta p{color:#ddd6cc}
.contact-panel{display:grid;grid-template-columns:.82fr 1.18fr;gap:24px}.contact-item{background:#fff;border:1px solid var(--line);border-radius:20px;padding:20px}.form{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-soft)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.field{display:grid;gap:8px}.field.full{grid-column:1/-1}label{font-weight:780;font-size:14px}input,textarea,select{width:100%;border:1px solid var(--line);border-radius:14px;padding:13px 14px;background:#fbfaf8;outline:none}textarea{min-height:120px;resize:vertical}
.footer{background:#111;color:#fff;padding:52px 0 28px}.footer-grid{display:grid;grid-template-columns:1.35fr .8fr 1fr;gap:28px}.footer p,.footer a{color:#cfc7be}.footer h3{font-size:16px;margin-bottom:12px}.footer-links{display:grid;gap:8px}.footer-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:30px;padding-top:20px;display:flex;justify-content:space-between;gap:16px;color:#aaa39b;font-size:14px}
.whatsapp-float{position:fixed;right:20px;bottom:20px;background:#25d366;color:#fff;padding:14px 18px;border-radius:999px;font-weight:850;box-shadow:0 16px 40px rgba(37,211,102,.35);display:flex;align-items:center;gap:8px;z-index:70}
@media(max-width:980px){.topbar{display:none}.nav-links{position:fixed;left:16px;right:16px;top:82px;display:none;flex-direction:column;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:24px;padding:22px;box-shadow:var(--shadow)}.nav-links.open{display:flex}.nav-actions{display:none}.menu-btn{display:block}.hero-layout,.feature-row,.contact-panel,.footer-grid,.two{grid-template-columns:1fr}.three{grid-template-columns:1fr 1fr}.four{grid-template-columns:1fr 1fr}.clients{grid-template-columns:repeat(4,1fr)}}
@media(max-width:640px){.nav{padding:12px 16px}.brand img{height:46px}.section{padding:66px 0}.section-tight{padding:46px 0}.hero .photo-card{height:360px}.hero-actions,.btn{width:100%}.stats,.three,.four,.clients,.form-grid{grid-template-columns:1fr}.cta{padding:30px;border-radius:28px}.footer-bottom{flex-direction:column}.whatsapp-float{left:16px;right:16px;justify-content:center}}

.pill-row{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:22px}
.pill{display:inline-flex;padding:11px 16px;border-radius:999px;background:#fff;border:1px solid var(--line);font-weight:780;font-size:13px;color:#4c463f}
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:34px}
.kpi{background:#fff;border:1px solid var(--line);border-radius:22px;padding:24px;box-shadow:var(--shadow-soft)}
.kpi strong{display:block;font-size:32px;letter-spacing:-.04em}
.kpi span{display:block;color:var(--muted);font-size:14px}
.anchor-offset{scroll-margin-top:110px}
@media(max-width:980px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.kpi-grid{grid-template-columns:1fr}}


.section-soft{background:linear-gradient(180deg,#fbfaf7,#f3efe8)}
.section-divider{padding-top:14px;border-top:1px solid var(--line);margin-top:10px}
.category-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:34px}
.category-card{position:relative;overflow:hidden;min-height:420px;border-radius:30px;box-shadow:var(--shadow);background:#000;color:#fff}
.category-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.68)}
.category-card .overlay{position:absolute;inset:auto 0 0 0;padding:28px;background:linear-gradient(180deg,rgba(0,0,0,0),rgba(0,0,0,.72))}
.category-card p{color:rgba(255,255,255,.82);margin-bottom:0}
.showcase-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:34px}
.showcase-card{background:#fff;border:1px solid var(--line);border-radius:28px;overflow:hidden;box-shadow:var(--shadow-soft)}
.showcase-card .thumb{height:320px;overflow:hidden}.showcase-card .thumb img{width:100%;height:100%;object-fit:cover}
.showcase-card .body{padding:24px}
.metrics-band{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:38px}
.metric-box{background:rgba(255,255,255,.88);backdrop-filter:blur(4px);border:1px solid var(--line);border-radius:22px;padding:22px;box-shadow:var(--shadow-soft)}
.metric-box strong{display:block;font-size:34px;letter-spacing:-.05em}.metric-box span{color:var(--muted);font-size:14px}
.anchor-nav{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin-top:20px}
.project-note{font-size:14px;color:var(--muted);max-width:760px;margin:10px auto 0}
.gallery-header{display:flex;justify-content:space-between;gap:24px;align-items:end;margin-bottom:28px}
.gallery-header .lead{max-width:640px}
.gallery-count{display:inline-flex;padding:10px 14px;border-radius:999px;background:#fff;border:1px solid var(--line);font-weight:800;font-size:13px;white-space:nowrap}
.featured-strip{display:grid;grid-template-columns:1.08fr .92fr;gap:26px;align-items:stretch;margin-top:34px}
.featured-panel{background:#fff;border:1px solid var(--line);border-radius:30px;padding:30px;box-shadow:var(--shadow-soft)}
.inline-list{display:grid;gap:12px;margin-top:18px}.inline-list div{display:flex;gap:12px;align-items:flex-start;padding:12px 0;border-top:1px solid var(--line)}
.inline-list b{min-width:124px}
.small-gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.small-gallery .photo-card{height:220px}
@media(max-width:980px){.category-grid,.metrics-band,.showcase-grid,.featured-strip{grid-template-columns:1fr 1fr}.gallery-header{flex-direction:column;align-items:flex-start}.small-gallery{grid-template-columns:1fr 1fr}}
@media(max-width:640px){.category-grid,.metrics-band,.showcase-grid,.featured-strip,.small-gallery{grid-template-columns:1fr}.category-card{min-height:330px}.showcase-card .thumb{height:250px}}


.category-grid.category-grid-4{grid-template-columns:repeat(2,1fr)}
.subcategory-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:24px}
.subcategory-card{background:#fff;border:1px solid var(--line);border-radius:22px;padding:18px;box-shadow:var(--shadow-soft)}
.subcategory-card h3{font-size:18px;margin-bottom:8px}
@media(max-width:980px){.subcategory-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.subcategory-grid{grid-template-columns:1fr}}


/* v6 - home más corta */
.home-compact .hero{padding:42px 0 56px}
.home-compact .hero .photo-card{height:470px}
.home-compact .section{padding:56px 0}
.home-compact .section-tight{padding:42px 0}
.quick-links{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.quick-link{display:inline-flex;align-items:center;padding:10px 14px;border:1px solid var(--line);border-radius:999px;background:#fff;font-weight:780;font-size:13px;color:#4c463f}
.home-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:26px}
.home-mini-card{background:#fff;border:1px solid var(--line);border-radius:24px;overflow:hidden;box-shadow:var(--shadow-soft);display:flex;flex-direction:column}
.home-mini-card .thumb{height:170px;overflow:hidden}.home-mini-card .thumb img{width:100%;height:100%;object-fit:cover}
.home-mini-card .body{padding:18px}
.home-mini-card h3{font-size:20px;margin-bottom:8px}
.home-mini-card p{font-size:14px;color:var(--muted);margin-bottom:0}
.home-feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:26px}
.home-feature{background:#fff;border:1px solid var(--line);border-radius:26px;overflow:hidden;box-shadow:var(--shadow-soft)}
.home-feature .thumb{height:220px;overflow:hidden}.home-feature .thumb img{width:100%;height:100%;object-fit:cover}
.home-feature .body{padding:20px}
.home-clients-band{display:grid;grid-template-columns:1.2fr .8fr;gap:22px;align-items:stretch}
.home-text-card{background:#fff;border:1px solid var(--line);border-radius:28px;padding:28px;box-shadow:var(--shadow-soft)}
.home-bullets{display:grid;gap:10px;margin-top:18px}.home-bullets div{padding:12px 0;border-top:1px solid var(--line)}
.home-bullets b{display:block;margin-bottom:3px}
.home-side-photos{display:grid;grid-template-columns:1fr 1fr;gap:14px}.home-side-photos .photo-card{height:168px}
.home-cta-compact{background:linear-gradient(135deg,#171717,#2a2723);color:#fff;border-radius:34px;padding:38px;box-shadow:var(--shadow)}
.home-cta-compact p{color:#ddd6cc}
@media(max-width:980px){.home-grid-4{grid-template-columns:repeat(2,1fr)}.home-feature-grid,.home-clients-band{grid-template-columns:1fr}.home-compact .hero .photo-card{height:360px}}
@media(max-width:640px){.home-grid-4,.home-feature-grid,.home-side-photos{grid-template-columns:1fr}.home-compact .hero{padding:34px 0 42px}.home-cta-compact{padding:28px}}


/* v7 - Home ultra limpia y premium */
.home-premium{background:#f5f2ec}
.home-premium .topbar{background:#0f0f0f;color:#d8d0c4}
.home-premium .hero-premium{padding:34px 0 46px}
.hero-premium-card{display:grid;grid-template-columns:1fr 1fr;min-height:560px;border-radius:42px;overflow:hidden;background:#171717;color:#fff;box-shadow:var(--shadow)}
.hero-premium-copy{padding:62px;display:flex;flex-direction:column;justify-content:center;background:linear-gradient(135deg,#171717,#2d2924)}
.hero-premium-copy h1{font-size:clamp(42px,5.8vw,72px);margin-bottom:20px}
.hero-premium-copy .lead{color:#ddd6cc;max-width:620px}
.hero-premium-image{position:relative;min-height:420px}.hero-premium-image img{width:100%;height:100%;object-fit:cover}.hero-premium-image:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(23,23,23,.15),rgba(23,23,23,0))}
.home-premium-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:28px}.home-premium-actions .btn-outline{color:#fff;border-color:rgba(255,255,255,.25)}.home-premium-actions .btn-outline:hover{background:rgba(255,255,255,.08)}
.premium-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:18px}.premium-strip a{padding:15px 16px;border-radius:18px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);color:#fff;font-weight:820}.premium-strip small{display:block;color:#bfb7ad;font-weight:600;margin-top:4px}
.premium-section{padding:48px 0}.premium-title-row{display:flex;align-items:end;justify-content:space-between;gap:24px;margin-bottom:24px}.premium-title-row .lead{max-width:620px}
.premium-work-grid{display:grid;grid-template-columns:1.2fr .8fr .8fr;gap:18px}.premium-work{position:relative;overflow:hidden;border-radius:30px;min-height:330px;background:#111;box-shadow:var(--shadow-soft)}.premium-work:first-child{min-height:420px}.premium-work img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.72)}.premium-work div{position:absolute;left:0;right:0;bottom:0;padding:24px;color:#fff;background:linear-gradient(180deg,rgba(0,0,0,0),rgba(0,0,0,.72))}.premium-work h3{margin-bottom:6px}.premium-work p{margin:0;color:rgba(255,255,255,.82)}
.premium-info{display:grid;grid-template-columns:1fr 1fr;gap:22px}.premium-panel{background:#fff;border:1px solid var(--line);border-radius:30px;padding:30px;box-shadow:var(--shadow-soft)}.premium-panel .clients{grid-template-columns:repeat(4,1fr);margin-top:22px}.premium-panel .clients .client:last-child{grid-column:auto}.premium-list{display:grid;gap:12px;margin-top:18px}.premium-list div{display:flex;justify-content:space-between;gap:18px;padding:12px 0;border-top:1px solid var(--line)}.premium-list b{white-space:nowrap}.premium-list span{text-align:right;color:var(--muted)}
.premium-cta{padding:36px;border-radius:34px;background:linear-gradient(135deg,#171717,#28231e);color:#fff;box-shadow:var(--shadow);display:flex;align-items:center;justify-content:space-between;gap:24px}.premium-cta p{color:#ddd6cc;margin-bottom:0}.premium-cta h2{margin-bottom:8px}
@media(max-width:980px){.hero-premium-card,.premium-info{grid-template-columns:1fr}.hero-premium-copy{padding:42px}.premium-strip,.premium-panel .clients{grid-template-columns:repeat(2,1fr)}.premium-work-grid{grid-template-columns:1fr 1fr}.premium-work:first-child{grid-column:1/-1}.premium-cta{display:block}.premium-cta .home-premium-actions{margin-bottom:0}}
@media(max-width:640px){.hero-premium-card{border-radius:28px}.hero-premium-copy{padding:30px}.premium-strip,.premium-work-grid{grid-template-columns:1fr}.premium-work,.premium-work:first-child{min-height:280px}.premium-title-row{display:block}.premium-panel .clients{grid-template-columns:1fr}.premium-list div{display:block}.premium-list span{text-align:left;display:block;margin-top:4px}}


/* v8 - refinamiento final para publicar */
:root{--gold:#b89562;--sand:#e8dfd0}
.header{box-shadow:0 6px 24px rgba(23,23,23,.035)}
.nav-links a{transition:.18s ease}.nav-links a:hover{color:#000}
.page-note{font-size:13px;color:var(--muted);margin-top:10px}
.home-v8{background:#f4f0e8}.home-v8 .hero-premium{padding:30px 0 34px}
.v8-hero{display:grid;grid-template-columns:1.05fr .95fr;min-height:520px;border-radius:44px;overflow:hidden;background:#111;color:#fff;box-shadow:var(--shadow)}
.v8-hero-copy{padding:58px;display:flex;flex-direction:column;justify-content:center;background:radial-gradient(circle at top left,rgba(24,194,192,.14),transparent 36%),linear-gradient(135deg,#141414,#2a251f)}
.v8-hero-copy h1{font-size:clamp(42px,5.4vw,68px);margin-bottom:18px}.v8-hero-copy .lead{color:#ddd6cc;max-width:610px}
.v8-hero-media{position:relative;min-height:420px}.v8-hero-media img{width:100%;height:100%;object-fit:cover}.v8-hero-media:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(17,17,17,.25),rgba(17,17,17,0));z-index:1}.v8-hero-media .media-badge{position:absolute;left:24px;bottom:24px;z-index:2;background:rgba(255,255,255,.92);color:#171717;border-radius:18px;padding:14px 16px;font-weight:850;box-shadow:var(--shadow-soft)}.v8-hero-media .media-badge small{display:block;font-weight:650;color:var(--muted);margin-top:3px}
.v8-mini-nav{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:22px}.v8-mini-nav a{padding:15px 16px;border-radius:18px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.13);font-weight:850;color:#fff}.v8-mini-nav small{display:block;color:#beb6aa;font-weight:600;margin-top:2px}
.v8-compact-section{padding:34px 0}.v8-row{display:grid;grid-template-columns:.92fr 1.08fr;gap:20px;align-items:stretch}.v8-panel{background:#fff;border:1px solid var(--line);border-radius:32px;padding:30px;box-shadow:var(--shadow-soft)}.v8-panel h2{font-size:clamp(30px,3.5vw,44px)}
.v8-rubro-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:18px}.v8-rubro{background:#fbfaf8;border:1px solid var(--line);border-radius:20px;padding:18px}.v8-rubro b{display:block;margin-bottom:6px}.v8-rubro span{color:var(--muted);font-size:14px}
.v8-feature-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:16px;height:100%}.v8-feature{position:relative;min-height:260px;border-radius:28px;overflow:hidden;background:#111;box-shadow:var(--shadow-soft)}.v8-feature.tall{min-height:420px}.v8-feature img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.78)}.v8-feature div{position:absolute;left:0;right:0;bottom:0;padding:22px;color:#fff;background:linear-gradient(180deg,rgba(0,0,0,0),rgba(0,0,0,.72))}.v8-feature p{margin:0;color:rgba(255,255,255,.82)}
.v8-final-band{display:grid;grid-template-columns:1.1fr .9fr;gap:18px;align-items:stretch}.v8-dark-card{background:linear-gradient(135deg,#151515,#2b251e);color:#fff;border-radius:32px;padding:34px;box-shadow:var(--shadow)}.v8-dark-card p{color:#ddd6cc}.v8-client-card{background:#fff;border:1px solid var(--line);border-radius:32px;padding:30px;box-shadow:var(--shadow-soft)}.v8-client-card .clients{grid-template-columns:repeat(3,1fr);margin-top:18px}.v8-client-card .client{font-size:12px;padding:14px 10px}
.gallery-card .thumb img{cursor:zoom-in;transition:transform .25s ease,filter .25s ease}.gallery-card:hover .thumb img{transform:scale(1.035)}
.lightbox{position:fixed;inset:0;background:rgba(10,10,10,.86);z-index:999;display:none;align-items:center;justify-content:center;padding:24px}.lightbox.open{display:flex}.lightbox-inner{max-width:min(1100px,96vw);max-height:92vh;background:#111;border-radius:24px;overflow:hidden;box-shadow:0 40px 90px rgba(0,0,0,.45);position:relative}.lightbox img{max-height:82vh;width:100%;object-fit:contain;background:#0c0c0c}.lightbox-caption{color:#fff;padding:14px 18px;background:#111;font-weight:750}.lightbox-close{position:absolute;right:12px;top:12px;border:0;background:rgba(255,255,255,.92);color:#111;border-radius:999px;width:42px;height:42px;font-size:24px;cursor:pointer;line-height:1}.lightbox-close:hover{background:#fff}
.quick-contact{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:22px}.quick-contact a{display:block;border:1px solid var(--line);border-radius:20px;padding:18px;background:#fff;box-shadow:var(--shadow-soft);font-weight:850}.quick-contact small{display:block;color:var(--muted);font-weight:600;margin-top:5px}
@media(max-width:980px){.v8-hero,.v8-row,.v8-final-band{grid-template-columns:1fr}.v8-hero-copy{padding:42px}.v8-mini-nav,.v8-rubro-grid{grid-template-columns:repeat(2,1fr)}.v8-feature-grid{grid-template-columns:1fr 1fr}.v8-feature.tall{min-height:320px}.quick-contact{grid-template-columns:1fr}}
@media(max-width:640px){.v8-hero{border-radius:28px}.v8-hero-copy{padding:30px}.v8-mini-nav,.v8-rubro-grid,.v8-feature-grid,.v8-client-card .clients{grid-template-columns:1fr}.v8-feature,.v8-feature.tall{min-height:260px}.v8-panel,.v8-dark-card,.v8-client-card{padding:24px;border-radius:26px}.lightbox{padding:12px}.lightbox-inner{border-radius:16px}}


/* v9 - mejoras comerciales, mobile y portfolio */
.service-detail-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
  margin-top:30px;
}
.service-detail{
  background:#fff;
  border:1px solid var(--line);
  border-radius:26px;
  padding:24px;
  box-shadow:var(--shadow-soft);
}
.service-detail h3{
  font-size:21px;
  margin-bottom:8px;
}
.service-detail ul{
  padding-left:18px;
  margin:12px 0 0;
  color:var(--muted);
}
.service-detail li{
  margin:5px 0;
}

.process-grid{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:16px;
  margin-top:30px;
}
.process-step{
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  padding:22px;
  box-shadow:var(--shadow-soft);
}
.process-step strong{
  display:block;
  font-size:30px;
  letter-spacing:-.05em;
  color:var(--accent);
  margin-bottom:12px;
}
.process-step h3{
  font-size:18px;
  margin-bottom:8px;
}
.process-step p{
  font-size:14px;
  color:var(--muted);
  margin-bottom:0;
}

.trust-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:22px;
  margin-top:30px;
}
.trust-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:28px;
  padding:28px;
  box-shadow:var(--shadow-soft);
}
.trust-list{
  display:grid;
  gap:12px;
  margin-top:18px;
}
.trust-list div{
  padding:12px 0;
  border-top:1px solid var(--line);
}
.trust-list b{
  display:block;
  margin-bottom:3px;
}

.filter-bar{
  position:sticky;
  top:83px;
  z-index:20;
  background:rgba(247,245,241,.92);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
  padding:12px 0;
}
.filter-inner{
  max-width:var(--max);
  margin:auto;
  padding:0 20px;
  display:flex;
  gap:10px;
  overflow:auto;
  scrollbar-width:none;
}
.filter-inner::-webkit-scrollbar{display:none}
.filter-btn{
  display:inline-flex;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid var(--line);
  background:#fff;
  font-weight:800;
  font-size:13px;
  white-space:nowrap;
  color:#4c463f;
}
.filter-btn:hover{
  border-color:var(--accent);
  color:var(--ink);
}

.mobile-cta{
  display:none;
}
@media(max-width:980px){
  .service-detail-grid{grid-template-columns:1fr 1fr}
  .process-grid{grid-template-columns:1fr 1fr}
  .trust-grid{grid-template-columns:1fr}
}
@media(max-width:640px){
  .service-detail-grid,.process-grid{grid-template-columns:1fr}
  .filter-bar{top:70px}
  .whatsapp-float{display:none}
  .mobile-cta{
    position:fixed;
    left:12px;
    right:12px;
    bottom:12px;
    z-index:80;
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:8px;
    background:rgba(255,255,255,.92);
    border:1px solid var(--line);
    border-radius:22px;
    padding:8px;
    box-shadow:0 18px 44px rgba(0,0,0,.16);
    backdrop-filter:blur(16px);
  }
  .mobile-cta a{
    min-height:44px;
    border-radius:16px;
    display:flex;
    align-items:center;
    justify-content:center;
    font-weight:850;
    font-size:13px;
  }
  .mobile-cta .wa{background:#25d366;color:#fff}
  .mobile-cta .quote{background:var(--dark);color:#fff}
  body{padding-bottom:74px}
}


/* v11 - trabajos divididos por sección */
.work-index-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
  margin-top:32px;
}
.work-index-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:28px;
  overflow:hidden;
  box-shadow:var(--shadow-soft);
  transition:.18s ease;
}
.work-index-card:hover{
  transform:translateY(-3px);
  box-shadow:var(--shadow);
}
.work-index-card .thumb{
  height:220px;
  overflow:hidden;
}
.work-index-card .thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.work-index-card .body{
  padding:22px;
}
.work-index-card h3{
  font-size:22px;
  margin-bottom:8px;
}
.work-index-card p{
  font-size:14px;
  color:var(--muted);
}
.work-index-card .btn{
  width:100%;
  margin-top:8px;
}

.work-nav{
  position:sticky;
  top:83px;
  z-index:20;
  background:rgba(247,245,241,.94);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
  padding:12px 0;
}
.work-nav-inner{
  max-width:var(--max);
  margin:auto;
  padding:0 20px;
  display:flex;
  gap:10px;
  overflow:auto;
  scrollbar-width:none;
}
.work-nav-inner::-webkit-scrollbar{display:none}
.work-nav a{
  display:inline-flex;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid var(--line);
  background:#fff;
  font-weight:800;
  font-size:13px;
  white-space:nowrap;
  color:#4c463f;
}
.work-nav a.active,
.work-nav a:hover{
  border-color:var(--accent);
  color:var(--ink);
}

.category-hero{
  padding:62px 0 34px;
}
.category-hero-layout{
  display:grid;
  grid-template-columns:1fr .82fr;
  gap:34px;
  align-items:center;
}
.category-hero .photo-card{
  height:330px;
}
.category-stats{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:22px;
}
.category-stat{
  background:#fff;
  border:1px solid var(--line);
  border-radius:999px;
  padding:10px 14px;
  font-size:13px;
  font-weight:800;
  color:#4c463f;
}
.category-gallery{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
}
.category-gallery .gallery-card .thumb{
  height:260px;
}
.category-top-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:28px;
}
.related-work{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
  margin-top:24px;
}
.related-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:22px;
  padding:18px;
  box-shadow:var(--shadow-soft);
}
.related-card h3{
  font-size:18px;
  margin-bottom:6px;
}
.related-card p{
  color:var(--muted);
  font-size:14px;
  margin-bottom:10px;
}
.mobile-cta{
  display:none;
}
@media(max-width:980px){
  .work-index-grid{grid-template-columns:repeat(2,1fr)}
  .category-hero-layout{grid-template-columns:1fr}
  .category-gallery{grid-template-columns:repeat(2,1fr)}
  .related-work{grid-template-columns:1fr}
}
@media(max-width:640px){
  .work-index-grid,.category-gallery{grid-template-columns:1fr}
  .category-hero{padding:44px 0 24px}
  .category-hero .photo-card{height:280px}
  .work-nav{top:70px}
  .work-index-card .thumb{height:190px}
  .category-gallery .gallery-card .thumb{height:230px}
}


/* v13 - páginas SEO de servicios */
.seo-service-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
  margin-top:30px;
}
.seo-service-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:28px;
  overflow:hidden;
  box-shadow:var(--shadow-soft);
  transition:.18s ease;
}
.seo-service-card:hover{
  transform:translateY(-3px);
  box-shadow:var(--shadow);
}
.seo-service-card .thumb{
  height:210px;
  overflow:hidden;
}
.seo-service-card .thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.seo-service-card .body{
  padding:24px;
}
.seo-service-card h3{
  font-size:22px;
  margin-bottom:8px;
}
.seo-service-card p{
  color:var(--muted);
  font-size:15px;
}
.service-hero{
  padding:58px 0 36px;
}
.service-hero-layout{
  display:grid;
  grid-template-columns:1fr .86fr;
  gap:36px;
  align-items:center;
}
.service-hero .photo-card{
  height:360px;
}
.service-benefits{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
  margin-top:28px;
}
.service-benefit{
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  padding:22px;
  box-shadow:var(--shadow-soft);
}
.service-benefit h3{
  font-size:19px;
  margin-bottom:8px;
}
.service-benefit p{
  color:var(--muted);
  font-size:14px;
}
.service-two-col{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:28px;
  align-items:start;
}
.service-checklist{
  background:#fff;
  border:1px solid var(--line);
  border-radius:28px;
  padding:28px;
  box-shadow:var(--shadow-soft);
}
.service-checklist ul{
  margin:16px 0 0;
  padding-left:20px;
  color:var(--muted);
}
.service-checklist li{
  margin:8px 0;
}
.service-related{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
  margin-top:24px;
}
.service-related a{
  background:#fff;
  border:1px solid var(--line);
  border-radius:22px;
  padding:20px;
  box-shadow:var(--shadow-soft);
}
.service-related h3{
  font-size:18px;
}
.service-related p{
  color:var(--muted);
  font-size:14px;
}
.faq-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
  margin-top:28px;
}
.faq-item{
  background:#fff;
  border:1px solid var(--line);
  border-radius:22px;
  padding:22px;
  box-shadow:var(--shadow-soft);
}
.faq-item h3{
  font-size:18px;
  margin-bottom:8px;
}
.faq-item p{
  color:var(--muted);
  font-size:14px;
  margin-bottom:0;
}
@media(max-width:980px){
  .seo-service-grid,.service-benefits,.service-related{grid-template-columns:1fr 1fr}
  .service-hero-layout,.service-two-col{grid-template-columns:1fr}
}
@media(max-width:640px){
  .seo-service-grid,.service-benefits,.service-related,.faq-grid{grid-template-columns:1fr}
  .service-hero{padding:42px 0 26px}
  .service-hero .photo-card{height:280px}
}


/* v14 - FAQ + contacto más profesional */
.contact-hero-grid{
  display:grid;
  grid-template-columns:1fr .9fr;
  gap:32px;
  align-items:center;
}
.contact-quick-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
  margin-top:28px;
}
.contact-quick-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:26px;
  padding:24px;
  box-shadow:var(--shadow-soft);
}
.contact-quick-card h3{
  font-size:20px;
  margin-bottom:8px;
}
.contact-quick-card p{
  color:var(--muted);
  font-size:14px;
}
.contact-quick-card .btn{
  width:100%;
  margin-top:8px;
}
.quote-help-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:22px;
}
.quote-help{
  background:#fff;
  border:1px solid var(--line);
  border-radius:28px;
  padding:28px;
  box-shadow:var(--shadow-soft);
}
.quote-help ul{
  margin:16px 0 0;
  padding-left:20px;
  color:var(--muted);
}
.quote-help li{
  margin:8px 0;
}
.faq-section{
  border-top:1px solid var(--line);
  padding-top:34px;
  margin-top:34px;
}
.faq-section:first-child{
  border-top:0;
  padding-top:0;
  margin-top:0;
}
.faq-layout{
  display:grid;
  grid-template-columns:.42fr .58fr;
  gap:34px;
  align-items:start;
}
.faq-list{
  display:grid;
  gap:14px;
}
.faq-list details{
  background:#fff;
  border:1px solid var(--line);
  border-radius:20px;
  padding:18px 20px;
  box-shadow:var(--shadow-soft);
}
.faq-list summary{
  cursor:pointer;
  font-weight:850;
  color:var(--ink);
}
.faq-list p{
  margin:12px 0 0;
  color:var(--muted);
  font-size:15px;
}
.help-strip{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
  margin-top:28px;
}
.help-strip-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:22px;
  padding:20px;
  box-shadow:var(--shadow-soft);
}
.help-strip-card h3{
  font-size:18px;
}
.help-strip-card p{
  color:var(--muted);
  font-size:14px;
}
.form-note{
  margin-top:14px;
  padding:14px 16px;
  border-radius:18px;
  background:#f4efe7;
  border:1px solid var(--line);
  color:var(--muted);
  font-size:14px;
}
@media(max-width:980px){
  .contact-hero-grid,.quote-help-grid,.faq-layout{grid-template-columns:1fr}
  .contact-quick-grid,.help-strip{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  .contact-quick-grid,.help-strip{grid-template-columns:1fr}
}


/* v15 - velocidad + galería ampliable */
.gallery-card .thumb,
.home-feature .thumb,
.work-index-card .thumb,
.seo-service-card .thumb,
.photo-card {
  cursor: zoom-in;
}
.gallery-card .thumb img,
.home-feature .thumb img,
.work-index-card .thumb img,
.seo-service-card .thumb img,
.photo-card img {
  transition: transform .28s ease, filter .28s ease;
}
.gallery-card:hover .thumb img,
.home-feature:hover .thumb img,
.work-index-card:hover .thumb img,
.seo-service-card:hover .thumb img,
.photo-card:hover img {
  transform: scale(1.035);
  filter: contrast(1.03);
}
.lightbox{
  position:fixed;
  inset:0;
  z-index:999;
  background:rgba(0,0,0,.88);
  display:none;
  align-items:center;
  justify-content:center;
  padding:24px;
}
.lightbox.open{
  display:flex;
}
.lightbox img{
  max-width:min(1180px, 94vw);
  max-height:86vh;
  object-fit:contain;
  border-radius:18px;
  box-shadow:0 30px 90px rgba(0,0,0,.5);
}
.lightbox-close{
  position:absolute;
  right:22px;
  top:18px;
  width:46px;
  height:46px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.28);
  background:rgba(255,255,255,.12);
  color:#fff;
  font-size:28px;
  line-height:1;
  cursor:pointer;
}
.lightbox-caption{
  position:absolute;
  left:24px;
  right:24px;
  bottom:18px;
  color:#fff;
  text-align:center;
  font-weight:700;
  text-shadow:0 2px 12px rgba(0,0,0,.6);
}
.performance-note{
  font-size:13px;
  color:var(--muted);
  margin-top:12px;
}
@media(max-width:640px){
  .lightbox{
    padding:12px;
  }
  .lightbox img{
    max-width:96vw;
    max-height:78vh;
    border-radius:14px;
  }
  .lightbox-close{
    right:14px;
    top:12px;
  }
}


/* v16 - Google Ads ready */
.ads-hero{
  padding:54px 0 34px;
}
.ads-hero-layout{
  display:grid;
  grid-template-columns:1fr .82fr;
  gap:36px;
  align-items:center;
}
.ads-hero .photo-card{
  height:370px;
}
.ads-cta-row{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:28px;
}
.ads-proof{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
  margin-top:26px;
}
.ads-proof-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:20px;
  padding:16px;
  box-shadow:var(--shadow-soft);
}
.ads-proof-card strong{
  display:block;
  font-size:22px;
  letter-spacing:-.03em;
}
.ads-proof-card span{
  color:var(--muted);
  font-size:13px;
}
.ads-section-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
}
.ads-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:28px;
  padding:28px;
  box-shadow:var(--shadow-soft);
}
.ads-card ul{
  margin:16px 0 0;
  padding-left:20px;
  color:var(--muted);
}
.ads-card li{
  margin:8px 0;
}
.ads-mini-gallery{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
  margin-top:24px;
}
.ads-mini-gallery .gallery-card .thumb{
  height:230px;
}
.ads-lead-form{
  background:#fff;
  border:1px solid var(--line);
  border-radius:30px;
  padding:28px;
  box-shadow:var(--shadow);
}
.ads-trust-strip{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
  margin-top:24px;
}
.ads-trust-strip div{
  background:#fff;
  border:1px solid var(--line);
  border-radius:18px;
  padding:14px;
  font-weight:850;
  text-align:center;
}
.policy-content{
  max-width:900px;
  margin:auto;
}
.policy-content h2{
  margin-top:34px;
  font-size:30px;
}
.policy-content p,
.policy-content li{
  color:var(--muted);
}
.policy-content ul{
  padding-left:22px;
}
.ads-callout{
  border:1px solid var(--line);
  background:#fff;
  border-radius:28px;
  padding:28px;
  box-shadow:var(--shadow-soft);
}
@media(max-width:980px){
  .ads-hero-layout,.ads-section-grid{grid-template-columns:1fr}
  .ads-proof,.ads-trust-strip{grid-template-columns:repeat(2,1fr)}
  .ads-mini-gallery{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  .ads-proof,.ads-trust-strip,.ads-mini-gallery{grid-template-columns:1fr}
  .ads-hero .photo-card{height:280px}
  .ads-cta-row .btn{width:100%}
}


/* v17 - inicio premium corregido */
.home-hero-showcase{
  position:relative;
  height:520px;
  border-radius:42px;
}
.home-hero-showcase img{
  filter:contrast(1.03) saturate(1.02);
}
.showcase-label{
  position:absolute;
  left:24px;
  right:24px;
  bottom:24px;
  padding:18px 20px;
  border-radius:22px;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(12px);
  box-shadow:0 16px 44px rgba(23,23,23,.16);
}
.showcase-label strong{
  display:block;
  font-size:17px;
  letter-spacing:-.02em;
}
.showcase-label span{
  display:block;
  color:var(--muted);
  font-size:14px;
  margin-top:3px;
}

.home-clients-band{
  grid-template-columns:1.05fr .95fr;
  gap:28px;
  align-items:center;
}
.home-trust-showcase{
  position:relative;
  min-height:540px;
  border-radius:38px;
  overflow:hidden;
  background:#111;
}
.home-trust-showcase img{
  width:100%;
  height:100%;
  min-height:540px;
  object-fit:cover;
  filter:brightness(.82) contrast(1.04) saturate(1.03);
}
.home-trust-showcase:after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg,rgba(0,0,0,0) 38%,rgba(0,0,0,.72) 100%),
    linear-gradient(90deg,rgba(0,0,0,.12),rgba(0,0,0,0));
  pointer-events:none;
}
.trust-showcase-overlay{
  position:absolute;
  left:26px;
  right:26px;
  bottom:26px;
  z-index:2;
  color:#fff;
}
.trust-showcase-overlay span{
  display:inline-flex;
  margin-bottom:10px;
  padding:7px 11px;
  border-radius:999px;
  background:rgba(24,194,192,.92);
  color:#fff;
  font-size:12px;
  font-weight:850;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.trust-showcase-overlay strong{
  display:block;
  font-size:clamp(28px,3vw,42px);
  line-height:1.02;
  letter-spacing:-.04em;
  max-width:560px;
}
.trust-showcase-overlay p{
  color:rgba(255,255,255,.82);
  margin:10px 0 0;
  max-width:480px;
}
.home-text-card{
  border-radius:34px;
}
.home-text-card .lead{
  max-width:680px;
}
.home-text-card .clients{
  grid-template-columns:repeat(4,1fr);
}
.home-text-card .client:last-child{
  grid-column:auto;
}
@media(max-width:980px){
  .home-hero-showcase{
    height:380px;
  }
  .home-clients-band{
    grid-template-columns:1fr;
  }
  .home-trust-showcase,
  .home-trust-showcase img{
    min-height:380px;
  }
}
@media(max-width:640px){
  .home-hero-showcase{
    height:300px;
    border-radius:28px;
  }
  .showcase-label{
    left:14px;
    right:14px;
    bottom:14px;
    padding:14px;
    border-radius:18px;
  }
  .home-trust-showcase,
  .home-trust-showcase img{
    min-height:330px;
    border-radius:28px;
  }
  .trust-showcase-overlay{
    left:18px;
    right:18px;
    bottom:18px;
  }
  .home-text-card .clients{
    grid-template-columns:1fr 1fr;
  }
}


/* v18 - mobile + conversión + Google Maps */
.location-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
}
.location-btn::before{
  content:"";
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 0 5px rgba(24,194,192,.16);
}
.mobile-actions-strip{
  display:none;
}
.mobile-quick-contact{
  display:none;
}
.hero-mobile-summary{
  display:none;
}
.location-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:28px;
  padding:28px;
  box-shadow:var(--shadow-soft);
}
.location-card h3{
  font-size:22px;
  margin-bottom:8px;
}
.location-card p{
  color:var(--muted);
}
.location-card .btn{
  margin-top:10px;
}
.conversion-strip{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
  margin-top:22px;
}
.conversion-strip a{
  border:1px solid var(--line);
  border-radius:20px;
  padding:16px;
  background:#fff;
  box-shadow:var(--shadow-soft);
}
.conversion-strip strong{
  display:block;
  font-size:16px;
}
.conversion-strip span{
  display:block;
  color:var(--muted);
  font-size:13px;
  margin-top:3px;
}

@media(max-width:980px){
  .nav{
    padding:12px 18px;
  }
  .brand img{
    width:86px;
  }
  .brand-sub{
    font-size:10px;
    letter-spacing:.14em;
    max-width:210px;
  }
  .nav-actions{
    display:none;
  }
  .mobile-actions-strip{
    display:grid;
    grid-template-columns:1fr 1fr 1fr;
    gap:8px;
    padding:10px 16px;
    background:#fff;
    border-bottom:1px solid var(--line);
    position:sticky;
    top:0;
    z-index:55;
  }
  .mobile-actions-strip a{
    min-height:42px;
    display:flex;
    align-items:center;
    justify-content:center;
    text-align:center;
    border-radius:999px;
    font-size:13px;
    font-weight:850;
    border:1px solid var(--line);
    background:#f7f3ee;
    color:var(--ink);
  }
  .mobile-actions-strip a.primary{
    background:var(--ink);
    color:#fff;
    border-color:var(--ink);
  }
  .mobile-actions-strip a.wa{
    background:#25d366;
    color:#fff;
    border-color:#25d366;
  }
  .hero{
    padding-top:28px;
  }
  .hero .container,
  .hero-layout,
  .service-hero-layout,
  .ads-hero-layout{
    gap:20px;
  }
  .hero h1,
  .service-hero h1,
  .ads-hero h1{
    font-size:clamp(38px,9vw,58px);
    line-height:.98;
  }
  .hero .lead,
  .service-hero .lead,
  .ads-hero .lead{
    font-size:17px;
  }
  .hero-actions{
    gap:10px;
  }
}

@media(max-width:640px){
  body{
    padding-bottom:78px;
  }
  .topbar{
    display:none;
  }
  .header{
    position:sticky;
    top:0;
    z-index:70;
    background:rgba(255,255,255,.94);
    backdrop-filter:blur(12px);
  }
  .nav{
    min-height:68px;
  }
  .brand img{
    width:78px;
  }
  .brand-sub{
    display:none;
  }
  .menu-btn{
    width:46px;
    height:46px;
  }
  .mobile-actions-strip{
    top:68px;
    padding:8px 12px;
    grid-template-columns:1fr 1fr 1fr;
  }
  .mobile-actions-strip a{
    min-height:38px;
    font-size:12px;
    padding:0 6px;
  }
  .section{
    padding:42px 0;
  }
  .section-tight{
    padding:28px 0;
  }
  .hero{
    padding:22px 0 28px;
  }
  .hero .eyebrow,
  .service-hero .eyebrow,
  .ads-hero .eyebrow{
    margin-bottom:12px;
  }
  .hero h1,
  .service-hero h1,
  .ads-hero h1{
    font-size:clamp(34px,10.5vw,48px);
    line-height:.97;
    letter-spacing:-.055em;
  }
  .hero .lead,
  .service-hero .lead,
  .ads-hero .lead{
    font-size:16px;
    line-height:1.5;
    margin-top:14px;
  }
  .hero-actions,
  .ads-cta-row,
  .category-top-actions{
    display:grid;
    grid-template-columns:1fr;
    width:100%;
    gap:9px;
    margin-top:20px;
  }
  .hero-actions .btn,
  .ads-cta-row .btn,
  .category-top-actions .btn{
    width:100%;
    min-height:48px;
  }
  .hero-mobile-summary{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:8px;
    margin-top:14px;
  }
  .hero-mobile-summary span{
    background:#fff;
    border:1px solid var(--line);
    border-radius:16px;
    padding:10px;
    font-size:12px;
    font-weight:800;
    text-align:center;
    box-shadow:var(--shadow-soft);
  }
  .home-hero-showcase,
  .home-trust-showcase,
  .photo-card{
    border-radius:24px;
  }
  .home-hero-showcase{
    height:270px;
  }
  .showcase-label{
    display:none;
  }
  .home-text-card{
    padding:22px !important;
    border-radius:24px;
  }
  .home-text-card h1,
  .home-text-card h2{
    font-size:clamp(30px,8vw,42px);
    line-height:1.02;
  }
  .home-text-card .lead{
    font-size:15px;
  }
  .clients{
    grid-template-columns:1fr 1fr !important;
    gap:8px;
  }
  .client{
    padding:11px 8px;
    font-size:12px;
  }
  .stats{
    grid-template-columns:1fr 1fr;
    gap:10px;
  }
  .stat{
    padding:16px;
  }
  .stat strong{
    font-size:26px;
  }
  .service-benefits,
  .ads-proof,
  .contact-quick-grid,
  .quote-help-grid,
  .conversion-strip{
    grid-template-columns:1fr;
  }
  .faq-list details{
    padding:16px;
  }
  .form{
    padding:22px;
    border-radius:24px;
  }
  .mobile-cta{
    display:grid !important;
    grid-template-columns:1fr 1fr 1fr;
    gap:8px;
    padding:10px;
    background:rgba(255,255,255,.94);
    backdrop-filter:blur(14px);
    border-top:1px solid var(--line);
  }
  .mobile-cta a{
    min-height:48px;
    border-radius:999px;
    font-size:13px;
    font-weight:900;
  }
  .mobile-cta .map{
    display:flex;
    align-items:center;
    justify-content:center;
    background:#f4efe7;
    color:var(--ink);
  }
  .whatsapp-float{
    display:none !important;
  }
}


/* v19 - Ubicación solo en Contacto */
.mobile-actions-strip{
  grid-template-columns:1fr 1fr !important;
}
.contact-page .mobile-actions-strip{
  grid-template-columns:1fr 1fr 1fr !important;
}
.mobile-cta{
  grid-template-columns:1fr 1fr !important;
}
.contact-page .mobile-cta{
  grid-template-columns:1fr 1fr 1fr !important;
}
.nav-actions .location-btn{
  display:none !important;
}


/* v20 - clientes y confianza */
.clients-hero{
  padding:62px 0 36px;
}
.clients-hero-layout{
  display:grid;
  grid-template-columns:1fr .88fr;
  gap:34px;
  align-items:center;
}
.clients-hero .photo-card{
  height:380px;
}
.client-logo-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
  margin-top:30px;
}
.client-logo-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  padding:24px 14px;
  text-align:center;
  box-shadow:var(--shadow-soft);
  min-height:92px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:#35302b;
}
.sector-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
  margin-top:28px;
}
.sector-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:26px;
  padding:24px;
  box-shadow:var(--shadow-soft);
}
.sector-card h3{
  font-size:20px;
  margin-bottom:8px;
}
.sector-card p{
  color:var(--muted);
  font-size:14px;
}
.confidence-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
  align-items:stretch;
}
.confidence-panel{
  background:#fff;
  border:1px solid var(--line);
  border-radius:30px;
  padding:30px;
  box-shadow:var(--shadow-soft);
}
.confidence-panel ul{
  margin:18px 0 0;
  padding-left:20px;
  color:var(--muted);
}
.confidence-panel li{
  margin:8px 0;
}
.client-highlight{
  background:linear-gradient(135deg,#171717,#2a2723);
  color:#fff;
  border-radius:34px;
  padding:38px;
  box-shadow:var(--shadow);
}
.client-highlight p{
  color:#ddd6cc;
}
.client-highlight .clients{
  margin-top:22px;
}
.client-highlight .client{
  background:rgba(255,255,255,.09);
  border-color:rgba(255,255,255,.16);
  color:#fff;
}
@media(max-width:980px){
  .clients-hero-layout,.confidence-row{grid-template-columns:1fr}
  .client-logo-grid,.sector-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  .clients-hero{
    padding:42px 0 26px;
  }
  .clients-hero .photo-card{
    height:280px;
  }
  .client-logo-grid,.sector-grid{grid-template-columns:1fr}
  .client-highlight{
    padding:26px;
    border-radius:26px;
  }
}


/* v21 - home portada más corta + WhatsApp icon */
.btn-whatsapp{
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
}
.btn-whatsapp::before{
  content:"";
  width:18px;
  height:18px;
  flex:0 0 18px;
  background-repeat:no-repeat;
  background-position:center;
  background-size:contain;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'><path d='M20.52 3.48A11.78 11.78 0 0 0 12.06 0C5.49 0 .14 5.35.14 11.92c0 2.1.55 4.15 1.6 5.95L0 24l6.29-1.65a11.85 11.85 0 0 0 5.77 1.48h.01c6.57 0 11.92-5.35 11.92-11.92 0-3.18-1.24-6.17-3.47-8.43zm-8.46 18.33h-.01a9.84 9.84 0 0 1-5.01-1.37l-.36-.21-3.73.98 1-3.64-.23-.37a9.83 9.83 0 0 1-1.52-5.27c0-5.45 4.43-9.88 9.89-9.88 2.64 0 5.11 1.03 6.98 2.9a9.8 9.8 0 0 1 2.89 6.98c0 5.45-4.44 9.88-9.9 9.88zm5.42-7.4c-.3-.15-1.77-.87-2.04-.96-.27-.1-.46-.15-.66.15-.2.3-.76.96-.93 1.16-.17.2-.34.22-.64.07-.3-.15-1.25-.46-2.38-1.48-.88-.79-1.47-1.77-1.64-2.07-.17-.3-.02-.47.13-.62.13-.13.3-.34.44-.51.15-.17.2-.3.3-.5.1-.2.05-.37-.02-.52-.07-.15-.66-1.6-.9-2.19-.24-.58-.48-.5-.66-.5h-.56c-.2 0-.52.07-.8.37-.27.3-1.04 1.02-1.04 2.48s1.07 2.87 1.22 3.07c.15.2 2.1 3.2 5.08 4.49.71.31 1.27.49 1.7.62.72.23 1.37.2 1.89.12.58-.09 1.77-.72 2.02-1.42.25-.7.25-1.29.17-1.42-.07-.12-.27-.2-.57-.35z'/></svg>");
}
.home-cover{
  padding:56px 0 34px;
}
.home-cover-grid{
  display:grid;
  grid-template-columns:1.02fr .98fr;
  gap:34px;
  align-items:center;
}
.home-cover .lead{
  max-width:680px;
}
.home-cover-image{
  position:relative;
  height:500px;
  border-radius:40px;
  overflow:hidden;
  box-shadow:var(--shadow);
}
.home-cover-image img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.home-cover-image::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,0) 42%, rgba(0,0,0,.68) 100%);
}
.home-cover-label{
  position:absolute;
  left:22px;
  right:22px;
  bottom:22px;
  z-index:2;
  color:#fff;
}
.home-cover-label strong{
  display:block;
  font-size:30px;
  line-height:1.02;
  letter-spacing:-.04em;
}
.home-cover-label span{
  display:block;
  margin-top:7px;
  color:rgba(255,255,255,.82);
}
.home-mini-proof{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:10px;
  margin-top:16px;
}
.home-mini-proof div{
  background:#fff;
  border:1px solid var(--line);
  border-radius:18px;
  padding:12px;
  text-align:center;
  font-size:13px;
  font-weight:850;
  box-shadow:var(--shadow-soft);
}
.home-short-services{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
}
.home-short-service{
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  padding:24px;
  box-shadow:var(--shadow-soft);
}
.home-short-service h3{
  font-size:21px;
  margin-bottom:8px;
}
.home-short-service p{
  color:var(--muted);
  font-size:14px;
  margin-bottom:14px;
}
.home-short-service .btn{
  width:100%;
}
.home-compact-trust{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:22px;
  align-items:stretch;
}
.home-compact-panel{
  background:#fff;
  border:1px solid var(--line);
  border-radius:30px;
  padding:30px;
  box-shadow:var(--shadow-soft);
}
.home-compact-panel .clients{
  margin-top:18px;
}
.home-compact-panel .client{
  font-size:13px;
}
.home-compact-panel p{
  color:var(--muted);
}
.home-compact-panel ul{
  margin:16px 0 0;
  padding-left:20px;
  color:var(--muted);
}
.home-compact-panel li{
  margin:8px 0;
}
.home-final-cta{
  text-align:center;
  background:linear-gradient(135deg,#171717,#2e2a26);
  border-radius:34px;
  padding:42px 34px;
  color:#fff;
  box-shadow:var(--shadow);
}
.home-final-cta p{
  color:rgba(255,255,255,.82);
}
.home-final-cta .hero-actions{
  justify-content:center;
}
@media(max-width:980px){
  .home-cover-grid,.home-compact-trust{
    grid-template-columns:1fr;
  }
  .home-short-services{
    grid-template-columns:1fr 1fr;
  }
  .home-cover-image{
    height:380px;
  }
}
@media(max-width:640px){
  .home-cover{
    padding:28px 0 22px;
  }
  .home-cover-grid{
    gap:20px;
  }
  .home-cover-image{
    height:280px;
    border-radius:24px;
  }
  .home-cover-label{
    left:16px;
    right:16px;
    bottom:16px;
  }
  .home-cover-label strong{
    font-size:24px;
  }
  .home-short-services{
    grid-template-columns:1fr;
  }
  .home-mini-proof{
    grid-template-columns:1fr 1fr;
  }
  .home-compact-panel{
    padding:22px;
    border-radius:24px;
  }
  .home-final-cta{
    border-radius:24px;
    padding:28px 20px;
  }
}


/* v22 - trabajos más premium */
.portfolio-hero{
  padding:54px 0 30px;
}
.portfolio-hero-grid{
  display:grid;
  grid-template-columns:1fr .9fr;
  gap:34px;
  align-items:center;
}
.portfolio-hero .photo-card{
  height:360px;
  border-radius:36px;
}
.portfolio-index-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
  margin-top:30px;
}
.portfolio-index-card{
  position:relative;
  min-height:360px;
  border-radius:30px;
  overflow:hidden;
  background:#111;
  box-shadow:var(--shadow);
  color:#fff;
}
.portfolio-index-card img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  filter:brightness(.7) contrast(1.04);
  transition:.25s ease;
}
.portfolio-index-card:hover img{
  transform:scale(1.04);
  filter:brightness(.62) contrast(1.06);
}
.portfolio-index-card:after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,0) 35%,rgba(0,0,0,.76));
}
.portfolio-index-card .body{
  position:absolute;
  left:22px;
  right:22px;
  bottom:22px;
  z-index:2;
}
.portfolio-index-card h3{
  font-size:24px;
  margin:8px 0;
}
.portfolio-index-card p{
  color:rgba(255,255,255,.82);
  font-size:14px;
}
.portfolio-index-card .mini-link{
  display:inline-flex;
  margin-top:10px;
  color:#fff;
  font-weight:850;
  border-bottom:2px solid var(--accent);
}

.project-feature{
  display:grid;
  grid-template-columns:1.08fr .92fr;
  gap:28px;
  align-items:stretch;
}
.project-feature-img{
  min-height:430px;
  border-radius:34px;
  overflow:hidden;
  box-shadow:var(--shadow);
  background:#111;
}
.project-feature-img img{
  width:100%;
  height:100%;
  min-height:430px;
  object-fit:cover;
}
.project-feature-content{
  background:#fff;
  border:1px solid var(--line);
  border-radius:34px;
  padding:34px;
  box-shadow:var(--shadow-soft);
}
.project-feature-content h2{
  font-size:clamp(32px,3.5vw,48px);
}
.project-feature-list{
  display:grid;
  gap:12px;
  margin-top:20px;
}
.project-feature-list div{
  padding:12px 0;
  border-top:1px solid var(--line);
}
.project-feature-list b{
  display:block;
  margin-bottom:3px;
}
.project-feature-list span{
  color:var(--muted);
}

.portfolio-grid-premium{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
}
.portfolio-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:28px;
  overflow:hidden;
  box-shadow:var(--shadow-soft);
  transition:.2s ease;
}
.portfolio-card:hover{
  transform:translateY(-3px);
  box-shadow:var(--shadow);
}
.portfolio-card .thumb{
  height:260px;
  overflow:hidden;
}
.portfolio-card .thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.portfolio-card .body{
  padding:22px;
}
.portfolio-card h3{
  font-size:21px;
  margin-bottom:8px;
}
.portfolio-card p{
  color:var(--muted);
  font-size:14px;
}
.portfolio-card-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-top:14px;
}
.portfolio-card-actions .btn{
  min-height:40px;
  padding:9px 14px;
  font-size:13px;
}
.category-intro{
  display:grid;
  grid-template-columns:.76fr 1.24fr;
  gap:28px;
  align-items:end;
  margin-bottom:28px;
}
.category-intro p{
  color:var(--muted);
}
.portfolio-related{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
  margin-top:24px;
}
.portfolio-related a{
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  padding:22px;
  box-shadow:var(--shadow-soft);
}
.portfolio-related h3{
  font-size:20px;
}
.portfolio-related p{
  color:var(--muted);
  font-size:14px;
}
@media(max-width:980px){
  .portfolio-hero-grid,
  .project-feature,
  .category-intro{
    grid-template-columns:1fr;
  }
  .portfolio-index-grid,
  .portfolio-grid-premium{
    grid-template-columns:1fr 1fr;
  }
  .portfolio-related{
    grid-template-columns:1fr;
  }
}
@media(max-width:640px){
  .portfolio-hero{
    padding:34px 0 22px;
  }
  .portfolio-hero .photo-card{
    height:260px;
    border-radius:24px;
  }
  .portfolio-index-grid,
  .portfolio-grid-premium{
    grid-template-columns:1fr;
  }
  .portfolio-index-card{
    min-height:280px;
    border-radius:24px;
  }
  .project-feature-img,
  .project-feature-img img{
    min-height:290px;
    border-radius:24px;
  }
  .project-feature-content{
    padding:24px;
    border-radius:24px;
  }
  .portfolio-card .thumb{
    height:230px;
  }
}


/* v23 - Empresa real + clientes completos */
.company-hero{
  padding:62px 0 38px;
}
.company-hero-grid{
  display:grid;
  grid-template-columns:1fr .88fr;
  gap:36px;
  align-items:center;
}
.company-hero .photo-card{
  height:390px;
  border-radius:38px;
}
.company-story{
  display:grid;
  grid-template-columns:.72fr 1.28fr;
  gap:28px;
  align-items:start;
}
.company-story-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:30px;
  padding:32px;
  box-shadow:var(--shadow-soft);
}
.company-story-card p{
  color:var(--muted);
  font-size:17px;
}
.company-story-card p:last-child{
  margin-bottom:0;
}
.company-year{
  background:linear-gradient(135deg,#171717,#2d2925);
  color:#fff;
  border-radius:30px;
  padding:32px;
  box-shadow:var(--shadow);
  position:sticky;
  top:110px;
}
.company-year strong{
  display:block;
  font-size:64px;
  letter-spacing:-.07em;
  line-height:.9;
}
.company-year span{
  display:block;
  color:#ddd6cc;
  margin-top:12px;
}
.values-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
  margin-top:28px;
}
.value-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:28px;
  padding:28px;
  box-shadow:var(--shadow-soft);
}
.value-card h3{
  font-size:24px;
  margin-bottom:10px;
}
.value-card p{
  color:var(--muted);
}
.company-capabilities{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
}
.capability-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:28px;
  padding:28px;
  box-shadow:var(--shadow-soft);
}
.capability-card ul{
  margin:16px 0 0;
  padding-left:20px;
  color:var(--muted);
}
.capability-card li{
  margin:8px 0;
}
.clients-category-grid{
  display:grid;
  grid-template-columns:1fr 1.2fr;
  gap:26px;
  align-items:start;
}
.client-category-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:30px;
  padding:30px;
  box-shadow:var(--shadow-soft);
}
.client-list-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
  margin-top:20px;
}
.client-pill{
  background:#f8f5ef;
  border:1px solid var(--line);
  border-radius:999px;
  padding:10px 12px;
  text-align:center;
  font-size:13px;
  font-weight:800;
  color:#403a33;
}
.client-category-intro{
  background:linear-gradient(135deg,#171717,#2d2925);
  color:#fff;
  border-radius:30px;
  padding:30px;
  box-shadow:var(--shadow);
  position:sticky;
  top:110px;
}
.client-category-intro p{
  color:#ddd6cc;
}
.clients-feature-row{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
  margin-top:28px;
}
.clients-feature-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  padding:22px;
  box-shadow:var(--shadow-soft);
}
.clients-feature-card h3{
  font-size:19px;
  margin-bottom:8px;
}
.clients-feature-card p{
  color:var(--muted);
  font-size:14px;
}
@media(max-width:980px){
  .company-hero-grid,
  .company-story,
  .company-capabilities,
  .clients-category-grid{
    grid-template-columns:1fr;
  }
  .values-grid,
  .client-list-grid{
    grid-template-columns:1fr 1fr;
  }
  .clients-feature-row{
    grid-template-columns:1fr 1fr;
  }
  .company-year,
  .client-category-intro{
    position:relative;
    top:auto;
  }
}
@media(max-width:640px){
  .company-hero{
    padding:42px 0 26px;
  }
  .company-hero .photo-card{
    height:280px;
    border-radius:24px;
  }
  .values-grid,
  .client-list-grid,
  .clients-feature-row{
    grid-template-columns:1fr;
  }
  .company-story-card,
  .value-card,
  .capability-card,
  .client-category-card,
  .client-category-intro{
    padding:22px;
    border-radius:24px;
  }
  .company-year strong{
    font-size:52px;
  }
}


/* v24 - header + logo premium */
.header{
  background:rgba(250,247,242,.94);
  backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(49,43,36,.10);
}
.nav{
  min-height:94px;
  gap:24px;
}
.brand{
  display:flex;
  align-items:center;
  gap:18px;
  min-width:360px;
  text-decoration:none;
}
.brand img{
  width:104px;
  height:auto;
  object-fit:contain;
  display:block;
  background:transparent !important;
  border-radius:0 !important;
  box-shadow:none !important;
  mix-blend-mode:multiply;
}
.brand-sub{
  font-size:11px;
  line-height:1.55;
  letter-spacing:.22em;
  font-weight:850;
  color:#6b6258;
  text-transform:uppercase;
  max-width:390px;
}
.nav-links{
  gap:24px;
}
.nav-links a{
  font-size:14px;
  font-weight:850;
}
.nav-actions{
  gap:12px;
}
.nav-actions .btn-dark{
  min-width:158px;
}
@media(max-width:1180px){
  .brand{
    min-width:auto;
  }
  .brand-sub{
    max-width:300px;
    letter-spacing:.18em;
  }
  .nav-links{
    gap:16px;
  }
}
@media(max-width:980px){
  .nav{
    min-height:78px;
  }
  .brand{
    gap:12px;
  }
  .brand img{
    width:92px;
  }
  .brand-sub{
    display:block;
    max-width:260px;
    font-size:10px;
    letter-spacing:.14em;
  }
}
@media(max-width:640px){
  .nav{
    min-height:70px;
  }
  .brand img{
    width:82px;
  }
  .brand-sub{
    display:none;
  }
  .mobile-actions-strip{
    top:70px;
  }
}


/* v25 - Inicio portada premium inspirado en mockup */
.topbar{
  display:none !important;
}
.header{
  background:rgba(252,249,244,.96) !important;
  border-bottom:1px solid rgba(30,28,25,.08) !important;
  box-shadow:none !important;
}
.nav{
  max-width:1380px !important;
  min-height:104px !important;
  padding:20px 36px !important;
}
.brand{
  min-width:455px !important;
  gap:22px !important;
}
.brand img{
  width:176px !important;
  height:auto !important;
  max-height:56px !important;
  object-fit:contain !important;
  mix-blend-mode:multiply;
}
.brand > div{
  border-left:1px solid rgba(23,23,23,.18);
  padding-left:22px;
}
.brand-sub{
  font-size:9px !important;
  line-height:2 !important;
  letter-spacing:.34em !important;
  font-weight:800 !important;
  color:#746f68 !important;
  max-width:360px !important;
}
.nav-links{
  gap:34px !important;
  font-size:13px !important;
  font-weight:650 !important;
  color:#3d3934 !important;
}
.nav-links a.active::after,
.nav-links a:hover::after{
  bottom:-15px !important;
  height:2px !important;
  background:#008b84 !important;
}
.nav-actions .btn-dark{
  background:#007e78 !important;
  border-radius:7px !important;
  min-height:54px !important;
  min-width:174px !important;
  font-size:14px !important;
  box-shadow:0 14px 32px rgba(0,126,120,.16);
}
.nav-actions .btn-dark:hover{
  background:#006d68 !important;
}

.home-cover{
  min-height:calc(100vh - 104px);
  padding:70px 0 76px !important;
  display:flex;
  align-items:center;
}
.home-cover .container{
  max-width:1380px !important;
  padding:0 36px !important;
}
.home-cover-grid{
  display:grid !important;
  grid-template-columns:.84fr 1.16fr !important;
  gap:58px !important;
  align-items:center !important;
}
.home-cover .eyebrow{
  color:#008b84 !important;
  font-size:13px !important;
  letter-spacing:.04em !important;
  font-weight:800 !important;
  margin-bottom:26px !important;
}
.home-cover h1{
  font-family:Georgia, "Times New Roman", serif !important;
  font-size:clamp(48px,4.6vw,74px) !important;
  line-height:1.08 !important;
  letter-spacing:-.055em !important;
  font-weight:500 !important;
  color:#191918 !important;
  max-width:650px !important;
  margin-bottom:28px !important;
}
.home-cover h1::after{
  content:"";
  display:block;
  width:66px;
  height:2px;
  background:#008b84;
  margin-top:32px;
}
.home-cover .lead{
  font-size:18px !important;
  line-height:1.65 !important;
  color:#68635d !important;
  max-width:500px !important;
  margin-bottom:0 !important;
}
.home-cover .hero-actions{
  margin-top:34px !important;
  gap:20px !important;
}
.home-cover .btn{
  border-radius:6px !important;
  min-height:58px !important;
  padding:14px 30px !important;
  font-size:14px !important;
}
.home-cover .btn-accent{
  background:#007e78 !important;
  color:#fff !important;
  box-shadow:0 18px 36px rgba(0,126,120,.16);
}
.home-cover .btn-outline{
  border-color:rgba(23,23,23,.28) !important;
  background:transparent !important;
  color:#272522 !important;
  min-width:162px;
}
.home-cover .hero-mobile-summary,
.home-cover .stats,
.home-cover .home-mini-proof,
.home-cover-label{
  display:none !important;
}
.home-cover-image{
  height:auto !important;
  min-height:620px !important;
  border-radius:0 !important;
  box-shadow:none !important;
  background:transparent !important;
  display:grid !important;
  grid-template-columns:1.04fr 1fr 1.02fr !important;
  gap:8px !important;
  overflow:visible !important;
}
.home-cover-image::after{
  display:none !important;
}
.home-cover-image > img{
  display:none !important;
}
.home-triptych-panel{
  height:620px;
  overflow:hidden;
  border-radius:7px;
  background:#ede7dd;
  box-shadow:0 24px 55px rgba(23,23,23,.08);
}
.home-triptych-panel img{
  width:100%;
  height:100%;
  object-fit:cover;
  transform:scale(1.01);
}
.home-triptych-panel:nth-child(1){
  margin-top:0;
}
.home-triptych-panel:nth-child(2){
  margin-top:0;
}
.home-triptych-panel:nth-child(3){
  margin-top:0;
}
.whatsapp-float{
  width:64px !important;
  height:64px !important;
  padding:0 !important;
  border-radius:50% !important;
  right:32px !important;
  bottom:32px !important;
  font-size:0 !important;
  background:#16b956 !important;
  box-shadow:0 14px 34px rgba(22,185,86,.34) !important;
  display:grid !important;
  place-items:center !important;
}
.whatsapp-float::before{
  content:"";
  width:36px;
  height:36px;
  background-repeat:no-repeat;
  background-size:contain;
  background-position:center;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'><path d='M20.52 3.48A11.78 11.78 0 0 0 12.06 0C5.49 0 .14 5.35.14 11.92c0 2.1.55 4.15 1.6 5.95L0 24l6.29-1.65a11.85 11.85 0 0 0 5.77 1.48h.01c6.57 0 11.92-5.35 11.92-11.92 0-3.18-1.24-6.17-3.47-8.43zm-8.46 18.33h-.01a9.84 9.84 0 0 1-5.01-1.37l-.36-.21-3.73.98 1-3.64-.23-.37a9.83 9.83 0 0 1-1.52-5.27c0-5.45 4.43-9.88 9.89-9.88 2.64 0 5.11 1.03 6.98 2.9a9.8 9.8 0 0 1 2.89 6.98c0 5.45-4.44 9.88-9.9 9.88zm5.42-7.4c-.3-.15-1.77-.87-2.04-.96-.27-.1-.46-.15-.66.15-.2.3-.76.96-.93 1.16-.17.2-.34.22-.64.07-.3-.15-1.25-.46-2.38-1.48-.88-.79-1.47-1.77-1.64-2.07-.17-.3-.02-.47.13-.62.13-.13.3-.34.44-.51.15-.17.2-.3.3-.5.1-.2.05-.37-.02-.52-.07-.15-.66-1.6-.9-2.19-.24-.58-.48-.5-.66-.5h-.56c-.2 0-.52.07-.8.37-.27.3-1.04 1.02-1.04 2.48s1.07 2.87 1.22 3.07c.15.2 2.1 3.2 5.08 4.49.71.31 1.27.49 1.7.62.72.23 1.37.2 1.89.12.58-.09 1.77-.72 2.02-1.42.25-.7.25-1.29.17-1.42-.07-.12-.27-.2-.57-.35z'/></svg>");
}
.footer{
  margin-top:0;
}

/* home: no repetir secciones debajo de portada */
.home-page main + .footer{
  margin-top:0;
}

@media(max-width:1180px){
  .brand{
    min-width:330px !important;
  }
  .brand img{
    width:140px !important;
  }
  .brand-sub{
    font-size:8px !important;
    letter-spacing:.25em !important;
  }
  .nav-links{
    gap:20px !important;
  }
}
@media(max-width:980px){
  .nav{
    min-height:78px !important;
    padding:14px 20px !important;
  }
  .brand{
    min-width:auto !important;
  }
  .brand img{
    width:120px !important;
    max-height:48px !important;
  }
  .brand > div{
    display:none;
  }
  .nav-links{
    top:82px !important;
  }
  .home-cover{
    min-height:auto;
    padding:42px 0 50px !important;
  }
  .home-cover .container{
    padding:0 20px !important;
  }
  .home-cover-grid{
    grid-template-columns:1fr !important;
    gap:32px !important;
  }
  .home-cover h1{
    font-size:clamp(42px,9vw,58px) !important;
    max-width:720px !important;
  }
  .home-cover-image{
    min-height:430px !important;
  }
  .home-triptych-panel{
    height:430px;
  }
}
@media(max-width:640px){
  .home-cover{
    padding:34px 0 98px !important;
  }
  .home-cover h1{
    font-size:40px !important;
    line-height:1.08 !important;
  }
  .home-cover .lead{
    font-size:16px !important;
  }
  .home-cover .hero-actions{
    gap:10px !important;
  }
  .home-cover .btn{
    width:100%;
  }
  .home-cover-image{
    min-height:auto !important;
    grid-template-columns:1fr !important;
    gap:12px !important;
  }
  .home-triptych-panel{
    height:270px;
    border-radius:14px;
  }
  .home-triptych-panel:nth-child(2),
  .home-triptych-panel:nth-child(3){
    display:none;
  }
  .whatsapp-float{
    display:none !important;
  }
}


/* v26 - home más delicada y más chica */
.header{
  background:rgba(252,249,244,.97) !important;
}
.nav{
  max-width:1280px !important;
  min-height:84px !important;
  padding:16px 28px !important;
}
.brand{
  min-width:390px !important;
  gap:16px !important;
}
.brand img{
  width:128px !important;
  max-height:44px !important;
}
.brand > div{
  padding-left:16px !important;
}
.brand-sub{
  font-size:7.5px !important;
  line-height:1.9 !important;
  letter-spacing:.30em !important;
  color:#807a73 !important;
  max-width:290px !important;
}
.nav-links{
  gap:24px !important;
  font-size:12px !important;
  font-weight:600 !important;
}
.nav-links a.active::after,
.nav-links a:hover::after{
  bottom:-12px !important;
}
.nav-actions .btn-dark{
  min-height:46px !important;
  min-width:154px !important;
  padding:10px 18px !important;
  font-size:13px !important;
  border-radius:6px !important;
}
.home-cover{
  min-height:auto !important;
  padding:44px 0 56px !important;
}
.home-cover .container{
  max-width:1280px !important;
  padding:0 28px !important;
}
.home-cover-grid{
  grid-template-columns:.92fr 1.08fr !important;
  gap:42px !important;
  align-items:center !important;
}
.home-cover .eyebrow{
  font-size:12px !important;
  letter-spacing:.12em !important;
  margin-bottom:18px !important;
}
.home-cover h1{
  font-size:clamp(30px,3.8vw,58px) !important;
  line-height:1.07 !important;
  letter-spacing:-.045em !important;
  max-width:500px !important;
  margin-bottom:18px !important;
}
.home-cover h1::after{
  width:52px !important;
  margin-top:22px !important;
}
.home-cover .lead{
  font-size:15px !important;
  line-height:1.62 !important;
  max-width:430px !important;
  color:#706a64 !important;
}
.home-cover .hero-actions{
  margin-top:24px !important;
  gap:14px !important;
}
.home-cover .btn{
  min-height:48px !important;
  padding:12px 20px !important;
  font-size:13px !important;
}
.home-cover-image{
  min-height:470px !important;
  gap:7px !important;
}
.home-triptych-panel{
  height:470px !important;
  border-radius:6px !important;
  box-shadow:0 16px 32px rgba(23,23,23,.06) !important;
}
.whatsapp-float{
  width:58px !important;
  height:58px !important;
  right:24px !important;
  bottom:24px !important;
}
.whatsapp-float::before{
  width:32px !important;
  height:32px !important;
}
@media (max-width:1180px){
  .nav{padding:14px 22px !important; min-height:78px !important;}
  .brand{min-width:330px !important;}
  .brand img{width:118px !important;}
  .brand-sub{font-size:7px !important; letter-spacing:.24em !important; max-width:250px !important;}
  .nav-links{gap:16px !important; font-size:11.5px !important;}
  .home-cover{padding:36px 0 46px !important;}
  .home-cover-grid{gap:28px !important;}
  .home-cover h1{font-size:clamp(28px,3.9vw,46px) !important; max-width:430px !important;}
  .home-cover .lead{font-size:14px !important;}
  .home-cover-image{min-height:400px !important;}
  .home-triptych-panel{height:400px !important;}
}
@media (max-width:980px){
  .nav{min-height:74px !important; padding:12px 18px !important;}
  .brand img{width:112px !important; max-height:42px !important;}
  .home-cover{padding:28px 0 42px !important;}
  .home-cover .container{padding:0 18px !important;}
  .home-cover-grid{grid-template-columns:1fr !important; gap:24px !important;}
  .home-cover h1{font-size:clamp(30px,8vw,44px) !important; max-width:600px !important;}
  .home-cover .lead{max-width:560px !important;}
  .home-cover-image{min-height:360px !important;}
  .home-triptych-panel{height:360px !important;}
}
@media (max-width:640px){
  .home-cover{padding:22px 0 82px !important;}
  .home-cover h1{font-size:32px !important; line-height:1.1 !important; margin-bottom:14px !important;}
  .home-cover .eyebrow{font-size:11px !important; margin-bottom:14px !important;}
  .home-cover .lead{font-size:14px !important;}
  .home-cover .btn{min-height:46px !important; font-size:12.5px !important;}
  .home-triptych-panel{height:238px !important; border-radius:12px !important;}
}


/* v27 - WhatsApp flotante perfectamente centrado */
.whatsapp-float{
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  padding:0 !important;
  line-height:0 !important;
  text-indent:-9999px !important;
  overflow:hidden !important;
}
.whatsapp-float::before{
  content:"" !important;
  display:block !important;
  position:static !important;
  inset:auto !important;
  margin:0 !important;
  padding:0 !important;
  width:31px !important;
  height:31px !important;
  flex:0 0 31px !important;
  transform:translateX(0) translateY(0) !important;
  text-indent:0 !important;
  background-repeat:no-repeat !important;
  background-position:center center !important;
  background-size:contain !important;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='white' d='M20.52 3.48A11.78 11.78 0 0 0 12.06 0C5.49 0 .14 5.35.14 11.92c0 2.1.55 4.15 1.6 5.95L0 24l6.29-1.65a11.85 11.85 0 0 0 5.77 1.48h.01c6.57 0 11.92-5.35 11.92-11.92c0-3.18-1.24-6.17-3.47-8.43ZM12.06 21.81h-.01a9.84 9.84 0 0 1-5.01-1.37l-.36-.21l-3.73.98l1-3.64l-.23-.37a9.83 9.83 0 0 1-1.52-5.27c0-5.45 4.43-9.88 9.89-9.88c2.64 0 5.11 1.03 6.98 2.9a9.8 9.8 0 0 1 2.89 6.98c0 5.45-4.44 9.88-9.9 9.88Zm5.42-7.4c-.3-.15-1.77-.87-2.04-.96c-.27-.1-.46-.15-.66.15c-.2.3-.76.96-.93 1.16c-.17.2-.34.22-.64.07c-.3-.15-1.25-.46-2.38-1.48c-.88-.79-1.47-1.77-1.64-2.07c-.17-.3-.02-.47.13-.62c.13-.13.3-.34.44-.51c.15-.17.2-.3.3-.5c.1-.2.05-.37-.02-.52c-.07-.15-.66-1.6-.9-2.19c-.24-.58-.48-.5-.66-.5h-.56c-.2 0-.52.07-.8.37c-.27.3-1.04 1.02-1.04 2.48s1.07 2.87 1.22 3.07c.15.2 2.1 3.2 5.08 4.49c.71.31 1.27.49 1.7.62c.72.23 1.37.2 1.89.12c.58-.09 1.77-.72 2.02-1.42c.25-.7.25-1.29.17-1.42c-.07-.12-.27-.2-.57-.35Z'/></svg>") !important;
}


/* v28 - Contacto / presupuesto premium */
.quote-contact-hero{
  padding:54px 0 34px;
}
.quote-contact-grid{
  display:grid;
  grid-template-columns:1.02fr .98fr;
  gap:34px;
  align-items:stretch;
}
.quote-contact-copy{
  background:#fff;
  border:1px solid var(--line);
  border-radius:32px;
  padding:42px;
  box-shadow:var(--shadow-soft);
}
.quote-contact-copy h1{
  max-width:780px;
}
.quote-contact-copy .lead{
  max-width:650px;
}
.quote-primary-card{
  background:linear-gradient(135deg,#171717,#2d2925);
  color:#fff;
  border-radius:32px;
  padding:34px;
  box-shadow:var(--shadow);
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  min-height:100%;
}
.quote-primary-card p{
  color:rgba(255,255,255,.78);
}
.quote-primary-card .badge{
  background:rgba(255,255,255,.10);
  color:#fff;
  border-color:rgba(255,255,255,.16);
}
.quote-primary-card h2{
  color:#fff;
  font-size:clamp(30px,3vw,44px);
  margin:16px 0 12px;
}
.quote-primary-card .btn{
  width:100%;
  margin-top:14px;
}
.quote-primary-card .btn-accent{
  background:#16b956;
  color:#fff;
}
.quote-contact-details{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
  margin-top:24px;
}
.quote-contact-detail{
  background:#f8f5ef;
  border:1px solid var(--line);
  border-radius:18px;
  padding:14px;
}
.quote-contact-detail strong{
  display:block;
  font-size:14px;
}
.quote-contact-detail span{
  display:block;
  margin-top:4px;
  font-size:13px;
  color:var(--muted);
}
.quote-steps-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
  margin-top:28px;
}
.quote-step-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:26px;
  padding:24px;
  box-shadow:var(--shadow-soft);
}
.quote-step-card .num{
  width:36px;
  height:36px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:#008b84;
  color:#fff;
  font-weight:900;
  margin-bottom:16px;
}
.quote-step-card h3{
  font-size:20px;
  margin-bottom:8px;
}
.quote-step-card p{
  color:var(--muted);
  font-size:14px;
}
.project-consult-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
  margin-top:28px;
}
.project-consult-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:28px;
  overflow:hidden;
  box-shadow:var(--shadow-soft);
  transition:.2s ease;
}
.project-consult-card:hover{
  transform:translateY(-3px);
  box-shadow:var(--shadow);
}
.project-consult-card .thumb{
  height:168px;
  overflow:hidden;
}
.project-consult-card .thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.project-consult-card .body{
  padding:20px;
}
.project-consult-card h3{
  font-size:20px;
  margin:8px 0 8px;
}
.project-consult-card p{
  color:var(--muted);
  font-size:14px;
  min-height:58px;
}
.project-consult-card .btn{
  width:100%;
  min-height:42px;
  padding:10px 14px;
  font-size:13px;
  margin-top:14px;
}
.quote-form-layout{
  display:grid;
  grid-template-columns:.92fr 1.08fr;
  gap:26px;
  align-items:start;
}
.quote-info-stack{
  display:grid;
  gap:16px;
}
.quote-info-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:26px;
  padding:24px;
  box-shadow:var(--shadow-soft);
}
.quote-info-card h3{
  font-size:21px;
  margin-bottom:8px;
}
.quote-info-card p{
  color:var(--muted);
  margin:0;
}
.quote-info-card a{
  font-weight:850;
}
.premium-form{
  border-radius:30px !important;
  padding:32px !important;
}
.premium-form .form-grid{
  grid-template-columns:1fr 1fr;
}
.form-note-box{
  margin-top:16px;
  background:#f8f5ef;
  border:1px solid var(--line);
  border-radius:18px;
  padding:14px;
  color:var(--muted);
  font-size:13px;
}
.location-premium{
  background:#fff;
  border:1px solid var(--line);
  border-radius:32px;
  padding:32px;
  box-shadow:var(--shadow-soft);
  display:grid;
  grid-template-columns:1fr .84fr;
  gap:28px;
  align-items:center;
}
.location-map-preview{
  min-height:260px;
  border-radius:26px;
  background:
    radial-gradient(circle at 30% 25%, rgba(0,139,132,.20), transparent 30%),
    radial-gradient(circle at 70% 70%, rgba(23,23,23,.16), transparent 30%),
    linear-gradient(135deg,#f7f2ea,#ebe4d8);
  border:1px solid var(--line);
  display:grid;
  place-items:center;
  text-align:center;
  padding:26px;
}
.location-map-preview strong{
  display:block;
  font-size:28px;
  letter-spacing:-.04em;
}
.location-map-preview span{
  display:block;
  margin-top:6px;
  color:var(--muted);
}
.contact-page .mobile-actions-strip{
  grid-template-columns:1fr 1fr 1fr !important;
}

@media(max-width:980px){
  .quote-contact-grid,
  .quote-form-layout,
  .location-premium{
    grid-template-columns:1fr;
  }
  .quote-steps-grid,
  .project-consult-grid{
    grid-template-columns:1fr 1fr;
  }
  .quote-contact-details{
    grid-template-columns:1fr;
  }
}
@media(max-width:640px){
  .quote-contact-hero{
    padding:28px 0 24px;
  }
  .quote-contact-copy,
  .quote-primary-card,
  .premium-form,
  .location-premium{
    border-radius:24px !important;
    padding:22px !important;
  }
  .quote-contact-copy h1{
    font-size:38px;
  }
  .quote-steps-grid,
  .project-consult-grid{
    grid-template-columns:1fr;
  }
  .project-consult-card .thumb{
    height:210px;
  }
  .premium-form .form-grid{
    grid-template-columns:1fr;
  }
}


/* v29 - Cómo trabajamos */
.process-hero{
  padding:56px 0 34px;
}
.process-hero-grid{
  display:grid;
  grid-template-columns:1fr .92fr;
  gap:34px;
  align-items:stretch;
}
.process-hero-copy{
  background:#fff;
  border:1px solid var(--line);
  border-radius:32px;
  padding:42px;
  box-shadow:var(--shadow-soft);
}
.process-hero-img{
  min-height:420px;
  border-radius:32px;
  overflow:hidden;
  box-shadow:var(--shadow);
  background:#111;
}
.process-hero-img img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.process-timeline{
  position:relative;
  display:grid;
  gap:18px;
  margin-top:30px;
}
.process-timeline:before{
  content:"";
  position:absolute;
  left:29px;
  top:28px;
  bottom:28px;
  width:1px;
  background:var(--line);
}
.timeline-item{
  position:relative;
  display:grid;
  grid-template-columns:60px 1fr;
  gap:20px;
}
.timeline-num{
  width:58px;
  height:58px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:#008b84;
  color:#fff;
  font-weight:900;
  z-index:2;
  box-shadow:0 12px 28px rgba(0,139,132,.18);
}
.timeline-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:28px;
  padding:26px;
  box-shadow:var(--shadow-soft);
}
.timeline-card h3{
  font-size:24px;
  margin-bottom:8px;
}
.timeline-card p{
  color:var(--muted);
}
.timeline-card ul{
  margin:16px 0 0;
  padding-left:18px;
  color:var(--muted);
}
.timeline-card li{
  margin:7px 0;
}
.process-detail-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
  margin-top:28px;
}
.process-detail-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:28px;
  padding:26px;
  box-shadow:var(--shadow-soft);
}
.process-detail-card h3{
  font-size:22px;
  margin-bottom:10px;
}
.process-detail-card p,
.process-detail-card li{
  color:var(--muted);
}
.process-detail-card ul{
  margin:14px 0 0;
  padding-left:18px;
}
.quality-band{
  display:grid;
  grid-template-columns:.86fr 1.14fr;
  gap:26px;
  align-items:center;
  background:linear-gradient(135deg,#171717,#2d2925);
  color:#fff;
  border-radius:34px;
  padding:34px;
  box-shadow:var(--shadow);
}
.quality-band p{
  color:rgba(255,255,255,.78);
}
.quality-band .badge{
  background:rgba(255,255,255,.10);
  color:#fff;
  border-color:rgba(255,255,255,.16);
}
.quality-points{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}
.quality-point{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  border-radius:22px;
  padding:18px;
}
.quality-point strong{
  display:block;
  margin-bottom:6px;
}
.process-mini-cta{
  display:grid;
  grid-template-columns:1fr .86fr;
  gap:24px;
  align-items:center;
  background:#fff;
  border:1px solid var(--line);
  border-radius:32px;
  padding:34px;
  box-shadow:var(--shadow-soft);
}
.process-mini-cta .mini-list{
  display:grid;
  gap:10px;
}
.process-mini-cta .mini-list div{
  background:#f8f5ef;
  border:1px solid var(--line);
  border-radius:18px;
  padding:14px;
  color:#5f5851;
  font-weight:750;
}
@media(max-width:980px){
  .process-hero-grid,
  .quality-band,
  .process-mini-cta{
    grid-template-columns:1fr;
  }
  .process-detail-grid{
    grid-template-columns:1fr 1fr;
  }
}
@media(max-width:640px){
  .process-hero{
    padding:30px 0 24px;
  }
  .process-hero-copy,
  .quality-band,
  .process-mini-cta{
    border-radius:24px;
    padding:22px;
  }
  .process-hero-copy h1{
    font-size:38px;
  }
  .process-hero-img{
    min-height:260px;
    border-radius:24px;
  }
  .process-timeline:before{
    left:20px;
  }
  .timeline-item{
    grid-template-columns:42px 1fr;
    gap:12px;
  }
  .timeline-num{
    width:42px;
    height:42px;
    font-size:13px;
  }
  .timeline-card{
    padding:20px;
    border-radius:22px;
  }
  .process-detail-grid,
  .quality-points{
    grid-template-columns:1fr;
  }
}


/* v30 - Servicios premium */
.services-premium-hero{
  padding:54px 0 32px;
}
.services-premium-grid{
  display:grid;
  grid-template-columns:1fr .94fr;
  gap:34px;
  align-items:stretch;
}
.services-premium-copy{
  background:#fff;
  border:1px solid var(--line);
  border-radius:32px;
  padding:42px;
  box-shadow:var(--shadow-soft);
}
.services-premium-image{
  border-radius:32px;
  overflow:hidden;
  min-height:430px;
  box-shadow:var(--shadow);
  background:#111;
}
.services-premium-image img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.services-pill-row{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:24px;
}
.services-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid var(--line);
  background:#f8f5ef;
  color:#5f5851;
  font-size:13px;
  font-weight:850;
}
.service-pillar-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
  margin-top:30px;
}
.service-pillar{
  background:#fff;
  border:1px solid var(--line);
  border-radius:30px;
  overflow:hidden;
  box-shadow:var(--shadow-soft);
  transition:.22s ease;
}
.service-pillar:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow);
}
.service-pillar .thumb{
  height:240px;
  overflow:hidden;
}
.service-pillar .thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.service-pillar .body{
  padding:28px;
}
.service-pillar h3{
  font-size:28px;
  margin:10px 0;
}
.service-pillar p{
  color:var(--muted);
}
.service-pillar ul{
  margin:18px 0 0;
  padding-left:18px;
  color:var(--muted);
}
.service-pillar li{
  margin:8px 0;
}
.service-links-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
  margin-top:28px;
}
.service-link-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  padding:24px;
  box-shadow:var(--shadow-soft);
}
.service-link-card h3{
  font-size:21px;
  margin-bottom:8px;
}
.service-link-card p{
  color:var(--muted);
  font-size:14px;
}
.service-link-card .btn{
  width:100%;
  margin-top:12px;
  min-height:42px;
  padding:10px 14px;
  font-size:13px;
}
.materials-band{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:24px;
  align-items:center;
  background:linear-gradient(135deg,#171717,#2d2925);
  color:#fff;
  border-radius:34px;
  padding:36px;
  box-shadow:var(--shadow);
}
.materials-band p{
  color:rgba(255,255,255,.78);
}
.materials-band .badge{
  background:rgba(255,255,255,.10);
  color:#fff;
  border-color:rgba(255,255,255,.16);
}
.materials-mini-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}
.material-mini{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  border-radius:22px;
  padding:18px;
}
.material-mini strong{
  display:block;
  margin-bottom:6px;
}
.service-cta-split{
  display:grid;
  grid-template-columns:1fr .92fr;
  gap:24px;
  align-items:center;
  background:#fff;
  border:1px solid var(--line);
  border-radius:32px;
  padding:34px;
  box-shadow:var(--shadow-soft);
}
.service-cta-list{
  display:grid;
  gap:10px;
}
.service-cta-list div{
  background:#f8f5ef;
  border:1px solid var(--line);
  border-radius:18px;
  padding:14px;
  color:#5f5851;
  font-weight:750;
}
@media(max-width:980px){
  .services-premium-grid,
  .materials-band,
  .service-cta-split{
    grid-template-columns:1fr;
  }
  .service-pillar-grid,
  .service-links-grid{
    grid-template-columns:1fr 1fr;
  }
}
@media(max-width:640px){
  .services-premium-hero{
    padding:30px 0 22px;
  }
  .services-premium-copy,
  .materials-band,
  .service-cta-split{
    border-radius:24px;
    padding:22px;
  }
  .services-premium-copy h1{
    font-size:38px;
  }
  .services-premium-image{
    min-height:260px;
    border-radius:24px;
  }
  .service-pillar-grid,
  .service-links-grid,
  .materials-mini-grid{
    grid-template-columns:1fr;
  }
  .service-pillar .thumb{
    height:220px;
  }
  .service-pillar .body,
  .service-link-card{
    padding:22px;
  }
}


/* v31 - SEO local + Google Ads */
.local-hero{
  padding:54px 0 32px;
}
.local-hero-grid{
  display:grid;
  grid-template-columns:1fr .92fr;
  gap:34px;
  align-items:stretch;
}
.local-hero-copy{
  background:#fff;
  border:1px solid var(--line);
  border-radius:32px;
  padding:42px;
  box-shadow:var(--shadow-soft);
}
.local-hero-image{
  min-height:420px;
  border-radius:32px;
  overflow:hidden;
  box-shadow:var(--shadow);
  background:#111;
}
.local-hero-image img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.local-pill-row{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:22px;
}
.local-pill{
  display:inline-flex;
  padding:10px 14px;
  border-radius:999px;
  background:#f8f5ef;
  border:1px solid var(--line);
  color:#5f5851;
  font-size:13px;
  font-weight:850;
}
.local-service-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
  margin-top:28px;
}
.local-service-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:26px;
  padding:24px;
  box-shadow:var(--shadow-soft);
}
.local-service-card h3{
  font-size:22px;
  margin-bottom:8px;
}
.local-service-card p{
  color:var(--muted);
  font-size:14px;
}
.local-service-card .btn{
  width:100%;
  margin-top:14px;
  min-height:42px;
  font-size:13px;
  padding:10px 14px;
}
.local-info-band{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:24px;
  align-items:center;
  background:linear-gradient(135deg,#171717,#2d2925);
  color:#fff;
  border-radius:34px;
  padding:36px;
  box-shadow:var(--shadow);
}
.local-info-band p{
  color:rgba(255,255,255,.78);
}
.local-info-band .badge{
  background:rgba(255,255,255,.10);
  color:#fff;
  border-color:rgba(255,255,255,.16);
}
.local-zone-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:14px;
}
.local-zone-card{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  border-radius:20px;
  padding:18px;
}
.local-zone-card strong{
  display:block;
  margin-bottom:6px;
}
.ads-pack-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
  margin-top:28px;
}
.ads-pack-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  padding:22px;
  box-shadow:var(--shadow-soft);
}
.ads-pack-card h3{
  font-size:19px;
  margin-bottom:8px;
}
.ads-pack-card p{
  color:var(--muted);
  font-size:14px;
}
.local-faq{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
  margin-top:28px;
}
.local-faq details{
  background:#fff;
  border:1px solid var(--line);
  border-radius:20px;
  padding:18px 20px;
  box-shadow:var(--shadow-soft);
}
.local-faq summary{
  cursor:pointer;
  font-weight:850;
}
.local-faq p{
  margin:12px 0 0;
  color:var(--muted);
}
@media(max-width:980px){
  .local-hero-grid,
  .local-info-band{
    grid-template-columns:1fr;
  }
  .local-service-grid,
  .ads-pack-grid{
    grid-template-columns:1fr 1fr;
  }
}
@media(max-width:640px){
  .local-hero{
    padding:30px 0 22px;
  }
  .local-hero-copy,
  .local-info-band{
    border-radius:24px;
    padding:22px;
  }
  .local-hero-copy h1{
    font-size:38px;
  }
  .local-hero-image{
    min-height:260px;
    border-radius:24px;
  }
  .local-service-grid,
  .ads-pack-grid,
  .local-zone-grid,
  .local-faq{
    grid-template-columns:1fr;
  }
}


/* v32 - Lightbox profesional para fotos */
[data-lightbox-image]{
  cursor: zoom-in;
}
[data-lightbox-image]{
  transition: transform .28s ease, filter .28s ease;
}
[data-lightbox-image]:hover{
  filter: contrast(1.04) saturate(1.03);
}
.lightbox-modal{
  position:fixed;
  inset:0;
  z-index:9999;
  display:none;
  align-items:center;
  justify-content:center;
  padding:28px;
  background:rgba(10,10,10,.90);
  backdrop-filter:blur(8px);
}
.lightbox-modal.open{
  display:flex;
}
.lightbox-stage{
  position:relative;
  width:min(1180px,94vw);
  height:min(82vh,760px);
  display:flex;
  align-items:center;
  justify-content:center;
}
.lightbox-stage img{
  max-width:100%;
  max-height:100%;
  object-fit:contain;
  border-radius:18px;
  box-shadow:0 30px 90px rgba(0,0,0,.55);
  background:#111;
}
.lightbox-close,
.lightbox-prev,
.lightbox-next{
  position:absolute;
  border:1px solid rgba(255,255,255,.22);
  background:rgba(255,255,255,.12);
  color:#fff;
  cursor:pointer;
  display:grid;
  place-items:center;
  transition:.18s ease;
  backdrop-filter:blur(10px);
}
.lightbox-close:hover,
.lightbox-prev:hover,
.lightbox-next:hover{
  background:rgba(255,255,255,.22);
}
.lightbox-close{
  top:18px;
  right:18px;
  width:46px;
  height:46px;
  border-radius:50%;
  font-size:30px;
  line-height:1;
  z-index:3;
}
.lightbox-prev,
.lightbox-next{
  top:50%;
  transform:translateY(-50%);
  width:50px;
  height:64px;
  border-radius:999px;
  font-size:32px;
  z-index:3;
}
.lightbox-prev{
  left:18px;
}
.lightbox-next{
  right:18px;
}
.lightbox-caption{
  position:absolute;
  left:24px;
  right:24px;
  bottom:18px;
  color:#fff;
  text-align:center;
  font-size:14px;
  font-weight:700;
  line-height:1.4;
  text-shadow:0 2px 14px rgba(0,0,0,.65);
  pointer-events:none;
}
.lightbox-counter{
  position:absolute;
  left:18px;
  top:18px;
  color:#fff;
  font-size:13px;
  font-weight:800;
  padding:10px 13px;
  border-radius:999px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.18);
  backdrop-filter:blur(10px);
}
.lightbox-hint{
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  bottom:18px;
  color:rgba(255,255,255,.72);
  font-size:12px;
  display:none;
}
.zoom-badge{
  position:absolute;
  right:12px;
  bottom:12px;
  width:38px;
  height:38px;
  border-radius:50%;
  background:rgba(0,0,0,.42);
  border:1px solid rgba(255,255,255,.18);
  backdrop-filter:blur(8px);
  display:grid;
  place-items:center;
  color:#fff;
  font-size:0;
  pointer-events:none;
  opacity:0;
  transition:.2s ease;
}
.zoom-badge:before{
  content:"";
  width:18px;
  height:18px;
  border:2px solid #fff;
  border-radius:50%;
  display:block;
  position:relative;
}
.zoom-badge:after{
  content:"";
  width:9px;
  height:2px;
  background:#fff;
  transform:rotate(45deg);
  position:absolute;
  right:9px;
  bottom:10px;
  border-radius:2px;
}
.thumb,
.photo-card,
.home-triptych-panel,
.project-feature-img,
.services-premium-image,
.process-hero-img,
.local-hero-image,
.clients-hero .photo-card,
.company-hero .photo-card{
  position:relative;
}
.thumb:hover .zoom-badge,
.photo-card:hover .zoom-badge,
.home-triptych-panel:hover .zoom-badge,
.project-feature-img:hover .zoom-badge,
.services-premium-image:hover .zoom-badge,
.process-hero-img:hover .zoom-badge,
.local-hero-image:hover .zoom-badge{
  opacity:1;
}
@media(max-width:640px){
  .lightbox-modal{
    padding:12px;
  }
  .lightbox-stage{
    width:96vw;
    height:78vh;
  }
  .lightbox-stage img{
    border-radius:12px;
  }
  .lightbox-close{
    top:12px;
    right:12px;
    width:42px;
    height:42px;
    font-size:26px;
  }
  .lightbox-prev,
  .lightbox-next{
    width:42px;
    height:54px;
    font-size:26px;
  }
  .lightbox-prev{
    left:8px;
  }
  .lightbox-next{
    right:8px;
  }
  .lightbox-caption{
    bottom:12px;
    font-size:12px;
  }
  .lightbox-counter{
    top:12px;
    left:12px;
    font-size:12px;
    padding:8px 11px;
  }
  .zoom-badge{
    opacity:1;
    width:34px;
    height:34px;
  }
}


/* v36 - privacidad y cookies */
.cookie-banner{position:fixed;left:18px;right:18px;bottom:18px;z-index:9998;max-width:920px;margin:auto;background:#171717;color:#fff;border-radius:22px;box-shadow:0 22px 70px rgba(0,0,0,.28);padding:18px;display:none;gap:18px;align-items:center}.cookie-banner.show{display:flex}.cookie-banner p{color:rgba(255,255,255,.80);margin:0;font-size:14px}.cookie-banner a{color:#fff;text-decoration:underline}.cookie-actions{display:flex;gap:10px;flex:0 0 auto}.cookie-actions button{border:0;border-radius:999px;padding:11px 16px;font-weight:850;cursor:pointer}.cookie-accept{background:#16b956;color:#fff}.cookie-reject{background:rgba(255,255,255,.12);color:#fff}.policy-grid{display:grid;grid-template-columns:.34fr .66fr;gap:28px;align-items:start}.policy-nav{position:sticky;top:110px;background:#fff;border:1px solid var(--line);border-radius:24px;padding:20px;box-shadow:var(--shadow-soft)}.policy-nav a{display:block;padding:10px 0;border-bottom:1px solid var(--line);font-weight:800}.policy-body{background:#fff;border:1px solid var(--line);border-radius:30px;padding:34px;box-shadow:var(--shadow-soft)}.policy-body h2{margin-top:34px}.policy-body p,.policy-body li{color:var(--muted)}@media(max-width:780px){.cookie-banner{flex-direction:column;align-items:stretch}.cookie-actions{display:grid;grid-template-columns:1fr 1fr}.policy-grid{grid-template-columns:1fr}.policy-nav{position:relative;top:auto}.policy-body{padding:22px;border-radius:24px}}


/* v39 - footer público más corto y WhatsApp perfectamente centrado */
.footer-grid-clean{
  grid-template-columns:1.2fr .9fr .9fr !important;
  gap:34px !important;
  align-items:start;
}
.footer-brand{
  min-width:auto !important;
}
.footer-brand img{
  width:132px !important;
  max-height:48px !important;
}
.footer-links-clean{
  display:grid !important;
  grid-template-columns:1fr !important;
  gap:10px !important;
}
.footer-links-clean a{
  width:max-content;
}
.footer-bottom{
  align-items:center;
}
.footer-legal-links a{
  color:#aaa39b;
}
.whatsapp-float{
  width:58px !important;
  height:58px !important;
  padding:0 !important;
  border-radius:50% !important;
  display:grid !important;
  place-items:center !important;
  font-size:0 !important;
  line-height:0 !important;
  text-indent:0 !important;
  overflow:hidden !important;
  position:fixed !important;
  right:24px !important;
  bottom:24px !important;
}
.whatsapp-float::before{
  content:"" !important;
  width:30px !important;
  height:30px !important;
  display:block !important;
  position:absolute !important;
  inset:0 !important;
  margin:auto !important;
  background-repeat:no-repeat !important;
  background-position:center center !important;
  background-size:contain !important;
  transform:none !important;
  flex:none !important;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='white' d='M20.52 3.48A11.78 11.78 0 0 0 12.06 0C5.49 0 .14 5.35.14 11.92c0 2.1.55 4.15 1.6 5.95L0 24l6.29-1.65a11.85 11.85 0 0 0 5.77 1.48h.01c6.57 0 11.92-5.35 11.92-11.92c0-3.18-1.24-6.17-3.47-8.43ZM12.06 21.81h-.01a9.84 9.84 0 0 1-5.01-1.37l-.36-.21l-3.73.98l1-3.64l-.23-.37a9.83 9.83 0 0 1-1.52-5.27c0-5.45 4.43-9.88 9.89-9.88c2.64 0 5.11 1.03 6.98 2.9a9.8 9.8 0 0 1 2.89 6.98c0 5.45-4.44 9.88-9.9 9.88Zm5.42-7.4c-.3-.15-1.77-.87-2.04-.96c-.27-.1-.46-.15-.66.15c-.2.3-.76.96-.93 1.16c-.17.2-.34.22-.64.07c-.3-.15-1.25-.46-2.38-1.48c-.88-.79-1.47-1.77-1.64-2.07c-.17-.3-.02-.47.13-.62c.13-.13.3-.34.44-.51c.15-.17.2-.3.3-.5c.1-.2.05-.37-.02-.52c-.07-.15-.66-1.6-.9-2.19c-.24-.58-.48-.5-.66-.5h-.56c-.2 0-.52.07-.8.37c-.27.3-1.04 1.02-1.04 2.48s1.07 2.87 1.22 3.07c.15.2 2.1 3.2 5.08 4.49c.71.31 1.27.49 1.7.62c.72.23 1.37.2 1.89.12c.58-.09 1.77-.72 2.02-1.42c.25-.7.25-1.29.17-1.42c-.07-.12-.27-.2-.57-.35Z'/></svg>") !important;
}
@media(max-width:980px){
  .footer-grid-clean{
    grid-template-columns:1fr !important;
    gap:24px !important;
  }
}
@media(max-width:640px){
  .footer-links-clean a{
    width:auto;
  }
  .footer-bottom{
    gap:10px !important;
  }
  .whatsapp-float{
    width:56px !important;
    height:56px !important;
    right:16px !important;
    bottom:16px !important;
    left:auto !important;
  }
  .whatsapp-float::before{
    width:28px !important;
    height:28px !important;
  }
}


/* v41 - contactos, galería descriptiva y conversión */
.contact-icons,
.social-icons{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
}
.icon-link{
  width:44px;
  height:44px;
  border-radius:50%;
  display:grid;
  place-items:center;
  color:var(--ink);
  background:#fff;
  border:1px solid var(--line);
  box-shadow:var(--shadow-soft);
  transition:.2s ease;
}
.icon-link:hover{
  transform:translateY(-2px);
  border-color:rgba(0,135,128,.28);
  color:var(--accent);
}
.icon-link img,
.icon-link svg{
  width:21px;
  height:21px;
  display:block;
}
.icon-link.whatsapp{
  background:#16b956;
  color:#fff;
  border-color:#16b956;
}
.icon-link.whatsapp:hover{
  color:#fff;
  filter:brightness(.96);
}
.contact-mini-card{
  display:flex;
  gap:14px;
  align-items:flex-start;
  padding:16px;
  border:1px solid var(--line);
  border-radius:20px;
  background:#fff;
  box-shadow:var(--shadow-soft);
}
.contact-mini-card .icon-link{
  flex:0 0 44px;
}
.contact-mini-card strong{
  display:block;
  margin-bottom:4px;
}
.contact-mini-card p{
  margin:0;
  color:var(--muted);
  font-size:14px;
}
.gallery-caption{
  position:absolute;
  left:12px;
  right:12px;
  bottom:12px;
  padding:12px 13px;
  border-radius:16px;
  background:linear-gradient(180deg, rgba(15,15,15,.15), rgba(15,15,15,.74));
  color:#fff;
  opacity:0;
  transform:translateY(8px);
  transition:.24s ease;
  pointer-events:none;
}
.photo-card:hover .gallery-caption,
.thumb:hover .gallery-caption,
.project-feature-img:hover .gallery-caption,
.home-triptych-panel:hover .gallery-caption,
.services-premium-image:hover .gallery-caption{
  opacity:1;
  transform:translateY(0);
}
.gallery-caption strong{
  display:block;
  font-size:14px;
  line-height:1.2;
}
.gallery-caption span{
  display:block;
  margin-top:3px;
  font-size:12px;
  color:rgba(255,255,255,.82);
  line-height:1.35;
}
.gallery-helper{
  display:flex;
  justify-content:space-between;
  gap:16px;
  align-items:flex-end;
  margin-bottom:22px;
}
.gallery-helper p{
  max-width:680px;
  color:var(--muted);
  margin:0;
}
.thankyou-card{
  max-width:820px;
  margin:0 auto;
  text-align:center;
  border:1px solid var(--line);
  background:#fff;
  border-radius:34px;
  padding:56px 34px;
  box-shadow:var(--shadow-soft);
}
.thankyou-icon{
  width:72px;
  height:72px;
  margin:0 auto 22px;
  display:grid;
  place-items:center;
  border-radius:50%;
  background:rgba(0,135,128,.10);
  color:var(--accent);
  font-size:34px;
  font-weight:900;
}
.thankyou-card h1{
  margin-bottom:14px;
}
.thankyou-card p{
  color:var(--muted);
  max-width:620px;
  margin:0 auto 24px;
}
.thankyou-actions{
  display:flex;
  justify-content:center;
  gap:12px;
  flex-wrap:wrap;
}
.admin-demo-panel{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:24px;
}
.admin-box{
  background:#fff;
  border:1px solid var(--line);
  border-radius:28px;
  padding:26px;
  box-shadow:var(--shadow-soft);
}
.admin-box textarea,
.admin-box input,
.admin-box select{
  width:100%;
  border:1px solid var(--line);
  border-radius:14px;
  padding:12px;
  margin-top:8px;
  margin-bottom:14px;
  font-family:inherit;
}
.admin-box textarea{
  min-height:120px;
  resize:vertical;
}
.admin-note{
  padding:14px 16px;
  border-radius:18px;
  background:rgba(0,135,128,.08);
  color:var(--muted);
  font-size:14px;
}
@media(max-width:780px){
  .gallery-caption{
    opacity:1;
    transform:none;
    left:10px;
    right:10px;
    bottom:10px;
    padding:10px 11px;
  }
  .gallery-helper{
    display:block;
  }
  .admin-demo-panel{
    grid-template-columns:1fr;
  }
  .thankyou-card{
    padding:38px 22px;
    border-radius:26px;
  }
}


/* v42 - redes sociales oficiales */
.social-title{
  margin-top:18px;
  margin-bottom:10px;
  font-size:13px;
  font-weight:850;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(255,255,255,.62);
}
.footer .social-title{
  color:rgba(255,255,255,.62);
}
.contact-social-box{
  margin-top:22px;
  padding:20px;
  border:1px solid var(--line);
  border-radius:24px;
  background:#fff;
  box-shadow:var(--shadow-soft);
}
.contact-social-box h3{
  margin-bottom:8px;
}
.contact-social-box p{
  margin-top:0;
  color:var(--muted);
}
.icon-link.instagram:hover{
  color:#c13584;
  border-color:rgba(193,53,132,.35);
}
.icon-link.facebook:hover{
  color:#1877f2;
  border-color:rgba(24,119,242,.35);
}
.footer .icon-link{
  background:rgba(255,255,255,.08);
  border-color:rgba(255,255,255,.12);
  color:#fff;
  box-shadow:none;
}
.footer .icon-link:hover{
  background:rgba(255,255,255,.14);
}


/* v43 - Contacto simple, sin fotos ni repeticiones */
.simple-contact{
  padding:54px 0 42px;
}
.simple-contact-grid{
  display:grid;
  grid-template-columns:.92fr 1.08fr;
  gap:26px;
  align-items:start;
}
.simple-contact-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:30px;
  padding:32px;
  box-shadow:var(--shadow-soft);
}
.simple-contact-card h1{
  font-size:clamp(38px,5vw,62px);
  margin-bottom:14px;
}
.simple-contact-card .lead{
  font-size:17px;
  max-width:620px;
}
.simple-contact-list{
  display:grid;
  gap:12px;
  margin-top:24px;
}
.simple-contact-item{
  display:flex;
  gap:14px;
  align-items:flex-start;
  padding:16px;
  border:1px solid var(--line);
  border-radius:20px;
  background:#f8f5ef;
}
.simple-contact-item .icon-link{
  flex:0 0 42px;
  width:42px;
  height:42px;
  box-shadow:none;
}
.simple-contact-item strong{
  display:block;
  margin-bottom:3px;
}
.simple-contact-item p{
  margin:0;
  color:var(--muted);
  font-size:14px;
}
.simple-contact-item a.text-link{
  font-weight:850;
}
.simple-contact-form{
  background:#fff;
  border:1px solid var(--line);
  border-radius:30px;
  padding:32px;
  box-shadow:var(--shadow-soft);
}
.simple-contact-form h2{
  font-size:clamp(28px,3vw,40px);
}
.simple-contact-form .form-grid{
  grid-template-columns:1fr 1fr;
}
.simple-contact-form .field.full{
  grid-column:1 / -1;
}
.simple-contact-note{
  margin-top:14px;
  padding:14px 16px;
  border-radius:18px;
  background:rgba(0,135,128,.08);
  color:var(--muted);
  font-size:13px;
}
.simple-social{
  margin-top:22px;
  padding-top:18px;
  border-top:1px solid var(--line);
}
.simple-social h3{
  font-size:16px;
  margin-bottom:10px;
}
.simple-contact-map{
  margin-top:22px;
  padding:20px;
  border:1px solid var(--line);
  border-radius:24px;
  background:#fff;
  box-shadow:var(--shadow-soft);
}
.simple-contact-map h2{
  font-size:26px;
  margin-bottom:8px;
}
.simple-contact-map p{
  color:var(--muted);
}
.simple-contact-map .hero-actions{
  margin-top:16px;
}
@media(max-width:920px){
  .simple-contact-grid{
    grid-template-columns:1fr;
  }
}
@media(max-width:640px){
  .simple-contact{
    padding:30px 0 26px;
  }
  .simple-contact-card,
  .simple-contact-form,
  .simple-contact-map{
    border-radius:24px;
    padding:22px;
  }
  .simple-contact-form .form-grid{
    grid-template-columns:1fr;
  }
  .simple-contact-item{
    padding:14px;
  }
}


/* v44 - pulido visual final general */
:root{
  --radius-soft:24px;
  --radius-card:28px;
  --shadow-final:0 18px 44px rgba(23,23,23,.075);
}
html{
  scroll-behavior:smooth;
}
body{
  text-rendering:optimizeLegibility;
}
.container{
  max-width:1240px;
}
.section{
  padding:72px 0;
}
.section-tight{
  padding:50px 0;
}
h1{
  max-width:920px;
}
h2{
  max-width:860px;
}
.center h1,
.center h2,
.center .lead{
  margin-left:auto;
  margin-right:auto;
}
.lead{
  line-height:1.62;
}
.btn{
  border-radius:10px !important;
  letter-spacing:.01em;
}
.btn-accent,
.btn-dark{
  box-shadow:0 14px 32px rgba(0,126,120,.12);
}
.btn:hover{
  transform:translateY(-1px);
}
.photo-card,
.card,
.service-pillar,
.portfolio-card,
.local-service-card,
.simple-contact-card,
.simple-contact-form,
.simple-contact-map,
.company-story-card,
.value-card,
capability-card,
.client-category-card,
.project-consult-card,
.process-detail-card,
.timeline-card{
  box-shadow:var(--shadow-final);
}
.card,
.service-pillar,
.portfolio-card,
.local-service-card,
.simple-contact-card,
.simple-contact-form,
.simple-contact-map{
  border-radius:var(--radius-card);
}
.eyebrow{
  letter-spacing:.16em !important;
  font-size:11px !important;
}
.badge{
  letter-spacing:.06em;
}
.header{
  border-bottom:1px solid rgba(23,23,23,.08) !important;
}
.nav{
  max-width:1240px !important;
}
.nav-links a{
  white-space:nowrap;
}
.nav-actions .btn-dark{
  border-radius:10px !important;
}
.home-cover .btn{
  border-radius:10px !important;
}
.home-cover h1{
  max-width:560px !important;
}
.home-cover .lead{
  max-width:460px !important;
}
.home-triptych-panel{
  border-radius:10px !important;
}
.gallery-caption{
  border-radius:14px;
  background:linear-gradient(180deg,rgba(20,20,20,.20),rgba(20,20,20,.78));
}
.footer{
  padding:46px 0 24px !important;
}
.footer-grid-clean{
  grid-template-columns:1.22fr .72fr .9fr !important;
}
.footer p,
.footer a{
  font-size:14px;
  line-height:1.55;
}
.footer-links-clean{
  gap:8px !important;
}
.footer .contact-icons,
.footer .social-icons{
  margin-top:12px;
}
.footer .icon-link{
  width:38px;
  height:38px;
}
.footer .icon-link svg{
  width:18px;
  height:18px;
}
.footer-bottom{
  font-size:13px;
}
.simple-contact{
  padding:48px 0 38px !important;
}
.simple-contact-grid{
  gap:22px !important;
}
.simple-contact-card h1{
  font-size:clamp(34px,4.5vw,56px) !important;
}
.simple-contact-form h2{
  font-size:clamp(26px,2.8vw,36px) !important;
}
.simple-contact-item{
  background:#faf7f1;
}
.simple-contact-note{
  font-size:13px;
}
.local-hero-copy h1,
.services-premium-copy h1,
.process-hero-copy h1,
.company-hero h1,
.clients-hero h1,
.portfolio-hero h1{
  font-size:clamp(36px,4.6vw,62px);
  line-height:1.04;
}
.service-pillar h3,
.project-feature-content h2{
  font-size:clamp(24px,2.6vw,38px);
}
.portfolio-index-card h3{
  font-size:22px;
}
.cookie-banner{
  max-width:780px;
  border-radius:18px;
}
.whatsapp-float{
  width:56px !important;
  height:56px !important;
  right:22px !important;
  bottom:22px !important;
  display:grid !important;
  place-items:center !important;
  padding:0 !important;
  border-radius:50% !important;
  font-size:0 !important;
  line-height:0 !important;
  text-indent:0 !important;
  overflow:hidden !important;
}
.whatsapp-float::before{
  width:29px !important;
  height:29px !important;
  position:absolute !important;
  inset:0 !important;
  margin:auto !important;
  display:block !important;
  transform:none !important;
  background-position:center center !important;
  background-size:contain !important;
}

/* v44 - ajuste mobile */
@media(max-width:980px){
  .container{
    padding-left:20px;
    padding-right:20px;
  }
  .section{
    padding:56px 0;
  }
  .section-tight{
    padding:40px 0;
  }
  .nav{
    min-height:72px !important;
  }
  .nav-links{
    max-height:calc(100vh - 98px);
    overflow:auto;
  }
  .footer-grid-clean{
    grid-template-columns:1fr !important;
    gap:22px !important;
  }
  .footer-links-clean{
    grid-template-columns:1fr 1fr !important;
    gap:8px 18px !important;
  }
  .footer-links-clean a{
    width:auto !important;
  }
}
@media(max-width:640px){
  .container{
    padding-left:16px;
    padding-right:16px;
  }
  .section{
    padding:42px 0;
  }
  .section-tight{
    padding:32px 0;
  }
  h1{
    font-size:clamp(32px,10vw,42px) !important;
    line-height:1.06 !important;
    letter-spacing:-.045em !important;
  }
  h2{
    font-size:clamp(28px,8vw,36px) !important;
    line-height:1.08 !important;
  }
  .lead{
    font-size:15px !important;
    line-height:1.55 !important;
  }
  .btn{
    min-height:46px !important;
    font-size:13px !important;
    padding:11px 16px !important;
  }
  .hero-actions{
    gap:9px !important;
  }
  .brand img{
    width:108px !important;
  }
  .home-cover{
    padding-top:24px !important;
  }
  .home-cover h1{
    font-size:34px !important;
  }
  .home-triptych-panel{
    height:230px !important;
  }
  .simple-contact-card,
  .simple-contact-form,
  .simple-contact-map{
    padding:20px !important;
  }
  .simple-contact-list{
    gap:10px;
  }
  .simple-contact-item{
    border-radius:18px;
  }
  .footer{
    padding:36px 0 22px !important;
  }
  .footer-links-clean{
    grid-template-columns:1fr !important;
  }
  .footer-bottom{
    flex-direction:column;
    align-items:flex-start;
  }
  .whatsapp-float{
    width:54px !important;
    height:54px !important;
    right:15px !important;
    bottom:15px !important;
    left:auto !important;
  }
  .whatsapp-float::before{
    width:27px !important;
    height:27px !important;
  }
}


/* v45 - unificación tipográfica premium
   Objetivo: que las páginas internas no se vean grandes/pesadas como landing genérica.
   Se alinean con la portada: títulos serif, finos, elegantes y más controlados. */

:root{
  --display-serif: Georgia, "Times New Roman", serif;
}

/* Títulos principales generales */
main h1{
  font-family:var(--display-serif) !important;
  font-weight:500 !important;
  letter-spacing:-.052em !important;
  line-height:1.08 !important;
  color:#191918;
}

/* Bajada general para que no compita con el título */
main .lead,
main .section-lead,
main .muted{
  line-height:1.62;
}

/* Heroes internos: mismo estilo visual que Inicio */
.services-premium-copy h1,
.local-hero-copy h1,
.process-hero-copy h1,
.company-hero h1,
.clients-hero h1,
.portfolio-hero h1,
.quote-contact-copy h1,
.simple-contact-card h1,
.thankyou-card h1,
.hero h1,
.service-hero h1,
.ads-hero h1{
  font-family:var(--display-serif) !important;
  font-size:clamp(38px,3.8vw,58px) !important;
  font-weight:500 !important;
  line-height:1.08 !important;
  letter-spacing:-.052em !important;
  max-width:680px !important;
}

/* Páginas comerciales/SEO: evitar títulos gigantes */
.local-hero-copy h1,
.service-hero h1,
.ads-hero h1{
  font-size:clamp(36px,3.6vw,54px) !important;
  max-width:720px !important;
}

/* Servicios estaba muy pesado: lo dejamos más fino */
.services-premium-copy h1{
  font-size:clamp(38px,3.55vw,56px) !important;
  max-width:640px !important;
}

/* Trabajos/Empresa/Clientes */
.portfolio-hero h1,
.company-hero h1,
.clients-hero h1{
  font-size:clamp(38px,3.65vw,56px) !important;
}

/* Contacto simple también con el mismo tono */
.simple-contact-card h1{
  font-size:clamp(36px,3.7vw,54px) !important;
}

/* H2 con personalidad, pero sin exagerar */
main h2{
  font-family:Inter, Arial, sans-serif;
  font-size:clamp(28px,3.2vw,44px) !important;
  line-height:1.12 !important;
  letter-spacing:-.04em !important;
  font-weight:820 !important;
}

/* Cards internas: menos aire y menos bloque visual */
.services-premium-copy,
.local-hero-copy,
.company-story-card,
.simple-contact-card,
.simple-contact-form,
.simple-contact-map{
  padding:38px !important;
}

/* Ajustar imágenes hero para que no dominen tanto */
.services-premium-image,
.local-hero-image,
.portfolio-hero .photo-card,
.company-hero .photo-card{
  min-height:390px !important;
  border-radius:24px !important;
}

/* Página de servicios: equilibrio entre texto e imagen */
.services-premium-grid{
  grid-template-columns:.98fr 1.02fr !important;
  gap:30px !important;
  align-items:center !important;
}

/* Página de trabajos y empresa */
.portfolio-hero-grid,
.company-hero-grid{
  gap:30px !important;
  align-items:center !important;
}

/* Evitar títulos de tarjetas demasiado grandes */
.service-pillar h3,
.service-link-card h3,
.local-service-card h3,
.portfolio-index-card h3,
.card h3,
.value-card h3,
.client-category-card h3{
  font-family:Inter, Arial, sans-serif !important;
  font-size:clamp(20px,2vw,26px) !important;
  line-height:1.15 !important;
  letter-spacing:-.025em !important;
  font-weight:820 !important;
}

/* Textos de tarjetas más compactos */
.service-pillar p,
.service-link-card p,
.local-service-card p,
.portfolio-index-card p,
.card p{
  font-size:14.5px;
  line-height:1.58;
}

/* Overline más elegante y consistente */
.eyebrow,
.section-kicker,
.home-cover .eyebrow{
  font-size:11px !important;
  letter-spacing:.16em !important;
  font-weight:850 !important;
}

/* Botones coherentes con la portada */
main .btn{
  border-radius:10px !important;
  font-size:13px !important;
  min-height:46px !important;
  padding:11px 18px !important;
}

/* Home queda como referencia, no la hacemos más grande */
.home-cover h1{
  font-family:var(--display-serif) !important;
  font-weight:500 !important;
}

/* Mobile: evitar títulos enormes en todas las páginas */
@media(max-width:980px){
  .services-premium-grid,
  .local-hero-grid,
  .portfolio-hero-grid,
  .company-hero-grid{
    grid-template-columns:1fr !important;
  }

  .services-premium-copy h1,
  .local-hero-copy h1,
  .process-hero-copy h1,
  .company-hero h1,
  .clients-hero h1,
  .portfolio-hero h1,
  .quote-contact-copy h1,
  .simple-contact-card h1,
  .thankyou-card h1,
  .hero h1,
  .service-hero h1,
  .ads-hero h1{
    font-size:clamp(34px,6vw,46px) !important;
    max-width:760px !important;
  }

  .services-premium-image,
  .local-hero-image,
  .portfolio-hero .photo-card,
  .company-hero .photo-card{
    min-height:320px !important;
  }
}

@media(max-width:640px){
  main h1,
  .services-premium-copy h1,
  .local-hero-copy h1,
  .process-hero-copy h1,
  .company-hero h1,
  .clients-hero h1,
  .portfolio-hero h1,
  .quote-contact-copy h1,
  .simple-contact-card h1,
  .thankyou-card h1,
  .hero h1,
  .service-hero h1,
  .ads-hero h1{
    font-size:34px !important;
    line-height:1.1 !important;
    letter-spacing:-.045em !important;
  }

  main h2{
    font-size:28px !important;
    line-height:1.12 !important;
  }

  .services-premium-copy,
  .local-hero-copy,
  .company-story-card,
  .simple-contact-card,
  .simple-contact-form,
  .simple-contact-map{
    padding:20px !important;
    border-radius:22px !important;
  }

  .services-premium-image,
  .local-hero-image,
  .portfolio-hero .photo-card,
  .company-hero .photo-card{
    min-height:245px !important;
    border-radius:18px !important;
  }

  .service-pillar h3,
  .service-link-card h3,
  .local-service-card h3,
  .portfolio-index-card h3,
  .card h3,
  .value-card h3,
  .client-category-card h3{
    font-size:21px !important;
  }
}


/* v46 - Corian® más fino y proporcionado */
.corian-hero,
.material-hero,
.corian-page .hero,
body.corian .hero{
  padding-top:64px !important;
  padding-bottom:54px !important;
}

.corian-hero h1,
.material-hero h1,
.corian-page h1,
body.corian main h1,
main .center h1{
  font-size:clamp(38px,4.2vw,58px) !important;
  line-height:1.08 !important;
  letter-spacing:-.052em !important;
  max-width:780px !important;
  margin-left:auto !important;
  margin-right:auto !important;
}

.corian-hero .lead,
.material-hero .lead,
.corian-page .lead,
body.corian main .lead,
main .center .lead{
  max-width:720px !important;
  font-size:17px !important;
  line-height:1.62 !important;
  margin-left:auto !important;
  margin-right:auto !important;
}

.corian-hero .section-kicker,
.material-hero .section-kicker,
.corian-page .section-kicker,
body.corian .section-kicker,
main .center .section-kicker{
  margin-bottom:18px !important;
}

@media(max-width:980px){
  .corian-hero,
  .material-hero,
  .corian-page .hero,
  body.corian .hero{
    padding-top:48px !important;
    padding-bottom:42px !important;
  }

  .corian-hero h1,
  .material-hero h1,
  .corian-page h1,
  body.corian main h1,
  main .center h1{
    font-size:clamp(34px,6vw,46px) !important;
    max-width:680px !important;
  }
}

@media(max-width:640px){
  .corian-hero,
  .material-hero,
  .corian-page .hero,
  body.corian .hero{
    padding-top:34px !important;
    padding-bottom:30px !important;
  }

  .corian-hero h1,
  .material-hero h1,
  .corian-page h1,
  body.corian main h1,
  main .center h1{
    font-size:34px !important;
    line-height:1.1 !important;
  }

  .corian-hero .lead,
  .material-hero .lead,
  .corian-page .lead,
  body.corian main .lead,
  main .center .lead{
    font-size:15px !important;
  }
}


/* v47 - textos profesionales y conversión */
.home-trust-row{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:10px;
  margin-top:24px;
  max-width:540px;
}
.home-trust-item{
  border-top:1px solid var(--line);
  padding-top:12px;
}
.home-trust-item strong{
  display:block;
  font-size:14px;
  color:#151515;
  line-height:1.2;
}
.home-trust-item span{
  display:block;
  margin-top:3px;
  font-size:12.5px;
  color:var(--muted);
  line-height:1.35;
}
.quote-helper-row{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:16px;
}
.quote-helper-row span{
  display:inline-flex;
  align-items:center;
  min-height:30px;
  padding:7px 11px;
  border:1px solid rgba(0,135,128,.18);
  border-radius:999px;
  background:rgba(0,135,128,.065);
  color:#006f69;
  font-size:12px;
  font-weight:780;
}
.conversion-note{
  margin-top:18px;
  padding:14px 16px;
  border-radius:18px;
  background:#faf7f1;
  border:1px solid var(--line);
  color:var(--muted);
  font-size:13.5px;
  line-height:1.55;
}
.conversion-note strong{
  color:#151515;
}
.cta-slim{
  margin-top:22px;
  padding:20px;
  border:1px solid var(--line);
  border-radius:24px;
  background:#fff;
  box-shadow:var(--shadow-final, 0 18px 44px rgba(23,23,23,.075));
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
}
.cta-slim h2{
  font-size:clamp(24px,2.4vw,34px) !important;
  margin-bottom:4px;
}
.cta-slim p{
  margin:0;
  color:var(--muted);
}
.cta-slim .btn{
  flex:0 0 auto;
}
.copy-tight p{
  max-width:760px;
}
.form-helper{
  margin-top:10px;
  font-size:12.5px;
  color:var(--muted);
}
@media(max-width:760px){
  .home-trust-row{
    grid-template-columns:repeat(2,1fr);
    margin-top:18px;
  }
  .cta-slim{
    align-items:flex-start;
    flex-direction:column;
  }
}
@media(max-width:520px){
  .home-trust-row{
    grid-template-columns:1fr;
  }
  .home-trust-item{
    padding-top:9px;
  }
  .quote-helper-row{
    gap:7px;
  }
  .quote-helper-row span{
    font-size:11.5px;
  }
}


/* v48 - WhatsApp unificado y prolijo */
.btn.btn-whatsapp,
.btn.btn-whatsapp.btn-outline,
.btn.btn-whatsapp.btn-dark{
  background:var(--accent) !important;
  color:#fff !important;
  border-color:var(--accent) !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:10px !important;
  min-height:46px;
  padding:0 22px !important;
  box-shadow:0 12px 26px rgba(0,135,128,.18);
}
.btn.btn-whatsapp:hover,
.btn.btn-whatsapp.btn-outline:hover,
.btn.btn-whatsapp.btn-dark:hover{
  background:#007a74 !important;
  border-color:#007a74 !important;
  color:#fff !important;
  transform:translateY(-1px);
}
.btn.btn-whatsapp::before{
  width:18px !important;
  height:18px !important;
  flex:0 0 18px !important;
  background-size:contain !important;
  background-position:center !important;
}
.hero-actions .btn.btn-whatsapp{
  min-width:230px;
}
.simple-contact-item.simple-contact-whatsapp{
  background:#f4fbf8;
  border-color:rgba(0,135,128,.18);
  align-items:center;
}
.simple-contact-item.simple-contact-whatsapp .icon-link.whatsapp{
  width:48px;
  height:48px;
  flex:0 0 48px;
}
.simple-contact-item.simple-contact-whatsapp .icon-link.whatsapp svg{
  width:22px;
  height:22px;
}
.simple-contact-item .meta-line{
  margin-top:4px;
  font-size:12.5px;
  color:var(--muted);
}
.simple-contact-item .phone-link{
  font-size:18px;
  line-height:1.2;
  font-weight:850;
  color:#151515;
}
.simple-contact-item .phone-link:hover{
  color:var(--accent);
}
@media(max-width:760px){
  .hero-actions .btn.btn-whatsapp{
    min-width:unset;
    width:100%;
  }
}


/* v49 - formulario inteligente a WhatsApp */
.form-whatsapp-hint{
  margin-top:14px;
  padding:12px 14px;
  border-radius:16px;
  background:rgba(0,135,128,.07);
  border:1px solid rgba(0,135,128,.16);
  color:#31514e;
  font-size:13px;
  line-height:1.45;
}
.form-whatsapp-hint strong{
  color:#007f78;
}
.form-submit-row{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
  margin-top:4px;
}
.form-submit-row .btn{
  flex:0 0 auto;
}
.form-submit-note{
  color:var(--muted);
  font-size:12.5px;
  line-height:1.4;
}
input:focus,
textarea:focus,
select:focus{
  border-color:rgba(0,135,128,.45);
  box-shadow:0 0 0 4px rgba(0,135,128,.08);
  background:#fff;
}
.form-success-soft{
  margin-top:12px;
  padding:12px 14px;
  border-radius:16px;
  border:1px solid rgba(22,185,86,.18);
  background:rgba(22,185,86,.08);
  color:#1d5f39;
  font-size:13px;
  line-height:1.45;
  display:none;
}
.form-success-soft.is-visible{
  display:block;
}
@media(max-width:640px){
  .form-submit-row{
    display:grid;
    grid-template-columns:1fr;
  }
  .form-submit-row .btn{
    width:100%;
  }
}


/* v50 - centro de conversión y presupuesto */
.quote-hero{
  padding:56px 0 42px;
}
.quote-hero-grid{
  display:grid;
  grid-template-columns:.95fr 1.05fr;
  gap:30px;
  align-items:start;
}
.quote-hero-copy{
  padding:38px 0;
}
.quote-hero-copy h1{
  font-family:var(--display-serif, Georgia, "Times New Roman", serif) !important;
  font-size:clamp(38px,3.8vw,58px) !important;
  font-weight:500 !important;
  letter-spacing:-.052em !important;
  line-height:1.08 !important;
  max-width:720px;
}
.quote-steps{
  display:grid;
  grid-template-columns:1fr;
  gap:10px;
  margin-top:24px;
  max-width:620px;
}
.quote-steps div{
  display:grid;
  grid-template-columns:34px 1fr;
  column-gap:12px;
  align-items:start;
  padding:14px 0;
  border-top:1px solid var(--line);
}
.quote-steps span{
  display:grid;
  place-items:center;
  width:30px;
  height:30px;
  border-radius:999px;
  background:rgba(0,135,128,.1);
  color:var(--accent);
  font-weight:900;
  font-size:13px;
}
.quote-steps strong{
  display:block;
  color:#151515;
  font-size:15px;
}
.quote-steps p{
  grid-column:2;
  margin:4px 0 0;
  color:var(--muted);
  line-height:1.55;
  font-size:13.5px;
}
.budget-form-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:28px;
  padding:34px;
  box-shadow:0 22px 60px rgba(23,23,23,.085);
}
.budget-form-card h2{
  margin-bottom:8px;
}
.budget-helper-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:20px;
}
.budget-helper-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:26px;
  padding:28px;
}
.budget-helper-card h2{
  font-size:clamp(24px,2.5vw,34px) !important;
  margin-bottom:12px;
}
.clean-list{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:10px;
}
.clean-list li{
  position:relative;
  padding-left:20px;
  color:var(--muted);
  line-height:1.55;
}
.clean-list li::before{
  content:"";
  position:absolute;
  left:0;
  top:.62em;
  width:7px;
  height:7px;
  border-radius:999px;
  background:var(--accent);
}
.thanks-next-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
  margin-top:24px;
}
.thanks-next-card{
  border:1px solid var(--line);
  border-radius:20px;
  padding:18px;
  background:#fff;
}
.thanks-next-card strong{
  display:block;
  color:#151515;
  margin-bottom:5px;
}
.thanks-next-card span{
  display:block;
  color:var(--muted);
  font-size:13px;
  line-height:1.45;
}
@media(max-width:980px){
  .quote-hero-grid,
  .budget-helper-grid{
    grid-template-columns:1fr;
  }
  .quote-hero-copy{
    padding:20px 0 0;
  }
}
@media(max-width:640px){
  .quote-hero{
    padding:30px 0 22px;
  }
  .budget-form-card,
  .budget-helper-card{
    padding:20px;
    border-radius:22px;
  }
  .quote-hero-copy h1{
    font-size:34px !important;
  }
  .thanks-next-grid{
    grid-template-columns:1fr;
  }
}


/* v52 - profesional total: home, galería y preparación publicación */
.home-proof-strip{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1px;
  border:1px solid var(--line);
  border-radius:24px;
  overflow:hidden;
  background:var(--line);
  margin-top:28px;
}
.home-proof-strip .proof-item{
  background:#fff;
  padding:18px 16px;
}
.home-proof-strip strong{
  display:block;
  color:#151515;
  font-size:20px;
  letter-spacing:-.03em;
  margin-bottom:3px;
}
.home-proof-strip span{
  color:var(--muted);
  font-size:12.5px;
  line-height:1.35;
}
.home-mini-services{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;
  margin-top:28px;
}
.home-mini-service{
  border:1px solid var(--line);
  border-radius:20px;
  padding:18px;
  background:rgba(255,255,255,.72);
  text-decoration:none;
  color:inherit;
  transition:transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.home-mini-service:hover{
  transform:translateY(-2px);
  border-color:rgba(0,135,128,.28);
  box-shadow:0 18px 42px rgba(23,23,23,.075);
}
.home-mini-service strong{
  display:block;
  font-size:15px;
  margin-bottom:5px;
  color:#151515;
}
.home-mini-service span{
  color:var(--muted);
  font-size:12.5px;
  line-height:1.4;
}
.home-final-cta{
  margin-top:34px;
  padding:28px;
  border:1px solid rgba(0,135,128,.18);
  border-radius:28px;
  background:linear-gradient(135deg, rgba(0,135,128,.08), rgba(255,255,255,.92));
  display:grid;
  grid-template-columns:1fr auto;
  gap:20px;
  align-items:center;
}
.home-final-cta h2{
  font-size:clamp(26px,3vw,40px) !important;
  line-height:1.08 !important;
  margin:0 0 8px !important;
}
.home-final-cta p{
  color:var(--muted);
  margin:0;
  max-width:720px;
}
.premium-gallery-intro{
  display:flex;
  align-items:end;
  justify-content:space-between;
  gap:20px;
  margin-bottom:22px;
}
.premium-gallery-intro p{
  color:var(--muted);
  max-width:680px;
  margin:0;
}
.gallery-premium-grid,
.work-gallery,
.gallery-grid{
  align-items:stretch;
}
.gallery-card,
.work-card,
.project-card{
  position:relative;
  overflow:hidden;
}
.gallery-card img,
.work-card img,
.project-card img{
  transition:transform .35s ease, filter .35s ease;
}
.gallery-card:hover img,
.work-card:hover img,
.project-card:hover img{
  transform:scale(1.035);
  filter:saturate(1.04) contrast(1.03);
}
.gallery-card::after,
.work-card::after,
.project-card::after{
  content:"Ver imagen";
  position:absolute;
  left:14px;
  bottom:14px;
  padding:9px 12px;
  border-radius:999px;
  background:rgba(0,0,0,.72);
  color:#fff;
  font-size:12px;
  font-weight:800;
  opacity:0;
  transform:translateY(8px);
  transition:opacity .22s ease, transform .22s ease;
  pointer-events:none;
}
.gallery-card:hover::after,
.work-card:hover::after,
.project-card:hover::after{
  opacity:1;
  transform:translateY(0);
}
.work-filter-bar{
  position:sticky;
  top:78px;
  z-index:20;
  background:rgba(250,248,244,.94);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.work-filter-bar .container{
  overflow-x:auto;
  scrollbar-width:none;
}
.work-filter-bar .container::-webkit-scrollbar{
  display:none;
}
.publish-checklist{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
  margin-top:24px;
}
.publish-check{
  border:1px solid var(--line);
  border-radius:20px;
  background:#fff;
  padding:18px;
}
.publish-check strong{
  display:block;
  margin-bottom:6px;
  color:#151515;
}
.publish-check span{
  display:block;
  color:var(--muted);
  font-size:13px;
  line-height:1.45;
}
@media(max-width:980px){
  .home-proof-strip,
  .home-mini-services,
  .publish-checklist{
    grid-template-columns:repeat(2,1fr);
  }
  .home-final-cta{
    grid-template-columns:1fr;
  }
}
@media(max-width:640px){
  .home-proof-strip,
  .home-mini-services,
  .publish-checklist{
    grid-template-columns:1fr;
  }
  .home-proof-strip{
    border-radius:20px;
  }
  .home-final-cta{
    padding:20px;
    border-radius:22px;
  }
  .premium-gallery-intro{
    display:block;
  }
  .work-filter-bar{
    top:66px;
  }
}


/* v54 - corrección del header y menú mobile */
.header,
.nav{
  overflow:visible !important;
}

@media (max-width: 980px){
  .nav{
    position:relative !important;
    align-items:center !important;
    gap:12px !important;
  }
  .brand{
    min-width:0 !important;
    flex:1 1 auto !important;
    max-width:calc(100% - 56px) !important;
    gap:10px !important;
  }
  .brand > div{
    min-width:0 !important;
    flex:1 1 auto !important;
  }
  .brand-sub{
    max-width:none !important;
    white-space:normal !important;
    overflow-wrap:anywhere !important;
    line-height:1.42 !important;
  }
  .menu-btn{
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    flex:0 0 44px !important;
    margin-left:auto !important;
    position:relative !important;
    z-index:130 !important;
  }
  .nav-links{
    position:absolute !important;
    left:0 !important;
    right:0 !important;
    top:calc(100% + 8px) !important;
    display:none;
    max-height:min(70vh, 520px) !important;
    overflow:auto !important;
    overscroll-behavior:contain;
    border-radius:22px !important;
    padding:18px !important;
    box-shadow:0 20px 50px rgba(23,23,23,.14) !important;
    z-index:120 !important;
  }
  .nav-links.open{
    display:flex !important;
  }
}

@media (max-width: 640px){
  .nav{
    padding:10px 14px !important;
    min-height:72px !important;
  }
  .brand{
    max-width:calc(100% - 54px) !important;
  }
  .brand img{
    width:92px !important;
    max-height:none !important;
    height:auto !important;
  }
  .brand-sub{
    font-size:8px !important;
    letter-spacing:.14em !important;
  }
  .nav-links{
    left:2px !important;
    right:2px !important;
    top:calc(100% + 6px) !important;
    border-radius:18px !important;
    padding:16px !important;
  }
}

@media (max-width: 420px){
  .brand img{
    width:84px !important;
  }
  .brand-sub{
    font-size:7px !important;
    letter-spacing:.12em !important;
  }
}


/* v55 - botón hamburguesa mobile con 3 líneas bien apiladas */
.menu-btn{
  flex-direction:column !important;
  gap:4px !important;
}
.menu-btn span{
  display:block !important;
  width:18px !important;
  height:2px !important;
  margin:0 !important;
  border-radius:999px !important;
  background:var(--ink) !important;
  flex:0 0 2px !important;
}
@media (max-width: 980px){
  .menu-btn{
    width:46px !important;
    height:46px !important;
  }
}


/* v60 - crédito de desarrollo */
.footer-credit{
  margin-top:10px;
  color:rgba(255,255,255,.58);
  font-size:12px;
  line-height:1.4;
}
.footer-credit a{
  color:rgba(255,255,255,.82);
  text-decoration:none;
  font-weight:800;
}
.footer-credit a:hover{
  color:#fff;
  text-decoration:underline;
}
@media(max-width:640px){
  .footer-credit{
    text-align:left;
    font-size:11.5px;
  }
}



/* v61 - política de privacidad limpia */
.privacy-clean{
  padding:42px 0 54px;
}
.privacy-clean-wrap{
  max-width:1040px;
  margin:0 auto;
  padding:0 22px;
}
.privacy-hero-clean{
  background:#fff;
  border:1px solid var(--line);
  border-radius:28px;
  padding:34px;
  box-shadow:0 18px 55px rgba(23,23,23,.065);
  margin-bottom:18px;
}
.privacy-hero-clean .eyebrow{
  margin-bottom:12px;
}
.privacy-hero-clean h1{
  font-family:var(--display-serif, Georgia, "Times New Roman", serif) !important;
  font-size:clamp(34px,4vw,54px) !important;
  line-height:1.05 !important;
  letter-spacing:-.045em !important;
  font-weight:500 !important;
  margin:0 0 14px !important;
  max-width:760px;
}
.privacy-hero-clean p{
  max-width:760px;
  color:var(--muted);
  font-size:17px;
  line-height:1.65;
  margin:0;
}
.privacy-layout-clean{
  display:grid;
  grid-template-columns:260px 1fr;
  gap:18px;
  align-items:start;
}
.privacy-toc-clean{
  position:sticky;
  top:106px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  padding:18px;
}
.privacy-toc-clean strong{
  display:block;
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--accent);
  margin-bottom:10px;
}
.privacy-toc-clean a{
  display:block;
  padding:10px 0;
  border-top:1px solid var(--line);
  color:#252525;
  text-decoration:none;
  font-weight:800;
  font-size:14px;
}
.privacy-toc-clean a:first-of-type{
  border-top:0;
}
.privacy-toc-clean a:hover{
  color:var(--accent);
}
.privacy-content-clean{
  display:grid;
  gap:14px;
}
.privacy-card-clean{
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  padding:26px;
}
.privacy-card-clean h2{
  font-family:var(--font, Inter, Arial, sans-serif) !important;
  font-size:clamp(22px,2.2vw,30px) !important;
  line-height:1.18 !important;
  letter-spacing:-.035em !important;
  margin:0 0 10px !important;
  font-weight:900 !important;
}
.privacy-card-clean p{
  color:var(--muted);
  line-height:1.7;
  margin:0;
}
.privacy-card-clean ul{
  margin:10px 0 0;
  padding-left:18px;
  color:var(--muted);
  line-height:1.75;
}
.privacy-card-clean li{
  margin:3px 0;
}
.privacy-summary-clean{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
  margin-top:18px;
}
.privacy-summary-clean div{
  border:1px solid var(--line);
  background:rgba(250,248,244,.68);
  border-radius:18px;
  padding:16px;
}
.privacy-summary-clean strong{
  display:block;
  color:#151515;
  margin-bottom:4px;
  font-size:14px;
}
.privacy-summary-clean span{
  display:block;
  color:var(--muted);
  line-height:1.45;
  font-size:13px;
}
.privacy-actions-clean{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:18px;
}
@media(max-width:900px){
  .privacy-layout-clean{
    grid-template-columns:1fr;
  }
  .privacy-toc-clean{
    position:static;
  }
  .privacy-summary-clean{
    grid-template-columns:1fr;
  }
}
@media(max-width:640px){
  .privacy-clean{
    padding:24px 0 38px;
  }
  .privacy-clean-wrap{
    padding:0 16px;
  }
  .privacy-hero-clean,
  .privacy-card-clean{
    padding:20px;
    border-radius:22px;
  }
  .privacy-hero-clean h1{
    font-size:34px !important;
  }
  .privacy-hero-clean p{
    font-size:15.5px;
  }
  .privacy-toc-clean{
    border-radius:20px;
  }
}



/* v66 - trabajos alineados + lightbox más prolijo */
.portfolio-index-card .body{
  inset:0 !important;
  left:0 !important;
  right:0 !important;
  bottom:0 !important;
  padding:0 22px 22px !important;
  display:flex !important;
  flex-direction:column !important;
  justify-content:flex-end !important;
  z-index:2 !important;
}
.portfolio-index-card .badge{
  position:absolute !important;
  left:22px !important;
  top:120px !important;
  z-index:3 !important;
  margin:0 !important;
}
.portfolio-index-card h3{
  min-height:58px !important;
  display:flex !important;
  align-items:flex-end !important;
  margin:0 0 8px !important;
}
.portfolio-index-card p{
  min-height:50px !important;
  margin:0 !important;
}
.portfolio-index-card .mini-link{
  margin-top:14px !important;
}

/* Caption del lightbox: mismo ancho de la foto, no una barra gigante */
.lightbox-stage{
  overflow:visible !important;
}
.lightbox-stage .lightbox-caption{
  left:auto !important;
  right:auto !important;
  bottom:auto;
  width:auto;
  max-width:none;
  box-sizing:border-box;
  padding:12px 16px !important;
  background:rgba(8,8,8,.84);
  border:1px solid rgba(255,255,255,.08);
  border-top:0;
  border-radius:0 0 14px 14px;
  text-align:center;
  text-shadow:none !important;
  font-size:13px !important;
  font-weight:850 !important;
  line-height:1.35 !important;
}
@media(max-width:640px){
  .portfolio-index-card .badge{
    top:96px !important;
  }
  .portfolio-index-card h3{
    min-height:auto !important;
  }
  .portfolio-index-card p{
    min-height:auto !important;
  }
  .lightbox-stage .lightbox-caption{
    font-size:12px !important;
    padding:10px 12px !important;
    border-radius:0 0 10px 10px;
  }
}


/* v68 - Corian más comercial y profesional */
.corian-v68{padding:44px 0 56px}
.corian-v68-hero{display:grid;grid-template-columns:1.02fr .98fr;gap:28px;align-items:stretch}
.corian-v68-copy{background:#fff;border:1px solid var(--line);border-radius:34px;padding:42px;box-shadow:var(--shadow-soft)}
.corian-v68-copy h1{font-size:clamp(42px,5vw,76px)!important;line-height:.98!important;letter-spacing:-.055em!important;margin:0 0 18px!important}
.corian-v68-photo{min-height:520px;border-radius:34px;overflow:hidden;position:relative;box-shadow:var(--shadow);background:#111}
.corian-v68-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.88) contrast(1.02)}
.corian-v68-photo-label{position:absolute;left:22px;right:22px;bottom:22px;background:rgba(255,255,255,.92);border:1px solid rgba(255,255,255,.68);border-radius:22px;padding:18px;backdrop-filter:blur(12px)}
.corian-v68-photo-label strong{display:block;font-size:18px;color:#151515}.corian-v68-photo-label span{display:block;color:var(--muted);margin-top:4px;line-height:1.45;font-size:13.5px}
.corian-v68-points{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:24px}
.corian-v68-point{border:1px solid var(--line);background:#fbfaf7;border-radius:18px;padding:16px}.corian-v68-point strong{display:block;margin-bottom:5px;color:#151515}.corian-v68-point span{display:block;color:var(--muted);line-height:1.42;font-size:13px}
.corian-v68-section{padding:44px 0}.corian-v68-head{display:flex;justify-content:space-between;align-items:end;gap:24px;margin-bottom:22px}.corian-v68-head h2{font-size:clamp(30px,3.4vw,48px)!important;line-height:1.05!important;margin:0!important}.corian-v68-head p{color:var(--muted);max-width:660px;margin:0;line-height:1.65}
.corian-benefit-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.corian-benefit-card{background:#fff;border:1px solid var(--line);border-radius:24px;padding:22px;box-shadow:var(--shadow-soft)}.corian-benefit-card .num{display:inline-flex;width:34px;height:34px;border-radius:50%;align-items:center;justify-content:center;background:rgba(0,135,128,.10);color:var(--accent);font-weight:900;margin-bottom:14px}.corian-benefit-card h3{font-size:19px;margin:0 0 8px}.corian-benefit-card p{color:var(--muted);font-size:14px;line-height:1.55;margin:0}
.corian-app-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.corian-app-card{background:#fff;border:1px solid var(--line);border-radius:24px;padding:24px;display:flex;gap:14px;align-items:flex-start}.corian-app-card span{width:10px;height:10px;border-radius:50%;background:var(--accent);flex:0 0 auto;margin-top:8px}.corian-app-card strong{display:block;font-size:17px;margin-bottom:5px}.corian-app-card p{color:var(--muted);margin:0;line-height:1.5;font-size:14px}
.corian-v68-band{background:linear-gradient(135deg,#111,#28231d);color:#fff;border-radius:34px;padding:34px;display:grid;grid-template-columns:1fr 1fr;gap:26px;align-items:center;box-shadow:var(--shadow)}.corian-v68-band h2{color:#fff;font-size:clamp(30px,3vw,44px)!important;margin:0 0 10px!important}.corian-v68-band p{color:#ded6ca;line-height:1.65}.corian-v68-band .steps{display:grid;gap:10px}.corian-v68-band .steps div{border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06);border-radius:18px;padding:14px 16px;color:#fff;font-weight:800}
.corian-faq-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.corian-faq-item{background:#fff;border:1px solid var(--line);border-radius:22px;padding:22px}.corian-faq-item h3{font-size:18px;margin:0 0 8px}.corian-faq-item p{color:var(--muted);margin:0;line-height:1.6;font-size:14px}
.corian-trademark-note{margin-top:18px;padding:16px 18px;border:1px solid var(--line);border-radius:18px;background:#fbfaf7;color:var(--muted);line-height:1.6;font-size:13px}
@media(max-width:980px){.corian-v68-hero,.corian-v68-band{grid-template-columns:1fr}.corian-v68-photo{min-height:390px}.corian-v68-points,.corian-benefit-grid,.corian-app-grid{grid-template-columns:repeat(2,1fr)}.corian-v68-head{display:block}.corian-v68-head p{margin-top:10px}}
@media(max-width:640px){.corian-v68{padding:24px 0 36px}.corian-v68-copy{padding:24px;border-radius:26px}.corian-v68-copy h1{font-size:38px!important}.corian-v68-photo{min-height:300px;border-radius:26px}.corian-v68-points,.corian-benefit-grid,.corian-app-grid,.corian-faq-grid{grid-template-columns:1fr}.corian-v68-band{padding:24px;border-radius:26px}}


/* v69 - documentación oficial Corian */
.corian-doc-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
  margin-top:22px;
}
.corian-doc-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  padding:24px;
  box-shadow:var(--shadow-soft);
}
.corian-doc-card h3{
  font-size:20px;
  margin:0 0 9px;
}
.corian-doc-card p{
  color:var(--muted);
  font-size:14px;
  line-height:1.62;
  margin:0 0 16px;
}
.corian-doc-card .mini-link{
  color:var(--accent);
  font-weight:900;
  text-decoration:none;
}
.corian-doc-card .mini-link:hover{
  text-decoration:underline;
}
.corian-doc-note{
  margin-top:16px;
  background:#fbfaf7;
  border:1px solid var(--line);
  border-radius:22px;
  padding:18px;
  color:var(--muted);
  line-height:1.65;
  font-size:13.5px;
}
.corian-doc-note strong{
  color:#151515;
}
@media(max-width:900px){
  .corian-doc-grid{
    grid-template-columns:1fr;
  }
}



/* v71 - galería dinámica en tarjetas */
.dynamic-gallery-section{
  padding-top:42px !important;
}
.dynamic-gallery-section .premium-gallery-intro{
  align-items:center;
  margin-bottom:18px;
}
.dynamic-gallery-section .premium-gallery-intro .eyebrow{
  margin-bottom:5px;
}
.dynamic-gallery-section .gallery-grid[data-dynamic-gallery]{
  display:grid !important;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:22px;
  align-items:stretch;
}
.dynamic-gallery-section .gallery-card.project-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  overflow:hidden;
  padding:0 !important;
  box-shadow:var(--shadow-soft);
  transition:transform .18s ease, box-shadow .18s ease;
}
.dynamic-gallery-section .gallery-card.project-card:hover{
  transform:translateY(-3px);
  box-shadow:var(--shadow);
}
.dynamic-gallery-section .gallery-card.project-card::after{
  content:"Ampliar";
  left:14px;
  top:14px;
  bottom:auto;
  opacity:0;
  z-index:4;
}
.dynamic-gallery-section .gallery-card.project-card:hover::after{
  opacity:1;
}
.dynamic-gallery-section .gallery-open{
  display:block;
  width:100%;
  aspect-ratio:4/3;
  border:0;
  padding:0;
  margin:0;
  background:transparent;
  cursor:pointer;
  overflow:hidden;
}
.dynamic-gallery-section .gallery-open img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.dynamic-gallery-section .gallery-card-body{
  padding:18px 20px 20px;
  min-height:118px;
}
.dynamic-gallery-section .gallery-card-body h3{
  margin:0 0 6px;
  font-size:18px;
  line-height:1.18;
  letter-spacing:-.02em;
}
.dynamic-gallery-section .gallery-card-body p{
  margin:0;
  color:var(--muted);
  font-size:14px;
  line-height:1.5;
}
@media(max-width:980px){
  .dynamic-gallery-section .gallery-grid[data-dynamic-gallery]{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}
@media(max-width:640px){
  .dynamic-gallery-section{
    padding-top:28px !important;
  }
  .dynamic-gallery-section .premium-gallery-intro{
    display:block;
  }
  .dynamic-gallery-section .premium-gallery-intro .btn{
    margin-top:14px;
    width:100%;
  }
  .dynamic-gallery-section .gallery-grid[data-dynamic-gallery]{
    grid-template-columns:1fr;
    gap:16px;
  }
  .dynamic-gallery-section .gallery-card-body{
    min-height:auto;
  }
}


/* v77 - ajustes lightbox navegable */
.lightbox-modal.open{
  display:flex !important;
}
.lightbox-prev,
.lightbox-next,
.lightbox-close{
  z-index:10005;
}
.lightbox-counter{
  z-index:10006;
}
.lightbox-caption{
  max-width:none;
  box-sizing:border-box;
}
@media(max-width:640px){
  .lightbox-prev,
  .lightbox-next{
    width:44px;
    height:44px;
    font-size:32px;
  }
}



/* v78 - lightbox flechas corregidas */
.lightbox-modal{
  position:fixed !important;
  inset:0 !important;
  display:none !important;
  align-items:center !important;
  justify-content:center !important;
  background:rgba(12,12,12,.88) !important;
  backdrop-filter:blur(8px);
  z-index:99999 !important;
  padding:54px 90px !important;
}
.lightbox-modal.open{
  display:flex !important;
}
.lightbox-stage{
  position:relative !important;
  width:100% !important;
  height:100% !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
}
.lightbox-stage img{
  max-width:100% !important;
  max-height:100% !important;
  object-fit:contain !important;
  border-radius:18px !important;
  box-shadow:0 30px 80px rgba(0,0,0,.45) !important;
}
.lightbox-close,
.lightbox-prev,
.lightbox-next{
  position:fixed !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  border:1px solid rgba(255,255,255,.22) !important;
  background:rgba(20,20,20,.62) !important;
  color:#fff !important;
  z-index:100002 !important;
  cursor:pointer !important;
  opacity:1 !important;
  visibility:visible !important;
}
.lightbox-close{
  top:18px !important;
  right:20px !important;
  width:48px !important;
  height:48px !important;
  border-radius:999px !important;
  font-size:34px !important;
  line-height:1 !important;
}
.lightbox-prev,
.lightbox-next{
  top:50% !important;
  transform:translateY(-50%) !important;
  width:56px !important;
  height:64px !important;
  border-radius:22px !important;
  font-size:48px !important;
  line-height:1 !important;
  font-family:Arial, sans-serif !important;
}
.lightbox-prev{ left:22px !important; }
.lightbox-next{ right:22px !important; }
.lightbox-prev[hidden],
.lightbox-next[hidden],
.lightbox-counter[hidden]{
  display:none !important;
}
.lightbox-caption{
  position:absolute !important;
  padding:14px 18px !important;
  background:rgba(8,8,8,.82) !important;
  color:#fff !important;
  border-radius:0 0 16px 16px !important;
  text-align:center !important;
  font-weight:700 !important;
  z-index:100001 !important;
  box-sizing:border-box !important;
}
.lightbox-counter{
  position:fixed !important;
  top:76px !important;
  left:22px !important;
  z-index:100002 !important;
  background:rgba(20,20,20,.62) !important;
  border:1px solid rgba(255,255,255,.22) !important;
  color:#fff !important;
  border-radius:999px !important;
  padding:10px 14px !important;
  font-weight:800 !important;
}
@media(max-width:640px){
  .lightbox-modal{
    padding:66px 14px 58px !important;
  }
  .lightbox-prev,
  .lightbox-next{
    width:44px !important;
    height:50px !important;
    border-radius:16px !important;
    font-size:36px !important;
    bottom:12px !important;
    top:auto !important;
    transform:none !important;
  }
  .lightbox-prev{ left:calc(50% - 58px) !important; }
  .lightbox-next{ right:calc(50% - 58px) !important; }
  .lightbox-close{
    width:44px !important;
    height:44px !important;
    font-size:30px !important;
  }
  .lightbox-counter{
    top:18px !important;
    left:18px !important;
  }
}



/* v81 - ubicación contacto más limpia */
.simple-contact-map h2{
  max-width: 520px;
}
.simple-contact-map p{
  max-width: 520px;
  line-height: 1.65;
}
.simple-contact-map strong{
  color: #171717;
}


/* v82 - redes sociales destacadas */
.social-strip{
  padding:46px 0 0;
  background:linear-gradient(180deg, rgba(246,242,236,.2), rgba(246,242,236,.8));
}
.social-strip-card{
  border:1px solid var(--line);
  border-radius:32px;
  background:rgba(255,255,255,.92);
  box-shadow:var(--shadow-soft);
  padding:28px;
  display:grid;
  grid-template-columns:.82fr 1.18fr;
  gap:24px;
  align-items:center;
}
.social-strip-copy h2{
  font-size:clamp(30px, 3vw, 46px);
  line-height:1.02;
  margin:4px 0 10px;
}
.social-strip-copy p:not(.eyebrow){
  color:var(--muted);
  max-width:520px;
  font-size:16px;
  line-height:1.65;
}
.social-strip-actions{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:14px;
}
.social-action-card,
.contact-social-card{
  display:flex;
  align-items:center;
  gap:13px;
  min-height:78px;
  padding:15px;
  border-radius:24px;
  border:1px solid var(--line);
  background:#fff;
  color:var(--ink);
  box-shadow:0 14px 36px rgba(26,20,14,.08);
  transition:.2s ease;
}
.social-action-card:hover,
.contact-social-card:hover{
  transform:translateY(-3px);
  border-color:rgba(0,135,128,.32);
  box-shadow:0 18px 42px rgba(26,20,14,.12);
}
.social-action-card strong,
.contact-social-card strong{
  display:block;
  font-size:15px;
  line-height:1.1;
}
.social-action-card small,
.contact-social-card small{
  display:block;
  margin-top:4px;
  color:var(--muted);
  font-size:12px;
  line-height:1.25;
}
.social-action-icon{
  width:48px;
  height:48px;
  border-radius:18px;
  display:grid;
  place-items:center;
  flex:0 0 48px;
  color:#fff;
  background:var(--accent);
  box-shadow:0 12px 28px rgba(0,135,128,.22);
}
.social-action-icon svg{
  width:24px;
  height:24px;
  display:block;
}
.social-action-card.whatsapp .social-action-icon{
  background:#25d366;
  box-shadow:0 12px 28px rgba(37,211,102,.24);
}
.social-action-card.instagram .social-action-icon,
.contact-social-card.instagram .social-action-icon{
  background:linear-gradient(135deg, #833ab4, #fd1d1d, #fcb045);
  box-shadow:0 12px 28px rgba(253,29,29,.18);
}
.social-action-card.facebook .social-action-icon,
.contact-social-card.facebook .social-action-icon{
  background:#1877f2;
  box-shadow:0 12px 28px rgba(24,119,242,.2);
}

/* Contacto: redes más visibles */
.simple-social-featured{
  margin-top:26px;
  padding:22px;
  border:1px solid var(--line);
  border-radius:26px;
  background:linear-gradient(180deg,#fff,rgba(246,242,236,.55));
  box-shadow:var(--shadow-soft);
}
.simple-social-featured h3{
  font-size:24px;
  line-height:1.1;
  margin:4px 0 16px;
}
.contact-social-cards{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:12px;
}
.contact-social-card{
  min-height:84px;
}
.contact-social-card .social-action-icon{
  width:52px;
  height:52px;
  flex-basis:52px;
  border-radius:19px;
}
.contact-social-card .social-action-icon svg{
  width:25px;
  height:25px;
}

@media(max-width:980px){
  .social-strip-card{
    grid-template-columns:1fr;
  }
}
@media(max-width:720px){
  .social-strip{
    padding:32px 0 0;
  }
  .social-strip-card{
    border-radius:26px;
    padding:22px;
  }
  .social-strip-actions,
  .contact-social-cards{
    grid-template-columns:1fr;
  }
  .social-action-card,
  .contact-social-card{
    min-height:72px;
  }
}
