/*
Theme Name: SEOTheme – Creatribu
Theme URI: https://creatribu.com
Author: Creatribu DBloper
Author URI: https://creatribu.com
Description: Tema desarrollado para especialistas en SEO. Es una web rápida y optimizada de fácil instalación y configuración con jerarquía 100% SEO.
Version: 1.1.0
Text Domain: seotheme
*/

:root{ --accent:#0f6fff; --bg:#0f2233; --text:#0f2233; --light:#ffffff; --muted:#7b8a99; --container:1200px; --pad:15px; --font:'Montserrat', Arial, sans-serif; }

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;color:#222;font:16px/1.6 var(--font);background:#fff}
a{color:var(--accent);text-decoration:none}
img{max-width:100%;height:auto;display:block}

/* Layout */
.container{max-width:var(--container);margin:0 auto;padding:0 var(--pad); text-align: center;}
.header{position:sticky;top:0;background:#fff;border-bottom:1px solid #eee;z-index:40}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:10px var(--pad)}
.brand{display:flex;align-items:center;gap:12px}
.brand img{height:42px;width:auto}
.nav{display:flex;align-items:center;gap:18px}
.nav a{padding:8px 6px;font-weight:600;color:var(--accent)}
.btn{display:inline-block;padding:10px 16px;border-radius:8px;border:2px solid var(--accent);color:#fff;background:var(--accent);font-weight:700}
.btn.outline{background:transparent;color:var(--accent)}
.menu-toggle{display:none;border:none;background:#fff;font-size:26px}

/* Hero */
.hero{position:relative;color:#fff}
.hero .media{position:relative;min-height:54vh;background:#111;display:grid;place-items:center;text-align:center}
.hero .media:before{content:"";position:absolute;inset:0;background:rgba(0,0,0,.75)}
.hero .inner{position:relative;z-index:2}
.hero h1{font-size:clamp(36px,5vw,56px);margin:0 0 10px}
.hero p{font-size:clamp(16px,2.2vw,22px);margin:0}

/* Sections */
.section{padding:33px 0}
.section h2{font-size:32px;margin:0 0 10px;color: var(--accent);}
.section .lead{color:#444;max-width:800px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.card{padding:20px;border:1px solid #eee;border-radius:14px;background:#fff}
.card h3{margin:0 0 6px;font-size:20px; color: var(--accent);}
.two-col{display:grid;grid-template-columns:1.05fr .95fr;gap:36px;align-items:center; text-align: left;}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.cta{border-radius: 16px;padding: 32px 32px 50px 32px;background: #f8fafc;border: 1px solid #eef2f7;color: #555;margin-top: 40px;align-items: center;}
.faq .item{border-bottom:1px solid #eee}
.faq button{width:100%;text-align:center;padding:16px 0;border:0;background:none;font-weight:500; font-size: 21px}
.faq .panel{display:none;padding:0 0 16px;color:#444}

/* Social bar */
.social-bar{padding:22px 0;var(--accent);border-top:1px solid #eef2f7;border-bottom:1px solid #eef2f7}
.social-bar .inner{display:flex;align-items:center;justify-content:center;gap:14px}
.social-bar a{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:999px;border:1px solid #e5e7eb;background:#fff;transition:transform .15s ease, border-color .15s ease}
.social-bar a:hover{transform:translateY(-2px);border-color:var(--accent)}
.social-bar svg{width:22px;height:22px;fill:#111}

/* Icon helpers */
.icon .ico, .social-bar .ico{width:22px;height:22px;display:inline-block}
.icon i, .social-bar i{font-size:22px; line-height:1;}

/* Footer */
.footer{background: #f8fafc;border-top: 1px solid #eef2f7;border-bottom: 1px solid #eef2f7;color:#555;margin-top:40px}
.footer a{color: var(--accent);text-decoration:underline}
.footer .footer-inner{display:flex;flex-wrap:wrap;gap:16px;align-items:center;justify-content:space-between;padding:18px var(--pad)}
.footer .brand img{height:34px}

/* Responsive */
@media (max-width: 980px){
  .grid-3{grid-template-columns:1fr}
  .two-col{grid-template-columns:1fr}
  .services-grid{grid-template-columns:1fr}
}
@media (max-width: 820px){
  .nav{display:none}
  .menu-toggle{display:block}
  .nav.mobile{display:flex;flex-direction:column;gap:8px;padding:12px var(--pad)}
}

/* Fix: header menu without bullets */
.nav .menu{margin:0;padding:0}
.nav .menu li{list-style:none;margin:0;padding:0}
.nav .menu li::marker{content:none}

/* Fix: header button text white */
.header .btn{color:#fff !important}

/* HARD RESET: remove bullets/dots in header menu */
.header nav ul,
.header .nav ul,
.nav ul,
.nav .menu,
.nav .menu ul{list-style:none !important;margin:0;padding:0}
.header nav li,
.header .nav li,
.nav li{list-style:none !important}
.header nav li::marker,
.header .nav li::marker,
.nav li::marker{content:""}

/* Valores: iconos integrados */
.icon .ico, .social-bar .ico{display:inline-block;border:none;outline:none;box-shadow:none}
.icon.values .ico{width:50px;height:50px; color: var(--accent);}

/* Enforce horizontal header menu (desktop) */
.nav{display:block;position:relative}
.nav .menu{display:flex;flex-direction:row;align-items:center;gap:18px;margin:0;padding:0}
.nav .menu li{list-style:none;margin:0;padding:0}
.nav .menu > li{display:inline-block}
.nav .menu > li > a{display:inline-block;padding:8px 6px;font-weight:600}

/* Align Contact button to the right of Blog within the same row */
.nav{display:flex;align-items:center;gap:16px}
.nav .btn{margin-left:14px;white-space:nowrap}

/* --- Mobile menu improvements --- */
@media (max-width: 820px){
  .menu-toggle{display:block}
  /* Ensure positioning context from header */
  .header{position:sticky;top:0;z-index:100}
  .header .header-inner{position:relative}
  /* Hide menu by default on mobile */
  #primary-menu.nav .menu{display:none}
  /* Dropdown panel */
  #primary-menu.nav.mobile{
    position:absolute;
    left:0; right:0; top:100%;
    background:#ffffff;
    border-bottom:1px solid #e5e7eb;
    box-shadow:0 6px 18px rgba(0,0,0,.06);
    z-index:150;
  }
  #primary-menu.nav.mobile .menu{
    display:flex;
    flex-direction:column;
    gap:0;
    margin:0;
    padding:10px var(--pad);
  }
  #primary-menu.nav.mobile .menu > li > a{
    display:block;
    padding:12px 6px;
    border-radius:10px;
  }
  /* Contact button full-width inside dropdown */
  #primary-menu.nav .btn{display:none}
  #primary-menu.nav.mobile .btn{
    display:block;
    width:100%;
    text-align:center;
    margin:10px var(--pad) 12px;
    border-radius:12px;
  }
}

/* --- Mobile header layout: toggle on the right --- */
@media (max-width: 820px){
  .header .header-inner{position:relative}
  .menu-toggle{
    display:block !important;
    position:absolute;
    right:var(--pad);
    top:50%;
    transform:translateY(-50%);
    z-index:160;
  }
  /* Hide desktop menu; it will appear in dropdown when nav has .mobile */
  #primary-menu.nav .menu{display:none}
  #primary-menu.nav.mobile .menu{display:flex}
}

/* Desktop: hide toggle, nav inline */
@media (min-width: 821px){
  .menu-toggle{display:none !important}
  #primary-menu.nav .menu{display:flex !important}
}

/* --- Hover styles: slightly darker than --accent --- */
:root{ --accent-hover: color-mix(in srgb, var(--accent) 85%, black); }

a:hover{ color: var(--accent-hover); text-decoration: underline; text-underline-offset: 2px; }

/* Header menu hover */
.nav .menu > li > a:hover{ color: var(--accent-hover); }

/* Buttons hover */
.btn:hover{
  background: var(--accent-hover);
  border-color: var(--accent-hover);
  color: #fff;
  transform: translateY(-1px);
  transition: background .15s ease, border-color .15s ease, transform .15s ease;
}

/* Blog grid */
.posts-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:24px;
}
.post-card{
  display:flex;
  flex-direction:column;
  border:1px solid #eee;
  border-radius:14px;
  overflow:hidden;
  background:#fff;
}
.post-card .thumb{display:block;aspect-ratio:16/9;background:#f4f6f8}
.post-card .thumb img{width:100%;height:100%;object-fit:cover;display:block}
.post-card .thumb.placeholder{background:linear-gradient(135deg,#f1f5f9,#e2e8f0)}
.post-card .content{padding:16px}
.post-card .entry-title{margin:0 0 6px;font-size:20px;line-height:1.3}
.post-card .entry-title a{text-decoration:none}
.post-card .meta{margin:0 0 10px;color:#6b7280;font-size:14px}
.post-card .excerpt{color:#374151;margin:0 0 14px}
.post-card .btn.readmore{align-self:flex-start}

/* Responsive grid */
@media (max-width: 980px){
  .posts-grid{grid-template-columns:repeat(2, minmax(0,1fr));}
}
@media (max-width: 640px){
  .posts-grid{grid-template-columns:1fr;}
}
