/* ── Reset & Base ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;color:#1a1a2e;line-height:1.6;background:#fff}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* ── Colors ── */
:root{
  --indigo:79 70 229;    /* indigo-600 */
  --violet:124 58 237;   /* violet-600 */
  --purple:147 51 234;   /* purple-600 */
  --gray-50:#f8fafc;
  --gray-100:#f1f5f9;
  --gray-200:#e2e8f0;
  --gray-400:#94a3b8;
  --gray-500:#64748b;
  --gray-600:#475569;
  --gray-700:#334155;
  --gray-800:#1e293b;
  --gray-900:#0f172a;
}

/* ── Layout ── */
.container{max-width:1120px;margin:0 auto;padding:0 24px}
.section{padding:96px 0}
.section-sm{padding:64px 0}

/* ── Typography ── */
h1{font-size:clamp(2.25rem,5vw,3.5rem);font-weight:800;line-height:1.1;letter-spacing:-0.02em}
h2{font-size:clamp(1.75rem,3.5vw,2.5rem);font-weight:700;line-height:1.2;letter-spacing:-0.01em}
h3{font-size:1.25rem;font-weight:600;line-height:1.3}
.text-muted{color:var(--gray-500)}
.text-sm{font-size:0.875rem}
.text-xs{font-size:0.75rem}
.text-center{text-align:center}
.max-w-2xl{max-width:42rem;margin-left:auto;margin-right:auto}
.max-w-3xl{max-width:48rem;margin-left:auto;margin-right:auto}

/* ── Gradient Text ── */
.gradient-text{
  background:linear-gradient(135deg,rgb(var(--indigo)),rgb(var(--violet)),rgb(var(--purple)));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}

/* ── Buttons ── */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:12px 28px;border-radius:8px;font-weight:600;font-size:0.9375rem;
  transition:all 0.2s;cursor:pointer;border:none;
}
.btn-primary{
  background:linear-gradient(135deg,rgb(var(--indigo)),rgb(var(--violet)));
  color:#fff;box-shadow:0 4px 14px rgba(var(--indigo),0.3);
}
.btn-primary:hover{box-shadow:0 6px 20px rgba(var(--indigo),0.4);transform:translateY(-1px)}
.btn-outline{
  background:transparent;color:rgb(var(--indigo));
  border:1.5px solid rgb(var(--indigo));
}
.btn-outline:hover{background:rgba(var(--indigo),0.05)}

/* ── Navigation ── */
.nav{
  position:fixed;top:12px;left:50%;transform:translateX(-50%);z-index:50;
  width:calc(100% - 32px);max-width:1080px;
  background:rgba(255,255,255,0.82);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border:1px solid rgba(0,0,0,0.06);
  border-radius:16px;
  box-shadow:0 4px 24px rgba(0,0,0,0.06),0 1px 3px rgba(0,0,0,0.04);
  transition:transform 0.35s cubic-bezier(0.4,0,0.2,1),opacity 0.35s ease;
}
.nav.nav-hidden{
  transform:translateX(-50%) translateY(-120%);
  opacity:0;pointer-events:none;
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:56px;padding:0 20px;
}
.nav-logo{display:flex;align-items:center;gap:10px;font-weight:700;font-size:1.125rem}
.nav-logo svg{width:32px;height:32px}
.nav-menu{display:flex;align-items:center;gap:0;flex:1;justify-content:flex-end}
.nav-links{display:flex;align-items:center;gap:28px;list-style:none}
.nav-links a{font-size:0.875rem;color:var(--gray-600);transition:color 0.15s;white-space:nowrap}
.nav-links a:hover{color:rgb(var(--indigo))}
.nav-cta{margin-left:24px;flex-shrink:0}

