:root{
  --bg:#07111c;
  --bg-soft:#0d1826;
  --card:#101f31;
  --card-2:#13263c;
  --text:#eef5fb;
  --muted:#a9b7c8;
  --line:rgba(255,255,255,.08);
  --cyan:#58d6ff;
  --green:#79f2a8;
  --violet:#8d8cff;
  --amber:#d6a96c;
  --amber-soft:#f2d1a7;
  --shadow:0 18px 60px rgba(0,0,0,.38);
  --radius:28px;
  --container:min(1180px, calc(100vw - 32px));
  --header-h:78px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--text);
  background:
    radial-gradient(900px 400px at 15% -10%, rgba(88,214,255,.12), transparent 60%),
    radial-gradient(900px 400px at 100% 0%, rgba(121,242,168,.09), transparent 55%),
    linear-gradient(180deg, #07111c 0%, #091522 30%, #07111c 100%);
  line-height:1.5;
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}

background: linear-gradient(
  to bottom,
  rgba(0,0,0,0.1),
  rgba(0,0,0,0.4)
);

.site-shell{
  position:relative;
  overflow:hidden;
}
.site-shell::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px);
  background-size: 36px 36px;
  mask-image: linear-gradient(180deg, rgba(0,0,0,.55), transparent 85%);
}
.site-shell::after{
  content:"";
  position:fixed;
  inset:auto -10vw 18vh auto;
  width:50vw;
  height:50vw;
  border-radius:50%;
  background: radial-gradient(circle, rgba(214,169,108,.16), transparent 60%);
  filter:blur(50px);
  pointer-events:none;
}

.container{width:var(--container); margin:0 auto}
.section{padding:96px 0; position:relative}
.section-title{
  font-size:clamp(30px, 4vw, 54px);
  line-height:1.02;
  margin:0 0 18px;
  letter-spacing:-.03em;
}
.section-kicker{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:9px 14px;
  border-radius:999px;
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:#dff6ff;
  background:rgba(88,214,255,.09);
  border:1px solid rgba(88,214,255,.18);
  margin-bottom:18px;
}
.section-kicker::before{
  content:"";
  width:10px; height:10px; border-radius:50%;
  background:linear-gradient(135deg, var(--cyan), var(--green));
  box-shadow:0 0 18px rgba(88,214,255,.55);
}
.lead{
  color:var(--muted);
  font-size:clamp(16px, 2vw, 19px);
  max-width:760px;
}
.copy p{margin:0 0 14px; color:var(--muted)}
.copy strong{color:var(--text)}

.header{
  position:sticky;
  top:0;
  z-index:40;
  backdrop-filter: blur(14px);
  background:rgba(6,12,20,.72);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.header__inner{
  min-height:var(--header-h);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}
.brand{
  display:flex;
  align-items:center;
  gap:14px;
  min-width:0;
}
.brand__mark{
  width:42px; height:42px;
  border-radius:14px;
  background:
    linear-gradient(135deg, rgba(88,214,255,.18), rgba(141,140,255,.18)),
    #0f2032;
  border:1px solid rgba(255,255,255,.08);
  position:relative;
  overflow:hidden;
  box-shadow: var(--shadow);
}
.brand__mark::before,
.brand__mark::after{
  content:"";
  position:absolute; inset:11px 9px;
  border-radius:14px 2px 14px 2px;
  border:2px solid rgba(255,255,255,.82);
}
.brand__mark::after{
  inset:7px 15px 15px 7px;
  border-color: var(--amber-soft);
}
.brand__text{min-width:0}
.brand__title{
  font-weight:700;
  font-size:15px;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.brand__subtitle{
  color:var(--muted);
  font-size:12px;
  white-space:nowrap;
}

.nav{
  display:flex;
  align-items:center;
  gap:22px;
}
.nav a{
  color:#d7e5f2;
  font-size:14px;
  position:relative;
}
.nav a::after{
  content:"";
  position:absolute; left:0; right:0; bottom:-8px;
  height:2px; border-radius:999px;
  transform:scaleX(0);
  transform-origin:left;
  background:linear-gradient(90deg, var(--cyan), var(--amber));
  transition:.25s;
}
.nav a:hover::after{transform:scaleX(1)}

.header__cta{
  display:flex;
  align-items:center;
  gap:10px;
}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  border:1px solid transparent;
  border-radius:16px;
  padding:14px 18px;
  font-weight:600;
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease, background .22s ease;
  will-change:transform;
}
.btn:hover{transform:translateY(-2px)}
.btn--primary{
  color:#09131f;
  background:linear-gradient(135deg, var(--amber-soft), var(--amber));
  box-shadow:0 10px 28px rgba(214,169,108,.28);
}
.btn--secondary{
  color:var(--text);
  background:rgba(255,255,255,.03);
  border-color:rgba(255,255,255,.12);
}
.btn--ghost{
  color:#d7ecf8;
  background:transparent;
  border-color:rgba(88,214,255,.28);
}

.menu-toggle{
  display:none;
  width:46px; height:46px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.1);
  background:rgba(255,255,255,.04);
  color:var(--text);
}
.menu-toggle svg{width:22px;height:22px}

