/* ===========================================================
   redai.pl — styl strony publicznej
   Marka: czerwień (sprzęt), grafit (premium), biel
=========================================================== */
:root{
  --red:#dc2626;
  --red-dark:#991b1b;
  --red-deep:#7f1d1d;
  --red-soft:#fee2e2;
  --red-glow:rgba(220,38,38,.18);
  --ink:#0b0b0d;
  --graphite:#1a1a1f;
  --steel:#2a2a31;
  --muted:#6b6b76;
  --line:#e8e8ee;
  --bg:#fafafa;
  --bg-card:#ffffff;
  --bg-dark:#0b0b0d;
  --gold:#facc15;
  --green:#16a34a;
  --amber:#f59e0b;
  --shadow-sm:0 1px 2px rgba(15,15,20,.06);
  --shadow:0 4px 18px rgba(15,15,20,.08);
  --shadow-lg:0 20px 50px rgba(15,15,20,.18);
  --r-sm:6px;
  --r:10px;
  --r-lg:16px;
  --r-xl:24px;
  --font:'Inter','SF Pro Display','Segoe UI',-apple-system,BlinkMacSystemFont,system-ui,sans-serif;
  --mono:'JetBrains Mono','Fira Code',Menlo,Consolas,monospace;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden;overflow-x:clip}
/* Round 5: utility hide on mobile */
@media (max-width:640px){.hide-mobile{display:none !important}}
body{overflow-x:hidden;overflow-x:clip}
/* Mobile overflow safety net (round 5) — chroni przed elementem wystającym poza viewport */
@media (max-width:640px){
  img,svg,video,iframe,table,pre,code{max-width:100%}
  .container{max-width:100%}
}
body{
  margin:0;overflow-x:hidden;

  font-family:var(--font);
  font-size:16px;
  line-height:1.55;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

a{color:var(--red-dark);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;display:block}
h1,h2,h3,h4,h5{font-weight:700;letter-spacing:-.01em;line-height:1.15;margin:0 0 .6em}
h1{font-size:clamp(2.1rem,4vw,3.4rem);letter-spacing:-.02em}
h2{font-size:clamp(1.7rem,2.8vw,2.4rem);letter-spacing:-.015em}
h3{font-size:1.35rem}
p{margin:0 0 1em}

.container{max-width:1200px;margin:0 auto;padding:0 24px}
.container-narrow{max-width:880px;margin:0 auto;padding:0 24px}

.skip{position:absolute;left:-9999px}
.skip:focus{left:1rem;top:1rem;background:#000;color:#fff;padding:.5rem 1rem;z-index:9999}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  background:#fff;color:var(--ink);border:1px solid var(--line);
  padding:.7rem 1.15rem;border-radius:var(--r);
  font-weight:600;font-size:.95rem;cursor:pointer;
  transition:transform .12s ease, box-shadow .12s ease, background .12s ease;
  text-decoration:none;
}
.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow);text-decoration:none}
.btn-primary{background:var(--red);color:#fff;border-color:var(--red)}
.btn-primary:hover{background:var(--red-dark);border-color:var(--red-dark)}
.btn-ghost{background:transparent}
.btn-dark{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn-dark:hover{background:#000}
.btn-sm{padding:.5rem .85rem;font-size:.85rem}
.btn-lg{padding:.95rem 1.5rem;font-size:1.05rem}
.btn-block{display:flex;width:100%;justify-content:center}

.kicker{display:inline-block;font-size:.75rem;letter-spacing:.18em;text-transform:uppercase;color:var(--red);font-weight:700;margin-bottom:.6rem}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:80;background:rgba(255,255,255,.92);backdrop-filter:saturate(180%) blur(10px);
  border-bottom:1px solid var(--line);
}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;height:72px;gap:1.5rem}
.brand{display:flex;align-items:center;color:var(--ink);font-weight:700;text-decoration:none}
.brand:hover{text-decoration:none}
.brand-logo{display:block;height:36px;width:auto;max-width:140px}
.brand-foot .brand-logo{height:32px;max-width:124px}
.main-nav{display:flex;align-items:center;gap:.4rem}
.nav-link{padding:.55rem .85rem;border-radius:var(--r);color:var(--graphite);font-weight:500;font-size:.95rem}
.nav-link:hover{background:var(--red-soft);color:var(--red-dark);text-decoration:none}
.nav-link.active{color:var(--red);background:#fff5f5}
.nav-cta{margin-left:.6rem}
.nav-toggle{display:none;background:none;border:0;width:42px;height:42px;cursor:pointer;flex-direction:column;justify-content:center;align-items:center;gap:5px}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--ink);border-radius:2px;transition:transform .2s}