/* Mobile nav */
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px;width:40px;height:40px;position:relative;z-index:60}
.nav-toggle span{
  display:block;width:20px;height:2px;background:var(--gray-700);
  position:absolute;left:10px;
  transition:transform 0.35s cubic-bezier(0.4,0,0.2,1),opacity 0.25s ease,top 0.35s cubic-bezier(0.4,0,0.2,1);
}
.nav-toggle span:nth-child(1){top:12px}
.nav-toggle span:nth-child(2){top:19px}
.nav-toggle span:nth-child(3){top:26px}
.nav-toggle.active span:nth-child(1){top:19px;transform:rotate(45deg)}
.nav-toggle.active span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-toggle.active span:nth-child(3){top:19px;transform:rotate(-45deg)}

/* Mobile overlay */
.nav-overlay{
  display:none;position:fixed;inset:0;z-index:45;
  background:rgba(255,255,255,0.96);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  flex-direction:column;align-items:center;justify-content:center;gap:0;
  opacity:0;transition:opacity 0.35s ease;
}
.nav-overlay.open{display:flex;opacity:1}
.nav-overlay .nav-overlay-links{
  list-style:none;text-align:center;display:flex;flex-direction:column;gap:8px;
}
.nav-overlay .nav-overlay-links li{
  opacity:0;transform:translateY(16px);
  transition:opacity 0.3s ease,transform 0.3s cubic-bezier(0.16,1,0.3,1);
}
.nav-overlay.open .nav-overlay-links li{opacity:1;transform:translateY(0)}
.nav-overlay.open .nav-overlay-links li:nth-child(1){transition-delay:0.08s}
.nav-overlay.open .nav-overlay-links li:nth-child(2){transition-delay:0.14s}
.nav-overlay.open .nav-overlay-links li:nth-child(3){transition-delay:0.20s}
.nav-overlay.open .nav-overlay-links li:nth-child(4){transition-delay:0.26s}
.nav-overlay .nav-overlay-links a{
  font-size:1.5rem;font-weight:600;color:var(--gray-800);
  padding:12px 24px;display:block;border-radius:12px;
  transition:color 0.15s,background 0.15s;
}
.nav-overlay .nav-overlay-links a:hover{color:rgb(var(--indigo));background:rgba(var(--indigo),0.05)}
.nav-overlay .nav-overlay-cta{
  margin-top:32px;opacity:0;transform:translateY(16px);
  transition:opacity 0.3s ease 0.26s,transform 0.3s cubic-bezier(0.16,1,0.3,1) 0.26s;
}
.nav-overlay.open .nav-overlay-cta{opacity:1;transform:translateY(0)}

@media(max-width:768px){
  .nav{width:calc(100% - 24px);top:8px;border-radius:14px}
  .nav-inner{height:52px;padding:0 16px}
  .nav-toggle{display:block}
  .nav-menu{display:none}
}

/* Page transition (on wrapper, not body — to preserve position:fixed nav) */
.page-content{transition:opacity 0.35s ease,transform 0.35s cubic-bezier(0.16,1,0.3,1)}
.page-content.page-enter{opacity:0;transform:translateY(12px)}
.page-content.page-exit{opacity:0;transform:translateY(-8px)}

