/* ═══════════════════════════════════════════════════
   ChatZona — main.css v4.0 — Layout + Component Utils
   Cargado automáticamente por czHead() en todos los templates
   ═══════════════════════════════════════════════════ */

/* DESIGN TOKENS v4 */
:root{
  /* Core v4 variables */
  --blue:#1a56db;--blue-d:#1447c0;--blue-l:#eff5ff;--blue-m:#dbeafe;--blue-b:#93c5fd;
  --amber:#f59e0b;--amber-d:#d97706;--amber-l:#fef3c7;
  --ink:#0f172a;--mid:#64748b;--soft:#94a3b8;--line:#e2e8f0;--bg:#f8fafc;--white:#ffffff;
  --green:#059669;--red:#dc2626;

  /* --cz-* aliases — used by templates for backward compatibility */
  --cz-fd:'Bricolage Grotesque',sans-serif;
  --cz-fu:'Plus Jakarta Sans',system-ui,sans-serif;
  --cz-fm:'Plus Jakarta Sans',system-ui,sans-serif;
  --cz-font-head:'Bricolage Grotesque',sans-serif;
  --cz-bg:#f8fafc;
  --cz-live:#059669;--cz-green:#059669;--cz-red:#dc2626;
  --cz-fb:'Plus Jakarta Sans',system-ui,sans-serif;
  --cz-blue:#1a56db;--cz-blue-d:#1447c0;
  --cz-blue-900:#0e1f5c;--cz-blue-700:#1447c0;--cz-blue-600:#1a56db;
  --cz-blue-500:#1a56db;--cz-blue-400:#3b82f6;--cz-blue-300:#93c5fd;
  --cz-blue-200:#dbeafe;--cz-blue-100:#eff5ff;--cz-blue-50:#f0f7ff;
  --cz-ink:#0f172a;
  --cz-ink-700:#1e293b;--cz-ink-600:#334155;--cz-ink-500:#64748b;
  --cz-ink-400:#94a3b8;--cz-ink-300:#cbd5e1;--cz-ink-200:#e2e8f0;
  --cz-ink-100:#f1f5f9;--cz-ink-50:#f8fafc;
  --cz-amber:#f59e0b;--cz-amber-600:#d97706;--cz-amber-500:#f59e0b;
  --cz-amber-400:#fbbf24;--cz-amber-300:#fcd34d;--cz-amber-50:#fef3c7;
  --cz-deep-700:#1e3a5f;--cz-deep-800:#0f2744;
  --cz-r-sm:8px;--cz-r-md:12px;--cz-r-lg:20px;
  --cz-sh-xs:0 1px 2px rgba(0,0,0,.04);
  --cz-sh-sm:0 1px 3px rgba(0,0,0,.06),0 2px 8px rgba(0,0,0,.04);
  --cz-sh-md:0 4px 16px rgba(26,86,219,.10);
  --cz-sh-lg:0 8px 32px rgba(26,86,219,.14);
  --cz-sh-glow:0 0 0 3px rgba(26,86,219,.12);
  --cz-s2:2px;--cz-s3:3px;
  /* legacy shorthand aliases */
  --r:10px;--rl:16px;--rx:24px;
  --fh:'Bricolage Grotesque',sans-serif;
  --fb:'Plus Jakarta Sans',system-ui,sans-serif;
  --ff:'Plus Jakarta Sans',system-ui,sans-serif;
  --ff-head:'Bricolage Grotesque',sans-serif;
  --font-head:'Bricolage Grotesque',sans-serif;
  --font-body:'Plus Jakarta Sans',system-ui,sans-serif;
  --s1:0 1px 3px rgba(15,23,42,.06),0 1px 2px rgba(15,23,42,.04);
  --s2:0 4px 16px rgba(26,86,219,.08),0 1px 4px rgba(15,23,42,.04);
  --s3:0 8px 32px rgba(26,86,219,.12);
  --shadow-sm:var(--cz-sh-sm);--shadow-md:var(--cz-sh-md);--shadow-lg:var(--cz-sh-lg);
  --shadow-search:0 4px 16px rgba(26,86,219,.12);
  /* blue scale aliases (without cz- prefix) */
  --blue-50:var(--cz-blue-50);--blue-100:var(--cz-blue-100);--blue-200:var(--cz-blue-200);
  --blue-300:var(--cz-blue-300);--blue-400:var(--cz-blue-400);--blue-600:var(--cz-blue-600);
  --blue-700:var(--cz-blue-700);--blue-900:var(--cz-blue-900);
  /* ink scale aliases */
  --ink-50:var(--cz-ink-50);--ink-100:var(--cz-ink-100);--ink-200:var(--cz-ink-200);
  --ink-300:var(--cz-ink-300);--ink-400:var(--cz-ink-400);--ink-500:var(--cz-ink-500);
  --ink-600:var(--cz-ink-600);--ink-700:var(--cz-ink-700);--ink-900:#0a0f1e;
  --ink-2:var(--cz-ink-500);--ink-3:var(--cz-ink-400);
  /* radius aliases */
  --r-sm:var(--cz-r-sm);--r-md:var(--cz-r-md);--r-lg:var(--cz-r-lg);--r-xl:24px;--r-full:999px;
  /* green/amber/color aliases */
  --green-500:#059669;--green-700:#047857;--green-l:#d1fae5;--green-lt:#ecfdf5;
  --cz-green-100:#d1fae5;--cz-green-600:#059669;--cz-green-700:#047857;
  --cz-amber-700:#b45309;--cz-ink-900:#0a0f1e;
  --red-l:#fee2e2;--orange:#f97316;--yellow:#f59e0b;--yellow-dk:#d97706;
  --hdr-h:60px;
}

