/*
Theme Name: 1-800 Office Solutions Blog Redesign
Theme URI: https://1800officesolutions.com/
Description: Editorial blog redesign — child theme of visualedge. Overrides only single.php (and optionally home.php / archive.php) so blog posts render in the new design. Elementor-built pages are untouched.
Author: 1-800 Office Solutions
Version: 1.1.0
Template: visualedge
License: Proprietary
Text Domain: blog-redesign
*/

/* ============================================================
   IMPORTANT: This stylesheet only loads on single posts (and
   the blog hub if home.php / archive.php overrides ship). The
   `.bp-` prefix on every selector is enforced via a body class
   added by functions.php so styles never bleed into other
   theme contexts.
   ============================================================ */

:root{
  --bg:#FFFFFF; --surface:#F7F8FA; --surface-2:#EEF1F5; --surface-3:#E5EAF1;
  --ink:#0B1220; --text:#1F2937; --text-muted:#4B5563; --text-dim:#6B7280;
  --border:#E5E7EB; --border-strong:#D1D5DB;
  --brand:#1180C1; --brand-deep:#143A99; --brand-soft:#E8F1F9;
  --brand-grad:linear-gradient(135deg,#143A99 0%,#1180C1 100%);
  --accent:#FF6B1A; --accent-soft:#FFEFE3; --accent-deep:#E55A0E;
  --ok:#059669; --warn:#D97706; --err:#DC2626;
  --tag-lease:#143A99; --tag-lease-soft:#E8F1F9;
  --tag-print:#0F766E; --tag-print-soft:#D1FAE5;
  --tag-sec:#B91C1C; --tag-sec-soft:#FEE2E2;
  --tag-it:#1180C1; --tag-it-soft:#E8F1F9;
  --tag-fin:#7C3AED; --tag-fin-soft:#EDE9FE;
  --tag-comp:#D97706; --tag-comp-soft:#FEF3C7;
  --sans:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --display:"Oswald","Inter",system-ui,sans-serif;
  /* --serif intentionally aliases --sans so the blog body matches the rest of the
     site (Inter). We keep the variable name so existing .prose / .lede selectors
     don't need rewriting and a future "switch back to serif body" is one line. */
  --serif:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --mono:ui-monospace,"SF Mono",Menlo,Monaco,Consolas,monospace;
  --r-sm:6px; --r:10px; --r-lg:16px; --r-xl:22px;
  --shadow-sm:0 1px 2px rgba(11,18,32,.05);
  --shadow:0 4px 14px rgba(11,18,32,.06),0 1px 3px rgba(11,18,32,.04);
  --shadow-lg:0 20px 48px rgba(11,18,32,.10),0 4px 12px rgba(11,18,32,.05);
  --container:1240px;
  --reading:760px;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{margin:0;font-family:var(--sans);color:var(--text);background:var(--bg);line-height:1.55;font-size:16px;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{font-family:var(--display);color:var(--ink);letter-spacing:-.01em;line-height:1.1;margin:0 0 12px}
h1{font-size:clamp(34px,5vw,54px);font-weight:700;letter-spacing:-.02em}
h2{font-size:clamp(26px,3.4vw,38px);font-weight:700}
h3{font-size:20px;font-weight:600;font-family:var(--sans);letter-spacing:-.01em}
p{margin:0 0 14px}
.container{max-width:var(--container);margin:0 auto;padding:0 24px}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;font-weight:600;color:var(--brand-deep);text-transform:uppercase;letter-spacing:.14em;background:var(--brand-soft);padding:6px 12px;border-radius:999px;margin-bottom:18px}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--ok);box-shadow:0 0 0 3px rgba(5,150,105,.22);animation:pulseDot 1.6s ease-in-out infinite}
@keyframes pulseDot{0%,100%{opacity:1}50%{opacity:.5}}

