/*
Theme Name: CDNViral Editorial
Theme URI: https://cdnviral.online/
Author: CDNViral
Description: Editorial WordPress theme for CDNViral with a Shorts-style feed, category pages, legal pages, and AdSense-ready structure.
Version: 1.0.0
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: cdnviral-editorial
*/

:root{
  --bg:#f7f7f4;
  --paper:#ffffff;
  --ink:#171717;
  --muted:#62666d;
  --line:#ddd8ce;
  --red:#d71920;
  --blue:#2458a6;
  --green:#16745b;
  --shadow:0 14px 34px rgba(20,20,20,.08);
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--ink);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Arial,sans-serif;line-height:1.6}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{width:min(1120px,calc(100% - 32px));margin-inline:auto}
.skip-link{position:absolute;left:-999px;top:10px;background:#fff;padding:8px 12px;border:1px solid var(--line);z-index:999}
.skip-link:focus{left:10px}
.site-header{position:sticky;top:0;z-index:50;background:rgba(247,247,244,.94);border-bottom:1px solid var(--line);backdrop-filter:blur(14px)}
.header-inner{min-height:68px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;letter-spacing:0}
.brand-mark{display:inline-flex;align-items:center;justify-content:center;width:42px;height:30px;background:var(--red);color:#fff;border-radius:6px;font-size:12px}
.site-nav{display:flex;align-items:center;gap:16px;font-size:14px;color:#303236;white-space:nowrap}
.site-nav a{padding:8px 0}
.site-nav a:hover{color:var(--red)}
.nav-cta,.button-link{display:inline-flex;align-items:center;justify-content:center;border-radius:6px;font-weight:800;line-height:1.2}
.nav-cta{background:#161616;color:#fff!important;padding:10px 14px!important}
.button-link{padding:12px 16px;border:1px solid var(--line)}
.button-link.primary{background:var(--red);border-color:var(--red);color:#fff}
.button-link.secondary{background:#fff;color:#171717}
.intro-band{border-bottom:1px solid var(--line);background:linear-gradient(180deg,#fff 0%,#f7f7f4 100%)}
.intro-grid{display:grid;grid-template-columns:minmax(0,1.45fr) minmax(280px,.8fr);gap:40px;padding:58px 0 42px;align-items:end}
.eyebrow{margin:0 0 10px;color:var(--green);font-size:12px;font-weight:850;letter-spacing:.08em;text-transform:uppercase}
h1,h2,h3,p{letter-spacing:0}
h1{margin:0;font-size:clamp(36px,6vw,72px);line-height:.95;max-width:860px}
h2{margin:0 0 12px;font-size:clamp(26px,3vw,38px);line-height:1.05}
h3{margin:8px 0 0;font-size:16px;line-height:1.3}
.intro-copy p:not(.eyebrow){max-width:690px;margin:18px 0 0;color:var(--muted);font-size:18px}
.actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:26px}
.intro-notes{background:var(--paper);border:1px solid var(--line);border-radius:8px;padding:22px;box-shadow:var(--shadow)}
.intro-notes h2{font-size:22px}
.intro-notes ul{margin:8px 0 0;padding-left:18px;color:var(--muted)}
.section-block{padding:46px 0}
.editorial-brief{display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);gap:28px;padding:38px 0;border-bottom:1px solid var(--line)}
.editorial-brief p:last-child{margin:0;color:var(--muted);font-size:18px}
.section-head{display:flex;align-items:end;justify-content:space-between;gap:20px;margin-bottom:20px}
.section-head a{color:var(--blue);font-weight:800}
.video-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.video-card{background:var(--paper);border:1px solid var(--line);border-radius:8px;overflow:hidden;box-shadow:var(--shadow)}
.video-card a{display:block;height:100%}
.video-card img{width:100%;aspect-ratio:9/12;object-fit:cover;background:#111}
.video-card h3,.video-meta{display:block;padding-inline:14px}
.video-card h3{padding-bottom:16px}
.video-meta{padding-top:12px;color:var(--muted);font-size:12px;font-weight:800;text-transform:uppercase}
.topic-band{background:#101114;color:#fff;border-top:1px solid #101114;border-bottom:1px solid #101114}
.topic-band .eyebrow{color:#7ee0bf}
.topic-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}
.topic-link{display:flex;min-height:150px;flex-direction:column;justify-content:space-between;border:1px solid rgba(255,255,255,.18);border-radius:8px;padding:18px;background:rgba(255,255,255,.06)}
.topic-link strong{font-size:22px;line-height:1}
.topic-link span{color:rgba(255,255,255,.72);font-size:14px}
.trust-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}
.trust-card{display:flex;min-height:140px;flex-direction:column;justify-content:space-between;background:#fff;border:1px solid var(--line);border-radius:8px;padding:18px;box-shadow:var(--shadow)}
.trust-card strong{font-size:20px;line-height:1.1}
.trust-card span{color:var(--muted);font-size:14px}
.editorial-columns{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:36px;padding:52px 0}
.editorial-columns article{border-top:3px solid var(--red);padding-top:18px}
.editorial-columns p:not(.eyebrow),.entry-content{color:var(--muted)}
.site-footer{border-top:1px solid var(--line);background:#fff}
.footer-inner{min-height:86px;display:flex;align-items:center;justify-content:space-between;gap:20px;color:var(--muted);font-size:14px}
.footer-inner nav{display:flex;gap:16px;flex-wrap:wrap}
.page-wrap{padding:56px 0}
.content-page,.content-card{background:#fff;border:1px solid var(--line);border-radius:8px;padding:clamp(24px,5vw,48px);box-shadow:var(--shadow)}
.content-page{max-width:820px}
.content-page h1{font-size:clamp(34px,5vw,56px);margin-bottom:24px}
.entry-content h2{color:var(--ink);margin-top:28px;font-size:26px}
.entry-content a{color:var(--blue);font-weight:800;text-decoration:underline;text-underline-offset:3px}
.entry-content .button-link{text-decoration:none;color:inherit}
.post-list{display:grid;gap:18px}
.empty-copy{color:var(--muted)}
@media (max-width:860px){
  .header-inner{align-items:flex-start;flex-direction:column;padding:14px 0}
  .site-nav{width:100%;overflow:auto;padding-bottom:4px}
  .intro-grid,.editorial-columns,.editorial-brief{grid-template-columns:1fr}
  .video-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .topic-grid,.trust-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:560px){
  .wrap{width:min(100% - 24px,1120px)}
  .intro-grid{padding-top:36px}
  h1{font-size:42px}
  .video-grid,.topic-grid,.trust-grid{grid-template-columns:1fr}
  .footer-inner{align-items:flex-start;flex-direction:column;padding:24px 0}
}
