/* styles.css
   Полностью самоописывающийся CSS с корневыми переменными и секциями.
   Комментарии поясняют структуру.
*/

/* =====================
   Корневые переменные (цвета, размеры, сетка)
   ===================== */
:root{
  /* Цвета фона */
  --bg-1: #05070B;
  --bg-2: #0B1118;

  /* Акценты (изумрудно-салатовые градиенты) */
  --accent-a: #00FFAA;
  --accent-b: #0CE69C;
  --accent-c: #007F5F;

  /* Золото для мелких деталей */
  --gold: #D9B45B;

  /* Нейтральные тона для текста */
  --muted: rgba(170,190,200,0.6);
  --text-main: #E6F7F0;
  --panel: rgba(255,255,255,0.03);

  /* Блоки/отступы */
  --radius: 12px; /* соответствует требованию 10–14px */
  --space: 16px;  /* кратно 8px, базовое отступление */
  --grid-gap: 16px;

  /* Тени и свечение */
  --soft-shadow: 0 8px 24px rgba(0,0,0,0.45);
  --glow-alpha: 0.12;

  /* Типографика */
  --font-sans: Inter, ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;
  --scale-h1: 28px;
  --scale-h2: 18px;
  --scale-body: 14px;

  /* Анимации */
  --fast: 0.2s;
  --med: 0.32s;
  --ease: cubic-bezier(.15,.8,.25,1);
}

/* =====================
   Базовые ресеты и фон
   ===================== */
* { box-sizing: border-box; }
html,body{ height:100%; }
body{
  margin:0;
  min-height:100%;
  font-family: var(--font-sans);
  background: linear-gradient(180deg,var(--bg-1),var(--bg-2));
  color:var(--text-main);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  /* контекстная подсветка */
  background-attachment: fixed;
  line-height:1.45;
  font-size:var(--scale-body);
}

/* Фоновый фрактал — полупрозрачный слой с эффектом движения */
#fractal-bg{
  position:fixed;
  inset:0;
  z-index:0;
  pointer-events:none;
  background-image:
    radial-gradient(circle at 10% 20%, rgba(12,30,20,0.06) 0 8%, transparent 20%),
    radial-gradient(circle at 80% 80%, rgba(6,15,30,0.04) 0 10%, transparent 30%),
    radial-gradient(circle at 60% 30%, rgba(0,255,170,0.02), transparent 10%),
    repeating-conic-gradient(from 0deg at 50% 50%, rgba(0,0,0,0.02) 0 2deg, transparent 2deg 8deg);
  mix-blend-mode: screen;
  filter: blur(14px) saturate(1.1);
  transform: translateZ(0);
  animation: bg-drift 18s linear infinite;
  opacity:0.95;
}

/* Фоновая анимация — медленное дрейфование для ощущения "аномалий" */
@keyframes bg-drift {
  0% { transform: translate3d(0,0,0) scale(1); }
  50% { transform: translate3d(-6px,4px,0) scale(1.01); }
  100% { transform: translate3d(0,0,0) scale(1); }
}

/* =====================
   Контейнер и сетка страницы
   ===================== */
.container{
  position:relative;
  z-index:2;
  max-width:1100px;
  margin:40px auto;
  padding:24px;
  display:grid;
  grid-template-columns: 1fr;
  gap:24px;
}

.box{
  background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));
  border-radius: var(--radius);
  padding:var(--space);
  box-shadow: var(--soft-shadow);
  border: 1px solid rgba(255,255,255,0.03);
  position:relative;
  overflow:hidden;
  transition: box-shadow var(--med) var(--ease), transform var(--med) var(--ease);
}

/* Карточка - базовый UI-панель (строгие поверхности, панельная структура) */
.card{
  /* background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01)); */
  border-radius: var(--radius);
  padding:var(--space);
  box-shadow: var(--soft-shadow);
  border: 1px solid rgba(255,255,255,0.03);
  position:relative;
  overflow:hidden;
  transition: box-shadow var(--med) var(--ease), transform var(--med) var(--ease);
}

/* лёгкая подсветка по наведению — технически минималистично */
.card:hover{ transform: translateY(-6px); box-shadow: 0 16px 40px rgba(0,0,0,0.55); }

/* =====================
   Шапка
   ===================== */
.header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:20px;
}
.header-left { max-width: 78%; }
.title{
  font-size:28px;
  margin:0 0 6px 0;
  letter-spacing:0.6px;
  font-weight:700;
}
.subtitle{
  margin:0;
  color:var(--muted);
  font-size:13px;
}

/* metadata chip */
.meta-chip{
  display:inline-block;
  background: linear-gradient(90deg, rgba(0,0,0,0.12), rgba(255,255,255,0.02));
  padding:6px 10px;
  border-radius: 10px;
  color:var(--muted);
  font-size:12px;
  margin-bottom:8px;
}

/* =====================
   Секции и заголовки
   ===================== */
.section-title{
  font-size:var(--scale-h2);
  margin:0 0 8px 0;
  color:var(--text-main);
}
.muted{ color:var(--muted); font-size:13px; }

