/* ==========================================================================
   PROFIT.NINJA 4.0 — rhythmic landing
   Old palette (navy/teal/magenta, Poppins). Goal: BREAK the monotony of
   "4 icons in a row". Alternating backgrounds, big L/R image splits, a
   carousel, a full-width stats band, an interactive stepper.
   Taller sticky nav (logo ~72px). Dark footer with bigger logo.
   ========================================================================== */

:root{
  --bg:#0b0626; --bg-2:#130b44; --bg-3:#190f55; --bg-card:#150c49;
  --teal:#2aeec7; --teal-2:#57f4d6; --teal-deep:#18b894;
  --mag:#fb0096; --mag-2:#ff5cc0;
  --ink:#fff; --muted:#b3acdf; --muted-2:#7a72ab;
  --line:rgba(255,255,255,.08); --line-teal:rgba(42,238,199,.22); --line-mag:rgba(251,0,150,.28);
  --outline:#0a0420;
  --font:"Poppins",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  --radius:22px; --maxw:1200px;
  --shadow-sticker:5px 5px 0 var(--outline);
  --shadow-soft:0 26px 70px -34px rgba(0,0,0,.75);
  --nav-h:96px;
}
*{box-sizing:border-box} html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font);background:var(--bg);color:var(--muted);line-height:1.62;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block} a{color:var(--teal);text-decoration:none}
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px;position:relative;z-index:1}

