/* ═══════════════════════════════
   DESIGN TOKENS
═══════════════════════════════ */
:root {
  --blue:       #2457D9;
  --blue-mid:   #1A3FB5;
  --blue-lt:    #EEF3FF;
  --blue-lt2:   #D4E2FF;
  --surface:    #FFFFFF;
  --surface-2:  #F6F8FE;
  --surface-3:  #EDF0F9;
  --text:       #0F1728;
  --text-2:     #4A5568;
  --text-3:     #8896AB;
  --border:     #DFE5F2;
  --green:      #059669;
  --orange:     #EA580C;
  --violet:     #7C3AED;
  --yellow:     #D97706;
  --cyan:       #0284C7;
  --sh-sm:  0 1px 4px rgba(36,87,217,.07);
  --sh-md:  0 4px 20px rgba(36,87,217,.10);
  --sh-lg:  0 16px 48px rgba(36,87,217,.14);
  --card-bg:   #FFFFFF;
  --nav-bg:    rgba(255,255,255,.97);
  --body-bg:   #FFFFFF;
  --overlay-bg: rgba(15,23,40,.38);
  --scrim-start: rgba(255,255,255,.94);
  --scrim-mid: rgba(255,255,255,.74);
  --scrim-end: rgba(255,255,255,.14);
  --footer-bg: #0F1728;
  --footer-border: transparent;
  --svc-bg-n: rgba(36,87,217,.035);
}

[data-theme="dark"] {
  --surface:    #0F172A;
  --surface-2:  #1E293B;
  --surface-3:  #334155;
  --text:       #F1F5F9;
  --text-2:     #94A3B8;
  --text-3:     #64748B;
  --border:     #334155;
  --blue-lt:    #1E3A5F;
  --blue-lt2:   #1E3A5F;
  --sh-sm:  0 1px 4px rgba(0,0,0,.4);
  --sh-md:  0 4px 20px rgba(0,0,0,.5);
  --sh-lg:  0 16px 48px rgba(0,0,0,.6);
  --card-bg:   #253347;
  --nav-bg:    rgba(15,23,42,.92);
  --body-bg:   #0F172A;
  --overlay-bg: rgba(0,0,0,.6);
  --scrim-start: rgba(15,23,42,.94);
  --scrim-mid: rgba(15,23,42,.78);
  --scrim-end: rgba(15,23,42,.2);
  --footer-bg: #0F172A;
  --footer-border: rgba(255,255,255,.08);
  --svc-bg-n: rgba(255,255,255,.1);
}

/* ═══════════════════════════════
   BASE
═══════════════════════════════ */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; transition:background .3s,color .3s; }
body { font-family:'DM Sans',sans-serif; background:var(--body-bg); color:var(--text); overflow-x:hidden; cursor:none; transition:background .3s,color .3s; }

/* ── CURSOR ── */
#cur  { position:fixed; width:10px; height:10px; background:var(--blue); border-radius:50%; pointer-events:none; z-index:9999; transform:translate(-50%,-50%); transition:width .25s,height .25s; }
#ring { position:fixed; width:34px; height:34px; border:1.5px solid rgba(36,87,217,.3); border-radius:50%; pointer-events:none; z-index:9998; transform:translate(-50%,-50%); transition:left .07s,top .07s,width .25s,height .25s; }

