/*
Theme Name: MeetOnCam
Theme URI: https://meetoncam.com
Author: MeetOnCam
Author URI: https://meetoncam.com
Description: Next-generation, 3D & interactive cam-discovery and review theme. Aurora/neon "after-dark" design system with a swipeable 3D live deck, match quiz and conversion-first review, comparison and category templates. Built for an affiliate funnel (Jerkmate widget + CrakRevenue SmartLink) with Review/Article/ItemList/FAQ schema.
Version: 1.2.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: meetoncam
Tags: dark, custom-colors, custom-menu, featured-images, full-width-template, theme-options, translation-ready
*/

/* ============================== TOKENS ============================== */
:root{
  --bg:        oklch(0.13 0.028 285);
  --bg-2:      oklch(0.10 0.025 285);
  --surface:   oklch(0.19 0.035 285 / 0.55);
  --text:      oklch(0.97 0.01 285);
  --muted:     oklch(0.74 0.03 285);
  --faint:     oklch(0.60 0.03 285);
  --magenta:   oklch(0.68 0.27 350);
  --magenta-2: oklch(0.74 0.24 350);
  --cyan:      oklch(0.82 0.15 200);
  --gold:      oklch(0.84 0.14 85);
  --live:      oklch(0.80 0.19 150);
  --border:    oklch(1 0 0 / 0.10);
  --glass:     oklch(1 0 0 / 0.045);
  --grad-primary: linear-gradient(115deg, oklch(0.68 0.27 350), oklch(0.62 0.25 305) 55%, oklch(0.74 0.18 220));
  --grad-neon:    linear-gradient(135deg, oklch(0.68 0.27 350), oklch(0.82 0.15 200));
  --grad-gold:    linear-gradient(135deg, oklch(0.86 0.14 90), oklch(0.78 0.16 60));
  --shadow-neon:  0 30px 80px -30px oklch(0.68 0.27 350 / 0.55);
  --shadow-cyan:  0 30px 80px -30px oklch(0.82 0.15 200 / 0.45);
  --radius: 22px;
  --maxw: 1200px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Hanken Grotesk",system-ui,sans-serif;
  background:var(--bg); color:var(--text);
  -webkit-font-smoothing:antialiased; overflow-x:hidden; line-height:1.5;
}
h1,h2,h3,.display{font-family:"Syne",sans-serif;letter-spacing:-0.02em;line-height:1.05}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.grad-text{background:var(--grad-primary);-webkit-background-clip:text;background-clip:text;color:transparent}
.glass{background:var(--glass);border:1px solid var(--border);backdrop-filter:blur(20px) saturate(160%)}
.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:12px;top:12px;z-index:200;background:var(--bg);padding:10px 16px;border-radius:10px;border:1px solid var(--border)}

/* ============================== ATMOSPHERE ============================== */
.aurora{position:fixed;inset:0;z-index:-2;overflow:hidden;background:
   radial-gradient(60% 70% at 18% 8%, oklch(0.68 0.27 350 / 0.28), transparent 70%),
   radial-gradient(55% 65% at 88% 18%, oklch(0.62 0.25 305 / 0.26), transparent 70%),
   radial-gradient(60% 60% at 60% 100%, oklch(0.74 0.18 220 / 0.22), transparent 70%),
   linear-gradient(180deg, var(--bg), var(--bg-2));}
