@font-face{
  font-family: "Inter";
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("/assets/fonts/InterVariable.woff2") format("woff2-variations");
}
@font-face{
  font-family: "Inter";
  font-style: italic;
  font-weight: 100 900;
  font-display: swap;
  src: url("/assets/fonts/InterVariable-Italic.woff2") format("woff2-variations");
}
:root{
  --bg: #070814;
  --fg: rgba(255,255,255,.88);
  --muted: rgba(255,255,255,.62);
  --glass: rgba(255,255,255,.06);
  --shadow: 0 25px 80px rgba(0,0,0,.55);
  --rad: 26px;
  --accent1: #7c3aed;
  --accent2: #22d3ee;
  --accent3: #f472b6;
  --accent4: #a3e635;
}

:root {
  --font-main: 'Inter', -apple-system, BlinkMacSystemFont,
  'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
}

body {
  font-family: var(--font-main);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Inter, Arial, "Noto Sans", "Apple Color Emoji","Segoe UI Emoji";
  background: radial-gradient(1200px 700px at 20% 10%, rgba(124,58,237,.25), transparent 55%),
              radial-gradient(1000px 700px at 80% 30%, rgba(34,211,238,.22), transparent 55%),
              radial-gradient(900px 650px at 70% 90%, rgba(244,114,182,.18), transparent 55%),
              radial-gradient(900px 650px at 10% 90%, rgba(163,230,53,.12), transparent 60%),
              var(--bg);
  color:var(--fg);
  overflow-x:hidden;
}
.grid-overlay{
  position:fixed; inset:0;
  pointer-events:none;
  background:
    linear-gradient(to right, rgba(255,255,255,.06) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,.05) 1px, transparent 1px);
  background-size: 72px 72px;
  mask-image: radial-gradient(700px 480px at 50% 18%, rgba(0,0,0,1), transparent 70%);
  opacity:.35;
  z-index:0;
}
#fx{
  position:fixed; inset:0;
  width:100%; height:100%;
  z-index:0;
  opacity:.9;
  pointer-events:none;
  mix-blend-mode: screen;
  filter: saturate(1.05) contrast(1.05);
}
.cursor{
  position:fixed;
  width: 28px; height: 28px;
  border-radius:999px;
  pointer-events:none;
  z-index:9999;
  transform: translate(-50%, -50%);
  background: radial-gradient(circle at 30% 30%, rgba(34,211,238,.85), rgba(124,58,237,.0) 55%),
              radial-gradient(circle at 70% 70%, rgba(244,114,182,.65), rgba(244,114,182,0) 60%);
  filter: blur(.2px);
  opacity:.7;
  transition: transform .08s ease, opacity .25s ease;
}
@media (prefers-reduced-motion: reduce){ .cursor{display:none} }

.wrap{position:relative; z-index:1}
.container{max-width:1180px; margin:0 auto; padding: 26px 20px 90px}
header{
  position:sticky; top:0; z-index:50;
  backdrop-filter: blur(14px);
  background: linear-gradient(to bottom, rgba(7,8,20,.72), rgba(7,8,20,.35));
  border-bottom:1px solid rgba(255,255,255,.08);
}
.nav{
  display:flex; align-items:center; justify-content:space-between;
  gap:16px;
  padding:14px 20px;
  max-width:1180px; margin:0 auto;
}
.brand{display:flex; align-items:center; gap:12px; min-width: 220px;}
.logo{
  width:38px; height:38px; border-radius:14px;
  background: conic-gradient(from 210deg, var(--accent2), var(--accent1), var(--accent3), var(--accent4), var(--accent2));
  box-shadow: 0 10px 25px rgba(124,58,237,.25), 0 10px 25px rgba(34,211,238,.18);
  position:relative; overflow:hidden;
}
.logo:after{
  content:"";
  position:absolute; inset:-30%;
  background: radial-gradient(circle at 35% 35%, rgba(255,255,255,.8), transparent 55%);
  transform: rotate(20deg);
  opacity:.35;
}
.logo.mini{ width:34px; height:34px; border-radius: 14px; }
.brand b{font-size:14px; letter-spacing:.35px}
.brand span{display:block; font-size:12px; color:var(--muted); margin-top:1px}

