:root{
  --bg0:#070A10;
  --bg1:#0B1220;
  --card: rgba(255,255,255,.06);
  --card2: rgba(255,255,255,.09);
  --stroke: rgba(255,255,255,.10);
  --text:#EAF1FF;
  --muted: rgba(234,241,255,.68);
  --accent:#2AA7FF;
  --accent2:#00E5FF;
  --shadow: 0 18px 70px rgba(0,0,0,.55);
  --r:18px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  color:var(--text);
  background: radial-gradient(1200px 700px at 10% 10%, rgba(42,167,255,.18), transparent 60%),
              radial-gradient(900px 600px at 85% 25%, rgba(0,229,255,.10), transparent 55%),
              linear-gradient(180deg, var(--bg0), var(--bg1));
}

a{color:inherit;text-decoration:none}
.container{width:min(1160px, 92vw); margin:0 auto}

.bg{min-height:100%}
.no-scroll{overflow:hidden}

.glass{
  background: linear-gradient(180deg, var(--card), rgba(255,255,255,.04));
  border:1px solid var(--stroke);
  border-radius: var(--r);
  box-shadow: var(--shadow);
  backdrop-filter: blur(10px);
}

.header{
  position:sticky; top:0; z-index:50;
  background: rgba(7,10,16,.58);
  border-bottom: 1px solid rgba(255,255,255,.08);
  backdrop-filter: blur(12px);
}
.header__row{display:flex; align-items:center; justify-content:space-between; padding:14px 0}
.brand{display:flex; gap:12px; align-items:center}
.logo{height:44px; width:auto; max-width:360px; filter: drop-shadow(0 0 18px rgba(42,167,255,.35));}
.logo.sm{height:34px; width:auto; max-width:280px;}
.brand__name{font-weight:800; letter-spacing:.2px}
.brand__tag{font-size:13px; color:var(--muted)}
.accent{color:var(--accent)}

.nav{display:flex; gap:18px; align-items:center}
.nav a{color:var(--muted); font-weight:600; font-size:14px}
.nav a:hover{color:var(--text)}
.nav__admin{
  display:inline-flex; align-items:center; justify-content:center;
  width:40px; height:40px; border-radius: 12px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.05);
}
.nav__admin:hover{border-color: rgba(42,167,255,.45); box-shadow:0 0 0 6px rgba(42,167,255,.08)}

.header__actions{display:none; align-items:center; gap:10px}
.header__cabinet{
  display:inline-flex; align-items:center; justify-content:center;
  min-height:42px; padding:0 14px; border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.05);
  color:var(--text); font-weight:800; font-size:13px;
}
.menu-toggle{
  width:48px; height:48px; border-radius:16px; flex:0 0 auto;
  border:1px solid rgba(255,255,255,.12);
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03));
  display:none; align-items:center; justify-content:center; flex-direction:column; gap:6px;
  box-shadow:0 16px 40px rgba(0,0,0,.28);
}
.menu-toggle span{
  display:block; width:18px; height:2px; border-radius:999px; background:#eaf1ff;
  transition:transform .25s ease, opacity .25s ease;
}
.menu-toggle.is-active span:first-child{transform:translateY(4px) rotate(45deg)}
.menu-toggle.is-active span:last-child{transform:translateY(-4px) rotate(-45deg)}

.mobile-menu{
  position:fixed; inset:0; z-index:120; pointer-events:none; overflow:hidden;
}
.mobile-menu__backdrop{
  position:absolute; inset:0; background:rgba(3,8,14,.62); opacity:0; transition:opacity .28s ease;
  backdrop-filter:blur(8px);
}
.mobile-menu__panel{
  position:absolute; top:0; right:0; width:min(92vw, 420px); height:100dvh; max-height:100dvh;
  padding:18px 18px calc(18px + env(safe-area-inset-bottom, 0px));
  display:flex; flex-direction:column; gap:18px; overflow-y:auto; overscroll-behavior:contain;
  -webkit-overflow-scrolling:touch;
  background:linear-gradient(180deg, rgba(7,10,16,.97), rgba(10,18,32,.96));
  border-left:1px solid rgba(255,255,255,.08);
  box-shadow:-24px 0 70px rgba(0,0,0,.5);
  transform:translateX(100%); transition:transform .32s cubic-bezier(.22,.8,.2,1);
}
.mobile-menu.open{pointer-events:auto}
.mobile-menu.open .mobile-menu__backdrop{opacity:1}
.mobile-menu.open .mobile-menu__panel{transform:translateX(0)}
.mobile-menu__head{display:flex; align-items:center; justify-content:space-between; gap:14px}
.logo--menu{height:40px; max-width:220px}
.mobile-menu__close{
  width:44px; height:44px; border-radius:14px; border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.05); color:var(--text); font-size:28px; line-height:1; cursor:pointer;
}
.mobile-menu__eyebrow{
  display:inline-flex; align-self:flex-start; min-height:34px; padding:0 12px; border-radius:999px;
  border:1px solid rgba(42,167,255,.22); background:rgba(42,167,255,.09); color:#b8def7;
  font-size:11px; letter-spacing:.18em; text-transform:uppercase; font-weight:800; align-items:center;
}
.mobile-menu__nav{display:grid; gap:12px}
.mobile-menu__nav a{
  display:flex; flex-direction:column; gap:4px; padding:16px 18px; border-radius:22px;
  border:1px solid rgba(255,255,255,.08); background:rgba(255,255,255,.04);
  color:var(--text); box-shadow:inset 0 1px 0 rgba(255,255,255,.03);
}
.mobile-menu__nav a span{font-size:19px; font-weight:900; letter-spacing:.01em}
.mobile-menu__nav a small{color:var(--muted); font-size:13px; line-height:1.45}
.mobile-menu__foot{margin-top:auto; display:grid; gap:10px; padding-top:4px}
.mobile-menu__foot .btn{width:100%; justify-content:center}