.aurora::before,.aurora::after{content:"";position:absolute;width:55vw;height:55vw;border-radius:50%;filter:blur(80px);opacity:.5;mix-blend-mode:screen}
.aurora::before{background:radial-gradient(circle,oklch(0.68 0.27 350 / .6),transparent 60%);top:-10vw;left:-8vw;animation:drift1 22s ease-in-out infinite}
.aurora::after{background:radial-gradient(circle,oklch(0.74 0.18 220 / .55),transparent 60%);bottom:-12vw;right:-6vw;animation:drift2 26s ease-in-out infinite}
@keyframes drift1{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(8vw,6vw) scale(1.15)}}
@keyframes drift2{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-7vw,-5vw) scale(1.1)}}
.grain{position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.04;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
@media(prefers-reduced-motion:reduce){
  .aurora::before,.aurora::after,.ticker-track,.sticky-match,.logo .dot,.eyebrow .d,.tag.live .d{animation:none!important}
  *{scroll-behavior:auto}
}

/* ============================== HEADER ============================== */
header.nav{position:sticky;top:0;z-index:60;backdrop-filter:blur(18px) saturate(160%);
  background:oklch(0.13 0.028 285 / 0.6);border-bottom:1px solid var(--border)}
.nav-in{display:flex;align-items:center;gap:18px;height:68px}
.logo{font-family:"Syne";font-weight:800;font-size:21px;display:flex;align-items:center;gap:10px}
.logo .dot{width:11px;height:11px;border-radius:50%;background:var(--grad-neon);box-shadow:0 0 14px oklch(0.68 0.27 350/.9);animation:pulse 2.4s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.8)}}
.nav-links{display:flex;gap:24px;margin-left:14px;list-style:none}
.nav-links a{color:var(--muted);font-weight:500;font-size:14.5px;transition:color .2s}
.nav-links a:hover,.nav-links .current-menu-item>a{color:var(--text)}
.nav-cta{margin-left:auto;display:flex;align-items:center;gap:12px}
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:700;font-size:14.5px;padding:11px 20px;border-radius:999px;cursor:pointer;border:0;transition:transform .18s, box-shadow .25s;font-family:inherit;line-height:1}
.btn-primary{background:var(--grad-primary);color:white;box-shadow:var(--shadow-neon)}
.btn-primary:hover{transform:translateY(-2px) scale(1.02)}
.btn-ghost{background:var(--glass);border:1px solid var(--border);color:var(--text)}
.btn-ghost:hover{background:oklch(1 0 0 / .08)}
.menu-btn{display:none;background:none;border:0;color:var(--text);font-size:24px;cursor:pointer}