.links{display:flex; align-items:center; gap:10px; flex-wrap:wrap; justify-content:center;}
.links a{
  color:rgba(255,255,255,.72);
  text-decoration:none;
  font-size:13px;
  padding:9px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  transition: transform .2s ease, background .2s ease, border-color .2s ease, color .2s ease;
}
.links a:hover{
  transform: translateY(-1px);
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.18);
  color: rgba(255,255,255,.9);
}

.cta{display:flex; align-items:center; gap:10px; min-width: 240px; justify-content:flex-end;}
.btn{
  appearance:none; border:none; cursor:pointer;
  color: rgba(255,255,255,.9);
  background: linear-gradient(120deg, rgba(124,58,237,.95), rgba(34,211,238,.85));
  padding:10px 14px;
  border-radius:999px;
  font-weight:650;
  font-size:13px;
  box-shadow: 0 14px 30px rgba(124,58,237,.18), 0 14px 30px rgba(34,211,238,.10);
  transition: transform .2s ease, filter .2s ease;
  white-space:nowrap;
  text-decoration:none;
  display:inline-flex; align-items:center; justify-content:center;
  position:relative;
}
.btn:hover{transform: translateY(-1px); filter:saturate(1.05) brightness(1.03)}
.btn:active{transform: translateY(0px) scale(.99)}
.ghost{
  background: rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.14);
  box-shadow:none;
  font-weight:600;
}

/* hero */
.hero{
  padding: 54px 0 26px;
  display:grid;
  grid-template-columns: 1.25fr .75fr;
  gap: 26px;
  align-items:stretch;
}
@media (max-width: 980px){
  .hero{grid-template-columns:1fr; padding-top: 34px}
  .cta{min-width:auto}
  .brand{min-width:auto}
}
.card{
  border-radius: var(--rad);
  background: linear-gradient(180deg, rgba(255,255,255,.075), rgba(255,255,255,.03));
  border:1px solid rgba(255,255,255,.10);
  box-shadow: var(--shadow);
  position:relative;
  overflow:hidden;
}
.card:before{
  content:"";
  position:absolute; inset:-2px;
  background: radial-gradient(500px 220px at 18% 20%, rgba(34,211,238,.22), transparent 58%),
              radial-gradient(520px 250px at 70% 10%, rgba(124,58,237,.22), transparent 60%),
              radial-gradient(520px 250px at 80% 80%, rgba(244,114,182,.14), transparent 60%);
  opacity:.9;
  pointer-events:none;
}
.card > *{position:relative; z-index:1}
.hero-main{padding: 26px 26px 24px}
.tagline{display:flex; flex-wrap:wrap; gap:10px; align-items:center; margin-bottom: 14px;}
.chip{
  display:inline-flex; gap:8px; align-items:center;
  border-radius:999px;
  padding:8px 10px;
  font-size:12px;
  color: rgba(255,255,255,.8);
  background: rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.12);
}
.dot{
  width:8px; height:8px; border-radius:99px;
  background: radial-gradient(circle at 30% 30%, var(--accent2), rgba(34,211,238,.2));
  box-shadow: 0 0 0 6px rgba(34,211,238,.10);
}
h1{
  margin: 10px 0 12px;
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.15;

}

.hero-h1{
  font-size: clamp(26px, 4.2vw, 42px);
  line-height: 1.05;
  max-inline-size: 26ch;
  margin-inline: auto;
}

.subtitle{
  font-size: 16px;
  line-height: 1.6;
  font-weight: 400;
  color: rgba(255,255,255,.72); /* или var(--muted), если есть */
  max-width: 640px;

}
.hero-actions{display:flex; gap:12px; flex-wrap:wrap; align-items:center; margin-top: 18px}
.hint{font-size:12px; color: rgba(255,255,255,.55); display:flex; align-items:center; gap:8px;}
.kbd{
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  font-size:11px;
  padding: 4px 8px;
  border-radius:10px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
}
.hero-side{padding: 18px}
.metric{
  display:grid; gap:10px;
  padding: 16px;
  border-radius: 18px;
  background: rgba(255,255,255,.045);
  border:1px solid rgba(255,255,255,.10);
  margin-bottom: 12px;
}
.metric b{font-size:14px}
.metric p{margin:0; color:var(--muted); font-size:12px; line-height:1.45}
.bar{
  height:10px; border-radius:999px;
  background: rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.10);
  overflow:hidden;
}
.bar > i{
  display:block; height:100%;
  width:0%;
  border-radius:999px;
  background: linear-gradient(90deg, rgba(34,211,238,.95), rgba(124,58,237,.95), rgba(244,114,182,.92));
  box-shadow: 0 0 24px rgba(34,211,238,.25);
  transition: width 1.2s ease;
}