/* ═══════════════════════════════
   HEADER — two rows
═══════════════════════════════ */
.hd-top {
  background:var(--blue);
  height:38px; padding:0 48px;
  display:flex; align-items:center; justify-content:space-between;
  gap:16px;
}
.hd-phone {
  display:flex; align-items:center; gap:7px;
  font-size:13px; font-weight:600; color:#fff; text-decoration:none;
  transition:opacity .2s; white-space:nowrap;
}
.hd-phone:hover { opacity:.8; }
.hd-messengers { display:flex; align-items:center; gap:5px; }
.msg {
  width:26px; height:26px; border-radius:7px;
  background:rgba(255,255,255,.15); border:1px solid rgba(255,255,255,.1);
  display:flex; align-items:center; justify-content:center;
  text-decoration:none; color:#fff; font-size:11px; font-weight:800;
  transition:background .2s, transform .15s; flex-shrink:0;
}
.msg:hover { background:rgba(255,255,255,.3); transform:scale(1.1); }
.msg svg { width:14px; height:14px; display:block; }
.hd-right { display:flex; align-items:center; gap:20px; }
.hd-right a { font-size:12px; color:rgba(255,255,255,.8); text-decoration:none; transition:color .15s; }
.hd-right a:hover { color:#fff; }
.hd-right span { font-size:12px; color:rgba(255,255,255,.55); }

/* Main nav */
nav {
  position:sticky; top:0; z-index:500;
  height:62px; padding:0 48px;
  background:var(--nav-bg);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
  display:flex; align-items:center; gap:16px;
  box-shadow:var(--sh-sm);
  transition:background .3s;
}
.nav-logo { font-family:'Syne',sans-serif; font-weight:800; font-size:15px; letter-spacing:-1px; color:var(--text); text-decoration:none; flex-shrink:0; }
.nav-logo span { color:var(--blue); font-style:italic; }

.nav-links { display:flex; list-style:none; flex:1; }
.nav-links li { position:relative; }
.nav-links a { display:block; padding:8px 13px; font-size:13px; font-weight:500; color:var(--text-2); text-decoration:none; white-space:nowrap; transition:color .2s; }
.nav-links a:hover { color:var(--blue); }
.nav-links li:hover .drop { opacity:1; pointer-events:all; transform:translateY(0); }
.drop {
  position:absolute; top:calc(100% + 6px); left:0; min-width:196px;
  background:var(--card-bg); border:1px solid var(--border); border-radius:12px; padding:6px;
  opacity:0; pointer-events:none; transform:translateY(-7px); transition:all .18s;
  box-shadow:var(--sh-md);
}
.drop::before {
  content:''; position:absolute; top:-12px; left:0; right:0; height:12px;
}
.drop a { display:block; padding:8px 13px; border-radius:8px; font-size:13px; color:var(--text-2); transition:background .12s,color .12s; }
.drop a:hover { background:var(--blue-lt); color:var(--blue); }

/* Search */
.nav-search { position:relative; flex-shrink:0; }
.nav-search input {
  width:210px; height:34px; border:1.5px solid var(--border); border-radius:100px;
  padding:0 34px 0 13px; font-family:'DM Sans',sans-serif; font-size:13px; color:var(--text);
  background:var(--surface-2); outline:none;
  transition:border-color .2s,width .3s,box-shadow .2s,background .3s,color .3s;
}
.nav-search input:focus { border-color:var(--blue); box-shadow:0 0 0 3px rgba(36,87,217,.09); width:260px; background:var(--card-bg); }
.nav-search input::placeholder { color:var(--text-3); }
.nav-search-ico {
  position:absolute; right:10px; top:50%; transform:translateY(-50%);
  background:none; border:none; cursor:pointer; color:var(--text-3); display:flex; align-items:center;
  transition:color .18s;
}
.nav-search-ico:hover { color:var(--blue); }
.nav-search-ico svg { width:14px; height:14px; }

.nav-cta {
  padding:8px 20px; background:var(--blue); border-radius:100px;
  font-size:13px; font-weight:700; color:#fff; text-decoration:none; flex-shrink:0;
  box-shadow:0 4px 12px rgba(36,87,217,.28);
  transition:background .2s,transform .15s,box-shadow .2s;
}
.nav-cta:hover { background:var(--blue-mid); transform:translateY(-1px); box-shadow:0 8px 20px rgba(36,87,217,.34); }

/* Hamburger */
.nav-hamburger {
  display:none; width:36px; height:36px; border:none; background:none;
  cursor:pointer; flex-shrink:0; align-items:center; justify-content:center;
  color:var(--text); padding:0;
}
.nav-hamburger svg { width:22px; height:22px; }

/* Mobile drawer */
.mob-overlay {
  position:fixed; inset:0; z-index:999;
  background:rgba(0,0,0,.4); opacity:0; pointer-events:none;
  transition:opacity .3s;
}
.mob-overlay.open { opacity:1; pointer-events:all; }
.mob-drawer {
  position:fixed; top:0; right:0; bottom:0; z-index:1000;
  width:100%;
  background:var(--card-bg); border-left:1px solid var(--border);
  padding:24px 20px;
  display:flex; flex-direction:column; gap:6px;
  transform:translateX(100%); transition:transform .3s cubic-bezier(.22,.68,0,1);
  box-shadow:-6px 0 30px rgba(0,0,0,.1);
  overflow-y:auto;
}
.mob-drawer.open { transform:translateX(0); }
.mob-drawer-hd {
  display:flex; align-items:center; justify-content:flex-end; margin-bottom:4px;
}
.mob-drawer-close {
  width:34px; height:34px; border-radius:50%;
  border:1.5px solid var(--border); background:none;
  cursor:pointer; display:flex; align-items:center; justify-content:center;
  color:var(--text-2); font-size:18px; transition:background .12s,color .12s;
}
.mob-drawer-close:hover { background:var(--blue-lt); color:var(--blue); }
.mob-drawer a {
  display:block; padding:11px 14px; border-radius:10px;
  font-size:14px; font-weight:500; color:var(--text-2); text-decoration:none;
  transition:background .12s,color .12s;
}
.mob-drawer a:hover { background:var(--blue-lt); color:var(--blue); }
.mob-drawer .mob-main { font-weight:700; color:var(--text); }
.mob-toggle {
  display:flex; align-items:center; justify-content:space-between; cursor:pointer;
}
.mob-toggle span { transition:transform .25s; font-size:12px; margin-left:auto; }
.mob-toggle.open span { transform:rotate(180deg); }
.mob-sub-wrap { display:none; }
.mob-sub-wrap.open { display:block; }
.mob-drawer .mob-sub { padding-left:28px; font-size:13px; }
.mob-drawer .nav-cta { text-align:center; margin-top:12px; }

/* Theme toggle */
.theme-toggle {
  width:34px; height:34px; border-radius:50%;
  border:1.5px solid var(--border); background:var(--card-bg);
  cursor:pointer; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  color:var(--text-2); font-size:16px;
  transition:background .2s,border-color .2s,color .2s,transform .15s;
  box-shadow:var(--sh-sm);
}
.theme-toggle:hover { border-color:var(--blue); color:var(--blue); transform:scale(1.08); }

/* Search modal */
.s-overlay {
  position:fixed; inset:0; z-index:600;
  background:var(--overlay-bg); backdrop-filter:blur(5px);
  -webkit-backdrop-filter:blur(5px);
  display:none; align-items:flex-start; justify-content:center; padding-top:110px;
}
.s-overlay.open { display:flex; animation:fadeUp .2s ease; }
.s-box { background:var(--card-bg); border-radius:20px; width:620px; max-width:92vw; box-shadow:var(--sh-lg); overflow:hidden; transition:background .3s; }
.s-row { display:flex; align-items:center; gap:12px; padding:16px 18px; border-bottom:1px solid var(--border); }
.s-row svg { width:18px; height:18px; flex-shrink:0; color:var(--text-3); }
.s-row input { flex:1; border:none; outline:none; font-size:16px; font-family:'DM Sans',sans-serif; color:var(--text); background:transparent; }
.s-row input::placeholder { color:var(--text-3); }
.s-close { background:none; border:none; font-size:18px; cursor:pointer; color:var(--text-3); line-height:1; padding:2px 4px; }
.s-hints { padding:14px 18px; }
.s-hints p { font-size:11px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; color:var(--text-3); margin-bottom:9px; }
.s-tags { display:flex; flex-wrap:wrap; gap:7px; }
.s-tag { padding:5px 13px; border-radius:100px; background:var(--surface-2); border:1px solid var(--border); font-size:12.5px; color:var(--text-2); cursor:pointer; transition:background .12s,color .12s,border-color .12s; }
.s-tag:hover { background:var(--blue-lt); border-color:var(--blue-lt2); color:var(--blue); }

/* ═══════════════════════════════
   HERO SLIDER
═══════════════════════════════ */
.hero-slider { position:relative; width:100%; height:calc(100vh - 100px); min-height:560px; overflow:hidden; }
.slide { position:absolute; inset:0; display:flex; align-items:center; padding:56px 48px 76px; opacity:0; transition:opacity .85s; pointer-events:none; }
.slide.active { opacity:1; pointer-events:all; z-index:2; }
.slide-bg { position:absolute; inset:0; overflow:hidden; }
.slide-bg img { width:100%; height:100%; display:block; object-fit:cover; }
.slide-scrim {
  position:absolute; inset:0; z-index:1;
  background:linear-gradient(108deg, var(--scrim-start) 0%, var(--scrim-mid) 42%, var(--scrim-end) 100%);
  transition:background .5s;
}
.slide-grid {
  position:absolute; inset:0; z-index:1;
  background-image:linear-gradient(rgba(36,87,217,.055) 1px,transparent 1px),linear-gradient(90deg,rgba(36,87,217,.055) 1px,transparent 1px);
  background-size:60px 60px;
}
.slide-content { position:relative; z-index:3; max-width:620px; }

.eyebrow {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--blue-lt); border:1px solid var(--blue-lt2); border-radius:100px;
  padding:5px 14px 5px 10px; font-size:11px; font-weight:700; letter-spacing:1.3px;
  text-transform:uppercase; color:var(--blue); margin-bottom:22px;
}
.eyebrow .dot { width:6px; height:6px; border-radius:50%; background:var(--blue); animation:pulse 2s ease-in-out infinite; }
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.35;transform:scale(.65)} }