.hero{position:relative; padding:54px 0 26px; overflow:visible}
.hero__grid{display:grid; grid-template-columns: 1.35fr .85fr; gap:22px; align-items:stretch}
.hero h1{margin:12px 0 10px; font-size:44px; line-height:1.05}
.lead{color:var(--muted); font-size:16px; line-height:1.6; max-width:56ch}
.chip{
  display:inline-flex; gap:10px; align-items:center;
  padding:10px 14px; border-radius:999px;
  border:1px solid rgba(42,167,255,.25);
  background: rgba(42,167,255,.08);
}
.glow{box-shadow: 0 0 30px rgba(42,167,255,.18)}
.hero__actions{display:flex; gap:12px; margin-top:18px}
.hero__stats{display:flex; gap:12px; margin-top:18px; flex-wrap:wrap}
.stat{padding:12px 14px; border-radius:16px; min-width:150px}
.stat__n{font-size:22px; font-weight:800}
.stat__t{font-size:12px; color:var(--muted)}

.section{padding:42px 0}
.section__head{display:flex; align-items:flex-end; justify-content:space-between; gap:14px; margin-bottom:16px}
.section__head h2{margin:0; font-size:28px}
.muted{color:var(--muted)}

.grid.cards{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:14px;
}
.svc{padding:16px; position:relative; overflow:hidden; transform: translateZ(0)}
.svc::after{
  content:"";
  position:absolute; inset:-80px -40px auto auto;
  width:170px; height:170px;
  background: radial-gradient(circle at 30% 30%, rgba(42,167,255,.25), transparent 60%);
  filter: blur(6px);
}
.svc__icon{font-size:22px}
.svc__title{margin-top:10px; font-weight:800}
.svc__descr{margin-top:6px; color:var(--muted); font-size:14px; line-height:1.5}
.svc__btn{margin-top:12px}

.book{padding:18px}
.form{display:flex; flex-direction:column; gap:10px}
.grid2{display:grid; grid-template-columns:1fr 1fr; gap:12px}
.grid2__full{grid-column: 1 / -1}
.lbl{font-size:12px; color:var(--muted)}
.inp{
  width:100%;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.22);
  color:var(--text);
  outline:none;
}
.inp:focus{border-color: rgba(42,167,255,.55); box-shadow: 0 0 0 6px rgba(42,167,255,.10)}
.msg{min-height:18px; font-size:13px; color:var(--muted)}

.btn{
  display:inline-flex; align-items:center; justify-content:center;
  gap:10px;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  color:var(--text);
  cursor:pointer;
  font-weight:800;
}
.btn:hover{border-color: rgba(255,255,255,.22)}
.btn.primary{
  border-color: rgba(42,167,255,.55);
  background: linear-gradient(180deg, rgba(42,167,255,.35), rgba(42,167,255,.18));
  box-shadow: 0 14px 45px rgba(42,167,255,.20);
}
.btn.ghost{background: rgba(255,255,255,.04)}
.btn.sm{padding:9px 10px; border-radius:12px; font-size:13px}
.btn.danger{border-color: rgba(255,80,80,.55); background: rgba(255,80,80,.12)}
.iconbtn{
  width:42px; height:42px; border-radius:14px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  color:var(--text);
  cursor:pointer;
}

.mapgrid{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap:14px;
}
.mapbox{padding:14px}
.mapbox__head{display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:10px}
.mini-title{font-weight:900}
.map{height:420px; border-radius:16px; overflow:hidden; border:1px solid rgba(255,255,255,.10); background: rgba(0,0,0,.18)}
.reviews iframe{border-radius:16px}

.modal{position:fixed; inset:0; display:none; z-index:100}
.modal.open{display:block}
.modal__backdrop{position:absolute; inset:0; background: rgba(0,0,0,.55)}
.modal__card{
  position:relative;
  width:min(920px, 92vw);
  margin: 6vh auto 0;
  max-height: 88vh;
  display:flex;
  flex-direction:column;
}
.modal__head{display:flex; align-items:flex-start; justify-content:space-between; gap:12px; padding:16px; border-bottom:1px solid rgba(255,255,255,.08)}
.modal__body{padding:16px; overflow:auto}
.modal__foot{padding:16px; border-top:1px solid rgba(255,255,255,.08); display:flex; gap:10px; justify-content:flex-end}

.price__section{margin-bottom:14px}
.price__cat{font-weight:900; margin-bottom:8px; color:rgba(234,241,255,.92)}
.price__rows{display:flex; flex-direction:column; gap:8px}
.price__row{
  display:flex; align-items:center; justify-content:space-between; gap:14px;
  padding:10px 12px;
  border:1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.04);
  border-radius:14px;
}
.price__t{color:rgba(234,241,255,.88)}
.price__p{font-weight:900}

