* { margin: 0; padding: 0; box-sizing: border-box; font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif; }
:root{
  --primary-bg:#0a0a0a;
  --accent:#7CFC00;
  --text:#ffffff;
  --text2:#b3b3b3;
  --shadow: 0 20px 50px rgba(0,0,0,.55);
}

html, body { height: 100%; background: var(--primary-bg); color: var(--text); }
a { color: inherit; text-decoration: none; }
.container { width: min(1100px, calc(100% - 40px)); margin: 0 auto; }
.muted{ color: var(--text2); }

/* ===== Background blobs ===== */
.bg-blobs{
  position: fixed;
  inset: -25vh -25vw;
  z-index: -2;
  pointer-events: none;
  filter: blur(60px);
  opacity: .75;
}
.blob{
  position: absolute;
  border-radius: 999px;
  background: rgba(124,252,0,.14);
  mix-blend-mode: screen;
  will-change: transform;
}
.blob.b1{ width: 520px; height: 520px; left: 8%; top: 8%; }
.blob.b2{ width: 640px; height: 640px; right: 10%; top: 20%; background: rgba(124,252,0,.10); }
.blob.b3{ width: 560px; height: 560px; left: 18%; bottom: 10%; background: rgba(255,255,255,.06); }
@media (prefers-reduced-motion: no-preference){
  .blob{ animation: drift 14s ease-in-out infinite; }
  .blob.b2{ animation-duration: 18s; }
  .blob.b3{ animation-duration: 22s; }
  @keyframes drift{
    0%,100%{ transform: translate(0,0) scale(1); }
    50%{ transform: translate(40px, -30px) scale(1.05); }
  }
}

/* ===== Party overlay ===== */
.party{
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: 0;
  transition: .25s ease;
  z-index: 999;
  background:
    repeating-linear-gradient(90deg, rgba(124,252,0,.06) 0 2px, transparent 2px 18px),
    radial-gradient(800px 500px at 20% 20%, rgba(124,252,0,.12), transparent 55%),
    radial-gradient(900px 600px at 80% 60%, rgba(255,255,255,.06), transparent 60%);
  mix-blend-mode: screen;
  filter: saturate(1.2);
}
body.party-on .party{ opacity: 1; }
body.party-on .brand, body.party-on h1{
  text-shadow: 2px 0 rgba(124,252,0,.35), -2px 0 rgba(255,255,255,.18);
}
@keyframes wiggle { 0%,100%{ transform: rotate(0deg);} 25%{ transform: rotate(1deg);} 75%{ transform: rotate(-1deg);} }
body.party-on .photo-card{ animation: wiggle .22s linear infinite; }

/* ===== Top nav ===== */
.nav{
  position: sticky; top: 0; z-index: 30;
  backdrop-filter: blur(10px);
  background: rgba(10,10,10,.62);
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.nav-inner{
  display:flex; align-items:center; justify-content:space-between;
  padding: 14px 0;
  gap: 16px;
}
.brand{
  display:flex; align-items:center; gap:10px;
  font-weight: 700;
  letter-spacing: .2px;
  user-select: none;
}
.dot{
  width:10px; height:10px; border-radius:50%;
  background: var(--accent);
  box-shadow: 0 0 18px rgba(124,252,0,.55);
  cursor: pointer;
}
.nav-links{ display:flex; gap: 14px; flex-wrap: wrap; }
.nav-links a{
  font-size: 14px;
  color: var(--text2);
  padding: 8px 10px;
  border-radius: 10px;
  border: 1px solid transparent;
  transition: .2s ease;
}
.nav-links a:hover{
  color: var(--text);
  border-color: rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
}

.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,.10);
  background: rgba(255,255,255,.02);
  color: var(--text);
  transition: .2s ease;
  white-space: nowrap;
}
.btn:hover{ border-color: rgba(124,252,0,.30); box-shadow: 0 0 0 6px rgba(124,252,0,.05); }
.btn-accent{
  background: rgba(124,252,0,.10);
  border-color: rgba(124,252,0,.28);
}
.btn-accent:hover{ background: rgba(124,252,0,.13); }

/* icon button (for mobile header) */
.iconbtn{
  width: 40px;
  height: 40px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.02);
  color: var(--text);
  transition: .2s ease;
}
.iconbtn:hover{ border-color: rgba(124,252,0,.25); }
.iconbtn i{ font-size: 18px; }

/* ===== Mobile bottom tab bar + FAB ===== */
.mbar{
  display:none;
  position: fixed;
  left: 12px; right: 12px;
  bottom: calc(12px + env(safe-area-inset-bottom));
  z-index: 60;
  border-radius: 20px;
  background: rgba(10,10,10,.72);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,.12);
  padding: 10px 12px;
  box-shadow: 0 18px 50px rgba(0,0,0,.65);
}
.mbar-inner{
  display:grid;
  grid-template-columns: 1fr 1fr 1fr 1fr 1fr;
  gap: 6px;
  align-items: center;
}
.mitem{
  display:flex;
  flex-direction: column;
  align-items:center;
  justify-content:center;
  gap: 6px;
  padding: 10px 6px;
  border-radius: 14px;
  border: 1px solid transparent;
  color: var(--text2);
  transition: .15s ease;
  font-size: 11px;
  user-select:none;
}
.mitem i{ font-size: 16px; }
.mitem:active{ transform: scale(.98); }
.mitem.active{
  color: var(--text);
  background: rgba(124,252,0,.09);
  border-color: rgba(124,252,0,.26);
}

