/* SwediPlayTV.se — Swedish-flag inspired design system */
:root{
  --blue:#0F1B3C;
  --blue-dark:#004F7C;
  --blue-deep:#0F1B3C;
  --yellow:#E5B12C;
  --yellow-soft:#FFE066;
  --ink:#0B1F33;
  --muted:#5A6B7B;
  --bg:#F7FAFD;
  --card:#FFFFFF;
  --line:#E2EBF2;
  --ok:#1A9F5C;
  --warn:#E03A3A;
  --shadow:0 6px 24px rgba(0,53,84,.08);
  --shadow-lg:0 14px 40px rgba(0,53,84,.16);
  --radius:14px;
  --radius-sm:8px;
  --max:1180px;
  --font:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;font-family:var(--font);color:var(--ink);background:var(--bg);line-height:1.6;font-size:17px}
img,svg{max-width:100%;height:auto;display:block}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{line-height:1.2;color:var(--blue-deep);margin:0 0 .6em}
h1{font-size:clamp(1.9rem,4vw,2.8rem);font-weight:800;letter-spacing:-.01em}
h2{font-size:clamp(1.5rem,2.6vw,2rem);font-weight:800;margin-top:2.2em}
h3{font-size:1.25rem;font-weight:700;margin-top:1.6em}
p{margin:0 0 1em}
.container{max-width:var(--max);margin:0 auto;padding:0 22px}

/* Top bar (yellow stripe) */
.topbar{background:var(--yellow);color:var(--blue-deep);font-size:14px;font-weight:600;padding:8px 0;text-align:center}
.topbar span{margin:0 14px}