/* ============================== TICKER ============================== */
.ticker{border-bottom:1px solid var(--border);background:oklch(1 0 0 / .02);overflow:hidden;white-space:nowrap}
.ticker-track{display:inline-flex;gap:42px;padding:9px 0;animation:scroll 38s linear infinite;font-size:13px;color:var(--muted)}
.ticker-track b{color:var(--text)}
.ticker .live-dot{color:var(--live)}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============================== HERO ============================== */
.hero{position:relative;padding:74px 0 40px;text-align:center}
.eyebrow{display:inline-flex;align-items:center;gap:8px;padding:7px 15px;border-radius:999px;font-size:13px;font-weight:600;color:var(--muted);margin-bottom:26px}
.eyebrow .d{width:7px;height:7px;border-radius:50%;background:var(--live);box-shadow:0 0 10px var(--live);animation:pulse 2s infinite}
.hero h1{font-size:clamp(40px,7vw,82px);font-weight:800;margin-bottom:20px}
.hero p.sub{font-size:clamp(16px,2.2vw,21px);color:var(--muted);max-width:620px;margin:0 auto 32px}
.hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.btn-lg{padding:16px 30px;font-size:16px}
.hero-stats{display:flex;gap:34px;justify-content:center;flex-wrap:wrap;margin-top:46px}
.stat{text-align:center}
.stat .n{font-family:"Syne";font-weight:800;font-size:30px;background:var(--grad-neon);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat .l{font-size:12.5px;color:var(--faint);text-transform:uppercase;letter-spacing:.08em;margin-top:3px}

/* ============================== SECTION SHELL ============================== */
section.blk{padding:70px 0;position:relative}
.sec-head{margin-bottom:38px}
.sec-head .chip{display:inline-flex;align-items:center;gap:8px;padding:6px 13px;border-radius:999px;font-size:12.5px;font-weight:600;color:var(--muted);margin-bottom:14px}
.sec-head h2{font-size:clamp(28px,4.4vw,46px);font-weight:800}
.sec-head p{color:var(--muted);max-width:560px;margin-top:10px;font-size:16px}
.center{text-align:center}
.center .sec-head p{margin-left:auto;margin-right:auto}

/* ============================== 3D CAROUSEL ============================== */
.deck-head{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;margin-bottom:30px}
.deck-nav{display:flex;gap:10px}
.icon-btn{width:48px;height:48px;border-radius:50%;display:grid;place-items:center;cursor:pointer;background:var(--glass);border:1px solid var(--border);color:var(--text);transition:.2s;font-size:18px}
.icon-btn:hover{background:oklch(1 0 0/.1);transform:scale(1.06)}
.stage{position:relative;height:560px;perspective:1700px;touch-action:pan-y;user-select:none}
.card3d{position:absolute;left:50%;top:50%;width:330px;height:500px;transform-style:preserve-3d;
  transition:transform .55s cubic-bezier(.22,.9,.3,1), opacity .55s;will-change:transform,opacity;cursor:grab}
.card3d:active{cursor:grabbing}
.card-inner{position:relative;height:100%;width:100%;border-radius:26px;overflow:hidden;background:oklch(0.18 0.03 285 / .85);border:1px solid var(--border)}
.card3d .neon{position:absolute;inset:-2px;border-radius:28px;padding:2px;background:var(--grad-neon);opacity:0;transition:opacity .4s;filter:blur(.4px);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude}
.card3d.active .neon{opacity:1;animation:huerot 6s linear infinite}
@keyframes huerot{to{filter:hue-rotate(360deg)}}
.card3d.active{box-shadow:var(--shadow-neon)}
.preview{position:relative;height:58%;overflow:hidden}
.preview .mesh{position:absolute;inset:0;background-size:200% 200%;animation:meshmove 7s ease infinite}
@keyframes meshmove{0%,100%{background-position:0 0}50%{background-position:100% 100%}}
.preview::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 25%,oklch(1 0 0/.22),transparent 55%),linear-gradient(180deg,transparent 40%,oklch(0.12 0.03 285/.92))}
.tag{position:absolute;z-index:2;display:inline-flex;align-items:center;gap:6px;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:5px 10px;border-radius:999px;backdrop-filter:blur(8px)}
.tag.live{top:14px;left:14px;background:oklch(0 0 0/.45);color:white}
.tag.live .d{width:6px;height:6px;border-radius:50%;background:#ff4d4d;box-shadow:0 0 8px #ff4d4d;animation:pulse 1.4s infinite}
.tag.badge{top:14px;right:14px;background:var(--grad-gold);color:oklch(0.2 0.03 60)}
.tag.smart{top:14px;right:14px;background:oklch(0 0 0/.5);color:var(--cyan)}
.preview .ident{position:absolute;z-index:2;bottom:14px;left:14px;right:14px;display:flex;align-items:center;gap:11px}
.preview .ava{width:42px;height:42px;border-radius:13px;display:grid;place-items:center;font-family:"Syne";font-weight:800;color:white;background:oklch(1 0 0/.18);backdrop-filter:blur(6px)}
.preview .ident .nm{font-family:"Syne";font-weight:700;font-size:17px;color:white;text-shadow:0 2px 8px rgba(0,0,0,.5)}
.preview .ident .ct{font-size:11.5px;color:oklch(1 0 0/.82)}
.card-body{padding:18px 18px 20px;height:42%;display:flex;flex-direction:column;gap:11px}
.card-body .tl{font-size:13.5px;color:var(--muted);min-height:38px}
.card-meta{display:flex;align-items:center;gap:9px;font-size:12.5px}
.rating{display:inline-flex;align-items:center;gap:5px;font-weight:700}
.rating .s{color:var(--gold)}
.bestfor{background:oklch(1 0 0/.05);padding:3px 9px;border-radius:999px;color:var(--muted);font-size:11.5px}
.card-cta{margin-top:auto;display:flex;align-items:center;justify-content:center;gap:8px;padding:13px;border-radius:14px;font-weight:700;font-size:14.5px;color:white;background:var(--grad-primary);transition:transform .18s}
.card-cta:hover{transform:scale(1.03)}
.card-cta.smart{background:transparent;border:1.5px solid var(--cyan);color:var(--cyan)}
.dots{display:flex;justify-content:center;gap:8px;margin-top:26px}
.dots button{height:6px;width:7px;border-radius:999px;border:0;background:oklch(1 0 0/.2);cursor:pointer;transition:.3s}
.dots button.on{width:30px;background:var(--grad-neon)}
.swipe-hint{text-align:center;color:var(--faint);font-size:12.5px;margin-top:12px}

/* ============================== TOP RANK CARDS ============================== */
.rank-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.rankcard{position:relative;border-radius:var(--radius);padding:24px;background:var(--surface);border:1px solid var(--border);backdrop-filter:blur(18px);overflow:hidden;transition:transform .3s, border-color .3s}
.rankcard:hover{transform:translateY(-6px);border-color:oklch(0.68 0.27 350/.5)}
.rankcard .rnk{position:absolute;top:-10px;right:14px;font-family:"Syne";font-weight:800;font-size:84px;color:oklch(1 0 0/.05);line-height:1}
.rankcard .top{display:flex;align-items:center;gap:13px;margin-bottom:14px}
.rankcard .ava{width:50px;height:50px;border-radius:14px;display:grid;place-items:center;font-family:"Syne";font-weight:800;font-size:20px;color:white;flex-shrink:0}
.rankcard h3{font-size:21px;font-weight:700}
.rankcard h3 a{transition:color .2s}
.rankcard h3 a:hover{color:var(--magenta-2)}
.rankcard .bf{font-size:12.5px;color:var(--cyan);font-weight:600}
.rankcard .rt{display:flex;align-items:center;gap:6px;font-size:13px;margin:6px 0 14px}
.rankcard .rt .s{color:var(--gold);letter-spacing:1px}
.rankcard ul{list-style:none;display:flex;flex-direction:column;gap:8px;margin-bottom:18px}
.rankcard li{font-size:13.5px;color:var(--muted);display:flex;gap:8px;align-items:flex-start}
.rankcard li::before{content:"✦";color:var(--magenta-2)}
.crown{position:absolute;top:14px;left:14px;background:var(--grad-gold);color:oklch(0.2 0.03 60);font-size:11px;font-weight:700;padding:5px 11px;border-radius:999px;text-transform:uppercase;letter-spacing:.05em}

/* compact list card (category/archive) */
.rankcard .bf{margin-bottom:2px}

/* ============================== QUIZ ============================== */
.quiz-shell{max-width:680px;margin:0 auto;border-radius:28px;padding:38px;position:relative;overflow:hidden}
.quiz-shell::before{content:"";position:absolute;inset:0;background:var(--grad-primary);opacity:.07}
.prog{display:flex;gap:8px;margin-bottom:26px;position:relative}
.prog span{flex:1;height:5px;border-radius:999px;background:oklch(1 0 0/.1);overflow:hidden}
.prog span i{display:block;height:100%;width:0;background:var(--grad-neon);transition:width .5s}
.prog span.done i{width:100%}
.qstep{position:relative}
.qstep h3{font-size:25px;font-weight:700;margin-bottom:22px}
.opts{display:grid;gap:12px}
.opt{display:flex;align-items:center;justify-content:space-between;padding:17px 20px;border-radius:15px;background:var(--glass);border:1px solid var(--border);cursor:pointer;font-weight:600;font-size:15.5px;transition:.2s;text-align:left;color:var(--text);font-family:inherit;width:100%}
.opt:hover{border-color:var(--magenta);background:oklch(0.68 0.27 350/.1);transform:translateX(4px)}
.opt .arrow{color:var(--faint);transition:.2s}
.opt:hover .arrow{color:var(--magenta-2);transform:translateX(3px)}
.qresult{text-align:center;position:relative}
.qresult .score-ring{width:130px;height:130px;margin:0 auto 18px;border-radius:50%;display:grid;place-items:center;position:relative;background:conic-gradient(var(--magenta) 0 94%,oklch(1 0 0/.08) 94%)}
.qresult .score-ring::before{content:"";position:absolute;inset:9px;border-radius:50%;background:oklch(0.15 0.03 285)}
.qresult .score-ring .v{position:relative;font-family:"Syne";font-weight:800;font-size:33px}
.qresult .lbl{color:var(--cyan);font-weight:600;font-size:13.5px;text-transform:uppercase;letter-spacing:.1em;margin-bottom:6px}
.qresult h3{font-size:34px;font-weight:800;margin-bottom:8px}
.qresult p{color:var(--muted);margin-bottom:22px;max-width:420px;margin-left:auto;margin-right:auto}
.reset{background:none;border:0;color:var(--faint);font-size:13px;cursor:pointer;margin-top:16px;font-family:inherit}
.reset:hover{color:var(--text)}

/* ============================== COMPARE HUB ============================== */
.cmp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.cmp{display:flex;flex-direction:column;gap:14px;padding:22px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);transition:.3s}
.cmp:hover{transform:translateY(-5px);border-color:oklch(0.82 0.15 200/.5);box-shadow:var(--shadow-cyan)}
.cmp .vs{display:flex;align-items:center;gap:12px}
.cmp .vs .a,.cmp .vs .b{flex:1;text-align:center}
.cmp .ava{width:46px;height:46px;border-radius:13px;margin:0 auto 7px;display:grid;place-items:center;font-family:"Syne";font-weight:800;color:white}
.cmp .vs .nm{font-weight:700;font-size:14px}
.cmp .vsx{font-family:"Syne";font-weight:800;color:var(--faint);font-size:13px}
.cmp .verdict{font-size:13px;color:var(--muted);border-top:1px solid var(--border);padding-top:13px}
.cmp .verdict b{color:var(--text)}
.cmp .go{font-size:13.5px;font-weight:700;color:var(--cyan);display:flex;align-items:center;gap:6px}

