/* bestpersonaldevelopmentapps.com — "warm editorial almanac" identity (brand.md, playbook 06)
   Theming lives entirely in CSS variables so this site's identity is unique & contained. */

:root{
  --paper:#F6F1E7;
  --surface:#FCFAF4;
  --surface-2:#F1E9D9;
  --ink:#23211B;
  --green:#1E3A32;
  --green-700:#244A40;
  --green-deep:#142721;
  --clay:#B2552F;
  --clay-dark:#8F4022;
  --accent-soft:#E8DBC8;
  --muted:#6E685A;
  --line:#DED3BE;
  --good:#3F7A4F;
  --bad:#A6492F;
  --radius:14px;
  --radius-sm:9px;
  --maxw:1080px;
  --prose:680px;
  --shadow:0 1px 2px rgba(20,39,33,.06), 0 8px 26px rgba(20,39,33,.07);
  --shadow-lg:0 18px 50px rgba(20,39,33,.13);
  --display:"Fraunces", Georgia, "Times New Roman", serif;
  --body:"Hanken Grotesk", "Segoe UI", system-ui, -apple-system, sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--body);
  color:var(--ink);
  background-color:var(--paper);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");
  line-height:1.62;
  font-size:18px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--green);text-underline-offset:3px;text-decoration-thickness:1px}
a:hover{color:var(--clay)}
:focus-visible{outline:3px solid var(--clay);outline-offset:2px;border-radius:4px}

