/* CASFORGE theme — all design tokens come from :root CSS vars (set per-site in
   store config), so a buyer rebrands the whole site by editing one map. */
*{box-sizing:border-box}
html{font-family:var(--font);color:var(--ink);background:var(--bg);line-height:1.6;-webkit-text-size-adjust:100%}
body{margin:0}
input,textarea,select{color:var(--ink)}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
.container{max-width:1140px;margin:0 auto;padding:0 20px}
.muted{color:var(--muted)}
.small{font-size:.85rem}
h1{font-size:2.1rem;line-height:1.15;margin:.2em 0 .4em}
h2{font-size:1.5rem;margin:1.6em 0 .5em}
h3{font-size:1.15rem;margin:0 0 .4em}
.lead{font-size:1.2rem;color:var(--muted);margin:.2em 0 1em}

/* header */
.site-header{border-bottom:1px solid var(--line);background:var(--bg);position:sticky;top:0;z-index:10}
.hd{display:flex;align-items:center;gap:24px;height:64px}
.brand{font-weight:800;font-size:1.2rem;color:var(--ink)}
.nav{display:flex;gap:18px;flex-wrap:wrap;flex:1}
.nav a{color:var(--ink);font-weight:500;font-size:.95rem}
.lang{display:flex;gap:8px}
.lang-link{border:1px solid var(--line);border-radius:8px;padding:2px 8px;font-size:.8rem;color:var(--muted)}

/* layout */
.wrap{padding:28px 0 64px}
.layout{display:grid;grid-template-columns:1fr 320px;gap:40px;align-items:start}
.crumbs{padding-top:16px}
.crumbs ol{list-style:none;display:flex;flex-wrap:wrap;gap:8px;padding:0;margin:0;font-size:.85rem;color:var(--muted)}
.crumbs li:not(:last-child)::after{content:"›";margin-left:8px;color:var(--muted)}

/* hero / page head */
.hero{padding:36px 0 8px}
.page-head{margin-bottom:8px}
.answer{font-size:1.05rem;background:var(--bg-soft);border-left:4px solid var(--brand);padding:14px 18px;border-radius:0 var(--radius) var(--radius) 0;margin:14px 0}