.hero-title {
  font-family:'Syne',sans-serif; font-weight:800;
  font-size:clamp(40px,5.2vw,78px); line-height:.97; letter-spacing:-2.5px;
  color:var(--text); margin-bottom:18px;
}
.lb { color:var(--blue); }
.lg { background:linear-gradient(90deg,var(--blue),var(--cyan)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; }
.lo { background:linear-gradient(90deg,var(--orange),var(--yellow)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; }
.lv { background:linear-gradient(90deg,var(--violet),var(--blue)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; }

.hero-sub { font-size:16.5px; font-weight:300; line-height:1.72; color:var(--text-2); max-width:470px; margin-bottom:34px; }
.h-actions { display:flex; gap:13px; align-items:center; }

.btn-p {
  display:inline-flex; align-items:center; gap:8px;
  padding:13px 26px; background:var(--blue); border-radius:100px;
  font-size:14px; font-weight:700; color:#fff; text-decoration:none;
  box-shadow:0 8px 22px rgba(36,87,217,.28);
  transition:background .2s,transform .15s,box-shadow .2s;
}
.btn-p:hover { background:var(--blue-mid); transform:translateY(-2px); box-shadow:0 14px 30px rgba(36,87,217,.36); }
.btn-g {
  display:inline-flex; align-items:center; gap:8px;
  padding:13px 22px; border:1.5px solid var(--border); border-radius:100px;
  font-size:14px; font-weight:500; color:var(--text-2); text-decoration:none;
  transition:border-color .2s,color .2s,background .2s;
}
.btn-g:hover { border-color:var(--blue); color:var(--blue); background:var(--blue-lt); }

/* Stat cards */
.hero-stats { position:absolute; right:48px; top:50%; transform:translateY(-50%); z-index:4; display:flex; flex-direction:column; gap:11px; }
.stat-card { background:var(--card-bg); border:1px solid var(--border); border-radius:15px; padding:15px 19px; min-width:142px; box-shadow:var(--sh-md); transition:transform .2s,background .3s; }
.stat-card:hover { transform:translateX(-4px); }
.stat-n { font-family:'Syne',sans-serif; font-weight:800; font-size:30px; line-height:1; letter-spacing:-1px; }
.stat-n.c { color:var(--cyan); }
.stat-n.g { color:var(--green); }
.stat-n.v { color:var(--violet); }
.stat-l { font-size:11.5px; color:var(--text-3); margin-top:3px; }

/* Controls */
.sl-nav { position:absolute; bottom:26px; left:48px; z-index:5; display:flex; align-items:center; gap:14px; }
.dots { display:flex; gap:7px; }
.dot { width:22px; height:4px; border-radius:2px; background:rgba(36,87,217,.18); cursor:pointer; border:none; padding:0; transition:background .3s,width .3s; }
.dot.active { background:var(--blue); width:64px; }
.arrows { display:flex; gap:7px; }
.arrow { width:34px; height:34px; border-radius:50%; border:1.5px solid var(--border); background:var(--card-bg); color:var(--text-2); font-size:13px; cursor:pointer; display:flex; align-items:center; justify-content:center; box-shadow:var(--sh-sm); transition:background .2s,border-color .2s,color .2s; }
.arrow:hover { background:var(--blue); border-color:var(--blue); color:#fff; }
.sl-prog { position:absolute; bottom:0; left:0; right:0; height:3px; background:var(--border); z-index:5; }
.sl-bar { height:100%; background:var(--blue); width:0%; }

/* ═══════════════════════════════
   TICKER
═══════════════════════════════ */
.ticker { background:var(--blue); padding:12px 0; overflow:hidden; white-space:nowrap; }
.ticker-t { display:inline-flex; animation:tkr 22s linear infinite; }
.ti { font-family:'Syne',sans-serif; font-size:11.5px; font-weight:700; letter-spacing:2px; text-transform:uppercase; padding:0 28px; color:rgba(255,255,255,.9); }
.ts { color:rgba(255,255,255,.35); padding-right:28px; }
@keyframes tkr { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }

/* ═══════════════════════════════
   SECTIONS
═══════════════════════════════ */
.sec { padding:84px 48px; }
.sec-alt { background:var(--surface-2); }
.sec-tag { font-size:11px; font-weight:700; letter-spacing:2.5px; text-transform:uppercase; color:var(--blue); margin-bottom:13px; }
.sec-title { font-family:'Syne',sans-serif; font-weight:800; font-size:clamp(30px,3.3vw,48px); line-height:1.06; letter-spacing:-1.2px; color:var(--text); margin-bottom:48px; }
.sec-title em { font-style:normal; color:var(--blue); }
.page-header {
  display:flex; flex-direction:column; justify-content:center;
  min-height:240px;
}
@keyframes fadeUp { from{opacity:0;transform:translateY(26px)} to{opacity:1;transform:translateY(0)} }

/* ═══════════════════════════════
   SERVICES
═══════════════════════════════ */
.svc-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.svc-card {
  background:var(--card-bg); border:1px solid var(--border); border-radius:18px;
  padding:32px 28px; position:relative; overflow:hidden; cursor:pointer;
  transition:transform .22s,box-shadow .22s,border-color .22s,background .3s;
}
.svc-card:hover { transform:translateY(-5px); box-shadow:var(--sh-lg); border-color:var(--blue-lt2); }
.svc-card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--cc,var(--blue)); transform:scaleX(0); transform-origin:left; transition:transform .32s cubic-bezier(.4,0,.2,1); }
.svc-card:hover::before { transform:scaleX(1); }
.svc-card:nth-child(1){--cc:var(--blue)} .svc-card:nth-child(2){--cc:var(--cyan)} .svc-card:nth-child(3){--cc:var(--green)} .svc-card:nth-child(4){--cc:var(--orange)} .svc-card:nth-child(5){--cc:var(--violet)} .svc-card:nth-child(6){--cc:var(--yellow)}
.svc-ico { width:44px; height:44px; border-radius:11px; background:var(--blue-lt); display:flex; align-items:center; justify-content:center; font-size:19px; margin-bottom:18px; transition:transform .2s; }
.svc-card:hover .svc-ico { transform:scale(1.12) rotate(-6deg); }
.svc-nm { font-family:'Syne',sans-serif; font-weight:700; font-size:17px; color:var(--text); margin-bottom:9px; }
.svc-ds { font-size:13.5px; line-height:1.7; color:var(--text-2); margin-bottom:20px; }
.svc-lk { font-size:12.5px; font-weight:600; color:var(--cc,var(--blue)); text-decoration:none; display:inline-flex; align-items:center; gap:5px; transition:gap .2s; }
.svc-lk:hover { gap:9px; }
.svc-bg-n { position:absolute; bottom:12px; right:18px; font-family:'Syne',sans-serif; font-size:60px; font-weight:800; color:var(--svc-bg-n); line-height:1; pointer-events:none; }

/* ═══════════════════════════════
   PROCESS
═══════════════════════════════ */
.proc-row { display:grid; grid-template-columns:repeat(4,1fr); position:relative; }
.proc-row::before { content:''; position:absolute; top:33px; left:12.5%; right:12.5%; height:1px; background:linear-gradient(90deg,transparent,var(--blue-lt2),transparent); }
.step { padding:0 18px 36px; text-align:center; }
.step-n {
  width:66px; height:66px; border-radius:50%; border:2px solid var(--blue-lt2);
  display:flex; align-items:center; justify-content:center; margin:0 auto 18px;
  font-family:'Syne',sans-serif; font-weight:800; font-size:18px; color:var(--blue);
  background:var(--card-bg); position:relative; z-index:1; box-shadow:var(--sh-sm);
  transition:background .28s,color .28s,border-color .28s,box-shadow .28s;
}
.step:hover .step-n { background:var(--blue); color:#fff; border-color:var(--blue); box-shadow:0 8px 22px rgba(36,87,217,.28); }
.step-t { font-family:'Syne',sans-serif; font-weight:700; font-size:15.5px; color:var(--text); margin-bottom:7px; }
.step-d { font-size:13px; color:var(--text-2); line-height:1.65; }

/* ═══════════════════════════════
   PORTFOLIO
═══════════════════════════════ */
.port-strip { padding:76px 0; background:var(--card-bg); transition:background .3s; }
.port-strip .sec-tag, .port-strip .sec-title { padding:0 48px; }
.port-strip .sec-title { margin-bottom:26px; }
.port-scroll { display:flex; gap:16px; padding:0 48px; overflow-x:auto; scrollbar-width:none; cursor:grab; }
.port-scroll::-webkit-scrollbar { display:none; }
.p-card { flex:0 0 308px; height:208px; border-radius:16px; position:relative; overflow:hidden; border:1px solid var(--border); box-shadow:var(--sh-sm); transition:transform .28s,box-shadow .28s; }
.p-card:hover { transform:translateY(-6px); box-shadow:var(--sh-lg); }
.p-bg { position:absolute; inset:0; }
.p-in { position:absolute; inset:0; display:flex; flex-direction:column; justify-content:flex-end; padding:18px; background:linear-gradient(to top,rgba(8,16,40,.88) 30%,transparent); }
.p-tag { font-size:9.5px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; margin-bottom:4px; }
.p-nm  { font-family:'Syne',sans-serif; font-weight:700; font-size:16px; color:#fff; }
.p-tag.bl{color:#93c5fd} .p-tag.gr{color:#6ee7b7} .p-tag.vi{color:#c4b5fd} .p-tag.or{color:#fdba74} .p-tag.ye{color:#fde68a}
.p-card:nth-child(1) .p-bg{background:linear-gradient(135deg,#0f2570,#2457d9,#60a5fa)}
.p-card:nth-child(2) .p-bg{background:linear-gradient(135deg,#064e3b,#059669,#6ee7b7)}
.p-card:nth-child(3) .p-bg{background:linear-gradient(135deg,#2e1065,#7c3aed,#a78bfa)}
.p-card:nth-child(4) .p-bg{background:linear-gradient(135deg,#7c2d12,#ea580c,#fb923c)}
.p-card:nth-child(5) .p-bg{background:linear-gradient(135deg,#78350f,#d97706,#fcd34d)}
.p-card:nth-child(6) .p-bg{background:linear-gradient(135deg,#0c4a6e,#0284c7,#38bdf8)}

/* ═══════════════════════════════
   PROMO BAND
═══════════════════════════════ */
.promo { margin:24px 48px; background:linear-gradient(128deg,var(--blue-mid),var(--blue)); border-radius:22px; padding:52px 56px; display:flex; align-items:center; justify-content:space-between; gap:32px; position:relative; overflow:hidden; box-shadow:var(--sh-lg); }
.promo::before { content:''; position:absolute; top:-70px; right:-50px; width:280px; height:280px; border-radius:50%; background:rgba(255,255,255,.07); }
.promo h2 { font-family:'Syne',sans-serif; font-weight:800; font-size:clamp(22px,2.5vw,36px); line-height:1.12; letter-spacing:-.7px; color:#fff; margin-bottom:10px; }
.promo p  { font-size:14.5px; color:rgba(255,255,255,.74); line-height:1.65; max-width:400px; }
.promo-act { display:flex; gap:11px; flex-shrink:0; position:relative; z-index:1; }
.btn-wh { padding:13px 26px; background:#fff; border-radius:100px; font-size:13.5px; font-weight:700; color:var(--blue); text-decoration:none; transition:transform .14s,box-shadow .2s; white-space:nowrap; }
.btn-wh:hover { transform:translateY(-2px); box-shadow:0 10px 24px rgba(0,0,0,.16); }
.btn-ow { padding:13px 22px; border:1.5px solid rgba(255,255,255,.4); border-radius:100px; font-size:13.5px; font-weight:600; color:#fff; text-decoration:none; transition:border-color .2s,background .2s; white-space:nowrap; }
.btn-ow:hover { border-color:#fff; background:rgba(255,255,255,.1); }

/* ═══════════════════════════════
   WHY US
═══════════════════════════════ */
.why-grid { display:grid; grid-template-columns:1fr 1fr; gap:15px; margin-top:48px; }
.why-item { background:var(--card-bg); border:1px solid var(--border); border-radius:17px; padding:28px 26px; display:flex; gap:16px; align-items:flex-start; transition:transform .2s,box-shadow .2s,border-color .2s,background .3s; }
.why-item:hover { transform:translateY(-4px); box-shadow:var(--sh-md); border-color:var(--blue-lt2); }
.why-ico { width:42px; height:42px; flex-shrink:0; border-radius:11px; display:flex; align-items:center; justify-content:center; font-size:19px; }
.why-item:nth-child(1) .why-ico { background:#dbeafe; }
.why-item:nth-child(2) .why-ico { background:#d1fae5; }
.why-item:nth-child(3) .why-ico { background:#ede9fe; }
.why-item:nth-child(4) .why-ico { background:#ffedd5; }
.why-body h3 { font-family:'Syne',sans-serif; font-weight:700; font-size:16.5px; color:var(--text); margin-bottom:6px; }
.why-body p  { font-size:13.5px; color:var(--text-2); line-height:1.7; }

/* ═══════════════════════════════
   POPULAR SERVICES
═══════════════════════════════ */
.pop-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:15px; margin-top:44px; }
.pop-card {
  background:var(--card-bg); border:1px solid var(--border); border-radius:18px;
  padding:24px 20px; display:flex; flex-direction:column; gap:11px; cursor:pointer;
  transition:transform .22s,box-shadow .22s,border-color .22s,background .3s;
}
.pop-card:hover { transform:translateY(-6px); box-shadow:var(--sh-lg); border-color:var(--blue-lt2); }
.pop-ico { width:44px; height:44px; border-radius:12px; display:flex; align-items:center; justify-content:center; font-size:19px; transition:transform .22s; }
.pop-card:hover .pop-ico { transform:scale(1.1) rotate(-6deg); }
.pop-card:nth-child(1) .pop-ico{background:#dbeafe;} .pop-card:nth-child(1){--pc:var(--blue)}
.pop-card:nth-child(2) .pop-ico{background:#fee2e2;} .pop-card:nth-child(2){--pc:var(--orange)}
.pop-card:nth-child(3) .pop-ico{background:#d1fae5;} .pop-card:nth-child(3){--pc:var(--green)}
.pop-card:nth-child(4) .pop-ico{background:#ede9fe;} .pop-card:nth-child(4){--pc:var(--violet)}
.pop-card:nth-child(5) .pop-ico{background:#fef3c7;} .pop-card:nth-child(5){--pc:var(--yellow)}
.pop-nm  { font-family:'Syne',sans-serif; font-weight:700; font-size:14px; color:var(--text); line-height:1.3; }
.pop-ds  { font-size:12.5px; color:var(--text-2); line-height:1.65; flex:1; }
.pop-pr  { font-family:'Syne',sans-serif; font-weight:800; font-size:16.5px; color:var(--pc,var(--blue)); letter-spacing:-.3px; }
.pop-lk  { display:inline-flex; align-items:center; gap:5px; font-size:12px; font-weight:600; color:var(--pc,var(--blue)); text-decoration:none; transition:gap .2s; }
.pop-lk:hover { gap:9px; }

/* ═══════════════════════════════
   PRICING
═══════════════════════════════ */
.price-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:48px; }
.price-card { background:var(--card-bg); border:1px solid var(--border); border-radius:18px; padding:36px 30px; position:relative; overflow:hidden; transition:transform .22s,box-shadow .22s,background .3s; }
.price-card:hover { transform:translateY(-5px); box-shadow:var(--sh-lg); }
.price-card.feat { background:var(--blue); border-color:transparent; box-shadow:0 20px 56px rgba(36,87,217,.28); }
.price-card.feat::before { content:'Популярный'; position:absolute; top:16px; right:-24px; background:var(--card-bg); color:var(--blue); font-size:9px; font-weight:800; letter-spacing:1.2px; text-transform:uppercase; padding:4px 36px; transform:rotate(35deg); transition:background .3s; }
.pr-nm { font-size:11px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--text-3); margin-bottom:16px; }
.feat .pr-nm { color:rgba(255,255,255,.65); }
.pr-amt { font-family:'Syne',sans-serif; font-weight:800; font-size:46px; line-height:1; letter-spacing:-2px; color:var(--text); }
.feat .pr-amt { color:#fff; }
.pr-amt sup { font-size:18px; font-weight:600; vertical-align:super; letter-spacing:0; }
.pr-per { font-size:12px; color:var(--text-3); margin-top:3px; margin-bottom:22px; }
.feat .pr-per { color:rgba(255,255,255,.58); }
.pr-desc { font-size:13px; color:var(--text-2); line-height:1.6; margin-bottom:22px; padding-bottom:22px; border-bottom:1px solid var(--border); }
.feat .pr-desc { color:rgba(255,255,255,.78); border-bottom-color:rgba(255,255,255,.18); }
.pr-feats { list-style:none; display:flex; flex-direction:column; gap:10px; margin-bottom:28px; }
.pr-feat { display:flex; align-items:flex-start; gap:8px; font-size:13.5px; color:var(--text-2); line-height:1.5; }
.feat .pr-feat { color:rgba(255,255,255,.82); }
.pr-feat-i { flex-shrink:0; margin-top:1px; color:var(--green); font-weight:700; }
.feat .pr-feat-i { color:#86efac; }
.pr-feat.no { opacity:.38; }
.pr-feat.no .pr-feat-i { color:var(--text-3); }
.btn-pr { display:block; text-align:center; padding:12px 20px; border-radius:100px; font-size:13.5px; font-weight:700; text-decoration:none; transition:transform .14s,box-shadow .2s,background .2s; }
.btn-pr-ol { border:1.5px solid var(--blue-lt2); color:var(--blue); background:var(--blue-lt); }
.btn-pr-ol:hover { background:var(--blue); color:#fff; border-color:var(--blue); transform:translateY(-2px); box-shadow:0 8px 18px rgba(36,87,217,.22); }
.btn-pr-so { background:rgba(255,255,255,.18); color:#fff; border:1.5px solid rgba(255,255,255,.28); }
.btn-pr-so:hover { background:rgba(255,255,255,.3); transform:translateY(-2px); }
.pr-note { text-align:center; font-size:12.5px; color:var(--text-3); margin-top:22px; }
.pr-note a { color:var(--blue); text-decoration:none; }

/* ═══════════════════════════════
   NEWS
═══════════════════════════════ */
.news-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:44px; }
.news-card { background:var(--card-bg); border:1px solid var(--border); border-radius:18px; overflow:hidden; display:flex; flex-direction:column; transition:transform .22s,box-shadow .22s,border-color .22s,background .3s; }
.news-card:hover { transform:translateY(-5px); box-shadow:var(--sh-lg); border-color:var(--blue-lt2); }
.news-img { height:172px; position:relative; overflow:hidden; flex-shrink:0; }
.news-img-bg { position:absolute; inset:0; }
.news-card:nth-child(1) .news-img-bg { background:linear-gradient(135deg,#0f2570,#2457d9,#60a5fa); }
.news-card:nth-child(2) .news-img-bg { background:linear-gradient(135deg,#064e3b,#059669,#6ee7b7); }
.news-card:nth-child(3) .news-img-bg { background:linear-gradient(135deg,#2e1065,#7c3aed,#c4b5fd); }
.news-lbl { position:absolute; bottom:11px; left:13px; background:rgba(255,255,255,.14); backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px); border:1px solid rgba(255,255,255,.18); border-radius:100px; padding:3px 11px; font-size:10.5px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:#fff; }
.news-body { padding:20px 20px 24px; flex:1; display:flex; flex-direction:column; gap:9px; }
.news-meta { display:flex; align-items:center; gap:9px; }
.news-date { font-size:11.5px; color:var(--text-3); }
.news-cat  { font-size:10.5px; font-weight:700; letter-spacing:.7px; text-transform:uppercase; color:var(--blue); background:var(--blue-lt); border-radius:100px; padding:2px 10px; }
.news-title { font-family:'Syne',sans-serif; font-weight:700; font-size:15.5px; line-height:1.42; color:var(--text); text-decoration:none; flex:1; transition:color .18s; }
.news-title:hover { color:var(--blue); }
.news-ex { font-size:13px; color:var(--text-2); line-height:1.65; }
.news-lk { font-size:12.5px; font-weight:600; color:var(--blue); text-decoration:none; display:inline-flex; align-items:center; gap:5px; margin-top:auto; transition:gap .2s; }
.news-lk:hover { gap:9px; }
.news-more { display:flex; justify-content:center; margin-top:30px; }
.btn-more { display:inline-flex; align-items:center; gap:8px; padding:11px 26px; border:1.5px solid var(--blue-lt2); border-radius:100px; font-size:13.5px; font-weight:600; color:var(--blue); text-decoration:none; background:var(--blue-lt); transition:background .2s,border-color .2s,transform .14s; }
.btn-more:hover { background:var(--blue); color:#fff; border-color:var(--blue); transform:translateY(-2px); }

/* ═══════════════════════════════
   FOOTER
═══════════════════════════════ */
footer { background:var(--footer-bg); border-top:1px solid var(--footer-border); padding:60px 48px 30px; transition:background .3s,border-color .3s; }
.ft-top { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:44px; margin-bottom:48px; }
.ft-logo { font-family:'Syne',sans-serif; font-weight:800; font-size:22px; letter-spacing:-1px; color:#fff; margin-bottom:12px; }
.ft-logo span { color:#93c5fd; font-style:italic; }
.ft-desc { font-size:13px; color:rgba(255,255,255,.48); line-height:1.7; max-width:256px; margin-bottom:20px; }
.ft-social { display:flex; gap:7px; flex-wrap:wrap; }
.ft-soc { width:32px; height:32px; border-radius:8px; background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.1); display:flex; align-items:center; justify-content:center; font-size:11px; font-weight:800; text-decoration:none; color:rgba(255,255,255,.55); transition:background .2s,color .2s; }
.ft-soc:hover { background:var(--blue); color:#fff; border-color:transparent; }
.ft-col h4 { font-family:'Syne',sans-serif; font-weight:700; font-size:12.5px; letter-spacing:.5px; color:#fff; margin-bottom:14px; }
.ft-col a  { display:block; font-size:12.5px; color:rgba(255,255,255,.48); text-decoration:none; margin-bottom:8px; transition:color .18s; }
.ft-col a:hover { color:#fff; }
.ft-bot { display:flex; justify-content:space-between; align-items:center; padding-top:22px; border-top:1px solid rgba(255,255,255,.07); }
.ft-bot span { font-size:11.5px; color:rgba(255,255,255,.32); }
.ft-badge { display:inline-flex; align-items:center; gap:5px; background:rgba(36,87,217,.28); border:1px solid rgba(36,87,217,.48); border-radius:100px; padding:4px 12px; font-size:10.5px; color:#93c5fd; font-weight:700; letter-spacing:.5px; }

/* ═══════════════════════════════
   INFO PAGE CARDS
═══════════════════════════════ */
.info-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}
.info-card {
  display:flex; flex-direction:column; gap:14px;
  background:var(--card-bg); border:1px solid var(--border);
  border-radius:18px; padding:28px 24px;
  text-decoration:none;
  transition:transform .22s,box-shadow .22s,border-color .22s,background .3s;
  position:relative; overflow:hidden;
}
.info-card:hover { transform:translateY(-5px); box-shadow:var(--sh-lg); border-color:var(--blue-lt2); }
.info-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:var(--info-cc,var(--blue));
  transform:scaleX(0); transform-origin:left;
  transition:transform .32s cubic-bezier(.4,0,.2,1);
}
.info-card:hover::before { transform:scaleX(1); }
.info-card-ico {
  width:48px; height:48px; border-radius:12px;
  display:flex; align-items:center; justify-content:center;
  font-size:22px; flex-shrink:0;
  transition:transform .2s;
}
.info-card:hover .info-card-ico { transform:scale(1.1) rotate(-6deg); }
.info-card-nm {
  font-family:'Syne',sans-serif; font-weight:700;
  font-size:15px; color:var(--text); line-height:1.35;
  flex:1;
}
.info-card-lk {
  font-size:12.5px; font-weight:600; color:var(--blue);
  display:inline-flex; align-items:center; gap:5px;
  transition:gap .2s;
}
.info-card:hover .info-card-lk { gap:9px; }

/* ═══════════════════════════════
   INFO PAGE STATS
═══════════════════════════════ */
.info-stats {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:16px; margin-top:8px;
}
.info-stat {
  background:var(--card-bg); border:1px solid var(--border);
  border-radius:17px; padding:26px 24px;
  text-align:center;
  transition:transform .2s,box-shadow .2s,border-color .2s,background .3s;
}
.info-stat:hover { transform:translateY(-4px); box-shadow:var(--sh-md); border-color:var(--blue-lt2); }
.info-stat-n {
  font-family:'Syne',sans-serif; font-weight:800;
  font-size:36px; line-height:1; letter-spacing:-1px; margin-bottom:6px;
}
.info-stat-n.c { color:var(--cyan); }
.info-stat-n.g { color:var(--green); }
.info-stat-n.v { color:var(--violet); }
.info-stat-n.o { color:var(--orange); }
.info-stat-t {
  font-family:'Syne',sans-serif; font-weight:700;
  font-size:14px; color:var(--text); margin-bottom:8px;
}
.info-stat-d { font-size:13px; color:var(--text-2); line-height:1.65; }

/* ═══════════════════════════════
   PORTFOLIO PAGE
═══════════════════════════════ */
.pfltr { display:flex; flex-wrap:wrap; gap:7px; margin-bottom:0; }
.pfltr-btn {
  padding:7px 16px; border:1.5px solid var(--border); border-radius:100px;
  background:var(--card-bg); font-family:'DM Sans',sans-serif;
  font-size:12px; font-weight:500; color:var(--text-2); cursor:pointer;
  transition:background .18s,color .18s,border-color .18s;
  white-space:nowrap;
}
.pfltr-btn:hover { border-color:var(--blue-lt2); color:var(--blue); background:var(--blue-lt); }
.pfltr-btn.active { background:var(--blue); color:#fff; border-color:var(--blue); }

.pf-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:16px; }
.pf-item {
  display:flex; flex-direction:column; justify-content:flex-end;
  height:280px; border-radius:18px; position:relative; overflow:hidden;
  text-decoration:none; border:1px solid var(--border);
  transition:transform .28s,box-shadow .28s;
}
.pf-item:hover { transform:translateY(-6px); box-shadow:var(--sh-lg); }
.pf-item-bg { position:absolute; inset:0; }
.pf-item-scrim { position:absolute; inset:0; background:linear-gradient(to top,rgba(8,16,40,.92) 20%,transparent 60%); }
.pf-item-in { position:relative; z-index:2; padding:20px 22px; display:flex; flex-direction:column; gap:10px; }
.pf-item-tag {
  align-self:flex-start;
  font-size:9.5px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase;
  padding:4px 11px; border-radius:100px;
  background:rgba(255,255,255,.14); backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.18); color:#fff;
}
.pf-item-nm { font-family:'Syne',sans-serif; font-weight:700; font-size:15px; color:#fff; line-height:1.35; }
.pf-item-ds { font-size:12px; color:rgba(255,255,255,.65); line-height:1.55; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }

/* ═══════════════════════════════
   SERVICES PAGE
═══════════════════════════════ */
.us-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.us-card {
  background:var(--card-bg); border:1px solid var(--border); border-radius:18px;
  padding:32px 28px; position:relative; overflow:hidden; cursor:pointer;
  transition:transform .22s,box-shadow .22s,border-color .22s,background .3s;
  text-decoration:none; display:flex; flex-direction:column;
}
.us-card:hover { transform:translateY(-5px); box-shadow:var(--sh-lg); border-color:var(--blue-lt2); }
.us-card-ico {
  width:44px; height:44px; border-radius:11px;
  display:flex; align-items:center; justify-content:center;
  font-size:19px; margin-bottom:18px; transition:transform .2s;
}
.us-card:hover .us-card-ico { transform:scale(1.12) rotate(-6deg); }
.us-card-nm { font-family:'Syne',sans-serif; font-weight:700; font-size:17px; color:var(--text); margin-bottom:9px; }
.us-card-ds { font-size:13.5px; line-height:1.7; color:var(--text-2); margin-bottom:20px; flex:1; }
.us-card-lk { font-size:12.5px; font-weight:600; color:var(--us-cc,var(--blue)); text-decoration:none; display:inline-flex; align-items:center; gap:5px; transition:gap .2s; }
.us-card:hover .us-card-lk { gap:9px; }

/* ═══════════════════════════════
   SEO CASES PAGE
═══════════════════════════════ */
.kc-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(360px,1fr)); gap:18px; }
.kc-item {
  display:flex; flex-direction:column; justify-content:flex-end;
  min-height:340px; border-radius:18px; position:relative; overflow:hidden;
  text-decoration:none; border:1px solid var(--border);
  transition:transform .28s,box-shadow .28s;
}
.kc-item:hover { transform:translateY(-6px); box-shadow:var(--sh-lg); }
.kc-item-bg { position:absolute; inset:0; }
.kc-item-scrim { position:absolute; inset:0; background:linear-gradient(to top,rgba(8,16,40,.94) 15%,transparent 55%); }
.kc-item-in { position:relative; z-index:2; padding:22px 24px; }
.kc-item-nm { font-family:'Syne',sans-serif; font-weight:700; font-size:17px; color:#fff; line-height:1.35; margin-bottom:16px; }
.kc-stats { display:flex; gap:12px; flex-wrap:wrap; margin-bottom:14px; }
.kc-stat {
  flex:1; min-width:90px;
  background:rgba(255,255,255,.1); backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.15);
  border-radius:10px; padding:10px 12px; text-align:center;
}
.kc-stat-v { font-family:'Syne',sans-serif; font-weight:800; font-size:18px; color:#fff; letter-spacing:-.3px; }
.kc-stat-l { font-size:10.5px; color:rgba(255,255,255,.65); line-height:1.35; margin-top:2px; }
.kc-item-ds { font-size:12.5px; color:rgba(255,255,255,.7); line-height:1.5; }

/* ═══════════════════════════════
   PRICING PAGE (accordion)
═══════════════════════════════ */
.tr-grid { display:flex; flex-direction:column; gap:10px; }
.tr-card {
  background:var(--card-bg); border:1px solid var(--border); border-radius:18px;
  overflow:hidden; transition:background .3s,border-color .3s,box-shadow .3s;
}
.tr-card:hover { box-shadow:var(--sh-sm); border-color:var(--blue-lt2); }
.tr-card-hd {
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 24px; cursor:pointer; user-select:none; gap:16px;
  font-family:'Syne',sans-serif; font-weight:700; font-size:15px; color:var(--text);
  transition:background .15s;
}
.tr-card-hd:hover { background:var(--surface-2); }
.tr-card-hd .tr-arrow {
  flex-shrink:0; width:28px; height:28px; border-radius:50%;
  background:var(--surface-2); border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  font-size:11px; color:var(--text-3);
  transition:transform .28s,background .15s,color .15s,border-color .15s;
}
.tr-card.open .tr-card-hd .tr-arrow { transform:rotate(180deg); background:var(--blue); color:#fff; border-color:var(--blue); }
.tr-card-body { max-height:0; overflow:hidden; transition:max-height .35s cubic-bezier(.4,0,.2,1); }
.tr-card.open .tr-card-body { max-height:none; }
.tr-list { padding:0 24px 18px; }
.tr-item {
  display:flex; justify-content:space-between; align-items:center;
  padding:10px 0; gap:16px;
  border-bottom:1px solid var(--border);
  transition:padding-left .15s,background .15s;
}
.tr-item:hover { padding-left:6px; }
.tr-item:last-child { border-bottom:none; }
.tr-item-nm { font-size:13.5px; color:var(--text-2); line-height:1.5; flex:1; }
.tr-item-pr {
  font-family:'Syne',sans-serif; font-weight:700; font-size:14px;
  color:var(--text); white-space:nowrap; flex-shrink:0;
}

/* ═══════════════════════════════
   HOSTING PAGE
═══════════════════════════════ */
.ht-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(290px,1fr)); gap:16px; margin-top:36px; }
.ht-card {
  background:var(--card-bg); border:1px solid var(--border); border-radius:18px;
  padding:28px 24px; display:flex; flex-direction:column; position:relative; overflow:hidden;
  transition:transform .22s,box-shadow .22s,border-color .22s,background .3s;
}
.ht-card:hover { transform:translateY(-5px); box-shadow:var(--sh-lg); border-color:var(--blue-lt2); }
.ht-card.vip { border-color:var(--blue-lt2); background:linear-gradient(180deg,var(--card-bg),var(--blue-lt)); }
.ht-card.vip::before {
  content:'1С-Битрикс'; position:absolute; top:14px; right:-22px;
  background:var(--blue); color:#fff; font-size:8px; font-weight:800;
  letter-spacing:1px; text-transform:uppercase;
  padding:3px 32px; transform:rotate(35deg); white-space:nowrap;
}
.ht-card-tag {
  display:inline-flex; align-items:center; gap:5px;
  font-size:10px; font-weight:700; letter-spacing:1.2px; text-transform:uppercase;
  color:var(--text-3); margin-bottom:6px;
}
.ht-card-name { font-family:'Syne',sans-serif; font-weight:800; font-size:21px; color:var(--text); letter-spacing:-.5px; margin-bottom:4px; }
.ht-card-desc { font-size:13px; color:var(--text-2); line-height:1.5; margin-bottom:16px; }
.ht-card-price { margin-bottom:16px; }
.ht-card-price-row { display:flex; align-items:baseline; gap:10px; flex-wrap:wrap; }
.ht-card-price-main { font-family:'Syne',sans-serif; font-weight:800; font-size:36px; color:var(--text); letter-spacing:-1px; line-height:1; }
.ht-card-price-year { font-family:'Syne',sans-serif; font-weight:700; font-size:20px; color:var(--text-3); letter-spacing:-.3px; text-decoration:line-through; }
.ht-card-price-label { font-size:11px; color:var(--green); font-weight:600; margin-top:3px; }
.ht-card-specs { display:flex; flex-wrap:wrap; gap:6px; margin-bottom:20px; }
.ht-card-spec {
  font-size:11.5px; color:var(--text-2); background:var(--surface-2);
  padding:4px 10px; border-radius:6px; border:1px solid var(--border);
}
.ht-card .btn-pr { margin-top:auto; }
.ht-feat-grid .info-card-ico { width:48px; height:48px; border-radius:12px; font-size:22px; }
.ht-hard-grid { grid-template-columns:repeat(4,1fr); }
.ht-free-grid { display:flex; flex-wrap:wrap; gap:8px; margin-top:8px; }
.ht-free-item {
  padding:8px 16px; border-radius:100px; border:1.5px solid var(--border);
  background:var(--card-bg); font-size:13px; font-weight:500; color:var(--text-2);
  transition:background .15s,border-color .15s,color .15s;
}
.ht-free-item:hover { background:var(--blue-lt); border-color:var(--blue-lt2); color:var(--blue); }
.ht-cms-grid { display:flex; flex-wrap:wrap; gap:8px; }
.ht-cms-item {
  padding:7px 16px; border-radius:10px; border:1px solid var(--border);
  background:var(--card-bg); font-size:13px; font-weight:500; color:var(--text-2);
  transition:background .15s,border-color .15s,transform .15s;
}
.ht-cms-item:hover { background:var(--blue-lt); border-color:var(--blue-lt2); transform:translateY(-2px); }

/* ═══════════════════════════════
   CONTACTS PAGE
═══════════════════════════════ */
.contact-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}
.contact-card {
  background:var(--card-bg); border:1px solid var(--border);
  border-radius:18px; padding:28px 26px;
  transition:transform .22s,box-shadow .22s,border-color .22s,background .3s;
}
.contact-card:hover { transform:translateY(-4px); box-shadow:var(--sh-md); border-color:var(--blue-lt2); }
.contact-card-ico {
  width:44px; height:44px; border-radius:11px;
  background:var(--blue-lt); color:var(--blue);
  display:flex; align-items:center; justify-content:center;
  font-size:20px; margin-bottom:16px;
}
.contact-card h3 {
  font-family:'Syne',sans-serif; font-weight:700;
  font-size:15px; color:var(--text); margin-bottom:10px;
}
.contact-card p, .contact-card a {
  font-size:14px; color:var(--text-2); line-height:1.7;
}
.contact-card a { color:var(--blue); text-decoration:none; transition:color .15s; }
.contact-card a:hover { color:var(--blue-mid); }
.contact-card ul { list-style:none; display:flex; flex-direction:column; gap:4px; }

.address-section {
  background:var(--card-bg); border:1px solid var(--border);
  border-radius:18px; padding:32px; margin-bottom:16px;
  transition:background .3s,border-color .3s;
}
.address-section:last-child { margin-bottom:0; }
.address-info h3 {
  font-family:'Syne',sans-serif; font-weight:700;
  font-size:17px; color:var(--text); margin-bottom:4px;
}
.address-info .note {
  font-size:13px; color:var(--orange); font-weight:600; margin-bottom:12px;
}
.address-info .directions {
  font-size:14px; color:var(--text-2); line-height:1.7; margin-top:12px;
}
.address-info .directions strong {
  color:var(--text);
}
.address-media {
  display:grid;
  grid-template-columns:1fr 380px;
  gap:24px;
}
.address-map-wrap {
  border-radius:12px; overflow:hidden; border:1px solid var(--border);
  height:100%; min-height:280px;
  position:relative;
}
.address-map-wrap iframe {
  width:100%; height:100%; border:0; display:block; position:absolute; inset:0;
}
.address-label {
  font-size:14px; font-weight:700; color:var(--text);
  margin-bottom:10px;
}
.address-photos {
  display:flex; flex-direction:column; gap:10px;
}
.address-photo-wrap {
  width:100%;
}
.address-photo {
  display:block; width:100%; height:auto;
  border-radius:10px; border:1px solid var(--border); background:var(--surface-2);
  transition:transform .2s,box-shadow .2s;
}
.address-photo:hover { transform:scale(1.02); box-shadow:var(--sh-sm); }

@media (max-width:760px) {
  .contact-grid { grid-template-columns:1fr; }
  .address-media { grid-template-columns:1fr; }
  .address-map-wrap { min-height:220px; }
}

/* ═══════════════════════════════
   NEWS PAGE
═══════════════════════════════ */
.news-page-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(360px,1fr));
  gap:18px;
}
.news-page-card {
  display:flex; flex-direction:column;
  background:var(--card-bg); border:1px solid var(--border);
  border-radius:18px; overflow:hidden; text-decoration:none;
  transition:transform .22s,box-shadow .22s,border-color .22s,background .3s;
}
.news-page-card:hover { transform:translateY(-5px); box-shadow:var(--sh-lg); border-color:var(--blue-lt2); }
.news-page-img {
  height:180px; overflow:hidden; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  background:var(--surface-2);
}
.news-page-img img { display:block; max-width:100%; max-height:100%; object-fit:contain; }
.news-page-body {
  padding:22px 24px 26px; flex:1;
  display:flex; flex-direction:column; gap:10px;
}
.news-page-date {
  font-size:12px; color:var(--text-3); font-weight:500;
}
.news-page-title {
  font-family:'Syne',sans-serif; font-weight:700;
  font-size:16px; line-height:1.42; color:var(--text);
  transition:color .18s;
}
.news-page-card:hover .news-page-title { color:var(--blue); }
.news-page-ex {
  font-size:13.5px; color:var(--text-2); line-height:1.65;
  flex:1;
}
.news-page-lk {
  font-size:12.5px; font-weight:600; color:var(--blue);
  display:inline-flex; align-items:center; gap:5px;
  margin-top:auto; transition:gap .2s;
}
.news-page-card:hover .news-page-lk { gap:9px; }

@media (max-width:760px) {
  .news-page-grid { grid-template-columns:1fr; }
}

/* ═══════════════════════════════
   SAYTY TARIFFS
═══════════════════════════════ */
.sayty-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px; margin-top:36px;
}
.sayty-card {
  background:var(--card-bg); border:1px solid var(--border);
  border-radius:18px; padding:32px 26px;
  display:flex; flex-direction:column; gap:20px; position:relative; overflow:hidden;
  transition:transform .22s,box-shadow .22s,border-color .22s,background .3s;
}
.sayty-card:hover { transform:translateY(-5px); box-shadow:var(--sh-lg); border-color:var(--blue-lt2); }
.sayty-card-feat {
  border-color:var(--blue-lt2);
  background:linear-gradient(180deg,var(--card-bg),var(--blue-lt));
}
.sayty-card-tag {
  font-size:10px; font-weight:700; letter-spacing:1.2px; text-transform:uppercase;
  color:var(--text-3);
}
.sayty-card-icon {
  width:48px; height:48px; border-radius:12px;
  background:var(--blue-lt); color:var(--blue);
  display:flex; align-items:center; justify-content:center;
  font-size:22px; flex-shrink:0;
}
.sayty-card-name {
  font-family:'Syne',sans-serif; font-weight:800;
  font-size:21px; color:var(--text); letter-spacing:-.3px;
}
.sayty-card-desc {
  font-size:13px; color:var(--text-2); line-height:1.55;
}
.sayty-card-price {
  display:flex; flex-direction:column; align-items:flex-start; gap:0;
}
.sayty-card-price-old {
  font-family:'Syne',sans-serif; font-weight:700;
  font-size:16px; color:var(--text-3); text-decoration:line-through; letter-spacing:-.3px;
}
.sayty-card-price-main {
  font-family:'Syne',sans-serif; font-weight:800;
  font-size:36px; color:var(--blue); letter-spacing:-1px; line-height:1;
}
.sayty-card-discount {
  font-size:11px; color:var(--green); font-weight:600;
}
.sayty-card-feats {
  list-style:none; display:flex; flex-direction:column; gap:6px;
  flex:1;
}
.sayty-card-feats li {
  font-size:13px; color:var(--text-2); line-height:1.45;
  padding-left:18px; position:relative;
}
.sayty-card-feats li::before {
  content:'✓'; position:absolute; left:0; top:0;
  color:var(--green); font-weight:700; font-size:12px;
}
.sayty-card-feats li b { color:var(--text); }
.sayty-card-btn {
  display:block; text-align:center; padding:12px 20px;
  background:var(--blue); color:#fff; border-radius:100px;
  font-size:13.5px; font-weight:700; text-decoration:none;
  box-shadow:0 4px 12px rgba(36,87,217,.28);
  transition:background .2s,transform .14s,box-shadow .2s;
}
.sayty-card-btn:hover { background:var(--blue-mid); transform:translateY(-2px); box-shadow:0 8px 18px rgba(36,87,217,.34); }

/* ═══════════════════════════════
   BRIEF FORM
═══════════════════════════════ */
.brf-form { max-width:860px; margin:0 auto; display:flex; flex-direction:column; gap:28px; }
.brf-section {
  background:var(--card-bg); border:1px solid var(--border);
  border-radius:18px; padding:36px 34px;
  transition:background .3s,border-color .3s,box-shadow .3s;
}
.brf-section:hover { border-color:var(--blue-lt2); box-shadow:var(--sh-sm); }
.brf-section-title {
  font-family:'Syne',sans-serif; font-weight:800;
  font-size:22px; letter-spacing:-.5px; color:var(--text);
  margin-bottom:24px; padding-bottom:16px;
  border-bottom:1.5px solid var(--border);
}
.brf-subsection { margin-top:22px; }
.brf-subsection-title {
  font-family:'Syne',sans-serif; font-weight:700;
  font-size:16px; color:var(--text); margin-bottom:14px;
}
.brf-hint { font-size:13px; color:var(--text-3); margin-bottom:10px; line-height:1.5; }
.brf-row { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-bottom:12px; }
.brf-row:last-child { margin-bottom:0; }
.brf-row-3 { grid-template-columns:1fr 1fr 1fr; }
.brf-field { display:flex; flex-direction:column; gap:6px; }
.brf-field-2 { grid-column:span 2; }
.brf-label {
  font-size:13px; font-weight:600; color:var(--text-2);
  line-height:1.45;
}
.brf-req { color:var(--orange); }
.brf-input, .brf-textarea, .brf-select {
  width:100%; padding:10px 14px;
  font-family:'DM Sans',sans-serif; font-size:14px; color:var(--text);
  background:var(--surface-2); border:1.5px solid var(--border);
  border-radius:10px; outline:none;
  transition:border-color .2s,box-shadow .2s,background .3s,color .3s;
}
.brf-input:focus, .brf-textarea:focus, .brf-select:focus {
  border-color:var(--blue); box-shadow:0 0 0 3px rgba(36,87,217,.09);
  background:var(--card-bg);
}
.brf-input::placeholder, .brf-textarea::placeholder { color:var(--text-3); }
.brf-textarea { resize:vertical; min-height:56px; }
.brf-chk-grid { display:flex; flex-wrap:wrap; gap:8px; }
.brf-chk {
  display:inline-flex; align-items:center; gap:7px;
  padding:7px 14px; border-radius:100px;
  background:var(--surface-2); border:1.5px solid var(--border);
  font-size:13px; color:var(--text-2); cursor:pointer;
  transition:background .15s,border-color .15s,color .15s;
  user-select:none;
}
.brf-chk:hover { border-color:var(--blue-lt2); color:var(--text); }
.brf-chk input { accent-color:var(--blue); width:15px; height:15px; flex-shrink:0; }
.brf-chk b { color:var(--text); }
.brf-submit-wrap { margin-top:24px; display:flex; flex-direction:column; gap:12px; }
.brf-submit {
  align-self:flex-start;
  padding:14px 34px; background:var(--blue); border:none; border-radius:100px;
  font-family:'DM Sans',sans-serif; font-size:15px; font-weight:700; color:#fff;
  cursor:pointer;
  box-shadow:0 4px 14px rgba(36,87,217,.28);
  transition:background .2s,transform .15s,box-shadow .2s;
}
.brf-submit:hover { background:var(--blue-mid); transform:translateY(-2px); box-shadow:0 8px 22px rgba(36,87,217,.34); }
.brf-note { font-size:12px; color:var(--text-3); }

@media (max-width:760px) {
  .brf-section { padding:24px 18px; }
  .brf-row { grid-template-columns:1fr; }
  .brf-row-3 { grid-template-columns:1fr; }
  .brf-field-2 { grid-column:span 1; }
  .brf-chk-grid { flex-direction:column; }
  .brf-chk { border-radius:10px; width:100%; }
}

/* ═══════════════════════════════
   SCROLL TO TOP
═══════════════════════════════ */
.scroll-top {
  position:fixed; bottom:32px; right:32px; z-index:900;
  width:48px; height:48px; border-radius:50%;
  background:var(--card-bg); border:1.5px solid var(--border);
  color:var(--blue); box-shadow:var(--sh-md);
  cursor:pointer; display:flex; align-items:center; justify-content:center;
  opacity:0; pointer-events:none; transform:translateY(16px);
  transition:opacity .3s,transform .3s,background .2s,border-color .2s,box-shadow .2s;
}
.scroll-top.show { opacity:1; pointer-events:all; transform:translateY(0); }
.scroll-top:hover {
  background:var(--blue); border-color:var(--blue); color:#fff;
  transform:translateY(-3px); box-shadow:0 8px 22px rgba(36,87,217,.32);
}
.scroll-top svg { width:20px; height:20px; display:block; }

/* ═══════════════════════════════
   COOKIE BANNER
═══════════════════════════════ */
.cookie-banner {
  position:fixed; bottom:0; left:0; right:0; z-index:99999;
  background:var(--blue); color:#cbd5e1;
  padding:14px 32px;
  transition:opacity .3s;
}
.cookie-banner-inner {
  max-width:1200px; margin:0 auto;
  display:flex; align-items:center; justify-content:space-between; gap:16px;
}
.cookie-banner-text { font-size:13px; line-height:1.5; }
.cookie-banner-text a { color:#93c5fd; text-decoration:underline; }
.cookie-banner-text a:hover { color:#fff; }
.cookie-banner-btn {
  flex-shrink:0; padding:7px 20px; border-radius:100px;
  background:#fff; color:var(--blue); border:none;
  font-size:13px; font-weight:600; cursor:pointer;
  transition:background .15s;
}
.cookie-banner-btn:hover { background:#e2e8f0; }

@media (max-width:560px) {
  .cookie-banner { padding:12px 18px; }
  .cookie-banner-inner { flex-direction:column; text-align:center; }
  .cookie-banner-text { font-size:12px; }
  .cookie-banner-btn { width:100%; }
}

/* ═══════════════════════════════
   RESPONSIVE
═══════════════════════════════ */
@media (max-width:960px) {
  .hd-top { padding:0 18px; }
  .hd-right { display:none; }
  nav { padding:0 18px; gap:10px; }
  .nav-links { display:none; }
  .nav-hamburger { display:flex; }
  .nav-cta { display:none; }
  .nav-search input { width:150px; }
  .slide { padding:56px 18px 68px; }
  .hero-stats { display:none; }
  .hero-title { font-size:38px; letter-spacing:-1.5px; }
  .sl-nav { left:18px; }
  .sec { padding:52px 18px; }
  .page-header { min-height:180px; }
  .svc-grid { grid-template-columns:1fr; }
  .proc-row { grid-template-columns:1fr 1fr; gap:24px; }
  .proc-row::before { display:none; }
  .why-grid { grid-template-columns:1fr; }
  .pop-grid { grid-template-columns:1fr 1fr; }
  .pop-grid .pop-card:last-child { grid-column:span 2; }
  .info-grid { grid-template-columns:1fr 1fr; }
  .info-stats { grid-template-columns:1fr 1fr; }
  .price-grid { grid-template-columns:1fr; }
  .price-card.feat { order:-1; }
  .news-grid { grid-template-columns:1fr; }
  .promo { margin:0 18px; flex-direction:column; padding:34px 26px; }
  .promo-act { flex-direction:column; width:100%; }
  .ft-top { grid-template-columns:1fr 1fr; gap:26px; }
  .ft-bot { flex-direction:column; gap:10px; text-align:center; }
  .port-strip .sec-tag, .port-strip .sec-title { padding:0 18px; }
  .port-scroll { padding:0 18px; }
  .pf-grid { grid-template-columns:1fr 1fr; }
  .pfltr { flex-wrap:nowrap; overflow-x:auto; scrollbar-width:none; padding-bottom:4px; }
  .pfltr::-webkit-scrollbar { display:none; }
  .kc-grid { grid-template-columns:1fr 1fr; }
  .us-grid { grid-template-columns:1fr 1fr; }
  .tr-card-hd { padding:16px 18px; font-size:14px; }
  .tr-list { padding:0 18px 14px; }
  .ht-hard-grid { grid-template-columns:1fr 1fr; }
  .sayty-grid { grid-template-columns:1fr 1fr; }
  .news-page-grid { grid-template-columns:1fr 1fr; }
}

@media (max-width:560px) {
  .info-stats { grid-template-columns:1fr; }
  .pf-grid { grid-template-columns:1fr; }
  .us-grid { grid-template-columns:1fr; }
  .kc-grid { grid-template-columns:1fr; }
  .kc-stats { flex-direction:column; }
  .ht-card-price-main { font-size:28px; }
  .ht-card-price-year { font-size:16px; }
  .ht-hard-grid { grid-template-columns:1fr; }
  .sayty-grid { grid-template-columns:1fr; }
  .news-page-grid { grid-template-columns:1fr; }
}