/* marquee */
.marquee{
  margin: 22px 0 0;
  border-top:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.02);
  overflow:hidden;
}
.marquee .track{
  display:flex;
  gap: 18px;
  width:max-content;
  animation: scroll 22s linear infinite;
  padding: 12px 0;
}
.marquee span{
  color: rgba(255,255,255,.68);
  font-size: 13px;
  letter-spacing: .28px;
  white-space:nowrap;
  padding: 6px 10px;
  border-radius: 999px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
}
@keyframes scroll{ from{transform:translateX(0)} to{transform:translateX(-50%)} }
@media (prefers-reduced-motion: reduce){ .marquee .track{animation:none} }

/* sections */
section{margin-top: 32px}
.sec-head{display:flex; align-items:flex-end; justify-content:space-between; gap:16px; margin: 10px 0 12px;}
.sec-head h2{margin:0; font-size: 22px; letter-spacing: -0.01em;}
.sec-head p{margin:0; color:var(--muted); font-size:13px}
.grid{display:grid; grid-template-columns: repeat(12, 1fr); gap: 14px;}

.service{
  grid-column: span 6;
  padding: 18px;
  border-radius: var(--rad);
  background: rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.11);
  position:relative;
  overflow:hidden;
  transform-style: preserve-3d;
  transition: transform .18s ease, border-color .2s ease, background .2s ease;
  will-change: transform;
}
.service:hover{ border-color: rgba(255,255,255,.20); background: rgba(255,255,255,.06); }
.service:before{
  content:"";
  position:absolute; inset:-60% -40%;
  background: radial-gradient(circle at 30% 30%, rgba(34,211,238,.18), transparent 55%),
              radial-gradient(circle at 60% 40%, rgba(124,58,237,.16), transparent 60%),
              radial-gradient(circle at 40% 70%, rgba(244,114,182,.10), transparent 62%);
  transform: translateZ(-1px);
  opacity:.9;
  pointer-events:none;
}
.service h3{margin: 10px 0 8px; font-size: 16px}
.service p{margin: 0; color: var(--muted); font-size: 13px; line-height: 1.5}
.badge{
  display:inline-flex; align-items:center; gap:8px;
  font-size: 12px; color: rgba(255,255,255,.8);
  padding: 7px 10px;
  border-radius: 999px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
}
.icon{
  width: 22px; height: 22px;
  border-radius: 10px;
  background: linear-gradient(135deg, rgba(34,211,238,.95), rgba(124,58,237,.95));
  box-shadow: 0 10px 20px rgba(124,58,237,.18);
}
.icon.alt{background: linear-gradient(135deg, rgba(244,114,182,.95), rgba(34,211,238,.90))}
.icon.green{background: linear-gradient(135deg, rgba(163,230,53,.95), rgba(34,211,238,.85))}
.icon.orange{background: linear-gradient(135deg, rgba(251,191,36,.95), rgba(244,114,182,.85))}
@media (max-width: 980px){ .service{grid-column: span 12} }