.hero{
  padding:calc(68px + var(--header-h)) 0 70px;
}
.hero__grid{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:34px;
  align-items:center;
}
.hero__eyebrow{
  display:inline-flex;
  align-items:center;
  gap:12px;
  color:#d8eff8;
  font-size:13px;
  letter-spacing:.14em;
  text-transform:uppercase;
  margin-bottom:20px;
}
.hero__eyebrow span{
  width:40px;height:2px;
  background:linear-gradient(90deg, var(--cyan), var(--green), var(--amber));
}
.hero h1{
  margin:0 0 16px;
  font-size:clamp(30px, 5.4vw, 54px);
  line-height:.96;
  letter-spacing:-.05em;
}
.hero h1 .accent{
  color:transparent;
  background:linear-gradient(135deg, var(--amber-soft), var(--amber), #fff6d6);
  -webkit-background-clip:text;
  background-clip:text;
}
.hero__text{
  font-size:clamp(17px, 2.1vw, 20px);
  color:var(--muted);
  max-width:700px;
}
.hero__actions{
  margin-top:30px;
  display:flex;
  gap:14px;
  flex-wrap:wrap;
}
.hero__facts{
  margin-top:28px;
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:14px;
}
.fact{
  padding:16px 16px 18px;
  border-radius:20px;
  background:rgba(255,255,255,.035);
  border:1px solid rgba(255,255,255,.08);
}
.fact strong{
  display:block;
  font-size:26px;
  letter-spacing:-.04em;
  margin-bottom:4px;
}
.fact span{font-size:13px; color:var(--muted)}

.hero-visual{
  position:relative;
  min-height:560px;
}
.hero-visual__base,
.hero-visual__card{
  border-radius:28px;
  overflow:hidden;
  box-shadow:var(--shadow);
  border:1px solid rgba(255,255,255,.08);
  background:#0f2032;
}
.hero-visual__base{
  position:absolute;
  inset:70px 0 0 80px;
}
.hero-visual__base img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.hero-visual__card{
  position:absolute;
  background:#0d1826;
}
.hero-visual__card img{
  width:100%; height:100%; object-fit:cover;
}
.hero-visual__card--one{left:0; top:0; width:260px; height:340px; transform:rotate(-5deg)}
.hero-visual__card--two{right:0; top:46px; width:250px; height:310px; transform:rotate(7deg)}
.hero-visual__card--three{right:34px; bottom:18px; width:270px; height:320px; transform:rotate(-4deg)}
.hero-visual__badge{
  position:absolute;
  left:24px; bottom:24px;
  display:flex;
  gap:12px;
  align-items:center;
  padding:14px 16px;
  border-radius:18px;
  color:#eaf7ff;
  background:rgba(4,10,16,.72);
  backdrop-filter: blur(12px);
  border:1px solid rgba(255,255,255,.12);
  max-width:320px;
}
.hero-visual__badge strong{display:block}
.hero-visual__badge span{font-size:13px; color:#c5d2df}

.ribbon{
  padding:18px 0 0;
}
.ribbon__inner{
  display:grid;
  grid-template-columns:repeat(5, minmax(0,1fr));
  gap:14px;
}
.ribbon__item{
  padding:18px 16px;
  border-radius:20px;
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.08);
  color:#d9e6f3;
  text-align:center;
  font-size:14px;
}

.featured{
  display:grid;
  grid-template-columns:1fr 1.05fr;
  gap:34px;
  align-items:start;
}
.panel{
  border-radius:32px;
  background:linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.025));
  border:1px solid rgba(255,255,255,.08);
  box-shadow:var(--shadow);
}
.panel--padded{padding:34px}
.featured__media{
  padding:18px;
}
.gallery-grid{
  display:grid;
  gap:14px;
  grid-template-columns:1.2fr .8fr;
  grid-template-areas:
    "main side1"
    "main side2"
    "bottom1 bottom2";
}
.gallery-grid__item{
  position:relative;
  overflow:hidden;
  border-radius:24px;
  min-height:160px;
  cursor:pointer;
  isolation:isolate;
  box-shadow: 0 20px 60px rgba(0,0,0,0.5);
}
.gallery-grid__item img{
  width:100%; height:100%; object-fit:cover;
  background: #050a12;
  border-radius: 16px;
  transition:transform .45s ease;
}
.gallery-grid__item::after{
  content:"+";
  position:absolute;
  right:14px; top:14px;
  width:38px; height:38px; border-radius:50%;
  display:grid; place-items:center;
  background:rgba(7,17,28,.66);
  color:#fff;
  font-size:26px;
  opacity:0;
  transform:translateY(8px);
  transition:.25s;
  border:1px solid rgba(255,255,255,.15);
}
.gallery-grid__item:hover img{transform:scale(1.05)}
.gallery-grid__item:hover::after{opacity:1; transform:translateY(0)}
.gallery-grid__item--main{grid-area:main; min-height:450px}
.gallery-grid__item--side1{grid-area:side1}
.gallery-grid__item--side2{grid-area:side2}
.gallery-grid__item--bottom1{grid-area:bottom1}
.gallery-grid__item--bottom2{grid-area:bottom2}