/* ============================== CATEGORIES ============================== */
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.cat{padding:20px;border-radius:18px;background:var(--surface);border:1px solid var(--border);transition:.3s;cursor:pointer;position:relative;overflow:hidden;display:block}
.cat:hover{transform:translateY(-4px);border-color:var(--magenta)}
.cat .ic{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;font-size:19px;margin-bottom:12px;background:var(--grad-primary)}
.cat h4{font-size:15.5px;font-weight:700;margin-bottom:3px}
.cat p{font-size:12px;color:var(--faint)}

/* ============================== TRUST ============================== */
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.trust{text-align:center;padding:26px 16px;border-radius:18px;background:var(--surface);border:1px solid var(--border)}
.trust .ic{font-size:26px;margin-bottom:10px}
.trust h4{font-size:15px;font-weight:700;margin-bottom:5px}
.trust p{font-size:12.5px;color:var(--faint)}

/* ============================== FOOTER ============================== */
footer.site{border-top:1px solid var(--border);padding:50px 0 34px;margin-top:40px;background:oklch(1 0 0/.015)}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:30px;margin-bottom:34px}
.foot-grid h5{font-size:13px;text-transform:uppercase;letter-spacing:.08em;color:var(--faint);margin-bottom:14px}
.foot-grid a{display:block;color:var(--muted);font-size:13.5px;margin-bottom:9px;transition:.2s}
.foot-grid a:hover{color:var(--text)}
.foot-brand .logo{margin-bottom:14px}
.foot-brand p{color:var(--faint);font-size:13px;max-width:300px}
.foot-bot{border-top:1px solid var(--border);padding-top:22px;font-size:12px;color:var(--faint);display:flex;flex-direction:column;gap:16px}
.foot-legal{display:flex;flex-wrap:wrap;gap:8px 18px}
.foot-legal a{color:var(--muted);transition:color .2s}
.foot-legal a:hover{color:var(--text)}
.foot-bot-row{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;align-items:center}
.foot-badges a{color:var(--magenta-2);text-decoration:underline;text-underline-offset:2px}
.age{display:inline-grid;place-items:center;width:30px;height:30px;border-radius:8px;border:1.5px solid var(--magenta-2);color:var(--magenta-2);font-weight:800;font-size:12px;font-family:"Syne"}
.foot-badges{display:flex;gap:10px;align-items:center}

