/* Yalc tools directory — shared styles for /tools/ and /stacks/ */

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{
  font-family:'Inter',sans-serif;
  color:#1a1a1a;
  background:#F8EDE8 url('/assets/paper-bg.png') top left / 900px auto repeat fixed;
  line-height:1.6;
  min-height:100vh;
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:0.01ms !important;animation-iteration-count:1 !important;transition-duration:0.01ms !important;scroll-behavior:auto !important}
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%;height:auto}
h1,h2,h3,h4,h5,h6{font-family:'Outfit',sans-serif}
.container{max-width:1180px;margin:0 auto;padding:0 32px}
.container-narrow{max-width:880px;margin:0 auto;padding:0 32px}
.accent{background:linear-gradient(135deg,#E07A95,#C9506E);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.glass{background:rgba(255,255,255,0.4);backdrop-filter:blur(28px) saturate(1.6);-webkit-backdrop-filter:blur(28px) saturate(1.6);border:1px solid rgba(255,255,255,0.55);box-shadow:0 4px 24px rgba(201,80,110,0.05),0 1px 3px rgba(0,0,0,0.04)}

/* NAV */
.nav{position:fixed;top:16px;left:50%;transform:translateX(-50%);width:calc(100% - 32px);max-width:1180px;display:flex;align-items:center;justify-content:space-between;padding:14px 24px;border-radius:16px;z-index:100}
.nav-logo{display:flex;align-items:center;gap:8px;text-decoration:none;color:#1a1a1a}
.nav-logo img{width:28px;height:28px;border-radius:6px}
.nav-logo span{font-family:'Outfit',sans-serif;font-weight:700;font-size:16px}
.nav-right{display:flex;align-items:center;gap:24px}
.nav-link{font-family:'Outfit',sans-serif;font-size:14px;font-weight:500;color:#1a1a1a;text-decoration:none;opacity:0.7;transition:opacity 0.2s}
.nav-link:hover,.nav-link.active{opacity:1}

/* Resources nav link with chevron */
.nav-link.has-chev{display:inline-flex;align-items:center;gap:5px}
.nav-link.has-chev .chev{width:11px;height:11px;transition:transform 0.2s ease}
.nav-link.has-chev[aria-expanded="true"] .chev{transform:rotate(180deg)}

/* Portal dropdown panel — appended to body, escapes any container clipping */
.resources-panel{position:fixed;display:none;width:280px;padding:10px;background:#ffffff;border:1px solid rgba(0,0,0,0.08);box-shadow:0 16px 40px rgba(0,0,0,0.12),0 4px 12px rgba(0,0,0,0.06);border-radius:14px;z-index:99999;font-family:'Inter',sans-serif}
.resources-panel.open{display:block;animation:rpFade .16s ease both}
@keyframes rpFade{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.resources-panel a{display:block;padding:10px 14px;border-radius:10px;text-decoration:none;color:#1a1a1a;transition:background .15s}
.resources-panel a:hover{background:rgba(201,80,110,0.08)}
.resources-panel a strong{display:block;font-family:'Outfit',sans-serif;font-size:14px;font-weight:600;letter-spacing:-0.01em;margin-bottom:2px}
.resources-panel a span{display:block;font-size:11.5px;color:rgba(26,26,26,0.55);font-weight:400}
.btn-pink{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background:linear-gradient(135deg,#E07A95,#C9506E);color:#fff;border:none;border-radius:10px;font-family:'Outfit',sans-serif;font-size:14px;font-weight:600;text-decoration:none;cursor:pointer;transition:transform 0.2s,box-shadow 0.2s}
.btn-pink:hover{transform:translateY(-1px);box-shadow:0 8px 24px rgba(201,80,110,0.3)}
.btn-glass{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background:rgba(255,255,255,0.4);color:#1a1a1a;border:1px solid rgba(255,255,255,0.55);border-radius:10px;font-family:'Outfit',sans-serif;font-size:14px;font-weight:500;text-decoration:none;cursor:pointer;transition:transform 0.2s,background 0.2s}
.btn-glass:hover{transform:translateY(-1px);background:rgba(255,255,255,0.6)}

/* HUB HERO */
.hub-hero{padding:160px 0 60px;text-align:center;position:relative}
.hub-hero .glow-orb{position:absolute;width:520px;height:520px;background:radial-gradient(circle,rgba(224,122,149,0.18),transparent 70%);top:-100px;left:50%;transform:translateX(-50%);pointer-events:none;z-index:-1;filter:blur(40px)}
.hub-eyebrow{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.18em;color:#C9506E;text-transform:uppercase;font-weight:600;margin-bottom:18px;display:inline-block;padding:6px 14px;background:rgba(201,80,110,0.08);border:1px solid rgba(201,80,110,0.18);border-radius:20px}
.hub-hero h1{font-size:clamp(2.4rem,5vw,3.8rem);font-weight:700;letter-spacing:-0.025em;line-height:1.08;margin-bottom:18px;color:#1a1a1a;max-width:880px;margin-left:auto;margin-right:auto}
.hub-hero p{font-size:clamp(1rem,1.5vw,1.1rem);color:rgba(26,26,26,0.65);line-height:1.65;max-width:620px;margin:0 auto}

/* FILTERS */
.filters{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin:36px auto 56px;max-width:880px}
.filter-pill{font-family:'Outfit',sans-serif;font-size:13px;font-weight:500;padding:9px 18px;border-radius:999px;background:rgba(255,255,255,0.55);border:1.5px solid rgba(255,255,255,0.85);color:rgba(26,26,26,0.7);cursor:pointer;transition:all 0.2s;box-shadow:0 2px 8px rgba(201,80,110,0.04)}
.filter-pill:hover{background:rgba(255,255,255,0.65);color:#1a1a1a}
.filter-pill.active{background:linear-gradient(135deg,#E07A95,#C9506E);color:#fff;border-color:transparent}

/* TOOL CARDS (hub grid) */
.tools-section{padding:0 0 80px}
.tool-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:40px}
@media(max-width:900px){.tool-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.tool-grid{grid-template-columns:1fr}}
.tool-card{display:flex;flex-direction:column;border-radius:20px;overflow:hidden;text-decoration:none;color:inherit;transition:transform 0.3s ease,box-shadow 0.3s ease,border-color 0.3s ease;background:rgba(255,255,255,0.55);backdrop-filter:blur(24px) saturate(1.5);-webkit-backdrop-filter:blur(24px) saturate(1.5);border:2px solid rgba(255,255,255,0.85);box-shadow:0 6px 24px rgba(201,80,110,0.06),0 2px 6px rgba(0,0,0,0.04);padding:28px}
.tool-card:hover{transform:translateY(-5px);box-shadow:0 24px 48px rgba(201,80,110,0.16),0 6px 12px rgba(0,0,0,0.06);border-color:rgba(201,80,110,0.25)}
.tool-card.hidden{display:none}
.tool-card-head{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.tool-card-logo{width:42px;height:42px;border-radius:10px;background:#fff;display:flex;align-items:center;justify-content:center;font-family:'Outfit',sans-serif;font-weight:700;font-size:18px;color:#C9506E;border:1px solid rgba(201,80,110,0.15);overflow:hidden}
.tool-card-logo img{width:100%;height:100%;object-fit:contain;padding:6px}
.tool-card-name{font-family:'Outfit',sans-serif;font-size:18px;font-weight:600}
.tool-card-tagline{font-size:14px;color:rgba(26,26,26,0.65);line-height:1.5;margin-bottom:18px;flex:1}
.tool-card-meta{display:flex;align-items:center;justify-content:space-between;padding-top:14px;border-top:1px solid rgba(26,26,26,0.06)}
.tool-card-cat{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.1em;text-transform:uppercase;color:rgba(26,26,26,0.5)}
.tool-card-score{font-family:'Outfit',sans-serif;font-size:13px;font-weight:600;color:#C9506E}
.tool-card-score-label{font-family:'Inter',sans-serif;font-size:10px;font-weight:500;color:rgba(26,26,26,0.5);margin-right:4px}

/* HERO CTA (top of page redirect button) */
.hero-cta-row{display:flex;align-items:center;gap:14px;margin-top:18px;flex-wrap:wrap}
.hero-cta-btn{display:inline-flex;align-items:center;gap:8px;padding:14px 26px;background:linear-gradient(135deg,#E07A95,#C9506E);color:#fff;border:none;border-radius:12px;font-family:'Outfit',sans-serif;font-size:15px;font-weight:600;text-decoration:none;cursor:pointer;transition:transform 0.2s,box-shadow 0.2s,filter 0.2s;box-shadow:0 6px 20px rgba(201,80,110,0.18)}
.hero-cta-btn:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(201,80,110,0.28);filter:brightness(1.05)}
.hero-cta-btn .arrow{transition:transform 0.2s}
.hero-cta-btn:hover .arrow{transform:translateX(4px)}
.hero-cta-note{font-size:13px;color:rgba(26,26,26,0.55);font-family:'Inter',sans-serif}

/* TOOL PAGE LAYOUT */
.tool-hero{padding:140px 0 40px}
.tool-hero-inner{display:grid;grid-template-columns:auto 1fr;gap:32px;align-items:center}
@media(max-width:700px){.tool-hero-inner{grid-template-columns:1fr;gap:20px}}
.tool-hero-logo{width:96px;height:96px;border-radius:20px;background:#fff;display:flex;align-items:center;justify-content:center;font-family:'Outfit',sans-serif;font-weight:700;font-size:38px;color:#C9506E;border:1px solid rgba(201,80,110,0.15);overflow:hidden}
.tool-hero-logo img{width:100%;height:100%;object-fit:contain;padding:14px}
.tool-eyebrow{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.18em;color:#C9506E;text-transform:uppercase;font-weight:600;margin-bottom:10px;display:inline-block;padding:6px 14px;background:rgba(201,80,110,0.08);border:1px solid rgba(201,80,110,0.18);border-radius:20px}
.tool-hero h1{font-size:clamp(2rem,4vw,3rem);font-weight:700;letter-spacing:-0.025em;line-height:1.1;margin-bottom:14px}
.tool-verdict{font-size:1.15rem;color:rgba(26,26,26,0.78);line-height:1.55;font-style:italic;border-left:3px solid #C9506E;padding-left:16px}

/* AT-A-GLANCE CARD */
.glance{display:grid;grid-template-columns:repeat(5,1fr);gap:0;border-radius:18px;overflow:hidden;margin:40px 0}
@media(max-width:900px){.glance{grid-template-columns:repeat(2,1fr)}}
@media(max-width:500px){.glance{grid-template-columns:1fr}}
.glance-cell{padding:20px;background:rgba(255,255,255,0.55);border-right:1px solid rgba(26,26,26,0.06);border-bottom:1px solid rgba(26,26,26,0.06)}
.glance-cell:last-child{border-right:none}
.glance-label{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.1em;text-transform:uppercase;color:rgba(26,26,26,0.5);margin-bottom:6px}
.glance-value{font-family:'Outfit',sans-serif;font-size:15px;font-weight:600;color:#1a1a1a}
.glance-fit{background:linear-gradient(135deg,rgba(224,122,149,0.12),rgba(201,80,110,0.06))}
.glance-fit .glance-value{font-size:24px;color:#C9506E}

/* SECTION HEADERS */
.tool-section{padding:48px 0}
.tool-section-eyebrow{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.18em;color:#C9506E;text-transform:uppercase;font-weight:600;margin-bottom:10px;display:inline-block}
.tool-section h2{font-size:clamp(1.5rem,2.5vw,2rem);font-weight:700;letter-spacing:-0.02em;margin-bottom:18px}
.tool-section p{font-size:1.05rem;color:rgba(26,26,26,0.78);line-height:1.7;margin-bottom:14px}
.tool-section h3{font-size:1.2rem;font-weight:600;margin:22px 0 10px;color:#1a1a1a}

/* WORKFLOW POSITION DIAGRAM */
.workflow-diagram{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:8px;margin:24px 0;padding:24px;background:rgba(255,255,255,0.45);border-radius:16px;border:1px solid rgba(255,255,255,0.6)}
.workflow-step{padding:10px 16px;border-radius:10px;font-family:'Outfit',sans-serif;font-size:13px;font-weight:500;background:rgba(255,255,255,0.55);border:1px solid rgba(26,26,26,0.08);color:rgba(26,26,26,0.6)}
.workflow-step.active{background:linear-gradient(135deg,#E07A95,#C9506E);color:#fff;font-weight:600;border-color:transparent;box-shadow:0 6px 16px rgba(201,80,110,0.25)}
.workflow-arrow{color:rgba(26,26,26,0.3);font-family:'JetBrains Mono',monospace}

/* YALC FRAMEWORK BLOCKS */
.framework-block{padding:24px;border-radius:16px;background:rgba(255,255,255,0.5);border:1px solid rgba(255,255,255,0.6);margin-bottom:18px}
.framework-block h3{margin-top:0;display:flex;align-items:center;gap:10px}
.framework-block h3::before{content:'';width:6px;height:6px;border-radius:50%;background:linear-gradient(135deg,#E07A95,#C9506E);display:inline-block}
.prompt-pattern{font-family:'JetBrains Mono',monospace;font-size:13px;line-height:1.55;background:rgba(26,26,26,0.05);border:1px solid rgba(26,26,26,0.08);border-left:3px solid #C9506E;padding:14px 16px;border-radius:8px;margin:10px 0;color:#1a1a1a;white-space:pre-wrap;word-break:break-word}
.chain-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin:8px 0;font-size:14px}
.chain-label{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:rgba(26,26,26,0.5);min-width:90px}
.anti-pattern{padding:10px 14px;background:rgba(201,80,110,0.06);border:1px solid rgba(201,80,110,0.15);border-radius:8px;margin:8px 0;font-size:14px}
.anti-pattern::before{content:'⚠ ';color:#C9506E;font-weight:600}
.skill-flag{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:10px;font-family:'Outfit',sans-serif;font-size:13px;font-weight:600;margin-top:10px}
.skill-flag.available{background:rgba(72,187,120,0.12);color:#2f855a;border:1px solid rgba(72,187,120,0.25)}
.skill-flag.requested{background:rgba(201,80,110,0.08);color:#C9506E;border:1px solid rgba(201,80,110,0.18)}

/* PROS/CONS GRID */
.pcw-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:18px}
@media(max-width:800px){.pcw-grid{grid-template-columns:1fr}}
.pcw-col{padding:20px;border-radius:14px;background:rgba(255,255,255,0.5);border:1px solid rgba(255,255,255,0.6)}
.pcw-col h4{font-family:'Outfit',sans-serif;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:0.1em;margin-bottom:12px}
.pcw-col.pros h4{color:#2f855a}
.pcw-col.cons h4{color:#C9506E}
.pcw-col.who h4{color:#1a1a1a}
.pcw-col ul{list-style:none;padding:0}
.pcw-col li{font-size:14px;line-height:1.55;padding:6px 0;color:rgba(26,26,26,0.78)}
.pcw-col li::before{content:'• ';color:rgba(26,26,26,0.4)}

/* PRICING TABLE */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:18px}
@media(max-width:800px){.pricing-grid{grid-template-columns:1fr}}
.pricing-col{padding:20px;border-radius:14px;background:rgba(255,255,255,0.5);border:1px solid rgba(255,255,255,0.6)}
.pricing-col h4{font-family:'Outfit',sans-serif;font-size:14px;font-weight:600;margin-bottom:8px}
.pricing-col .price{font-family:'Outfit',sans-serif;font-size:24px;font-weight:700;color:#C9506E;margin:6px 0}
.pricing-col p{font-size:13px;color:rgba(26,26,26,0.65);line-height:1.5;margin:0}

/* ALTERNATIVES + STACKS */
.alt-list,.stack-list{display:flex;flex-direction:column;gap:12px;margin-top:18px}
.alt-row{display:grid;grid-template-columns:auto 1fr auto;gap:16px;align-items:center;padding:16px 20px;border-radius:14px;background:rgba(255,255,255,0.5);border:1px solid rgba(255,255,255,0.6);text-decoration:none;color:inherit;transition:transform 0.2s,box-shadow 0.2s}
.alt-row:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(201,80,110,0.08)}
.alt-name{font-family:'Outfit',sans-serif;font-weight:600;font-size:15px}
.alt-rule{font-size:13px;color:rgba(26,26,26,0.65);line-height:1.5}
.alt-arrow{color:rgba(26,26,26,0.4);font-family:'JetBrains Mono',monospace}

/* FAQ */
.faq-list{display:flex;flex-direction:column;gap:10px;margin-top:18px}
.faq-item{padding:18px 22px;border-radius:14px;background:rgba(255,255,255,0.5);border:1px solid rgba(255,255,255,0.6);cursor:pointer}
.faq-item summary{font-family:'Outfit',sans-serif;font-size:15px;font-weight:600;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:14px}
.faq-item summary::after{content:'+';font-size:20px;color:#C9506E;transition:transform 0.2s}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item p{margin-top:12px;font-size:14px;color:rgba(26,26,26,0.78);line-height:1.65}

/* CTA BLOCK */
.tool-cta{padding:60px 0 80px}
.cta-card{padding:40px;border-radius:20px;background:linear-gradient(135deg,rgba(224,122,149,0.12),rgba(201,80,110,0.06));border:1px solid rgba(201,80,110,0.18);display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center}
@media(max-width:700px){.cta-card{grid-template-columns:1fr;text-align:center}}
.cta-text h2{font-size:1.5rem;font-weight:700;margin-bottom:8px}
.cta-text p{font-size:14px;color:rgba(26,26,26,0.7);margin:0}
.cta-btns{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
@media(max-width:700px){.cta-btns{justify-content:center}}

/* META FOOTER (last reviewed) */
.tool-meta-footer{padding:30px 0 80px;text-align:center;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:rgba(26,26,26,0.45)}

/* EMPTY STATE */
.empty-state{text-align:center;padding:80px 24px;color:rgba(26,26,26,0.5);font-size:14px;display:none}

/* STACK PAGE */
.stack-hero{padding:140px 0 40px;text-align:center}
.stack-icp{display:inline-block;padding:6px 14px;background:rgba(201,80,110,0.08);border:1px solid rgba(201,80,110,0.18);border-radius:20px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:#C9506E;margin-bottom:16px}
.stack-flow{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:8px;margin:30px 0 50px}
.stack-tool{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 18px;border-radius:14px;background:rgba(255,255,255,0.55);border:1px solid rgba(255,255,255,0.7);min-width:110px}
.stack-tool-name{font-family:'Outfit',sans-serif;font-weight:600;font-size:14px}
.stack-tool-role{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.1em;text-transform:uppercase;color:rgba(26,26,26,0.5)}
.stack-arrow{font-size:20px;color:rgba(201,80,110,0.5);font-family:'JetBrains Mono',monospace}
.stack-slot{display:grid;grid-template-columns:auto 1fr auto;gap:18px;align-items:center;padding:18px 22px;border-radius:14px;background:rgba(255,255,255,0.5);border:1px solid rgba(255,255,255,0.6);text-decoration:none;color:inherit;margin:10px 0;transition:transform 0.2s,box-shadow 0.2s}
.stack-slot:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(201,80,110,0.08)}
.runnable{padding:24px;border-radius:16px;background:rgba(26,26,26,0.04);border:1px solid rgba(26,26,26,0.1);margin-top:16px}
.runnable code{font-family:'JetBrains Mono',monospace;font-size:13px;line-height:1.6;color:#1a1a1a;display:block;white-space:pre-wrap;word-break:break-word}

/* HUB SEARCH BAR */
.hub-search{max-width:680px;margin:24px auto 16px;position:relative}
.hub-search input{width:100%;padding:14px 18px 14px 46px;border-radius:14px;border:1.5px solid rgba(255,255,255,0.85);background:rgba(255,255,255,0.6);font-family:'Inter',sans-serif;font-size:15px;color:#1a1a1a;outline:none;transition:border-color 0.2s,background 0.2s,box-shadow 0.2s;backdrop-filter:blur(20px) saturate(1.5)}
.hub-search input:focus{border-color:#E07A95;background:#fff;box-shadow:0 8px 24px rgba(201,80,110,0.12)}
.hub-search-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:rgba(26,26,26,0.5);pointer-events:none}
.hub-search-kbd{position:absolute;right:14px;top:50%;transform:translateY(-50%);padding:4px 10px;background:rgba(26,26,26,0.06);border:1px solid rgba(26,26,26,0.08);border-radius:6px;font-family:'JetBrains Mono',monospace;font-size:11px;color:rgba(26,26,26,0.5);pointer-events:none}

/* YALC PICKS (FEATURED) */
.picks-section{padding:40px 0 24px}
.picks-eyebrow{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.18em;color:#C9506E;text-transform:uppercase;font-weight:600;text-align:center;display:block;margin-bottom:8px}
.picks-section h2{text-align:center;font-size:clamp(1.6rem,3vw,2.2rem);font-weight:700;letter-spacing:-0.02em;margin-bottom:8px}
.picks-section .section-sub{text-align:center;font-size:14px;color:rgba(26,26,26,0.6);margin-bottom:32px;max-width:560px;margin-left:auto;margin-right:auto}
.picks-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:900px){.picks-grid{grid-template-columns:1fr}}
.pick-card{display:flex;flex-direction:column;border-radius:20px;text-decoration:none;color:inherit;padding:32px;background:rgba(255,255,255,0.6);backdrop-filter:blur(28px) saturate(1.6);-webkit-backdrop-filter:blur(28px) saturate(1.6);border:2px solid rgba(255,255,255,0.85);box-shadow:0 8px 28px rgba(201,80,110,0.08),0 2px 8px rgba(0,0,0,0.04);transition:transform 0.3s,box-shadow 0.3s,border-color 0.3s;position:relative;overflow:hidden}
.pick-card:hover{transform:translateY(-5px);box-shadow:0 24px 48px rgba(201,80,110,0.16);border-color:rgba(201,80,110,0.3)}
.pick-rank{position:absolute;top:18px;right:18px;font-family:'JetBrains Mono',monospace;font-size:11px;color:rgba(26,26,26,0.5);letter-spacing:0.1em}
.pick-head{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.pick-logo{width:54px;height:54px;border-radius:12px;background:#fff;display:flex;align-items:center;justify-content:center;font-family:'Outfit',sans-serif;font-weight:700;font-size:22px;color:#C9506E;border:1px solid rgba(201,80,110,0.15);overflow:hidden}
.pick-logo img{width:100%;height:100%;object-fit:contain;padding:8px}
.pick-name{font-family:'Outfit',sans-serif;font-size:22px;font-weight:700}
.pick-tagline{font-size:14px;color:rgba(26,26,26,0.7);line-height:1.55;margin-bottom:18px;flex:1}
.pick-verdict{font-size:13px;color:rgba(26,26,26,0.78);line-height:1.55;font-style:italic;border-left:2px solid #C9506E;padding-left:12px;margin-bottom:18px}
.pick-meta{display:flex;align-items:center;justify-content:space-between;padding-top:16px;border-top:1px solid rgba(26,26,26,0.06)}
.pick-cat{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.1em;text-transform:uppercase;color:rgba(26,26,26,0.5)}
.pick-fit{font-family:'Outfit',sans-serif;font-size:14px;font-weight:700;color:#C9506E}

/* TOOLS BY CATEGORY (sectioned listings) */
.cat-section{padding:48px 0}
.cat-header{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:28px;flex-wrap:wrap;border-bottom:1px solid rgba(26,26,26,0.08);padding-bottom:18px}
.cat-header h2{font-size:clamp(1.5rem,2.5vw,2rem);font-weight:700;letter-spacing:-0.02em;margin-bottom:6px}
.cat-header p{font-size:14px;color:rgba(26,26,26,0.6);line-height:1.55;max-width:560px;margin:0}
.cat-count{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:rgba(26,26,26,0.5);padding:6px 12px;background:rgba(255,255,255,0.5);border:1px solid rgba(255,255,255,0.7);border-radius:999px}
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:900px){.cat-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.cat-grid{grid-template-columns:1fr}}
.cat-card{position:relative;display:flex;flex-direction:column;border-radius:18px;text-decoration:none;color:inherit;padding:24px;background:rgba(255,255,255,0.5);backdrop-filter:blur(24px) saturate(1.5);-webkit-backdrop-filter:blur(24px) saturate(1.5);border:1.5px solid rgba(255,255,255,0.7);transition:transform 0.25s,box-shadow 0.25s,border-color 0.25s}
.cat-card:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(201,80,110,0.1);border-color:rgba(201,80,110,0.2)}
.cat-medal{position:absolute;top:14px;right:14px;font-size:18px;line-height:1}
.cat-card-head{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.cat-card-logo{width:38px;height:38px;border-radius:9px;background:#fff;display:flex;align-items:center;justify-content:center;font-family:'Outfit',sans-serif;font-weight:700;font-size:16px;color:#C9506E;border:1px solid rgba(201,80,110,0.15);overflow:hidden;flex-shrink:0}
.cat-card-logo img{width:100%;height:100%;object-fit:contain;padding:6px}
.cat-card-name{font-family:'Outfit',sans-serif;font-size:17px;font-weight:600}
.cat-card-tagline{font-size:13px;color:rgba(26,26,26,0.65);line-height:1.5;margin-bottom:14px;flex:1}
.cat-card-meta{display:flex;align-items:center;justify-content:space-between;padding-top:12px;border-top:1px solid rgba(26,26,26,0.06)}
.cat-card-fit{font-family:'Outfit',sans-serif;font-size:13px;font-weight:700;color:#C9506E}
.cat-card-fit-label{font-family:'Inter',sans-serif;font-size:10px;font-weight:500;color:rgba(26,26,26,0.5);margin-right:4px}
.cat-card-pricing{font-family:'JetBrains Mono',monospace;font-size:10px;color:rgba(26,26,26,0.5)}

/* STACKS BLOCK ON HUB */
.stacks-feature{padding:60px 0}
.stacks-feature-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:24px}
@media(max-width:700px){.stacks-feature-grid{grid-template-columns:1fr}}
.stack-feature-card{padding:28px;border-radius:18px;background:rgba(255,255,255,0.55);border:2px solid rgba(255,255,255,0.85);text-decoration:none;color:inherit;transition:transform 0.3s,box-shadow 0.3s}
.stack-feature-card:hover{transform:translateY(-3px);box-shadow:0 16px 32px rgba(201,80,110,0.1)}
.stack-feature-eyebrow{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.18em;color:#C9506E;text-transform:uppercase;font-weight:600;margin-bottom:10px;display:block}
.stack-feature-card h3{font-family:'Outfit',sans-serif;font-size:20px;font-weight:600;margin-bottom:8px}
.stack-feature-card p{font-size:14px;color:rgba(26,26,26,0.65);line-height:1.55;margin:0}

/* Top-of-article skill CTA banner */
.article-skill-cta{padding:8px 0 28px}
.skill-cta-card{display:flex;align-items:center;gap:18px;padding:18px 22px;background:linear-gradient(135deg,rgba(224,122,149,0.10),rgba(255,255,255,0.55));border:1.5px solid rgba(201,80,110,0.22);border-radius:16px;text-decoration:none;color:inherit;transition:transform .25s,box-shadow .25s,border-color .25s;backdrop-filter:blur(20px) saturate(1.4);-webkit-backdrop-filter:blur(20px) saturate(1.4);box-shadow:0 4px 16px rgba(201,80,110,0.06)}
.skill-cta-card:hover{transform:translateY(-2px);box-shadow:0 14px 30px rgba(201,80,110,0.16);border-color:rgba(201,80,110,0.40)}
.skill-cta-spark{flex-shrink:0;width:42px;height:42px;border-radius:12px;background:linear-gradient(135deg,#E07A95,#C9506E);color:#fff;display:flex;align-items:center;justify-content:center}
.skill-cta-text{flex:1;display:flex;flex-direction:column;gap:3px;min-width:0}
.skill-cta-text strong{font-family:'Outfit',sans-serif;font-size:15px;font-weight:600;color:#1a1a1a;letter-spacing:-0.01em;line-height:1.3}
.skill-cta-text span{font-size:13px;color:rgba(26,26,26,0.65);line-height:1.4}
.skill-cta-actions{flex-shrink:0;display:flex;align-items:center;gap:14px}
.skill-cta-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;background:linear-gradient(135deg,#E07A95,#C9506E);color:#fff;border-radius:10px;font-family:'Outfit',sans-serif;font-size:13px;font-weight:600;white-space:nowrap}
.skill-cta-link{display:inline-flex;align-items:center;gap:5px;font-family:'Outfit',sans-serif;font-size:12.5px;font-weight:500;color:#1a1a1a;opacity:0.7;white-space:nowrap;text-decoration:none}
.skill-cta-link:hover{opacity:1;color:#C9506E}
@media(max-width:680px){
  .skill-cta-card{flex-direction:column;align-items:flex-start;gap:14px;padding:18px}
  .skill-cta-actions{flex-direction:row;width:100%;justify-content:space-between}
}

/* ─────────────────────────────────────────────────────────────────
   BLOG ARTICLE — editorial layout
   Body prose set in Newsreader (refined serif), display in Outfit.
   ───────────────────────────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Newsreader:ital,opsz,wght@0,6..72,400;0,6..72,500;0,6..72,600;0,6..72,700;1,6..72,400;1,6..72,500&display=swap');

.container-prose{max-width:720px;margin:0 auto;padding:0 32px}

/* Article hero (title block) */
.article-hero{padding:140px 0 18px;text-align:center;position:relative}
.article-hero::before{content:'';position:absolute;width:560px;height:560px;background:radial-gradient(circle,rgba(224,122,149,0.16),transparent 70%);top:-140px;left:50%;transform:translateX(-50%);pointer-events:none;z-index:-1;filter:blur(40px)}
.article-eyebrow{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.18em;color:#C9506E;text-transform:uppercase;font-weight:600;display:inline-block;padding:6px 14px;background:rgba(201,80,110,0.08);border:1px solid rgba(201,80,110,0.18);border-radius:20px;margin-bottom:22px}
.article-title{font-family:'Outfit',sans-serif;font-weight:700;font-size:clamp(2.1rem,4.6vw,3.4rem);line-height:1.1;letter-spacing:-0.025em;color:#1a1a1a;margin:0 auto 18px;max-width:18ch}
.article-subtitle{font-family:'Newsreader',Georgia,serif;font-weight:400;font-size:clamp(1.05rem,1.6vw,1.22rem);line-height:1.55;color:rgba(26,26,26,0.68);max-width:60ch;margin:0 auto 28px;font-style:italic}
.article-meta{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:rgba(26,26,26,0.55);font-weight:600}
.article-meta>span{position:relative;padding-right:14px}
.article-meta>span:not(:last-child)::after{content:'';position:absolute;right:0;top:50%;width:3px;height:3px;background:rgba(201,80,110,0.5);border-radius:50%;transform:translateY(-50%)}
.article-meta .article-author{color:#C9506E}

/* Hero image — centered, rounded, contained */
.article-hero-image{padding:30px 0 14px}
.article-hero-image-inner{max-width:980px;margin:0 auto;padding:0 32px}
.article-hero-image-inner img{width:100%;height:auto;border-radius:24px;border:1px solid rgba(255,255,255,0.7);box-shadow:0 24px 60px rgba(201,80,110,0.14),0 6px 18px rgba(0,0,0,0.06);background:#f0e0d8;display:block}

/* Highlights panel */
.article-highlights-section{padding:18px 0 30px}
.article-highlights{background:rgba(255,255,255,0.55);backdrop-filter:blur(24px) saturate(1.5);-webkit-backdrop-filter:blur(24px) saturate(1.5);border:1.5px solid rgba(255,255,255,0.85);border-radius:20px;padding:28px 32px;box-shadow:0 6px 24px rgba(201,80,110,0.06),0 2px 6px rgba(0,0,0,0.04);position:relative}
.article-highlights-label{position:absolute;top:-11px;left:24px;font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:0.18em;color:#fff;text-transform:uppercase;font-weight:700;background:linear-gradient(135deg,#E07A95,#C9506E);padding:5px 12px;border-radius:6px;box-shadow:0 4px 10px rgba(201,80,110,0.25)}
.article-highlights ul{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:10px 28px}
.article-highlights li{font-family:'Inter',sans-serif;font-size:14.5px;line-height:1.5;color:rgba(26,26,26,0.78);padding-left:22px;position:relative}
.article-highlights li::before{content:'';position:absolute;left:0;top:9px;width:10px;height:2px;background:linear-gradient(90deg,#E07A95,#C9506E);border-radius:2px}
@media(max-width:680px){.article-highlights ul{grid-template-columns:1fr}.article-highlights{padding:24px 22px}}

/* Body prose — editorial serif */
.article-body-section{padding:36px 0 44px}
.article-body-section .container-narrow{max-width:720px}
.article-body{font-family:'Newsreader',Georgia,serif;font-size:19px;line-height:1.78;color:#2a2424;font-weight:400}
.article-body>*+*{margin-top:1.2em}
.article-body p{margin:0;font-feature-settings:"liga","kern"}
.article-body p+p{margin-top:1.1em}
.article-body p>strong{font-weight:600;color:#1a1a1a}
.article-body em{font-style:italic;color:#3a2f2f}
.article-body a{color:#C9506E;text-decoration:none;background-image:linear-gradient(currentColor,currentColor);background-position:0 100%;background-repeat:no-repeat;background-size:100% 1px;transition:background-size .2s ease,color .2s ease,padding-bottom .2s ease;padding-bottom:1px}
.article-body a:hover{color:#A23F58;background-size:100% 2px}
.article-body h2{font-family:'Outfit',sans-serif;font-size:clamp(1.55rem,2.6vw,1.95rem);font-weight:700;letter-spacing:-0.02em;line-height:1.2;color:#1a1a1a;margin:2.2em 0 0.6em;padding-top:1.4em;position:relative}
.article-body h2::before{content:'';position:absolute;top:0;left:0;width:36px;height:3px;background:linear-gradient(90deg,#E07A95,#C9506E);border-radius:2px}
.article-body h3{font-family:'Outfit',sans-serif;font-size:1.28rem;font-weight:600;letter-spacing:-0.01em;line-height:1.3;color:#1a1a1a;margin:1.7em 0 0.4em}
.article-body h4{font-family:'Outfit',sans-serif;font-size:1.08rem;font-weight:600;color:#1a1a1a;margin:1.5em 0 0.35em}
.article-body ul,.article-body ol{margin:0;padding-left:1.4em}
.article-body li{margin:0.35em 0;line-height:1.7}
.article-body ul li::marker{color:#C9506E}
.article-body ol li::marker{color:#C9506E;font-weight:600}
.article-body blockquote{margin:1.6em 0;padding:6px 0 6px 22px;border-left:3px solid #E07A95;font-style:italic;color:rgba(26,26,26,0.72);font-size:1.04em}
.article-body blockquote p{margin:0}
.article-body code{font-family:'JetBrains Mono',monospace;font-size:0.86em;background:rgba(201,80,110,0.09);color:#A23F58;padding:2px 7px;border-radius:5px;border:1px solid rgba(201,80,110,0.14)}
.article-body pre{font-family:'JetBrains Mono',monospace;font-size:13px;background:rgba(26,26,26,0.04);border:1px solid rgba(26,26,26,0.08);border-radius:12px;padding:18px 20px;overflow-x:auto;line-height:1.55}
.article-body pre code{background:transparent;border:none;padding:0;color:#1a1a1a}
.article-body hr{border:none;height:1px;background:linear-gradient(90deg,transparent,rgba(201,80,110,0.3),transparent);margin:2.4em auto;width:60%}
.article-body img{border-radius:14px;margin:1.6em 0;border:1px solid rgba(255,255,255,0.7);box-shadow:0 10px 28px rgba(201,80,110,0.08)}
.article-body figure{margin:1.8em 0}
.article-body figcaption{font-family:'Inter',sans-serif;font-size:13px;color:rgba(26,26,26,0.55);text-align:center;margin-top:10px;font-style:italic}
.article-body table{width:100%;border-collapse:collapse;margin:1.6em 0;font-family:'Inter',sans-serif;font-size:14.5px}
.article-body th,.article-body td{padding:10px 14px;text-align:left;border-bottom:1px solid rgba(26,26,26,0.08)}
.article-body th{font-family:'Outfit',sans-serif;font-weight:600;color:#1a1a1a;background:rgba(201,80,110,0.05)}
@media(max-width:680px){.article-body{font-size:17.5px;line-height:1.72}}

/* Article CTA wrapper (the .cta-card itself is already styled) */
.article-cta{padding:24px 0 36px}

/* Footer keyword line */
.article-footer-keyword{padding:8px 0 56px}
.article-footer-keyword p{font-family:'Newsreader',Georgia,serif;font-style:italic;font-size:14.5px;color:rgba(26,26,26,0.5);text-align:center;margin:0;line-height:1.55}

/* Related articles */
.related-articles{padding:24px 0 96px;border-top:1px solid rgba(26,26,26,0.06);margin-top:20px}
.related-articles-title{font-family:'Outfit',sans-serif;font-size:clamp(1.4rem,2.4vw,1.85rem);font-weight:700;letter-spacing:-0.02em;color:#1a1a1a;margin:36px 0 26px;text-align:center}
.related-articles-list{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1180px;margin:0 auto}
.related-article-card{display:flex;flex-direction:column;gap:10px;padding:24px;border-radius:18px;text-decoration:none;color:inherit;background:rgba(255,255,255,0.55);backdrop-filter:blur(24px) saturate(1.5);-webkit-backdrop-filter:blur(24px) saturate(1.5);border:1.5px solid rgba(255,255,255,0.85);box-shadow:0 4px 16px rgba(201,80,110,0.05),0 1px 3px rgba(0,0,0,0.04);transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease}
.related-article-card:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(201,80,110,0.14),0 4px 10px rgba(0,0,0,0.05);border-color:rgba(201,80,110,0.28)}
.related-article-eyebrow{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.16em;text-transform:uppercase;color:#C9506E;font-weight:600;padding:4px 9px;background:rgba(201,80,110,0.08);border:1px solid rgba(201,80,110,0.18);border-radius:5px;align-self:flex-start}
.related-article-title{font-family:'Outfit',sans-serif;font-size:1.15rem;font-weight:700;line-height:1.3;letter-spacing:-0.01em;color:#1a1a1a;margin:6px 0 0}
.related-article-excerpt{font-family:'Inter',sans-serif;font-size:14px;line-height:1.55;color:rgba(26,26,26,0.62);margin:0;flex:1}
.related-article-arrow{font-family:'Outfit',sans-serif;font-size:13px;font-weight:600;color:#C9506E;margin-top:6px;display:inline-flex;align-items:center;gap:4px;transition:gap .2s ease}
.related-article-card:hover .related-article-arrow{gap:8px}
@media(max-width:980px){.related-articles-list{grid-template-columns:1fr 1fr}}
@media(max-width:680px){.related-articles-list{grid-template-columns:1fr;gap:18px;padding:0 16px}.related-articles{padding:18px 0 72px}}

/* Hero responsive */
@media(max-width:680px){
  .article-hero{padding:120px 0 8px}
  .article-hero-image{padding:22px 0 8px}
  .article-hero-image-inner{padding:0 16px}
  .article-hero-image-inner img{border-radius:18px}
  .article-body-section{padding:26px 0 28px}
  .container-narrow,.container-prose{padding:0 22px}
}