/* portfolio */
.shots{grid-column: span 12; display:grid; grid-template-columns: repeat(12, 1fr); gap:14px;}
.shot{
  grid-column: span 4;
  border-radius: var(--rad);
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  overflow:hidden;
  position:relative;
  min-height: 170px;
}
.shot:before{
  content:"";
  position:absolute; inset:-30%;
  background:
    radial-gradient(circle at 30% 25%, rgba(34,211,238,.28), transparent 55%),
    radial-gradient(circle at 65% 35%, rgba(124,58,237,.24), transparent 60%),
    radial-gradient(circle at 45% 75%, rgba(244,114,182,.18), transparent 58%);
  filter: blur(2px);
  opacity:.95;
}
.shot .cap{
  position:absolute; left:14px; right:14px; bottom:14px;
  padding: 10px 12px;
  border-radius: 18px;
  background: rgba(7,8,20,.45);
  border:1px solid rgba(255,255,255,.12);
  backdrop-filter: blur(10px);
  display:flex; align-items:center; justify-content:space-between; gap:10px;
}
.shot b{font-size: 13px}
.shot small{color: var(--muted); font-size: 12px}
.pill{
  font-size: 11px;
  padding: 6px 10px;
  border-radius: 999px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  color: rgba(255,255,255,.78);
  white-space:nowrap;
}
@media (max-width: 980px){ .shot{grid-column: span 12; min-height: 160px} }

/* contact */
.contact{display:grid; grid-template-columns: 1fr 1fr; gap:14px;}
@media (max-width: 980px){ .contact{grid-template-columns:1fr} }
.form{
  padding: 18px;
  border-radius: var(--rad);
  background: rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.11);
  position:relative;
  overflow:hidden;
}
.form:before{
  content:"";
  position:absolute; inset:-60% -40%;
  background:
    radial-gradient(circle at 25% 30%, rgba(163,230,53,.13), transparent 55%),
    radial-gradient(circle at 70% 25%, rgba(34,211,238,.16), transparent 58%),
    radial-gradient(circle at 60% 80%, rgba(124,58,237,.14), transparent 60%);
  opacity:.9;
  pointer-events:none;
}
.form > *{position:relative; z-index:1}
.row{display:grid; grid-template-columns:1fr 1fr; gap:10px}
@media (max-width: 680px){ .row{grid-template-columns:1fr} }
label{display:block; font-size:12px; color: rgba(255,255,255,.72); margin: 10px 0 6px}
input, select, textarea{
  width:100%;
  padding: 12px 12px;
  border-radius: 14px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(7,8,20,.35);
  color: rgba(255,255,255,.9);
  outline:none;
  transition: border-color .2s ease;
}
input:focus, select:focus, textarea:focus{
  border-color: rgba(34,211,238,.45);
  box-shadow: 0 0 0 4px rgba(34,211,238,.10);
}
textarea{min-height: 120px; resize: vertical}
.form-actions{margin-top: 12px; display:flex; align-items:center; gap:10px; flex-wrap:wrap;}
.status{font-size: 12px; color: rgba(255,255,255,.65);}

.reveal{opacity:0; transform: translateY(14px); transition: opacity .7s ease, transform .7s ease;}
.reveal.in{opacity:1; transform: translateY(0)}
@media (prefers-reduced-motion: reduce){ .reveal{opacity:1; transform:none} }

footer{
  margin-top: 34px;
  padding-top: 18px;
  border-top:1px solid rgba(255,255,255,.08);
  display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap;
  color: rgba(255,255,255,.55);
  font-size: 12px;
}
.social{display:flex; gap:10px; flex-wrap:wrap;}
.social a{
  color: rgba(255,255,255,.7);
  text-decoration:none;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  padding: 8px 10px;
  border-radius: 999px;
  position:relative;
}
.mono{font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace}

/* ===== Mobile nav / burger ===== */
.burger{
  display:none;
  width:44px; height:44px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.05);
  backdrop-filter: blur(10px);
  box-shadow: 0 18px 40px rgba(0,0,0,.35);
  cursor:pointer;
  position:relative;
  overflow:hidden;
  -webkit-tap-highlight-color: transparent;
  transform: translate3d(0,0,0);
}
.burger span{
  position:absolute;
  left: 12px; right: 12px;
  height:2px;
  border-radius:99px;
  background: linear-gradient(90deg, rgba(34,211,238,.95), rgba(124,58,237,.95), rgba(244,114,182,.92));
  transform-origin:center;
  transition: transform .22s ease, top .22s ease, opacity .18s ease;
}
.burger span:nth-child(1){ top: 14px; }
.burger span:nth-child(2){ top: 21px; opacity:.9; }
.burger span:nth-child(3){ top: 28px; }
.burger.open span:nth-child(1){ top: 21px; transform: rotate(45deg); }
.burger.open span:nth-child(2){ opacity:0; }
.burger.open span:nth-child(3){ top: 21px; transform: rotate(-45deg); }
.burger.magnet{
  box-shadow: 0 22px 55px rgba(0,0,0,.45), 0 0 0 5px rgba(34,211,238,.10);
  border-color: rgba(34,211,238,.28);
}
@media (max-width: 860px){
  .links{ display:none; }
  .burger{ display:inline-flex; align-items:center; justify-content:center; }
  .cta{ gap:10px; }
}