/* ============================== STICKY MATCH ============================== */
.sticky-match{position:fixed;bottom:22px;right:22px;z-index:70;display:flex;align-items:center;gap:9px;padding:14px 22px;border-radius:999px;background:var(--grad-primary);color:white;font-weight:700;font-size:14.5px;box-shadow:var(--shadow-neon);cursor:pointer;border:0;font-family:inherit;animation:bob 3s ease-in-out infinite;text-decoration:none}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
.sticky-match:hover{transform:scale(1.05)}

.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s, transform .7s}
.reveal.in{opacity:1;transform:none}

/* ============================== PAGE HEAD (archives) ============================== */
.page-head{padding:66px 0 10px;text-align:center}
.page-head .chip{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;border-radius:999px;font-size:12.5px;font-weight:600;color:var(--muted);margin-bottom:16px}
.page-head h1{font-size:clamp(32px,5.5vw,58px);font-weight:800;margin-bottom:14px}
.page-head p{color:var(--muted);max-width:620px;margin:0 auto;font-size:16.5px}
.list-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}

/* ============================== REVIEW (single cam_site) ============================== */
.review-wrap{max-width:1080px;margin:0 auto;padding:48px 22px 0}
.rev-top{display:grid;grid-template-columns:1.15fr .85fr;gap:30px;align-items:start;margin-bottom:36px}
@media(max-width:880px){.rev-top{grid-template-columns:1fr}}
.rev-headline{display:flex;align-items:center;gap:18px;margin-bottom:18px}
.rev-headline .ava{width:74px;height:74px;border-radius:20px;display:grid;place-items:center;font-family:"Syne";font-weight:800;font-size:32px;color:white;flex-shrink:0;box-shadow:var(--shadow-neon)}
.rev-headline h1{font-size:clamp(30px,5vw,50px);font-weight:800;line-height:1}
.rev-breadcrumb{font-size:13px;color:var(--faint);margin-bottom:22px;display:flex;gap:8px;flex-wrap:wrap}
.rev-breadcrumb a{color:var(--muted)}
.rev-breadcrumb a:hover{color:var(--text)}
.rev-rating-row{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:18px}
.rev-rating-row .stars{color:var(--gold);font-size:19px;letter-spacing:2px}
.rev-rating-row .num{font-family:"Syne";font-weight:800;font-size:22px}
.rev-rating-row .cnt{color:var(--faint);font-size:13.5px}
.verdict-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;backdrop-filter:blur(18px);position:relative;overflow:hidden}
.verdict-box::before{content:"";position:absolute;inset:0;background:var(--grad-primary);opacity:.05}
.verdict-box h2{font-size:18px;margin-bottom:10px;position:relative}
.verdict-box p{color:var(--muted);font-size:15px;position:relative}
.quickfacts{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:18px;position:relative}
.qf{background:oklch(1 0 0/.04);border:1px solid var(--border);border-radius:13px;padding:12px 14px}
.qf .k{font-size:11px;text-transform:uppercase;letter-spacing:.07em;color:var(--faint);margin-bottom:3px}
.qf .v{font-size:14px;font-weight:600}