/* ── Hero ── */
.hero{
  padding:150px 0 96px;
  background:linear-gradient(180deg,rgba(var(--indigo),0.03) 0%,#fff 100%);
}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.hero-badge{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 14px;border-radius:999px;font-size:0.8125rem;font-weight:500;
  background:rgba(var(--indigo),0.08);color:rgb(var(--indigo));
  margin-bottom:20px;
}
.hero-title{margin-bottom:20px}
.hero-desc{font-size:1.125rem;color:var(--gray-500);line-height:1.7;margin-bottom:32px}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap}
.hero-visual{
  position:relative;
  background:linear-gradient(135deg,rgb(var(--indigo)),rgb(var(--violet)),rgb(var(--purple)));
  border-radius:16px;padding:48px 32px;color:#fff;
  box-shadow:0 24px 48px rgba(var(--indigo),0.2);
}
.hero-visual-step{display:flex;align-items:start;gap:16px;margin-bottom:24px}
.hero-visual-step:last-child{margin-bottom:0}
.hero-visual-icon{
  width:40px;height:40px;border-radius:10px;
  background:rgba(255,255,255,0.15);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.hero-visual-icon svg{width:20px;height:20px}
@media(max-width:768px){
  .hero{padding:80px 0 64px}
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .hero-visual{display:none}
}

/* ── Features Grid ── */
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-top:56px}
.feature-card{
  padding:32px;border-radius:12px;border:1px solid var(--gray-200);
  transition:all 0.2s;background:#fff;
}
.feature-card:hover{border-color:rgba(var(--indigo),0.3);box-shadow:0 8px 24px rgba(var(--indigo),0.08)}
.feature-icon{
  width:48px;height:48px;border-radius:12px;margin-bottom:16px;
  background:linear-gradient(135deg,rgba(var(--indigo),0.1),rgba(var(--violet),0.1));
  display:flex;align-items:center;justify-content:center;
  color:rgb(var(--indigo));
}
.feature-card h3{margin-bottom:8px}
.feature-card p{color:var(--gray-500);font-size:0.9375rem;line-height:1.6}
@media(max-width:768px){.features-grid{grid-template-columns:1fr;gap:20px}}

/* ── How it works ── */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;margin-top:56px}
.step{text-align:center;position:relative}
.step-number{
  width:56px;height:56px;border-radius:50%;
  background:linear-gradient(135deg,rgb(var(--indigo)),rgb(var(--violet)));
  color:#fff;font-weight:700;font-size:1.25rem;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 16px;
}
.step h3{margin-bottom:8px}
.step p{color:var(--gray-500);font-size:0.875rem}
@media(max-width:768px){.steps{grid-template-columns:1fr 1fr;gap:24px}}
@media(max-width:480px){.steps{grid-template-columns:1fr}}

/* ── Pricing ── */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:56px}
.price-card{
  padding:32px;border-radius:12px;border:1px solid var(--gray-200);
  display:flex;flex-direction:column;background:#fff;
}
.price-card.featured{
  border:2px solid rgb(var(--indigo));position:relative;
  box-shadow:0 8px 32px rgba(var(--indigo),0.12);
}
.price-badge{
  position:absolute;top:-12px;left:24px;
  background:rgb(var(--indigo));color:#fff;
  font-size:0.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:0.05em;
  padding:4px 12px;border-radius:999px;
}
.price-amount{font-size:2rem;font-weight:800;margin:12px 0 4px}
.price-amount span{font-size:0.875rem;font-weight:400;color:var(--gray-500)}
.price-desc{color:var(--gray-500);font-size:0.8125rem;margin-bottom:24px}
.price-list{list-style:none;flex:1;margin-bottom:24px}
.price-list li{
  display:flex;align-items:start;gap:10px;
  padding:6px 0;font-size:0.9375rem;color:var(--gray-700);
}
.price-list li svg{width:18px;height:18px;color:rgb(34 197 94);flex-shrink:0;margin-top:2px}
@media(max-width:768px){.pricing-grid{grid-template-columns:1fr;max-width:400px;margin-left:auto;margin-right:auto}}

