/*
Theme Name: חדשות הדין
Theme URI: https://lawnews.co.il
Author: מערכת חדשות הדין
Description: ערכת עיצוב ייעודית לאתר חדשות הדין. צפיפות עיתונאית, גבהים אחידים, RTL.
Version: 1.0.0
Requires PHP: 7.4
License: Proprietary
Text Domain: lawnews
*/
/* ============================================================
   חדשות הדין  |  lawnews.co.il
   מערכת עיצוב ראשית — צפיפות עיתונאית, גבהים אחידים
   ============================================================ */

:root{
  --ink:#111111;
  --ink-2:#333333;
  --gray-7:#555555;
  --gray-5:#767676;
  --gray-4:#9a9a9a;
  --line:#e2e2e2;
  --paper:#ffffff;
  --paper-2:#f7f7f7;
  --accent:#9c1c28;
  --accent-dark:#7d151f;
  --navy:#122444;
  --display:'Noto Sans Hebrew', Arial, sans-serif;
  --sans:'Assistant', Arial, sans-serif;
  --serif:'Noto Serif Hebrew', 'David Libre', serif;
}

*{margin:0;padding:0;box-sizing:border-box}
body{
  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
input{font-family:inherit}
a:focus-visible,button:focus-visible,input:focus-visible{
  outline:2px solid var(--accent);
  outline-offset:2px;
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
}

.container{max-width:1180px;margin:0 auto;padding:0 20px}

/* ─── Category colors ─────────────────────────── */
.c-work{--cat:#1d4ed8}
.c-family{--cat:#9c1c28}
.c-medical{--cat:#0e7490}
.c-btl{--cat:#5b21b6}
.c-consumer{--cat:#047857}
.c-realestate{--cat:#b45309}
.c-law{--cat:#334155}
.c-guides{--cat:#0f766e}
.card-kicker,.kicker{color:var(--cat,var(--accent))}

/* ─── Utility bar ─────────────────────────────── */
.topbar{background:#111;color:#b7b7b7;font-size:12px}
.topbar .container{display:flex;justify-content:space-between;align-items:center;height:32px}
.topbar-date span{color:#d9d9d9}
.topbar-date .sep{margin:0 8px;color:#555}
.topbar-links{display:flex;gap:20px}
.topbar-links a:hover{color:#fff}

/* ─── Masthead ────────────────────────────────── */
.masthead{border-bottom:1px solid var(--line)}
.masthead .container{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:16px;padding-bottom:14px;
}
.brand{display:flex;flex-direction:column;gap:2px}
.brand .logotype{
  font-family:var(--display);
  font-weight:900;
  font-size:32px;
  letter-spacing:-0.5px;
  line-height:1;
  color:var(--ink);
}
.brand .logotype .dot{color:var(--accent)}
.brand .tagline{font-size:11.5px;color:var(--gray-5);letter-spacing:.2px}
.masthead-left{display:flex;align-items:center;gap:14px}
.btn-outline{
  font-size:13px;font-weight:600;color:var(--ink);
  border:1px solid var(--ink);
  padding:7px 16px;
  transition:all .12s;
}
.btn-outline:hover{background:var(--ink);color:#fff}
.search-btn{
  width:36px;height:36px;
  display:flex;align-items:center;justify-content:center;
  color:var(--ink-2);
  border:1px solid transparent;
}
.search-btn:hover{border-color:var(--line)}

/* ─── Nav ─────────────────────────────────────── */
.navbar{
  border-bottom:2px solid var(--ink);
  background:var(--paper);
  position:sticky;top:0;z-index:100;
}
.navbar .container{display:flex;align-items:stretch;height:44px}
.navbar a{
  display:flex;align-items:center;
  white-space:nowrap;
  padding:0 14px;
  font-size:14.5px;font-weight:600;color:var(--ink-2);
  border-bottom:3px solid transparent;
  margin-bottom:-2px;
  transition:color .12s;
}
.navbar a:hover{color:var(--accent)}
.navbar a.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:700}

/* ─── Shared atoms ────────────────────────────── */
.kicker{
  display:flex;align-items:center;gap:10px;
  font-size:13.5px;font-weight:700;
}
.kicker a:hover{text-decoration:underline}
.kicker .promoted{
  font-weight:600;color:var(--gray-5);
  border:1px solid var(--line);
  font-size:11px;
  padding:1px 8px;
  letter-spacing:.3px;
}
.card-kicker{font-size:11.5px;font-weight:800;margin-bottom:4px}
.meta{font-size:11.5px;color:var(--gray-4)}
.meta b{color:var(--gray-5);font-weight:600}
.chip{
  display:inline-block;width:fit-content;
  font-size:10.5px;font-weight:800;
  color:var(--cat,var(--accent));
  background:color-mix(in srgb, var(--cat,var(--accent)) 9%, #fff);
  padding:2px 8px;
}
.tag{
  font-size:12.5px;font-weight:500;
  background:var(--paper-2);
  border:1px solid var(--line);
  color:var(--ink-2);
  padding:3px 11px;
  transition:all .12s;
}
.tag:hover{border-color:var(--ink);color:var(--ink)}

/* ─── Section heads ───────────────────────────── */
.section-block{margin-top:28px}
.section-head{
  display:flex;justify-content:space-between;align-items:baseline;
  border-top:3px solid var(--ink);
  padding-top:9px;
  margin-bottom:14px;
}
.section-head h2{
  font-family:var(--display);
  font-size:19px;font-weight:900;letter-spacing:-0.3px;
}
.section-head h2 a:hover{color:var(--accent)}
.section-head .more-link{font-size:12.5px;font-weight:600;color:var(--gray-5)}
.section-head .more-link:hover{color:var(--accent)}

/* ─── Overlay cards (hero mosaic + category tiles) */
.hero-mosaic{
  display:grid;
  grid-template-columns:minmax(0,2fr) minmax(0,1fr);
  gap:12px;
}
.overlay-card{
  position:relative;display:block;overflow:hidden;background:#111;
}
.overlay-card img{
  position:absolute;inset:0;
  width:100%;height:100%;object-fit:cover;
  filter:saturate(.95);
}
.overlay-text{
  position:absolute;inset:0;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:26px 30px;
  background:linear-gradient(to top,rgba(8,8,10,.92) 0,rgba(8,8,10,.44) 48%,rgba(8,8,10,0) 76%);
  color:#fff;
}
.overlay-tag{
  width:fit-content;
  background:var(--cat,var(--accent));color:#fff;
  font-size:11.5px;font-weight:800;letter-spacing:.2px;
  padding:3px 10px;
  margin-bottom:10px;
}
.hero-main{height:396px}
.hero-main h1{
  font-family:var(--display);
  font-weight:900;
  font-size:clamp(23px, 2.6vw, 31px);
  line-height:1.22;
  letter-spacing:-0.4px;
  max-width:19em;
  margin-bottom:7px;
}
.hero-sub{
  font-size:14.5px;line-height:1.5;
  color:rgba(255,255,255,.82);
  max-width:42em;
  margin-bottom:8px;
}
.overlay-text small{font-size:11.5px;color:rgba(255,255,255,.6)}
.overlay-card:hover h1,.overlay-card:hover h3{
  text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:3px;
}
.hero-side{display:grid;grid-template-rows:1fr 1fr;gap:12px}
.overlay-sm{min-height:0}
.overlay-sm .overlay-text{padding:14px 16px}
.overlay-sm .overlay-tag{font-size:10px;padding:2px 8px;margin-bottom:7px}
.overlay-sm h3{
  font-family:var(--display);
  font-weight:800;
  font-size:16px;
  line-height:1.3;
  color:#fff;
}

/* mini cards row under hero */
.mini-row{display:grid;grid-template-columns:repeat(3,1fr);gap:0 22px;margin-top:4px}
.mini-card{
  display:grid;grid-template-columns:88px 1fr;gap:11px;
  align-items:center;
  padding:12px 0 11px;
  border-top:1px solid var(--line);
}
.mini-card img{width:88px;height:62px;object-fit:cover;filter:saturate(.9)}
.mini-card .card-kicker{font-size:10.5px;margin-bottom:2px}
.mini-card h3{font-size:13.5px;font-weight:700;line-height:1.38;color:var(--ink)}
.mini-card:hover h3{text-decoration:underline;text-decoration-thickness:1.5px;text-underline-offset:3px}

/* ─── Story cards: uniform vertical cards ─────── */
.story-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.story-card{
  border:1px solid var(--line);
  background:var(--paper);
  display:flex;flex-direction:column;
}
.story-img{position:relative;aspect-ratio:16/9;overflow:hidden;flex:none}
.story-img img{width:100%;height:100%;object-fit:cover;filter:saturate(.92)}
.story-img .overlay-tag{position:absolute;top:9px;right:9px;margin:0;font-size:10.5px}
.story-body{padding:11px 13px 12px;flex:1;display:flex;flex-direction:column}
.story-body h3{
  font-family:var(--display);
  font-size:15.5px;font-weight:800;line-height:1.35;
  letter-spacing:-0.2px;
  color:var(--ink);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  min-height:2.7em;
  margin-bottom:6px;
}
.story-card:hover h3{text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:3px}
.story-body p{
  font-size:12.5px;color:var(--gray-7);line-height:1.55;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  margin-bottom:7px;
}
.story-body .meta{margin-top:auto}

/* ─── Category tiles with images ──────────────── */
.cat-tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.cat-tile{
  position:relative;display:block;overflow:hidden;
  height:124px;
  background:#111;
  border-bottom:3px solid var(--cat,var(--ink));
}
.cat-tile img{
  position:absolute;inset:0;
  width:100%;height:100%;object-fit:cover;
  filter:saturate(.8);
  transition:transform .25s;
}
.cat-tile:hover img{transform:scale(1.04)}
.cat-tile .tile-text{
  position:absolute;inset:0;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:12px 15px;
  background:linear-gradient(to top,rgba(8,8,10,.9) 0,rgba(8,8,10,.35) 60%,rgba(8,8,10,.12) 100%);
  color:#fff;
}
.cat-tile h3{font-family:var(--display);font-size:16.5px;font-weight:800;line-height:1.2}
.cat-tile p{font-size:11.5px;color:rgba(255,255,255,.78);line-height:1.45;margin-top:2px}

/* ─── Compact horizontal cards grid ───────────── */
.compact-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.compact-card{
  display:grid;grid-template-columns:100px 1fr;gap:12px;
  align-items:center;
  border:1px solid var(--line);
  background:var(--paper);
  padding:10px 12px;
}
.compact-card img{width:100px;height:70px;object-fit:cover;filter:saturate(.9)}
.compact-card .chip{margin-bottom:4px}
.compact-card h3{font-size:13.5px;font-weight:700;line-height:1.4;color:var(--ink)}
.compact-card:hover h3{text-decoration:underline;text-decoration-thickness:1.5px;text-underline-offset:2px}
.compact-card .meta{margin-top:4px;display:block}

/* ─── Thumb lists (rows with images) ──────────── */
.thumb-list li{border-bottom:1px solid #ececec}
.thumb-list li:last-child{border-bottom:none}
.thumb-list a{
  display:grid;grid-template-columns:82px 1fr;gap:11px;
  align-items:center;
  padding:9px 0;
}
.thumb-list li:first-child a{padding-top:0}
.thumb-list img{width:82px;height:56px;object-fit:cover;filter:saturate(.9)}
.thumb-list h4{font-size:13.5px;font-weight:700;line-height:1.4;color:var(--ink)}
.thumb-list a:hover h4{text-decoration:underline;text-decoration-thickness:1.5px;text-underline-offset:2px}
.thumb-list .meta{margin-top:2px;display:block}
.thumb-list .card-kicker{font-size:10.5px;margin-bottom:2px}

/* ranked thumb list (sidebar) */
.rank-list li{
  display:grid;grid-template-columns:18px 66px 1fr;gap:10px;
  align-items:center;
  padding:8px 0;
  border-bottom:1px solid #ececec;
}
.rank-list li:first-child{padding-top:0}
.rank-list li:last-child{border-bottom:none}
.rank-list .rank{
  font-family:var(--display);
  font-weight:900;font-size:20px;line-height:1;
  color:var(--accent);
  text-align:center;
  font-variant-numeric:tabular-nums;
}
.rank-list img{width:66px;height:46px;object-fit:cover;filter:saturate(.9)}
.rank-list h4{font-size:12.5px;font-weight:700;line-height:1.38;color:var(--ink)}
.rank-list a{display:contents}
.rank-list a:hover h4{text-decoration:underline;text-decoration-thickness:1.5px;text-underline-offset:2px}

/* legacy headline list (kept for docs/other) */
.headline-list li{padding:10px 0;border-bottom:1px solid #ececec}
.headline-list li:first-child{padding-top:0}
.headline-list h4{font-size:14.5px;font-weight:700;line-height:1.45;color:var(--ink)}
.headline-list a:hover h4{color:var(--accent)}
.headline-list .meta{margin-top:2px;display:block}

/* ─── Cards (legacy 3-col grid, category pages) ── */
.cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.card{border:1px solid var(--line);background:var(--paper);display:flex;flex-direction:column}
.card img{width:100%;aspect-ratio:16/9;object-fit:cover;filter:saturate(.92);flex:none}
.card .card-inner{padding:11px 13px 12px;flex:1;display:flex;flex-direction:column}
.card h3{
  font-family:var(--display);
  font-size:15.5px;font-weight:800;line-height:1.35;color:var(--ink);
  letter-spacing:-0.2px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  min-height:2.7em;
  margin-bottom:6px;
}
.card:hover h3{text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:3px}
.card p{
  font-size:12.5px;color:var(--gray-7);line-height:1.55;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  margin-bottom:7px;
}
.card .meta{margin-top:auto}

/* ─── Homepage grid ───────────────────────────── */
.home-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) 300px;
  gap:0 36px;
  align-items:start;
  padding:18px 0 0;
}

/* ─── Newsletter band ─────────────────────────── */
.newsletter-band{
  background:var(--navy);
  color:#fff;
  margin-top:34px;
  padding:24px 0;
}
.newsletter-band .container{
  display:flex;align-items:center;justify-content:space-between;gap:28px;flex-wrap:wrap;
}
.newsletter-band h2{font-family:var(--display);font-size:20px;font-weight:900}
.newsletter-band h2 .dot{color:#e0687a}
.newsletter-band p{font-size:13.5px;color:#c3cddd;margin-top:2px}
.newsletter-band form{display:flex;gap:10px;flex:1;max-width:440px}
.newsletter-band input{
  flex:1;
  border:1px solid rgba(255,255,255,.25);
  background:rgba(255,255,255,.08);
  color:#fff;
  padding:10px 14px;
  font-size:14px;
  outline:none;
}
.newsletter-band input::placeholder{color:#93a3c0}
.newsletter-band input:focus{border-color:#fff}
.newsletter-band button{
  background:#fff;color:var(--navy);
  font-weight:800;font-size:14px;
  padding:10px 24px;
  transition:all .12s;
}
.newsletter-band button:hover{background:var(--accent);color:#fff}

/* ─── Dual lists ──────────────────────────────── */
.dual-lists{display:grid;grid-template-columns:1fr 1fr;gap:0 44px}

/* ─── Category page ───────────────────────────── */
.breadcrumb{
  display:flex;align-items:center;gap:8px;
  font-size:12.5px;color:var(--gray-5);
  padding:12px 0 0;
}
.breadcrumb a:hover{color:var(--accent);text-decoration:underline}
.breadcrumb .sep{color:#ccc}

.category-head{
  border-bottom:1px solid var(--line);
  padding:10px 0 16px;
  margin-bottom:20px;
}
.category-head h1{
  font-family:var(--display);
  font-weight:900;
  font-size:32px;
  letter-spacing:-0.5px;
  line-height:1.15;
  margin-bottom:6px;
}
.category-head .cat-desc{font-size:15px;color:var(--gray-7);max-width:46em;line-height:1.6}
.subcats{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}

.page-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) 300px;
  gap:0 36px;
  align-items:start;
}
.sidebar{
  border-right:1px solid var(--line);
  padding-right:28px;
}

/* featured (horizontal) */
.feature-card{
  display:grid;grid-template-columns:1.15fr 1fr;gap:20px;
  padding-bottom:20px;margin-bottom:18px;
  border-bottom:1px solid var(--line);
}
.feature-card img{width:100%;aspect-ratio:16/9.5;object-fit:cover;filter:saturate(.92)}
.feature-card h2{
  font-family:var(--display);
  font-size:23px;font-weight:900;line-height:1.25;letter-spacing:-0.3px;
  margin:6px 0 8px;
}
.feature-card:hover h2{text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:3px}
.feature-card p{font-size:14.5px;color:var(--gray-7);line-height:1.6;margin-bottom:8px}

/* article list rows */
.article-row{
  display:grid;grid-template-columns:220px 1fr;gap:18px;
  padding:16px 0;
  border-bottom:1px solid var(--line);
}
.article-row:first-child{padding-top:0}
.article-row img{width:100%;aspect-ratio:16/10;object-fit:cover;filter:saturate(.92)}
.article-row h3{
  font-family:var(--display);
  font-size:17.5px;font-weight:800;line-height:1.32;letter-spacing:-0.2px;
  margin:4px 0 6px;
}
.article-row:hover h3{color:var(--accent)}
.article-row p{
  font-size:13.5px;color:var(--gray-7);line-height:1.55;margin-bottom:7px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}

/* pagination */
.pagination{
  display:flex;justify-content:center;align-items:center;gap:6px;
  padding:22px 0 4px;
}
.pagination a,.pagination span{
  min-width:34px;height:34px;
  display:flex;align-items:center;justify-content:center;
  border:1px solid var(--line);
  font-size:13px;font-weight:600;color:var(--ink-2);
  padding:0 10px;
  font-variant-numeric:tabular-nums;
  transition:all .12s;
}
.pagination a:hover{border-color:var(--ink);color:var(--ink)}
.pagination .current{background:var(--ink);border-color:var(--ink);color:#fff}
.pagination .dots{border:none;color:var(--gray-4)}

/* ─── Article page ────────────────────────────── */
.page{padding:20px 0 48px}
.article-title{
  font-family:var(--display);
  font-weight:900;
  font-size:clamp(27px, 3.4vw, 40px);
  line-height:1.16;
  letter-spacing:-0.6px;
  color:var(--ink);
  margin-bottom:12px;
  max-width:21em;
}
.article-subtitle{
  font-size:18.5px;
  line-height:1.55;
  color:var(--ink-2);
  font-weight:500;
  margin-bottom:16px;
  max-width:38em;
}
.article-kicker{margin-bottom:10px}

.article-meta{
  display:flex;align-items:center;flex-wrap:wrap;gap:6px 0;
  padding:12px 0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  font-size:13px;color:var(--gray-5);
  margin-bottom:16px;
}
.article-meta .byline{display:flex;align-items:center;gap:9px;color:var(--ink)}
.byline-avatar{
  width:30px;height:30px;border-radius:50%;
  background:var(--ink);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-weight:900;font-size:13px;
  flex-shrink:0;
}
.article-meta .byline a{font-weight:700;border-bottom:1px solid transparent}
.article-meta .byline a:hover{border-bottom-color:var(--ink)}
.article-meta .sep{margin:0 13px;color:#ccc}
.comments-link{
  display:inline-flex;align-items:center;gap:6px;
  color:var(--accent);font-weight:700;
}
.comments-link:hover{text-decoration:underline}
.share-row{margin-right:auto;display:flex;align-items:center;gap:8px}
.share-row .share-btn{
  width:32px;height:32px;
  display:flex;align-items:center;justify-content:center;
  border:1px solid var(--line);
  border-radius:50%;
  color:var(--gray-7);
  transition:all .12s;
}
.share-row .share-btn:hover{background:var(--ink);border-color:var(--ink);color:#fff}

.article-hero{margin-bottom:20px}
.article-hero img{width:100%;aspect-ratio:16/8.6;object-fit:cover}
.article-hero figcaption{
  display:flex;justify-content:space-between;gap:16px;
  font-size:12px;color:var(--gray-5);
  padding-top:8px;
  border-bottom:1px solid var(--line);
  padding-bottom:9px;
}
.article-hero .credit{color:var(--gray-4);flex-shrink:0}

.article-body{
  font-size:17.5px;
  line-height:1.78;
  color:#222222;
  max-width:680px;
}
.article-body p{margin-bottom:1.2em}
.article-body p.lead{font-weight:600;font-size:19px;color:var(--ink)}
.article-body h2{
  font-family:var(--display);
  font-weight:800;
  font-size:22px;
  line-height:1.3;
  color:var(--ink);
  letter-spacing:-0.2px;
  margin:1.5em 0 .55em;
  padding-top:.8em;
  border-top:1px solid var(--line);
  position:relative;
}
.article-body h2::before{
  content:"";
  position:absolute;
  top:-2px;right:0;
  width:36px;height:3px;
  background:var(--accent);
}
.article-body strong{font-weight:700;color:var(--ink)}
.article-body a{color:var(--accent-dark);text-decoration:underline;text-decoration-color:rgba(156,28,40,.35);text-underline-offset:3px}
.article-body a:hover{text-decoration-color:var(--accent-dark)}
.article-body ul.checklist{margin:0 0 1.4em}
.article-body ul.checklist li{
  position:relative;
  padding:0 22px .55em 0;
}
.article-body ul.checklist li::before{
  content:"";
  position:absolute;right:0;top:.62em;
  width:8px;height:8px;
  background:var(--accent);
}

.numbered-list{margin:0 0 1.4em;counter-reset:items}
.numbered-list li{
  position:relative;
  padding:0 44px 1em 0;
  margin-bottom:1em;
  border-bottom:1px solid #eee;
}
.numbered-list li:last-child{border-bottom:none;margin-bottom:0}
.numbered-list li::before{
  counter-increment:items;
  content:counter(items) ".";
  position:absolute;right:0;top:0;
  font-family:var(--display);
  font-weight:900;
  font-size:24px;
  line-height:1.3;
  color:var(--accent);
}

.pullquote{
  margin:1.8em 0;
  padding:6px 26px 6px 0;
  border-right:3px solid var(--ink);
  font-family:var(--serif);
  font-size:22px;
  line-height:1.62;
  font-weight:500;
  color:var(--ink);
}
.pullquote .qmark{color:var(--accent);font-family:var(--display);font-weight:900}
.pullquote footer{
  margin-top:10px;
  font-family:var(--sans);
  font-size:13px;font-weight:600;color:var(--gray-5);
}

.spec-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;
  margin:1.2em 0 1.5em;
}
.spec-item{border-top:2px solid var(--ink);padding-top:10px}
.spec-item h4{font-size:15px;font-weight:800;margin-bottom:3px;color:var(--ink)}
.spec-item p{font-size:13px;line-height:1.55;color:var(--gray-7);margin:0}

.info-note{
  background:var(--paper-2);
  border-right:3px solid var(--accent);
  padding:14px 18px;
  margin:0 0 1.4em;
  font-size:14.5px;
  line-height:1.65;
  color:var(--ink-2);
}
.info-note .note-label{
  display:block;
  font-weight:800;font-size:12.5px;color:var(--accent);
  letter-spacing:.4px;
  margin-bottom:3px;
}

.article-disclaimer{
  margin-top:2em;
  padding-top:1em;
  border-top:1px solid var(--line);
  font-size:12px;
  line-height:1.7;
  color:var(--gray-4);
}

.article-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px;max-width:680px}
.article-tags .label{font-size:13px;font-weight:700;color:var(--ink);margin-left:4px;align-self:center}

.author-card{
  margin-top:24px;
  border-top:2px solid var(--ink);
  padding-top:16px;
  display:flex;gap:16px;
  max-width:680px;
}
.author-card .byline-avatar{width:52px;height:52px;font-size:20px}
.author-card .kicker-sm{font-size:11.5px;font-weight:800;color:var(--accent);letter-spacing:.6px;margin-bottom:2px}
.author-card h4{font-size:16px;font-weight:800;color:var(--ink)}
.author-card p{font-size:13.5px;color:var(--gray-7);line-height:1.6;margin-top:4px;max-width:38em}

/* ─── Sidebar widgets ─────────────────────────── */
.widget{margin-bottom:24px}
.widget-title{
  font-size:15.5px;font-weight:800;color:var(--ink);
  border-top:3px solid var(--ink);
  padding-top:8px;
  margin-bottom:12px;
  display:flex;justify-content:space-between;align-items:baseline;
}
.widget-title a{font-size:12px;font-weight:600;color:var(--gray-5)}
.widget-title a:hover{color:var(--accent)}

.related-list .related-item{
  display:flex;gap:11px;
  padding:9px 0;
  border-bottom:1px solid #ececec;
}
.related-list .related-item:first-child{padding-top:0}
.related-list .related-item:last-child{border-bottom:none}
.related-item img{width:84px;height:58px;object-fit:cover;flex-shrink:0;filter:saturate(.9)}
.related-item h4{font-size:13px;font-weight:700;line-height:1.4;color:var(--ink)}
.related-item:hover h4{color:var(--accent)}
.related-item time{font-size:11px;color:var(--gray-4);display:block;margin-top:3px}

.newsletter{background:var(--paper-2);padding:16px;border:1px solid var(--line)}
.newsletter h3{font-size:15.5px;font-weight:800;margin-bottom:3px}
.newsletter h3 .dot{color:var(--accent)}
.newsletter p{font-size:12.5px;color:var(--gray-7);line-height:1.55;margin-bottom:12px}
.newsletter input{
  width:100%;
  border:1px solid #c9c9c9;
  padding:9px 12px;
  font-size:13px;
  margin-bottom:8px;
  background:#fff;
  outline:none;
}
.newsletter input:focus{border-color:var(--ink)}
.newsletter button{
  width:100%;
  background:var(--ink);color:#fff;
  font-weight:700;font-size:13.5px;
  padding:10px;
  transition:background .12s;
}
.newsletter button:hover{background:var(--accent)}
.newsletter small{display:block;margin-top:7px;font-size:11px;color:var(--gray-4)}

.cta-widget{
  position:relative;
  overflow:hidden;
  color:#fff;
  padding:18px;
  background:#111;
}
.cta-widget img{
  position:absolute;inset:0;
  width:100%;height:100%;object-fit:cover;
  filter:brightness(.4) saturate(.7);
}
.cta-widget > *{position:relative}
.cta-widget h3{font-size:16.5px;font-weight:800;margin-bottom:5px}
.cta-widget p{font-size:12.5px;color:#d5dbe6;line-height:1.6}
.cta-widget .cta-btn{
  display:block;
  background:#fff;color:var(--ink);
  font-weight:800;font-size:13.5px;text-align:center;
  padding:10px;margin-top:13px;
  transition:all .12s;
}
.cta-widget .cta-btn:hover{background:var(--accent);color:#fff}

.topics{display:flex;flex-wrap:wrap;gap:7px}

.more-section{margin-top:36px;border-top:3px solid var(--ink);padding-top:10px}
.more-section .section-head{border-top:none;padding-top:0}

/* ─── Doc pages ───────────────────────────────── */
.doc-page{max-width:760px;padding:28px 0 52px}
.doc-page h1{
  font-family:var(--display);
  font-weight:900;font-size:31px;letter-spacing:-0.4px;
  margin-bottom:5px;
}
.doc-page .doc-updated{font-size:13px;color:var(--gray-5);margin-bottom:22px}
.doc-body{font-size:16px;line-height:1.75;color:#222}
.doc-body h2{
  font-family:var(--display);
  font-size:19.5px;font-weight:800;
  margin:1.6em 0 .45em;
  padding-top:.75em;
  border-top:1px solid var(--line);
  position:relative;
}
.doc-body h2::before{
  content:"";
  position:absolute;top:-2px;right:0;
  width:30px;height:3px;
  background:var(--accent);
}
.doc-body p{margin-bottom:1em}
.doc-body ul{margin:0 0 1.1em}
.doc-body ul li{
  position:relative;
  padding:0 20px .4em 0;
}
.doc-body ul li::before{
  content:"";
  position:absolute;right:0;top:.65em;
  width:7px;height:7px;
  background:var(--accent);
}
.doc-body a{color:var(--accent-dark);text-decoration:underline;text-underline-offset:3px}
.doc-body .doc-table{width:100%;border-collapse:collapse;margin:0 0 1.3em;font-size:14px}
.doc-body .doc-table th{
  text-align:right;
  font-weight:800;
  border-bottom:2px solid var(--ink);
  padding:7px 10px;
}
.doc-body .doc-table td{border-bottom:1px solid var(--line);padding:7px 10px;vertical-align:top}

/* ─── Footer ──────────────────────────────────── */
.footer{
  background:#111;
  color:#9c9c9c;
  margin-top:44px;
  padding:38px 0 0;
  font-size:13px;
}
.footer-grid{
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:32px;
  padding-bottom:30px;
}
.footer .logotype{
  font-family:var(--display);
  font-size:23px;font-weight:900;color:#fff;letter-spacing:-0.4px;
  margin-bottom:8px;
  display:block;
}
.footer .logotype .dot{color:var(--accent)}
.footer .footer-domain{
  display:inline-block;
  font-size:12px;color:#8a8a8a;letter-spacing:.4px;
  margin-bottom:10px;
}
.footer p{line-height:1.7;font-size:12.5px;color:#8a8a8a;max-width:30em}
.footer h4{color:#fff;font-weight:700;font-size:13.5px;margin-bottom:10px}
.footer ul{display:flex;flex-direction:column;gap:7px}
.footer ul a{font-size:12.5px;transition:color .12s}
.footer ul a:hover{color:#fff}
.footer-bottom{border-top:1px solid #2a2a2a;padding:14px 0}
.footer-bottom .container{
  display:flex;justify-content:space-between;align-items:center;
  gap:8px;flex-wrap:wrap;
  font-size:11.5px;color:#777;
}
.footer-bottom .legal-links{display:flex;gap:16px}
.footer-bottom .legal-links a:hover{color:#fff}

/* ─── Cookie banner ───────────────────────────── */
.cookie-banner{
  position:fixed;
  bottom:0;right:0;left:0;
  z-index:400;
  background:var(--paper);
  border-top:3px solid var(--ink);
  box-shadow:0 -4px 24px rgba(0,0,0,.1);
  padding:14px 0;
  display:none;
}
.cookie-banner.visible{display:block}
.cookie-banner .container{
  display:flex;align-items:center;gap:24px;flex-wrap:wrap;
}
.cookie-banner .cookie-text{flex:1;min-width:280px}
.cookie-banner h3{font-size:14.5px;font-weight:800;margin-bottom:2px}
.cookie-banner p{font-size:12.5px;color:var(--gray-7);line-height:1.55}
.cookie-banner p a{color:var(--accent-dark);text-decoration:underline;text-underline-offset:2px}
.cookie-actions{display:flex;gap:10px;flex-shrink:0}
.cookie-actions .btn-accept{
  background:var(--ink);color:#fff;
  font-weight:700;font-size:13px;
  padding:9px 22px;
  transition:background .12s;
}
.cookie-actions .btn-accept:hover{background:var(--accent)}
.cookie-actions .btn-essential{
  background:none;color:var(--ink);
  border:1px solid var(--ink);
  font-weight:600;font-size:13px;
  padding:9px 16px;
  transition:all .12s;
}
.cookie-actions .btn-essential:hover{background:var(--paper-2)}

/* ─── Responsive ──────────────────────────────── */
@media (max-width:1020px){
  .home-grid,.page-grid{grid-template-columns:1fr}
  .sidebar{border-right:none;padding-right:0;margin-top:36px;
    display:grid;grid-template-columns:1fr 1fr;gap:0 28px;align-items:start}
  .navbar .container{overflow-x:auto}
  .article-body{max-width:none}
  .hero-main{height:340px}
}
@media (max-width:640px){
  .topbar-links{display:none}
  .navbar .container{scrollbar-width:none}
  .navbar .container::-webkit-scrollbar{display:none}
  .hero-mosaic{grid-template-columns:1fr}
  .hero-main{height:280px}
  .hero-main .overlay-text{padding:18px}
  .hero-side{grid-template-columns:1fr 1fr;grid-template-rows:1fr}
  .overlay-sm{height:150px}
  .overlay-sm h3{font-size:13.5px}
  .mini-row{grid-template-columns:1fr;gap:0}
  .story-grid{grid-template-columns:1fr}
  .story-body h3{min-height:0}
  .cat-tiles{grid-template-columns:1fr 1fr;gap:10px}
  .cat-tile{height:104px}
  .compact-grid{grid-template-columns:1fr}
  .dual-lists{grid-template-columns:1fr}
  .cards-grid{grid-template-columns:1fr}
  .card h3{min-height:0}
  .feature-card{grid-template-columns:1fr}
  .article-row{grid-template-columns:1fr}
  .sidebar{grid-template-columns:1fr}
  .spec-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .brand .logotype{font-size:26px}
  .btn-outline{display:none}
  .share-row{margin-right:0;width:100%;margin-top:8px}
  .newsletter-band .container{flex-direction:column;align-items:stretch}
  .newsletter-band form{max-width:none}
  .footer-bottom .container{flex-direction:column;align-items:flex-start}
}

/* ─── WP additions: ad slots, search, a11y ────── */
.skip-link{position:absolute;right:-9999px;top:0;background:var(--ink);color:#fff;padding:10px 18px;z-index:500;font-size:14px}
.skip-link:focus{right:0}
.ad-slot{margin:16px 0;text-align:center}
.ad-slot .ad-label{display:block;font-size:10px;color:var(--gray-4);letter-spacing:.6px;margin-bottom:4px}
.ad-slot:empty{display:none}
.nav-search{display:none;border-bottom:1px solid var(--line);background:var(--paper-2)}
.nav-search.open{display:block}
.nav-search .container{display:flex;gap:10px;padding-top:10px;padding-bottom:10px}
.nav-search input{flex:1;border:1px solid #c9c9c9;padding:9px 12px;font-size:14px;background:#fff;outline:none}
.nav-search input:focus{border-color:var(--ink)}
.nav-search button{background:var(--ink);color:#fff;font-weight:700;font-size:13.5px;padding:9px 22px}
.nav-search button:hover{background:var(--accent)}
.share-btn.copied{background:var(--accent);border-color:var(--accent);color:#fff}
.newsletter .nl-thanks,.newsletter-band .nl-thanks{display:none;font-weight:700;font-size:13.5px;color:#fff}
.newsletter .nl-thanks{color:var(--ink)}
.pagination .prev-next{padding:0 14px}
