:root{--bg:#fff;--bg-alt:#f8f5f4;--text:#23262e;--muted:#555c66;--line:#eaded9;--primary:#8b2713;--mid:#d77454;--bright:#ea8b69;--soft:rgba(215,116,84,.10);--cta:#d77454;--light:#fdebe5;--sh:0 16px 40px rgba(35,38,46,.10);--sh-sm:0 4px 16px rgba(35,38,46,.08)}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
.page-top-anchor{position:absolute;top:0;left:0;width:1px;height:1px;pointer-events:none}
body{margin:0;font-family:Inter,system-ui,sans-serif;color:var(--text);background:var(--bg);line-height:1.7}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
button{font:inherit}
textarea{font:inherit;resize:vertical}

.container{width:min(1440px,calc(100% - 64px));margin:0 auto}
.section{padding:120px 0;scroll-margin-top:110px}
.section-alt{background:var(--bg-alt)}
.section-head{max-width:980px;margin:0 auto 56px;text-align:center}
.section-head h2{margin-bottom:16px}
.section-head p{color:var(--muted);max-width:900px;margin-left:auto;margin-right:auto}

.eyebrow{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:999px;background:rgba(30,91,189,.07);border:1px solid rgba(30,91,189,.15);color:var(--mid);font-size:13px;font-weight:600;letter-spacing:.02em;width:fit-content;margin:0 auto 18px}
.eyebrow::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--mid);flex:0 0 6px;box-shadow:0 0 0 3px rgba(30,91,189,.12)}
.eyebrow-light{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.2);color:rgba(255,255,255,.85)}
.eyebrow-light::before{background:rgba(255,255,255,.8);box-shadow:0 0 0 3px rgba(255,255,255,.1)}

h1,h2,h3{margin:0;color:var(--text);letter-spacing:-.02em}
h2{font-size:clamp(28px,2.8vw,42px);line-height:1.15;text-align:center}
h3{font-size:20px;line-height:1.3}
p{margin:0;font-size:17px;color:var(--muted)}