/* FAB: короткий, чтобы точно влез */
.mfab{
  display:flex;
  align-items:center;
  justify-content:center;
  gap: 8px;
  width: 100%;
  height: 100%;
  padding: 12px 10px;
  border-radius: 16px;
  border: 1px solid rgba(124,252,0,.28);
  background: rgba(124,252,0,.08);
  color: var(--text);
  font-weight: 800;
  letter-spacing: .2px;
  transition: .2s ease;
  position: relative;
  overflow: hidden;
  line-height: 1;
  min-width: 0;
}
.mfab i{ color: var(--accent); font-size: 18px; }
.mfab span{
  font-size: 24px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 64px; /* гарантируем, что ничего не вылезет */
}
.mfab:active{ transform: scale(.99); }
.mfab:hover{ background: rgba(124,252,0,.10); }
.mfab::before{
  content:"";
  position:absolute;
  top:-40%;
  left:-60%;
  width: 60%;
  height: 180%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.10), transparent);
  transform: rotate(20deg);
  opacity: .7;
}
@media (prefers-reduced-motion: no-preference){
  .mfab::before{ animation: shine 3.8s ease-in-out infinite; }
  @keyframes shine{
    0%{ transform: translateX(0) rotate(20deg); }
    55%{ transform: translateX(260%) rotate(20deg); }
    100%{ transform: translateX(260%) rotate(20deg); }
  }
}

/* FAB Sheet */
.sheet{ position: fixed; inset: 0; z-index: 1200; display: none; }
.sheet.open{ display:block; }
.sheet-backdrop{
  position:absolute; inset:0;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(6px);
  opacity: 0;
  transition: .22s ease;
}
.sheet.open .sheet-backdrop{ opacity: 1; }
.sheet-panel{
  position:absolute;
  left: 0; right: 0;
  bottom: 0;
  border-radius: 22px 22px 0 0;
  background: rgba(10,10,10,.86);
  border-top: 1px solid rgba(255,255,255,.10);
  transform: translateY(16px);
  opacity: 0;
  transition: .22s ease;
  padding: 14px 14px calc(18px + env(safe-area-inset-bottom));
  max-width: 760px;
  margin: 0 auto;
}
.sheet.open .sheet-panel{ transform: translateY(0); opacity: 1; }
.sheet-grab{
  width: 54px; height: 5px;
  border-radius: 999px;
  background: rgba(255,255,255,.16);
  margin: 6px auto 10px;
}
.sheet-head{
  display:flex; align-items:flex-start; justify-content:space-between;
  gap: 12px; margin-bottom: 10px;
}
.sheet-title{ font-weight: 900; letter-spacing: -.2px; font-size: 16px; }
.sheet-sub{ margin-top: 4px; color: rgba(255,255,255,.60); font-size: 13px; line-height: 1.35; }
.xbtn{
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.03);
  border-radius: 14px;
  width: 40px; height: 40px;
  display:flex; align-items:center; justify-content:center;
  cursor: pointer; transition: .2s ease; color: var(--text);
  flex: 0 0 auto;
}
.xbtn:hover{ border-color: rgba(124,252,0,.25); }

.field{ display:grid; gap: 6px; margin-top: 10px; }
.field label{ font-size: 12px; color: rgba(255,255,255,.65); }
.input, .textarea{
  width: 100%;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.03);
  color: var(--text);
  padding: 12px 12px;
  outline: none;
  transition: .2s ease;
}
.textarea{ min-height: 96px; resize: vertical; }
.input:focus, .textarea:focus{
  border-color: rgba(124,252,0,.40);
  box-shadow: 0 0 0 6px rgba(124,252,0,.05);
}
.sheet-actions{ display:flex; gap: 10px; flex-wrap: wrap; margin-top: 12px; }
.btn-ghost{ border: 1px solid rgba(255,255,255,.12); background: rgba(255,255,255,.03); }
.btn-send{ border-color: rgba(124,252,0,.28); background: rgba(124,252,0,.10); }
.btn-send i{ color: var(--accent); }

