/*
 * Путь: /wp-content/themes/sml-theme/assets/css/pages-shared.css
 * Описание: Общий совместимый слой после разбиения pages.css.
 *           Сохраняет рабочий каскад внутренних страниц без потерь по фону, шрифтам и общим блокам.
 * Версия: 1.0.0
 * Автор: NUVREN
 */

/*\n * Path: /wp-content/themes/sml-theme/assets/css/pages.css\n * Description: Page styles bundle (about/contact/services/projects/team/materials/reviews).\n *              Built by concatenating original per-page CSS files without altering rules.\n * Version: 1.0.0* Author: NUVREN / Nuvren.com\n */\n
\n/* ==========================================================================\n   Source: about.css\n   ========================================================================== */\n
/*
 * Путь: /wp-content/themes/sml-theme/assets/css/about.css
 * Описание: Стили страницы About.
 *           - /about/: компактный hero (как Materials/Projects) + surface-блок с историей, фактами, ценностями и CTA.
 *           - Общие токены/типографика/кнопки/контейнер — в core.css + layout.css.
 *           - Без тяжелых библиотек, с prefers-reduced-motion.
 * Версия: 1.0.0
 * Автор: NUVREN / Nuvren.com
 */

/*
  Важно:
  - Не задаем шрифты вручную: используется платный шрифт из fonts.css через core.css.
  - Не красим текст в белый: страница светлая, используем ink/muted токены.
  - Отступы и безопасные зоны: только через контейнер и аккуратные spacing значения.
*/

/* ─────────────────────────────────────────────────────────────
   Hero actions (кнопки под подзаголовком)
   ───────────────────────────────────────────────────────────── */

.sml-about-hero__actions{
  margin-top: 14px;
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
}

/* ─────────────────────────────────────────────────────────────
   Main grid: Story + Facts
   ───────────────────────────────────────────────────────────── */

.sml-about-grid{
  display:grid;
  grid-template-columns: 1fr;
  gap: 14px;
}

.sml-about-panel{
  background: var(--sml-surface-solid);
  border: 1px solid var(--sml-border);
  border-radius: var(--sml-radius-xl);
  box-shadow: var(--sml-shadow-sm);
  padding: 14px;
}

.sml-about-h2{
  letter-spacing: -0.02em;
}

.sml-about-prose{
  max-width: 80ch;
}

.sml-about-prose p{ margin: 10px 0; color: rgba(var(--sml-ink-rgb), 0.84); line-height: 1.7; }

.sml-about-aside{
  display:block;
}

.sml-about-facts{
  display:grid;
  grid-template-columns: 1fr;
  gap: 10px;
}

.sml-about-fact{
  background: rgba(var(--sml-surface-rgb), 0.72);
  border: 1px solid var(--sml-border);
  border-radius: var(--sml-radius-lg);
  box-shadow: var(--sml-shadow-sm);
  padding: 14px;
}

.sml-about-fact__k{
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 780;
  color: rgba(var(--sml-ink-rgb), 0.56);
}

.sml-about-fact__v{
  margin-top: 6px;
  font-size: 16px;
  font-weight: 860;
  letter-spacing: -0.01em;
  color: rgba(var(--sml-ink-rgb), 0.92);
}

@media (min-width: 860px){
  .sml-about-grid{
    grid-template-columns: minmax(0, 1.35fr) minmax(0, 0.65fr);
    gap: 12px;
    align-items: start;
  }
  .sml-about-panel{ padding: 18px; }
}

/* ─────────────────────────────────────────────────────────────
   Values cards
   ───────────────────────────────────────────────────────────── */

.sml-about-values{
  margin-top: 18px;
  border-top: 1px solid rgba(var(--sml-ink-rgb), 0.08);
  padding-top: 18px;
}

.sml-about-sub{
  color: var(--sml-muted);
  line-height: 1.65;
  max-width: 72ch;
}

.sml-about-cards{
  margin-top: 12px;
  display:grid;
  grid-template-columns: 1fr;
  gap: 10px;
}

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

@media (min-width: 980px){
  .sml-about-cards{ grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; }
}

.sml-about-card{
  background: var(--sml-surface-solid);
  border: 1px solid var(--sml-border);
  border-radius: var(--sml-radius-xl);
  box-shadow: var(--sml-shadow-sm);
  padding: 14px;
}

.sml-about-card__title{
  font-weight: 880;
  letter-spacing: -0.02em;
  color: rgba(var(--sml-ink-rgb), 0.92);
}

.sml-about-card__text{
  margin-top: 8px;
  color: rgba(var(--sml-ink-rgb), 0.74);
  line-height: 1.65;
}

/* ─────────────────────────────────────────────────────────────
   CTA + Hiring
   ───────────────────────────────────────────────────────────── */

.sml-about-cta,
.sml-about-hiring{
  margin-top: 18px;
}

.sml-about-cta__inner,
.sml-about-hiring__inner{
  background:
    radial-gradient(120% 90% at 20% 10%, rgba(67, 130, 57, 0.10), transparent 58%),
    linear-gradient(180deg, rgba(18, 22, 18, 0.02), rgba(18, 22, 18, 0.06));
  border: 1px solid var(--sml-border);
  border-radius: var(--sml-radius-xl);
  box-shadow: var(--sml-shadow-sm);
  padding: 16px;
  display:flex;
  gap: 12px;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
}

.sml-about-cta__actions,
.sml-about-hiring__actions{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
}

@media (min-width: 768px){
  .sml-about-cta__inner,
  .sml-about-hiring__inner{ padding: 18px; }
}

/* ─────────────────────────────────────────────────────────────
   Reduced motion
   ───────────────────────────────────────────────────────────── */

@media (prefers-reduced-motion: reduce){
  .sml-about-panel,
  .sml-about-fact,
  .sml-about-card,
  .sml-about-cta__inner,
  .sml-about-hiring__inner{
    scroll-behavior: auto;
  }
}

/* Contact uses the same page frame as other internal templates:
   sml-page-hero + sml-page + sml-page-surface.
   Keep Contact-specific rules only for the grid/cards.
*/

.sml-contact{
  padding-top: 6px;
  padding-bottom: clamp(38px, 4.4vw, 60px);
}

.sml-contact-head {
  max-width: 980px;
  margin-bottom: 22px;
}

.sml-contact-eyebrow{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid var(--sml-border);
  background: rgba(var(--sml-surface-rgb), 0.72);
  box-shadow: var(--sml-shadow-sm);
}

.sml-contact-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
  gap: 12px;
  align-items: start;
}

@media (max-width: 960px) {
  .sml-contact-grid { grid-template-columns: 1fr; }
}

.sml-contact-card{
  border-radius: var(--sml-radius-xl);
  border: 1px solid var(--sml-border);
  background: var(--sml-surface-solid);
  box-shadow: var(--sml-shadow-sm);
  overflow: hidden;
}

.sml-contact-card__inner {
  padding: 18px;
}

@media (min-width: 768px) {
  .sml-contact-card__inner { padding: 22px; }
}

.sml-contact-card__title {
  margin: 0 0 12px;
}

.sml-team-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}

.sml-team-item {
  border-radius: 16px;
  border: 1px solid rgba(18,22,18,0.10);
  background: rgba(255,255,255,0.44);
  box-shadow: 0 18px 54px rgba(18,22,18,0.08);
  padding: 16px;
  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-team-item:hover {
  transform: translateY(-2px);
  box-shadow: 0 26px 80px rgba(18,22,18,0.12);
  border-color: rgba(67,130,57,0.22);
}

.sml-team-item__name {
  margin: 0 0 6px;
  font-weight: 820;
  letter-spacing: -0.02em;
}

.sml-team-item__role {
  margin: 0 0 10px;
  color: var(--sml-muted);
  line-height: 1.6;
}

.sml-team-item__cta {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
}

.sml-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 9px 12px;
  border-radius: 999px;
  border: 1px solid rgba(67,130,57,0.26);
  background: rgba(67,130,57,0.08);
  color: rgba(18,22,18,0.92);
  font-weight: 720;
  transition: transform var(--sml-dur-2) var(--sml-ease), background var(--sml-dur-2) var(--sml-ease), border-color var(--sml-dur-2) var(--sml-ease);
}

.sml-chip:hover {
  transform: translateY(-1px);
  background: rgba(67,130,57,0.12);
  border-color: rgba(67,130,57,0.36);
}

.sml-chip:active { transform: translateY(0); }

.sml-contact-form {
  display: grid;
  gap: 12px;
}

.sml-contact-form .sml-field {
  display: grid;
  gap: 8px;
}

.sml-contact-form textarea {
  min-height: 140px;
  resize: vertical;
}

.sml-contact-actions {
  display: flex;
  gap: 12px;
  align-items: center;
  flex-wrap: wrap;
  margin-top: 6px;
}

.sml-contact-msg {
  min-height: 18px;
  font-size: 13px;
  font-weight: 700;
}

.sml-contact-msg.is-ok { color: rgba(40, 120, 62, 1); }
.sml-contact-msg.is-err { color: rgba(188, 44, 44, 1); }

/* reCAPTCHA box alignment */
.sml-recaptcha {
  transform-origin: left top;
}

.sml-materials{
  padding-top: 6px;
  padding-bottom: clamp(40px, 4.8vw, 68px); /* чтобы листинг не прилипал к футеру */
}

.sml-materials-head{
  display:flex;
  flex-direction: column;
  gap: 10px;
  margin: 0 0 16px;
  max-width: 68ch;
}

.sml-materials-title{
  margin: 0;
  letter-spacing: -0.02em;
}

.sml-materials-sub{
  margin: 0;
  max-width: 72ch;
  color: var(--sml-muted);
  font-size: 15px;
  line-height: 1.62;
}

.sml-material-card__meta{
  display:flex;
  justify-content:flex-start;
}

/* ─────────────────────────────────────────────────────────────
   Material detail (/material/{slug}/)
   ───────────────────────────────────────────────────────────── */

.sml-material-detail{
  padding-top: 6px;
  padding-bottom: clamp(44px, 5.6vw, 72px); /* КЛЮЧ: низ секции, чтобы не сливалось с футером */
}

.sml-material-hero{
  position: relative;
  border-radius: var(--sml-radius-xl);
  overflow: hidden;
  border: 1px solid var(--sml-border);
  background:
    radial-gradient(900px 460px at 20% 18%, rgba(67,130,57,0.16), transparent 62%),
    linear-gradient(180deg, rgba(18,22,18,0.02), rgba(18,22,18,0.08));
  box-shadow: var(--sml-shadow-md);
  min-height: 220px;
}

/* Доп.воздух под hero (чтобы контент визуально не прилипал) */
.sml-material-hero{ margin-bottom: 16px; }

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

.sml-material-hero__img{
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
  transform: scale(1.02);
}

.sml-material-hero__veil{
  position:absolute;
  inset:0;
  background:
    radial-gradient(120% 90% at 18% 18%, rgba(67,130,57,0.22), transparent 62%),
    linear-gradient(180deg, rgba(0,0,0,0.00), rgba(0,0,0,0.30));
}

.sml-material-hero__copy{
  position: relative;
  padding: 20px;
  max-width: 860px;
  color: #fff;
}

.sml-material-hero__price{
  display:inline-flex;
  align-items:center;
  height: 32px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.18);
  background: rgba(0,0,0,0.22);
  backdrop-filter: blur(10px);
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 850;
  color: rgba(255,255,255,0.92);
}

.sml-material-hero__title{
  margin: 10px 0 0;
  color:#fff;
  text-shadow: 0 10px 26px rgba(0,0,0,0.28);
}

.sml-material-hero__sub{
  margin: 10px 0 0;
  color: rgba(255,255,255,0.84);
  max-width: 72ch;
}

.sml-material-hero__actions{
  margin-top: 16px;
  display:flex;
  flex-wrap: wrap;
  gap: 10px;
}

.sml-material-hero__actions .sml-btn{
  box-shadow: 0 18px 50px rgba(0,0,0,0.20);
}

.sml-material-hero .sml-btn{
  border-color: rgba(255,255,255,0.14);
}

.sml-material-hero .sml-btn--ghost{
  background: rgba(255,255,255,0.10);
  color: #fff;
}

.sml-material-hero .sml-btn--ghost:hover{
  background: rgba(255,255,255,0.16);
}

/* Layout: prose + aside */
.sml-material-layout{
  margin-top: 18px; /* КЛЮЧ: чтобы не слипалось с hero */
  margin-bottom: 18px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}

@media (min-width: 980px){
  .sml-material-layout{
    grid-template-columns: 1.35fr 0.65fr;
    gap: 18px;
    margin-top: 20px;
  }
}

/* Prose panel */
.sml-material-prose{
  background: var(--sml-surface-solid);
  border: 1px solid var(--sml-border);
  border-radius: var(--sml-radius-xl);
  box-shadow: var(--sml-shadow-sm);
  padding: 18px;
  min-height: 220px; /* чтобы блок выглядел завершенным */
}

/* Внутренний ритм текста (чтобы не было “слипшихся” заголовков и списков) */
.sml-material-prose > *:first-child{ margin-top: 0; }
.sml-material-prose > *:last-child{ margin-bottom: 0; }

.sml-material-prose p{ margin: 0 0 12px; line-height: 1.7; }
.sml-material-prose h2{ margin: 18px 0 10px; }
.sml-material-prose h3{ margin: 16px 0 8px; }
.sml-material-prose ul,
.sml-material-prose ol{ margin: 10px 0 14px; padding-left: 18px; }
.sml-material-prose li{ margin: 6px 0; }

@media (min-width: 980px){
  .sml-material-prose{
    padding: 20px;
    min-height: 260px;
  }
}

.sml-material-aside{ position: relative; }

/* Contact panel */
.sml-material-panel{
  position: sticky;
  top: 92px;
  background: rgba(var(--sml-surface-rgb), 0.92);
  border: 1px solid var(--sml-border);
  border-radius: var(--sml-radius-xl);
  box-shadow: var(--sml-shadow-sm);
  padding: 16px;
}

@media (max-width: 979px){
  .sml-material-panel{
    position: static;
    top:auto;
  }
}

.sml-material-panel__title{
  font-weight: 900;
  letter-spacing: -0.01em;
  margin: 0 0 10px;
}

.sml-material-panel__row{
  display: grid;
  grid-template-columns: 92px 1fr;
  gap: 10px;
  padding: 10px 0;
  border-top: 1px solid rgba(var(--sml-ink-rgb), 0.08);
}

.sml-material-panel__row:first-of-type{
  border-top: 0;
  padding-top: 0;
}

.sml-material-panel__label{
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 800;
  color: rgba(var(--sml-ink-rgb), 0.58);
}

.sml-material-panel__value{
  font-weight: 700;
  color: rgba(var(--sml-ink-rgb), 0.86);
}

@media (max-width: 560px){
  .sml-material-hero__copy{ padding: 18px; }
  .sml-material-panel{ padding: 14px; }
  .sml-material-layout{ margin-top: 16px; }
  .sml-material-detail{ padding-bottom: 64px; } /* чтобы точно был воздух до футера */
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .sml-material-hero__img{
    transform: none !important;
  }
}

@media (prefers-reduced-motion: reduce){
  .sml-overlay__panel,
  .sml-overlay__menu li,
  .sml-overlay__block{
    animation: none !important;
  }
}

@keyframes smlFloatIn {
  0%   { transform: translate3d(0, 10px, 0) scale(0.985); filter: blur(2px); opacity: 0.001; }
  100% { transform: translate3d(0, 0, 0) scale(1); filter: blur(0); opacity: 1; }
}

@keyframes smlPanelIn {
  0%   { transform: translate3d(26px, 0, 0); opacity: 0.001; }
  100% { transform: translate3d(0, 0, 0); opacity: 1; }
}

/* Включается JS-ом через класс .sml-motion-ready на html */
html.sml-motion-ready .sml-overlay.is-open .sml-overlay__panel{
  animation: smlPanelIn 420ms var(--sml-ease) both;
}

