/* ═══════════════════════════════════════════════════════
   CONCORDATO.IT — Stylesheet
   Editorial magazine for Italian concordato procedures
   ═══════════════════════════════════════════════════════ */

:root {
  --navy: #0C1B2E;
  --navy-80: #1E2D42;
  --navy-60: #344258;
  --ink: #1A1A2E;
  --gold: #B8932F;
  --gold-light: #D4AF5A;
  --gold-pale: #F5EDD4;
  --gold-bg: rgba(184,147,47,0.06);
  --cream: #FAFAF6;
  --cream-warm: #F5F3EB;
  --paper: #FFFFFF;
  --slate: #52596B;
  --slate-light: #7A8194;
  --border: rgba(12,27,46,0.08);
  --border-hover: rgba(12,27,46,0.15);
  --success: #1B7340;
  --red: #B42318;
  --font-display: 'Playfair Display', Georgia, serif;
  --font-body: 'Inter', -apple-system, sans-serif;
  --font-mono: 'JetBrains Mono', monospace;
  --max-w: 1200px;
  --article-w: 780px;
  --gutter: 24px;
  --radius: 12px;
}

/* ─── RESET ─── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-body);color:var(--ink);background:var(--cream);line-height:1.7;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ─── LAYOUT ─── */
.wrap{max-width:var(--max-w);margin:0 auto;padding:0 var(--gutter)}
.wrap-narrow{max-width:var(--article-w);margin:0 auto;padding:0 var(--gutter)}

/* ─── ANIMATIONS ─── */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.animate{opacity:0}
.animate.visible{animation:fadeUp .5s ease forwards}

/* ═══════════════════════════════════════════
   TOPBAR
   ═══════════════════════════════════════════ */
.topbar{
  background:var(--navy);color:rgba(255,255,255,.5);
  font-size:12px;padding:7px 0;text-align:center;letter-spacing:.3px;
}
.topbar a{color:var(--gold-light);font-weight:500}
.topbar strong{color:rgba(255,255,255,.8)}

/* ═══════════════════════════════════════════
   NAV
   ═══════════════════════════════════════════ */
.nav{
  position:sticky;top:0;z-index:100;
  background:rgba(255,255,255,.97);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);padding:0 var(--gutter);
}
.nav-inner{
  max-width:var(--max-w);margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;height:60px;
}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
.logo-icon{height:34px;width:34px;max-height:34px;max-width:34px;flex-shrink:0}
.logo-text{font-family:var(--font-display);font-size:24px;font-weight:700;color:var(--navy);letter-spacing:-.5px;white-space:nowrap}
.logo-text em{color:var(--gold);font-style:normal}
.nav-links{display:flex;gap:4px;align-items:center;flex-wrap:nowrap;overflow-x:auto}
.nav-links a{
  font-size:13px;font-weight:500;color:var(--slate);
  padding:7px 12px;border-radius:6px;transition:all .2s;white-space:nowrap;
}
.nav-links a:hover,.nav-links a.active{background:var(--gold-bg);color:var(--gold)}
.hamburger{display:none;background:none;border:none;cursor:pointer;padding:8px}
.hamburger span{display:block;width:20px;height:2px;background:var(--navy);margin:4px 0;border-radius:2px}
.mobile-menu{display:none;background:var(--paper);border-bottom:1px solid var(--border);padding:16px var(--gutter)}
.mobile-menu a{display:block;padding:10px 0;font-size:15px;color:var(--ink);border-bottom:1px solid var(--border)}
.mobile-menu.open{display:block}

/* ═══════════════════════════════════════════
   AD UNITS — Posizionamenti AdSense
   ═══════════════════════════════════════════ */

/* Base ad unit wrapper */
.ad-unit{
  margin:20px auto;overflow:hidden;text-align:center;
  min-height:50px;
}

/* Responsive top banner */
.ad-responsive-top{margin:16px auto 20px;max-width:728px}

/* Leaderboard 728x90 */
.ad-leaderboard{max-width:728px;margin:20px auto}

/* In-article (fluid, native-looking) */
.ad-in-article{margin:32px 0;padding:16px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}

/* After TOC */
.ad-after-toc{margin:20px 0 32px}

/* Sidebar ads */
.ad-sidebar-box{margin-bottom:20px;min-height:250px}
.ad-sticky{position:sticky;top:76px}