/* ── CTA Section ── */
.cta-section{
  background:linear-gradient(135deg,rgb(var(--indigo)),rgb(var(--violet)),rgb(var(--purple)));
  color:#fff;text-align:center;border-radius:16px;padding:72px 48px;
}
.cta-section h2{color:#fff;margin-bottom:16px}
.cta-section p{color:rgba(255,255,255,0.8);margin-bottom:32px;font-size:1.0625rem}
.btn-white{background:#fff;color:rgb(var(--indigo));font-weight:600}
.btn-white:hover{box-shadow:0 6px 20px rgba(0,0,0,0.15);transform:translateY(-1px)}

/* ── Footer ── */
.footer{
  background:var(--gray-900);color:var(--gray-400);
  padding:64px 0 32px;
}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
.footer-brand p{margin-top:12px;font-size:0.875rem;line-height:1.7;max-width:280px}
.footer h4{color:#fff;font-size:0.875rem;font-weight:600;text-transform:uppercase;letter-spacing:0.05em;margin-bottom:16px}
.footer-links{list-style:none}
.footer-links li{margin-bottom:10px}
.footer-links a{font-size:0.875rem;transition:color 0.15s}
.footer-links a:hover{color:#fff}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,0.1);
  padding-top:24px;display:flex;justify-content:space-between;
  font-size:0.8125rem;
}
@media(max-width:768px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .footer-bottom{flex-direction:column;gap:8px}
}
@media(max-width:480px){.footer-grid{grid-template-columns:1fr}}

/* ── Contact ── */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;margin-top:56px}
.contact-info-card{
  padding:24px;border-radius:12px;border:1px solid var(--gray-200);
  margin-bottom:16px;display:flex;align-items:start;gap:16px;
}
.contact-info-icon{
  width:40px;height:40px;border-radius:10px;flex-shrink:0;
  background:rgba(var(--indigo),0.08);color:rgb(var(--indigo));
  display:flex;align-items:center;justify-content:center;
}
.contact-form label{display:block;font-size:0.875rem;font-weight:500;margin-bottom:6px;color:var(--gray-700)}
.contact-form input,.contact-form textarea,.contact-form select{
  width:100%;padding:10px 14px;border:1px solid var(--gray-200);border-radius:8px;
  font-size:0.9375rem;font-family:inherit;transition:border-color 0.15s;
  background:#fff;
}
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{
  outline:none;border-color:rgb(var(--indigo));box-shadow:0 0 0 3px rgba(var(--indigo),0.1);
}
.contact-form textarea{min-height:120px;resize:vertical}
.form-group{margin-bottom:20px}
@media(max-width:768px){.contact-grid{grid-template-columns:1fr}}

/* ── Screenshot Showcase ── */
.showcase{padding:96px 0}
.showcase-header{text-align:center;margin-bottom:64px}
.showcase-header p{color:var(--gray-500);margin-top:8px}

.showcase-item{
  display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;
  margin-bottom:80px;
}
.showcase-item:last-child{margin-bottom:0}
.showcase-item.reverse{direction:rtl}
.showcase-item.reverse>*{direction:ltr}

.showcase-text{max-width:480px}
.showcase-text .showcase-label{
  display:inline-flex;align-items:center;gap:6px;
  font-size:0.75rem;font-weight:600;text-transform:uppercase;letter-spacing:0.06em;
  color:rgb(var(--indigo));margin-bottom:12px;
}
.showcase-text h3{font-size:1.5rem;font-weight:700;margin-bottom:12px;line-height:1.3}
.showcase-text p{color:var(--gray-500);font-size:0.9375rem;line-height:1.7}
.showcase-text ul{list-style:none;margin-top:16px}
.showcase-text ul li{
  display:flex;align-items:start;gap:10px;
  padding:5px 0;font-size:0.9375rem;color:var(--gray-600);
}
.showcase-text ul li svg{width:18px;height:18px;color:rgb(var(--indigo));flex-shrink:0;margin-top:2px}

.showcase-img{
  position:relative;border-radius:12px;overflow:hidden;
  box-shadow:0 20px 60px rgba(0,0,0,0.12),0 0 0 1px rgba(0,0,0,0.05);
  transform:scale(0.92) translateY(30px);
  opacity:0;
  transition:transform 0.7s cubic-bezier(0.16,1,0.3,1),opacity 0.7s ease;
}
.showcase-img.in-view{
  transform:scale(1) translateY(0);
  opacity:1;
}
.showcase-img img{
  width:100%;height:auto;display:block;
  background:var(--gray-100);
}
.showcase-img .placeholder{
  width:100%;aspect-ratio:16/10;
  background:linear-gradient(135deg,var(--gray-100),var(--gray-200));
  display:flex;align-items:center;justify-content:center;
  color:var(--gray-400);font-size:0.875rem;font-weight:500;
}

/* Hero screenshot — tablet emerging from behind the next section */
.hero-screenshot{
  position:relative;
  z-index:1;
  margin-top:64px;
  margin-bottom:-220px;          /* deep overlap into next section */
  border-radius:20px;
  overflow:visible;
  /* initial state — hidden, pushed down, will be animated via JS scroll */
  transform:perspective(1200px) rotateX(6deg) scale(0.92) translateY(160px);
  opacity:0;
  transition:opacity 0.6s ease;
}
.hero-screenshot.in-view{
  opacity:1;
}
.hero-screenshot img{
  width:100%;height:auto;display:block;
  border-radius:20px;
  background:var(--gray-100);
  box-shadow:
    0 4px 24px rgba(0,0,0,0.10),
    0 20px 60px rgba(var(--indigo),0.12),
    0 40px 100px rgba(var(--indigo),0.08),
    0 0 0 1px rgba(0,0,0,0.06);
  transform:scale(1.04);
  transition:transform 5s cubic-bezier(0.16,1,0.3,1),box-shadow 1s ease;
}
.hero-screenshot.in-view img{
  transform:scale(1);
}
.hero-screenshot .placeholder{
  width:100%;aspect-ratio:16/9;
  background:linear-gradient(135deg,rgba(var(--indigo),0.05),rgba(var(--violet),0.08));
  display:flex;align-items:center;justify-content:center;
  color:var(--gray-400);font-size:0.9375rem;font-weight:500;
}

/* Next section sits ON TOP of the hero screenshot */
.hero + .section,
.hero + .section.bg-light{
  position:relative;
  z-index:2;
  padding-top:120px;             /* spacing from section edge to "Warum Noutdated" */
}

/* Scroll-triggered fade-in for general elements */
.scroll-fade{
  opacity:0;transform:translateY(24px);
  transition:opacity 0.6s ease,transform 0.6s cubic-bezier(0.16,1,0.3,1);
}
.scroll-fade.in-view{opacity:1;transform:translateY(0)}

@media(max-width:768px){
  .showcase-item,.showcase-item.reverse{grid-template-columns:1fr;gap:32px;direction:ltr}
  .showcase-item.reverse>*{direction:ltr}
  .showcase-text{max-width:100%}
  .hero-screenshot{margin-top:40px;margin-bottom:-120px}
  .hero + .section,.hero + .section.bg-light{padding-top:80px}
}

/* ── FAQ ── */
.faq-list{max-width:720px;margin:48px auto 0}
.faq-item{
  border:1px solid var(--gray-200);border-radius:12px;
  margin-bottom:12px;background:#fff;overflow:hidden;
  transition:border-color 0.2s;
}
.faq-item[open]{border-color:rgba(var(--indigo),0.3)}
.faq-item summary{
  padding:20px 24px;font-weight:600;font-size:1rem;cursor:pointer;
  list-style:none;display:flex;align-items:center;justify-content:space-between;
  color:var(--gray-800);transition:color 0.15s;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:"";width:20px;height:20px;flex-shrink:0;margin-left:16px;
  background:url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M6 9l6 6 6-6' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/contain no-repeat;
  transition:transform 0.25s ease;
}
.faq-item[open] summary::after{transform:rotate(180deg)}
.faq-item[open] summary{color:rgb(var(--indigo))}
.faq-item p{padding:0 24px 20px;color:var(--gray-500);font-size:0.9375rem;line-height:1.7}

/* ── Knowledge Hub (Wissen) ── */
.wissen-intro{text-align:center;margin-bottom:64px}
.wissen-intro p{color:var(--gray-500);margin-top:8px}
.wissen-grid{display:flex;flex-direction:column;gap:56px}
.wissen-card{
  display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;
}
.wissen-card:nth-child(even){direction:rtl}
.wissen-card:nth-child(even)>*{direction:ltr}
.wissen-card-img{
  border-radius:16px;overflow:hidden;aspect-ratio:16/10;
  background:linear-gradient(135deg,rgba(var(--indigo),0.06),rgba(var(--violet),0.1));
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 12px 40px rgba(0,0,0,0.08);
}
.wissen-card-img img{width:100%;height:100%;object-fit:cover}
.wissen-card-text .wissen-tag{
  display:inline-block;font-size:0.6875rem;font-weight:700;text-transform:uppercase;
  letter-spacing:0.06em;color:rgb(var(--indigo));
  background:rgba(var(--indigo),0.08);padding:4px 10px;border-radius:999px;margin-bottom:12px;
}
.wissen-card-text h3{font-size:1.375rem;font-weight:700;margin-bottom:8px;line-height:1.3}
.wissen-card-text p{color:var(--gray-500);font-size:0.9375rem;line-height:1.7;margin-bottom:16px}
.wissen-card-text .wissen-link{
  font-size:0.875rem;font-weight:600;color:rgb(var(--indigo));
  display:inline-flex;align-items:center;gap:6px;transition:gap 0.2s;
}
.wissen-card-text .wissen-link:hover{gap:10px}
@media(max-width:768px){
  .wissen-card,.wissen-card:nth-child(even){grid-template-columns:1fr;direction:ltr;gap:24px}
}

/* ── Knowledge Article ── */
.article-hero{
  position:relative;margin-top:80px;padding:80px 0 60px;
  background:linear-gradient(180deg,rgba(var(--indigo),0.04) 0%,#fff 100%);
}
.article-hero-img{
  border-radius:16px;overflow:hidden;margin-top:40px;
  box-shadow:0 20px 60px rgba(var(--indigo),0.12);max-height:400px;
}
.article-hero-img img{width:100%;height:100%;object-fit:cover;display:block}
.article-meta{
  display:flex;align-items:center;gap:16px;margin-top:16px;
  color:var(--gray-500);font-size:0.8125rem;
}
.article-meta span{display:flex;align-items:center;gap:4px}
.article-body{max-width:760px;margin:0 auto;padding:64px 24px 96px}
.article-body h2{margin:48px 0 16px;font-size:1.75rem}
.article-body h3{margin:32px 0 12px;font-size:1.25rem}
.article-body p{color:var(--gray-600);font-size:1.0625rem;line-height:1.8;margin-bottom:20px}
.article-body ul,.article-body ol{margin:0 0 20px 24px;color:var(--gray-600);font-size:1.0625rem;line-height:1.8}
.article-body blockquote{
  border-left:3px solid rgb(var(--indigo));margin:32px 0;padding:16px 24px;
  background:rgba(var(--indigo),0.03);border-radius:0 8px 8px 0;
  font-size:1.0625rem;color:var(--gray-600);font-style:italic;
}
.article-two-col{
  display:grid;grid-template-columns:1fr 1fr;gap:32px;margin:32px 0;
}
.article-two-col .col-card{
  padding:24px;border-radius:12px;border:1px solid var(--gray-200);background:#fff;
}
.article-two-col .col-card h4{font-size:1rem;font-weight:700;margin-bottom:8px;color:var(--gray-800)}
.article-two-col .col-card p{font-size:0.9375rem;margin-bottom:0}
.article-highlight{
  background:linear-gradient(135deg,rgba(var(--indigo),0.05),rgba(var(--violet),0.07));
  border-radius:12px;padding:32px;margin:32px 0;
}
.article-highlight h3{margin-top:0}
@media(max-width:768px){
  .article-two-col{grid-template-columns:1fr}
  .article-hero{padding:60px 0 40px}
}

/* ── Utility ── */
.mb-2{margin-bottom:8px}
.mb-4{margin-bottom:16px}
.mb-6{margin-bottom:24px}
.mt-2{margin-top:8px}
.mt-4{margin-top:16px}
.mt-8{margin-top:32px}
.gap-2{gap:8px}
.flex{display:flex}
.items-center{align-items:center}
.justify-center{justify-content:center}
.bg-light{background:var(--gray-50)}
