/* ============================================================
   Centrum Ubezpieczeń Pro — main.css  ·  "Immersive Trust"
   Bricolage Grotesque + Manrope · granat/turkus/aqua + indygo
   ============================================================ */
:root{
  --navy:#0e2a47; --navy-deep:#081c33; --indigo:#1b2f6b;
  --teal:#1e9e8a; --aqua:#2fd6b8; --aqua-soft:#7fe6d3;
  --ink:#13202e; --muted:#5a6b7e; --line:#e7edf4;
  --bg:#ffffff; --bg-soft:#f5f8fb; --gold:#e0a943;
  --radius:16px; --radius-lg:24px; --radius-xl:32px;
  --gutter:clamp(20px,4vw,60px); --maxw:1200px;
  --shadow-sm:0 1px 3px rgba(14,42,71,.05),0 10px 30px rgba(14,42,71,.06);
  --shadow-md:0 10px 30px rgba(14,42,71,.10),0 30px 70px rgba(14,42,71,.12);
  --shadow-glow:0 18px 50px rgba(30,158,138,.28);
  --fd:"Bricolage Grotesque",Georgia,serif;
  --fb:"Manrope",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --ease:cubic-bezier(.22,1,.36,1);
}
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{margin:0;font-family:var(--fb);color:var(--ink);background:var(--bg);font-size:17px;line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:var(--teal);text-decoration:none}
h1,h2,h3,h4{font-family:var(--fd);color:var(--navy);line-height:1.08;font-weight:700;letter-spacing:-.02em;margin:0 0 .4em}
.cup-wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter)}
.cup-wrap--narrow{max-width:760px}
.cup-wrap--wide{max-width:1100px}
.cup-skip{position:absolute;left:-999px}
.cup-skip:focus{left:16px;top:50px;z-index:300;background:#fff;padding:8px 14px;border-radius:8px}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease);transition-delay:var(--d,0s)}
.reveal.is-visible{opacity:1;transform:none}

/* ---------- Progress bar ---------- */
.cup-progress{position:fixed;top:0;left:0;right:0;height:3px;z-index:200;background:transparent}
#cup-progress-bar{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--teal),var(--aqua));box-shadow:0 0 12px rgba(47,214,184,.6);transition:width .1s linear}

/* ---------- Header ---------- */
.cup-header{position:sticky;top:0;z-index:150;background:rgba(255,255,255,.72);backdrop-filter:saturate(180%) blur(14px);border-bottom:1px solid transparent;transition:background .3s,box-shadow .3s,border-color .3s}
.cup-header.is-scrolled{background:rgba(255,255,255,.92);box-shadow:var(--shadow-sm);border-color:var(--line)}
.cup-header__inner{max-width:var(--maxw);margin:0 auto;padding:16px var(--gutter);display:flex;align-items:center;gap:24px;transition:padding .3s}
.cup-header.is-scrolled .cup-header__inner{padding:10px var(--gutter)}
.cup-logo{display:inline-flex;align-items:center;gap:11px}
.custom-logo{height:50px;width:auto}
.cup-logo__icon{height:44px;width:auto;transition:transform .4s var(--ease)}
.cup-logo:hover .cup-logo__icon{transform:rotate(-8deg) scale(1.06)}
.cup-logo__text{font-family:var(--fd);font-weight:700;color:var(--navy);font-size:19px;line-height:.98;display:flex;flex-direction:column;letter-spacing:-.02em}
.cup-logo__text span{color:var(--teal);font-weight:600;font-size:.82em}
.cup-nav{margin-left:auto}
.cup-nav__list{list-style:none;display:flex;gap:2px;margin:0;padding:0;flex-wrap:wrap}
.cup-nav__list a{position:relative;display:inline-block;padding:9px 13px;color:var(--navy);font-weight:600;font-size:14.5px;border-radius:9px;transition:color .15s}
.cup-nav__list a::after{content:"";position:absolute;left:13px;right:13px;bottom:6px;height:2px;background:var(--aqua);border-radius:2px;transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.cup-nav__list a:hover{color:var(--teal)}
.cup-nav__list a:hover::after,.cup-nav__list .current-cat a::after,.cup-nav__list .current-menu-item a::after{transform:scaleX(1)}
.cup-burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px;margin-left:auto}
.cup-burger span{width:24px;height:2px;background:var(--navy);border-radius:2px;transition:.3s var(--ease)}

/* ---------- Buttons ---------- */
.cup-btn{display:inline-flex;align-items:center;gap:9px;border:0;border-radius:999px;padding:15px 26px;font:inherit;font-weight:700;font-size:16px;cursor:pointer;transition:transform .15s var(--ease),box-shadow .2s,background .2s}
.cup-btn--accent{background:linear-gradient(120deg,var(--teal),var(--aqua));color:#062a24}
.cup-btn--accent:hover{transform:translateY(-2px);box-shadow:var(--shadow-glow);color:#062a24}
.cup-btn--light{background:#fff;color:var(--navy)}
.cup-btn--light:hover{transform:translateY(-2px);box-shadow:0 18px 40px rgba(0,0,0,.25)}

/* ---------- HERO ---------- */
.cup-hero{position:relative;overflow:hidden;color:#fff;isolation:isolate;background:var(--navy-deep)}
.cup-hero__inner{position:relative;max-width:var(--maxw);margin:0 auto;padding:clamp(64px,10vw,128px) var(--gutter) clamp(72px,9vw,118px);z-index:2;display:grid;grid-template-columns:1.04fr .96fr;gap:clamp(28px,5vw,60px);align-items:center}
.cup-hero__content{max-width:600px}
.cup-hero__aurora{position:absolute;inset:0;z-index:0;filter:blur(60px) saturate(140%)}
.cup-blob{position:absolute;border-radius:50%;opacity:.55;mix-blend-mode:screen;animation:cup-float 18s var(--ease) infinite alternate}
.cup-blob--1{width:46vw;height:46vw;left:-8vw;top:-12vw;background:radial-gradient(circle,#1e9e8a,transparent 65%)}
.cup-blob--2{width:50vw;height:50vw;right:-12vw;top:-6vw;background:radial-gradient(circle,#2a59b5,transparent 65%);animation-delay:-6s}
.cup-blob--3{width:40vw;height:40vw;left:30vw;bottom:-22vw;background:radial-gradient(circle,#2fd6b8,transparent 60%);animation-delay:-11s}
@keyframes cup-float{0%{transform:translate(0,0) scale(1)}100%{transform:translate(4vw,3vw) scale(1.15)}}
.cup-hero__grain{position:absolute;inset:0;z-index:1;opacity:.06;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.cup-hero__shield{position:absolute;right:-30px;top:8%;width:min(44%,500px);z-index:1;opacity:.9;animation:cup-bob 7s var(--ease) infinite alternate}
@keyframes cup-bob{0%{transform:translateY(0) rotate(-3deg)}100%{transform:translateY(-22px) rotate(2deg)}}
.cup-eyebrow{display:inline-block;font-weight:700;font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--aqua-soft);margin:0 0 18px}
.cup-hero__title{color:#fff;font-size:clamp(38px,6.4vw,74px);font-weight:800;letter-spacing:-.03em;margin:0 0 22px;max-width:16ch}
.cup-hero__title span{display:block}
.cup-hero__title em{font-style:italic;font-weight:600}
.cup-grad{background:linear-gradient(100deg,var(--aqua),var(--aqua-soft) 60%,#cfeee6);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.cup-hero__lede{font-size:clamp(17px,2vw,21px);color:#c4d3e3;max-width:54ch;margin:0 0 34px;line-height:1.6}

/* Finder glass */
.cup-finder{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.16);border-radius:var(--radius-xl);padding:24px;max-width:680px;backdrop-filter:blur(10px);box-shadow:0 20px 60px rgba(0,0,0,.3)}
.cup-finder__label{display:block;font-size:12.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:#9fb6cc;margin-bottom:12px}
.cup-finder__row{display:flex;gap:12px;flex-wrap:wrap}
.cup-finder__select-wrap{position:relative;flex:1 1 260px;display:flex;align-items:center}
.cup-finder__select-wrap .cup-ico{position:absolute;left:16px;width:22px;height:22px;color:var(--teal);pointer-events:none}
.cup-finder__select{width:100%;appearance:none;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%230e2a47' stroke-width='2'%3E%3Cpath d='M3 5l4 4 4-4'/%3E%3C/svg%3E") no-repeat right 18px center;border:0;border-radius:14px;padding:16px 44px 16px 46px;font:inherit;font-size:16px;font-weight:500;color:var(--ink);cursor:pointer}
.cup-finder__note{margin:14px 0 0;font-size:13.5px;color:#a9bccf}
.cup-finder__note strong{color:#fff}
/* Custom dropdown (zamiast natywnego select) */
.cup-select{position:relative;flex:1 1 260px}
.cup-select__btn{width:100%;display:flex;align-items:center;gap:10px;background:#fff;border:0;border-radius:14px;padding:15px 16px;font:inherit;font-size:16px;font-weight:500;color:var(--ink);cursor:pointer;text-align:left}
.cup-select__btn .cup-ico{width:22px;height:22px;color:var(--teal);flex:0 0 auto}
.cup-select__label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cup-select__chev{width:14px;height:14px;color:var(--navy);flex:0 0 auto;transition:transform .25s var(--ease)}
.cup-select.is-open .cup-select__chev{transform:rotate(180deg)}
.cup-select__menu{position:absolute;top:calc(100% + 10px);left:0;right:0;z-index:40;list-style:none;margin:0;padding:7px;background:#fff;border-radius:18px;box-shadow:var(--shadow-md);max-height:0;overflow:hidden;opacity:0;transform:translateY(-8px) scale(.98);transform-origin:top;pointer-events:none;transition:opacity .22s,transform .22s var(--ease)}
.cup-select.is-open .cup-select__menu{max-height:60vh;opacity:1;transform:none;pointer-events:auto;overflow-y:auto}
.cup-select__opt{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:12px;cursor:pointer;color:var(--navy);font-weight:600;font-size:15.5px;transition:background .15s,color .15s;outline:none}
.cup-select__opt:hover,.cup-select__opt:focus-visible{background:var(--teal-tint);color:var(--teal-600)}
.cup-select__opt .cup-ico{width:36px;height:36px;flex:0 0 auto;padding:7px;border-radius:10px;background:var(--teal-tint);color:var(--navy)}
.cup-select__opt:hover .cup-ico,.cup-select__opt:focus-visible .cup-ico{background:#fff;color:var(--teal-600)}
.cup-scroll{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);width:26px;height:42px;border:2px solid rgba(255,255,255,.35);border-radius:14px;z-index:3}
.cup-scroll span{position:absolute;left:50%;top:8px;width:4px;height:8px;background:var(--aqua);border-radius:2px;transform:translateX(-50%);animation:cup-scrolldot 1.8s infinite}
@keyframes cup-scrolldot{0%{opacity:0;top:8px}40%{opacity:1}80%{opacity:0;top:22px}100%{opacity:0}}

/* ---------- Hero panel (glass „Twoja ochrona") ---------- */
.cup-hero__panel{position:relative;justify-self:end;width:100%;max-width:430px}
.cup-panel{position:relative;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:var(--radius-xl);padding:22px;backdrop-filter:blur(14px);box-shadow:0 30px 70px rgba(0,0,0,.35);animation:cup-bob 7s var(--ease) infinite alternate}
.cup-panel__halo{position:absolute;inset:-2px;border-radius:inherit;background:radial-gradient(120% 100% at 80% 0,rgba(47,214,184,.35),transparent 55%);filter:blur(22px);z-index:-1}
.cup-panel__head{display:flex;align-items:center;gap:10px;padding:2px 6px 15px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:8px}
.cup-panel__live{width:9px;height:9px;border-radius:50%;background:var(--aqua);animation:cup-pulse 2s infinite}
@keyframes cup-pulse{0%{box-shadow:0 0 0 0 rgba(47,214,184,.5)}70%{box-shadow:0 0 0 9px rgba(47,214,184,0)}100%{box-shadow:0 0 0 0 rgba(47,214,184,0)}}
.cup-panel__title{font-family:var(--fd);font-weight:700;color:#fff;font-size:17px}
.cup-panel__badge{margin-left:auto;font-size:12px;font-weight:700;color:var(--aqua);background:rgba(47,214,184,.12);border:1px solid rgba(47,214,184,.3);padding:4px 10px;border-radius:999px}
.cup-panel__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:3px}
.cup-panel__list li{opacity:0;transform:translateX(12px);animation:cup-rowin .55s var(--ease) forwards;animation-delay:calc(.5s + var(--i,0)*.09s)}
@keyframes cup-rowin{to{opacity:1;transform:none}}
.cup-panel__list a{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:13px;color:#e7eef6;transition:background .18s,transform .18s var(--ease)}
.cup-panel__list a:hover{background:rgba(255,255,255,.08);transform:translateX(3px)}
.cup-panel__ico{display:inline-grid;place-items:center;width:38px;height:38px;border-radius:11px;background:rgba(47,214,184,.12);color:var(--aqua-soft);flex:0 0 auto}
.cup-panel__ico .cup-ico{width:21px;height:21px}
.cup-panel__name{font-weight:600;font-size:15px}
.cup-panel__chk{width:20px;height:20px;margin-left:auto;color:var(--aqua);flex:0 0 auto}
.cup-panel__foot{margin:14px 6px 2px;font-size:13px;color:#a9bccf;line-height:1.5}
.cup-panel__foot strong{color:#fff}
/* Hero art (ilustracja z logo) */
.cup-hero__art{position:relative;justify-self:center;width:100%;max-width:480px}
.cup-hero__art img{position:relative;z-index:1;width:100%;height:auto;animation:cup-bob 7s var(--ease) infinite alternate;filter:drop-shadow(0 24px 50px rgba(0,0,0,.4))}
.cup-hero__art-glow{position:absolute;inset:4% 6% 12%;border-radius:50%;background:radial-gradient(circle,rgba(47,214,184,.34),rgba(43,89,181,.18) 45%,transparent 68%);filter:blur(36px);z-index:0;animation:cup-pulseglow 6s ease-in-out infinite}
@keyframes cup-pulseglow{0%,100%{opacity:.65;transform:scale(.95)}50%{opacity:1;transform:scale(1.06)}}

/* ---------- Hero z pełnoekranowym zdjęciem ---------- */
.cup-hero--photo{min-height:clamp(560px,80vh,840px);display:flex;align-items:center;background:var(--navy-deep)}
.cup-hero__photo{position:absolute;inset:0;z-index:0;overflow:hidden}
.cup-hero__photo img{width:100%;height:100%;object-fit:cover;object-position:72% center;transform:scale(1.04);animation:cup-kenburns 22s ease-in-out infinite alternate}
@keyframes cup-kenburns{0%{transform:scale(1.04)}100%{transform:scale(1.12) translateX(-1.5%)}}
.cup-hero__scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(100deg,rgba(8,28,51,.97) 0%,rgba(8,28,51,.84) 30%,rgba(8,28,51,.52) 56%,rgba(8,28,51,.2) 100%)}
.cup-hero--photo .cup-hero__grain{z-index:2}
.cup-hero--photo .cup-hero__inner{display:block;width:100%}
.cup-hero--photo .cup-hero__content{max-width:640px}

/* ---------- Stats ---------- */
.cup-stats{background:var(--navy);color:#fff;position:relative;z-index:3;margin-top:-1px}
.cup-stats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;padding:42px var(--gutter)}
.cup-stat{display:flex;flex-direction:column;gap:4px;border-left:2px solid rgba(47,214,184,.5);padding-left:18px}
.cup-stat__num{font-family:var(--fd);font-size:clamp(34px,4.4vw,52px);font-weight:800;line-height:1;background:linear-gradient(120deg,#fff,var(--aqua-soft));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.cup-stat__lbl{color:#a9bccf;font-size:14.5px;font-weight:500}

/* ---------- Section heads ---------- */
.cup-section{padding:clamp(56px,8vw,104px) 0}
.cup-shead{text-align:center;max-width:640px;margin:0 auto clamp(36px,5vw,56px)}
.cup-shead--left{text-align:left;margin:0}
.cup-shead--row{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;text-align:left;max-width:none;flex-wrap:wrap}
.cup-kicker{display:inline-block;font-weight:700;font-size:12.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--teal);margin-bottom:12px;padding:6px 14px;background:rgba(30,158,138,.1);border-radius:999px}
.cup-kicker--light{color:var(--aqua-soft);background:rgba(255,255,255,.1)}
.cup-shead__title{font-size:clamp(28px,4vw,46px)}
.cup-shead__sub{color:var(--muted);font-size:18px;margin:.3em 0 0}
.cup-textlink{font-weight:700;color:var(--teal);white-space:nowrap}

/* ---------- Category cards (tilt+glow) ---------- */
.cup-cats{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px;perspective:1200px}
.cup-cat{position:relative;display:flex;flex-direction:column;gap:7px;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:30px 26px 24px;overflow:hidden;transform-style:preserve-3d;transition:transform .25s var(--ease),box-shadow .25s,border-color .25s}
.cup-cat:hover{box-shadow:var(--shadow-md);border-color:transparent}
.cup-cat__glow{position:absolute;inset:-1px;border-radius:inherit;opacity:0;background:radial-gradient(420px circle at var(--mx,50%) var(--my,0%),rgba(47,214,184,.18),transparent 45%);transition:opacity .3s;pointer-events:none}
.cup-cat:hover .cup-cat__glow{opacity:1}
.cup-cat__ico{display:inline-grid;place-items:center;width:58px;height:58px;border-radius:16px;background:linear-gradient(135deg,rgba(30,158,138,.12),rgba(47,214,184,.16));color:var(--navy);margin-bottom:12px;transition:background .25s,color .25s,transform .25s var(--ease)}
.cup-cat:hover .cup-cat__ico{background:linear-gradient(135deg,var(--navy),var(--indigo));color:#fff;transform:translateY(-3px)}
.cup-cat__ico .cup-ico{width:30px;height:30px}
.cup-cat:hover .cup-cat__ico .cup-ico{animation:cup-wiggle .6s var(--ease)}
@keyframes cup-wiggle{30%{transform:rotate(-9deg)}60%{transform:rotate(6deg)}100%{transform:none}}
.cup-cat__name{font-family:var(--fd);font-weight:700;font-size:21px;color:var(--navy)}
.cup-cat__desc{color:var(--muted);font-size:15px;line-height:1.55}
.cup-cat__go{margin-top:10px;font-weight:700;color:var(--teal);font-size:15px;display:inline-flex;gap:6px}
.cup-cat__go i{font-style:normal;transition:transform .25s var(--ease)}
.cup-cat:hover .cup-cat__go i{transform:translateX(6px)}

/* ---------- Why (dark) ---------- */
.cup-why{background:linear-gradient(160deg,var(--navy),var(--navy-deep));color:#fff;position:relative;overflow:hidden}
.cup-why::before{content:"";position:absolute;width:60vw;height:60vw;right:-20vw;top:-20vw;background:radial-gradient(circle,rgba(30,158,138,.25),transparent 60%);filter:blur(50px)}
.cup-why__grid{position:relative;display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(30px,5vw,70px);align-items:center;padding:clamp(56px,8vw,100px) var(--gutter)}
.cup-why .cup-shead__title{color:#fff}.cup-why .cup-shead__sub{color:#b7c7d8}
.cup-steps{list-style:none;margin:0;padding:0;position:relative}
.cup-steps::before{content:"";position:absolute;left:25px;top:10px;bottom:10px;width:2px;background:linear-gradient(var(--aqua),transparent);opacity:.5}
.cup-step{display:flex;gap:20px;padding:14px 0;align-items:flex-start}
.cup-step__no{flex:0 0 auto;display:inline-grid;place-items:center;width:52px;height:52px;border-radius:14px;background:rgba(255,255,255,.06);border:1px solid rgba(47,214,184,.4);font-family:var(--fd);font-weight:800;color:var(--aqua);position:relative;z-index:1}
.cup-step h3{color:#fff;font-size:21px;margin:.1em 0 .25em}
.cup-step p{color:#b7c7d8;margin:0;font-size:15.5px}

/* ---------- Cards grid ---------- */
.cup-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:28px}
.cup-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;transition:transform .25s var(--ease),box-shadow .25s}
.cup-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.cup-card__media{aspect-ratio:16/9;overflow:hidden;background:linear-gradient(135deg,#e7f4f1,#dbeef9);display:block}
.cup-card__img{width:100%;height:100%;object-fit:cover;transition:transform .55s var(--ease)}
.cup-card:hover .cup-card__img{transform:scale(1.07)}
.cup-card__ph{display:grid;place-items:center;height:100%;color:var(--teal)}.cup-card__ph svg{width:56px;height:56px}
.cup-card__body{padding:20px 22px 22px;display:flex;flex-direction:column;gap:10px;flex:1}
.cup-card__title{font-size:21px;line-height:1.22;margin:0}.cup-card__title a{color:var(--navy)}.cup-card__title a:hover{color:var(--teal)}
.cup-card__excerpt{color:var(--muted);font-size:15px;margin:0;flex:1}
.cup-card__meta{color:#94a3b5;font-size:13.5px;display:flex;gap:7px;align-items:center}
.cup-tag{align-self:flex-start;display:inline-block;background:rgba(30,158,138,.1);color:var(--teal);font-weight:700;font-size:12px;letter-spacing:.03em;text-transform:uppercase;padding:5px 12px;border-radius:999px}
.cup-tag--lg{font-size:12.5px;margin-bottom:10px}

/* ---------- CTA ---------- */
.cup-cta{padding:clamp(40px,6vw,72px) 0}
.cup-cta__inner{position:relative;overflow:hidden;text-align:center;background:linear-gradient(120deg,var(--navy),var(--indigo));color:#fff;border-radius:var(--radius-xl);padding:clamp(40px,6vw,68px) var(--gutter);box-shadow:var(--shadow-md)}
.cup-cta__inner::before{content:"";position:absolute;width:50vw;height:50vw;left:-10vw;bottom:-30vw;background:radial-gradient(circle,rgba(47,214,184,.35),transparent 60%);filter:blur(40px)}
.cup-cta h2{color:#fff;font-size:clamp(26px,3.6vw,40px);position:relative}
.cup-cta p{color:#c4d3e3;margin:.4em auto 1.6em;max-width:44ch;position:relative}
.cup-cta .cup-btn{position:relative}

/* ---------- Page head (archive/blog/page) ---------- */
.cup-pagehead{position:relative;overflow:hidden;background:var(--navy-deep);color:#fff;padding:clamp(56px,8vw,96px) 0 clamp(40px,6vw,64px)}
.cup-pagehead__aurora{position:absolute;inset:0;filter:blur(60px);opacity:.7}
.cup-pagehead .cup-wrap{position:relative;z-index:1}
.cup-pagehead__ico{display:inline-grid;place-items:center;width:64px;height:64px;border-radius:18px;background:rgba(255,255,255,.08);border:1px solid rgba(47,214,184,.4);color:var(--aqua);margin-bottom:16px}
.cup-pagehead__ico svg{width:34px;height:34px}
.cup-pagehead__title{color:#fff;font-size:clamp(30px,4.6vw,52px)}
.cup-pagehead__sub{color:#b7c7d8;font-size:18px;max-width:60ch}
.cup-crumbs{font-size:14px;color:#9fb6cc;margin:0 0 16px}.cup-crumbs a{color:#9fb6cc}.cup-crumbs a:hover{color:var(--aqua)}.cup-crumbs span{margin:0 6px;opacity:.6}

/* ---------- Article ---------- */
.cup-article__head{position:relative;overflow:hidden;background:var(--navy-deep);color:#fff;padding:clamp(40px,6vw,80px) 0 clamp(28px,4vw,44px)}
.cup-article__head-aurora{position:absolute;inset:0;filter:blur(70px);opacity:.65}
.cup-article__head .cup-wrap{position:relative;z-index:1}
.cup-article__title{color:#fff;font-size:clamp(30px,4.8vw,54px);margin:.15em 0 .3em;letter-spacing:-.025em}
.cup-article__lede{font-size:clamp(18px,2.2vw,22px);color:#c4d3e3;line-height:1.55;margin:0 0 18px;max-width:60ch}
.cup-article__meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;color:#9fb6cc;font-size:15px}
.cup-by{display:inline-flex;align-items:center;gap:9px}.cup-by__ava{border-radius:50%}.cup-by__name{font-weight:700;color:#fff}
.cup-dot{opacity:.5}.cup-upd{color:var(--aqua);font-weight:700}
.cup-article__hero{margin:clamp(-40px,-4vw,-30px) auto clamp(28px,4vw,44px);position:relative;z-index:2;border-radius:var(--radius-xl);overflow:hidden;aspect-ratio:16/9;box-shadow:var(--shadow-md)}
.cup-article__hero img,.post-hero img{width:100%;height:100%;object-fit:cover;display:block}

/* Prose */
.cup-prose{font-size:18.5px;line-height:1.8;color:#23303f}
.cup-prose>*+*{margin-top:1.3em}
.cup-prose>p:first-of-type::first-letter{font-family:var(--fd);font-weight:800;float:left;font-size:3.4em;line-height:.82;padding:.05em .12em 0 0;color:var(--teal)}
.cup-prose h2{font-size:clamp(25px,3vw,34px);margin:1.7em 0 .5em}
.cup-prose h2::after{content:"";display:block;width:56px;height:4px;background:linear-gradient(90deg,var(--teal),var(--aqua));border-radius:4px;margin-top:.45em}
.cup-prose h3{font-size:clamp(20px,2.4vw,25px);margin:1.4em 0 .4em}
.cup-prose a{text-decoration:underline;text-decoration-color:rgba(30,158,138,.4);text-underline-offset:3px;font-weight:600}
.cup-prose ul,.cup-prose ol{margin:0 0 1.2em;padding-left:1.4em}.cup-prose li{margin:.45em 0}.cup-prose ul li::marker{color:var(--teal)}
.cup-prose blockquote{margin:1.7em 0;padding:20px 26px;background:linear-gradient(120deg,rgba(30,158,138,.08),rgba(47,214,184,.08));border-left:4px solid var(--teal);border-radius:0 14px 14px 0;color:var(--navy)}
.cup-prose blockquote p:last-child{margin-bottom:0}
.cup-prose img{border-radius:14px;margin:1.6em 0}
.cup-prose strong{color:var(--navy)}
/* Tabele */
.cup-prose .wp-block-table,.cup-prose table{width:100%;border-collapse:collapse;margin:1.7em 0;font-size:16px;background:#fff;border-radius:14px;overflow:hidden;box-shadow:var(--shadow-sm)}
.cup-prose figure.wp-block-table{box-shadow:none;overflow-x:auto;display:block}.cup-prose figure.wp-block-table>table{margin:0}
.cup-prose th,.cup-prose td{padding:14px 17px;text-align:left;border-bottom:1px solid var(--line);vertical-align:top}
.cup-prose thead th{background:linear-gradient(120deg,var(--navy),var(--indigo));color:#fff;font-family:var(--fb);font-weight:700;font-size:14.5px;border:0}
.cup-prose tbody tr:nth-child(even){background:var(--bg-soft)}
.cup-prose tbody tr:hover{background:rgba(30,158,138,.07)}
.cup-prose td:first-child{font-weight:700;color:var(--navy)}

/* Disclaimer / author / tags */
.cup-disclaimer{margin:38px 0 0;padding:20px 24px;background:#fff8ec;border:1px solid #f0dcae;border-left:4px solid var(--gold);border-radius:0 14px 14px 0;font-size:14.5px;color:#6b5836;line-height:1.6}
.cup-disclaimer strong{color:#8a6d1e}
.cup-tags{margin-top:24px;display:flex;gap:8px;flex-wrap:wrap}.cup-tags a{background:var(--bg-soft);border:1px solid var(--line);padding:5px 13px;border-radius:999px;font-size:13.5px;color:var(--muted)}
.cup-authorbox{margin:40px 0 0;display:flex;gap:18px;padding:26px;background:var(--bg-soft);border-radius:var(--radius-lg);border:1px solid var(--line)}
.cup-authorbox__ava{border-radius:50%;flex:0 0 auto}
.cup-authorbox__label{font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:var(--teal);font-weight:700}
.cup-authorbox__name{margin:2px 0 6px;font-size:22px}.cup-authorbox__bio{margin:0;color:var(--muted);font-size:15.5px;line-height:1.6}
.cup-related{padding-top:clamp(44px,6vw,76px)}
.cup-empty{color:var(--muted);padding:40px 0;font-size:18px;text-align:center}

/* Pagination */
.cup-pagi{margin-top:46px}.cup-pagi .nav-links{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}
.cup-pagi a,.cup-pagi .current{padding:10px 16px;border-radius:12px;border:1px solid var(--line);font-weight:700;color:var(--navy)}
.cup-pagi .current{background:var(--navy);color:#fff;border-color:var(--navy)}.cup-pagi a:hover{background:rgba(30,158,138,.1);color:var(--teal)}

/* ---------- Footer ---------- */
.cup-footer{position:relative;overflow:hidden;background:var(--navy-deep);color:#cdd9e6}
.cup-footer__glow{position:absolute;width:60vw;height:30vw;left:50%;top:-10vw;transform:translateX(-50%);background:radial-gradient(ellipse,rgba(30,158,138,.18),transparent 60%);filter:blur(50px)}
.cup-footer__inner{position:relative;max-width:var(--maxw);margin:0 auto;padding:60px var(--gutter) 38px;display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:40px}
.cup-footer .cup-logo__text{color:#fff}.cup-footer .cup-logo__text span{color:var(--aqua)}
.cup-footer__tag{margin:14px 0 0;color:#90a4ba;max-width:34ch}
.cup-footer__col h3{color:#fff;font-family:var(--fb);font-size:13px;text-transform:uppercase;letter-spacing:.1em;margin:0 0 14px}
.cup-footer__col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.cup-footer__col a{color:#aebfd0}.cup-footer__col a:hover{color:var(--aqua)}
.cup-footer__bar{position:relative;border-top:1px solid rgba(255,255,255,.08)}
.cup-footer__bar p{max-width:var(--maxw);margin:0 auto;padding:18px var(--gutter);font-size:13px;color:#7e93aa;line-height:1.6}

/* Back to top */
.cup-top{position:fixed;right:22px;bottom:22px;z-index:140;width:48px;height:48px;border:0;border-radius:50%;background:linear-gradient(135deg,var(--teal),var(--aqua));color:#062a24;font-size:20px;font-weight:800;cursor:pointer;opacity:0;transform:translateY(20px) scale(.8);transition:.3s var(--ease);box-shadow:var(--shadow-glow)}
.cup-top.is-shown{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .cup-hero__inner{grid-template-columns:1fr;gap:34px}
  .cup-hero__content{max-width:none}
  .cup-hero__panel{justify-self:stretch;max-width:520px}
  .cup-hero__art{max-width:380px;margin:0 auto}
  .cup-why__grid{grid-template-columns:1fr;gap:34px}
  .cup-stats__grid{grid-template-columns:repeat(2,1fr);gap:26px}
  .cup-footer__inner{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .cup-nav{position:fixed;inset:62px 0 auto 0;background:#fff;border-bottom:1px solid var(--line);box-shadow:var(--shadow-md);transform:translateY(-130%);transition:transform .32s var(--ease);margin:0;max-height:80vh;overflow:auto}
  .cup-header.is-open .cup-nav{transform:translateY(0)}
  .cup-nav__list{flex-direction:column;gap:0;padding:10px var(--gutter)}
  .cup-nav__list a{display:block;padding:14px 8px}.cup-nav__list a::after{display:none}
  .cup-burger{display:flex}
  .cup-header.is-open .cup-burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .cup-header.is-open .cup-burger span:nth-child(2){opacity:0}
  .cup-header.is-open .cup-burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .cup-hero__shield{opacity:.32}
}
@media (max-width:600px){
  :root{--gutter:24px}
  body{font-size:16px}.cup-prose{font-size:17px}
  .cup-finder__row{flex-direction:column}.cup-btn{width:100%;justify-content:center}
  .cup-stats__grid{grid-template-columns:1fr 1fr;gap:20px;padding:32px var(--gutter)}
  .cup-footer__inner{grid-template-columns:1fr;gap:30px}
  .cup-authorbox{flex-direction:column}
  .cup-shead--row{flex-direction:column;align-items:flex-start}
}
@media (max-width:760px){
  .cup-hero--photo{min-height:auto}
  .cup-hero__photo img{object-position:66% center}
  .cup-hero__scrim{background:linear-gradient(180deg,rgba(8,28,51,.9) 0%,rgba(8,28,51,.64) 38%,rgba(8,28,51,.92) 100%)}
}
/* ---------- Porównywarka (Faza 2) ---------- */
.cup-widget{min-height:360px;background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--radius-lg);padding:8px;overflow:hidden}
.cup-widget__soon{min-height:344px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:14px;padding:40px 24px}
.cup-widget__soon h2{margin:0;color:var(--navy)}
.cup-widget__soon p{color:var(--muted);max-width:46ch;margin:0}
.cup-affnote{font-size:13px;color:var(--muted);line-height:1.55;margin:16px 2px 0;padding:12px 16px;background:var(--bg-soft);border:1px dashed var(--line);border-radius:12px}
.cup-finder__cta{margin-top:14px}
.cup-ctabar,.cup-inlinecta{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;background:linear-gradient(120deg,var(--navy),var(--indigo));color:#fff;border-radius:var(--radius-lg);padding:22px 26px;margin:0 0 30px;box-shadow:var(--shadow-sm)}
.cup-inlinecta{margin:32px 0 0}
.cup-ctabar strong,.cup-inlinecta strong{display:block;font-family:var(--fd);font-size:20px}
.cup-ctabar span,.cup-inlinecta span{color:#c4d3e3;font-size:14.5px}
.cup-faq details{border:1px solid var(--line);border-radius:14px;padding:2px 18px;margin:0 0 12px;background:#fff;transition:box-shadow .2s}
.cup-faq details[open]{box-shadow:var(--shadow-sm)}
.cup-faq summary{cursor:pointer;list-style:none;padding:16px 0;font-family:var(--fd);font-weight:600;color:var(--navy);font-size:17px;display:flex;justify-content:space-between;align-items:center;gap:12px}
.cup-faq summary::-webkit-details-marker{display:none}
.cup-faq summary::after{content:"+";font-size:24px;line-height:1;color:var(--teal);transition:transform .2s}
.cup-faq details[open] summary::after{transform:rotate(45deg)}
.cup-faq details p{margin:0 0 16px;color:#3a4a5c;line-height:1.6}
@media (max-width:600px){.cup-ctabar,.cup-inlinecta{flex-direction:column;align-items:flex-start}.cup-ctabar .cup-btn,.cup-inlinecta .cup-btn{width:100%;justify-content:center}}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1!important;transform:none!important}
  .cup-panel__list li{opacity:1!important;transform:none!important}
}

/* ===== Szablon artykułu v2: TL;DR / TOC / boxy / źródła / linkedin ===== */
.cup-tldr{background:var(--bg-soft);border:1px solid var(--line);border-left:4px solid var(--teal);border-radius:var(--radius);padding:22px 26px;margin:0 0 28px}
.cup-tldr__title{font-family:var(--fd);font-size:18px;font-weight:700;color:var(--navy);margin:0 0 12px;letter-spacing:-.01em}
.cup-tldr ul{list-style:none;margin:0;padding:0;display:grid;gap:10px}
.cup-tldr li{position:relative;padding-left:30px;font-family:var(--fb);font-size:15.5px;line-height:1.5;color:var(--ink)}
.cup-tldr li::before{content:"";position:absolute;left:0;top:2px;width:18px;height:18px;border-radius:50%;background:var(--aqua);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/14px no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/14px no-repeat}

.cup-toc{border:1px solid var(--line);border-radius:var(--radius);padding:18px 24px;margin:0 0 30px;background:#fff}
.cup-toc__title{display:block;font-family:var(--fb);font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:10px}
.cup-toc ol{margin:0;padding-left:22px;display:grid;gap:7px}
.cup-toc li{font-family:var(--fb);font-size:15px;line-height:1.4}
.cup-toc a{color:var(--navy);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .15s,color .15s}
.cup-toc a:hover{color:var(--teal);border-bottom-color:var(--teal)}
.cup-prose h2{scroll-margin-top:90px}

.cup-box{border-radius:var(--radius);padding:18px 22px 18px 56px;margin:24px 0;position:relative;font-family:var(--fb);line-height:1.6}
.cup-box__title{display:block;font-family:var(--fd);font-weight:700;font-size:16px;margin-bottom:4px}
.cup-box__body{font-size:15.5px;color:var(--ink)}
.cup-box__body p{margin:.4em 0 0}
.cup-box::before{position:absolute;left:18px;top:18px;width:24px;height:24px;background-size:contain;background-repeat:no-repeat;content:""}
.cup-box--warto{background:rgba(30,158,138,.07);border:1px solid rgba(30,158,138,.25)}
.cup-box--warto .cup-box__title{color:var(--teal)}
.cup-box--warto::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%231e9e8a' viewBox='0 0 24 24'%3E%3Cpath d='M12 2a10 10 0 100 20 10 10 0 000-20zm1 15h-2v-6h2zm0-8h-2V7h2z'/%3E%3C/svg%3E")}
.cup-box--uwaga{background:rgba(224,169,67,.10);border:1px solid rgba(224,169,67,.35)}
.cup-box--uwaga .cup-box__title{color:#b9831f}
.cup-box--uwaga::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23e0a943' viewBox='0 0 24 24'%3E%3Cpath d='M1 21h22L12 2zm12-3h-2v-2h2zm0-4h-2v-4h2z'/%3E%3C/svg%3E")}
.cup-box--oko{background:rgba(14,42,71,.05);border:1px solid rgba(14,42,71,.18)}
.cup-box--oko .cup-box__title{color:var(--navy)}
.cup-box--oko::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%230e2a47' viewBox='0 0 24 24'%3E%3Cpath d='M12 5C5 5 1 12 1 12s4 7 11 7 11-7 11-7-4-7-11-7zm0 11a4 4 0 110-8 4 4 0 010 8zm0-2a2 2 0 100-4 2 2 0 000 4z'/%3E%3C/svg%3E")}

.cup-faq-sec{margin:34px 0 0}
.cup-sources{margin:30px 0 0;border-top:1px solid var(--line);padding-top:20px}
.cup-sources__title{font-family:var(--fd);font-size:16px;font-weight:700;color:var(--navy);margin:0 0 10px}
.cup-sources ol{margin:0;padding-left:20px;display:grid;gap:6px}
.cup-sources li{font-family:var(--fb);font-size:13.5px;line-height:1.45;color:var(--muted)}
.cup-sources a{color:var(--teal);text-decoration:none;word-break:break-word}
.cup-sources a:hover{text-decoration:underline}

.cup-authorbox__linkedin{display:inline-flex;align-items:center;gap:7px;margin-top:10px;font-family:var(--fb);font-size:13.5px;font-weight:600;color:var(--navy);text-decoration:none}
.cup-authorbox__linkedin:hover{color:var(--teal)}
.cup-authorbox__in{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:5px;background:#0a66c2;color:#fff;font-family:var(--fd);font-size:11px;font-weight:800;line-height:1}

/* ===== Szablon artykułu v2 — układ 2-kolumnowy (desktop) ===== */
.cup-layout{display:block}
.cup-layout__main{min-width:0}
.cup-layout__top-mobile{display:none}
.cup-layout__aside{min-width:0}
.cup-aside-sticky>*{margin:0 0 18px}
.cup-aside-sticky>*:last-child{margin-bottom:0}
/* w panelu TL;DR i TOC bez dolnych marginesów (steruje stos) */
.cup-aside-sticky .cup-tldr,.cup-aside-sticky .cup-toc{margin:0}

/* Sticky CTA „Oblicz składkę" */
.cup-asidecta{position:relative;overflow:hidden;background:linear-gradient(135deg,var(--navy),var(--indigo));color:#fff;border-radius:var(--radius-lg);padding:22px 22px 24px;box-shadow:var(--shadow-sm)}
.cup-asidecta::before{content:"";position:absolute;width:240px;height:240px;right:-90px;top:-110px;background:radial-gradient(circle,rgba(47,214,184,.4),transparent 62%);filter:blur(18px);pointer-events:none}
.cup-asidecta__eyebrow{position:relative;display:inline-block;font-weight:700;font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--aqua-soft);margin-bottom:9px}
.cup-asidecta__title{position:relative;display:block;font-family:var(--fd);font-weight:700;font-size:20px;line-height:1.18;color:#fff;letter-spacing:-.01em}
.cup-asidecta__desc{position:relative;margin:8px 0 16px;color:#c4d3e3;font-size:14px;line-height:1.5}
.cup-asidecta .cup-btn{position:relative;width:100%;justify-content:center}

/* TOC w panelu bocznym */
.cup-aside-toc .cup-toc{background:#fff}

/* Desktop: dwie kolumny + sticky prawy panel */
@media (min-width:1000px){
  .cup-layout{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:clamp(36px,4vw,64px);align-items:start}
  .cup-layout--solo{display:block;max-width:760px;margin:0 auto}
  .cup-layout__main{max-width:760px}
  .cup-aside-sticky{position:sticky;top:90px}
  /* TL;DR + TOC żyją w panelu — blok mobilny ukryty */
  .cup-layout__top-mobile{display:none}
  /* TOC sticky-nav: ogranicz wysokość, scroll wewnętrzny gdy długi */
  .cup-aside-toc .cup-toc{max-height:46vh;overflow-y:auto}
}

/* Szerszy ekran: nieco węższa kolumna tekstu dla komfortu czytania */
@media (min-width:1280px){
  .cup-layout{grid-template-columns:minmax(0,1fr) 360px}
}

/* Mobile / tablet: jedna kolumna; TL;DR nad treścią, reszta panelu pod treścią */
@media (max-width:999px){
  .cup-layout{display:block;max-width:760px;margin:0 auto}
  /* TL;DR + spis treści nad treścią (z bufora); reszta panelu (sticky CTA, TOC) ukryta,
     bo inline CTA i tak jest w treści — unikamy dublowania na mobile. */
  .cup-layout__top-mobile{display:block;margin:0 0 26px}
  .cup-layout__top-mobile .cup-tldr{margin:0 0 18px}
  .cup-layout__top-mobile .cup-toc{margin:0}
  .cup-layout__aside{display:none}
}
