/* ============================================================
   IZ Legal — main.css  v1.0
   Navy profundo · Dorado · Blanco · Gris azulado
   ============================================================ */

:root {
  /* Fondos */
  --navy:       #07142A;
  --navy-mid:   #0D1F40;
  --navy-light: #14294E;
  --navy-card:  rgba(255,255,255,0.04);

  /* Dorado */
  --gold:       #C9A84C;
  --gold-light: #D4B563;
  --gold-bright:#E8C96A;
  --gold-pale:  rgba(201,168,76,0.10);
  --gold-pale2: rgba(201,168,76,0.06);
  --gradient:   linear-gradient(135deg, #B8932E 0%, #E8C96A 100%);
  --gradient-text: linear-gradient(135deg, #C9A84C 0%, #E8C96A 100%);

  /* Texto */
  --text-primary:   #FFFFFF;
  --text-secondary: #9DB4CC;
  --text-muted:     #4A6882;
  --text-dark:      #07142A;

  /* Bordes */
  --border:        rgba(201,168,76,0.12);
  --border-mid:    rgba(201,168,76,0.25);
  --border-active: rgba(201,168,76,0.50);
  --border-subtle: rgba(255,255,255,0.07);

  /* Sombras */
  --shadow-sm:   0 4px 16px rgba(0,0,0,0.25);
  --shadow-md:   0 8px 32px rgba(0,0,0,0.35);
  --shadow-lg:   0 20px 60px rgba(0,0,0,0.45);
  --shadow-gold: 0 8px 32px rgba(201,168,76,0.22);

  /* Tipografía */
  --font-serif: 'Playfair Display', Georgia, serif;
  --font-sans:  'Inter', -apple-system, BlinkMacSystemFont, sans-serif;

  /* Radios */
  --radius-sm: 8px;
  --radius-md: 16px;
  --radius-lg: 24px;

  /* Movimiento */
  --ease: cubic-bezier(0.4,0,0.2,1);
  --dur:  0.28s;

  --container: 1200px;
  --section-y: 96px;
}

/* ---- Reset ---- */
*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; font-size:16px; scroll-padding-top:80px; }
body {
  font-family: var(--font-sans);
  background: var(--navy);
  color: var(--text-primary);
  line-height: 1.6;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
a   { color:inherit; text-decoration:none; }
ul  { list-style:none; }
img { max-width:100%; height:auto; display:block; }
button { font-family: var(--font-sans); }

/* ---- Utilidades ---- */
.gradient-text {
  background: var(--gradient-text);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.font-serif { font-family: var(--font-serif); }
.container  { max-width:var(--container); margin:0 auto; padding:0 24px; }
.section    { padding:var(--section-y) 0; }
.section-alt{ background:var(--navy-mid); }

/* ============================================================
   SCROLL PROGRESS
   ============================================================ */
.scroll-progress {
  position:fixed; top:0; left:0;
  width:0%; height:3px;
  background: var(--gradient);
  z-index:9999;
  transition:width 0.08s linear;
  pointer-events:none;
}

/* ============================================================
   BOTONES
   ============================================================ */
.btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:13px 28px;
  border-radius:var(--radius-sm);
  font-family:var(--font-sans);
  font-size:15px; font-weight:600;
  cursor:pointer; white-space:nowrap;
  border:1.5px solid transparent;
  transition: transform var(--dur) var(--ease),
              box-shadow var(--dur) var(--ease),
              background var(--dur) var(--ease),
              border-color var(--dur) var(--ease),
              color var(--dur) var(--ease);
}
.btn-gold {
  background: var(--gradient);
  color: var(--text-dark);
  font-weight:700;
  box-shadow: 0 4px 16px rgba(201,168,76,0.35);
}
.btn-gold:hover {
  transform:translateY(-2px);
  box-shadow: var(--shadow-gold);
}
.btn-outline {
  background:transparent;
  color:var(--text-primary);
  border-color:var(--border-mid);
}
.btn-outline:hover {
  border-color:var(--gold);
  color:var(--gold);
  background:var(--gold-pale);
}
.btn-dark {
  background: var(--navy);
  color: var(--gold);
  font-weight:700;
  box-shadow: var(--shadow-sm);
}
.btn-dark:hover { transform:translateY(-2px); box-shadow:var(--shadow-md); }
:focus-visible { outline:2px solid var(--gold); outline-offset:3px; border-radius:4px; }

/* ============================================================
   NAVEGACIÓN
   ============================================================ */
.site-nav {
  position:fixed; top:0; left:0; right:0;
  z-index:1000; padding:18px 0;
  background:rgba(7,20,42,0.92);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  transition:padding var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.site-nav.scrolled {
  padding:12px 0;
  box-shadow:0 4px 32px rgba(0,0,0,0.40);
  border-bottom-color:var(--border-mid);
}
.nav-inner {
  display:flex; align-items:center;
  justify-content:space-between; gap:24px;
}
.nav-logo {
  display:flex; align-items:center; gap:10px;
  font-family:var(--font-serif);
  font-size:20px; font-weight:700;
  letter-spacing:0.3px; flex-shrink:0;
  color:var(--text-primary);
}
.nav-logo-icon {
  width:34px; height:34px;
  background:var(--gradient);
  border-radius:8px;
  display:flex; align-items:center; justify-content:center;
  font-size:14px; font-weight:800; font-family:var(--font-sans);
  color:var(--text-dark); flex-shrink:0;
}
.nav-logo-text span { color:var(--gold); }

.nav-menu { display:flex; align-items:center; gap:32px; }
.nav-link {
  font-size:14px; font-weight:500;
  color:var(--text-secondary);
  transition:color var(--dur) var(--ease);
  position:relative;
}
.nav-link::after {
  content:''; position:absolute;
  bottom:-4px; left:0; width:0; height:1px;
  background:var(--gold);
  transition:width var(--dur) var(--ease);
}
.nav-link:hover { color:#fff; }
.nav-link:hover::after { width:100%; }

/* Dropdown */
.nav-item-has-children { position:relative; }
.nav-item-has-children::before {
  content:''; position:absolute;
  top:100%; left:-12px; right:-12px; height:18px; z-index:1000;
}
.nav-dropdown {
  position:absolute; top:calc(100% + 18px); left:50%;
  transform:translateX(-50%) translateY(-6px);
  min-width:240px;
  background:var(--navy-mid);
  border:1px solid var(--border-mid);
  border-radius:var(--radius-md);
  padding:6px;
  opacity:0; pointer-events:none;
  transition:opacity var(--dur) var(--ease), transform var(--dur) var(--ease);
  box-shadow:var(--shadow-lg); z-index:1001;
}
.nav-item-has-children:hover .nav-dropdown {
  opacity:1; pointer-events:all;
  transform:translateX(-50%) translateY(0);
}
.nav-item-has-children > .nav-link {
  display:inline-flex; align-items:center; gap:4px;
}
.nav-item-has-children > .nav-link::after { content:none; }
.nav-item-has-children > .nav-link::before {
  content:''; order:2;
  width:8px; height:5px;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 8 5' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l3 3 3-3' stroke='%239DB4CC' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-size:contain;
  transition:transform var(--dur) var(--ease); flex-shrink:0;
}
.nav-item-has-children:hover > .nav-link::before { transform:rotate(180deg); }
.nav-dropdown-link {
  display:block; padding:10px 14px;
  font-size:14px; font-weight:500;
  color:var(--text-secondary); border-radius:var(--radius-sm);
  transition:background var(--dur) var(--ease), color var(--dur) var(--ease), padding-left var(--dur) var(--ease);
}
.nav-dropdown-link:hover { background:var(--gold-pale); color:var(--gold); padding-left:18px; }

.nav-cta { display:flex; align-items:center; gap:12px; }
.nav-toggle {
  display:none; flex-direction:column; gap:5px;
  cursor:pointer; padding:4px; background:none; border:none;
}
.nav-toggle span {
  display:block; width:24px; height:2px;
  background:var(--text-primary); border-radius:2px;
  transition:transform var(--dur) var(--ease), opacity var(--dur) var(--ease);
}
.nav-toggle[aria-expanded="true"] span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity:0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }
.nav-mobile-menu {
  display:flex; flex-direction:column; align-items:center;
  justify-content:center; gap:36px;
  position:fixed; inset:0;
  background:var(--navy); z-index:999;
  opacity:0; pointer-events:none;
  transition:opacity var(--dur) var(--ease);
}
.nav-mobile-menu.is-open { opacity:1; pointer-events:all; }
.nav-mobile-menu ul { display:flex; flex-direction:column; align-items:center; gap:28px; }
.nav-mobile-menu .nav-link { font-size:20px; font-weight:700; color:var(--text-primary); }

/* ============================================================
   HERO
   ============================================================ */
.hero {
  min-height:100vh; display:flex; align-items:center;
  position:relative; overflow:hidden;
  padding:120px 0 80px;
  background:var(--navy);
}
.hero-blob {
  position:absolute; border-radius:50%;
  pointer-events:none; z-index:0;
}
.hero-blob-1 {
  width:700px; height:700px;
  top:-200px; right:-100px;
  background:radial-gradient(circle, rgba(201,168,76,0.10) 0%, transparent 65%);
  animation:blobFloat 14s ease-in-out infinite;
}
.hero-blob-2 {
  width:350px; height:350px;
  bottom:-100px; left:5%;
  background:radial-gradient(circle, rgba(201,168,76,0.06) 0%, transparent 70%);
  animation:blobFloat 18s ease-in-out infinite reverse;
}
.hero-grid-overlay {
  position:absolute; inset:0;
  background-image:radial-gradient(circle, rgba(201,168,76,0.07) 1px, transparent 1px);
  background-size:36px 36px;
  mask-image:radial-gradient(ellipse 70% 70% at 65% 40%, black 0%, transparent 100%);
  -webkit-mask-image:radial-gradient(ellipse 70% 70% at 65% 40%, black 0%, transparent 100%);
  z-index:0;
}
.hero-inner {
  position:relative; z-index:1;
  display:grid; grid-template-columns:1fr 1fr;
  gap:64px; align-items:center; width:100%;
}
.hero-eyebrow {
  display:inline-flex; align-items:center; gap:10px;
  padding:6px 16px;
  background:var(--gold-pale); border:1px solid var(--border-mid);
  border-radius:100px; font-size:12px; font-weight:600;
  color:var(--gold); margin-bottom:24px;
  text-transform:uppercase; letter-spacing:1px;
}
.hero-eyebrow::before {
  content:''; width:6px; height:6px;
  background:var(--gold); border-radius:50%;
  animation:pulseDot 2s ease-in-out infinite;
}
.hero h1 {
  font-family:var(--font-serif);
  font-size:clamp(2.4rem,4.8vw,3.8rem);
  font-weight:700; line-height:1.12;
  letter-spacing:-0.5px;
  color:var(--text-primary); margin-bottom:24px;
}
.hero-subtitle {
  font-size:18px; color:var(--text-secondary);
  line-height:1.75; max-width:500px; margin-bottom:40px;
}
.hero-actions { display:flex; align-items:center; gap:14px; flex-wrap:wrap; }
.hero-divider {
  display:flex; gap:32px; margin-top:52px;
  padding-top:36px; border-top:1px solid var(--border); flex-wrap:wrap;
}
.hero-stat-val {
  font-family:var(--font-serif);
  font-size:26px; font-weight:700;
  background:var(--gradient-text);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}
.hero-stat-lbl { font-size:12px; color:var(--text-muted); margin-top:2px; }

/* Hero visual */
.hero-visual { position:relative; height:460px; }
.hero-card {
  position:absolute;
  background:var(--navy-mid);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:24px; box-shadow:var(--shadow-md);
}
.hero-card-main {
  width:300px; top:50%; left:50%;
  transform:translate(-50%,-50%); z-index:3;
  animation:cardFloat 6s ease-in-out infinite;
  border-color:var(--border-mid);
}
.hero-card-sm-a {
  width:195px; top:6%; right:0; z-index:2;
  animation:cardFloat 8s ease-in-out infinite reverse;
  animation-delay:-2s;
}
.hero-card-sm-b {
  width:185px; bottom:8%; left:0; z-index:2;
  animation:cardFloat 7s ease-in-out infinite;
  animation-delay:-4s;
}
.hc-label { font-size:10px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; color:var(--gold); margin-bottom:14px; }
.hc-status { display:inline-flex; align-items:center; gap:6px; font-size:12px; font-weight:600; margin-bottom:12px; }
.hc-status::before { content:''; width:7px; height:7px; background:#22C55E; border-radius:50%; animation:pulseDot 2s ease-in-out infinite; }
.hc-score { font-family:var(--font-serif); font-size:40px; font-weight:700; line-height:1; margin-bottom:4px; }
.hc-score-lbl { font-size:12px; color:var(--text-muted); margin-bottom:16px; }
.hc-bars { display:flex; flex-direction:column; gap:8px; }
.hc-bar-item { display:flex; align-items:center; justify-content:space-between; gap:8px; font-size:11px; }
.hc-bar-label { color:var(--text-muted); width:90px; flex-shrink:0; }
.hc-bar-track { flex:1; height:4px; background:var(--border); border-radius:2px; overflow:hidden; }
.hc-bar-fill  { height:100%; background:var(--gradient); border-radius:2px; }
.hc-bar-val   { color:var(--gold-light); font-weight:600; width:28px; text-align:right; }
.hc-tag { display:inline-block; font-size:10px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:var(--gold); background:var(--gold-pale); border-radius:100px; padding:2px 10px; margin-bottom:10px; }
.hc-big  { font-family:var(--font-serif); font-size:28px; font-weight:700; color:var(--text-primary); margin-bottom:2px; }
.hc-sub  { font-size:11px; color:var(--text-muted); }

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee-section {
  background:var(--navy-mid); padding:28px 0;
  border-top:1px solid var(--border); border-bottom:1px solid var(--border);
  overflow:hidden;
}
.marquee-label { text-align:center; font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:2.5px; color:var(--text-muted); margin-bottom:18px; }
.marquee-wrap  { overflow:hidden; position:relative; }
.marquee-wrap::before,
.marquee-wrap::after {
  content:''; position:absolute; top:0; bottom:0; width:100px; z-index:2; pointer-events:none;
}
.marquee-wrap::before { left:0;  background:linear-gradient(to right, var(--navy-mid), transparent); }
.marquee-wrap::after  { right:0; background:linear-gradient(to left,  var(--navy-mid), transparent); }
.marquee-track {
  display:flex; gap:10px; width:max-content;
  animation:marqueeScroll 30s linear infinite;
}
.marquee-wrap:hover .marquee-track { animation-play-state:paused; }
.marquee-item {
  display:inline-flex; align-items:center; gap:7px;
  padding:7px 16px;
  background:var(--gold-pale2); border:1px solid var(--border);
  border-radius:100px; font-size:13px; font-weight:500;
  color:var(--text-secondary); white-space:nowrap;
  transition:background var(--dur) var(--ease), color var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.marquee-item:hover { background:var(--gold-pale); color:var(--gold); border-color:var(--border-mid); }
.marquee-item-dot { width:5px; height:5px; border-radius:50%; background:var(--gold); opacity:0.5; flex-shrink:0; }

/* ============================================================
   SECTION HEADER
   ============================================================ */
.section-header { text-align:center; max-width:620px; margin:0 auto 60px; }
.section-tag {
  display:inline-block; font-size:10px; font-weight:700;
  text-transform:uppercase; letter-spacing:2.5px;
  color:var(--gold); background:var(--gold-pale);
  border:1px solid var(--border); padding:4px 12px;
  border-radius:100px; margin-bottom:16px;
}
.section-header h2 {
  font-family:var(--font-serif);
  font-size:clamp(1.8rem,3vw,2.7rem); font-weight:700;
  letter-spacing:-0.3px; line-height:1.18; margin-bottom:16px;
}
.section-header p { color:var(--text-secondary); font-size:17px; line-height:1.75; }

/* ============================================================
   SERVICIOS (cards homepage)
   ============================================================ */
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }

.service-card {
  background:var(--navy-card);
  border:1px solid var(--border-subtle);
  border-radius:var(--radius-lg); padding:32px;
  position:relative; overflow:hidden;
  transition:border-color var(--dur) var(--ease),
              background var(--dur) var(--ease),
              transform var(--dur) var(--ease),
              box-shadow var(--dur) var(--ease);
  cursor:default; will-change:transform;
}
.service-card::before {
  content:''; position:absolute;
  top:0; left:0; right:0; height:2px;
  background:var(--gradient); opacity:0;
  transition:opacity var(--dur) var(--ease);
}
.service-card:hover {
  border-color:var(--border-mid);
  background:rgba(201,168,76,0.05);
  transform:translateY(-5px);
  box-shadow:var(--shadow-gold);
}
.service-card:hover::before { opacity:1; }

.service-icon {
  width:48px; height:48px;
  background:var(--gold-pale);
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  display:flex; align-items:center; justify-content:center;
  margin-bottom:20px; color:var(--gold); flex-shrink:0;
  transition:background var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.service-card:hover .service-icon { background:var(--gold); border-color:var(--gold); color:var(--text-dark); }
.service-icon svg { width:24px; height:24px; }

.service-card h3 {
  font-family:var(--font-serif);
  font-size:18px; font-weight:700;
  margin-bottom:10px; color:var(--text-primary);
  line-height:1.3;
}
.service-card p  { font-size:14px; color:var(--text-secondary); line-height:1.75; margin-bottom:18px; }
.service-tags    { display:flex; flex-wrap:wrap; gap:6px; margin-bottom:18px; }
.service-tag-item {
  font-size:11px; font-weight:500;
  padding:3px 10px;
  background:var(--gold-pale2); border:1px solid var(--border);
  border-radius:100px; color:var(--gold-light);
}
.service-card-link {
  display:inline-flex; align-items:center; gap:6px;
  font-size:13px; font-weight:700; color:var(--gold);
  transition:gap var(--dur) var(--ease), color var(--dur) var(--ease);
}
.service-card-link:hover { gap:10px; color:var(--gold-bright); }
.service-card-link svg { width:14px; height:14px; }

/* ============================================================
   ¿POR QUÉ IZ LEGAL?
   ============================================================ */
.why-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:0; }
.why-item {
  padding:36px;
  border-bottom:1px solid var(--border-subtle);
  border-right:1px solid var(--border-subtle);
  transition:background var(--dur) var(--ease);
}
.why-item:hover { background:var(--gold-pale2); }
.why-item:nth-child(2n) { border-right:none; }
.why-item:nth-last-child(-n+2) { border-bottom:none; }
.why-num {
  font-family:var(--font-serif);
  font-size:36px; font-weight:700;
  background:var(--gradient-text);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text; line-height:1;
  margin-bottom:14px;
}
.why-item h3 { font-family:var(--font-serif); font-size:18px; font-weight:700; margin-bottom:10px; }
.why-item p  { font-size:14px; color:var(--text-secondary); line-height:1.75; }

/* ============================================================
   FEATURE GRID (páginas de servicio)
   ============================================================ */
.feature-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.feature-card {
  background:var(--navy-card); border:1px solid var(--border-subtle);
  border-radius:var(--radius-md); padding:26px;
  transition:border-color var(--dur) var(--ease), transform var(--dur) var(--ease), background var(--dur) var(--ease);
}
.feature-card:hover { border-color:var(--border-mid); background:rgba(201,168,76,0.04); transform:translateY(-3px); }
.feature-card-icon {
  width:44px; height:44px;
  background:var(--gold-pale); border:1px solid var(--border);
  border-radius:var(--radius-sm);
  display:flex; align-items:center; justify-content:center;
  margin-bottom:16px; color:var(--gold);
  transition:background var(--dur) var(--ease), color var(--dur) var(--ease);
}
.feature-card:hover .feature-card-icon { background:var(--gold); color:var(--text-dark); }
.feature-card-icon svg { width:22px; height:22px; }
.feature-card h3 { font-family:var(--font-serif); font-size:16px; font-weight:700; margin-bottom:8px; }
.feature-card p  { font-size:13px; color:var(--text-secondary); line-height:1.72; }

/* ============================================================
   PROCESO
   ============================================================ */
.process-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:0; }
.process-step { position:relative; padding:28px 24px; text-align:center; }
.process-step:not(:last-child)::after {
  content:''; position:absolute;
  top:28px; right:-14%; width:28%; height:1px;
  background:linear-gradient(to right, var(--gold), transparent);
}
.process-step-num {
  width:42px; height:42px;
  background:var(--gradient);
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-serif); font-size:16px; font-weight:700;
  color:var(--text-dark); margin:0 auto 16px;
  position:relative; z-index:1;
  box-shadow:0 4px 16px rgba(201,168,76,0.35);
}
.process-step h4 { font-family:var(--font-serif); font-size:15px; font-weight:700; margin-bottom:6px; }
.process-step p  { font-size:12px; color:var(--text-secondary); line-height:1.65; }

/* ============================================================
   BLOG
   ============================================================ */
.blog-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.blog-card {
  background:var(--navy-card); border:1px solid var(--border-subtle);
  border-radius:var(--radius-lg); overflow:hidden;
  transition:border-color var(--dur) var(--ease), transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.blog-card:hover { border-color:var(--border-mid); transform:translateY(-5px); box-shadow:var(--shadow-gold); }
.blog-card-img {
  height:180px; background:var(--navy-mid);
  display:flex; align-items:center; justify-content:center;
  position:relative; overflow:hidden;
}
.blog-card-img-placeholder {
  width:100%; height:100%;
  background:linear-gradient(135deg, var(--navy-mid) 0%, var(--navy-light) 100%);
  display:flex; align-items:center; justify-content:center;
}
.blog-card-img-placeholder svg { width:40px; height:40px; opacity:0.3; color:var(--gold); }
.blog-card-body { padding:24px; }
.blog-card-meta { display:flex; align-items:center; gap:12px; margin-bottom:12px; }
.blog-card-cat {
  font-size:10px; font-weight:700; text-transform:uppercase;
  letter-spacing:1.5px; color:var(--gold);
  background:var(--gold-pale); border:1px solid var(--border);
  padding:3px 10px; border-radius:100px;
}
.blog-card-date { font-size:12px; color:var(--text-muted); }
.blog-card h3 {
  font-family:var(--font-serif);
  font-size:17px; font-weight:700; line-height:1.35;
  margin-bottom:10px; color:var(--text-primary);
  transition:color var(--dur) var(--ease);
}
.blog-card:hover h3 { color:var(--gold-light); }
.blog-card p  { font-size:13px; color:var(--text-secondary); line-height:1.7; margin-bottom:16px; }
.blog-card-link {
  display:inline-flex; align-items:center; gap:6px;
  font-size:13px; font-weight:700; color:var(--gold);
  transition:gap var(--dur) var(--ease);
}
.blog-card-link:hover { gap:10px; }
.blog-card-link svg { width:14px; height:14px; }

/* Blog archive / single */
.blog-archive-header { padding:120px 0 60px; border-bottom:1px solid var(--border); }
.blog-archive-header h1 { font-family:var(--font-serif); font-size:clamp(2rem,4vw,3rem); font-weight:700; margin-bottom:12px; }
.blog-archive-header p  { color:var(--text-secondary); font-size:17px; }
.blog-archive-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:24px; padding:var(--section-y) 0; }

.single-header { padding:120px 0 56px; border-bottom:1px solid var(--border); }
.single-header .blog-card-meta { margin-bottom:20px; }
.single-header h1 { font-family:var(--font-serif); font-size:clamp(2rem,3.5vw,2.8rem); font-weight:700; line-height:1.2; max-width:800px; }
.single-content { max-width:760px; padding:var(--section-y) 0; }
.single-content h2,.single-content h3 { font-family:var(--font-serif); font-weight:700; }
.single-content h2 { font-size:1.6rem; margin:36px 0 14px; }
.single-content h3 { font-size:1.2rem; margin:28px 0 10px; }
.single-content p  { color:var(--text-secondary); line-height:1.85; margin-bottom:18px; }
.single-content ul,.single-content ol { color:var(--text-secondary); padding-left:20px; margin-bottom:18px; line-height:1.8; }
.single-content a  { color:var(--gold-light); text-decoration:underline; }
.single-content strong { color:var(--text-primary); }

/* ============================================================
   CTA — DOS VARIANTES
   ============================================================ */
/* Variante dorada (páginas de servicio) */
.cta-inner {
  background:var(--gradient);
  border-radius:var(--radius-lg); padding:72px 56px;
  text-align:center; position:relative; overflow:hidden;
}
.cta-inner::before {
  content:''; position:absolute;
  top:-80px; left:50%; transform:translateX(-50%);
  width:400px; height:400px;
  background:radial-gradient(circle, rgba(255,255,255,0.12) 0%, transparent 70%);
  pointer-events:none;
}
.cta-inner > .section-tag {
  background:rgba(7,20,42,0.25); border-color:rgba(7,20,42,0.20);
  color:var(--text-dark); margin-bottom:14px;
}
.cta-inner h2 {
  font-family:var(--font-serif);
  font-size:clamp(1.8rem,3vw,2.6rem); font-weight:700;
  margin-bottom:14px; color:var(--text-dark);
}
.cta-inner .cta-desc { color:rgba(7,20,42,0.70); max-width:500px; margin:0 auto 44px; font-size:17px; line-height:1.75; }

/* Variante oscura (homepage — con formulario) */
.cta-inner-dark {
  background:var(--navy-mid);
  border:1px solid var(--border-mid);
  box-shadow:var(--shadow-md);
}
.cta-inner-dark > .section-tag  { background:var(--gold-pale); color:var(--gold); }
.cta-inner-dark h2               { color:var(--text-primary); }
.cta-inner-dark .cta-desc        { color:var(--text-secondary); }

/* Formulario */
.contact-form { max-width:680px; margin:0 auto; text-align:left; }
.contact-form-grid { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-bottom:20px; }
.form-group { display:flex; flex-direction:column; gap:6px; }
.form-group--full { grid-column:1/-1; }
.form-label { font-size:13px; font-weight:600; color:var(--text-secondary); }
.form-label span { color:var(--gold); }
.form-input {
  width:100%; padding:12px 14px;
  background:rgba(255,255,255,0.06);
  border:1.5px solid var(--border-subtle);
  border-radius:var(--radius-sm); color:var(--text-primary);
  font-family:var(--font-sans); font-size:15px;
  transition:border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
  outline:none; -webkit-appearance:none;
}
.form-input::placeholder { color:var(--text-muted); }
.form-input:focus { border-color:var(--gold); box-shadow:0 0 0 3px rgba(201,168,76,0.15); }
.form-textarea { resize:vertical; min-height:120px; line-height:1.6; }
.contact-form .btn { display:flex; margin:0 auto; }
.contact-alert { border-radius:var(--radius-sm); padding:14px 18px; font-size:14px; margin-bottom:24px; }
.contact-alert--success { background:rgba(34,197,94,0.08); border:1px solid rgba(34,197,94,0.25); color:#4ade80; }
.contact-alert--error   { background:rgba(239,68,68,0.08);  border:1px solid rgba(239,68,68,0.25);  color:#f87171; }

/* ============================================================
   PAGE HERO (páginas interiores)
   ============================================================ */
.page-hero {
  padding:140px 0 72px;
  background:var(--navy-mid);
  border-bottom:1px solid var(--border);
  position:relative; overflow:hidden;
}
.page-hero::before {
  content:''; position:absolute;
  top:-150px; right:-80px;
  width:500px; height:500px;
  background:radial-gradient(circle, rgba(201,168,76,0.08) 0%, transparent 70%);
  pointer-events:none;
}
.page-hero-inner { position:relative; z-index:1; max-width:760px; }
.page-breadcrumb { display:flex; align-items:center; gap:8px; font-size:13px; color:var(--text-muted); margin-bottom:20px; }
.page-breadcrumb a { color:var(--gold-light); transition:color var(--dur) var(--ease); }
.page-breadcrumb a:hover { color:#fff; }
.page-hero-tag {
  display:inline-block; font-size:10px; font-weight:700;
  text-transform:uppercase; letter-spacing:2px;
  color:var(--gold); background:var(--gold-pale);
  border:1px solid var(--border); padding:4px 12px;
  border-radius:100px; margin-bottom:18px;
}
.page-hero h1 {
  font-family:var(--font-serif);
  font-size:clamp(2rem,4vw,3rem); font-weight:700;
  letter-spacing:-0.3px; line-height:1.12; margin-bottom:18px;
}
.page-hero-desc {
  font-size:18px; color:var(--text-secondary);
  line-height:1.75; max-width:620px; margin-bottom:32px;
}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer {
  background:#040d1c;
  border-top:1px solid var(--border);
  padding:64px 0 32px;
}
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr; gap:60px; margin-bottom:48px; }
.footer-brand-logo {
  display:flex; align-items:center; gap:10px;
  font-family:var(--font-serif); font-size:20px; font-weight:700;
  color:var(--text-primary); margin-bottom:14px;
}
.footer-logo-icon {
  width:32px; height:32px;
  background:var(--gradient); border-radius:7px;
  display:flex; align-items:center; justify-content:center;
  font-size:13px; font-weight:800; font-family:var(--font-sans);
  color:var(--text-dark); flex-shrink:0;
}
.footer-brand-desc { font-size:14px; color:rgba(255,255,255,0.45); line-height:1.75; max-width:300px; margin-bottom:22px; }
.footer-socials { display:flex; gap:10px; }
.footer-social-link {
  width:36px; height:36px; display:flex; align-items:center; justify-content:center;
  background:rgba(201,168,76,0.07); border:1px solid var(--border);
  border-radius:9px;
  transition:background var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.footer-social-link:hover { background:var(--gold-pale); border-color:var(--border-mid); }
.footer-social-link svg { width:15px; height:15px; fill:rgba(255,255,255,0.4); transition:fill var(--dur) var(--ease); }
.footer-social-link:hover svg { fill:var(--gold); }
.footer-col-title { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:2px; color:var(--text-muted); margin-bottom:18px; }
.footer-links { display:flex; flex-direction:column; gap:12px; }
.footer-link { font-size:14px; color:rgba(255,255,255,0.50); transition:color var(--dur) var(--ease); }
.footer-link:hover { color:var(--gold-light); }
.footer-bottom {
  padding-top:28px; border-top:1px solid var(--border);
  display:flex; align-items:center; justify-content:space-between;
  gap:16px; flex-wrap:wrap;
}
.footer-copyright { font-size:13px; color:rgba(255,255,255,0.25); }

/* ============================================================
   GRIDS INLINE
   ============================================================ */
.inline-grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.inline-grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }

/* ============================================================
   ANIMACIONES
   ============================================================ */
@keyframes blobFloat {
  0%,100% { transform:translate(0,0) scale(1); }
  33%      { transform:translate(30px,-25px) scale(1.04); }
  66%      { transform:translate(-20px,18px) scale(0.97); }
}
@keyframes cardFloat {
  0%,100% { transform:translate(-50%,-50%) translateY(0); }
  50%      { transform:translate(-50%,-50%) translateY(-14px); }
}
@keyframes pulseDot {
  0%,100% { opacity:1; transform:scale(1); }
  50%      { opacity:0.35; transform:scale(0.7); }
}
@keyframes marqueeScroll {
  from { transform:translateX(0); }
  to   { transform:translateX(-50%); }
}
.animate-on-scroll {
  opacity:0; transform:translateY(24px);
  transition:opacity 0.6s var(--ease), transform 0.6s var(--ease);
}
.animate-on-scroll.is-visible { opacity:1; transform:translateY(0); }

/* ============================================================
   BANNER DE COOKIES
   ============================================================ */
.cookie-banner {
  position:fixed; bottom:0; left:0; right:0;
  z-index:9998;
  background:var(--navy-mid);
  border-top:1px solid var(--border-mid);
  box-shadow:0 -4px 32px rgba(0,0,0,0.40);
  transform:translateY(100%);
  transition:transform 0.4s var(--ease);
  padding:18px 0;
}
.cookie-banner.is-visible { transform:translateY(0); }
.cookie-banner-inner {
  max-width:var(--container); margin:0 auto; padding:0 24px;
  display:flex; align-items:center;
  justify-content:space-between; gap:20px; flex-wrap:wrap;
}
.cookie-banner-text h3 {
  font-family:var(--font-serif);
  font-size:14px; font-weight:700; color:var(--text-primary); margin-bottom:3px;
}
.cookie-banner-text p { font-size:13px; color:var(--text-secondary); }
.cookie-banner-text a { color:var(--gold-light); text-decoration:underline; }
.cookie-banner-actions {
  display:flex; align-items:center; gap:8px; flex-shrink:0; flex-wrap:wrap;
}
.btn-ck {
  padding:9px 16px; border-radius:var(--radius-sm);
  font-size:13px; font-weight:600; cursor:pointer;
  transition:all var(--dur) var(--ease); white-space:nowrap;
  font-family:var(--font-sans);
}
.btn-ck-config    { background:transparent; border:1.5px solid var(--border-subtle); color:var(--text-secondary); }
.btn-ck-config:hover { border-color:var(--border-mid); color:var(--gold); }
.btn-ck-necessary { background:var(--gold-pale2); border:1.5px solid var(--border); color:var(--gold-light); }
.btn-ck-necessary:hover { background:var(--gold-pale); border-color:var(--border-mid); }
.btn-ck-accept    { background:var(--gradient); border:none; color:var(--text-dark); font-weight:700; box-shadow:0 4px 12px rgba(201,168,76,0.30); }
.btn-ck-accept:hover { box-shadow:0 6px 20px rgba(201,168,76,0.45); }
@media (max-width:640px) {
  .cookie-banner-inner { flex-direction:column; align-items:flex-start; }
  .cookie-banner-actions { width:100%; }
  .btn-ck { flex:1; text-align:center; }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px) {
  .hero-inner   { grid-template-columns:1fr; }
  .hero-visual  { display:none; }
  .services-grid{ grid-template-columns:repeat(2,1fr); }
  .why-grid     { grid-template-columns:1fr; }
  .why-item     { border-right:none !important; }
  .feature-grid { grid-template-columns:repeat(2,1fr); }
  .process-grid { grid-template-columns:repeat(2,1fr); }
  .process-step::after { display:none; }
  .blog-grid    { grid-template-columns:repeat(2,1fr); }
  .blog-archive-grid { grid-template-columns:1fr; }
  .footer-grid  { grid-template-columns:1fr 1fr; }
}
@media (max-width:768px) {
  :root { --section-y:68px; }
  .nav-menu     { display:none; }
  .nav-cta .btn { display:none; }
  .nav-toggle   { display:flex; }
  .hero h1      { letter-spacing:0; }
  .hero-divider { gap:20px; }
  .services-grid{ grid-template-columns:1fr; }
  .feature-grid { grid-template-columns:1fr; }
  .process-grid { grid-template-columns:1fr; }
  .blog-grid    { grid-template-columns:1fr; }
  .cta-inner    { padding:44px 24px; }
  .contact-form-grid { grid-template-columns:1fr; }
  .footer-grid  { grid-template-columns:1fr; gap:36px; }
  .footer-bottom{ flex-direction:column; align-items:flex-start; }
  .inline-grid-2,.inline-grid-3 { grid-template-columns:1fr; }
  .page-hero    { padding:110px 0 52px; }
}
@media (max-width:480px) {
  .hero-actions  { flex-direction:column; width:100%; }
  .hero-actions .btn { width:100%; justify-content:center; }
}
@media (prefers-reduced-motion:reduce) {
  .animate-on-scroll { opacity:1; transform:none; transition:none; }
  .hero-blob,.hero-card-main,.hero-card-sm-a,.hero-card-sm-b,
  .hc-status::before,.hero-eyebrow::before,.marquee-track { animation:none; }
}
::-webkit-scrollbar { width:6px; }
::-webkit-scrollbar-track { background:var(--navy); }
::-webkit-scrollbar-thumb { background:rgba(201,168,76,0.30); border-radius:3px; }
::-webkit-scrollbar-thumb:hover { background:rgba(201,168,76,0.55); }
