/*!
 * Путь: /wp-content/themes/sml-theme/assets/css/home.css
 * Описание: Главная + индексные шаблоны (Home/Projects/Services) по ТЗ SML.
 *           Акцент: Projects (3–2–1 при 1180/768), Services split (Core/Additional),
 *           Materials (2 карточки), Team, Updates + аккуратные empty/admin states.
 * Версия: 1.1.1
 * Автор: NUVREN / Nuvren.com
 */

/* ─────────────────────────────────────────────────────────────
   HERO
   ───────────────────────────────────────────────────────────── */

.sml-hero {
  position: relative;
  min-height: clamp(560px, 78vh, 860px);
  display: grid;
  align-items: center;
  overflow: hidden;
  isolation: isolate;
  background: var(--sml-dark-surface);
}

.sml-hero__media {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.sml-hero__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.sml-hero__veil {
  position: absolute;
  inset: 0;
  z-index: 1;
  /* Один veil - для читаемости, но не "убивает" фото */
  background:
    radial-gradient(900px 520px at 18% 18%, rgba(255,255,255,0.08), transparent 60%),
    linear-gradient(180deg, rgba(0,0,0,0.10), rgba(0,0,0,0.46));
}

.sml-hero__inner {
  position: relative;
  z-index: 2;
  padding-top: clamp(44px, 6vw, 70px);
  padding-bottom: clamp(64px, 8vw, 96px);
}

.sml-hero__copy {
  max-width: 820px; /* ТЗ: max-width 820px */
  color: #fff;
}

.sml-hero__lead { color: rgba(255,255,255,0.82); }

.sml-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 22px;
}

.sml-hero__pills { margin-top: 22px; }

/* Breakpoints: 360 / 480 */
@media (max-width: 479px) {
  .sml-hero__actions { flex-direction: column; align-items: stretch; }
  .sml-hero__actions .sml-btn { width: 100%; }
}
@media (max-width: 359px) {
  .sml-hero { min-height: 520px; }
}

/* ─────────────────────────────────────────────────────────────
   PROJECTS (карточки)
   ───────────────────────────────────────────────────────────── */

.sml-project-grid {
  display: grid;
  gap: var(--sml-gap);
  grid-template-columns: 1fr; /* <768: 1 колонка */
}

@media (min-width: 768px) {
  .sml-project-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } /* 768-1179: 2 */
}

@media (min-width: 1180px) {
  .sml-project-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); } /* 1180+: 3 */
}

.sml-project-card {
  display: flex;
  flex-direction: column;
  background: var(--sml-surface-solid);
  border: 1px solid var(--sml-border);
  border-radius: var(--sml-radius-lg);
  overflow: hidden;
  box-shadow: var(--sml-shadow-sm);
  color: inherit;
  transition: transform var(--sml-dur-2) var(--sml-ease), box-shadow var(--sml-dur-2) var(--sml-ease), border-color var(--sml-dur-2) var(--sml-ease);
}

.sml-project-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--sml-shadow-md);
  border-color: rgba(67,130,57,0.18);
}

.sml-project-card:focus-visible {
  outline: none;
  box-shadow: var(--sml-ring), var(--sml-shadow-md);
  border-color: rgba(67,130,57,0.22);
}

.sml-project-card__media {
  aspect-ratio: 16 / 10; /* ТЗ: 16:10 */
  background: rgba(18,22,18,0.06);
  position: relative;
}

.sml-project-card__media::after {
  /* Очень лёгкий overlay на media */
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0.00), rgba(0,0,0,0.10));
  pointer-events: none;
}

.sml-project-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.sml-project-card__body {
  padding: 16px 16px 14px;
  display: grid;
  gap: 8px;
}

.sml-project-card__title {
  font-size: 19px;
  font-weight: 800;
  letter-spacing: -0.01em;
  line-height: 1.2;
}