.footer{
  margin-top: 30px;
  border-top:1px solid rgba(255,255,255,.08);
  background: rgba(7,10,16,.50);
  backdrop-filter: blur(10px);
  position: sticky; bottom: 0;
}
.footer__row{display:flex; justify-content:space-between; align-items:center; padding:14px 0}
.footer__links{display:flex; gap:14px}
.footer__links a{color:var(--muted); font-weight:700; font-size:13px}
.footer__links a:hover{color:var(--text)}

.topbar{position:sticky; top:0; z-index:50; background: rgba(7,10,16,.62); border-bottom:1px solid rgba(255,255,255,.08); backdrop-filter: blur(12px)}
.topbar__row{display:flex; justify-content:space-between; align-items:center; padding:14px 0}
.topbar__left{display:flex; gap:12px; align-items:center}
.h{font-size:18px; font-weight:900}
.h2{font-size:20px; font-weight:900; margin:0}

.tabs{display:flex; gap:10px; margin-bottom:12px}
.tab{
  padding:10px 12px; border-radius:14px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  color:var(--muted);
  cursor:pointer; font-weight:900;
}
.tab.active{color:var(--text); border-color: rgba(42,167,255,.45); box-shadow: 0 0 0 6px rgba(42,167,255,.08)}
.panel{padding:10px 0}
.panel__head{display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:10px}

.table-wrap{padding:10px}
.table{width:100%; border-collapse:separate; border-spacing:0 10px}
.table thead th{font-size:12px; color:var(--muted); text-align:left; font-weight:800; padding:0 10px}
.table tbody tr{background: rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08)}
.table td{padding:10px; border-top:1px solid rgba(255,255,255,.08); border-bottom:1px solid rgba(255,255,255,.08)}
.table tbody tr td:first-child{border-left:1px solid rgba(255,255,255,.08); border-radius:14px 0 0 14px}
.table tbody tr td:last-child{border-right:1px solid rgba(255,255,255,.08); border-radius:0 14px 14px 0}
.tinp{
  width:100%;
  padding:10px 10px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.18);
  color:var(--text);
  outline:none;
}
.tinp:focus{border-color: rgba(42,167,255,.55); box-shadow: 0 0 0 6px rgba(42,167,255,.08)}
.center{text-align:center}
.right{text-align:right}

.toast{
  position:fixed; right:18px; bottom:18px;
  padding:12px 14px; border-radius:14px;
  background: rgba(0,0,0,.55);
  border:1px solid rgba(255,255,255,.10);
  opacity:0; transform: translateY(10px);
  transition:.25s;
}
.toast.show{opacity:1; transform: translateY(0)}

.auth-wrap{min-height:100vh; display:flex; align-items:center; justify-content:center; padding:30px 0}
.brand-row{display:flex; align-items:center; gap:12px; margin-bottom:14px}
.card{width:min(520px, 92vw); padding:18px}
.pad{padding:18px 0}

.bg-orb{position:absolute; border-radius:999px; filter: blur(30px); opacity:.55; pointer-events:none}
.orb1{width:320px;height:320px; left:-90px; top:60px; background: rgba(42,167,255,.25)}
.orb2{width:260px;height:260px; right:-70px; top:120px; background: rgba(0,229,255,.16)}

.hidden{display:none}

@media (max-width: 980px){
  .hero__grid{grid-template-columns:1fr}
  .grid.cards{grid-template-columns:1fr}
  .mapgrid{grid-template-columns:1fr}
  .nav--desktop{display:none}
  .header__actions{display:flex}
  .menu-toggle{display:flex}
  .hero h1{font-size:36px}
  .grid2{grid-template-columns:1fr}
  .footer{position:static}
}

@media (min-width: 981px){
  .mobile-menu{display:none}
}

@media (max-width: 640px){
  .header__row{padding:12px 0}
  .logo{height:38px; max-width:220px}
  .header__cabinet{display:none}
  .mobile-menu__panel{width:100%; max-width:none; padding:16px}
  .mobile-menu__nav a{padding:15px 16px; border-radius:20px}
  .mobile-menu__nav a span{font-size:18px}
}


/* 2GIS widget embed */
.map-actions{display:flex; gap:10px; align-items:center; flex-wrap:wrap}
.map--widget{width:100%; height:420px; border:0; border-radius:16px; display:block}
@media (max-width: 980px){
  .map--widget{height:520px}
}


.inp[readonly]{opacity:.92; cursor:not-allowed}


/* --- Fix: prevent horizontal "drift" on mobile --- */
html, body{ overflow-x:hidden; }
body{ overscroll-behavior-x: none; }

/* --- Fix: static background (no scrolling) --- */
body{
  background-attachment: fixed;
  background-size: cover;
}

/* Make decorative orbs stay fixed behind content */
.bg-orb{
  position: fixed;
  z-index: -1;
}


