/*
 * Theme Name: Reformasturias Pro
 * Template: basic
 * Description: Child theme de Basic con rediseño profesional (navy + ámbar) para reformasturias.es. Reversible: activar de nuevo el theme "Basic".
 * Author: Optimización VPS
 * Version: 1.0
 */

/* ============================================================
   SISTEMA DE DISEÑO
   ============================================================ */
:root{
  /* paleta tomada del logo: navy #20344A, azul #2B6EB0, verde #507639 */
  --navy:#20344a;        /* azul corporativo (logo) */
  --navy-700:#2a4765;
  --navy-600:#2b5a8c;
  --blue:#2b6eb0;        /* azul del logo (enlaces/detalles) */
  --accent:#4c7329;      /* verde del logo oscurecido → contraste AA 5.3:1 con texto blanco */
  --accent-600:#3a5c20;  /* verde más oscuro (hover) */
  --ink:#1f2a37;         /* texto principal */
  --muted:#5b6675;       /* texto secundario */
  --line:#e6eaf0;        /* bordes */
  --bg:#ffffff;
  --soft:#f4f7f4;        /* fondos de sección (tinte verde muy suave) */
  --soft-2:#eaf1ea;
  --radius:14px;
  --radius-sm:10px;
  --shadow:0 6px 24px rgba(32,52,74,.08);
  --shadow-lg:0 18px 48px rgba(32,52,74,.16);
  --maxw:1180px;
  --font:"Poppins",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
  --font-head:"Poppins",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
}

/* ============================================================
   BASE / TIPOGRAFÍA
   ============================================================ */
html{scroll-behavior:smooth;}
body{
  font-family:var(--font);
  color:var(--ink);
  background:var(--bg);
  line-height:1.7;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
.wrapper{background:var(--bg);}
a{color:var(--navy-600);text-decoration:none;transition:color .15s ease;}
a:hover{color:var(--accent-600);}
h1,h2,h3,h4{font-family:var(--font-head);color:var(--navy);line-height:1.22;font-weight:700;letter-spacing:-.01em;margin:1.4em 0 .55em;}
h1{font-size:2.15rem;}
h2{font-size:1.6rem;}
h3{font-size:1.25rem;}
p{margin:0 0 1.05em;}
strong,b{color:var(--navy);font-weight:700;}
img{max-width:100%;height:auto;border-radius:10px;}
hr{border:0;border-top:1px solid var(--line);margin:2rem 0;}

/* ancho de lectura cómodo */
.maxwidth{max-width:var(--maxw);margin-left:auto;margin-right:auto;padding-left:20px;padding-right:20px;}

/* ============================================================
   HEADER (sticky, blanco, sombra)
   ============================================================ */
#header{
  position:sticky;top:0;z-index:1000;
  background:#fff;
  box-shadow:0 1px 0 var(--line),0 6px 18px rgba(22,40,74,.05);
}
#header{transition:box-shadow .25s ease;}
.header-top-wrap{
  max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:1rem;
  padding:6px 20px;transition:padding .25s ease;
}
/* estado encogido al hacer scroll */
#header.rt-shrink .custom-logo,#header.rt-shrink .custom-logo-image,
#header.rt-shrink .logo img,#header.rt-shrink .rt-logo-img{width:130px;}
.header-top-wrap .sitetitle{grid-column:2;justify-self:center;max-width:none;width:auto;margin:0;padding:0;text-align:center;float:none;}
.header-top-wrap .rt-headcta{grid-column:3;justify-self:end;}
.sitedescription{display:none;}  /* coletilla redundante */
/* logo en imagen (custom_logo nativo): ocultar texto del nombre, dimensionar el PNG */
#logo,.blog-name{font-size:0!important;line-height:0;margin:0;}
.custom-logo,.custom-logo-image,.logo img,.rt-logo-img{width:300px;max-width:42vw;height:auto;border-radius:0;display:block;margin:0 auto;transition:width .25s ease,max-height .25s ease;}
.sitedescription{color:var(--muted);font-size:.82rem;margin:.15rem 0 0;font-weight:500;}

