/* Mejoragencia — sistema de diseño. Editorial + premium. */
@font-face{font-family:'Fraunces';font-style:normal;font-weight:400 600;font-display:optional;src:url(/assets/fonts/fraunces.woff2) format('woff2')}
@font-face{font-family:'Fraunces';font-style:italic;font-weight:400 600;font-display:optional;src:url(/assets/fonts/fraunces-italic.woff2) format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:300 600;font-display:swap;src:url(/assets/fonts/inter.woff2) format('woff2')}
:root{
  --paper:#FBFAF7; --ink:#16140F; --muted:#6B675F; --faint:#949087;
  --line:#EAE6DD; --line-strong:#D9D4C9; --card:#FFFFFF;
  --brand:#4F46E5; --brand-2:#3A32B0; --brand-soft:#EEEFFE;
  --teal:#0E8B79; --teal-soft:#E1F3EF;
  --gold:#A9760E; --gold-soft:#FAF0D8;
  --star:#DBA000;
  --r-sm:8px; --r:12px; --r-lg:18px; --r-xl:26px;
  --shadow:0 1px 2px rgba(22,20,15,.05);
  --shadow-lg:0 24px 50px -24px rgba(22,20,15,.28);
  --maxw:1180px;
  --font-display:'Fraunces',Georgia,'Times New Roman',serif;
  --font-sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-sans);background:var(--paper);color:var(--ink);line-height:1.65;font-size:16px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:500;line-height:1.08;letter-spacing:-.015em}
::selection{background:var(--brand);color:#fff}
:focus-visible{outline:2.5px solid var(--brand);outline-offset:2px;border-radius:3px}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{font-family:var(--font-sans);font-size:12px;font-weight:600;letter-spacing:.13em;text-transform:uppercase;color:var(--brand)}
.muted{color:var(--muted)}
.center{text-align:center}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-sans);font-size:15px;font-weight:600;padding:12px 22px;border-radius:999px;border:1px solid transparent;cursor:pointer;transition:transform .15s,background .15s,border-color .15s,color .15s;white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--brand);color:#fff}
.btn-primary:hover{background:var(--brand-2)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line-strong)}
.btn-ghost:hover{border-color:var(--ink)}
.btn-lg{padding:15px 28px;font-size:16px}

/* header */
.site-head{position:sticky;top:0;z-index:60;background:rgba(251,250,247,.82);backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;gap:26px;height:68px}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-size:21px;font-weight:600;letter-spacing:-.02em}
.brand .mk{width:34px;height:34px;background:url(/assets/favicon.svg) center/contain no-repeat;font-size:0;flex-shrink:0}
.nav-menu{display:flex;gap:22px;font-size:15px;color:var(--muted);flex:1}
.nav-menu a{position:relative;padding:4px 0;transition:color .15s}
.nav-menu a:hover{color:var(--ink)}
.nav-menu a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:2px;background:var(--brand);transition:right .2s}
.nav-menu a:hover::after{right:0}
.nav-act{display:flex;align-items:center;gap:14px}
.nav-act .link{font-size:15px;color:var(--muted)}
.nav-act .link:hover{color:var(--ink)}

