/* ─────────────────────────────────────────────────────────────────
 * LIDAM — interior page styles (Services / People / News / Contact)
 * Additive layer on top of lidam.css. Reuses the same tokens.
 * ───────────────────────────────────────────────────────────────── */

/* Active nav item */
.nav a[aria-current="page"] {
  color: var(--l-accent);
  background: var(--l-accent-soft);
}

/* Language switcher (per-URL links) */
.lang-switch {
  display: inline-flex; align-items: center; gap: 2px;
  border: 1px solid var(--l-line); border-radius: 8px; overflow: hidden;
}
.lang-switch a {
  padding: 6px 9px; font-size: 12.5px; font-weight: var(--wds-weight-bold);
  letter-spacing: 0.02em; color: var(--wds-color-label-alternative);
  line-height: 1; white-space: nowrap; transition: background .14s, color .14s;
}
.lang-switch a:hover { background: var(--wds-color-fill-normal); color: var(--wds-color-label-normal); }
.lang-switch a[aria-current="true"] { background: var(--l-ink); color: #fff; }
@media (max-width: 400px) {
  .lang-switch a { padding: 6px 7px; font-size: 12px; }
}

/* ───────── INTERIOR PAGE HERO ───────── */
.page-hero {
  background: var(--l-accent-tint);
  border-bottom: 1px solid var(--l-line);
  padding-block: clamp(56px, 7vw, 96px);
}
.page-hero .inner { max-width: 820px; }
.page-hero h1 {
  margin: 20px 0 0; font-weight: var(--wds-weight-bold);
  font-size: clamp(36px, 5vw, 54px); line-height: 1.08; letter-spacing: -0.03em;
  color: var(--l-ink);
}
.page-hero .lede {
  margin: 22px 0 0; font-size: 19px; line-height: 1.62;
  color: var(--wds-color-label-alternative); max-width: 620px;
}

/* ───────── SERVICES — detailed rows ───────── */
.svc-detail-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; }
.svc-detail {
  background: #fff; border: 1px solid var(--l-line); border-radius: 20px;
  padding: 32px; display: flex; flex-direction: column; gap: 0;
  transition: border-color .16s, box-shadow .16s;
}
.svc-detail:hover { border-color: color-mix(in srgb, var(--l-accent) 45%, var(--l-line)); box-shadow: var(--wds-shadow-2); }
.svc-detail .svc-idx { font-family: var(--wds-font-family-mono); font-size: 12px; font-weight: var(--wds-weight-bold); color: var(--l-accent); letter-spacing: 0.04em; }
.svc-detail h3 { margin: 14px 0 0; font-size: 22px; font-weight: var(--wds-weight-bold); color: var(--l-ink); letter-spacing: -0.02em; }
.svc-detail p { margin: 12px 0 0; font-size: 15.5px; line-height: 1.6; color: var(--wds-color-label-alternative); }
.svc-detail ul { margin: 18px 0 0; padding: 0; list-style: none; display: flex; flex-direction: column; gap: 9px; }
.svc-detail ul li { display: flex; align-items: flex-start; gap: 10px; font-size: 14.5px; line-height: 1.45; color: var(--wds-color-label-neutral); font-weight: var(--wds-weight-medium); }
.svc-detail ul .ic { font-size: 16px; color: var(--l-accent); margin-top: 2px; flex: none; }

/* ───────── PEOPLE — full roster cards ───────── */
.person-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.person-card {
  background: #fff; border: 1px solid var(--l-line); border-radius: 20px; overflow: hidden;
  transition: border-color .16s, box-shadow .16s, transform .16s;
}
.person-card:hover { border-color: color-mix(in srgb, var(--l-accent) 45%, var(--l-line)); box-shadow: var(--wds-shadow-2); }
.person-photo {
  aspect-ratio: 1 / 1; display: grid; place-items: center;
  background:
    repeating-linear-gradient(135deg, rgba(112,115,124,0.08) 0 2px, transparent 2px 11px),
    var(--l-accent-tint);
}
.person-photo .r-avatar {
  width: 68px; height: 68px; border-radius: 50%;
  background: #fff; color: var(--l-accent); border: 1px solid var(--l-line);
  display: grid; place-items: center; font-size: 22px; font-weight: var(--wds-weight-bold);
}
/* real member portraits */
.person-photo img { width: 100%; height: 100%; object-fit: cover; object-position: top center; }
.lead-photo img { width: 100%; height: 100%; object-fit: cover; object-position: top center; }
.roster .r-avatar { overflow: hidden; padding: 0; }
.roster .r-avatar img { width: 100%; height: 100%; object-fit: cover; object-position: top center; }
.person-body { padding: 22px 24px 26px; }
.person-body .role { font-size: 12px; font-weight: var(--wds-weight-bold); letter-spacing: 0.06em; text-transform: uppercase; color: var(--l-accent); }
.person-body .name { margin-top: 8px; font-size: 20px; font-weight: var(--wds-weight-bold); color: var(--l-ink); letter-spacing: -0.02em; }
.person-body .meta { margin-top: 12px; font-size: 14px; line-height: 1.55; color: var(--wds-color-label-alternative); }
.person-body .langs { margin-top: 14px; font-family: var(--wds-font-family-mono); font-size: 12px; font-weight: var(--wds-weight-semibold); color: var(--wds-color-label-assistive); letter-spacing: 0.04em; }
/* cards / rows as links */
a.person-card { display: block; color: inherit; }
a.lead-person { color: inherit; }
.roster-row { display: flex; align-items: center; gap: 16px; width: 100%; color: inherit; }
.roster li:hover .r-name { color: var(--l-accent); }

