/* File: assets/css/pages/about.css */
/* About page — light, square 4px, alternating sections, BMW-style. */

.page-id-59 .site-main,
body.page-template-page-about .site-main{background:var(--dag-sec-white)}

/* ═══════════ HERO ═══════════ */
.about-hero{
  background:var(--dag-secondary);
  color:var(--dag-sec-dark-fg);
  padding:clamp(48px, 6vw, 96px) 0;
  position:relative;
  overflow:hidden;
  border-bottom:4px solid var(--dag-primary);
}

.about-hero > *{
  max-width:var(--dag-container);
  margin-inline:auto;
  padding-inline:var(--dag-gutter);
  position:relative;
  z-index:2;
}

.about-hero__grid{
  display:grid;
  grid-template-columns:minmax(0, 1.1fr) minmax(0, .9fr);
  gap:clamp(24px, 4vw, 56px);
  align-items:center;
}
@media (max-width: 900px){
  .about-hero__grid{grid-template-columns:1fr}
}

.about-hero__content{display:flex;flex-direction:column;gap:18px}

.about-kicker,
.about-hero__kicker{
  font-size:12px;
  font-weight:700;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--dag-accent);
  padding-left:26px;
  position:relative;
  margin:0;
}
.about-kicker::before,
.about-hero__kicker::before{
  content:"";
  position:absolute;
  left:0; top:50%;
  transform:translateY(-50%);
  width:18px;
  height:2px;
  background:var(--dag-accent);
}

.about-hero__title{
  font-family:var(--dag-font-display);
  font-weight:400;
  font-size:clamp(36px, 2.4rem + 2.4vw, 64px);
  line-height:.95;
  letter-spacing:.02em;
  text-transform:uppercase;
  color:var(--dag-sec-dark-fg);
  margin:0;
}

.about-hero__lead{
  font-size:clamp(15px, .95rem + .3vw, 18px);
  color:rgba(255,255,255,.85);
  max-width:54ch;
  margin:0;
  line-height:1.6;
}

.about-hero__actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:8px;
}

.about-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-height:46px;
  padding:12px 22px;
  border-radius:var(--dag-radius-sm);
  border:1px solid var(--dag-accent);
  background:var(--dag-accent);
  color:var(--dag-secondary);
  font-weight:700;
  letter-spacing:.04em;
  text-transform:uppercase;
  font-size:13px;
  text-decoration:none;
  transition:background var(--anim-fast) ease, border-color var(--anim-fast) ease, color var(--anim-fast) ease;
}
.about-btn:hover{background:#fff; border-color:#fff; color:var(--dag-secondary)}

.about-btn--primary{
  background:var(--dag-primary);
  border-color:var(--dag-primary);
  color:var(--dag-primary-contrast);
}
.about-btn--primary:hover{
  background:var(--dag-primary-hover);
  border-color:var(--dag-primary-hover);
  color:var(--dag-primary-contrast);
}

.about-btn--ghost{
  background:transparent;
  border-color:rgba(255,255,255,.4);
  color:var(--dag-sec-dark-fg);
}
.about-btn--ghost:hover{
  background:rgba(255,255,255,.1);
  border-color:rgba(255,255,255,.6);
  color:var(--dag-sec-dark-fg);
}

.about-hero__highlights{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:8px;
}

.about-chip{
  display:inline-flex;
  align-items:center;
  padding:6px 12px;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.18);
  color:var(--dag-sec-dark-fg);
  font-size:12px;
  font-weight:600;
  letter-spacing:.06em;
  text-transform:uppercase;
}

.about-hero__meta{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(180px, 1fr));
  gap:8px;
  margin-top:14px;
  padding-top:18px;
  border-top:1px solid rgba(255,255,255,.15);
}