.sml-project-card__text {
  color: var(--sml-muted);
  line-height: 1.6;
  font-size: 15px;

  /* 1-2 строки (как ТЗ) */
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.sml-project-card__meta {
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 760;
  color: rgba(18,22,18,0.58);
}

.sml-project-card__cta {
  margin-top: 2px;
  font-weight: 800;
  color: var(--sml-brand);
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

/* ─────────────────────────────────────────────────────────────
   SERVICES (Core / Additional)
   ───────────────────────────────────────────────────────────── */

.sml-services-split {
  display: grid;
  grid-template-columns: 1fr; /* <768: 1 */
  gap: var(--sml-gap);
}

@media (min-width: 768px) {
  .sml-services-split { grid-template-columns: repeat(2, minmax(0, 1fr)); } /* 768+: 2 */
}

.sml-services-col {
  background: var(--sml-surface-solid);
  border: 1px solid var(--sml-border);
  border-radius: var(--sml-radius-lg);
  box-shadow: var(--sml-shadow-sm);
  padding: 18px;
}

.sml-services-col__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
}

.sml-services-list {
  display: grid;
  gap: 0;
  border-top: 1px solid rgba(18,22,18,0.08);
}

.sml-service-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
  padding: 14px 0;
  border-bottom: 1px solid rgba(18,22,18,0.08);
  color: inherit;
}

.sml-service-row__title {
  font-weight: 780;
  letter-spacing: -0.01em;
  line-height: 1.25;
}

.sml-service-row__text {
  grid-column: 1 / -1;
  margin-top: 6px;
  color: var(--sml-muted);
  line-height: 1.6;
  font-size: 15px;

  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.sml-service-row__cta {
  font-weight: 800;
  color: var(--sml-brand);
  align-self: start;
  white-space: nowrap;
}

.sml-service-row:hover .sml-service-row__title { text-decoration: underline; text-underline-offset: 3px; }
.sml-service-row:focus-visible {
  outline: none;
  border-radius: 12px;
  box-shadow: var(--sml-ring);
  background: rgba(67,130,57,0.06);
}

/* ─────────────────────────────────────────────────────────────
   MATERIALS (2 cards)
   ───────────────────────────────────────────────────────────── */

.sml-material-grid {
  display: grid;
  grid-template-columns: 1fr; /* <768: 1 */
  gap: var(--sml-gap);
}

@media (min-width: 768px) {
  .sml-material-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

.sml-material-card {
  display: block;
  background: var(--sml-surface-solid);
  border: 1px solid var(--sml-border);
  border-radius: var(--sml-radius-lg);
  box-shadow: var(--sml-shadow-sm);
  padding: 18px;
  color: inherit;
  transition: transform var(--sml-dur-2) var(--sml-ease), box-shadow var(--sml-dur-2) var(--sml-ease), border-color var(--sml-dur-2) var(--sml-ease);
}

.sml-material-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--sml-shadow-md);
  border-color: rgba(67,130,57,0.18);
}

.sml-material-card:focus-visible {
  outline: none;
  box-shadow: var(--sml-ring), var(--sml-shadow-md);
}

.sml-material-card__label {
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 760;
  color: rgba(18,22,18,0.56);
}

.sml-material-card__title {
  margin-top: 10px;
  font-size: 19px;
  font-weight: 800;
  letter-spacing: -0.01em;
}

.sml-material-card__text {
  margin-top: 8px;
  color: var(--sml-muted);
  line-height: 1.6;
  font-size: 15px;
  max-width: 62ch;
}

.sml-material-card__cta {
  margin-top: 14px;
  font-weight: 800;
  color: var(--sml-brand);
}

/* ─────────────────────────────────────────────────────────────
   TEAM (3 cards / fallback)
   ───────────────────────────────────────────────────────────── */

.sml-team-grid {
  display: grid;
  gap: var(--sml-gap);
  grid-template-columns: 1fr; /* <768: 1 */
}

@media (min-width: 768px) {
  .sml-team-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } /* 768-1179: 2 */
}
@media (min-width: 1180px) {
  .sml-team-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); } /* 1180+: 3 */
}

.sml-team-card {
  background: var(--sml-surface-solid);
  border: 1px solid var(--sml-border);
  border-radius: var(--sml-radius-lg);
  box-shadow: var(--sml-shadow-sm);
  padding: 18px;
  display: grid;
  gap: 10px;
}

.sml-team-card__name {
  font-size: 18px;
  font-weight: 800;
  letter-spacing: -0.01em;
}