/* ───────── PERSON DETAIL ───────── */
.person-hero { padding-bottom: 0; }
.back-link { display: inline-flex; align-items: center; gap: 8px; font-size: 14px; font-weight: var(--wds-weight-semibold); color: var(--wds-color-label-alternative); }
.back-link:hover { color: var(--l-accent); }
.back-link .ic { font-size: 16px; transform: rotate(180deg); }
.person-detail { display: grid; grid-template-columns: 340px 1fr; gap: 56px; align-items: start; }
.pd-side { position: sticky; top: 96px; }
.pd-photo { aspect-ratio: 1 / 1; border-radius: 20px; overflow: hidden; border: 1px solid var(--l-line); background: var(--l-accent-tint); }
.pd-photo img { width: 100%; height: 100%; object-fit: cover; object-position: top center; }
.pd-side .role { margin-top: 22px; font-size: 12px; font-weight: var(--wds-weight-bold); letter-spacing: 0.06em; text-transform: uppercase; color: var(--l-accent); }
.pd-side .name { margin: 8px 0 0; font-size: 28px; font-weight: var(--wds-weight-bold); letter-spacing: -0.02em; color: var(--l-ink); }
.pd-meta { margin: 12px 0 0; font-size: 15px; line-height: 1.6; color: var(--wds-color-label-alternative); }
.pd-contact { list-style: none; margin: 22px 0 0; padding: 22px 0 0; border-top: 1px solid var(--l-line); display: flex; flex-direction: column; gap: 12px; }
.pd-contact li { display: flex; align-items: center; gap: 12px; font-size: 14px; color: var(--wds-color-label-neutral); }
.pd-contact .ic { font-size: 16px; color: var(--wds-color-label-assistive); flex: none; }
.pd-body { display: flex; flex-direction: column; gap: 34px; }
.pd-block h2 { display: flex; align-items: center; gap: 10px; margin: 0 0 14px; font-size: 13px; font-weight: var(--wds-weight-bold); letter-spacing: 0.08em; text-transform: uppercase; color: var(--l-ink); }
.pd-block h2 .ic { font-size: 16px; color: var(--l-accent); }
.pd-block ul { list-style: none; margin: 0; padding: 0; }
.pd-block li { position: relative; padding: 12px 0 12px 22px; border-bottom: 1px solid var(--l-line-soft); font-size: 15px; line-height: 1.5; color: var(--wds-color-label-normal); }
.pd-block li:last-child { border-bottom: none; }
.pd-block li::before { content: ""; position: absolute; left: 2px; top: 19px; width: 6px; height: 6px; border-radius: 50%; background: var(--l-accent-soft); border: 1px solid var(--l-accent); }
.pd-block p { margin: 0; font-size: 15px; line-height: 1.65; color: var(--wds-color-label-alternative); }
@media (max-width: 860px) {
  .person-detail { grid-template-columns: 1fr; gap: 32px; }
  .pd-side { position: static; }
  .pd-photo { max-width: 300px; }
}