.menu-backdrop{
  position:fixed; inset:0;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(6px);
  z-index:120;
  opacity:0;
  transition: opacity .22s ease;
}
.menu-backdrop.show{ opacity:1; }

.mobile-menu{
  position:fixed;
  top: 14px;
  right: 14px;
  width: min(420px, calc(100vw - 28px));
  height: min(640px, calc(100vh - 28px));
  z-index:130;
  border-radius: 28px;
  border:1px solid rgba(255,255,255,.14);
  background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(7,8,20,.55));
  box-shadow: 0 30px 90px rgba(0,0,0,.65);
  overflow:hidden;

  transform: translateY(-6px) translateX(12px) scale(.98);
  opacity:0;
  transition: transform .24s ease, opacity .24s ease;
  touch-action: pan-y;
}
.mobile-menu.show{
  transform: translateY(0) translateX(0) scale(1);
  opacity:1;
}
.mobile-menu.dragging{ transition: none !important; }
.mobile-menu:before{
  content:"";
  position:absolute; inset:-30%;
  background:
    radial-gradient(circle at 25% 20%, rgba(34,211,238,.22), transparent 55%),
    radial-gradient(circle at 70% 18%, rgba(124,58,237,.20), transparent 60%),
    radial-gradient(circle at 55% 85%, rgba(244,114,182,.14), transparent 60%);
  opacity:.95;
  pointer-events:none;
}
.mobile-menu > *{ position:relative; z-index:1; }
.mm-head{
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding: 16px 16px 12px;
  border-bottom: 1px solid rgba(255,255,255,.10);
}
.mm-brand{display:flex; align-items:center; gap:12px;}
.mm-brand b{ font-size: 13px; letter-spacing:.2px; }
.mm-brand span{ display:block; font-size: 12px; color: rgba(255,255,255,.62); margin-top:1px; }
.mm-close{
  width:44px; height:44px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.05);
  color: rgba(255,255,255,.85);
  cursor:pointer;
  position:relative;
}
.mm-body{ padding: 14px; display:grid; gap: 10px; }
.mm-link{
  text-decoration:none;
  color: rgba(255,255,255,.86);
  padding: 14px 14px;
  border-radius: 18px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.05);
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
  position:relative;
}
.mm-link:hover{ transform: translateY(-1px); border-color: rgba(255,255,255,.20); background: rgba(255,255,255,.07); }
.mm-link.active{ border-color: rgba(34,211,238,.38); box-shadow: 0 0 0 4px rgba(34,211,238,.10); }
.mm-sep{ height:1px; background: rgba(255,255,255,.10); margin: 6px 2px; }
.mm-cta{
  display:flex; justify-content:center; align-items:center;
  text-decoration:none;
  padding: 14px 14px;
  border-radius: 18px;
  color: rgba(255,255,255,.95);
  font-weight: 700;
  background: linear-gradient(120deg, rgba(124,58,237,.95), rgba(34,211,238,.85));
  box-shadow: 0 18px 40px rgba(124,58,237,.18), 0 18px 40px rgba(34,211,238,.10);
  position:relative;
}
.mm-toggle{
  padding: 14px 14px;
  border-radius: 18px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  color: rgba(255,255,255,.85);
  cursor:pointer;
  position:relative;
}
.mm-foot{
  padding: 14px;
  border-top: 1px solid rgba(255,255,255,.10);
  display:flex; gap:10px; flex-wrap:wrap;
}
.mm-chip{
  font-size: 12px;
  color: rgba(255,255,255,.70);
  padding: 8px 10px;
  border-radius: 999px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
}

