:root{
  --bg:#07080b;
  --bg2:#0b0d12;
  --card:#0e1118;
  --text:#e9ecf5;
  --muted:#a7afc2;
  --gold:#d6b46a;
  --gold2:#f3d28a;
  --line: rgba(255,255,255,.08);
  --shadow: 0 30px 80px rgba(0,0,0,.55);
  --radius: 18px;
}

*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  margin:0;
  font-family: "Manrope", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background: radial-gradient(1200px 700px at 10% 0%, rgba(214,180,106,.10), transparent 60%),
              radial-gradient(900px 600px at 90% 20%, rgba(243,210,138,.08), transparent 55%),
              linear-gradient(180deg, var(--bg), var(--bg2));
  color: var(--text);
}

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

.muted{ color:var(--muted); }
.small{ font-size: .92rem; }

/* ---------------------------
   Nav
---------------------------- */
.nav{
  position: sticky; top:0; z-index:50;
  border-bottom:1px solid var(--line);
  backdrop-filter: blur(14px);
  background: rgba(7,8,11,.55);
}
.nav__inner{
  display:flex; align-items:center; justify-content:space-between;
  padding: 14px 0;
  position: relative;
}
.logo{
  font-weight:800; letter-spacing:.12em;
  text-transform: uppercase;
}

.nav__links{ display:flex; gap:18px; align-items:center; }
.nav__links a{ color: var(--muted); font-weight:600; }
.nav__links a:hover{ color: var(--text); }

/* Burger button */
.nav__burger{
  display:none;
  background:transparent;
  border:none;
  padding: 10px;
  border-radius: 12px;
  cursor:pointer;
  border: 1px solid transparent;
}
.nav__burger:focus-visible{
  outline: 2px solid rgba(214,180,106,.55);
  outline-offset: 3px;
}
.nav__burger span{
  display:block;
  width: 26px;
  height: 2px;
  background: var(--text);
  margin: 6px 0;
  border-radius: 99px;
  transition: transform .18s ease, opacity .18s ease;
}

/* ---------------------------
   Buttons
---------------------------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding: 12px 16px;
  border-radius: 999px;
  border:1px solid var(--line);
  font-weight:700;
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.btn:hover{ transform: translateY(-1px); box-shadow: 0 14px 40px rgba(0,0,0,.45); }
.btn--gold{
  background: linear-gradient(135deg, var(--gold), var(--gold2));
  color:#161514;
  border-color: rgba(214,180,106,.45);
}
.btn--ghost{
  background: rgba(255,255,255,.03);
  color: var(--text);
}
.btn--sm{ padding:10px 12px; font-size:.92rem; }

/* ---------------------------
   Hero
---------------------------- */
.hero{ padding: 74px 0 34px; position: relative; overflow: clip; }
.hero__inner{ display:grid; grid-template-columns: 1.25fr .75fr; gap: 34px; align-items: start; }

.badge{
  display:inline-flex; gap:8px; align-items:center;
  padding: 8px 12px;
  border-radius:999px;
  border:1px solid var(--line);
  background: rgba(255,255,255,.03);
  color: var(--muted);
  font-weight:600;
  width: fit-content;
}

.h1{
  font-size: clamp(2.3rem, 4.2vw, 4rem);
  line-height: 1.02;
  margin: 14px 0 12px;
  letter-spacing:-.02em;
}
.gold{
  background: linear-gradient(135deg, var(--gold), var(--gold2));
  -webkit-background-clip:text;
  background-clip:text;
  color: transparent;
}
.lead{
  font-size: 1.15rem;
  line-height: 1.6;
  color: var(--muted);
  max-width: 56ch;
}

.hero__cta{ display:flex; gap: 12px; margin-top: 18px; flex-wrap: wrap; }

.hero__stats{
  margin-top: 22px;
  display:flex; gap: 16px; flex-wrap: wrap;
}
.stat{
  border:1px solid var(--line);
  border-radius: 14px;
  padding: 12px 14px;
  background: rgba(255,255,255,.03);
  min-width: 170px;
}
.stat__n{ display:block; font-weight:800; letter-spacing:.06em; }
.stat__t{ display:block; color: var(--muted); font-weight:600; margin-top: 4px; }

.card{
  border:1px solid var(--line);
  border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  box-shadow: var(--shadow);
  padding: 18px;
}
.card__top{ display:flex; justify-content:space-between; gap:10px; margin-bottom: 14px; }