.about-pill{
  display:flex;
  flex-direction:column;
  gap:4px;
  padding:12px 14px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  border-left:3px solid var(--dag-accent);
}
.about-pill__label{
  font-size:10px;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--dag-accent);
}
.about-pill__value,
.about-pill__valueLink{
  color:var(--dag-sec-dark-fg);
  font-weight:600;
  text-decoration:none;
  font-size:14px;
  line-height:1.4;
}
.about-pill__valueLink:hover{color:var(--dag-accent); text-decoration:underline}
.about-pill__small,
.about-pill__sep{
  color:rgba(255,255,255,.65);
  font-size:12px;
  font-weight:500;
}

/* Hero media frame */
.about-hero__media{
  position:relative;
  aspect-ratio:4/3;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.15);
  background:rgba(255,255,255,.04);
}
.about-hero__frame{position:absolute; inset:0}
.about-hero__img,
.about-hero__media img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.about-hero__shade{
  position:absolute;
  inset:0;
  background:linear-gradient(135deg, transparent 50%, rgba(6,27,58,.45));
  pointer-events:none;
}

/* ═══════════ SECTIONS (3-card "what to expect") — soft bg ═══════════ */
.about-sections{
  padding:clamp(56px, 6vw, 96px) 0;
  background:var(--dag-sec-soft);
}
.about-sections > *{
  max-width:var(--dag-container);
  margin-inline:auto;
  padding-inline:var(--dag-gutter);
}

.about-sections__grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:24px;
}
@media (max-width: 980px){.about-sections__grid{grid-template-columns:1fr}}

.about-card{
  background:var(--dag-surface);
  border:1px solid var(--dag-border);
  border-left:3px solid var(--dag-primary);
  padding:28px 26px;
  box-shadow:var(--dag-shadow-xs);
  transition:transform var(--dag-transition), box-shadow var(--dag-transition), border-color var(--dag-transition);
}
.about-card:hover{
  transform:translateY(-2px);
  box-shadow:var(--dag-shadow-md);
  border-left-color:var(--dag-secondary);
}
.about-card__title{
  font-family:var(--dag-font-display);
  font-weight:400;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:var(--dag-secondary);
  margin:0 0 12px;
  font-size:22px;
  line-height:1.1;
}
.about-card__text{
  margin:0;
  color:var(--dag-text-2);
  line-height:1.6;
  font-size:15px;
}

/* ═══════════ TEAM — white bg ═══════════ */
.about-team{
  padding:clamp(56px, 6vw, 96px) 0;
  background:var(--dag-sec-white);
}
.about-team > *{
  max-width:var(--dag-container);
  margin-inline:auto;
  padding-inline:var(--dag-gutter);
}

/* ═══════════ FAQ — soft bg ═══════════ */
.about-faq{
  padding:clamp(56px, 6vw, 96px) 0;
  background:var(--dag-sec-soft);
}
.about-faq > *{
  max-width:var(--dag-container);
  margin-inline:auto;
  padding-inline:var(--dag-gutter);
}

/* ═══════════ CTA — dark night-blue ═══════════ */
.about-cta{
  padding:clamp(48px, 6vw, 88px) 0;
  background:var(--dag-secondary);
  color:var(--dag-sec-dark-fg);
}
.about-cta > *{
  max-width:var(--dag-container);
  margin-inline:auto;
  padding-inline:var(--dag-gutter);
}

.about-cta__card{
  display:grid;
  grid-template-columns:minmax(0, 1.2fr) minmax(0, 1fr);
  gap:clamp(24px, 4vw, 56px);
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.12);
  padding:clamp(24px, 3vw, 40px);
}
@media (max-width: 900px){
  .about-cta__card{grid-template-columns:1fr}
}

.about-cta__main{display:flex;flex-direction:column;gap:14px}
.about-cta__title{
  font-family:var(--dag-font-display);
  font-weight:400;
  font-size:clamp(28px, 1.6rem + 1.4vw, 44px);
  letter-spacing:.02em;
  text-transform:uppercase;
  color:var(--dag-sec-dark-fg);
  margin:0;
  line-height:1;
}
.about-cta__text{
  color:rgba(255,255,255,.78);
  margin:0;
  line-height:1.55;
  font-size:15px;
  max-width:50ch;
}