/* CTA / widget panel (above the fold, per funnel) */
.cta-panel{position:sticky;top:88px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);background:oklch(0.18 0.03 285/.7);backdrop-filter:blur(18px);box-shadow:var(--shadow-neon)}
.cta-panel .head{padding:18px 20px;background:var(--grad-primary);color:white}
.cta-panel .head .l{font-size:12px;text-transform:uppercase;letter-spacing:.08em;opacity:.85}
.cta-panel .head .t{font-family:"Syne";font-weight:800;font-size:22px}
.cta-panel .body{padding:20px}
.widget-slot{border-radius:14px;overflow:hidden;margin-bottom:16px;min-height:230px;background:oklch(0 0 0/.25);border:1px solid var(--border);position:relative}
.widget-slot .mesh{position:absolute;inset:0;background-size:200% 200%;animation:meshmove 7s ease infinite;opacity:.9}
.widget-slot .ph{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;text-align:center;padding:18px}
.widget-slot .ph .pl{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:oklch(1 0 0/.85);background:oklch(0 0 0/.4);padding:5px 12px;border-radius:999px;backdrop-filter:blur(6px)}
.widget-slot .ph .nm{font-family:"Syne";font-weight:800;font-size:24px;color:white;text-shadow:0 2px 10px rgba(0,0,0,.5)}
.cta-panel .btn{width:100%;justify-content:center;font-size:15.5px;padding:15px}
.cta-panel .fine{font-size:11.5px;color:var(--faint);text-align:center;margin-top:10px}