html.sml-motion-ready .sml-overlay.is-open .sml-overlay__menu li{
  animation: smlFloatIn 520ms var(--sml-ease) both;
}

html.sml-motion-ready .sml-overlay.is-open .sml-overlay__menu li:nth-child(1){ animation-delay: 40ms; }
html.sml-motion-ready .sml-overlay.is-open .sml-overlay__menu li:nth-child(2){ animation-delay: 90ms; }
html.sml-motion-ready .sml-overlay.is-open .sml-overlay__menu li:nth-child(3){ animation-delay: 140ms; }
html.sml-motion-ready .sml-overlay.is-open .sml-overlay__menu li:nth-child(4){ animation-delay: 190ms; }
html.sml-motion-ready .sml-overlay.is-open .sml-overlay__menu li:nth-child(5){ animation-delay: 240ms; }
html.sml-motion-ready .sml-overlay.is-open .sml-overlay__menu li:nth-child(6){ animation-delay: 290ms; }

html.sml-motion-ready .sml-overlay.is-open .sml-overlay__block{
  animation: smlFloatIn 560ms var(--sml-ease) both;
  animation-delay: 120ms;
}

.sml-page{
  padding: clamp(28px, 3.8vw, 52px) 0;
}

/* ────────────────────────────────────────
   Page hero (internal pages)
   Purpose: remove "plain block" feeling and unify the rhythm across templates.
   ──────────────────────────────────────── */

.sml-page-hero{
  position: relative;
  overflow: hidden;
  padding: clamp(34px, 4.6vw, 64px) 0;
  background:
    radial-gradient(120% 90% at 18% 12%, rgba(67,130,57,0.10), transparent 58%),
    radial-gradient(120% 90% at 82% 28%, rgba(18,22,18,0.08), transparent 56%),
    linear-gradient(180deg, rgba(247,243,234,0.86), rgba(247,243,234,0.70));
  border-top: 1px solid rgba(18, 22, 18, 0.06);
  border-bottom: 1px solid rgba(18, 22, 18, 0.08);
}

.sml-page-hero::before{
  content:"";
  position:absolute;
  inset:0;
  background: url("../img/noise.png") repeat;
  opacity: 0.06;
  pointer-events:none;
  mix-blend-mode: multiply;
}

.sml-page-hero > *{ position: relative; }

.sml-page-hero__inner{
  display: grid;
  gap: 12px;
  max-width: 820px;
}

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

.sml-page-hero__sub{
  margin: 0;
  max-width: 68ch;
  color: var(--sml-muted);
}

.sml-page-surface{
  margin-top: 0;
  background: rgba(var(--sml-surface-rgb), 0.86);
  border: 1px solid rgba(18, 22, 18, 0.10);
  border-radius: var(--sml-radius-xl);
  box-shadow: 0 26px 80px rgba(18, 22, 18, 0.10);
  padding: clamp(16px, 2.4vw, 22px);
}

.sml-page-surface .sml-prose{ max-width: 900px; }