/* Content */
.hero{ padding: 56px 0 18px; }
.hero-grid{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 28px;
  align-items: center;
}
.kicker{
  display:inline-flex; align-items:center; gap:10px;
  color: var(--text2);
  font-size: 14px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.02);
  padding: 8px 12px;
  border-radius: 999px;
  width: fit-content;
}
.kicker i{ color: var(--accent); }
h1{
  margin-top: 14px;
  font-size: clamp(34px, 4.2vw, 54px);
  line-height: 1.05;
  letter-spacing: -0.5px;
}
.lead{
  margin-top: 14px;
  color: var(--text2);
  font-size: 16px;
  line-height: 1.6;
  max-width: 58ch;
}
.hero-cta{ margin-top: 18px; display:flex; gap: 12px; flex-wrap: wrap; }
.badges{ margin-top: 16px; display:flex; gap: 10px; flex-wrap: wrap; }
.badge{
  display:inline-flex; align-items:center; gap:8px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.02);
  padding: 10px 12px;
  border-radius: 14px;
  color: var(--text2);
  font-size: 14px;
}
.badge i{ color: var(--accent); }

.photo-card{
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 26px;
  overflow: hidden;
  box-shadow: var(--shadow);
  position: relative;
}
.photo{
  width:100%;
  aspect-ratio: 890 / 1280;
  object-fit: cover;
  display:block;
  filter: contrast(1.02) saturate(1.02);
}
.photo-overlay{
  position:absolute; left:0; right:0; bottom:0;
  padding: 16px 16px 18px;
  background: linear-gradient(180deg, transparent, rgba(0,0,0,.75));
  display:flex; justify-content:space-between; align-items:flex-end; gap: 12px;
}
.photo-title{ font-weight: 700; }
.photo-sub{ color: var(--text2); font-size: 13px; margin-top: 4px; }
.pill{
  display:inline-flex; align-items:center; gap:8px;
  padding: 10px 12px;
  border-radius: 999px;
  background: rgba(124,252,0,.12);
  border: 1px solid rgba(124,252,0,.25);
  font-size: 13px;
  color: var(--text);
  white-space: nowrap;
}

section{ padding: 44px 0; scroll-margin-top: 90px; }
.section-head{ display:flex; align-items:flex-end; justify-content:space-between; gap: 18px; margin-bottom: 18px; }
.section-title{ font-size: 22px; letter-spacing: -0.2px; }
.section-desc{ color: var(--text2); font-size: 14px; line-height: 1.6; max-width: 70ch; }

.grid-3{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.grid-2{ display:grid; grid-template-columns: 1fr 1fr; gap: 14px; }

.card{
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 20px;
  padding: 18px;
  transition: .2s ease;
  min-height: 160px;
}
.card:hover{ border-color: rgba(124,252,0,.25); transform: translateY(-2px); }
.card h3{ display:flex; align-items:center; gap:10px; font-size: 16px; margin-bottom: 10px; }
.card h3 i{ color: var(--accent); }
.card p{ color: var(--text2); line-height: 1.6; font-size: 14px; }
.card .meta{ margin-top: 12px; display:flex; gap: 10px; flex-wrap: wrap; }
.mini{
  font-size: 12px;
  color: var(--text2);
  border: 1px solid rgba(255,255,255,.10);
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.02);
}

footer{
  padding: 18px 0; /* меньше пустого места на десктопе */
  color: var(--text2);
  font-size: 13px;
}
.footer-inner{ display:flex; justify-content:space-between; gap: 12px; flex-wrap: wrap; }

/* Pop FX */
.pop{
  position: fixed;
  font-size: 14px;
  color: var(--accent);
  text-shadow: 0 0 18px rgba(124,252,0,.4);
  pointer-events:none;
  z-index: 1000;
  transform: translate(-50%, -50%);
  animation: pop .75s ease forwards;
}
@keyframes pop{
  0%{ opacity:0; transform: translate(-50%, -30%) scale(.9); }
  10%{ opacity:1; }
  100%{ opacity:0; transform: translate(-50%, -90%) scale(1.05); }
}

@media (prefers-reduced-motion: no-preference){
  html { scroll-behavior: smooth; }
}

/* ===== Responsive ===== */
@media (max-width: 920px){
  .hero-grid{ grid-template-columns: 1fr; }
  .photo-card{ max-width: 520px; }
  .grid-3{ grid-template-columns: 1fr; }
  .grid-2{ grid-template-columns: 1fr; }
}

@media (max-width: 720px){
  .nav{ position: relative; top: auto; }
  .nav-links{ display:none; }

  /* В мобильной шапке убираем кнопку TG, оставляем только иконку на канал */
  .nav-inner{
    padding: calc(14px + env(safe-area-inset-top)) 0 14px;
    align-items: center;
  }
  .nav .desktop-cta{ display:none; }
  .nav .mobile-cta{ display:inline-flex; }

  .container{ width: min(1100px, calc(100% - 28px)); }
  .mbar{ display:block; }
  section{ scroll-margin-top: 16px; }
  .hero{ padding-top: 34px; }
  .kicker{ font-size: 13px; }
  .lead{ font-size: 15px; }

  /* footer needs space under bottom bar only on mobile */
  footer{
    padding: 18px 0 calc(120px + env(safe-area-inset-bottom));
  }
}