.sml-team-card__role {
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 760;
  color: rgba(18,22,18,0.56);
}

.sml-team-card__resp {
  color: var(--sml-muted);
  line-height: 1.6;
  font-size: 15px;
}

.sml-team-card__link {
  display: inline-flex;
  gap: 8px;
  align-items: center;
  font-weight: 800;
  color: var(--sml-brand);
}
.sml-team-card__link:hover { text-decoration: underline; text-underline-offset: 3px; }

.sml-team-card__link--secondary { color: rgba(18,22,18,0.86); }
.sml-team-card__link--secondary:hover { color: var(--sml-brand); }

/* ─────────────────────────────────────────────────────────────
   UPDATES (3 rows)
   ───────────────────────────────────────────────────────────── */

.sml-updates-list {
  display: grid;
  gap: 10px;
}

.sml-update-row {
  display: grid;
  grid-template-columns: 1fr; /* mobile */
  gap: 10px;
  align-items: baseline;
  padding: 14px 14px;
  background: var(--sml-surface-solid);
  border: 1px solid var(--sml-border);
  border-radius: var(--sml-radius-lg);
  box-shadow: var(--sml-shadow-sm);
  color: inherit;
  transition: transform var(--sml-dur-2) var(--sml-ease), box-shadow var(--sml-dur-2) var(--sml-ease), border-color var(--sml-dur-2) var(--sml-ease);
}

@media (min-width: 768px) {
  .sml-update-row {
    grid-template-columns: 1fr auto; /* desktop/tablet */
    gap: 12px;
  }
}

.sml-update-row:hover {
  transform: translateY(-2px);
  box-shadow: var(--sml-shadow-md);
  border-color: rgba(67,130,57,0.18);
}

.sml-update-row:focus-visible {
  outline: none;
  box-shadow: var(--sml-ring), var(--sml-shadow-md);
}

.sml-update-row__title {
  font-weight: 780;
  letter-spacing: -0.01em;
  line-height: 1.25;
}

.sml-update-row__meta {
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 760;
  color: rgba(18,22,18,0.56);
}

/* ─────────────────────────────────────────────────────────────
   EMPTY / ADMIN HINT
   ───────────────────────────────────────────────────────────── */

.sml-empty {
  background: var(--sml-surface-solid);
  border: 1px solid rgba(18,22,18,0.08);
  border-radius: var(--sml-radius-lg);
  box-shadow: var(--sml-shadow-sm);
  padding: 18px;
}

.sml-empty--inline { padding: 16px 18px; }

.sml-empty__text {
  margin: 0 0 14px;
  color: var(--sml-muted);
  line-height: 1.6;
}

/* Подсказка только для админа: компактно и отделено */
.sml-admin-hint {
  margin-top: 14px;
  padding: 12px 12px;
  border-radius: 14px;
  border: 1px dashed rgba(18,22,18,0.20);
  background: rgba(var(--sml-surface-rgb), 0.62);
  color: rgba(18,22,18,0.78);
  font-size: 13px;
  line-height: 1.55;
}

/* ─────────────────────────────────────────────────────────────
   CTA
   ───────────────────────────────────────────────────────────── */

.sml-cta { padding: clamp(56px, 6.5vw, 92px) 0; }

.sml-cta__inner {
  background: linear-gradient(135deg, rgba(67, 130, 57, 0.10), rgba(var(--sml-surface-rgb), 0.80));
  border: 1px solid rgba(67, 130, 57, 0.18);
  border-radius: var(--sml-radius-lg);
  padding: clamp(22px, 3.2vw, 30px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  box-shadow: var(--sml-shadow-md);
}

.sml-cta__actions { display: flex; gap: 12px; flex-wrap: wrap; }

@media (max-width: 1023px) {
  .sml-cta__inner { flex-direction: column; align-items: flex-start; }
}

@media (min-width: 1440px) {
  .sml-hero__inner { padding-top: 74px; padding-bottom: 108px; }
}

/* ─────────────────────────────────────────────────────────────
   Minor fixes
   ───────────────────────────────────────────────────────────── */

.sml-project-grid--curated { margin-top: 12px; }