/* homepage hero */
.home-hero{background:linear-gradient(135deg,#0c1116,#123,#0e7a5f);color:#fff;border-radius:var(--radius);padding:48px 34px;margin:24px 0 10px}
.hh-inner{max-width:780px}
.home-hero h1{color:#fff;font-size:2.4rem;line-height:1.1;margin:0 0 .35em}
.home-sub{color:#dceee8;font-size:1.18rem;margin:0 0 24px;max-width:62ch}
.hero-cta{display:flex;gap:10px;flex-wrap:wrap;max-width:540px}
.hero-cta input[type=email]{flex:1;min-width:220px;padding:12px 14px;border:0;border-radius:10px;font:inherit}
.hero-cta .btn{padding:12px 18px}
.answer-wrap{margin:14px 0 4px}
.card.hl{background:var(--bg-soft);cursor:default}
.card.hl:hover{transform:none;box-shadow:none}

/* pillar hub intro */
.hub-intro{margin:12px 0 8px}
.hub-intro p{margin:0 0 1em;font-size:1.06rem;line-height:1.65}

/* cards grid */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:18px;margin:18px 0}
.card{display:block;border:1px solid var(--line);border-radius:var(--radius);padding:18px;background:var(--bg);transition:box-shadow .15s,transform .15s}
.card:hover{box-shadow:0 8px 28px rgba(16,21,28,.08);transform:translateY(-2px);text-decoration:none}
.card h3{color:var(--ink)}
.tag{display:inline-block;font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;color:var(--brand);font-weight:700;margin-bottom:6px}

/* article */
.post{max-width:760px}
.post-head h1{margin-top:.2em}
.byline{color:var(--muted);font-size:.9rem;margin:.4em 0 1em}
.hero-img{width:100%;height:auto;border-radius:var(--radius);margin:8px 0 4px;background:var(--bg-soft)}
.sec{margin:8px 0}
.tldr{background:linear-gradient(180deg,var(--bg-soft),var(--bg));border:1px solid var(--line);border-radius:var(--radius);padding:18px 22px;margin:18px 0}
.tldr-h{font-weight:800;color:var(--brand);margin-bottom:8px;text-transform:uppercase;letter-spacing:.03em;font-size:.85rem}
.tldr ul{margin:0;padding-left:20px}
.tldr li{margin:6px 0}

/* table of contents */
.toc{background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--radius);padding:14px 18px;margin:18px 0}
.toc-h{font-weight:800;font-size:.8rem;text-transform:uppercase;letter-spacing:.04em;color:var(--brand);margin-bottom:8px}
.toc ul{margin:0;padding-left:18px}
.toc li{margin:5px 0}
.lead-intro{font-size:1.12rem;line-height:1.7;background:none;border:0;padding:0}

/* tables */
.table-wrap{overflow-x:auto;margin:20px 0;border:1px solid var(--line);border-radius:var(--radius);scrollbar-width:thin}
.table-wrap::-webkit-scrollbar{height:9px}
.table-wrap::-webkit-scrollbar-thumb{background:var(--line);border-radius:9px}
table{border-collapse:collapse;width:100%;font-size:.85rem;line-height:1.45}
/* caption = a clean title bar attached to the top of the table card (not a floating line) */
caption{caption-side:top;text-align:left;font-weight:700;font-size:.95rem;color:var(--ink);padding:12px 14px;border-bottom:1px solid var(--line)}
th,td{border-bottom:1px solid var(--line);border-right:1px solid var(--line);padding:8px 11px;text-align:left;vertical-align:top}
th:last-child,td:last-child{border-right:0}
tbody tr:last-child td{border-bottom:0}
thead th{background:var(--bg-soft);font-weight:700;color:var(--ink)}
/* keep the first column (the row label) visible while scrolling wide comparison tables */
.table-wrap td:first-child,.table-wrap th:first-child{position:sticky;left:0;font-weight:600;box-shadow:1px 0 0 var(--line)}
.table-wrap td:first-child{background:var(--bg)}
.table-wrap thead th:first-child{background:var(--bg-soft);z-index:2}

/* faq */
.faq details{border:1px solid var(--line);border-radius:10px;padding:4px 14px;margin:10px 0;background:var(--bg)}
.faq summary{cursor:pointer;font-weight:600;padding:8px 0}
.faq-a{padding:0 0 12px;color:var(--muted)}

/* itemlist / related */
.itemlist{padding-left:22px}
.itemlist li{margin:8px 0}
.related h2{font-size:1rem;margin:0 0 10px}
.related-list{list-style:none;padding:0;margin:0}
.related-list li{margin:0 0 12px}
.related-list a{display:flex;gap:10px;align-items:center;color:var(--ink)}
.related-list a:hover{text-decoration:none}
.related-list a:hover .rel-t{color:var(--brand)}
.rel-thumb{width:76px;height:50px;object-fit:cover;border-radius:8px;flex-shrink:0;background:var(--bg-soft)}
.rel-t{font-size:.86rem;font-weight:600;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.authorbox{border-top:1px solid var(--line);margin-top:28px;padding-top:18px;display:flex;gap:14px;align-items:flex-start}
.author-avatar{border-radius:12px;object-fit:cover;flex-shrink:0}
.author-avatar.lg{border-radius:18px;display:block;margin-bottom:10px}
.author-role{color:var(--muted);font-size:.9rem;margin:4px 0}
.author-more{display:inline-block;margin-top:8px;font-size:.85rem;font-weight:600}

/* ---- sidebar: article meta + share ---- */
.meta-card{border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;margin-bottom:18px;background:var(--bg)}
.meta-list{list-style:none;margin:0 0 12px;padding:0}
.meta-list li{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid var(--line);font-size:.86rem}
.meta-list li:last-child{border-bottom:0}
.meta-list .ml-k{color:var(--muted)}
.meta-list b{font-weight:700}
.like-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:7px;border:1px solid var(--line);background:var(--bg-soft);color:var(--ink);border-radius:10px;padding:9px;font:inherit;font-size:.86rem;font-weight:600;cursor:pointer;transition:.15s}
.like-btn:hover{border-color:var(--brand);color:var(--brand)}
.like-btn.liked{background:var(--brand);color:#fff;border-color:var(--brand);cursor:default}
.like-btn .like-n{font-weight:800}
.share-card{border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;margin-bottom:18px;background:var(--bg)}
.share-h{font-weight:700;font-size:.88rem;margin-bottom:10px}
.share-row{display:flex;gap:8px;flex-wrap:wrap}
.sh{width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;border-radius:10px;border:1px solid var(--line);background:var(--bg-soft);color:var(--ink);font-weight:700;font-size:1rem;cursor:pointer;text-decoration:none;transition:.15s}
.sh:hover{text-decoration:none;color:#fff;transform:translateY(-2px)}
.sh-x:hover{background:#000;border-color:#000}
.sh-in:hover{background:#0a66c2;border-color:#0a66c2}
.sh-fb:hover{background:#1877f2;border-color:#1877f2}
.sh-tg:hover{background:#229ed9;border-color:#229ed9}
.sh-wa:hover{background:#25d366;border-color:#25d366}
.sh-cp:hover{background:var(--brand);border-color:var(--brand)}
.sh.done{background:var(--brand);border-color:var(--brand);color:#fff}

/* ---- author page ---- */
.author-page{max-width:820px;margin:0 auto}
.author-hero{display:flex;gap:22px;align-items:center;background:var(--bg-soft);border:1px solid var(--line);border-radius:16px;padding:24px;margin-bottom:8px}
.author-avatar.xl{width:120px;height:120px;border-radius:20px;object-fit:cover;flex-shrink:0}
.author-hero h1{margin:0 0 2px}
.author-hero .author-role{font-size:1.02rem;margin:2px 0 8px}
.author-creds{font-size:.9rem;color:var(--muted);margin:0 0 10px}
.author-stats{display:flex;gap:18px}
.author-stats .stat{font-size:.88rem;color:var(--muted)}
.author-stats .stat b{font-size:1.25rem;color:var(--ink);margin-right:4px}
.author-bio{margin:22px 0}
.author-bio h2{font-size:1.2rem;margin:0 0 8px}
.author-expertise{margin:18px 0}
.author-expertise h3{font-size:1rem;margin:0 0 10px}
.chips{display:flex;gap:8px;flex-wrap:wrap}
.chip-x{font-size:.8rem;font-weight:600;background:var(--bg-soft);border:1px solid var(--line);color:var(--ink);border-radius:999px;padding:5px 12px}
.author-social{margin:28px 0 8px;border-top:1px solid var(--line);padding-top:20px}
.author-social h3{font-size:1rem;margin:0 0 12px}
.social-links{display:flex;gap:10px;flex-wrap:wrap}
.social-link{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line);border-radius:10px;padding:8px 14px;font-size:.88rem;font-weight:600;color:var(--ink)}
.social-link:hover{background:var(--brand);border-color:var(--brand);color:#fff;text-decoration:none}
@media(max-width:560px){.author-hero{flex-direction:column;text-align:center}}

/* sidebar */
.sidebar{position:sticky;top:84px}
.cta-card{border:1px solid var(--line);border-left:4px solid var(--brand-2);border-radius:var(--radius);padding:18px;background:var(--bg-soft);margin-bottom:22px}
.cta-h{font-weight:800;margin-bottom:6px}
.btn{display:inline-block;background:var(--brand);color:#fff;border-radius:10px;padding:9px 14px;font-weight:600;margin-top:8px}
.btn:hover{background:var(--brand-2);text-decoration:none}

/* comments + forms */
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.comments{border-top:1px solid var(--line);margin-top:28px;padding-top:18px}
.comment{border:1px solid var(--line);border-radius:10px;padding:12px 14px;margin:10px 0}
.c-meta{font-size:.85rem;color:var(--muted);margin-bottom:4px}
.cform{margin-top:18px;display:grid;gap:10px;max-width:640px}
.cform input,.cform textarea{width:100%;padding:9px 11px;border:1px solid var(--line);border-radius:9px;font:inherit;background:var(--bg)}
.cform textarea{min-height:90px}
.cf-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.cf-row input{flex:1}
.cap{font-size:.9rem;color:var(--muted);display:flex;gap:8px;align-items:center}
.cta-card input{width:100%;padding:9px 11px;border:1px solid var(--line);border-radius:9px;font:inherit;margin:6px 0;background:var(--bg)}

/* footer */
.site-footer{border-top:1px solid var(--line);background:var(--bg-soft);margin-top:40px}
.ft{display:grid;grid-template-columns:2fr 1fr;gap:24px;padding:36px 20px}
.ft-nav,.social{display:flex;flex-direction:column;gap:8px}
.ft-nav a,.social a{color:var(--ink);font-size:.92rem}

@media(max-width:900px){
  .layout{grid-template-columns:1fr}
  .sidebar{position:static}
  .nav{display:none}
  .ft{grid-template-columns:1fr}
}

/* ---- content cards with thumbnails ---- */
.artcard,.hubcard{padding:0;overflow:hidden;display:flex;flex-direction:column}
.card-thumb{display:block;background:var(--bg-soft);aspect-ratio:16/9;overflow:hidden}
.card-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s ease}
.artcard:hover .card-thumb img,.hubcard:hover .card-thumb img{transform:scale(1.05)}
.card-body{padding:15px 17px 17px;display:flex;flex-direction:column;flex:1}
.card-body h3{margin:.15rem 0 .4rem;font-size:1.04rem;line-height:1.3}
.card-excerpt{font-size:.9rem;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;line-clamp:3;overflow:hidden;margin:0}
.card-meta{margin-top:auto;padding-top:10px;font-size:.78rem;color:var(--muted);font-weight:600}

/* ---- trust / testimonials ---- */
.trust{margin:36px 0}
.trust-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px;margin-top:16px}
.tcard{margin:0;border:1px solid var(--line);border-radius:var(--radius);padding:22px;background:var(--bg);display:flex;flex-direction:column;gap:12px}
.tcard .stars{color:#f5a623;letter-spacing:2px;font-size:1rem}
.tcard blockquote{margin:0;font-size:1.02rem;line-height:1.55;color:var(--ink);flex:1}
.tcard blockquote::before{content:"“";color:var(--brand);font-size:1.4em;line-height:0;margin-right:2px}
.tcard figcaption{display:flex;align-items:center;gap:12px}
.tavatar{width:44px;height:44px;border-radius:50%;object-fit:cover;flex-shrink:0}
.tavatar.mono{display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff;font-weight:800;font-size:1.1rem}
.tcard figcaption b{display:block;font-size:.95rem}
.tcard .trole{display:block;color:var(--muted);font-size:.82rem}

/* ---- interactive tools (cost calculator / license finder) ---- */
.tool{max-width:920px;margin:0 auto}
.tool-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin:18px 0 8px}
.tool-inputs{display:flex;flex-direction:column;gap:6px;border:1px solid var(--line);border-radius:var(--radius);padding:20px;background:var(--bg)}
.tool-inputs label{font-weight:600;font-size:.86rem;margin-top:10px}
.tool-inputs label:first-child{margin-top:0}
.tool-inputs select,.tool-inputs input{padding:10px 12px;border:1px solid var(--line);border-radius:10px;font:inherit;background:var(--bg)}
.tool-inputs .btn{margin-top:16px;text-align:center}
.tool-result{border:1px solid var(--line);border-top:4px solid var(--brand);border-radius:var(--radius);padding:20px;background:var(--bg-soft);align-self:start}
.tr-row{display:flex;justify-content:space-between;gap:14px;align-items:baseline;padding:9px 0;border-bottom:1px solid var(--line);font-size:.92rem}
.tr-row span{color:var(--muted)}
.tr-row b{font-weight:700;text-align:right}
.tr-total{font-size:1.05rem;border-bottom:2px solid var(--brand)}
.tr-total b{color:var(--brand);font-size:1.2rem}
.tr-note{font-size:.76rem;color:var(--muted);margin:12px 0 0}
.rec-route{font-size:1.3rem;font-weight:800;color:var(--brand);margin-bottom:8px;line-height:1.2}
.rec-why{font-size:.92rem;margin:0 0 12px}
.rec-watch{margin-top:12px;font-size:.86rem;background:var(--bg);border:1px solid var(--line);border-radius:10px;padding:11px 13px}
.tool-cta{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;background:var(--bg-soft);border:1px solid var(--line);border-left:4px solid var(--brand-2);border-radius:var(--radius);padding:22px 24px;margin:24px 0}
.tool-cta-txt{flex:1;min-width:240px}
.tool-cta-txt .cta-h{font-weight:800;font-size:1.1rem;margin-bottom:4px}
.tool-thumb{display:flex;align-items:center;justify-content:center;font-size:3.2rem;background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff}
@media(max-width:720px){.tool-grid{grid-template-columns:1fr}}

/* ---- carousel (launch-guides on the homepage) ---- */
.carousel-sec{margin:34px 0}
.carousel-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}
.carousel-head h2{margin:0}
.carousel-nav{display:flex;gap:8px;flex-shrink:0}
.car-btn{width:40px;height:40px;border-radius:50%;border:1px solid var(--line);background:var(--bg);color:var(--ink);font-size:1.5rem;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:.15s}
.car-btn:hover{background:var(--brand);color:#fff;border-color:var(--brand)}
.car-btn:disabled{opacity:.3;cursor:default;background:var(--bg);color:var(--ink);border-color:var(--line)}
.carousel{display:flex;gap:18px;overflow-x:auto;scroll-snap-type:x proximity;scroll-behavior:smooth;padding:4px 2px 12px;scrollbar-width:thin;scrollbar-color:var(--line) transparent}
.car-item{flex:0 0 300px;scroll-snap-align:start;margin:0}
@media(max-width:560px){.car-item{flex:0 0 82%}}

/* ---- hub (pillar) inline lead CTA — full-width, no sidebar ---- */
.hub-cta{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;background:var(--bg-soft);border:1px solid var(--line);border-left:4px solid var(--brand-2);border-radius:var(--radius);padding:22px 24px;margin:30px 0}
.hub-cta-txt{flex:1;min-width:240px}
.hub-cta-txt .cta-h{font-weight:800;font-size:1.1rem;margin-bottom:4px}
.hub-cta-form{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.hub-cta-form input[type=email]{padding:11px 13px;border:1px solid var(--line);border-radius:10px;font:inherit;min-width:240px;background:var(--bg)}
.hub-cta-form .btn{margin-top:0}

/* ---- popup / modal (admin-configurable) ---- */
body.cf-noscroll{overflow:hidden}
.cf-popup{position:fixed;inset:0;z-index:90;display:flex;align-items:center;justify-content:center;padding:20px}
.cf-popup[hidden]{display:none}
.cf-popup-overlay{position:absolute;inset:0;background:rgba(12,18,24,.6);opacity:0;transition:opacity .25s}
.cf-popup.open .cf-popup-overlay{opacity:1}
.cf-popup-card{position:relative;background:var(--bg);border-radius:18px;max-width:440px;width:100%;padding:30px 28px 24px;box-shadow:0 24px 70px rgba(12,18,24,.32);transform:translateY(16px) scale(.97);opacity:0;transition:transform .28s cubic-bezier(.2,.8,.3,1),opacity .28s;border-top:5px solid var(--brand)}
.cf-popup.open .cf-popup-card{transform:none;opacity:1}
.cf-popup-x{position:absolute;top:10px;right:12px;background:none;border:none;font-size:1.7rem;line-height:1;color:var(--muted);cursor:pointer;padding:2px 9px;border-radius:8px}
.cf-popup-x:hover{background:var(--bg-soft);color:var(--ink)}
.cf-popup-img{width:100%;border-radius:12px;margin-bottom:14px;aspect-ratio:16/9;object-fit:cover}
.cf-popup-badge{display:inline-block;font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;font-weight:800;color:var(--brand);background:var(--bg-soft);padding:4px 10px;border-radius:999px;margin-bottom:10px}
.cf-popup-title{margin:.1rem 0 .5rem;font-size:1.38rem;line-height:1.25}
.cf-popup-body{color:var(--muted);font-size:.95rem;margin:0 0 16px}
.cf-popup-form{display:grid;gap:10px}
.cf-popup-form input,.cf-popup-form select{width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:10px;font:inherit;background:var(--bg)}
.cf-popup-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.cf-popup-cta{width:100%;text-align:center;padding:12px;font-size:1rem;margin-top:4px}
.cf-popup-fine{font-size:.76rem;color:var(--muted);text-align:center;margin:8px 0 0}
@media(max-width:480px){.cf-popup-row{grid-template-columns:1fr}.cf-popup-card{padding:26px 20px 20px}}
