/*
  Theme Name: Torres Construcción
  Theme URI: https://torresconstruccion.com
  Author: J. Torres
  Author URI: https://torresconstruccion.com
  Description: Tema profesional para Torres Construcción – Remodelación, Reparaciones, Pintura, Techos, Plomería y Electricidad en Puerto Rico. Compatible con Elementor Pro.
  Version: 1.3.0
  Requires at least: 6.0
  Tested up to: 6.7
  Requires PHP: 8.1
  License: GNU General Public License v2 or later
  License URI: https://www.gnu.org/licenses/gpl-2.0.html
  Text Domain: torres-construccion
  Tags: construction, elementor, business, professional, spanish
  */

  /* ── Variables ───────────────────────────────────────── */
  :root {
    --tc-blue:    #002d6e;
    --tc-blue2:   #001a4a;
    --tc-orange:  #FF6600;
    --tc-orange2: #e55a00;
    --tc-white:   #ffffff;
    --tc-gray:    #f4f6f9;
    --tc-text:    #333333;
    --tc-muted:   #666666;
    --tc-radius:  6px;
    --tc-shadow:  0 4px 20px rgba(0,0,0,.12);
    --tc-trans:   .25s ease;
  }

  /* ── Reset ───────────────────────────────────────────── */
  *,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{font-family:'Open Sans',Arial,sans-serif;color:var(--tc-text);background:#fff;line-height:1.6}
  img{max-width:100%;height:auto;display:block}
  a{color:var(--tc-orange);text-decoration:none}
  a:hover{color:var(--tc-orange2)}
  ul{list-style:none}

  /* ── Typography ──────────────────────────────────────── */
  h1,h2,h3,h4,h5,h6{font-family:'Montserrat',sans-serif;font-weight:700;line-height:1.2;color:var(--tc-blue)}
  h1{font-size:clamp(32px,5vw,56px)}
  h2{font-size:clamp(26px,4vw,40px)}
  h3{font-size:clamp(18px,2.5vw,24px)}
  p{margin-bottom:1rem}

  /* ── Container ───────────────────────────────────────── */
  .tc-container{max-width:1200px;margin:0 auto;padding:0 24px}

  /* ── Buttons ─────────────────────────────────────────── */
  .tc-btn{display:inline-block;font-family:'Montserrat',sans-serif;font-weight:700;font-size:15px;padding:14px 32px;border-radius:var(--tc-radius);transition:all var(--tc-trans);cursor:pointer;border:2px solid transparent;text-align:center}
  .tc-btn-primary{background:var(--tc-orange);color:var(--tc-white)}
  .tc-btn-primary:hover{background:var(--tc-orange2);color:var(--tc-white);transform:translateY(-2px);box-shadow:0 6px 20px rgba(255,102,0,.4)}
  .tc-btn-outline{background:transparent;color:var(--tc-white);border-color:var(--tc-white)}
  .tc-btn-outline:hover{background:var(--tc-white);color:var(--tc-blue)}
  .tc-btn-blue{background:var(--tc-blue);color:var(--tc-white)}
  .tc-btn-blue:hover{background:var(--tc-blue2);color:var(--tc-white);transform:translateY(-2px)}
  .tc-btn-lg{padding:18px 48px;font-size:18px}

  /* ── Section ─────────────────────────────────────────── */
  .tc-section{padding:80px 0}
  .tc-section-gray{background:var(--tc-gray)}
  .tc-section-blue{background:var(--tc-blue)}
  .tc-section-dark{background:var(--tc-blue2)}
  .tc-section-orange{background:var(--tc-orange)}
  .tc-section-title{text-align:center;margin-bottom:16px}
  .tc-section-title.light{color:var(--tc-white)}
  .tc-divider{width:60px;height:3px;background:var(--tc-orange);margin:0 auto 20px;border:none}
  .tc-divider.left{margin:0 0 20px}
  .tc-section-sub{text-align:center;color:var(--tc-muted);font-size:17px;margin-bottom:48px}
  .tc-section-sub.light{color:rgba(255,255,255,.8)}

  /* ── Header ──────────────────────────────────────────── */
  #tc-header{position:sticky;top:0;z-index:1000;background:var(--tc-blue);box-shadow:0 2px 20px rgba(0,0,0,.3)}
  .tc-header-inner{display:flex;align-items:center;justify-content:space-between;padding:12px 0;gap:16px}
  .tc-logo img{max-height:60px;width:auto}
  .tc-logo span{color:var(--tc-white);font-family:'Montserrat',sans-serif;font-weight:800;font-size:20px}
  .tc-nav{display:flex;align-items:center;gap:8px}
  .tc-nav a{color:rgba(255,255,255,.9);font-family:'Montserrat',sans-serif;font-weight:600;font-size:14px;padding:8px 14px;border-radius:4px;transition:all var(--tc-trans)}
  .tc-nav a:hover,.tc-nav a.active{color:var(--tc-white);background:rgba(255,255,255,.15)}
  .tc-nav .tc-btn-cta{background:var(--tc-orange);color:var(--tc-white);padding:10px 22px;border-radius:4px}
  .tc-nav .tc-btn-cta:hover{background:var(--tc-orange2)}
  .tc-header-phone{color:var(--tc-orange);font-family:'Montserrat',sans-serif;font-weight:700;font-size:15px;white-space:nowrap}
  .tc-hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px}
  .tc-hamburger span{display:block;width:26px;height:2px;background:var(--tc-white);transition:all var(--tc-trans);border-radius:2px}
  .tc-mobile-nav{display:none;background:var(--tc-blue2);padding:16px 24px}
  .tc-mobile-nav.open{display:block}
  .tc-mobile-nav a{display:block;color:var(--tc-white);font-family:'Montserrat',sans-serif;font-weight:600;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.1)}

  /* ── Hero ────────────────────────────────────────────── */
  .tc-hero{background:linear-gradient(135deg,var(--tc-blue) 0%,var(--tc-blue2) 100%);padding:100px 0 80px;text-align:center}
  .tc-hero h1{color:var(--tc-white);margin-bottom:16px}
  .tc-hero-divider{width:80px;height:4px;background:var(--tc-orange);margin:0 auto 24px;border:none;border-radius:2px}
  .tc-hero-sub{color:rgba(255,255,255,.85);font-size:19px;margin-bottom:40px;max-width:700px;margin-left:auto;margin-right:auto}
  .tc-hero-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

  /* ── Stats ───────────────────────────────────────────── */
  .tc-stats{background:var(--tc-blue2);padding:60px 0}
  .tc-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
  .tc-stat-num{font-family:'Montserrat',sans-serif;font-weight:800;font-size:clamp(40px,5vw,60px);color:var(--tc-orange);line-height:1}
  .tc-stat-label{color:rgba(255,255,255,.8);font-size:14px;margin-top:8px;font-family:'Montserrat',sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.5px}

  /* ── Services cards ──────────────────────────────────── */
  .tc-services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
  .tc-card{background:var(--tc-white);border-radius:var(--tc-radius);padding:36px 28px;text-align:center;box-shadow:var(--tc-shadow);transition:all var(--tc-trans)}
  .tc-card:hover{transform:translateY(-6px);box-shadow:0 12px 40px rgba(0,0,0,.15)}
  .tc-card-icon{font-size:52px;margin-bottom:16px}
  .tc-card h3{color:var(--tc-blue);margin-bottom:12px}
  .tc-card p{color:var(--tc-muted);font-size:15px;margin:0}

  /* ── About ───────────────────────────────────────────── */
  .tc-about-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
  .tc-about-img img{border-radius:8px;box-shadow:var(--tc-shadow)}
  .tc-about-text h2{margin-bottom:8px}
  .tc-about-text .tc-divider{margin-bottom:20px}
  .tc-about-text p{color:#444;margin-bottom:16px}
  .tc-check-list{margin-bottom:28px}
  .tc-check-list li{padding:6px 0;color:#444;font-size:15px}
  .tc-check-list li::before{content:"✅ ";margin-right:4px}

  /* ── CTA ─────────────────────────────────────────────── */
  .tc-cta{text-align:center;padding:80px 0}
  .tc-cta h2{color:var(--tc-white);margin-bottom:16px}
  .tc-cta p{color:rgba(255,255,255,.9);font-size:18px;margin-bottom:32px}
  .tc-cta .tc-btn{font-size:20px;padding:20px 56px}

  /* ── Contact ─────────────────────────────────────────── */
  .tc-contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px}
  .tc-contact-form label{display:block;font-family:'Montserrat',sans-serif;font-weight:600;font-size:14px;color:var(--tc-blue);margin-bottom:6px}
  .tc-contact-form input,.tc-contact-form textarea,.tc-contact-form select{width:100%;border:2px solid #dde3ee;border-radius:4px;padding:12px 16px;font-family:'Open Sans',sans-serif;font-size:15px;transition:border-color var(--tc-trans);margin-bottom:18px}
  .tc-contact-form input:focus,.tc-contact-form textarea:focus{outline:none;border-color:var(--tc-blue)}
  .tc-contact-form textarea{height:140px;resize:vertical}
  .tc-info-box{background:var(--tc-gray);border-radius:8px;padding:36px;margin-bottom:24px}
  .tc-info-box h3{color:var(--tc-blue);margin-bottom:20px}
  .tc-info-item{display:flex;gap:14px;align-items:flex-start;margin-bottom:18px}
  .tc-info-icon{font-size:24px;flex-shrink:0;margin-top:2px}
  .tc-info-item a{color:var(--tc-blue);font-weight:600}
  .tc-info-item a:hover{color:var(--tc-orange)}
  .tc-map-container iframe{border-radius:8px;width:100%;display:block}

  /* ── Blog / Posts ────────────────────────────────────── */
  .tc-posts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
  .tc-post-card{background:var(--tc-white);border-radius:var(--tc-radius);overflow:hidden;box-shadow:var(--tc-shadow);transition:transform var(--tc-trans)}
  .tc-post-card:hover{transform:translateY(-4px)}
  .tc-post-card-thumb img{width:100%;height:200px;object-fit:cover}
  .tc-post-card-thumb-placeholder{height:200px;background:linear-gradient(135deg,var(--tc-blue),var(--tc-blue2));display:flex;align-items:center;justify-content:center;font-size:48px}
  .tc-post-card-body{padding:24px}
  .tc-post-card-body h3{font-size:17px;margin-bottom:8px;line-height:1.4}
  .tc-post-card-body h3 a{color:var(--tc-blue)}
  .tc-post-card-body p{color:var(--tc-muted);font-size:14px;margin:0}
  .tc-post-meta{font-size:12px;color:var(--tc-muted);margin-bottom:10px;font-family:'Montserrat',sans-serif}

  /* ── Single post ─────────────────────────────────────── */
  .tc-single-wrap{max-width:860px;margin:60px auto;padding:0 24px}
  .tc-single-wrap h1{margin-bottom:16px}
  .tc-single-wrap .tc-post-meta{margin-bottom:32px}
  .tc-single-content h2{margin:36px 0 14px;padding-bottom:8px;border-bottom:2px solid var(--tc-orange)}
  .tc-single-content h3{margin:28px 0 10px;color:var(--tc-blue)}
  .tc-single-content p{margin-bottom:18px;line-height:1.8;color:#444}
  .tc-single-content ul{margin:16px 0 24px 24px;list-style:disc}
  .tc-single-content ul li{margin-bottom:8px;color:#444}

  /* ── Footer ──────────────────────────────────────────── */
  #tc-footer{background:var(--tc-blue2)}
  .tc-footer-top{padding:60px 0 40px}
  .tc-footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px}
  .tc-footer-logo img{max-height:56px;width:auto;margin-bottom:16px}
  .tc-footer-logo span{color:var(--tc-white);font-family:'Montserrat',sans-serif;font-weight:800;font-size:18px;display:block;margin-bottom:16px}
  .tc-footer-about{color:rgba(255,255,255,.7);font-size:14px;line-height:1.7}
  .tc-footer-col h4{color:var(--tc-white);font-family:'Montserrat',sans-serif;font-size:15px;margin-bottom:16px;padding-bottom:8px;border-bottom:2px solid var(--tc-orange)}
  .tc-footer-col a{display:block;color:rgba(255,255,255,.7);font-size:14px;margin-bottom:10px;transition:color var(--tc-trans)}
  .tc-footer-col a:hover{color:var(--tc-orange)}
  .tc-footer-contact-item{display:flex;gap:10px;margin-bottom:14px;font-size:14px;color:rgba(255,255,255,.7)}
  .tc-footer-contact-item a{color:var(--tc-orange)}
  .tc-footer-contact-item a:hover{color:var(--tc-orange2)}
  .tc-footer-bottom{background:#00122e;padding:18px 0;text-align:center}
  .tc-footer-bottom p{color:rgba(255,255,255,.5);font-size:13px;margin:0}

  /* ── Gallery ─────────────────────────────────────────── */
  .tc-gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
  .tc-gallery-item{border-radius:var(--tc-radius);overflow:hidden;aspect-ratio:4/3;background:var(--tc-gray);display:flex;align-items:center;justify-content:center;font-size:40px;box-shadow:var(--tc-shadow)}

  /* ── Page hero ───────────────────────────────────────── */
  .tc-page-hero{background:linear-gradient(135deg,var(--tc-blue),var(--tc-blue2));padding:80px 0 60px;text-align:center}
  .tc-page-hero h1{color:var(--tc-white);margin-bottom:12px}
  .tc-page-hero p{color:rgba(255,255,255,.8);font-size:18px}

  /* ── Responsive ──────────────────────────────────────── */
  @media(max-width:900px){
    .tc-services-grid,.tc-stats-grid{grid-template-columns:repeat(2,1fr)}
    .tc-about-grid,.tc-contact-grid{grid-template-columns:1fr;gap:32px}
    .tc-footer-grid{grid-template-columns:1fr 1fr;gap:28px}
    .tc-posts-grid{grid-template-columns:repeat(2,1fr)}
  }
  @media(max-width:640px){
    .tc-nav{display:none}
    .tc-hamburger{display:flex}
    .tc-header-phone{display:none}
    .tc-services-grid,.tc-stats-grid,.tc-posts-grid,.tc-gallery-grid{grid-template-columns:1fr}
    .tc-footer-grid{grid-template-columns:1fr}
    .tc-hero-btns{flex-direction:column;align-items:center}
  }
  