/* lock scroll when overlays open */
body.locked{ overflow:hidden; }

/* ===== Bottom Dock (mobile) ===== */
.dock{
  position: fixed;
  left: 12px; right: 12px;
  bottom: 12px;
  z-index: 140;
  display:none;

  padding: 10px;
  border-radius: 26px;
  border:1px solid rgba(255,255,255,.14);
  background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(7,8,20,.55));
  box-shadow: 0 25px 80px rgba(0,0,0,.65);
  backdrop-filter: blur(14px);

  gap: 10px;
  align-items: stretch;
  justify-content: space-between;
}
.dock:before{
  content:"";
  position:absolute; inset:-40%;
  background:
    radial-gradient(circle at 20% 30%, rgba(34,211,238,.20), transparent 55%),
    radial-gradient(circle at 80% 25%, rgba(124,58,237,.18), transparent 60%),
    radial-gradient(circle at 55% 90%, rgba(244,114,182,.12), transparent 60%);
  opacity:.9;
  pointer-events:none;
}
.dock > *{ position:relative; z-index:1; }
.dock-btn{
  flex: 1;
  display:flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  text-decoration:none;
  color: rgba(255,255,255,.86);
  border-radius: 18px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.05);
  padding: 12px 12px;
  transition: transform .18s ease, background .18s ease, border-color .18s ease;
  user-select:none;
  -webkit-tap-highlight-color: transparent;
  position:relative;
}
.dock-btn:active{ transform: scale(.99); }
.dock-btn:hover{ background: rgba(255,255,255,.07); border-color: rgba(255,255,255,.20); }
.dock-ic{
  width: 26px; height: 26px;
  border-radius: 12px;
  display:grid; place-items:center;
  font-size: 14px;
  background: linear-gradient(135deg, rgba(34,211,238,.85), rgba(124,58,237,.90));
  box-shadow: 0 12px 30px rgba(124,58,237,.14);
}
.dock-t{ font-size: 12px; letter-spacing:.15px; }
.dock-primary{
  background: linear-gradient(120deg, rgba(124,58,237,.95), rgba(34,211,238,.85));
  border-color: rgba(255,255,255,.18);
}
.dock-primary .dock-ic{
  background: rgba(0,0,0,.15);
  border:1px solid rgba(255,255,255,.14);
  box-shadow:none;
}
.dock-btn.active{
  border-color: rgba(34,211,238,.38);
  box-shadow: 0 0 0 4px rgba(34,211,238,.10);
}
@media (max-width: 860px){
  .dock{ display:flex; }
  body{ padding-bottom: 92px; }
}

/* ===== Scroll progress ===== */
.scroll-progress{
  position: fixed;
  top: 0; left: 0; right: 0;
  height: 3px;
  z-index: 200;
  background: rgba(255,255,255,.06);
  border-bottom: 1px solid rgba(255,255,255,.08);
  backdrop-filter: blur(10px);
}
.scroll-progress i{
  display:block;
  height:100%;
  width:0%;
  background: linear-gradient(90deg, rgba(34,211,238,.95), rgba(124,58,237,.95), rgba(244,114,182,.90), rgba(163,230,53,.85));
  box-shadow: 0 0 20px rgba(34,211,238,.22);
  transform: translateZ(0);
}