.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;border-radius:var(--r);font-weight:600;font-size:15px;border:1px solid transparent;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,background .18s ease,border-color .18s ease;text-decoration:none}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 6px 16px rgba(255,107,26,.28)}
.btn-primary:hover{background:var(--accent-deep);box-shadow:0 10px 22px rgba(255,107,26,.32)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.35)}
.btn-ghost:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.55)}
.btn-light{background:#fff;color:var(--ink);border-color:var(--border)}
.btn-light:hover{border-color:var(--border-strong);box-shadow:var(--shadow)}
.btn-lg{padding:14px 24px;font-size:16px}
.btn-sm{padding:9px 14px;font-size:13px}

/* Site chrome */
.topbar{background:#0B1220;color:#D1D5DB;font-size:13px;padding:8px 0}
.topbar .container{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.topbar a{color:#fff}
.topbar .live{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:12px}
.dot-live{width:7px;height:7px;border-radius:50%;background:#22C55E;box-shadow:0 0 0 3px rgba(34,197,94,.25);animation:blink 2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.4}}
.topbar-right{display:flex;gap:22px;align-items:center}
.topbar-right a:hover{color:#fff;text-decoration:underline}

.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.92);backdrop-filter:saturate(180%) blur(12px);-webkit-backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--border)}
.read-progress{position:absolute;left:0;right:0;bottom:-1px;height:3px;background:transparent;z-index:101}
.read-progress .bar{height:100%;width:0%;background:linear-gradient(90deg,var(--brand-deep),var(--brand),var(--accent));transition:width .12s ease-out}
.nav{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:14px 0}
.brand{display:inline-flex;align-items:center;gap:10px;color:var(--ink)}
.brand img{display:block;height:40px;width:auto;max-width:200px}
.nav-primary{display:flex;gap:4px;align-items:center;list-style:none;margin:0;padding:0}
.nav-primary > li{position:relative}
.nav-primary > li > a,.nav-primary > li > button{display:flex;align-items:center;gap:4px;padding:10px 14px;color:var(--ink);font-weight:500;font-size:15px;border-radius:var(--r-sm);background:none;border:0;cursor:pointer;font-family:inherit}
.nav-primary > li > a:hover,.nav-primary > li > button:hover{background:var(--surface);text-decoration:none}
.nav-primary > li > a.active{color:var(--brand-deep);background:var(--brand-soft)}
.nav-primary .caret{width:10px;height:10px;stroke:currentColor;stroke-width:2;fill:none}
.nav-actions{display:flex;align-items:center;gap:12px}
.nav-phone{display:inline-flex;align-items:center;gap:6px;font-weight:700;color:var(--ink);font-size:15px;text-decoration:none}
.nav-phone svg{width:16px;height:16px;stroke:var(--brand);stroke-width:2;fill:none}
.mega{position:absolute;left:0;top:100%;transform:translateY(8px);background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:28px;min-width:860px;max-width:calc(100vw - 40px);opacity:0;visibility:hidden;transition:opacity .18s ease,visibility .18s ease,transform .18s ease;z-index:200}
.mega.mega-center{left:50%;transform:translateX(-50%) translateY(8px)}
.mega.mega-right{left:auto;right:0}
.nav-primary > li:hover > .mega,.nav-primary > li:focus-within > .mega{opacity:1;visibility:visible;transform:translateY(0)}
.nav-primary > li:hover > .mega.mega-center,.nav-primary > li:focus-within > .mega.mega-center{transform:translateX(-50%) translateY(0)}
.mega-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px}
.mega-grid-3{grid-template-columns:repeat(3,1fr)}
.mega-grid-5{grid-template-columns:repeat(5,1fr);gap:22px}
.mega-col .mega-head{font-size:11px;color:var(--text-dim);margin:0 0 12px;font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;font-weight:700}
.mega-col ul{list-style:none;margin:0;padding:0}
.mega-col li{margin-bottom:2px}
.mega-col a{display:block;padding:7px 10px;border-radius:var(--r-sm);font-size:14px;color:var(--text);font-weight:500;text-decoration:none}
.mega-col a:hover{background:var(--brand-soft);color:var(--brand-deep);text-decoration:none}
.mega-promo{background:var(--surface);border-radius:var(--r);padding:18px;border:1px solid var(--border)}
.mega-promo .eyebrow{margin-bottom:10px;font-size:10px}
.mega-promo .title{font-family:var(--display);font-size:17px;font-weight:600;color:var(--ink);line-height:1.2;margin-bottom:8px}
.mega-promo .desc{font-size:13px;color:var(--text-muted);margin-bottom:12px;line-height:1.45}
.mega-promo a.cta{font-size:13px;font-weight:600;color:var(--brand-deep);display:inline-flex;align-items:center;gap:4px;text-decoration:none}
.nav-toggle{display:none;width:40px;height:40px;border-radius:var(--r-sm);border:1px solid var(--border);background:#fff;cursor:pointer}
.nav-toggle svg{width:20px;height:20px;stroke:var(--ink);stroke-width:2;fill:none}
@media (max-width:1024px){
  .nav-primary{display:none}
  .nav-toggle{display:grid;place-items:center}
  .mega{min-width:auto;width:100%;position:static;transform:none;opacity:1;visibility:visible;box-shadow:none;border:0;padding:12px 0}
  .mega-grid,.mega-grid-3,.mega-grid-5{grid-template-columns:1fr;gap:16px}
}
@media (max-width:640px){
  .topbar-right{display:none}
}
.skip{position:absolute;left:-9999px}
.skip:focus{left:12px;top:12px;z-index:1000;background:var(--ink);color:#fff;padding:10px 16px;border-radius:var(--r)}

/* Article hero */
.art-hero{position:relative;color:#E5E7EB;padding:80px 0 56px;overflow:hidden;background-color:#0B1220;background-image:linear-gradient(110deg,rgba(11,18,32,.97) 0%,rgba(11,18,32,.88) 35%,rgba(20,58,153,.55) 80%,rgba(17,128,193,.32) 100%),radial-gradient(ellipse 70% 50% at 88% 12%,rgba(255,107,26,.22) 0%,transparent 60%),radial-gradient(ellipse 60% 60% at 8% 88%,rgba(124,58,237,.10) 0%,transparent 60%),linear-gradient(180deg,#0B1220 0%,#0F172A 60%,#0B1220 100%)}
.art-hero::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,.06) 1px,transparent 0);background-size:32px 32px;opacity:.4;pointer-events:none;mix-blend-mode:screen}
.art-hero .container{position:relative;z-index:1;max-width:980px}
.bcrumb{font-family:var(--mono);font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:#9CA3AF;margin-bottom:24px;display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.bcrumb a{color:#D1D5DB;text-decoration:none}
.bcrumb a:hover{color:#fff;text-decoration:underline}
.bcrumb .sep{color:#4B5563}
.art-tag{display:inline-block;font-family:var(--mono);font-size:11px;font-weight:700;color:#FBBF24;background:rgba(251,191,36,.10);border:1px solid rgba(251,191,36,.32);padding:5px 12px;border-radius:4px;letter-spacing:.12em;text-transform:uppercase;margin-bottom:20px}
.art-h1{font-family:var(--display);color:#fff;font-weight:700;font-size:clamp(32px,4.4vw,52px);line-height:1.08;letter-spacing:-.02em;margin:0 0 22px;max-width:880px}
.art-h1 .hl{color:#FF8A3D}
.art-deck{font-family:var(--serif);font-size:clamp(18px,1.7vw,22px);color:#D1D5DB;line-height:1.55;margin:0 0 32px;max-width:740px;font-weight:400;font-style:italic}
.art-meta{display:flex;flex-wrap:wrap;gap:18px 28px;align-items:center;font-family:var(--mono);font-size:12.5px;color:#9CA3AF;letter-spacing:.06em;text-transform:uppercase}
.art-meta .am-author{display:inline-flex;align-items:center;gap:10px;text-transform:none;letter-spacing:0;font-family:var(--sans);font-size:14px;color:#E5E7EB}
.am-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#1180C1 0%,#143A99 100%);display:grid;place-items:center;color:#fff;font-family:var(--display);font-weight:700;font-size:14px;letter-spacing:.02em;border:2px solid rgba(255,255,255,.18)}
.am-author b{color:#fff;font-weight:600}
.am-author .am-role{color:#9CA3AF;font-size:12px;font-weight:400;margin-left:6px}
.art-stats{margin-top:36px;display:grid;grid-template-columns:repeat(3,1fr);gap:24px;padding:24px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.10);border-radius:var(--r-lg);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
@media (max-width:680px){.art-stats{grid-template-columns:1fr;gap:16px;padding:20px}}
.art-stat{position:relative}
.art-stat + .art-stat{padding-left:24px;border-left:1px solid rgba(255,255,255,.10)}
@media (max-width:680px){.art-stat + .art-stat{padding-left:0;border-left:0;border-top:1px solid rgba(255,255,255,.10);padding-top:16px}}
.art-stat-v{font-family:var(--display);font-size:36px;font-weight:700;color:#fff;line-height:1;letter-spacing:-.02em}
.art-stat-v .pct{color:#FF8A3D}
.art-stat-l{font-size:13px;color:#9CA3AF;margin-top:6px;line-height:1.4}

/* Article shell */
.art-shell{padding:48px 0 64px}
.art-grid{display:grid;grid-template-columns:1fr 280px;gap:64px;align-items:start;max-width:1180px;margin:0 auto}
@media (max-width:1024px){.art-grid{grid-template-columns:1fr;gap:32px}}
.art-main{max-width:var(--reading);margin:0 auto;width:100%}
.art-rail{position:sticky;top:90px}
@media (max-width:1024px){.art-rail{position:static;top:auto}}

/* Action bar (share / save) */
.art-actions{display:flex;gap:8px;align-items:center;padding-bottom:18px;margin-bottom:30px;border-bottom:1px solid var(--border)}
.art-actions .a-label{font-family:var(--mono);font-size:11px;color:var(--text-dim);letter-spacing:.14em;text-transform:uppercase;margin-right:8px;font-weight:700}
.a-btn{width:36px;height:36px;border-radius:50%;background:#fff;border:1px solid var(--border);color:var(--text);display:grid;place-items:center;cursor:pointer;transition:border-color .15s,background .15s,color .15s,transform .15s;text-decoration:none}
.a-btn:hover{border-color:var(--brand);background:var(--brand-soft);color:var(--brand-deep);transform:translateY(-1px);text-decoration:none}
.a-btn svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:2}
.a-spacer{flex:1}
.a-readtime{font-family:var(--mono);font-size:12px;color:var(--text-dim);letter-spacing:.06em;text-transform:uppercase}

/* Prose typography. Body uses --serif which is aliased to Inter so it matches
   the rest of the site. Size + line-height tuned for sans (Inter) readability. */
.prose{font-family:var(--serif);font-size:18px;line-height:1.65;color:var(--text)}
.prose > *:first-child{margin-top:0}
.prose p{margin:0 0 22px;font-family:var(--serif)}
.prose .lede{font-size:22px;line-height:1.55;color:var(--ink);font-weight:500;font-style:italic}
.prose .lede::first-letter{font-family:var(--display);font-weight:700;float:left;font-size:64px;line-height:.85;padding:6px 12px 0 0;color:var(--brand-deep)}
.prose h2,.prose h2.wp-block-heading{font-family:var(--display);font-size:30px;font-weight:700;color:var(--ink);margin:48px 0 16px;line-height:1.15;letter-spacing:-.01em;scroll-margin-top:96px}
.prose h3,.prose h3.wp-block-heading{font-family:var(--sans);font-size:20px;font-weight:700;color:var(--ink);margin:32px 0 12px;line-height:1.25;letter-spacing:-.005em;scroll-margin-top:96px}
.prose h4,.prose h4.wp-block-heading{font-family:var(--sans);font-size:17px;font-weight:700;color:var(--ink);margin:24px 0 10px;line-height:1.3;letter-spacing:-.005em}
.prose ul,.prose ol{margin:0 0 22px;padding-left:26px;font-family:var(--serif)}
.prose ul.wp-block-list,.prose ol.wp-block-list{padding-left:26px}
.prose li{margin-bottom:10px;line-height:1.65;font-family:var(--serif)}
.prose li::marker{color:var(--brand);font-weight:700}
.prose strong{color:var(--ink);font-weight:600}
.prose em{font-style:italic;color:var(--text)}
.prose a{color:var(--brand-deep);text-decoration:underline;text-decoration-color:rgba(20,58,153,.32);text-underline-offset:3px;transition:text-decoration-color .15s}
.prose a:hover{text-decoration-color:var(--brand-deep)}
.prose hr,.prose hr.wp-block-separator{border:0;border-top:1px solid var(--border);margin:40px auto;max-width:120px}

/* WordPress / Gutenberg images & figures — clean, centered, rounded */
.prose figure,.prose figure.wp-block-image{margin:32px auto;text-align:center}
.prose figure img,.prose img,.prose .wp-block-image img{max-width:100%;height:auto;border-radius:var(--r-lg);border:1px solid var(--border);box-shadow:var(--shadow);display:block;margin:0 auto;background:var(--surface)}
.prose figcaption,.prose figure figcaption{font-family:var(--sans);font-size:13px;color:var(--text-dim);text-align:center;margin-top:12px;line-height:1.45;font-style:italic}
.prose .aligncenter,.prose .alignwide,.prose .alignfull{margin-left:auto;margin-right:auto}
.prose .alignleft{float:left;margin:0 24px 16px 0;max-width:50%}
.prose .alignright{float:right;margin:0 0 16px 24px;max-width:50%}

/* WordPress / Gutenberg blockquotes — auto pull-quote treatment */
.prose blockquote,.prose blockquote.wp-block-quote{margin:36px -8px;padding:24px 28px 24px 36px;border-left:4px solid var(--accent);background:linear-gradient(90deg,var(--accent-soft) 0%,transparent 100%);border-radius:0 var(--r) var(--r) 0;font-family:var(--display);font-size:24px;line-height:1.3;color:var(--ink);font-weight:600;letter-spacing:-.01em;font-style:normal}
.prose blockquote::before,.prose blockquote.wp-block-quote::before{content:"\201C";font-family:var(--display);font-size:46px;line-height:0;color:var(--accent);margin-right:4px;vertical-align:-12px;font-weight:700}
.prose blockquote p{font-family:var(--display);font-size:24px;line-height:1.3;color:var(--ink);font-weight:600;margin:0 0 8px}
.prose blockquote p:last-child{margin:0}
.prose blockquote cite{display:block;margin-top:12px;font-family:var(--sans);font-size:13px;font-weight:500;color:var(--text-muted);font-style:normal;letter-spacing:0}
.prose blockquote cite::before{content:"— "}

/* WordPress / Gutenberg tables — auto polished data-table treatment */
.prose figure.wp-block-table{margin:32px 0;text-align:left}
.prose figure.wp-block-table table,.prose table,.prose table.wp-block-table{width:100%;border-collapse:collapse;font-family:var(--sans);font-size:14.5px;border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;background:#fff;box-shadow:var(--shadow-sm);margin:0;display:table}
.prose figure.wp-block-table img,.prose table img{border:0;border-radius:0;box-shadow:none}
.prose th{text-align:left;padding:14px 22px;font-family:var(--mono);font-size:11px;color:var(--text-dim);letter-spacing:.1em;text-transform:uppercase;font-weight:700;border-bottom:1px solid var(--border);background:var(--surface);font-style:normal}
.prose td{padding:14px 22px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:top;font-family:var(--sans);font-size:14.5px;line-height:1.55;font-style:normal}
.prose tr:last-child td{border-bottom:0}
.prose figure.wp-block-table figcaption{margin-top:10px;text-align:left;padding-left:4px}

/* Inline code & pre — clean monospace block */
.prose code{font-family:var(--mono);font-size:14px;background:var(--surface);padding:2px 6px;border-radius:4px;color:var(--brand-deep);border:1px solid var(--border)}
.prose pre,.prose pre.wp-block-code{font-family:var(--mono);font-size:13.5px;background:#0B1220;color:#E5E7EB;padding:18px 22px;border-radius:var(--r-lg);overflow-x:auto;margin:24px 0;line-height:1.55}
.prose pre code{background:transparent;border:0;color:inherit;padding:0}

/* WordPress embeds (YouTube, Vimeo, etc) — responsive */
.prose .wp-block-embed,.prose .wp-block-embed__wrapper{margin:32px 0}
.prose iframe{max-width:100%;border-radius:var(--r-lg);border:1px solid var(--border);display:block;margin:0 auto}

/* Buttons that come through Gutenberg — neutralized so they don't fight */
.prose .wp-block-button__link{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;border-radius:var(--r);font-weight:600;font-size:15px;background:var(--accent);color:#fff;text-decoration:none;font-family:var(--sans);box-shadow:0 6px 16px rgba(255,107,26,.28)}
.prose .wp-block-button__link:hover{background:var(--accent-deep);text-decoration:none;color:#fff}

/* Legacy custom-theme callouts that some old posts used (.quick-answer, .stat-callout) —
   re-style here so they look right after we strip the original inline <style> blocks. */
.prose .quick-answer{background:var(--brand-soft);border-left:4px solid var(--brand);padding:22px 26px;border-radius:0 var(--r) var(--r) 0;margin:28px 0;font-family:var(--serif);font-size:17px;line-height:1.55;color:var(--ink)}
.prose .quick-answer strong{display:block;font-family:var(--mono);font-size:11px;color:var(--brand-deep);letter-spacing:.14em;text-transform:uppercase;margin-bottom:8px;font-weight:700}
.prose .quick-answer br{display:none}
.prose .stat-callout{background:linear-gradient(135deg,#143A99 0%,#1180C1 100%);color:#fff;padding:28px;border-radius:var(--r-lg);text-align:center;margin:28px 0;font-family:var(--sans)}
.prose .stat-callout .stat-number{font-family:var(--display);font-size:48px;font-weight:700;color:#FBBF24;line-height:1;letter-spacing:-.02em;display:block;margin-bottom:6px}
.prose .stat-callout .stat-label{font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.85);font-weight:700}
.prose .section-label{display:inline-block;font-family:var(--mono);font-size:11px;color:var(--brand-deep);letter-spacing:.14em;text-transform:uppercase;font-weight:700;margin-bottom:8px}

/* Pull quote */
.pq{margin:36px -8px;padding:24px 28px 24px 36px;border-left:4px solid var(--accent);background:linear-gradient(90deg,var(--accent-soft) 0%,transparent 100%);border-radius:0 var(--r) var(--r) 0;font-family:var(--display);font-size:24px;line-height:1.3;color:var(--ink);font-weight:600;letter-spacing:-.01em}
.pq::before{content:"\201C";font-family:var(--display);font-size:46px;line-height:0;color:var(--accent);margin-right:4px;vertical-align:-12px;font-weight:700}
.pq cite{display:block;margin-top:12px;font-family:var(--sans);font-size:13px;font-weight:500;color:var(--text-muted);font-style:normal;letter-spacing:0}
.pq cite::before{content:"— "}

/* Stat callout */
.stat-callout{margin:36px 0;padding:28px 32px;background:#0B1220;color:#fff;border-radius:var(--r-lg);position:relative;overflow:hidden;display:grid;grid-template-columns:auto 1fr;gap:24px;align-items:center}
.stat-callout::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,.05) 1px,transparent 0);background-size:24px 24px;opacity:.5;pointer-events:none}
.stat-callout > *{position:relative;z-index:1}
.sc-num{font-family:var(--display);font-size:64px;font-weight:700;color:#FF8A3D;line-height:.95;letter-spacing:-.03em;text-shadow:0 4px 18px rgba(255,107,26,.32);min-width:120px}
.sc-body p{font-family:var(--sans);font-size:15px;line-height:1.55;color:#D1D5DB;margin:0}
.sc-body .sc-label{font-family:var(--mono);font-size:11px;color:#FBBF24;letter-spacing:.14em;text-transform:uppercase;font-weight:700;margin-bottom:4px;display:block}

/* Data table (audit findings) */
.data-table{margin:32px 0;border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;background:#fff;box-shadow:var(--shadow-sm)}
.dt-head{padding:18px 22px 16px;border-bottom:1px solid var(--border);background:var(--surface)}
.dt-head .dt-eye{font-family:var(--mono);font-size:11px;color:var(--text-dim);letter-spacing:.14em;text-transform:uppercase;font-weight:700;margin-bottom:6px}
.dt-head .dt-title{font-family:var(--display);font-size:18px;font-weight:700;color:var(--ink);margin:0}
.data-table table{width:100%;border-collapse:collapse;font-family:var(--sans);font-size:14.5px}
.data-table th{text-align:left;padding:14px 22px;font-family:var(--mono);font-size:11px;color:var(--text-dim);letter-spacing:.1em;text-transform:uppercase;font-weight:700;border-bottom:1px solid var(--border);background:#fff}
.data-table td{padding:14px 22px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:top}
.data-table tr:last-child td{border-bottom:0}
.data-table .col-pct{font-family:var(--mono);font-weight:700;color:var(--accent-deep);text-align:right;white-space:nowrap}
.data-table .col-cnt{font-family:var(--mono);color:var(--text-muted);text-align:right;white-space:nowrap}
.data-table .row-total td{background:var(--surface);font-weight:700;color:var(--ink)}

/* Inline CTA card */
.inline-cta{margin:40px 0;padding:28px 32px;background:linear-gradient(135deg,#143A99 0%,#1180C1 100%);color:#fff;border-radius:var(--r-lg);position:relative;overflow:hidden;display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center}
.inline-cta::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,.08) 1px,transparent 0);background-size:24px 24px;opacity:.5;pointer-events:none}
.inline-cta > *{position:relative;z-index:1}
@media (max-width:640px){.inline-cta{grid-template-columns:1fr;text-align:left}}
.inline-cta .ic-eye{font-family:var(--mono);font-size:11px;color:#FBBF24;letter-spacing:.14em;text-transform:uppercase;font-weight:700;margin-bottom:6px}
.inline-cta h4{font-family:var(--display);font-size:22px;font-weight:700;color:#fff;margin:0 0 4px;line-height:1.2;letter-spacing:-.01em}
.inline-cta p{font-family:var(--sans);font-size:14px;color:rgba(255,255,255,.88);margin:0;line-height:1.5}
.inline-cta .btn{box-shadow:0 8px 22px rgba(0,0,0,.25);background:#fff;color:var(--brand-deep);font-family:var(--sans)}
.inline-cta .btn:hover{background:#FBBF24;color:var(--ink)}

/* Numbered list (the seven patterns) */
.num-list{counter-reset:numlist;list-style:none;padding:0;margin:32px 0}
.num-list li{counter-increment:numlist;position:relative;padding-left:64px;margin-bottom:24px;font-family:var(--serif);font-size:18px;line-height:1.65;color:var(--text)}
.num-list li::before{content:counter(numlist,decimal-leading-zero);position:absolute;left:0;top:-2px;font-family:var(--display);font-size:34px;font-weight:700;color:var(--brand);line-height:1;letter-spacing:-.02em;width:50px;text-align:right}
.num-list li b{display:block;font-family:var(--sans);font-size:17px;color:var(--ink);font-weight:700;margin-bottom:4px;letter-spacing:-.005em}

/* Side rail */
.rail-card{background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);padding:20px;margin-bottom:18px}
.rail-eye{font-family:var(--mono);font-size:11px;color:var(--text-dim);letter-spacing:.14em;text-transform:uppercase;font-weight:700;margin:0 0 14px}
.toc-list{list-style:none;margin:0;padding:0;border-left:2px solid var(--border)}
.toc-list li{padding:0}
.toc-list a{display:block;padding:8px 0 8px 14px;margin-left:-2px;font-size:13.5px;color:var(--text-muted);font-weight:500;border-left:2px solid transparent;text-decoration:none;line-height:1.4;transition:color .15s,border-color .15s}
.toc-list a:hover{color:var(--brand-deep);text-decoration:none}
.toc-list a.is-active{color:var(--brand-deep);border-left-color:var(--brand);font-weight:600}
.rail-cta{background:linear-gradient(135deg,#0B1220 0%,#143A99 100%);color:#fff;border-radius:var(--r-lg);padding:22px;border:0}
.rail-cta .rail-eye{color:#FBBF24}
.rail-cta h4{font-family:var(--display);font-size:18px;font-weight:700;color:#fff;margin:0 0 8px;line-height:1.25}
.rail-cta p{font-size:13px;color:rgba(255,255,255,.84);margin:0 0 14px;line-height:1.5}
.rail-cta .btn{width:100%;justify-content:center;background:#fff;color:var(--brand-deep);font-size:14px;padding:11px 14px;font-family:var(--sans)}
.rail-cta .btn:hover{background:#FBBF24;color:var(--ink)}
.rail-stats{font-family:var(--mono);font-size:11px;color:rgba(255,255,255,.6);text-align:center;margin-top:10px;letter-spacing:.06em;text-transform:uppercase}

/* Author bio */
.author-bio{margin:48px 0 0;padding:28px;border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface);display:grid;grid-template-columns:72px 1fr;gap:20px;align-items:center}
@media (max-width:560px){.author-bio{grid-template-columns:1fr;text-align:center}}
.bio-avatar{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,#1180C1 0%,#143A99 100%);display:grid;place-items:center;color:#fff;font-family:var(--display);font-weight:700;font-size:28px;letter-spacing:.02em;margin:0 auto}
.bio-name{font-family:var(--display);font-size:20px;font-weight:700;color:var(--ink);margin:0 0 2px}
.bio-role{font-family:var(--mono);font-size:11px;color:var(--brand-deep);letter-spacing:.1em;text-transform:uppercase;margin-bottom:8px;font-weight:700}
.bio-text{font-size:14px;color:var(--text-muted);line-height:1.55;margin:0}
.bio-links{margin-top:10px;display:flex;gap:14px;justify-content:flex-start}
@media (max-width:560px){.bio-links{justify-content:center}}
.bio-links a{font-size:12px;font-family:var(--mono);color:var(--brand-deep);letter-spacing:.06em;text-transform:uppercase;font-weight:700;text-decoration:none}
.bio-links a:hover{text-decoration:underline}

/* Tag row */
.tag-row{margin:32px 0 0;display:flex;flex-wrap:wrap;gap:8px;align-items:center;padding:18px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.tag-row .tr-label{font-family:var(--mono);font-size:11px;color:var(--text-dim);letter-spacing:.14em;text-transform:uppercase;font-weight:700;margin-right:6px}
.tag-row a{display:inline-flex;align-items:center;background:var(--surface);border:1px solid var(--border);color:var(--text);padding:6px 12px;border-radius:999px;font-size:12.5px;font-weight:500;text-decoration:none;transition:border-color .15s,background .15s,color .15s}
.tag-row a:hover{border-color:var(--brand);background:var(--brand-soft);color:var(--brand-deep);text-decoration:none}

/* Read next */
.read-next{padding:64px 0;background:var(--surface);border-top:1px solid var(--border)}
.rn-head{max-width:760px;margin:0 auto 32px;text-align:center}
.rn-head .s-eye{font-family:var(--mono);font-size:11px;color:var(--brand-deep);text-transform:uppercase;letter-spacing:.14em;font-weight:700;margin-bottom:10px}
.rn-head h2{font-family:var(--display);font-size:clamp(24px,3vw,34px);font-weight:700;color:var(--ink);margin:0 0 8px}
.rn-head p{font-size:15px;color:var(--text-muted);max-width:600px;margin:0 auto;line-height:1.55}
.rn-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:1180px;margin:0 auto;padding:0 24px}
@media (max-width:920px){.rn-grid{grid-template-columns:1fr;gap:16px}}
.rn-card{background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column;transition:border-color .18s,box-shadow .18s,transform .18s;color:inherit;text-decoration:none}
.rn-card:hover{border-color:var(--brand);box-shadow:var(--shadow-lg);transform:translateY(-3px);text-decoration:none}
.rn-cover{height:120px;position:relative}
.rn-cover.lease{background:linear-gradient(135deg,#143A99 0%,#1180C1 100%)}
.rn-cover.it{background:linear-gradient(135deg,#1E40AF 0%,#3B82F6 100%)}
.rn-cover.fin{background:linear-gradient(135deg,#5B21B6 0%,#8B5CF6 100%)}
.rn-cover.sec{background:linear-gradient(135deg,#7F1D1D 0%,#DC2626 100%)}
.rn-cover.print{background:linear-gradient(135deg,#0F766E 0%,#10B981 100%)}
.rn-cover::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,.10) 1px,transparent 0);background-size:18px 18px;opacity:.5}
.rn-cover-date{position:absolute;right:14px;top:12px;font-family:var(--mono);font-size:10.5px;font-weight:600;color:rgba(255,255,255,.95);letter-spacing:.1em;text-transform:uppercase;background:rgba(0,0,0,.45);padding:3px 8px;border-radius:3px;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:1}
/* When the cover has a real photo behind it, hide the dot pattern + bump badge contrast */
.rn-cover.has-thumb::before{display:none}
.rn-cover.has-thumb .rn-cover-date{background:rgba(0,0,0,.6)}
.guide-cover.has-thumb::before{display:none}
.guide-cover.has-thumb .guide-cover-date{background:rgba(0,0,0,.6)}
.rn-body{padding:18px 20px 20px;flex:1;display:flex;flex-direction:column}
.rn-tag{display:inline-block;font-family:var(--mono);font-size:10.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:3px 8px;border-radius:4px;margin-bottom:10px;align-self:flex-start}
.rn-tag.lease{color:var(--tag-lease);background:var(--tag-lease-soft)}
.rn-tag.it{color:var(--tag-it);background:var(--tag-it-soft)}
.rn-tag.fin{color:var(--tag-fin);background:var(--tag-fin-soft)}
.rn-tag.sec{color:var(--tag-sec);background:var(--tag-sec-soft)}
.rn-tag.print{color:var(--tag-print);background:var(--tag-print-soft)}
.rn-card h3{font-family:var(--display);font-size:18px;font-weight:700;color:var(--ink);line-height:1.2;margin:0 0 8px;letter-spacing:-.01em}
.rn-excerpt{font-size:14px;color:var(--text-muted);line-height:1.5;margin:0 0 12px;flex:1}
.rn-meta{font-family:var(--mono);font-size:11px;color:var(--text-dim);letter-spacing:.06em;text-transform:uppercase;border-top:1px solid var(--border);padding-top:10px}

/* Newsletter strip (after read next) */
.news-strip{background:linear-gradient(135deg,#0B1220 0%,#143A99 60%,#1180C1 100%);color:#fff;padding:56px 0;text-align:center}
.news-strip .s-eye{color:#FBBF24}
.news-strip h2{color:#fff;font-family:var(--display);font-size:clamp(24px,3vw,34px);margin:0 0 10px}
.news-strip p{color:rgba(255,255,255,.86);font-size:15px;max-width:560px;margin:0 auto 18px;line-height:1.55}
.news-form{max-width:480px;margin:0 auto;display:flex;gap:8px;background:#fff;border-radius:var(--r);padding:6px;box-shadow:0 12px 32px rgba(0,0,0,.28)}
.news-form input{flex:1;border:0;padding:12px 14px;font-size:14px;font-family:inherit;color:var(--ink);background:transparent;outline:none}
.news-form button{background:var(--accent);color:#fff;border:0;padding:11px 18px;border-radius:var(--r-sm);font-weight:700;font-size:14px;font-family:inherit;cursor:pointer;transition:background .15s}
.news-form button:hover{background:var(--accent-deep)}
.news-mini{margin-top:14px;font-family:var(--mono);font-size:11px;color:rgba(255,255,255,.6);letter-spacing:.06em;text-transform:uppercase}

/* Footer */
footer{background:#0B1220;color:#9CA3AF;padding:56px 0 24px;font-size:14px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr 1fr;gap:48px;padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,.08)}
footer h3{color:#fff;font-family:var(--sans);font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-bottom:16px}
footer a{color:#9CA3AF;font-size:13px;line-height:2}
footer a:hover{color:#fff;text-decoration:none}
footer ul{list-style:none;padding:0;margin:0}
.foot-brand{max-width:320px}
.foot-brand .brand{color:#fff;margin-bottom:14px}
.foot-brand p{font-size:13px;line-height:1.6;color:#9CA3AF}
.foot-contact{margin:18px 0 0;font-size:13px;line-height:1.55;color:#9CA3AF}
.foot-addr{font-style:normal;margin:0 0 10px;color:#9CA3AF;font-size:12.5px;line-height:1.55}
.foot-addr a{color:inherit;text-decoration:none}
.foot-addr a:hover{color:#fff}
.foot-emails{list-style:none;padding:0;margin:8px 0 0}
.foot-emails li{font-size:12px;margin-bottom:6px;line-height:1.4}
.foot-emails a{color:#D1D5DB;text-decoration:none;line-height:1.5;font-size:12.5px}
.foot-emails a:hover{color:#fff;text-decoration:underline}
.foot-mid{display:flex;justify-content:space-between;align-items:center;gap:32px;flex-wrap:wrap;padding:24px 0;border-bottom:1px solid rgba(255,255,255,.08)}
.foot-trust{display:flex;flex-wrap:wrap;gap:18px 28px;align-items:center;margin:0;padding:0;border:0}
.foot-trust-item{display:inline-flex;align-items:center;gap:8px;font-size:12px;color:#D1D5DB;line-height:1}
.fti-stars{color:#FBBF24;letter-spacing:1px;font-size:13px}
.fti-label{font-size:12px;color:#9CA3AF}
.fti-label b{color:#fff;font-weight:700}
.fti-badge{display:inline-grid;place-items:center;height:22px;min-width:38px;padding:0 8px;border-radius:4px;font-family:var(--display);font-weight:700;font-size:11px;letter-spacing:.04em;color:#fff}
.fti-badge.soc{background:#0F766E}
.fti-badge.cap{background:#1180C1}
.fti-link{text-decoration:none;color:inherit;transition:transform .18s ease,opacity .18s ease}
.fti-link:hover{transform:translateY(-1px);opacity:.92}
.foot-social{display:flex;gap:10px;margin:0;padding:0;border:0;align-items:center}
.foot-social a{display:inline-grid;place-items:center;width:36px;height:36px;border-radius:6px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);color:#D1D5DB;transition:background .18s ease,color .18s ease,transform .18s ease}
.foot-social a:hover{background:rgba(17,128,193,.22);border-color:rgba(17,128,193,.45);color:#fff;transform:translateY(-1px)}
.foot-social svg{width:16px;height:16px;fill:currentColor}
.foot-oems{padding:24px 0;border-bottom:1px solid rgba(255,255,255,.08);margin:0;display:flex;align-items:center;gap:28px;flex-wrap:wrap}
.foot-oem-lbl{display:inline-block;font-size:10px;text-transform:uppercase;letter-spacing:.14em;color:#6B7280;font-weight:700;margin:0;font-family:var(--mono);flex-shrink:0}
.foot-oem-row{display:flex;flex-wrap:wrap;gap:6px}
.foot-oem{font-size:11px;font-weight:600;color:#D1D5DB;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);padding:4px 9px;border-radius:4px;letter-spacing:.02em}
.foot-bottom{padding-top:24px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:12px}
@media (max-width:900px){
  .foot-grid{grid-template-columns:1fr 1fr;gap:32px}
  .foot-brand{grid-column:1/-1;max-width:100%}
  .foot-mid{justify-content:flex-start}
  .foot-oems{gap:16px}
}

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


/* ============================================================
 * Blog hub + archive design — pulled from blog-v2.html template.
 * These classes (.hero, .cyber-quote, .cq-*, .feat-*, .filter-bar, .fb-*,
 * .guide-grid, .guide-card, .guide-cover, .gtag, .editor-*, .topics-cloud,
 * .topic-pill, .sub-band, .sub-form, .tools-band, .tool-card, .news cover, etc.)
 * are used by home.php and archive.php but were missing from the original
 * style.css extraction (which only covered single-post styles).
 * ============================================================ */

/* Hero */
.hero{position:relative;color:#E5E7EB;padding:72px 0 64px;overflow:hidden;background-color:#0B1220;background-image:linear-gradient(100deg,rgba(11,18,32,.95) 0%,rgba(11,18,32,.85) 40%,rgba(11,18,32,.62) 70%,rgba(11,18,32,.42) 100%),radial-gradient(ellipse 90% 60% at 85% 20%,rgba(17,128,193,.22) 0%,transparent 55%),radial-gradient(ellipse 70% 50% at 10% 90%,rgba(124,58,237,.10) 0%,transparent 55%),linear-gradient(180deg,#0B1220 0%,#0F172A 60%,#0B1220 100%)}

.hero::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,.05) 1px,transparent 0);background-size:32px 32px;opacity:.35;pointer-events:none;mix-blend-mode:screen}

.hero .container{position:relative;z-index:1}

.hero-grid{display:grid;grid-template-columns:1.25fr 1fr;gap:48px;align-items:center}

@media (max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:32px}
}

.hero h1{color:#fff;margin-bottom:18px}

.hero h1 .hl{color:#FF8A3D}

.hero-sub{font-size:18px;color:#D1D5DB;max-width:640px;margin-bottom:24px;line-height:1.6}

.proof-pills{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:28px}

.proof-pill{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.10);color:#E5E7EB;padding:7px 12px;border-radius:999px;font-size:12.5px;font-family:var(--mono);font-weight:500}

.proof-pill .pp-k{color:#FBBF24;font-weight:700}

.hero-ctas{display:flex;gap:12px;flex-wrap:wrap}

.hero-ctas .btn-primary{box-shadow:0 8px 22px rgba(255,107,26,.38)}

.hero-micro{margin-top:14px;font-size:12.5px;color:#9CA3AF}

/* Hero quote / signup card */
.cyber-quote{background:#fff;border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);overflow:hidden;color:var(--ink)}

.cq-head{padding:22px 26px 18px;border-bottom:1px solid var(--border);background:linear-gradient(180deg,var(--surface) 0%,#fff 100%)}

.cq-eyebrow{font-family:var(--mono);font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--text-dim);display:inline-flex;align-items:center;gap:8px;margin-bottom:10px}

.cq-eyebrow .dot{width:8px;height:8px;border-radius:50%;background:#10B981;box-shadow:0 0 0 4px rgba(16,185,129,.18)}

.cq-title{font-family:var(--display);font-size:22px;line-height:1.2;font-weight:700;color:var(--ink);margin:0 0 6px;letter-spacing:-.01em}

.cq-sub{font-size:14px;line-height:1.5;color:var(--text-muted);margin:0}

.cq-body{padding:22px 26px 24px}

.cq-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}

.cq-full{grid-column:1 / -1}

.cq-field input,.cq-field select{width:100%;padding:12px 13px;border:1px solid var(--border-strong);border-radius:var(--r-sm);font-size:14px;font-family:inherit;color:var(--ink);background:#fff;transition:border-color .15s,box-shadow .15s;-webkit-appearance:none;appearance:none}

.cq-field select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M3 4.5 6 7.5 9 4.5' stroke='%23374151' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:14px;padding-right:36px}

.cq-field input:focus,.cq-field select:focus{outline:0;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}

.cq-submit{width:100%;margin-top:14px;padding:14px 18px;background:var(--accent);color:#fff;border:0;border-radius:var(--r-sm);font-family:var(--display);font-size:15px;font-weight:700;letter-spacing:.01em;cursor:pointer;transition:background .15s,transform .1s}

.cq-submit:hover{background:var(--accent-deep);transform:translateY(-1px)}

.cq-foot{font-size:12px;color:var(--text-muted);text-align:center;margin:12px 0 0;line-height:1.5}

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

/* Sections */
section.s{padding:72px 0}

section.s.tight{padding:56px 0}

.s-head{max-width:760px;margin-bottom:40px}

.s-lede{font-size:17px;color:var(--text-muted);max-width:720px;line-height:1.6}

/* Featured post hero card */
.feat-band{background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}

.feat-card{background:#fff;border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow);overflow:hidden;display:grid;grid-template-columns:1.2fr 1fr;gap:0}

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

.feat-body{padding:36px 40px}

@media (max-width:560px){
  .feat-body{padding:28px 24px}
}

.feat-tag{display:inline-block;font-family:var(--mono);font-size:11px;font-weight:700;color:var(--brand-deep);background:var(--brand-soft);padding:5px 11px;border-radius:4px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:14px}

.feat-card h2{font-family:var(--display);font-size:clamp(24px,3vw,32px);line-height:1.15;color:var(--ink);margin:0 0 14px}

.feat-card p{font-size:15.5px;color:var(--text-muted);line-height:1.6;margin:0 0 18px}

.feat-meta{display:flex;flex-wrap:wrap;gap:16px;font-family:var(--mono);font-size:12px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.08em;margin-bottom:24px}

.feat-meta .fm-item{display:inline-flex;align-items:center;gap:6px}

.feat-meta .fm-dot{width:5px;height:5px;border-radius:50%;background:var(--brand)}

.feat-cover{background:linear-gradient(135deg,#143A99 0%,#1180C1 50%,#0B1220 100%);position:relative;min-height:280px;display:grid;place-items:center;overflow:hidden}

.feat-cover::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,.10) 1px,transparent 0);background-size:24px 24px;opacity:.55}

.feat-cover-inner{position:relative;z-index:1;text-align:center;color:#fff;padding:24px}

.feat-cover-num{font-family:var(--display);font-size:96px;font-weight:700;line-height:1;color:rgba(255,255,255,.95);text-shadow:0 4px 24px rgba(0,0,0,.4);letter-spacing:-.04em}

.feat-cover-sub{font-family:var(--mono);font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:#FBBF24;margin-top:8px}

/* Filter bar (chips) */
.filter-bar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:32px;align-items:center;justify-content:flex-start}

.filter-bar .fb-label{font-family:var(--mono);font-size:11px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.14em;font-weight:700;margin-right:8px}

.fb-chip{display:inline-flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--border);color:var(--text);padding:7px 12px;border-radius:999px;font-size:13px;font-weight:500;text-decoration:none;transition:border-color .15s,background .15s,color .15s,box-shadow .15s;cursor:pointer}

.fb-chip:hover{border-color:var(--brand);background:var(--brand-soft);color:var(--brand-deep);text-decoration:none}

.fb-chip.is-active{background:var(--ink);color:#fff;border-color:var(--ink)}

.fb-chip .fb-num{font-family:var(--mono);font-size:11px;font-weight:700;color:var(--text-dim)}

.fb-chip.is-active .fb-num{color:rgba(255,255,255,.7)}

/* Latest posts grid */
.guide-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}

@media (max-width:980px){
  .guide-grid{grid-template-columns:repeat(2,1fr)}
}

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

.guide-card{background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column;transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease;color:inherit;text-decoration:none}

.guide-card:hover{border-color:var(--brand);box-shadow:var(--shadow-lg);transform:translateY(-3px);text-decoration:none}

/* Base cover sizing — was missing, caused thumbnails to collapse to a thin strip
   showing only a sliver of the 768x432 source image. 16/9 = full thumb visible. */
.guide-cover{position:relative;width:100%;aspect-ratio:16/9;background-color:#0B1220;overflow:hidden}

.guide-cover.comp{background:linear-gradient(135deg,#92400E 0%,#F59E0B 100%)}

.guide-cover.news{background:linear-gradient(135deg,#1F2937 0%,#475569 100%)}

.guide-cover-mark{position:absolute;left:18px;bottom:14px;font-family:var(--display);font-size:48px;font-weight:700;color:rgba(255,255,255,.95);line-height:1;letter-spacing:-.04em;z-index:1}

.guide-body{padding:18px 20px 20px;flex:1;display:flex;flex-direction:column}

.gtag{display:inline-block;font-family:var(--mono);font-size:10.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:3px 8px;border-radius:4px;margin-bottom:10px;align-self:flex-start}

.gtag.lease{color:var(--tag-lease);background:var(--tag-lease-soft)}

.gtag.print{color:var(--tag-print);background:var(--tag-print-soft)}

.gtag.sec{color:var(--tag-sec);background:var(--tag-sec-soft)}

.gtag.it{color:var(--tag-it);background:var(--tag-it-soft)}

.gtag.fin{color:var(--tag-fin);background:var(--tag-fin-soft)}

.gtag.comp{color:var(--tag-comp);background:var(--tag-comp-soft)}

.gtag.news{color:var(--tag-news);background:var(--tag-news-soft)}

.guide-card h3{font-family:var(--display);font-size:18px;font-weight:700;color:var(--ink);line-height:1.2;margin:0 0 8px;letter-spacing:-.01em}

.guide-excerpt{font-size:14px;color:var(--text-muted);line-height:1.55;margin:0 0 14px;flex:1}

.guide-meta{font-family:var(--mono);font-size:11px;color:var(--text-dim);letter-spacing:.06em;text-transform:uppercase;border-top:1px solid var(--border);padding-top:10px;display:flex;justify-content:space-between;gap:8px;flex-wrap:wrap}

.guide-meta .gm-author{color:var(--text-muted);font-weight:600;text-transform:none;letter-spacing:0;font-family:var(--sans);font-size:12px}

/* Editor's pick column (mini list) */
.editor-band{background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}

.editor-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:48px;align-items:start}

@media (max-width:900px){
  .editor-grid{grid-template-columns:1fr;gap:24px}
}

.editor-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}

.editor-row{display:grid;grid-template-columns:34px 1fr;gap:14px;padding:14px 0;border-top:1px solid var(--border);text-decoration:none;color:inherit;align-items:start}

.editor-row:first-child{border-top:0;padding-top:6px}

.editor-row:hover{text-decoration:none;background:linear-gradient(180deg,transparent 0,rgba(232,241,249,.5) 100%)}

.editor-num{font-family:var(--display);font-size:24px;font-weight:700;color:var(--brand);line-height:1;letter-spacing:-.02em}

.editor-row h4{font-family:var(--display);font-size:17px;font-weight:600;color:var(--ink);margin:0 0 4px;line-height:1.25;letter-spacing:-.01em}

.editor-row .em-meta{font-family:var(--mono);font-size:11px;color:var(--text-dim);letter-spacing:.08em;text-transform:uppercase}

/* Topic cloud */
.topics{background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}

.topics-cloud{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;max-width:920px;margin:0 auto}

.topic-pill{display:inline-flex;align-items:center;background:#fff;border:1px solid var(--border);color:var(--ink);padding:10px 16px;border-radius:999px;font-weight:500;font-size:14px;text-decoration:none;transition:border-color .18s,background .18s,color .18s}

.topic-pill:hover{border-color:var(--brand);background:var(--brand-soft);color:var(--brand-deep);text-decoration:none}

.topic-pill .tp-num{font-family:var(--mono);font-size:11px;color:var(--text-dim);margin-left:6px;font-weight:700}

/* Subscribe band */
.sub-band{background:linear-gradient(135deg,#0B1220 0%,#143A99 60%,#1180C1 100%);color:#fff;border-radius:var(--r-xl);padding:48px 40px;display:grid;grid-template-columns:1.1fr 1fr;gap:40px;align-items:center;position:relative;overflow:hidden;box-shadow:var(--shadow-lg)}

.sub-band::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,.08) 1px,transparent 0);background-size:28px 28px;opacity:.5}

.sub-band > *{position:relative;z-index:1}

@media (max-width:900px){
  .sub-band{grid-template-columns:1fr;padding:36px 24px;gap:28px}
}

.sub-band h2{color:#fff;margin-bottom:10px}

.sub-band p{color:rgba(255,255,255,.92);font-size:16px;line-height:1.55;margin:0 0 14px}

.sub-band .sub-stat{font-family:var(--mono);font-size:12px;color:#FBBF24;letter-spacing:.1em;text-transform:uppercase;font-weight:700;margin-bottom:14px}

.sub-form{background:#fff;border-radius:var(--r-lg);padding:24px;color:var(--ink)}

/* Tools links band */
.tools-band{background:#fff;border-top:1px solid var(--border)}

.tools-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}

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

.tool-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:24px;transition:border-color .18s,box-shadow .18s;text-decoration:none;color:inherit;display:block}

.tool-card:hover{border-color:var(--brand);box-shadow:var(--shadow);text-decoration:none}

.tool-ico{width:42px;height:42px;border-radius:10px;background:var(--brand-soft);color:var(--brand-deep);display:grid;place-items:center;font-family:var(--display);font-size:18px;font-weight:700;margin-bottom:12px;letter-spacing:.02em}

.tool-name{font-family:var(--display);font-size:18px;font-weight:700;color:var(--ink);margin:0 0 6px}

.tool-desc{font-size:14px;color:var(--text-muted);line-height:1.5;margin:0 0 12px}

.tool-link{font-size:13px;font-weight:600;color:var(--brand-deep);font-family:var(--mono);letter-spacing:.04em;text-transform:uppercase}

/* Final CTA */
.final-cta{background:var(--brand-grad);padding:56px 0;color:#fff;text-align:center;position:relative;overflow:hidden}

.final-cta::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,.08) 1px,transparent 0);background-size:28px 28px;opacity:.5}

.final-cta > .container{position:relative;z-index:1}

.final-cta h2{color:#fff;margin-bottom:12px}

.final-cta p{color:rgba(255,255,255,.92);font-size:17px;max-width:620px;margin:0 auto 22px}

.final-cta .btn-ghost{background:#fff;color:var(--brand-deep);border-color:#fff}

.final-cta .btn-ghost:hover{background:var(--ink);color:#fff;border-color:var(--ink)}

/* Proof strip */
.proof-strip{background:#fff;border-bottom:1px solid var(--border);padding:36px 0}

.proof-row{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}

.proof-item .pv{font-family:var(--display);font-size:clamp(32px,4vw,44px);font-weight:700;color:var(--brand-deep);line-height:1;letter-spacing:-.02em}

.proof-item .pl{font-size:13px;color:var(--text-muted);margin-top:8px;line-height:1.35}

@media (max-width:720px){
  .proof-row{grid-template-columns:repeat(2,1fr);gap:28px}
}