.about-cta__info{
  display:flex;
  flex-direction:column;
  gap:14px;
  border-left:1px solid rgba(255,255,255,.12);
  padding-left:clamp(16px, 2vw, 28px);
}
@media (max-width: 900px){
  .about-cta__info{
    border-left:0;
    border-top:1px solid rgba(255,255,255,.12);
    padding-left:0;
    padding-top:18px;
  }
}

.about-infoRow{
  display:grid;
  grid-template-columns:120px 1fr;
  gap:12px;
  align-items:start;
}
.about-infoLabel{
  font-size:11px;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--dag-accent);
  padding-top:2px;
}
.about-infoValue{
  color:var(--dag-sec-dark-fg);
  font-weight:600;
  font-size:14.5px;
  line-height:1.5;
}
.about-infoValue a{color:var(--dag-sec-dark-fg);text-decoration:none;border-bottom:1px solid transparent}
.about-infoValue a:hover{color:var(--dag-accent); border-bottom-color:var(--dag-accent)}

/* ═══════════ EDITOR (the_content) — light card ═══════════ */
.about-editor{
  margin-top:24px;
  padding:24px 26px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.12);
  border-left:3px solid var(--dag-accent);
  grid-column:1 / -1;
}
.about-editor__title{
  font-family:var(--dag-font-display);
  font-weight:400;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--dag-accent);
  font-size:16px;
  margin:0 0 12px;
  padding-bottom:10px;
  border-bottom:1px solid rgba(255,255,255,.15);
}
.about-editor__content{
  color:rgba(255,255,255,.85);
  font-size:14.5px;
  line-height:1.7;
  max-width:80ch;
}
.about-editor__content p{margin:0 0 .9em}
.about-editor__content p:last-child{margin-bottom:0}
.about-editor__content a{color:var(--dag-accent); text-decoration:underline}
.about-editor__content strong,
.about-editor__content b{color:var(--dag-sec-dark-fg)}
.about-editor__content ul,
.about-editor__content ol{padding-left:1.4em; margin:.5em 0}
.about-editor__content li::marker{color:var(--dag-accent)}

/* ═══════════ FIX: about-pill text overflow ═══════════ */
.about-hero__meta{
  align-items:stretch !important;
}
.about-pill{
  min-width:0;
  overflow:hidden;
}
.about-pill__value,
.about-pill__valueLink{
  overflow-wrap:anywhere;
  word-break:break-word;
  display:flex;
  flex-wrap:wrap;
  gap:6px 10px;
  align-items:baseline;
  line-height:1.45;
}
.about-pill__sep{
  display:inline-block;
  color:rgba(255,255,255,.4);
  margin:0 2px;
}
.about-pill__small{
  display:inline-block;
  color:rgba(255,255,255,.6);
  font-size:11px;
  font-weight:500;
}
.about-pill__map{
  display:inline-block;
  margin-left:6px;
  font-weight:700;
  color:var(--dag-accent);
  text-decoration:underline;
  text-underline-offset:2px;
}

/* ═══════════ FIX: pill links на тёмном фоне — белый текст ═══════════ */
.about-pill a,
.about-pill__valueLink,
.about-pill__valueLink a,
.about-pill__value a{
  color:var(--dag-sec-dark-fg) !important;
  text-decoration:none !important;
  font-weight:600 !important;
  border-bottom:1px solid transparent !important;
  transition:color var(--anim-fast) ease, border-color var(--anim-fast) ease !important;
}
.about-pill a:hover,
.about-pill__valueLink:hover,
.about-pill__valueLink a:hover,
.about-pill__value a:hover{
  color:var(--dag-accent) !important;
  border-bottom-color:var(--dag-accent) !important;
}
.about-pill__map{
  color:var(--dag-accent) !important;
  border-bottom:1px solid var(--dag-accent) !important;
}
.about-pill__map:hover{
  color:#fff !important;
  border-bottom-color:#fff !important;
}

/* ═══════════ TEAM GRID — symmetric: 4→4, 6→3+3, 8→4+4, 9→3+3+3 ═══════════ */
.about-team .team-grid,
.team-grid{
  display:grid !important;
  gap:24px !important;
  grid-template-columns:repeat(4, minmax(0, 1fr)) !important;
}