/* ───────── SERVICE DETAIL ───────── */
.page-hero .back-link { margin-bottom: 20px; }
a.svc-detail { color: inherit; }
.svc-detail-more { margin-top: 20px; display: inline-flex; align-items: center; gap: 6px; font-size: 14px; font-weight: var(--wds-weight-bold); color: var(--l-accent); }
.svc-detail-more .ic { font-size: 15px; transition: transform .16s var(--wds-easing-standard); }
.svc-detail:hover .svc-detail-more .ic { transform: translate(2px, -2px); }
.svc-overview { display: grid; grid-template-columns: 220px 1fr; gap: 40px; align-items: start; }
.svc-overview .eyebrow { padding-top: 4px; }
.svc-overview-body p { margin: 0 0 18px; font-size: 17px; line-height: 1.7; color: var(--wds-color-label-normal); }
.svc-overview-body p:last-child { margin-bottom: 0; }
.facts-grid { margin-top: 40px; display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; }
.fact { background: #fff; border: 1px solid var(--l-line); border-radius: 16px; padding: 24px 26px; }
.fact h3 { margin: 0; font-size: 16px; font-weight: var(--wds-weight-bold); color: var(--l-accent); letter-spacing: -0.01em; }
.fact p { margin: 10px 0 0; font-size: 14.5px; line-height: 1.6; color: var(--wds-color-label-alternative); }
.faq-list { margin-top: 40px; display: flex; flex-direction: column; }
.faq-item { padding: 26px 0; border-bottom: 1px solid var(--l-line); }
.faq-item:first-child { border-top: 1px solid var(--l-line); }
.faq-item h3 { margin: 0; font-size: 18px; font-weight: var(--wds-weight-bold); color: var(--l-ink); letter-spacing: -0.015em; }
.faq-item p { margin: 12px 0 0; font-size: 15.5px; line-height: 1.65; color: var(--wds-color-label-alternative); max-width: 820px; }
.related-grid { margin-top: 40px; display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.related-card { display: flex; flex-direction: column; background: #fff; border: 1px solid var(--l-line); border-radius: 18px; padding: 26px; color: inherit; transition: border-color .16s, box-shadow .16s; }
.related-card:hover { border-color: color-mix(in srgb, var(--l-accent) 45%, var(--l-line)); box-shadow: var(--wds-shadow-1); }
.related-card h3 { margin: 0; font-size: 17px; font-weight: var(--wds-weight-bold); color: var(--l-ink); line-height: 1.35; letter-spacing: -0.015em; }
.related-card p { margin: 10px 0 0; font-size: 14px; line-height: 1.55; color: var(--wds-color-label-alternative); display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.related-more { margin-top: 16px; display: inline-flex; align-items: center; gap: 6px; font-size: 13.5px; font-weight: var(--wds-weight-bold); color: var(--l-accent); }
.related-more .ic { font-size: 14px; }
@media (max-width: 860px) {
  .svc-overview { grid-template-columns: 1fr; gap: 16px; }
  .facts-grid { grid-template-columns: 1fr; }
  .related-grid { grid-template-columns: 1fr; }
}

/* ───────── NEWS — article cards ───────── */
.news-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.news-card {
  display: flex; flex-direction: column;
  background: #fff; border: 1px solid var(--l-line); border-radius: 20px; overflow: hidden;
  transition: border-color .16s, box-shadow .16s, transform .16s;
}
.news-card:hover { border-color: color-mix(in srgb, var(--l-accent) 45%, var(--l-line)); box-shadow: var(--wds-shadow-2); transform: translateY(-2px); }
.news-thumb {
  aspect-ratio: 16 / 9; position: relative;
  background:
    repeating-linear-gradient(135deg, rgba(112,115,124,0.07) 0 2px, transparent 2px 12px),
    var(--l-accent-tint);
}
.news-cat {
  position: absolute; top: 14px; left: 14px;
  display: inline-flex; align-items: center; padding: 5px 11px; border-radius: 999px;
  font-size: 11.5px; font-weight: var(--wds-weight-bold); letter-spacing: 0.02em;
  background: #fff; color: var(--l-accent); border: 1px solid var(--l-line);
}
.news-body { padding: 22px 24px 24px; display: flex; flex-direction: column; flex: 1; }
.news-date { font-family: var(--wds-font-family-mono); font-size: 12px; font-weight: var(--wds-weight-semibold); color: var(--wds-color-label-assistive); letter-spacing: 0.03em; }
.news-title { margin: 10px 0 0; font-size: 18px; font-weight: var(--wds-weight-bold); color: var(--l-ink); letter-spacing: -0.015em; line-height: 1.35; }
.news-excerpt { margin: 10px 0 0; font-size: 14.5px; line-height: 1.55; color: var(--wds-color-label-alternative); }
.news-more { margin-top: 18px; display: inline-flex; align-items: center; gap: 6px; font-size: 14px; font-weight: var(--wds-weight-bold); color: var(--l-accent); }
.news-more .ic { font-size: 15px; transition: transform .16s var(--wds-easing-standard); }
.news-card:hover .news-more .ic { transform: translate(2px,-2px); }

/* ───────── CONTACT ───────── */
.contact-grid { display: grid; grid-template-columns: 1.15fr 0.85fr; gap: 48px; align-items: start; }
.contact-form {
  background: #fff; border: 1px solid var(--l-line); border-radius: 24px; padding: 36px;
}
.form-row { display: grid; gap: 8px; margin-bottom: 20px; }
.form-row.two { grid-template-columns: 1fr 1fr; gap: 16px; }
.form-row.two > div { display: grid; gap: 8px; }
.form-row label { font-size: 13px; font-weight: var(--wds-weight-bold); color: var(--l-ink); letter-spacing: 0.01em; }
.form-row .req { color: var(--wds-color-status-negative); margin-inline-start: 3px; }
.contact-form .wds-input { height: 46px; border-radius: var(--wds-radius-10); border-color: var(--l-line); }
.contact-form textarea.wds-input { height: auto; min-height: 132px; padding-top: 12px; resize: vertical; line-height: 1.55; }
.contact-form .btn { width: 100%; margin-top: 4px; }
.contact-form .note { margin: 16px 0 0; font-size: 13px; color: var(--wds-color-label-assistive); line-height: 1.5; text-align: center; }
.form-status { margin: 14px 0 0; padding: 12px 16px; border-radius: var(--wds-radius-10); font-size: 14px; font-weight: var(--wds-weight-semibold); line-height: 1.5; }
.form-status[data-ok="true"] { background: var(--l-accent-soft); color: var(--l-accent-heavy); border: 1px solid color-mix(in srgb, var(--l-accent) 30%, transparent); }
.form-status[data-ok="false"] { background: #FDECEC; color: #B42318; border: 1px solid #F5C2C0; }

.contact-info { display: flex; flex-direction: column; gap: 16px; }
.info-card {
  background: var(--l-accent-tint); border: 1px solid var(--l-line); border-radius: 20px; padding: 26px 28px;
}
.info-card h3 { margin: 0 0 16px; font-size: 13px; font-weight: var(--wds-weight-bold); letter-spacing: 0.06em; text-transform: uppercase; color: var(--l-accent); }
.info-card ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 14px; }
.info-card li { display: flex; gap: 12px; font-size: 15px; line-height: 1.5; color: var(--wds-color-label-neutral); font-weight: var(--wds-weight-medium); }
.info-card li .ic { font-size: 18px; color: var(--l-accent); margin-top: 1px; flex: none; }
.info-card a { color: inherit; }
.info-card a:hover { color: var(--l-accent); }
.info-map {
  aspect-ratio: 3 / 2; border: 1px solid var(--l-line); border-radius: 20px; overflow: hidden;
  background:
    repeating-linear-gradient(135deg, rgba(112,115,124,0.08) 0 2px, transparent 2px 12px),
    var(--l-accent-tint);
  display: grid; place-items: center;
}
.info-map span { font-family: var(--wds-font-family-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--wds-color-label-assistive); }

/* ───────── RESPONSIVE ───────── */
@media (max-width: 940px) {
  .svc-detail-grid { grid-template-columns: 1fr; }
  .person-grid { grid-template-columns: 1fr 1fr; }
  .news-grid { grid-template-columns: 1fr 1fr; }
  .contact-grid { grid-template-columns: 1fr; gap: 32px; }
}
@media (max-width: 560px) {
  .person-grid { grid-template-columns: 1fr; }
  .news-grid { grid-template-columns: 1fr; }
  .form-row.two { grid-template-columns: 1fr; }
  .contact-form { padding: 26px 22px; }
}

/* ───────── BLOG ARTICLE (news detail) ───────── */
.article-hero .article-back {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 14px; font-weight: var(--wds-weight-bold); color: var(--l-accent);
  margin-bottom: 18px;
}
.article-hero .article-back:hover { color: var(--l-accent-strong); }
.article-meta { display: inline-flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.news-cat--inline { position: static; }
.article-date { font-family: var(--wds-font-family-mono); font-size: 13px; font-weight: var(--wds-weight-semibold); color: var(--wds-color-label-alternative); }
.article-hero h1 { font-size: clamp(28px, 4vw, 44px); line-height: 1.16; }
.article-wrap { max-width: 760px; margin: 0 auto; }
.article-source {
  margin-top: 48px; padding-top: 24px; border-top: 1px solid var(--l-line);
  display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap;
}
.article-source p { margin: 0; font-size: 14px; color: var(--wds-color-label-alternative); }

/* prose — rendered blog HTML from the ip-here feed */
.prose { font-size: 17px; line-height: 1.75; color: var(--wds-color-label-neutral); }
.prose > * + * { margin-top: 1.15em; }
.prose h2 { margin-top: 1.8em; font-size: 26px; line-height: 1.3; font-weight: var(--wds-weight-bold); letter-spacing: -0.02em; color: var(--l-ink); }
.prose h3 { margin-top: 1.5em; font-size: 20px; line-height: 1.35; font-weight: var(--wds-weight-bold); letter-spacing: -0.015em; color: var(--l-ink); }
.prose p { margin-top: 1.1em; }
.prose a { color: var(--l-accent); text-decoration: underline; text-underline-offset: 2px; }
.prose a:hover { color: var(--l-accent-strong); }
.prose strong { font-weight: var(--wds-weight-bold); color: var(--l-ink); }
.prose ul, .prose ol { margin-top: 1.1em; padding-inline-start: 1.4em; }
.prose li { margin-top: 0.4em; }
.prose li::marker { color: var(--l-accent); }
.prose blockquote {
  margin: 1.5em 0; padding: 4px 0 4px 22px; border-inline-start: 3px solid var(--l-accent);
  color: var(--wds-color-label-alternative); font-style: italic;
}
.prose blockquote cite { display: block; margin-top: 8px; font-size: 14px; font-style: normal; color: var(--wds-color-label-assistive); }
.prose hr.bp-divider { margin: 2.2em 0; border: 0; border-top: 1px solid var(--l-line); }
.prose .bp-tablewrap { overflow-x: auto; margin: 1.5em 0; }
.prose table { width: 100%; border-collapse: collapse; font-size: 15px; }
.prose th, .prose td { padding: 10px 14px; border: 1px solid var(--l-line); text-align: start; vertical-align: top; }
.prose thead th { background: var(--l-accent-tint); color: var(--l-ink); font-weight: var(--wds-weight-bold); }
.prose pre.bp-code {
  margin: 1.5em 0; padding: 18px 20px; border-radius: 12px; overflow-x: auto;
  background: var(--l-ink); color: #E7EEF5; font-size: 13.5px; line-height: 1.6;
}
.prose code { font-family: var(--wds-font-family-mono); font-size: 0.9em; }
.prose :not(pre) > code { background: var(--wds-color-fill-normal); padding: 2px 6px; border-radius: 6px; color: var(--l-ink); }
.prose .bp-figure { margin: 1.6em 0; }
.prose .bp-figure img { border-radius: 12px; border: 1px solid var(--l-line); width: 100%; }
.prose .bp-figure figcaption { margin-top: 10px; font-size: 13px; color: var(--wds-color-label-assistive); text-align: center; }
.prose .bp-callout {
  margin: 1.5em 0; padding: 18px 20px; border-radius: 12px;
  border: 1px solid var(--l-line); background: var(--l-accent-tint);
}
.prose .bp-callout__title { margin: 0 0 6px; font-weight: var(--wds-weight-bold); color: var(--l-ink); }
.prose .bp-callout p { margin: 0; }
.prose .bp-callout--warning { background: #FFF7E9; border-color: #F5D9A6; }
.prose .bp-callout--danger { background: #FEF0F0; border-color: #F6C6C6; }
.prose .bp-callout--success { background: #EEFBF2; border-color: #B7E7C6; }
.prose .bp-kv { margin: 1.5em 0; padding: 18px 20px; border: 1px solid var(--l-line); border-radius: 12px; }
.prose .bp-kv__title { margin: 0 0 10px; font-weight: var(--wds-weight-bold); color: var(--l-ink); }
.prose .bp-kv dl { margin: 0; }
.prose .bp-kv__row { display: flex; gap: 16px; padding: 8px 0; border-bottom: 1px solid var(--l-line-soft); }
.prose .bp-kv__row:last-child { border-bottom: none; }
.prose .bp-kv dt { flex: 0 0 34%; font-weight: var(--wds-weight-semibold); color: var(--l-ink); margin: 0; }
.prose .bp-kv dd { flex: 1; margin: 0; }
.prose .bp-kv__note { color: var(--wds-color-label-assistive); font-size: 0.9em; }
.prose .bp-cta {
  margin: 1.8em 0; padding: 26px 28px; border-radius: 16px;
  background: var(--l-ink); color: #fff;
}
.prose .bp-cta__title { margin: 0; font-size: 19px; font-weight: var(--wds-weight-bold); }
.prose .bp-cta p { margin: 8px 0 0; color: rgba(255,255,255,0.78); }
.prose .bp-cta__btn {
  display: inline-flex; margin-top: 16px; padding: 10px 20px; border-radius: var(--wds-radius-10);
  background: #fff; color: var(--l-ink); font-weight: var(--wds-weight-bold); text-decoration: none;
}