/* Multiplex (recommended content grid) */
.ad-multiplex{margin:32px auto;max-width:var(--max-w);padding:0 var(--gutter)}

/* Bottom banner */
.ad-bottom{max-width:var(--max-w);margin:0 auto}

/* In-feed (between article cards) */
.ad-card-unit{border-radius:var(--radius);min-height:200px}

/* Mobile: make all ads full width */
@media(max-width:728px){
  .ad-leaderboard,.ad-responsive-top{max-width:100%}
  .ad-sidebar-box{min-height:auto}
}

/* Hide ad label in production (uncomment for testing) */
/*
.ad-unit::before{
  content:'AD';display:block;font-size:9px;color:var(--slate-light);
  letter-spacing:1px;text-align:center;margin-bottom:4px;
}
*/
.ad-sticky{position:sticky;top:80px}

/* ═══════════════════════════════════════════
   HOMEPAGE — HERO
   ═══════════════════════════════════════════ */
.hero-ed{
  padding:56px 0 40px;border-bottom:1px solid var(--border);
  background:var(--navy);
  background-image:url('/assets/img/hero-bg.jpg');background-color:#0C1B2E;
  background-size:cover;background-position:center;
  color:white;
}
.hero-ed h1{color:white}
.hero-ed h1 em{color:var(--gold-light);font-style:normal}
.hero-ed .excerpt{color:rgba(255,255,255,.65)}
.hero-ed .cat-badge{color:var(--gold-light);border-color:rgba(201,168,76,.3)}
.hero-ed .read-cta{background:var(--gold);color:var(--navy)}
.hero-ed .read-cta:hover{background:var(--gold-light)}
.hero-ed-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:32px;align-items:start}
.hero-aside-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);backdrop-filter:blur(4px)}
.hero-aside-card:hover{background:rgba(255,255,255,.1);border-color:rgba(201,168,76,.3)}
.hero-aside-card h3{color:white}
.hero-aside-card p{color:rgba(255,255,255,.5)}
.hero-aside-card .card-cat{color:var(--gold-light)}
.hero-aside-card .card-meta{color:rgba(255,255,255,.35)}
.hero-main .cat-badge{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--font-mono);font-size:10px;text-transform:uppercase;
  letter-spacing:1.5px;color:var(--gold);font-weight:600;margin-bottom:14px;
}
.hero-main .cat-badge::before{content:'';width:24px;height:2px;background:var(--gold)}
.hero-main h1{font-family:var(--font-display);font-size:clamp(28px,3.5vw,44px);line-height:1.18;margin-bottom:14px;font-weight:700}
.hero-main h1 em{font-style:italic;color:var(--gold)}
.hero-main .excerpt{font-size:17px;color:var(--slate);line-height:1.7;margin-bottom:20px;text-align:justify}
.read-cta{
  display:inline-flex;align-items:center;gap:8px;
  font-size:14px;font-weight:600;color:var(--navy);
  padding:10px 24px;border:1px solid var(--border);border-radius:8px;transition:all .25s;
}
.read-cta:hover{background:var(--navy);color:white;border-color:var(--navy)}

/* Hero aside cards */
.hero-aside{display:flex;flex-direction:column;gap:14px}
.hero-aside-card{
  padding:18px 20px;border:1px solid var(--border);border-radius:var(--radius);
  background:var(--paper);transition:all .3s;cursor:pointer;
}
.hero-aside-card:hover{border-color:var(--gold);box-shadow:0 8px 24px rgba(0,0,0,.04)}
.hero-aside-card .card-cat{
  font-family:var(--font-mono);font-size:10px;text-transform:uppercase;
  letter-spacing:1.2px;color:var(--gold);margin-bottom:5px;font-weight:600;
}
.hero-aside-card h3{font-family:var(--font-display);font-size:17px;line-height:1.3;margin-bottom:5px}
.hero-aside-card p{font-size:13px;color:var(--slate-light);line-height:1.5}
.hero-aside-card .card-meta{font-size:11px;color:var(--slate-light);margin-top:6px;display:flex;gap:12px}

/* ═══════════════════════════════════════════
   SECTION HEADERS
   ═══════════════════════════════════════════ */