/* ---- alternating section backgrounds (the rhythm) ---- */
.section{padding:104px 0;position:relative;z-index:1}
.section--tight{padding:74px 0}
/* a section that directly follows a .page-head needs less top space (head already padded) */
.section--after-head{padding-top:40px}
.section--flush{padding-top:16px}
.s-dark{background:var(--bg)}
.s-deep{background:linear-gradient(180deg,#120a40,#0b0626)}
.s-glow-t{background:radial-gradient(900px 500px at 78% 20%,rgba(42,238,199,.12),transparent 60%),var(--bg)}
.s-glow-m{background:radial-gradient(900px 500px at 22% 30%,rgba(251,0,150,.12),transparent 60%),var(--bg-2)}
.s-band{background:linear-gradient(135deg,#150c49,#1d1060)}
/* faint top/bottom hairlines to separate stacked sections */
.s-deep,.s-glow-t,.s-glow-m,.s-band{border-top:1px solid var(--line)}

/* type */
h1,h2,h3,h4{color:var(--ink);margin:0 0 .5em;line-height:1.05}
.display{font-weight:900;font-style:italic;text-transform:uppercase;letter-spacing:-.015em;font-size:clamp(2.8rem,6.2vw,5rem)}
.h-sec{font-weight:900;font-style:italic;text-transform:uppercase;font-size:clamp(2rem,4vw,3.1rem)}
.h-sub{font-weight:800;font-size:clamp(1.25rem,2.1vw,1.6rem)}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-style:italic;font-weight:700;text-transform:uppercase;letter-spacing:.16em;font-size:.8rem;color:var(--mag);margin-bottom:14px}
.lead{font-size:clamp(1.05rem,1.5vw,1.22rem);color:var(--muted)}
.t-teal{color:var(--teal)} .t-mag{color:var(--mag)} .t-ink{color:var(--ink)}
.center{text-align:center} .measure{max-width:720px} .center .measure{margin-inline:auto}

/* sparkle helpers */
.spk{display:inline-block;vertical-align:middle}
.spk--teal{color:var(--teal)} .spk--mag{color:var(--mag)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.55rem;font-weight:800;font-size:1rem;padding:14px 28px;border-radius:14px;border:2px solid var(--outline);cursor:pointer;transition:transform .14s,box-shadow .14s,background .2s,color .2s}
.btn--primary{background:var(--teal);color:#06231d;box-shadow:var(--shadow-sticker)}
.btn--primary:hover{transform:translate(-2px,-2px);box-shadow:7px 7px 0 var(--outline);background:var(--teal-2)}
.btn--mag{background:var(--mag);color:#fff;box-shadow:var(--shadow-sticker)}
.btn--mag:hover{transform:translate(-2px,-2px);box-shadow:7px 7px 0 var(--outline);background:var(--mag-2)}
.btn--ghost{background:transparent;color:var(--ink);border:2px solid var(--line)}
.btn--ghost:hover{border-color:var(--teal);color:var(--teal);transform:translateY(-2px)}
.btn--sm{padding:10px 18px;font-size:.9rem;border-radius:11px}

/* pills/tags */
.tag{display:inline-flex;align-items:center;gap:6px;font-size:.74rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:5px 12px;border-radius:999px;background:rgba(42,238,199,.1);color:var(--teal);border:1px solid var(--line-teal)}
.tag--mag{background:rgba(251,0,150,.12);color:var(--mag-2);border-color:var(--line-mag)}
.tag--ghost{background:transparent;color:var(--muted);border-color:var(--line)}
.chip{display:inline-flex;align-items:center;gap:9px;background:var(--bg-3);border:2px solid var(--line);border-radius:999px;padding:7px 16px 7px 7px;font-weight:700;font-size:.9rem;color:var(--ink)}
.chip img{width:30px;height:30px;border-radius:50%;background:rgba(42,238,199,.1);padding:3px;object-fit:contain}
.badge-new{font-size:.56rem;font-weight:800;letter-spacing:.06em;background:var(--mag);color:#fff;padding:2px 6px;border-radius:6px;margin-left:5px;text-transform:uppercase;border:1.5px solid var(--outline);vertical-align:middle}

/* ===================== TALLER NAV (logo ~72px) ===================== */
.nav{position:sticky;top:0;z-index:60;background:rgba(11,6,38,.86);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.nav__inner{display:flex;align-items:center;gap:18px;height:var(--nav-h)}
.nav__logo img{height:72px;width:auto}
.nav__links{display:flex;align-items:center;gap:2px;margin-left:22px}
.nav__links>a,.nav__drop>button{color:var(--muted);font-size:.97rem;font-weight:600;padding:10px 14px;border-radius:10px;transition:color .2s,background .2s;background:none;border:0;font-family:inherit;cursor:pointer;display:inline-flex;align-items:center;gap:6px}
.nav__links>a:hover,.nav__drop>button:hover{color:var(--ink);background:rgba(255,255,255,.04)}
.nav__links a.active,.nav__drop.active>button{color:var(--teal)}
.nav__drop{position:relative}
.nav__drop>button::after{content:"▾";font-size:.7rem;opacity:.7}
.nav__menu{position:absolute;top:calc(100% + 10px);left:0;min-width:240px;background:var(--bg-2);border:1px solid var(--line);border-radius:14px;padding:8px;box-shadow:var(--shadow-soft);opacity:0;visibility:hidden;transform:translateY(-6px);transition:.18s;z-index:70}
.nav__drop:hover .nav__menu,.nav__drop:focus-within .nav__menu{opacity:1;visibility:visible;transform:translateY(0)}
.nav__menu a{display:flex;gap:10px;align-items:center;padding:10px 12px;border-radius:10px;color:var(--muted);font-size:.92rem}
.nav__menu a:hover{background:rgba(42,238,199,.08);color:var(--teal)}
.nav__menu a img{width:32px;height:32px;object-fit:contain}
.nav__menu a small{display:block;color:var(--muted-2);font-size:.74rem;font-weight:500}
.nav__cta{margin-left:auto;display:flex;align-items:center;gap:10px}
.nav__burger{display:none;background:none;border:0;cursor:pointer;padding:8px}
.nav__burger span{display:block;width:24px;height:2px;background:var(--ink);margin:5px 0;border-radius:2px}
@media (max-width:1060px){
  :root{--nav-h:84px}
  .nav__logo img{height:60px}
  .nav__links,.nav__cta .btn--ghost{display:none}
  .nav__burger{display:block;margin-left:auto}.nav__cta{margin-left:0}
  .nav.open .nav__links{display:flex;flex-direction:column;align-items:stretch;position:absolute;top:var(--nav-h);left:0;right:0;background:var(--bg-2);border-bottom:1px solid var(--line);padding:12px 24px 20px;gap:2px;margin:0}
  .nav.open .nav__menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;background:transparent;border:0;padding:4px 0 4px 14px}
}

/* ===================== HERO ===================== */
.hero{padding:84px 0 100px;position:relative;overflow:hidden}
.hero__grid{display:grid;grid-template-columns:1.04fr .96fr;gap:46px;align-items:center}
.hero h1{font-size:clamp(3rem,6.4vw,5.2rem)}
.hero__sub{font-size:1.24rem;max-width:34ch;margin:22px 0 30px}
.hero__cta{display:flex;flex-wrap:wrap;gap:16px;align-items:center}
.hero__art{position:relative}
.hero__art img{filter:drop-shadow(0 36px 64px rgba(0,0,0,.6))}
.hero__halo{position:absolute;inset:-8% -6%;background:radial-gradient(closest-side,rgba(42,238,199,.18),transparent 70%);z-index:-1}
@media (max-width:920px){.hero__grid{grid-template-columns:1fr;gap:12px}.hero__art{order:-1;max-width:440px;margin:0 auto}}

/* ===================== FULL-WIDTH STATS BAND ===================== */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:2px solid var(--line-teal);border-radius:24px;overflow:hidden;background:linear-gradient(135deg,rgba(42,238,199,.06),rgba(251,0,150,.05))}
.stats .st{padding:34px 26px;text-align:center;border-right:1px solid var(--line)}
.stats .st:last-child{border-right:0}
.stats .st .num{font-size:clamp(1.8rem,3vw,2.6rem);font-weight:900;font-style:italic;color:var(--teal);line-height:1}
.stats .st .lbl{font-size:.86rem;color:var(--muted);margin-top:6px}
@media(max-width:740px){.stats{grid-template-columns:1fr 1fr}.stats .st:nth-child(2){border-right:0}.stats .st{border-bottom:1px solid var(--line)}}

/* ===================== BIG SPLIT (L/R alternating) ===================== */
.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.split--rev .split__media{order:2}
.split__media{position:relative}
.split__media img{filter:drop-shadow(0 30px 56px rgba(0,0,0,.55))}
.split__media .halo{position:absolute;inset:0;z-index:-1;background:radial-gradient(closest-side,rgba(42,238,199,.16),transparent 70%)}
.split--mag .split__media .halo{background:radial-gradient(closest-side,rgba(251,0,150,.16),transparent 70%)}
.split--wide{grid-template-columns:1.15fr .85fr}
.split--wide.split--rev{grid-template-columns:.85fr 1.15fr}
@media(max-width:880px){.split,.split--wide,.split--wide.split--rev{grid-template-columns:1fr;gap:30px}.split--rev .split__media{order:-1}}

/* inline mini-feature rows (instead of icon grid) */
.feat-rows{display:flex;flex-direction:column;gap:14px;margin-top:8px}
.feat-row{display:flex;gap:14px;align-items:flex-start}
.feat-row img{width:46px;height:46px;object-fit:contain;flex:0 0 46px;filter:drop-shadow(2px 2px 0 rgba(10,4,32,.3))}
.feat-row h4{margin:0 0 2px;font-size:1.02rem}
.feat-row p{margin:0;font-size:.9rem}

/* shuriken + check lists */
.shu-list{list-style:none;padding:0;margin:0}
.shu-list li{display:flex;gap:12px;align-items:flex-start;margin-bottom:13px;color:var(--muted)}
.shu-list li::before{content:"";flex:0 0 18px;height:18px;margin-top:4px;background:url('../img/shuriken.png') center/contain no-repeat}
.check-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}
.check-list li{display:flex;gap:12px;align-items:flex-start;color:var(--muted)}
.check-list li::before{content:"";flex:0 0 22px;height:22px;margin-top:1px;border-radius:7px;border:2px solid var(--outline);background:var(--teal) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M5 12.5 L10 17 L19 7' fill='none' stroke='%23062318' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'/></svg>") center/13px no-repeat;box-shadow:2px 2px 0 var(--outline)}

/* sec heads */
.sec-head{margin-bottom:50px}
.sec-head--row{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;flex-wrap:wrap}

/* ===================== STEPPER ===================== */
.stepper__tabs{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-bottom:1px solid var(--line);margin-bottom:50px}
.stepper__tab{text-align:center;padding:22px 16px;cursor:pointer;border:0;border-bottom:3px solid transparent;background:none;font-family:inherit;color:inherit;transition:.2s}
.stepper__tab .s-n{font-size:.72rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-2);display:block;margin-bottom:6px}
.stepper__tab .s-t{font-weight:800;font-size:1.04rem;color:var(--muted)}
.stepper__tab:hover .s-t{color:var(--ink)}
.stepper__tab.active{border-bottom-color:var(--teal);background:linear-gradient(180deg,rgba(42,238,199,.06),transparent)}
.stepper__tab.active .s-n,.stepper__tab.active .s-t{color:var(--teal)}
.stepper__tab.active .s-t{color:var(--ink)}
.stepper__pane{display:none}
.stepper__pane.active{display:grid;grid-template-columns:1fr 1.05fr;gap:54px;align-items:center}
.stepper__art{display:grid;place-items:center}
.stepper__art img{max-height:380px;filter:drop-shadow(0 26px 50px rgba(0,0,0,.5))}
/* big-icon variant (no ninja illustration) */
.stepper__art--icon{min-height:300px}
.stepper__art--icon .ico-wrap{width:230px;height:230px;border-radius:32px;background:radial-gradient(120% 120% at 30% 20%,rgba(42,238,199,.14),rgba(251,0,150,.1) 70%,transparent);border:1px solid var(--line-teal);display:grid;place-items:center;box-shadow:var(--shadow-soft)}
.stepper__art--icon .ico-wrap img{width:130px;height:130px;max-height:none;object-fit:contain;filter:drop-shadow(0 10px 22px rgba(0,0,0,.45))}
@media(max-width:880px){.stepper__tabs{grid-template-columns:repeat(2,1fr)}.stepper__pane.active{grid-template-columns:1fr}.stepper__art{order:-1}}

/* ===================== CAROUSEL ===================== */
.carousel{position:relative}
.carousel__track{display:flex;gap:22px;overflow-x:auto;scroll-snap-type:x mandatory;padding:6px 2px 18px;scrollbar-width:none}
.carousel__track::-webkit-scrollbar{display:none}
.carousel__card{scroll-snap-align:start;flex:0 0 320px;max-width:320px}
.carousel__nav{display:flex;gap:10px;justify-content:flex-end;margin-bottom:18px}
.carousel__btn{width:46px;height:46px;border-radius:12px;border:2px solid var(--line);background:var(--bg-2);color:var(--ink);cursor:pointer;font-size:1.1rem;display:grid;place-items:center;transition:.18s}
.carousel__btn:hover{border-color:var(--teal);color:var(--teal)}
@media(max-width:640px){.carousel__card{flex-basis:84%;max-width:84%}}

/* cards */
.card{background:linear-gradient(180deg,var(--bg-2),var(--bg));border:1px solid var(--line);border-radius:var(--radius);padding:28px;transition:transform .2s,border-color .2s,box-shadow .2s}
.card:hover{transform:translateY(-5px);border-color:var(--line-teal);box-shadow:var(--shadow-soft)}
.card h3{font-size:1.18rem;font-weight:800}
.card p{font-size:.94rem;margin:0}
.card__icon{width:80px;height:80px;margin-bottom:14px;object-fit:contain;filter:drop-shadow(2px 3px 0 rgba(10,4,32,.35))}
.card__media{height:180px;border-radius:16px;background:radial-gradient(120% 90% at 50% 0%,rgba(42,238,199,.14),rgba(19,11,68,0));display:grid;place-items:center;margin-bottom:18px;border:1px solid var(--line)}
.card__media img{max-height:150px;object-fit:contain}
.card__link{display:inline-flex;align-items:center;gap:6px;margin-top:16px;font-weight:700;font-size:.9rem;color:var(--teal)}
.card__link::after{content:"→";transition:transform .2s}
.card:hover .card__link::after{transform:translateX(4px)}

/* quotes carousel cards */
.quote{background:var(--bg-2);border:2px solid var(--line);border-radius:18px;padding:26px}
.quote .mark{font-family:Georgia,serif;font-size:2.6rem;line-height:.4;color:var(--teal);display:block;height:20px}
.quote p{color:var(--ink);font-size:1.02rem;margin:12px 0 18px}
.quote .who{display:flex;align-items:center;gap:11px}
.quote .who .av{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--mag),var(--teal));display:grid;place-items:center;font-weight:800;color:#fff;font-size:.85rem;border:2px solid var(--outline)}
.quote .who small{display:block;color:var(--muted-2);font-size:.78rem}
.quote .who b{color:var(--ink);font-size:.9rem}

/* metrics inline */
.metrics{display:flex;gap:34px;flex-wrap:wrap}
.metrics .m .v{font-size:1.8rem;font-weight:900;font-style:italic;color:var(--teal);line-height:1}
.metrics .m .k{font-size:.78rem;color:var(--muted-2)}

/* panel mockup */
.mock{background:var(--bg-2);border:1px solid var(--line);border-radius:18px;padding:18px;box-shadow:var(--shadow-soft)}
.mock__bar{display:flex;align-items:center;gap:8px;margin-bottom:14px}
.mock__dot{width:10px;height:10px;border-radius:50%}
.mock__stat{display:flex;justify-content:space-between;align-items:center;background:var(--bg-3);border:1px solid var(--line);border-radius:12px;padding:14px 16px;margin-bottom:10px}
.mock__stat .big{font-size:1.4rem;font-weight:900;font-style:italic;color:var(--teal)}
.bars{display:flex;align-items:flex-end;gap:8px;height:96px;padding:10px 4px 0}
.bars i{flex:1;background:linear-gradient(180deg,var(--teal),rgba(42,238,199,.25));border-radius:5px 5px 0 0;display:block}

/* framework rail */
.rail{display:flex;gap:14px;flex-wrap:wrap;align-items:stretch;justify-content:center}
.rail__node{flex:1 1 150px;max-width:185px;background:var(--bg-2);border:1px solid var(--line);border-radius:16px;padding:22px 16px;text-align:center}
.rail__node.future{opacity:.55;border-style:dashed}
.rail__node .ic{width:48px;height:48px;object-fit:contain;margin:0 auto 8px}
.rail__node h4{margin:0 0 4px;font-size:1.04rem}
.rail__node p{margin:0;font-size:.8rem}
.rail__arrow{align-self:center;color:var(--teal);font-size:1.5rem}
@media(max-width:760px){.rail__arrow{transform:rotate(90deg)}}

/* CTA band */
.cta-band{background:linear-gradient(180deg,rgba(19,11,68,.6),rgba(19,11,68,.92)),url('../img/bg.png') center/cover;border:2px solid var(--line-teal);border-radius:28px;padding:68px 40px;text-align:center}

/* ===================== DARK FOOTER (bigger logo) ===================== */
.footer{border-top:1px solid var(--line);padding:72px 0 40px;margin-top:0;background:linear-gradient(180deg,#0d0730,#0b0626)}
.footer h4{font-size:.95rem;font-style:italic;text-transform:uppercase;color:var(--ink);margin:0 0 14px}
.footer a{display:block;color:var(--muted);font-size:.92rem;padding:5px 0}
.footer a:hover{color:var(--teal)}
.footer p{color:var(--muted-2)}
.footer__logo img{height:84px;width:auto;margin-bottom:16px}
/* align all columns to the top, then nudge the link columns down to the logo baseline */
.footer__grid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr 1.1fr;gap:26px;align-items:start}
.footer__grid>div:not(:first-child){padding-top:30px}
/* contact channels: icon + text on one baseline */
.footer__grid a:has(.ic-ch){display:flex;align-items:center;gap:10px}
.ic-ch{width:18px;height:18px;flex:0 0 18px;fill:currentColor;opacity:.85}
.footer__bottom{margin-top:46px;padding-top:24px;border-top:1px solid var(--line);display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:.85rem;color:var(--muted-2)}
@media(max-width:860px){.footer__grid{grid-template-columns:1fr 1fr 1fr}}
@media(max-width:560px){.footer__grid{grid-template-columns:1fr 1fr}}

/* util */
.mt-s{margin-top:14px}.mt-m{margin-top:26px}.mt-l{margin-top:46px}
.flex{display:flex}.gap{gap:14px}.wrapf{flex-wrap:wrap}.aic{align-items:center}.jcc{justify-content:center}

/* hero trust stats (inline row under hero copy) */
.hero__stats{display:flex;gap:30px;margin-top:42px;flex-wrap:wrap}
.hero__stats .num{display:block;font-size:1.7rem;font-weight:900;font-style:italic;color:var(--teal);line-height:1.1}
.hero__stats .lbl{display:block;font-size:.82rem;color:var(--muted-2);max-width:18ch;margin-top:4px}

/* hero 3-point list (normal flowing text, shuriken bullet) */
.hero__points{list-style:none;padding:0;margin:24px 0 30px;max-width:42ch}
.hero__points li{position:relative;padding-left:30px;font-size:1.08rem;line-height:1.55;margin-bottom:16px;color:var(--muted)}
.hero__points li::before{content:"";position:absolute;left:0;top:.3em;width:18px;height:18px;background:url('../img/shuriken.png') center/contain no-repeat}
.hero__points li b{color:var(--ink);font-weight:700}

/* Industry Insights — blog post cards with big cover (from 2.0) */
.post{display:flex;flex-direction:column;height:100%}
.post__thumb{height:180px;border-radius:14px;margin-bottom:16px;display:grid;place-items:center;border:1px solid var(--line);overflow:hidden;position:relative}
.post__thumb img{width:100%;height:100%;object-fit:cover}
.post__thumb img.cover-ico{width:auto;height:auto;max-height:120px;max-width:60%;object-fit:contain;margin:auto;filter:drop-shadow(0 8px 16px rgba(0,0,0,.4))}
.post__thumb--ai{background:linear-gradient(135deg,#2a1466,#fb0096)}
.post__thumb--seo{background:linear-gradient(135deg,#0d2f47,#2aeec7)}
.post__thumb--reg{background:linear-gradient(135deg,#1c1160,#7b45f0)}
.post__thu
/* simple dropdown menu — links only, no icons/descriptions */
.nav__menu--simple{min-width:170px}
.nav__menu--simple a{display:block;padding:10px 14px;font-size:.94rem}
.nav__menu--simple a small{display:none}

/* ============================================================
   SUBPAGE primitives (KB / Insights / Cases / Advertisers)
   ============================================================ */
/* unified page header (same rhythm on every subpage + articles) */
.page-head{padding:48px 0 32px;border-bottom:1px solid var(--line)}
.crumb{font-size:.85rem;color:var(--muted-2);margin-bottom:18px;letter-spacing:.01em}
.crumb a{color:var(--muted)}
.crumb a:hover{color:var(--teal)}
.page-head .eyebrow{margin-bottom:12px}
.page-head h1{margin-bottom:0}
.page-head .lead{margin-top:16px}
/* hero pages: pull the crumb up to the same top rhythm as page-head */
.hero{padding-top:48px}
.hero>.wrap:first-child .crumb{margin-bottom:8px}
/* subpage heroes (Network, Media Buying): a breadcrumb sits above the grid.
   Pin the grid content to the top so different illustration heights don't shift
   the heading — keeps top spacing identical across subpages. */
.hero .crumb + .hero__grid{align-items:start}
.hero .crumb + .hero__grid > div:first-child{padding-top:4px}
.search{display:flex;align-items:center;gap:10px;background:var(--bg-2);border:2px solid var(--line);border-radius:14px;padding:13px 18px}
.search input{flex:1;background:none;border:0;color:var(--ink);font-size:1rem;outline:none;font-family:inherit}
.search input::placeholder{color:var(--muted-2)}

/* KB documentation layout */
.kb-layout{display:grid;grid-template-columns:250px 1fr;gap:40px;align-items:start}
.kb-side{position:sticky;top:108px}
.kb-side h4{font-size:.76rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted-2);margin:18px 0 8px}
.kb-side a{display:block;color:var(--muted);padding:7px 12px;border-radius:9px;font-size:.92rem}
.kb-side a:hover,.kb-side a.active{background:rgba(42,238,199,.08);color:var(--teal)}
@media(max-width:820px){.kb-layout{grid-template-columns:1fr}.kb-side{position:static}}

/* Insights featured post */
.feature-post{display:grid;grid-template-columns:1.1fr .9fr;gap:0;background:var(--bg-2);border:1px solid var(--line);border-radius:22px;overflow:hidden;text-decoration:none}
.feature-post:hover{border-color:var(--line-teal);box-shadow:var(--shadow-soft)}
.feature-post__img{background:linear-gradient(135deg,#1c1160,#0b0626);min-height:300px;display:grid;place-items:center}
.feature-post__img img{width:64%}
.feature-post__body{padding:38px}
@media(max-width:760px){.feature-post{grid-template-columns:1fr}}

/* Case study metrics + stages */
.cs-metrics{display:flex;gap:26px;margin:18px 0;flex-wrap:wrap}
.cs-metrics .m .v{font-size:1.5rem;font-weight:900;font-style:italic;color:var(--teal);line-height:1}
.cs-metrics .m .k{font-size:.76rem;color:var(--muted-2)}
.cs-stage{border-left:2px solid var(--line-teal);padding-left:18px}
.cs-stage h4{font-size:.82rem;text-transform:uppercase;letter-spacing:.08em;color:var(--mag);margin-bottom:4px}
.cs-stage p{margin:0;font-size:.94rem}
.cs-card{display:flex;flex-direction:column;height:100%}

/* article (KB / insight / case detail body) */
.article{max-width:760px}
.article h2{margin-top:1.6em;font-style:normal;text-transform:none;font-size:1.5rem}
.article p,.article li{color:#c8c3e6}
.article ul{padding-left:1.2em}
.article .callout{background:rgba(42,238,199,.07);border:1px solid var(--line-teal);border-radius:14px;padding:18px 22px;margin:24px 0}
.article .callout strong{color:var(--teal)}
.article__cover{height:300px;border-radius:18px;margin:24px 0 8px;display:grid;place-items:center;border:1px solid var(--line)}
.article__cover img{height:150px}
/* KB glossary list */
.kb-gloss{margin:8px 0 0}
.kb-gloss dt{color:var(--ink);font-weight:800;margin-top:18px;font-size:1.02rem}
.kb-gloss dd{margin:4px 0 0;color:#d6d1f0;padding-left:0;border-left:2px solid var(--line-teal);padding:2px 0 2px 14px}

/* ============================================================
   CAMPAIGNS / offers list (toned-down, dark)
   ============================================================ */
.page-head.center{text-align:center}
.page-head.center .measure{margin-inline:auto}
.search-bar{display:grid;grid-template-columns:1fr 190px 190px auto;gap:12px;background:var(--bg-2);border:1px solid var(--line);border-radius:16px;padding:14px}
.search-bar input,.search-bar select{background:var(--bg-3);border:1px solid var(--line);border-radius:11px;color:var(--ink);padding:12px 14px;font-family:inherit;font-size:.95rem;outline:none}
.search-bar input:focus,.search-bar select:focus{border-color:var(--teal)}
@media(max-width:820px){.search-bar{grid-template-columns:1fr 1fr}}
.offers{display:flex;flex-direction:column;gap:14px}
.offer{display:flex;align-items:center;gap:18px;background:var(--bg-2);border:1px solid var(--line);border-radius:16px;padding:18px 22px;transition:transform .15s,border-color .2s,box-shadow .2s}
.offer:hover{transform:translateY(-2px);border-color:var(--line-teal);box-shadow:var(--shadow-soft)}
.offer__img{flex:0 0 56px;width:56px;height:56px;border-radius:12px;background:var(--bg-3);border:1px solid var(--line-teal);color:var(--teal);font-weight:900;font-size:.92rem}
.offer__main{flex:1;min-width:0}
.offer__title{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.offer__title h3{margin:0;font-size:1.12rem;font-weight:800}
.offer__meta{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:7px;color:var(--muted-2);font-size:.84rem}
.offer__pay{flex:0 0 auto;text-align:right}
.offer__pay .l{font-size:.74rem;color:var(--muted-2);display:block}
.offer__pay .v{font-size:1.18rem;font-weight:900;color:var(--ink)}
@media(max-width:820px){.offer{flex-wrap:wrap}.offer__pay{margin-left:auto}}

/* channel icons (footer + contact) */
/* ============================================================
   LONG-FORM ARTICLE (insight posts)
   ============================================================ */
.post-wrap{max-width:760px;margin:0 auto}
/* article header shares the page-head rhythm; date lives in the eyebrow up top */
.post-head{padding:48px 0 28px}
.post-head .crumb{margin-bottom:18px}
.post-head .eyebrow{margin-bottom:14px}
.post-head h1{margin:0 0 20px}
.post-byline{display:flex;align-items:center;gap:12px;flex-wrap:wrap;color:var(--muted-2);font-size:.9rem;margin-top:0}
.post-byline .chip{padding:5px 14px 5px 7px}
.article h2{margin:1.8em 0 .5em;font-style:normal;text-transform:none;font-size:1.55rem;color:var(--ink)}
.article h3{margin:1.3em 0 .4em;font-style:normal;text-transform:none;font-size:1.15rem;color:var(--ink)}
.article p{margin:0 0 1.15em}
.article p,.article li{font-size:1.04rem;line-height:1.75}
.article ol{margin:.6em 0 1.4em}
.article li{margin-bottom:.4em}
.article strong{color:var(--ink)}
.article a{color:var(--teal);text-decoration:underline;text-underline-offset:3px}
.article .lead{font-size:1.18rem;color:var(--muted)}

/* takeaway box */
.takeaway{background:linear-gradient(135deg,rgba(42,238,199,.08),rgba(123,69,240,.06));border:1px solid var(--line-teal);border-left:4px solid var(--teal);border-radius:14px;padding:22px 26px;margin:28px 0}
.takeaway h3{margin:0 0 8px;color:var(--teal);font-size:1.05rem;text-transform:uppercase;letter-spacing:.06em;font-weight:800}
.takeaway p{margin:0;color:var(--ink)}

/* mini playbook */
.playbook{background:var(--bg-2);border:1px solid var(--line);border-radius:16px;padding:24px 28px;margin:28px 0}
.playbook h3{margin:0 0 12px;font-size:1.1rem}
.playbook ul{list-style:none;padding:0;margin:0}
.playbook li{position:relative;padding-left:30px;margin-bottom:11px;color:#cfc9ec}
.playbook li::before{content:"";position:absolute;left:0;top:.3em;width:18px;height:18px;border-radius:6px;border:2px solid var(--outline);background:var(--teal) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M5 12.5 L10 17 L19 7' fill='none' stroke='%23062318' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'/></svg>") center/12px no-repeat}

/* FAQ */
.faq{margin:28px 0}
.faq details{border:1px solid var(--line);border-radius:12px;padding:0 18px;margin-bottom:10px;background:var(--bg-2)}
.faq summary{cursor:pointer;font-weight:700;color:var(--ink);padding:16px 0;list-style:none;position:relative;font-size:1.02rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:0;top:14px;color:var(--teal);font-size:1.3rem;font-weight:400}
.faq details[open] summary::after{content:"–"}
.faq details[open] summary{border-bottom:1px solid var(--line)}
.faq details p{padding:14px 0;margin:0}

/* author / cta strip at end */
.post-cta{display:grid;grid-template-columns:120px 1fr;gap:24px;align-items:center;background:var(--bg-2);border:1px solid var(--line-teal);border-radius:18px;padding:26px;margin:36px 0 0}
.post-cta img{filter:drop-shadow(0 10px 20px rgba(0,0,0,.4))}
@media(max-width:560px){.post-cta{grid-template-columns:1fr;text-align:center}.post-cta img{max-width:120px;margin:0 auto}}

/* big topical cover */
.post-cover{height:260px;border-radius:18px;margin:22px 0 8px;display:grid;place-items:center;border:1px solid var(--line)}
.post-cover img{max-height:130px;max-width:55%;object-fit:contain;filter:drop-shadow(0 10px 20px rgba(0,0,0,.45))}
.post-cover--ai{background:linear-gradient(135deg,#2a1466,#fb0096)}
.post-cover--seo{background:linear-gradient(135deg,#0d2f47,#2aeec7)}
.post-cover--reg{background:linear-gradient(135deg,#1c1160,#7b45f0)}
.post-cover--ads{background:linear-gradient(135deg,#13314a,#18b894)}
.post-cover--macro{background:linear-gradient(135deg,#241062,#0b0626)}

/* ============================================================
   ARTICLE polish — sparkle headings, shuriken lists, tables
   ============================================================ */
/* readable body, slightly brighter */
.article p,.article li{color:#d6d1f0}
.article .lead{color:#e8e5f7}

/* H2 with teal sparkle marker */
.article h2{position:relative;padding-left:30px}
.article h2::before{content:"";position:absolute;left:0;top:.18em;width:20px;height:20px;background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M12 0.5 C13 7 17 11 23.5 12 C17 13 13 17 12 23.5 C11 17 7 13 0.5 12 C7 11 11 7 12 0.5 Z' fill='%232aeec7'/></svg>") center/contain no-repeat}

/* article unordered lists -> shuriken bullets */
.article ul{list-style:none;padding-left:0}
.article ul li{position:relative;padding-left:30px;margin-bottom:11px}
.article ul li::before{content:"";position:absolute;left:0;top:.36em;width:17px;height:17px;background:url('../img/shuriken.png') center/contain no-repeat}
/* ordered lists keep numbers but style them */
.article ol{counter-reset:s;list-style:none;padding-left:0}
.article ol li{position:relative;padding-left:40px;margin-bottom:12px;counter-increment:s}
.article ol li::before{content:counter(s);position:absolute;left:0;top:0;width:26px;height:26px;border-radius:8px;background:rgba(42,238,199,.12);border:1px solid var(--line-teal);color:var(--teal);font-weight:800;font-size:.82rem;display:grid;place-items:center}

/* smaller, neater article cover */
.post-cover{height:200px}
.post-cover img{max-height:110px;max-width:42%}
/* comparison / data table */
.a-table{width:100%;border-collapse:separate;border-spacing:0;margin:24px 0;border:1px solid var(--line);border-radius:14px;overflow:hidden;font-size:.96rem}
.a-table th,.a-table td{padding:13px 16px;text-align:left;border-bottom:1px solid var(--line)}
.a-table thead th{background:var(--bg-3);color:var(--ink);font-weight:800;font-size:.82rem;text-transform:uppercase;letter-spacing:.04em}
.a-table tbody tr:last-child td{border-bottom:0}
.a-table tbody tr:nth-child(even){background:rgba(255,255,255,.02)}
.a-table td:first-child{color:var(--ink);font-weight:600}
.a-table .good{color:var(--teal);font-weight:700}
.a-table .bad{color:var(--mag-2);font-weight:700}

/* pull-stat strip inside article */
.a-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:26px 0}
@media(max-width:560px){.a-stats{grid-template-columns:1fr}}
.a-stats .s{background:var(--bg-2);border:1px solid var(--line);border-radius:14px;padding:18px 20px;text-align:center}
.a-stats .s .v{font-size:1.7rem;font-weight:900;font-style:italic;color:var(--teal);line-height:1}
.a-stats .s .k{font-size:.8rem;color:var(--muted-2);margin-top:5px}

/* inline mini-card row (icon + text) */
.a-rows{display:grid;gap:14px;margin:24px 0}
.a-row{display:flex;gap:14px;align-items:flex-start;background:var(--bg-2);border:1px solid var(--line);border-radius:14px;padding:16px 18px}
.a-row img{width:42px;height:42px;flex:0 0 42px;object-fit:contain;filter:drop-shadow(2px 2px 0 rgba(10,4,32,.3))}
.a-row h4{margin:0 0 3px;font-size:1.02rem}
.a-row p{margin:0;font-size:.92rem}

/* KB glossary list */
.kb-gloss{margin:8px 0 0}
.kb-gloss dt{color:var(--ink);font-weight:800;margin-top:18px;font-size:1.02rem}
.kb-gloss dd{margin:4px 0 0;color:#d6d1f0;border-left:2px solid var(--line-teal);padding:2px 0 2px 14px}

/* ===== v5 additions: Laravel/Livewire integration (contact, offers) ===== */

/* Contact page layout */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
@media(max-width:820px){.contact-grid{grid-template-columns:1fr}}
.contact-channels{display:flex;flex-direction:column;gap:12px;margin-top:8px}
.contact-channels a{display:inline-flex;align-items:center;gap:10px;color:inherit;text-decoration:none;opacity:.9}
.contact-channels a:hover{opacity:1}
.contact-channels .ic-ch{width:20px;height:20px;fill:currentColor}
.contact-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:560px){.contact-row{grid-template-columns:1fr}}
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.field label{font-size:.9rem;font-weight:600}
.field .req{color:#ff5470}
.field input,.field textarea{width:100%;padding:12px 14px;border-radius:10px;border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.04);color:inherit;font:inherit}
.field input:focus,.field textarea:focus{outline:none;border-color:#19d3c5}
.captcha{margin:8px 0 20px}

/* Form notes (success / error) */
.form-note{padding:10px 14px;border-radius:10px;margin-bottom:14px;font-size:.92rem}
.form-note--ok{background:rgba(25,211,197,.12);border:1px solid rgba(25,211,197,.4)}
.form-note--err{background:rgba(255,84,112,.12);border:1px solid rgba(255,84,112,.4);color:#ff8198}

/* Offer card: logo image + type tag colours */
.offer__img img{max-width:100%;max-height:100%;object-fit:contain;border-radius:8px}
.tag--cpa{background:rgba(25,211,197,.18)}
.tag--cps{background:rgba(80,150,255,.18)}
.tag--cpl{background:rgba(255,180,60,.18)}

/* Livewire helpers */
.lw-spin{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:lw-spin .6s linear infinite;vertical-align:middle;margin-left:6px}
@keyframes lw-spin{to{transform:rotate(360deg)}}
.offers-empty{padding:40px;text-align:center;opacity:.7}
.offers-pagination{display:flex;justify-content:center;margin-top:24px}
.offers-pagination nav{display:flex;flex-direction:column;align-items:center;gap:10px}
.offers-pagination nav>p{margin:0;color:var(--muted-2);font-size:.85rem}
.offers-pagination ul,.offers-pagination .pagination{display:flex;flex-wrap:wrap;justify-content:center;gap:6px;list-style:none;margin:0;padding:0}
.offers-pagination li{list-style:none}
.offers-pagination a,.offers-pagination span{display:inline-flex;align-items:center;justify-content:center;min-width:38px;height:38px;padding:0 10px;border-radius:8px;border:1px solid rgba(255,255,255,.12);text-decoration:none;color:inherit}
.offers-pagination a:hover{background:rgba(255,255,255,.06)}
.offers-pagination .active span{background:#19d3c5;color:#0b0626;border-color:#19d3c5;font-weight:600}
.offers-pagination .disabled span{opacity:.4}


/* v5 fix: flagi i meta inline poziomo */
.offer__meta>span{display:inline-flex;align-items:center;gap:4px;flex-wrap:wrap}
.offer__meta img{display:inline-block;vertical-align:middle;border-radius:2px}

/* ===== v5: campaign detail (offers/show) ===== */
.camp-hero{display:grid;grid-template-columns:auto 1fr auto;gap:24px;align-items:center}
@media(max-width:760px){.camp-hero{grid-template-columns:1fr;gap:16px}}
.camp-hero__logo{width:96px;height:96px;border-radius:18px;display:grid;place-items:center;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  font-weight:800;font-size:1.4rem;color:#19d3c5;overflow:hidden}
.camp-hero__logo img{width:100%;height:100%;object-fit:contain}
.camp-meta{display:flex;flex-wrap:wrap;align-items:center;gap:14px;margin-top:10px;color:var(--muted-2);font-size:.9rem}
.camp-meta img{vertical-align:middle;border-radius:2px}
.camp-hero__pay{text-align:right;display:flex;flex-direction:column;align-items:flex-end}
@media(max-width:760px){.camp-hero__pay{align-items:flex-start;text-align:left}}
.camp-hero__pay .l{font-size:.8rem;color:var(--muted-2);text-transform:uppercase;letter-spacing:.04em}
.camp-hero__pay .v{font-size:1.6rem;font-weight:800;color:#fff}
.camp-facts{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media(max-width:620px){.camp-facts{grid-template-columns:repeat(2,1fr)}}
.camp-facts .f{padding:16px;border-radius:12px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1)}
.camp-facts .k{font-size:.78rem;color:var(--muted-2);text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px}
.camp-facts .v{font-size:1.05rem;font-weight:700;color:#fff}
.camp-desc{line-height:1.65;color:var(--muted-1)}
.camp-desc p{margin:0 0 14px}
.camp-desc h2,.camp-desc h3{color:#fff;margin:22px 0 10px}
.camp-desc ul{padding-left:20px;margin:0 0 14px}
.camp-desc li{margin:6px 0}
.camp-traffic p{margin:6px 0;color:var(--muted-1)}

/* v5 fix: zmniejsz odstęp ostatniej sekcji przed footerem (było ~146px łącznie) */
main > section:last-child,
section:last-of-type{padding-bottom:48px}
.footer{padding-top:56px}

/* ===== v2.0 fixes: campaign detail / offer flags / advertisers / paginacja ===== */

/* Flagi poziomo — camp-meta (detail) i offer__meta (lista) span z <img> */
.camp-meta > span{display:inline-flex;align-items:center;gap:4px;flex-wrap:wrap}
.camp-meta img{display:inline-block}

/* Campaign detail: równy odstęp góra/dół w hero i sekcjach */
.hero.s-deep{padding:56px 0}
.hero.s-deep .camp-hero{margin-top:24px}
section.s-dark{padding:56px 0}

/* Formularze 2.0: select bez stylów -> dopasuj do input */
.field select{
  width:100%;padding:12px 14px;border-radius:10px;
  border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.04);
  color:inherit;font:inherit;appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23999' d='M6 8 0 0h12z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;padding-right:38px;cursor:pointer;
}
.field select:focus{outline:none;border-color:#19d3c5}
.field select option{background:#1a0f44;color:#fff}

/* Advertisers: box po prawej — wypełnij wysokość, wycentruj treść, padding */
.adv-contact{
  display:flex;flex-direction:column;justify-content:center;align-items:center;
  text-align:center;height:100%;min-height:340px;padding:40px 32px;gap:6px;
}
.adv-contact p{margin:6px 0}
.adv-contact a{display:inline-flex;align-items:center;gap:8px;justify-content:center}
.adv-contact .ic-ch{width:18px;height:18px;fill:currentColor}

/* split: równa wysokość kolumn (formularz vs box) */
.split{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:stretch}
@media(max-width:820px){.split{grid-template-columns:1fr}}


/* Paginacja Bootstrap-5: brak BS CSS -> ręcznie ogarnij responsywność i wygląd */
.offers-pagination .d-sm-none{display:none !important}      /* ukryj mobilny Previous/Next */
.offers-pagination nav{display:flex;flex-direction:column;align-items:center;gap:12px;width:100%}
.offers-pagination .d-none.d-sm-flex,
.offers-pagination nav > div:last-child{display:flex !important;flex-direction:column;align-items:center;gap:10px;width:100%}
.offers-pagination .small.text-muted,
.offers-pagination p{margin:0;color:var(--muted-2);font-size:.85rem}
.offers-pagination ul.pagination{display:flex;flex-wrap:wrap;justify-content:center;gap:6px;list-style:none;margin:0;padding:0}
.offers-pagination li.page-item{list-style:none}
.offers-pagination .page-link{display:inline-flex;align-items:center;justify-content:center;min-width:38px;height:38px;padding:0 10px;border-radius:8px;border:1px solid rgba(255,255,255,.12);text-decoration:none;color:inherit;background:transparent}
.offers-pagination .page-link:hover{background:rgba(255,255,255,.06)}
.offers-pagination .page-item.active .page-link{background:#19d3c5;color:#0b0626;border-color:#19d3c5;font-weight:600}
.offers-pagination .page-item.disabled .page-link{opacity:.4;pointer-events:none}