/* 1 member */
.team-grid:has(> .team-card:nth-child(1):last-child){
  grid-template-columns:repeat(1, minmax(0, 1fr)) !important;
  max-width:340px;
  margin-inline:auto;
}

/* 2 members */
.team-grid:has(> .team-card:nth-child(2):last-child){
  grid-template-columns:repeat(2, minmax(0, 1fr)) !important;
  max-width:680px;
  margin-inline:auto;
}

/* 3 members */
.team-grid:has(> .team-card:nth-child(3):last-child){
  grid-template-columns:repeat(3, minmax(0, 1fr)) !important;
}

/* 4 members → 4 в ряд */
.team-grid:has(> .team-card:nth-child(4):last-child){
  grid-template-columns:repeat(4, minmax(0, 1fr)) !important;
}

/* 5 members → 5 в ряд (или 3+2 на узких) */
.team-grid:has(> .team-card:nth-child(5):last-child){
  grid-template-columns:repeat(5, minmax(0, 1fr)) !important;
}

/* 6 members → 3+3 */
.team-grid:has(> .team-card:nth-child(6):last-child){
  grid-template-columns:repeat(3, minmax(0, 1fr)) !important;
}

/* 7 → 4+3 (7-я центрируется через grid-column trick — оставляем default flow) */
.team-grid:has(> .team-card:nth-child(7):last-child){
  grid-template-columns:repeat(4, minmax(0, 1fr)) !important;
}

/* 8 → 4+4 */
.team-grid:has(> .team-card:nth-child(8):last-child){
  grid-template-columns:repeat(4, minmax(0, 1fr)) !important;
}

/* 9 → 3+3+3 */
.team-grid:has(> .team-card:nth-child(9):last-child){
  grid-template-columns:repeat(3, minmax(0, 1fr)) !important;
}

/* 10 → 5+5 */
.team-grid:has(> .team-card:nth-child(10):last-child){
  grid-template-columns:repeat(5, minmax(0, 1fr)) !important;
}

/* 11+ → 4 в ряд по умолчанию (auto-flow) */
.team-grid:has(> .team-card:nth-child(11)){
  grid-template-columns:repeat(4, minmax(0, 1fr)) !important;
}

/* Responsive overrides */
@media (max-width: 1100px){
  .team-grid,
  .about-team .team-grid{grid-template-columns:repeat(3, minmax(0, 1fr)) !important}
  .team-grid:has(> .team-card:nth-child(1):last-child){grid-template-columns:1fr !important}
  .team-grid:has(> .team-card:nth-child(2):last-child){grid-template-columns:repeat(2, 1fr) !important}
}

@media (max-width: 760px){
  .team-grid,
  .about-team .team-grid{grid-template-columns:repeat(2, minmax(0, 1fr)) !important}
}

@media (max-width: 460px){
  .team-grid,
  .about-team .team-grid{grid-template-columns:1fr !important}
}

/* Team card — единый стиль */
.about-team .team-card,
.team-card{
  background:var(--dag-surface);
  border:1px solid var(--dag-border);
  border-bottom:3px solid var(--dag-primary);
  padding:0;
  display:flex;
  flex-direction:column;
  overflow:hidden;
  transition:transform var(--dag-transition), box-shadow var(--dag-transition), border-color var(--dag-transition);
}
.about-team .team-card:hover,
.team-card:hover{
  transform:translateY(-3px);
  box-shadow:var(--dag-shadow-md);
  border-bottom-color:var(--dag-secondary);
}

.team-card img{
  display:block;
  width:100%;
  aspect-ratio:1/1;
  object-fit:cover;
  background:var(--dag-surface-3);
}

.team-card__body,
.team-card > div:not(.team-card__avatar){
  padding:16px 18px 18px;
}

.team-card__name,
.team-card h3{
  font-family:var(--dag-font-display);
  font-weight:400;
  letter-spacing:.04em;
  text-transform:uppercase;
  font-size:18px;
  color:var(--dag-secondary);
  margin:0 0 6px;
  line-height:1.1;
}