/* --- Quick form premium --- */
.quick{
  padding:18px;
  position:relative;
  overflow:hidden;
}
.quick::before{
  content:"";
  position:absolute;
  inset:-1px;
  border-radius: var(--r);
  padding:1px;
  background: linear-gradient(135deg, rgba(42,167,255,.55), rgba(0,229,255,.12), rgba(255,255,255,.10));
  -webkit-mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events:none;
  opacity:.55;
}
.quick__head{
  display:flex;
  gap:12px;
  align-items:center;
  margin-bottom:14px;
}
.quick__badge{
  width:40px;
  height:40px;
  border-radius:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(42,167,255,.10);
  border:1px solid rgba(42,167,255,.25);
  box-shadow: 0 0 0 6px rgba(42,167,255,.08);
}
.quick__title{
  font-weight:900;
  font-size:18px;
  letter-spacing:.2px;
}
.quick__sub{
  color:var(--muted);
  font-size:13px;
  margin-top:2px;
}

.quick__grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:12px;
}
.field{display:flex; flex-direction:column; gap:6px;}
.field--full{grid-column: 1 / -1;}

.btn--wide{
  width:100%;
  justify-content:center;
  position:relative;
  overflow:hidden;
}
.btn__shine{
  position:absolute;
  inset:-40%;
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.22), transparent 55%);
  transform: translateX(-25%);
  opacity:.65;
  pointer-events:none;
}
.btn__arrow{opacity:.9}

.quick__trust{
  margin-top:12px;
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.quick__pill{
  font-size:12px;
  color:rgba(234,241,255,.78);
  padding:8px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
}

/* Mobile */
@media (max-width: 720px){
  .quick__grid{grid-template-columns: 1fr;}
}


/* --- Quick request v2 (premium) --- */
.quickv2{
  padding:0;
  overflow:hidden;
  position:relative;
}
.quickv2::before{
  content:"";
  position:absolute;
  inset:-120px -120px auto auto;
  width:260px; height:260px;
  background: radial-gradient(circle at 30% 30%, rgba(42,167,255,.28), transparent 62%);
  filter: blur(6px);
  pointer-events:none;
}
.quickv2__top{
  padding:16px 16px 12px;
  border-bottom:1px solid rgba(255,255,255,.08);
  background:
    radial-gradient(700px 260px at 10% 0%, rgba(42,167,255,.18), transparent 55%),
    rgba(255,255,255,.03);
}
.quickv2__kicker{
  display:inline-flex;
  gap:8px;
  align-items:center;
  font-weight:900;
  font-size:12px;
  letter-spacing:.8px;
  text-transform:uppercase;
  color:rgba(234,241,255,.72);
}
.quickv2__title{
  margin-top:8px;
  font-size:20px;
  font-weight:950;
  letter-spacing:.2px;
}
.quickv2__sub{
  margin-top:6px;
  color:var(--muted);
  font-size:13.5px;
  line-height:1.5;
}
.quickv2__form{padding:14px 16px 12px;}
.quickv2__fields{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:12px;
}
.qfield{display:flex; flex-direction:column; gap:6px;}
.qfield--full{grid-column: 1 / -1;}
.qfield__lbl{font-size:12px; color:rgba(234,241,255,.62); font-weight:800;}
.qfield__row{
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.22);
}
.qfield__ic{
  width:32px; height:32px;
  border-radius:12px;
  display:flex; align-items:center; justify-content:center;
  background: rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
  flex: 0 0 auto;
}
.qfield__inp{
  width:100%;
  border:0;
  outline:0;
  background: transparent;
  color: var(--text);
  font: inherit;
}
.qfield__row:focus-within{
  border-color: rgba(42,167,255,.55);
  box-shadow: 0 0 0 6px rgba(42,167,255,.10);
}

.quickv2__btn{
  grid-column: 1 / -1;
  width:100%;
  justify-content:center;
  margin-top:2px;
  padding:14px 14px;
  border-radius:16px;
  position:relative;
  overflow:hidden;
}
.quickv2__btn::after{
  content:"";
  position:absolute;
  inset:-40% -20% auto -40%;
  width:60%;
  height:220%;
  transform: rotate(18deg);
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.18), transparent);
  animation: shine 2.8s ease-in-out infinite;
  pointer-events:none;
  opacity:.75;
}
@keyframes shine{
  0%{transform: translateX(-30%) rotate(18deg); opacity:0}
  25%{opacity:.75}
  55%{opacity:.55}
  100%{transform: translateX(220%) rotate(18deg); opacity:0}
}
.quickv2__arrow{opacity:.9}

.quickv2__trust{
  padding:12px 16px 16px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  border-top:1px solid rgba(255,255,255,.06);
  background: rgba(255,255,255,.02);
}
.quickv2__trust-item{
  display:inline-flex;
  gap:8px;
  align-items:center;
  padding:8px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  color:rgba(234,241,255,.80);
  font-size:12px;
  font-weight:800;
}
.quickv2__trust .tmark{opacity:.95}

@media (max-width: 980px){
  .quickv2__fields{grid-template-columns:1fr;}
}