.bullets{
  display:grid;
  gap:14px;
  margin-top:28px;
}
.bullet{
  display:flex;
  gap:14px;
  align-items:flex-start;
  padding:16px 18px;
  border-radius:20px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
}
.bullet__icon{
  flex:0 0 38px;
  width:38px; height:38px;
  border-radius:12px;
  background:linear-gradient(135deg, rgba(88,214,255,.18), rgba(214,169,108,.18));
  display:grid; place-items:center;
  color:#fff;
}
.bullet strong{display:block; margin-bottom:4px}
.bullet span{color:var(--muted); font-size:14px}

.values-grid,
.catalog-grid,
.contacts-grid{
  display:grid;
  gap:18px;
}
.values-grid{
  grid-template-columns:repeat(4, minmax(0,1fr));
}
.value-card,
.catalog-card,
.contact-card{
  padding:24px;
  border-radius:26px;
  background:linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.08);
}
.value-card__num{
  width:44px;height:44px;
  border-radius:14px;
  display:grid; place-items:center;
  margin-bottom:16px;
  font-weight:700;
  background:rgba(214,169,108,.12);
  color:var(--amber-soft);
  border:1px solid rgba(214,169,108,.24);
}
.value-card p{margin:10px 0 0; color:var(--muted)}

.catalog-grid{
  grid-template-columns:1.2fr repeat(2, .9fr);
  align-items:stretch;
}
.catalog-card h3{margin:0 0 10px; font-size:24px}
.catalog-card p{margin:0; color:var(--muted)}
.catalog-card--main{
  position:relative;
  overflow:hidden;
  min-height:260px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
}
.catalog-card--main img{
  position:absolute; inset:0;
  width:100%; height:100%; object-fit:cover;
}
.catalog-card--main .overlay{
  position:relative;
  z-index:1;
  padding:28px;
  background:linear-gradient(180deg, transparent 20%, rgba(7,17,28,.9) 88%);
}
.catalog-card--placeholder{
  position:relative;
  min-height:260px;
}
.catalog-card--placeholder::before{
  content:"";
  position:absolute; inset:0;
  background:
    radial-gradient(circle at 15% 20%, rgba(88,214,255,.12), transparent 35%),
    linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.02));
}
.catalog-card__label{
  display:inline-block;
  padding:8px 12px;
  border-radius:999px;
  font-size:12px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#d8eef8;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.05);
  margin-bottom:14px;
}