.container{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.skip{position:absolute;left:-9999px}
.skip:focus{left:12px;top:12px;background:var(--green);color:#fff;padding:10px 14px;border-radius:8px;z-index:50}

/* ---------- typography ---------- */
h1,h2,h3,h4{font-family:var(--display);font-weight:600;line-height:1.12;color:var(--green-deep);letter-spacing:-.01em;margin:0 0 .5em}
h1{font-size:clamp(2.1rem,5vw,3.4rem);font-weight:500}
h2{font-size:clamp(1.5rem,3vw,2.1rem);margin-top:1.6em}
h3{font-size:1.22rem;margin-top:1.5em}
p{margin:0 0 1.05em}
.lead{font-size:1.18rem;color:#3a382f}
.kicker{font-family:var(--body);font-weight:700;font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--clay);margin:0 0 .6em}
.muted{color:var(--muted)}
.small{font-size:.86rem}
.prose{max-width:var(--prose)}
.prose h2,.prose h3{max-width:100%}
hr{border:none;border-top:1px solid var(--line);margin:2.4rem 0}

/* ---------- header ---------- */
.site-header{background:var(--green-deep);color:#f3ede0;position:sticky;top:0;z-index:40}
.site-header .container{display:flex;align-items:center;gap:18px;min-height:64px}
.brand{display:flex;align-items:center;gap:11px;text-decoration:none;color:#fff;font-family:var(--display);font-weight:600;font-size:1.06rem;line-height:1.05;letter-spacing:-.01em}
.brand .mark{width:34px;height:34px;border-radius:9px;background:linear-gradient(150deg,var(--clay),#d98a4f);display:grid;place-items:center;color:#fff;font-weight:700;font-family:var(--display);flex:0 0 auto;box-shadow:inset 0 0 0 1px rgba(255,255,255,.14)}
.brand small{display:block;font-family:var(--body);font-weight:500;font-size:.66rem;letter-spacing:.04em;color:#bcd1c4;text-transform:uppercase}
.nav{margin-left:auto;display:flex;align-items:center;gap:6px}
.nav a{color:#dfeae0;text-decoration:none;font-size:.93rem;font-weight:600;padding:9px 11px;border-radius:8px}
.nav a:hover{color:#fff;background:rgba(255,255,255,.08)}
.nav .nav-cta{background:var(--clay);color:#fff;padding:9px 15px}
.nav .nav-cta:hover{background:#c4663b}
.menu-toggle,.menu-check{display:none}

@media (max-width:860px){
  .nav{position:fixed;inset:64px 0 auto 0;background:var(--green-deep);flex-direction:column;align-items:stretch;gap:2px;padding:10px 16px 18px;margin:0;display:none;border-top:1px solid rgba(255,255,255,.1)}
  .nav a{padding:12px 10px}
  .menu-check:checked ~ .nav{display:flex}
  .menu-toggle{display:inline-grid;place-items:center;margin-left:auto;width:42px;height:42px;border-radius:9px;background:rgba(255,255,255,.08);color:#fff;cursor:pointer;font-size:1.3rem;border:none}
}

/* ---------- disclosure strip (conspicuous, playbook 16) ---------- */
.disclosure-strip{background:var(--accent-soft);border-bottom:1px solid var(--line);color:#4a3f2c;font-size:.9rem}
.disclosure-strip .container{padding-top:10px;padding-bottom:10px;display:flex;gap:10px;align-items:flex-start}
.disclosure-strip .dot{flex:0 0 auto;margin-top:2px}
.disclosure-strip a{color:var(--clay-dark);font-weight:700}

/* ---------- hero ---------- */
.hero{padding:54px 0 22px}
.hero .lead{max-width:660px}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:18px}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:.97rem;padding:13px 22px;border-radius:999px;text-decoration:none;border:1px solid transparent;cursor:pointer;transition:transform .12s ease, box-shadow .12s ease, background .15s}
.btn-cta{background:var(--clay);color:#fff;box-shadow:0 6px 18px rgba(178,85,47,.28)}
.btn-cta:hover{background:#c4663b;color:#fff;transform:translateY(-1px);box-shadow:0 10px 26px rgba(178,85,47,.34)}
.btn-ghost{background:transparent;color:var(--green);border-color:var(--green)}
.btn-ghost:hover{background:var(--green);color:#fff}
.btn-sm{padding:9px 16px;font-size:.86rem}
.cta-note{font-size:.78rem;color:var(--muted);margin-top:7px}

/* ---------- sections ---------- */
section{padding:14px 0}
.section-pad{padding:30px 0}
.band{background:var(--surface);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.reveal{opacity:0;transform:translateY(10px);animation:rise .7s cubic-bezier(.2,.7,.2,1) forwards}
.reveal:nth-child(2){animation-delay:.06s}.reveal:nth-child(3){animation-delay:.12s}.reveal:nth-child(4){animation-delay:.18s}
@keyframes rise{to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){.reveal{animation:none;opacity:1;transform:none}}

/* ---------- ranking table ---------- */
.rank-wrap{margin:22px 0}
.rank-table{width:100%;border-collapse:separate;border-spacing:0;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.rank-table th,.rank-table td{padding:16px 16px;text-align:left;vertical-align:top;border-bottom:1px solid var(--line)}
.rank-table thead th{background:var(--green);color:#eef4ee;font-family:var(--body);font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700}
.rank-table tbody tr:last-child td{border-bottom:none}
.rank-table .num{font-family:var(--display);font-size:1.7rem;color:var(--muted);width:46px;font-weight:600}
.rank-table .app{font-weight:700;font-size:1.06rem;color:var(--green-deep)}
.rank-table .app .cat{display:block;font-weight:500;font-size:.82rem;color:var(--muted);font-family:var(--body)}
.rank-table .score{font-family:var(--display);font-size:1.35rem;color:var(--green);font-weight:600}
.rank-table tr.top td{background:linear-gradient(0deg,rgba(232,219,200,.5),rgba(232,219,200,.5)),var(--surface)}
.rank-table tr.top .num{color:var(--clay)}
.pill{display:inline-block;font-size:.66rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;background:var(--clay);color:#fff;padding:3px 9px;border-radius:999px;vertical-align:middle;margin-left:6px}
@media (max-width:760px){
  .rank-table thead{display:none}
  .rank-table,.rank-table tbody,.rank-table tr,.rank-table td{display:block;width:100%}
  .rank-table tr{border-bottom:1px solid var(--line);padding:6px 0}
  .rank-table td{border:none;padding:6px 16px}
  .rank-table td.actions{padding-bottom:16px}
}

/* ---------- cards / grids ---------- */
.grid{display:grid;gap:18px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media (max-width:860px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);transition:transform .14s ease,box-shadow .14s ease}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.card h3{margin-top:0}
.card .cat{font-size:.8rem;color:var(--clay);font-weight:700;letter-spacing:.04em;text-transform:uppercase}
.card-link{text-decoration:none;color:inherit;display:block}

/* ---------- rating badges ---------- */
.badges{display:flex;flex-wrap:wrap;gap:8px;margin:6px 0 2px}
.badge{display:inline-flex;align-items:center;gap:6px;background:var(--surface-2);border:1px solid var(--line);border-radius:999px;padding:5px 11px;font-size:.82rem;font-weight:600;color:#4a3f2c}
.badge b{color:var(--green-deep)}
.badge .star{color:var(--clay)}

/* ---------- verdict box ---------- */
.verdict{background:var(--surface);border:1px solid var(--line);border-left:5px solid var(--clay);border-radius:var(--radius);padding:20px 22px;box-shadow:var(--shadow);margin:18px 0}
.verdict .kicker{margin-bottom:.4em}
.verdict p:last-child{margin-bottom:0}
.scorechip{display:inline-flex;align-items:baseline;gap:6px;background:var(--green);color:#fff;border-radius:10px;padding:6px 12px;font-family:var(--display);font-weight:600}
.scorechip span{font-size:.74rem;font-family:var(--body);font-weight:600;opacity:.85}

/* ---------- pros / cons ---------- */
.proscons{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:18px 0}
@media (max-width:560px){.proscons{grid-template-columns:1fr}}
.proscons .box{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px}
.proscons h4{font-family:var(--body);font-weight:800;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;margin:0 0 10px}
.proscons .pros h4{color:var(--good)}
.proscons .cons h4{color:var(--bad)}
.proscons ul{list-style:none;margin:0;padding:0}
.proscons li{padding-left:26px;position:relative;margin-bottom:9px;font-size:.95rem}
.proscons .pros li::before{content:"✓";position:absolute;left:0;color:var(--good);font-weight:800}
.proscons .cons li::before{content:"–";position:absolute;left:2px;color:var(--bad);font-weight:800}

/* ---------- pricing ---------- */
.plans{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin:16px 0}
.plan{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);padding:15px}
.plan .pname{font-weight:700;font-size:.92rem}
.plan .pprice{font-family:var(--display);font-size:1.4rem;color:var(--green);font-weight:600}
.plan .pper{color:var(--muted);font-size:.85rem}
.plan .pnote{font-size:.78rem;color:var(--clay-dark);margin-top:4px}

/* ---------- feature checklist ---------- */
.features{display:grid;grid-template-columns:repeat(2,1fr);gap:6px 22px;margin:14px 0;padding:0;list-style:none}
@media (max-width:560px){.features{grid-template-columns:1fr}}
.features li{display:flex;gap:10px;align-items:baseline;padding:7px 0;border-bottom:1px dashed var(--line);font-size:.93rem}
.features .fk{color:#4a463b}
.features .fv{margin-left:auto;font-weight:700;text-align:right}
.features .yes{color:var(--good)}
.features .no{color:#b9ae98}

/* ---------- comparison table ---------- */
.compare{width:100%;border-collapse:collapse;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;margin:18px 0;box-shadow:var(--shadow)}
.compare th,.compare td{padding:13px 15px;text-align:left;border-bottom:1px solid var(--line);font-size:.95rem;vertical-align:top}
.compare thead th{background:var(--green);color:#eef4ee;font-family:var(--body);font-size:.78rem;letter-spacing:.06em;text-transform:uppercase}
.compare tbody th{font-weight:700;color:var(--muted);font-family:var(--body);font-size:.82rem;width:34%}
.compare td.win{background:rgba(232,219,200,.45);font-weight:600}
.compare tr:last-child td,.compare tr:last-child th{border-bottom:none}

/* ---------- FAQ (zero-JS details/summary) ---------- */
.faq{margin:18px 0}
.faq details{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);margin-bottom:10px;overflow:hidden}
.faq summary{cursor:pointer;padding:15px 18px;font-weight:700;color:var(--green-deep);list-style:none;display:flex;justify-content:space-between;gap:12px;font-size:1.01rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--clay);font-weight:800;font-size:1.3rem;line-height:1}
.faq details[open] summary::after{content:"–"}
.faq details > div{padding:0 18px 16px;color:#3c3a31}

/* ---------- breadcrumbs / subnav ---------- */
.crumbs{font-size:.82rem;color:var(--muted);padding:14px 0 0}
.crumbs a{color:var(--muted);text-decoration:none}
.crumbs a:hover{color:var(--clay)}
.subnav{position:sticky;top:64px;z-index:30;background:var(--surface);border-bottom:1px solid var(--line);margin:0 0 8px}
.subnav .container{display:flex;gap:4px;overflow-x:auto;padding-top:8px;padding-bottom:8px}
.subnav a{white-space:nowrap;font-size:.86rem;font-weight:600;color:var(--green);text-decoration:none;padding:7px 12px;border-radius:8px}
.subnav a:hover{background:var(--accent-soft)}

/* ---------- author / trust ---------- */
.author-box{display:flex;gap:14px;align-items:flex-start;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;margin:22px 0}
.author-box .ava{width:50px;height:50px;border-radius:50%;background:linear-gradient(150deg,var(--green),var(--green-700));color:#fff;display:grid;place-items:center;font-family:var(--display);font-weight:600;font-size:1.2rem;flex:0 0 auto}
.author-box .nm{font-weight:700;color:var(--green-deep)}
.author-box .rl{font-size:.83rem;color:var(--clay-dark);font-weight:600}
.author-box .bio{font-size:.9rem;margin:6px 0 0;color:#46443a}
.byline{font-size:.88rem;color:var(--muted);margin:-6px 0 18px}
.byline b{color:var(--ink)}
.trust-strip{display:flex;flex-wrap:wrap;gap:10px 20px;align-items:center;padding:16px 0;color:var(--muted);font-size:.85rem}
.trust-strip .chip{display:inline-flex;align-items:center;gap:7px;background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:7px 13px;font-weight:600;color:#4a463b}

/* ---------- callouts ---------- */
.callout{border-radius:var(--radius);padding:16px 18px;margin:18px 0;font-size:.93rem;border:1px solid}
.callout.crisis{background:#fbeee9;border-color:#e9c7b8;color:#6b3520}
.callout.disclaimer{background:var(--surface);border-color:var(--line);color:#46443a}
.callout b{color:inherit}

/* ---------- mini provider verdict rows (listicle write-ups) ---------- */
.writeup{border-top:1px solid var(--line);padding:24px 0}
.writeup:first-of-type{border-top:none}
.writeup .head{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.writeup .num{font-family:var(--display);font-size:2rem;color:var(--clay);font-weight:600;line-height:1}
.writeup h3{margin:0}
.writeup .meta{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0}

/* ---------- footer ---------- */
.site-footer{background:var(--green-deep);color:#cdded2;margin-top:64px;padding:54px 0 28px;font-size:.92rem;position:relative}
.site-footer::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--clay),#d98a4f 55%,rgba(217,138,79,0))}
.footer-cols{display:grid;grid-template-columns:1.7fr repeat(4,1fr);gap:32px 26px}
.foot-brand{max-width:34ch}
@media (max-width:860px){.footer-cols{grid-template-columns:repeat(2,1fr);gap:28px 24px}.foot-brand{grid-column:1 / -1;max-width:48ch}}
@media (max-width:560px){.footer-cols{grid-template-columns:1fr;gap:24px}}
.site-footer h4{color:#fff;font-family:var(--body);font-size:.73rem;letter-spacing:.14em;text-transform:uppercase;margin:0 0 14px}
.site-footer ul{list-style:none;margin:0;padding:0}
.site-footer li{margin-bottom:9px}
.site-footer a{color:#c2d4c8;text-decoration:none;transition:color .14s}
.site-footer a:hover{color:#fff}
.foot-col a:hover{text-decoration:underline;text-underline-offset:3px}
.site-footer .brand{color:#fff;margin-bottom:14px}
.foot-disc{font-size:.85rem;color:#93a89b;line-height:1.55}
.foot-disc a{color:#e7d3b9;text-decoration:underline;text-underline-offset:2px}
.foot-disc a:hover{color:#fff}
.foot-bottom{border-top:1px solid rgba(255,255,255,.13);margin-top:42px;padding-top:22px;display:flex;flex-direction:column;gap:16px}
.foot-util{display:flex;flex-wrap:wrap;align-items:center;row-gap:6px}
.foot-util a{position:relative;font-weight:600;color:#cdded2;padding:2px 15px}
.foot-util a:first-child{padding-left:0}
.foot-util a + a::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:1px;height:13px;background:rgba(255,255,255,.22)}
.foot-util a:hover{color:#fff}
.foot-legal{display:flex;flex-wrap:wrap;justify-content:space-between;gap:6px 24px;color:#8ea597;font-size:.8rem}
.foot-med{max-width:62ch}

/* ---------- generic list spacing in prose ---------- */
.prose ul,.prose ol{margin:0 0 1.1em;padding-left:1.3em}
.prose li{margin-bottom:.5em}
.tldr{background:var(--accent-soft);border-radius:var(--radius);padding:18px 20px;margin:0 0 22px}
.tldr .kicker{margin-bottom:.4em}
.tldr p:last-child{margin-bottom:0}
.post-meta{color:var(--muted);font-size:.88rem;margin-bottom:6px}

/* ---------- app logos / review header / expert pages (added) ---------- */
.appcell{display:flex;align-items:center;gap:11px}
.logo{border-radius:9px;flex:0 0 auto;vertical-align:middle;box-shadow:var(--shadow)}
.logo-lg{border-radius:16px}
.review-head{display:flex;align-items:center;gap:18px;margin-bottom:8px}
.review-head h1{margin:0 0 .15em}
.review-head .byline{margin:0}
.review-head .kicker{margin-bottom:.3em}
.writeup .head .logo{margin:0 2px}
.btn-pair{display:inline-flex;gap:8px;flex-wrap:wrap}
.ava-lg{width:84px;height:84px;font-size:2rem;flex:0 0 auto}
@media (max-width:560px){.review-head{gap:12px}.ava-lg{width:64px;height:64px;font-size:1.5rem}}

/* ---------- article images, review screenshots, contact form (added) ---------- */
figure.post-img{margin:24px 0}
figure.post-img img{width:100%;height:auto;border-radius:var(--radius);border:1px solid var(--line);box-shadow:var(--shadow)}
figure.post-img figcaption{font-size:.78rem;color:var(--muted);margin-top:8px}
figure.post-img figcaption a{color:var(--muted);text-decoration:underline}
.shots{display:flex;gap:14px;overflow-x:auto;padding:8px 2px 16px;margin:18px 0;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory}
.shots img{height:460px;width:auto;border-radius:20px;border:1px solid var(--line);box-shadow:var(--shadow-lg);flex:0 0 auto;background:var(--surface);scroll-snap-align:start}
@media (max-width:560px){.shots img{height:380px}}
.form{max-width:580px;margin:20px 0}
.form label{display:block;font-weight:700;font-size:.9rem;margin:16px 0 6px;color:var(--green-deep)}
.form input,.form textarea{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);font:inherit;color:var(--ink)}
.form input:focus,.form textarea:focus{outline:3px solid var(--clay);outline-offset:1px;border-color:var(--clay)}
.form textarea{min-height:150px;resize:vertical}
.form .hp{position:absolute!important;left:-9999px;width:1px;height:1px;overflow:hidden}
.form button.btn{margin-top:20px;border:none;cursor:pointer}
.form .formnote{font-size:.82rem;color:var(--muted);margin-top:12px}

/* ---------- compare tool controls (added) ---------- */
.cmp-controls{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;margin:14px 0;display:flex;flex-wrap:wrap;gap:14px 26px;align-items:center}
.cmp-filters{display:flex;flex-wrap:wrap;gap:8px 16px;align-items:center}
.cmp-label{font-weight:700;font-size:.86rem;color:var(--green-deep)}
.cmp-filters label{display:inline-flex;align-items:center;gap:6px;font-size:.88rem;cursor:pointer}
.cmp-filters input{width:16px;height:16px;accent-color:var(--clay)}
.cmp-sortwrap{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-left:auto}
.cmp-sortwrap label{font-weight:700;font-size:.86rem;color:var(--green-deep)}
.cmp-sortwrap select{padding:8px 10px;border:1px solid var(--line);border-radius:8px;background:var(--surface);font:inherit;color:var(--ink)}
#cmp td[data-s]{font-family:var(--display);color:var(--green);font-size:1.05rem}
#cmp .appcell a{text-decoration:none}

/* Language switcher (i18n: EN/ES/PT) — sits at the end of the primary nav */
.lang-switch{display:inline-flex;align-items:center;gap:2px;margin-left:8px;padding:3px;border:1px solid rgba(255,255,255,.22);border-radius:999px}
.lang-switch a,.lang-switch .ls-cur{font-family:var(--body);font-size:.74rem;font-weight:800;letter-spacing:.04em;line-height:1;padding:5px 9px;border-radius:999px;text-decoration:none}
.lang-switch a{color:#cfe0d3}
.lang-switch a:hover{color:#fff;background:rgba(255,255,255,.12)}
.lang-switch .ls-cur{background:var(--clay);color:#fff}
@media(max-width:860px){
  .nav .lang-switch{margin:8px 10px 2px;align-self:flex-start}
}

/* ============ modern polish pass (2026-06-17) ============ */
::selection{background:var(--clay);color:#fff}

/* sticky header: depth + hairline so it lifts off content on scroll */
.site-header{box-shadow:0 1px 0 rgba(255,255,255,.05), 0 8px 24px rgba(20,39,33,.16)}

/* hero: warm radial atmosphere (depth without clutter) */
.hero{position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;z-index:0;top:-150px;right:-160px;width:560px;height:560px;border-radius:50%;
  background:radial-gradient(circle at center,rgba(178,85,47,.13),rgba(178,85,47,0) 70%);pointer-events:none}
.hero > .container{position:relative;z-index:1}

/* prose links: subtle underline that warms to clay on hover (refines the default, no double rule) */
.prose a:not(.btn){text-decoration-color:var(--accent-soft);text-decoration-thickness:1.5px;transition:color .18s,text-decoration-color .18s}
.prose a:not(.btn):hover{color:var(--clay);text-decoration-color:var(--clay)}

/* cards: clay top-accent wipe on hover + crisper lift */
.card{position:relative;overflow:hidden}
.card::after{content:"";position:absolute;left:0;top:0;height:3px;width:100%;background:linear-gradient(90deg,var(--clay),#d98a4f);transform:scaleX(0);transform-origin:left;transition:transform .28s ease}
.card:hover::after{transform:scaleX(1)}

/* buttons: tactile press */
.btn:active{transform:translateY(0) scale(.985)}

/* thin, branded scrollbars on horizontal scrollers */
.shots,.subnav .container{scrollbar-width:thin;scrollbar-color:var(--line) transparent}
.shots::-webkit-scrollbar,.subnav .container::-webkit-scrollbar{height:8px}
.shots::-webkit-scrollbar-thumb,.subnav .container::-webkit-scrollbar-thumb{background:var(--line);border-radius:99px}
.shots::-webkit-scrollbar-track,.subnav .container::-webkit-scrollbar-track{background:transparent}

/* FAQ: gentle emphasis when open */
.faq details[open]{box-shadow:var(--shadow);border-color:var(--accent-soft)}
.faq details[open] summary{color:var(--clay-dark)}
.faq summary:hover{color:var(--clay-dark)}

/* rating-table rows: quiet hover so long tables stay scannable */
.rank-table tbody tr{transition:background .14s}
.rank-table tbody tr:hover td{background:rgba(232,219,200,.32)}
.rank-table tr.top:hover td{background:linear-gradient(0deg,rgba(232,219,200,.62),rgba(232,219,200,.62)),var(--surface)}

/* badges + chips: subtle interactive feedback */
.badge,.trust-strip .chip{transition:border-color .14s,background .14s,transform .14s}
.trust-strip .chip:hover{border-color:var(--clay);transform:translateY(-1px)}

/* nicer mobile menu button affordance */
.menu-toggle:hover{background:rgba(255,255,255,.14)}