.sec-header{
  display:flex;align-items:baseline;justify-content:space-between;
  margin-bottom:28px;padding-bottom:14px;border-bottom:2px solid var(--navy);
}
.sec-header h2{font-family:var(--font-display);font-size:22px;font-weight:700}
.sec-header .see-all{font-size:13px;font-weight:600;color:var(--gold)}

/* ═══════════════════════════════════════════
   ARTICLE CARDS
   ═══════════════════════════════════════════ */
.articles-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-bottom:48px}
.article-card{
  background:var(--paper);border:1px solid var(--border);border-radius:var(--radius);
  overflow:hidden;transition:all .3s;
}
.article-card:hover{transform:translateY(-3px);box-shadow:0 12px 40px rgba(0,0,0,.06);border-color:var(--border-hover)}
.article-card a{display:block}
.card-img{height:155px;position:relative;overflow:hidden}
.card-img .tag{
  position:absolute;top:12px;left:12px;
  font-family:var(--font-mono);font-size:9px;text-transform:uppercase;
  letter-spacing:1.5px;padding:4px 10px;border-radius:4px;font-weight:600;
}
.tag-prev{background:rgba(12,27,46,.85);color:var(--gold-light)}
.tag-fisc{background:rgba(27,115,64,.85);color:#b8f0c8}
.tag-sempl{background:rgba(180,35,24,.85);color:#fcc}
.tag-minor{background:rgba(184,147,47,.85);color:#fff}
.tag-negoz{background:rgba(82,89,107,.85);color:#ddd}
.tag-sovra{background:rgba(139,105,20,.85);color:#ffe}
.tag-fiscalita{background:rgba(107,76,27,.85);color:#ffe}
.tag-norm{background:rgba(52,66,88,.85);color:#c8d8f0}
.card-body{padding:18px 20px}
.card-body h3{font-family:var(--font-display);font-size:16px;line-height:1.35;margin-bottom:8px;font-weight:600}
.card-body p{
  font-size:13px;color:var(--slate-light);line-height:1.55;margin-bottom:12px;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;
  text-align:justify;
}
.card-footer{display:flex;justify-content:space-between;align-items:center;font-size:11px;color:var(--slate-light)}

/* ═══════════════════════════════════════════
   MEGA SECTIONS
   ═══════════════════════════════════════════ */
.mega-section{padding:56px 0;border-top:1px solid var(--border)}
.mega-section:nth-child(even){background:var(--cream-warm)}
.mega-section .intro-text{font-size:15px;color:var(--slate);line-height:1.7;max-width:700px;margin-bottom:32px;text-align:justify}

/* ═══════════════════════════════════════════
   AFFILIATE COMPONENTS
   ═══════════════════════════════════════════ */
.affiliate-banner{
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy-80) 100%);
  border-radius:14px;padding:36px;margin:48px 0;
  display:grid;grid-template-columns:1fr auto;gap:32px;align-items:center;color:white;
}
.affiliate-banner h3{font-family:var(--font-display);font-size:22px;margin-bottom:8px}
.affiliate-banner p{font-size:14px;color:rgba(255,255,255,.6);line-height:1.6}
.aff-cta{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--gold);color:var(--navy);padding:14px 28px;
  border-radius:8px;font-size:15px;font-weight:600;white-space:nowrap;transition:all .25s;
}
.aff-cta:hover{background:var(--gold-light);transform:translateY(-2px)}

.affiliate-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:32px 0}
.aff-card{background:var(--paper);border:1px solid var(--border);border-radius:10px;padding:24px;transition:all .3s}
.aff-card:hover{border-color:var(--gold);box-shadow:0 8px 24px rgba(0,0,0,.04)}
.aff-card .aff-badge{
  font-family:var(--font-mono);font-size:9px;text-transform:uppercase;
  letter-spacing:1.5px;color:var(--gold);font-weight:600;margin-bottom:10px;display:block;
}
.aff-card h4{font-family:var(--font-display);font-size:17px;margin-bottom:6px}
.aff-card p{font-size:13px;color:var(--slate-light);line-height:1.5;margin-bottom:14px;text-align:justify}
.aff-card .aff-link{
  font-size:13px;font-weight:600;color:var(--navy);
  display:inline-flex;align-items:center;gap:4px;
  padding:8px 16px;border:1px solid var(--border);border-radius:6px;transition:all .2s;
}
.aff-card .aff-link:hover{background:var(--navy);color:white}

/* Inline affiliate box (in-article) */
.affiliate-inline{
  background:var(--gold-bg);border:1px solid rgba(184,147,47,.15);
  border-radius:var(--radius);padding:28px;margin:40px 0;
  display:flex;gap:24px;align-items:center;
}
.affiliate-inline .aff-icon{
  width:56px;height:56px;border-radius:10px;background:var(--paper);
  display:flex;align-items:center;justify-content:center;
  font-size:24px;flex-shrink:0;border:1px solid var(--border);
}
.affiliate-inline h4{font-size:15px;font-weight:600;margin-bottom:4px}
.affiliate-inline p{font-size:13px;color:var(--slate);line-height:1.5}
.affiliate-inline .aff-link{margin-top:8px}

/* ═══════════════════════════════════════════
   GUIDE INDEX
   ═══════════════════════════════════════════ */
.guide-index{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin:32px 0}
.guide-item{
  display:flex;gap:14px;align-items:start;padding:18px;
  background:var(--paper);border:1px solid var(--border);border-radius:10px;
  transition:all .3s;cursor:pointer;
}
.guide-item:hover{border-color:var(--gold);box-shadow:0 4px 16px rgba(0,0,0,.04)}
.guide-num{font-family:var(--font-display);font-size:28px;color:rgba(12,27,46,.08);line-height:1;min-width:36px}
.guide-item h4{font-size:14px;font-weight:600;margin-bottom:3px;line-height:1.35}
.guide-item p{font-size:12px;color:var(--slate-light);line-height:1.4}
.guide-item .g-meta{font-size:11px;color:var(--slate-light);margin-top:5px}

/* ═══════════════════════════════════════════
   ARTICLE PAGE — LAYOUT
   ═══════════════════════════════════════════ */
.article-header{
  padding:48px 0 36px;border-bottom:1px solid var(--border);
  background:var(--navy);color:white;
  background-size:cover;background-position:center;
}
.article-header .cat-link{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--font-mono);font-size:10px;text-transform:uppercase;
  letter-spacing:1.5px;color:var(--gold-light);font-weight:600;margin-bottom:16px;
}
.article-header h1{
  font-family:var(--font-display);font-size:clamp(28px,3.5vw,42px);
  line-height:1.18;margin-bottom:16px;font-weight:700;max-width:var(--article-w);
  color:white;
}
.article-header .breadcrumbs,.article-header .breadcrumbs a{color:rgba(255,255,255,.5)}
.article-header .breadcrumbs a:hover{color:var(--gold-light)}
.article-meta{
  display:flex;gap:20px;font-size:13px;color:rgba(255,255,255,.5);flex-wrap:wrap;
}
.article-meta span{display:flex;align-items:center;gap:5px}

/* Article body with sidebar */
.article-layout{
  display:grid;grid-template-columns:1fr 300px;gap:48px;
  padding:48px 0;align-items:start;
}

/* ═══════════════════════════════════════════
   ARTICLE BODY — PROSE
   ═══════════════════════════════════════════ */
.article-body{max-width:var(--article-w)}
.article-body p{
  font-size:17px;line-height:1.85;margin-bottom:24px;
  text-align:justify;text-justify:inter-word;
  color:var(--ink);hyphens:auto;-webkit-hyphens:auto;
}
.article-body h2{
  font-family:var(--font-display);font-size:28px;font-weight:700;
  margin:52px 0 20px;padding-top:32px;border-top:1px solid var(--border);
  line-height:1.25;
}
.article-body h2:first-of-type{border-top:none;padding-top:0;margin-top:0}
.article-body h3{
  font-family:var(--font-display);font-size:22px;font-weight:600;
  margin:40px 0 16px;line-height:1.3;
}
.article-body h4{
  font-size:18px;font-weight:600;margin:32px 0 12px;line-height:1.35;
}
.article-body ul,.article-body ol{
  margin:0 0 24px 24px;font-size:17px;line-height:1.85;color:var(--ink);
}
.article-body li{margin-bottom:10px;text-align:justify}
.article-body blockquote{
  border-left:3px solid var(--gold);margin:32px 0;padding:20px 28px;
  background:var(--gold-bg);border-radius:0 var(--radius) var(--radius) 0;
  font-size:17px;line-height:1.75;color:var(--slate);font-style:italic;
}
.article-body blockquote p{margin-bottom:0;text-align:justify}
.article-body strong{font-weight:600;color:var(--navy)}
.article-body a{color:var(--gold);text-decoration:underline;text-underline-offset:3px}
.article-body a:hover{color:var(--navy)}

/* Tables */
.article-body table{
  width:100%;border-collapse:collapse;margin:32px 0;font-size:15px;
}
.article-body thead{background:var(--navy);color:white}
.article-body th{padding:12px 16px;text-align:left;font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.5px}
.article-body td{padding:12px 16px;border-bottom:1px solid var(--border)}
.article-body tbody tr:nth-child(even){background:var(--cream)}
.article-body tbody tr:hover{background:var(--gold-bg)}

/* Info boxes */
.info-box{
  border-radius:var(--radius);padding:24px 28px;margin:32px 0;
  font-size:15px;line-height:1.7;
}
.info-box p{font-size:15px;margin-bottom:0;text-align:justify}
.info-box.tip{background:rgba(27,115,64,.06);border:1px solid rgba(27,115,64,.15);color:#145530}
.info-box.warning{background:rgba(180,35,24,.06);border:1px solid rgba(180,35,24,.15);color:#8B1A12}
.info-box.note{background:rgba(12,27,46,.04);border:1px solid rgba(12,27,46,.1);color:var(--slate)}
.info-box.highlight{background:var(--gold-bg);border:1px solid rgba(184,147,47,.15);color:#6B4C1B}
.info-box-title{font-weight:600;margin-bottom:6px;font-size:14px;text-transform:uppercase;letter-spacing:.5px}

/* TOC */
.toc{
  background:var(--paper);border:1px solid var(--border);border-radius:var(--radius);
  padding:28px;margin:0 0 40px;
}
.toc h3{font-family:var(--font-display);font-size:18px;margin-bottom:14px;padding-bottom:10px;border-bottom:2px solid var(--gold)}
.toc ol{margin:0;padding-left:20px;counter-reset:toc}
.toc li{padding:8px 0;border-bottom:1px solid var(--border);font-size:15px;counter-increment:toc}
.toc li:last-child{border-bottom:none}
.toc li a{color:var(--ink);transition:color .2s}
.toc li a:hover{color:var(--gold)}

/* ═══════════════════════════════════════════
   SIDEBAR
   ═══════════════════════════════════════════ */
.sidebar{display:flex;flex-direction:column;gap:24px}
.sidebar-box{
  background:var(--paper);border:1px solid var(--border);
  border-radius:var(--radius);padding:22px;
}
.sidebar-box h4{
  font-family:var(--font-display);font-size:16px;margin-bottom:12px;
  padding-bottom:10px;border-bottom:2px solid var(--gold);
}
.sidebar-box ul{list-style:none}
.sidebar-box li{padding:9px 0;border-bottom:1px solid var(--border);font-size:14px}
.sidebar-box li:last-child{border-bottom:none}
.sidebar-box li a{display:flex;justify-content:space-between;align-items:center;transition:color .2s}
.sidebar-box li a:hover{color:var(--gold)}
.sidebar-box li .arrow{color:var(--slate-light);font-size:12px}

/* ═══════════════════════════════════════════
   FAQ
   ═══════════════════════════════════════════ */
.faq-section{padding:56px 0;background:var(--cream-warm)}
.faq-list{max-width:800px}
.faq-item{border-bottom:1px solid var(--border)}
.faq-q{
  width:100%;padding:18px 0;background:none;border:none;cursor:pointer;
  font-family:var(--font-body);font-size:16px;font-weight:600;color:var(--ink);
  text-align:left;display:flex;justify-content:space-between;align-items:center;
}
.faq-q::after{content:'+';font-size:20px;font-weight:300;color:var(--gold);min-width:20px;text-align:center}
.faq-item.open .faq-q::after{content:'−'}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-item.open .faq-a{max-height:500px;padding-bottom:18px}
.faq-a p{color:var(--slate);font-size:15px;line-height:1.7;text-align:justify}

/* ═══════════════════════════════════════════
   NEWSLETTER
   ═══════════════════════════════════════════ */
.newsletter{background:var(--navy);padding:60px 0;text-align:center;color:white}
.newsletter h2{font-family:var(--font-display);font-size:clamp(24px,3vw,32px);margin-bottom:10px}
.newsletter p{color:rgba(255,255,255,.5);font-size:15px;margin-bottom:24px}
.nl-form{display:flex;gap:10px;max-width:480px;margin:0 auto}
.nl-form input{
  flex:1;padding:14px 18px;border:1px solid rgba(255,255,255,.15);border-radius:8px;
  background:rgba(255,255,255,.05);color:white;font-size:15px;
  font-family:var(--font-body);outline:none;
}
.nl-form input::placeholder{color:rgba(255,255,255,.3)}
.nl-form input:focus{border-color:var(--gold)}
.nl-form button{
  padding:14px 28px;background:var(--gold);color:var(--navy);border:none;
  border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .25s;white-space:nowrap;
}
.nl-form button:hover{background:var(--gold-light)}

/* ═══════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════ */
.footer{background:var(--navy);border-top:1px solid rgba(255,255,255,.05);padding:56px 0 28px;color:rgba(255,255,255,.4)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr;gap:28px;margin-bottom:40px}
.footer h5{color:white;font-size:11px;text-transform:uppercase;letter-spacing:1.5px;font-weight:600;margin-bottom:12px}
.footer ul{list-style:none}
.footer li{margin-bottom:7px}
.footer a{color:rgba(255,255,255,.4);font-size:13px;transition:color .2s}
.footer a:hover{color:var(--gold-light)}
.footer-brand p{font-size:13px;line-height:1.6;margin-top:10px}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.06);padding-top:20px;
  display:flex;justify-content:space-between;font-size:12px;flex-wrap:wrap;gap:10px;
}

/* ═══════════════════════════════════════════
   BREADCRUMBS
   ═══════════════════════════════════════════ */
.breadcrumbs{
  font-size:13px;color:var(--slate-light);margin-bottom:16px;
}
.breadcrumbs a{color:var(--slate);transition:color .2s}
.breadcrumbs a:hover{color:var(--gold)}
.breadcrumbs span{margin:0 6px;opacity:.5}

/* ═══════════════════════════════════════════
   RELATED ARTICLES
   ═══════════════════════════════════════════ */
.related{padding:48px 0;border-top:1px solid var(--border);background:var(--cream-warm)}
.related h2{font-family:var(--font-display);font-size:22px;margin-bottom:28px}

/* ═══════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════ */
@media(max-width:960px){
  .hero-ed-grid{grid-template-columns:1fr}
  .hero-aside{flex-direction:row;overflow-x:auto;gap:12px;padding-bottom:8px;-webkit-overflow-scrolling:touch}
  .hero-aside-card{min-width:280px;flex-shrink:0}
  .articles-grid{grid-template-columns:repeat(2,1fr)}
  .article-layout{grid-template-columns:1fr}
  .sidebar{flex-direction:row;overflow-x:auto;gap:16px;-webkit-overflow-scrolling:touch}
  .sidebar-box{min-width:280px;flex-shrink:0}
  .affiliate-banner{grid-template-columns:1fr;text-align:center}
  .affiliate-strip{grid-template-columns:1fr 1fr}
  .affiliate-inline{flex-direction:column;text-align:center}
  .guide-index{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .nav-links{display:none}
  .hamburger{display:block}
  .logo-icon{height:28px;width:28px;max-height:28px;max-width:28px}
  .logo-text{font-size:20px}
}
@media(max-width:600px){
  .articles-grid{grid-template-columns:1fr}
  .affiliate-strip{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .nl-form{flex-direction:column}
  .article-body p,.article-body li{font-size:16px;line-height:1.8}
  .article-body h2{font-size:24px}
  .article-body h3{font-size:20px}
}

/* ═══════════════════════════════════════════
   ARTICLE IMAGES
   ═══════════════════════════════════════════ */
.article-img{
  margin:32px 0;border-radius:var(--radius);overflow:hidden;
  box-shadow:0 4px 20px rgba(0,0,0,.08);
}
.article-img img{
  width:100%;height:auto;display:block;
  transition:transform .3s ease;
}
.article-img:hover img{transform:scale(1.02)}
.article-img figcaption{
  padding:10px 16px;font-size:13px;color:var(--slate-light);
  background:var(--cream-warm);font-style:italic;text-align:center;
}

/* Card image with photo */
.card-img{
  position:relative;overflow:hidden;
}
.card-img::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to bottom,transparent 40%,rgba(0,0,0,.4) 100%);
}