.cta-block{
  padding:34px;
  border-radius:34px;
  background:
    radial-gradient(circle at 15% 10%, rgba(88,214,255,.14), transparent 30%),
    radial-gradient(circle at 90% 20%, rgba(214,169,108,.18), transparent 30%),
    linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.08);
  box-shadow:var(--shadow);
}
.cta-block__grid{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:24px;
  align-items:center;
}
.contacts-grid{
  grid-template-columns:repeat(3, minmax(0,1fr));
  margin-top:24px;
}
.contact-card small{
  display:block;
  color:var(--muted);
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.08em;
  margin-bottom:8px;
}
.contact-card strong{
  font-size:20px;
  letter-spacing:-.03em;
}
.contact-card p{
  margin:10px 0 0;
  color:var(--muted);
  font-size:14px;
}
.footer{
  padding:34px 0 52px;
  color:var(--muted);
  font-size:14px;
}
.footer__inner{
  display:flex;
  justify-content:space-between;
  gap:20px;
  border-top:1px solid rgba(255,255,255,.08);
  padding-top:20px;
}
.footer__inner span:last-child{text-align:right}

.reveal{
  opacity:0;
  transform:translateY(18px);
  transition:opacity .55s ease, transform .55s ease;
}
.reveal.is-visible{
  opacity:1;
  transform:none;
}

.lightbox{
  position:fixed;
  inset:0;
  background:rgba(4,10,16,.88);
  display:none;
  align-items:center;
  justify-content:center;
  z-index:80;
  padding:18px;
}
.lightbox.is-open{display:flex}
.lightbox__dialog{
  position:relative;
  width:min(1200px, 100%);
  max-height:100%;
}
.lightbox img{
  width:100%;
  max-height:88vh;
  object-fit:contain;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.12);
  background:#08121d;
}
.lightbox__close{
  position:absolute;
  right:10px; top:10px;
  width:48px; height:48px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(7,17,28,.7);
  color:#fff;
  font-size:30px;
  line-height:1;
}

.project-video {
  position: relative;
}

.project-video::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, rgba(3,7,19,0.1), rgba(3,7,19,0.6));
  pointer-events: none;
}

.project-detail-image {
  min-height: auto !important;
  padding: 0 !important;
  background: #030713;
  aspect-ratio: 16 / 5;
}

.project-detail-image img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.gallery-grid__item {
  transition: transform 0.4s ease, box-shadow 0.4s ease;
}

.gallery-grid__item:hover {
  transform: scale(1.02);
  box-shadow: 0 20px 60px rgba(0,0,0,0.35);
}


.memo-flip-card {
  position: relative;
  perspective: 1200px;
  padding: 0 !important;
  overflow: visible;
  background: transparent;
  border: none;
}

.memo-flip-card__inner {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 100%;
  transform-style: preserve-3d;
  transition: transform 0.8s cubic-bezier(.2,.7,.2,1);
  border-radius: 22px;
}

.memo-flip-card:hover .memo-flip-card__inner,
.memo-flip-card:focus .memo-flip-card__inner,
.memo-flip-card.is-flipped .memo-flip-card__inner {
  transform: rotateY(180deg);
}

.memo-flip-card__face {
  position: absolute;
  inset: 0;
  overflow: hidden;
  border-radius: 22px;
  backface-visibility: hidden;
  background: #050a12;
  box-shadow: 0 20px 60px rgba(0,0,0,0.35);
}

.memo-flip-card__face img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.memo-flip-card__face--back {
  transform: rotateY(180deg);
}

.memo-flip-card__label {
  position: absolute;
  left: 16px;
  bottom: 16px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(5, 10, 18, 0.72);
  border: 1px solid rgba(236, 188, 120, 0.32);
  color: #f3d2a0;
  font-size: 13px;
  font-weight: 600;
  backdrop-filter: blur(10px);
}

@media (max-width: 760px) {
  .memo-flip-card__inner {
    min-height: 280px;
  }

  .memo-flip-card__label {
    font-size: 12px;
    left: 12px;
    bottom: 12px;
  }
}