/* ===== Premium visual refresh ===== */
:root{
  --panel: rgba(10,17,28,.76);
  --panel-soft: rgba(255,255,255,.04);
}
html{scroll-behavior:smooth}
body{background-attachment:fixed;background-size:cover}
.ui-icon{width:24px;height:24px;color:#cfeaff;display:block;stroke-linecap:round;stroke-linejoin:round}
.ui-icon.sm{width:18px;height:18px}
.eyebrow{display:inline-block;padding:8px 14px;border-radius:999px;border:1px solid rgba(67,176,255,.24);background:rgba(42,167,255,.08);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#b9dff6;font-weight:800;margin-bottom:10px}
.section__head--soft{margin-bottom:18px}
.brand{position:relative}
.nav a{transition:.25s ease}
.nav__admin .ui-icon{width:20px;height:20px}
.chip .ui-icon{color:#61c7ff}
.trust-icon{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:999px;background:rgba(42,167,255,.12);color:#7fd3ff}
.hero{padding-top:46px}
.hero__left,.hero__right{animation:fadeUp .7s ease both}
.hero__right{animation-delay:.08s}
@keyframes fadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}

/* slider */
.section--slider{padding-top:18px}
.premium-slider{position:relative;padding:16px 16px 12px;overflow:hidden;border-radius:26px;background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03))}
.premium-slider__track{position:relative;min-height:620px}
.premium-slide{position:absolute;inset:0;opacity:0;pointer-events:none;transform:scale(1.02);transition:opacity .55s ease, transform .7s ease}
.premium-slide.is-active{opacity:1;pointer-events:auto;transform:none}
.premium-slide img{width:100%;height:620px;display:block;object-fit:cover;border-radius:22px;border:1px solid rgba(255,255,255,.08)}
.premium-slide__content{position:absolute;left:34px;bottom:34px;max-width:580px;padding:0}
.premium-slide__eyebrow{display:inline-flex;padding:8px 14px;border-radius:999px;background:rgba(6,17,31,.72);backdrop-filter:blur(10px);border:1px solid rgba(122,215,255,.24);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#d5f2ff;font-weight:800;margin-bottom:14px}
.premium-slide__content h3{font-size:44px;line-height:1.04;margin:0 0 10px;text-shadow:0 6px 24px rgba(0,0,0,.4)}
.premium-slide__content p{max-width:52ch;color:rgba(233,244,255,.84);font-size:16px;line-height:1.55;margin:0 0 16px;text-shadow:0 4px 18px rgba(0,0,0,.38)}
.premium-slide__actions{display:flex;gap:12px;flex-wrap:wrap}
.slider-nav{position:absolute;top:50%;transform:translateY(-50%);width:52px;height:52px;border-radius:16px;border:1px solid rgba(255,255,255,.12);background:rgba(7,16,28,.66);color:#fff;font-size:30px;line-height:1;display:grid;place-items:center;cursor:pointer;backdrop-filter:blur(10px);z-index:3;transition:.25s ease}
.slider-nav:hover{border-color:rgba(94,202,255,.42);box-shadow:0 0 0 8px rgba(42,167,255,.08)}
.slider-nav--prev{left:30px}.slider-nav--next{right:30px}
.premium-slider__footer{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 4px 0}
.premium-slider__meta{font-size:32px;font-weight:900;letter-spacing:.08em}
.premium-slider__meta span{font-size:32px}.premium-slider__meta #sliderTotal{color:rgba(234,241,255,.38)}
.premium-slider__progress{flex:1;max-width:360px;height:6px;border-radius:999px;background:rgba(255,255,255,.08);overflow:hidden}
.premium-slider__progress span{display:block;height:100%;width:33.333%;background:linear-gradient(90deg,#27b4ff,#00e0ff);border-radius:999px;transition:width .35s ease}
.premium-slider__dots{display:flex;gap:8px}.premium-slider__dot{width:11px;height:11px;border-radius:999px;border:0;background:rgba(255,255,255,.24);cursor:pointer;padding:0}.premium-slider__dot.is-active{width:30px;background:linear-gradient(90deg,#27b4ff,#00e0ff)}

/* services */
.grid.cards{grid-template-columns:repeat(3,1fr);gap:18px}
.svc{padding:22px;transition:transform .25s ease,border-color .25s ease,box-shadow .25s ease;cursor:pointer}
.svc:hover{transform:translateY(-5px);border-color:rgba(81,191,255,.3);box-shadow:0 18px 55px rgba(0,0,0,.45)}
.glass-icon{display:inline-flex;align-items:center;justify-content:center;width:58px;height:58px;border-radius:18px;background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03));border:1px solid rgba(255,255,255,.1);box-shadow:inset 0 1px 0 rgba(255,255,255,.06), 0 12px 28px rgba(0,0,0,.18);color:#80d7ff;transition:.25s ease}
.svc:hover .glass-icon{transform:translateY(-2px) scale(1.03);color:#bcefff;border-color:rgba(86,188,255,.34);box-shadow:0 12px 30px rgba(27,146,255,.18)}
.svc__title{font-size:20px;margin-top:14px}.svc__descr{font-size:14px;line-height:1.65}

/* contacts */
.section--contacts{padding-bottom:54px}
.contacts-layout{display:grid;grid-template-columns:minmax(320px, 400px) minmax(0,1fr);gap:18px;align-items:stretch}
.contacts-panel,.contacts-map{padding:18px}
.contacts-panel{display:flex;flex-direction:column}
.contacts-panel__intro h3{font-size:42px;line-height:1.04;margin:16px 0 10px;max-width:10ch}.contacts-panel__intro p{max-width:42ch;color:var(--muted);line-height:1.65}
.pill{display:inline-flex;padding:10px 14px;border-radius:999px;background:rgba(42,167,255,.12);border:1px solid rgba(42,167,255,.22);font-size:12px;font-weight:900;letter-spacing:.12em;text-transform:uppercase;color:#d4efff}
.contacts-grid{display:flex;flex-direction:column;gap:12px;margin-top:20px}
.contact-card{display:flex;align-items:center;gap:16px;padding:16px 18px;border-radius:20px;background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));border:1px solid rgba(255,255,255,.1);min-height:0;transition:.25s ease}
.contact-card:hover{transform:translateY(-3px);border-color:rgba(96,201,255,.32);box-shadow:0 18px 40px rgba(0,0,0,.28)}
.contact-card.is-static:hover{transform:none;box-shadow:none}
.contact-card__icon{display:inline-flex;align-items:center;justify-content:center;width:50px;height:50px;border-radius:16px;background:linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.03));border:1px solid rgba(255,255,255,.08);color:#88d9ff;flex:0 0 auto;box-shadow:inset 0 1px 0 rgba(255,255,255,.06)}
.contact-card__meta{display:flex;flex-direction:column;gap:6px;min-width:0;flex:1}
.contact-card__label{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:rgba(227,239,255,.56);font-weight:800}
.contact-card__meta strong{font-size:18px;line-height:1.35;word-break:break-word}
.contact-card__meta small{font-size:13px;line-height:1.5;color:var(--muted)}
.contacts-map{display:flex;flex-direction:column;min-height:100%}
.contacts-map__head{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:14px}
.map--large{height:760px;flex:1;min-height:760px}

/* admin polish */
.auth-wrap{position:relative}
.auth-wrap::before{content:"";position:absolute;inset:auto 8% 10% auto;width:260px;height:260px;border-radius:999px;background:radial-gradient(circle, rgba(42,167,255,.18), transparent 65%);filter:blur(20px);pointer-events:none}
.card{position:relative;overflow:hidden}
.card::after{content:"";position:absolute;inset:-1px auto auto -1px;width:180px;height:180px;background:radial-gradient(circle at top left, rgba(0,229,255,.16), transparent 68%);pointer-events:none}
.brand-row{margin-bottom:18px}
.brand-row .logo{height:52px}
.brand-row .muted{max-width:30ch}
.topbar__left .logo.sm{height:38px}
.table tbody tr:hover{box-shadow:0 10px 24px rgba(0,0,0,.18)}
.table td .btn{white-space:nowrap}

/* buttons etc */
.btn{transition:.25s ease}.btn:hover{transform:translateY(-1px)}
.quickv2__trust-item .ui-icon{width:15px;height:15px}
.footer{position:static}

@media (max-width: 1080px){
  .premium-slider__track,.premium-slide img{min-height:540px;height:540px}
  .premium-slide__content h3{font-size:38px}
  .contacts-layout{grid-template-columns:1fr}
  .map--large{height:560px;min-height:560px}
}
@media (max-width: 760px){
  .header__row{padding:12px 0}.nav{gap:10px}.nav a{font-size:13px}
  .hero{padding-top:28px}.hero h1{font-size:36px}.lead{font-size:15px}
  .premium-slider{padding:12px}.premium-slider__track{min-height:460px}.premium-slide img{height:460px}.premium-slide__content{left:18px;right:18px;bottom:20px}.premium-slide__content h3{font-size:28px}.premium-slide__content p{font-size:14px}.slider-nav{display:none}.premium-slider__footer{padding-top:10px;flex-wrap:wrap}.premium-slider__progress{order:3;max-width:none;width:100%}
  .grid.cards{grid-template-columns:1fr}
  .contacts-panel__intro h3{font-size:30px;max-width:none}
  .contacts-grid{gap:12px}
  .contact-card{padding:15px 16px;align-items:flex-start}
  .contact-card__meta strong{font-size:16px}
  .map--large{height:420px;min-height:420px}
}

.admin-dashboard{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
  margin-bottom:18px;
}
.metric{padding:18px;border:1px solid rgba(255,255,255,.08);border-radius:20px}
.metric--accent{box-shadow:0 0 0 1px rgba(42,167,255,.18) inset, 0 16px 40px rgba(42,167,255,.08)}
.metric__label{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.metric__value{font-size:36px;font-weight:900;line-height:1;margin-bottom:6px}
.metric__hint{font-size:13px;color:var(--muted)}
.panel__head--stack{align-items:stretch;gap:14px}
.panel__head--spaced{justify-content:space-between}
.requests-toolbar{display:flex;gap:10px;align-items:center}
.requests-search{min-width:280px}
.requests-filter{min-width:210px}
.requests-table td{vertical-align:top}
.request-id{font-size:18px;font-weight:900}
.request-main{font-weight:800;color:var(--text)}
.request-comment{max-width:240px;white-space:pre-wrap;color:rgba(234,241,255,.84)}
.request-note{min-width:220px;resize:vertical}
.request-link{display:inline-block;margin-top:4px;color:#86cfff;font-weight:700}
.request-link:hover{color:#c7e8ff}
.tiny{font-size:12px}
.status-badge{display:inline-flex;align-items:center;justify-content:center;padding:8px 10px;border-radius:999px;font-size:12px;font-weight:900;margin-bottom:8px;border:1px solid transparent}
.status-badge.is-new{background:rgba(255,190,60,.14);border-color:rgba(255,190,60,.34);color:#ffd98c}
.status-badge.is-confirmed{background:rgba(61,180,255,.14);border-color:rgba(61,180,255,.34);color:#9fdcff}
.status-badge.is-progress{background:rgba(100,108,255,.14);border-color:rgba(100,108,255,.34);color:#b7baff}
.status-badge.is-muted{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.12);color:#c5d0df}
.status-badge.is-done{background:rgba(71,214,122,.14);border-color:rgba(71,214,122,.34);color:#a8f0bd}
.status-badge.is-cancelled{background:rgba(255,95,95,.14);border-color:rgba(255,95,95,.34);color:#ffb4b4}
.request-status-select{min-width:170px}
@media (max-width: 1100px){
  .admin-dashboard{grid-template-columns:repeat(2,minmax(0,1fr))}
  .requests-toolbar{flex-direction:column;align-items:stretch}
  .requests-search,.requests-filter{min-width:0;width:100%}
}
@media (max-width: 760px){
  .admin-dashboard{grid-template-columns:1fr}
  .panel__head--spaced{flex-direction:column}
  .requests-table{display:block;overflow:auto}
}


.request-money{min-width:120px}
.request-id{font-size:16px;letter-spacing:.03em}
@media (max-width: 1280px){
  .admin-dashboard{grid-template-columns:repeat(3,minmax(0,1fr))}
}



/* --- Personal cabinet --- */
.hp-field{position:absolute!important;left:-9999px!important;opacity:0!important;pointer-events:none!important}
.auth-page,.cabinet-page{min-height:100vh}
.cabinet-page{display:flex;flex-direction:column}
.cabinet-page main{flex:1 0 auto}
.auth-layout{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 40px)}
.auth-layout--single{max-width:760px}
.auth-back{display:inline-flex;margin-bottom:18px;color:var(--text);text-decoration:none;opacity:.82}
.auth-card{display:grid;grid-template-columns:1.05fr .95fr;gap:28px;padding:28px;border-radius:28px;max-width:1080px;width:100%}
.auth-card--compact{max-width:920px}
.auth-card--single{grid-template-columns:1fr;max-width:760px}
.auth-card__side{display:flex;flex-direction:column;justify-content:center}
.auth-card__side--full{min-height:340px}
.auth-card__form{display:flex;flex-direction:column;justify-content:center;padding:8px 0}
.auth-benefits{display:grid;gap:10px;margin:18px 0 0;padding:0;list-style:none;color:var(--muted)}
.auth-benefits li::before{content:'• ';color:var(--accent)}
.auth-benefits--plain{display:grid;gap:8px}
.auth-card__foot{margin-top:14px;color:var(--muted)}
.auth-card__foot a{color:var(--text)}
.form--stack{display:grid;gap:14px}
.field{display:grid;gap:8px}
.field span{font-size:13px;color:var(--muted);font-weight:700}
.field input,.field textarea,.field select{width:100%;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);color:var(--text);border-radius:16px;padding:14px 15px;outline:none}
.field textarea{resize:vertical;min-height:110px}
.auth-submit{width:100%;justify-content:center}
.auth-msg{min-height:24px}
.auth-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}
.cabinet-layout{display:grid;gap:22px}
.cabinet-grid{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(320px,.9fr);gap:22px;align-items:start}
.cabinet-card{padding:22px;border-radius:24px}
.cabinet-requests{display:grid;gap:14px}
.glass-sub{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:20px}
.cabinet-request summary{list-style:none;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:18px 18px 16px;cursor:pointer}
.cabinet-request summary::-webkit-details-marker{display:none}
.cabinet-request__body{padding:0 18px 18px}
.cabinet-request__meta{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:14px}
.cabinet-request__meta span{display:block;font-size:12px;color:var(--muted);margin-bottom:5px}
.cabinet-request__meta strong{font-size:14px}
.cabinet-note{padding:12px 14px;border-radius:16px;background:rgba(255,255,255,.04);margin-bottom:10px}
.cabinet-history{display:grid;gap:10px;padding-top:4px}
.history-item{padding:12px 14px;border-radius:16px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06)}
.mt16{margin-top:16px}.mt8{margin-top:8px}
.status-badge.is-in_progress{background:rgba(100,108,255,.14);border-color:rgba(100,108,255,.34);color:#b7baff}
.status-badge.is-no_answer{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.12);color:#c5d0df}
.status-badge.is-done{background:rgba(71,214,122,.14);border-color:rgba(71,214,122,.34);color:#a8f0bd}
.status-badge.is-cancelled{background:rgba(255,95,95,.14);border-color:rgba(255,95,95,.34);color:#ffb4b4}
.status-badge.is-new{background:rgba(255,190,60,.14);border-color:rgba(255,190,60,.34);color:#ffd98c}
.status-badge.is-confirmed{background:rgba(61,180,255,.14);border-color:rgba(61,180,255,.34);color:#9fdcff}
@media (max-width: 980px){
  .auth-card,.cabinet-grid{grid-template-columns:1fr}
}
@media (max-width: 640px){
  .auth-card,.cabinet-card{padding:18px}
  .cabinet-request__meta{grid-template-columns:1fr}
  .auth-actions{flex-direction:column}
}


/* --- Auth pages polish --- */
.auth-page{display:flex;flex-direction:column;min-height:100vh}
.auth-shell{flex:1;display:flex;flex-direction:column}
.auth-header{padding:18px 0 6px}
.auth-header__row{display:flex;align-items:center;justify-content:space-between;gap:16px}
.auth-brand{display:inline-flex;align-items:center;gap:12px;min-width:0}
.auth-brand__logo{height:40px;width:auto;max-width:260px;display:block}
.auth-brand__text{display:flex;flex-direction:column;gap:2px}
.auth-brand__title{font-weight:900;letter-spacing:.2px}
.auth-brand__sub{font-size:13px;color:var(--muted)}
.auth-link{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  min-height:44px;padding:0 14px;border-radius:14px;
  border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.05);
  color:var(--text);font-weight:700;text-decoration:none;
  transition:.2s ease;
}
.auth-link:hover{border-color:rgba(42,167,255,.45);box-shadow:0 0 0 6px rgba(42,167,255,.08);transform:translateY(-1px)}
.auth-link--ghost{background:rgba(255,255,255,.04)}
.auth-link__arrow{opacity:.78;font-size:16px;line-height:1}
.auth-layout{flex:1;display:flex;align-items:center;justify-content:center;min-height:0;padding-bottom:22px}
.auth-card h1{font-size:26px;line-height:1.12;margin:18px 0 12px}
.auth-footer{margin-top:auto}
.auth-footer .footer__row{padding:18px 0}
@media (max-width: 820px){
  .auth-header__row{align-items:flex-start;flex-direction:column}
  .auth-brand__text{display:none}
  .auth-layout{padding-top:8px}
  .auth-link{width:100%;justify-content:center}
}


/* --- Premium cabinet refresh --- */
.premium-cabinet{gap:26px}
.cabinet-hero{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(360px,.95fr);gap:22px;align-items:start}
.cabinet-welcome{position:relative;overflow:hidden;min-height:280px;padding:30px;border-radius:28px;background:
  radial-gradient(circle at top right, rgba(42,167,255,.18), transparent 34%),
  linear-gradient(135deg, rgba(255,255,255,.045), rgba(255,255,255,.02));}
.cabinet-welcome::after{content:'';position:absolute;right:-80px;bottom:-100px;width:260px;height:260px;border-radius:50%;background:radial-gradient(circle, rgba(255,200,60,.18), transparent 68%);pointer-events:none}
.cabinet-welcome__eyebrow{display:inline-flex;align-items:center;min-height:38px;padding:0 14px;border-radius:999px;border:1px solid rgba(42,167,255,.28);background:rgba(10,71,118,.18);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:#a9d8ff;font-weight:800;margin-bottom:18px}
.cabinet-welcome__title{font-size:44px;line-height:.98;margin:0 0 16px;font-weight:900;max-width:740px}
.cabinet-welcome__text{max-width:760px;color:var(--muted);font-size:18px;line-height:1.65;margin:0 0 20px}
.cabinet-pills{display:flex;flex-wrap:wrap;gap:10px}
.cabinet-pill{display:inline-flex;align-items:center;min-height:40px;padding:0 14px;border-radius:999px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);font-weight:700;color:#dfe9f6}
.cabinet-profile-card{padding:26px;border-radius:28px;background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));box-shadow:0 22px 70px rgba(0,0,0,.28)}
.cabinet-profile-card__top{display:flex;align-items:center;justify-content:space-between;gap:18px}
.cabinet-avatar{width:64px;height:64px;border-radius:20px;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:900;color:#fff;background:linear-gradient(135deg, rgba(42,167,255,.85), rgba(18,69,120,.95));box-shadow:0 12px 35px rgba(42,167,255,.24)}
.cabinet-profile-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.cabinet-grid--premium{grid-template-columns:minmax(0,1.15fr) minmax(360px,.72fr);gap:22px}
.cabinet-requests-card,.cabinet-request-form-card{padding:24px;border-radius:28px}
.cabinet-request{transition:transform .18s ease,border-color .18s ease,background .18s ease}
.cabinet-request[open]{background:rgba(255,255,255,.055);border-color:rgba(42,167,255,.16)}
.cabinet-request:hover{transform:translateY(-1px)}
.cabinet-empty{padding:28px;border-radius:22px;background:linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.02));border:1px solid rgba(255,255,255,.08)}
.cabinet-empty__title{font-size:24px;font-weight:900;margin-bottom:8px}
.cabinet-note--accent{background:linear-gradient(180deg, rgba(42,167,255,.09), rgba(255,255,255,.04));border:1px solid rgba(42,167,255,.16)}
.cabinet-page .topbar{background:rgba(7,10,16,.72)}
.cabinet-page .topbar__row{padding:16px 0}
.cabinet-page .brand .logo{filter:drop-shadow(0 6px 18px rgba(255,191,0,.18))}
.cabinet-footer{margin-top:30px}
.cabinet-footer .footer__row{padding:18px 0}
@media (max-width: 1180px){
  .cabinet-hero,.cabinet-grid--premium{grid-template-columns:1fr}
}
@media (max-width: 760px){
  .cabinet-welcome{padding:22px;min-height:auto}
  .cabinet-welcome__title{font-size:32px}
  .cabinet-welcome__text{font-size:16px}
  .cabinet-profile-grid{grid-template-columns:1fr}
}