/* CTA cabecera (inyectado) */
.rt-headcta{display:flex;flex-direction:column;align-items:flex-end;gap:9px;flex-shrink:0;}
.rt-headcta .rt-phone{
  display:inline-flex;align-items:center;gap:8px;
  color:var(--navy);font-weight:800;font-size:1.06rem;white-space:nowrap;
}
.rt-headcta .rt-phone span{display:flex;flex-direction:column;line-height:1.05;}
.rt-headcta .rt-phone small{font-size:.66rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;}
.rt-headcta .rt-phone .ico{width:38px;height:38px;border-radius:50%;background:var(--soft-2);display:flex;align-items:center;justify-content:center;font-size:1.05rem;}
.btn-cta{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--accent);color:#ffffff;font-weight:800;
  padding:12px 20px;border-radius:999px;font-size:.97rem;white-space:nowrap;
  box-shadow:0 6px 16px rgba(95,140,57,.35);transition:transform .12s ease,box-shadow .12s ease,background .12s ease;
}
.btn-cta:hover{background:var(--accent-600);color:#eafce0;transform:translateY(-1px);box-shadow:0 10px 22px rgba(95,140,57,.45);}
/* fila teléfono + icono WhatsApp */
.rt-phone-row{display:flex;align-items:center;gap:10px;}
.rt-wa-ic{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;background:#25d366;color:#fff;flex-shrink:0;transition:transform .12s ease;}
.rt-wa-ic:hover{color:#fff;transform:scale(1.08);}
/* WhatsApp en hero */
.rt-hero-calls{display:flex;flex-wrap:wrap;gap:12px;}
.rt-wa-btn{background:#25d366!important;border-color:#25d366!important;color:#fff!important;}
.rt-wa-btn:hover{background:#1ebe5b!important;}
.rt-wa-btn svg{margin-right:2px;}
/* logo del footer */
.rt-footer-logo{text-align:center;padding:28px 20px 6px;background:var(--navy);}
.rt-footer-logo img{width:200px;max-width:60vw;height:auto;display:inline-block;border-radius:0;}

/* NAV */
.topnav{background:var(--navy);}
.topnav nav{max-width:var(--maxw);margin:0 auto;}
.topnav,ul.top-menu{background:var(--navy);}
ul.top-menu{display:flex;flex-wrap:wrap;gap:2px;max-width:var(--maxw);margin:0 auto;padding:0 12px;list-style:none;}
ul.top-menu .sub-menu,ul.top-menu .children,ul.top-menu ul,ul.top-menu li ul{background:var(--navy-700);}
ul.top-menu li{margin:0;position:relative;}
ul.top-menu li a,ul.top-menu li span{
  display:block;padding:14px 16px;color:#dbe4f2;font-weight:600;font-size:.96rem;
  border-bottom:3px solid transparent;transition:color .15s,border-color .15s,background .15s;
}
ul.top-menu li a:hover{color:#fff;background:rgba(255,255,255,.06);}
ul.top-menu li.current_page_item>a,ul.top-menu li.current_page_item>span,
ul.top-menu li.current-menu-item>a{color:#fff;border-bottom-color:var(--accent);}
ul.top-menu li.current_page_item>span{color:#fff;}
/* submenús */
ul.top-menu ul{position:absolute;top:100%;left:0;background:var(--navy-700);min-width:220px;box-shadow:var(--shadow-lg);border-radius:0 0 10px 10px;padding:6px 0;display:none;z-index:50;}
ul.top-menu li:hover>ul{display:block;}
ul.top-menu ul li a{padding:10px 16px;border-bottom:0;}
#mobile-menu{display:none;background:var(--navy);color:#fff;font-weight:700;padding:14px 20px;cursor:pointer;}

/* ============================================================
   HERO (inyectado en portada)
   ============================================================ */
.rt-hero{
  background:linear-gradient(135deg,#2f7cc4 0%,#1f5183 100%);
  color:#fff;position:relative;overflow:hidden;
}
.rt-hero::after{content:"";position:absolute;right:-120px;top:-120px;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(95,140,57,.18),transparent 70%);}
.rt-hero-inner{max-width:var(--maxw);margin:0 auto;padding:64px 20px;position:relative;z-index:1;}
.rt-eyebrow{display:inline-block;background:rgba(255,255,255,.18);color:#fff;font-weight:700;font-size:.8rem;letter-spacing:.06em;text-transform:uppercase;padding:6px 14px;border-radius:999px;margin-bottom:18px;}
.rt-hero h2{color:#fff;font-size:2.6rem;line-height:1.12;margin:0 0 14px;max-width:760px;}
.rt-hero p.lead{color:#cdd8ea;font-size:1.18rem;max-width:620px;margin:0 0 28px;}
.rt-hero-btns{display:flex;flex-wrap:wrap;gap:14px;}
.btn-ghost{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.28);padding:12px 22px;border-radius:999px;font-weight:700;transition:background .15s;}
.btn-ghost:hover{background:rgba(255,255,255,.16);color:#fff;}

/* hero a 2 columnas (copy + formulario) */
.rt-hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center;}
.rt-hero-copy h2{font-size:2.4rem;}
.rt-hero-points{list-style:none;margin:18px 0 24px;padding:0;}
.rt-hero-points li{position:relative;padding:5px 0 5px 30px;color:#dbe4f2;font-weight:500;}
.rt-hero-points li::before{content:"";position:absolute;left:2px;top:11px;width:9px;height:9px;border-right:2.5px solid #a3e063;border-bottom:2.5px solid #a3e063;transform:rotate(45deg);}

/* ============================================================
   FORMULARIO DE PRESUPUESTO (tarjeta)
   ============================================================ */
.rt-form{background:#fff;border-radius:16px;box-shadow:var(--shadow-lg);padding:26px 24px;max-width:440px;}
.rt-hero-formwrap .rt-form{margin-left:auto;}
.rt-form-title{margin:0 0 4px;font-size:1.35rem;color:var(--navy);}
.rt-form-sub{margin:0 0 16px;color:var(--muted);font-size:.92rem;}
.rt-form .rt-field{margin:0 0 11px;}
.rt-form input,.rt-form select,.rt-form textarea{
  width:100%;box-sizing:border-box;padding:12px 14px;border:1.5px solid var(--line);border-radius:10px;
  font-family:inherit;font-size:.97rem;color:var(--ink);background:#fff;transition:border-color .15s,box-shadow .15s;
}
.rt-form input:focus,.rt-form select:focus,.rt-form textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(95,140,57,.18);}
.rt-form textarea{resize:vertical;min-height:74px;}
.rt-form-submit{width:100%;justify-content:center;border:0;cursor:pointer;font-size:1.02rem;margin-top:4px;}
.rt-form-legal{margin:10px 0 0;font-size:.74rem;color:var(--muted);text-align:center;}
.rt-check label{display:flex;align-items:flex-start;gap:9px;font-size:.82rem;color:var(--muted);line-height:1.4;cursor:pointer;}
.rt-check input{width:auto;margin:2px 0 0;flex:0 0 auto;accent-color:var(--accent-600);}
.rt-check a{color:var(--navy-600);text-decoration:underline;}
.rt-form-ok{background:#e8f7ee;border:1px solid #b6e3c6;color:#1c7a45;padding:16px;border-radius:10px;font-weight:600;}
.rt-form-err{background:#fdecec;border:1px solid #f5c2c2;color:#b42318;padding:11px 14px;border-radius:10px;font-size:.9rem;margin-bottom:12px;}
.rt-hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden;}
/* formulario embebido en página normal (shortcode) */
.entry .rt-form{max-width:520px;margin:1.5rem 0;border:1px solid var(--line);}

/* franja de confianza */
.rt-trust{background:var(--soft);border-bottom:1px solid var(--line);}
.rt-trust-inner{max-width:var(--maxw);margin:0 auto;padding:18px 20px;display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
.rt-trust-item{display:flex;align-items:center;gap:10px;color:var(--navy);font-weight:700;font-size:.95rem;}
.rt-trust-item .ico{font-size:1.3rem;color:var(--accent-600);}
.rt-trust-item small{display:block;color:var(--muted);font-weight:500;font-size:.78rem;}

/* ============================================================
   LAYOUT CONTENIDO + SIDEBAR
   ============================================================ */
#main{max-width:var(--maxw);margin:0 auto;padding:40px 20px;display:flex;gap:40px;align-items:flex-start;}
main.content{flex:1 1 auto;min-width:0;}
aside.block,.sidebar{flex:0 0 300px;}
article.post.page,article.post{background:transparent;}
.entry-box{margin:0;}
.entry{font-size:1.02rem;}
.entry ul,.entry ol{margin:0 0 1.2em;padding-left:0;}
.entry ul{list-style:none;}
.entry ul li{position:relative;padding:6px 0 6px 30px;margin:0;}
.entry ul li::before{content:"";position:absolute;left:4px;top:13px;width:9px;height:9px;border-right:2.5px solid var(--accent-600);border-bottom:2.5px solid var(--accent-600);transform:rotate(45deg);}
.entry ol{padding-left:1.3em;}
.entry ol li{margin:6px 0;}
.entry a{font-weight:600;text-decoration:underline;text-decoration-color:rgba(95,140,57,.45);text-underline-offset:3px;}
.entry a:hover{text-decoration-color:var(--accent-600);}
.entry blockquote{border-left:4px solid var(--accent);background:var(--soft);padding:14px 20px;border-radius:0 10px 10px 0;margin:1.4em 0;color:var(--navy);font-style:italic;}
.entry table{width:100%;border-collapse:collapse;margin:1.4em 0;}
.entry table th{background:var(--navy);color:#fff;text-align:left;padding:10px 12px;}
.entry table td{border:1px solid var(--line);padding:10px 12px;}

/* Índice de contenidos (TOC) */
.rt-toc{background:var(--soft);border:1px solid var(--line);border-left:4px solid var(--accent);border-radius:12px;padding:6px 18px 14px;margin:0 0 2rem;}
.rt-toc-title{width:100%;display:flex;align-items:center;justify-content:space-between;background:none;border:0;cursor:pointer;font-family:var(--font-head);font-weight:700;color:var(--navy);font-size:1.08rem;padding:12px 0;}
.rt-toc-tog{transition:transform .2s;}
.rt-toc.rt-toc-collapsed .rt-toc-tog{transform:rotate(-90deg);}
.rt-toc-list{list-style:none;margin:0;padding:0;columns:2;column-gap:28px;}
.rt-toc.rt-toc-collapsed .rt-toc-list{display:none;}
.rt-toc-list li{margin:0 0 7px;break-inside:avoid;}
.rt-toc-list a{display:block;color:var(--navy-600);font-weight:500;font-size:.96rem;padding-left:16px;position:relative;text-decoration:none;}
.rt-toc-list a::before{content:"›";position:absolute;left:2px;color:var(--accent);font-weight:800;}
.rt-toc-list a:hover{color:var(--accent-600);}
@media(max-width:600px){.rt-toc-list{columns:1;}}

/* "Leer más" por sección */
.rt-sec-body.rt-collapsed{max-height:300px;overflow:hidden;position:relative;}
.rt-sec-body.rt-collapsed::after{content:"";position:absolute;left:0;right:0;bottom:0;height:80px;background:linear-gradient(transparent,var(--bg));}
.rt-readmore{display:inline-flex;align-items:center;gap:6px;background:var(--soft-2);color:var(--accent-600);border:1px solid var(--line);font-weight:700;font-size:.92rem;padding:8px 18px;border-radius:999px;cursor:pointer;margin:2px 0 1.6rem;transition:background .15s;}
.rt-readmore:hover{background:var(--accent);color:#fff;border-color:var(--accent);}
/* scroll-margin para que el índice no tape el destino bajo el header sticky */
.entry h2[id]{scroll-margin-top:120px;}

/* paneles azules entre secciones (lectura dinámica) */
.rt-callout{background:linear-gradient(135deg,#2f7cc4 0%,#1f5183 100%);color:#fff;border-radius:16px;padding:32px 28px;margin:2.6rem 0;text-align:center;box-shadow:var(--shadow-lg);position:relative;overflow:hidden;}
.rt-callout::after{content:"";position:absolute;right:-60px;top:-60px;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,rgba(163,224,99,.20),transparent 70%);}
.rt-callout.rt-callout-alt{background:linear-gradient(135deg,#20344a 0%,#2b5a8c 100%);}
.rt-callout h3{color:#fff;margin:0 0 8px;font-size:1.55rem;position:relative;z-index:1;}
.rt-callout p{color:#e3edf7;margin:0 0 20px;font-size:1.06rem;position:relative;z-index:1;}
.rt-callout strong{color:#fff;}
.rt-callout .btn-cta,.rt-callout .btn-ghost{position:relative;z-index:1;}
.rt-callout .btn-ghost{background:rgba(255,255,255,.14);}

/* botones dentro del contenido */
.entry a.button,.entry .wp-block-button__link,a.btn,.btn-inline{
  display:inline-flex;align-items:center;gap:8px;background:var(--accent);color:#ffffff!important;
  font-weight:800;padding:12px 22px;border-radius:999px;text-decoration:none!important;box-shadow:0 6px 16px rgba(95,140,57,.3);
}
.entry a.button:hover{background:var(--accent-600);}

/* ============================================================
   TARJETAS sil-cards (enlaces internos / servicios)
   ============================================================ */
.sil-link-box{margin:2.4rem 0;}
.sil-link-box>h2,.sil-link-box>h3{text-align:center;margin-bottom:1.4rem;}
.sil-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:22px;}
article.sil-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow);transition:transform .15s ease,box-shadow .15s ease;display:flex;flex-direction:column;
}
article.sil-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);}
.sil-card-thumb{aspect-ratio:16/10;overflow:hidden;background:var(--soft-2);}
.sil-card-thumb img{width:100%;height:100%;object-fit:cover;border-radius:0;transition:transform .4s ease;}
article.sil-card:hover .sil-card-thumb img{transform:scale(1.06);}
.sil-card-body{padding:16px 18px;flex:1;display:flex;flex-direction:column;}
.sil-card-body a,.sil-card-body h3,.sil-card-body .sil-card-title{color:var(--navy);font-weight:700;font-size:1.05rem;line-height:1.3;}
.sil-card-body a:hover{color:var(--accent-600);}

/* ============================================================
   SIDEBAR
   ============================================================ */
aside.block .widget,.sidebar .widget{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;margin-bottom:22px;box-shadow:var(--shadow);}
aside.block .widget-title,.sidebar .widgettitle,.sidebar h3{color:var(--navy);font-size:1.05rem;margin:0 0 12px;padding-bottom:10px;border-bottom:2px solid var(--soft-2);}
aside.block ul{list-style:none;margin:0;padding:0;}
aside.block ul li{padding:7px 0;border-bottom:1px solid var(--soft);}
aside.block ul li:last-child{border-bottom:0;}

/* ============================================================
   FOOTER
   ============================================================ */
#footer,footer.clearfix,.copyrights{background:var(--navy);color:#c3cfe2;}
.copyrights{max-width:none;padding:28px 20px;margin:0;font-size:.92rem;}
.copyrights .maxwidth,.copyrights.maxwidth{max-width:var(--maxw);margin:0 auto;}
.copyrights a{color:#fff;}
.copyrights a:hover{color:var(--accent);}
.footer-counter{opacity:.6;}

/* ============================================================
   BOTÓN FLOTANTE (móvil: llamar / WhatsApp)
   ============================================================ */
.rt-fab{position:fixed;right:16px;bottom:16px;z-index:1200;display:none;flex-direction:column;gap:12px;}
.rt-fab a{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem;box-shadow:var(--shadow-lg);}
.rt-fab .fab-call{background:var(--accent-600);}
.rt-fab .fab-wa{background:#25d366;}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:980px){
  #main{flex-direction:column;gap:0;padding:28px 18px;}
  aside.block,.sidebar{flex:none;width:100%;margin-top:24px;}
  .rt-trust-inner{grid-template-columns:repeat(2,1fr);}
  .rt-hero h2,.rt-hero-copy h2{font-size:2rem;}
  .rt-hero-grid{grid-template-columns:1fr;gap:30px;}
  .rt-hero-formwrap .rt-form{margin:0;max-width:none;}
}
@media (max-width:760px){
  body{font-size:16px;}
  h1{font-size:1.7rem;}
  .header-top-wrap{padding:10px 16px;grid-template-columns:1fr;justify-items:center;gap:8px;min-height:auto;}
  .header-top-wrap .sitetitle,.header-top-wrap .rt-headcta{grid-column:1;justify-self:center;}
  .custom-logo,.custom-logo-image,.logo img,.rt-logo-img{width:190px;max-width:62vw;}
  .rt-headcta .btn-cta{display:none;}            /* en móvil el CTA va en el FAB */
  .rt-headcta .rt-phone small{display:none;}
  #mobile-menu{display:block;}
  .topnav nav{display:none;}            /* el slideToggle nativo del theme lo muestra (inline display) */
  ul.top-menu{flex-direction:column;padding:0;}
  ul.top-menu li a,ul.top-menu li span{padding:14px 20px;border-bottom:1px solid rgba(255,255,255,.08);}
  ul.top-menu ul{position:static;box-shadow:none;background:rgba(0,0,0,.18);}
  .rt-hero-inner{padding:44px 18px;}
  .rt-hero h2{font-size:1.7rem;}
  .rt-hero p.lead{font-size:1.05rem;}
  .rt-fab{display:flex;}
}
@media (max-width:480px){
  .rt-trust-inner{grid-template-columns:1fr;}
}