/* pros/cons */
.pc-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:30px 0}
@media(max-width:680px){.pc-grid{grid-template-columns:1fr}}
.pc{border-radius:var(--radius);padding:22px;border:1px solid var(--border);background:var(--surface)}
.pc h3{font-size:16px;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.pc.pros h3{color:var(--live)}
.pc.cons h3{color:var(--magenta-2)}
.pc ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.pc li{font-size:14px;color:var(--muted);display:flex;gap:9px;align-items:flex-start}
.pc.pros li::before{content:"✓";color:var(--live);font-weight:800}
.pc.cons li::before{content:"✕";color:var(--magenta-2);font-weight:800}

/* best-for ribbon */
.bestfor-row{display:flex;flex-wrap:wrap;gap:10px;margin:8px 0 4px}
.bestfor-row .pill{background:oklch(0.82 0.15 200/.12);border:1px solid oklch(0.82 0.15 200/.4);color:var(--cyan);font-size:12.5px;font-weight:600;padding:7px 14px;border-radius:999px}

/* long-form article body */
.article-body{max-width:760px;margin:18px auto 0;font-size:16.5px;line-height:1.75}
.article-body h2{font-size:clamp(24px,3.4vw,32px);font-weight:800;margin:38px 0 14px}
.article-body h3{font-size:21px;font-weight:700;margin:26px 0 10px}
.article-body p{color:oklch(0.86 0.02 285);margin-bottom:16px}
.article-body ul,.article-body ol{margin:0 0 18px 4px;padding-left:22px;color:oklch(0.86 0.02 285)}
.article-body li{margin-bottom:9px}
.article-body strong{color:var(--text)}
.article-body a{color:var(--cyan);text-decoration:underline;text-underline-offset:3px}
.article-body blockquote{border-left:3px solid var(--magenta);padding:6px 0 6px 20px;margin:20px 0;color:var(--muted);font-style:italic}

/* related strip */
.related{margin-top:18px}
.related .list-grid{grid-template-columns:repeat(3,1fr)}

/* FAQ */
.faq{max-width:760px;margin:10px auto 0}
.faq details{border:1px solid var(--border);border-radius:15px;background:var(--surface);padding:0 20px;margin-bottom:12px;overflow:hidden}
.faq summary{cursor:pointer;padding:18px 0;font-weight:700;font-size:16px;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:14px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--magenta-2);font-size:22px;font-weight:400;transition:.2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{color:var(--muted);font-size:14.5px;padding:0 0 18px;line-height:1.65}

/* ============================== COMPARISON (single) ============================== */
.cmp-hero{display:grid;grid-template-columns:1fr auto 1fr;gap:18px;align-items:center;max-width:760px;margin:10px auto 30px}
.cmp-hero .side{text-align:center}
.cmp-hero .side .ava{width:86px;height:86px;border-radius:22px;margin:0 auto 12px;display:grid;place-items:center;font-family:"Syne";font-weight:800;font-size:36px;color:white;box-shadow:var(--shadow-neon)}
.cmp-hero .side h2{font-size:24px}
.cmp-hero .side .rt{color:var(--gold);font-size:14px;margin-top:4px}
.cmp-hero .vsx{font-family:"Syne";font-weight:800;font-size:30px;color:var(--faint)}
.cmp-verdict{max-width:760px;margin:0 auto 30px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:26px;text-align:center;position:relative;overflow:hidden}
.cmp-verdict::before{content:"";position:absolute;inset:0;background:var(--grad-primary);opacity:.06}
.cmp-verdict .lbl{position:relative;color:var(--cyan);font-weight:700;font-size:12.5px;text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px}
.cmp-verdict p{position:relative;font-size:17px;color:var(--text)}
.cmp-table{max-width:820px;margin:0 auto 30px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border)}
.cmp-table table{width:100%;border-collapse:collapse;font-size:14.5px}
.cmp-table th,.cmp-table td{padding:15px 18px;text-align:left;border-bottom:1px solid var(--border)}
.cmp-table thead th{background:oklch(1 0 0/.04);font-family:"Syne";font-weight:700;font-size:15px}
.cmp-table td:first-child{color:var(--faint);font-weight:600}
.cmp-table tr:last-child td{border-bottom:0}
.cmp-cta-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;max-width:760px;margin:0 auto}
@media(max-width:600px){.cmp-cta-row{grid-template-columns:1fr}}

/* ============================== GENERIC PAGE/POST ============================== */
.page-body{max-width:760px;margin:0 auto;padding:30px 22px 0}
.page-body.article-body h1{font-size:clamp(30px,5vw,46px);font-weight:800;margin-bottom:18px}
.alignwide{max-width:1040px;margin-left:auto;margin-right:auto}
.alignfull{max-width:none}
.wp-block-image img{border-radius:14px}

/* ============================== RESPONSIVE ============================== */
@media(max-width:900px){
  .rank-grid,.cmp-grid,.list-grid,.related .list-grid{grid-template-columns:1fr}
  .cat-grid,.trust-grid{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr}
  .nav-links{display:none}
  .menu-btn{display:block;margin-left:auto}
  .nav-cta{margin-left:0}
  .nav-cta .btn-ghost{display:none}
  .cta-panel{position:static}
  .cmp-hero{grid-template-columns:1fr;gap:8px}
  .cmp-hero .vsx{margin:6px 0}
}
@media(max-width:560px){
  .cat-grid{grid-template-columns:1fr 1fr}
  .hero-stats{gap:22px}
  .sticky-match span.t{display:none}
  .quickfacts{grid-template-columns:1fr}
}

/* mobile slide-down menu */
.mobile-menu{display:none;border-bottom:1px solid var(--border);background:oklch(0.12 0.028 285/.96);backdrop-filter:blur(18px)}
.mobile-menu.open{display:block}
.mobile-menu ul{list-style:none;padding:14px 22px 20px;display:flex;flex-direction:column;gap:4px}
.mobile-menu a{display:block;padding:12px 0;color:var(--muted);font-weight:600;border-bottom:1px solid oklch(1 0 0/.05)}
.mobile-menu a:hover{color:var(--text)}