.chip{
  padding: 8px 10px;
  border-radius: 999px;
  border:1px solid rgba(214,180,106,.25);
  color: var(--gold2);
  background: rgba(214,180,106,.08);
  font-weight: 800;
  letter-spacing:.08em;
  font-size:.78rem;
  text-transform: uppercase;
}
.chip--muted{
  border-color: var(--line);
  background: rgba(255,255,255,.03);
  color: var(--muted);
}

.mock{
  border-radius: 14px;
  border:1px solid var(--line);
  background: rgba(0,0,0,.25);
  padding: 16px;
  margin-bottom: 12px;
}
.mock__row{
  height: 10px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(214,180,106,.35), rgba(255,255,255,.10));
  margin: 10px 0;
}

.hero__glow{
  position:absolute; inset:-120px -120px auto -120px;
  height: 420px;
  background: radial-gradient(closest-side, rgba(214,180,106,.20), transparent 70%);
  filter: blur(24px);
  pointer-events:none;
  transform: translateZ(0);
}

/* ---------------------------
   Sections / grids
---------------------------- */
.section{ padding: 62px 0; }
.section--soft{
  background: rgba(255,255,255,.02);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.section__head{ margin-bottom: 22px; }
.h2{
  font-size: clamp(1.5rem, 2.2vw, 2.1rem);
  margin:0 0 8px;
  letter-spacing:-.02em;
}

.grid3{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.grid4{ display:grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.grid2{ display:grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }

.panel{
  border:1px solid var(--line);
  border-radius: var(--radius);
  padding: 18px;
  background: rgba(255,255,255,.03);
  transition: transform .18s ease, border-color .18s ease;
}
.panel:hover{ transform: translateY(-2px); border-color: rgba(214,180,106,.28); }
.panel h3{ margin: 0 0 8px; letter-spacing:-.01em; }

.list{ margin: 12px 0 0; padding-left: 18px; color: var(--muted); }
.list li{ margin: 8px 0; }

/* ---------------------------
   Work cards
---------------------------- */
.work{
  border:1px solid var(--line);
  border-radius: var(--radius);
  overflow:hidden;
  background: rgba(255,255,255,.02);
  transition: transform .18s ease, border-color .18s ease;
  will-change: transform;
}
.work:hover{
  transform: translateY(-3px);
  border-color: rgba(214,180,106,.28);
}

.work__btn{
  appearance: none;
  border: 0;
  padding: 0;
  width: 100%;
  background: transparent;
  color: inherit;
  text-align: left;
  cursor: pointer;
  display: block;
}
.work__btn:focus-visible{
  outline: 2px solid rgba(214,180,106,.55);
  outline-offset: 4px;
  border-radius: var(--radius);
}

.work__thumb{
  position: relative;
  height: 170px;
  border-bottom:1px solid var(--line);

  /* если есть background-image — будет красиво */
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;

  /* fallback gradient если картинки нет */
  background-image:
    radial-gradient(400px 240px at 20% 40%, rgba(214,180,106,.14), transparent 60%),
    linear-gradient(135deg, rgba(255,255,255,.05), rgba(255,255,255,.01));
}
.work__btn:hover .work__thumb{ filter: brightness(1.03); }

.work__meta{ padding: 14px 16px; }
.work__title{ font-weight: 800; }

/* Tags */
.tag{
  position:absolute;
  top: 10px;
  left: 10px;
  display:inline-flex;
  align-items:center;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: .72rem;
  font-weight: 900;
  letter-spacing:.10em;
  text-transform: uppercase;
  border: 1px solid var(--line);
  background: rgba(0,0,0,.35);
  backdrop-filter: blur(10px);
}
.tag--new{ border-color: rgba(214,180,106,.25); color: var(--gold2); }
.tag--dtf{ border-color: rgba(255,255,255,.18); color: #fff; opacity:.95; }
.tag--premium{ border-color: rgba(214,180,106,.25); color: var(--gold2); }

/* ---------------------------
   Steps
---------------------------- */
.step{
  border:1px solid var(--line);
  border-radius: var(--radius);
  padding: 16px;
  background: rgba(255,255,255,.03);
  will-change: transform;
}
.step__n{
  color: var(--gold2);
  font-weight: 900;
  letter-spacing:.12em;
}
.step__t{ font-weight: 800; margin-top: 8px; }

/* ---------------------------
   Form
---------------------------- */
.form{
  border:1px solid var(--line);
  border-radius: var(--radius);
  padding: 18px;
  background: rgba(255,255,255,.03);
}
label{ display:block; font-weight:700; color: var(--muted); }
input,textarea{
  width:100%;
  margin-top: 8px;
  padding: 12px 12px;
  border-radius: 12px;
  border:1px solid var(--line);
  background: rgba(0,0,0,.22);
  color: var(--text);
  outline: none;
}
input:focus, textarea:focus{
  border-color: rgba(214,180,106,.38);
  box-shadow: 0 0 0 6px rgba(214,180,106,.08);
}

/* ---------------------------
   Footer
---------------------------- */
.footer{
  padding: 26px 0;
  border-top:1px solid var(--line);
}
.footer__inner{
  display:flex;
  justify-content:space-between;
  gap: 16px;
  align-items:center;
  flex-wrap: wrap;
}
.footer__brand{
  font-weight: 900;
  letter-spacing:.12em;
  text-transform: uppercase;
}

/* ---------------------------
   Reveal animations
---------------------------- */
.reveal{
  opacity: 0;
  transform: translateY(14px);
  transition: opacity .75s ease, transform .75s ease;
}
.reveal.is-visible{
  opacity: 1;
  transform: translateY(0);
}

/* ---------------------------
   Lightbox (modal preview)
---------------------------- */
.lightbox{
  position: fixed;
  inset: 0;
  z-index: 200;
  display: none;
}
.lightbox.is-open{ display: block; }

.lightbox__backdrop{
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.72);
  backdrop-filter: blur(10px);
}

.lightbox__dialog{
  position: relative;
  width: min(980px, calc(100% - 28px));
  margin: 54px auto;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(10,12,16,.92);
  box-shadow: 0 40px 120px rgba(0,0,0,.75);
  overflow: hidden;
}

.lightbox__close{
  position: absolute;
  right: 10px;
  top: 10px;
  width: 40px;
  height: 40px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.05);
  color: var(--text);
  font-size: 22px;
  cursor: pointer;
}
.lightbox__close:hover{ border-color: rgba(214,180,106,.35); }

.lightbox__media{ background: #05060a; }
.lightbox__media img{
  display: block;
  width: 100%;
  height: auto;
  max-height: 72vh;
  object-fit: contain;
}
.lightbox__caption{
  padding: 14px 16px 16px;
  border-top: 1px solid var(--line);
}
.lightbox__title{
  font-weight: 900;
  letter-spacing: -.01em;
  margin-bottom: 4px;
}

/* ---------------------------
   Small UI upgrades
---------------------------- */
.brandmark{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width: 24px;
  height: 24px;
  border-radius: 999px;
  background: rgba(214,180,106,.10);
  border: 1px solid rgba(214,180,106,.20);
  color: var(--gold2);
  margin-right: 8px;
}
.brandmark--lg{ width: 30px; height: 30px; margin-right: 10px; }

.trustbar{
  margin-top: 18px;
  display:flex;
  gap: 12px;
  flex-wrap: wrap;
}
.trust{
  display:flex;
  gap: 10px;
  align-items:flex-start;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 12px 14px;
  background: rgba(255,255,255,.03);
  min-width: 220px;
}
.trust__icon{
  width: 30px; height: 30px;
  display:flex; align-items:center; justify-content:center;
  border-radius: 10px;
  background: rgba(214,180,106,.10);
  border: 1px solid rgba(214,180,106,.18);
  color: var(--gold2);
  font-weight: 900;
}
.trust__t{ font-weight: 800; }

.mini-cta{ margin-top: 14px; display:flex; gap:10px; flex-wrap: wrap; }

/* CTA band */
.cta-band{
  padding: 26px 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: rgba(255,255,255,.02);
}
.cta-band__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 16px;
  flex-wrap: wrap;
}
.cta-band__kicker{
  color: var(--gold2);
  font-weight: 900;
  letter-spacing:.10em;
  text-transform: uppercase;
  font-size:.78rem;
}
.cta-band__title{
  font-size: 1.3rem;
  font-weight: 900;
  margin-top: 4px;
}
.cta-band__right{ display:flex; gap:10px; flex-wrap: wrap; }

/* Scroll-to-top */
.to-top{
  position: fixed;
  right: 16px;
  bottom: 16px;
  width: 46px;
  height: 46px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: rgba(7,8,11,.65);
  color: var(--text);
  backdrop-filter: blur(12px);
  box-shadow: 0 14px 40px rgba(0,0,0,.45);
  cursor: pointer;
  opacity: 0;
  transform: translateY(10px);
  transition: opacity .2s ease, transform .2s ease, border-color .2s ease;
  z-index: 120;
}
.to-top.is-visible{
  opacity: 1;
  transform: translateY(0);
}
.to-top:hover{ border-color: rgba(214,180,106,.28); }

/* ---------------------------
   Responsive
---------------------------- */
@media (max-width: 900px){
  .hero__inner{ grid-template-columns: 1fr; }
  .grid3{ grid-template-columns: 1fr; }
  .grid4{ grid-template-columns: 1fr 1fr; }
}

/* MOBILE NAV FIXES ARE HERE */
@media (max-width: 560px){
  .grid4{ grid-template-columns: 1fr; }
  .grid2{ grid-template-columns: 1fr; }

  /* Hide links by default */
  .nav__links{
    display:none;
  }

  /* Show burger */
  .nav__burger{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    border-color: var(--line);
    background: rgba(255,255,255,.03);
  }
  .nav__burger:hover{
    border-color: rgba(214,180,106,.28);
  }

  /* When nav is open, show dropdown */
  .nav.is-open .nav__links{
    display:flex;
    flex-direction: column;
    align-items: stretch;
    gap: 10px;

    position: absolute;
    top: calc(100% + 10px);
    right: 0;

    width: min(320px, calc(100vw - 28px));
    padding: 14px;

    border: 1px solid var(--line);
    border-radius: 16px;
    background: rgba(10,12,16,.92);
    backdrop-filter: blur(14px);
    box-shadow: 0 24px 80px rgba(0,0,0,.65);

    z-index: 80;
  }

  .nav.is-open .nav__links a{
    padding: 10px 12px;
    border-radius: 12px;
    background: rgba(255,255,255,.03);
    border: 1px solid rgba(255,255,255,.06);
    color: var(--text);
  }
  .nav.is-open .nav__links a:hover{
    border-color: rgba(214,180,106,.25);
  }

  /* Make the CTA button full width in dropdown */
  .nav.is-open .nav__links .btn{
    width: 100%;
    justify-content: center;
  }

  /* Animate burger into X when open */
  .nav.is-open .nav__burger span:nth-child(1){
    transform: translateY(8px) rotate(45deg);
  }
  .nav.is-open .nav__burger span:nth-child(2){
    transform: translateY(-8px) rotate(-45deg);
  }
}

/* Fallback gradients (optional legacy) */
.work__thumb--1{ background:
  radial-gradient(400px 220px at 20% 30%, rgba(214,180,106,.18), transparent 60%),
  linear-gradient(135deg, rgba(255,255,255,.06), rgba(255,255,255,.01));
}
.work__thumb--2{ background:
  radial-gradient(420px 260px at 65% 25%, rgba(214,180,106,.16), transparent 62%),
  linear-gradient(135deg, rgba(255,255,255,.05), rgba(255,255,255,.01));
}
.work__thumb--3{ background:
  radial-gradient(420px 260px at 35% 35%, rgba(214,180,106,.14), transparent 62%),
  linear-gradient(135deg, rgba(255,255,255,.05), rgba(255,255,255,.01));
}
.work__thumb--4{ background:
  radial-gradient(420px 260px at 60% 35%, rgba(214,180,106,.14), transparent 62%),
  linear-gradient(135deg, rgba(255,255,255,.05), rgba(255,255,255,.01));
}
.work__thumb--5{ background:
  radial-gradient(420px 260px at 40% 30%, rgba(214,180,106,.16), transparent 62%),
  linear-gradient(135deg, rgba(255,255,255,.05), rgba(255,255,255,.01));
}
.work__thumb--6{ background:
  radial-gradient(420px 260px at 55% 30%, rgba(214,180,106,.16), transparent 62%),
  linear-gradient(135deg, rgba(255,255,255,.05), rgba(255,255,255,.01));
}


.star-rating{
  display:inline-flex;
  align-items:center;
  gap:6px;
  user-select:none;
}

/* ПРОБИВАЕМ любые глобальные button-стили */
.star-rating .star{
  appearance:none !important;
  -webkit-appearance:none !important;
  border:0 !important;
  background:transparent !important;
  box-shadow:none !important;
  padding:0 !important;
  margin:0 !important;
  border-radius:0 !important;

  font-size:26px;
  line-height:1;
  cursor:pointer;

  color: rgba(255,255,255,.28);
  transition: color .18s ease, transform .12s ease, text-shadow .18s ease;
}

.star-rating .star.is-on,
.star-rating .star.is-active{
  color: var(--gold2, #D8B04A);
  text-shadow: 0 10px 26px rgba(214,180,106,.18);
}

.star-rating .star:hover{
  transform: translateY(-1px) scale(1.05);
  color: var(--gold2, #D8B04A);
}

.star-rating .star:focus-visible{
  outline:2px solid rgba(214,180,106,.55);
  outline-offset:4px;
  border-radius:8px;
}

.review-stars .star{
  font-size: 14px;
  line-height: 1;
  color: rgba(255,255,255,.28);
}
.review-stars .star.is-on{
  color: var(--gold2, #D8B04A);
}