.team-card__role,
.team-card__title{
  font-size:11px;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--dag-primary);
  margin:0 0 8px;
}

.team-card__bio,
.team-card p{
  font-size:13.5px;
  color:var(--dag-text-2);
  line-height:1.5;
  margin:0;
}

/* ═══════════ TEAM CARD — flat children, padding via direct selectors ═══════════ */
.team-card{
  background:var(--dag-surface) !important;
  border:1px solid var(--dag-border) !important;
  border-bottom:3px solid var(--dag-primary) !important;
  padding:0 !important;
  display:flex !important;
  flex-direction:column !important;
  overflow:hidden !important;
  transition:transform var(--dag-transition), box-shadow var(--dag-transition), border-color var(--dag-transition) !important;
}
.team-card:hover{
  transform:translateY(-3px);
  box-shadow:var(--dag-shadow-md) !important;
  border-bottom-color:var(--dag-secondary) !important;
}

/* Media block */
.team-card__media{
  position:relative;
  width:100%;
  aspect-ratio:1/1;
  overflow:hidden;
  background:var(--dag-surface-3);
  margin:0;
}
.team-card__img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:var(--team-focus, 50% 18%);
}
.team-card__avatar{
  width:100%;
  aspect-ratio:1/1;
  background:linear-gradient(135deg, var(--dag-surface-2), var(--dag-surface-3));
  display:block;
}

/* Name (h3 — direct child) */
.team-card > .team-card__name,
.team-card .team-card__name{
  font-family:var(--dag-font-display) !important;
  font-weight:400 !important;
  letter-spacing:.04em !important;
  text-transform:uppercase !important;
  font-size:20px !important;
  color:var(--dag-secondary) !important;
  line-height:1.05 !important;
  margin:18px 20px 6px !important;
  padding:0 !important;
}

/* Role (div — direct child) */
.team-card > .team-card__role,
.team-card .team-card__role{
  font-size:11px !important;
  font-weight:700 !important;
  letter-spacing:.14em !important;
  text-transform:uppercase !important;
  color:var(--dag-primary) !important;
  margin:0 20px 10px !important;
  padding:0 0 10px !important;
  border-bottom:1px solid var(--dag-border) !important;
  line-height:1.2 !important;
}

/* Bio (p — direct child, last in card) */
.team-card > .team-card__bio,
.team-card .team-card__bio{
  font-size:13.5px !important;
  color:var(--dag-text-2) !important;
  line-height:1.55 !important;
  margin:0 20px 18px !important;
  padding:0 !important;
  flex:1 1 auto !important;
}

/* Empty bio — keep card height visually consistent */
.team-card > .team-card__bio:empty{
  margin:0;
  min-height:0;
}

/* Section header above grid (h2 + subtitle) */
.about-section-head{
  margin-bottom:32px;
  text-align:left;
}
.about-section-title{
  font-family:var(--dag-font-display) !important;
  font-weight:400 !important;
  font-size:clamp(28px, 1.6rem + 1.4vw, 44px) !important;
  letter-spacing:.04em !important;
  text-transform:uppercase !important;
  color:var(--dag-secondary) !important;
  line-height:.95 !important;
  margin:0 0 10px !important;
  padding:0 !important;
  background:none !important;
  border:0 !important;
}
.about-section-subtitle{
  color:var(--dag-muted) !important;
  font-size:15px !important;
  margin:0 !important;
  padding:0 !important;
  max-width:60ch;
}

/* About sections head — same treatment */
.about-sections .about-section-head,
.about-faq .about-section-head{margin-bottom:24px}

/* Mobile padding tighten */
@media (max-width: 460px){
  .team-card > .team-card__name,
  .team-card .team-card__name{margin:14px 16px 6px !important; font-size:18px !important}
  .team-card > .team-card__role,
  .team-card .team-card__role{margin:0 16px 8px !important; padding-bottom:8px !important}
  .team-card > .team-card__bio,
  .team-card .team-card__bio{margin:0 16px 14px !important; font-size:13px !important}
}
