/* HiddenSec frontend styles. Block theme already provides CSS vars (--wp--preset--color--*) and layout. */

:root {
	--hs-primary: var(--wp--preset--color--primary, #0C79FE);
	--hs-primary-dark: var(--wp--preset--color--primary-dark, #005FD6);
	--hs-primary-soft: var(--wp--preset--color--primary-soft, #4888E8);
	--hs-accent: var(--wp--preset--color--accent, #13B9EA);
	--hs-scanner: var(--wp--preset--color--scanner, #22e07d);
	--hs-ink: var(--wp--preset--color--ink, #0E1012);
	--hs-ink-night: var(--wp--preset--color--ink-night, #070A12);
	--hs-muted: var(--wp--preset--color--muted, #475569);
	--hs-subtle: var(--wp--preset--color--subtle, #8D9AB0);
	--hs-line: var(--wp--preset--color--line, #e6eaf2);
	--hs-line-night: var(--wp--preset--color--line-night, #1c2433);
	--hs-surface: var(--wp--preset--color--surface, #f5f7fb);
	--hs-surface-night: var(--wp--preset--color--surface-night, #0F1421);
	--hs-card: var(--wp--preset--color--card, #ffffff);
	--hs-card-night: var(--wp--preset--color--card-night, #131A2A);
	--hs-radius: 14px;
	--hs-radius-lg: 22px;
	--hs-shadow: 0 4px 14px rgba(15, 23, 42, 0.06);
	--hs-shadow-lg: 0 12px 40px rgba(15, 23, 42, 0.10);
	--hs-glow: 0 4px 30px rgba(19, 185, 234, 0.36);
	--hs-glow-strong: 0 6px 40px rgba(12, 121, 254, 0.55);
}

html { scroll-behavior: smooth; }
body { color: var(--hs-ink); -webkit-font-smoothing: antialiased; }

/* ---------- Accessibility ---------- */
.hs-skip-link {
	position: absolute; left: -9999px; top: -9999px;
	background: var(--hs-primary); color: #fff;
	padding: 12px 18px; border-radius: 0 0 12px 0;
	z-index: 1000; font-weight: 600; text-decoration: none;
}
.hs-skip-link:focus { left: 0; top: 0; outline: 2px solid #fff; outline-offset: 2px; }

a:focus-visible, button:focus-visible, [tabindex]:focus-visible, summary:focus-visible {
	outline: 2px solid var(--hs-primary);
	outline-offset: 3px;
	border-radius: 6px;
}
.hs-btn:focus-visible { outline-offset: 4px; }

@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after {
		animation-duration: 0.001ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.001ms !important;
	}
	html { scroll-behavior: auto; }
}

.sr-only {
	position: absolute; width: 1px; height: 1px; padding: 0;
	margin: -1px; overflow: hidden; clip: rect(0,0,0,0);
	white-space: nowrap; border: 0;
}

/* ---------- Header (glassy, modern SaaS) ---------- */
.hs-site-header {
	position: sticky;
	top: 0;
	z-index: 60;
	background: rgba(255, 255, 255, 0.72);
	backdrop-filter: saturate(180%) blur(18px);
	-webkit-backdrop-filter: saturate(180%) blur(18px);
	border-bottom: 1px solid rgba(15, 23, 42, 0.06);
}
.hs-site-header__inner {
	max-width: 1200px;
	margin: 0 auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 12px 24px;
	gap: 32px;
}

/* Brand: logo + text "NoSpy" */
.hs-brand { display: inline-flex; align-items: center; gap: 10px; text-decoration: none; }
.hs-brand .hs-brand__logo,
.hs-brand .wp-block-site-logo { display: inline-flex; margin: 0; }
.hs-brand .wp-block-site-logo img,
.hs-brand img.custom-logo { width: 32px; height: 32px; border-radius: 8px; display: block; }
.hs-brand .wp-block-site-title,
.hs-brand__name { font-size: 17px; font-weight: 700; letter-spacing: -0.015em; line-height: 1; color: var(--hs-ink); }
.hs-brand .wp-block-site-title a,
.hs-brand__name a { color: inherit; text-decoration: none; }

/* Navigation */
.hs-nav { display: flex; align-items: center; flex: 1; justify-content: center; gap: 4px; }
.hs-nav .wp-block-navigation__container { gap: 2px; }
.hs-nav .wp-block-navigation-item__content {
	display: inline-flex; align-items: center; gap: 4px;
	padding: 8px 12px; border-radius: 8px;
	color: var(--hs-ink); text-decoration: none;
	font-size: 15px; font-weight: 500; letter-spacing: -0.005em;
	transition: color 0.12s ease, background 0.12s ease;
}
.hs-nav .wp-block-navigation-item__content:hover { color: var(--hs-primary); background: rgba(12, 121, 254, 0.06); }
.hs-nav .wp-block-navigation-submenu__toggle { padding: 2px; opacity: 0.6; }

/* Submenu dropdown card */
.hs-nav .wp-block-navigation__submenu-container {
	min-width: 220px; padding: 8px;
	background: #fff; border: 1px solid rgba(15, 23, 42, 0.08);
	border-radius: var(--hs-radius);
	box-shadow: 0 12px 40px rgba(15, 23, 42, 0.10), 0 2px 6px rgba(15, 23, 42, 0.04);
	margin-top: 6px;
}
.hs-nav .wp-block-navigation__submenu-container .wp-block-navigation-item__content {
	display: block; padding: 9px 12px; border-radius: 8px;
	color: var(--hs-ink); font-weight: 500;
}
.hs-nav .wp-block-navigation__submenu-container .wp-block-navigation-item__content:hover { background: rgba(12, 121, 254, 0.06); color: var(--hs-primary); }

/* Top-level Try-now CTA */
.hs-cta-header { flex-shrink: 0; }
.hs-cta-header .wp-block-button__link {
	padding: 9px 18px; font-size: 14px; font-weight: 600;
	background: var(--hs-primary); color: #fff !important;
	border-radius: 10px; box-shadow: var(--hs-glow);
	transition: transform 0.12s ease, box-shadow 0.2s ease, background 0.12s ease;
}
.hs-cta-header .wp-block-button__link:hover { background: var(--hs-primary-dark); transform: translateY(-1px); box-shadow: var(--hs-glow-strong); }

.hs-btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 14px 22px; border-radius: 14px; text-decoration: none; font-weight: 600; transition: transform .12s ease, box-shadow .2s ease, background-color .12s ease, color .12s ease; line-height: 1; }
.hs-btn-primary { background: var(--hs-primary); color: #fff !important; box-shadow: var(--hs-glow); }
.hs-btn-primary:hover { background: var(--hs-primary-dark); transform: translateY(-1px); box-shadow: var(--hs-glow-strong); }
.hs-btn-ghost { background: transparent; color: var(--hs-primary); border: 1px solid var(--hs-line); }
.hs-btn-ghost:hover { background: var(--hs-surface); }
.hs-btn-store { background: var(--hs-ink-night); color: #fff !important; padding: 14px 22px; border: 1px solid rgba(255,255,255,0.08); }
.hs-btn-store:hover { background: #000; transform: translateY(-1px); }

/* ---------- Mobile / responsive ---------- */
@media (max-width: 900px) {
	.hs-site-header__inner { padding: 10px 18px; gap: 12px; }
	.hs-nav { flex: 0 0 auto; justify-content: flex-end; }
	.hs-cta-header { display: none; }
}
@media (max-width: 560px) {
	.hs-brand .wp-block-site-title,
	.hs-brand__name { display: none; }
}

/* ---------- Footer ---------- */
.hs-footer { background: #0b1424; color: #cbd5e1; padding: 64px 24px 24px; }
.hs-footer__inner { max-width: 1200px; margin: 0 auto; }
.hs-footer__top { display: grid; gap: 40px; grid-template-columns: 1.4fr 1fr 1fr 1fr; align-items: start; }
.hs-footer__brand .hs-logo { color: #fff; }
.hs-footer__brand .hs-logo__name { color: #fff; }
.hs-footer__desc { color: #94a3b8; margin: 14px 0 18px; max-width: 36ch; }
.hs-footer__col h4 { color: #fff; font-size: 14px; text-transform: uppercase; letter-spacing: 0.06em; margin: 0 0 14px; font-weight: 700; }
.hs-footer__col ul { list-style: none; padding: 0; margin: 0; }
.hs-footer__col li { margin: 8px 0; }
.hs-footer__col a { color: #cbd5e1; text-decoration: none; }
.hs-footer__col a:hover { color: #fff; }
.hs-footer__bottom { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 16px; align-items: center; border-top: 1px solid #1e293b; margin-top: 48px; padding-top: 20px; font-size: 14px; color: #94a3b8; }
.hs-footer__bottom ul { list-style: none; padding: 0; margin: 0; display: flex; gap: 18px; flex-wrap: wrap; }
.hs-footer__bottom a { color: #cbd5e1; text-decoration: none; }
.hs-footer__bottom a:hover { color: #fff; }
@media (max-width: 880px) { .hs-footer__top { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .hs-footer__top { grid-template-columns: 1fr; } }

/* ---------- Hero (Dark "security" style from app store creatives) ---------- */
.hs-hero { position: relative; overflow: hidden; padding: 100px 24px 110px; color: #fff; background: radial-gradient(ellipse at top right, rgba(12,121,254,0.35) 0%, rgba(7,10,18,0) 55%), radial-gradient(ellipse at bottom left, rgba(19,185,234,0.18) 0%, rgba(7,10,18,0) 50%), #070A12; }
.hs-hero::before {
	content: "";
	position: absolute; inset: 0;
	background-image:
		linear-gradient(rgba(72,136,232,0.06) 1px, transparent 1px),
		linear-gradient(90deg, rgba(72,136,232,0.06) 1px, transparent 1px);
	background-size: 64px 64px;
	mask-image: radial-gradient(ellipse 80% 60% at 50% 40%, #000 50%, transparent 100%);
	pointer-events: none;
}
.hs-hero__inner { position: relative; max-width: 1200px; margin: 0 auto; display: grid; grid-template-columns: 1.2fr 0.8fr; gap: 56px; align-items: center; }
.hs-hero__eyebrow { display: inline-flex; align-items: center; gap: 8px; padding: 6px 14px; border-radius: 999px; border: 1px solid rgba(72,136,232,0.35); background: rgba(12,121,254,0.08); color: #8DB5FF; font-size: 13px; font-weight: 500; letter-spacing: 0.04em; margin-bottom: 18px; }
.hs-hero__eyebrow::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--hs-scanner); box-shadow: 0 0 8px var(--hs-scanner); }
.hs-hero h1 { color: #fff; font-size: clamp(2.4rem, 5vw, 4rem); line-height: 1.05; letter-spacing: -0.02em; margin: 0 0 20px; font-weight: 800; }
.hs-hero h1 .hs-grad { background: linear-gradient(90deg, #4888E8 0%, #13B9EA 100%); -webkit-background-clip: text; background-clip: text; color: transparent; }
.hs-hero p.lead { color: var(--hs-subtle); font-size: 18px; max-width: 56ch; margin: 0 0 28px; line-height: 1.55; }
.hs-hero__ctas { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; }
.hs-hero__rating { display: flex; align-items: center; gap: 10px; margin-top: 22px; color: var(--hs-subtle); font-size: 14px; }
.hs-hero__rating strong { color: #fff; font-size: 18px; }
.hs-hero__rating .stars { color: #FFC857; letter-spacing: 1px; }
.hs-hero__screenshot { position: relative; display: flex; justify-content: center; align-items: center; }
.hs-hero__phone {
	width: 300px; aspect-ratio: 393 / 852;
	background: #000; border-radius: 44px; padding: 6px;
	box-shadow: 0 40px 100px rgba(12, 121, 254, 0.40), inset 0 0 0 1px rgba(255,255,255,0.10);
	position: relative; z-index: 2;
}
.hs-hero__phone img {
	display: block; width: 100%; height: 100%;
	border-radius: 38px; object-fit: cover;
}
/* Glow ring around the phone */
.hs-hero__phone::after {
	content: ""; position: absolute; inset: -30px; border-radius: 60px; z-index: -1;
	background: radial-gradient(ellipse at center, rgba(12,121,254,0.35), transparent 60%);
	filter: blur(20px);
}
@media (max-width: 880px) {
	.hs-hero__inner { grid-template-columns: 1fr; gap: 32px; }
	.hs-hero__screenshot { order: -1; }
	.hs-hero__phone { width: 240px; }
}

/* ---------- Generic section wrapper ---------- */
.hs-section { padding: 72px 24px; }
.hs-section__inner { max-width: 1200px; margin: 0 auto; }
.hs-section__eyebrow { color: var(--hs-primary); font-weight: 700; text-transform: uppercase; font-size: 13px; letter-spacing: 0.1em; }
.hs-section__title { font-size: clamp(1.6rem, 3vw, 2.4rem); line-height: 1.2; margin: 8px 0 12px; letter-spacing: -0.01em; }
.hs-section__lede { color: var(--hs-muted); max-width: 64ch; margin: 0 0 36px; }
.hs-section--alt { background: var(--hs-surface); }

/* Trust bar */
.hs-trust { padding: 28px 24px; background: var(--hs-surface); border-top: 1px solid var(--hs-line); border-bottom: 1px solid var(--hs-line); }
.hs-trust__inner { max-width: 1200px; margin: 0 auto; display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; text-align: center; }
.hs-trust__num { font-size: 28px; font-weight: 800; color: var(--hs-ink); }
.hs-trust__label { color: var(--hs-muted); font-size: 14px; }
@media (max-width: 720px) { .hs-trust__inner { grid-template-columns: repeat(2, 1fr); } }

/* Cards / Features */
.hs-grid { display: grid; gap: 24px; }
.hs-grid--3 { grid-template-columns: repeat(3, 1fr); }
.hs-grid--4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 980px) { .hs-grid--4 { grid-template-columns: repeat(2, 1fr); } .hs-grid--3 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .hs-grid--4, .hs-grid--3 { grid-template-columns: 1fr; } }

.hs-card { background: var(--hs-card); border: 1px solid var(--hs-line); border-radius: var(--hs-radius); padding: 24px; box-shadow: var(--hs-shadow); }
.hs-card h3 { margin: 12px 0 8px; font-size: 18px; }
.hs-card p { color: var(--hs-muted); margin: 0; font-size: 15px; }
.hs-card__icon { width: 48px; height: 48px; border-radius: 14px; background: linear-gradient(135deg, var(--hs-primary), var(--hs-primary-dark)); box-shadow: var(--hs-glow); display: inline-flex; align-items: center; justify-content: center; color: #fff; font-size: 22px; }

/* How it works */
.hs-steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; counter-reset: hs-step; }
.hs-step { background: var(--hs-card); border-radius: var(--hs-radius); padding: 22px; border: 1px solid var(--hs-line); position: relative; }
.hs-step::before { counter-increment: hs-step; content: counter(hs-step); position: absolute; top: -16px; left: 18px; width: 34px; height: 34px; background: var(--hs-primary); color: #fff; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-weight: 800; font-size: 14px; box-shadow: var(--hs-glow); }
.hs-step h4 { margin: 8px 0 6px; font-size: 16px; }
.hs-step p { color: var(--hs-muted); font-size: 14px; margin: 0; }
@media (max-width: 980px) { .hs-steps { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .hs-steps { grid-template-columns: 1fr; } }

/* Use Cases */
.hs-tabs { display: flex; flex-wrap: wrap; gap: 8px; margin: 0 0 20px; }
.hs-tab { padding: 10px 16px; border-radius: 999px; border: 1px solid var(--hs-line); background: var(--hs-card); cursor: pointer; font-weight: 500; }
.hs-tab.is-active { background: var(--hs-primary); color: #fff; border-color: var(--hs-primary); }
.hs-usecase-card { background: var(--hs-card); border: 1px solid var(--hs-line); border-radius: var(--hs-radius); padding: 22px; }
.hs-usecase-card h3 { margin: 0 0 8px; font-size: 18px; }
.hs-usecase-card p { color: var(--hs-muted); margin: 0; }

/* CTA strip — dark "security" panel matching the app's marketing style */
.hs-cta-strip { position: relative; overflow: hidden; padding: 64px 24px; color: #fff; background: radial-gradient(ellipse at top right, rgba(12,121,254,0.5) 0%, rgba(7,10,18,0) 60%), #070A12; }
.hs-cta-strip::before {
	content: ""; position: absolute; inset: 0;
	background-image: linear-gradient(rgba(72,136,232,0.06) 1px, transparent 1px), linear-gradient(90deg, rgba(72,136,232,0.06) 1px, transparent 1px);
	background-size: 48px 48px;
	mask-image: radial-gradient(ellipse 70% 60% at 50% 50%, #000 50%, transparent 100%);
	pointer-events: none;
}
.hs-cta-strip__inner { position: relative; max-width: 1200px; margin: 0 auto; display: flex; flex-wrap: wrap; justify-content: space-between; align-items: center; gap: 24px; }
.hs-cta-strip h2 { color: #fff; margin: 0; font-size: clamp(1.5rem, 2.4vw, 2rem); }
.hs-cta-strip p { color: var(--hs-subtle); margin: 6px 0 0; }
.hs-cta-strip .hs-btn-primary { background: var(--hs-primary); color: #fff !important; box-shadow: var(--hs-glow-strong); }
.hs-cta-strip .hs-btn-primary:hover { background: var(--hs-primary-dark); }

/* App screenshots */
.hs-screens { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.hs-screen { aspect-ratio: 393 / 852; background: #000; border-radius: 28px; box-shadow: 0 20px 50px rgba(12,121,254,0.18), inset 0 0 0 1px rgba(72,136,232,0.18); position: relative; overflow: hidden; padding: 4px; }
.hs-screen img { display: block; width: 100%; height: 100%; border-radius: 24px; object-fit: cover; }
.hs-screens { grid-template-columns: repeat(3, 1fr); max-width: 880px; margin: 0 auto; }
@media (max-width: 980px) { .hs-screens { grid-template-columns: repeat(3, 1fr); max-width: 720px; } }
@media (max-width: 720px) { .hs-screens { grid-template-columns: 1fr 1fr 1fr; gap: 12px; } }
@media (max-width: 980px) { .hs-screens { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .hs-screens { grid-template-columns: 1fr; } }

/* Reviews */
.hs-review-card { background: var(--hs-card); border: 1px solid var(--hs-line); border-radius: var(--hs-radius); padding: 22px; }
.hs-review-card__stars { color: #f59e0b; letter-spacing: 2px; }
.hs-review-card__quote { color: var(--hs-ink); margin: 10px 0; }
.hs-review-card__author { color: var(--hs-muted); font-size: 14px; }

/* Pricing */
.hs-pricing { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.hs-plan { background: var(--hs-card); border: 1px solid var(--hs-line); border-radius: var(--hs-radius); padding: 28px; display: flex; flex-direction: column; gap: 14px; }
.hs-plan h3 { margin: 0; font-size: 20px; }
.hs-plan__price { font-size: 36px; font-weight: 800; color: var(--hs-ink); }
.hs-plan__price small { font-size: 14px; color: var(--hs-muted); font-weight: 500; }
.hs-plan ul { list-style: none; padding: 0; margin: 0; }
.hs-plan li { padding-left: 24px; position: relative; margin: 6px 0; color: var(--hs-muted); }
.hs-plan li::before { content: "✓"; position: absolute; left: 0; color: var(--hs-accent); font-weight: 700; }
.hs-plan--featured { border-color: var(--hs-primary); box-shadow: var(--hs-glow); position: relative; }
.hs-plan--featured::before { content: "Most popular"; position: absolute; top: -12px; right: 20px; background: var(--hs-primary); color: #fff; padding: 4px 10px; border-radius: 999px; font-size: 12px; font-weight: 600; }
@media (max-width: 880px) { .hs-pricing { grid-template-columns: 1fr; } }

/* FAQ */
.hs-faq { max-width: 800px; margin: 0 auto; }
.hs-faq details { background: var(--hs-card); border: 1px solid var(--hs-line); border-radius: var(--hs-radius); padding: 16px 20px; margin-bottom: 12px; }
.hs-faq details[open] { border-color: var(--hs-primary); }
.hs-faq summary { font-weight: 600; cursor: pointer; list-style: none; display: flex; justify-content: space-between; align-items: center; }
.hs-faq summary::-webkit-details-marker { display: none; }
.hs-faq summary::after { content: "+"; color: var(--hs-primary); font-size: 22px; font-weight: 700; }
.hs-faq details[open] summary::after { content: "−"; }
.hs-faq details > *:not(summary) { margin-top: 12px; color: var(--hs-muted); }

/* HowTo block — schema.org HowTo wraps in .hs-howto */
.hs-howto { background: var(--hs-surface); border-left: 4px solid var(--hs-primary); border-radius: var(--hs-radius); padding: 22px 26px; margin: 28px 0; }
.hs-howto h2, .hs-howto h3 { margin-top: 0; }
.hs-howto ol { padding-left: 22px; }
.hs-howto li { margin: 8px 0; padding-left: 6px; }
.hs-howto li::marker { color: var(--hs-primary); font-weight: 700; }

/* SEO text */
.hs-seo-text { background: var(--hs-surface); }
.hs-seo-text__inner { max-width: 800px; margin: 0 auto; color: var(--hs-muted); }
.hs-seo-text__inner h2 { color: var(--hs-ink); margin-top: 0; }

/* Blog */
.hs-page-header { padding: 56px 24px; text-align: center; }
.hs-page-header h1 { margin: 0 0 12px; }
.hs-page-header p { color: var(--hs-muted); max-width: 64ch; margin: 0 auto; }

.hs-featured-article { padding: 24px; background: var(--hs-card); border: 1px solid var(--hs-line); border-radius: var(--hs-radius-lg); display: grid; grid-template-columns: 1.1fr 1fr; gap: 24px; align-items: center; }
.hs-featured-article__cover { aspect-ratio: 16/9; background: radial-gradient(ellipse at top right, rgba(19,185,234,0.4), transparent 60%), linear-gradient(160deg, var(--hs-primary), var(--hs-ink-night)); border-radius: var(--hs-radius); }
.hs-featured-article__meta { color: var(--hs-muted); font-size: 14px; }
.hs-featured-article h2 { margin: 8px 0 12px; font-size: clamp(1.4rem, 2.4vw, 2rem); }
.hs-featured-article p { color: var(--hs-muted); margin: 0 0 16px; }
@media (max-width: 880px) { .hs-featured-article { grid-template-columns: 1fr; } }

.hs-blog-layout { display: grid; grid-template-columns: 1fr 320px; gap: 40px; align-items: start; }
.hs-blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
@media (max-width: 1080px) { .hs-blog-layout { grid-template-columns: 1fr; } .hs-blog-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .hs-blog-grid { grid-template-columns: 1fr; } }
.hs-article-card { background: var(--hs-card); border: 1px solid var(--hs-line); border-radius: var(--hs-radius); overflow: hidden; display: flex; flex-direction: column; }
.hs-article-card__cover { aspect-ratio: 16/9; background: radial-gradient(ellipse at top right, rgba(19,185,234,0.35), transparent 60%), linear-gradient(160deg, var(--hs-primary), var(--hs-ink-night)); }
.hs-article-card__body { padding: 18px 18px 22px; display: flex; flex-direction: column; gap: 10px; }
.hs-article-card__meta { color: var(--hs-muted); font-size: 13px; display: flex; gap: 4px 8px; flex-wrap: wrap; align-items: center; }
.hs-article-card__meta > *:empty { display: none; }
.hs-article-card h3 { font-size: 18px; margin: 0; line-height: 1.3; }
.hs-article-card a { color: var(--hs-ink); text-decoration: none; }
.hs-article-card a:hover { color: var(--hs-primary); }
.hs-article-card__author { display: flex; gap: 8px; align-items: center; color: var(--hs-muted); font-size: 13px; }
.hs-article-card__author-avatar { width: 24px; height: 24px; border-radius: 50%; background: #cbd5e1; }

.hs-sidebar { display: flex; flex-direction: column; gap: 18px; position: sticky; top: 80px; }
.hs-sidebar__widget { background: var(--hs-card); border: 1px solid var(--hs-line); border-radius: var(--hs-radius); padding: 18px; }
.hs-sidebar__widget h4 { margin: 0 0 12px; font-size: 14px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--hs-muted); }
.hs-sidebar__widget--cta { background: radial-gradient(ellipse at top right, rgba(19,185,234,0.35), transparent 60%), linear-gradient(135deg, var(--hs-primary), var(--hs-primary-dark)); color: #fff; box-shadow: var(--hs-glow); border-color: transparent; }
.hs-sidebar__widget--cta h4 { color: rgba(255,255,255,0.85); }
.hs-sidebar__widget--cta a { color: #fff !important; }

.hs-pagination { display: flex; justify-content: center; gap: 8px; padding: 32px 0; }
.hs-pagination a, .hs-pagination span { padding: 8px 12px; border: 1px solid var(--hs-line); border-radius: 8px; text-decoration: none; color: var(--hs-ink); }
.hs-pagination .current { background: var(--hs-primary); color: #fff; border-color: var(--hs-primary); }

/* Single article */
.hs-article-layout { display: grid; grid-template-columns: 240px 1fr; gap: 40px; padding: 40px 24px 64px; max-width: 1100px; margin: 0 auto; }
.hs-article-toc { position: sticky; top: 88px; align-self: start; font-size: 14px; }
.hs-article-toc h4 { margin: 0 0 12px; font-size: 13px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--hs-muted); }
.hs-article-toc ol { padding-left: 18px; color: var(--hs-muted); }
.hs-article-toc a { color: var(--hs-muted); text-decoration: none; }
.hs-article-toc a:hover { color: var(--hs-primary); }
.hs-article-toc a.is-active { color: var(--hs-primary); font-weight: 600; }
.hs-article-toc li { margin: 4px 0; }
.hs-article-toc ol ol { padding-left: 16px; margin-top: 4px; }
.hs-subscribe__success { color: var(--hs-scanner); font-weight: 500; margin: 0; }
@media (max-width: 980px) { .hs-article-layout { grid-template-columns: 1fr; } .hs-article-toc { position: relative; top: auto; } }

.hs-article-hero { padding: 40px 24px 0; max-width: 880px; margin: 0 auto; }
.hs-article-hero__cover { aspect-ratio: 21/9; background: radial-gradient(ellipse at top right, rgba(19,185,234,0.35), transparent 60%), linear-gradient(160deg, var(--hs-primary), var(--hs-ink-night)); border-radius: var(--hs-radius-lg); margin: 20px 0; }
.hs-article-hero p.lede { color: var(--hs-muted); font-size: 18px; }

.hs-author-bar { display: flex; flex-wrap: wrap; gap: 16px 24px; padding: 16px 0; border-top: 1px solid var(--hs-line); border-bottom: 1px solid var(--hs-line); align-items: center; color: var(--hs-muted); font-size: 14px; }
.hs-author-bar__avatar { width: 44px; height: 44px; border-radius: 50%; background: #cbd5e1; flex-shrink: 0; overflow: hidden; display: inline-flex; align-items: center; justify-content: center; }
.hs-author-bar__avatar-img, .hs-author-bar__avatar img { width: 100%; height: 100%; border-radius: 50%; display: block; object-fit: cover; }
.hs-author-bar__group { display: flex; flex-direction: column; }
.hs-author-bar__name { color: var(--hs-ink); font-weight: 600; }
.hs-author-bar__share { display: flex; gap: 10px; margin-left: auto; }
.hs-author-bar__share a { width: 32px; height: 32px; border-radius: 50%; border: 1px solid var(--hs-line); display: inline-flex; align-items: center; justify-content: center; color: var(--hs-muted); }

.hs-quick-answer { background: linear-gradient(180deg, rgba(12,121,254,0.07), rgba(12,121,254,0.02)); border: 1px solid rgba(12,121,254,0.18); border-left: 4px solid var(--hs-primary); border-radius: var(--hs-radius); padding: 20px 24px; margin: 28px 0; }
.hs-quick-answer h3 { margin: 0 0 6px; font-size: 13px; text-transform: uppercase; color: var(--hs-primary); letter-spacing: 0.1em; font-weight: 700; }
.hs-quick-answer p { margin: 0; color: var(--hs-ink); }

.hs-callout { border-radius: var(--hs-radius); padding: 18px 22px; margin: 22px 0; border-left: 4px solid; }
.hs-callout h4 { margin: 0 0 4px; font-size: 14px; text-transform: uppercase; letter-spacing: 0.06em; }
.hs-callout p { margin: 6px 0 0; }
.hs-callout--how-it-works { background: linear-gradient(180deg, rgba(12,121,254,0.08), rgba(12,121,254,0.02)); border-color: var(--hs-primary); }
.hs-callout--how-it-works h4 { color: var(--hs-primary); }
.hs-callout--detail { background: #fef3c7; border-color: #f59e0b; }
.hs-callout--detail h4 { color: #b45309; }
.hs-callout--testing { background: linear-gradient(180deg, rgba(34,224,125,0.10), rgba(34,224,125,0.02)); border-color: var(--hs-scanner); }
.hs-callout--testing h4 { color: #0E8E47; }
.hs-callout--doesnt-work { background: #fee2e2; border-color: #ef4444; }
.hs-callout--doesnt-work h4 { color: #b91c1c; }

.hs-inline-cta { background: var(--hs-surface); border: 1px solid var(--hs-line); border-radius: var(--hs-radius); padding: 18px 22px; margin: 24px 0; display: flex; flex-wrap: wrap; justify-content: space-between; align-items: center; gap: 12px; }
.hs-inline-cta p { margin: 0; color: var(--hs-ink); font-weight: 500; }

.hs-bottom-cta { position: relative; overflow: hidden; background: radial-gradient(ellipse at top right, rgba(12,121,254,0.55) 0%, rgba(7,10,18,0) 60%), #070A12; color: #fff; padding: 48px 40px; border-radius: var(--hs-radius-lg); text-align: center; margin: 40px 0; box-shadow: 0 30px 80px rgba(12,121,254,0.18); }
.hs-bottom-cta::before {
	content: ""; position: absolute; inset: 0;
	background-image: linear-gradient(rgba(72,136,232,0.06) 1px, transparent 1px), linear-gradient(90deg, rgba(72,136,232,0.06) 1px, transparent 1px);
	background-size: 36px 36px;
	mask-image: radial-gradient(ellipse 80% 60% at 50% 50%, #000 50%, transparent 100%);
	pointer-events: none;
}
.hs-bottom-cta > * { position: relative; }
.hs-bottom-cta h2 { color: #fff; margin: 0 0 10px; }
.hs-bottom-cta p { margin: 0 0 18px; color: var(--hs-subtle); }

.hs-related { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; }
@media (max-width: 720px) { .hs-related { grid-template-columns: 1fr; } }

/* Review page */
.hs-howtoread { background: var(--hs-surface); border-radius: var(--hs-radius); padding: 22px; margin: 24px 0; }
.hs-howtoread h3 { margin: 0 0 6px; font-size: 16px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--hs-muted); }
.hs-howtoread p { margin: 0; color: var(--hs-muted); }

.hs-review-list { display: flex; flex-direction: column; gap: 20px; }
.hs-review-row { background: var(--hs-card); border: 1px solid var(--hs-line); border-radius: var(--hs-radius); padding: 22px; display: grid; grid-template-columns: 56px 1fr auto; gap: 22px; align-items: start; }
.hs-review-row__rank { font-size: 24px; font-weight: 800; color: var(--hs-ink); display: flex; align-items: center; gap: 6px; }
.hs-review-row__rank::before { content: "#"; color: var(--hs-subtle); font-weight: 500; }
.hs-review-row__title { font-size: 18px; font-weight: 700; margin: 0 0 4px; }
.hs-review-row__sub { color: var(--hs-muted); font-size: 14px; margin: 0 0 14px; }
.hs-review-row--featured { border-color: var(--hs-primary); box-shadow: var(--hs-glow); position: relative; padding-top: 32px; }
.hs-review-row--featured::before { content: "Editor's Choice 2026"; position: absolute; top: -12px; left: 22px; background: var(--hs-primary); color: #fff; padding: 4px 12px; border-radius: 999px; font-size: 12px; font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; }

.hs-bar { display: grid; grid-template-columns: 120px 1fr 40px; gap: 12px; align-items: center; margin: 6px 0; font-size: 14px; color: var(--hs-muted); }
.hs-bar__track { background: var(--hs-line); border-radius: 999px; height: 8px; overflow: hidden; }
.hs-bar__fill { height: 100%; background: var(--hs-accent); border-radius: 999px; }
.hs-bar__value { text-align: right; font-variant-numeric: tabular-nums; color: var(--hs-ink); font-weight: 600; }

.hs-tags { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 10px; }
.hs-tag { padding: 4px 10px; border-radius: 999px; font-size: 13px; border: 1px solid var(--hs-line); color: var(--hs-muted); background: var(--hs-card); }
.hs-tag--ok { color: #15803d; border-color: #bbf7d0; background: #f0fdf4; }
.hs-tag--no { color: #b91c1c; border-color: #fecaca; background: #fef2f2; }

.hs-compare-table { width: 100%; border-collapse: collapse; background: var(--hs-card); border: 1px solid var(--hs-line); border-radius: var(--hs-radius); overflow: hidden; }
.hs-compare-table th, .hs-compare-table td { padding: 14px 16px; text-align: left; border-bottom: 1px solid var(--hs-line); }
.hs-compare-table th { background: var(--hs-surface); font-size: 13px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--hs-muted); }
.hs-compare-table tbody tr:last-child td { border-bottom: 0; }
.hs-compare-table .row-featured { background: rgba(12,121,254,0.06); font-weight: 700; }

/* Utilities */
.hs-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
@media (max-width: 720px) { .hs-grid-2 { grid-template-columns: 1fr; } }

.hs-flex { display: flex; gap: 12px; }
.hs-flex-center { display: flex; align-items: center; justify-content: center; gap: 12px; flex-wrap: wrap; }
.hs-mt-30 { margin-top: 30px; }