/* Слой (layer) — визуальная организация по пластам */
.layer{ margin-top:16px; }
.layer-head{ margin-bottom:12px; }
.layer-title{ margin:0; font-size:16px; font-weight:600; }

/* Сетки карточек */
.cards-grid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(260px,1fr));
  gap:var(--grid-gap);
}

/* =====================
   Карточки сервисов
   ===================== */
.service-card{
  display:flex;
  flex-direction:column;  
  justify-content: space-between;
  gap:12px;
  padding:14px;
  border-radius: calc(var(--radius) - 2px);
  background: linear-gradient(180deg, rgba(13, 26, 21, 0.28), rgba(7, 22, 29, 0.22));
  border: 1px solid rgba(19, 44, 31, 0.178);
}

/* Верхняя часть карточки — иконка + текст */
.card-top{
  display:flex;
  gap:12px;
  align-items:flex-start;
}
.icon{
  width:44px;
  height:44px;
  flex:0 0 44px;
  border-radius:10px;
  padding:8px;
  background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(0,0,0,0.06));
  display:inline-block;
  color:var(--accent-b);
  box-shadow: 0 6px 18px rgba(0,0,0,0.5), 0 0 18px rgba(0,255,170,var(--glow-alpha));
  transition: transform var(--fast) var(--ease);
}
.service-card:hover .icon{ transform: translateY(4px) rotate(-2deg); }

/* Текст внутри карточки */
.card-title{ margin:0; font-weight:700; font-size:15px; letter-spacing:0.3px; }
.card-desc{ margin:4px 0 0 0; color:var(--muted); font-size:13px; }

/* Действия карточки */
.card-actions{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
}

/* Кнопки квадратные */
.btn-square{
  display:inline-grid;
  place-items:center;
  width:36px;
  height:36px;
  border-radius:8px;
  background: rgba(255,255,255,0.02);
  color:var(--text-main);
  border:1px solid rgba(255,255,255,0.03);
  text-decoration:none;
  font-weight:700;
  font-size:smaller;
  cursor:pointer;
  transition: transform var(--fast) var(--ease), background var(--fast) var(--ease);
}
.btn-square:hover{ transform: translateY(-3px); background: rgba(255,255,255,0.035); }

/* Акцентная кнопка 'Перейти' */
.btn-accent{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 14px;
  border-radius:10px;
  background:linear-gradient(90deg, var(--accent-a), var(--accent-b), var(--accent-c));
  box-shadow: 0 8px 30px rgba(0,127,95,0.12), 0 0 28px rgba(0,255,170,0.12);
  color: #02120f;
  font-weight:700;
  text-decoration:none;
  /* border: 1px solid rgba(255,255,255,0.06); */
  transition: transform var(--fast) var(--ease), box-shadow var(--fast) var(--ease);
}
.btn-accent:hover{ transform: translateY(-4px); box-shadow: 0 16px 44px rgba(0,127,95,0.2); }

/* Большая акцентная кнопка */
.btn-accent.large{
  /* padding:14px 18px; */
  font-size:15px;
  margin-top:12px;
  display:inline-block;
}

/* =====================
   Технические карточки (компактные)
   ===================== */
.tech-grid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(200px,1fr));
  gap:12px;
  margin-top:8px;
}
.tech-card{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:10px;
  background: linear-gradient(180deg, rgba(255,255,255,0.015), rgba(0,0,0,0.06));
  border-radius:10px;
  min-height:64px;
}
.tech-top{ color:var(--text-main); }
.tech-actions{ display:flex; gap:8px; align-items:center; }

/* =====================
   Модал — внутренняя база знаний
   ===================== */
.modal{
  position:fixed;
  inset:0;
  display:grid;
  place-items:center;
  z-index:100;
  background: linear-gradient(0deg, rgba(2,6,8,0.6), rgba(2,6,8,0.55));
  opacity:0;
  pointer-events:none;
  transition: opacity var(--fast) var(--ease);
}
.modal[aria-hidden="false"]{ opacity:1; pointer-events:auto; }
.modal-content{ width:min(720px,92%); max-height:78vh; overflow:auto; padding:18px; border-radius:14px; background: rgba(0, 0, 0, 0.829);}

/* Кнопка закрытия */
.btn-square.close{ position:absolute; right:14px; top:14px; }

/* Мелкие стили */
.large{ display:inline-block; }

/* =====================
   Золотые микродетали — тонкие линии и маркеры
   ===================== */
.card::after{
  /* тонкая золотая полоска сверху — негромкая декоративность */
  content: "";
  position:absolute;
  left:12px;
  right:12px;
  top:6px;
  height:2px;
  background: linear-gradient(90deg, transparent, rgba(217,180,91,0.95), transparent);
  opacity:0.9;
  pointer-events:none;
  mix-blend-mode: overlay;
}

/* =====================
   Адаптив и мелкие правки
   ===================== */
@media (max-width:640px){
  .header{ flex-direction:column; align-items:flex-start; gap:12px; }
  .title{ font-size:22px; }
  .card{ padding:12px; }
  .icon{ width:40px; height:40px; }
}
