/*
Theme Name: IA Agency Pro
Theme URI: https://example.com/
Author: ChatGPT
Author URI: https://example.com/
Description: Tema WordPress moderno tipo agencia (estilo landing) con secciones: Hero, Servicios, Métricas, Testimonios, FAQ, Partners y Blog. Inspiración de estructura similar a una agencia de IA.
Version: 1.2.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 8.0
License: GPL v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: ia-agency-pro
Tags: one-column, custom-logo, custom-menu, featured-images, block-styles, editor-style
*/

/* ---------- Reset / Base ---------- */
:root{
  --bg: #0b0f17;
  --bg2:#0f172a;
  --card:#111827;
  --text:#e5e7eb;
  --muted:#9ca3af;
  --line: rgba(255,255,255,.10);
  --accent:#00D4FF;
  --accent2:#A855F7;
  --shadow: 0 18px 60px rgba(0,0,0,.35);
  --radius: 18px;
  --radius-sm: 12px;
  --max: 1180px;
  --pad: 22px;
  --font: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font);
  color:var(--text);
  background:
    radial-gradient(1200px 700px at 10% -10%, rgba(0,212,255,.30), transparent 62%),
    radial-gradient(900px 600px at 90% 0%, rgba(168,85,247,.22), transparent 60%),
    radial-gradient(900px 520px at 50% 120%, rgba(34,211,238,.14), transparent 60%),
    linear-gradient(180deg, var(--bg), var(--bg2));
  min-height:100vh;
}
a{color:inherit; text-decoration:none}
img{max-width:100%; height:auto}
.container{
  width:100%;
  max-width:var(--max);
  margin:0 auto;
  padding:0 var(--pad);
}
.sep{height:1px; background:var(--line); margin:0}
.section{
  padding:72px 0;
}
.section.tight{padding:52px 0}
.kicker{
  display:inline-flex; align-items:center; gap:10px;
  color:var(--muted);
  font-size:13px; letter-spacing:.18em;
  text-transform:uppercase;
}
.kicker:before{
  content:"";
  width:10px; height:10px; border-radius:999px;
  background:linear-gradient(90deg, var(--accent), var(--accent2));
  box-shadow:0 0 0 5px rgba(124,58,237,.12);
}
.h1{
  font-size: clamp(34px, 5vw, 54px);
  line-height:1.05;
  margin:14px 0 12px;
  letter-spacing:-.02em;
}
.h2{
  font-size: clamp(24px, 3.2vw, 38px);
  line-height:1.1;
  margin:0 0 10px;
  letter-spacing:-.02em;
}
.p{
  color:var(--muted);
  font-size:16px;
  line-height:1.65;
  margin:0;
}
.grid{
  display:grid;
  gap:18px;
}
.grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid.cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
@media(max-width: 960px){
  .grid.cols-4{grid-template-columns:repeat(2,minmax(0,1fr))}
  .grid.cols-3{grid-template-columns:repeat(2,minmax(0,1fr))}
  .grid.cols-2{grid-template-columns:repeat(1,minmax(0,1fr))}
}
.card{
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border:1px solid var(--line);
  box-shadow: var(--shadow);
  border-radius: var(--radius);
  padding:22px;
  position:relative;
  overflow:hidden;
}
.card:before{
  content:"";
  position:absolute; inset:-2px;
  background: radial-gradient(420px 180px at 20% 0%, rgba(124,58,237,.20), transparent 60%),
              radial-gradient(420px 180px at 90% 20%, rgba(34,197,94,.14), transparent 60%);
  opacity:.8;
  pointer-events:none;
}
.card > *{position:relative}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  border-radius:999px;
  padding:12px 18px;
  font-weight:600;
  border:1px solid var(--line);
  background: rgba(255,255,255,.05);
  transition: transform .12s ease, background .12s ease, border-color .12s ease;
}
.btn:hover{transform: translateY(-1px); background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.18)}
.btn.primary{
  border-color: transparent;
  background: linear-gradient(90deg, var(--accent), #5b21b6);
}
.btn.primary:hover{background: linear-gradient(90deg, #8b5cf6, #6d28d9)}
.btn.ghost{
  background: transparent;
}
.badge{
  display:inline-flex; gap:8px; align-items:center;
  padding:8px 12px;
  border-radius: 999px;
  border:1px solid var(--line);
  background: rgba(0,0,0,.18);
  color: var(--muted);
  font-size: 13px;
}

/* ---------- Header ---------- */
.topbar{
  border-bottom:1px solid var(--line);
  background: rgba(0,0,0,.12);
}
.topbar .row{
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 0;
  gap:10px;
  font-size:13px;
  color:var(--muted);
}
.topbar .row .left, .topbar .row .right{
  display:flex; align-items:center; gap:16px;
  flex-wrap:wrap;
}
.header{
  position:sticky;
  top:0;
  z-index:50;
  background: rgba(11,15,23,.72);
  backdrop-filter: blur(12px);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.navwrap{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 0;
  gap:14px;
}
.brand{
  display:flex; align-items:center; gap:12px;
  min-width: 180px;
}
.brand .logo{
  width:42px; height:42px; border-radius:14px;
  background: linear-gradient(135deg, rgba(124,58,237,.95), rgba(34,197,94,.65));
  box-shadow: 0 0 0 6px rgba(124,58,237,.12);
  display:flex; align-items:center; justify-content:center;
  font-weight:800;
}
.brand .name{font-weight:800; letter-spacing:-.02em}
.menu{
  display:flex; align-items:center; gap:18px;
}
.menu a{
  color:var(--muted);
  font-weight:600;
  font-size:14px;
}
.menu a:hover{color:var(--text)}
.header-actions{
  display:flex; align-items:center; gap:10px;
}
.burger{
  display:none;
  width:44px; height:44px;
  border-radius: 14px;
  border:1px solid var(--line);
  background: rgba(255,255,255,.04);
  color:var(--text);
}
.mobile{
  display:none;
  padding: 0 0 14px;
}
.mobile a{
  display:block;
  padding:12px 14px;
  border:1px solid var(--line);
  border-radius: 14px;
  color:var(--muted);
  font-weight:700;
  margin-top:10px;
  background: rgba(255,255,255,.03);
}
.mobile a:hover{color:var(--text); background: rgba(255,255,255,.06)}
@media(max-width: 980px){
  .menu{display:none}
  .burger{display:inline-flex; align-items:center; justify-content:center}
  .mobile.show{display:block}
}

/* ---------- Hero ---------- */
.hero{
  padding: 74px 0 54px;
}
.hero-grid{
  display:grid;
  grid-template-columns: 1.3fr .7fr;
  gap:22px;
  align-items:stretch;
}
@media(max-width: 960px){
  .hero-grid{grid-template-columns: 1fr}
}
.hero .card{
  padding: 28px;
}
.hero .headline{
  font-size: clamp(34px, 5vw, 60px);
  line-height:1.02;
  margin: 12px 0 14px;
  letter-spacing:-.03em;
}
.hero .sub{
  color:var(--muted);
  font-size: 16px;
  line-height:1.7;
  max-width: 62ch;
}
.hero .cta{
  display:flex; gap:12px; flex-wrap:wrap;
  margin-top: 18px;
}
.hero .pills{
  display:flex; flex-wrap:wrap; gap:10px;
  margin-top: 18px;
}
.hero .aside{
  display:flex; flex-direction:column; gap:16px;
}
.list{
  display:flex; flex-direction:column; gap:12px;
}
.list .item{
  display:flex; gap:12px;
  padding:14px;
  border-radius: var(--radius-sm);
  border:1px solid var(--line);
  background: rgba(255,255,255,.03);
}
.dot{
  width:10px; height:10px; border-radius:999px;
  background: linear-gradient(90deg, var(--accent), var(--accent2));
  margin-top: 6px;
}
.item h4{
  margin:0;
  font-size:14px;
  letter-spacing:-.01em;
}
.item p{
  margin:3px 0 0;
  color:var(--muted);
  font-size:13px;
  line-height:1.5;
}

/* ---------- Cards content ---------- */
.icon{
  width:40px; height:40px; border-radius:14px;
  background: rgba(124,58,237,.16);
  border:1px solid rgba(124,58,237,.30);
  display:flex; align-items:center; justify-content:center;
  font-weight:800;
}
.card h3{
  margin: 12px 0 8px;
  font-size: 18px;
  letter-spacing:-.02em;
}
.card .meta{
  color:var(--muted);
  font-size:14px;
  line-height:1.6;
}

/* ---------- Stats ---------- */
.stats{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:16px;
}
@media(max-width: 960px){
  .stats{grid-template-columns:repeat(2,minmax(0,1fr))}
}
.stat{
  padding:18px;
  border-radius: var(--radius);
  border:1px solid var(--line);
  background: rgba(255,255,255,.03);
}
.stat .n{
  font-size: 28px;
  font-weight: 900;
  letter-spacing:-.03em;
}
.stat .l{
  margin-top:6px;
  color:var(--muted);
  font-weight:700;
  font-size:13px;
  letter-spacing:.08em;
  text-transform:uppercase;
}

/* ---------- FAQ ---------- */
.faq{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.faq-item{
  border:1px solid var(--line);
  border-radius: var(--radius);
  overflow:hidden;
  background: rgba(255,255,255,.03);
}
.faq-q{
  width:100%;
  text-align:left;
  background: transparent;
  color: var(--text);
  border:0;
  padding: 16px 18px;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  font-weight:800;
}
.faq-a{
  padding: 0 18px 16px;
  color: var(--muted);
  display:none;
  line-height:1.65;
}
.faq-item.open .faq-a{display:block}

/* ---------- Footer ---------- */
.footer{
  padding: 46px 0;
  border-top:1px solid var(--line);
  background: rgba(0,0,0,.12);
}
.footer-grid{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:22px;
}
@media(max-width: 960px){
  .footer-grid{grid-template-columns: 1fr}
}
.small{color:var(--muted); font-size:13px; line-height:1.6}
.social{
  display:flex; gap:10px; flex-wrap:wrap; margin-top: 12px;
}
.social a{
  padding:10px 12px;
  border-radius: 999px;
  border:1px solid var(--line);
  background: rgba(255,255,255,.03);
  color:var(--muted);
  font-weight:700;
  font-size:13px;
}
.social a:hover{color:var(--text); background: rgba(255,255,255,.07)}


/* ---------- v1.1: Narrow title + Futuristic neurons ---------- */
.brand .name{
  max-width: 220px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
@media(max-width: 520px){
  .brand .name{
    max-width: 150px;
  }
  .header-actions .btn.primary{
    padding: 10px 14px;
  }
}

.hero .headline{
  max-width: 20ch;
  overflow-wrap: anywhere;
}

.hero-neurons{
  position:relative;
  overflow:hidden;
}
.neuron-canvas{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  opacity:.55;
  pointer-events:none;
  mix-blend-mode: screen;
  filter: saturate(1.1);
}
.hero-neurons .hero-content{ position:relative; z-index:2; }


/* ---------- Logo sizing (narrow header) ---------- */
.custom-logo-link img,
.header-logo{
  width:42px !important;
  height:42px !important;
  border-radius:14px;
  object-fit:contain;
  filter: drop-shadow(0 0 10px rgba(0,212,255,.25));
}
.brand{min-width:auto}
.header-actions .btn.primary{
  box-shadow: 0 10px 30px rgba(0,212,255,.14);
}

/* ---------- Futuristic glow polish ---------- */
.card{
  box-shadow: 0 22px 80px rgba(0,0,0,.40);
}
.card:after{
  content:"";
  position:absolute;
  inset:-2px;
  background: radial-gradient(420px 200px at 10% 10%, rgba(0,212,255,.12), transparent 55%),
              radial-gradient(420px 200px at 90% 10%, rgba(168,85,247,.12), transparent 55%);
  opacity:.9;
  pointer-events:none;
}


/* Full brand mark in hero */
.hero-logo-full{
  display:block;
  max-width: 360px;
  width: 100%;
  height:auto;
  margin: 2px 0 10px;
  filter: drop-shadow(0 0 18px rgba(0,212,255,.18));
}
@media(max-width: 520px){
  .hero-logo-full{ max-width: 280px; }
}
