/*
Theme Name: Housteamer
Theme URI: https://housteamer.com
Author: Housteamer
Description: Tema completo para empresa de limpieza profunda en Houston. Incluye landing completa, blog, servicios, sobre nosotros y contacto. Compatible con Elementor.
Version: 1.0.0
License: GPL v2 or later
Text Domain: housteamer
Tags: business, blog, one-column, two-columns, custom-colors, custom-logo, custom-menu, featured-images, full-width-template, theme-options, threaded-comments, translation-ready
*/

:root{
  --primary:#2563eb;
  --primary-deep:#1e3a8a;
  --primary-soft:#dbeafe;
  --accent:#f59e0b;
  --accent-deep:#b45309;
  --ink:#0f172a;
  --muted:#475569;
  --soft:#f1f5f9;
  --bg:#ffffff;
  --border:#e2e8f0;
  --radius:14px;
  --shadow:0 10px 30px -10px rgba(2,6,23,.15);
  --shadow-lg:0 20px 60px -20px rgba(2,6,23,.25);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--ink);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--primary);text-decoration:none}
a:hover{color:var(--primary-deep)}
h1,h2,h3,h4{font-family:'Montserrat',sans-serif;font-weight:800;color:var(--primary-deep);line-height:1.2;margin:0 0 12px}
h1{font-size:clamp(2rem,4.5vw,3.4rem)}
h2{font-size:clamp(1.6rem,3vw,2.4rem)}
h3{font-size:1.25rem}
p{margin:0 0 12px;color:var(--muted)}
.container{max-width:1200px;margin:0 auto;padding:0 24px}
.eyebrow{display:inline-block;color:var(--primary);font-weight:700;letter-spacing:.18em;text-transform:uppercase;font-size:.78rem;margin-bottom:10px}
.h-title{text-align:center;margin-bottom:14px}
.h-sub{text-align:center;max-width:720px;margin:0 auto 40px}
.band{padding:80px 0}
.soft{background:var(--soft)}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 26px;border-radius:999px;font-weight:700;font-family:'Montserrat';font-size:.95rem;border:none;cursor:pointer;transition:transform .2s,box-shadow .2s,background .2s;text-decoration:none}
.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-deep);color:#fff}
.btn-accent{background:var(--accent);color:#fff}
.btn-accent:hover{background:var(--accent-deep);color:#fff}
.btn-ghost{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.5)}
.btn-light{background:#fff;color:var(--primary)}

/* Header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--border)}
.site-header-inner{display:flex;align-items:center;justify-content:space-between;padding:16px 0;gap:24px}
.site-brand{display:flex;align-items:center;gap:10px;font-family:'Montserrat';font-weight:900;font-size:1.25rem;color:var(--primary-deep)}
.site-brand .logo-mark{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--primary),var(--primary-deep));display:grid;place-items:center;color:#fff}
.main-nav ul{list-style:none;display:flex;gap:28px;margin:0;padding:0}
.main-nav a{color:var(--ink);font-weight:600;font-size:.95rem}
.main-nav a:hover{color:var(--primary)}
.header-cta{display:flex;gap:10px;align-items:center}
.nav-toggle{display:none;background:none;border:0;font-size:1.5rem;color:var(--ink);cursor:pointer}
@media(max-width:900px){
  .main-nav{display:none}
  .main-nav.open{display:block;position:absolute;top:100%;left:0;right:0;background:#fff;border-bottom:1px solid var(--border);padding:20px 24px}
  .main-nav.open ul{flex-direction:column;gap:18px}
  .nav-toggle{display:block}
  .header-cta .btn{display:none}
}

/* Hero */
.hero{background:linear-gradient(135deg,#eff6ff 0%,#dbeafe 100%);padding:90px 0 80px;position:relative;overflow:hidden}
.hero:before{content:"";position:absolute;inset:0;background:radial-gradient(900px 400px at 80% -10%,rgba(37,99,235,.15),transparent 60%)}
.hero-inner{position:relative;display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center}
.hero h1 span{color:var(--accent)}
.hero .lead{font-size:1.1rem;color:#1e293b;margin:18px 0 28px;max-width:540px}
.tag{display:inline-flex;gap:8px;align-items:center;background:#fff;color:var(--primary);padding:8px 14px;border-radius:999px;font-weight:600;font-size:.85rem;box-shadow:var(--shadow);margin-bottom:18px}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap}
.hero-ctas .btn-ghost{color:var(--primary-deep);border-color:var(--primary)}
.hero-trust{display:flex;gap:24px;flex-wrap:wrap;margin-top:32px;color:var(--primary-deep);font-weight:600;font-size:.9rem}
.hero-trust i{color:var(--accent);margin-right:6px}
@media(max-width:900px){.hero-inner{grid-template-columns:1fr}}

/* Lead Form */
.lead-form{background:#fff;padding:32px;border-radius:20px;box-shadow:var(--shadow-lg);border:1px solid var(--border)}
.lead-form h3{margin-bottom:6px}
.lead-form p.sub{font-size:.9rem;margin-bottom:18px}
.lead-form .field{margin-bottom:12px}
.lead-form label{display:block;font-size:.8rem;font-weight:600;color:var(--ink);margin-bottom:6px;text-transform:uppercase;letter-spacing:.05em}
.lead-form input,.lead-form select,.lead-form textarea{width:100%;padding:12px 14px;border:1.5px solid var(--border);border-radius:10px;font-family:inherit;font-size:.95rem;background:#fafbfc;transition:border .2s}
.lead-form input:focus,.lead-form select:focus,.lead-form textarea:focus{outline:none;border-color:var(--primary);background:#fff}
.lead-form .btn{width:100%;justify-content:center;margin-top:6px}
.lead-form .small{font-size:.75rem;color:var(--muted);text-align:center;margin-top:10px}

/* Promo */
.promo{background:linear-gradient(90deg,var(--primary-deep),var(--primary));color:#fff;padding:30px 0}
.promo .container{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.promo h2{color:#fff;font-size:1.5rem;margin:0}
.promo p{color:rgba(255,255,255,.85);margin:4px 0 0}
.promo img{width:140px;height:90px;object-fit:cover;border-radius:12px;border:3px solid rgba(255,255,255,.2)}

/* Grid + Cards */
.grid{display:grid;gap:24px}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:980px){.cols-3,.cols-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.cols-2,.cols-3,.cols-4{grid-template-columns:1fr}}

.card{background:#fff;padding:28px;border-radius:var(--radius);border:1px solid var(--border);transition:transform .25s,box-shadow .25s}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card.dark{background:linear-gradient(135deg,var(--primary-deep),var(--primary));color:#fff}
.card.dark h3,.card.dark p{color:#fff}
.card.dark p{opacity:.9}
.card .icon{width:54px;height:54px;border-radius:14px;background:var(--primary-soft);color:var(--primary);display:grid;place-items:center;font-size:1.4rem;margin-bottom:16px}
.card.dark .icon{background:rgba(255,255,255,.15);color:#fff}
.card .num{font-family:'Montserrat';font-weight:900;font-size:2.4rem;color:var(--accent);line-height:1;margin-bottom:14px}

/* Service Cards */
.svc-card{background:#fff;border-radius:18px;overflow:hidden;border:1px solid var(--border);transition:transform .25s,box-shadow .25s;display:flex;flex-direction:column}
.svc-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.svc-card .img{aspect-ratio:4/3;overflow:hidden;background:var(--soft)}
.svc-card .img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.svc-card:hover .img img{transform:scale(1.05)}
.svc-card .body{padding:24px}
.svc-card .icon{width:44px;height:44px;border-radius:12px;background:var(--soft);color:var(--primary);display:grid;place-items:center;font-size:1.1rem;margin-bottom:12px}
.pill{display:inline-flex;align-items:center;gap:6px;color:var(--primary);font-weight:600;font-size:.9rem;margin-top:10px}

/* Split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.split img{border-radius:20px;box-shadow:var(--shadow-lg)}
.split ul{list-style:none;padding:0;margin:18px 0}
.split ul li{padding:8px 0;color:var(--ink)}
.split ul li i{color:var(--accent);margin-right:10px}
@media(max-width:900px){.split{grid-template-columns:1fr}}

/* Lead band */
.lead-band{background:linear-gradient(135deg,var(--primary-deep),var(--primary));color:#fff;border-radius:24px;padding:48px;box-shadow:var(--shadow-lg)}
.lead-band .inner{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center}
.lead-band h2{color:#fff}
.lead-band p{color:rgba(255,255,255,.85)}
@media(max-width:900px){.lead-band{padding:32px}.lead-band .inner{grid-template-columns:1fr}}

/* Reviews */
.review .stars{color:var(--accent);font-size:1.1rem;margin-bottom:10px}
.review .name{margin-top:14px;font-weight:700;color:var(--primary-deep);font-size:.9rem}

/* Posts */
.post-card{background:#fff;border-radius:18px;overflow:hidden;border:1px solid var(--border);display:flex;flex-direction:column;transition:transform .25s,box-shadow .25s;color:inherit}
.post-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);color:inherit}
.post-card .img{aspect-ratio:16/10;overflow:hidden;background:var(--soft)}
.post-card .img img{width:100%;height:100%;object-fit:cover}
.post-card .body{padding:22px}
.post-card .meta{font-size:.78rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px;font-weight:600}
.post-card h3{margin-bottom:8px}
.post-card .read{color:var(--primary);font-weight:600;font-size:.9rem;margin-top:10px;display:inline-block}

.blog-hero{background:linear-gradient(135deg,var(--primary-deep),var(--primary));color:#fff;padding:80px 0}
.blog-hero h1{color:#fff}
.blog-hero p{color:rgba(255,255,255,.9);font-size:1.1rem;max-width:640px}

/* Post article */
.post-article{max-width:780px;margin:60px auto;padding:0 24px}
.post-article .cover{aspect-ratio:16/9;border-radius:18px;overflow:hidden;margin-bottom:30px;box-shadow:var(--shadow)}
.post-article .cover img{width:100%;height:100%;object-fit:cover}
.post-article .meta{color:var(--muted);font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;font-weight:600;margin-bottom:10px}
.post-article h1{margin-bottom:24px}
.post-article .content{font-size:1.05rem;color:#1e293b}
.post-article .content h2{margin-top:36px;margin-bottom:14px}
.post-article .content h3{margin-top:24px;margin-bottom:10px;color:var(--primary-deep)}
.post-article .content p{color:#334155;margin-bottom:16px}
.post-article .content ul,.post-article .content ol{padding-left:20px;color:#334155;margin-bottom:16px}
.post-article .content li{margin-bottom:8px}
.post-article .content a{color:var(--primary);text-decoration:underline}

/* FAQ */
.faq{max-width:820px;margin:0 auto}
.faq details{background:#fff;border:1px solid var(--border);border-radius:12px;padding:18px 22px;margin-bottom:12px;transition:box-shadow .2s}
.faq details[open]{box-shadow:var(--shadow)}
.faq summary{font-weight:700;color:var(--primary-deep);cursor:pointer;font-family:'Montserrat';list-style:none;display:flex;justify-content:space-between;align-items:center}
.faq summary::after{content:"+";font-size:1.4rem;color:var(--primary);transition:transform .2s}
.faq details[open] summary::after{content:"−"}
.faq .answer{margin-top:12px;color:var(--muted)}

/* Final */
.final{background:linear-gradient(135deg,var(--primary-deep),var(--primary));color:#fff;padding:90px 0;text-align:center}
.final h2{color:#fff;font-size:clamp(1.8rem,3.5vw,2.6rem)}
.final p{color:rgba(255,255,255,.85);font-size:1.1rem;max-width:580px;margin:0 auto 30px}
.final-ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:30px}
.final-trust{display:flex;gap:30px;justify-content:center;flex-wrap:wrap;font-size:.9rem;color:rgba(255,255,255,.9)}
.final-trust i{color:var(--accent);margin-right:6px}

/* Page hero */
.page-hero{background:linear-gradient(135deg,#eff6ff,#dbeafe);padding:80px 0 60px;text-align:center}
.page-hero h1{margin-bottom:14px}
.page-hero p{max-width:680px;margin:0 auto;font-size:1.05rem}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px}
@media(max-width:900px){.contact-grid{grid-template-columns:1fr}}
.contact-info{background:var(--soft);padding:32px;border-radius:18px}
.contact-info .item{display:flex;gap:14px;align-items:flex-start;margin-bottom:20px}
.contact-info .item i{width:42px;height:42px;border-radius:10px;background:var(--primary);color:#fff;display:grid;place-items:center;flex-shrink:0}
.contact-info .item h4{margin:0 0 4px;color:var(--primary-deep)}
.contact-info .item p{margin:0;font-size:.95rem}

/* Footer */
.site-footer{background:#0b1220;color:#cbd5e1;padding:60px 0 30px}
.site-footer-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px}
@media(max-width:900px){.site-footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.site-footer-grid{grid-template-columns:1fr}}
.site-footer h4{color:#fff;font-size:1rem;margin-bottom:14px}
.site-footer a{color:#cbd5e1;display:block;padding:4px 0;font-size:.9rem}
.site-footer a:hover{color:var(--accent)}
.site-footer .brand{font-family:'Montserrat';font-weight:900;font-size:1.3rem;color:#fff;margin-bottom:10px;display:flex;gap:10px;align-items:center}
.site-footer .copyright{border-top:1px solid rgba(255,255,255,.1);padding-top:20px;text-align:center;font-size:.85rem;color:#94a3b8}

/* WP defaults */
.alignleft{float:left;margin:5px 20px 20px 0}
.alignright{float:right;margin:5px 0 20px 20px}
.aligncenter{display:block;margin:5px auto;clear:both}
.wp-caption{max-width:100%}
.wp-caption-text{font-size:.85rem;color:var(--muted);text-align:center;margin-top:6px}
.screen-reader-text{position:absolute!important;clip:rect(1px,1px,1px,1px);height:1px;width:1px;overflow:hidden}
.sticky,.bypostauthor,.gallery-caption{}