/* RESET BÁSICO */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--cz-fu,'Plus Jakarta Sans',system-ui,sans-serif);background:var(--bg,#f8fafc);color:var(--ink,#0f172a);-webkit-font-smoothing:antialiased;overflow-x:hidden;line-height:1.6}
a{text-decoration:none;color:inherit}
button{font-family:inherit;cursor:pointer;border:none;background:none}
img{display:block;max-width:100%;height:auto}

/* ACCESIBILIDAD */
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}
.skip-link{position:absolute;top:-40px;left:0;background:var(--blue,#1a56db);color:#fff;padding:8px 16px;z-index:9999;border-radius:0 0 8px 0;font-weight:700;transition:top .2s}
.skip-link:focus{top:0}
:focus-visible{outline:2px solid var(--blue,#1a56db);outline-offset:2px;border-radius:4px}

/* LAYOUT */
.container{max-width:1240px;margin:0 auto;padding:0 24px}
.w,.cz-w{max-width:1240px;margin:0 auto;padding:0 24px}
.w-sm{max-width:860px;margin:0 auto;padding:0 24px}
.w-xs{max-width:640px;margin:0 auto;padding:0 24px}

/* GRIDS */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.grid-auto{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}
.content-sidebar{display:grid;grid-template-columns:1fr 320px;gap:24px;align-items:start}

/* BOTONES */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 22px;border-radius:10px;font-family:var(--cz-fd,'Bricolage Grotesque',sans-serif);font-weight:800;font-size:15px;cursor:pointer;transition:all .2s;text-decoration:none;border:none}
.btn-primary{background:var(--blue,#1a56db);color:#fff;box-shadow:0 4px 20px rgba(26,86,219,.3)}
.btn-primary:hover{background:var(--blue-d,#1447c0);transform:translateY(-2px)}
.btn-secondary{background:#fff;color:var(--blue,#1a56db);border:2px solid var(--blue,#1a56db)}
.btn-secondary:hover{background:var(--blue-l,#eff5ff)}
.btn-sm{padding:8px 16px;font-size:13px}
.btn-ghost{background:transparent;color:var(--mid,#64748b);border:1.5px solid var(--line,#e2e8f0)}
.btn-ghost:hover{border-color:var(--blue,#1a56db);color:var(--blue,#1a56db)}

/* CARDS */
.card{background:#fff;border:1.5px solid var(--line,#e2e8f0);border-radius:14px;transition:all .22s}
.card:hover{box-shadow:0 8px 30px rgba(26,86,219,.1);transform:translateY(-3px);border-color:var(--blue-b,#93c5fd)}
.card-body{padding:16px 20px}

/* SECCIONES */
.sec{padding:52px 0}
.sec-alt{background:#fff}
.sh{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:24px;gap:12px;flex-wrap:wrap}
.sh-tag{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--blue,#1a56db);margin-bottom:4px}
.sh-title{font-family:var(--cz-fd,'Bricolage Grotesque',sans-serif);font-size:clamp(20px,3vw,26px);font-weight:800;color:var(--ink,#0f172a);letter-spacing:-.5px}
.sh-link{font-size:13px;font-weight:600;color:var(--blue,#1a56db);white-space:nowrap;flex-shrink:0}
.sh-link:hover{text-decoration:underline}

/* PAGE HERO */
.ph{padding:40px 0 28px;background:linear-gradient(160deg,var(--blue-l,#eff5ff),#fff)}
.ph-title{font-family:var(--cz-fd,'Bricolage Grotesque',sans-serif);font-size:clamp(26px,4vw,40px);font-weight:800;color:var(--ink,#0f172a);letter-spacing:-.5px;margin-bottom:6px}
.ph-sub{font-size:16px;color:var(--mid,#64748b);line-height:1.6}
.ph-hero{padding:52px 0 40px}

/* BREADCRUMB */
.cz-crumb{padding:10px 0;border-bottom:1px solid var(--line,#e2e8f0);background:#fff}
.cz-crumb-in{display:flex;align-items:center;gap:6px;font-size:12.5px;color:var(--mid,#64748b)}
.cz-crumb-in a{color:var(--mid,#64748b);transition:color .15s}
.cz-crumb-in a:hover{color:var(--blue,#1a56db)}
.cz-crumb-in .sep{color:var(--soft,#94a3b8)}
.cz-crumb-in .cur{color:var(--ink,#0f172a)}

/* BADGES */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:100px;font-size:11px;font-weight:700}
.badge-blue{background:var(--blue-l,#eff5ff);color:var(--blue,#1a56db)}
.badge-amber{background:var(--amber-l,#fef3c7);color:var(--amber,#f59e0b)}
.badge-green{background:#d1fae5;color:#059669}
.badge-red{background:#fee2e2;color:#dc2626}

/* PILLS / TAGS */
.tag{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;border-radius:100px;font-size:12px;font-weight:600;background:var(--bg,#f8fafc);border:1.5px solid var(--line,#e2e8f0);color:var(--mid,#64748b);transition:all .15s}
.tag:hover,.tag.on{background:var(--blue-l,#eff5ff);border-color:var(--blue-b,#93c5fd);color:var(--blue,#1a56db)}

/* CZ- COMPONENT SYSTEM (newer templates) */
.cz-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:10px;font-family:var(--cz-fd,'Bricolage Grotesque',sans-serif);font-weight:700;font-size:14px;cursor:pointer;transition:all .2s;text-decoration:none;border:none;white-space:nowrap}
.cz-btn--primary{background:var(--blue,#1a56db);color:#fff;box-shadow:0 4px 20px rgba(26,86,219,.3)}
.cz-btn--primary:hover{background:var(--blue-d,#1447c0);transform:translateY(-1px);box-shadow:0 6px 24px rgba(26,86,219,.4)}
.cz-btn--ghost{background:transparent;color:var(--blue,#1a56db);border:1.5px solid var(--blue,#1a56db)}
.cz-btn--ghost:hover{background:var(--blue-l,#eff5ff)}
.cz-btn--block{display:flex;width:100%}
.cz-btn--display{padding:14px 28px;font-size:16px}
.cz-card{background:#fff;border:1.5px solid var(--line,#e2e8f0);border-radius:14px;padding:16px;transition:all .22s}
.cz-card:hover{border-color:var(--blue-b,#93c5fd);box-shadow:0 4px 16px rgba(26,86,219,.1)}
.cz-chip{display:inline-flex;align-items:center;gap:5px;padding:5px 14px;border-radius:100px;font-size:13px;font-weight:600;background:var(--bg,#f8fafc);border:1.5px solid var(--line,#e2e8f0);color:var(--mid,#64748b);transition:all .15s;text-decoration:none;white-space:nowrap;cursor:pointer}
.cz-chip:hover,.cz-chip.on{background:var(--blue,#1a56db);color:#fff;border-color:var(--blue,#1a56db)}
.cz-sh{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:20px;gap:12px;flex-wrap:wrap}
.cz-sh-kicker,.cz-sh-tag{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--blue,#1a56db);margin-bottom:4px}
.cz-sh-title{font-family:var(--cz-fd,'Bricolage Grotesque',sans-serif);font-size:clamp(18px,3vw,24px);font-weight:800;color:var(--ink,#0f172a);letter-spacing:-.5px}
.cz-sh-link{font-size:13px;font-weight:600;color:var(--blue,#1a56db);white-space:nowrap;flex-shrink:0;text-decoration:none}
.cz-sh-link:hover{text-decoration:underline}

/* ESTRELLAS */
.stars{color:#f59e0b;font-size:14px;letter-spacing:1px}

/* FORMS */
.form-group{margin-bottom:16px}
.form-label{display:block;font-size:12px;font-weight:700;color:var(--mid,#64748b);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}
.form-input,.form-select,.form-textarea{width:100%;padding:10px 14px;border:1.5px solid var(--line,#e2e8f0);border-radius:8px;font-size:14px;font-family:inherit;color:var(--ink,#0f172a);outline:none;transition:border-color .18s;background:#fff}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--blue,#1a56db);box-shadow:0 0 0 3px rgba(26,86,219,.1)}
.form-textarea{resize:vertical;min-height:80px}

/* SIDEBAR */
.sidebar-box{background:#fff;border:1.5px solid var(--line,#e2e8f0);border-radius:14px;overflow:hidden;margin-bottom:20px}
.sidebar-box-head{padding:12px 16px;border-bottom:1px solid var(--line,#e2e8f0);font-family:var(--cz-fd,'Bricolage Grotesque',sans-serif);font-size:14px;font-weight:800;color:var(--ink,#0f172a)}
.sidebar-box-body{padding:16px}

/* NEWSLETTER WIDGET */
.nl-msg{font-size:13px;margin-top:8px;padding:8px 12px;border-radius:8px;display:none}
.nl-msg:not(:empty){display:block}
.nl-ok{background:#d1fae5;color:#059669}
.nl-err{background:#fee2e2;color:#dc2626}

/* PAGINACIÓN */
.pagination{display:flex;gap:6px;justify-content:center;margin-top:32px;flex-wrap:wrap}
.page-btn{width:38px;height:38px;border-radius:8px;border:1.5px solid var(--line,#e2e8f0);background:#fff;color:var(--mid,#64748b);font-weight:700;font-size:14px;cursor:pointer;transition:all .18s;display:flex;align-items:center;justify-content:center;text-decoration:none}
.page-btn:hover,.page-btn.active{background:var(--blue,#1a56db);border-color:var(--blue,#1a56db);color:#fff}

/* AD SLOTS */
.ad-slot{text-align:center;overflow:hidden;display:flex;align-items:center;justify-content:center}
.ad-728x90{min-height:90px;width:100%;max-width:728px;margin:0 auto}
.ad-300x250{min-height:250px;width:100%;max-width:300px}
.ad-300x600{min-height:600px;width:100%;max-width:300px}

/* STICKY CTA MÓVIL */
.cz-sticky-cta{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--blue,#1a56db);z-index:200;padding:0}
.cz-sticky-cta a{display:block;padding:14px;text-align:center;color:#fff;font-family:var(--cz-fd,'Bricolage Grotesque',sans-serif);font-weight:800;font-size:15px}

/* CANAL: Nick Card */
.nick-card{background:#fff;border:2px solid var(--blue,#1a56db);border-radius:20px;padding:24px;box-shadow:0 4px 24px rgba(26,86,219,.12)}
.nick-input{width:100%;padding:12px 16px;border:1.5px solid var(--line,#e2e8f0);border-radius:10px;font-size:16px;font-family:inherit;outline:none;transition:border-color .18s;background:#fff}
.nick-input:focus{border-color:var(--blue,#1a56db);box-shadow:0 0 0 3px rgba(26,86,219,.1)}

/* RESPONSIVE */
@media(max-width:1024px){
  .content-sidebar{grid-template-columns:1fr}
  .grid-4{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .grid-2{grid-template-columns:1fr}
  .sec{padding:36px 0}
  .ph{padding:28px 0 20px}
  .cz-sticky-cta{display:block}
  .content-sidebar{grid-template-columns:1fr}
}
@media(max-width:480px){
  .grid-3,.grid-4{grid-template-columns:1fr}
  .w,.container{padding:0 16px}
  .sh{flex-direction:column;align-items:flex-start}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;transition-duration:.01ms!important}
}

/* TOUCH TARGETS WCAG 2.1 AA — mínimo 44x44px en mobile */
@media(max-width:768px){
  .btn,.cz-btn{min-height:44px;padding-top:12px;padding-bottom:12px}
  .cz-chip{min-height:36px;padding-top:8px;padding-bottom:8px}
  a.cz-chip,a.btn,a.cz-btn{display:inline-flex;align-items:center;justify-content:center}
  /* Larger tap area for navigation links */
  nav a,.cz-nav a{min-height:44px;display:inline-flex;align-items:center}
  /* Form inputs for mobile readability */
  input[type="text"],input[type="email"],input[type="search"],textarea,select{
    font-size:16px; /* Prevents iOS zoom on focus */
    min-height:44px;
    padding:10px 14px;
  }
  /* Improved spacing between clickable items */
  .filter-bar a,.filter-bar select{margin:4px 2px}
}

/* MOBILE OPTIMIZATIONS */
@media(max-width:640px){
  /* Reduce typography slightly */
  body{font-size:15px}
  h1{font-size:clamp(22px,5vw,32px)}
  h2{font-size:clamp(18px,4vw,24px)}
  /* Better card padding */
  .card-body,.cz-card{padding:14px 16px}
  /* Hide non-essential decorations on small screens */
  .hide-mobile{display:none}
  /* Stack action buttons vertically */
  .actions-stack-mobile{flex-direction:column;width:100%}
  .actions-stack-mobile a,.actions-stack-mobile button{width:100%;justify-content:center}
}

/* PERFORMANCE: aspect-ratio for images prevents layout shift (CLS) */
.cover-img,.poster-img,.hero-img,.thumb-img{
  aspect-ratio:auto;
  background-color:var(--bg);
}

/* Skeleton loading placeholder */
.skeleton{
  background:linear-gradient(90deg,#e2e8f0 25%,#f1f5f9 50%,#e2e8f0 75%);
  background-size:200% 100%;
  animation:skeleton-shimmer 1.5s infinite;
  border-radius:8px;
}
@keyframes skeleton-shimmer{
  0%{background-position:200% 0}
  100%{background-position:-200% 0}
}

/* ── Herramientas ────────────────────────────────────── */
.tool-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.tool-card{background:#fff;border:1.5px solid var(--cz-ink-100);border-radius:14px;padding:20px;text-decoration:none;color:var(--cz-ink);display:block;transition:all .2s}
.tool-card:hover{border-color:var(--cz-blue-300);transform:translateY(-3px);box-shadow:0 8px 24px rgba(26,86,219,.08)}
.tool-card-ico{font-size:32px;margin-bottom:10px}
.tool-card-name{font-family:var(--cz-fd);font-size:15px;font-weight:700;margin-bottom:4px}
.tool-card-desc{font-size:13px;color:var(--cz-ink-500);line-height:1.5}
.tool-nav{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}
.tool-nav a{display:flex;align-items:center;gap:6px;padding:8px 14px;background:#fff;border:1.5px solid var(--cz-ink-100);border-radius:8px;font-size:13px;font-weight:600;color:var(--cz-ink);text-decoration:none;transition:all .2s}
.tool-nav a:hover,.tool-nav a.active{border-color:var(--cz-blue);background:var(--cz-blue-50);color:var(--cz-blue)}
.tool-box{background:#fff;border:1.5px solid var(--cz-ink-100);border-radius:14px;overflow:hidden;max-width:900px;margin-bottom:32px}
.tool-box-header{background:var(--cz-blue);padding:18px 22px;color:#fff}
.tool-box-body{padding:24px}
.tool-result{border-radius:10px;padding:14px 18px;margin-top:14px;font-size:14px;font-weight:600;display:none}
.tool-result.ok{background:#ecfdf5;border:1.5px solid #6ee7b7;color:#065f46;display:block}
.tool-result.err{background:#fef2f2;border:1.5px solid #fca5a5;color:#991b1b;display:block}
.tool-field{margin-bottom:14px}
.tool-field label{display:block;font-size:12px;font-weight:700;color:var(--cz-ink-500);text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px}
.tool-field input,.tool-field select,.tool-field textarea{width:100%;padding:10px 12px;background:#fff;border:1.5px solid var(--cz-ink-100);border-radius:8px;font-family:inherit;font-size:14px;color:var(--cz-ink);outline:none;transition:all .2s;box-sizing:border-box}
.tool-field input:focus,.tool-field select:focus,.tool-field textarea:focus{border-color:var(--cz-blue);box-shadow:0 0 0 3px rgba(26,86,219,.1)}
.tool-btn{padding:11px 20px;background:var(--cz-blue);color:#fff;font-family:var(--cz-fd);font-weight:700;font-size:14px;border:none;border-radius:8px;cursor:pointer;transition:all .2s}
.tool-btn:hover{background:var(--cz-blue-700);transform:translateY(-1px)}
.tool-btn-ghost{padding:9px 16px;background:#fff;color:var(--cz-blue);border:1.5px solid var(--cz-blue);font-family:var(--cz-fd);font-weight:600;font-size:13px;border-radius:8px;cursor:pointer;transition:all .2s}
.tool-btn-ghost:hover{background:var(--cz-blue-50)}
.strength-bar{height:6px;border-radius:3px;background:var(--cz-ink-100);margin:8px 0 4px}
.strength-fill{height:100%;border-radius:3px;transition:width .3s,background .3s}
.tool-pass-list{display:flex;flex-direction:column;gap:6px;margin-top:12px}
.tool-pass-item{display:flex;align-items:center;gap:8px;background:var(--cz-ink-50);border-radius:8px;padding:8px 12px;font-family:monospace;font-size:13px;letter-spacing:.5px}
.tool-pass-copy{margin-left:auto;background:none;border:none;cursor:pointer;font-size:14px;opacity:.6;transition:opacity .2s;padding:2px 6px}
.tool-pass-copy:hover{opacity:1}
.unit-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:10px;margin-top:16px}
.unit-field{display:flex;flex-direction:column;gap:4px}
.unit-field label{font-size:11px;font-weight:700;color:var(--cz-ink-500);text-transform:uppercase;letter-spacing:.5px}
.unit-field input{padding:8px 10px;border:1.5px solid var(--cz-ink-100);border-radius:8px;font-size:14px;font-family:monospace;width:100%;box-sizing:border-box;transition:border-color .2s;outline:none}
.unit-field input:focus{border-color:var(--cz-blue);box-shadow:0 0 0 3px rgba(26,86,219,.1)}
.unit-tabs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:18px}
.unit-tab{padding:6px 14px;border:1.5px solid var(--cz-ink-100);border-radius:20px;font-size:13px;font-weight:600;cursor:pointer;background:#fff;color:var(--cz-ink);transition:all .2s}
.unit-tab.active,.unit-tab:hover{border-color:var(--cz-blue);background:var(--cz-blue-50);color:var(--cz-blue)}
.img-drop{border:2px dashed var(--cz-ink-200);border-radius:12px;padding:40px 20px;text-align:center;cursor:pointer;transition:all .2s;background:var(--cz-ink-50)}
.img-drop:hover,.img-drop.dragover{border-color:var(--cz-blue);background:var(--cz-blue-50)}
.img-preview{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:16px}
@media(max-width:600px){.img-preview{grid-template-columns:1fr}}
.img-preview img{width:100%;border-radius:8px;border:1.5px solid var(--cz-ink-100)}
.qr-preview{text-align:center;margin-top:20px}
.qr-preview canvas,.qr-preview img{border:8px solid #fff;border-radius:8px;box-shadow:0 4px 16px rgba(0,0,0,.12)}

/* PRINT STYLES (better SEO + accessibility) */
@media print{
  nav,.cz-sticky-cta,.ad-slot,footer{display:none!important}
  body{font-size:12pt;color:#000;background:#fff}
  a{color:#000;text-decoration:underline}
  img{max-width:100%!important}
}

/* HIGH CONTRAST MODE (WCAG 2.1 AAA) */
@media(prefers-contrast:high){
  :root{
    --blue:#0033cc;
    --ink:#000;
    --mid:#333;
    --line:#666;
  }
  .btn,.cz-btn,a{border:2px solid currentColor!important}
}

/* DARK MODE PREFERENCE (graceful) */
@media(prefers-color-scheme:dark){
  /* Solo colores específicos en dark mode (mantenemos diseño claro pero con detalles) */
  .skeleton{background:linear-gradient(90deg,#1e293b 25%,#334155 50%,#1e293b 75%)}
}

/* FOCUS VISIBLE (Accesibilidad - keyboard navigation) */
:focus-visible{
  outline:3px solid var(--blue,#1a56db);
  outline-offset:2px;
  border-radius:4px;
}

/* SKIP LINK on focus */
.skip-link:focus{top:0;outline:3px solid var(--amber,#f59e0b)}

/* ═══════════════════════════════════════════════
   ASESOR IA — página completa + widget flotante
   ═══════════════════════════════════════════════ */

/* Página completa */
.asesor-page{padding:40px 0 80px}
.asesor-hero{text-align:center;padding:40px 0 28px}
.asesor-hero-title{font-family:var(--ff);font-size:clamp(1.8rem,4vw,2.8rem);font-weight:800;color:var(--ink);margin:8px 0}
.asesor-hero-sub{color:var(--mid);font-size:1.05rem;max-width:560px;margin:0 auto}

/* Selector de temas */
.asesor-temas{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:32px}
.asesor-tema-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:14px 18px;border:1.5px solid var(--line);border-radius:14px;background:var(--white);cursor:pointer;font-family:var(--fb);font-size:.82rem;font-weight:600;color:var(--mid);transition:all .2s;min-width:90px}
.asesor-tema-btn:hover{border-color:var(--tema-color,var(--blue));color:var(--tema-color,var(--blue));transform:translateY(-2px)}
.asesor-tema-btn.active{border-color:var(--tema-color,var(--blue));background:color-mix(in srgb,var(--tema-color,var(--blue)) 8%,white);color:var(--tema-color,var(--blue))}
.asesor-tema-emoji{font-size:1.5rem;line-height:1}
.asesor-tema-label{font-size:.75rem;white-space:nowrap}

/* Chat area */
.asesor-chat-wrap{background:var(--white);border:1.5px solid var(--line);border-radius:20px;overflow:hidden;max-width:720px;margin:0 auto;display:flex;flex-direction:column}
.asesor-welcome{padding:40px 24px;text-align:center;color:var(--mid)}
.asesor-bot-avatar{font-size:3rem;margin-bottom:12px}
.asesor-welcome p{margin:4px 0;font-size:1rem}
.asesor-welcome-sub{font-size:.9rem;color:var(--soft)}
.asesor-messages{padding:20px;display:flex;flex-direction:column;gap:14px;max-height:420px;overflow-y:auto;min-height:60px}
.asesor-msg{display:flex;gap:10px;align-items:flex-start}
.asesor-msg-user{flex-direction:row-reverse}
.asesor-msg-avatar{font-size:1.4rem;flex-shrink:0;margin-top:2px}
.asesor-msg-bubble{padding:12px 16px;border-radius:16px;font-size:.93rem;line-height:1.6;max-width:80%;word-wrap:break-word}
.asesor-msg-assistant .asesor-msg-bubble{background:var(--blue-l);color:var(--ink);border-bottom-left-radius:4px}
.asesor-msg-user .asesor-msg-bubble{background:var(--blue);color:#fff;border-bottom-right-radius:4px;margin-left:auto}

/* Sugerencias */
.asesor-sugerencias{display:flex;flex-wrap:wrap;gap:8px;padding:0 20px 16px}
.asesor-sug-btn{padding:6px 14px;border:1.5px solid var(--line);border-radius:20px;background:var(--bg);font-size:.82rem;font-family:var(--fb);color:var(--mid);cursor:pointer;transition:all .15s}
.asesor-sug-btn:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-l)}

/* Input */
.asesor-input-wrap{display:flex;align-items:flex-end;gap:8px;padding:12px 16px;border-top:1.5px solid var(--line)}
.asesor-input{flex:1;border:1.5px solid var(--line);border-radius:12px;padding:10px 14px;font-family:var(--fb);font-size:.95rem;resize:none;line-height:1.5;background:var(--bg);transition:border-color .2s}
.asesor-input:focus{border-color:var(--blue);outline:none;background:var(--white)}
.asesor-input:disabled{opacity:.5;cursor:not-allowed}
.asesor-send-btn{flex-shrink:0;width:44px;height:44px;border-radius:12px;background:var(--blue);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;box-shadow:0 3px 12px rgba(26,86,219,.3)}
.asesor-send-btn:hover:not(:disabled){background:var(--blue-d);transform:translateY(-1px)}
.asesor-send-btn:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}
.asesor-disclaimer{padding:8px 20px 14px;font-size:.77rem;color:var(--soft);text-align:center}

/* Salas */
.asesor-salas-wrap{max-width:720px;margin:20px auto 0;padding:20px;background:var(--blue-l);border-radius:16px;border:1.5px solid var(--blue-m)}
.asesor-salas-title{font-size:.95rem;font-weight:700;color:var(--ink);margin:0 0 12px}
.asesor-salas{display:flex;flex-wrap:wrap;gap:8px}
.asesor-sala-btn{padding:7px 16px;border-radius:20px;background:var(--white);border:1.5px solid var(--blue-b);color:var(--blue);font-size:.85rem;font-weight:600;text-decoration:none;transition:all .15s}
.asesor-sala-btn:hover{background:var(--blue);color:#fff;border-color:var(--blue)}

/* ── Widget flotante ── */
.asesor-fab{position:fixed;bottom:24px;right:24px;z-index:9000;background:var(--blue);color:#fff;border:none;border-radius:28px;padding:12px 18px 12px 14px;display:flex;align-items:center;gap:8px;cursor:pointer;font-family:var(--fb);font-size:.88rem;font-weight:700;box-shadow:0 4px 20px rgba(26,86,219,.45);transition:all .25s}
.asesor-fab:hover,.asesor-fab.active{background:var(--blue-d);transform:translateY(-2px);box-shadow:0 8px 28px rgba(26,86,219,.5)}
.asesor-fab-icon{font-size:1.2rem;line-height:1}
@media(max-width:480px){.asesor-fab-label{display:none}.asesor-fab{border-radius:50%;width:52px;height:52px;padding:0;justify-content:center}}

.asesor-widget{position:fixed;bottom:82px;right:24px;z-index:8999;width:360px;max-width:calc(100vw - 32px);background:var(--white);border:1.5px solid var(--line);border-radius:20px;box-shadow:0 8px 40px rgba(0,0,0,.18);display:none;flex-direction:column;overflow:hidden;max-height:560px}
.asesor-widget.open{display:flex}
.asesor-widget-header{display:flex;align-items:center;padding:12px 16px;background:var(--blue);color:#fff;gap:8px}
.asesor-widget-title{flex:1;font-family:var(--ff);font-size:.95rem;font-weight:700}
.asesor-widget-expand,.asesor-widget-close{background:none;border:none;color:#fff;cursor:pointer;font-size:1rem;padding:2px 6px;border-radius:6px;opacity:.8;text-decoration:none;line-height:1}
.asesor-widget-expand:hover,.asesor-widget-close:hover{opacity:1;background:rgba(255,255,255,.15)}
.asesor-widget-temas{display:flex;gap:6px;padding:10px 12px;overflow-x:auto;border-bottom:1px solid var(--line);scrollbar-width:none}
.asesor-widget-temas::-webkit-scrollbar{display:none}
.asesor-widget-tema{background:none;border:1.5px solid var(--line);border-radius:8px;padding:5px 8px;cursor:pointer;font-size:1.1rem;transition:all .15s;flex-shrink:0}
.asesor-widget-tema:hover,.asesor-widget-tema.active{border-color:var(--tema-color,var(--blue));background:color-mix(in srgb,var(--tema-color,var(--blue)) 10%,white)}
.asesor-widget-messages{flex:1;padding:12px;overflow-y:auto;min-height:80px;max-height:260px}
.asesor-widget-welcome{color:var(--mid);font-size:.88rem;text-align:center;padding:16px 0}
.asesor-widget-sugs{display:flex;flex-wrap:wrap;gap:6px;padding:6px 10px;border-top:1px solid var(--line)}
.asesor-widget-footer{display:flex;gap:6px;padding:8px 10px;border-top:1px solid var(--line)}
.asesor-widget-input{flex:1;border:1.5px solid var(--line);border-radius:10px;padding:7px 10px;font-size:.88rem;font-family:var(--fb);resize:none;line-height:1.4}
.asesor-widget-input:focus{border-color:var(--blue);outline:none}
.asesor-widget-send{width:36px;height:36px;border-radius:10px;background:var(--blue);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s}
.asesor-widget-send:hover:not(:disabled){background:var(--blue-d)}
.asesor-widget-send:disabled{opacity:.4;cursor:not-allowed}

@media(max-width:480px){
  .asesor-widget{right:8px;bottom:72px;width:calc(100vw - 16px)}
  .asesor-fab{right:16px;bottom:16px}
}

/* ═══════════════════════════════════════════
   PARTIDOS HOY — Marcadores y resultados
   ═══════════════════════════════════════════ */
.partidos-filtros{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.partidos-filtro{padding:7px 16px;border:1.5px solid var(--line);border-radius:20px;font-size:.85rem;font-weight:600;color:var(--mid);text-decoration:none;transition:all .15s}
.partidos-filtro:hover,.partidos-filtro.active{border-color:var(--blue);color:var(--blue);background:var(--blue-l)}
.partidos-updated{font-size:.82rem;color:var(--soft);margin-bottom:20px}
.partidos-empty{padding:48px 0;text-align:center;color:var(--mid)}
.partidos-liga{margin-bottom:32px}
.partidos-liga-title{font-size:1.05rem;font-weight:700;color:var(--ink);margin:0 0 12px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.partidos-liga-pais{font-weight:400;color:var(--mid);font-size:.88rem}
.partidos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:10px}
.partido-card{background:var(--white);border:1.5px solid var(--line);border-radius:14px;padding:14px 16px;transition:all .2s}
.partido-card:hover{border-color:var(--blue-b);box-shadow:0 2px 12px rgba(26,86,219,.08)}
.partido-live{border-color:var(--green)!important;background:linear-gradient(135deg,rgba(5,150,105,.03),white)}
.partido-equipos{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:8px;margin-bottom:8px}
.partido-equipo{font-size:.88rem;font-weight:600;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.partido-local{text-align:right}
.partido-visitante{text-align:left}
.partido-marcador{text-align:center;display:flex;align-items:center;justify-content:center;gap:4px;white-space:nowrap}
.marcador-num{font-size:1.3rem;font-weight:800;color:var(--ink);min-width:24px;text-align:center}
.marcador-sep{font-size:1rem;color:var(--mid);font-weight:700}
.marcador-hora{font-size:.9rem;font-weight:700;color:var(--blue);background:var(--blue-l);padding:3px 10px;border-radius:8px}
.partido-meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.partido-status{font-size:.75rem;font-weight:700;padding:3px 10px;border-radius:10px;text-transform:uppercase}
.status-live{background:#dcfce7;color:var(--green)}
.status-fin{background:var(--bg);color:var(--mid)}
.status-prx{background:var(--blue-l);color:var(--blue)}
.partido-venue{font-size:.75rem;color:var(--soft);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:160px}
.badge-live{background:var(--green);color:#fff;font-size:.72rem;font-weight:800;padding:2px 8px;border-radius:8px;text-transform:uppercase;letter-spacing:.03em}
.badge-sm{font-size:.68rem;padding:2px 6px}
.partidos-live-badge{display:flex;align-items:center;gap:6px;font-size:.85rem;font-weight:700;color:var(--green)}
.live-dot{width:8px;height:8px;border-radius:50%;background:var(--green);animation:livePulse 1.2s ease-in-out infinite}
@keyframes livePulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}
.deportes-chat-cta{background:var(--blue-l);border:1.5px solid var(--blue-m);border-radius:16px;padding:20px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-top:32px}
.deportes-chat-text{display:flex;flex-direction:column;gap:4px}
.deportes-chat-text strong{color:var(--ink);font-size:.95rem}
.deportes-chat-text span{color:var(--mid);font-size:.85rem}
.deportes-chat-btns{display:flex;gap:8px;flex-wrap:wrap}
@media(max-width:640px){.partidos-grid{grid-template-columns:1fr}.partido-equipos{grid-template-columns:1fr auto 1fr}}

/* Noticias de agencias — bloque claves y fuentes */
.nota-claves{background:var(--blue-l);border-left:3px solid var(--blue);
  border-radius:8px;padding:14px 18px;margin:0 0 20px}
.nota-claves h2{font-size:15px;margin:0 0 8px;color:var(--blue-d)}
.nota-claves ul{margin:0;padding-left:20px}
.nota-claves li{margin:4px 0;font-size:14.5px}
.article-fuentes{margin-top:24px;padding-top:14px;border-top:1px solid var(--line);
  font-size:13px;color:var(--mid)}
.fuente-chip{display:inline-block;background:var(--bg);border:1px solid var(--line);
  border-radius:6px;padding:2px 8px;margin:2px;font-size:12px}

/* ── WCAG 2.1 AA — Accessibility global fixes ─────────────────────────────
   Skip link: visible on keyboard focus, hidden off-screen otherwise.
   Focus rings: restore visible focus indicator for all elements that use
   outline:none, via :focus-visible (keyboard-only, not mouse clicks).
   ──────────────────────────────────────────────────────────────────────── */
.cz-skip-link{position:absolute;left:-9999px;top:-9999px;z-index:9999;
  background:var(--blue);color:#fff;font-weight:700;font-size:14px;
  padding:10px 20px;border-radius:0 0 8px 8px;text-decoration:none}
.cz-skip-link:focus{left:50%;top:0;transform:translateX(-50%)}

/* Global focus ring for keyboard users — covers outline:none inputs/buttons */
input:focus-visible,select:focus-visible,textarea:focus-visible,
button:focus-visible,a:focus-visible,[tabindex]:focus-visible{
  outline:2px solid var(--blue) !important;
  outline-offset:2px !important;
  box-shadow:0 0 0 4px rgba(26,86,219,.15) !important
}
/* Inputs that use border-color on focus still keep their border + ring */
.form-input:focus-visible,.form-select:focus-visible,.form-textarea:focus-visible,
.nick-input:focus-visible,.tool-field input:focus-visible,.unit-field input:focus-visible{
  border-color:var(--blue) !important
}

/* ── FIX MÓVIL: layouts de 2 columnas (contenido + sidebar) ──────────────────
   Los items de un grid/flex tienen min-width:auto por defecto y NO se encogen
   por debajo del ancho de su contenido (widgets/tablas de la sidebar), lo que
   desbordaba el viewport en móvil y hacía que la página se viera "encogida"
   (innerWidth 429-585 en vez de 390). min-width:0 deja que los hijos se ajusten.
   No se toca html/body overflow para no romper el header sticky. */
@media (max-width: 768px) {
  .a-layout > *, .act-layout > *, .actor-layout > *, .alb-layout > *, .b-layout > *,
  .be-layout > *, .bk-layout > *, .bl-layout > *, .bm-layout > *, .c-layout > *,
  .canal-layout > *, .cine-layout > *, .content-sidebar > *, .ct-grid > *, .d-layout > *,
  .dep-layout > *, .hero-in > *, .hs-layout > *, .layout > *, .layout-2 > *,
  .layout-art > *, .m-layout > *, .mg-layout > *, .mm-layout > *, .mo-layout > *,
  .r-layout > *, .sel-layout > *, .ti-layout > *, .ts-layout > *, .v-layout > *,
  .vg-layout > *, .vid-content > *, .wc-layout > *, .h-grid-rooms > * {
    min-width: 0;
  }
}