/* ===== Command palette ===== */
.palette-backdrop{
  position: fixed; inset:0;
  z-index: 210;
  background: rgba(0,0,0,.62);
  backdrop-filter: blur(10px);
  opacity:0;
  transition: opacity .2s ease;
}
.palette-backdrop.show{ opacity:1; }
.palette{
  position: fixed;
  left: 50%;
  top: 12vh;
  transform: translateX(-50%) translateY(-6px) scale(.98);
  width: min(720px, calc(100vw - 26px));
  max-height: min(74vh, 740px);
  z-index: 220;
  border-radius: 28px;
  border: 1px solid rgba(255,255,255,.14);
  background: linear-gradient(180deg, rgba(255,255,255,.09), rgba(7,8,20,.62));
  box-shadow: 0 40px 120px rgba(0,0,0,.75);
  overflow:hidden;
  opacity:0;
  transition: transform .22s ease, opacity .22s ease;
}
.palette:before{
  content:"";
  position:absolute; inset:-35%;
  background:
    radial-gradient(circle at 20% 20%, rgba(34,211,238,.22), transparent 55%),
    radial-gradient(circle at 75% 18%, rgba(124,58,237,.20), transparent 60%),
    radial-gradient(circle at 58% 90%, rgba(244,114,182,.14), transparent 60%);
  opacity:.95;
  pointer-events:none;
}
.palette > *{ position:relative; z-index:1; }
.palette.show{ opacity:1; transform: translateX(-50%) translateY(0) scale(1); }
.pal-top{ display:flex; align-items:center; justify-content:space-between; padding: 14px 14px 10px; border-bottom: 1px solid rgba(255,255,255,.10); }
.pal-kbd{display:flex; gap:6px; align-items:center; color: rgba(255,255,255,.66); font-size:12px}
.pal-close{
  width:44px; height:44px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.05);
  color: rgba(255,255,255,.85);
  cursor:pointer;
  position:relative;
}
.pal-input{
  width: calc(100% - 28px);
  margin: 12px 14px 8px;
  padding: 14px 14px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(7,8,20,.40);
  color: rgba(255,255,255,.92);
  outline:none;
}
.pal-input:focus{ border-color: rgba(34,211,238,.45); box-shadow: 0 0 0 4px rgba(34,211,238,.10); }
.pal-hint{ margin: 0 14px 10px; color: rgba(255,255,255,.56); font-size: 12px; }
.pal-list{
  margin: 0 10px 12px;
  padding: 6px;
  border-radius: 20px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  overflow:auto;
  max-height: calc(min(74vh, 740px) - 220px);
}
.pal-item{
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding: 12px 12px;
  border-radius: 16px;
  border:1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.02);
  cursor:pointer;
  transition: transform .14s ease, background .14s ease, border-color .14s ease;
  position:relative;
}
.pal-item + .pal-item{ margin-top: 8px; }
.pal-item:hover{ transform: translateY(-1px); background: rgba(255,255,255,.05); border-color: rgba(255,255,255,.16); }
.pal-item.active{
  border-color: rgba(34,211,238,.38);
  box-shadow: 0 0 0 4px rgba(34,211,238,.10);
  background: rgba(255,255,255,.06);
}
.pal-left{ display:flex; align-items:center; gap:10px; }
.pal-ic{
  width: 28px; height: 28px;
  border-radius: 14px;
  display:grid; place-items:center;
  background: linear-gradient(135deg, rgba(34,211,238,.85), rgba(124,58,237,.90));
  border:1px solid rgba(255,255,255,.10);
}
.pal-txt b{ display:block; font-size: 13px; }
.pal-txt small{ color: rgba(255,255,255,.60); font-size: 12px; }
.pal-k{
  font-size: 11px;
  padding: 6px 10px;
  border-radius: 999px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  color: rgba(255,255,255,.72);
  white-space: nowrap;
}
.pal-foot{ padding: 12px 14px 14px; border-top: 1px solid rgba(255,255,255,.10); display:flex; gap:10px; flex-wrap:wrap; }
.pal-chip{
  font-size: 12px;
  color: rgba(255,255,255,.70);
  padding: 8px 10px;
  border-radius: 999px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
}

/* ===== Ripple ===== */
.ripple{
  position:absolute;
  border-radius:999px;
  transform: translate(-50%, -50%);
  pointer-events:none;
  width: 10px; height: 10px;
  background: radial-gradient(circle, rgba(34,211,238,.40), rgba(124,58,237,.18), rgba(244,114,182,0) 70%);
  animation: ripple .7s ease-out forwards;
  filter: saturate(1.05);
}
@keyframes ripple{
  from{ opacity: .9; transform: translate(-50%,-50%) scale(1); }
  to{ opacity: 0; transform: translate(-50%,-50%) scale(18); }
}

/* security helper: don't block .well-known if you add nginx deny dotfiles */


/* ===== Anchor offset for sticky header ===== */
section{ scroll-margin-top: 90px; }
@media (max-width: 860px){ section{ scroll-margin-top: 72px; } }


