:root{
  --navy:#061633;
  --navy-2:#0d244f;
  --blue:#1458ff;
  --gold:#1458ff;
  --gold-2:#4f8cff;
  --cream:#fbf8f1;
  --cream-2:#f5efe2;
  --line:#e8dfd0;
  --text:#132344;
  --muted:#5c6a82;
  --green:#48a75e;
  --shadow:0 18px 50px rgba(7,22,51,.10);
  --shadow-soft:0 8px 26px rgba(7,22,51,.075);
  --radius:18px;
  --heading-font:"Manrope",Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  color:var(--text);
  background:
    radial-gradient(circle at 8% 4%,rgba(20,88,255,.10),transparent 26%),
    radial-gradient(circle at 70% 10%,rgba(19,88,255,.06),transparent 26%),
    linear-gradient(180deg,#fff 0%,#fbf8f1 57%,#fff 100%);
  font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  -webkit-font-smoothing:antialiased;
}

a{color:inherit;text-decoration:none}
button,a{font:inherit}
.container{width:min(1180px,calc(100% - 86px));margin:0 auto}

.topbar{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.86);
  border-bottom:1px solid rgba(10,27,61,.08);
  backdrop-filter:blur(16px);
}
.topbar__inner{height:70px;display:grid;grid-template-columns:210px 1fr auto;align-items:center;gap:28px}
.brand{display:flex;align-items:center;width:178px;height:48px;overflow:hidden}
.brand img{width:176px;height:auto;display:block;transform:translateY(1px)}
.nav{display:flex;justify-content:center;gap:48px;font-weight:700;color:#101d3b;font-size:15px;letter-spacing:-.01em}
.nav a{padding:25px 0;transition:.22s ease}
.nav a:hover{color:var(--blue)}
.topbar__cta{justify-self:end;display:inline-flex;align-items:center;gap:10px;padding:13px 21px;background:linear-gradient(180deg,var(--gold-2),var(--gold));color:#fff;border-radius:7px;font-weight:800;box-shadow:0 8px 18px rgba(20,88,255,.24);font-size:14px}
.topbar__cta:hover{filter:brightness(1.04);transform:translateY(-1px)}
.menu-btn{display:none;justify-self:end;width:44px;height:40px;border:1px solid var(--line);background:#fff;border-radius:10px;align-items:center;justify-content:center;flex-direction:column;gap:5px;cursor:pointer}
.menu-btn span{display:block;width:19px;height:2px;background:var(--navy);border-radius:2px}
.mobile-menu{display:none}

.ico{display:inline-block;position:relative;width:18px;height:18px;flex:0 0 auto}
.ico--calendar::before{content:"";position:absolute;inset:2px;border:2px solid currentColor;border-radius:3px}.ico--calendar::after{content:"";position:absolute;left:4px;right:4px;top:7px;border-top:2px solid currentColor;box-shadow:2px -4px 0 -1px currentColor,-2px -4px 0 -1px currentColor}
.ico--shield::before{content:"";position:absolute;inset:1px 3px 1px 3px;border:2px solid currentColor;border-radius:8px 8px 10px 10px;clip-path:polygon(0 0,100% 0,100% 62%,50% 100%,0 62%)}
.ico--headset::before{content:"";position:absolute;left:3px;top:2px;width:12px;height:10px;border:2px solid currentColor;border-bottom:0;border-radius:12px 12px 0 0}.ico--headset::after{content:"";position:absolute;left:2px;bottom:2px;width:14px;height:8px;border-left:3px solid currentColor;border-right:3px solid currentColor;border-radius:2px}

.section-shell{position:relative;overflow:hidden}
.hero{border-bottom:1px solid rgba(14,34,72,.08)}
.hero__grid{min-height:565px;display:grid;grid-template-columns:43% 57%;align-items:center;gap:28px;padding:47px 0 42px}
.eyebrow{display:inline-flex;align-items:center;gap:10px;padding:9px 14px;border-radius:999px;background:#eef4ff;color:#1458ff;font-size:13px;font-weight:800;letter-spacing:.04em;margin-bottom:25px}
.hero h1{font-family:var(--heading-font);font-size:52px;line-height:1.10;letter-spacing:-.045em;color:var(--navy);margin:0 0 22px;font-weight:800}
.hero h1 span{color:#1458ff;display:inline-block}
.hero__lead{font-size:18px;line-height:1.62;color:#31405e;margin:0 0 28px;max-width:472px;font-weight:500}
.hero__actions{display:flex;gap:18px;align-items:center;margin-bottom:31px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;border-radius:7px;min-height:55px;padding:0 27px;font-weight:800;transition:.2s ease;border:1px solid transparent}
.btn--primary{background:var(--navy);color:#fff;box-shadow:0 12px 24px rgba(7,22,51,.16)}
.btn--primary:hover{background:#0b2149;transform:translateY(-1px)}
.btn--ghost{background:#fff;color:#112040;border-color:#d8deea;box-shadow:0 6px 18px rgba(10,27,61,.04)}
.btn--ghost:hover{border-color:#c0c9da;transform:translateY(-1px)}
.hero__mini{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:470px}
.hero__mini div{display:grid;grid-template-columns:25px 1fr;column-gap:9px;align-items:center;color:#1f2d4d;font-size:12px;font-weight:800}
.hero__mini small{grid-column:2;color:#68758d;font-weight:700;margin-top:2px;font-size:11px}.mini-ico{grid-row:1/3;display:grid;place-items:center;color:#1458ff;font-size:10px;font-weight:900;width:24px;height:24px;border:1px solid #bcd0ff;background:#eef4ff;border-radius:50%}.mini-ico--shield::before{content:"◇"}.mini-ico--hand::before{content:"↻"}

.hero__visual{position:relative;min-height:490px;}
.dots-pattern{position:absolute;left:2%;top:40%;width:340px;height:160px;background-image:radial-gradient(rgba(20,88,255,.36) 1px,transparent 1px);background-size:12px 12px;opacity:.55;mask-image:radial-gradient(circle,black 20%,transparent 70%)}
.browser-card{position:absolute;right:78px;top:34px;width:586px;background:#fff;border:1px solid #cfd5dd;border-radius:18px;box-shadow:var(--shadow);overflow:hidden;z-index:3}
.browser-card__bar{height:49px;background:#f5f6f8;border-bottom:1px solid #d8dde7;display:flex;align-items:center;gap:16px;padding:0 16px}
.window-dots{display:flex;gap:9px}.window-dots span{width:9px;height:9px;border-radius:50%}.window-dots span:nth-child(1){background:#e1584b}.window-dots span:nth-child(2){background:#dba03b}.window-dots span:nth-child(3){background:#48a65f}.browser-arrows{font-size:26px;line-height:0;color:#9aa5b6;letter-spacing:7px}.url{background:#fff;border:1px solid #e1e5ed;border-radius:7px;height:27px;display:flex;align-items:center;justify-content:center;min-width:200px;color:#2c3953;font-weight:700;font-size:13px;box-shadow:inset 0 1px 2px rgba(0,0,0,.03)}
.site-preview{height:350px;position:relative;overflow:hidden;background:linear-gradient(150deg,#1a355b 0%,#6e8aa4 50%,#dee2d8 100%)}
.site-preview::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(6,20,45,.64),rgba(6,20,45,.06) 65%,rgba(6,20,45,.55)),linear-gradient(180deg,rgba(255,255,255,.04),rgba(6,20,45,.55));z-index:1}.site-preview__nav{position:absolute;right:45px;top:28px;z-index:4;display:flex;gap:23px;color:#fff;font-size:12px;font-weight:700;opacity:.93}.site-preview__content{position:absolute;left:67px;top:113px;z-index:4;color:#fff}.site-preview__content h2{font-size:30px;line-height:1.23;font-weight:500;letter-spacing:-.03em;margin:0 0 28px}.site-preview__content button{background:#fff;color:#1f2c43;border:0;border-radius:4px;padding:13px 26px;font-weight:800;font-size:12px}.mountains{position:absolute;inset:0;background:
  linear-gradient(172deg,transparent 48%,rgba(20,43,67,.74) 48.3%,rgba(20,43,67,.74) 52%,transparent 52.3%) 75% 58%/380px 170px no-repeat,
  linear-gradient(143deg,transparent 49%,rgba(31,64,94,.84) 49.5%,rgba(31,64,94,.84) 54%,transparent 54.5%) 45% 62%/470px 220px no-repeat,
  linear-gradient(165deg,transparent 46%,rgba(214,223,230,.66) 46.5%,rgba(214,223,230,.66) 52%,transparent 52.5%) 63% 48%/330px 160px no-repeat,
  radial-gradient(ellipse at 50% 74%,#80a6bf 0%,#31577f 18%,transparent 39%),
  linear-gradient(180deg,#274a73 0%,#99b3bf 54%,#17304c 100%);opacity:.9;filter:saturate(1.1)}
.help-badge{position:absolute;right:189px;top:2px;width:88px;height:88px;border-radius:50%;background:linear-gradient(180deg,#4f8cff,#1458ff);color:#fff;display:flex;align-items:center;justify-content:center;flex-direction:column;font-size:11px;font-weight:800;text-align:center;box-shadow:0 11px 24px rgba(20,88,255,.30),inset 0 0 0 3px rgba(255,255,255,.23);z-index:6}.help-badge .ico{width:25px;height:25px;margin-bottom:4px}
.status-list{position:absolute;right:12px;top:86px;width:198px;display:flex;flex-direction:column;gap:9px;z-index:7}.status-card{height:63px;background:#fff;border:1px solid #e2e6ef;border-radius:9px;display:flex;align-items:center;gap:13px;padding:0 14px;box-shadow:0 7px 18px rgba(7,22,51,.1);position:relative}.status-card strong{display:block;color:#102345;font-size:13px;line-height:1}.status-card small{font-size:10px;color:#69758b;font-weight:700}.status-card b{position:absolute;right:12px;top:25px;width:13px;height:13px;background:#dff3e4;border-radius:50%}.status-card b::after{content:"✓";position:absolute;inset:0;text-align:center;line-height:13px;color:#349852;font-size:9px;font-weight:900}.status-card i{position:absolute;right:13px;bottom:16px;width:55px;height:14px;background:repeating-linear-gradient(90deg,#48a75e 0 4px,transparent 4px 8px);clip-path:polygon(0 65%,100% 20%,100% 100%,0 100%)}.status-card em{position:absolute;right:12px;bottom:17px;width:35px;height:22px;border-right:2px solid #43a95c;border-top:2px solid #43a95c;transform:skewY(-24deg)}.status-icon{width:34px;height:34px;border-radius:50%;background:#eef4ff;position:relative;flex:0 0 auto}.status-icon::after{position:absolute;inset:0;display:grid;place-items:center;color:#2868ff;font-weight:900}.refresh::after{content:"↻"}.shield::after{content:"◇"}.speed::after{content:"◔"}.search::after{content:"⌕"}.tools::after{content:"✕"}
.floating-card{position:absolute;background:#fff;border:1px solid #e1e6ef;border-radius:9px;box-shadow:0 12px 24px rgba(7,22,51,.12);z-index:8;color:#102346}.floating-card strong{display:block;font-size:12px;margin-bottom:7px}.floating-card--traffic{left:3px;bottom:57px;width:178px;height:102px;padding:15px}.floating-card--traffic div{display:flex;gap:11px;align-items:baseline}.floating-card--traffic span{font-size:25px;font-weight:800;letter-spacing:-.03em}.floating-card--traffic small{font-size:11px;color:#2c9e55;font-weight:900}.floating-card--traffic svg{width:100%;height:43px}.floating-card--traffic path{fill:none;stroke:#2868ff;stroke-width:3;stroke-linecap:round}.floating-card--state{left:195px;bottom:49px;width:151px;height:111px;padding:17px}.floating-card--state p{color:#2d9652;font-size:12px;font-weight:900;margin:6px 0 19px}.floating-card--state p span{display:inline-grid;place-items:center;width:20px;height:20px;border-radius:50%;background:#2d9652;color:#fff;margin-right:7px}.floating-card--state small{font-size:12px;font-weight:700;color:#6e7789}.floating-card--speed{left:358px;bottom:42px;width:145px;height:116px;padding:18px}.floating-card--speed>span{font-size:25px;font-weight:800}.gauge{width:83px;height:45px;margin:11px auto 0;border:11px solid #e6edf1;border-bottom:0;border-radius:90px 90px 0 0;position:relative;overflow:hidden}.gauge::before{content:"";position:absolute;inset:-11px;border:11px solid #48a75e;border-bottom:0;border-radius:90px 90px 0 0;clip-path:polygon(0 0,76% 0,76% 100%,0 100%)}.gauge i{position:absolute;left:36px;bottom:-3px;width:3px;height:37px;background:#152343;transform:rotate(39deg);transform-origin:bottom}

.services,.pricing,.benefits,.final-cta{padding:24px 0;border-bottom:1px solid rgba(14,34,72,.06)}
.section-title{font-family:var(--heading-font);color:var(--navy);font-size:28px;letter-spacing:-.035em;text-align:center;margin:0 0 21px;font-weight:800}
.services__grid{display:grid;grid-template-columns:repeat(6,1fr);gap:26px}.service-card{min-height:190px;border:1px solid #e6e1d7;background:rgba(255,255,255,.75);border-radius:8px;box-shadow:var(--shadow-soft);padding:21px 14px;text-align:center;transition:.2s ease}.service-card:hover{transform:translateY(-4px);box-shadow:0 16px 34px rgba(7,22,51,.11)}.service-card h3{margin:9px 0 12px;color:#172748;font-size:16px;line-height:1.18}.service-card p{margin:0;color:#5e6b82;font-size:12px;line-height:1.65;font-weight:600}.service-icon{display:block;width:64px;height:54px;margin:0 auto 11px;position:relative;color:#102655}.service-icon::before,.service-icon::after{position:absolute;content:""}.monitor::before{inset:4px 8px 13px;border:4px solid currentColor;border-radius:4px;background:#f3f8ff}.monitor::after{right:2px;bottom:4px;width:24px;height:24px;border-radius:50%;background:#cdd8e7;box-shadow:inset 0 0 0 4px currentColor}.code::before{content:"‹ / ›";inset:10px 0 auto;display:grid;place-items:center;height:34px;background:#f0f5ff;border-radius:6px;color:currentColor;font-size:29px;font-weight:900}.seo::before{left:8px;top:4px;width:34px;height:34px;border:4px solid currentColor;border-radius:50%}.seo::after{left:39px;top:35px;width:22px;height:5px;background:currentColor;transform:rotate(45deg);border-radius:8px}.backup::before{left:3px;top:6px;width:35px;height:39px;background:#15305d;clip-path:polygon(50% 0,100% 18%,100% 70%,50% 100%,0 70%,0 18%)}.backup::after{right:4px;top:18px;width:25px;height:29px;border-radius:50%/12%;border:3px solid #99a8bd;background:#ecf2fb}.meter::before{left:4px;right:4px;bottom:5px;height:38px;border:4px solid currentColor;border-bottom:0;border-radius:70px 70px 0 0}.meter::after{left:31px;bottom:2px;width:4px;height:33px;background:currentColor;transform:rotate(42deg);transform-origin:bottom}.headset::before{left:10px;top:1px;width:44px;height:37px;border:4px solid currentColor;border-bottom:0;border-radius:35px 35px 0 0}.headset::after{left:4px;top:31px;width:56px;height:18px;border-left:7px solid currentColor;border-right:7px solid currentColor;border-radius:4px}

.pricing{padding-top:20px}.pricing__grid{display:grid;grid-template-columns:1.12fr 1.18fr 1.12fr .78fr;gap:24px;align-items:stretch}.price-card,.custom-card{position:relative;background:rgba(255,255,255,.74);border:1px solid #e5decf;border-radius:9px;box-shadow:0 6px 20px rgba(7,22,51,.045);padding:22px 18px 18px;min-height:276px}.price-head{display:flex;align-items:center;gap:13px}.price-head h3{font-family:var(--heading-font);color:var(--navy);font-size:25px;letter-spacing:-.035em;margin:0;font-weight:800}.price-head span{font-size:12px;font-weight:800;color:#738098;background:#f4f6fa;border-radius:6px;padding:6px 10px}.price-card p{color:#536178;font-weight:600;font-size:13px;margin:7px 0 14px}.price{display:flex;align-items:baseline;gap:7px;color:#21314f;font-weight:700;margin-bottom:19px}.price strong{font-size:31px;color:#071a3c;letter-spacing:-.04em}.price small{font-size:14px;color:#3d4960}.price-card ul{list-style:none;margin:0 0 18px;padding:0;display:grid;gap:11px}.price-card li{font-size:12px;font-weight:700;color:#40506d;display:flex;align-items:flex-start;gap:9px}.price-card li::before{content:"";width:13px;height:13px;border-radius:50%;border:2px solid #3975ff;flex:0 0 auto;margin-top:1px;background:radial-gradient(circle at 50% 50%,#3975ff 0 2px,transparent 2px)}.price-card--featured{padding-top:36px;border-color:#bdd0ff}.price-card--featured li::before{border-color:#1458ff;background:radial-gradient(circle at 50% 50%,#1458ff 0 2px,transparent 2px)}.popular{position:absolute;left:-1px;right:-1px;top:-1px;height:33px;background:var(--navy);color:#fff;border-radius:9px 9px 0 0;text-align:center;font-size:12px;font-weight:800;line-height:33px}.popular span{color:#7fb0ff}.price-btn{display:flex;align-items:center;justify-content:center;height:36px;border-radius:6px;font-size:13px;font-weight:900;border:1px solid #cfd6e3}.price-btn--ghost{background:#fff;color:#112241}.price-btn--gold{background:linear-gradient(180deg,#4f8cff,#1458ff);color:#fff;border-color:#1458ff;box-shadow:0 8px 20px rgba(20,88,255,.24)}.custom-card{background:linear-gradient(150deg,#fff,#f1f6ff);display:flex;flex-direction:column;justify-content:center;padding:30px}.rocket{width:64px;height:64px;border:1px solid #cbdcff;border-radius:50%;display:grid;place-items:center;color:var(--navy);font-size:42px;margin:0 auto 18px;transform:rotate(-35deg)}.custom-card h3{margin:0 0 17px;color:var(--navy);line-height:1.3;font-size:17px}.custom-card p{font-size:13px;line-height:1.6;color:#5b6880;margin:0 0 26px;font-weight:700}.custom-card a{height:45px;border-radius:6px;background:linear-gradient(180deg,#4f8cff,#1458ff);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:900}

.benefits{padding-top:8px;padding-bottom:25px}.benefits__grid{display:grid;grid-template-columns:230px 1fr 300px;gap:27px;align-items:start}.gain-list h2{font-family:var(--heading-font);color:var(--navy);font-size:24px;letter-spacing:-.035em;margin:0 0 17px;font-weight:800}.gain-list ul{list-style:none;margin:0;padding:0;display:grid;gap:13px}.gain-list li{font-size:13px;font-weight:700;color:#485774;display:flex;gap:10px;align-items:center}.gain-list li::before{content:"✓";display:grid;place-items:center;width:15px;height:15px;border:1px solid #1458ff;color:#1458ff;border-radius:50%;font-size:10px;flex:0 0 auto}.metrics-panel{background:rgba(255,255,255,.76);border:1px solid #e8e1d5;border-radius:10px;box-shadow:0 8px 23px rgba(7,22,51,.055);overflow:hidden}.metrics-row{display:grid;grid-template-columns:repeat(4,1fr)}.metric{min-height:126px;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;border-right:1px solid #e8edf4}.metric:last-child{border-right:0}.metric span{color:#1c4b9b;font-size:24px;margin-bottom:7px}.metric strong{font-size:26px;color:#123061;letter-spacing:-.03em;margin-bottom:3px}.metric small{font-size:12px;color:#53617b;font-weight:700;line-height:1.25}.badges{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid #e8edf4}.badges span{min-height:54px;display:grid;align-content:center;justify-content:center;text-align:left;border-right:1px solid #e8edf4;padding-left:36px;position:relative}.badges span:last-child{border-right:0}.badges span::before{content:"";position:absolute;left:17px;top:18px;width:23px;height:23px;border-radius:50%;background:#eef4ff;box-shadow:inset 0 0 0 1px #cbdcff}.badges b{color:#0e2c5d;font-size:11px}.badges small{color:#60708b;font-size:9px;font-weight:700}.testimonial{margin:0;min-height:190px;background:rgba(255,255,255,.76);border:1px solid #e8e1d5;border-radius:10px;box-shadow:0 8px 23px rgba(7,22,51,.055);padding:22px 24px;color:#233352}.testimonial>span{font-size:50px;line-height:.6;color:#2766ca;font-family:Georgia,serif;font-weight:700}.testimonial p{font-size:13px;line-height:1.58;font-weight:600;color:#4d5b74;margin:5px 0 13px}.stars{color:#1458ff;letter-spacing:3px;font-size:14px;margin-bottom:9px}.testimonial cite{font-style:normal;font-size:13px;color:#15315e;font-weight:900}.testimonial small{font-size:12px;color:#56647e;font-weight:700}

.final-cta{padding:14px 0 28px;border-bottom:0}.final-cta__box{min-height:80px;background:linear-gradient(90deg,#f1f6ff,#fff);border:1px solid #cbdcff;border-radius:9px;display:grid;grid-template-columns:82px 1fr auto;align-items:center;gap:18px;padding:0 28px 0 41px;box-shadow:0 10px 25px rgba(7,22,51,.045)}.final-cta__icon{width:56px;height:56px;border-radius:50%;background:#e7f0ff;display:grid;place-items:center;color:#0d254d}.final-cta h2{font-family:var(--heading-font);margin:0 0 3px;color:var(--navy);font-size:23px;letter-spacing:-.035em;font-weight:800}.final-cta p{margin:0;color:#53637c;font-size:13px;font-weight:600}.final-cta .btn{min-height:48px;min-width:202px}

@media (max-width:1120px){
  .container{width:min(100% - 40px,1180px)}
  .topbar__inner{grid-template-columns:180px 1fr auto}.nav{gap:26px}.brand{width:160px}.brand img{width:160px}
  .hero__grid{grid-template-columns:1fr;min-height:0;padding-top:38px}.hero__visual{min-height:520px}.browser-card{left:0;right:auto}.status-list{right:0}.help-badge{right:188px}.services__grid{grid-template-columns:repeat(3,1fr)}.pricing__grid{grid-template-columns:repeat(2,1fr)}.benefits__grid{grid-template-columns:1fr}.gain-list ul{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:760px){
  .container{width:min(100% - 26px,1180px)}
  .topbar__inner{height:66px;grid-template-columns:155px 1fr}.brand,.brand img{width:148px}.nav,.topbar__cta{display:none}.menu-btn{display:flex}.mobile-menu{background:#fff;border-bottom:1px solid var(--line);padding:13px;display:grid;gap:8px}.mobile-menu[hidden]{display:none}.mobile-menu a{padding:12px 13px;border-radius:10px;font-weight:800;color:var(--navy);background:#f5f8ff}.mobile-menu__cta{background:linear-gradient(180deg,#4f8cff,#1458ff)!important;color:#fff!important;text-align:center}
  .hero__grid{padding:30px 0}.hero h1{font-size:40px}.hero__lead{font-size:15px}.hero__actions{flex-direction:column;align-items:stretch}.btn{width:100%}.hero__mini{grid-template-columns:1fr}.hero__visual{min-height:700px;transform:scale(.86);transform-origin:top left;width:116%}.browser-card{width:580px}.status-list{left:390px;right:auto}.floating-card--traffic{bottom:115px}.floating-card--state{bottom:110px}.floating-card--speed{bottom:107px}.services__grid,.pricing__grid{grid-template-columns:1fr}.benefits__grid{gap:16px}.gain-list ul{grid-template-columns:1fr}.metrics-row,.badges{grid-template-columns:repeat(2,1fr)}.metric:nth-child(2){border-right:0}.badges span:nth-child(2){border-right:0}.final-cta__box{grid-template-columns:1fr;text-align:center;padding:24px;justify-items:center}.final-cta__icon{margin:auto}
}
@media (max-width:520px){
  .hero__visual{transform:scale(.68);width:147%;min-height:555px}.browser-card{width:560px}.status-list{left:372px}.hero h1{font-size:36px}.section-title{font-size:25px}.metrics-row,.badges{grid-template-columns:1fr}.metric,.badges span{border-right:0;border-bottom:1px solid #e8edf4}.badges span{text-align:center;padding-left:0}.badges span::before{display:none}
}


/* Hero graphic replaced with the provided WebUply visual */
.hero__visual--image{
  min-height:490px;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:visible;
}
.hero-panel-image{
  width:min(760px,112%);
  height:auto;
  display:block;
  transform:translate(24px, 2px);
  filter:drop-shadow(0 18px 32px rgba(7,22,51,.10));
  user-select:none;
  pointer-events:none;
}

@media (max-width:1120px){
  .hero__visual--image{min-height:auto; padding:12px 0 20px;}
  .hero-panel-image{width:min(100%,860px); transform:none; margin:0 auto;}
}
@media (max-width:760px){
  .hero__visual--image{transform:none; width:100%; min-height:auto; padding:8px 0 12px;}
  .hero-panel-image{width:120%; max-width:none; transform:translateX(-5%);}
}
@media (max-width:520px){
  .hero__visual--image{transform:none; width:100%; min-height:auto;}
  .hero-panel-image{width:135%; transform:translateX(-11%);}
}


/* Contact form above services */
.contact-intake{
  padding:22px 0 28px;
  background:
    radial-gradient(circle at 15% 30%, rgba(20,88,255,.08), transparent 28%),
    linear-gradient(180deg, rgba(255,255,255,.2), rgba(245,248,255,.44));
  border-top:1px solid rgba(203,220,255,.55);
  border-bottom:1px solid rgba(203,220,255,.55);
}
.contact-intake__grid{
  display:grid;
  grid-template-columns:.82fr 1.18fr;
  gap:28px;
  align-items:stretch;
}
.contact-intake__copy{
  background:linear-gradient(145deg,#ffffff,#f3f7ff);
  border:1px solid #cbdcff;
  border-radius:14px;
  box-shadow:0 12px 34px rgba(7,22,51,.07);
  padding:30px 30px 28px;
  position:relative;
  overflow:hidden;
}
.contact-intake__copy::after{
  content:"";
  position:absolute;
  right:-42px;
  top:-42px;
  width:160px;
  height:160px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(20,88,255,.16), transparent 68%);
}
.eyebrow--blue{
  background:#eef4ff;
  color:#1458ff;
  border:1px solid #cbdcff;
}
.contact-intake h2{
  font-family:var(--heading-font);
  font-size:34px;
  line-height:1.14;
  color:var(--navy);
  letter-spacing:-.04em;
  font-weight:800;
  margin:18px 0 14px;
  max-width:460px;
}
.contact-intake__copy p{
  color:#53637c;
  font-size:15px;
  line-height:1.72;
  font-weight:600;
  margin:0 0 24px;
  max-width:510px;
}
.contact-intake__points{
  display:grid;
  gap:10px;
}
.contact-intake__points span{
  display:flex;
  align-items:center;
  gap:10px;
  color:#223657;
  font-size:13px;
  font-weight:900;
}
.contact-intake__points span::before{
  content:"✓";
  width:20px;
  height:20px;
  display:grid;
  place-items:center;
  border-radius:50%;
  color:#fff;
  background:linear-gradient(180deg,#4f8cff,#1458ff);
  box-shadow:0 6px 14px rgba(20,88,255,.22);
  font-size:12px;
  flex:0 0 auto;
}
.contact-form{
  background:rgba(255,255,255,.86);
  border:1px solid #cbdcff;
  border-radius:14px;
  box-shadow:0 14px 38px rgba(7,22,51,.08);
  padding:24px;
  display:grid;
  gap:15px;
}
.form-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:15px;
}
.contact-form label{
  display:grid;
  gap:8px;
  color:#132344;
  font-size:12px;
  font-weight:900;
  letter-spacing:.01em;
}
.contact-form input,
.contact-form select,
.contact-form textarea{
  width:100%;
  border:1px solid #d6e2ff;
  background:#fbfdff;
  color:#10234a;
  border-radius:10px;
  padding:13px 14px;
  font:600 14px/1.2 "Inter",system-ui,sans-serif;
  outline:none;
  transition:border-color .2s ease, box-shadow .2s ease, background .2s ease;
}
.contact-form textarea{
  resize:vertical;
  min-height:112px;
}
.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus{
  border-color:#1458ff;
  background:#fff;
  box-shadow:0 0 0 4px rgba(20,88,255,.12);
}
.contact-form__bottom{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding-top:2px;
}
.contact-form__bottom p{
  margin:0;
  color:#5d6f8d;
  font-size:13px;
  font-weight:800;
}
.contact-form__bottom .btn{
  min-width:210px;
  min-height:48px;
  border:0;
  cursor:pointer;
}
.form-success{
  border:1px solid rgba(20,88,255,.25);
  background:#eef4ff;
  color:#123061;
  border-radius:10px;
  padding:12px 14px;
  font-size:13px;
  font-weight:800;
}
.contact-intake__copy,
.contact-form{
  opacity:0;
  transform:translateY(14px);
  transition:opacity .55s ease, transform .55s ease;
}
.contact-intake__copy.is-visible,
.contact-form.is-visible{
  opacity:1;
  transform:translateY(0);
}

@media (max-width:1120px){
  .contact-intake__grid{grid-template-columns:1fr;}
  .contact-intake h2{max-width:none;}
}
@media (max-width:760px){
  .contact-intake{padding:18px 0 22px;}
  .contact-intake__copy,.contact-form{padding:20px;border-radius:12px;}
  .contact-intake h2{font-size:30px;}
  .form-row{grid-template-columns:1fr;}
  .contact-form__bottom{flex-direction:column;align-items:stretch;}
  .contact-form__bottom .btn{width:100%;}
}

/* Work process section under consultation */
.work-process{
  padding:24px 0 30px;
  background:
    radial-gradient(circle at 78% 8%, rgba(20,88,255,.09), transparent 26%),
    linear-gradient(180deg, rgba(255,255,255,.74), rgba(241,246,255,.56));
  border-bottom:1px solid rgba(203,220,255,.55);
}
.work-process__shell{
  background:linear-gradient(135deg,rgba(255,255,255,.92),rgba(245,249,255,.90));
  border:1px solid #cbdcff;
  border-radius:16px;
  box-shadow:0 16px 42px rgba(7,22,51,.075);
  padding:28px;
  position:relative;
  overflow:hidden;
}
.work-process__shell::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:radial-gradient(rgba(20,88,255,.18) 1px, transparent 1px);
  background-size:14px 14px;
  opacity:.28;
  mask-image:radial-gradient(circle at 88% 12%, black 0 16%, transparent 42%);
  pointer-events:none;
}
.work-process__head{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:.92fr 1.08fr;
  gap:28px;
  align-items:end;
  margin-bottom:22px;
}
.work-process__head .eyebrow{margin-bottom:14px;justify-self:start;grid-column:1/2;}
.work-process__head h2{
  font-family:var(--heading-font);
  color:var(--navy);
  font-size:32px;
  line-height:1.14;
  letter-spacing:-.04em;
  font-weight:800;
  margin:0;
  grid-column:1/2;
}
.work-process__head p{
  color:#53637c;
  font-size:15px;
  line-height:1.7;
  font-weight:650;
  margin:0;
  max-width:610px;
  grid-column:2/3;
  grid-row:1/3;
}
.work-process__grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:15px;
}
.process-card{
  position:relative;
  min-height:225px;
  background:rgba(255,255,255,.86);
  border:1px solid #d6e2ff;
  border-radius:14px;
  padding:22px 18px 20px;
  box-shadow:0 10px 28px rgba(7,22,51,.06);
  overflow:hidden;
  opacity:0;
  transform:translateY(14px);
  transition:opacity .55s ease, transform .55s ease, border-color .22s ease, box-shadow .22s ease;
}
.process-card.is-visible{
  opacity:1;
  transform:translateY(0);
}
.process-card:hover{
  border-color:#9bbaff;
  box-shadow:0 16px 34px rgba(20,88,255,.11);
  transform:translateY(-3px);
}
.process-card--featured{
  background:linear-gradient(180deg,#ffffff,#edf4ff);
  border-color:#9bbaff;
}
.process-card__number{
  position:absolute;
  right:15px;
  top:12px;
  color:rgba(20,88,255,.13);
  font-size:42px;
  font-weight:900;
  letter-spacing:-.06em;
}
.process-card__icon{
  width:44px;
  height:44px;
  display:grid;
  place-items:center;
  border-radius:13px;
  background:linear-gradient(180deg,#4f8cff,#1458ff);
  color:#fff;
  font-weight:900;
  box-shadow:0 10px 22px rgba(20,88,255,.22);
  margin-bottom:16px;
}
.process-card h3{
  margin:0 0 10px;
  color:#10254b;
  font-size:18px;
  line-height:1.18;
  letter-spacing:-.02em;
}
.process-card p{
  margin:0;
  color:#53637c;
  font-size:13px;
  line-height:1.62;
  font-weight:650;
}
@media (max-width:1120px){
  .work-process__head{grid-template-columns:1fr;gap:12px;align-items:start;}
  .work-process__head .eyebrow,.work-process__head h2,.work-process__head p{grid-column:auto;grid-row:auto;}
  .work-process__grid{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:760px){
  .work-process{padding:18px 0 22px;}
  .work-process__shell{padding:20px;border-radius:12px;}
  .work-process__head h2{font-size:29px;}
  .work-process__grid{grid-template-columns:1fr;}
  .process-card{min-height:auto;}
}


/* Simple, friendlier heading style update */
.service-card h3,
.process-card h3,
.custom-card h3,
.price-card h3,
.gain-list h2,
.final-cta h2,
.contact-intake h2,
.work-process__head h2,
.section-title,
.hero h1{
  font-family:var(--heading-font);
}
.service-card h3,
.process-card h3,
.custom-card h3{
  letter-spacing:-.025em;
  font-weight:800;
}
.hero h1 span{
  letter-spacing:-.045em;
}


/* v-next: hero quick-benefit row removed and pricing moved directly under process */
.hero__actions{margin-bottom:0;}
.work-process{padding-bottom:22px;}
.pricing{padding-top:16px;}


/* v-next: smoother section transitions + real anchor navigation polish */
.hero,
.contact-intake,
.work-process,
.pricing,
.services,
.benefits,
.final-cta,
.service-card#seo{
  scroll-margin-top:96px;
}

main > section{
  position:relative;
  isolation:isolate;
}
main > section > .container{
  position:relative;
  z-index:2;
}
main > section + section::before{
  content:"";
  position:absolute;
  left:50%;
  top:-26px;
  width:min(860px, calc(100% - 58px));
  height:52px;
  transform:translateX(-50%);
  border-radius:999px;
  background:
    radial-gradient(circle at 50% 50%, rgba(20,88,255,.15), transparent 58%),
    linear-gradient(90deg, transparent, rgba(203,220,255,.78), transparent);
  opacity:.78;
  pointer-events:none;
  z-index:0;
}
main > section + section::after{
  content:"";
  position:absolute;
  left:50%;
  top:-2px;
  width:82px;
  height:4px;
  transform:translateX(-50%);
  border-radius:999px;
  background:linear-gradient(90deg, transparent, #4f8cff, #1458ff, transparent);
  box-shadow:0 8px 22px rgba(20,88,255,.22);
  pointer-events:none;
  z-index:1;
}

.hero{
  background:
    radial-gradient(circle at 72% 40%, rgba(20,88,255,.08), transparent 32%),
    linear-gradient(180deg, rgba(255,255,255,.72), rgba(248,251,255,.62));
}
.contact-intake{
  background:
    radial-gradient(circle at 12% 28%, rgba(20,88,255,.10), transparent 30%),
    radial-gradient(circle at 86% 10%, rgba(79,140,255,.08), transparent 28%),
    linear-gradient(180deg, rgba(248,251,255,.96), rgba(255,255,255,.90));
}
.work-process{
  background:
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(245,248,255,.70));
}
.pricing{
  background:
    radial-gradient(circle at 50% 8%, rgba(20,88,255,.08), transparent 26%),
    linear-gradient(180deg, rgba(245,248,255,.72), rgba(255,255,255,.88));
}
.services{
  background:
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(247,250,255,.66));
}
.benefits{
  background:
    radial-gradient(circle at 72% 12%, rgba(20,88,255,.08), transparent 28%),
    linear-gradient(180deg, rgba(247,250,255,.70), rgba(255,255,255,.94));
}
.final-cta{
  background:linear-gradient(180deg, rgba(255,255,255,.95), rgba(242,247,255,.84));
}

.section-title{
  position:relative;
  padding-bottom:18px;
}
.section-title::after{
  content:"";
  position:absolute;
  left:50%;
  bottom:0;
  width:118px;
  height:4px;
  transform:translateX(-50%);
  border-radius:999px;
  background:linear-gradient(90deg, transparent, #4f8cff, #1458ff, transparent);
  box-shadow:0 8px 18px rgba(20,88,255,.18);
}

.nav a,
.mobile-menu a{
  position:relative;
}
.nav a::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:16px;
  height:3px;
  border-radius:999px;
  background:linear-gradient(90deg,#4f8cff,#1458ff);
  transform:scaleX(0);
  transform-origin:center;
  transition:transform .22s ease, opacity .22s ease;
  opacity:0;
}
.nav a:hover::after,
.nav a.is-active::after{
  transform:scaleX(1);
  opacity:1;
}
.nav a.is-active{
  color:#1458ff;
}
.mobile-menu a.is-active{
  color:#1458ff;
  background:#eef4ff;
  box-shadow:inset 0 0 0 1px #cbdcff;
}

.service-card#seo:target,
.service-card.service-card--seo.anchor-highlight{
  animation:anchorPulse 1.45s ease;
  border-color:#9bbcff;
  box-shadow:0 18px 38px rgba(20,88,255,.16);
}
@keyframes anchorPulse{
  0%{transform:translateY(0);box-shadow:0 0 0 0 rgba(20,88,255,.24)}
  38%{transform:translateY(-5px);box-shadow:0 0 0 9px rgba(20,88,255,.10), 0 18px 38px rgba(20,88,255,.15)}
  100%{transform:translateY(0);box-shadow:0 8px 26px rgba(7,22,51,.075)}
}

@media (max-width:760px){
  .hero,
  .contact-intake,
  .work-process,
  .pricing,
  .services,
  .benefits,
  .final-cta,
  .service-card#seo{scroll-margin-top:86px;}
  main > section + section::before{width:calc(100% - 26px);height:40px;top:-20px;}
  main > section + section::after{width:62px;}
  .section-title{padding-bottom:15px;}
}


/* v-next: clean section spacing without blue separators */
main > section + section::before,
main > section + section::after{
  content:none !important;
  display:none !important;
}

html{
  scroll-padding-top:108px;
}

.hero,
.contact-intake,
.work-process,
.pricing,
.services,
.benefits,
.final-cta,
.service-card#seo{
  scroll-margin-top:108px;
}

.hero{
  background:linear-gradient(180deg, rgba(255,255,255,.88), rgba(248,251,255,.72));
}
.contact-intake,
.work-process,
.pricing,
.services,
.benefits,
.final-cta{
  background:transparent;
}

.contact-intake{
  padding:58px 0 64px;
  border-top:0;
  border-bottom:0;
}
.work-process{
  padding:62px 0 62px;
  border-bottom:0;
}
.pricing{
  padding-top:64px;
  padding-bottom:66px;
}
.services{
  padding-top:68px;
  padding-bottom:66px;
}
.benefits{
  padding-top:64px;
  padding-bottom:62px;
}
.final-cta{
  padding-top:54px;
  padding-bottom:54px;
}

.contact-intake + .work-process,
.work-process + .pricing,
.pricing + .services,
.services + .benefits,
.benefits + .final-cta{
  margin-top:0;
}

@media (max-width:760px){
  html{scroll-padding-top:92px;}
  .hero,
  .contact-intake,
  .work-process,
  .pricing,
  .services,
  .benefits,
  .final-cta,
  .service-card#seo{
    scroll-margin-top:92px;
  }
  .contact-intake{padding:38px 0 44px;}
  .work-process{padding:42px 0 44px;}
  .pricing,.services,.benefits{padding-top:46px;padding-bottom:46px;}
  .final-cta{padding-top:38px;padding-bottom:38px;}
}


/* v-next: pricing buttons pinned lower + cleaner Premium offer */
.price-card{
  display:flex;
  flex-direction:column;
  min-height:335px;
  padding-bottom:20px;
}
.price-card ul{
  margin-bottom:22px;
}
.price-btn{
  margin-top:auto;
  align-self:stretch;
  min-height:42px;
}
.custom-card{
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  min-height:335px;
}
.custom-card p{
  margin-bottom:22px;
}
.custom-card a{
  margin-top:auto;
}

/* v-next: simple animated CSS graphics for the service section */
.services__grid{
  align-items:stretch;
}
.service-card{
  min-height:245px;
  padding:26px 16px 22px;
  overflow:hidden;
  position:relative;
}
.service-card::before{
  content:"";
  position:absolute;
  inset:auto -38px -52px auto;
  width:118px;
  height:118px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(20,88,255,.10), transparent 68%);
  pointer-events:none;
}
.service-card:hover .service-icon{
  transform:translateY(-4px) scale(1.03);
}
.service-icon{
  width:78px;
  height:68px;
  margin:0 auto 16px;
  border-radius:22px;
  background:
    radial-gradient(circle at 28% 22%, rgba(255,255,255,.95), rgba(255,255,255,0) 34%),
    linear-gradient(145deg,#f9fbff,#eaf2ff);
  border:1px solid #cbdcff;
  box-shadow:0 13px 28px rgba(20,88,255,.13), inset 0 1px 0 rgba(255,255,255,.9);
  color:#1458ff;
  transition:transform .24s ease, box-shadow .24s ease;
  animation:serviceIconFloat 5.8s ease-in-out infinite;
}
.service-card:nth-child(2) .service-icon{animation-delay:.35s;}
.service-card:nth-child(3) .service-icon{animation-delay:.7s;}
.service-card:nth-child(4) .service-icon{animation-delay:1.05s;}
.service-card:nth-child(5) .service-icon{animation-delay:1.4s;}
.service-card:nth-child(6) .service-icon{animation-delay:1.75s;}
.service-icon::before,
.service-icon::after{
  content:"";
  position:absolute;
  box-sizing:border-box;
}
.monitor::before{
  left:15px; top:16px; width:39px; height:27px;
  border:3px solid currentColor; border-radius:7px;
  background:linear-gradient(180deg,#fff,#edf4ff);
  animation:screenPulse 3.2s ease-in-out infinite;
}
.monitor::after{
  left:31px; top:44px; width:18px; height:9px;
  border-radius:0 0 7px 7px;
  background:currentColor;
  box-shadow:0 8px 0 -3px currentColor, 29px -29px 0 -5px #4f8cff;
  animation:tinyPop 3.2s ease-in-out infinite;
}
.code::before{
  content:"</>";
  left:14px; top:17px; width:50px; height:34px;
  display:grid; place-items:center;
  border-radius:12px;
  background:#fff;
  color:#1458ff;
  font-size:19px;
  font-weight:900;
  letter-spacing:-.12em;
  box-shadow:inset 0 0 0 1px #d7e5ff;
  animation:codeSlide 3.4s ease-in-out infinite;
}
.code::after{
  left:21px; top:53px; width:36px; height:4px;
  border-radius:99px;
  background:linear-gradient(90deg,#4f8cff,#1458ff);
  animation:barScan 2.8s ease-in-out infinite;
}
.seo::before{
  left:16px; top:14px; width:31px; height:31px;
  border:4px solid currentColor;
  border-radius:50%;
  background:#fff;
  box-shadow:17px 18px 0 -12px currentColor;
  animation:seoSearch 3.6s ease-in-out infinite;
}
.seo::after{
  left:46px; top:43px; width:23px; height:6px;
  border-radius:999px;
  background:currentColor;
  transform:rotate(45deg);
  transform-origin:left center;
  animation:seoHandle 3.6s ease-in-out infinite;
}
.backup::before{
  left:20px; top:12px; width:38px; height:44px;
  background:linear-gradient(180deg,#1458ff,#0d3bb3);
  clip-path:polygon(50% 0,88% 13%,88% 58%,50% 100%,12% 58%,12% 13%);
  border-radius:0;
  animation:shieldGlow 3.9s ease-in-out infinite;
}
.backup::after{
  left:30px; top:30px; width:18px; height:10px;
  border-left:3px solid #fff;
  border-bottom:3px solid #fff;
  transform:rotate(-45deg);
  border-radius:1px;
  animation:checkDraw 3.9s ease-in-out infinite;
}
.meter::before{
  left:15px; top:20px; width:48px; height:34px;
  border:4px solid currentColor;
  border-bottom:0;
  border-radius:48px 48px 0 0;
  background:radial-gradient(circle at 50% 100%,#fff 0 20px,transparent 21px);
}
.meter::after{
  left:38px; top:37px; width:5px; height:24px;
  border-radius:99px;
  background:#1458ff;
  transform-origin:50% 90%;
  animation:meterNeedle 3.2s ease-in-out infinite;
}
.headset::before{
  left:18px; top:14px; width:42px; height:34px;
  border:4px solid currentColor;
  border-bottom:0;
  border-radius:38px 38px 0 0;
  background:transparent;
  animation:headsetPulse 4s ease-in-out infinite;
}
.headset::after{
  left:13px; top:39px; width:52px; height:17px;
  border-left:8px solid currentColor;
  border-right:8px solid currentColor;
  border-radius:7px;
  box-shadow:34px 12px 0 -8px currentColor;
  animation:headsetDots 4s ease-in-out infinite;
}
@keyframes serviceIconFloat{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-6px)}
}
@keyframes screenPulse{
  0%,100%{box-shadow:inset 0 0 0 0 rgba(20,88,255,.0)}
  50%{box-shadow:inset 0 0 0 5px rgba(20,88,255,.08)}
}
@keyframes tinyPop{
  0%,100%{opacity:.78; transform:scale(1)}
  50%{opacity:1; transform:scale(1.08)}
}
@keyframes codeSlide{
  0%,100%{transform:translateX(0)}
  50%{transform:translateX(3px)}
}
@keyframes barScan{
  0%,100%{transform:scaleX(.55); opacity:.55}
  50%{transform:scaleX(1); opacity:1}
}
@keyframes seoSearch{
  0%,100%{transform:translate(0,0)}
  50%{transform:translate(4px,-2px)}
}
@keyframes seoHandle{
  0%,100%{transform:rotate(45deg) translate(0,0)}
  50%{transform:rotate(45deg) translate(2px,-1px)}
}
@keyframes shieldGlow{
  0%,100%{filter:drop-shadow(0 0 0 rgba(20,88,255,0))}
  50%{filter:drop-shadow(0 8px 10px rgba(20,88,255,.22))}
}
@keyframes checkDraw{
  0%,100%{opacity:.72; transform:rotate(-45deg) scale(.94)}
  50%{opacity:1; transform:rotate(-45deg) scale(1.06)}
}
@keyframes meterNeedle{
  0%,100%{transform:rotate(-38deg)}
  50%{transform:rotate(42deg)}
}
@keyframes headsetPulse{
  0%,100%{opacity:.84}
  50%{opacity:1}
}
@keyframes headsetDots{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-2px)}
}

@media (prefers-reduced-motion: reduce){
  .service-icon,
  .service-icon::before,
  .service-icon::after{
    animation:none !important;
  }
}

@media (max-width:760px){
  .price-card,.custom-card{min-height:auto;}
  .service-card{min-height:auto;}
}


/* --- refined service icons: cleaner visuals, no side-floating --- */
.service-card:hover .service-icon{
  transform:translateY(-3px) scale(1.02);
  box-shadow:0 16px 30px rgba(20,88,255,.14), inset 0 1px 0 rgba(255,255,255,.92);
}
.service-icon{
  width:82px;
  height:72px;
  margin:0 auto 16px;
  border-radius:24px;
  background:
    radial-gradient(circle at 28% 20%, rgba(255,255,255,.96), rgba(255,255,255,.08) 34%),
    linear-gradient(145deg,#f8fbff,#edf4ff 60%,#e6efff);
  border:1px solid #cddcff;
  box-shadow:0 12px 28px rgba(20,88,255,.10), inset 0 1px 0 rgba(255,255,255,.95);
  color:#1b5cff;
  transition:transform .24s ease, box-shadow .24s ease;
  animation:serviceIconBreathe 5.2s ease-in-out infinite;
}
.service-icon::before,
.service-icon::after{
  content:"";
  position:absolute;
  box-sizing:border-box;
}
/* Stała opieka techniczna */
.monitor::before{
  left:17px;
  top:15px;
  width:48px;
  height:31px;
  border:3px solid currentColor;
  border-radius:9px;
  background:linear-gradient(180deg,#ffffff,#edf5ff);
  animation:screenGlow 3.2s ease-in-out infinite;
}
.monitor::after{
  left:24px;
  top:48px;
  width:34px;
  height:10px;
  border-radius:8px 8px 10px 10px;
  background:currentColor;
  clip-path:polygon(28% 0,72% 0,78% 38%,100% 38%,100% 100%,0 100%,0 38%,22% 38%);
  opacity:.98;
}
/* Poprawki i rozwój */
.code::before{
  content:"</>";
  left:15px;
  top:16px;
  width:52px;
  height:34px;
  display:grid;
  place-items:center;
  border-radius:12px;
  background:#fff;
  color:currentColor;
  font-size:18px;
  font-weight:900;
  letter-spacing:-.10em;
  box-shadow:inset 0 0 0 1px #dce7ff;
  animation:codePulse 3.4s ease-in-out infinite;
}
.code::after{
  left:21px;
  top:55px;
  width:40px;
  height:4px;
  border-radius:999px;
  background:linear-gradient(90deg,#78a3ff,#1b5cff);
  opacity:.95;
  animation:underlineGlow 3.2s ease-in-out infinite;
}
/* Optymalizacja SEO */
.seo::before{
  left:17px;
  top:13px;
  width:31px;
  height:31px;
  border:4px solid currentColor;
  border-radius:50%;
  background:
    linear-gradient(135deg, rgba(27,92,255,.10), rgba(27,92,255,0) 62%),
    #fff;
  box-shadow:inset 0 0 0 1px rgba(27,92,255,.06);
  animation:seoPulse 3.6s ease-in-out infinite;
}
.seo::after{
  left:45px;
  top:41px;
  width:21px;
  height:6px;
  border-radius:999px;
  background:currentColor;
  transform:rotate(45deg);
  transform-origin:left center;
}
/* Bezpieczeństwo */
.backup::before{
  left:22px;
  top:12px;
  width:36px;
  height:42px;
  background:
    linear-gradient(180deg,#2f74ff 0%, #1750e2 58%, #113fc2 100%);
  clip-path:polygon(50% 0,84% 12%,84% 54%,50% 100%,16% 54%,16% 12%);
  filter:drop-shadow(0 7px 10px rgba(20,88,255,.20));
  animation:shieldGlow 3.9s ease-in-out infinite;
}
.backup::after{
  left:31px;
  top:19px;
  width:18px;
  height:22px;
  background:linear-gradient(180deg,rgba(255,255,255,.78),rgba(255,255,255,.20));
  clip-path:polygon(50% 0,82% 12%,82% 54%,50% 100%,18% 54%,18% 12%);
  opacity:.9;
  animation:innerShieldPulse 3.9s ease-in-out infinite;
}
/* Szybkość */
.meter::before{
  left:16px;
  top:20px;
  width:48px;
  height:34px;
  border:4px solid currentColor;
  border-bottom:0;
  border-radius:48px 48px 0 0;
  background:radial-gradient(circle at 50% 100%,#fff 0 20px,transparent 21px);
}
.meter::after{
  left:39px;
  top:36px;
  width:5px;
  height:23px;
  border-radius:999px;
  background:#1b5cff;
  transform-origin:50% 90%;
  animation:meterNeedleCalm 3.4s ease-in-out infinite;
}
/* Kontakt i wsparcie */
.headset::before{
  left:20px;
  top:13px;
  width:40px;
  height:30px;
  border:4px solid currentColor;
  border-bottom:0;
  border-radius:36px 36px 0 0;
  background:transparent;
  animation:headsetGlow 3.8s ease-in-out infinite;
}
.headset::after{
  left:18px;
  top:33px;
  width:44px;
  height:16px;
  border-left:8px solid currentColor;
  border-right:8px solid currentColor;
  border-radius:8px;
  box-shadow:18px 12px 0 -15px currentColor;
}

@keyframes serviceIconBreathe{
  0%,100%{transform:translateY(0) scale(1)}
  50%{transform:translateY(-2px) scale(1.02)}
}
@keyframes screenGlow{
  0%,100%{box-shadow:inset 0 0 0 0 rgba(27,92,255,0), 0 0 0 rgba(27,92,255,0)}
  50%{box-shadow:inset 0 0 0 4px rgba(27,92,255,.06), 0 8px 18px rgba(27,92,255,.08)}
}
@keyframes codePulse{
  0%,100%{transform:scale(1); opacity:.96}
  50%{transform:scale(1.03); opacity:1}
}
@keyframes underlineGlow{
  0%,100%{opacity:.75; transform:scaleX(.8)}
  50%{opacity:1; transform:scaleX(1)}
}
@keyframes seoPulse{
  0%,100%{box-shadow:inset 0 0 0 1px rgba(27,92,255,.06), 0 0 0 rgba(27,92,255,0)}
  50%{box-shadow:inset 0 0 0 1px rgba(27,92,255,.06), 0 8px 16px rgba(27,92,255,.10)}
}
@keyframes shieldGlow{
  0%,100%{filter:drop-shadow(0 0 0 rgba(20,88,255,0))}
  50%{filter:drop-shadow(0 8px 12px rgba(20,88,255,.18))}
}
@keyframes checkPulse{
  0%,100%{opacity:.9; transform:rotate(-45deg) scale(1)}
  50%{opacity:1; transform:rotate(-45deg) scale(1.08)}
}
@keyframes meterNeedleCalm{
  0%,100%{transform:rotate(-26deg)}
  50%{transform:rotate(24deg)}
}
@keyframes headsetGlow{
  0%,100%{opacity:.92; filter:drop-shadow(0 0 0 rgba(27,92,255,0))}
  50%{opacity:1; filter:drop-shadow(0 7px 10px rgba(27,92,255,.12))}
}

@media (prefers-reduced-motion: reduce){
  .service-icon,
  .service-icon::before,
  .service-icon::after{
    animation:none !important;
  }
}


/* --- topbar language switcher --- */
.topbar__inner{
  grid-template-columns:210px 1fr auto auto;
}
.language-switcher{
  position:relative;
  justify-self:end;
  z-index:70;
}
.language-switcher__button{
  height:43px;
  min-width:86px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:7px;
  padding:0 12px;
  border:1px solid #cbdcff;
  border-radius:8px;
  background:linear-gradient(180deg,#ffffff,#f4f8ff);
  color:#0b1d42;
  font-weight:900;
  cursor:pointer;
  box-shadow:0 7px 18px rgba(7,22,51,.06);
  transition:transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.language-switcher__button:hover,
.language-switcher.is-open .language-switcher__button{
  transform:translateY(-1px);
  border-color:#8eb0ff;
  box-shadow:0 12px 24px rgba(20,88,255,.13);
}
.language-switcher__flag{
  font-size:19px;
  line-height:1;
}
.language-switcher__code{
  font-size:13px;
  letter-spacing:.03em;
}
.language-switcher__chevron{
  font-size:15px;
  line-height:1;
  color:#416399;
  transform:translateY(-1px);
  transition:transform .2s ease;
}
.language-switcher.is-open .language-switcher__chevron{
  transform:translateY(1px) rotate(180deg);
}
.language-switcher__menu{
  position:absolute;
  right:0;
  top:calc(100% + 10px);
  width:184px;
  padding:8px;
  border:1px solid #d7e3ff;
  border-radius:14px;
  background:rgba(255,255,255,.97);
  box-shadow:0 18px 42px rgba(7,22,51,.16);
  backdrop-filter:blur(12px);
  display:grid;
  gap:6px;
  animation:languageDrop .18s ease both;
}
.language-switcher__menu[hidden]{display:none;}
.language-switcher__menu button{
  width:100%;
  min-height:42px;
  border:0;
  border-radius:10px;
  background:transparent;
  color:#10234a;
  display:grid;
  grid-template-columns:30px 1fr auto;
  align-items:center;
  gap:8px;
  padding:8px 10px;
  text-align:left;
  cursor:pointer;
  font-weight:800;
  transition:background .18s ease, color .18s ease, transform .18s ease;
}
.language-switcher__menu button:hover,
.language-switcher__menu button.is-active{
  background:#eef4ff;
  color:#1458ff;
  transform:translateX(2px);
}
.language-switcher__menu button span{font-size:20px;line-height:1;}
.language-switcher__menu button strong{font-size:13px;}
.language-switcher__menu button small{font-size:11px;color:#647491;font-weight:900;}
.mobile-language{
  display:none;
}
@keyframes languageDrop{
  from{opacity:0;transform:translateY(-7px) scale(.98)}
  to{opacity:1;transform:translateY(0) scale(1)}
}

@media (max-width:1120px){
  .topbar__inner{grid-template-columns:180px 1fr auto auto;gap:18px;}
}
@media (max-width:760px){
  .topbar__inner{grid-template-columns:155px 1fr;}
  .language-switcher{display:none;}
  .mobile-language{
    display:grid;
    gap:10px;
    padding:13px;
    border-radius:12px;
    background:#f5f8ff;
    border:1px solid #d7e3ff;
    color:var(--navy);
    font-weight:900;
  }
  .mobile-language>span{font-size:13px;}
  .mobile-language__flags{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;}
  .mobile-language__flags button{
    min-height:38px;
    border:1px solid #cbdcff;
    border-radius:10px;
    background:#fff;
    color:#10234a;
    font-weight:900;
    cursor:pointer;
  }
  .mobile-language__flags button.is-active{
    background:#1458ff;
    border-color:#1458ff;
    color:#fff;
  }
}


/* --- smaller language switcher + CSS-only flags --- */
.language-switcher__button{
  height:34px;
  min-width:64px;
  gap:5px;
  padding:0 8px;
  border-radius:7px;
  font-size:12px;
}
.language-switcher__code{
  font-size:11px;
  letter-spacing:.04em;
}
.language-switcher__chevron{
  font-size:12px;
}
.language-switcher__menu{
  width:164px;
  top:calc(100% + 8px);
  padding:7px;
  border-radius:12px;
}
.language-switcher__menu button{
  min-height:36px;
  grid-template-columns:24px 1fr auto;
  gap:7px;
  padding:7px 8px;
  border-radius:9px;
}
.language-switcher__menu button strong{font-size:12px;}
.language-switcher__menu button small{font-size:10px;}
.language-switcher__flag,
.language-switcher__menu button span.flag,
.mobile-language__flags .flag{
  font-size:0 !important;
  line-height:0 !important;
}
.flag{
  position:relative;
  display:inline-block;
  width:20px;
  height:14px;
  border-radius:3px;
  overflow:hidden;
  flex:0 0 auto;
  box-shadow:inset 0 0 0 1px rgba(7,22,51,.14), 0 1px 3px rgba(7,22,51,.08);
  background:#fff;
}
.language-switcher__button .flag{
  width:18px;
  height:12px;
  border-radius:2px;
}
.flag--pl{
  background:linear-gradient(to bottom,#ffffff 0 50%,#dc143c 50% 100%);
}
.flag--en{
  background-color:#012169;
  background-image:
    linear-gradient(32deg, transparent 34%, #ffffff 34% 44%, #c8102e 44% 56%, #ffffff 56% 66%, transparent 66%),
    linear-gradient(-32deg, transparent 34%, #ffffff 34% 44%, #c8102e 44% 56%, #ffffff 56% 66%, transparent 66%),
    linear-gradient(to right, transparent 31%, #ffffff 31% 43%, #c8102e 43% 57%, #ffffff 57% 69%, transparent 69%),
    linear-gradient(to bottom, transparent 31%, #ffffff 31% 43%, #c8102e 43% 57%, #ffffff 57% 69%, transparent 69%);
  background-repeat:no-repeat;
}

.mobile-language__flags button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  font-size:12px;
}
.mobile-language__flags button.is-active .flag{
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.45), 0 1px 3px rgba(7,22,51,.12);
}
@media (max-width:1120px){
  .language-switcher__button{min-width:60px;padding:0 7px;}
}


/* --- prettier topic dropdown in contact form --- */
.topic-select-field{
  position:relative;
}

.topic-select-field::after{
  content:"";
  position:absolute;
  right:17px;
  bottom:18px;
  width:9px;
  height:9px;
  border-right:2px solid #1b5cff;
  border-bottom:2px solid #1b5cff;
  transform:rotate(45deg);
  pointer-events:none;
  transition:transform .18s ease, border-color .18s ease;
}

.topic-select-field:focus-within::after{
  transform:rotate(225deg) translate(-2px,-2px);
  border-color:#0b46d8;
}

.contact-form select[name="topic"]{
  appearance:none;
  -webkit-appearance:none;
  min-height:50px;
  padding:0 48px 0 16px;
  border:1px solid #cbdcff;
  border-radius:12px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(244,248,255,.98)),
    radial-gradient(circle at 92% 50%, rgba(27,92,255,.10), transparent 30%);
  color:#10234a;
  font-weight:850;
  letter-spacing:-.01em;
  cursor:pointer;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.88), 0 9px 22px rgba(20,88,255,.07);
  transition:border-color .18s ease, box-shadow .18s ease, transform .18s ease, background .18s ease;
}

.contact-form select[name="topic"]:hover{
  border-color:#8eb0ff;
  background:
    linear-gradient(180deg, #ffffff, #f0f6ff),
    radial-gradient(circle at 92% 50%, rgba(27,92,255,.14), transparent 32%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.9), 0 13px 28px rgba(20,88,255,.11);
}

.contact-form select[name="topic"]:focus{
  outline:none;
  border-color:#1b5cff;
  box-shadow:0 0 0 4px rgba(27,92,255,.12), 0 14px 30px rgba(20,88,255,.13);
}

.contact-form select[name="topic"]:invalid{
  color:#72809a;
}

.contact-form select[name="topic"] option{
  color:#10234a;
  background:#ffffff;
  font-weight:800;
}

@media (max-width:760px){
  .topic-select-field::after{
    bottom:17px;
  }
}


/* --- expanded benefits section: clean cards instead of stats/testimonial boxes --- */
.benefits--expanded{
  padding:88px 0 96px;
  background:
    radial-gradient(circle at 12% 18%, rgba(27,92,255,.08), transparent 28%),
    radial-gradient(circle at 88% 72%, rgba(27,92,255,.06), transparent 30%),
    linear-gradient(180deg, rgba(255,255,255,.70), rgba(245,249,255,.72));
}

.benefits--expanded .container{
  max-width:1180px;
}

.benefits__header{
  max-width:760px;
  margin:0 auto 34px;
  text-align:center;
}

.benefits__header h2{
  margin:12px 0 12px;
  color:#0b1d42;
  font-family:Manrope, Inter, system-ui, sans-serif;
  font-size:clamp(30px, 4vw, 48px);
  line-height:1.05;
  letter-spacing:-.055em;
}

.benefits__header p{
  margin:0;
  color:#59677d;
  font-size:16px;
  line-height:1.75;
  font-weight:650;
}

.gain-list--cards{
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:18px;
  margin-top:28px;
}

.gain-card{
  position:relative;
  min-height:210px;
  padding:23px 22px 22px;
  border:1px solid #dce7ff;
  border-radius:14px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.96), rgba(247,250,255,.94));
  box-shadow:0 16px 38px rgba(7,22,51,.07);
  overflow:hidden;
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}

.gain-card::before{
  content:"";
  position:absolute;
  right:-42px;
  bottom:-48px;
  width:132px;
  height:132px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(27,92,255,.13), transparent 66%);
  pointer-events:none;
}

.gain-card:hover{
  transform:translateY(-4px);
  border-color:#a9c1ff;
  box-shadow:0 22px 52px rgba(20,88,255,.13);
}

.gain-card__icon{
  width:42px;
  height:42px;
  display:inline-grid;
  place-items:center;
  border-radius:12px;
  background:linear-gradient(145deg,#1458ff,#4f8cff);
  color:#fff;
  font-weight:950;
  box-shadow:0 10px 22px rgba(20,88,255,.22);
}

.gain-card h3{
  position:relative;
  margin:17px 0 9px;
  color:#10234a;
  font-family:Manrope, Inter, system-ui, sans-serif;
  font-size:19px;
  line-height:1.22;
  letter-spacing:-.03em;
}

.gain-card p{
  position:relative;
  margin:0;
  color:#5b6a82;
  font-size:13.5px;
  line-height:1.68;
  font-weight:650;
}

.gain-card--wide{
  grid-column:span 2;
  min-height:180px;
}

@media (max-width:1040px){
  .gain-list--cards{
    grid-template-columns:repeat(2, minmax(0,1fr));
  }
}

@media (max-width:620px){
  .benefits--expanded{
    padding:64px 0 72px;
  }

  .gain-list--cards{
    grid-template-columns:1fr;
  }

  .gain-card,
  .gain-card--wide{
    grid-column:auto;
    min-height:auto;
  }
}


/* --- longer, thinner, softer fading blue lines under sections --- */
.section-title::after,
.benefits__header h2::after,
.work-process__head h2::after,
.contact-intake__copy h2::after{
  width:clamp(150px, 22vw, 310px) !important;
  height:2px !important;
  border-radius:999px !important;
  background:linear-gradient(
    90deg,
    rgba(27,92,255,0) 0%,
    rgba(27,92,255,.10) 12%,
    rgba(27,92,255,.72) 42%,
    rgba(27,92,255,.72) 58%,
    rgba(27,92,255,.10) 88%,
    rgba(27,92,255,0) 100%
  ) !important;
  box-shadow:0 5px 18px rgba(27,92,255,.16) !important;
}

.section-title::after{
  margin-top:15px !important;
}

.benefits__header h2::after,
.work-process__head h2::after,
.contact-intake__copy h2::after{
  content:"";
  display:block;
  margin:16px auto 0;
}

.contact-intake__copy h2::after{
  margin-left:0;
  margin-right:auto;
}

@media (max-width:760px){
  .section-title::after,
  .benefits__header h2::after,
  .work-process__head h2::after,
  .contact-intake__copy h2::after{
    width:min(72vw, 230px) !important;
  }
}


/* --- minimalist redesign for "Co zyskujesz" cards --- */
.gain-card{
  min-height:196px;
  padding:26px 24px 24px;
  border:1px solid #e3ebfb;
  border-radius:16px;
  background:#ffffff;
  box-shadow:0 14px 32px rgba(7,22,51,.055);
}

.gain-card::before{
  display:none;
}

.gain-card::after{
  content:"";
  position:absolute;
  left:24px;
  top:0;
  width:64px;
  height:3px;
  border-radius:999px;
  background:linear-gradient(90deg, rgba(20,88,255,.26), rgba(20,88,255,.82), rgba(20,88,255,.18));
}

.gain-card:hover{
  transform:translateY(-3px);
  border-color:#c9d8fb;
  box-shadow:0 18px 38px rgba(20,88,255,.09);
}

.gain-card__icon{
  display:none;
}

.gain-card h3{
  margin:2px 0 10px;
  font-size:20px;
  line-height:1.24;
  letter-spacing:-.035em;
}

.gain-card p{
  color:#627089;
  font-size:14px;
  line-height:1.72;
}

.gain-card--wide{
  min-height:172px;
}

@media (max-width:620px){
  .gain-card{
    min-height:auto;
    padding:24px 20px 22px;
  }

  .gain-card::after{
    left:20px;
    width:56px;
  }
}


/* --- subtle blue borders for cards + footer --- */
.gain-card{
  border:1px solid #d4e0ff !important;
  box-shadow:0 14px 32px rgba(7,22,51,.05);
}

.gain-card::after{
  display:none !important;
}

.service-card,
.price-card,
.custom-card{
  border:1px solid #d4e0ff !important;
}

.service-card:hover,
.price-card:hover,
.custom-card:hover,
.gain-card:hover{
  border-color:#b9ccff !important;
}

.site-footer{
  padding:34px 0 0;
  background:linear-gradient(180deg,#f7faff 0%, #eef4ff 100%);
  border-top:1px solid #d9e5ff;
}

.site-footer__grid{
  display:grid;
  grid-template-columns:1.35fr .9fr .85fr;
  gap:28px;
  align-items:start;
}

.site-footer__brand{
  max-width:460px;
}

.site-footer__logo{
  width:168px;
  height:auto;
  display:block;
  margin-bottom:14px;
}

.site-footer__brand p,
.site-footer__contact a,
.site-footer__col nav a{
  color:#5f6d84;
  font-size:14px;
  line-height:1.75;
  font-weight:650;
}

.site-footer__col h3{
  margin:4px 0 12px;
  color:#10234a;
  font-family:Manrope, Inter, system-ui, sans-serif;
  font-size:18px;
  letter-spacing:-.03em;
}

.site-footer__col nav,
.site-footer__contact{
  display:grid;
  gap:8px;
}

.site-footer__col nav a,
.site-footer__contact a{
  text-decoration:none;
  transition:color .18s ease, transform .18s ease;
}

.site-footer__col nav a:hover,
.site-footer__contact a:hover{
  color:#1458ff;
  transform:translateX(2px);
}

.site-footer__bottom{
  margin-top:28px;
  border-top:1px solid #dbe6ff;
  color:#71809b;
  font-size:13px;
  font-weight:700;
}

.site-footer__bottom .container{
  padding-top:16px;
  padding-bottom:22px;
}

@media (max-width:920px){
  .site-footer__grid{
    grid-template-columns:1fr;
    gap:18px;
  }

  .site-footer{
    padding-top:28px;
  }
}


/* --- softer topic dropdown matching site style --- */
.topic-select-field::after{
  right:18px;
  bottom:19px;
  width:8px;
  height:8px;
  border-right:1.5px solid #5b8dff;
  border-bottom:1.5px solid #5b8dff;
}

.topic-select-field:focus-within::after{
  border-color:#3b74f4;
}

.contact-form select[name="topic"]{
  min-height:52px;
  padding:0 48px 0 16px;
  border:1px solid #d7e4ff;
  border-radius:14px;
  background:linear-gradient(180deg,#ffffff 0%, #f7faff 100%);
  color:#22324f;
  font-weight:500;
  letter-spacing:0;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.95), 0 8px 20px rgba(20,88,255,.045);
}

.contact-form select[name="topic"]:hover{
  border-color:#bfd2ff;
  background:linear-gradient(180deg,#ffffff 0%, #f4f8ff 100%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.95), 0 10px 24px rgba(20,88,255,.06);
  transform:none;
}

.contact-form select[name="topic"]:focus{
  border-color:#8cb0ff;
  box-shadow:0 0 0 3px rgba(20,88,255,.08), 0 12px 28px rgba(20,88,255,.07);
}

.contact-form select[name="topic"]:invalid{
  color:#7a889f;
  font-weight:500;
}

.contact-form select[name="topic"] option{
  color:#22324f;
  background:#ffffff;
  font-weight:500;
}


/* --- custom topic dropdown with rounded menu --- */
.topic-select-field{
  position:relative;
}

.topic-select-field::after{
  display:none !important;
}

.topic-select-native{
  position:absolute !important;
  width:1px !important;
  height:1px !important;
  opacity:0 !important;
  pointer-events:none !important;
}

.custom-select{
  position:relative;
  margin-top:0;
}

.custom-select__trigger{
  width:100%;
  min-height:52px;
  border:1px solid #d7e4ff;
  border-radius:14px;
  background:linear-gradient(180deg,#ffffff 0%, #f7faff 100%);
  color:#22324f;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:0 16px;
  font:500 15px/1.2 Inter, system-ui, sans-serif;
  letter-spacing:0;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.95), 0 8px 20px rgba(20,88,255,.045);
  cursor:pointer;
  transition:border-color .18s ease, box-shadow .18s ease, background .18s ease;
}

.custom-select__trigger:hover{
  border-color:#bfd2ff;
  background:linear-gradient(180deg,#ffffff 0%, #f4f8ff 100%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.95), 0 10px 24px rgba(20,88,255,.06);
}

.custom-select.is-open .custom-select__trigger,
.custom-select__trigger:focus-visible{
  outline:none;
  border-color:#8cb0ff;
  box-shadow:0 0 0 3px rgba(20,88,255,.08), 0 12px 28px rgba(20,88,255,.07);
}

.custom-select__value{
  color:#22324f;
  font-weight:500;
  text-align:left;
}

.custom-select__value.is-placeholder{
  color:#7a889f;
}

.custom-select__chevron{
  flex:0 0 auto;
  width:8px;
  height:8px;
  margin-right:2px;
  border-right:1.5px solid #5b8dff;
  border-bottom:1.5px solid #5b8dff;
  transform:rotate(45deg);
  transition:transform .18s ease, border-color .18s ease;
}

.custom-select.is-open .custom-select__chevron{
  transform:rotate(225deg) translate(-1px,-1px);
  border-color:#3b74f4;
}

.custom-select__menu{
  position:absolute;
  top:calc(100% + 8px);
  left:0;
  right:0;
  padding:8px;
  border:1px solid #d7e4ff;
  border-radius:14px;
  background:linear-gradient(180deg,#ffffff 0%, #f8fbff 100%);
  box-shadow:0 18px 34px rgba(20,88,255,.09), 0 4px 12px rgba(7,22,51,.05);
  z-index:35;
}

.custom-select__menu[hidden]{
  display:none;
}

.custom-select__option{
  width:100%;
  border:0;
  background:transparent;
  color:#22324f;
  text-align:left;
  border-radius:10px;
  min-height:42px;
  padding:10px 12px;
  font:500 14px/1.35 Inter, system-ui, sans-serif;
  cursor:pointer;
  transition:background .16s ease, color .16s ease;
}

.custom-select__option:hover,
.custom-select__option.is-selected{
  background:#edf4ff;
  color:#1458ff;
}

.custom-select__option.is-placeholder{
  color:#7a889f;
}

@media (max-width:760px){
  .custom-select__trigger{
    min-height:50px;
  }

  .custom-select__menu{
    border-radius:13px;
  }
}


/* =========================================================
   Mobile/tablet responsiveness polish
   ========================================================= */

/* prevent accidental horizontal scroll from wide cards/images */
html,
body{
  max-width:100%;
  overflow-x:hidden;
}

img{
  max-width:100%;
  height:auto;
}

@media (max-width:1180px){
  .container{
    width:min(100% - 36px, 1120px);
  }

  .topbar__inner{
    gap:12px;
  }

  .nav{
    gap:10px;
  }

  .nav a{
    padding:10px 8px;
    font-size:13px;
  }

  .topbar__cta{
    min-width:auto;
    padding:0 13px;
    font-size:13px;
  }

  .hero__grid{
    grid-template-columns:1fr .92fr;
    gap:34px;
  }

  .hero h1{
    font-size:clamp(42px, 5vw, 66px);
  }

  .services__grid{
    grid-template-columns:repeat(3, minmax(0,1fr));
    gap:18px;
  }

  .pricing__grid{
    grid-template-columns:repeat(2, minmax(0,1fr));
  }

  .custom-card{
    min-height:260px;
  }
}

@media (max-width:920px){
  body{
    background:#f7f9fd;
  }

  .container{
    width:min(100% - 28px, 820px);
  }

  .topbar{
    position:sticky;
    top:0;
  }

  .topbar__inner{
    min-height:70px;
    grid-template-columns:150px 1fr auto;
    gap:10px;
  }

  .brand img{
    max-width:142px;
  }

  .nav,
  .topbar__cta,
  .language-switcher{
    display:none;
  }

  .menu-btn{
    display:inline-flex;
    justify-self:end;
  }

  .mobile-menu{
    left:14px;
    right:14px;
    top:74px;
    border:1px solid #d4e0ff;
    border-radius:18px;
    background:rgba(255,255,255,.98);
    box-shadow:0 18px 42px rgba(7,22,51,.16);
    padding:14px;
    max-height:calc(100vh - 92px);
    overflow-y:auto;
  }

  .mobile-menu a,
  .mobile-menu__cta{
    min-height:44px;
    border-radius:12px;
    font-size:14px;
  }

  .mobile-language{
    margin-top:4px;
  }

  .hero{
    padding-top:34px;
  }

  .hero__grid{
    grid-template-columns:1fr;
    gap:28px;
  }

  .hero__copy{
    text-align:center;
    max-width:720px;
    margin:0 auto;
  }

  .hero .eyebrow{
    margin-left:auto;
    margin-right:auto;
  }

  .hero h1{
    font-size:clamp(38px, 9vw, 58px);
    line-height:1.04;
  }

  .hero__lead{
    max-width:620px;
    margin-left:auto;
    margin-right:auto;
    font-size:16px;
    line-height:1.72;
  }

  .hero__actions{
    justify-content:center;
    flex-wrap:wrap;
  }

  .hero__visual{
    width:min(100%, 680px);
    margin:0 auto;
  }

  .hero__visual--image{
    padding:0;
    transform:none;
  }

  .hero-panel-image{
    width:100%;
    border-radius:18px;
    box-shadow:0 20px 50px rgba(7,22,51,.16);
  }

  .contact-intake{
    padding:64px 0 68px;
  }

  .contact-intake__grid{
    grid-template-columns:1fr;
    gap:24px;
  }

  .contact-intake__copy{
    text-align:center;
  }

  .contact-intake__copy .eyebrow,
  .contact-intake__copy h2::after{
    margin-left:auto;
    margin-right:auto;
  }

  .contact-intake__points{
    justify-content:center;
  }

  .contact-form{
    max-width:720px;
    margin:0 auto;
  }

  .form-row{
    grid-template-columns:1fr;
    gap:14px;
  }

  .work-process{
    padding:64px 0 70px;
  }

  .work-process__shell{
    padding:30px 22px;
    border-radius:22px;
  }

  .work-process__grid{
    grid-template-columns:repeat(2, minmax(0,1fr));
    gap:16px;
  }

  .process-card{
    min-height:220px;
  }

  .pricing{
    padding:64px 0 72px;
  }

  .price-card,
  .custom-card{
    border-radius:16px;
    min-height:0;
  }

  .price-card{
    padding:23px 19px 18px;
  }

  .price-card--featured{
    padding-top:46px;
  }

  .price{
    flex-wrap:wrap;
  }

  .price strong{
    font-size:28px;
  }

  .services{
    padding:64px 0 72px;
  }

  .service-card{
    min-height:0;
    border-radius:16px;
    padding:24px 18px 22px;
  }

  .service-icon{
    transform:scale(.94);
    margin-bottom:12px;
  }

  .benefits--expanded{
    padding:64px 0 72px;
  }

  .gain-list--cards{
    grid-template-columns:repeat(2, minmax(0,1fr));
  }

  .gain-card,
  .gain-card--wide{
    grid-column:auto;
    min-height:0;
  }

  .final-cta{
    padding:54px 0 48px;
  }

  .final-cta__box{
    grid-template-columns:1fr;
    text-align:center;
    justify-items:center;
    gap:18px;
    padding:28px 20px;
    border-radius:20px;
  }

  .site-footer__grid{
    grid-template-columns:1fr 1fr;
  }

  .site-footer__brand{
    grid-column:1 / -1;
    max-width:100%;
  }
}

@media (max-width:720px){
  .container{
    width:min(100% - 24px, 640px);
  }

  .section-shell{
    padding-left:0;
    padding-right:0;
  }

  .topbar__inner{
    min-height:66px;
    grid-template-columns:136px 1fr auto;
  }

  .brand img{
    max-width:132px;
  }

  .mobile-menu{
    top:70px;
  }

  .hero{
    padding-top:28px;
    padding-bottom:48px;
  }

  .hero h1{
    font-size:clamp(34px, 10.2vw, 48px);
    letter-spacing:-.055em;
  }

  .hero__lead{
    font-size:15px;
  }

  .eyebrow{
    max-width:100%;
    white-space:normal;
    justify-content:center;
    text-align:center;
    line-height:1.35;
    padding:8px 11px;
    font-size:11px;
  }

  .btn{
    min-height:46px;
    width:100%;
    max-width:320px;
  }

  .hero__actions{
    display:grid;
    justify-items:center;
    gap:11px;
  }

  .hero-panel-image{
    border-radius:16px;
  }

  .contact-intake__copy h2,
  .work-process__head h2,
  .benefits__header h2,
  .section-title{
    font-size:clamp(28px, 8vw, 38px);
    line-height:1.1;
  }

  .contact-intake__copy p,
  .work-process__head p,
  .benefits__header p{
    font-size:14.5px;
    line-height:1.7;
  }

  .contact-intake__points{
    display:grid;
    grid-template-columns:1fr;
    gap:9px;
  }

  .contact-form{
    padding:18px;
    border-radius:18px;
  }

  .contact-form input,
  .contact-form textarea,
  .custom-select__trigger{
    font-size:14px;
  }

  .custom-select__menu{
    position:absolute;
    max-height:246px;
    overflow-y:auto;
  }

  .contact-form__bottom{
    grid-template-columns:1fr;
    gap:14px;
    text-align:center;
  }

  .contact-form__bottom .btn{
    max-width:none;
  }

  .work-process__grid{
    grid-template-columns:1fr;
  }

  .process-card{
    min-height:0;
    padding:22px 18px;
  }

  .process-card__number{
    font-size:13px;
  }

  .pricing__grid{
    grid-template-columns:1fr;
    gap:16px;
  }

  .price-card,
  .custom-card{
    padding:22px 18px 18px;
  }

  .price-card--featured{
    padding-top:45px;
  }

  .price-head{
    align-items:flex-start;
    flex-direction:column;
    gap:8px;
  }

  .price-head h3{
    font-size:24px;
  }

  .price-card ul{
    gap:9px;
  }

  .price-card li{
    font-size:13px;
    line-height:1.45;
  }

  .price-btn{
    min-height:42px;
  }

  .custom-card{
    text-align:center;
    min-height:0;
  }

  .services__grid{
    grid-template-columns:1fr;
    gap:14px;
  }

  .service-card{
    display:grid;
    grid-template-columns:72px 1fr;
    column-gap:14px;
    text-align:left;
    align-items:center;
    padding:18px;
  }

  .service-icon{
    grid-row:1 / span 2;
    margin:0;
    transform:scale(.82);
    transform-origin:left center;
  }

  .service-card h3{
    margin:0 0 6px;
    font-size:18px;
  }

  .service-card p{
    font-size:13.2px;
    line-height:1.55;
  }

  .gain-list--cards{
    grid-template-columns:1fr;
    gap:13px;
  }

  .gain-card{
    padding:22px 18px;
    border-radius:15px;
  }

  .gain-card h3{
    font-size:18px;
  }

  .gain-card p{
    font-size:13.5px;
  }

  .final-cta__box .btn{
    max-width:320px;
  }

  .site-footer{
    padding-top:30px;
  }

  .site-footer__grid{
    grid-template-columns:1fr;
    gap:22px;
  }

  .site-footer__logo{
    width:146px;
  }

  .site-footer__bottom .container{
    padding-top:14px;
    padding-bottom:18px;
    text-align:center;
  }
}

@media (max-width:430px){
  .container{
    width:min(100% - 18px, 390px);
  }

  .topbar__inner{
    grid-template-columns:122px 1fr auto;
    min-height:62px;
  }

  .brand img{
    max-width:118px;
  }

  .menu-btn{
    width:42px;
    height:38px;
  }

  .mobile-menu{
    left:9px;
    right:9px;
    top:66px;
    padding:12px;
    border-radius:16px;
  }

  .hero h1{
    font-size:33px;
  }

  .hero__lead{
    font-size:14px;
  }

  .hero__visual{
    width:calc(100% + 2px);
  }

  .hero-panel-image{
    border-radius:14px;
    box-shadow:0 16px 34px rgba(7,22,51,.14);
  }

  .contact-intake,
  .work-process,
  .pricing,
  .services,
  .benefits--expanded{
    padding-top:52px;
    padding-bottom:58px;
  }

  .contact-intake__copy h2,
  .work-process__head h2,
  .benefits__header h2,
  .section-title{
    font-size:28px;
  }

  .work-process__shell{
    padding:22px 14px;
    border-radius:18px;
  }

  .contact-form{
    padding:15px;
  }

  .service-card{
    grid-template-columns:62px 1fr;
    column-gap:10px;
    padding:16px 14px;
  }

  .service-icon{
    transform:scale(.72);
  }

  .price strong{
    font-size:26px;
  }

  .final-cta__box{
    padding:24px 16px;
  }

  .site-footer__brand p,
  .site-footer__contact a,
  .site-footer__col nav a{
    font-size:13.5px;
  }
}


/* --- hero screen graphic: no visible box, subtle hover tilt --- */
.hero__visual--image{
  perspective:1400px;
}

.hero-panel-image{
  pointer-events:auto;
  border-radius:0 !important;
  box-shadow:none !important;
  filter:none !important;
  transition:transform .32s ease, filter .32s ease;
  transform-style:preserve-3d;
}

@media (hover:hover) and (pointer:fine){
  .hero__visual--image:hover .hero-panel-image{
    transform:translate(20px, 2px) rotate(-1.25deg) rotateY(-10deg) rotateX(2deg) scale(1.012);
  }

  @media (max-width:1120px){
    .hero__visual--image:hover .hero-panel-image{
      transform:rotate(-1deg) rotateY(-8deg) scale(1.01);
    }
  }
}

@media (max-width:760px){
  .hero-panel-image{
    border-radius:0 !important;
    box-shadow:none !important;
    filter:none !important;
  }
}


/* --- real form sending states --- */
.hp-field{
  position:absolute;
  left:-9999px;
  width:1px;
  height:1px;
  overflow:hidden;
  opacity:0;
  pointer-events:none;
}

.contact-form.is-sending{
  pointer-events:none;
}

.contact-form.is-sending button[type="submit"]{
  opacity:.72;
}

.form-success{
  border-radius:12px;
  padding:12px 14px;
  background:#eef8f1;
  border:1px solid #bde8c8;
  color:#216139;
  font-weight:700;
  line-height:1.45;
}

.form-success.is-error{
  background:#fff2f2;
  border-color:#ffc8c8;
  color:#8a2727;
}


/* --- mobile form width + centered hero screen image fix --- */
@media (max-width:760px){
  .contact-intake .container{
    width:min(100% - 14px, 640px) !important;
  }

  .contact-form{
    width:100% !important;
    max-width:none !important;
    margin-left:auto !important;
    margin-right:auto !important;
    padding:14px !important;
    border-radius:16px !important;
  }

  .contact-intake__grid{
    gap:18px !important;
  }

  .contact-form label{
    min-width:0;
  }

  .contact-form input,
  .contact-form textarea,
  .custom-select__trigger{
    width:100%;
  }

  .hero__visual,
  .hero__visual--image{
    width:100% !important;
    max-width:100% !important;
    margin-left:auto !important;
    margin-right:auto !important;
    justify-content:center !important;
    align-items:center !important;
    overflow:visible !important;
    transform:none !important;
  }

  .hero-panel-image{
    display:block !important;
    width:min(100%, 520px) !important;
    max-width:100% !important;
    margin-left:auto !important;
    margin-right:auto !important;
    transform:none !important;
    object-fit:contain !important;
  }
}

@media (max-width:430px){
  .contact-intake .container{
    width:min(100% - 10px, 420px) !important;
  }

  .contact-form{
    padding:12px !important;
    border-radius:15px !important;
  }

  .form-row{
    gap:11px !important;
  }

  .contact-form input,
  .contact-form textarea,
  .custom-select__trigger{
    min-height:48px;
  }

  .contact-form textarea{
    min-height:112px;
  }

  .hero__visual{
    width:100% !important;
  }

  .hero-panel-image{
    width:min(100%, 390px) !important;
    transform:none !important;
    margin-inline:auto !important;
  }
}


/* --- white background behind the hero JPG screen graphic --- */
.hero,
.hero__visual,
.hero__visual--image{
  background:#ffffff !important;
}

@media (max-width:920px){
  .hero{
    background:#ffffff !important;
  }
}


/* --- SEO FAQ section --- */
.faq-section{
  padding:74px 0 80px;
  background:#ffffff;
  border-bottom:1px solid rgba(14,34,72,.06);
}

.faq-section__head{
  max-width:760px;
  margin:0 auto 28px;
  text-align:center;
}

.faq-section__head h2{
  margin:12px 0 10px;
  color:#0b1d42;
  font-family:Manrope, Inter, system-ui, sans-serif;
  font-size:clamp(30px, 4vw, 46px);
  line-height:1.08;
  letter-spacing:-.055em;
}

.faq-section__head p{
  margin:0;
  color:#59677d;
  font-size:15.5px;
  line-height:1.7;
  font-weight:650;
}

.faq-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:16px;
}

.faq-item{
  border:1px solid #d4e0ff;
  border-radius:16px;
  background:#ffffff;
  box-shadow:0 14px 32px rgba(7,22,51,.045);
  padding:0;
  overflow:hidden;
}

.faq-item summary{
  list-style:none;
  cursor:pointer;
  padding:20px 22px;
  color:#10234a;
  font-family:Manrope, Inter, system-ui, sans-serif;
  font-size:17px;
  font-weight:800;
  letter-spacing:-.025em;
  display:flex;
  justify-content:space-between;
  gap:18px;
}

.faq-item summary::-webkit-details-marker{
  display:none;
}

.faq-item summary::after{
  content:"+";
  flex:0 0 auto;
  width:26px;
  height:26px;
  border-radius:50%;
  background:#eef4ff;
  color:#1458ff;
  display:grid;
  place-items:center;
  font-weight:900;
  line-height:1;
}

.faq-item[open] summary::after{
  content:"−";
}

.faq-item p{
  margin:0;
  padding:0 22px 22px;
  color:#5f6d84;
  font-size:14px;
  line-height:1.72;
  font-weight:650;
}

@media (max-width:760px){
  .faq-section{
    padding:58px 0 64px;
  }

  .faq-grid{
    grid-template-columns:1fr;
  }

  .faq-item summary{
    padding:18px;
    font-size:15.5px;
  }

  .faq-item p{
    padding:0 18px 18px;
    font-size:13.5px;
  }
}


/* --- mobile service cards icon overlap fix + hero background consistency --- */

/* Background behind monitor graphic should blend with the page, not create a separate white/beige block. */
.hero,
.hero__grid,
.hero__visual,
.hero__visual--image{
  background:transparent !important;
}

/* On phones, service cards become clean vertical cards so icons cannot overlap text. */
@media (max-width:720px){
  .services__grid{
    grid-template-columns:1fr !important;
    gap:14px !important;
  }

  .service-card{
    display:block !important;
    text-align:center !important;
    min-height:auto !important;
    padding:22px 18px 20px !important;
    overflow:hidden !important;
  }

  .service-icon{
    display:block !important;
    width:70px !important;
    height:62px !important;
    margin:0 auto 14px !important;
    transform:none !important;
    transform-origin:center center !important;
  }

  .service-card:hover .service-icon{
    transform:none !important;
  }

  .service-card h3{
    margin:0 0 8px !important;
    font-size:18px !important;
    line-height:1.22 !important;
    position:relative !important;
    z-index:2 !important;
  }

  .service-card p{
    font-size:13.5px !important;
    line-height:1.6 !important;
    max-width:320px !important;
    margin:0 auto !important;
    position:relative !important;
    z-index:2 !important;
  }
}

@media (max-width:430px){
  .service-card{
    padding:20px 15px 18px !important;
  }

  .service-icon{
    width:64px !important;
    height:58px !important;
    margin-bottom:12px !important;
  }

  .service-card h3{
    font-size:17px !important;
  }

  .service-card p{
    font-size:13px !important;
  }
}


/* --- final mobile service icon fix + hero background matching page --- */

/* Make the hero background identical to the page background so nothing differs behind the monitor image. */
.hero{
  background:
    radial-gradient(circle at 8% 4%,rgba(20,88,255,.10),transparent 26%),
    radial-gradient(circle at 70% 10%,rgba(19,88,255,.06),transparent 26%),
    linear-gradient(180deg,#fff 0%,#fbf8f1 57%,#fff 100%) !important;
}

.hero__grid,
.hero__visual,
.hero__visual--image{
  background:transparent !important;
}

@media (max-width:720px){
  .service-card{
    display:flex !important;
    flex-direction:column !important;
    align-items:center !important;
    justify-content:flex-start !important;
    text-align:center !important;
    min-height:auto !important;
    padding:24px 16px 20px !important;
    overflow:hidden !important;
  }

  .service-icon{
    width:58px !important;
    height:50px !important;
    margin:0 auto 10px !important;
    transform:scale(.78) !important;
    transform-origin:center center !important;
    flex:0 0 auto !important;
  }

  .service-icon::before,
  .service-icon::after{
    box-sizing:border-box !important;
  }

  .service-card h3{
    margin:0 0 8px !important;
    max-width:250px !important;
  }

  .service-card p{
    max-width:290px !important;
    margin:0 auto !important;
  }
}

@media (max-width:430px){
  .service-card{
    padding:22px 14px 18px !important;
    border-radius:14px !important;
  }

  .service-icon{
    width:54px !important;
    height:46px !important;
    margin-bottom:8px !important;
    transform:scale(.72) !important;
  }

  .service-card h3{
    font-size:16px !important;
    line-height:1.2 !important;
  }

  .service-card p{
    font-size:12.8px !important;
    line-height:1.56 !important;
    max-width:250px !important;
  }
}


@keyframes innerShieldPulse{
  0%,100%{opacity:.82; transform:translateY(0) scale(1);}
  50%{opacity:1; transform:translateY(-1px) scale(1.04);}
}


/* --- clean and stable service icons in "Kompleksowa opieka" --- */
.services__grid .service-card{
  text-align:center !important;
}

.services__grid .service-icon{
  position:relative !important;
  display:block !important;
  width:64px !important;
  height:56px !important;
  margin:0 auto 12px !important;
  color:#1b5cff !important;
  transform:none !important;
  background:none !important;
  flex:0 0 auto !important;
}

.services__grid .service-icon::before,
.services__grid .service-icon::after{
  content:"" !important;
  position:absolute !important;
  box-sizing:border-box !important;
}

/* Stała opieka techniczna */
.services__grid .monitor::before{
  left:8px !important;
  top:6px !important;
  width:48px !important;
  height:31px !important;
  border:3px solid currentColor !important;
  border-radius:9px !important;
  background:transparent !important;
}
.services__grid .monitor::after{
  left:20px !important;
  top:41px !important;
  width:24px !important;
  height:10px !important;
  background:currentColor !important;
  border-radius:8px 8px 10px 10px !important;
  clip-path:polygon(28% 0,72% 0,80% 40%,100% 40%,100% 100%,0 100%,0 40%,20% 40%) !important;
  box-shadow:none !important;
}

/* Poprawki i rozwój */
.services__grid .code::before{
  content:"</>" !important;
  left:8px !important;
  top:9px !important;
  width:48px !important;
  height:28px !important;
  display:grid !important;
  place-items:center !important;
  color:currentColor !important;
  font-size:20px !important;
  font-weight:900 !important;
  letter-spacing:-0.08em !important;
  background:transparent !important;
  border:none !important;
  box-shadow:none !important;
}
.services__grid .code::after{
  left:16px !important;
  top:43px !important;
  width:32px !important;
  height:4px !important;
  border-radius:999px !important;
  background:currentColor !important;
}

/* SEO */
.services__grid .seo::before{
  left:10px !important;
  top:6px !important;
  width:28px !important;
  height:28px !important;
  border:4px solid currentColor !important;
  border-radius:50% !important;
  background:transparent !important;
  box-shadow:none !important;
}
.services__grid .seo::after{
  left:35px !important;
  top:31px !important;
  width:21px !important;
  height:5px !important;
  background:currentColor !important;
  border-radius:999px !important;
  transform:rotate(45deg) !important;
  transform-origin:left center !important;
}

/* Bezpieczeństwo i kopie zapasowe — prosta tarcza */
.services__grid .backup::before{
  left:17px !important;
  top:5px !important;
  width:30px !important;
  height:36px !important;
  border:4px solid currentColor !important;
  border-radius:0 !important;
  background:transparent !important;
  clip-path:polygon(50% 0,84% 12%,84% 56%,50% 100%,16% 56%,16% 12%) !important;
  filter:none !important;
  animation:none !important;
}
.services__grid .backup::after{
  display:none !important;
}

/* Szybkość */
.services__grid .meter::before{
  left:12px !important;
  top:16px !important;
  width:40px !important;
  height:24px !important;
  border:4px solid currentColor !important;
  border-bottom:0 !important;
  border-radius:40px 40px 0 0 !important;
  background:transparent !important;
}
.services__grid .meter::after{
  left:31px !important;
  top:25px !important;
  width:4px !important;
  height:18px !important;
  background:currentColor !important;
  border-radius:999px !important;
  transform:rotate(38deg) !important;
  transform-origin:bottom center !important;
}

/* Kontakt i wsparcie */
.services__grid .support::before{
  left:12px !important;
  top:9px !important;
  width:40px !important;
  height:28px !important;
  border:4px solid currentColor !important;
  border-bottom:0 !important;
  border-radius:26px 26px 0 0 !important;
  background:transparent !important;
}
.services__grid .support::after{
  left:12px !important;
  top:24px !important;
  width:40px !important;
  height:15px !important;
  background:
    linear-gradient(currentColor,currentColor) left 0 top 0 / 4px 15px no-repeat,
    linear-gradient(currentColor,currentColor) right 0 top 0 / 4px 15px no-repeat,
    linear-gradient(currentColor,currentColor) center bottom / 18px 4px no-repeat;
  border-radius:0 !important;
}

/* Mobile stability */
@media (max-width:720px){
  .services__grid .service-card{
    display:flex !important;
    flex-direction:column !important;
    align-items:center !important;
    justify-content:flex-start !important;
    padding:22px 16px 19px !important;
    overflow:hidden !important;
  }

  .services__grid .service-icon{
    width:58px !important;
    height:50px !important;
    margin:0 auto 10px !important;
  }

  .services__grid .monitor::before{left:7px !important; top:6px !important; width:44px !important; height:28px !important;}
  .services__grid .monitor::after{left:18px !important; top:38px !important; width:22px !important; height:9px !important;}

  .services__grid .code::before{left:7px !important; top:8px !important; width:44px !important; height:26px !important; font-size:18px !important;}
  .services__grid .code::after{left:15px !important; top:39px !important; width:28px !important;}

  .services__grid .seo::before{left:9px !important; top:5px !important; width:26px !important; height:26px !important;}
  .services__grid .seo::after{left:32px !important; top:29px !important; width:18px !important;}

  .services__grid .backup::before{left:15px !important; top:4px !important; width:28px !important; height:33px !important;}

  .services__grid .meter::before{left:10px !important; top:14px !important; width:36px !important; height:22px !important;}
  .services__grid .meter::after{left:28px !important; top:22px !important; height:17px !important;}

  .services__grid .support::before{left:10px !important; top:8px !important; width:36px !important; height:26px !important;}
  .services__grid .support::after{left:10px !important; top:22px !important; width:36px !important; height:14px !important;}

  .services__grid .service-card h3{
    max-width:250px !important;
    margin:0 0 8px !important;
  }

  .services__grid .service-card p{
    max-width:290px !important;
    margin:0 auto !important;
  }
}

@media (max-width:430px){
  .services__grid .service-card{
    padding:20px 14px 17px !important;
  }

  .services__grid .service-icon{
    width:54px !important;
    height:46px !important;
    margin-bottom:9px !important;
  }

  .services__grid .service-card h3{
    font-size:16px !important;
    line-height:1.2 !important;
  }

  .services__grid .service-card p{
    font-size:12.8px !important;
    line-height:1.55 !important;
    max-width:250px !important;
  }
}


/* --- remove icons from "Kompleksowa opieka" section --- */
.services__grid .service-icon{
  display:none !important;
}

.services__grid .service-card{
  display:flex !important;
  flex-direction:column !important;
  justify-content:center !important;
  align-items:center !important;
  text-align:center !important;
  min-height:165px !important;
  padding:24px 18px !important;
}

.services__grid .service-card h3{
  margin:0 0 10px !important;
}

.services__grid .service-card p{
  margin:0 auto !important;
  max-width:260px !important;
}

@media (max-width:720px){
  .services__grid .service-card{
    min-height:auto !important;
    padding:22px 16px !important;
  }

  .services__grid .service-card h3{
    margin:0 0 8px !important;
  }

  .services__grid .service-card p{
    max-width:300px !important;
  }
}


/* --- fixed topbar: follows the user while scrolling --- */
body{
  padding-top:70px;
}

.topbar{
  position:fixed !important;
  top:0 !important;
  left:0 !important;
  right:0 !important;
  width:100% !important;
  z-index:9999 !important;
  background:rgba(255,255,255,.94) !important;
  border-bottom:1px solid rgba(10,27,61,.10) !important;
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
  box-shadow:0 8px 28px rgba(7,22,51,.055);
}

.mobile-menu{
  position:fixed !important;
  z-index:9998 !important;
}

@media (max-width:920px){
  body{
    padding-top:66px;
  }
}

@media (max-width:430px){
  body{
    padding-top:62px;
  }
}