@media (max-width: 1100px){
  .hero__grid,
  .featured,
  .cta-block__grid{
    grid-template-columns:1fr;
  }
  .hero-visual{min-height:640px}
  .hero-visual__base{inset:82px 0 0 50px}
  .values-grid{grid-template-columns:repeat(2, minmax(0,1fr))}
  .catalog-grid{grid-template-columns:1fr}
  .contacts-grid{grid-template-columns:1fr}
}
@media (max-width: 860px){
  .nav,
  .header__cta .btn--primary{display:none}
  .menu-toggle{display:inline-grid; place-items:center}
  .header__inner{position:relative}
  .nav.is-open{
    display:flex;
    position:absolute;
    top:calc(100% + 10px);
    left:0; right:0;
    flex-direction:column;
    align-items:flex-start;
    gap:16px;
    padding:20px;
    border-radius:24px;
    background:rgba(8,16,26,.96);
    border:1px solid rgba(255,255,255,.08);
    box-shadow:var(--shadow);
  }
  .hero{padding-top:calc(38px + var(--header-h))}
  .hero__facts{grid-template-columns:1fr}
  .ribbon__inner{grid-template-columns:1fr 1fr}
  .gallery-grid{
    grid-template-columns:1fr 1fr;
    grid-template-areas:
      "main main"
      "side1 side2"
      "bottom1 bottom2";
  }
  .gallery-grid__item--main{min-height:320px}
  .hero-visual{
    min-height:520px;
  }
  .hero-visual__base{inset:110px 0 0 0}
  .hero-visual__card--one{width:180px;height:230px}
  .hero-visual__card--two{width:180px;height:220px}
  .hero-visual__card--three{width:190px;height:220px; right:8px}
}
@media (max-width: 640px){
  :root{--container:min(100vw - 24px, 100vw - 24px)}
  .section{padding:74px 0}
  .panel--padded, .cta-block{padding:24px}
  .brand__subtitle{display:none}
  .hero h1{font-size:clamp(34px, 11vw, 54px)}
  .hero-visual{min-height:430px}
  .hero-visual__card--one{width:140px;height:180px}
  .hero-visual__card--two{width:140px;height:170px}
  .hero-visual__card--three{width:150px;height:175px}
  .hero-visual__badge{left:12px; right:12px; max-width:none}
  .ribbon__inner{grid-template-columns:1fr}
  .values-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr; grid-template-areas:"main" "side1" "side2" "bottom1" "bottom2";}
  .gallery-grid__item{min-height:220px}
  .gallery-grid__item--main{min-height:260px}
  .footer__inner{flex-direction:column}
}

.memo-flip-card {
  position: relative;
  display: block;
  min-height: 260px;
  aspect-ratio: 1 / 1;
  padding: 0 !important;
  overflow: hidden !important;
  background: #050a12 !important;
  border: none;
  perspective: 1200px;
  transform: none !important;
  box-shadow: 0 20px 60px rgba(0,0,0,0.5);
}

/* Убираем плюсик от обычной галереи */
.memo-flip-card::after {
  display: none !important;
  content: none !important;
}

/* Убираем масштабирование картинки от обычной галереи */
.memo-flip-card:hover img {
  transform: none !important;
}

.memo-flip-card__inner {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  transform-style: preserve-3d;
  -webkit-transform-style: preserve-3d;
  transition: transform 0.8s cubic-bezier(.2,.7,.2,1);
  border-radius: 22px;
}

/* На компьютере — переворот при наведении */
.memo-flip-card:hover .memo-flip-card__inner,
.memo-flip-card:focus .memo-flip-card__inner,
.memo-flip-card.is-flipped .memo-flip-card__inner {
  transform: rotateY(180deg);
}

.memo-flip-card__face {
  position: absolute;
  inset: 0;
  overflow: hidden;
  border-radius: 22px;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  background: #050a12;
}

.memo-flip-card__face img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  border-radius: 22px;
}

.memo-flip-card__face--front {
  transform: rotateY(0deg);
}

.memo-flip-card__face--back {
  transform: rotateY(180deg);
}

.memo-flip-card__label {
  position: absolute;
  left: 16px;
  bottom: 16px;
  z-index: 3;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(5, 10, 18, 0.72);
  border: 1px solid rgba(236, 188, 120, 0.32);
  color: #f3d2a0;
  font-size: 13px;
  font-weight: 600;
  backdrop-filter: blur(10px);
}

@media (max-width: 640px) {
  .memo-flip-card {
    min-height: 280px;
    aspect-ratio: 1 / 1;
  }
}

.gallery-grid--project-6 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-areas:
    "main main"
    "bottom1 bottom2";
  gap: 20px;
}

.gallery-grid--project-6 .gallery-grid__item--main {
  grid-area: main;
}

.gallery-grid--project-6 .gallery-grid__item--bottom1 {
  grid-area: bottom1;
}

.gallery-grid--project-6 .gallery-grid__item--bottom2 {
  grid-area: bottom2;
}