/* ============================== COMPARISON / FEATURE TABLE ============================== */
.ctable-wrap{border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);backdrop-filter:blur(18px);overflow:hidden;overflow-x:auto}
.ctable{width:100%;border-collapse:collapse;font-size:14.5px;min-width:760px}
.ctable thead th{font-family:"Syne",sans-serif;font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.04em;color:var(--faint);text-align:center;padding:18px 14px;background:oklch(1 0 0/.03);border-bottom:1px solid var(--border);white-space:nowrap}
.ctable thead th.col-plat{text-align:left}
.ctable tbody td{padding:16px 14px;text-align:center;border-bottom:1px solid var(--border);vertical-align:middle}
.ctable tbody tr:last-child td{border-bottom:0}
.ctable tbody tr{transition:background .2s}
.ctable tbody tr:hover{background:oklch(1 0 0/.03)}
.ctable td.col-plat{text-align:left}
.ctable .plat{display:flex;align-items:center;gap:12px}
.ctable .plat .ava{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;font-family:"Syne";font-weight:800;font-size:17px;color:#fff;flex-shrink:0}
.ctable .plat .meta{display:flex;flex-direction:column;gap:2px;text-align:left}
.ctable .plat .nm{font-family:"Syne";font-weight:700;font-size:16px}
.ctable .plat .nm:hover{color:var(--magenta-2)}
.ctable .plat .bf{font-size:12px;color:var(--cyan)}
.ctable .rate{display:inline-flex;align-items:center;gap:5px;font-weight:800;font-family:"Syne"}
.ctable .rate .s{color:var(--gold)}
.ctable td.price{color:var(--muted);font-size:13.5px;white-space:nowrap}
.ctable .ck{font-size:17px;font-weight:800}
.ctable .ck.yes{color:var(--live)}
.ctable .ck.no{color:var(--faint);font-weight:400}
.ctable .tbl-btn{padding:9px 18px;font-size:13.5px;box-shadow:none}
.ctable .tbl-btn:hover{transform:translateY(-1px) scale(1.03)}
.ctable-foot{text-align:center;color:var(--faint);font-size:12.5px;margin-top:14px}
.ctable-foot a{color:var(--cyan)}

/* ============================== GUIDE CARDS ============================== */
.guide-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.guide-card{display:flex;flex-direction:column;gap:10px;padding:26px 24px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);transition:.3s;position:relative;overflow:hidden}
.guide-card:hover{transform:translateY(-6px);border-color:oklch(0.68 0.27 350/.5);box-shadow:var(--shadow-neon)}
.guide-card .ic{width:52px;height:52px;border-radius:15px;display:grid;place-items:center;font-size:24px;background:var(--grad-primary);margin-bottom:6px}
.guide-card h3{font-size:19px;font-weight:700;line-height:1.2}
.guide-card p{font-size:14px;color:var(--muted);line-height:1.55;flex:1}
.guide-card .go{font-size:13.5px;font-weight:700;color:var(--cyan);margin-top:6px}
.guide-hero-ic{width:74px;height:74px;border-radius:20px;display:grid;place-items:center;font-size:34px;background:var(--grad-primary);margin:0 auto 18px;box-shadow:var(--shadow-neon)}

@media(max-width:900px){
  .guide-grid{grid-template-columns:1fr}
}

/* ============================== EDITORIAL INTRO (SEO copy) ============================== */
.home-intro{text-align:center}
.home-intro .intro-body{max-width:780px;margin:0 auto}
.home-intro .lead{font-size:clamp(17px,2.2vw,20px);color:oklch(0.90 0.02 285);line-height:1.7;margin-bottom:18px}
.home-intro .intro-body p{color:var(--muted);font-size:16px;line-height:1.75;margin-bottom:16px}
.home-intro .intro-body em{color:var(--text);font-style:italic}
.home-intro .intro-body a{color:var(--cyan);text-decoration:underline;text-underline-offset:3px}
.home-intro .intro-body a:hover{color:var(--text)}
.home-intro .intro-points{list-style:none;display:inline-grid;gap:10px;margin-top:14px;text-align:left}
.home-intro .intro-points li{position:relative;padding-left:26px;color:var(--muted);font-size:15px;line-height:1.6}
.home-intro .intro-points li::before{content:"✦";position:absolute;left:0;top:1px;color:var(--magenta-2)}
.home-intro .intro-points strong{color:var(--text)}
@media(min-width:760px){.home-intro .intro-points{grid-template-columns:1fr 1fr;gap:12px 26px}}