/* hero */
.hero{position:relative;padding:90px 0 96px;text-align:center;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background-image:radial-gradient(var(--line-strong) 1px,transparent 1px);background-size:26px 26px;opacity:.5;-webkit-mask-image:radial-gradient(ellipse 70% 60% at 50% 35%,#000 30%,transparent 75%);mask-image:radial-gradient(ellipse 70% 60% at 50% 35%,#000 30%,transparent 75%)}
.hero>*{position:relative}
.hero .kicker{display:inline-flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--line-strong);border-radius:999px;padding:6px 14px;font-size:13px;font-weight:500;color:var(--muted);margin-bottom:26px;box-shadow:var(--shadow)}
.hero .kicker .dot{width:7px;height:7px;border-radius:50%;background:var(--teal)}
.hero h1{font-size:clamp(38px,6vw,64px);line-height:1.02;max-width:880px;margin:0 auto 22px}
.hero h1 em{font-style:italic;color:var(--brand)}
.hero .sub{font-size:clamp(17px,2.2vw,21px);color:var(--muted);max-width:600px;margin:0 auto 38px}

/* search command bar */
.search{display:flex;gap:6px;background:var(--card);border:1px solid var(--line-strong);border-radius:999px;padding:7px 7px 7px 10px;max-width:680px;margin:0 auto;box-shadow:var(--shadow-lg)}
.search .f{display:flex;align-items:center;gap:8px;flex:1;padding:0 8px}
.search .f svg{color:var(--faint);flex-shrink:0}
.search select{border:none;background:transparent;font-family:inherit;font-size:15px;color:var(--ink);padding:12px 0;width:100%;outline:none;cursor:pointer;appearance:none}
.search .sep{width:1px;background:var(--line);margin:8px 0}
.popular{margin-top:22px;font-size:14px;color:var(--muted)}
.popular a{display:inline-block;background:var(--card);border:1px solid var(--line);border-radius:999px;padding:6px 14px;margin:4px;color:var(--ink);font-weight:500;font-size:13px;transition:border-color .15s,color .15s}
.popular a:hover{border-color:var(--brand);color:var(--brand)}

/* sections */
.section{padding:84px 0}
.section.tint{background:var(--card);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.sec-head{max-width:640px;margin-bottom:44px}
.sec-head.center{margin-left:auto;margin-right:auto}
.section h2{font-size:clamp(28px,4vw,40px);margin:12px 0 12px}
.section .lead{font-size:18px;color:var(--muted)}

/* category grid */
.cats{display:grid;grid-template-columns:repeat(auto-fit,minmax(264px,1fr));gap:16px}
.cat{display:flex;flex-direction:column;background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:26px 24px;transition:border-color .18s,transform .18s,box-shadow .18s}
.cat:hover{border-color:var(--ink);transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.cat .ic{width:46px;height:46px;border-radius:12px;background:var(--brand-soft);color:var(--brand);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.cat h3{font-size:21px;margin-bottom:6px}
.cat p{font-size:14.5px;color:var(--muted);flex:1;margin-bottom:18px}
.cat .go{font-size:13px;font-weight:600;color:var(--ink);display:inline-flex;align-items:center;gap:7px;transition:gap .18s}
.cat:hover .go{gap:12px;color:var(--brand)}

/* steps */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:34px}
.step .n{font-family:var(--font-display);font-size:15px;font-weight:600;width:40px;height:40px;border-radius:11px;background:var(--paper);border:1px solid var(--line-strong);display:flex;align-items:center;justify-content:center;color:var(--brand);margin-bottom:16px}
.step h3{font-size:21px;margin-bottom:7px}
.step p{font-size:15px;color:var(--muted)}

/* stats */
.stats{background:var(--ink);color:var(--paper);border-radius:var(--r-xl);padding:54px 44px;display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:30px;text-align:center}
.stats .num{font-family:var(--font-display);font-size:clamp(34px,5vw,48px);font-weight:500;color:#fff;line-height:1}
.stats .lbl{font-size:14px;color:#A7A29A;margin-top:10px}

/* cta */
.cta{background:var(--brand);color:#fff;border-radius:var(--r-xl);padding:60px 48px;text-align:center;position:relative;overflow:hidden}
.cta::before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.14) 1px,transparent 1px);background-size:22px 22px;opacity:.6}
.cta>*{position:relative}
.cta .eyebrow{color:#C7C3F7}
.cta h2{color:#fff;margin:10px 0 12px}
.cta p{color:#D9D6F7;font-size:18px;max-width:560px;margin:0 auto 28px}
.cta .btn-primary{background:#fff;color:var(--brand)}
.cta .btn-primary:hover{background:#F3F2FF}

/* breadcrumb */
.crumb{font-size:13px;color:var(--muted);padding:22px 0 0;display:flex;gap:8px;flex-wrap:wrap}
.crumb a:hover{color:var(--brand)}
.crumb span{color:var(--faint)}

/* ranking page header */
.rank-head{padding:18px 0 36px;border-bottom:1px solid var(--line)}
.rank-head h1{font-size:clamp(32px,5vw,52px);max-width:880px;margin:14px 0 16px}
.rank-head .intro{font-size:18px;color:var(--muted);max-width:720px;margin-bottom:22px}
.rank-meta{display:flex;flex-wrap:wrap;gap:10px}
.tag{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:500;padding:7px 13px;border-radius:999px;border:1px solid var(--line-strong);color:var(--muted);background:var(--card)}
.tag.good{color:var(--teal);border-color:var(--teal-soft);background:var(--teal-soft)}
.tag svg{flex-shrink:0}

/* filters */
.filters{display:flex;gap:10px;flex-wrap:wrap;padding:24px 0}
.filters .fpill{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:500;padding:9px 15px;border-radius:999px;border:1px solid var(--line-strong);background:var(--card);color:var(--ink);cursor:pointer;transition:border-color .15s}
.filters .fpill:hover{border-color:var(--ink)}

/* destacado */
.destacado{position:relative;border:1px solid var(--gold);background:var(--gold-soft);border-radius:var(--r-lg);padding:8px 8px 8px 0;margin-bottom:18px}
.destacado .flag{position:absolute;top:-11px;left:22px;background:var(--gold);color:#fff;font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:3px 10px;border-radius:999px}

/* agency card */
.agency{display:grid;grid-template-columns:auto 1fr auto;gap:22px;background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:26px;margin-bottom:16px;transition:border-color .18s,box-shadow .18s}
.agency:hover{border-color:var(--line-strong);box-shadow:var(--shadow-lg)}
.agency .rank-no{font-family:var(--font-display);font-size:46px;font-weight:500;color:var(--line-strong);line-height:1;width:54px;text-align:center}
.agency .body{min-width:0}
.agency .name{font-family:var(--font-display);font-size:24px;font-weight:600;margin-bottom:4px}
.agency .name a:hover{color:var(--brand)}
.agency .submeta{font-size:14px;color:var(--muted);margin-bottom:14px}
.agency .submeta b{color:var(--ink);font-weight:600}
.badges{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:16px}
.badge{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:600;padding:5px 11px;border-radius:999px}
.badge.premier{background:var(--gold-soft);color:var(--gold)}
.badge.verif{background:var(--brand-soft);color:var(--brand)}
.badge.star{background:var(--paper);color:var(--ink);border:1px solid var(--line)}
.badge.star svg{color:var(--star)}
.subscores{display:grid;grid-template-columns:repeat(auto-fit,minmax(124px,1fr));gap:12px 18px}
.ss .ss-top{display:flex;justify-content:space-between;font-size:12.5px;color:var(--muted);margin-bottom:5px}
.ss .ss-top b{color:var(--ink);font-weight:600}
.ss .ss-bar{height:6px;border-radius:4px;background:var(--paper);border:1px solid var(--line);overflow:hidden}
.ss .ss-bar i{display:block;height:100%;background:var(--teal);border-radius:4px}
.agency .score{display:flex;flex-direction:column;align-items:center;gap:10px;width:128px;border-left:1px solid var(--line);padding-left:22px}
.ring{position:relative;width:96px;height:96px}
.ring svg{transform:rotate(-90deg)}
.ring .rtrack{stroke:var(--line);}
.ring .rfill{stroke:var(--brand);stroke-linecap:round;transition:stroke-dashoffset .6s}
.ring .rval{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.ring .rval b{font-family:var(--font-display);font-size:28px;font-weight:600;line-height:1}
.ring .rval span{font-size:11px;color:var(--faint)}
.agency .score .lbl{font-size:11px;color:var(--faint);text-align:center;letter-spacing:.04em;text-transform:uppercase}
.agency .score .btn{width:100%;justify-content:center;padding:10px 14px;font-size:14px}

/* secondary list (positions 4-10) */
.minilist{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;margin-top:4px}
.minirow{display:flex;align-items:center;gap:16px;padding:16px 22px;border-top:1px solid var(--line);transition:background .15s}
.minirow:first-child{border-top:none}
.minirow:hover{background:var(--paper)}
.minirow .mr-no{font-family:var(--font-display);font-size:22px;color:var(--faint);width:34px}
.minirow .mr-name{flex:1;font-weight:600}
.minirow .mr-name span{display:block;font-weight:400;font-size:13px;color:var(--muted)}
.minirow .mr-badges{display:flex;gap:6px}
.minirow .mr-score{font-family:var(--font-display);font-size:22px;font-weight:600;width:48px;text-align:right}

/* methodology callout */
.callout{display:flex;gap:18px;align-items:flex-start;background:var(--card);border:1px solid var(--line);border-left:3px solid var(--brand);border-radius:var(--r);padding:24px 26px;margin:36px 0}
.callout .ic{color:var(--brand);flex-shrink:0;margin-top:2px}
.callout h3{font-family:var(--font-sans);font-size:17px;font-weight:600;margin-bottom:5px}
.callout p{font-size:15px;color:var(--muted)}
.callout a{color:var(--brand);font-weight:600}

/* prose (methodology) */
.prose{max-width:760px;margin:0 auto}
.prose h2{font-size:30px;margin:42px 0 14px}
.prose h3{font-size:22px;margin:32px 0 10px}
.prose p{font-size:17px;color:#3a372f;margin-bottom:16px}
.prose ul{margin:0 0 18px 22px}
.prose li{font-size:17px;color:#3a372f;margin-bottom:8px}
.prose strong{font-weight:600}

/* weight table */
.weights{border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;margin:24px 0}
.wrow{display:grid;grid-template-columns:1fr auto 120px;align-items:center;gap:16px;padding:15px 22px;border-top:1px solid var(--line);background:var(--card)}
.wrow:first-child{border-top:none}
.wrow .wname{font-weight:600;font-size:15px}
.wrow .wname span{display:block;font-weight:400;font-size:13px;color:var(--muted)}
.wrow .wpct{font-family:var(--font-display);font-size:20px;font-weight:600}
.wrow .wbar{height:7px;border-radius:4px;background:var(--paper);border:1px solid var(--line);overflow:hidden}
.wrow .wbar i{display:block;height:100%;background:var(--brand);border-radius:4px}

/* faq */
.faq{max-width:820px;margin:0 auto}
.faq details{border:1px solid var(--line);border-radius:var(--r);background:var(--card);margin-bottom:12px;padding:4px 22px}
.faq summary{font-family:var(--font-display);font-size:18px;font-weight:500;padding:18px 0;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:24px;color:var(--brand);transition:transform .2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{padding:0 0 20px;font-size:16px;color:var(--muted)}

/* footer */
.site-foot{background:var(--ink);color:#C9C5BD;padding:64px 0 34px;margin-top:8px}
.fgrid{display:grid;grid-template-columns:1.5fr repeat(4,1fr);gap:34px;margin-bottom:46px}
.site-foot .brand{color:#fff;margin-bottom:14px}
.site-foot .brand .mk{background:url(/assets/favicon.svg) center/contain no-repeat}
.site-foot .fdesc{font-size:14px;color:#938E86;max-width:280px}
.site-foot h4{font-family:var(--font-sans);font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:#fff;margin-bottom:15px}
.site-foot ul{list-style:none}
.site-foot li{margin-bottom:10px}
.site-foot a{font-size:14px;color:#C9C5BD;transition:color .15s}
.site-foot a:hover{color:#fff}
.fbot{border-top:1px solid #2A2722;padding-top:26px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:13px;color:#938E86}

/* 404 */
.err{min-height:60vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:80px 24px}
.err .code{font-family:var(--font-display);font-size:120px;font-weight:500;color:var(--line-strong);line-height:1}
.err h1{font-size:34px;margin:8px 0 12px}
.err p{font-size:18px;color:var(--muted);max-width:460px;margin-bottom:28px}

@media(max-width:880px){
  .nav-menu{display:none}
  .search{flex-direction:column;border-radius:var(--r-lg)}
  .search .sep{display:none}
  .search .btn{justify-content:center}
  .agency{grid-template-columns:auto 1fr;gap:16px;padding:20px}
  .agency .score{grid-column:1/-1;flex-direction:row;border-left:none;border-top:1px solid var(--line);padding:16px 0 0;width:100%;justify-content:space-between}
  .agency .score .btn{width:auto}
  .fgrid{grid-template-columns:1fr 1fr}
  .stats,.cta{padding:40px 26px}
}
@media(max-width:520px){
  .nav-act .link{display:none}
  .fgrid{grid-template-columns:1fr}
  .agency .rank-no{font-size:34px;width:40px}
  .wrow{grid-template-columns:1fr 60px;gap:10px}
  .wrow .wbar{display:none}
}
@media(prefers-reduced-motion:reduce){*{transition:none!important;scroll-behavior:auto!important}}

/* perfil de agencia */
.pf-head{display:grid;grid-template-columns:1fr auto;gap:32px;align-items:start;padding:24px 0 30px;border-bottom:1px solid var(--line)}
.pf-name{font-size:clamp(30px,5vw,46px);margin:10px 0 10px}
.pf-meta{font-size:15px;color:var(--muted);margin-bottom:16px}
.pf-meta b{color:var(--ink);font-weight:600}
.pf-score{display:flex;flex-direction:column;align-items:center;gap:12px;background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:22px 30px;min-width:210px}
.pf-score .ring{width:118px;height:118px}
.pf-score .ring .rval b{font-size:34px}
.pf-score .lbl{font-size:11px;color:var(--faint);text-transform:uppercase;letter-spacing:.06em}
.pf-cta{display:flex;gap:10px;margin-top:4px;flex-wrap:wrap;justify-content:center}
.pf-grid{display:grid;grid-template-columns:1fr 320px;gap:44px;padding:40px 0}
.pf-main h2{font-size:25px;margin:0 0 6px}
.pf-main h2:not(:first-child){margin-top:42px}
.pf-main .h2sub{font-size:15px;color:var(--muted);margin-bottom:20px}
.sig{margin-bottom:17px}
.sig .sig-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:5px}
.sig .sig-name{font-weight:600;font-size:15px}
.sig .sig-val{font-family:var(--font-display);font-weight:600;font-size:17px}
.sig .sig-bar{height:8px;border-radius:5px;background:var(--paper);border:1px solid var(--line);overflow:hidden}
.sig .sig-bar i{display:block;height:100%;background:var(--teal);border-radius:5px}
.sig .sig-desc{font-size:13px;color:var(--muted);margin-top:5px}
.review{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:18px 20px;margin-bottom:14px}
.review .rv-top{display:flex;justify-content:space-between;gap:12px;margin-bottom:8px}
.review .rv-who{font-weight:600;font-size:14px}
.review .rv-who span{display:block;font-weight:400;color:var(--muted);font-size:13px}
.review .rv-stars{color:var(--star);font-size:13px;white-space:nowrap}
.ai-box{background:var(--brand-soft);border:1px solid #C7C3F7;border-radius:var(--r-lg);padding:24px 26px;margin-top:8px}
.ai-box .ai-h{display:flex;align-items:center;gap:10px;font-weight:600;font-size:16px;color:var(--brand-2);margin-bottom:12px}
.ai-box p{font-size:15px;color:#2e2b66;margin-bottom:10px;font-style:italic}
.ai-box .ai-src{font-size:12px;color:var(--brand-2);opacity:.85;font-style:normal}
.ai-box .ai-soon{font-size:13px;color:var(--brand-2);opacity:.7;font-style:normal;margin-top:6px}
.pf-facts{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:22px 24px;position:sticky;top:84px}
.pf-facts h3{font-family:var(--font-sans);font-size:12px;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);margin:0 0 14px}
.pf-facts .fact{display:flex;justify-content:space-between;gap:12px;font-size:14px;border-bottom:1px solid var(--line);padding:10px 0}
.pf-facts .fact:last-of-type{border-bottom:none}
.pf-facts .fact dt{color:var(--muted)}
.pf-facts .fact dd{font-weight:600;text-align:right;margin:0}
.chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:14px}
.chip{font-size:12.5px;background:var(--paper);border:1px solid var(--line);border-radius:999px;padding:4px 11px}
@media(max-width:880px){.pf-head{grid-template-columns:1fr}.pf-score{min-width:0}.pf-grid{grid-template-columns:1fr;gap:26px}.pf-facts{position:static}}