/* ===== Mobile readability fix ===== */
@media (max-width: 860px){
  .mobile-menu{ background: linear-gradient(180deg, rgba(7,8,20,.92), rgba(7,8,20,.88)); backdrop-filter: blur(18px); }
  .mobile-menu:before{ opacity: .45; }
  .mm-link, .mm-cta, .mm-toggle{ background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.18); }
  .mm-link:hover{ background: rgba(255,255,255,.10); }
  .mm-head, .mm-foot{ background: rgba(7,8,20,.65); backdrop-filter: blur(10px); }
}


/* ===== Lightbox (ultra) ===== */
.lightbox{
  position: fixed;
  inset: 0;
  z-index: 260;
  display: grid;
  place-items: center;
  opacity: 0;
  transition: opacity .18s ease;
}
.lightbox.show{ opacity: 1; }
.lb-backdrop{
  position:absolute; inset:0;
  background: rgba(0,0,0,.66);
  backdrop-filter: blur(12px);
}
.lb-card{
  position:relative;
  width: min(920px, calc(100vw - 26px));
  border-radius: 28px;
  border:1px solid rgba(255,255,255,.16);
  background: linear-gradient(180deg, rgba(255,255,255,.10), rgba(7,8,20,.70));
  box-shadow: 0 50px 140px rgba(0,0,0,.82);
  overflow:hidden;
}
.lb-card:before{
  content:"";
  position:absolute; inset:-35%;
  background:
    radial-gradient(circle at 18% 20%, rgba(34,211,238,.22), transparent 55%),
    radial-gradient(circle at 78% 18%, rgba(124,58,237,.20), transparent 60%),
    radial-gradient(circle at 60% 90%, rgba(244,114,182,.14), transparent 60%);
  opacity:.95;
  pointer-events:none;
}
.lb-card > *{ position:relative; z-index:1; }
.lb-close{
  position:absolute;
  top: 12px; right: 12px;
  width:44px; height:44px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.90);
  cursor:pointer;
}
.lb-head{
  padding: 18px 18px 12px;
  border-bottom: 1px solid rgba(255,255,255,.10);
  display:grid;
  gap:4px;
}
.lb-head b{ font-size: 16px; letter-spacing: .2px; }
.lb-head span{ color: rgba(255,255,255,.62); font-size: 12px; }
.lb-body{
  padding: 14px 18px 18px;
  display:grid;
  grid-template-columns: 1.25fr .75fr;
  gap: 14px;
  align-items: stretch;
}
.lb-preview{
  border-radius: 22px;
  border:1px solid rgba(255,255,255,.12);
  background:
    radial-gradient(circle at 30% 25%, rgba(34,211,238,.25), transparent 55%),
    radial-gradient(circle at 65% 35%, rgba(124,58,237,.24), transparent 60%),
    radial-gradient(circle at 45% 75%, rgba(244,114,182,.18), transparent 58%),
    rgba(255,255,255,.03);
  min-height: 220px;
}
.lb-meta{
  border-radius: 22px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  padding: 12px;
  display:grid;
  gap:10px;
}
.lb-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding: 10px 10px;
  border-radius: 16px;
  border:1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.02);
}
.lb-row span{ color: rgba(255,255,255,.62); font-size: 12px; }
.lb-row i{ font-style: normal; color: rgba(255,255,255,.88); font-size: 12px; }
.lb-actions{
  padding: 0 18px 18px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
@media (max-width: 860px){
  .lb-body{ grid-template-columns: 1fr; }
  .lb-preview{ min-height: 180px; }
}
/* ===== FIX: invisible overlays must NOT catch clicks ===== */

/* любые оверлеи по умолчанию не кликабельны */
.menu-backdrop,
.palette-backdrop,
.lightbox {
  pointer-events: none;
}

/* когда реально показаны — кликабельны */
.menu-backdrop.show,
.palette-backdrop.show,
.lightbox.show {
  pointer-events: auto;
}

/* на всякий: декоративные слои всегда мимо кликов */
#fx,
.grid-overlay,
.cursor {
  pointer-events: none !important;
}