@media (max-width:880px){
  .nav-toggle{display:flex}
  .main-nav{position:fixed;top:72px;left:0;right:0;background:#fff;flex-direction:column;align-items:stretch;padding:1rem;gap:.2rem;border-bottom:1px solid var(--line);box-shadow:var(--shadow);transform:translateY(-110%);opacity:0;pointer-events:none;transition:.2s}
  .main-nav.open{transform:none;opacity:1;pointer-events:auto}
  .nav-link, .nav-cta{width:100%;text-align:left}
}

/* ---------- Hero ---------- */
.hero{
  position:relative;overflow:hidden;
  background:radial-gradient(ellipse at top right,rgba(220,38,38,.10),transparent 60%),
             linear-gradient(180deg,#fff 0%,#fafafa 100%);
  padding:80px 0 100px;
  border-bottom:1px solid var(--line);
}
.hero-inner{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center}
.hero h1{margin:0 0 1rem}
.hero h1 .accent{color:var(--red);background:linear-gradient(90deg,var(--red),#ef4444);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-sub{font-size:clamp(1.05rem,1.4vw,1.2rem);color:var(--muted);max-width:560px;margin:0 0 2rem}
.hero-ctas{display:flex;gap:.8rem;flex-wrap:wrap;margin-bottom:1.6rem}
.hero-meta{display:flex;gap:1.6rem;flex-wrap:wrap;color:var(--muted);font-size:.9rem}
.hero-meta b{color:var(--ink);font-weight:700}

.hero-visual{position:relative}
.sbox{
  position:relative;aspect-ratio:1.25/1;
  background:linear-gradient(160deg,#dc2626 0%,#991b1b 100%);
  border-radius:18px;
  padding:1.2rem;
  box-shadow:0 30px 80px rgba(127,29,29,.45),0 8px 24px rgba(0,0,0,.18);
  transform:perspective(900px) rotateY(-6deg) rotateX(3deg);
}
.sbox::before{
  content:"";position:absolute;inset:8px;border:1px solid rgba(255,255,255,.18);border-radius:14px;pointer-events:none;
}
.sbox-screen{
  background:#0a0a0a;border-radius:8px;padding:1rem;height:100%;
  font-family:var(--mono);color:#fef2f2;font-size:.82rem;line-height:1.7;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.04);
  position:relative;overflow:hidden;
}
.sbox-screen::after{
  content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(220,38,38,.15));pointer-events:none;
}
.sbox-line{display:flex;gap:.5rem}
.sbox-line .prompt{color:var(--red)}
.sbox-line .ok{color:#4ade80}
.sbox-cur{display:inline-block;width:8px;height:1em;background:#fef2f2;vertical-align:middle;animation:blink 1s infinite}
@keyframes blink{50%{opacity:0}}
.sbox-led{position:absolute;top:1rem;right:1rem;width:10px;height:10px;background:#facc15;border-radius:50%;box-shadow:0 0 16px #facc15}
.sbox-led.green{background:#4ade80;box-shadow:0 0 16px #4ade80;top:1rem;right:2.2rem}

.hero-badge-row{position:absolute;top:-12px;left:24px;display:flex;gap:.5rem}
.hero-pill{background:#0a0a0a;color:#fef2f2;font-family:var(--mono);font-size:.7rem;padding:.3rem .65rem;border-radius:100px;letter-spacing:.05em}
.hero-pill .dot{display:inline-block;width:6px;height:6px;background:#4ade80;border-radius:50%;margin-right:.3rem;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

@media (max-width:880px){
  .hero{padding:48px 0 70px}
  .hero-inner{grid-template-columns:1fr;gap:36px}
  .sbox{transform:none}
}

/* ---------- Sections ---------- */
section{padding:80px 0}
section.pad-sm{padding:48px 0}
section.dark{background:var(--ink);color:#fff}
section.dark h2, section.dark h3{color:#fff}
section.tint{background:linear-gradient(180deg,#fff,#fff5f5)}
section.tint-graphite{background:#16161c;color:#fff}
section.tint-graphite h2{color:#fff}

.section-head{text-align:center;max-width:780px;margin:0 auto 56px}
.section-head .lead{color:var(--muted);font-size:1.1rem}
.section-head.left{text-align:left;margin-left:0}

/* ---------- Grids / Cards ---------- */
.grid{display:grid;gap:24px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
@media (max-width:980px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:620px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

.card{
  background:var(--bg-card);border:1px solid var(--line);
  border-radius:var(--r-lg);padding:28px;
  transition:transform .14s ease, box-shadow .14s ease, border-color .14s;
}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:#f1d4d4}
.card-glow{position:relative;overflow:hidden}
.card-glow::before{content:"";position:absolute;inset:-2px;background:linear-gradient(135deg,transparent,var(--red-glow),transparent);opacity:0;transition:.3s;pointer-events:none;border-radius:inherit}
.card-glow:hover::before{opacity:1}
.card .ico{
  width:48px;height:48px;border-radius:12px;background:var(--red-soft);color:var(--red);
  display:inline-flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:14px;
}
.card h3{font-size:1.15rem;margin-bottom:.5rem}
.card p{color:var(--muted);font-size:.96rem;margin:0}

/* Feature blocks (numbered) */
.numbered{counter-reset:nx}
.numbered .card{counter-increment:nx}
.numbered .card::after{content:counter(nx,decimal-leading-zero);position:absolute;top:1rem;right:1.2rem;font-family:var(--mono);font-size:.85rem;color:#e5cccc;font-weight:700}
.numbered .card{position:relative}

/* Stats strip */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;margin:40px 0}
.stat{padding:28px;background:#fff;text-align:center}
.stat .num{font-size:2rem;font-weight:800;letter-spacing:-.03em;color:var(--red)}
.stat .lbl{color:var(--muted);font-size:.88rem;text-transform:uppercase;letter-spacing:.08em}
@media (max-width:720px){.stats{grid-template-columns:1fr 1fr}}

/* Comparison table */
.compare{width:100%;border-collapse:separate;border-spacing:0;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.compare th,.compare td{padding:14px 18px;text-align:left;border-bottom:1px solid var(--line);font-size:.95rem;vertical-align:middle}
.compare thead th{background:#16161c;color:#fff;font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:.06em}
.compare thead th.us{background:var(--red)}
.compare td.us{background:#fff5f5}
.compare .yes{color:var(--green);font-weight:700}
.compare .no{color:#aaa}
.compare .partial{color:var(--amber)}
.compare tr:last-child td{border-bottom:0}

/* ───────── LANDING PAGES (lp.php) ───────── */
.lp-trust-strip{
  background:#fafafa;border-top:1px solid #f0f0f0;border-bottom:1px solid #f0f0f0;
  padding:14px 0;text-align:center;
}
.lp-trust-strip__items{display:inline-flex;gap:32px;flex-wrap:wrap;justify-content:center;color:#52525b;font-size:.85rem}
.lp-trust-strip__item{display:inline-flex;align-items:center;gap:6px}
.lp-trust-strip__item b{color:#18181b;font-weight:700}

.lp-pain{padding:64px 0;background:#fff}
.lp-pain h2{font-size:clamp(1.6rem,2.6vw,2.2rem);text-align:center;margin:0 0 8px;line-height:1.2}
.lp-pain p.lp-lead{text-align:center;color:#52525b;font-size:1.05rem;margin:0 auto 40px;max-width:680px;line-height:1.5}
.lp-pain__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.lp-pain__card{
  background:#fafafa;border:1px solid #f0f0f0;border-radius:12px;
  padding:24px;text-align:left;
  transition:transform .18s ease,box-shadow .18s ease;
}
.lp-pain__card:hover{transform:translateY(-4px);box-shadow:0 12px 28px rgba(0,0,0,.06)}
.lp-pain__icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:42px;height:42px;border-radius:10px;
  background:rgba(220,38,38,.08);color:#dc2626;
  font-size:20px;font-weight:700;margin-bottom:14px;
}
.lp-pain__card h3{margin:0 0 8px;font-size:1.1rem;line-height:1.3;color:#18181b}
.lp-pain__card p{margin:0;color:#52525b;font-size:.95rem;line-height:1.55}
@media (max-width:780px){.lp-pain__grid{grid-template-columns:1fr}}

.lp-features{padding:64px 0;background:#fafafa}
.lp-features h2{font-size:clamp(1.6rem,2.6vw,2.2rem);text-align:center;margin:0 0 8px;line-height:1.2}
.lp-features p.lp-lead{text-align:center;color:#52525b;font-size:1.05rem;margin:0 auto 40px;max-width:680px;line-height:1.5}
.lp-features__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.lp-features__item{display:flex;gap:16px;padding:20px;background:#fff;border:1px solid #f0f0f0;border-radius:10px}
.lp-features__check{
  flex-shrink:0;width:28px;height:28px;border-radius:50%;
  background:rgba(34,197,94,.12);color:#16a34a;
  display:flex;align-items:center;justify-content:center;font-weight:900;font-size:14px;
}
.lp-features__body h4{margin:0 0 4px;font-size:1rem;font-weight:600;color:#18181b}
.lp-features__body p{margin:0;color:#52525b;font-size:.92rem;line-height:1.5}
@media (max-width:780px){.lp-features__grid{grid-template-columns:1fr}}

.lp-pricing{padding:64px 0;background:#fff}
.lp-pricing h2{font-size:clamp(1.6rem,2.6vw,2.2rem);text-align:center;margin:0 0 8px;line-height:1.2}
.lp-pricing p.lp-lead{text-align:center;color:#52525b;font-size:1.05rem;margin:0 auto 40px;max-width:680px;line-height:1.5}
.lp-pricing__card{
  max-width:560px;margin:0 auto;
  background:linear-gradient(180deg,#fff,#fff5f5);
  border:1px solid #fecaca;border-radius:14px;
  padding:32px;text-align:center;
  box-shadow:0 12px 32px rgba(220,38,38,.08);
}
.lp-pricing__name{font-size:.75rem;color:#dc2626;letter-spacing:.18em;text-transform:uppercase;font-weight:700;margin-bottom:8px}
.lp-pricing__hook{font-size:1.4rem;font-weight:700;color:#18181b;margin-bottom:16px;line-height:1.3}
.lp-pricing__rows{display:flex;flex-direction:column;gap:8px;margin:20px 0;text-align:left}
.lp-pricing__row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid #f0f0f0;font-size:.95rem;color:#52525b}
.lp-pricing__row b{color:#18181b;font-weight:700}
.lp-pricing__total{display:flex;justify-content:space-between;padding:14px 0 4px;border-top:2px solid #18181b;font-size:1.1rem;font-weight:700;color:#18181b}
.lp-pricing__roi{margin-top:18px;padding:14px 16px;border-radius:10px;background:rgba(34,197,94,.08);color:#15803d;font-size:.9rem;font-weight:600;line-height:1.4}

.lp-faq{padding:64px 0;background:#fafafa}
.lp-faq h2{font-size:clamp(1.6rem,2.6vw,2.2rem);text-align:center;margin:0 0 40px;line-height:1.2}
.lp-faq__list{max-width:720px;margin:0 auto;display:flex;flex-direction:column;gap:10px}
.lp-faq__item{background:#fff;border:1px solid #f0f0f0;border-radius:10px;padding:0;overflow:hidden}
.lp-faq__q{
  width:100%;background:none;border:none;padding:18px 22px;
  display:flex;justify-content:space-between;align-items:center;gap:16px;
  font:600 1rem/1.4 inherit;color:#18181b;text-align:left;cursor:pointer;
}
.lp-faq__q::after{content:"+";font-size:1.4rem;font-weight:400;color:#dc2626;transition:transform .18s ease}
.lp-faq__item[open] .lp-faq__q::after{content:"−"}
.lp-faq__a{padding:0 22px 18px;color:#52525b;font-size:.95rem;line-height:1.6}

.lp-cta-band{background:linear-gradient(135deg,#dc2626,#991b1b);color:#fff;padding:56px 0;text-align:center}
.lp-cta-band h2{color:#fff;font-size:clamp(1.6rem,2.6vw,2.2rem);margin:0 0 12px}
.lp-cta-band p{color:rgba(255,255,255,.92);margin:0 0 24px;font-size:1.05rem}
.lp-cta-band .btn{background:#fff;color:#dc2626;border-color:#fff;font-weight:700}
.lp-cta-band .btn:hover{background:#0a0a0a;color:#fff;border-color:#0a0a0a}

.lp-body section.lp-section{margin:32px 0}
.lp-body section.lp-section h2{font-size:1.4rem;margin:0 0 12px;color:#18181b}
.lp-body section.lp-section p{color:#52525b;line-height:1.6;margin:0 0 12px}
.lp-body section.lp-section ul,.lp-body section.lp-section ol{color:#52525b;line-height:1.7;padding-left:24px}
.lp-body section.lp-section li{margin-bottom:6px}

/* CTA band */
.cta-band{
  background:linear-gradient(120deg,#7f1d1d 0%,#dc2626 100%);
  color:#fff;border-radius:var(--r-xl);padding:64px;
  display:grid;grid-template-columns:1.4fr 1fr;align-items:center;gap:32px;
  box-shadow:var(--shadow-lg);
  position:relative;overflow:hidden;
}
.cta-band::before{content:"";position:absolute;top:-40%;right:-10%;width:60%;height:200%;background:radial-gradient(closest-side,rgba(255,255,255,.16),transparent);pointer-events:none}
.cta-band h2{color:#fff;margin-bottom:.6rem}
.cta-band p{opacity:.92;font-size:1.05rem;margin-bottom:0}
.cta-band .btn{background:#fff;color:var(--red-dark);border-color:#fff}
.cta-band .btn:hover{background:#0a0a0a;color:#fff;border-color:#0a0a0a}
@media (max-width:780px){.cta-band{grid-template-columns:1fr;padding:36px}}

/* Articles list */
.articles{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media (max-width:980px){.articles{grid-template-columns:repeat(2,1fr)}}
@media (max-width:620px){.articles{grid-template-columns:1fr}}
.article-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column;transition:.15s}
.article-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.article-card .hero{background:linear-gradient(135deg,var(--red),var(--red-deep));aspect-ratio:16/9;display:flex;align-items:center;justify-content:center;color:#fff;font-size:3rem;padding:0}
.article-card .body{padding:20px}
.article-card .cat{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--red);font-weight:700}
.article-card h3{font-size:1.05rem;margin:.4rem 0 .5rem;color:var(--ink)}
.article-card p{color:var(--muted);font-size:.92rem;margin:0 0 .8rem}
.article-card .meta{font-size:.8rem;color:var(--muted);display:flex;gap:.6rem}

/* Article single */
.article-single{padding:48px 0 80px}
.article-single .hdr{max-width:820px;margin:0 auto 40px;text-align:left}
.article-single .body{max-width:760px;margin:0 auto;font-size:1.08rem;line-height:1.75}
.article-single .body h2{margin-top:2em}
.article-single .body h3{margin-top:1.6em}
.article-single .body ul,.article-single .body ol{padding-left:1.4em}
.article-single .body blockquote{border-left:4px solid var(--red);padding:.6em 1.2em;background:#fff5f5;margin:1.4em 0;border-radius:0 var(--r) var(--r) 0}
.article-single .body pre{background:#0b0b0d;color:#fef2f2;padding:1em;border-radius:var(--r);overflow:auto;font-family:var(--mono);font-size:.92em}
.article-single .body code{background:#fff1f1;color:var(--red-dark);padding:.1em .3em;border-radius:4px;font-family:var(--mono);font-size:.92em}
.article-single .body pre code{background:none;color:inherit;padding:0}

/* Hooks/features (Claude/Codex comparison) */
.hooks-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media (max-width:780px){.hooks-grid{grid-template-columns:1fr}}
.hook{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:18px;border-left:3px solid var(--red)}
.hook .nm{font-family:var(--mono);font-size:.85rem;color:var(--red-dark);font-weight:700}
.hook .desc{font-size:.92rem;color:var(--muted);margin:.3rem 0 0}

/* Forms */
.form-block{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:32px;box-shadow:var(--shadow-sm)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media (max-width:680px){.form-row{grid-template-columns:1fr}}
.field{margin-bottom:16px}
.field label{display:block;margin-bottom:6px;font-weight:600;font-size:.9rem;color:var(--graphite)}
.field input, .field textarea, .field select{
  width:100%;padding:.7rem .9rem;border:1px solid var(--line);border-radius:var(--r);font-family:inherit;font-size:1rem;background:#fff;transition:.15s;
}
.field input:focus, .field textarea:focus, .field select:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 3px var(--red-glow)}
.field textarea{min-height:120px;resize:vertical}
.field .hint{font-size:.85rem;color:var(--muted);margin-top:4px}

/* Walidacja — wszystkie wymagane pola podświetlane jednocześnie po submit */
.field input.is-invalid, .field textarea.is-invalid, .field select.is-invalid,
input.is-invalid, textarea.is-invalid, select.is-invalid{
  border-color:#dc2626 !important;
  background:#fff5f5;
  box-shadow:0 0 0 3px rgba(220,38,38,.12);
}
.field input.is-invalid:focus, .field textarea.is-invalid:focus, .field select.is-invalid:focus{
  border-color:#dc2626;
  box-shadow:0 0 0 3px rgba(220,38,38,.25);
}
.field.has-error > label{color:#dc2626}
.rh-checkbox-row.has-error{color:#dc2626}
.rh-checkbox-row input[type="checkbox"].is-invalid{outline:2px solid #dc2626;outline-offset:2px}

/* Pricing */
.pricing{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;align-items:stretch}
@media (max-width:780px){.pricing{grid-template-columns:1fr}}
.price-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:32px}
.price-card.feat{background:linear-gradient(140deg,#0b0b0d,#1a1a1f);color:#fff;border-color:transparent;position:relative;overflow:hidden}
.price-card.feat::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% 0%,var(--red-glow),transparent 60%);pointer-events:none}
.price-card h3{margin:0 0 .3rem}
.price-card .amount{font-size:2.2rem;font-weight:800;letter-spacing:-.02em}
.price-card .amount .small{font-size:1rem;color:inherit;opacity:.7;font-weight:500}
.price-card .desc{color:var(--muted);font-size:.95rem;margin:.4rem 0 1rem}
.price-card.feat .desc{color:#c9c9d3}
.price-card ul{list-style:none;padding:0;margin:1rem 0}
.price-card ul li{padding:8px 0;border-bottom:1px solid var(--line);font-size:.95rem;display:flex;gap:.5rem}
.price-card.feat ul li{border-color:#2a2a32}
.price-card ul li::before{content:"✓";color:var(--red);font-weight:700}
.price-card.feat ul li::before{color:#fca5a5}

/* Process timeline */
.process{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin:48px 0}
@media (max-width:880px){.process{grid-template-columns:repeat(2,1fr)}}
.process-step{padding:24px;background:#fff;border:1px solid var(--line);border-radius:var(--r);position:relative}
.process-step .step-num{font-family:var(--mono);font-size:.75rem;color:var(--red);font-weight:700;letter-spacing:.06em}
.process-step h4{margin:.4rem 0 .3rem;font-size:1rem}
.process-step p{font-size:.86rem;color:var(--muted);margin:0}

/* Partner levels */
.levels{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
@media (max-width:980px){.levels{grid-template-columns:repeat(2,1fr)}}
.level{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:24px;text-align:left}
.level.platinum{border-top:4px solid #818cf8;background:linear-gradient(180deg,#f8f8ff 0%,#fff 100%)}
.level.gold{border-top:4px solid #facc15}
.level.silver{border-top:4px solid #94a3b8}
.level.reseller{border-top:4px solid var(--red)}
.level h3{margin:0 0 .3rem;font-size:1.1rem}
.level .pct{font-size:1.6rem;font-weight:800;color:var(--ink)}
.level ul{list-style:none;padding:0;margin:.8rem 0 0;font-size:.9rem}
.level ul li{padding:5px 0;color:var(--graphite)}
.level ul li::before{content:"→ ";color:var(--red)}

/* Jobs */
.jobs-grid{display:grid;grid-template-columns:1fr;gap:14px}
.job-row{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:24px;display:grid;grid-template-columns:1.4fr 1fr 1fr auto;gap:1rem;align-items:center;transition:.15s}
.job-row:hover{box-shadow:var(--shadow);border-color:#f1d4d4}
.job-row .ttl{font-weight:700;font-size:1.05rem;color:var(--ink)}
.job-row .meta{color:var(--muted);font-size:.88rem}
.job-row .dept{font-family:var(--mono);font-size:.78rem;color:var(--red);letter-spacing:.06em;text-transform:uppercase}
@media (max-width:780px){.job-row{grid-template-columns:1fr}.job-row .btn{width:100%;justify-content:center}}

/* Footer */
.site-footer{background:#F9FAFB;color:#1F2937;padding:60px 0 0;margin-top:80px;border-top:1px solid #E5E7EB}
.site-footer a{color:var(--red);text-decoration:none}
.site-footer a:hover{color:var(--red-dark);text-decoration:underline}
.footer-grid{display:grid;grid-template-columns:1.5fr repeat(3,1fr);gap:40px;padding-bottom:48px}
.foot-col h4{color:#111827;margin:0 0 1rem;text-transform:uppercase;letter-spacing:.06em;font-size:.8rem;font-weight:700;opacity:.9}
.foot-col ul{list-style:none;padding:0;margin:0}
.foot-col ul li{padding:6px 0;font-size:.92rem;color:#374151}
.foot-col ul li a{color:#374151}
.foot-col ul li a:hover{color:var(--red)}
.foot-tag{font-size:.92rem;color:#4B5563;max-width:320px;margin:0 0 1rem;line-height:1.55}
.foot-meta{font-size:.82rem;color:#6B7280;margin:0}
.foot-contact a{font-family:var(--mono);font-size:.92rem;color:var(--red)}
.newsletter{margin-top:1rem}
.newsletter label{display:block;font-size:.78rem;color:#6B7280;margin-bottom:.4rem}
.newsletter-row{display:flex;gap:.4rem}
.newsletter input{flex:1;padding:.6rem .8rem;background:#fff;border:1px solid #D1D5DB;color:#111827;border-radius:var(--r-sm);font-size:.9rem}
.newsletter input::placeholder{color:#9CA3AF}
.footer-bottom{border-top:1px solid #E5E7EB;padding:18px 0;font-size:.85rem;color:#6B7280}
.row-between{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}
.legal{display:flex;gap:1.2rem}
.legal a{color:#6B7280;font-size:.85rem}
.legal a:hover{color:var(--red)}
@media (max-width:780px){.footer-grid{grid-template-columns:1fr 1fr;gap:32px}}
@media (max-width:520px){.footer-grid{grid-template-columns:1fr}}

/* Flash messages */
.flash-stack{position:fixed;top:16px;right:16px;z-index:1000;display:flex;flex-direction:column;gap:8px;max-width:400px}
.flash{padding:.8rem 1.1rem;border-radius:var(--r);background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-lg);font-size:.92rem;animation:slidein .25s ease}
.flash.success{border-left:4px solid var(--green)}
.flash.error{border-left:4px solid var(--red)}
.flash.info{border-left:4px solid #3b82f6}
@keyframes slidein{from{transform:translateX(20px);opacity:0}}

/* Utils */
.text-center{text-align:center}
.mt-0{margin-top:0!important}
.mt-1{margin-top:.5rem}
.mt-2{margin-top:1rem}
.mt-3{margin-top:1.5rem}
.mt-4{margin-top:2.5rem}
.mb-0{margin-bottom:0!important}
.text-muted{color:var(--muted)}
.text-red{color:var(--red)}
.fw-700{font-weight:700}
.divider{height:1px;background:var(--line);margin:48px 0}
.tag{display:inline-block;font-size:.74rem;padding:.2rem .55rem;border-radius:100px;background:#fff5f5;color:var(--red-dark);font-weight:600;letter-spacing:.03em}

/* Visible-only-on-small */
.only-mobile{display:none}
@media (max-width:780px){.only-mobile{display:initial}.only-desktop{display:none}}

/* ===========================================================
   ============== HOMEPAGE REDESIGN v2 (2026-05) ==============
   Wszystkie klasy prefixowane .rh- (redai homepage)
   Cel: kompleksowe wdrożenie AI, CEO 30-os firmy
=========================================================== */

/* ---------- 1. HERO ---------- */
.rh-hero{
  position:relative;overflow:hidden;
  background:
    radial-gradient(ellipse 80% 60% at top right,rgba(220,38,38,.10),transparent 60%),
    radial-gradient(ellipse 60% 40% at 10% 90%,rgba(220,38,38,.06),transparent 60%),
    linear-gradient(180deg,#fff 0%,#fafafa 100%);
  padding:88px 0 110px;border-bottom:1px solid var(--line);
}
.rh-hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center}
.rh-hero h1{margin:0 0 1.1rem;font-size:clamp(2.2rem,4.2vw,3.6rem);line-height:1.08;letter-spacing:-.025em}
.rh-accent{color:var(--red);background:linear-gradient(90deg,var(--red),#ef4444);-webkit-background-clip:text;background-clip:text;color:transparent}
.rh-hero-sub{font-size:clamp(1.08rem,1.4vw,1.22rem);color:var(--graphite);max-width:580px;margin:0 0 2rem;line-height:1.55}
.rh-hero-ctas{display:flex;gap:.8rem;flex-wrap:wrap;margin-bottom:.8rem}
.rh-hero-reassure{font-size:.875rem;color:#9CA3AF;margin:0 0 1.8rem;line-height:1.5;max-width:640px}
.rh-hero.rh-hero--dark .rh-hero-reassure{color:#9b9ba6}
.rh-hero-chips{list-style:none;padding:0;margin:0;display:flex;gap:1.8rem;flex-wrap:wrap;font-size:.95rem;color:var(--muted)}
.rh-hero-chips li b{color:var(--ink);font-weight:700;margin-right:.25rem}

.rh-hero-visual{position:relative}
.rh-dashboard{
  background:linear-gradient(160deg,#0e0e12 0%,#1a1a1f 100%);
  border-radius:18px;padding:0;color:#fff;
  box-shadow:0 30px 80px rgba(15,15,20,.32),0 8px 24px rgba(0,0,0,.18);
  transform:perspective(1000px) rotateY(-4deg) rotateX(2deg);
  overflow:hidden;border:1px solid #2a2a32;
}
.rh-dash-bar{display:flex;align-items:center;gap:.5rem;padding:12px 16px;background:#08080a;border-bottom:1px solid #1a1a1f}
.rh-dash-dot{width:11px;height:11px;border-radius:50%;display:inline-block}
.rh-dash-dot.red{background:#ef4444}.rh-dash-dot.amber{background:#f59e0b}.rh-dash-dot.green{background:#22c55e}
.rh-dash-dot.pulse{animation:pulse 2s infinite}
.rh-dash-title{margin-left:.6rem;font-family:var(--mono);font-size:.78rem;color:#9b9ba6}

.rh-dash-body{padding:24px}
.rh-dash-stat{margin-bottom:18px;padding:18px;background:linear-gradient(135deg,rgba(220,38,38,.16),rgba(220,38,38,.04));border-radius:12px;border:1px solid rgba(220,38,38,.25)}
.rh-dash-stat-num{font-size:2rem;font-weight:800;letter-spacing:-.02em;color:#fff}
.rh-dash-stat-num small{font-size:1rem;color:#fca5a5;font-weight:600;margin-left:.2rem}
.rh-dash-stat-lbl{color:#9b9ba6;font-size:.85rem;text-transform:uppercase;letter-spacing:.06em;margin-top:.2rem}

.rh-dash-rows{display:flex;flex-direction:column;gap:8px}
.rh-dash-row{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.8rem;padding:10px 12px;background:#15151b;border-radius:8px;font-size:.86rem;color:#d4d4dc}
.rh-dash-row b{color:#4ade80;font-weight:700;font-size:.85rem;white-space:nowrap}
.rh-tag{font-family:var(--mono);font-size:.66rem;padding:.18rem .5rem;border-radius:100px;font-weight:700;letter-spacing:.05em}
.rh-tag.green{background:#1f4d2a;color:#86efac}
.rh-tag.blue{background:#1e3a5f;color:#93c5fd}
.rh-tag.amber{background:#4a3a1c;color:#fbbf24}
.rh-tag.pink{background:#4a1f3b;color:#f0abfc}
.rh-tag.violet{background:#3a2a5c;color:#c4b5fd}

.rh-dash-foot{padding:10px 16px;background:#08080a;border-top:1px solid #1a1a1f;font-size:.78rem;color:#9b9ba6;display:flex;align-items:center;gap:.5rem}

@media (max-width:960px){
  .rh-hero{padding:36px 0 56px}
  .rh-hero-grid{grid-template-columns:1fr;gap:32px}
  .rh-dashboard{transform:none}
  .rh-hero-photo{transform:none}
  .rh-hero-chips{gap:.8rem;flex-direction:row;flex-wrap:wrap}
  .rh-hero-chips li{flex:1 1 45%}
  .rh-hero-ctas{flex-direction:column;align-items:stretch;width:100%}
  .rh-hero-ctas .btn{width:100%;justify-content:center}
}
@media (max-width:480px){
  .rh-hero{padding:28px 0 44px}
  .rh-hero-chips{flex-direction:column;gap:.6rem}
  .rh-hero-chips li{flex:0 1 auto}
  .rh-hero-photo{border-radius:14px}
  .rh-hero-photo-caption{left:10px;right:10px;bottom:10px;font-size:.78rem;padding:10px 12px}
  .rh-hero-photo-caption b{font-size:.92rem}
}
/* ---------- 2. TRUST / LOGO BAR ---------- */
.rh-trust{padding:48px 0;background:#fff;border-bottom:1px solid var(--line)}
.rh-trust--hidden,.rh-trust[hidden]{display:none !important}
.rh-trust-lead{text-align:center;color:#6b7280;font-size:.82rem;text-transform:uppercase;letter-spacing:.12em;margin:0 0 28px;font-weight:600}
.rh-trust-note{text-align:center;color:var(--muted);font-size:.85rem;margin:18px 0 0}
.rh-trust-note b{color:var(--ink)}
.rh-trust-sub{text-align:center;color:var(--muted);font-size:.78rem;margin:-18px 0 28px;font-style:italic;letter-spacing:.01em}
.rh-logos{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:2.4rem 3rem;margin-bottom:36px;opacity:.55;filter:grayscale(1)}
.rh-logo{font-size:1.4rem;color:#3a3a44;line-height:1.05;display:inline-flex;align-items:baseline;gap:.15em;border:0;padding:0;background:transparent;text-align:left;width:auto}
.rh-logo small{display:block;font-size:.55rem;font-weight:500;letter-spacing:.22em;color:#6b6b75;margin-top:.18rem;text-transform:uppercase}
.rh-logo--serif{font-family:Georgia,'Times New Roman',serif;font-weight:700;letter-spacing:-.01em;font-size:1.55rem}
.rh-logo--bold{font-family:Inter,system-ui,sans-serif;font-weight:900;letter-spacing:-.04em;font-size:1.25rem;text-align:center}
.rh-logo--light{font-family:Inter,system-ui,sans-serif;font-weight:300;letter-spacing:.3em;text-transform:uppercase;font-size:1.05rem}
.rh-logo--italic{font-family:Georgia,'Times New Roman',serif;font-style:italic;font-weight:700;font-size:1.45rem}
.rh-logo--italic i{font-style:normal;color:#dc2626;font-weight:800;font-style:italic}
.rh-logo--tight{font-family:Inter,system-ui,sans-serif;font-weight:800;letter-spacing:-.02em;font-size:1.4rem}
.rh-logo--tight em{font-style:normal;color:#dc2626;font-weight:900;margin-left:.05em}
.rh-logo--mono{font-family:var(--mono);font-weight:700;font-size:1.15rem;letter-spacing:-.02em}
.rh-quote{margin:0 auto;max-width:780px;text-align:center;padding:0 16px}
.rh-quote p{font-size:1.25rem;line-height:1.5;color:var(--ink);margin:0 0 .8rem;font-weight:500}
.rh-quote footer{color:var(--muted);font-size:.92rem;font-style:normal}
@media (max-width:780px){.rh-logos{gap:1.6rem 2rem}.rh-logo{font-size:1.15rem}.rh-logo--serif,.rh-logo--italic,.rh-logo--tight{font-size:1.25rem}}

/* ---------- 3. PAINS ---------- */
.rh-pains{background:#fafafa}
.rh-pain-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.rh-pain-grid .rh-pain:nth-child(4),
.rh-pain-grid .rh-pain:nth-child(5){grid-column:span 1}
@media (min-width:780px){
  .rh-pain-grid{grid-template-columns:repeat(6,1fr)}
  .rh-pain-grid .rh-pain:nth-child(-n+3){grid-column:span 2}
  .rh-pain-grid .rh-pain:nth-child(4),
  .rh-pain-grid .rh-pain:nth-child(5){grid-column:span 3}
}
@media (max-width:780px){.rh-pain-grid{grid-template-columns:repeat(2,1fr);gap:12px}.rh-pain-grid .rh-pain:nth-child(-n+5){grid-column:span 1}.rh-pain-grid .rh-pain:nth-child(5){grid-column:span 2}.rh-pain{padding:18px}.rh-pain-ico{font-size:1.4rem;margin-bottom:.3rem}.rh-pain h3{font-size:.95rem;line-height:1.25;margin:0 0 .35rem}.rh-pain p{font-size:.82rem;line-height:1.4}}
@media (max-width:480px){.rh-pain{padding:14px}.rh-pain h3{font-size:.88rem}.rh-pain p{font-size:.78rem}}

.rh-pain{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:26px;transition:.18s;border-left:3px solid #fee2e2}
.rh-pain:hover{border-left-color:var(--red);transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.rh-pain-ico{font-size:1.8rem;margin-bottom:.5rem}
.rh-pain h3{font-size:1.05rem;line-height:1.3;margin:0 0 .5rem;color:var(--ink)}
.rh-pain p{color:var(--muted);font-size:.92rem;margin:0;line-height:1.5}

/* ---------- 4. SOLUTION ---------- */
.rh-solution-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:stretch}
@media (max-width:880px){.rh-solution-grid{grid-template-columns:1fr}}
.rh-sol-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-xl);padding:32px;position:relative;transition:.2s;display:flex;flex-direction:column}
.rh-sol-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:#fca5a5}
.rh-sol-featured{background:linear-gradient(160deg,#0e0e12,#1a1a1f);color:#fff;border-color:transparent;position:relative;overflow:hidden}
.rh-sol-featured::before{content:"";position:absolute;top:-50%;right:-30%;width:80%;height:200%;background:radial-gradient(closest-side,var(--red-glow),transparent);pointer-events:none}
.rh-sol-num{font-family:var(--mono);font-size:.85rem;color:var(--red);font-weight:800;letter-spacing:.08em;margin-bottom:.6rem}
.rh-sol-card h3{font-size:1.5rem;margin:0 0 .8rem;letter-spacing:-.01em}
.rh-sol-lead{color:var(--graphite);font-size:.98rem;line-height:1.5;margin:0 0 1.2rem}
.rh-sol-card ul{list-style:none;padding:0;margin:auto 0 0}
.rh-sol-card ul li{padding:10px 0;border-top:1px solid var(--line);font-size:.93rem;color:var(--graphite);position:relative;padding-left:1.4em}
.rh-sol-card ul li::before{content:"→";position:absolute;left:0;color:var(--red);font-weight:700}
/* Featured (ciemna) karta — overrides PO regułach .rh-sol-card, żeby kolejność CSS wygrała przy tej samej specyficzności. WCAG AA OK. */
.rh-sol-featured,
.rh-sol-featured h3,
.rh-sol-featured .rh-sol-lead,
.rh-sol-featured p,
.rh-sol-featured strong,
.rh-sol-featured b,
.rh-sol-featured span{color:#fff}
.rh-sol-featured ul li{color:#e5e7eb;border-color:#374151}
.rh-sol-featured .rh-sol-num{color:#fca5a5}
.rh-sol-featured ul li::before{color:#fca5a5}
.rh-sol-featured a{color:#fca5a5}

/* ---------- 5. DEPARTMENTS TABS ---------- */
.rh-tabs{max-width:1100px;margin:0 auto}
/* Zakładki działów: zawsze jedna linia. Desktop = równe szerokości, mobile = swipe z snap. */
.rh-tabs-nav{
  display:flex;flex-wrap:nowrap;overflow-x:auto;gap:6px;
  background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);
  padding:6px;margin-bottom:24px;box-shadow:var(--shadow-sm);
  scroll-snap-type:x mandatory;scrollbar-width:none;-ms-overflow-style:none;
}
.rh-tabs-nav::-webkit-scrollbar{display:none}
.rh-tab{
  flex:1 1 auto;min-width:max-content;scroll-snap-align:start;
  display:flex;align-items:center;justify-content:center;gap:.5rem;
  padding:14px 20px;background:transparent;border:0;border-radius:var(--r);
  font-family:inherit;font-size:.92rem;font-weight:600;color:var(--graphite);
  cursor:pointer;transition:.15s;text-align:center;line-height:1.2;white-space:nowrap;
}
.rh-tab:hover{background:var(--red-soft);color:var(--red-dark)}
.rh-tab.is-active{background:var(--red);color:#fff;box-shadow:0 4px 14px rgba(220,38,38,.3)}
.rh-tab-ico{font-size:1.2rem;flex-shrink:0}
/* Na mobile zakładki nie zmieniają orientacji — po prostu można je swipe'ować w poziomie. */
@media (max-width:880px){
  .rh-tab{font-size:.86rem;padding:12px 16px}
}

.rh-tab-panel{display:none;animation:fadein .3s ease}
.rh-tab-panel.is-active{display:block}
@keyframes fadein{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
.rh-tab-grid{display:grid;grid-template-columns:1.4fr .8fr;gap:32px;align-items:start;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:32px}
@media (max-width:880px){.rh-tab-grid{grid-template-columns:1fr;padding:24px}}
.rh-tab-grid h3{font-size:1.2rem;margin:0 0 1.1rem}
.rh-task-list{list-style:none;padding:0;margin:0}
.rh-task-list li{padding:14px 0;border-bottom:1px solid var(--line);font-size:.95rem;color:var(--graphite);line-height:1.5}
.rh-task-list li:last-child{border-bottom:0}
.rh-task-list li b{color:var(--ink)}

.rh-metric-card{background:linear-gradient(140deg,#dc2626 0%,#7f1d1d 100%);color:#fff;border-radius:var(--r-lg);padding:32px;text-align:center;position:relative;overflow:hidden}
.rh-metric-card::before{content:"";position:absolute;top:-50%;right:-30%;width:80%;height:200%;background:radial-gradient(closest-side,rgba(255,255,255,.18),transparent);pointer-events:none}
.rh-metric-num{font-size:3.6rem;font-weight:800;letter-spacing:-.04em;line-height:1;margin-bottom:.5rem;position:relative}
.rh-metric-lbl{font-size:.98rem;line-height:1.35;font-weight:500;position:relative}
.rh-metric-foot{font-size:.78rem;opacity:.7;margin-top:1.2rem;font-style:italic;position:relative}

/* ---------- 6. TIMELINE / PROCES ---------- */
.rh-process{background:#fff}
.rh-timeline{list-style:none;padding:0;margin:0;display:flex;gap:0;position:relative;counter-reset:rhstep}
.rh-timeline::before{content:"";position:absolute;top:23px;left:8%;right:8%;height:3px;background:linear-gradient(90deg,rgba(220,38,38,.25),var(--red) 20%,var(--red) 80%,rgba(220,38,38,.25));z-index:0;border-radius:2px}
@media (max-width:980px){
  .rh-timeline{flex-direction:column;gap:18px}
  .rh-timeline::before{left:23px;right:auto;top:24px;bottom:24px;width:3px;height:auto;background:linear-gradient(180deg,var(--red),var(--red) 90%,rgba(220,38,38,.4))}
}
.rh-step{position:relative;padding:0 12px;z-index:1;flex:1 1 0;counter-increment:rhstep}
.rh-step::before{
  content:counter(rhstep);
  position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:48px;height:48px;border-radius:50%;
  background:var(--red);color:#fff;
  font-family:var(--mono);font-weight:700;font-size:1.1rem;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 14px rgba(220,38,38,.3);z-index:2;
  border:3px solid #fff;
}
@media (max-width:980px){
  .rh-step{padding:0 0 0 64px}
  .rh-step::before{left:0;transform:none;width:46px;height:46px;font-size:1rem}
}
.rh-step-time{display:block;text-align:center;margin:60px 0 14px;font-family:var(--mono);font-weight:700;font-size:.74rem;letter-spacing:.06em;color:var(--red);background:transparent;padding:0;box-shadow:none;text-transform:uppercase}
@media (max-width:980px){.rh-step-time{text-align:left;margin:0 0 8px}}
.rh-step-body{background:#fafafa;border:1px solid var(--line);border-radius:var(--r-lg);padding:20px;height:100%}
.rh-step-body h3{font-size:1.05rem;margin:0 0 .5rem}
.rh-step-body p{font-size:.9rem;color:var(--graphite);margin:0 0 .6rem;line-height:1.5}
.rh-step-out{display:block;font-size:.82rem;color:var(--muted);padding-top:.6rem;border-top:1px dashed var(--line);line-height:1.4}
.rh-step-out b{color:var(--red-dark)}

/* ---------- 7. SCOPE ---------- */
.rh-scope-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media (max-width:880px){.rh-scope-grid{grid-template-columns:1fr}}
.rh-scope-col{background:rgba(255,255,255,.04);border:1px solid #2a2a32;border-radius:var(--r-lg);padding:28px}
.rh-scope-col h3{font-size:1.15rem;margin:0 0 1.2rem;display:flex;align-items:center;gap:.6rem;color:#fff}
.rh-scope-mark{display:inline-flex;width:32px;height:32px;border-radius:50%;background:rgba(220,38,38,.2);color:#fca5a5;align-items:center;justify-content:center;font-weight:700}
.rh-scope-col ul{list-style:none;padding:0;margin:0}
.rh-scope-col ul li{padding:11px 0;border-top:1px solid #2a2a32;font-size:.93rem;color:#d4d4dc;line-height:1.5}
.rh-scope-col ul li:first-child{border-top:0}

/* ---------- 8. ROI CALCULATOR ---------- */
.rh-roi{background:linear-gradient(180deg,#fafafa,#fff)}
.rh-roi-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-xl);padding:0;display:grid;grid-template-columns:1fr 1fr;overflow:hidden;box-shadow:var(--shadow-lg);max-width:1080px;margin:0 auto}
@media (max-width:880px){.rh-roi-card{grid-template-columns:1fr}}
.rh-roi-inputs{padding:36px 32px;background:#fff}
.rh-roi-field{margin-bottom:24px}
.rh-roi-field label{display:block;font-weight:600;color:var(--graphite);margin-bottom:10px;font-size:.95rem}
.rh-roi-field input[type=range]{
  width:100%;-webkit-appearance:none;appearance:none;
  height:8px;background:var(--line);border-radius:100px;outline:none;
}
.rh-roi-field input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;width:24px;height:24px;border-radius:50%;
  background:var(--red);cursor:pointer;border:3px solid #fff;box-shadow:0 2px 12px rgba(220,38,38,.35);
}
.rh-roi-field input[type=range]::-moz-range-thumb{width:24px;height:24px;border-radius:50%;background:var(--red);cursor:pointer;border:3px solid #fff;box-shadow:0 2px 12px rgba(220,38,38,.35)}
.rh-roi-val{margin-top:8px;font-family:var(--mono);font-weight:700;color:var(--red-dark);font-size:.95rem}

.rh-roi-result{padding:36px 32px;background:linear-gradient(160deg,#0e0e12,#1a1a1f);color:#fff;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden}
.rh-roi-result::before{content:"";position:absolute;top:-50%;right:-30%;width:80%;height:200%;background:radial-gradient(closest-side,var(--red-glow),transparent);pointer-events:none}
.rh-roi-big{margin-bottom:1.6rem;position:relative}
.rh-roi-big-lbl{font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;color:#fca5a5;margin-bottom:.4rem}
.rh-roi-big-num{font-size:clamp(2.4rem,4vw,3.4rem);font-weight:800;letter-spacing:-.03em;line-height:1;color:#fff}
.rh-roi-big-num small{font-size:1.2rem;color:#fca5a5;font-weight:600;margin-left:.3rem}
.rh-roi-meta{display:flex;gap:1.6rem;margin-bottom:1.6rem;position:relative}
.rh-roi-meta div{font-size:.92rem;color:#d4d4dc}
.rh-roi-meta b{display:block;color:#fff;font-size:1.4rem;font-weight:800}
.rh-roi-foot{font-size:.78rem;color:#9b9ba6;margin:1rem 0 0;font-style:italic;position:relative}
.rh-roi-result .btn{position:relative;z-index:1}

/* ---------- 9. CASES ---------- */
.rh-case-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media (max-width:980px){.rh-case-grid{grid-template-columns:1fr}}
.rh-case{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:28px;transition:.2s;display:flex;flex-direction:column;gap:1.1rem}
.rh-case:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:#fca5a5}
.rh-case-tag{display:inline-block;font-family:var(--mono);font-size:.72rem;color:var(--red);background:var(--red-soft);padding:.3rem .7rem;border-radius:100px;letter-spacing:.05em;margin-bottom:.6rem}
.rh-case h3{font-size:1.15rem;line-height:1.3;margin:0;color:var(--ink)}
.rh-case-body p{margin:0;color:var(--graphite);font-size:.92rem;line-height:1.55}
.rh-case-nums{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--line);padding-top:1rem;margin-top:auto}
.rh-case-nums div{text-align:center;border-right:1px solid var(--line);padding:0 .4rem}
.rh-case-nums div:last-child{border-right:0}
.rh-case-nums b{display:block;font-size:1.3rem;color:var(--red);font-weight:800;letter-spacing:-.02em}
.rh-case-nums span{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}

/* ---------- 10. SECURITY ---------- */
.rh-sec-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
@media (max-width:880px){.rh-sec-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.rh-sec-grid{grid-template-columns:1fr}}
.rh-sec-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:24px;transition:.18s;text-align:left}
.rh-sec-card:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:#fca5a5}
.rh-sec-ico{font-size:2rem;margin-bottom:.7rem}
.rh-sec-card h3{font-size:1.05rem;margin:0 0 .5rem}
.rh-sec-card p{font-size:.88rem;color:var(--muted);margin:0;line-height:1.5}
.rh-sec-card--highlight{background:linear-gradient(180deg,#fff5f5 0%,#fff 70%);border:1.5px solid #fca5a5;box-shadow:0 8px 28px rgba(220,38,38,.08)}
.rh-sec-card--highlight h3{color:var(--brand-strong,#b91c1c)}
.rh-sec-card--highlight p{color:#3f3f46}
.rh-sec-card--highlight p b{color:#0a0a0a}
.rh-hero-stats-note{margin:1rem 0 0;font-size:.78rem;color:#9b9ba6;text-align:center;letter-spacing:.01em}

/* ---------- 11. FAQ ACCORDION ---------- */
.rh-faq{background:#fafafa}
.rh-accordion{display:flex;flex-direction:column;gap:8px;max-width:820px;margin:0 auto}
.rh-acc-item{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);transition:.15s;overflow:hidden}
.rh-acc-item[open]{border-color:#fca5a5;box-shadow:var(--shadow)}
.rh-acc-item summary{cursor:pointer;padding:18px 24px;font-weight:600;color:var(--ink);font-size:1.02rem;list-style:none;position:relative;padding-right:48px}
.rh-acc-item summary::-webkit-details-marker{display:none}
.rh-acc-item summary::after{content:"+";position:absolute;right:20px;top:50%;transform:translateY(-50%);font-size:1.6rem;color:var(--red);font-weight:300;line-height:1;transition:.15s}
.rh-acc-item[open] summary::after{transform:translateY(-50%) rotate(45deg)}
.rh-acc-item summary:hover{background:#fff5f5}
.rh-acc-body{padding:0 24px 20px;color:var(--graphite);font-size:.95rem;line-height:1.6}
.rh-acc-body p{margin:0}
.rh-acc-body b{color:var(--ink)}

/* ---------- 12. PARTNERS ---------- */
.rh-partners{padding:80px 0}
.rh-partner-card{background:linear-gradient(135deg,#0e0e12 0%,#1a1a1f 60%,#7f1d1d 130%);color:#fff;border-radius:var(--r-xl);padding:56px;display:grid;grid-template-columns:1.3fr 1fr;gap:48px;align-items:center;box-shadow:var(--shadow-lg);position:relative;overflow:hidden}
.rh-partner-card::before{content:"";position:absolute;top:-30%;right:-10%;width:60%;height:160%;background:radial-gradient(closest-side,rgba(220,38,38,.32),transparent);pointer-events:none}
.rh-partner-text{position:relative}
.rh-partner-text h2{color:#fff;margin:0 0 1rem;font-size:clamp(1.6rem,2.6vw,2.2rem)}
.rh-partner-lead{font-size:1.05rem;color:#d4d4dc;margin:0 0 1.6rem;line-height:1.55}
.rh-kicker-light{color:#fca5a5}
.rh-partner-stats{display:flex;gap:2.4rem;margin-bottom:2rem;flex-wrap:wrap}
.rh-partner-stats div b{display:block;font-size:1.8rem;color:#fff;font-weight:800;letter-spacing:-.02em;line-height:1}
.rh-partner-stats div span{display:block;font-size:.82rem;color:#fca5a5;text-transform:uppercase;letter-spacing:.05em;margin-top:.3rem}
.rh-partner-ctas{display:flex;gap:.8rem;flex-wrap:wrap}
.rh-partner-card .btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.3)}
.rh-partner-card .btn-ghost:hover{background:rgba(255,255,255,.08);border-color:#fff}

.rh-partner-bullets{list-style:none;padding:0;margin:0;position:relative}
.rh-partner-bullets li{padding:12px 0 12px 28px;color:#d4d4dc;font-size:.95rem;border-bottom:1px solid rgba(255,255,255,.08);position:relative;line-height:1.5}
.rh-partner-bullets li::before{content:"→";position:absolute;left:0;color:var(--red);font-weight:700}
.rh-partner-bullets li:last-child{border-bottom:0}
.rh-partner-bullets li b{color:#fff;font-weight:700}

@media (max-width:880px){.rh-partner-card{grid-template-columns:1fr;padding:32px;gap:32px}}

/* ---------- 13. CTA + FORM ---------- */
.rh-cta-form{padding:80px 0}
.rh-cta-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:48px;align-items:start;max-width:1180px;margin:0 auto}
@media (max-width:980px){.rh-cta-grid{grid-template-columns:1fr;gap:32px}}
.rh-cta-text h2{color:#fff;margin:0 0 1rem;font-size:clamp(1.8rem,3vw,2.6rem)}
.rh-cta-lead{font-size:1.1rem;color:#d4d4dc;margin:0 0 1.6rem;line-height:1.55}
.rh-cta-promises{list-style:none;padding:0;margin:0 0 2rem;display:flex;flex-direction:column;gap:8px}
.rh-cta-promises li{color:#d4d4dc;font-size:.95rem;padding:8px 0}
.rh-cta-promises li b{color:#fff;font-weight:700}
.rh-cta-direct{color:#9b9ba6;font-size:.95rem;padding:18px 0 0;border-top:1px solid #2a2a32}
.rh-cta-direct p{margin:0 0 .4rem;font-size:.82rem;text-transform:uppercase;letter-spacing:.06em;color:#9b9ba6}
.rh-cta-direct a{font-family:var(--mono);color:#fca5a5;font-weight:600}

.rh-cta-form-block{background:#fff;color:var(--ink);border-radius:var(--r-xl);padding:36px;box-shadow:var(--shadow-lg);position:relative;width:100%;max-width:100%;min-width:0}
@media (max-width:640px){
  .rh-cta-form-block{padding:24px 18px;border-radius:16px}
  .rh-cta-form-block h3{font-size:.9rem}
  .rh-cta-form-block .field input,
  .rh-cta-form-block .field textarea,
  .rh-cta-form-block .field select{font-size:16px;padding:.85rem .9rem;min-height:48px}
  .rh-cta-form-block .field textarea{min-height:120px}
  .rh-cta-form-block .btn{min-height:48px;font-size:1rem}
  .rh-radio-row{gap:6px}
  .rh-radio{min-width:0;flex:1 1 calc(50% - 3px)}
  .rh-radio span{padding:12px 8px;font-size:.88rem}
  .rh-checkbox-row{font-size:.85rem;line-height:1.45}
  .rh-form-foot{font-size:.78rem}
}
@media (max-width:380px){
  .rh-cta-form-block{padding:20px 14px}
}
.rh-cta-form-block h3{margin:1.4rem 0 1rem;font-size:1rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;padding-top:1rem;border-top:1px solid var(--line)}
.rh-cta-form-block h3.mt-0{margin-top:0;padding-top:0;border-top:0}

.rh-form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media (max-width:640px){.rh-form-row{grid-template-columns:1fr;gap:0}}

.rh-radio-row{display:flex;gap:8px;flex-wrap:wrap}
.rh-radio{flex:1;min-width:60px;cursor:pointer;position:relative}
.rh-radio input{position:absolute;inset:0;opacity:0;pointer-events:none;width:100%;height:100%}
.rh-radio span{display:block;padding:10px 14px;text-align:center;border:1.5px solid var(--line);border-radius:var(--r);font-weight:600;font-size:.92rem;color:var(--graphite);transition:.12s;background:#fff}
.rh-radio input:checked + span{background:var(--red);color:#fff;border-color:var(--red);box-shadow:0 4px 14px rgba(220,38,38,.3)}
.rh-radio span:hover{border-color:#fca5a5;color:var(--red-dark)}

.rh-checkbox-row{display:flex;align-items:flex-start;gap:.6rem;cursor:pointer;font-weight:400 !important;font-size:.86rem;color:var(--muted);line-height:1.5}
.rh-checkbox-row input{width:auto;margin-top:.2rem;accent-color:var(--red)}
.rh-rodo{margin-top:1.4rem}
.rh-form-foot{text-align:center;color:var(--muted);font-size:.82rem;margin:.8rem 0 0;font-style:italic}

/* ---------- Anchor offset (sticky header) ---------- */
section[id]{scroll-margin-top:80px}

/* =========================================================
   HOMEPAGE v3 — PREMIUM PHOTO PASS
   Wizualizacje rack RedAI + dark hero + split layouts.
   Wszystko nadpisuje wcześniejsze deklaracje przez kaskadę.
   ========================================================= */

/* ---------- HERO DARK z obrazem ---------- */
.rh-hero.rh-hero--dark{
  background:
    radial-gradient(ellipse 70% 50% at 75% 30%, rgba(220,38,38,.28), transparent 60%),
    radial-gradient(ellipse 50% 40% at 15% 90%, rgba(220,38,38,.12), transparent 60%),
    linear-gradient(180deg, #06060a 0%, #0c0c12 60%, #0a0a0e 100%);
  color:#fff;
  padding:96px 0 96px;
  border-bottom:1px solid #1a1a22;
}
.rh-hero.rh-hero--dark .kicker{
  color:#fca5a5; text-transform:uppercase; letter-spacing:.12em; font-size:.78rem;
  font-weight:700; display:inline-block; margin-bottom:1rem;
  padding:.4rem .8rem; background:rgba(220,38,38,.12); border:1px solid rgba(220,38,38,.3);
  border-radius:999px;
}
.rh-hero.rh-hero--dark h1{
  color:#fff;
  font-size:clamp(1.85rem, 5.4vw, 4.4rem);
  line-height:1.05; letter-spacing:-.03em; font-weight:800;
  margin:0 0 1rem;
  max-width:780px;
}
.rh-hero.rh-hero--dark .rh-accent{
  background:linear-gradient(90deg, #ef4444 0%, #f87171 60%, #fca5a5 100%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.rh-hero.rh-hero--dark .rh-hero-sub{
  color:#e4e4ec; font-size:clamp(1.05rem, 1.6vw, 1.42rem);
  max-width:620px; line-height:1.5; margin:0 0 .9rem;
  font-weight:600;
}
.rh-hero.rh-hero--dark .rh-hero-sub b{color:#fff;font-weight:700}
.rh-hero.rh-hero--dark .rh-hero-desc{
  color:#9b9ba6; font-size:clamp(.88rem, 1.1vw, 1rem);
  max-width:580px; line-height:1.55; margin:0 0 1.6rem;
}
.rh-hero.rh-hero--dark .rh-hero-chips{ color:#9b9ba6 }
.rh-hero.rh-hero--dark .rh-hero-chips li b{ color:#fff }
.rh-hero.rh-hero--dark .btn-ghost{
  background:transparent; color:#fff; border:1.5px solid rgba(255,255,255,.25);
}
.rh-hero.rh-hero--dark .btn-ghost:hover{
  background:rgba(255,255,255,.06); border-color:rgba(255,255,255,.5);
}

.rh-hero-bg{
  position:absolute; inset:0; pointer-events:none; z-index:0;
  background:
    radial-gradient(circle at 80% 20%, rgba(220,38,38,.18), transparent 40%),
    radial-gradient(circle at 20% 80%, rgba(220,38,38,.08), transparent 50%);
}
.rh-hero .container{ position:relative; z-index:1 }

.rh-hero-photo{
  position:relative; margin:0;
  border-radius:24px; overflow:hidden;
  box-shadow:
    0 30px 80px -20px rgba(220,38,38,.35),
    0 20px 60px -20px rgba(0,0,0,.6),
    0 0 0 1px rgba(255,255,255,.06);
  background:#0a0a0e;
  transform:perspective(1400px) rotateY(-3deg) rotateX(1.5deg);
  transition:transform .6s ease;
}
.rh-hero-photo:hover{ transform:perspective(1400px) rotateY(-1deg) rotateX(.5deg) }
.rh-hero-photo img{
  display:block; width:100%; height:auto;
  filter:saturate(1.05) contrast(1.05);
}
.rh-hero-photo-caption{
  position:absolute; left:18px; bottom:18px; right:18px;
  display:flex; align-items:center; gap:.6rem;
  padding:12px 16px; border-radius:12px;
  background:rgba(8,8,12,.85); backdrop-filter:blur(8px);
  color:#e4e4ec; font-size:.85rem; line-height:1.4;
  border:1px solid rgba(255,255,255,.08);
}
.rh-hero-photo-caption b{ color:#fff; font-size:1.05rem; font-weight:800; margin-right:.2rem }

.rh-hero-stats{
  display:grid; grid-template-columns:repeat(4, 1fr); gap:14px;
  margin-top:64px; padding-top:36px;
  border-top:1px solid rgba(255,255,255,.08);
}
.rh-hero-stat{
  display:flex; flex-direction:column; gap:.3rem;
  padding:18px 20px; border-radius:14px;
  background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.06);
}
.rh-hero-stat .rh-tag{
  width:fit-content; font-size:.68rem; letter-spacing:.1em; padding:3px 9px;
  border-radius:999px; font-weight:700;
}
.rh-hero-stat b{
  font-size:1.8rem; font-weight:800; color:#fff; letter-spacing:-.02em; line-height:1;
}
.rh-hero-stat small{ color:#9b9ba6; font-size:.78rem; line-height:1.35 }

/* tagi w hero (na ciemnym) - przeciwwagi do jasnych z dashboarda */
.rh-hero-stats .rh-tag.green{ background:rgba(34,197,94,.15); color:#86efac }
.rh-hero-stats .rh-tag.blue { background:rgba(59,130,246,.15); color:#93c5fd }
.rh-hero-stats .rh-tag.amber{ background:rgba(245,158,11,.15); color:#fcd34d }
.rh-hero-stats .rh-tag.pink { background:rgba(236,72,153,.15); color:#f9a8d4 }

@media (max-width:980px){
  .rh-hero.rh-hero--dark{ padding:64px 0 64px }
  .rh-hero-grid{ grid-template-columns:1fr; gap:36px }
  .rh-hero-photo{ transform:none }
  .rh-hero-stats{ grid-template-columns:repeat(2,1fr); margin-top:44px }
}
@media (max-width:520px){
  .rh-hero-stats{ grid-template-columns:1fr }
}

/* ---------- SPLIT HEAD: DZIALY ---------- */
.rh-depts-head{
  display:grid; grid-template-columns:1.15fr 1fr; gap:56px;
  align-items:center; margin-bottom:48px;
}
.rh-depts-visual{
  margin:0; border-radius:20px; overflow:hidden;
  box-shadow: 0 24px 60px -20px rgba(220,38,38,.25), 0 12px 40px -16px rgba(0,0,0,.4);
  background:#0a0a0e;
  position:relative;
}
.rh-depts-visual::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 60%, rgba(0,0,0,.4));
  pointer-events:none;
}
.rh-depts-visual img{ display:block; width:100%; height:auto; filter:saturate(1.1) }
.section-head--left{ text-align:left }
.section-head--left h2{ font-size:clamp(1.8rem,3vw,2.6rem); line-height:1.1 }

@media (max-width:980px){
  .rh-depts-head{ grid-template-columns:1fr; gap:28px }
}

/* ---------- SPLIT HEAD: BEZPIECZEŃSTWO ---------- */
.rh-sec-head{
  display:grid; grid-template-columns:1fr 1.15fr; gap:56px;
  align-items:center; margin-bottom:48px;
}
.rh-sec-photo{
  margin:0; border-radius:20px; overflow:hidden; position:relative;
  box-shadow: 0 24px 60px -20px rgba(220,38,38,.20), 0 12px 40px -16px rgba(0,0,0,.4);
  background:#0a0a0e;
}
.rh-sec-photo img{ display:block; width:100%; height:auto }
.rh-sec-photo figcaption{
  position:absolute; left:18px; bottom:18px; right:18px;
  padding:12px 16px; border-radius:12px;
  background:rgba(8,8,12,.85); backdrop-filter:blur(8px);
  color:#e4e4ec; font-size:.88rem; line-height:1.4;
  border:1px solid rgba(255,255,255,.08); font-style:normal;
}
@media (max-width:980px){
  .rh-sec-head{ grid-template-columns:1fr; gap:28px }
}

/* ---------- PARTNERZY z tłem ---------- */
.rh-partners{ position:relative; overflow:hidden }
.rh-partners-bg{
  position:absolute; inset:0; z-index:0;
  background-image:
    linear-gradient(135deg, rgba(8,8,12,.92) 0%, rgba(20,8,12,.85) 50%, rgba(8,8,12,.75) 100%),
    url('/assets/img/wizualizacje/datacenter-rack.webp');
  background-size:cover; background-position:center; background-repeat:no-repeat;
}
.rh-partners .container{ position:relative; z-index:1 }
.rh-partners .rh-partner-card{
  background:linear-gradient(160deg, rgba(20,20,26,.92), rgba(10,10,14,.92));
  backdrop-filter:blur(4px);
  border:1px solid rgba(220,38,38,.25);
  box-shadow: 0 30px 80px -20px rgba(0,0,0,.6), 0 0 60px -20px rgba(220,38,38,.3);
}

/* ---------- TRUST: poprawka logo bara — grayscale, hover odsłania kolor (placeholder, do podmianki na realne loga) ---------- */
.rh-logos{
  display:grid; grid-template-columns:repeat(6,1fr); gap:18px;
  align-items:center; opacity:.6; filter:grayscale(1);
  transition:opacity .25s ease, filter .25s ease;
}
.rh-logos:hover{opacity:1; filter:grayscale(0)}
.rh-logo{
  text-align:center; padding:12px 8px; height:40px;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--mono); font-size:.78rem; letter-spacing:.08em;
  color:var(--graphite); border:1px dashed var(--line); border-radius:8px;
  background:#fff;
  min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}
@media (max-width:780px){
  .rh-logos{grid-template-columns:repeat(3,1fr); gap:10px}
  .rh-logo{font-size:.68rem; padding:10px 4px; letter-spacing:.04em}
}
@media (max-width:420px){
  .rh-logos{grid-template-columns:repeat(2,1fr)}
}

/* ---------- Sticky header tweak: ciemniej gdy hero dark ---------- */
body.page-home .site-header{
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(12px);
}

/* ---------- Typografia ogólnie ---------- */
.section-head h2{ font-size:clamp(1.8rem, 3vw, 2.6rem); line-height:1.1; letter-spacing:-.025em }
.section-head .kicker{
  text-transform:uppercase; letter-spacing:.12em; font-size:.78rem; font-weight:700;
  color:var(--red-dark); margin-bottom:.6rem; display:inline-block;
}

/* ---------- Mobile: trochę powietrza ---------- */
@media (max-width:780px){
  .rh-hero.rh-hero--dark{ padding:48px 0 48px }
  .rh-hero.rh-hero--dark h1{ font-size:2.2rem }
}

/* iPhone SE i mniejsze (375x667) — żeby CTA mieściło się above fold */
@media (max-width:380px){
  .rh-hero,
  .rh-hero.rh-hero--dark{padding:18px 0 28px}
  .rh-hero .kicker,
  .rh-hero.rh-hero--dark .kicker{font-size:.68rem;margin-bottom:.55rem;padding:.28rem .55rem}
  .rh-hero h1,
  .rh-hero.rh-hero--dark h1{font-size:1.55rem;line-height:1.14;margin:0 0 .6rem}
  .rh-hero-sub,
  .rh-hero.rh-hero--dark .rh-hero-sub{font-size:.92rem;margin:0 0 .8rem;line-height:1.45}
  .rh-hero-desc,
  .rh-hero.rh-hero--dark .rh-hero-desc{font-size:.82rem;margin:0 0 .95rem;line-height:1.45}
  .rh-hero-ctas{gap:.5rem;margin-bottom:.5rem;flex-direction:column;align-items:stretch}
  .rh-hero-ctas .btn{padding:.7rem 1rem;font-size:.9rem;width:100%;justify-content:center}
  .rh-hero-reassure,
  .rh-hero.rh-hero--dark .rh-hero-reassure{font-size:.72rem;margin:0 0 .8rem;line-height:1.4}
  .rh-hero-chips{gap:.35rem .9rem;font-size:.8rem;flex-direction:row;flex-wrap:wrap}
  .rh-hero-chips li{flex:1 1 100%}
  .rh-hero-grid{gap:18px}
  .rh-hero-visual{display:none}
}

/* ==========================================================
   ZESPÓŁ + DELIVERABLES + CASE QUOTE — sekcje wprowadzone 2026-05-20
   ========================================================== */
.rh-team{ padding:88px 0 }
.rh-team-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.6rem; margin-top:2.2rem }
.rh-team-card{ background:#fff; border:1px solid var(--line); border-radius:14px; padding:1.6rem 1.5rem; text-align:left; transition:transform .18s ease, box-shadow .18s ease }
.rh-team-card:hover{ transform:translateY(-2px); box-shadow:0 14px 38px rgba(0,0,0,.08) }
.rh-team-photo{
  width:78px; height:78px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  background:linear-gradient(135deg, #0e0e12, #2a2a32);
  color:#fff; font-weight:800; font-size:1.4rem; letter-spacing:.04em;
  margin-bottom:1rem;
  border:3px solid var(--red);
}
.rh-team-card h3{ margin:0 0 .2rem; font-size:1.15rem }
.rh-team-role{ color:var(--red); font-weight:700; font-size:.92rem; margin:0 0 .6rem; text-transform:uppercase; letter-spacing:.04em }
.rh-team-bio{ font-size:.95rem; color:var(--graphite); line-height:1.55; margin:0 }
.rh-team-foot{
  margin-top:2rem; padding:1.2rem 1.6rem; border-left:4px solid var(--red);
  background:rgba(220,38,38,.05); border-radius:0 10px 10px 0;
  font-size:1.05rem; color:#0e0e12;
}
@media (max-width:980px){ .rh-team-grid{ grid-template-columns:repeat(2,1fr) } }

/* Mobile: pozioma karuzela zespołu (snap, scroll, ukryty scrollbar) */
.rh-team-dots{ display:none }
@media (max-width:640px){
  .rh-team-grid{
    display:flex;
    grid-template-columns:none;
    overflow-x:auto;
    scroll-snap-type:x mandatory;
    gap:1rem;
    padding:0 1.2rem 1rem;
    margin:1.4rem -1.2rem 0;
    scrollbar-width:none;
    -ms-overflow-style:none;
    scroll-behavior:smooth;
  }
  .rh-team-grid::-webkit-scrollbar{ display:none }
  .rh-team-card{
    flex:0 0 85%;
    scroll-snap-align:start;
    min-width:0;
  }
  .rh-team-dots{
    display:flex;
    justify-content:center;
    gap:.5rem;
    margin:.4rem 0 0;
    padding:0;
  }
  .rh-team-dot{
    width:8px; height:8px; border-radius:50%;
    background:#d4d4d8; border:0; padding:0;
    cursor:pointer; transition:background .2s ease, transform .2s ease;
  }
  .rh-team-dot.is-active{
    background:var(--red); transform:scale(1.25);
  }
}

.rh-deliverables{ padding:88px 0 }
.rh-deliv-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; margin-top:2.2rem }
.rh-deliv-item{ padding:1.5rem 1.4rem 1.4rem; border:1px solid var(--line); border-radius:14px; background:#fff }
.rh-deliv-ico{
  width:40px; height:40px; border-radius:50%;
  background:var(--red); color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-weight:800; font-size:1.3rem; margin-bottom:.9rem;
}
.rh-deliv-item h3{ margin:0 0 .5rem; font-size:1.08rem }
.rh-deliv-item p{ margin:0; font-size:.95rem; color:var(--graphite); line-height:1.55 }
@media (max-width:980px){ .rh-deliv-grid{ grid-template-columns:repeat(2,1fr) } }
@media (max-width:640px){ .rh-deliv-grid{ grid-template-columns:repeat(2,1fr); gap:.8rem } .rh-deliv-item{ padding:16px } .rh-deliv-item h3{ font-size:.95rem; line-height:1.25 } .rh-deliv-item p{ font-size:.82rem; line-height:1.4 } .rh-deliv-ico{ font-size:1.3rem } }
@media (max-width:420px){ .rh-deliv-item{ padding:12px } .rh-deliv-item h3{ font-size:.88rem } .rh-deliv-item p{ font-size:.78rem } }

/* Case study cards — wzbogacony layout */
.rh-case-quote{
  font-size:1.02rem; font-style:italic; color:#0e0e12;
  border-left:3px solid var(--red); padding:.4rem 0 .4rem 1rem;
  margin:.4rem 0 1.1rem;
}
.rh-case-author{ display:flex; align-items:center; gap:.9rem; margin:.6rem 0 1rem }
.rh-case-author-photo{
  width:48px; height:48px; border-radius:50%;
  background:linear-gradient(135deg, #dc2626, #7a1414);
  color:#fff; font-weight:700; font-size:.95rem;
  display:flex; align-items:center; justify-content:center;
}
.rh-case-author b{ display:block; font-size:1rem; color:#0e0e12 }
.rh-case-author span{ display:block; font-size:.84rem; color:#71717a }
.rh-case-meta{ font-size:.84rem; color:#71717a; margin:.2rem 0 0 }
.rh-cases-note{
  margin:1.6rem auto 0; max-width:780px; text-align:center;
  font-size:.86rem; color:#71717a; font-style:italic;
}

/* =========================================================
   CASE STUDIES — list view + single view
   ========================================================= */
.rh-cs-filters{
  display:flex; flex-wrap:wrap; gap:.6rem; justify-content:center;
  margin:0 0 2rem;
}
.rh-cs-filter{
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.55rem 1rem; border-radius:999px;
  background:#fff; border:1px solid #e5e7eb;
  color:var(--ink); text-decoration:none; font-size:.92rem; font-weight:500;
  transition:all .15s ease;
}
.rh-cs-filter:hover{ border-color:var(--red); color:var(--red) }
.rh-cs-filter.is-active{ background:var(--red); color:#fff; border-color:var(--red) }
.rh-cs-filter-c{
  display:inline-block; padding:.05rem .5rem; border-radius:999px;
  background:rgba(0,0,0,.08); font-size:.78rem; font-weight:600;
}
.rh-cs-filter.is-active .rh-cs-filter-c{ background:rgba(255,255,255,.25) }

.rh-cs-intro{
  max-width:780px; margin:0 auto 2rem; text-align:center;
  font-size:1rem; color:var(--graphite); line-height:1.7;
}

.rh-cs-grid{
  display:grid; grid-template-columns:repeat(3, 1fr); gap:1.2rem;
}
@media (max-width:980px){ .rh-cs-grid{ grid-template-columns:repeat(2, 1fr) } }
@media (max-width:640px){ .rh-cs-grid{ grid-template-columns:1fr } }

.rh-cs-card{
  display:flex; flex-direction:column; gap:.6rem;
  padding:1.3rem 1.3rem 1.1rem; border-radius:14px;
  background:#fff; border:1px solid #e5e7eb;
  text-decoration:none; color:var(--ink);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.rh-cs-card:hover{
  transform:translateY(-3px);
  box-shadow:0 14px 40px rgba(220,38,38,.08);
  border-color:var(--red);
}
.rh-cs-card-head{
  display:flex; align-items:center; justify-content:space-between;
  font-size:.82rem;
}
.rh-cs-card-dept{
  font-weight:600; color:var(--red);
}
.rh-cs-card-size{
  color:#71717a;
}
.rh-cs-card h3{
  font-size:1.06rem; line-height:1.35; margin:.1rem 0 .15rem; font-weight:700;
}
.rh-cs-card-industry{
  font-size:.84rem; color:#71717a; margin:0;
  text-transform:uppercase; letter-spacing:.04em; font-weight:600;
}
.rh-cs-card-excerpt{
  font-size:.93rem; color:var(--graphite); line-height:1.55;
  margin:0; flex-grow:1;
}
.rh-cs-card-metric{
  display:flex; align-items:baseline; gap:.5rem;
  padding:.7rem .9rem; border-radius:10px;
  background:#fff5f5; border:1px solid #fecaca;
  margin:.4rem 0 .2rem;
}
.rh-cs-card-metric-v{
  font-weight:800; color:var(--red); font-size:1.3rem;
  letter-spacing:-.02em;
}
.rh-cs-card-metric-l{
  font-size:.82rem; color:var(--graphite); line-height:1.3;
}
.rh-cs-card-tags{
  display:flex; flex-wrap:wrap; gap:.35rem; margin:.1rem 0 .3rem;
}
.rh-cs-tag{
  display:inline-block; padding:.2rem .55rem; border-radius:999px;
  background:#f4f4f5; color:#52525b; font-size:.74rem;
  border:1px solid #e4e4e7; font-weight:500;
}
.rh-cs-tag--link{ cursor:pointer; text-decoration:none; transition:all .15s ease }
.rh-cs-tag--link:hover{ background:var(--red); color:#fff; border-color:var(--red) }
.rh-cs-card-cta{
  margin-top:auto; padding-top:.4rem;
  color:var(--red); font-weight:600; font-size:.92rem;
}

/* Single case study */
.rh-cs-back{
  color:#71717a; text-decoration:none; font-size:.9rem;
}
.rh-cs-back:hover{ color:var(--red) }

.rh-cs-hero-metrics{
  display:grid; grid-template-columns:repeat(auto-fit, minmax(180px, 1fr));
  gap:1rem; margin:0 0 .8rem;
}
.rh-cs-hero-metric{
  padding:1.2rem 1.4rem; border-radius:12px;
  background:#fff; border:1px solid #e5e7eb;
  text-align:left;
}
.rh-cs-hero-metric--big{
  background:linear-gradient(135deg, #dc2626, #b91c1c);
  color:#fff; border-color:transparent;
}
.rh-cs-hero-metric-v{
  font-size:2.2rem; font-weight:800; line-height:1.05;
  letter-spacing:-.03em; color:var(--red);
}
.rh-cs-hero-metric--big .rh-cs-hero-metric-v{ color:#fff }
.rh-cs-hero-metric-l{
  font-size:.9rem; color:var(--graphite); line-height:1.4; margin-top:.3rem;
}
.rh-cs-hero-metric--big .rh-cs-hero-metric-l{ color:rgba(255,255,255,.92) }
.rh-cs-period{
  font-size:.86rem; color:#71717a; text-align:right; margin:.4rem 0 0;
}

.rh-cs-body{
  font-size:1.02rem; line-height:1.75; color:#27272a;
}
.rh-cs-body h2{
  margin:2rem 0 .8rem; font-size:1.4rem; font-weight:700;
  border-left:4px solid var(--red); padding-left:.8rem; line-height:1.3;
}
.rh-cs-body h3{
  margin:1.6rem 0 .6rem; font-size:1.1rem; font-weight:700;
}
.rh-cs-body p{ margin:0 0 1rem }
.rh-cs-body ul, .rh-cs-body ol{ margin:0 0 1.2rem 1.4rem }
.rh-cs-body li{ margin:.3rem 0 }
.rh-cs-body b, .rh-cs-body strong{ color:var(--ink) }

.rh-cs-quote{
  border:0; border-left:4px solid var(--red);
  margin:2rem 0; padding:1.2rem 1.4rem;
  background:#fff5f5; border-radius:0 12px 12px 0;
}
.rh-cs-quote p{
  font-size:1.08rem; line-height:1.6; font-style:italic;
  color:#27272a; margin:0 0 .6rem;
}
.rh-cs-quote footer{
  font-size:.87rem; color:#52525b;
}

.rh-cs-meta{
  margin:2rem 0 0; padding:1.4rem 0;
  border-top:1px solid #e5e7eb;
  display:flex; flex-direction:column; gap:.8rem;
  font-size:.92rem;
}
.rh-cs-meta strong{ display:inline-block; margin-right:.6rem; color:#71717a; font-weight:600 }
.rh-cs-dept-chip{
  display:inline-block; padding:.3rem .7rem; margin:.2rem .3rem .2rem 0;
  border-radius:999px; background:#f4f4f5; border:1px solid #e4e4e7;
  color:var(--ink); text-decoration:none; font-size:.86rem;
}
.rh-cs-dept-chip:hover{ background:var(--red); color:#fff; border-color:var(--red) }

.rh-cs-grid--related .rh-cs-card{ background:#fff }

/* =========================================================
   HOME — Case study teaser w tabach działów (sekcja #dzialy)
   ========================================================= */
.rh-tab-case{
  margin-top: 2rem;
  padding: 1.5rem 1.75rem;
  border: 1px solid #e5e7eb;
  border-left: 4px solid var(--red);
  border-radius: 12px;
  background: linear-gradient(180deg, #fafafa 0%, #fff 70%);
}
.rh-tab-case-tag{
  display:inline-block; padding:.25rem .7rem; font-size:.72rem;
  letter-spacing:.08em; text-transform:uppercase; font-weight:700;
  color:var(--red); background:#fee2e2; border-radius:999px;
  margin-bottom:.65rem;
}
.rh-tab-case h4{
  font-size:1.18rem; line-height:1.35; margin:.1rem 0 .6rem; color:var(--ink);
}
.rh-tab-case p{
  margin:0 0 1rem; color:#475569; font-size:.96rem; line-height:1.55;
}
.rh-tab-case-links{
  display:flex; gap:1.25rem; flex-wrap:wrap; align-items:center;
}
.rh-tab-case-cta{
  display:inline-block; padding:.55rem 1.1rem; border-radius:8px;
  background:var(--ink); color:#fff; font-weight:600; font-size:.92rem;
  text-decoration:none; transition:background .15s;
}
.rh-tab-case-cta:hover{ background:var(--red); color:#fff }
.rh-tab-case-more{
  color:var(--red); font-weight:600; font-size:.92rem;
  text-decoration:none; border-bottom:1px dashed transparent;
  transition:border-color .15s;
}
.rh-tab-case-more:hover{ border-bottom-color:var(--red) }

/* =========================================================
   HOME — Linki w kartach #dowody (3 historie)
   ========================================================= */
.rh-case-foot{
  display:flex; justify-content:space-between; align-items:center;
  gap:1rem; flex-wrap:wrap;
  padding-top:1rem; margin-top:1rem; border-top:1px solid #e5e7eb;
}
.rh-case-link{
  color:var(--ink); font-weight:700; font-size:.92rem; text-decoration:none;
  border-bottom:2px solid var(--red); padding-bottom:2px;
}
.rh-case-link:hover{ color:var(--red) }
.rh-case-more{
  color:#64748b; font-size:.86rem; text-decoration:none;
}
.rh-case-more:hover{ color:var(--red); text-decoration:underline }

/* =========================================================
   HOME — Poziomy wdrożenia (Start / Growth / Enterprise) — bez cen
   ========================================================= */
.rh-tiers{padding:80px 0;background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.rh-tiers-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:stretch;margin-top:40px}
@media (max-width:980px){.rh-tiers-grid{grid-template-columns:1fr;gap:16px}}
.rh-tier{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--r-xl);padding:32px 28px;display:flex;flex-direction:column;transition:.2s}
.rh-tier:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.rh-tier--featured{border:2px solid var(--red);box-shadow:0 8px 28px rgba(220,38,38,.12);transform:scale(1.02);background:linear-gradient(180deg,#fff5f5 0%,#fff 80%)}
@media (max-width:980px){.rh-tier--featured{transform:none}}
.rh-tier-badge{
  position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:var(--red);color:#fff;font-size:.78rem;font-weight:700;
  letter-spacing:.04em;text-transform:uppercase;
  padding:6px 14px;border-radius:999px;white-space:nowrap;
  box-shadow:0 4px 12px rgba(220,38,38,.35);
}
.rh-tier-head{margin-bottom:1.4rem;padding-bottom:1.2rem;border-bottom:1px solid var(--line)}
.rh-tier-head h3{margin:0 0 .6rem;font-size:1.35rem;letter-spacing:-.01em}
.rh-tier-for{margin:0;color:var(--muted);font-size:.92rem;line-height:1.45}
.rh-tier-list{list-style:none;padding:0;margin:0 0 1.6rem;flex:1}
.rh-tier-list li{
  position:relative;padding:10px 0 10px 1.8rem;
  font-size:.94rem;color:var(--ink);line-height:1.45;
  border-bottom:1px solid #f3f4f6;
}
.rh-tier-list li:last-child{border-bottom:0}
.rh-tier-list li::before{
  content:"✓";position:absolute;left:0;top:10px;
  width:1.2em;height:1.2em;color:var(--red);font-weight:800;
}
.rh-tiers-foot{
  margin:36px auto 0;max-width:760px;text-align:center;
  font-size:.94rem;color:var(--graphite);line-height:1.6;
}
.rh-tiers-foot b{color:var(--ink)}

/* =========================================================
   HOME — rh-tab-case sub-elements (meta/kpi/quote/author)
   ========================================================= */
.rh-tab-case-meta{
  margin:.1rem 0 .9rem !important; font-size:.86rem !important;
  color:#6b7280 !important; font-weight:600; letter-spacing:.01em;
}
.rh-tab-case-kpi{
  list-style:none; padding:0; margin:0 0 1.1rem;
  display:grid; gap:.5rem;
}
.rh-tab-case-kpi li{
  position:relative; padding:.55rem .85rem .55rem 1.05rem;
  background:#fff; border:1px solid #e5e7eb; border-radius:8px;
  font-size:.92rem; line-height:1.45; color:#374151;
}
.rh-tab-case-kpi li::before{
  content:""; position:absolute; left:0; top:.55rem; bottom:.55rem;
  width:3px; background:var(--red); border-radius:0 3px 3px 0;
}
.rh-tab-case-kpi li b{color:var(--ink); font-weight:700}
.rh-tab-case-quote{
  margin:0 0 .35rem !important; padding:.6rem 0 .6rem 1rem;
  border-left:3px solid #fca5a5; color:#1f2937 !important;
  font-style:italic; font-size:1rem !important; line-height:1.55 !important;
}
.rh-tab-case-author{
  margin:0 0 1.1rem !important; font-size:.88rem !important;
  color:#6b7280 !important; font-weight:600; font-style:normal;
}

/* =========================================================
   HOME — Szczegóły bezpieczeństwa (6 punktów pod kartami)
   ========================================================= */
.rh-sec-details{
  margin-top:48px; padding:32px 36px;
  background:#fff; border:1px solid var(--line); border-radius:var(--r-lg);
  box-shadow:var(--shadow-sm);
}
.rh-sec-details-head{
  margin:0 0 1.6rem; font-size:1.15rem; line-height:1.4;
  color:var(--ink); font-weight:700;
}
.rh-sec-details-list{
  display:grid; grid-template-columns:repeat(2,1fr); gap:24px 36px;
  margin:0; padding:0;
}
@media (max-width:780px){
  .rh-sec-details{padding:24px 22px}
  .rh-sec-details-list{grid-template-columns:1fr; gap:20px}
}
.rh-sec-detail dt{
  font-weight:700; color:var(--ink); font-size:.98rem;
  margin:0 0 .4rem; padding-left:14px; position:relative;
}
.rh-sec-detail dt::before{
  content:""; position:absolute; left:0; top:.5em;
  width:6px; height:6px; border-radius:50%; background:var(--red);
}
.rh-sec-detail dd{
  margin:0 0 0 14px; font-size:.92rem; line-height:1.55; color:var(--graphite);
}

/* =========================================================
   STICKY CTA BAR — Fix 14 (Grupa D)
   ========================================================= */
.rh-sticky-cta{
  position:fixed; left:0; right:0; bottom:0; z-index:90;
  background:rgba(11,11,13,.96); color:#fff;
  border-top:1px solid rgba(255,255,255,.08);
  box-shadow:0 -8px 24px rgba(0,0,0,.18);
  transform:translateY(100%); opacity:0;
  transition:transform .25s ease, opacity .25s ease;
  backdrop-filter:saturate(180%) blur(6px);
}
.rh-sticky-cta.is-visible{transform:translateY(0); opacity:1}
.rh-sticky-cta[hidden]{display:none}
.rh-sticky-cta-inner{
  display:flex; align-items:center; justify-content:space-between;
  gap:1.5rem; padding:12px 0;
}
.rh-sticky-cta-text{
  font-size:.92rem; line-height:1.4; color:#e5e7eb;
  flex:1 1 auto; min-width:0;
}
.rh-sticky-cta-text strong{color:#fff}
.rh-sticky-cta-short{display:none}
@media (max-width:640px){
  .rh-sticky-cta-long{display:none}
  .rh-sticky-cta-short{display:inline}
}
.rh-sticky-cta-btn{flex:0 0 auto; white-space:nowrap}
@media (max-width:640px){
  .rh-sticky-cta-inner{padding:10px 14px; gap:.9rem}
  .rh-sticky-cta-text{font-size:.82rem}
  .rh-sticky-cta-btn{padding:.55rem .9rem; font-size:.88rem}
  .rh-sticky-cta-text strong{display:block}
}

/* === Round 8: Co dostajecie po pierwszej rozmowie === */
.rh-after-call{padding:80px 0;background:#fff}
.rh-after-call .section-head{margin-bottom:2.4rem}
.rh-after-call-list{list-style:none;padding:0;margin:0 0 1.6rem;display:grid;gap:18px}
.rh-after-call-list li{display:flex;gap:18px;align-items:flex-start;padding:22px 22px;border:1px solid var(--line);border-radius:var(--r-lg);background:#fff;transition:border-color .15s, box-shadow .15s}
.rh-after-call-list li:hover{border-color:var(--brand);box-shadow:var(--shadow-sm)}
.rh-after-call-num{flex:0 0 auto;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--brand);color:#fff;border-radius:50%;font-weight:700;font-size:.95rem;letter-spacing:.02em}
.rh-after-call-list h3{margin:0 0 .35rem;font-size:1.08rem;color:var(--ink)}
.rh-after-call-list p{margin:0;color:var(--muted);font-size:.96rem;line-height:1.55}
.rh-after-call-note{margin:1.8rem auto 0;max-width:680px;color:var(--muted);font-size:.86rem;line-height:1.6;text-align:center;font-style:italic}
@media (max-width:640px){
  .rh-after-call{padding:56px 0}
  .rh-after-call-list li{padding:18px;gap:14px}
  .rh-after-call-num{width:36px;height:36px;font-size:.85rem}
  .rh-after-call-list h3{font-size:1rem}
}

/* ============================================
   PARTNERS PAGE — round 8 partner rewrite
   ============================================ */
.rh-partner-intro{max-width:780px;margin:0 auto 0;color:var(--graphite);font-size:1.05rem;line-height:1.7;text-align:center}
.rh-partner-steps{list-style:none;padding:0;margin:0;display:grid;gap:20px;max-width:920px;margin-left:auto;margin-right:auto}
.rh-partner-steps li{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:24px 28px;display:grid;grid-template-columns:56px 1fr;gap:20px;align-items:start;box-shadow:0 1px 2px rgba(0,0,0,.03)}
.rh-partner-step-num{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;background:var(--red);color:#fff;font-weight:800;font-size:1.2rem}
.rh-partner-steps h3{margin:0 0 .4rem;font-size:1.15rem}
.rh-partner-steps p{margin:0;color:var(--graphite);line-height:1.6}
.rh-partner-criteria{margin-top:40px;background:#fff;border:1px solid var(--line);border-left:4px solid var(--red);border-radius:var(--r-lg);padding:28px 32px;max-width:780px;margin-left:auto;margin-right:auto}
.rh-partner-criteria h3{margin:0 0 1rem;font-size:1.15rem}
.rh-partner-criteria ul{list-style:none;padding:0;margin:0 0 1rem}
.rh-partner-criteria ul li{padding:8px 0 8px 24px;position:relative;color:var(--graphite)}
.rh-partner-criteria ul li::before{content:"→";position:absolute;left:0;color:var(--red);font-weight:700}
.rh-partner-criteria-note{margin:0;font-size:.92rem;color:var(--muted);font-style:italic;border-top:1px solid var(--line);padding-top:12px}
.rh-partner-honest{list-style:none;padding:0;margin:32px auto 0;max-width:820px;display:grid;gap:16px}
.rh-partner-honest li{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:20px 24px;line-height:1.6;color:var(--graphite)}
.rh-partner-honest li b{display:block;color:var(--ink);font-size:1.02rem;margin-bottom:.3rem}
@media (max-width:720px){
  .rh-partner-steps li{grid-template-columns:1fr;gap:12px;padding:20px}
  .rh-partner-step-num{width:40px;height:40px;font-size:1rem}
  .rh-partner-criteria{padding:22px}
  .rh-partner-honest li{padding:18px 20px}
}

/* === Round 8: Footer brand spacing === */
.brand-foot{margin-bottom:1.4rem;display:inline-flex}
.foot-tag{margin-top:0}

/* === Round 8: Dept SVG icons === */
.dept-ico{display:inline-block;vertical-align:-3px;color:currentColor;flex-shrink:0}
.rh-tab .dept-ico{color:var(--graphite)}
.rh-tab.is-active .dept-ico{color:#fff}
.rh-cs-filter .dept-ico{vertical-align:-2px;margin-right:.15rem}
.rh-cs-card-dept .dept-ico{vertical-align:-2px}

/* === LP rich sections (audience / compare / process / mini-case / proof / guarantee) === */
.lp-audience{padding:64px 0;background:#fafafa}
.lp-audience h2{font-size:clamp(1.6rem,2.6vw,2.2rem);text-align:center;margin:0 0 8px;line-height:1.2}
.lp-audience p.lp-lead{text-align:center;color:#52525b;font-size:1.05rem;margin:0 auto 40px;max-width:680px;line-height:1.5}
.lp-audience__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.lp-audience__card{background:#fff;border:1px solid #ececef;border-radius:14px;padding:24px 22px}
.lp-audience__type{font-weight:700;color:#18181b;font-size:1.05rem;margin-bottom:8px;line-height:1.3}
.lp-audience__why{color:#52525b;font-size:.95rem;line-height:1.55}
@media(max-width:880px){.lp-audience__grid{grid-template-columns:1fr}}

.lp-compare{padding:64px 0;background:#fff}
.lp-compare h2{font-size:clamp(1.6rem,2.6vw,2.2rem);text-align:center;margin:0 0 8px;line-height:1.2}
.lp-compare p.lp-lead{text-align:center;color:#52525b;font-size:1.05rem;margin:0 auto 40px;max-width:720px;line-height:1.55}
.lp-compare__table{width:100%;border-collapse:separate;border-spacing:0;background:#fff;border:1px solid #ececef;border-radius:14px;overflow:hidden;font-size:.95rem}
.lp-compare__table th,.lp-compare__table td{padding:14px 18px;text-align:left;vertical-align:top;border-bottom:1px solid #f0f0f0}
.lp-compare__table th{background:#fafafa;color:#18181b;font-weight:700;font-size:.92rem}
.lp-compare__table tr:last-child td{border-bottom:0}
.lp-compare__table td.ok{color:#15803d}
.lp-compare__table td.bad{color:#991b1b}
@media(max-width:680px){.lp-compare__table th,.lp-compare__table td{padding:10px 12px;font-size:.88rem}}

.lp-process{padding:64px 0;background:#fafafa}
.lp-process h2{font-size:clamp(1.6rem,2.6vw,2.2rem);text-align:center;margin:0 0 8px;line-height:1.2}
.lp-process p.lp-lead{text-align:center;color:#52525b;font-size:1.05rem;margin:0 auto 40px;max-width:720px;line-height:1.55}
.lp-process__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.lp-process__step{background:#fff;border:1px solid #ececef;border-radius:14px;padding:24px 20px;position:relative}
.lp-process__num{position:absolute;top:-14px;left:20px;background:#0e0e12;color:#fff;width:28px;height:28px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem}
.lp-process__week{color:#dc2626;font-size:.75rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;margin:8px 0 6px}
.lp-process__name{font-weight:700;color:#18181b;font-size:1.05rem;margin-bottom:8px;line-height:1.3}
.lp-process__desc{color:#52525b;font-size:.9rem;line-height:1.55}
@media(max-width:880px){.lp-process__grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.lp-process__grid{grid-template-columns:1fr}}

.lp-mini-case{padding:64px 0;background:#fff}
.lp-mini-case h2{font-size:clamp(1.6rem,2.6vw,2.2rem);text-align:center;margin:0 0 32px;line-height:1.2}
.lp-mini-case__card{background:#fafafa;border:1px solid #ececef;border-radius:14px;padding:24px 26px;margin-bottom:18px}
.lp-mini-case__head{font-weight:700;color:#18181b;font-size:1.1rem;margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid #ececef}
.lp-mini-case__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.lp-mini-case__label{color:#dc2626;font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;margin-bottom:8px}
.lp-mini-case__text{color:#52525b;font-size:.92rem;line-height:1.55}
.lp-mini-case__win{color:#18181b;font-weight:600}
@media(max-width:680px){.lp-mini-case__grid{grid-template-columns:1fr;gap:14px}}

.lp-proof{padding:48px 0;background:#0e0e12;color:#fff}
.lp-proof__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.lp-proof__metric{font-size:clamp(1.8rem,3vw,2.4rem);font-weight:800;color:#fff;line-height:1.1;margin-bottom:6px;letter-spacing:-.02em}
.lp-proof__comment{color:rgba(255,255,255,.72);font-size:.85rem;line-height:1.4}
@media(max-width:680px){.lp-proof__grid{grid-template-columns:1fr 1fr;gap:18px}}

.lp-guarantee{padding:64px 0;background:#fafafa}
.lp-guarantee h2{font-size:clamp(1.6rem,2.6vw,2.2rem);text-align:center;margin:0 0 32px;line-height:1.2}
.lp-guarantee__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.lp-guarantee__card{background:#fff;border:1px solid #ececef;border-radius:14px;padding:24px 22px;display:flex;gap:14px;align-items:flex-start}
.lp-guarantee__check{flex-shrink:0;width:28px;height:28px;border-radius:50%;background:#15803d;color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700;margin-top:2px}
.lp-guarantee__card h3{margin:0 0 6px;font-size:1.05rem;color:#18181b;line-height:1.3}
.lp-guarantee__card p{margin:0;color:#52525b;font-size:.92rem;line-height:1.55}
@media(max-width:680px){.lp-guarantee__grid{grid-template-columns:1fr}}