/* Header */
.site-header{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50;box-shadow:0 1px 0 rgba(0,0,0,.02)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:14px 0;gap:20px}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;color:var(--blue-deep);font-size:1.15rem;text-decoration:none}
.brand img,.brand svg{width:42px;height:42px}
.brand span b{color:var(--yellow);background:var(--blue);padding:0 4px;border-radius:4px}
.nav ul{display:flex;gap:22px;list-style:none;margin:0;padding:0;flex-wrap:wrap}
.nav ul a{color:var(--ink);font-weight:600;font-size:.95rem}
.nav ul a:hover{color:var(--blue)}
.btn{display:inline-block;background:var(--yellow);color:var(--blue-deep);font-weight:800;padding:11px 20px;border-radius:99px;text-decoration:none;border:2px solid var(--yellow);transition:transform .15s ease, box-shadow .15s ease}
.btn:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(254,204,0,.5);text-decoration:none}
.btn-blue{background:var(--blue);color:#fff;border-color:var(--blue)}
.btn-blue:hover{box-shadow:0 6px 18px rgba(0,106,167,.45)}
.btn-outline{background:transparent;color:var(--blue);border-color:var(--blue)}

/* Hero */
.hero{background:linear-gradient(135deg,var(--blue) 0%,var(--blue-dark) 60%,var(--blue-deep) 100%);color:#fff;padding:64px 0 72px;position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:radial-gradient(800px 400px at 85% 20%,rgba(254,204,0,.18),transparent 70%)}
.hero .container{position:relative;display:grid;grid-template-columns:1.2fr 1fr;gap:40px;align-items:center}
.hero h1{color:#fff;font-size:clamp(2rem,4.5vw,3.2rem)}
.hero h1 em{font-style:normal;color:var(--yellow);background:linear-gradient(90deg,var(--yellow),var(--yellow-soft));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero p.lead{font-size:1.18rem;color:#DDEAF4;max-width:560px;margin-bottom:24px}
.hero .cta-row{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:22px}
.hero .badges{display:flex;gap:18px;flex-wrap:wrap;color:#CFE0EE;font-size:.92rem;font-weight:600}
.hero .badges b{color:var(--yellow)}
.hero-art{justify-self:end}

/* Trust strip */
.trust{background:#fff;border-bottom:1px solid var(--line);padding:18px 0}
.trust .row{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;text-align:center}
.trust .row div{font-size:.9rem;color:var(--muted)}
.trust .row b{display:block;font-size:1.4rem;color:var(--blue);font-weight:800}

/* Sections */
section.s{padding:64px 0}
section.s.alt{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.section-head{text-align:center;max-width:760px;margin:0 auto 40px}
.section-head .kicker{display:inline-block;background:var(--yellow);color:var(--blue-deep);font-weight:800;padding:5px 12px;border-radius:99px;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;margin-bottom:14px}
.section-head p{color:var(--muted);font-size:1.05rem}

/* Cards grid */
.grid{display:grid;gap:22px}
.grid.g3{grid-template-columns:repeat(3,1fr)}
.grid.g4{grid-template-columns:repeat(4,1fr)}
.grid.g2{grid-template-columns:repeat(2,1fr)}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow);transition:transform .2s ease, box-shadow .2s ease;display:flex;flex-direction:column}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.card .ico{width:54px;height:54px;border-radius:12px;background:linear-gradient(135deg,var(--blue),var(--blue-dark));display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.card .ico svg{width:30px;height:30px;color:var(--yellow)}
.card h3{margin:0 0 8px;font-size:1.15rem}
.card p{color:var(--muted);font-size:.95rem;margin:0 0 14px;flex:1}
.card a.more{color:var(--blue);font-weight:700;font-size:.92rem}
.card a.more::after{content:" →"}

/* Pricing */
.pricing{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.plan{background:#fff;border:2px solid var(--line);border-radius:var(--radius);padding:30px 26px;text-align:center;position:relative;transition:transform .2s ease,border-color .2s ease}
.plan:hover{transform:translateY(-4px);border-color:var(--blue)}
.plan.popular{border-color:var(--yellow);box-shadow:var(--shadow-lg)}
.plan .tag{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--yellow);color:var(--blue-deep);font-size:.75rem;font-weight:800;padding:5px 14px;border-radius:99px;letter-spacing:.05em;text-transform:uppercase}
.plan h3{font-size:1.1rem;margin:0 0 4px}
.plan .price{font-size:2.4rem;font-weight:800;color:var(--blue);margin:10px 0 0;letter-spacing:-.02em}
.plan .price span{font-size:.9rem;color:var(--muted);font-weight:500}
.plan .per{color:var(--muted);font-size:.85rem;margin:0 0 16px}
.plan ul{list-style:none;padding:0;margin:18px 0;text-align:left}
.plan ul li{padding:7px 0 7px 26px;position:relative;font-size:.92rem;color:#314A60}
.plan ul li::before{content:"✓";position:absolute;left:0;top:6px;color:var(--ok);font-weight:800}

/* Article body */
.article{background:#fff;border-bottom:1px solid var(--line)}
.article .wrap{display:grid;grid-template-columns:minmax(0,1fr) 290px;gap:48px;padding:50px 0 70px}
.article main h2{border-left:5px solid var(--yellow);padding-left:14px}
.article main p,.article main li{color:#22384C;font-size:1.02rem}
.article main ul,.article main ol{padding-left:22px}
.article main li{margin:.4em 0}
.article main blockquote{border-left:4px solid var(--blue);background:#EEF6FC;padding:18px 22px;margin:22px 0;border-radius:0 var(--radius-sm) var(--radius-sm) 0;color:var(--blue-deep);font-style:italic}
.article main table{border-collapse:collapse;width:100%;margin:22px 0;background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden}
.article main th{background:var(--blue);color:#fff;text-align:left;padding:12px 14px;font-size:.95rem}
.article main td{padding:11px 14px;border-top:1px solid var(--line);font-size:.95rem}
.article main tr:nth-child(even) td{background:#F7FAFD}
.tldr{background:linear-gradient(135deg,#FFF8DB,#FFF3B8);border-left:5px solid var(--yellow);padding:18px 22px;border-radius:var(--radius-sm);margin:0 0 26px}
.tldr b{color:var(--blue-deep)}
.meta{display:flex;gap:14px;flex-wrap:wrap;color:var(--muted);font-size:.88rem;margin:0 0 18px}
.meta span{display:inline-flex;align-items:center;gap:6px}
.meta b{color:var(--blue-deep)}

aside.toc{position:sticky;top:90px;align-self:start;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow)}
aside.toc h4{font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin:0 0 12px}
aside.toc ul{list-style:none;padding:0;margin:0}
aside.toc li{margin:6px 0}
aside.toc a{color:#314A60;font-size:.93rem;font-weight:600}
aside.toc a:hover{color:var(--blue)}
.related{background:linear-gradient(135deg,var(--blue),var(--blue-dark));color:#fff;border-radius:var(--radius);padding:22px;margin-top:22px}
.related h4{color:#fff;margin:0 0 10px;font-size:1rem}
.related a{color:var(--yellow);font-weight:600;display:block;padding:5px 0;font-size:.93rem;border-bottom:1px solid rgba(255,255,255,.1)}
.related a:last-child{border:0}

/* FAQ */
.faq details{background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);margin:10px 0;padding:0;overflow:hidden;transition:box-shadow .2s ease}
.faq details[open]{box-shadow:var(--shadow)}
.faq summary{cursor:pointer;padding:18px 22px;font-weight:700;color:var(--blue-deep);list-style:none;display:flex;justify-content:space-between;align-items:center;gap:12px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--blue);font-size:1.5rem;font-weight:400;transition:transform .2s ease}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details > div{padding:0 22px 20px;color:#22384C}

/* CTA banner */
.cta-banner{background:linear-gradient(135deg,var(--yellow) 0%,#FFD83A 100%);color:var(--blue-deep);text-align:center;padding:56px 22px;border-radius:var(--radius);margin:48px auto;max-width:var(--max)}
.cta-banner h2{color:var(--blue-deep);margin-top:0}
.cta-banner p{font-size:1.1rem;max-width:620px;margin:0 auto 22px}

/* Footer */
footer{background:var(--blue-deep);color:#A9C4D8;padding:54px 0 24px;margin-top:60px}
footer .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px;margin-bottom:36px}
footer h5{color:#fff;font-size:.95rem;text-transform:uppercase;letter-spacing:.06em;margin:0 0 14px}
footer ul{list-style:none;padding:0;margin:0}
footer ul li{padding:5px 0;font-size:.92rem}
footer ul a{color:#A9C4D8}
footer ul a:hover{color:var(--yellow)}
footer .brand{color:#fff;margin-bottom:12px}
footer .brand span{color:#fff}
footer .legal{border-top:1px solid rgba(255,255,255,.1);padding-top:20px;text-align:center;font-size:.85rem;color:#7A92A6}

/* Breadcrumb */
.crumbs{padding:18px 0;font-size:.88rem;color:var(--muted)}
.crumbs a{color:var(--blue)}
.crumbs span{margin:0 8px;color:var(--line)}

/* Responsive */
@media (max-width:900px){
  .hero .container{grid-template-columns:1fr}
  .hero-art{display:none}
  .grid.g3,.grid.g4,.pricing{grid-template-columns:repeat(2,1fr)}
  .article .wrap{grid-template-columns:1fr;padding:30px 0 50px;gap:30px}
  aside.toc{position:static}
  footer .cols{grid-template-columns:1fr 1fr;gap:24px}
  .trust .row{grid-template-columns:repeat(2,1fr)}
  .nav ul{display:none}
}
@media (max-width:560px){
  .grid.g3,.grid.g4,.pricing,.grid.g2{grid-template-columns:1fr}
  footer .cols{grid-template-columns:1fr}
  .hero{padding:44px 0 50px}
  section.s{padding:44px 0}
}


/* ═══════════════════════════════════════════════════════════════════
   VIBRANT UPGRADE — full-width layout + bolder visuals (May 2026)
   ═══════════════════════════════════════════════════════════════════ */

:root{
  --gradient-primary:linear-gradient(135deg,#0F1B3C 0%,#1F3A6E 45%,#0F1B3C 100%);
  --gradient-accent:linear-gradient(135deg,#E5B12C 0%,#FFD75A 50%,#E5B12C 100%);
  --gradient-action:linear-gradient(135deg,#25D366 0%,#128C7E 100%);
  --glow-gold:0 0 30px rgba(229,177,44,.55), 0 6px 20px rgba(229,177,44,.4);
  --glow-blue:0 0 30px rgba(31,58,110,.5), 0 6px 20px rgba(15,27,60,.35);
  --glow-green:0 0 25px rgba(37,211,102,.55), 0 6px 18px rgba(37,211,102,.4);
}

/* Wider container */
.container{max-width:1280px}

/* ── FIX: kill the empty 290px sidebar slot on article pages ── */
.article .wrap{
  display:block !important;
  grid-template-columns:none !important;
  max-width:980px;
  margin:0 auto;
  padding:60px 0 80px;
}
.article main{max-width:none}
.article main h2{
  border-left:none;
  padding-left:0;
  background:linear-gradient(90deg,#0F1B3C,#1F3A6E);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  position:relative;
  padding-bottom:14px;
  margin-top:2.6em;
}
.article main h2::after{
  content:"";
  display:block;
  position:absolute;
  bottom:0;left:0;
  width:80px;height:4px;
  background:var(--gradient-accent);
  border-radius:2px;
}
.article main h3{color:#0F1B3C;font-weight:700}

/* ── VIBRANT TOPBAR ── */
.topbar{
  background:var(--gradient-accent);
  background-size:200% 200%;
  animation:shimmer 6s ease infinite;
  font-weight:700;
  letter-spacing:.01em;
  padding:10px 0;
  box-shadow:0 2px 12px rgba(229,177,44,.4);
}
@keyframes shimmer{
  0%,100%{background-position:0% 50%}
  50%{background-position:100% 50%}
}
.topbar a{color:#0F1B3C;font-weight:800}

/* ── VIBRANT HEADER ── */
.site-header{
  background:rgba(255,255,255,.96);
  backdrop-filter:saturate(180%) blur(14px);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  border-bottom:2px solid transparent;
  border-image:var(--gradient-accent) 1;
}
.brand{font-weight:900;font-size:1.25rem}

/* ── VIBRANT BUTTONS ── */
.btn{
  background:var(--gradient-accent);
  background-size:200% 200%;
  color:#0F1B3C;
  font-weight:900;
  padding:13px 26px;
  border-radius:99px;
  border:none;
  text-shadow:0 1px 0 rgba(255,255,255,.3);
  box-shadow:var(--glow-gold);
  transition:all .25s cubic-bezier(.34,1.56,.64,1);
  letter-spacing:.01em;
}
.btn:hover{
  transform:translateY(-3px) scale(1.04);
  background-position:100% 50%;
  box-shadow:0 0 50px rgba(229,177,44,.7), 0 10px 30px rgba(229,177,44,.5);
  text-decoration:none;
}
.btn:active{transform:translateY(-1px) scale(1.01)}
.btn-blue{
  background:var(--gradient-primary);
  color:#fff;
  box-shadow:var(--glow-blue);
  text-shadow:none;
}
.btn-blue:hover{box-shadow:0 0 50px rgba(31,58,110,.6), 0 10px 30px rgba(15,27,60,.45)}

/* ── VIBRANT HERO ── */
.hero{
  background:linear-gradient(135deg,#0F1B3C 0%,#1F3A6E 35%,#2A4D8A 65%,#0F1B3C 100%);
  background-size:300% 300%;
  animation:heroShift 20s ease infinite;
  padding:80px 0 90px;
}
@keyframes heroShift{
  0%,100%{background-position:0% 50%}
  50%{background-position:100% 50%}
}
.hero::before{
  background:radial-gradient(900px 500px at 85% 20%,rgba(229,177,44,.30),transparent 70%),
             radial-gradient(700px 400px at 15% 80%,rgba(31,58,110,.45),transparent 70%);
  opacity:1;
}
.hero h1{font-size:clamp(2.2rem,5vw,3.8rem);font-weight:900;letter-spacing:-.02em}
.hero h1 em{
  background:var(--gradient-accent);
  background-size:200% 200%;
  animation:shimmer 4s ease infinite;
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
}
.hero p.lead{font-size:1.28rem;color:#EAF1F8;font-weight:500}
.hero .badges b{color:#FFD75A;text-shadow:0 0 12px rgba(255,215,90,.6)}

/* ── VIBRANT TRUST STRIP ── */
.trust{
  background:linear-gradient(180deg,#fff 0%,#F0F5FA 100%);
  padding:28px 0;
  border-bottom:3px solid transparent;
  border-image:var(--gradient-accent) 1;
}
.trust .row b{
  font-size:1.7rem;
  background:var(--gradient-primary);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
}

/* ── VIBRANT CARDS ── */
.card{
  border:none;
  background:linear-gradient(180deg,#fff 0%,#FAFCFE 100%);
  box-shadow:0 4px 20px rgba(15,27,60,.06), 0 1px 3px rgba(15,27,60,.04);
  position:relative;
  overflow:hidden;
}
.card::before{
  content:"";
  position:absolute;
  top:0;left:0;right:0;
  height:4px;
  background:var(--gradient-accent);
  opacity:0;
  transition:opacity .3s ease;
}
.card:hover{
  transform:translateY(-6px);
  box-shadow:0 20px 40px rgba(15,27,60,.15), 0 8px 16px rgba(15,27,60,.08);
}
.card:hover::before{opacity:1}
.card .ico{
  background:var(--gradient-primary);
  box-shadow:var(--glow-blue);
}
.card .ico svg{color:#FFD75A}

/* ── VIBRANT PRICING CARDS ── */
.pricing{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.plan{
  border:2px solid transparent;
  background:linear-gradient(#fff,#fff) padding-box,linear-gradient(135deg,rgba(229,177,44,.4),rgba(31,58,110,.3)) border-box;
  border-radius:18px;
  padding:34px 26px;
  transition:transform .25s cubic-bezier(.34,1.56,.64,1),box-shadow .25s ease;
}
.plan:hover{transform:translateY(-8px);box-shadow:var(--glow-gold)}
.plan.popular{
  background:linear-gradient(135deg,#fff8e7 0%,#fff 100%) padding-box,var(--gradient-accent) border-box;
  border-width:3px;
  transform:scale(1.03);
}
.plan.popular:hover{transform:scale(1.06) translateY(-4px)}
.plan .price{
  font-size:2.8rem;
  background:var(--gradient-primary);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  font-weight:900;
}
.plan .tag{
  background:var(--gradient-accent);
  color:#0F1B3C;
  font-weight:900;
  padding:6px 16px;
  box-shadow:0 4px 12px rgba(229,177,44,.5);
}

/* ── SECTION HEADERS ── */
.section-head .kicker{
  background:var(--gradient-accent);
  color:#0F1B3C;
  font-weight:900;
  padding:6px 16px;
  box-shadow:0 4px 14px rgba(229,177,44,.4);
}
.section-head h2{
  font-size:clamp(1.8rem,3vw,2.4rem);
  background:var(--gradient-primary);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
}

/* ── CTA BANNERS ── */
.cta-banner{
  background:var(--gradient-primary);
  color:#fff;
  padding:50px 30px;
  text-align:center;
  border-radius:0;
  margin:0;
  position:relative;
  overflow:hidden;
}
.cta-banner::before{
  content:"";
  position:absolute;inset:0;
  background:radial-gradient(600px 300px at 50% 50%,rgba(229,177,44,.18),transparent 70%);
}
.cta-banner h2{
  color:#FFD75A;
  font-size:clamp(1.6rem,3vw,2.2rem);
  margin:0 0 12px;
  position:relative;
  -webkit-text-fill-color:#FFD75A;
  background:none;
}
.cta-banner p{position:relative;font-size:1.1rem;color:#DDEAF4;margin:0 0 24px}
.cta-banner .btn{position:relative}

/* ── FOOTER ── */
footer{
  background:linear-gradient(180deg,#0F1B3C 0%,#0A1228 100%);
  color:#fff;
  padding:60px 0 30px;
  border-top:4px solid transparent;
  border-image:var(--gradient-accent) 1;
}

/* ── ARTICLE BODY ── */
.article main p,.article main li{font-size:1.06rem;line-height:1.75;color:#1F2937}
.article main strong{color:#0F1B3C}
.article main a{color:#1F3A6E;font-weight:600;border-bottom:2px solid rgba(229,177,44,.3);transition:border-color .2s ease}
.article main a:hover{border-bottom-color:#E5B12C;text-decoration:none}
.article main figure{
  margin:32px 0;
  border-radius:16px;
  overflow:hidden;
  box-shadow:0 12px 40px rgba(15,27,60,.15);
}
.article main aside{box-shadow:0 8px 24px rgba(15,27,60,.08)}

/* ── BREADCRUMBS ── */
.crumbs{padding:18px 0;color:var(--muted);font-size:.92rem;background:linear-gradient(180deg,#FAFCFE,#F7FAFD)}
.crumbs a{color:#1F3A6E;font-weight:600}

/* ── WHATSAPP BUBBLE ENHANCED ── */
a[aria-label="Kontakta oss på WhatsApp"]{
  box-shadow:var(--glow-green) !important;
  animation:waPulse 2.5s ease-in-out infinite;
}
@keyframes waPulse{
  0%,100%{box-shadow:0 0 0 0 rgba(37,211,102,.7), 0 6px 20px rgba(37,211,102,.5)}
  50%{box-shadow:0 0 0 14px rgba(37,211,102,0), 0 6px 20px rgba(37,211,102,.5)}
}

/* ── WHATSAPP CTA BUTTONS (special green-gradient style) ── */
a.wa-cta{
  background:var(--gradient-action) !important;
  color:#fff !important;
  font-weight:900;
  padding:14px 28px;
  border-radius:99px;
  display:inline-flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
  box-shadow:var(--glow-green);
  transition:all .25s cubic-bezier(.34,1.56,.64,1);
  border:none;
}
a.wa-cta:hover{
  transform:translateY(-3px) scale(1.04);
  box-shadow:0 0 50px rgba(37,211,102,.7), 0 12px 30px rgba(37,211,102,.5);
  text-decoration:none;
}
a.wa-cta::before{
  content:"💬";
  font-size:1.2rem;
}

/* ── RESPONSIVE TWEAKS ── */
@media (max-width:980px){
  .article .wrap{padding:40px 16px 60px}
  .pricing{grid-template-columns:1fr 1fr;gap:18px}
  .grid.g3,.grid.g4{grid-template-columns:1fr 1fr}
  .hero .container{grid-template-columns:1fr}
  .hero-art{display:none}
}
@media (max-width:640px){
  .pricing,.grid.g3,.grid.g4,.grid.g2{grid-template-columns:1fr}
  .topbar span{display:block;margin:2px 0}
  .nav ul{display:none}
}


/* ═══════════════════════════════════════════════════════════════════
   MOBILE MENU — hamburger + slide-down drawer (May 2026)
   ═══════════════════════════════════════════════════════════════════ */

/* Hamburger button — hidden on desktop, shown on mobile */
.nav-toggle{
  display:none;
  background:transparent;
  border:none;
  width:44px;
  height:44px;
  padding:0;
  cursor:pointer;
  position:relative;
  z-index:101;
  border-radius:8px;
  transition:background .2s ease;
}
.nav-toggle:hover{background:rgba(15,27,60,.06)}
.nav-toggle .bar{
  display:block;
  width:24px;
  height:3px;
  background:#0F1B3C;
  margin:5px auto;
  border-radius:3px;
  transition:transform .35s cubic-bezier(.65,.05,.36,1), opacity .25s ease;
  transform-origin:center;
}
.nav-toggle[aria-expanded="true"] .bar:nth-child(1){
  transform:translateY(8px) rotate(45deg);
}
.nav-toggle[aria-expanded="true"] .bar:nth-child(2){
  opacity:0;transform:scaleX(0);
}
.nav-toggle[aria-expanded="true"] .bar:nth-child(3){
  transform:translateY(-8px) rotate(-45deg);
}

/* Mobile menu backdrop */
.mobile-backdrop{
  display:none;
  position:fixed;
  inset:0;
  background:rgba(15,27,60,.6);
  backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
  z-index:90;
  opacity:0;
  transition:opacity .3s ease;
}
.mobile-backdrop.open{opacity:1}

/* Mobile menu drawer */
.mobile-menu{
  display:none;
  position:fixed;
  top:0;right:0;bottom:0;
  width:min(85vw,340px);
  background:linear-gradient(180deg,#fff 0%,#FAFCFE 100%);
  z-index:95;
  padding:80px 28px 28px;
  overflow-y:auto;
  transform:translateX(100%);
  transition:transform .35s cubic-bezier(.65,.05,.36,1);
  box-shadow:-12px 0 40px rgba(15,27,60,.18);
}
.mobile-menu.open{transform:translateX(0)}
.mobile-menu ul{
  list-style:none;
  margin:0 0 24px;
  padding:0;
}
.mobile-menu li{margin:0;border-bottom:1px solid #EEF2F6}
.mobile-menu li:last-child{border-bottom:none}
.mobile-menu li a{
  display:block;
  padding:16px 8px;
  color:#0F1B3C;
  font-weight:700;
  font-size:1.05rem;
  text-decoration:none;
  transition:color .2s ease, padding-left .2s ease;
}
.mobile-menu li a:hover{
  color:#1F3A6E;
  padding-left:14px;
  text-decoration:none;
}
.mobile-menu .mobile-cta{
  display:flex;
  flex-direction:column;
  gap:12px;
  padding-top:24px;
  border-top:2px solid #EEF2F6;
}
.mobile-menu .mobile-cta a{
  text-align:center;
  padding:14px 20px;
  border-radius:99px;
  font-weight:900;
  text-decoration:none;
  transition:transform .2s cubic-bezier(.34,1.56,.64,1);
}
.mobile-menu .mobile-cta a:hover{transform:translateY(-2px)}
.mobile-menu .mobile-cta .wa-btn{
  background:linear-gradient(135deg,#25D366 0%,#128C7E 100%);
  color:#fff;
  box-shadow:0 6px 20px rgba(37,211,102,.4);
}
.mobile-menu .mobile-cta .price-btn{
  background:linear-gradient(135deg,#E5B12C,#FFD75A);
  color:#0F1B3C;
  box-shadow:0 6px 20px rgba(229,177,44,.4);
}

/* Show on mobile */
@media (max-width:880px){
  .nav-toggle{display:block}
  .nav>nav{display:none}        /* hide desktop nav <nav> */
  .nav>a.btn{display:none}      /* hide desktop CTA button */
  .mobile-backdrop,.mobile-menu{display:block}
  .nav{justify-content:space-between}
  body.menu-open{overflow:hidden}
}

/* Tweak the topbar on smallest screens */
@media (max-width:520px){
  .topbar{font-size:12px;padding:7px 0}
  .topbar span{margin:1px 6px;display:inline-block}
}


/* ═══════════════════════════════════════════════════════════════════
   BUG FIXES — centering + dark-background text visibility
   ═══════════════════════════════════════════════════════════════════ */

/* FIX 1: force CTA banner to center properly with explicit child rules */
.cta-banner{text-align:center !important;display:block !important;width:100% !important}
.cta-banner > *{margin-left:auto !important;margin-right:auto !important;text-align:center !important}
.cta-banner h2,
.cta-banner p,
.cta-banner a{display:block;max-width:760px;margin-left:auto;margin-right:auto}
.cta-banner a.btn,
.cta-banner a.wa-cta{display:inline-flex !important;width:auto;margin:0 8px}
.cta-banner h2{
  background:none !important;
  -webkit-text-fill-color:#FFD75A !important;
  color:#FFD75A !important;
  -webkit-background-clip:initial !important;
  background-clip:initial !important;
}
.cta-banner h2::after{display:none !important}

/* FIX 2: undo the article-main h2 gradient when there's an inline color (dark-bg boxes) */
/* Match h2 elements that have inline color attribute — keep their explicit color visible */
.article main h2[style*="color"]{
  background:none !important;
  -webkit-background-clip:initial !important;
  background-clip:initial !important;
  -webkit-text-fill-color:initial !important;
  padding-bottom:0 !important;
}
.article main h2[style*="color"]::after{display:none !important}

/* Also fix the same issue on h2 inside dark <aside>/<div> backgrounds */
.article main aside h2,
.article main div[style*="background:#0F"] h2,
.article main div[style*="background:linear-gradient"] h2{
  background:none !important;
  -webkit-background-clip:initial !important;
  background-clip:initial !important;
  -webkit-text-fill-color:#FFD75A !important;
  color:#FFD75A !important;
  padding-bottom:0 !important;
}
.article main aside h2::after,
.article main div[style*="background:#0F"] h2::after,
.article main div[style*="background:linear-gradient"] h2::after{display:none !important}

/* FIX 3: blog card with image styling — vibrant hero card layout */
.blog-card{
  position:relative;
  background:#fff;
  border-radius:16px;
  overflow:hidden;
  box-shadow:0 6px 24px rgba(15,27,60,.08);
  text-decoration:none;
  color:inherit;
  display:flex;
  flex-direction:column;
  transition:transform .25s cubic-bezier(.34,1.56,.64,1), box-shadow .25s ease;
}
.blog-card:hover{
  transform:translateY(-6px);
  box-shadow:0 20px 40px rgba(15,27,60,.18);
  text-decoration:none;
}
.blog-card .blog-img{
  position:relative;
  aspect-ratio:16/9;
  overflow:hidden;
  background:linear-gradient(135deg,#0F1B3C,#1F3A6E);
}
.blog-card .blog-img img{
  width:100%;height:100%;
  object-fit:cover;
  transition:transform .5s ease;
}
.blog-card:hover .blog-img img{transform:scale(1.06)}
.blog-card .blog-img::after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 50%,rgba(15,27,60,.4) 100%);
  pointer-events:none;
}
.blog-card .blog-tag{
  position:absolute;
  top:14px;left:14px;
  background:linear-gradient(135deg,#E5B12C,#FFD75A);
  color:#0F1B3C;
  font-weight:900;
  padding:5px 12px;
  border-radius:99px;
  font-size:.78rem;
  letter-spacing:.04em;
  text-transform:uppercase;
  box-shadow:0 4px 12px rgba(229,177,44,.45);
  z-index:2;
}
.blog-card .blog-body{
  padding:22px 24px 24px;
  display:flex;
  flex-direction:column;
  flex:1;
}
.blog-card .blog-body h3{
  font-size:1.18rem;
  font-weight:800;
  margin:0 0 10px;
  color:#0F1B3C;
  line-height:1.35;
}
.blog-card .blog-body p{
  color:#5A6B7B;
  font-size:.96rem;
  margin:0 0 14px;
  flex:1;
}
.blog-card .blog-body .more{
  color:#1F3A6E;
  font-weight:800;
  font-size:.92rem;
  margin-top:auto;
}
.blog-card .blog-body .more::after{content:" →"}
.grid.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media (max-width:880px){.grid.blog-grid{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.grid.blog-grid{grid-template-columns:1fr}}