.sml-page-actions{
  margin-top: 18px;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.sml-page__title{ max-width: 980px; }
.sml-post-head{ max-width: 980px; margin-bottom: 18px; }

.sml-page__title,
.sml-post-head{
  margin-left: auto;
  margin-right: auto;
}

.sml-post-meta{
  margin-top: 10px;
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(18, 22, 18, 0.55);
}

.sml-page .sml-prose{ max-width: 860px; }

.sml-page .sml-prose h1,
.sml-page .sml-prose h2,
.sml-page .sml-prose h3{
  letter-spacing: -0.02em;
}

.sml-page .sml-prose ul{ padding-left: 18px; }
.sml-page .sml-prose li{ margin: 6px 0; }

/* Detail templates (Service/Project) */
.sml-backlink{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 13px;
  color: rgba(18, 22, 18, 0.72);
  margin-bottom: 16px;
  transition: color var(--sml-dur-1) var(--sml-ease-out), transform var(--sml-dur-1) var(--sml-ease-out);
}

.sml-backlink:hover{ color: rgba(18, 22, 18, 0.92); transform: translateX(-2px); }
.sml-backlink:focus-visible{ outline: none; box-shadow: var(--sml-ring); border-radius: 10px; padding: 4px 6px; margin-left: -6px; }

.sml-detail__media{
  margin-top: 18px;
  border-radius: var(--sml-radius-lg);
  overflow: hidden;
  border: 1px solid rgba(18, 22, 18, 0.10);
  box-shadow: 0 24px 70px rgba(18, 22, 18, 0.10);
}

.sml-detail__img{
  display: block;
  width: 100%;
  height: auto;
}

.sml-detail__cta{
  margin-top: 28px;
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

/* ─────────────────────────────────────────────────────────────
   Projects page frame (убираем "пустоту", делаем плотнее)
   ───────────────────────────────────────────────────────────── */

.sml-projects{
  padding-top: 6px;
  padding-bottom: 56px;
}

.sml-projects-head{
  margin: 0 0 18px;
  max-width: 68ch;
}

.sml-projects-eyebrow{
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 780;
  color: rgba(var(--sml-ink-rgb), 0.56);
  margin-bottom: 10px;
}

.sml-projects-title{
  margin: 0;
  letter-spacing: -0.02em;
}

.sml-projects-sub{
  margin: 10px 0 0;
  color: var(--sml-muted);
  line-height: 1.65;
  max-width: 72ch;
}

/*
  Grid/Card/Pagination для листинга — единые компоненты в /assets/css/layout.css.
*/

/* ─────────────────────────────────────────────────────────────
   Detail layout (title + text, без фото сверху)
   ───────────────────────────────────────────────────────────── */

.sml-project-detail{
  padding-top: 8px;
  padding-bottom: 56px;
}

.sml-project-detail__top{
  max-width: 86ch;
  margin: 0 0 18px;
}

.sml-project-detail__back{
  display:inline-flex;
  align-items:center;
  gap: 10px;
  color: rgba(var(--sml-ink-rgb), 0.78);
  text-decoration:none;
  font-weight: 800;
  margin-bottom: 14px;
}

.sml-project-detail__back:hover{ color: var(--sml-brand, #438239); text-decoration: underline; text-underline-offset: 3px; }
.sml-project-detail__back:focus-visible{ outline:none; box-shadow: var(--sml-ring); border-radius: 12px; padding: 6px 10px; margin-left: -10px; }

.sml-project-detail__title{
  margin: 0;
  letter-spacing: -0.03em;
  line-height: 1.05;
}

.sml-project-detail__meta{
  margin-top: 10px;
  display:flex;
  flex-wrap:wrap;
  gap: 8px;
  color: rgba(var(--sml-ink-rgb), 0.56);
}

.sml-project-pill{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid var(--sml-border);
  background: rgba(var(--sml-surface-rgb), 0.72);
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 780;
}

.sml-project-content{
  background: var(--sml-surface-solid);
  border: 1px solid var(--sml-border);
  border-radius: var(--sml-radius-xl);
  box-shadow: var(--sml-shadow-sm);
  padding: 18px;
}

.sml-project-content > *:first-child{ margin-top: 0; }
.sml-project-content > *:last-child{ margin-bottom: 0; }

.sml-project-content p{
  margin: 0 0 14px;
  line-height: 1.72;
  color: rgba(var(--sml-ink-rgb), 0.84);
}

.sml-project-content h2,
.sml-project-content h3,
.sml-project-content h4,
.sml-project-content .wp-block-heading{
  margin: 20px 0 8px;
  line-height: 1.16;
  letter-spacing: -0.025em;
  color: rgba(var(--sml-ink-rgb), 0.94);
}

.sml-project-content h2{ font-size: clamp(26px, 2.3vw, 34px); }

.sml-project-content h3,
.sml-project-content h4,
.sml-project-content .wp-block-heading{
  font-size: clamp(20px, 1.5vw, 24px);
}

.sml-project-content p + h2,
.sml-project-content p + h3,
.sml-project-content p + h4,
.sml-project-content p + .wp-block-heading{
  margin-top: 22px;
}

.sml-project-content ul,
.sml-project-content ol,
.sml-project-content .wp-block-list{
  margin: 10px 0 16px;
  padding-left: 20px;
}

.sml-project-content li{
  margin: 6px 0;
  line-height: 1.68;
  color: rgba(var(--sml-ink-rgb), 0.84);
}

.sml-project-content strong{
  color: rgba(var(--sml-ink-rgb), 0.94);
  font-weight: 820;
}

.sml-project-content p strong{
  display: inline-block;
  margin-bottom: 2px;
}

.sml-project-content .wp-block-separator{
  margin: 20px 0;
}

/* Video embed (если задан sml_project_video_url) */
.sml-project-video{
  margin: 0 0 18px;
  border-radius: var(--sml-radius-xl);
  overflow: hidden;
  border: 1px solid var(--sml-border);
  background:
    radial-gradient(120% 90% at 20% 10%, rgba(67, 130, 57, 0.14), transparent 58%),
    linear-gradient(180deg, rgba(18, 22, 18, 0.04), rgba(18, 22, 18, 0.10));
  box-shadow: var(--sml-shadow-sm);
}

.sml-project-video__ratio{
  position: relative;
  padding-top: 56.25%; /* 16:9 */
}

.sml-project-video__ratio iframe{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

@media (min-width:768px){
  .sml-project-content{ padding: 22px; }
  .sml-project-content p{ margin-bottom: 15px; }
}

@media (max-width: 767px){
  .sml-project-content p{
    margin-bottom: 12px;
    line-height: 1.66;
  }

  .sml-project-content h2,
  .sml-project-content h3,
  .sml-project-content h4,
  .sml-project-content .wp-block-heading{
    margin: 18px 0 7px;
  }

  .sml-project-content ul,
  .sml-project-content ol,
  .sml-project-content .wp-block-list{
    padding-left: 18px;
  }
}

/* ─────────────────────────────────────────────────────────────
   Instagram gallery (внизу)
   ───────────────────────────────────────────────────────────── */

.sml-project-gallery-wrap{
  margin-top: 18px;
}

.sml-project-gallery-head{
  display:flex;
  align-items:baseline;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}

.sml-project-gallery-title{
  margin: 0;
  font-size: 18px;
  font-weight: 850;
  letter-spacing: -0.02em;
}

.sml-project-gallery-count{
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 780;
  color: rgba(var(--sml-ink-rgb), 0.56);
}

.sml-project-gallery{
  display:grid;
  grid-template-columns: 1fr;
  gap: 10px;
}

.sml-project-gallery--empty{
  margin-bottom: 10px;
}

.sml-project-tile--ph{
  aspect-ratio: 1 / 1;
  background:
    radial-gradient(520px 300px at 22% 20%, rgba(67,130,57,0.10), transparent 60%),
    linear-gradient(180deg, rgba(18,22,18,0.04), rgba(18,22,18,0.08));
}

.sml-project-gallery-note{
  margin: 0;
  color: var(--sml-muted);
  line-height: 1.6;
}

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

@media (min-width:768px){
  .sml-project-gallery{ grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }
}

.sml-project-tile{
  position:relative;
  display:block;
  border-radius: var(--sml-radius-md);
  overflow:hidden;
  border: 1px solid var(--sml-border);
  background: rgba(var(--sml-ink-rgb), 0.05);
  box-shadow: var(--sml-shadow-sm);
}

.sml-project-tile::after{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,0.00), rgba(0,0,0,0.16));
  opacity:0;
  transition: opacity var(--sml-dur-2) var(--sml-ease-out);
  pointer-events:none;
}

.sml-project-tile:hover::after{ opacity: 1; }

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

.sml-project-tile__img{
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
  aspect-ratio: 1 / 1; /* Instagram */
}

.sml-project-gallery--single .sml-project-tile__img{
  aspect-ratio: 16 / 10;
}

/* ─────────────────────────────────────────────────────────────
   Lightbox
   ───────────────────────────────────────────────────────────── */

.sml-lightbox{
  position: fixed;
  inset: 0;
  z-index: 9999;
  display:none;
}

.sml-lightbox.is-open{ display:block; }

.sml-lightbox__backdrop{
  position:absolute;
  inset:0;
  background: rgba(0,0,0,0.72);
}

.sml-lightbox__panel{
  position:absolute;
  inset: 0;
  display:grid;
  place-items:center;
  padding: 20px;
}

.sml-lightbox__img{
  max-width: min(1060px, 92vw);
  max-height: 86vh;
  border-radius: 16px;
  box-shadow: 0 34px 110px rgba(0,0,0,0.35);
  background: rgba(0,0,0,0.20);
}

.sml-lightbox__close,
.sml-lightbox__nav{
  position:absolute;
  top: 18px;
  border: 1px solid rgba(255,255,255,0.22);
  background: rgba(0,0,0,0.35);
  color: rgba(255,255,255,0.92);
  height: 40px;
  min-width: 40px;
  border-radius: 999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  transition: transform var(--sml-dur-2, 220ms) var(--sml-ease, cubic-bezier(0.2,0.8,0.2,1)),
              background var(--sml-dur-2, 220ms) var(--sml-ease, cubic-bezier(0.2,0.8,0.2,1));
}

.sml-lightbox__close{ right: 18px; }
.sml-lightbox__nav--prev{ left: 18px; top: 50%; transform: translateY(-50%); }
.sml-lightbox__nav--next{ right: 18px; top: 50%; transform: translateY(-50%); }

.sml-lightbox__close:hover,
.sml-lightbox__nav:hover{
  background: rgba(0,0,0,0.50);
}

.sml-lightbox__close:focus-visible,
.sml-lightbox__nav:focus-visible{
  outline:none;
  box-shadow: 0 0 0 4px rgba(67,130,57,0.35);
}

/* ─────────────────────────────────────────────────────────────
   Reduced motion
   ───────────────────────────────────────────────────────────── */

@media (prefers-reduced-motion: reduce){
  .sml-project-tile::after,
  .sml-lightbox__close,
  .sml-lightbox__nav{
    transition:none !important;
  }
}

.sml-gr{
  margin: 0;
}

.sml-gr__header{
  display:flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 12px;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(var(--sml-ink-rgb), 0.08);
}

.sml-gr__title{
  margin: 0;
  font-family: var(--sml-font-ui);
  font-weight: var(--sml-w-semibold);
  letter-spacing: -0.02em;
  font-size: 18px;
}

.sml-gr__summary{
  display:flex;
  align-items:center;
  gap: 10px;
  white-space: nowrap;
}

.sml-gr__stars{ display:inline-flex; gap: 2px; }

.sml-gr__star{ font-size: 14px; line-height: 1; }
.sml-gr__star--full,
.sml-gr__star--half{ color: var(--sml-brand); }
.sml-gr__star--empty{ color: rgba(var(--sml-ink-rgb), 0.20); }

.sml-gr__meta{
  display:inline-flex;
  align-items: baseline;
  gap: 6px;
  font-family: var(--sml-font-ui);
}

.sml-gr__avg{ font-weight: var(--sml-w-heavy); }
.sml-gr__count{ color: rgba(var(--sml-ink-rgb), 0.60); }

.sml-gr__grid{
  margin-top: 16px;
  display:grid;
  gap: 14px;
}

/* Default grid */
.sml-gr--grid .sml-gr__grid,
.sml-gr__grid[data-layout="grid"]{
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

@media (max-width: 980px){
  .sml-gr--grid .sml-gr__grid,
  .sml-gr__grid[data-layout="grid"]{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 560px){
  .sml-gr--grid .sml-gr__grid,
  .sml-gr__grid[data-layout="grid"]{ grid-template-columns: 1fr; }
}

/* Carousel layout (horizontal scroll, no library) */
.sml-gr--carousel .sml-gr__grid,
.sml-gr__grid[data-layout="carousel"]{
  grid-auto-flow: column;
  grid-auto-columns: minmax(320px, 420px);
  overflow-x: auto;
  overscroll-behavior-x: contain;
  scroll-snap-type: x mandatory;
  padding-bottom: 12px;
  -webkit-overflow-scrolling: touch;
}

.sml-gr--carousel .sml-gr__grid::-webkit-scrollbar{ height: 10px; }
.sml-gr--carousel .sml-gr__grid::-webkit-scrollbar-thumb{ background: rgba(var(--sml-ink-rgb), 0.18); border-radius: 999px; }

.sml-gr--carousel .sml-gr__card{ scroll-snap-align: start; }

.sml-gr__card{
  border-radius: 22px;
  border: 1px solid rgba(var(--sml-ink-rgb), 0.10);
  background:
    radial-gradient(120% 90% at 18% 12%, rgba(67,130,57,0.08), transparent 60%),
    rgba(var(--sml-surface-rgb), 0.92);
  box-shadow: var(--sml-shadow-sm);
  padding: 16px;
  position: relative;
  overflow:hidden;
}

.sml-gr__card::before{
  content:"";
  position:absolute;
  inset:0;
  background: url("../img/noise.png") repeat;
  opacity: 0.05;
  pointer-events:none;
}

.sml-gr__card > *{ position: relative; }

.sml-gr__card-top{
  display:flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
}

.sml-gr__author{
  font-family: var(--sml-font-ui);
  font-weight: var(--sml-w-semibold);
  letter-spacing: -0.01em;
}

.sml-gr__rating{ display:inline-flex; gap: 2px; }

.sml-gr__date{
  margin-top: 6px;
  font-size: 12px;
  color: rgba(var(--sml-ink-rgb), 0.56);
}

.sml-gr__text{
  margin-top: 10px;
  font-size: 14px;
  line-height: 1.6;
  color: rgba(var(--sml-ink-rgb), 0.78);
}

@media (hover:hover) and (pointer:fine){
  .sml-gr__card{ transition: transform var(--sml-dur-3) var(--sml-ease-out), box-shadow var(--sml-dur-3) var(--sml-ease-out), border-color var(--sml-dur-3) var(--sml-ease-out); }
  .sml-gr__card:hover{
    transform: translateY(-2px);
    box-shadow: var(--sml-shadow-md);
    border-color: rgba(var(--sml-ink-rgb), 0.16);
  }
}

/* Error box */
.sml-gr-error{
  border-radius: 18px;
  border: 1px solid rgba(190, 20, 30, 0.22);
  background: rgba(190, 20, 30, 0.06);
  padding: 14px;
}

.sml-code{
  margin-top: 10px;
  padding: 10px;
  border-radius: 12px;
  background: rgba(0,0,0,0.06);
  overflow:auto;
}

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

/* ─────────────────────────────────────────────────────────────
   Services index (/services/)
   ───────────────────────────────────────────────────────────── */

.sml-services{
  padding-top: 6px;
  padding-bottom: 56px;
}

.sml-services-head{
  display:flex;
  flex-direction: column;
  gap: 10px;
  margin: 0 0 16px;
}

.sml-services-title{
  margin: 0;
  letter-spacing: -0.02em;
}

.sml-services-sub{
  margin: 0;
  max-width: 72ch;
  color: var(--sml-muted);
  font-size: 15px;
  line-height: 1.62;
}

/*
  Сетка/карточки/пагинация — единые компоненты в /assets/css/layout.css:
  .sml-project-grid, .sml-project-card, .sml-pagination
*/

/* ─────────────────────────────────────────────────────────────
   Service detail (/service/{slug}/)
   ───────────────────────────────────────────────────────────── */

.sml-service-detail{
  padding-top: 6px;
  padding-bottom: 56px;
}

.sml-backlink{
  display:inline-flex;
  align-items:center;
  gap: 10px;
  text-decoration:none;
  color: rgba(var(--sml-ink-rgb), 0.80);
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-size: 12px;
  margin: 0 0 12px;
}

.sml-backlink:hover{ color: var(--sml-brand); }

.sml-service-hero{
  position: relative;
  border-radius: var(--sml-radius-xl);
  overflow: hidden;
  border: 1px solid var(--sml-border);
  background:
    radial-gradient(900px 460px at 20% 18%, rgba(67,130,57,0.16), transparent 62%),
    linear-gradient(180deg, rgba(18,22,18,0.02), rgba(18,22,18,0.08));
  box-shadow: var(--sml-shadow-md);
}

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

.sml-service-hero__img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transform: scale(1.02);
}

.sml-service-hero__veil{
  position:absolute;
  inset: 0;
  background:
    radial-gradient(120% 90% at 18% 18%, rgba(67,130,57,0.22), transparent 62%),
    linear-gradient(180deg, rgba(0,0,0,0.00), rgba(0,0,0,0.28));
}

.sml-service-hero__copy{
  position: relative;
  padding: 20px;
  max-width: 860px;
  color: #fff;
}

.sml-service-hero__title{
  margin: 0;
  color: #fff;
  text-shadow: 0 10px 26px rgba(0,0,0,0.28);
}

.sml-service-hero__sub{
  margin: 10px 0 0;
  color: rgba(255,255,255,0.84);
  max-width: 72ch;
}

.sml-service-hero__actions{
  margin-top: 16px;
  display:flex;
  flex-wrap: wrap;
  gap: 10px;
}

.sml-service-hero__actions .sml-btn{ box-shadow: 0 18px 50px rgba(0,0,0,0.20); }

/* Layout: prose + aside */
.sml-service-layout{
  margin-top: 16px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}

/* Не даём футеру «прилипать», даже если контента мало */
.sml-service-layout{ margin-bottom: 18px; }

@media (min-width: 980px){
  .sml-service-layout{
    grid-template-columns: 1.35fr 0.65fr;
    gap: 18px;
  }
}

.sml-service-prose{
  background: var(--sml-surface-solid);
  border: 1px solid var(--sml-border);
  border-radius: var(--sml-radius-xl);
  box-shadow: var(--sml-shadow-sm);
  padding: 18px;
}

.sml-service-prose > *:first-child{ margin-top: 0; }
.sml-service-prose > *:last-child{ margin-bottom: 0; }

.sml-service-prose p{
  margin: 0 0 14px;
  line-height: 1.72;
  color: rgba(var(--sml-ink-rgb), 0.84);
}

.sml-service-prose h2,
.sml-service-prose h3,
.sml-service-prose h4,
.sml-service-prose .wp-block-heading{
  margin: 20px 0 8px;
  line-height: 1.16;
  letter-spacing: -0.025em;
  color: rgba(var(--sml-ink-rgb), 0.94);
}

.sml-service-prose h2{ font-size: clamp(26px, 2.3vw, 34px); }
.sml-service-prose h3,
.sml-service-prose h4,
.sml-service-prose .wp-block-heading{ font-size: clamp(20px, 1.5vw, 24px); }

.sml-service-prose p + h2,
.sml-service-prose p + h3,
.sml-service-prose p + h4,
.sml-service-prose p + .wp-block-heading{ margin-top: 22px; }

.sml-service-prose ul,
.sml-service-prose ol{
  margin: 10px 0 16px;
  padding-left: 20px;
}

.sml-service-prose li{
  margin: 6px 0;
  line-height: 1.68;
  color: rgba(var(--sml-ink-rgb), 0.84);
}

.sml-service-prose strong{
  color: rgba(var(--sml-ink-rgb), 0.94);
  font-weight: 820;
}

.sml-service-prose p strong{
  display: inline-block;
  margin-bottom: 2px;
}

.sml-service-prose .wp-block-list{
  margin: 10px 0 16px;
  padding-left: 20px;
}

.sml-service-prose .wp-block-separator{
  margin: 20px 0;
}

@media (min-width: 980px){
  .sml-service-prose{ padding: 20px; }
  .sml-service-prose p{ margin-bottom: 15px; }
}

@media (max-width: 767px){
  .sml-service-prose p{ margin-bottom: 12px; line-height: 1.66; }
  .sml-service-prose h2,
  .sml-service-prose h3,
  .sml-service-prose h4,
  .sml-service-prose .wp-block-heading{ margin: 18px 0 7px; }
  .sml-service-prose ul,
  .sml-service-prose ol,
  .sml-service-prose .wp-block-list{ padding-left: 18px; }
}

.sml-service-aside{ position: relative; }

/* Contact panel */
.sml-service-panel{
  position: sticky;
  top: 92px;
  background: rgba(var(--sml-surface-rgb), 0.92);
  border: 1px solid var(--sml-border);
  border-radius: var(--sml-radius-xl);
  box-shadow: var(--sml-shadow-sm);
  padding: 16px;
}

@media (max-width: 979px){
  .sml-service-panel{ position: static; top: auto; }
}

.sml-service-panel__title{
  font-weight: 900;
  letter-spacing: -0.01em;
  margin: 0 0 10px;
}

.sml-service-panel__note{
  margin: 0 0 14px;
  color: var(--sml-muted);
  line-height: 1.6;
  font-size: 14px;
}

.sml-service-panel__row{
  display: grid;
  grid-template-columns: 92px 1fr;
  gap: 10px;
  padding: 10px 0;
  border-top: 1px solid rgba(var(--sml-ink-rgb), 0.08);
}

.sml-service-panel__row:first-of-type{ border-top: 0; padding-top: 0; }

.sml-service-panel__label{
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 800;
  color: rgba(var(--sml-ink-rgb), 0.58);
}

.sml-service-panel__value{
  font-weight: 700;
  color: rgba(var(--sml-ink-rgb), 0.86);
}

.sml-detail__cta{
  margin-top: 14px;
  display: grid;
  gap: 10px;
}

/* Внутри hero кнопки на темном фоне */
.sml-service-hero .sml-btn{
  border-color: rgba(255,255,255,0.14);
}

.sml-service-hero .sml-btn--ghost{
  background: rgba(255,255,255,0.10);
  color: #fff;
}

.sml-service-hero .sml-btn--ghost:hover{
  background: rgba(255,255,255,0.16);
}

@media (max-width: 560px){
  .sml-service-hero__copy{ padding: 18px; }
  .sml-service-panel{ padding: 14px; }
}

:root{
  --sml-team-card-radius: 18px;
  --sml-team-card-border: rgba(var(--sml-ink-rgb), 0.10);
  --sml-team-card-border-strong: rgba(var(--sml-ink-rgb), 0.16);
  --sml-team-grid-max: 1040px;
}

.sml-team-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  max-width: var(--sml-team-grid-max);
  margin: 0 auto;
  align-items: start;
}

@media (max-width: 1023px){
  .sml-team-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 640px){
  .sml-team-grid{ grid-template-columns: 1fr; gap: 12px; }
}

/* Карточка */
.sml-team-card{
  position: relative;
  display:flex;
  flex-direction: column;
  border-radius: var(--sml-team-card-radius);
  border: 1px solid var(--sml-team-card-border);
  background: rgba(var(--sml-surface-rgb), 0.94);
  box-shadow: var(--sml-shadow-sm);
  overflow:hidden;
  transform: translateY(0);
  transition: transform var(--sml-dur-2) var(--sml-ease-out),
              box-shadow var(--sml-dur-2) var(--sml-ease-out),
              border-color var(--sml-dur-2) var(--sml-ease-out);
}

@media (hover:hover) and (pointer:fine){
  .sml-team-card:hover{
    transform: translateY(-2px);
    box-shadow: var(--sml-shadow-md);
    border-color: var(--sml-team-card-border-strong);
  }
}

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

/* Фото 1:1 */
.sml-team-card__media{
  aspect-ratio: 1 / 1;
  background:
    radial-gradient(120% 90% at 22% 12%, rgba(67,130,57,0.12), transparent 62%),
    linear-gradient(180deg, rgba(18,22,18,0.06), rgba(18,22,18,0.00));
  overflow:hidden;
  border-bottom: 1px solid rgba(var(--sml-ink-rgb), 0.06);
}

.sml-team-card__img{
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
  transform: scale(1.01);
  transition: transform var(--sml-dur-3) var(--sml-ease-out);
  object-position: 50% 25%;
}

@media (hover:hover) and (pointer:fine){
  .sml-team-card:hover .sml-team-card__img{ transform: scale(1.045); }
}

/* Placeholder */
.sml-team-card__ph{
  width:100%;
  height:100%;
  background:
    radial-gradient(120% 90% at 22% 12%, rgba(67,130,57,0.14), transparent 62%),
    linear-gradient(180deg, rgba(18,22,18,0.06), rgba(18,22,18,0.00));
}

/* Initials avatar (fallback, looks like a real UI component) */
.sml-avatar{
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center;
  background:
    radial-gradient(120% 90% at 22% 12%, rgba(67,130,57,0.14), transparent 62%),
    linear-gradient(180deg, rgba(18,22,18,0.06), rgba(18,22,18,0.00));
}

.sml-avatar__ini{
  font-family: var(--sml-font-ui);
  font-weight: var(--sml-w-semibold);
  letter-spacing: 0.12em;
  font-size: 20px;
  color: rgba(18, 22, 18, 0.62);
}

.sml-team-card__body{
  padding: 12px;
  display:grid;
  gap: 8px;
}

.sml-team-card__top{
  display:grid;
  gap: 2px;
}

.sml-team-card__name{
  margin: 0;
  font-family: var(--sml-font-ui);
  font-weight: var(--sml-w-semibold);
  letter-spacing: -0.015em;
  line-height: 1.18;
  font-size: 16px;
}

.sml-team-card__role{
  margin: 0;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: var(--sml-w-medium);
  color: rgba(var(--sml-ink-rgb), 0.58);
}

/* Контакты */
.sml-team-contacts{
  display:grid;
  gap: 8px;
}

.sml-team-row{
  display:grid;
  grid-template-columns: 1fr;
  gap: 10px;
  align-items:center;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(var(--sml-ink-rgb), 0.10);
  background: rgba(var(--sml-surface-rgb), 0.78);
  transition: background var(--sml-dur-1) var(--sml-ease-out),
              border-color var(--sml-dur-1) var(--sml-ease-out),
              transform var(--sml-dur-1) var(--sml-ease-out);
}

/* Icons removed for premium look */
.sml-team-row__icon{ display:none; }

.sml-team-row__value{
  min-width: 0;
  font-weight: var(--sml-w-semibold);
  font-size: 13px;
  color: rgba(var(--sml-ink-rgb), 0.92);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.sml-team-row__muted{
  color: rgba(var(--sml-ink-rgb), 0.60);
  font-weight: 800;
}

/* На мобиле ссылка должна быть удобной, поэтому она блочная и занимает всю строку */
.sml-taplink{
  display:block;
  width:100%;
  color: inherit;
  text-decoration: none;
  padding: 2px 0;
  -webkit-tap-highlight-color: rgba(67,130,57,0.14);
}

.sml-taplink:focus-visible{
  outline:none;
  box-shadow: var(--sml-ring);
  border-radius: 10px;
}

@media (hover:hover) and (pointer:fine){
  .sml-team-row:hover{
    transform: translateY(-1px);
    background: rgba(67,130,57,0.06);
    border-color: rgba(67,130,57,0.18);
  }
  .sml-taplink:hover{
    text-decoration: underline;
    text-underline-offset: 4px;
    text-decoration-color: rgba(67,130,57,0.75);
  }
}

/* Кнопка */
.sml-team-card__foot{
  margin-top: 2px;
  display:flex;
  justify-content:flex-start;
}

.sml-team-card__btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  height: 40px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid rgba(var(--sml-ink-rgb), 0.12);
  background: rgba(var(--sml-surface-rgb), 0.94);
  color: rgba(var(--sml-ink-rgb), 0.92);
  font-family: var(--sml-font-ui);
  font-weight: var(--sml-w-semibold);
  font-size: 13px;
  letter-spacing: 0.01em;
  text-decoration:none;
  transition: transform var(--sml-dur-1) var(--sml-ease-out),
              border-color var(--sml-dur-1) var(--sml-ease-out),
              background var(--sml-dur-1) var(--sml-ease-out);
}

/* Avatar fallback (when no photo set) */
.sml-team-avatar{
  width:100%;
  height:100%;
  display:grid;
  place-items:center;
  background:
    radial-gradient(120% 90% at 22% 12%, rgba(67,130,57,0.22), transparent 62%),
    radial-gradient(120% 90% at 82% 38%, rgba(255,255,255,0.12), transparent 58%),
    linear-gradient(180deg, rgba(18,22,18,0.10), rgba(18,22,18,0.02));
}
.sml-team-avatar span{
  font-family: var(--sml-font-ui);
  font-weight: var(--sml-w-heavy);
  letter-spacing: -0.02em;
  font-size: 28px;
  color: rgba(var(--sml-ink-rgb), 0.86);
}

.sml-team-card__btn::after{
  content:"→";
  transform: translateX(0);
  transition: transform var(--sml-dur-2) var(--sml-ease-out);
}

@media (hover:hover) and (pointer:fine){
  .sml-team-card__btn:hover{
    transform: translateY(-1px);
    border-color: rgba(67,130,57,0.22);
    background: rgba(67,130,57,0.08);
  }
  .sml-team-card__btn:hover::after{ transform: translateX(4px); }
}

.sml-team-card__btn:focus-visible{
  outline:none;
  box-shadow: var(--sml-ring);
}

/* Team page header */
.sml-team{
  padding-top: 6px;
  padding-bottom: clamp(38px, 4.4vw, 60px);
}

.sml-team-head{
  display:flex;
  flex-direction: column;
  gap: 10px;
  margin: 0 auto 16px;
  max-width: min(76ch, var(--sml-team-grid-max));
}

/* Detail */
.sml-team-detail{
  padding-top: 6px;
  padding-bottom: clamp(56px, 6vw, 96px);
}

.sml-team-detail__top{
  margin-top: 12px;
  display:grid;
  grid-template-columns: 1fr;
  gap: 14px;
  align-items:start;
  max-width: 1100px;
  margin-left: auto;
  margin-right: auto;
}

@media (min-width: 980px){
  .sml-team-detail__top{
    grid-template-columns: minmax(0, 1fr) minmax(0, 0.92fr);
    gap: 18px;
  }

  .sml-team-photo{
    grid-column: 1;
    grid-row: 1 / span 2;
  }

  .sml-team-info{
    grid-column: 2;
    grid-row: 1;
  }

  .sml-team-bio{
    grid-column: 2;
    grid-row: 2;
  }
}

.sml-team-photo{
  border-radius: var(--sml-radius-xl);
  border: 1px solid var(--sml-team-card-border);
  background:
    radial-gradient(120% 90% at 22% 12%, rgba(67,130,57,0.12), transparent 62%),
    linear-gradient(180deg, rgba(18,22,18,0.06), rgba(18,22,18,0.00));
  overflow:hidden;
  box-shadow: var(--sml-shadow-md);
}

.sml-team-photo__media{
  aspect-ratio: 1 / 1;
  overflow:hidden;
}

.sml-team-photo__img{
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
  object-position: 50% 25%;
}

.sml-team-info{
  border-radius: var(--sml-radius-xl);
  border: 1px solid var(--sml-team-card-border);
  background: rgba(var(--sml-surface-rgb), 0.94);
  box-shadow: var(--sml-shadow-md);
  padding: 16px;
  display:grid;
  gap: 12px;
}

@media (min-width: 980px){
  .sml-team-info{ padding: 18px; }
}

.sml-team-info__badge{
  width: fit-content;
  display:inline-flex;
  align-items:center;
  height: 30px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid rgba(var(--sml-ink-rgb), 0.12);
  background: rgba(var(--sml-surface-rgb), 0.84);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: 950;
  color: rgba(var(--sml-ink-rgb), 0.70);
}

.sml-team-info__name{
  margin: 0;
  font-weight: 860;
  letter-spacing: -0.02em;
  line-height: 1.06;
}

.sml-team-info__contacts{
  display:grid;
  gap: 10px;
}

.sml-team-info-row{
  display:grid;
  grid-template-columns: 76px 1fr;
  gap: 12px;
  align-items:center;
  padding: 10px 0;
  border-top: 1px solid rgba(var(--sml-ink-rgb), 0.08);
}

.sml-team-info-row:first-of-type{
  border-top: 0;
  padding-top: 0;
}

.sml-team-info-row__label{
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: 900;
  color: rgba(var(--sml-ink-rgb), 0.58);
}

.sml-team-info-row__value{
  min-width: 0;
  font-weight: 900;
  color: rgba(var(--sml-ink-rgb), 0.92);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.sml-team-info-row__value a{
  color: inherit;
  text-decoration:none;
}

@media (hover:hover) and (pointer:fine){
  .sml-team-info-row__value a:hover{
    text-decoration: underline;
    text-underline-offset: 4px;
    text-decoration-color: rgba(67,130,57,0.75);
  }
}

.sml-team-info__actions{
  display:flex;
  flex-wrap: wrap;
  gap: 10px;
  padding-top: 6px;
}

.sml-team-bio{
  margin-top: 0;
  border-radius: var(--sml-radius-xl);
  border: 1px solid rgba(var(--sml-ink-rgb), 0.10);
  background: rgba(var(--sml-surface-rgb), 0.94);
  box-shadow: var(--sml-shadow-sm);
  padding: 18px;
  max-width: none;
  margin-left: 0;
  margin-right: 0;
}

.sml-team-bio > *:first-child{ margin-top: 0; }
.sml-team-bio > *:last-child{ margin-bottom: 0; }
.sml-team-bio p{
  margin: 0 0 12px;
  line-height: 1.66;
  color: rgba(var(--sml-ink-rgb), 0.82);
}

/* Моб версия */
@media (max-width: 640px){
  :root{ --sml-team-card-radius: 16px; }
  .sml-team-card__body{ padding: 11px; }
  .sml-team-row{ padding: 11px 12px; }
  .sml-team-card__btn{ width: 100%; justify-content:center; }
  .sml-team-info{ padding: 14px; }
  .sml-team-bio{ padding: 16px; }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .sml-team-card,
  .sml-team-card__img,
  .sml-team-row,
  .sml-team-card__btn{
    transition:none !important;
  }
  .sml-team-card:hover{ transform:none; }
  .sml-team-card:hover .sml-team-card__img{ transform:none; }
}
/* ─────────────────────────────────────────────────────────────
   SELECT normalize (Safari/Chrome consistent)
   NOTE: placed in pages.css to ensure it wins over any later rules.
   ───────────────────────────────────────────────────────────── */

.sml-contact .sml-field select,
.sml-contact select,
.sml-field select,
select{
  -webkit-appearance: none;
  appearance: none;

  height: 44px;
  line-height: 44px;

  /* keep input look, reserve space for arrow */
  padding: 0 44px 0 14px;

  border-radius: 12px;
  border: 1px solid var(--sml-border-strong);
  background-color: var(--sml-surface);
  color: var(--sml-ink);

  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 20 20'%3E%3Cpath d='M5.5 7.5L10 12l4.5-4.5' fill='none' stroke='%23121612' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  background-size: 18px 18px;
}

.sml-contact .sml-field select::-ms-expand,
.sml-contact select::-ms-expand,
.sml-field select::-ms-expand,
select::-ms-expand{ display:none; }


/* ─────────────────────────────────────────────────────────────
   Privacy Policy (/privacy-policy/)
   ───────────────────────────────────────────────────────────── */

.sml-privacy{
  padding-top: 8px;
  padding-bottom: clamp(38px, 4.4vw, 60px);
}

.sml-privacy-hero{
  padding: 18px 0 10px;
}

.sml-privacy-hero__shell{
  position: relative;
  overflow: hidden;
  border-radius: 28px;
  border: 1px solid var(--sml-border);
  background:
    radial-gradient(120% 100% at 0% 0%, rgba(67,130,57,0.16), transparent 54%),
    radial-gradient(90% 80% at 100% 0%, rgba(18,22,18,0.06), transparent 52%),
    linear-gradient(180deg, rgba(255,255,255,0.96), rgba(248,249,246,0.98));
  box-shadow: var(--sml-shadow-md);
  padding: 18px;
}

.sml-privacy-hero__eyebrow{
  display:inline-flex;
  align-items:center;
  min-height: 32px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid rgba(var(--sml-ink-rgb), 0.10);
  background: rgba(var(--sml-surface-rgb), 0.82);
  box-shadow: var(--sml-shadow-sm);
  font-size: 12px;
  line-height: 1;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 800;
  color: rgba(var(--sml-ink-rgb), 0.74);
}

.sml-privacy-hero__grid{
  margin-top: 16px;
  display:grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(280px, 0.85fr);
  gap: 12px;
  align-items: stretch;
}

.sml-privacy-hero__copy{
  display:flex;
  flex-direction: column;
  justify-content: center;
  min-width: 0;
}

.sml-privacy-hero__title{
  margin: 0;
}

.sml-privacy-hero__sub{
  margin: 12px 0 0;
  max-width: 66ch;
  font-size: 16px;
  line-height: 1.72;
  color: rgba(var(--sml-ink-rgb), 0.76);
}

.sml-privacy-hero__actions{
  margin-top: 18px;
  display:flex;
  flex-wrap: wrap;
  gap: 10px;
}

.sml-privacy-summary{
  display:grid;
  grid-template-columns: 1fr;
  gap: 10px;
}

.sml-privacy-summary__card{
  background: rgba(var(--sml-surface-rgb), 0.82);
  border: 1px solid rgba(var(--sml-ink-rgb), 0.08);
  border-radius: 20px;
  box-shadow: var(--sml-shadow-sm);
  padding: 14px 15px;
}

.sml-privacy-summary__label{
  font-size: 11px;
  line-height: 1.2;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 800;
  color: rgba(var(--sml-ink-rgb), 0.52);
}

.sml-privacy-summary__value{
  margin-top: 7px;
  font-size: 15px;
  line-height: 1.55;
  font-weight: 760;
  color: rgba(var(--sml-ink-rgb), 0.90);
}

.sml-privacy-overview{
  margin-top: 14px;
  margin-bottom: 16px;
}

.sml-privacy-overview__grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.sml-privacy-overview__card{
  background: var(--sml-surface-solid);
  border: 1px solid var(--sml-border);
  border-radius: 22px;
  box-shadow: var(--sml-shadow-sm);
  padding: 16px;
}

.sml-privacy-overview__title{
  margin: 0;
  letter-spacing: -0.02em;
}

.sml-privacy-overview__text{
  margin: 8px 0 0;
  color: rgba(var(--sml-ink-rgb), 0.72);
  line-height: 1.68;
}

.sml-privacy-layout{
  display:grid;
  grid-template-columns: minmax(0, 280px) minmax(0, 1fr);
  gap: 18px;
  align-items: start;
}

.sml-privacy-nav{
  min-width: 0;
}

.sml-privacy-nav__inner{
  position: sticky;
  top: 104px;
  background: var(--sml-surface-solid);
  border: 1px solid var(--sml-border);
  border-radius: 22px;
  box-shadow: var(--sml-shadow-sm);
  padding: 14px;
}

.sml-privacy-nav__title{
  margin: 0 0 10px;
  font-size: 12px;
  line-height: 1.2;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 800;
  color: rgba(var(--sml-ink-rgb), 0.58);
}

.sml-privacy-nav nav{
  display:grid;
  gap: 6px;
}

.sml-privacy-nav a{
  display:block;
  padding: 10px 12px;
  border-radius: 14px;
  color: rgba(var(--sml-ink-rgb), 0.78);
  text-decoration:none;
  line-height: 1.45;
  border: 1px solid transparent;
  transition: background var(--sml-dur-2) var(--sml-ease-out), border-color var(--sml-dur-2) var(--sml-ease-out), color var(--sml-dur-2) var(--sml-ease-out), transform var(--sml-dur-2) var(--sml-ease-out);
}

.sml-privacy-nav a:hover{
  background: rgba(var(--sml-ink-rgb), 0.035);
  border-color: rgba(var(--sml-ink-rgb), 0.08);
  color: rgba(var(--sml-ink-rgb), 0.94);
  transform: translateX(2px);
}

.sml-privacy-nav a:focus-visible{
  outline:none;
  box-shadow: var(--sml-ring);
}

.sml-privacy-prose{
  max-width: none;
  min-width: 0;
}

.sml-privacy-block{
  background: var(--sml-surface-solid);
  border: 1px solid var(--sml-border);
  border-radius: 24px;
  box-shadow: var(--sml-shadow-sm);
  padding: 18px;
}

.sml-privacy-block + .sml-privacy-block{
  margin-top: 14px;
}

.sml-privacy-block__head{
  display:flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
}

.sml-privacy-block__num{
  flex: 0 0 auto;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(67,130,57,0.10);
  border: 1px solid rgba(67,130,57,0.16);
  color: rgba(var(--sml-ink-rgb), 0.86);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 860;
}

.sml-privacy-block h2{
  margin: 0;
  letter-spacing: -0.02em;
  font-size: clamp(21px, 2.4vw, 29px);
  line-height: 1.18;
}

.sml-privacy-block__body p,
.sml-privacy-block__body li{
  font-size: 15px;
  line-height: 1.76;
  color: rgba(var(--sml-ink-rgb), 0.76);
}

.sml-privacy-block__body ul{
  margin: 10px 0 0;
  padding-left: 20px;
}

.sml-privacy-block__body li + li{
  margin-top: 7px;
}

.sml-privacy-block__body a{
  word-break: break-word;
}

.sml-privacy-block--accent{
  background:
    radial-gradient(120% 90% at 0% 0%, rgba(67,130,57,0.10), transparent 52%),
    linear-gradient(180deg, rgba(255,255,255,0.96), rgba(248,249,246,0.98));
}

.sml-privacy-note{
  margin-top: 14px;
  border-radius: 22px;
  border: 1px solid rgba(67,130,57,0.18);
  background: rgba(67,130,57,0.06);
  box-shadow: var(--sml-shadow-sm);
  padding: 16px;
  color: rgba(var(--sml-ink-rgb), 0.80);
  line-height: 1.68;
}

@media (min-width: 861px){
  .sml-privacy-hero__shell{
    padding: 22px;
  }

  .sml-privacy-block{
    padding: 20px;
  }
}

@media (max-width: 1080px){
  .sml-privacy-hero__grid,
  .sml-privacy-layout{
    grid-template-columns: 1fr;
  }

  .sml-privacy-nav__inner{
    position: static;
  }
}

@media (max-width: 860px){
  .sml-privacy-overview__grid{
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px){
  .sml-privacy{
    padding-bottom: 44px;
  }

  .sml-privacy-hero{
    padding-top: 14px;
  }

  .sml-privacy-hero__shell{
    border-radius: 22px;
    padding: 14px;
  }

  .sml-privacy-hero__grid{
    margin-top: 14px;
    gap: 12px;
  }

  .sml-privacy-hero__sub,
  .sml-privacy-overview__text,
  .sml-privacy-summary__value,
  .sml-privacy-block__body p,
  .sml-privacy-block__body li,
  .sml-privacy-note{
    font-size: 14px;
    line-height: 1.7;
  }

  .sml-privacy-hero__actions{
    flex-direction: column;
  }

  .sml-privacy-hero__actions .sml-btn{
    width: 100%;
  }

  .sml-privacy-overview__card,
  .sml-privacy-nav__inner,
  .sml-privacy-block,
  .sml-privacy-note{
    border-radius: 18px;
  }

  .sml-privacy-nav nav{
    gap: 4px;
  }

  .sml-privacy-nav a{
    padding: 9px 10px;
  }

  .sml-privacy-block{
    padding: 14px;
  }

  .sml-privacy-block__head{
    gap: 10px;
    margin-bottom: 10px;
  }

  .sml-privacy-block__num{
    width: 36px;
    height: 36px;
    font-size: 11px;
  }
}

@media (prefers-reduced-motion: reduce){
  .sml-privacy-nav a,
  .sml-privacy-overview__card,
  .sml-privacy-block,
  .sml-privacy-summary__card{
    transition: none;
  }
}


/* ─────────────────────────────────────────────────────────────
   Terms of Service (/terms-of-service/)
   ───────────────────────────────────────────────────────────── */

.sml-terms{
  padding-top: 8px;
  padding-bottom: clamp(38px, 4.4vw, 60px);
}

.sml-terms-hero__grid{
  display:grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(280px, 0.85fr);
  gap: 12px;
  align-items: stretch;
}

.sml-terms-hero__copy{
  display:flex;
  flex-direction: column;
  justify-content: center;
  min-width: 0;
}

.sml-terms-hero__title{
  margin: 0;
}

.sml-terms-hero__sub{
  margin: 12px 0 0;
  max-width: 66ch;
  font-size: 16px;
  line-height: 1.72;
  color: rgba(var(--sml-ink-rgb), 0.76);
}

.sml-terms-hero__actions{
  margin-top: 18px;
  display:flex;
  flex-wrap: wrap;
  gap: 10px;
}

.sml-terms-summary{
  display:grid;
  grid-template-columns: 1fr;
  gap: 10px;
}

.sml-terms-summary__card{
  background: rgba(var(--sml-surface-rgb), 0.82);
  border: 1px solid rgba(var(--sml-ink-rgb), 0.08);
  border-radius: 20px;
  box-shadow: var(--sml-shadow-sm);
  padding: 14px 15px;
}

.sml-terms-summary__label{
  font-size: 11px;
  line-height: 1.2;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 800;
  color: rgba(var(--sml-ink-rgb), 0.52);
}

.sml-terms-summary__value{
  margin-top: 7px;
  font-size: 15px;
  line-height: 1.55;
  font-weight: 760;
  color: rgba(var(--sml-ink-rgb), 0.90);
}

.sml-terms-overview{
  margin-top: 14px;
  margin-bottom: 16px;
}

.sml-terms-overview__grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.sml-terms-overview__card{
  background: var(--sml-surface-solid);
  border: 1px solid var(--sml-border);
  border-radius: 22px;
  box-shadow: var(--sml-shadow-sm);
  padding: 16px;
}

.sml-terms-overview__title{
  margin: 0;
  letter-spacing: -0.02em;
}

.sml-terms-overview__text{
  margin: 8px 0 0;
  color: rgba(var(--sml-ink-rgb), 0.72);
  line-height: 1.68;
}

.sml-terms-layout{
  display:grid;
  grid-template-columns: minmax(0, 280px) minmax(0, 1fr);
  gap: 18px;
  align-items: start;
}

.sml-terms-nav{
  min-width: 0;
}

.sml-terms-nav__inner{
  position: sticky;
  top: 104px;
  background: var(--sml-surface-solid);
  border: 1px solid var(--sml-border);
  border-radius: 22px;
  box-shadow: var(--sml-shadow-sm);
  padding: 14px;
}

.sml-terms-nav__title{
  margin: 0 0 10px;
  font-size: 12px;
  line-height: 1.2;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 800;
  color: rgba(var(--sml-ink-rgb), 0.58);
}

.sml-terms-nav nav{
  display:grid;
  gap: 6px;
}

.sml-terms-nav a{
  display:block;
  padding: 10px 12px;
  border-radius: 14px;
  color: rgba(var(--sml-ink-rgb), 0.78);
  text-decoration:none;
  line-height: 1.45;
  border: 1px solid transparent;
  transition: background var(--sml-dur-2) var(--sml-ease-out), border-color var(--sml-dur-2) var(--sml-ease-out), color var(--sml-dur-2) var(--sml-ease-out), transform var(--sml-dur-2) var(--sml-ease-out);
}

.sml-terms-nav a:hover{
  background: rgba(var(--sml-ink-rgb), 0.035);
  border-color: rgba(var(--sml-ink-rgb), 0.08);
  color: rgba(var(--sml-ink-rgb), 0.94);
  transform: translateX(2px);
}

.sml-terms-nav a:focus-visible{
  outline:none;
  box-shadow: var(--sml-ring);
}

.sml-terms-prose{
  max-width: none;
  min-width: 0;
}

.sml-terms-block{
  background: var(--sml-surface-solid);
  border: 1px solid var(--sml-border);
  border-radius: 24px;
  box-shadow: var(--sml-shadow-sm);
  padding: 18px;
}

.sml-terms-block + .sml-terms-block{
  margin-top: 14px;
}

.sml-terms-block__head{
  display:flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
}

.sml-terms-block__num{
  flex: 0 0 auto;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(67,130,57,0.10);
  border: 1px solid rgba(67,130,57,0.16);
  color: rgba(var(--sml-ink-rgb), 0.86);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 860;
}

.sml-terms-block h2{
  margin: 0;
  letter-spacing: -0.02em;
  font-size: clamp(21px, 2.4vw, 29px);
  line-height: 1.18;
}

.sml-terms-block__body p,
.sml-terms-block__body li{
  font-size: 15px;
  line-height: 1.76;
  color: rgba(var(--sml-ink-rgb), 0.76);
}

.sml-terms-block__body ul{
  margin: 10px 0 0;
  padding-left: 20px;
}

.sml-terms-block__body li + li{
  margin-top: 7px;
}

.sml-terms-block__body a{
  word-break: break-word;
}

.sml-terms-block--accent{
  background:
    radial-gradient(120% 90% at 0% 0%, rgba(67,130,57,0.10), transparent 52%),
    linear-gradient(180deg, rgba(255,255,255,0.96), rgba(248,249,246,0.98));
}

.sml-terms-note{
  margin-top: 14px;
  border-radius: 22px;
  border: 1px solid rgba(67,130,57,0.18);
  background: rgba(67,130,57,0.06);
  box-shadow: var(--sml-shadow-sm);
  padding: 16px;
  color: rgba(var(--sml-ink-rgb), 0.80);
  line-height: 1.68;
}

@media (min-width: 861px){
  .sml-terms-block{
    padding: 20px;
  }
}

@media (max-width: 1080px){
  .sml-terms-hero__grid,
  .sml-terms-layout{
    grid-template-columns: 1fr;
  }

  .sml-terms-nav__inner{
    position: static;
  }
}

@media (max-width: 860px){
  .sml-terms-overview__grid{
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px){
  .sml-terms{
    padding-bottom: 44px;
  }

  .sml-terms-hero__sub,
  .sml-terms-overview__text,
  .sml-terms-summary__value,
  .sml-terms-block__body p,
  .sml-terms-block__body li,
  .sml-terms-note{
    font-size: 14px;
    line-height: 1.7;
  }

  .sml-terms-hero__actions{
    flex-direction: column;
  }

  .sml-terms-hero__actions .sml-btn{
    width: 100%;
  }

  .sml-terms-overview__card,
  .sml-terms-nav__inner,
  .sml-terms-block,
  .sml-terms-note{
    border-radius: 18px;
  }

  .sml-terms-nav nav{
    gap: 4px;
  }

  .sml-terms-nav a{
    padding: 9px 10px;
  }

  .sml-terms-block{
    padding: 14px;
  }

  .sml-terms-block__head{
    gap: 10px;
    margin-bottom: 10px;
  }

  .sml-terms-block__num{
    width: 36px;
    height: 36px;
    font-size: 11px;
  }
}

@media (prefers-reduced-motion: reduce){
  .sml-terms-nav a,
  .sml-terms-overview__card,
  .sml-terms-block,
  .sml-terms-summary__card{
    transition: none;
  }
}

/* ─────────────────────────────────────────────────────────────
   Legal pages tone refinement
   Privacy Policy + Terms of Service
   Align accent blocks with SML green system, remove cold/blue feel.
   ───────────────────────────────────────────────────────────── */

.sml-privacy-nav a:focus-visible,
.sml-terms-nav a:focus-visible{
  box-shadow: 0 0 0 3px rgba(67,130,57,0.18);
}

.sml-privacy-summary__card,
.sml-terms-summary__card{
  background:
    linear-gradient(180deg, rgba(255,255,255,0.94), rgba(248,249,246,0.98));
  border-color: rgba(67,130,57,0.12);
}

.sml-privacy-block--accent,
.sml-terms-block--accent{
  border-color: rgba(67,130,57,0.18);
  background:
    radial-gradient(120% 90% at 0% 0%, rgba(67,130,57,0.14), transparent 52%),
    linear-gradient(180deg, rgba(251,253,248,0.98), rgba(244,248,241,0.99));
}

.sml-privacy-note,
.sml-terms-note{
  border-color: rgba(67,130,57,0.22);
  background:
    radial-gradient(120% 100% at 0% 0%, rgba(67,130,57,0.12), transparent 55%),
    linear-gradient(180deg, rgba(247,250,243,0.98), rgba(240,246,237,0.98));
  color: rgba(var(--sml-ink-rgb), 0.84);
}

.sml-privacy-overview__card,
.sml-terms-overview__card,
.sml-privacy-nav__inner,
.sml-terms-nav__inner,
.sml-privacy-block,
.sml-terms-block{
  background:
    linear-gradient(180deg, rgba(255,255,255,0.96), rgba(249,250,247,0.98));
}


/* ─────────────────────────────────────────────────────────────
   Careers (/careers/)
   Integrated into pages.css, aligned to SML tokens and SMC density.
   ───────────────────────────────────────────────────────────── */

.sml-careers-hero .sml-page-hero__inner{
  max-width: 68ch;
}

.sml-careers-hero__grid,
.sml-careers-shell,
.sml-careers-shell--detail{
  display:grid;
  grid-template-columns:minmax(0,1fr) 340px;
  gap:18px;
  align-items:start;
}

.sml-careers-listing,
.sml-career-detail{
  padding-top: 8px;
  padding-bottom: clamp(44px, 6vw, 76px);
}

.sml-careers-main,
.sml-careers-aside,
.sml-career-detail__aside{
  display:grid;
  gap:14px;
}

.sml-careers-head,
.sml-careers-section-head{
  display:grid;
  gap:8px;
}

.sml-careers-head{
  max-width: 66ch;
  margin: 0 0 2px;
}

.sml-careers-head .sml-h3,
.sml-career-detail-subtitle{
  margin:0;
  letter-spacing:-0.02em;
}

.sml-careers-head .sml-sub,
.sml-careers-prose p,
.sml-career-detail-note p{
  margin:0;
  color: var(--sml-muted);
  line-height: 1.68;
}

.sml-careers-eyebrow{
  font-size: 11px;
  line-height: 1.2;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 800;
  color: rgba(var(--sml-ink-rgb), 0.56);
}

.sml-careers-sidecard,
.sml-careers-empty,
.sml-career-detail__main,
.sml-career-detail__aside .sml-about-panel{
  margin-top: 0;
}

.sml-career-side-list,
.sml-career-facts-grid{
  display:grid;
  gap:10px;
}

.sml-career-side-item{
  display:grid;
  gap:6px;
  padding:12px 14px;
  border:1px solid var(--sml-border);
  border-radius:16px;
  background: rgba(var(--sml-surface-rgb), 0.78);
}

.sml-career-side-item span{
  font-size:11px;
  line-height:1.2;
  letter-spacing:0.12em;
  text-transform:uppercase;
  font-weight:800;
  color: rgba(var(--sml-ink-rgb), 0.54);
}

.sml-career-side-item strong{
  font-size:15px;
  line-height:1.45;
  font-weight:860;
  letter-spacing:-0.01em;
  color: rgba(var(--sml-ink-rgb), 0.92);
}

.sml-careers-list{
  display:grid;
  gap:12px;
}

.sml-career-card{
  position:relative;
  background: linear-gradient(180deg, rgba(255,255,255,0.96), rgba(249,250,247,0.98));
  border:1px solid rgba(var(--sml-ink-rgb), 0.10);
  border-radius:20px;
  box-shadow: var(--sml-shadow-sm);
  overflow:hidden;
  transition: transform var(--sml-dur-2) var(--sml-ease-out), box-shadow var(--sml-dur-2) var(--sml-ease-out), border-color var(--sml-dur-2) var(--sml-ease-out);
}

@media (hover:hover) and (pointer:fine){
  .sml-career-card:hover{
    transform: translateY(-2px);
    box-shadow: var(--sml-shadow-md);
    border-color: rgba(67,130,57,0.18);
  }
}

.sml-career-card__body{
  position:relative;
  display:grid;
  gap:12px;
  padding:18px;
}

.sml-career-card__head{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:14px 18px;
  align-items:start;
}

.sml-career-card__topline{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  align-items:center;
  margin-bottom:8px;
}

.sml-career-chip,
.sml-career-pill{
  display:inline-flex;
  align-items:center;
  min-height:30px;
  padding:0 11px;
  border-radius:999px;
  font-size:12px;
  font-weight:800;
  line-height:1;
}

.sml-career-chip{
  border:1px solid rgba(67,130,57,0.22);
  background: rgba(67,130,57,0.09);
  color: rgba(var(--sml-ink-rgb), 0.90);
  text-transform:uppercase;
  letter-spacing:0.06em;
}

.sml-career-chip--soft,
.sml-career-pill{
  border:1px solid rgba(var(--sml-ink-rgb), 0.10);
  background: rgba(var(--sml-surface-rgb), 0.84);
  color: rgba(var(--sml-ink-rgb), 0.86);
}

.sml-career-card__title{
  margin:0;
  font-size: clamp(20px, 2vw, 24px);
  line-height:1.12;
  letter-spacing:-0.02em;
}

.sml-career-card__title a{
  color:inherit;
  text-decoration:none;
}

.sml-career-card__title a:hover{
  text-decoration:underline;
  text-underline-offset:4px;
}

.sml-career-card__company{
  margin-top:4px;
  font-size:13px;
  font-weight:780;
  color: rgba(var(--sml-ink-rgb), 0.66);
}

.sml-career-card__tags{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}

.sml-career-card__excerpt{
  margin:0;
  color: rgba(var(--sml-ink-rgb), 0.76);
  font-size:14px;
  line-height:1.62;
}

.sml-career-card__list,
.sml-careers-steps,
.sml-career-detail__list{
  margin:0;
  padding-left:18px;
  color: rgba(var(--sml-ink-rgb), 0.82);
}

.sml-career-card__list li + li,
.sml-careers-steps li + li,
.sml-career-detail__list li + li{
  margin-top:7px;
}

.sml-career-card__footer{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:space-between;
  gap:12px 18px;
  padding-top:2px;
}

.sml-career-card__contact,
.sml-career-card__footnote{
  font-size:13px;
  line-height:1.55;
  color: rgba(var(--sml-ink-rgb), 0.66);
}

.sml-career-card__actions,
.sml-career-form__actions,
.sml-career-aside-actions,
.sml-career-detail-cta{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
}

.sml-careers-steps{
  display:grid;
  gap:6px;
}

.sml-career-detail__main,
.sml-career-detail__aside{
  display:grid;
  gap:14px;
}

.sml-career-detail-block{
  margin-top: 2px;
  padding-top: 14px;
  border-top: 1px solid rgba(var(--sml-ink-rgb), 0.08);
}

.sml-career-detail-contact{
  display:grid;
  gap:0;
}

.sml-career-detail-contact__row{
  display:grid;
  grid-template-columns:100px 1fr;
  gap:12px;
  padding:10px 0;
  border-top:1px solid rgba(var(--sml-ink-rgb), 0.08);
}

.sml-career-detail-contact__row:first-child{
  border-top:0;
  padding-top:0;
}

.sml-career-detail-contact__row span{
  font-size:11px;
  line-height:1.2;
  letter-spacing:0.12em;
  text-transform:uppercase;
  font-weight:800;
  color: rgba(var(--sml-ink-rgb), 0.54);
}

.sml-career-detail-contact__row strong,
.sml-career-detail-contact__row a{
  color: rgba(var(--sml-ink-rgb), 0.90);
  font-weight:800;
  text-decoration:none;
}

.sml-career-detail-contact__row a:hover{
  text-decoration:underline;
  text-underline-offset:4px;
}

html.sml-career-lock,
body.sml-career-lock{
  overflow:hidden;
}

.sml-career-modal[hidden]{
  display:none !important;
}

.sml-career-modal{
  position:fixed;
  inset:0;
  z-index:9999;
}

.sml-career-modal__backdrop{
  position:absolute;
  inset:0;
  background:rgba(18,22,18,0.56);
  backdrop-filter:blur(3px);
}

.sml-career-modal__dialog{
  position:relative;
  width:min(820px, calc(100vw - 28px));
  max-height:calc(100dvh - 32px);
  margin:16px auto;
  overflow:auto;
  background:#fff;
  border:1px solid rgba(var(--sml-ink-rgb), 0.10);
  border-radius:24px;
  box-shadow:0 26px 80px rgba(18,22,18,0.18);
  padding:22px 22px 18px;
}

.sml-career-modal__dialog::before{
  content:"";
  position:absolute;
  inset:0;
  border-top:3px solid rgba(67,130,57,0.24);
  border-radius:inherit;
  pointer-events:none;
}

.sml-career-modal__close{
  position:absolute;
  top:12px;
  right:12px;
  width:40px;
  height:40px;
  border:1px solid rgba(var(--sml-ink-rgb), 0.10);
  border-radius:999px;
  background:#fff;
  color: rgba(var(--sml-ink-rgb), 0.76);
  font-size:26px;
  line-height:1;
  cursor:pointer;
}

.sml-career-modal__eyebrow{
  font-size:11px;
  line-height:1.2;
  letter-spacing:0.12em;
  text-transform:uppercase;
  font-weight:800;
  color: rgba(var(--sml-ink-rgb), 0.56);
}

.sml-career-modal__title{
  margin:8px 0 0;
}

.sml-career-modal__sub{
  margin:10px 0 0;
  color: var(--sml-muted);
}

.sml-career-form{
  margin-top:16px;
  display:grid;
  gap:12px;
}

.sml-career-form__grid{
  display:grid;
  gap:12px;
}

.sml-career-form__grid--2{
  grid-template-columns:repeat(2, minmax(0, 1fr));
}

.sml-career-upload__note{
  margin:8px 0 0;
  font-size:13px;
  color: rgba(var(--sml-ink-rgb), 0.62);
}

.sml-career-form__msg{
  min-height:20px;
  font-size:13px;
  font-weight:700;
}

.sml-career-form__msg.is-ok{color: rgba(40,120,62,1);}
.sml-career-form__msg.is-err{color: rgba(188,44,44,1);}

@media (max-width: 980px){
  .sml-careers-hero__grid,
  .sml-careers-shell,
  .sml-careers-shell--detail{
    grid-template-columns:1fr;
  }
}

@media (max-width: 760px){
  .sml-career-card__head,
  .sml-career-detail-contact__row,
  .sml-career-form__grid--2{
    grid-template-columns:1fr;
  }

  .sml-career-card__actions .sml-btn,
  .sml-career-form__actions .sml-btn,
  .sml-career-detail-cta .sml-btn,
  .sml-career-aside-actions .sml-btn{
    flex:1 1 100%;
  }

  .sml-career-modal__dialog{
    width:calc(100vw - 18px);
    max-height:calc(100dvh - 18px);
    margin:9px auto;
    padding:18px 16px 16px;
    border-radius:20px;
  }
}


/* Careers refinements v1.0.0 */
.sml-careers-hero{
  background:
    radial-gradient(115% 88% at 18% 12%, rgba(67,130,57,0.08), transparent 56%),
    radial-gradient(110% 84% at 82% 24%, rgba(67,130,57,0.05), transparent 58%),
    linear-gradient(180deg, rgba(247,243,234,0.92), rgba(247,243,234,0.76));
}

.sml-careers-hero .sml-h2{
  font-size: clamp(34px, 4.6vw, 54px);
  line-height: 1.02;
  letter-spacing: -0.03em;
}

.sml-careers-head .sml-h3,
.sml-career-detail-subtitle{
  font-size: clamp(26px, 2.3vw, 36px);
  line-height: 1.08;
}

.sml-careers-head .sml-sub,
.sml-careers-prose p,
.sml-career-detail-note p,
.sml-career-card__excerpt,
.sml-career-card__contact,
.sml-career-card__footnote,
.sml-career-detail-contact__row strong,
.sml-career-detail-contact__row a{
  text-wrap: pretty;
}

.sml-careers-shell,
.sml-careers-shell--detail{
  gap: 20px;
}

.sml-careers-head{
  margin: 0 0 6px;
}

.sml-career-card{
  border-radius: 18px;
}

.sml-career-card__body{
  gap: 14px;
  padding: 20px;
}

.sml-career-card__title{
  font-size: clamp(18px, 1.7vw, 22px);
  line-height: 1.14;
}

.sml-career-card__company,
.sml-career-card__contact,
.sml-career-card__footnote{
  font-size: 14px;
}

.sml-career-card__excerpt,
.sml-careers-prose p,
.sml-career-detail-note p,
.sml-career-card__list,
.sml-careers-steps,
.sml-career-detail__list{
  font-size: 15px;
  line-height: 1.68;
}

.sml-career-card__footer{
  padding-top: 6px;
}

.sml-career-card__actions{
  justify-content: flex-end;
}

.sml-careers-list{
  gap: 14px;
}

.sml-careers-pagination{
  margin-top: 4px;
}

.sml-careers-pagination ul{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  padding: 0;
  margin: 0;
  list-style: none;
}

.sml-careers-pagination li{
  margin: 0;
}

.sml-careers-pagination a,
.sml-careers-pagination span{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 42px;
  min-height: 42px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid rgba(var(--sml-ink-rgb), 0.10);
  background: rgba(255,255,255,0.86);
  color: rgba(var(--sml-ink-rgb), 0.88);
  text-decoration: none;
  font-size: 14px;
  font-weight: 800;
}

.sml-careers-pagination .current{
  border-color: rgba(67,130,57,0.24);
  background: rgba(67,130,57,0.10);
}

@supports not (text-wrap: pretty) {
  .sml-careers-head .sml-sub,
  .sml-careers-prose p,
  .sml-career-detail-note p,
  .sml-career-card__excerpt,
  .sml-career-card__contact,
  .sml-career-card__footnote,
  .sml-career-detail-contact__row strong,
  .sml-career-detail-contact__row a {
    overflow-wrap: anywhere;
  }
}

@media (max-width: 980px){
  .sml-careers-main,
  .sml-careers-aside,
  .sml-career-detail__aside{
    gap: 12px;
  }
}

@media (max-width: 760px){
  .sml-careers-listing,
  .sml-career-detail{
    padding-top: 4px;
    padding-bottom: 44px;
  }

  .sml-careers-hero .sml-h2{
    font-size: clamp(30px, 11vw, 42px);
  }

  .sml-careers-head .sml-h3,
  .sml-career-detail-subtitle{
    font-size: clamp(24px, 7vw, 30px);
  }

  .sml-career-card,
  .sml-careers-sidecard,
  .sml-careers-empty,
  .sml-career-detail__main,
  .sml-career-detail__aside .sml-about-panel{
    border-radius: 16px;
  }

  .sml-career-card__body{
    padding: 16px;
    gap: 12px;
  }

  .sml-career-card__head{
    gap: 12px;
  }

  .sml-career-card__topline,
  .sml-career-card__tags,
  .sml-career-card__actions,
  .sml-career-card__footer{
    gap: 8px;
  }

  .sml-career-chip,
  .sml-career-pill{
    min-height: 28px;
    font-size: 11px;
    padding: 0 10px;
  }

  .sml-career-card__title{
    font-size: 20px;
  }

  .sml-career-card__company,
  .sml-career-card__excerpt,
  .sml-career-card__contact,
  .sml-career-card__footnote,
  .sml-career-card__list,
  .sml-careers-steps,
  .sml-career-detail__list{
    font-size: 14px;
    line-height: 1.6;
  }

  .sml-career-card__footer{
    align-items: flex-start;
  }

  .sml-careers-pagination a,
  .sml-careers-pagination span{
    min-width: 40px;
    min-height: 40px;
    padding: 0 12px;
    font-size: 13px;
  }
}


/* Careers refinement patch, keep version 1.0.0 */
.sml-careers-hero{
  background:
    radial-gradient(115% 88% at 18% 12%, rgba(67,130,57,0.07), transparent 56%),
    radial-gradient(110% 84% at 82% 24%, rgba(67,130,57,0.04), transparent 58%),
    linear-gradient(180deg, rgba(247,243,234,0.94), rgba(245,240,229,0.82));
}

.sml-careers-hero .sml-h2{
  font-size: clamp(30px, 4vw, 44px);
  line-height: 1.04;
  letter-spacing: -0.028em;
}

.sml-careers-head .sml-h3,
.sml-career-detail-subtitle{
  font-size: clamp(22px, 2vw, 30px);
  line-height: 1.12;
}

.sml-careers-head .sml-sub,
.sml-careers-prose p,
.sml-career-detail-note p,
.sml-career-card__excerpt,
.sml-career-card__contact,
.sml-career-card__footnote,
.sml-career-card__list,
.sml-careers-steps,
.sml-career-detail__list{
  font-size: 14px;
  line-height: 1.64;
}

.sml-careers-head{
  margin: 0 0 4px;
}

.sml-careers-shell,
.sml-careers-shell--detail{
  gap: 18px;
}

.sml-careers-sidecard,
.sml-careers-empty,
.sml-career-detail__main,
.sml-career-detail__aside .sml-about-panel,
.sml-career-card{
  background:
    linear-gradient(180deg, rgba(255,255,255,0.97), rgba(248,245,238,0.98));
}

.sml-career-side-item,
.sml-career-facts-grid .sml-about-fact,
.sml-careers-pagination a,
.sml-careers-pagination span{
  background:
    linear-gradient(180deg, rgba(255,255,255,0.98), rgba(247,244,236,0.96));
}

.sml-career-card{
  border-radius: 18px;
  border-color: rgba(18,22,18,0.09);
}

.sml-career-card__body{
  gap: 12px;
  padding: 18px;
}

.sml-career-card__title{
  font-size: clamp(18px, 1.5vw, 21px);
  line-height: 1.16;
}

.sml-career-card__company{
  margin-top: 3px;
  font-size: 13px;
  line-height: 1.45;
}

.sml-career-chip,
.sml-career-pill{
  min-height: 28px;
  padding: 0 10px;
  font-size: 11px;
}

.sml-career-chip{
  border-color: rgba(67,130,57,0.18);
  background: rgba(67,130,57,0.08);
}

.sml-career-chip--soft,
.sml-career-pill{
  border-color: rgba(18,22,18,0.09);
  background: rgba(255,255,255,0.78);
}

.sml-career-card__footer{
  padding-top: 4px;
}

.sml-career-side-item strong,
.sml-career-detail-contact__row strong,
.sml-career-detail-contact__row a{
  font-size: 14px;
  line-height: 1.5;
}

.sml-careers-pagination .current{
  border-color: rgba(67,130,57,0.20);
  background: rgba(67,130,57,0.09);
}

@media (max-width: 760px){
  .sml-careers-hero .sml-h2{
    font-size: clamp(28px, 9vw, 38px);
  }

  .sml-careers-head .sml-h3,
  .sml-career-detail-subtitle{
    font-size: clamp(20px, 6vw, 26px);
  }

  .sml-career-card__body{
    padding: 15px;
    gap: 11px;
  }

  .sml-career-card__title{
    font-size: 19px;
  }

  .sml-career-card__company,
  .sml-career-card__excerpt,
  .sml-career-card__contact,
  .sml-career-card__footnote,
  .sml-career-card__list,
  .sml-careers-steps,
  .sml-career-detail__list,
  .sml-careers-head .sml-sub,
  .sml-careers-prose p,
  .sml-career-detail-note p{
    font-size: 13.5px;
    line-height: 1.58;
  }
}

/* Careers detail refinement, keep version 1.0.0 */
.sml-career-detail-hero .sml-page-hero__inner{
  max-width:none;
}

.sml-career-detail-hero__grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) 340px;
  gap:18px;
  align-items:start;
}

.sml-career-detail-hero__copy{
  max-width:68ch;
}

.sml-career-detail-hero__side{
  margin-top:0;
}

.sml-career-detail-hero__tags{
  margin-top:2px;
}

.sml-careers-shell--detail{
  grid-template-columns:minmax(0,1fr) 340px;
}

.sml-career-detail__main .sml-about-prose p + p{
  margin-top:12px;
}

.sml-career-detail__main .sml-about-prose ul,
.sml-career-detail__main .sml-about-prose ol{
  margin:10px 0 0;
  padding-left:18px;
}

.sml-career-detail__main .sml-about-prose li + li{
  margin-top:7px;
}

.sml-career-detail__main,
.sml-career-detail__aside .sml-about-panel{
  padding:18px;
}

.sml-career-detail__aside{
  gap:12px;
}

.sml-career-detail-subtitle{
  font-size:clamp(20px, 1.8vw, 26px);
  line-height:1.14;
}

.sml-career-detail-note p,
.sml-career-detail__list,
.sml-career-detail-contact__row strong,
.sml-career-detail-contact__row a,
.sml-careers-steps{
  font-size:14px;
  line-height:1.62;
}

.sml-career-detail-contact__row{
  grid-template-columns:92px 1fr;
}

@media (max-width: 980px){
  .sml-career-detail-hero__grid,
  .sml-careers-shell--detail{
    grid-template-columns:1fr;
  }
}

@media (max-width: 760px){
  .sml-career-detail-hero__grid{
    gap:14px;
  }

  .sml-career-detail__main,
  .sml-career-detail__aside .sml-about-panel{
    padding:15px;
  }

  .sml-career-detail-subtitle{
    font-size:clamp(19px, 5.8vw, 24px);
  }

  .sml-career-detail-note p,
  .sml-career-detail__list,
  .sml-career-detail-contact__row strong,
  .sml-career-detail-contact__row a,
  .sml-careers-steps{
    font-size:13px;
    line-height:1.58;
  }
}


/* Careers detail cleanup, keep version 1.0.0 */
.sml-career-detail-hero{
  padding: clamp(36px, 4.6vw, 60px) 0;
}

.sml-career-detail-hero .sml-page-hero__inner{
  max-width: 820px;
  gap: 12px;
}

.sml-career-detail-hero__tags{
  margin-top: 0;
}

.sml-careers-shell--detail{
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) 340px;
  gap: 18px;
  align-items: start;
}

.sml-career-detail__aside{
  display: grid;
  align-content: start;
  gap: 12px;
}

.sml-career-detail__main,
.sml-career-detail__aside .sml-about-panel{
  padding: 22px;
}

.sml-career-detail__main{
  min-width: 0;
}

.sml-career-detail-summary .sml-career-side-list{
  gap: 10px;
}

.sml-career-side-item{
  background: var(--sml-surface-2);
}

.sml-career-detail-subtitle{
  font-size: clamp(18px, 1.55vw, 24px);
  line-height: 1.16;
}

.sml-career-detail__main .sml-about-prose,
.sml-career-detail-note p,
.sml-career-detail__list,
.sml-career-detail-contact__row strong,
.sml-career-detail-contact__row a,
.sml-careers-steps{
  font-size: 14px;
  line-height: 1.68;
}

.sml-career-detail-contact__row{
  align-items: start;
}

.sml-career-detail__main .sml-about-prose p:last-child{
  margin-bottom: 0;
}

.sml-career-detail-block{
  margin-top: 18px;
  padding-top: 16px;
}

.sml-career-detail-note{
  margin-top: 18px;
}

@media (max-width: 980px){
  .sml-careers-shell--detail{
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px){
  .sml-career-detail-hero{
    padding: 30px 0;
  }

  .sml-career-detail__main,
  .sml-career-detail__aside .sml-about-panel{
    padding: 16px;
  }

  .sml-career-detail-subtitle{
    font-size: 19px;
  }
}


/* ==========================================================================
   Unified internal pages layer
   Goal: bring templates onto one visual system without changing logic.
   ========================================================================== */

.sml-page-hero{
  padding: clamp(34px, 4.2vw, 58px) 0 clamp(54px, 6vw, 88px);
  background:
    radial-gradient(120% 90% at 18% 10%, rgba(67,130,57,0.08), transparent 58%),
    linear-gradient(180deg, rgba(255,255,255,0.12), rgba(18,22,18,0.01));
}

.sml-page-hero__inner{
  max-width: 860px;
  display: grid;
  gap: 12px;
}

.sml-page-hero__eyebrow,
.sml-careers-eyebrow,
.sml-contact-eyebrow{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 0;
  font-size: 11px;
  line-height: 1.1;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: 760;
  color: rgba(var(--sml-ink-rgb), 0.56);
}

.sml-page-hero .sml-h1,
.sml-page-hero .sml-h2{
  font-size: clamp(30px, 4vw, 48px);
  line-height: 1.04;
  letter-spacing: -0.04em;
}

.sml-page-hero__sub,
.sml-sub,
.sml-about-sub{
  font-size: 15px;
  line-height: 1.68;
  color: rgba(var(--sml-ink-rgb), 0.68);
}

.sml-page,
.sml-contact,
.sml-about,
.sml-careers-listing,
.sml-career-detail{
  padding-top: 6px;
  padding-bottom: clamp(42px, 4.8vw, 74px);
}

.sml-page-surface{
  margin-top: -26px;
  background: rgba(var(--sml-surface-rgb), 0.88);
  border: 1px solid rgba(var(--sml-ink-rgb), 0.08);
  border-radius: 24px;
  box-shadow: 0 18px 56px rgba(18,22,18,0.08);
  padding: clamp(18px, 2.6vw, 28px);
}

.sml-about-panel,
.sml-contact-card,
.sml-about-card,
.sml-about-fact,
.sml-career-card,
.sml-careers-sidecard,
.sml-careers-empty,
.sml-career-detail__main,
.sml-career-detail__aside .sml-about-panel,
.sml-privacy-overview__card,
.sml-terms-overview__card,
.sml-privacy-summary__card,
.sml-terms-summary__card{
  border-radius: 22px;
  border: 1px solid rgba(var(--sml-ink-rgb), 0.08);
  box-shadow: 0 14px 40px rgba(18,22,18,0.06);
  background: rgba(var(--sml-surface-rgb), 0.90);
}

.sml-about-panel,
.sml-career-detail__main,
.sml-career-detail__aside .sml-about-panel{
  padding: 20px;
}

.sml-contact-card__inner,
.sml-about-card,
.sml-about-fact,
.sml-privacy-overview__card,
.sml-terms-overview__card,
.sml-privacy-summary__card,
.sml-terms-summary__card{
  padding: 18px;
}

.sml-about-h2,
.sml-contact-card__title,
.sml-careers-head .sml-h3,
.sml-career-detail-subtitle,
.sml-privacy-hero__title,
.sml-terms-hero__title{
  font-size: clamp(24px, 2vw, 34px);
  line-height: 1.12;
  letter-spacing: -0.03em;
}

.sml-about-card__title,
.sml-career-card__title,
.sml-project-card__title,
.sml-materials-home-card__title,
.sml-team-card__name,
.sml-material-panel__title,
.sml-service-panel__title,
.sml-project-gallery-title,
.sml-project-detail__title,
.sml-team-info__name{
  letter-spacing: -0.025em;
}

.sml-about-prose p,
.sml-page .sml-prose p,
.sml-contact-card p,
.sml-careers-prose p,
.sml-career-detail-note p,
.sml-career-card__excerpt,
.sml-career-card__contact,
.sml-career-card__footnote,
.sml-career-card__list,
.sml-career-detail__list,
.sml-career-detail-contact__row strong,
.sml-career-detail-contact__row a,
.sml-team-row__value,
.sml-team-row__muted{
  font-size: 15px;
  line-height: 1.68;
  color: rgba(var(--sml-ink-rgb), 0.76);
}

.sml-careers-shell,
.sml-careers-shell--detail,
.sml-about-grid,
.sml-contact-grid{
  align-items: start;
}

.sml-careers-shell{
  gap: 12px;
  grid-template-columns: minmax(0, 1.2fr) minmax(300px, 0.8fr);
}

.sml-careers-shell--detail{
  gap: 12px;
  grid-template-columns: minmax(0, 1.16fr) minmax(300px, 0.84fr);
}

.sml-careers-head,
.sml-careers-section-head{
  gap: 8px;
}

.sml-careers-list{
  gap: 12px;
}

.sml-career-card{
  overflow: hidden;
}

.sml-career-card__body{
  padding: 18px;
  gap: 12px;
}

.sml-career-card__head{
  gap: 12px;
  align-items: start;
}

.sml-career-card__title{
  font-size: clamp(24px, 2.1vw, 32px);
  line-height: 1.08;
}

.sml-career-card__company{
  font-size: 14px;
  line-height: 1.55;
  color: rgba(var(--sml-ink-rgb), 0.66);
}

.sml-career-card__topline,
.sml-career-card__tags,
.sml-career-card__actions,
.sml-career-card__footer,
.sml-about-hero__actions,
.sml-page-actions,
.sml-team-contacts,
.sml-contact-actions{
  gap: 10px;
}

.sml-career-chip,
.sml-career-pill,
.sml-chip{
  min-height: 34px;
  padding: 8px 12px;
  border-radius: 999px;
  font-size: 13px;
  line-height: 1.1;
  font-weight: 720;
}

.sml-career-chip,
.sml-chip{
  border-color: rgba(67,130,57,0.20);
  background: rgba(67,130,57,0.08);
}

.sml-career-chip--soft,
.sml-career-pill{
  border-color: rgba(var(--sml-ink-rgb), 0.10);
  background: rgba(var(--sml-surface-rgb), 0.92);
}

.sml-career-card__actions .sml-btn,
.sml-career-aside-actions .sml-btn,
.sml-career-detail-cta .sml-btn,
.sml-contact-actions .sml-btn,
.sml-about-hero__actions .sml-btn{
  min-height: 46px;
}

.sml-career-side-list,
.sml-career-detail-contact{
  gap: 10px;
}

.sml-career-side-item,
.sml-career-detail-contact__row{
  border-color: rgba(var(--sml-ink-rgb), 0.08);
  background: rgba(var(--sml-surface-rgb), 0.78);
}

.sml-career-side-item span,
.sml-career-detail-contact__row span{
  font-size: 11px;
  letter-spacing: 0.12em;
}

.sml-career-side-item strong,
.sml-career-detail-contact__row strong,
.sml-career-detail-contact__row a{
  font-size: 14px;
  line-height: 1.55;
  color: rgba(var(--sml-ink-rgb), 0.90);
}

.sml-career-detail-hero{
  padding-bottom: clamp(42px, 5vw, 70px);
}

.sml-career-detail-hero .sml-page-hero__inner{
  max-width: 820px;
}

.sml-career-detail-hero__copy{
  max-width: 72ch;
}

.sml-career-detail-hero__tags{
  margin-top: 2px;
}

.sml-career-detail__main .sml-about-prose{
  max-width: none;
}

.sml-career-detail__main .sml-about-prose p + p{
  margin-top: 12px;
}

.sml-career-detail-block{
  margin-top: 18px;
  padding-top: 16px;
  border-top: 1px solid rgba(var(--sml-ink-rgb), 0.08);
}

.sml-career-detail__list,
.sml-careers-steps{
  padding-left: 20px;
}

.sml-careers-pagination{
  margin-top: 16px;
}

.sml-careers-pagination a,
.sml-careers-pagination span{
  min-width: 42px;
  min-height: 42px;
  font-size: 14px;
}

/* Make detail templates feel like the same family */
.sml-service-detail,
.sml-material-detail,
.sml-project-detail,
.sml-team-detail{
  padding-top: clamp(32px, 4.2vw, 56px);
  padding-bottom: clamp(38px, 4.4vw, 60px);
}

.sml-service-layout,
.sml-material-layout{
  gap: 18px;
}

.sml-service-panel,
.sml-material-panel,
.sml-team-info,
.sml-project-content{
  border-radius: 22px;
  border: 1px solid rgba(var(--sml-ink-rgb), 0.08);
  box-shadow: 0 14px 40px rgba(18,22,18,0.06);
}

.sml-service-panel,
.sml-material-panel,
.sml-project-content{
  padding: 20px;
}

.sml-service-hero__title,
.sml-material-hero__title,
.sml-project-detail__title,
.sml-team-info__name{
  font-size: clamp(30px, 4vw, 48px);
  line-height: 1.04;
}

.sml-service-hero__sub,
.sml-material-hero__sub,
.sml-lead,
.sml-project-detail__meta,
.sml-team-info-row__value,
.sml-team-bio .sml-prose p{
  font-size: 15px;
  line-height: 1.68;
}

.sml-project-grid,
.sml-team-grid,
.sml-about-cards{
  gap: 14px;
}

.sml-project-card,
.sml-team-card,
.sml-materials-home-card{
  border-radius: 22px;
  box-shadow: 0 14px 40px rgba(18,22,18,0.07);
}

.sml-project-card__body,
.sml-team-card__body,
.sml-materials-home-card__body{
  padding: 14px;
}

@media (max-width: 1023px){
  .sml-careers-shell,
  .sml-careers-shell--detail,
  .sml-about-grid,
  .sml-contact-grid,
  .sml-service-layout,
  .sml-material-layout{
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px){
  .sml-page-hero{
    padding: 28px 0 56px;
  }

  .sml-page-hero .sml-h1,
  .sml-page-hero .sml-h2,
  .sml-service-hero__title,
  .sml-material-hero__title,
  .sml-project-detail__title,
  .sml-team-info__name{
    font-size: clamp(26px, 9vw, 36px);
  }

  .sml-about-h2,
  .sml-contact-card__title,
  .sml-careers-head .sml-h3,
  .sml-career-detail-subtitle,
  .sml-privacy-hero__title,
  .sml-terms-hero__title{
    font-size: clamp(21px, 6vw, 28px);
  }

  .sml-page-surface,
  .sml-about-panel,
  .sml-career-detail__main,
  .sml-career-detail__aside .sml-about-panel,
  .sml-service-panel,
  .sml-material-panel,
  .sml-project-content,
  .sml-contact-card__inner{
    padding: 16px;
  }

  .sml-page-hero__sub,
  .sml-sub,
  .sml-about-sub,
  .sml-about-prose p,
  .sml-page .sml-prose p,
  .sml-contact-card p,
  .sml-careers-prose p,
  .sml-career-detail-note p,
  .sml-career-card__excerpt,
  .sml-career-card__contact,
  .sml-career-card__footnote,
  .sml-career-card__list,
  .sml-career-detail__list,
  .sml-career-detail-contact__row strong,
  .sml-career-detail-contact__row a,
  .sml-team-row__value,
  .sml-team-row__muted,
  .sml-service-hero__sub,
  .sml-material-hero__sub,
  .sml-lead,
  .sml-project-detail__meta,
  .sml-team-info-row__value,
  .sml-team-bio .sml-prose p{
    font-size: 14px;
    line-height: 1.6;
  }

  .sml-career-card__body,
  .sml-project-card__body,
  .sml-team-card__body,
  .sml-materials-home-card__body{
    padding: 14px;
  }

  .sml-career-card__head,
  .sml-career-card__footer,
  .sml-career-card__actions,
  .sml-about-hero__actions,
  .sml-contact-actions{
    flex-direction: column;
    align-items: stretch;
  }

  .sml-career-card__title{
    font-size: 21px;
  }

  .sml-career-card__actions .sml-btn,
  .sml-career-aside-actions .sml-btn,
  .sml-career-detail-cta .sml-btn,
  .sml-contact-actions .sml-btn,
  .sml-about-hero__actions .sml-btn{
    width: 100%;
  }
}


/* ==========================================================================
   Final unified pass: global front-end normalization
   ========================================================================== */

.sml-page-hero{
  padding: clamp(34px, 4vw, 56px) 0 clamp(54px, 6vw, 82px);
  border-bottom: 1px solid rgba(var(--sml-ink-rgb), 0.07);
}

.sml-page-hero__inner{
  max-width: 840px;
  gap: 12px;
}

.sml-page-hero__eyebrow,
.sml-careers-eyebrow,
.sml-contact-eyebrow,
.sml-privacy-nav__title,
.sml-terms-nav__title{
  font-family: var(--sml-font-ui);
  font-size: 11px;
  line-height: 1.1;
  font-weight: var(--sml-w-semibold);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(var(--sml-ink-rgb), 0.56);
}

.sml-page-hero .sml-h1,
.sml-page-hero .sml-h2,
.sml-service-hero__title,
.sml-material-hero__title,
.sml-project-detail__title,
.sml-team-info__name,
.sml-privacy-hero__title,
.sml-terms-hero__title{
  font-size: clamp(30px, 3.6vw, 46px);
  line-height: 1.04;
  letter-spacing: -0.045em;
}

.sml-page-hero__sub,
.sml-sub,
.sml-about-sub,
.sml-lead,
.sml-page .sml-prose p,
.sml-about-prose p,
.sml-contact-card p,
.sml-project-detail__meta,
.sml-service-hero__sub,
.sml-material-hero__sub,
.sml-team-row__value,
.sml-team-row__muted,
.sml-team-info-row__value,
.sml-team-bio .sml-prose p,
.sml-careers-prose p,
.sml-career-detail-note p,
.sml-career-card__excerpt,
.sml-career-card__contact,
.sml-career-card__footnote,
.sml-career-card__list,
.sml-career-detail__list,
.sml-career-detail-contact__row strong,
.sml-career-detail-contact__row a{
  font-size: 15px;
  line-height: 1.64;
}

.sml-page,
.sml-contact,
.sml-about,
.sml-careers-listing,
.sml-career-detail,
.sml-service-detail,
.sml-material-detail,
.sml-project-detail,
.sml-team-detail{
  padding-top: clamp(20px, 2.4vw, 30px);
  padding-bottom: clamp(40px, 4.4vw, 72px);
}

.sml-page-surface{
  margin-top: 0;
  border-radius: 24px;
  border: 1px solid rgba(var(--sml-ink-rgb), 0.08);
  background: linear-gradient(180deg, rgba(255,255,255,0.78), rgba(247,243,234,0.88));
  box-shadow: 0 18px 56px rgba(18,22,18,0.08);
  padding: clamp(18px, 2.4vw, 26px);
}

.sml-about-panel,
.sml-about-card,
.sml-about-fact,
.sml-contact-card,
.sml-contact-card__inner,
.sml-service-panel,
.sml-material-panel,
.sml-project-content,
.sml-team-info,
.sml-career-card,
.sml-careers-sidecard,
.sml-careers-empty,
.sml-career-detail__main,
.sml-career-detail__aside .sml-about-panel,
.sml-privacy-summary__card,
.sml-terms-summary__card,
.sml-privacy-overview__card,
.sml-terms-overview__card,
.sml-privacy-block,
.sml-terms-block{
  border-radius: 20px;
  border-color: rgba(var(--sml-ink-rgb), 0.08);
  box-shadow: 0 14px 40px rgba(18,22,18,0.06);
}

.sml-about-card,
.sml-about-fact,
.sml-career-card,
.sml-project-card,
.sml-team-card{
  overflow: hidden;
}

.sml-project-card,
.sml-team-card,
.sml-about-card,
.sml-about-fact,
.sml-career-card,
.sml-service-panel,
.sml-material-panel,
.sml-contact-card{
  background: linear-gradient(180deg, rgba(255,255,255,0.97), rgba(247,244,236,0.95));
}

.sml-project-card__body,
.sml-team-card__body,
.sml-career-card__body,
.sml-materials-home-card__body{
  padding: 16px;
}

.sml-project-card__title,
.sml-team-card__name,
.sml-career-card__title,
.sml-materials-home-card__title{
  font-size: clamp(17px, 1.4vw, 20px);
  line-height: 1.16;
  letter-spacing: -0.02em;
}

.sml-project-card__text,
.sml-team-card__role,
.sml-about-card__text,
.sml-career-card__company{
  line-height: 1.56;
}

.sml-about-grid,
.sml-contact-grid,
.sml-service-layout,
.sml-material-layout,
.sml-career-detail-grid{
  gap: 18px;
}

.sml-about-values,
.sml-about-cta,
.sml-about-hiring,
.sml-project-gallery-wrap{
  margin-top: 20px;
}

.sml-about-cta__inner,
.sml-about-hiring__inner,
.sml-service-panel,
.sml-material-panel,
.sml-project-content,
.sml-team-info,
.sml-career-detail__main,
.sml-career-detail__aside .sml-about-panel{
  padding: clamp(16px, 2.2vw, 22px);
}

.sml-contact-card__title,
.sml-about-h2,
.sml-service-panel__title,
.sml-material-panel__title,
.sml-project-gallery-title,
.sml-career-detail-subtitle,
.sml-privacy-overview__title,
.sml-terms-overview__title{
  line-height: 1.14;
  letter-spacing: -0.025em;
}

.sml-backlink,
.sml-project-detail__back{
  font-size: 11px;
  letter-spacing: 0.14em;
}

.sml-pagination,
.sml-careers-pagination{
  margin-top: 18px;
}

.sml-careers-pagination ul,
.sml-pagination .nav-links{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  padding: 0;
  margin: 0;
  list-style: none;
}

.sml-careers-pagination li{
  margin: 0;
}

.sml-pagination a,
.sml-pagination span,
.sml-careers-pagination a,
.sml-careers-pagination span{
  min-width: 42px;
  min-height: 42px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid rgba(var(--sml-ink-rgb), 0.10);
  background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(247,244,236,0.96));
  color: rgba(var(--sml-ink-rgb), 0.88);
  font-family: var(--sml-font-ui);
  font-size: 14px;
  font-weight: var(--sml-w-semibold);
  text-decoration: none;
  box-shadow: none;
}

.sml-pagination a:hover,
.sml-careers-pagination a:hover{
  transform: translateY(-1px);
  border-color: rgba(67,130,57,0.22);
  box-shadow: 0 12px 26px rgba(18,22,18,0.06);
}

.sml-pagination .current,
.sml-careers-pagination .current{
  background: rgba(67,130,57,0.10);
  border-color: rgba(67,130,57,0.22);
  color: var(--sml-ink);
}

.sml-contact-form .sml-field + .sml-field,
.sml-service-panel__row + .sml-service-panel__row,
.sml-material-panel__row + .sml-material-panel__row,
.sml-team-info-row + .sml-team-info-row{
  margin-top: 12px;
}

.sml-contact-actions,
.sml-about-hero__actions,
.sml-about-cta__actions,
.sml-about-hiring__actions,
.sml-hero__actions,
.sml-service-hero__actions,
.sml-material-hero__actions,
.sml-detail__cta,
.sml-team-info__actions,
.sml-career-card__actions{
  gap: 10px;
}

@media (max-width: 980px){
  .sml-about-grid,
  .sml-contact-grid,
  .sml-service-layout,
  .sml-material-layout,
  .sml-career-detail-grid{
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767px){
  .sml-page-hero{
    padding-top: 28px;
    padding-bottom: 56px;
  }

  .sml-page-hero .sml-h1,
  .sml-page-hero .sml-h2,
  .sml-service-hero__title,
  .sml-material-hero__title,
  .sml-project-detail__title,
  .sml-team-info__name,
  .sml-privacy-hero__title,
  .sml-terms-hero__title{
    font-size: clamp(28px, 8.5vw, 36px);
  }

  .sml-page-surface,
  .sml-contact-card__inner,
  .sml-about-panel,
  .sml-service-panel,
  .sml-material-panel,
  .sml-project-content,
  .sml-team-info,
  .sml-career-detail__main,
  .sml-career-detail__aside .sml-about-panel{
    padding: 16px;
  }

  .sml-page-hero__sub,
  .sml-sub,
  .sml-about-sub,
  .sml-lead,
  .sml-page .sml-prose p,
  .sml-about-prose p,
  .sml-contact-card p,
  .sml-project-detail__meta,
  .sml-service-hero__sub,
  .sml-material-hero__sub,
  .sml-team-row__value,
  .sml-team-row__muted,
  .sml-team-info-row__value,
  .sml-team-bio .sml-prose p,
  .sml-careers-prose p,
  .sml-career-detail-note p,
  .sml-career-card__excerpt,
  .sml-career-card__contact,
  .sml-career-card__footnote,
  .sml-career-card__list,
  .sml-career-detail__list,
  .sml-career-detail-contact__row strong,
  .sml-career-detail-contact__row a{
    font-size: 14px;
    line-height: 1.6;
  }

  .sml-project-grid{
    gap: 14px;
  }

  .sml-pagination a,
  .sml-pagination span,
  .sml-careers-pagination a,
  .sml-careers-pagination span{
    min-width: 40px;
    min-height: 40px;
    padding: 0 12px;
  }

  .sml-contact-actions,
  .sml-about-hero__actions,
  .sml-about-cta__actions,
  .sml-about-hiring__actions,
  .sml-hero__actions,
  .sml-service-hero__actions,
  .sml-material-hero__actions,
  .sml-detail__cta,
  .sml-team-info__actions,
  .sml-career-card__actions{
    flex-direction: column;
    align-items: stretch;
  }

  .sml-contact-actions .sml-btn,
  .sml-about-hero__actions .sml-btn,
  .sml-about-cta__actions .sml-btn,
  .sml-about-hiring__actions .sml-btn,
  .sml-service-hero__actions .sml-btn,
  .sml-material-hero__actions .sml-btn,
  .sml-detail__cta .sml-btn,
  .sml-team-info__actions .sml-btn,
  .sml-career-card__actions .sml-btn{
    width: 100%;
  }
}


/* System-wide text density tuning */
.sml-page-hero__eyebrow,
.sml-careers-eyebrow,
.sml-contact-pill,
.sml-material-chip,
.sml-project-pill,
.sml-privacy-nav__title,
.sml-terms-nav__title{
  font-family: var(--sml-font-ui);
  font-size: 11px;
  letter-spacing: 0.12em;
}

.sml-page-hero__sub,
.sml-contact-card__text,
.sml-material-prose p,
.sml-about-prose p,
.sml-career-detail-copy,
.sml-career-card__excerpt,
.sml-privacy-hero__sub,
.sml-terms-hero__sub{
  font-size: 15px;
  line-height: 1.62;
}

.sml-page-surface,
.sml-about-panel,
.sml-contact-card,
.sml-material-panel,
.sml-career-card,
.sml-career-detail-card,
.sml-career-detail-aside > *,
.sml-privacy-shell,
.sml-terms-shell{
  border-radius: var(--sml-radius-lg);
}

@media (max-width: 767px){
  .sml-page{ padding: 18px 0 24px; }
  .sml-page-hero{ padding: 28px 0 34px; }
  .sml-page-hero__inner{ gap: 10px; }
  .sml-page-hero__sub,
  .sml-contact-card__text,
  .sml-material-prose p,
  .sml-about-prose p,
  .sml-career-card__excerpt,
  .sml-privacy-hero__sub,
  .sml-terms-hero__sub{ font-size: 14px; line-height: 1.58; }
  .sml-page-surface,
  .sml-about-panel,
  .sml-contact-card,
  .sml-material-panel,
  .sml-career-card,
  .sml-career-detail-card,
  .sml-career-detail-aside > *{ padding: 14px; }
}
/* Reviews footer spacing */
.sml-gr__footer{
  margin-top: 18px;
  padding-bottom: 6px;
}

/* --------------------------------------------------------------------------
   Team contacts typography fix
   Ensures phone and email use premium body font instead of heading/UI styling.
   -------------------------------------------------------------------------- */
.sml-team-row__value,
.sml-team-row__value a,
.sml-team-row__muted,
.sml-team-info-row__value,
.sml-team-info-row__value a{
  font-family: var(--sml-font-body);
  font-weight: var(--sml-w-regular);
  letter-spacing: -0.01em;
  font-style: normal;
}

.sml-team-row__value,
.sml-team-row__value a,
.sml-team-info-row__value,
.sml-team-info-row__value a{
  color: rgba(var(--sml-ink-rgb), 0.90);
}

.sml-team-row__muted{
  color: rgba(var(--sml-ink-rgb), 0.60);
}

.sml-team-row__value a,
.sml-team-info-row__value a{
  text-decoration: none;
}

/* --------------------------------------------------------------------------
   Partners assets targeted preview fix
   -------------------------------------------------------------------------- */
.sml-partners-page .sml-partners-files{
  margin-top: 20px;
  display: grid;
  gap: 18px;
}

.sml-partners-page .sml-partners-group{
  display: grid;
  gap: 12px;
}

.sml-partners-page .sml-partners-group__head{
  max-width: 72ch;
}

.sml-partners-page .sml-partners-assets{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.sml-partners-page .sml-partners-asset{
  display: grid;
  overflow: hidden;
  border-radius: 22px;
  border: 1px solid rgba(var(--sml-ink-rgb), 0.08);
  background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(247,244,236,0.96));
  box-shadow: 0 14px 40px rgba(18,22,18,0.06);
}

.sml-partners-page .sml-partners-asset__preview{
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 112px;
  padding: 14px 16px;
  border-bottom: 1px solid rgba(var(--sml-ink-rgb), 0.07);
  overflow: hidden;
}

.sml-partners-page .sml-partners-asset__preview--light{
  background: linear-gradient(180deg, rgba(250,250,246,0.98), rgba(243,240,232,0.96));
}

.sml-partners-page .sml-partners-asset__preview--dark{
  background:
    radial-gradient(120% 90% at 18% 12%, rgba(67,130,57,0.18), transparent 58%),
    linear-gradient(180deg, #162018, #101612);
}

.sml-partners-page .sml-partners-asset__badge{
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  min-height: 22px;
  padding: 0 8px;
  border-radius: 999px;
  border: 1px solid rgba(var(--sml-ink-rgb), 0.10);
  background: rgba(255,255,255,0.84);
  color: rgba(var(--sml-ink-rgb), 0.76);
  font-family: var(--sml-font-ui);
  font-size: 9px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: var(--sml-w-semibold);
  line-height: 1;
}

.sml-partners-page .sml-partners-asset__preview--dark .sml-partners-asset__badge{
  background: rgba(255,255,255,0.12);
  border-color: rgba(255,255,255,0.18);
  color: rgba(255,255,255,0.88);
}

.sml-partners-page .sml-brandasset-box{
  width: 100%;
  min-width: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.sml-partners-page .sml-brandasset-img{
  display: block;
  width: auto;
  height: auto;
  max-width: none;
  object-fit: contain;
  object-position: center;
  margin: 0 auto;
}

.sml-partners-page .sml-brandasset-img--mark{
  max-width: 132px !important;
  max-height: 132px !important;
}

.sml-partners-page .sml-brandasset-img--lockup{
  max-width: 264px !important;
  max-height: 218px !important;
}

.sml-partners-page .sml-partners-asset__body{
  display: grid;
  gap: 6px;
  padding: 14px 14px 16px;
}

.sml-partners-page .sml-partners-asset__title{
  margin: 0;
  font-family: var(--sml-font-ui);
  font-size: 18px;
  line-height: 1.14;
  letter-spacing: -0.02em;
}

.sml-partners-page .sml-partners-asset__meta{
  margin: 0;
  color: rgba(var(--sml-ink-rgb), 0.66);
  font-size: 14px;
  line-height: 1.55;
}

.sml-partners-page .sml-partners-asset__actions{
  margin-top: 6px;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.sml-partners-page .sml-partners-asset__actions .sml-btn{
  width: auto;
}

@media (max-width: 920px){
  .sml-partners-page .sml-partners-assets{
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767px){
  .sml-partners-page .sml-partners-files{
    margin-top: 18px;
    gap: 16px;
  }

  .sml-partners-page .sml-partners-asset__preview{
    min-height: 96px;
    padding: 12px 14px;
  }

  .sml-partners-page .sml-brandasset-img--mark{
    max-width: 84px !important;
    max-height: 84px !important;
  }

  .sml-partners-page .sml-brandasset-img--lockup{
    max-width: 168px !important;
    max-height: 48px !important;
  }

  .sml-partners-page .sml-partners-asset__badge{
    top: 8px;
    left: 8px;
    min-height: 20px;
    padding: 0 7px;
    font-size: 8px;
  }

  .sml-partners-page .sml-partners-asset__body{
    padding: 12px 12px 14px;
  }

  .sml-partners-page .sml-partners-asset__title{
    font-size: 16px;
  }

  .sml-partners-page .sml-partners-asset__meta{
    font-size: 13px;
  }
}

/* Team page hierarchy update */
.sml-team-section + .sml-team-section{
  margin-top: 28px;
  padding-top: 22px;
  border-top: 1px solid rgba(var(--sml-ink-rgb), 0.08);
}

.sml-team-section__head{
  margin: 0 auto 14px;
  max-width: var(--sml-team-grid-max);
}

.sml-team-grid--leadership,
.sml-team-grid--staff{
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: stretch;
  gap: 16px;
  width: 100%;
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
}

.sml-team-grid--leadership .sml-team-card,
.sml-team-grid--staff .sml-team-card{
  width: 100%;
  margin: 0;
}

.sml-team-grid--leadership .sml-team-card{
  flex: 0 1 320px;
  max-width: 360px;
}

.sml-team-grid--staff .sml-team-card{
  flex: 0 1 248px;
  max-width: 280px;
}

.sml-team-grid--supervisors .sml-team-card{
  flex: 0 1 248px;
  max-width: 270px;
}

.sml-team-card--lead .sml-team-card__media{
  aspect-ratio: 1 / 1;
}

.sml-team-card--lead .sml-team-card__body{
  padding: 16px;
  gap: 10px;
}

.sml-team-card--compact .sml-team-card__media{
  aspect-ratio: 1 / 0.92;
}

.sml-team-card--compact .sml-team-card__body{
  padding: 13px;
  gap: 8px;
}

.sml-team-card--compact .sml-team-card__name{
  font-size: 17px;
}

.sml-team-card--compact .sml-team-card__role{
  font-size: 10px;
}

.sml-team-card--compact .sml-team-row{
  padding: 8px 10px;
}

.sml-team-card--compact .sml-team-row__value{
  font-size: 12px;
}

.sml-team-card--compact .sml-team-card__btn{
  height: 38px;
  padding: 0 13px;
  font-size: 12px;
}

@media (max-width: 1199px){
  .sml-team-grid--leadership .sml-team-card{
    flex-basis: 300px;
    max-width: 340px;
  }

  .sml-team-grid--staff .sml-team-card{
    flex-basis: 232px;
    max-width: 260px;
  }

  .sml-team-grid--supervisors .sml-team-card{
    flex-basis: 220px;
    max-width: 240px;
  }
}

@media (max-width: 1023px){
  .sml-team-grid--leadership,
  .sml-team-grid--staff{
    gap: 14px;
  }

  .sml-team-grid--leadership .sml-team-card,
  .sml-team-grid--staff .sml-team-card{
    flex: 1 1 calc(50% - 14px);
    max-width: calc(50% - 7px);
  }
}

@media (max-width: 640px){
  .sml-team-section + .sml-team-section{
    margin-top: 22px;
    padding-top: 18px;
  }

  .sml-team-grid--leadership,
  .sml-team-grid--staff{
    gap: 12px;
  }

  .sml-team-grid--leadership .sml-team-card,
  .sml-team-grid--staff .sml-team-card{
    flex: 1 1 100%;
    max-width: 100%;
  }
}