.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.95);backdrop-filter:blur(14px);border-bottom:1px solid rgba(221,229,240,.8)}
.header-inner{display:flex;align-items:center;justify-content:space-between;min-height:96px}
.brand img{height:56px;width:auto}
.header-nav{display:flex;align-items:center;gap:2px;font-size:15.5px;color:var(--muted)}
.header-nav a{display:inline-flex;align-items:center;min-height:44px;padding:0 13px;border-radius:999px;white-space:nowrap;transition:all .2s}
.header-nav a:not(.nav-cta):hover{background:var(--soft);color:var(--mid)}
.nav-cta{padding:0 22px !important;background:var(--cta);color:#fff !important;font-weight:600;box-shadow:0 4px 16px rgba(30,91,189,.38);margin-left:12px;border-radius:999px}
.nav-cta:hover{background:#1650a8 !important;box-shadow:0 6px 22px rgba(30,91,189,.48) !important;transform:translateY(-1px)}

.hamburger{display:none;position:relative;z-index:1003;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;padding:9px;border:0;background:transparent;cursor:pointer;border-radius:12px;transition:background .2s}
.hamburger:hover,.hamburger.is-open{background:var(--soft)}
.hamburger span{height:2px;background:var(--text);border-radius:2px;display:block;transition:transform .22s,opacity .22s}
.hamburger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.is-open span:nth-child(2){opacity:0}
.hamburger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-menu-backdrop{position:fixed;inset:0;background:rgba(8,18,36,.52);z-index:9998;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .22s,visibility .22s}
.mobile-menu-backdrop.is-open{opacity:1;visibility:visible;pointer-events:auto}
.mobile-menu{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;width:100%;max-width:none;min-width:100%;height:100vh;height:100dvh;margin:0;background:var(--primary);z-index:9999;padding:24px;flex-direction:column;overflow-y:auto;box-shadow:none;border-radius:0;transform:translateX(100%);visibility:hidden;pointer-events:none;transition:transform .24s ease,visibility .24s}
.mobile-menu.is-open{transform:translateX(0);visibility:visible;pointer-events:auto}
.mobile-menu-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}
.mobile-menu-top img{height:38px}
.mobile-close{width:38px;height:38px;border:none;background:rgba(255,255,255,.12);color:#fff;border-radius:50%;font-size:24px;cursor:pointer;display:grid;place-items:center;line-height:1}
.mobile-close:hover{background:rgba(255,255,255,.2)}
.mobile-menu-links{display:flex;flex-direction:column;gap:4px}
.mobile-menu-links a{padding:13px 16px;color:rgba(255,255,255,.84);border-radius:10px;font-size:16px;transition:all .2s}
.mobile-menu-links a:hover{background:rgba(255,255,255,.1);color:#fff}
.mobile-menu-links .mobile-menu-cta{margin-top:8px;background:#fff;color:var(--primary);font-weight:700;text-align:center;justify-content:center}
.mobile-menu-links .mobile-menu-cta:hover{background:rgba(255,255,255,.9);color:var(--primary)}
body.mobile-menu-open{overflow:hidden}

.button{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;border-radius:999px;font-size:15px;font-weight:600;transition:all .22s;border:none;cursor:pointer;white-space:nowrap}
.button-primary{background:var(--cta);color:#fff;box-shadow:0 8px 22px rgba(30,91,189,.3)}
.button-primary:hover{background:#1650a8;transform:translateY(-2px);box-shadow:0 12px 28px rgba(30,91,189,.4)}
.button-secondary{border:1.5px solid var(--line);background:#fff;color:var(--text)}
.button-secondary:hover{border-color:var(--mid);color:var(--mid)}
.button-white{background:#fff;color:var(--primary);font-weight:700;box-shadow:0 8px 24px rgba(0,0,0,.18)}
.button-white:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(0,0,0,.24)}
.button-ghost{background:rgba(255,255,255,.1);color:rgba(255,255,255,.9);border:1.5px solid rgba(255,255,255,.25)}
.button-ghost:hover{background:rgba(255,255,255,.18);transform:translateY(-2px)}
.play-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.7);animation:blink 2s ease-in-out infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.4}}

.browser-frame{background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:var(--sh)}
.browser-bar{height:40px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:flex-end;padding:0 14px;gap:7px;background:#f0f4ff}
.browser-bar span{width:10px;height:10px;border-radius:50%}
.browser-bar span:nth-child(1){background:#1e3a6e}
.browser-bar span:nth-child(2){background:#3b6aab}
.browser-bar span:nth-child(3){background:#7ba4d4}

/* HERO */
.hero-dark{position:relative;background:linear-gradient(135deg,#0a1628 0%,#0d1f3a 45%,#112952 100%);overflow:hidden;padding:120px 0}
.hero-bg-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(59,130,246,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(59,130,246,.06) 1px,transparent 1px);background-size:48px 48px;mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 40%,transparent 100%)}
.hero-dark-inner{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;position:relative;z-index:1}
.hero-dark-copy .eyebrow{margin-left:0}
h1{font-size:clamp(36px,4vw,58px);line-height:1.08;color:#fff;margin-bottom:18px;text-align:left;letter-spacing:-.03em}
.hero-dark-subline{font-size:clamp(20px,2vw,28px);font-weight:700;color:#fff;line-height:1.25;margin:0 0 20px;text-align:left;letter-spacing:-.02em}
.hero-dark-lead{font-size:18px;color:rgba(219,234,254,.75);line-height:1.7;text-align:left;max-width:680px;margin-bottom:36px}
.hero-dark-actions{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:36px}
.hero-trust-bar{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.hero-trust-bar span{padding:6px 12px;border-radius:999px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.6);font-size:13px}
.hero-trust-label{color:rgba(219,234,254,.45);letter-spacing:.04em;text-transform:uppercase;font-weight:600;margin-right:4px;background:none !important;border:none !important;font-size:12px}
.hero-screen-frame{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.12);border-radius:20px;overflow:hidden;box-shadow:0 0 0 1px rgba(59,130,246,.15),0 32px 80px rgba(0,0,0,.5),0 0 100px rgba(30,91,189,.15)}
.hero-screen-dots{height:36px;background:rgba(255,255,255,.06);border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:flex-end;gap:7px;padding:0 14px}
.hero-screen-dots span{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.2)}
.hero-screen-dots span:nth-child(1){background:rgba(59,130,246,.7)}
.hero-screen-dots span:nth-child(2){background:rgba(59,130,246,.45)}
.hero-screen-frame img{display:block;width:100%;opacity:.9}
.hero-screen-glow{position:absolute;bottom:-40px;left:50%;transform:translateX(-50%);width:70%;height:60px;background:radial-gradient(ellipse at 50% 0%,rgba(59,130,246,.3),transparent 70%);pointer-events:none}
.hero-screen-wrap{position:relative}

/* STATS */
.stats-band{background:var(--primary);padding:28px 0}
.stats-band-inner{display:flex;align-items:center;justify-content:center;flex-wrap:wrap}
.stat-b{text-align:center;padding:14px 40px}
.stat-b strong{display:block;font-size:20px;font-weight:700;color:#fff;margin-bottom:5px;letter-spacing:-.01em}
.stat-b span{font-size:13px;color:rgba(219,234,254,.65)}
.stat-b-div{width:1px;height:36px;background:rgba(255,255,255,.14)}

/* PROBLEM */
.big-statement{max-width:1080px;margin:0 auto 72px;text-align:center}
.big-statement .eyebrow{margin:0 auto 16px}
.big-statement-h{font-size:clamp(28px,3vw,44px);line-height:1.15;letter-spacing:-.025em;text-align:center}
.big-statement-sub{font-size:18px;color:var(--muted);max-width:900px;margin:16px auto 0;text-align:center;line-height:1.7}
.scenario-flow{display:grid;gap:0}
.scenario-connector{height:1px;background:linear-gradient(90deg,transparent,var(--line),transparent);margin:0 80px}
.scenario-item{display:grid;grid-template-columns:80px 1fr 1fr;gap:32px;align-items:start;padding:40px 0}
.scenario-num{font-size:56px;font-weight:800;color:rgba(30,91,189,.1);line-height:1;letter-spacing:-.04em;padding-top:4px}
.scenario-body h3{margin-bottom:10px;font-size:22px}
.scenario-body p{color:var(--muted)}
.sr-problem-tag{display:inline-flex;margin-bottom:10px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#9b1c1c;background:#fee2e2;border:1px solid rgba(185,28,28,.2);padding:3px 10px;border-radius:999px}
.sr-solution-tag{display:inline-flex;margin-bottom:10px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--mid);background:rgba(30,91,189,.08);border:1px solid rgba(30,91,189,.18);padding:3px 10px;border-radius:999px}
.scenario-resolution{background:#f0f7ff;border:1px solid rgba(30,91,189,.15);border-radius:18px;padding:22px 26px}
.scenario-resolution p{font-size:15px;color:#1e3a6e;margin-top:8px}

/* JAK DZIAŁA */
.section-dark-alt{background:#f8faff}
.split-intro{max-width:980px;margin:0 auto 64px;text-align:center}
.split-intro .eyebrow{margin:0 auto 14px}
.split-intro h2{margin-top:12px;margin-bottom:0}
.split-steps-layout{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.split-steps-left{display:grid;gap:4px}
.split-step{display:grid;grid-template-columns:52px 1fr;gap:20px;align-items:start;padding:24px;border-radius:18px;transition:background .2s,box-shadow .2s;cursor:pointer}
.split-step:hover,.split-step.active{background:#fff;box-shadow:var(--sh-sm)}
.ss-marker{width:44px;height:44px;border-radius:50%;background:rgba(30,91,189,.08);border:2px solid rgba(30,91,189,.18);display:grid;place-items:center;font-size:16px;font-weight:700;color:var(--mid);flex-shrink:0;transition:all .2s}
.split-step.active .ss-marker{background:var(--cta);border-color:var(--cta);color:#fff;box-shadow:0 4px 14px rgba(30,91,189,.35)}
.ss-content h3{font-size:17px;margin-bottom:8px}
.split-step.active .ss-content h3{color:var(--primary)}
.ss-content p{font-size:15px;color:var(--muted)}
.split-steps-right{position:sticky;top:116px}
.split-screen-frame img{width:100%;display:block;padding:12px;background:#fff;transition:opacity .3s}

/* VIDEO */
.section-video-showcase{}
.video-showcase-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.video-showcase-copy .eyebrow{margin-left:0}
.video-showcase-copy h2{text-align:left;margin-bottom:18px}
.video-showcase-copy p{text-align:left;margin-top:12px}
.video-monitor-wrap{position:relative}
.video-monitor-badge{position:absolute;top:-14px;right:22px;z-index:2;background:var(--mid);color:#fff;font-size:13px;font-weight:600;padding:5px 14px;border-radius:999px;box-shadow:0 4px 12px rgba(30,91,189,.3)}
.video-monitor{background:#fff;border:1px solid var(--line);border-radius:20px;overflow:hidden;box-shadow:var(--sh)}
.video-monitor-top{height:40px;border-bottom:1px solid var(--line);display:flex;align-items:center;padding:0 14px;gap:7px;background:#f0f4ff}
.video-monitor-top span{width:10px;height:10px;border-radius:50%;background:#1e3a6e}
.video-monitor-screen video{display:block;width:100%;max-height:480px;background:#0d1f3a}

/* BENTO */
.bento-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:auto;gap:20px;align-items:stretch}
.bento-cell{border-radius:24px;padding:32px;position:relative;overflow:hidden;transition:transform .22s,box-shadow .22s;display:flex;flex-direction:column;height:100%}
.bento-cell:hover{transform:translateY(-3px);box-shadow:0 20px 48px rgba(13,31,58,.12)}
.bento-lg{grid-column:span 2}
.bento-md{grid-column:span 1}
.bento-sm{grid-column:span 1}
.bento-blue{background:linear-gradient(135deg,#1e5bbd 0%,#1e3a6e 100%)}
.bento-blue h3,.bento-blue p{color:#fff}
.bento-blue p{color:rgba(255,255,255,.75)}
.bento-dark{background:linear-gradient(135deg,#0d1f3a 0%,#1e3a6e 100%)}
.bento-dark h3,.bento-dark p{color:#fff}
.bento-dark p{color:rgba(219,234,254,.75)}
.bento-slate{background:#fff;border:1px solid var(--line)}
.bento-slate h3{color:var(--text)}
.bento-slate p{color:var(--muted)}
.bento-icon{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;margin-bottom:20px}
.bento-blue .bento-icon,.bento-dark .bento-icon{background:rgba(255,255,255,.12)}
.bento-slate .bento-icon{background:rgba(30,91,189,.07);border:1px solid rgba(30,91,189,.12)}
.bento-icon i{font-size:24px;line-height:1}
.bento-blue .bento-icon i,.bento-dark .bento-icon i{color:rgba(255,255,255,.9)}
.bento-slate .bento-icon i{color:var(--mid)}
.bento-icon-sm{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;margin-bottom:16px;background:rgba(30,91,189,.07);border:1px solid rgba(30,91,189,.12)}
.bento-icon-sm i{font-size:22px;line-height:1;color:var(--mid)}
.bento-cell h3{font-size:19px;line-height:1.3;margin-bottom:12px}
.bento-cell p{font-size:15px;line-height:1.65}
.bento-badge{display:inline-flex;margin-top:auto;padding:6px 14px;border-radius:999px;background:rgba(255,255,255,.2);color:rgba(255,255,255,.85);font-size:12px;font-weight:600;align-self:flex-start}
.bento-badge-light{background:rgba(255,255,255,.12);color:rgba(219,234,254,.85)}
.bento-cell-split{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start;height:100%;flex:1}
.bento-cell-text{display:flex;flex-direction:column}
.bento-cell-screen button{border:none;padding:0;cursor:pointer;border-radius:14px;overflow:hidden;border:1px solid rgba(255,255,255,.15);width:100%}
.bento-cell-screen img{width:100%;display:block;border-radius:12px;opacity:.85;transition:opacity .2s}
.bento-cell-screen button:hover img{opacity:1}

/* SECURITY */
.section-security{background:linear-gradient(135deg,#0a1628 0%,#0d1f3a 60%,#112952 100%);padding:120px 0}
.security-header{text-align:center;max-width:980px;margin:0 auto 72px}
.security-header .eyebrow{margin:0 auto 16px}
.security-header h2{color:#fff;margin-bottom:16px}
.security-header p{color:rgba(219,234,254,.7)}
.security-pillars{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-bottom:64px}
.security-pillar{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:22px;padding:28px 24px;transition:background .22s,transform .22s}
.security-pillar:hover{background:rgba(255,255,255,.09);transform:translateY(-3px)}
.sec-icon-wrap{width:52px;height:52px;border-radius:14px;background:rgba(59,130,246,.15);border:1px solid rgba(59,130,246,.25);display:grid;place-items:center;margin-bottom:18px}
.sec-icon-wrap svg{width:24px;height:24px;stroke:#60a5fa;fill:none;stroke-width:1.5}
.security-pillar h3{color:#fff;font-size:17px;margin-bottom:10px}
.security-pillar p{color:rgba(219,234,254,.65);font-size:15px}
.security-zt{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:24px;padding:36px 48px;display:flex;flex-direction:column;align-items:center;gap:28px}
.zt-label{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:rgba(219,234,254,.5)}
.zt-steps{display:flex;align-items:center;gap:24px;flex-wrap:wrap;justify-content:center}
.zt-step{display:flex;align-items:center;gap:16px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:16px 22px}
.zt-num{width:36px;height:36px;border-radius:50%;background:var(--mid);color:#fff;font-size:16px;font-weight:700;display:grid;place-items:center;flex-shrink:0}
.zt-step strong{display:block;color:#fff;font-size:15px;margin-bottom:2px}
.zt-step span{display:block;color:rgba(219,234,254,.55);font-size:13px}
.zt-arrow{color:rgba(255,255,255,.3);font-size:24px;font-weight:300}

/* REGULACJE */
.reg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.reg-item{display:flex;align-items:flex-start;gap:18px;background:#fff;border:1px solid var(--line);border-radius:20px;padding:24px 26px;transition:transform .2s,box-shadow .2s}
.reg-item:hover{transform:translateY(-3px);box-shadow:var(--sh-sm)}
.reg-badge{flex-shrink:0;min-width:52px;text-align:center;padding:8px 10px;border-radius:12px;background:var(--primary);color:#fff;font-size:13px;font-weight:700;letter-spacing:.02em}
.reg-desc{flex:1}
.reg-desc strong{display:block;color:var(--text);font-size:15px;margin-bottom:6px}
.reg-desc p{font-size:14px;color:var(--muted)}
.reg-check{flex-shrink:0;width:28px;height:28px;border-radius:50%;background:rgba(16,185,129,.12);border:1px solid rgba(16,185,129,.3);color:#059669;font-size:14px;font-weight:700;display:grid;place-items:center;margin-top:2px}
.reg-item-cta{background:linear-gradient(135deg,#f0f5ff 0%,#e8f0fe 100%);border-color:rgba(30,91,189,.18);flex-direction:column;justify-content:space-between;gap:20px}
.reg-cta-text strong{font-size:17px;color:var(--primary);margin-bottom:8px;display:block}
.reg-cta-text p{font-size:14px;color:var(--muted)}

/* COMPARISON */
.comparison-wrap{padding:16px;background:#fff;border:1px solid var(--line);border-radius:24px}
.comparison-table{width:100%;border-collapse:separate;border-spacing:0}
.comparison-table th,.comparison-table td{padding:18px 22px;vertical-align:top;text-align:left;border-bottom:1px solid var(--line);font-size:15px}
.comparison-table thead th{color:var(--text);background:#f0f5ff}
.comparison-table thead th:first-child{border-top-left-radius:14px}
.comparison-table thead th:last-child{border-top-right-radius:14px}
.comparison-table tbody th{width:24%;background:#fff;color:var(--text);font-weight:600}
.comparison-table tbody td{width:38%;background:#f8faff;color:var(--muted)}
.comparison-table .safedr-col{background:var(--primary) !important;color:var(--light) !important;border-bottom:1px solid rgba(219,234,254,.18) !important;position:relative;z-index:1}
.comparison-table .safedr-col::before{content:"";position:absolute;inset:0;background:inherit;box-shadow:0 10px 24px rgba(13,31,58,.15);z-index:-1}
.comparison-table thead .safedr-col::before{border-top-right-radius:14px}
.comparison-table tbody tr:last-child td:last-child{border-bottom:none}
.comparison-table tbody tr:last-child th:first-child{border-bottom-left-radius:14px}
.comparison-table tbody tr:last-child td:last-child{border-bottom-right-radius:14px}
.comparison-table tbody tr:last-child .safedr-col::before{border-bottom-right-radius:14px}
.comparison-table tbody tr:hover th{background:#f0f7ff}
.comparison-table tbody tr:hover td:not(.safedr-col){background:#edf3fb}
.comparison-table tbody tr:last-child th,.comparison-table tbody tr:last-child td{border-bottom:none}
.table-bool{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;margin-right:8px;font-size:11px;font-weight:700;vertical-align:middle;transform:translateY(-1px)}
.comparison-table td:not(.safedr-col) .table-bool--negative{background:#fce8ea;color:#c23b47;border:1px solid #f4c9cf}
.comparison-table .safedr-col .table-bool--positive{background:#fff;color:var(--primary);border:1px solid rgba(255,255,255,.7)}
.safedr-col-head{padding-top:16px !important;padding-bottom:16px !important}
.SafeDR-head-logo{height:26px;display:block;margin:0 auto;max-width:150px;width:auto}
.comparison-mobile{display:none;max-width:720px;margin:0 auto;gap:12px}
.comparison-accordion{overflow:hidden;border:1px solid var(--line);border-radius:20px;background:#fff}
.comparison-question{width:100%;background:#fff;border:none;padding:18px 50px 18px 20px;text-align:left;font-weight:700;font-size:17px;color:var(--text);cursor:pointer;position:relative}
.comparison-question::after{content:'+';position:absolute;right:20px;top:50%;transform:translateY(-50%);font-size:22px;color:var(--mid)}
.comparison-question[aria-expanded="true"]::after{content:'−'}
.comparison-answer{display:none;padding:0 16px 16px;gap:10px}
.comparison-answer.is-open{display:grid}
.comparison-mobile-card{padding:14px;border-radius:14px;border:1px solid var(--line)}
.comparison-mobile-card--positive{background:rgba(30,91,189,.04);border-color:rgba(30,91,189,.16)}
.comparison-mobile-head{display:flex;align-items:center;gap:10px;margin-bottom:8px;font-size:18px;font-weight:700}
.comparison-mobile-head--positive{color:var(--mid)}
.comparison-mobile-card p{margin:0;font-size:15px;color:var(--muted)}
.status-icon{width:28px;height:28px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;flex:0 0 28px;color:#fff}
.status-icon--positive{background:#1e5bbd}
.status-icon--negative{background:#dc4c57}

/* SLIDER */
.shots-slider{display:grid;grid-template-columns:52px 1fr 52px;gap:16px;align-items:center}
.shots-viewport{overflow:hidden}
.shots-track{display:flex;gap:20px;transition:transform .3s ease}
.sc-shot{display:block;flex:0 0 calc((100% - 40px)/3);border:none;padding:0;cursor:pointer;border-radius:14px;overflow:hidden;border:2px solid var(--line);box-shadow:none;transition:border-color .2s,box-shadow .2s,transform .2s;background:#fff}
.sc-shot:hover{border-color:var(--mid);box-shadow:0 8px 28px rgba(30,91,189,.15);transform:translateY(-3px)}
.sc-shot img{display:block;width:100%;height:auto;padding:10px;background:#fff}
.slide-card{flex:0 0 calc((100% - 40px)/3)}
.shots-arrow{width:52px;height:52px;border-radius:50%;border:1px solid var(--line);background:#fff;color:var(--mid);font-size:28px;cursor:pointer;box-shadow:var(--sh-sm);display:grid;place-items:center;transition:all .2s}
.shots-arrow:hover{border-color:rgba(30,91,189,.3);transform:translateY(-1px)}
.screenshots-section{scroll-margin-top:110px}

/* FAQ */
.faq-list{display:grid;gap:12px;max-width:900px;margin:0 auto}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:20px;overflow:hidden;transition:box-shadow .2s}
.faq-item:hover{box-shadow:var(--sh-sm)}
.faq-question{width:100%;background:#fff;border:none;padding:22px 24px;text-align:left;font-weight:600;font-size:16px;color:var(--text);cursor:pointer;position:relative}
.faq-question::after{content:'+';position:absolute;right:22px;top:50%;transform:translateY(-50%);font-size:22px;color:var(--mid);font-weight:400}
.faq-question[aria-expanded="true"]::after{content:'−'}
.faq-answer{display:none;padding:0 24px 22px}
.faq-answer.is-open{display:block}
.faq-answer p{text-align:left;font-size:15px}
.faq-answer p+p{margin-top:12px}
.faq-list-inner{margin:12px 0;padding-left:20px;display:grid;gap:6px}
.faq-list-inner li{font-size:15px;color:var(--muted);text-align:left}
.faq-list-inner li strong{color:var(--text)}

/* ABOUT */
.section-about{background:var(--primary)}
.section-about h2,.section-about h3,.section-about p{color:#fff}
.about-inner{display:grid;gap:56px}
.about-header{max-width:820px;margin:0 auto;text-align:center}
.about-heading{text-align:center;margin-bottom:18px}
.about-lead{color:rgba(219,234,254,.78);font-size:18px;text-align:center;max-width:640px;margin:0 auto}
.about-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.about-stat{text-align:center}
.about-stat-value{font-size:46px;font-weight:800;color:#fff;letter-spacing:-.04em;line-height:1}
.about-stat-label{font-size:13px;color:rgba(219,234,254,.6);margin-top:8px;line-height:1.5}
.about-pl-banner{background:rgba(255,255,255,.06);border:1px solid rgba(219,234,254,.15);border-radius:24px;padding:40px 48px;text-align:center}
.about-pl-title{font-size:22px;font-weight:700;color:#fff;margin-bottom:14px}
.about-pl-body{font-size:16px;color:rgba(219,234,254,.75);line-height:1.75;margin-bottom:24px}
.about-pl-supports{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:rgba(219,234,254,.4);margin-bottom:14px}
.about-pl-tags{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.about-pl-tag{padding:7px 16px;border-radius:999px;border:1px solid rgba(219,234,254,.25);background:rgba(219,234,254,.07);color:var(--light);font-size:13px;font-weight:600}
.about-bottom{text-align:center}
.about-link{display:inline-flex;align-items:center;gap:8px;color:var(--light);font-weight:600;font-size:16px;border-bottom:1px solid rgba(219,234,254,.25);padding-bottom:2px;transition:all .2s}
.about-link i{font-size:14px;line-height:1}
.about-link:hover{color:#fff;border-color:rgba(255,255,255,.5)}

/* DOWNLOAD BANNER */
.download-banner{background:linear-gradient(135deg,#0d1f3a 0%,#1e3a6e 100%);padding:56px 0}
.download-banner-inner{display:grid;grid-template-columns:minmax(0,620px) auto;align-items:center;justify-content:center;gap:72px;max-width:1120px}
.download-banner-copy .eyebrow{margin-left:0}
.download-banner-copy h2{text-align:left;color:#fff;font-size:clamp(24px,2.4vw,34px);margin:12px 0 14px}
.download-banner-copy p{color:rgba(219,234,254,.74);text-align:left;max-width:620px}
.download-banner-actions{display:flex;gap:16px;flex-wrap:wrap;flex-shrink:0;justify-content:flex-start}
.button-download{display:inline-flex;align-items:center;gap:10px;padding:14px 26px;border-radius:999px;background:#fff;color:var(--primary);font-size:15px;font-weight:700;box-shadow:0 8px 24px rgba(0,0,0,.18);transition:all .22s;border:none;cursor:pointer}
.button-download:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(0,0,0,.24)}
.button-download i{font-size:16px;line-height:1;color:var(--primary);flex-shrink:0}

/* KONTAKT */
.contact-intro-head{margin-bottom:56px}
.contact-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:stretch}
.contact-person-card-live{display:grid;grid-template-columns:220px 1fr;align-items:center;min-height:320px;padding:36px 40px;border:1px solid rgba(30,91,189,.14);border-radius:26px;background:linear-gradient(135deg,#f0f5ff 0%,#fff 55%);box-shadow:0 10px 36px rgba(30,91,189,.08)}
.circle-photo-live{width:168px;height:168px;border-radius:50%;overflow:hidden;justify-self:center;background:linear-gradient(135deg,#e8f0ff 0%,#ffffff 100%);border:4px solid rgba(30,91,189,.18);box-shadow:0 8px 24px rgba(30,91,189,.15)}
.circle-photo-live img{width:100%;height:100%;object-fit:cover;display:block}
.circle-photo-joanna img{object-position:center 22%;transform:scale(1.04)}
.circle-photo-bartlomiej img{object-position:center 22%;transform:scale(1.04)}
.contact-card-body-live{display:flex;flex-direction:column;justify-content:center;align-items:flex-start;padding-left:8px}
.contact-person-card-name{font-size:34px;font-weight:700;color:var(--text);letter-spacing:-.02em;margin-bottom:8px}
.contact-person-card-role{font-size:17px;color:var(--muted);margin-bottom:20px}
.contact-person-card-list{list-style:none;padding:0;margin:0 0 22px;display:grid;gap:8px}
.contact-person-card-list li,.contact-person-card-list a{font-size:19px;color:var(--mid);font-weight:600;text-decoration:none;text-align:left}
.contact-person-card-list a:hover{text-decoration:underline}
.contact-actions{display:flex;gap:12px;flex-wrap:wrap}
/* FOOTER */
.site-footer{padding:72px 0;background:#0a1628}
.footer-grid{display:grid;grid-template-columns:1.3fr .8fr .9fr;gap:64px 96px;align-items:start}
.footer-brand img{height:42px;margin-bottom:18px}
.site-footer p,.site-footer li,.site-footer a,.site-footer h3{color:#fff !important;font-size:15px;text-align:left}
.site-footer h3{font-size:17px;font-weight:700;margin-bottom:18px}
.site-footer a:hover{color:var(--light) !important}
.footer-copy,.footer-copy a{color:rgba(255,255,255,.45) !important;font-size:14px}
.footer-copy{margin-top:28px;padding-top:0;border-top:none}
.footer-copy-links{margin-left:12px}
.footer-copy-links a{margin-left:8px}
.footer-links ul,.footer-contact ul{padding:0;list-style:none;display:grid;gap:10px}
.footer-contact li{display:flex;gap:12px;align-items:flex-start}
.footer-icon{width:20px;display:inline-flex;justify-content:center;flex:0 0 20px;margin-top:2px}
.footer-icon i{color:rgba(255,255,255,.7);font-size:16px;line-height:1}
.social-links{display:flex;gap:10px;margin-top:22px}
.social-links a{width:40px;height:40px;border-radius:10px;border:1px solid rgba(255,255,255,.15);display:grid;place-items:center;background:rgba(255,255,255,.05);transition:all .2s}
.social-links a:hover{background:rgba(255,255,255,.12)}
.social-links i{color:#fff;font-size:17px;line-height:1}

/* LIGHTBOX */
.lightbox{position:fixed;inset:0;background:rgba(8,18,36,.9);backdrop-filter:blur(6px);z-index:2000;display:flex;align-items:center;justify-content:center;padding:40px 24px}
.lightbox[hidden]{display:none}
.lightbox-figure{margin:0;max-width:min(1200px,92vw);display:grid;gap:14px;justify-items:center}
.lightbox img{max-width:100%;max-height:80vh;border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.lightbox-caption{color:rgba(255,255,255,.75);font-size:15px;text-align:center}
.lightbox-close{position:absolute;top:20px;right:20px;width:46px;height:46px;border:none;border-radius:50%;background:rgba(255,255,255,.1);color:#fff;display:grid;place-items:center;cursor:pointer;font-size:26px}
.lightbox-close:hover{background:rgba(255,255,255,.18)}

.back-to-top{position:fixed;bottom:28px;right:28px;width:46px;height:46px;border-radius:50%;border:1px solid var(--line);background:#fff;color:var(--mid);box-shadow:var(--sh-sm);display:grid;place-items:center;cursor:pointer;opacity:0;transform:translateY(12px);transition:opacity .3s,transform .3s;z-index:40}
.back-to-top.is-visible{opacity:1;transform:translateY(0)}
.back-to-top i{font-size:18px;line-height:1;color:currentColor}

/* COOKIES */
.cookie-banner{position:fixed;left:24px;right:24px;bottom:24px;z-index:2100}
.cookie-banner[hidden],.cookie-modal[hidden]{display:none !important}
.cookie-banner-inner{width:min(1120px,100%);margin:0 auto;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:20px;align-items:end;padding:22px 24px;border:1px solid rgba(15,23,42,.08);border-radius:24px;background:rgba(255,255,255,.96);backdrop-filter:blur(10px);box-shadow:0 16px 40px rgba(15,23,42,.12)}
.cookie-banner-copy strong{display:block;margin-bottom:8px;font-size:18px;color:#0f172a}
.cookie-banner-copy p{margin:0;font-size:15px;line-height:1.65;color:#475569;text-align:left}
.cookie-banner-actions,.cookie-modal-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.cookie-btn{appearance:none;border-radius:999px;min-height:46px;padding:12px 20px;border:1px solid transparent;font-size:14px;font-weight:600;cursor:pointer;transition:transform .18s,box-shadow .18s,background-color .18s,border-color .18s,color .18s}
.cookie-btn:hover{transform:translateY(-1px)}
.cookie-btn-primary{background:#1e5bbd;color:#fff;border-color:#1e5bbd;box-shadow:0 10px 24px rgba(30,91,189,.2)}
.cookie-btn-primary:hover{background:#1650a8;border-color:#1650a8}
.cookie-btn-secondary{background:#fff;color:#1e3a6e;border-color:rgba(30,58,110,.22)}
.cookie-btn-secondary:hover{background:rgba(30,58,110,.05);border-color:rgba(30,58,110,.32)}
.cookie-btn-ghost{background:rgba(248,250,252,.95);color:#0f172a;border-color:rgba(15,23,42,.1)}
.cookie-btn-ghost:hover{background:#fff;border-color:rgba(15,23,42,.18)}
.cookie-modal{position:fixed;inset:0;z-index:2200}
.cookie-modal-backdrop{position:absolute;inset:0;background:rgba(10,16,28,.58);backdrop-filter:blur(3px)}
.cookie-modal-dialog{position:relative;width:min(760px,calc(100% - 32px));margin:clamp(24px,6vh,64px) auto;padding:32px;border-radius:28px;background:#fff;border:1px solid rgba(15,23,42,.08);box-shadow:0 24px 70px rgba(15,23,42,.22)}
.cookie-modal-close{position:absolute;top:18px;right:18px;width:44px;height:44px;border:none;border-radius:999px;background:rgba(15,23,42,.06);color:#0f172a;font-size:28px;line-height:1;cursor:pointer}
.cookie-modal-head p{text-align:left;margin:14px 0 0;color:#475569}
.cookie-modal-head h2{text-align:left;font-size:clamp(22px,2vw,28px);margin:14px 0 0}
.cookie-groups{display:grid;gap:16px;margin:28px 0 30px}
.cookie-group{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:18px;align-items:center;padding:20px 22px;border:1px solid #e5e7eb;border-radius:22px;background:#fff}
.cookie-group h3{margin:0 0 8px;font-size:18px;text-align:left}
.cookie-group p{margin:0;font-size:15px;line-height:1.65;color:#475569;text-align:left}
.cookie-group.is-locked{background:#f8fafc}
.cookie-toggle-static{display:inline-flex;align-items:center;min-height:42px;padding:0 14px;border-radius:999px;background:rgba(30,91,189,.08);color:#1e3a6e;font-size:13px;font-weight:600}
.cookie-switch-wrap{position:relative;display:inline-flex;align-items:center}
.cookie-switch-input{position:absolute;opacity:0;pointer-events:none}
.cookie-switch{position:relative;width:62px;height:36px;border-radius:999px;background:#cbd5e1;transition:background-color .18s}
.cookie-switch::after{content:'';position:absolute;top:4px;left:4px;width:28px;height:28px;border-radius:50%;background:#fff;box-shadow:0 4px 12px rgba(15,23,42,.18);transition:transform .18s}
.cookie-switch-input:checked + .cookie-switch{background:#1e5bbd}
.cookie-switch-input:checked + .cookie-switch::after{transform:translateX(26px)}
body.cookie-modal-open{overflow:hidden}



/* Korekty v15: wspólna szerokość opisów pod nagłówkami sekcji */
.section-head,
.big-statement,
.split-intro,
.security-header,
.about-header{
  max-width:1080px;
}
.section-head p,
.big-statement-sub,
.split-intro > p,
.security-header > p,
.about-lead p{
  max-width:940px;
  margin-left:auto;
  margin-right:auto;
}
.hero-dark-lead{
  max-width:760px;
}

/* Korekty v15: stabilniejszy układ kart funkcji */
.bento-grid{
  grid-auto-rows:minmax(300px,auto);
}
.bento-cell{
  min-height:300px;
}
.bento-cell p{
  flex:1 1 auto;
}
.bento-cell-text{
  height:100%;
}
.bento-cell-text p{
  flex:1 1 auto;
}
@media(max-width:860px){
  .bento-grid{grid-auto-rows:auto}
  .bento-cell{min-height:auto}
}

/* RESPONSIVE */
@media(max-width:1200px){
  .hero-dark-inner,.video-showcase-grid,.split-steps-layout{gap:40px}
  .bento-grid{grid-template-columns:1fr 1fr}
  .bento-lg,.bento-md,.bento-sm{grid-column:span 1}
  .bento-lg:first-child{grid-column:span 2}
  .security-pillars{grid-template-columns:1fr 1fr}
  .reg-grid{grid-template-columns:1fr 1fr}
  .about-stats{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
  .contact-person-card-live{grid-template-columns:180px 1fr;padding:28px 32px}
  .circle-photo-live{width:148px;height:148px}
  .contact-person-card-name{font-size:28px}
}
@media(max-width:960px){
  .split-steps-layout{grid-template-columns:1fr}
  .split-steps-right{display:none}
}
@media(max-width:860px){
  .container{width:min(100% - 32px,1440px)}
  .section{padding:80px 0}
  .header-inner{min-height:72px;gap:14px}
  .brand{display:flex;align-items:center;min-width:0;max-width:calc(100% - 58px)}
  .brand img{height:56px;max-width:min(100%,360px)}
  .header-nav{display:none}
  .hamburger{display:flex;flex:0 0 44px}
  .hero-dark-inner,.video-showcase-grid{grid-template-columns:1fr}
  .hero-dark-visual{display:none}
  .bento-grid{grid-template-columns:1fr}
  .bento-lg,.bento-md,.bento-sm,.bento-lg:first-child{grid-column:span 1}
  .bento-cell-split{grid-template-columns:1fr}
  .bento-cell-screen{display:none}
  .security-pillars{grid-template-columns:1fr}
  .zt-steps{flex-direction:column;align-items:stretch}
  .zt-arrow{transform:rotate(90deg);text-align:center}
  .reg-grid{grid-template-columns:1fr}
  .comparison-desktop{display:none}
  .comparison-mobile{display:grid}
  .shots-slider{grid-template-columns:40px 1fr 40px;gap:10px}
  .sc-shot,.slide-card{flex:0 0 100%}
  .shots-arrow{width:40px;height:40px;font-size:22px}
  .scenario-item{grid-template-columns:60px 1fr;gap:20px}
  .scenario-resolution{grid-column:1/-1}
  .contact-grid-2{grid-template-columns:1fr}
  .contact-person-card-live{grid-template-columns:1fr;min-height:auto;justify-items:center;text-align:center;padding:28px 22px}
  .contact-card-body-live{align-items:center;padding-left:0}
  .contact-person-card-name,.contact-person-card-role,.contact-person-card-list li{text-align:center}
  .contact-actions{justify-content:center}
  .about-stats{grid-template-columns:1fr 1fr}
  .about-pl-banner{padding:28px 22px}
  .footer-grid{grid-template-columns:1fr;gap:32px}
  .stat-b-div{display:none}
  .stats-band-inner{justify-content:flex-start}
  .stat-b{padding:10px 20px}
  .download-banner-inner{grid-template-columns:1fr;text-align:center;gap:28px;max-width:760px}
  .download-banner-copy .eyebrow{margin:0 auto}
  .download-banner-copy h2,.download-banner-copy p{text-align:center;margin-left:auto;margin-right:auto}
  .download-banner-actions{justify-content:center}
  .cookie-banner{left:16px;right:16px;bottom:16px}
  .cookie-banner-inner,.cookie-group{grid-template-columns:1fr}
  .cookie-banner-inner{padding:20px}
  .cookie-banner-actions{justify-content:flex-start}
  .security-zt{padding:24px 20px}
}

/* Korekty v17 */
h1,h2,.big-statement-h,.hero-dark-subline,.section-head p,.big-statement-sub{ text-wrap: balance; }
.shots-viewport{padding:14px;margin:-14px;overflow:hidden}
.sc-shot:hover{transform:translateY(-3px);box-shadow:0 12px 32px rgba(30,91,189,.18)}
.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);width:54px;height:54px;border:none;border-radius:50%;background:rgba(255,255,255,.12);color:#fff;display:grid;place-items:center;cursor:pointer;font-size:38px;line-height:1;z-index:2;transition:background .2s,transform .2s}
.lightbox-nav:hover{background:rgba(255,255,255,.22);transform:translateY(-50%) scale(1.04)}
.lightbox-prev{left:24px}.lightbox-next{right:24px}.lightbox-nav[hidden]{display:none}
@media(max-width:860px){.lightbox-nav{width:44px;height:44px;font-size:30px}.lightbox-prev{left:12px}.lightbox-next{right:12px}}

/* Korekty v18: rytm tekstu i responsywność */
.desktop-break{display:block}
.nowrap{white-space:nowrap}
@media(max-width:640px){
  .desktop-break{display:none}
  h1{font-size:clamp(34px,9vw,42px);line-height:1.12}
  h2,.big-statement-h{font-size:clamp(26px,8vw,34px);line-height:1.16}
  h3{font-size:18px}
  p{font-size:16px;line-height:1.65}
  .hero-dark{padding:88px 0 76px}
  .hero-dark-subline{font-size:21px;line-height:1.28}
  .hero-dark-lead{font-size:16px;line-height:1.65;max-width:100%}
  .hero-dark-actions .button{width:100%;white-space:normal;text-align:center}
  .stats-band-inner{display:grid;grid-template-columns:1fr 1fr;gap:10px;width:100%}
  .stat-b{padding:14px 10px;background:rgba(255,255,255,.045);border-radius:16px}
  .stat-b strong{font-size:17px}
  .stat-b span{font-size:12px;line-height:1.45;display:block}
  .scenario-item{grid-template-columns:1fr;padding:30px 0}
  .scenario-num{font-size:42px}
  .split-step{grid-template-columns:42px 1fr;padding:18px 14px;gap:14px}
  .ss-marker{width:38px;height:38px}
  .bento-cell{padding:24px 22px;border-radius:20px}
  .security-pillar{padding:24px 20px}
  .reg-item{padding:22px 20px;gap:14px}
  .contact-intro-head{text-align:left;margin-bottom:38px}
  .contact-intro-head .eyebrow{margin-left:0;margin-right:0}
  .contact-intro-head h2,.contact-intro-head p{text-align:left;margin-left:0;margin-right:0}
  .contact-actions{width:100%;display:grid;grid-template-columns:1fr;gap:10px}
  .contact-actions .button{width:100%}
  .form-actions .button{width:100%}
  .cookie-banner-actions{display:grid;grid-template-columns:1fr;gap:10px;width:100%}
  .cookie-btn{width:100%}
}
@media(min-width:641px) and (max-width:1024px){
  .section{padding:96px 0}
  .hero-dark{padding:104px 0}
  .section-head,.big-statement,.split-intro,.security-header{max-width:920px}
  .section-head p,.big-statement-sub,.security-header>p{max-width:820px}
  .stats-band-inner{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
  .stat-b{padding:18px 24px;background:rgba(255,255,255,.04);border-radius:18px}
  .stat-b-div{display:none}
}

/* Korekty v19: ujednolicenie rytmu sekcji i opisów */
:root{
  --section-y:112px;
  --section-y-tablet:88px;
  --section-y-mobile:72px;
  --section-head-gap:52px;
  --section-copy-width:1080px;
}
.section,
.section-security{
  padding-top:var(--section-y);
  padding-bottom:var(--section-y);
}
.section-head,
.big-statement,
.split-intro,
.security-header,
.about-header{
  max-width:1080px;
}
.section-head{
  margin-bottom:var(--section-head-gap);
}
.section-head p,
.big-statement-sub,
.split-intro > p,
.security-header > p,
.about-lead,
#faq .section-head p{
  max-width:var(--section-copy-width);
  margin-left:auto;
  margin-right:auto;
}
#kontakt .contact-intro-head{
  text-align:center;
  margin-left:auto;
  margin-right:auto;
}
#kontakt .contact-intro-head .eyebrow{
  margin-left:auto;
  margin-right:auto;
}
#kontakt .contact-intro-head h2,
#kontakt .contact-intro-head p{
  text-align:center;
  margin-left:auto;
  margin-right:auto;
}
@media(min-width:641px) and (max-width:1024px){
  .section,
  .section-security{
    padding-top:var(--section-y-tablet);
    padding-bottom:var(--section-y-tablet);
  }
  .section-head p,
  .big-statement-sub,
  .split-intro > p,
  .security-header > p,
  .about-lead,
  #faq .section-head p{
    max-width:min(var(--section-copy-width),100%);
  }
}
@media(max-width:640px){
  .section,
  .section-security{
    padding-top:var(--section-y-mobile);
    padding-bottom:var(--section-y-mobile);
  }
  .section-head{
    margin-bottom:38px;
  }
  .section-head p,
  .big-statement-sub,
  .split-intro > p,
  .security-header > p,
  .about-lead,
  #faq .section-head p{
    max-width:100%;
  }
  #kontakt .contact-intro-head,
  #kontakt .contact-intro-head h2,
  #kontakt .contact-intro-head p{
    text-align:center;
  }
  #kontakt .contact-intro-head .eyebrow{
    margin-left:auto;
    margin-right:auto;
  }
}

/* Korekty v21: grafika hero i spójniejsze CTA */
.hero-dark::before{
  content:"";
  position:absolute;
  top:8%;
  right:-8%;
  width:min(760px,58vw);
  height:min(760px,58vw);
  background:
    radial-gradient(circle at 45% 45%,rgba(219,234,254,.18) 0%,rgba(59,130,246,.10) 34%,rgba(30,91,189,.05) 58%,transparent 76%);
  pointer-events:none;
  z-index:0;
}
.hero-dark-visual{
  position:relative;
  display:flex;
  justify-content:center;
  align-items:center;
  min-height:520px;
}
.hero-illustration-wrap{
  position:relative;
  width:min(100%,640px);
  isolation:isolate;
}
.hero-illustration-wrap::before{
  content:"";
  position:absolute;
  inset:7% 2% 6%;
  border-radius:42% 58% 48% 52%;
  background:
    radial-gradient(circle at 50% 50%,rgba(226,240,255,.20) 0%,rgba(96,165,250,.13) 42%,rgba(59,130,246,.06) 64%,transparent 78%);
  filter:blur(18px);
  z-index:-1;
}
.hero-illustration{
  width:100%;
  height:auto;
  display:block;
  filter:
    drop-shadow(0 34px 48px rgba(0,0,0,.36))
    drop-shadow(0 0 38px rgba(59,130,246,.22));
}
@media(max-width:1200px){
  .hero-dark-visual{min-height:460px}
  .hero-illustration-wrap{width:min(100%,560px)}
}
@media(max-width:860px){
  .hero-dark-visual{display:flex;min-height:auto;margin-top:34px}
  .hero-illustration-wrap{width:min(100%,460px)}
}
@media(max-width:640px){
  .hero-dark-visual{margin-top:28px}
  .hero-illustration-wrap{width:min(100%,360px)}
}


/* Korekty v22: szersze opisy, bez wymuszonego łamania leadów, spójne karty kontaktu */
h1,h2,.big-statement-h,.hero-dark-subline{ text-wrap: balance; }
.section-head p,.big-statement-sub,.split-intro > p,.security-header > p,.about-lead,#faq .section-head p{
  text-wrap: pretty;
  max-width:var(--section-copy-width);
}
.contact-person-card-live,
.contact-person-card-live:nth-child(1),
.contact-person-card-live:nth-child(2){
  background:linear-gradient(135deg,#f0f5ff 0%,#ffffff 55%);
}

@media(max-width:480px){
  .container{width:min(100% - 24px,1440px)}
  .header-inner{min-height:68px}
  .brand img{height:34px}
  .mobile-menu{padding:20px}
  .mobile-menu-top img{height:32px}
}


/* SAFEGUARD PRODUCT OVERRIDES */
.brand img{height:56px;max-width:min(100%,360px)}
.mobile-menu-top img{height:34px;width:auto;max-width:260px}
.nav-cta{box-shadow:0 4px 16px rgba(215,116,84,.34)}
.nav-cta:hover{background:#c56446 !important;box-shadow:0 6px 22px rgba(215,116,84,.42) !important}
.button-primary{box-shadow:0 8px 22px rgba(215,116,84,.28)}
.button-primary:hover{background:#c56446;box-shadow:0 12px 28px rgba(215,116,84,.38)}
.button-white{color:var(--primary)}
.hero-dark{background:linear-gradient(135deg,#1f2229 0%,#242a31 48%,#311f1d 100%)}
.hero-bg-grid{background-image:linear-gradient(rgba(234,139,105,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(234,139,105,.08) 1px,transparent 1px)}
.hero-dark-lead{color:rgba(255,255,255,.76)}
.hero-trust-bar span{background:rgba(255,255,255,.08);color:rgba(255,255,255,.74)}
.hero-trust-label{color:rgba(255,255,255,.48)!important;background:none!important;border:none!important}
.hero-screen-frame{box-shadow:0 0 0 1px rgba(215,116,84,.16),0 32px 80px rgba(0,0,0,.45),0 0 100px rgba(215,116,84,.08)}
.hero-screen-dots span:nth-child(1){background:rgba(215,116,84,.9)}
.hero-screen-dots span:nth-child(2){background:rgba(215,116,84,.55)}
.hero-screen-frame img{opacity:1}
.browser-bar{background:#f6efec}
.browser-bar span:nth-child(1){background:#8b2713}
.browser-bar span:nth-child(2){background:#d77454}
.browser-bar span:nth-child(3){background:#e9b19e}
.scenario-resolution{background:#fff5f1;border:1px solid rgba(215,116,84,.18)}
.sr-solution-tag{color:var(--primary);background:rgba(215,116,84,.10);border:1px solid rgba(215,116,84,.22)}
.bento-blue{background:linear-gradient(135deg,#d77454 0%,#8b2713 100%)}
.bento-dark{background:linear-gradient(135deg,#23262e 0%,#8b2713 100%)}
.bento-slate .bento-icon,.bento-icon-sm{background:rgba(215,116,84,.08);border-color:rgba(215,116,84,.14)}
.section-security{background:linear-gradient(135deg,#1f2229 0%,#242a31 58%,#311f1d 100%)}
.sec-icon-wrap{background:rgba(215,116,84,.16);border-color:rgba(215,116,84,.28)}
.sec-icon-wrap i{color:#f4b29c;font-size:24px;line-height:1}
.zt-num{background:var(--mid)}
.reg-badge{background:var(--primary)}
.comparison-table thead th{background:#f5eeeb}
.comparison-table tbody th{background:#fff}
.comparison-table tbody td{background:#faf6f4}
.comparison-table tbody tr:hover th{background:#faf0ec}
.comparison-table tbody tr:hover td:not(.safedr-col){background:#f8ede8}
.shots-arrow{background:#fff;border:1px solid var(--line);color:var(--primary)}
.slide-card{background:#fff;border:1px solid var(--line)}
.slide-card:hover{border-color:rgba(215,116,84,.3)}
.faq-question:hover{color:var(--primary)}
.section-about{background:linear-gradient(135deg,#1f2229 0%,#242a31 58%,#311f1d 100%)}
.about-stat{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08)}
.about-stat-value{color:#fff}
.about-pl-banner{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08)}
.about-pl-tag{background:rgba(215,116,84,.14);color:#f6c3b3;border-color:rgba(215,116,84,.3)}
.download-banner{background:linear-gradient(135deg,#8b2713 0%,#c96444 100%)}
.contact-intro-head .eyebrow{margin:0 auto 18px}
.site-footer{background:#23262e}
.footer-brand img{max-width:280px}
.footer-copy-links a:hover,.footer-links a:hover,.footer-contact a:hover,.about-link:hover{color:#f6c3b3}
.back-to-top{background:var(--cta)}
.back-to-top:hover{background:#c56446}
.cookie-btn-primary{background:var(--cta)}
.cookie-btn-primary:hover{background:#c56446}
@media (max-width:1024px){.brand img{height:56px;max-width:min(100%,360px)}}
@media (max-width:640px){.brand img{height:56px;max-width:min(100%,360px)}}


/* SAFEGUARD V2 LAYOUT */
.feature-card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:stretch}
.feature-card{background:#fff;border:1px solid var(--line);border-radius:22px;padding:28px;box-shadow:var(--sh-sm);transition:transform .22s,box-shadow .22s,border-color .22s;min-height:100%}
.feature-card:hover{transform:translateY(-3px);box-shadow:0 20px 48px rgba(35,38,46,.12);border-color:rgba(215,116,84,.28)}
.feature-card-icon{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;margin-bottom:18px;background:rgba(215,116,84,.10);border:1px solid rgba(215,116,84,.16);color:var(--primary)}
.feature-card-icon i{font-size:23px;line-height:1}
.feature-card h3{font-size:19px;line-height:1.3;margin-bottom:10px;color:var(--text)}
.feature-card p{font-size:15px;line-height:1.65;color:var(--muted)}
.placeholder-showcase{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:stretch}
.placeholder-shot{display:block;border:0;background:transparent;padding:0;cursor:pointer;border-radius:22px;overflow:hidden;box-shadow:var(--sh-sm);transition:transform .22s,box-shadow .22s}
.placeholder-shot:hover{transform:translateY(-3px);box-shadow:0 20px 48px rgba(35,38,46,.12)}
.placeholder-shot img{width:100%;display:block}
.download-banner-with-placeholder{grid-template-columns:minmax(0,620px) minmax(280px,420px)}
.download-placeholder-card{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);border-radius:24px;padding:14px;box-shadow:0 16px 38px rgba(0,0,0,.18)}
.download-placeholder-card img{width:100%;border-radius:16px;display:block}
.sec-icon-wrap i{color:#f4b29c;font-size:24px;line-height:1}
.footer-icon i{color:rgba(255,255,255,.7);font-size:16px;line-height:1}
.social-links i{color:#fff;font-size:17px;line-height:1}
.back-to-top i{font-size:18px;line-height:1;color:currentColor}
@media (max-width:1024px){.feature-card-grid,.placeholder-showcase{grid-template-columns:1fr 1fr}.download-banner-with-placeholder{grid-template-columns:1fr;max-width:760px}.download-placeholder-card{max-width:460px;margin:0 auto}}
@media (max-width:640px){.feature-card-grid,.placeholder-showcase{grid-template-columns:1fr}}


/* ==========================================================================
   SafeGuard v2 — differentiated layout aligned with Safe product family
   ========================================================================== */

/* HERO: light background aligned with SafeDR/SafeConnect, in SafeGuard palette */
.hero-dark {
  position: relative;
  overflow: hidden;
  padding: 118px 0 108px;
  background:
    radial-gradient(circle at 12% 18%, rgba(215, 116, 84, 0.08), transparent 30%),
    radial-gradient(circle at 84% 28%, rgba(234, 139, 105, 0.06), transparent 34%),
    linear-gradient(180deg, rgba(248, 250, 252, 0.94) 0%, rgba(255, 255, 255, 1) 62%);
  background-color: #fff;
  isolation: isolate;
}
.hero-dark::before,
.hero-bg-grid {
  display: none !important;
}
.hero-network-inner {
  grid-template-columns: minmax(0, 0.95fr) minmax(460px, 1.05fr);
  gap: 72px;
}
.hero-dark-copy,
.hero-network-map {
  position: relative;
  z-index: 1;
}
.hero-dark h1 {
  color: var(--text);
}
.hero-dark .eyebrow-light {
  background: rgba(215, 116, 84, 0.08);
  border-color: rgba(215, 116, 84, 0.16);
  color: var(--mid);
}
.hero-dark .eyebrow-light::before {
  background: var(--mid);
  box-shadow: 0 0 0 3px rgba(215, 116, 84, 0.12);
}
.hero-dark-subline {
  color: var(--primary);
}
.hero-dark-lead {
  color: var(--muted);
}
.hero-dark .button-white {
  background: var(--cta);
  color: #fff;
  box-shadow: 0 8px 24px rgba(215, 116, 84, 0.24);
}
.hero-dark .button-white:hover {
  background: #c56446;
  box-shadow: 0 12px 30px rgba(215, 116, 84, 0.32);
}
.hero-dark .button-ghost {
  background: #fff;
  color: var(--text);
  border: 1.5px solid var(--line);
}
.hero-dark .button-ghost:hover {
  border-color: rgba(215, 116, 84, 0.24);
  color: var(--primary);
  background: #fffaf8;
}
.hero-trust-bar span {
  background: rgba(255, 255, 255, 0.74);
  border: 1px solid rgba(234, 222, 217, 0.9);
  color: var(--muted);
}
.hero-trust-label {
  color: rgba(85, 92, 102, 0.78) !important;
  background: none !important;
  border: none !important;
}

.hero-network-map {
  align-self: center;
}
.network-map-card {
  position: relative;
  min-height: 560px;
  border: 1px solid rgba(234, 222, 217, 0.94);
  border-radius: 34px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.88), rgba(255, 250, 248, 0.74)),
    radial-gradient(circle at 50% 48%, rgba(215, 116, 84, 0.08), transparent 50%);
  box-shadow:
    0 0 0 1px rgba(215, 116, 84, 0.05),
    0 28px 80px rgba(35, 38, 46, 0.10);
  overflow: hidden;
}
.network-map-card::before,
.network-map-card::after {
  content: "";
  position: absolute;
  inset: 72px;
  border: 1px solid rgba(215, 116, 84, 0.10);
  border-radius: 42% 58% 51% 49%;
  pointer-events: none;
}
.network-map-card::after {
  inset: 130px 112px;
  border-color: rgba(215, 116, 84, 0.16);
  transform: rotate(-10deg);
}
.network-map-core {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 178px;
  min-height: 178px;
  transform: translate(-50%, -50%);
  display: grid;
  place-items: center;
  align-content: center;
  gap: 7px;
  text-align: center;
  border-radius: 50%;
  background: #fff;
  border: 1px solid rgba(215, 116, 84, 0.22);
  box-shadow:
    0 16px 36px rgba(139, 39, 19, 0.10),
    0 0 0 12px rgba(215, 116, 84, 0.05);
  z-index: 2;
}
.network-map-core img {
  width: 46px;
  height: auto;
}
.network-map-core strong {
  font-size: 18px;
  line-height: 1.1;
  color: var(--text);
}
.network-map-core span,
.network-node span {
  display: block;
  font-size: 12px;
  color: var(--muted);
  line-height: 1.35;
}
.network-node {
  position: absolute;
  width: 184px;
  min-height: 118px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 7px;
  padding: 20px;
  background: rgba(255, 255, 255, 0.86);
  border: 1px solid rgba(234, 222, 217, 0.9);
  border-radius: 22px;
  box-shadow: 0 14px 34px rgba(35, 38, 46, 0.08);
}
.network-node::before {
  content: "";
  position: absolute;
  width: 52px;
  height: 1px;
  background: linear-gradient(90deg, rgba(215, 116, 84, 0.0), rgba(215, 116, 84, 0.34));
  top: 50%;
}
.network-node i {
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  border-radius: 12px;
  background: rgba(215, 116, 84, 0.09);
  color: var(--mid);
  font-size: 17px;
}
.network-node strong {
  font-size: 15px;
  line-height: 1.25;
  color: var(--text);
}
.node-user { top: 50px; left: 52px; }
.node-device { top: 58px; right: 46px; }
.node-policy { top: 50%; right: 28px; transform: translateY(-50%); }
.node-assets { bottom: 58px; right: 64px; }
.node-audit { bottom: 62px; left: 54px; }
.node-user::before,
.node-audit::before {
  right: -52px;
}
.node-device::before,
.node-policy::before,
.node-assets::before {
  left: -52px;
  transform: rotate(180deg);
}
.hero-graphic-note {
  margin-top: 14px;
  text-align: center;
  color: rgba(85, 92, 102, 0.72);
  font-size: 13px;
}

/* POINT OF DEPARTURE: transformation instead of duplicated scenario flow */
.access-shift {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 132px minmax(0, 1fr);
  gap: 24px;
  align-items: stretch;
}
.access-shift-panel {
  position: relative;
  padding: 34px;
  border-radius: 28px;
  border: 1px solid var(--line);
  background: #fff;
  box-shadow: var(--sh-sm);
}
.access-shift-panel h3 {
  font-size: 24px;
  margin: 10px 0 22px;
}
.shift-label {
  display: inline-flex;
  padding: 5px 12px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.access-shift-problem .shift-label {
  color: #8b1d1d;
  background: #fee2e2;
  border: 1px solid rgba(185, 28, 28, 0.18);
}
.access-shift-solution .shift-label {
  color: var(--primary);
  background: rgba(215, 116, 84, 0.10);
  border: 1px solid rgba(215, 116, 84, 0.20);
}
.access-shift-panel ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 16px;
}
.access-shift-panel li {
  display: grid;
  grid-template-columns: 24px 1fr;
  gap: 12px;
  align-items: start;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.65;
}
.access-shift-problem li i {
  color: #b91c1c;
  margin-top: 5px;
}
.access-shift-solution {
  background: linear-gradient(135deg, #fff 0%, #fff7f3 100%);
  border-color: rgba(215, 116, 84, 0.20);
}
.access-shift-solution li i {
  color: var(--mid);
  margin-top: 5px;
}
.access-shift-middle {
  display: grid;
  place-items: center;
  align-content: center;
  gap: 12px;
  color: var(--primary);
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  text-align: center;
}
.shift-arrow {
  width: 66px;
  height: 66px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: var(--cta);
  color: #fff;
  box-shadow: 0 14px 30px rgba(215, 116, 84, 0.24);
  font-size: 22px;
}

/* MODEL: cycle layout instead of step list + screenshot */
.access-cycle {
  position: relative;
  min-height: 660px;
  max-width: 1180px;
  margin: 0 auto;
  border-radius: 38px;
  background:
    radial-gradient(circle at 50% 50%, rgba(215, 116, 84, 0.08), transparent 36%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.82), rgba(255, 250, 248, 0.72));
  border: 1px solid rgba(234, 222, 217, 0.9);
  box-shadow: var(--sh-sm);
  overflow: hidden;
}
.access-cycle::before {
  content: "";
  position: absolute;
  inset: 116px 156px;
  border: 1.5px dashed rgba(215, 116, 84, 0.20);
  border-radius: 50%;
  pointer-events: none;
}
.cycle-center {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 204px;
  height: 204px;
  transform: translate(-50%, -50%);
  display: grid;
  place-items: center;
  align-content: center;
  gap: 8px;
  text-align: center;
  border-radius: 50%;
  background: #fff;
  border: 1px solid rgba(215, 116, 84, 0.24);
  box-shadow: 0 20px 48px rgba(139, 39, 19, 0.10);
}
.cycle-center img {
  width: 54px;
}
.cycle-center strong {
  font-size: 20px;
  color: var(--text);
}
.cycle-center span {
  max-width: 132px;
  font-size: 12px;
  color: var(--muted);
  line-height: 1.35;
}
.cycle-step {
  position: absolute;
  width: 260px;
  min-height: 180px;
  padding: 24px;
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.88);
  border: 1px solid rgba(234, 222, 217, 0.96);
  box-shadow: 0 12px 34px rgba(35, 38, 46, 0.08);
}
.cycle-step span {
  display: inline-grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: rgba(215, 116, 84, 0.10);
  color: var(--primary);
  font-size: 13px;
  font-weight: 800;
  margin-bottom: 13px;
}
.cycle-step h3 {
  font-size: 17px;
  margin-bottom: 8px;
}
.cycle-step p {
  font-size: 14px;
  line-height: 1.58;
}
.cycle-step-1 { top: 42px; left: 50%; transform: translateX(-50%); }
.cycle-step-2 { top: 178px; right: 48px; }
.cycle-step-3 { bottom: 56px; right: 162px; }
.cycle-step-4 { bottom: 56px; left: 162px; }
.cycle-step-5 { top: 178px; left: 48px; }
.model-note {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  max-width: 920px;
  margin: 28px auto 0;
  padding: 20px 24px;
  border-radius: 18px;
  background: #fff;
  border: 1px solid var(--line);
  box-shadow: var(--sh-sm);
}
.model-note i {
  color: var(--mid);
  margin-top: 4px;
}
.model-note p {
  font-size: 15px;
}

/* MECHANISMS: control map instead of regular cards grid */
.control-map {
  position: relative;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
  max-width: 1160px;
  margin: 0 auto;
}
.control-map-center {
  grid-column: 2;
  grid-row: 1 / span 2;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 10px;
  min-height: 300px;
  text-align: center;
  border-radius: 30px;
  background:
    radial-gradient(circle at 50% 34%, rgba(215, 116, 84, 0.12), transparent 54%),
    linear-gradient(135deg, #fff 0%, #fff8f5 100%);
  border: 1px solid rgba(215, 116, 84, 0.18);
  box-shadow: 0 18px 46px rgba(35, 38, 46, 0.08);
}
.control-map-center img {
  width: 64px;
}
.control-map-center strong {
  color: var(--text);
  font-size: 24px;
}
.control-map-center span {
  max-width: 190px;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.45;
}
.control-map-item {
  min-height: 214px;
  padding: 28px;
  background: rgba(255, 255, 255, 0.88);
  border: 1px solid var(--line);
  border-radius: 24px;
  box-shadow: var(--sh-sm);
  transition: transform 0.22s, box-shadow 0.22s;
}
.control-map-item:hover {
  transform: translateY(-3px);
  box-shadow: var(--sh);
}
.control-icon {
  width: 48px;
  height: 48px;
  display: grid;
  place-items: center;
  border-radius: 15px;
  margin-bottom: 18px;
  background: rgba(215, 116, 84, 0.08);
  border: 1px solid rgba(215, 116, 84, 0.14);
}
.control-icon i {
  color: var(--mid);
  font-size: 21px;
}
.control-map-item h3 {
  font-size: 18px;
  margin-bottom: 10px;
}
.control-map-item p {
  font-size: 15px;
  line-height: 1.62;
}

/* Small consistency fixes for existing SafeGuard palette */
.browser-bar {
  background: #f6efec;
}
.browser-bar span:nth-child(1) { background: #8b2713; }
.browser-bar span:nth-child(2) { background: #d77454; }
.browser-bar span:nth-child(3) { background: #e9b19e; }
.scenario-resolution {
  background: #fff5f1;
  border: 1px solid rgba(215, 116, 84, 0.18);
}
.sr-solution-tag {
  color: var(--primary);
  background: rgba(215, 116, 84, 0.10);
  border: 1px solid rgba(215, 116, 84, 0.22);
}
.bento-blue {
  background: linear-gradient(135deg, #d77454 0%, #8b2713 100%);
}
.bento-dark {
  background: linear-gradient(135deg, #23262e 0%, #8b2713 100%);
}
.bento-slate .bento-icon,
.bento-icon-sm {
  background: rgba(215, 116, 84, 0.08);
  border-color: rgba(215, 116, 84, 0.14);
}
.section-security {
  background: linear-gradient(135deg, #1f2229 0%, #242a31 58%, #311f1d 100%);
}

/* Responsive */
@media (max-width: 1180px) {
  .hero-network-inner {
    grid-template-columns: 1fr;
    gap: 48px;
  }
  .hero-network-map {
    max-width: 760px;
    margin: 0 auto;
    width: 100%;
  }
  .access-shift {
    grid-template-columns: 1fr;
  }
  .access-shift-middle {
    display: flex;
    justify-content: center;
  }
  .shift-arrow {
    transform: rotate(90deg);
  }
  .control-map {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .control-map-center {
    grid-column: 1 / -1;
    grid-row: auto;
    min-height: 220px;
  }
}

@media (max-width: 900px) {
  .network-map-card {
    min-height: auto;
    display: grid;
    grid-template-columns: 1fr;
    gap: 14px;
    padding: 22px;
  }
  .network-map-card::before,
  .network-map-card::after,
  .network-node::before {
    display: none;
  }
  .network-map-core,
  .network-node {
    position: static;
    width: 100%;
    min-height: auto;
    transform: none;
  }
  .network-map-core {
    border-radius: 24px;
    padding: 24px;
  }
  .network-node {
    padding: 18px;
  }
  .access-cycle {
    min-height: auto;
    display: grid;
    gap: 16px;
    padding: 22px;
  }
  .access-cycle::before {
    display: none;
  }
  .cycle-center,
  .cycle-step {
    position: static;
    width: 100%;
    height: auto;
    min-height: auto;
    transform: none;
  }
  .cycle-center {
    border-radius: 26px;
    padding: 24px;
  }
}

@media (max-width: 640px) {
  .hero-dark {
    padding: 88px 0 74px;
  }
  .hero-dark-actions {
    gap: 10px;
  }
  .hero-trust-bar {
    align-items: flex-start;
  }
  .access-shift-panel {
    padding: 24px;
  }
  .access-shift-panel h3 {
    font-size: 21px;
  }
  .control-map {
    grid-template-columns: 1fr;
  }
  .model-note {
    flex-direction: column;
  }
}


/* ==========================================================================
   SafeGuard v4 — corrections after content review
   ========================================================================== */

/* HERO: back to regular graphic placeholder, no cycle/network map inside hero */
.hero-dark {
  position: relative;
  overflow: hidden;
  padding: 118px 0 108px;
  background:
    radial-gradient(circle at 12% 18%, rgba(215, 116, 84, 0.08), transparent 30%),
    radial-gradient(circle at 84% 28%, rgba(234, 139, 105, 0.06), transparent 34%),
    linear-gradient(180deg, rgba(248, 250, 252, 0.94) 0%, rgba(255, 255, 255, 1) 62%);
  background-color: #fff;
  isolation: isolate;
}
.hero-dark::before,
.hero-bg-grid {
  display: none !important;
}
.hero-dark-copy,
.hero-screen-wrap {
  position: relative;
  z-index: 1;
}
.hero-dark h1 {
  color: var(--text);
}
.hero-dark .eyebrow-light {
  background: rgba(215, 116, 84, 0.08);
  border-color: rgba(215, 116, 84, 0.16);
  color: var(--mid);
}
.hero-dark .eyebrow-light::before {
  background: var(--mid);
  box-shadow: 0 0 0 3px rgba(215, 116, 84, 0.12);
}
.hero-dark-subline {
  color: var(--primary);
}
.hero-dark-lead {
  color: var(--muted);
}
.hero-dark .button-white {
  background: var(--cta);
  color: #fff;
  box-shadow: 0 8px 24px rgba(215, 116, 84, 0.24);
}
.hero-dark .button-white:hover {
  background: #c56446;
  box-shadow: 0 12px 30px rgba(215, 116, 84, 0.32);
}
.hero-dark .button-ghost {
  background: #fff;
  color: var(--text);
  border: 1.5px solid var(--line);
}
.hero-dark .button-ghost:hover {
  border-color: rgba(215, 116, 84, 0.24);
  color: var(--primary);
  background: #fffaf8;
}
.hero-trust-bar span {
  background: rgba(255, 255, 255, 0.74);
  border: 1px solid rgba(234, 222, 217, 0.9);
  color: var(--muted);
}
.hero-trust-label {
  color: rgba(85, 92, 102, 0.78) !important;
  background: none !important;
  border: none !important;
}
.hero-screen-frame {
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(234, 222, 217, 0.94);
  box-shadow:
    0 0 0 1px rgba(215, 116, 84, 0.08),
    0 20px 60px rgba(35, 38, 46, 0.10),
    0 0 80px rgba(215, 116, 84, 0.06);
}
.hero-screen-dots {
  background: rgba(248, 245, 244, 0.92);
  border-bottom: 1px solid rgba(234, 222, 217, 0.9);
}
.hero-screen-dots span {
  background: rgba(139, 39, 19, 0.18);
}
.hero-screen-dots span:nth-child(1) {
  background: rgba(215, 116, 84, 0.9);
}
.hero-screen-dots span:nth-child(2) {
  background: rgba(234, 139, 105, 0.58);
}
.hero-screen-frame img {
  opacity: 1;
}
.hero-screen-glow {
  background: radial-gradient(ellipse at 50% 0%, rgba(215, 116, 84, 0.16), transparent 70%);
}
.hero-graphic-note {
  margin-top: 14px;
  text-align: center;
  color: rgba(85, 92, 102, 0.72);
  font-size: 13px;
}

/* Remove previous v3 hero map if classes remain anywhere */
.hero-network-map,
.network-map-card,
.network-map-core,
.network-node {
  all: revert-layer;
}

/* Access transformation table/section */
.access-shift {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 132px minmax(0, 1fr);
  gap: 24px;
  align-items: stretch;
}
.access-shift-panel {
  position: relative;
  padding: 34px;
  border-radius: 28px;
  border: 1px solid var(--line);
  background: #fff;
  box-shadow: var(--sh-sm);
}
.access-shift-panel h3 {
  font-size: 24px;
  margin: 10px 0 22px;
}
.shift-label {
  display: inline-flex;
  padding: 5px 12px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.access-shift-problem .shift-label {
  color: #8b1d1d;
  background: #fee2e2;
  border: 1px solid rgba(185, 28, 28, 0.18);
}
.access-shift-solution .shift-label {
  color: var(--primary);
  background: rgba(215, 116, 84, 0.10);
  border: 1px solid rgba(215, 116, 84, 0.20);
}
.access-shift-panel ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 16px;
}
.access-shift-panel li {
  display: grid;
  grid-template-columns: 24px 1fr;
  gap: 12px;
  align-items: start;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.65;
}
.access-shift-problem li i {
  color: #b91c1c;
  margin-top: 5px;
}
.access-shift-solution {
  background: linear-gradient(135deg, #fff 0%, #fff7f3 100%);
  border-color: rgba(215, 116, 84, 0.20);
}
.access-shift-solution li i {
  color: var(--mid);
  margin-top: 5px;
}
.access-shift-middle {
  display: grid;
  place-items: center;
  align-content: center;
  gap: 12px;
  color: var(--primary);
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  text-align: center;
}
.shift-arrow {
  width: 66px;
  height: 66px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: var(--cta);
  color: #fff;
  box-shadow: 0 14px 30px rgba(215, 116, 84, 0.24);
  font-size: 22px;
}

/* Model: safe cards instead of overlapping absolute cycle */
.access-cycle {
  display: none !important;
}
.access-process-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 20px;
  align-items: stretch;
}
.process-card {
  position: relative;
  min-height: 280px;
  padding: 30px 26px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 24px;
  box-shadow: var(--sh-sm);
}
.process-card::after {
  content: "";
  position: absolute;
  top: 48px;
  right: -20px;
  width: 20px;
  height: 1px;
  background: linear-gradient(90deg, rgba(215, 116, 84, 0.38), transparent);
}
.process-card:last-child::after {
  display: none;
}
.process-number {
  display: inline-grid;
  place-items: center;
  width: 42px;
  height: 42px;
  margin-bottom: 18px;
  border-radius: 50%;
  background: rgba(215, 116, 84, 0.10);
  color: var(--primary);
  font-size: 14px;
  font-weight: 800;
}
.process-card h3 {
  margin-bottom: 12px;
  font-size: 18px;
}
.process-card p {
  font-size: 15px;
  line-height: 1.62;
}
.model-note {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  max-width: 920px;
  margin: 28px auto 0;
  padding: 20px 24px;
  border-radius: 18px;
  background: #fff;
  border: 1px solid var(--line);
  box-shadow: var(--sh-sm);
}
.model-note i {
  color: var(--mid);
  margin-top: 4px;
}
.model-note p {
  font-size: 15px;
}

/* Mechanisms: 3 columns x 2 rows, no central logo card */
.control-map {
  display: none !important;
}
.mechanism-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
}
.mechanism-card {
  min-height: 292px;
  padding: 30px;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid var(--line);
  border-radius: 24px;
  box-shadow: var(--sh-sm);
  transition: transform 0.22s, box-shadow 0.22s;
}
.mechanism-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--sh);
}
.mechanism-icon {
  width: 52px;
  height: 52px;
  display: grid;
  place-items: center;
  border-radius: 16px;
  margin-bottom: 20px;
  background: rgba(215, 116, 84, 0.08);
  border: 1px solid rgba(215, 116, 84, 0.14);
}
.mechanism-icon i {
  color: var(--mid);
  font-size: 22px;
}
.mechanism-card h3 {
  font-size: 19px;
  margin-bottom: 12px;
}
.mechanism-card p {
  font-size: 15px;
  line-height: 1.62;
}


/* Functional depth section: concrete SafeGuard operations */
.feature-detail-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
}
.feature-detail-card {
  position: relative;
  min-height: 250px;
  padding: 28px;
  border-radius: 24px;
  background: linear-gradient(145deg, #fff 0%, #fff7f3 100%);
  border: 1px solid rgba(215, 116, 84, 0.16);
  box-shadow: var(--sh-sm);
  overflow: hidden;
}
.feature-detail-card::after {
  content: "";
  position: absolute;
  right: -54px;
  bottom: -54px;
  width: 128px;
  height: 128px;
  border-radius: 999px;
  background: rgba(215, 116, 84, 0.08);
}
.feature-detail-tag {
  display: inline-flex;
  margin-bottom: 18px;
  padding: 7px 12px;
  border-radius: 999px;
  color: var(--primary);
  background: rgba(215, 116, 84, 0.10);
  border: 1px solid rgba(215, 116, 84, 0.18);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.feature-detail-card h3 {
  position: relative;
  z-index: 1;
  font-size: 20px;
  margin-bottom: 12px;
}
.feature-detail-card p {
  position: relative;
  z-index: 1;
  font-size: 15px;
  line-height: 1.62;
}

/* Operations: richer operational content from SafeGuard/Strażnik+ materials */
.operations-console {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 24px;
}
.operations-column {
  padding: 28px;
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.12);
}
.operations-column-accent {
  background: rgba(215, 116, 84, 0.12);
  border-color: rgba(215, 116, 84, 0.22);
}
.ops-label {
  display: inline-flex;
  margin-bottom: 22px;
  padding: 6px 12px;
  border-radius: 999px;
  color: rgba(255, 255, 255, 0.76);
  background: rgba(255, 255, 255, 0.10);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.ops-row {
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: 16px;
  padding: 18px 0;
  border-top: 1px solid rgba(255, 255, 255, 0.10);
}
.ops-row i {
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  border-radius: 14px;
  color: #fff;
  background: rgba(255, 255, 255, 0.10);
}
.ops-row h3 {
  color: #fff;
  font-size: 17px;
  margin-bottom: 6px;
}
.ops-row p {
  color: rgba(255, 255, 255, 0.68);
  font-size: 14px;
  line-height: 1.58;
}

/* Existing palette alignment */
.browser-bar {
  background: #f6efec;
}
.browser-bar span:nth-child(1) { background: #8b2713; }
.browser-bar span:nth-child(2) { background: #d77454; }
.browser-bar span:nth-child(3) { background: #e9b19e; }
.scenario-resolution {
  background: #fff5f1;
  border: 1px solid rgba(215, 116, 84, 0.18);
}
.sr-solution-tag {
  color: var(--primary);
  background: rgba(215, 116, 84, 0.10);
  border: 1px solid rgba(215, 116, 84, 0.22);
}
.bento-blue {
  background: linear-gradient(135deg, #d77454 0%, #8b2713 100%);
}
.bento-dark {
  background: linear-gradient(135deg, #23262e 0%, #8b2713 100%);
}
.bento-slate .bento-icon,
.bento-icon-sm {
  background: rgba(215, 116, 84, 0.08);
  border-color: rgba(215, 116, 84, 0.14);
}
.section-security {
  background: linear-gradient(135deg, #1f2229 0%, #242a31 58%, #311f1d 100%);
}

/* Responsive */
@media (max-width: 1180px) {
  .access-shift {
    grid-template-columns: 1fr;
  }
  .access-shift-middle {
    display: flex;
    justify-content: center;
  }
  .shift-arrow {
    transform: rotate(90deg);
  }
  .access-process-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .process-card::after {
    display: none;
  }
  .mechanism-grid,
  .feature-detail-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 860px) {
  .operations-console {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .hero-dark {
    padding: 88px 0 74px;
  }
  .hero-dark-actions {
    gap: 10px;
  }
  .hero-trust-bar {
    align-items: flex-start;
  }
  .access-shift-panel {
    padding: 24px;
  }
  .access-shift-panel h3 {
    font-size: 21px;
  }
  .access-process-grid,
  .mechanism-grid,
  .feature-detail-grid {
    grid-template-columns: 1fr;
  }
  .model-note {
    flex-direction: column;
  }
  .mechanism-card {
    min-height: auto;
  }
  .ops-row {
    grid-template-columns: 1fr;
  }
}


/* SafeGuard v5 — real screenshots gallery */
.screens-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:22px;
  align-items:stretch;
}
.screen-card{
  position:relative;
  display:flex;
  flex-direction:column;
  min-height:100%;
  padding:0;
  overflow:hidden;
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  box-shadow:var(--sh-sm);
  cursor:pointer;
  text-align:left;
  transition:transform .22s,box-shadow .22s,border-color .22s;
}
.screen-card:hover{
  transform:translateY(-3px);
  border-color:rgba(215,116,84,.28);
  box-shadow:var(--sh);
}
.screen-card img{
  display:block;
  width:100%;
  height:auto;
  aspect-ratio:auto;
  object-fit:contain;
  object-position:left top;
  border-bottom:1px solid var(--line);
  background:#f3f4f6;
}
.screen-card span{
  display:block;
  padding:18px 20px 20px;
  color:var(--muted);
  font-size:14px;
  line-height:1.55;
}
.screen-card strong{
  display:block;
  margin-bottom:5px;
  color:var(--text);
  font-size:16px;
  line-height:1.25;
}
.screen-card-wide{
  grid-column:span 2;
  grid-row:span 2;
}
.screen-card-wide img{
  aspect-ratio:auto;
}
.hero-screen-frame img{
  aspect-ratio:16/9;
  object-fit:cover;
  object-position:left top;
}
.lightbox img{
  transition:opacity .18s ease;
}
.lightbox-caption{
  max-width:min(920px,92vw);
  line-height:1.5;
}
@media(max-width:1100px){
  .screens-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media(max-width:640px){
  .screens-grid{grid-template-columns:1fr;}
  .screen-card-wide{grid-column:auto;grid-row:auto;}
}


/* v8 — transparent hero artwork without browser frame */
.hero-graphic-clean{
  display:flex;
  align-items:center;
  justify-content:flex-end;
}
.hero-graphic-clean .hero-screen-image{
  display:block;
  width:min(100%, 760px);
  height:auto;
  background:transparent !important;
  filter:drop-shadow(0 24px 42px rgba(35,38,46,.10));
}
.hero-graphic-clean .hero-screen-frame,
.hero-graphic-clean .hero-screen-dots,
.hero-graphic-clean .hero-screen-glow{
  display:none !important;
}
@media (max-width: 1100px){
  .hero-graphic-clean{justify-content:center;}
  .hero-graphic-clean .hero-screen-image{width:min(100%, 680px);}
}
@media (max-width: 640px){
  .hero-graphic-clean .hero-screen-image{width:100%;}
}

/* SafeGuard v9 — PDF section and contact cards refinements */
.download-banner-with-placeholder{
  grid-template-columns:minmax(0, 680px) minmax(240px, 320px);
  align-items:center;
}
.download-banner-copy p{
  margin-bottom:24px;
}
.download-cover-card{
  display:block;
  width:min(100%, 320px);
  justify-self:center;
  padding:10px;
  border-radius:22px;
  background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.22);
  box-shadow:0 18px 44px rgba(35,38,46,.22);
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.download-cover-card:hover{
  transform:translateY(-4px);
  border-color:rgba(255,255,255,.34);
  box-shadow:0 24px 54px rgba(35,38,46,.28);
}
.download-cover-card img{
  display:block;
  width:100%;
  height:auto;
  aspect-ratio:auto;
  object-fit:contain;
  object-position:top center;
  border-radius:14px;
  background:#fff;
}
.button-download{
  color:#8b2713;
}
.button-download i{
  color:#8b2713;
}
.contact-person-card-live,
.contact-person-card-live:nth-child(1),
.contact-person-card-live:nth-child(2){
  background:
    radial-gradient(circle at 12% 10%, rgba(215,116,84,.10), transparent 34%),
    linear-gradient(135deg, #fffaf7 0%, #ffffff 62%);
  border-color:rgba(215,116,84,.16);
  box-shadow:0 12px 34px rgba(35,38,46,.08);
}
.circle-photo-live{
  background:linear-gradient(135deg,#fff4ef 0%,#ffffff 100%);
  border-color:rgba(215,116,84,.20);
  box-shadow:0 8px 24px rgba(139,39,19,.10);
}
@media (max-width:1024px){
  .download-banner-with-placeholder{
    grid-template-columns:1fr;
  }
  .download-cover-card{
    max-width:320px;
    margin:4px auto 0;
  }
}
@media (max-width:640px){
  .download-banner-actions{
    display:grid;
    grid-template-columns:1fr;
    width:100%;
  }
  .download-banner-actions .button,
  .download-banner-actions .button-download{
    width:100%;
    justify-content:center;
    white-space:normal;
    text-align:center;
  }
  .download-cover-card{
    max-width:280px;
  }
}


/* SafeGuard v14 — strip below hero, refined spacing and icon */
.hero-product-strip{
  position:relative;
  z-index:2;
  background:#8b2713;
  color:#fff;
  box-shadow:0 14px 34px rgba(139,39,19,.16);
}
.hero-product-strip-inner{
  min-height:116px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:18px;
  padding:0 32px;
  text-align:left;
}
.hero-product-strip-icon{
  flex:0 0 auto;
  font-size:18px;
  color:rgba(255,255,255,.94);
}
.hero-product-strip strong{
  flex:0 0 auto;
  font-size:clamp(16px,1.42vw,21px);
  line-height:1.25;
  letter-spacing:-.01em;
  font-weight:700;
  white-space:nowrap;
}
.hero-product-strip span{
  flex:0 1 auto;
  max-width:none;
  font-size:14px;
  line-height:1.45;
  color:rgba(255,255,255,.84);
  white-space:nowrap;
}
@media (min-width:1101px){
  .hero-dark{
    padding-top:104px;
    padding-bottom:72px;
  }
}
@media (max-width:1180px){
  .hero-product-strip-inner{
    gap:16px;
    padding:18px 24px;
  }
  .hero-product-strip span{
    font-size:13.5px;
  }
}
@media (max-width:900px){
  .hero-product-strip-inner{
    padding-top:20px;
    padding-bottom:20px;
    flex-direction:column;
    align-items:flex-start;
    gap:8px;
  }
  .hero-product-strip strong,
  .hero-product-strip span{
    white-space:normal;
  }
}
@media (max-width:640px){
  .hero-product-strip-inner{
    padding-left:18px;
    padding-right:18px;
  }
}


/* SafeGuard v2 — switch rodziny Safe, poprawa mobile/logo i back-to-top */
.nav-safe-switch{position:relative;margin-left:8px;z-index:80}
.nav-safe-switch summary{display:inline-flex;align-items:center;gap:8px;min-height:40px;padding:0 15px;border:1px solid rgba(215,116,84,.28);border-radius:999px;background:rgba(215,116,84,.10);color:var(--primary);font-size:14px;font-weight:700;white-space:nowrap;cursor:pointer;list-style:none;transition:background .2s,border-color .2s,box-shadow .2s,transform .2s}
.nav-safe-switch summary::-webkit-details-marker{display:none}
.nav-safe-switch summary:hover{background:rgba(215,116,84,.16);border-color:rgba(215,116,84,.40);box-shadow:0 6px 20px rgba(35,38,46,.10);transform:translateY(-1px)}
.nav-safe-switch summary i{font-size:11px;transition:transform .2s}
.nav-safe-switch[open] summary i{transform:rotate(180deg)}
.nav-safe-switch-menu{position:absolute;top:calc(100% + 10px);right:0;width:430px;padding:8px;border:1px solid rgba(234,222,217,.96);border-radius:18px;background:#fff;box-shadow:0 20px 46px rgba(35,38,46,.14)}
.nav-safe-switch-menu::before{content:"";position:absolute;top:-6px;right:34px;width:12px;height:12px;background:#fff;border-top:1px solid rgba(234,222,217,.96);border-left:1px solid rgba(234,222,217,.96);transform:rotate(45deg)}
.header-nav .nav-safe-switch-menu a{display:flex;align-items:center;gap:14px;min-height:52px;padding:10px 12px;border-radius:12px;color:var(--text)}
.header-nav .nav-safe-switch-menu a:hover{background:var(--bg-alt);color:var(--primary)}
.nav-safe-switch-menu img{flex:0 0 150px;width:auto;height:26px;max-width:none;max-height:none;object-fit:contain;object-position:left center}
.nav-safe-switch-menu span{flex:1;min-width:0;color:var(--muted);font-size:13.5px;font-weight:650;line-height:1.2;white-space:nowrap}
.header-nav .nav-safe-switch-menu a:hover span{color:var(--primary)}
.header-safe-switch--mobile,.safe-switch-short{display:none}

.site-header .brand img,.site-header.is-scrolled .brand img{width:auto !important;height:56px !important;max-height:56px !important;object-fit:contain;object-position:left center}
.mobile-menu-top img{width:min(58vw,220px);height:auto;max-width:none;object-fit:contain;object-position:left center}

.back-to-top{position:fixed;bottom:28px;right:28px;width:46px;height:46px;border-radius:50%;border:1px solid var(--line);background:#fff;color:var(--primary);box-shadow:0 10px 24px rgba(35,38,46,.12);display:grid;place-items:center;cursor:pointer;opacity:0;visibility:hidden;transform:translateY(12px);transition:opacity .3s,visibility .3s,transform .3s,box-shadow .3s;z-index:2040}
.back-to-top.is-visible{opacity:1;visibility:visible;transform:translateY(0)}
.back-to-top i{color:currentColor;font-size:18px;line-height:1}
.back-to-top:hover,.back-to-top:focus-visible{transform:translateY(0);box-shadow:0 14px 28px rgba(35,38,46,.16)}

@media (min-width:992px){
  .header-nav{gap:0;font-size:14px}
  .header-nav > a:not(.nav-cta){padding:0 11px}
  .header-nav .nav-cta{margin-left:8px;padding:0 18px !important}
}

@media (max-width:991px){
  .nav-safe-switch{display:none}
  .header-safe-switch--mobile{display:block;position:relative;margin-left:auto;margin-right:10px;z-index:90}
  .header-safe-switch--mobile summary{display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:40px;padding:0 14px;border:1px solid rgba(215,116,84,.28);border-radius:999px;background:rgba(215,116,84,.10);color:var(--primary);font-size:13px;font-weight:700;white-space:nowrap;cursor:pointer;list-style:none}
  .header-safe-switch--mobile summary::-webkit-details-marker{display:none}
  .header-safe-switch--mobile summary i{font-size:10px;transition:transform .2s}
  .header-safe-switch--mobile[open] summary i{transform:rotate(180deg)}
  .header-safe-switch-menu{position:absolute;top:calc(100% + 10px);left:50%;width:min(420px,calc(100vw - 16px));padding:8px;border:1px solid rgba(234,222,217,.96);border-radius:16px;background:#fff;box-shadow:0 18px 42px rgba(35,38,46,.18);transform:translateX(-50%)}
  .header-safe-switch-menu::before{content:"";position:absolute;top:-6px;left:50%;width:12px;height:12px;background:#fff;border-top:1px solid rgba(234,222,217,.96);border-left:1px solid rgba(234,222,217,.96);transform:translateX(-50%) rotate(45deg)}
  .header-safe-switch-menu a{display:flex;align-items:center;gap:12px;min-height:46px;padding:10px;border-radius:12px;color:var(--text)}
  .header-safe-switch-menu a:hover{background:var(--bg-alt);color:var(--primary)}
  .header-safe-switch-menu img{flex:0 0 150px;width:auto;height:24px;max-width:none;max-height:none;object-fit:contain;object-position:left center}
  .header-safe-switch-menu span{flex:1 1 auto;min-width:0;color:var(--muted);font-size:12.8px;font-weight:650;line-height:1.1;white-space:nowrap}
  .header-safe-switch-menu a:hover span{color:var(--primary)}
  .site-header .brand img,.site-header.is-scrolled .brand img{width:auto !important;height:42px !important;max-height:42px !important}
  .mobile-menu-top img{width:min(56vw,210px);height:auto;max-width:none;object-fit:contain;object-position:left center}
}

@media (max-width:560px){
  .header-safe-switch--mobile{margin-right:8px}
  .header-safe-switch--mobile summary{padding:0 12px}
}

@media (max-width:480px){
  .safe-switch-full{display:none}
  .safe-switch-short{display:inline}
  .header-safe-switch--mobile summary{min-width:72px;padding:0 12px}
  .header-safe-switch-menu{width:min(420px,calc(100vw - 16px))}
  .header-safe-switch-menu img{flex-basis:150px;height:24px;max-width:none}
  .header-safe-switch-menu span{font-size:12px}
}

@media (max-width:380px){
  .site-header .brand img,.site-header.is-scrolled .brand img{height:38px !important;max-height:38px !important}
  .header-safe-switch--mobile summary{min-width:68px;padding:0 10px;font-size:12px}
}

/* Safe Family consistency v1 — wspólny standard menu, switcha i hero */
:root{
  --safe-header-height-desktop: 82px;
  --safe-header-height-mobile: 68px;
  --safe-brand-height-desktop: 52px;
  --safe-brand-height-mobile: 40px;
  --safe-switch-logo-height-desktop: 26px;
  --safe-switch-logo-height-mobile: 24px;
  --safe-menu-font-size: 14px;
  --safe-menu-link-height: 42px;
  --safe-menu-link-x: 11px;
  --safe-switch-width-desktop: 430px;
  --safe-switch-width-mobile: min(420px, calc(100vw - 16px));
}
.site-header{
  min-height: var(--safe-header-height-desktop) !important;
  z-index: 5000 !important;
}
.header-inner{
  min-height: var(--safe-header-height-desktop) !important;
  gap: 16px !important;
}
.brand{
  display:flex !important;
  align-items:center !important;
  flex:0 0 auto !important;
}
.brand img,
.site-header .brand img,
.site-header.is-sticky .brand img,
.site-header.is-scrolled .brand img{
  display:block !important;
  width:auto !important;
  height:var(--safe-brand-height-desktop) !important;
  max-width:320px !important;
  max-height:var(--safe-brand-height-desktop) !important;
  object-fit:contain !important;
  object-position:left center !important;
}
.header-nav{
  display:flex !important;
  align-items:center !important;
  gap:0 !important;
  margin-left:auto !important;
  font-size:var(--safe-menu-font-size) !important;
  line-height:1.2 !important;
}
.header-nav > a:not(.nav-cta){
  display:inline-flex !important;
  align-items:center !important;
  min-height:var(--safe-menu-link-height) !important;
  padding:0 var(--safe-menu-link-x) !important;
  font-size:var(--safe-menu-font-size) !important;
  font-weight:600 !important;
  line-height:1.2 !important;
  white-space:nowrap !important;
}
.header-nav .nav-cta{
  display:inline-flex !important;
  align-items:center !important;
  min-height:var(--safe-menu-link-height) !important;
  margin-left:8px !important;
  padding:0 18px !important;
  font-size:var(--safe-menu-font-size) !important;
  font-weight:700 !important;
  line-height:1.2 !important;
  white-space:nowrap !important;
}
.nav-safe-switch{
  position:relative !important;
  margin-left:8px !important;
  z-index:5100 !important;
}
.nav-safe-switch summary{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:8px !important;
  min-height:var(--safe-menu-link-height) !important;
  padding:0 15px !important;
  font-size:var(--safe-menu-font-size) !important;
  font-weight:700 !important;
  line-height:1.2 !important;
  white-space:nowrap !important;
  list-style:none !important;
}
.nav-safe-switch summary::-webkit-details-marker,
.header-safe-switch--mobile summary::-webkit-details-marker{display:none !important;}
.nav-safe-switch-menu{
  position:absolute !important;
  top:calc(100% + 10px) !important;
  right:0 !important;
  width:var(--safe-switch-width-desktop) !important;
  padding:8px !important;
  border-radius:18px !important;
}
.header-nav .nav-safe-switch-menu a{
  display:flex !important;
  align-items:center !important;
  gap:14px !important;
  min-height:52px !important;
  padding:10px 12px !important;
  border-radius:12px !important;
  font-size:13.5px !important;
  line-height:1.2 !important;
}
.nav-safe-switch-menu img{
  flex:0 0 150px !important;
  width:auto !important;
  height:var(--safe-switch-logo-height-desktop) !important;
  max-width:none !important;
  max-height:none !important;
  object-fit:contain !important;
  object-position:left center !important;
}
.nav-safe-switch-menu span{
  flex:1 1 auto !important;
  min-width:0 !important;
  font-size:13.5px !important;
  font-weight:650 !important;
  line-height:1.2 !important;
  white-space:nowrap !important;
}
.header-safe-switch--mobile,
.safe-switch-short{display:none !important;}
.safe-switch-full{display:inline !important;}
.back-to-top{
  width:46px !important;
  height:46px !important;
  border-radius:50% !important;
  display:grid !important;
  place-items:center !important;
  background:#fff !important;
  color:var(--primary) !important;
  opacity:0;
  visibility:hidden;
  z-index:5200 !important;
}
.back-to-top.is-visible{opacity:1 !important;visibility:visible !important;}
.back-to-top i,
.back-to-top svg{display:block !important;color:currentColor !important;fill:currentColor !important;stroke:currentColor !important;width:18px !important;height:18px !important;font-size:18px !important;line-height:1 !important;}
.hero-dark,
.hero.section{
  scroll-margin-top:var(--safe-header-height-desktop) !important;
}
@media (min-width:1101px){
  .hero-dark{padding-top:104px !important;padding-bottom:72px !important;}
  .hero.section{padding-top:104px !important;padding-bottom:72px !important;}
  .hero-dark-inner,
  .hero-grid-with-visual{align-items:center !important;}
}
@media (max-width:1180px) and (min-width:1101px){
  :root{--safe-menu-link-x:9px;--safe-menu-font-size:13.5px;}
  .header-nav .nav-cta{padding-left:16px !important;padding-right:16px !important;}
  .nav-safe-switch summary{padding-left:12px !important;padding-right:12px !important;}
}
@media (max-width:1100px){
  .site-header{min-height:var(--safe-header-height-mobile) !important;}
  .header-inner{
    min-height:var(--safe-header-height-mobile) !important;
    justify-content:flex-start !important;
    gap:10px !important;
  }
  .header-nav{display:none !important;}
  .nav-safe-switch{display:none !important;}
  .brand{min-width:0 !important;}
  .brand img,
  .site-header .brand img,
  .site-header.is-sticky .brand img,
  .site-header.is-scrolled .brand img{
    height:var(--safe-brand-height-mobile) !important;
    max-height:var(--safe-brand-height-mobile) !important;
    max-width:min(40vw, 220px) !important;
  }
  .header-safe-switch--mobile{
    display:block !important;
    position:relative !important;
    flex:0 0 auto !important;
    margin-left:auto !important;
    margin-right:8px !important;
    z-index:5100 !important;
  }
  .header-safe-switch--mobile summary{
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important;
    gap:7px !important;
    min-height:38px !important;
    padding:0 12px !important;
    font-size:12.8px !important;
    font-weight:700 !important;
    line-height:1.2 !important;
    white-space:nowrap !important;
    list-style:none !important;
  }
  .header-safe-switch-menu{
    position:absolute !important;
    top:calc(100% + 10px) !important;
    left:50% !important;
    width:var(--safe-switch-width-mobile) !important;
    padding:8px !important;
    border-radius:16px !important;
    transform:translateX(-50%) !important;
  }
  .header-safe-switch-menu a{
    display:flex !important;
    align-items:center !important;
    gap:12px !important;
    min-height:48px !important;
    padding:10px !important;
    border-radius:12px !important;
    line-height:1.15 !important;
  }
  .header-safe-switch-menu img{
    flex:0 0 150px !important;
    width:auto !important;
    height:var(--safe-switch-logo-height-mobile) !important;
    max-width:none !important;
    max-height:none !important;
    object-fit:contain !important;
    object-position:left center !important;
  }
  .header-safe-switch-menu span{
    flex:1 1 auto !important;
    min-width:0 !important;
    font-size:12.5px !important;
    font-weight:650 !important;
    line-height:1.15 !important;
    white-space:nowrap !important;
  }
  .hamburger{
    display:flex !important;
    flex:0 0 42px !important;
    width:42px !important;
    height:42px !important;
    padding:9px !important;
  }
  .mobile-menu-top img{
    width:auto !important;
    height:34px !important;
    max-width:min(58vw, 230px) !important;
    object-fit:contain !important;
    object-position:left center !important;
  }
  .hero-dark,
  .hero.section{scroll-margin-top:var(--safe-header-height-mobile) !important;}
}
@media (max-width:480px){
  .brand img,
  .site-header .brand img,
  .site-header.is-sticky .brand img,
  .site-header.is-scrolled .brand img{
    height:38px !important;
    max-height:38px !important;
    max-width:34vw !important;
  }
  .header-safe-switch--mobile summary{
    min-height:36px !important;
    padding:0 10px !important;
    font-size:12px !important;
  }
  .header-safe-switch-menu{width:min(360px, calc(100vw - 16px)) !important;}
  .header-safe-switch-menu img{flex-basis:132px !important;height:23px !important;}
  .header-safe-switch-menu span{font-size:12px !important;}
}
@media (max-width:380px){
  .brand img,
  .site-header .brand img,
  .site-header.is-sticky .brand img,
  .site-header.is-scrolled .brand img{
    height:34px !important;
    max-height:34px !important;
    max-width:30vw !important;
  }
  .header-safe-switch--mobile summary{font-size:11.6px !important;padding:0 8px !important;}
  .header-safe-switch-menu img{flex-basis:122px !important;height:22px !important;}
}

/* Safe Family consistency v2 — wspólny pierwszy ekran: header + hero + pasek = 100% wysokości ekranu */
:root{
  --safe-header-height:82px;
  --safe-header-height-mobile:68px;
  --safe-hero-strip-height:88px;
  --safe-hero-strip-height-mobile:116px;
}

.site-header{
  height:var(--safe-header-height) !important;
  min-height:var(--safe-header-height) !important;
  max-height:var(--safe-header-height) !important;
  box-sizing:border-box !important;
  display:flex !important;
  align-items:center !important;
}

.site-header > .container,
.site-header .header-inner{
  min-height:100% !important;
  height:100% !important;
  display:flex !important;
  align-items:center !important;
}

.hero-dark,
.hero.section{
  min-height:calc(100svh - var(--safe-header-height) - var(--safe-hero-strip-height)) !important;
  box-sizing:border-box !important;
  display:flex !important;
  align-items:center !important;
  padding-top:clamp(34px, 4.8vh, 58px) !important;
  padding-bottom:clamp(34px, 4.8vh, 58px) !important;
}

.hero-dark-inner,
.hero-grid,
.hero-grid-with-visual{
  width:100% !important;
  align-items:center !important;
}

.hero-product-strip,
.stats-band.hero-product-strip{
  height:var(--safe-hero-strip-height) !important;
  min-height:var(--safe-hero-strip-height) !important;
  max-height:var(--safe-hero-strip-height) !important;
  box-sizing:border-box !important;
  display:flex !important;
  align-items:center !important;
  padding-top:0 !important;
  padding-bottom:0 !important;
  overflow:hidden !important;
}

.hero-product-strip-inner,
.stats-band-inner.hero-product-strip-inner{
  min-height:100% !important;
  height:100% !important;
  display:flex !important;
  align-items:center !important;
  box-sizing:border-box !important;
  padding-top:0 !important;
  padding-bottom:0 !important;
}

.hero-product-strip strong,
.hero-product-strip span{
  line-height:1.35 !important;
}

@supports (height:100dvh){
  .hero-dark,
  .hero.section{
    min-height:calc(100dvh - var(--safe-header-height) - var(--safe-hero-strip-height)) !important;
  }
}

@media (max-width:980px){
  .site-header{
    height:var(--safe-header-height-mobile) !important;
    min-height:var(--safe-header-height-mobile) !important;
    max-height:var(--safe-header-height-mobile) !important;
  }

  .hero-dark,
  .hero.section{
    min-height:calc(100svh - var(--safe-header-height-mobile) - var(--safe-hero-strip-height-mobile)) !important;
    padding-top:32px !important;
    padding-bottom:32px !important;
  }

  @supports (height:100dvh){
    .hero-dark,
    .hero.section{
      min-height:calc(100dvh - var(--safe-header-height-mobile) - var(--safe-hero-strip-height-mobile)) !important;
    }
  }

  .hero-product-strip,
  .stats-band.hero-product-strip{
    height:var(--safe-hero-strip-height-mobile) !important;
    min-height:var(--safe-hero-strip-height-mobile) !important;
    max-height:var(--safe-hero-strip-height-mobile) !important;
  }

  .hero-product-strip-inner,
  .stats-band-inner.hero-product-strip-inner{
    align-items:center !important;
    justify-content:center !important;
  }
}

@media (max-width:640px){
  :root{
    --safe-header-height-mobile:64px;
    --safe-hero-strip-height-mobile:128px;
  }

  .hero-dark,
  .hero.section{
    padding-top:28px !important;
    padding-bottom:28px !important;
  }

  .hero-product-strip-inner,
  .stats-band-inner.hero-product-strip-inner{
    justify-content:center !important;
  }
}

/* Safe Family consistency v3 — tylko wysokość, bez rozciągania szerokości */
.hero-dark-inner.container,
.hero-grid.container,
.hero-grid-with-visual.container{
  width:min(1440px, calc(100% - 64px)) !important;
  max-width:1440px !important;
  margin-left:auto !important;
  margin-right:auto !important;
}

@media (max-width:860px){
  .hero-dark-inner.container,
  .hero-grid.container,
  .hero-grid-with-visual.container{
    width:min(1440px, calc(100% - 32px)) !important;
  }
}

@media (max-width:480px){
  .hero-dark-inner.container,
  .hero-grid.container,
  .hero-grid-with-visual.container{
    width:min(1440px, calc(100% - 24px)) !important;
  }
}
