/* ──────────────────────────────────────────────────────────────────
 * ECMI — subpages (blog index, article, plain text)
 * Loaded AFTER fluent-tokens.css and ecmi.css.
 * ────────────────────────────────────────────────────────────────── */

/* ── Compact header for subpages ─────────────────────── */
.sub-header {
  position: sticky; top: 0; z-index: 50;
  background: color-mix(in srgb, var(--bg-1) 85%, transparent);
  -webkit-backdrop-filter: saturate(140%) blur(16px); backdrop-filter: saturate(140%) blur(16px);
  border-bottom: 1px solid var(--stroke-subtle);
}
.sub-header .header-inner { display: flex; align-items: center; justify-content: space-between; height: 66px; }
.sub-nav { display: flex; align-items: center; gap: clamp(10px, 2vw, 26px); }
.sub-nav a {
  font: var(--type-body1-strong); color: var(--fg-2); padding: 8px 2px;
  position: relative; transition: color .15s var(--ease-easy);
}
.sub-nav a:hover { color: var(--fg-1); }
.sub-nav .back {
  display: inline-flex; align-items: center; gap: 7px; color: var(--fg-2);
  font: var(--type-body1-strong);
}
.sub-nav .back svg { width: 16px; height: 16px; transition: transform .2s var(--ease-decelerate); }
.sub-nav .back:hover svg { transform: translateX(-3px); }
@media (max-width: 600px) { .sub-nav .hide-sm { display: none; } }

/* ── Generic page shell ──────────────────────────────── */
.page-main { min-height: 60vh; }
.crumbs {
  display: flex; align-items: center; gap: 9px; flex-wrap: wrap;
  font: var(--type-caption1-strong); color: var(--fg-4);
}
.crumbs a { color: var(--fg-3); }
.crumbs a:hover { color: var(--fg-1); }
.crumbs .sep { opacity: .5; }

/* ── Blog index ──────────────────────────────────────── */
.blog-head { padding-top: clamp(48px, 8vh, 96px); padding-bottom: clamp(28px, 4vh, 44px); }
.blog-head h1 {
  font: var(--type-large-title); font-size: clamp(38px, 6vw, 62px);
  letter-spacing: -0.04em; line-height: 1.04; color: var(--fg-1); margin: 18px 0 0; text-wrap: balance;
}
.blog-head p { font: var(--type-subtitle1); font-weight: 400; color: var(--fg-2); margin: 18px 0 0; max-width: 56ch; line-height: 1.5; }

.blog-list {
  padding-bottom: clamp(64px, 11vh, 120px);
  display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(18px, 2.2vw, 26px);
}
@media (max-width: 920px) { .blog-list { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .blog-list { grid-template-columns: 1fr; } }

/* feature first post across full width */
.blog-list .post.feature { grid-column: 1 / -1; flex-direction: row; }
.blog-list .post.feature .post-thumb { width: 46%; aspect-ratio: auto; min-height: 280px; }
.blog-list .post.feature .post-body { padding: clamp(28px, 4vw, 44px); justify-content: center; }
.blog-list .post.feature h3 { font: var(--type-title2); letter-spacing: -0.03em; }
.blog-list .post.feature p { font: var(--type-body1); }
@media (max-width: 720px) {
  .blog-list .post.feature { flex-direction: column; }
  .blog-list .post.feature .post-thumb { width: 100%; aspect-ratio: 16/9; min-height: 0; }
}

/* ── Article ─────────────────────────────────────────── */
.article-hero { padding-top: clamp(40px, 6vh, 72px); }
.article-hero .crumbs { margin-bottom: 22px; }
.art-cat {
  display: inline-block; font: var(--type-caption1-strong); text-transform: uppercase; letter-spacing: .1em;
  color: var(--logo-accent); background: color-mix(in srgb, var(--logo-accent) 12%, var(--bg-3));
  border-radius: 999px; padding: 6px 14px;
}
.article-hero h1 {
  font: var(--type-large-title); font-size: clamp(32px, 5vw, 56px);
  letter-spacing: -0.04em; line-height: 1.06; color: var(--fg-1); margin: 20px 0 0; max-width: 22ch; text-wrap: balance;
}
.byline {
  margin-top: 26px; display: flex; align-items: center; gap: 14px; flex-wrap: wrap;
  font: var(--type-body2); color: var(--fg-3);
}
.byline .who { display: flex; align-items: center; gap: 11px; }
.byline .who > span:last-child { display: flex; flex-direction: column; line-height: 1.3; white-space: nowrap; }
.byline .avatar {
  width: 42px; height: 42px; border-radius: 50%; display: grid; place-items: center; flex: none;
  font: var(--type-body1-strong); color: #fff; background: linear-gradient(135deg, var(--logo-accent), var(--c-pokazsie));
}
.byline .who b { color: var(--fg-1); font-weight: 600; }
.byline .dot { width: 4px; height: 4px; border-radius: 50%; background: var(--stroke-1); }

.art-cover {
  margin: clamp(28px, 5vh, 48px) 0 0; border-radius: 18px; overflow: hidden;
  border: 1px solid var(--stroke-2); aspect-ratio: 16 / 8; background: var(--bg-3);
}
.art-cover .ph { width: 100%; height: 100%; }

/* prose column */
.prose { max-width: 720px; margin: clamp(32px, 6vh, 56px) auto 0; padding-bottom: clamp(56px, 9vh, 104px); }
.prose > * + * { margin-top: 1.35em; }
.prose .lead { font: var(--type-subtitle1); font-weight: 400; color: var(--fg-1); line-height: 1.5; }
.prose p { font: var(--type-body1); color: var(--fg-2); line-height: 1.72; }
.prose h2 { font: var(--type-title2); letter-spacing: -0.03em; color: var(--fg-1); margin-top: 1.7em; }
.prose h3 { font: var(--type-title3); letter-spacing: -0.02em; color: var(--fg-1); margin-top: 1.5em; }
.prose ul, .prose ol { padding-left: 1.3em; color: var(--fg-2); font: var(--type-body1); line-height: 1.7; }
.prose li + li { margin-top: .5em; }
.prose li::marker { color: var(--logo-accent); }
.prose a { color: var(--logo-accent); border-bottom: 1px solid color-mix(in srgb, var(--logo-accent) 40%, transparent); }
.prose a:hover { border-color: var(--logo-accent); }
.prose strong { color: var(--fg-1); font-weight: 600; }
.prose blockquote {
  margin-inline: 0; padding: 4px 0 4px 24px; border-left: 3px solid var(--logo-accent);
  font: var(--type-subtitle1); font-weight: 400; font-style: normal; color: var(--fg-1); line-height: 1.5;
}
.prose figure { margin: 0; }
.prose figure .ph-wrap { border-radius: 14px; overflow: hidden; border: 1px solid var(--stroke-2); aspect-ratio: 16/9; background: var(--bg-3); }
.prose figure .ph { width: 100%; height: 100%; }
.prose figcaption { margin-top: 10px; font: var(--type-caption1); color: var(--fg-4); text-align: center; }
.prose hr { border: 0; border-top: 1px solid var(--stroke-subtle); margin: 2.2em 0; }

.tags { display: flex; flex-wrap: wrap; gap: 9px; margin-top: 2em; }
.tags span { font: var(--type-caption1-strong); color: var(--fg-2); background: var(--bg-3); border: 1px solid var(--stroke-subtle); border-radius: 999px; padding: 6px 13px; }

.share { margin-top: 2em; display: flex; align-items: center; gap: 12px; }
.share span { font: var(--type-caption1-strong); text-transform: uppercase; letter-spacing: .1em; color: var(--fg-4); }
.share a { width: 38px; height: 38px; border-radius: 10px; display: grid; place-items: center; color: var(--fg-2); border: 1px solid var(--stroke-1); transition: all .18s var(--ease-easy); }
.share a:hover { color: var(--logo-accent); border-color: var(--logo-accent); transform: translateY(-2px); }
.share a svg { width: 18px; height: 18px; }

/* related posts */
.related { background: var(--bg-2); border-top: 1px solid var(--stroke-subtle); }
.related .wrap { padding-block: clamp(48px, 8vh, 90px); }
.related h2 { font: var(--type-title2); letter-spacing: -0.03em; color: var(--fg-1); margin: 0 0 clamp(24px,4vh,36px); }
.related-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(18px, 2.2vw, 26px); }
@media (max-width: 820px) { .related-grid { grid-template-columns: 1fr; } }

/* ── Plain text / legal page ─────────────────────────── */
.legal-head { padding-top: clamp(48px, 8vh, 96px); padding-bottom: clamp(20px, 3vh, 32px); }
.legal-head h1 { font: var(--type-large-title); font-size: clamp(34px, 5vw, 56px); letter-spacing: -0.04em; color: var(--fg-1); margin: 18px 0 0; }
.legal-head .updated { margin-top: 14px; font: var(--type-caption1-strong); text-transform: uppercase; letter-spacing: .1em; color: var(--fg-4); }
.legal-layout { display: grid; grid-template-columns: 240px 1fr; gap: clamp(28px, 5vw, 64px); padding-bottom: clamp(56px, 9vh, 104px); align-items: start; }
@media (max-width: 820px) { .legal-layout { grid-template-columns: 1fr; } .legal-toc { display: none; } }
.legal-toc { position: sticky; top: 96px; }
.legal-toc h5 { font: var(--type-caption1-strong); text-transform: uppercase; letter-spacing: .1em; color: var(--fg-4); margin: 0 0 14px; }
.legal-toc ol { list-style: none; margin: 0; padding: 0; counter-reset: toc; display: grid; gap: 9px; }
.legal-toc a { font: var(--type-body2); color: var(--fg-3); display: flex; gap: 10px; transition: color .15s var(--ease-easy); }
.legal-toc a::before { counter-increment: toc; content: counter(toc, decimal-leading-zero); color: var(--logo-accent); font-weight: 600; }
.legal-toc a:hover { color: var(--fg-1); }

/* ── Functional footer for subpages ──────────────────── */
.sub-footer { background: var(--ecmi); color: #fff; }
.sub-footer .wrap { padding-block: clamp(48px, 7vh, 80px); }
.sf-grid {
  display: grid; grid-template-columns: 1.6fr 1fr 1fr 1.1fr; gap: clamp(28px, 4vw, 56px);
  align-items: start;
}
@media (max-width: 900px) { .sf-grid { grid-template-columns: 1fr 1fr; gap: 36px 32px; } .sf-brand { grid-column: 1 / -1; } }
@media (max-width: 520px) { .sf-grid { grid-template-columns: 1fr; gap: 32px; } }

.sf-brand .brand-mark { color: #fff; }
.sf-brand p {
  font: var(--type-body2); color: rgba(255,255,255,.62); line-height: 1.6;
  margin: 18px 0 0; max-width: 36ch;
}
.sf-socials { display: flex; gap: 10px; margin-top: 22px; }
.sf-socials a {
  width: 38px; height: 38px; border-radius: 10px; display: grid; place-items: center;
  color: rgba(255,255,255,.78); border: 1px solid rgba(255,255,255,.18);
  transition: color .16s var(--ease-easy), border-color .16s var(--ease-easy), background .16s var(--ease-easy), transform .16s var(--ease-decelerate);
}
.sf-socials a:hover { color: #fff; background: rgba(255,255,255,.1); border-color: rgba(255,255,255,.4); transform: translateY(-2px); }
.sf-socials a svg { width: 18px; height: 18px; }

.sf-col h5 {
  font: var(--type-caption1-strong); text-transform: uppercase; letter-spacing: .12em;
  color: rgba(255,255,255,.5); margin: 0 0 16px;
}
.sf-col ul { list-style: none; margin: 0; padding: 0; display: grid; gap: 11px; }
.sf-col a, .sf-col span.txt { font: var(--type-body2); color: rgba(255,255,255,.74); transition: color .15s var(--ease-easy); }
.sf-col a { display: inline-flex; align-items: center; gap: 9px; white-space: nowrap; }
.sf-col a.wrap { white-space: normal; }
.sf-col a:hover { color: #fff; }
.sf-col a .sw { width: 8px; height: 8px; border-radius: 2.5px; background: var(--c, #fff); flex: none; }
.sf-col .ct { display: flex; gap: 10px; align-items: flex-start; color: rgba(255,255,255,.74); font: var(--type-body2); line-height: 1.45; }
.sf-col .ct svg { width: 17px; height: 17px; flex: none; margin-top: 2px; color: rgba(255,255,255,.55); }
.sf-col .ct a { display: inline; gap: 0; }

.sf-bottom {
  margin-top: clamp(36px, 5vh, 56px); padding-top: 24px;
  border-top: 1px solid rgba(255,255,255,.14);
  display: flex; align-items: center; justify-content: space-between; gap: 16px 24px; flex-wrap: wrap;
}
.sf-bottom .cp { font: var(--type-caption1); color: rgba(255,255,255,.5); }
.sf-bottom .legal { display: flex; flex-wrap: wrap; gap: 6px 20px; }
.sf-bottom .legal a { font: var(--type-caption1); color: rgba(255,255,255,.6); transition: color .15s var(--ease-easy); }
.sf-bottom .legal a:hover { color: #fff; }
.sf-top-link {
  display: inline-flex; align-items: center; gap: 7px; font: var(--type-caption1-strong);
  color: rgba(255,255,255,.7); transition: color .15s var(--ease-easy);
}
.sf-top-link:hover { color: #fff; }
.sf-top-link svg { width: 14px; height: 14px; }

/* ── Contact page ────────────────────────────────────── */
.contact-hero { padding-top: clamp(48px, 8vh, 96px); padding-bottom: clamp(20px, 3vh, 34px); }
.contact-hero h1 { font: var(--type-large-title); font-size: clamp(34px, 5vw, 58px); letter-spacing: -0.04em; color: var(--fg-1); margin: 18px 0 0; text-wrap: balance; }
.contact-hero p { font: var(--type-subtitle1); font-weight: 400; color: var(--fg-2); margin: 16px 0 0; max-width: 54ch; line-height: 1.5; }

.contact-grid {
  display: grid; grid-template-columns: 0.92fr 1.08fr; gap: clamp(28px, 4vw, 60px);
  padding-bottom: clamp(56px, 9vh, 104px); align-items: start;
}
@media (max-width: 860px) { .contact-grid { grid-template-columns: 1fr; gap: 36px; } }

.contact-info .ci-label { font: var(--type-caption1-strong); text-transform: uppercase; letter-spacing: .12em; color: var(--fg-4); }
.method { display: flex; gap: 15px; align-items: flex-start; padding: 18px 0; border-bottom: 1px solid var(--stroke-subtle); }
.method:first-of-type { padding-top: 22px; }
.method .mi {
  width: 44px; height: 44px; border-radius: 12px; flex: none; display: grid; place-items: center;
  color: var(--logo-accent); background: color-mix(in srgb, var(--logo-accent) 12%, var(--bg-3));
}
.method .mi svg { width: 22px; height: 22px; }
.method .mt b { display: block; font: var(--type-body1-strong); color: var(--fg-1); }
.method .mt a, .method .mt span { font: var(--type-body2); color: var(--fg-3); }
.method .mt a:hover { color: var(--logo-accent); }
.contact-socials { display: flex; gap: 10px; margin-top: 24px; }
.contact-socials a { width: 42px; height: 42px; border-radius: 11px; display: grid; place-items: center; color: var(--fg-2); border: 1px solid var(--stroke-1); transition: all .18s var(--ease-easy); }
.contact-socials a:hover { color: var(--logo-accent); border-color: var(--logo-accent); transform: translateY(-2px); }
.contact-socials a svg { width: 19px; height: 19px; }

.contact-form-wrap { background: var(--ecmi); border-radius: 22px; padding: clamp(26px, 3vw, 40px); }
.contact-form-wrap h2 { font: var(--type-title3); letter-spacing: -0.02em; color: #fff; margin: 0; }
.contact-form-wrap .ch-sub { font: var(--type-body2); color: rgba(255,255,255,.65); margin: 10px 0 0; }
.contact-form-wrap .form2 {
  background: none; border: none; padding: 0; -webkit-backdrop-filter: none; backdrop-filter: none;
  margin-top: 22px; max-width: none;
}
.contact-form-wrap .f2-accent { display: none; }

/* light company strip on contact page */
.contact-extra { background: var(--bg-2); border-top: 1px solid var(--stroke-subtle); }
.contact-extra .wrap { padding-block: clamp(40px, 6vh, 72px); display: grid; grid-template-columns: 1fr 1fr; gap: clamp(28px, 5vw, 60px); align-items: stretch; }
@media (max-width: 820px) { .contact-extra .wrap { grid-template-columns: 1fr; } }
.contact-extra h5 { font: var(--type-caption1-strong); text-transform: uppercase; letter-spacing: .1em; color: var(--fg-4); margin: 0 0 16px; }
.contact-extra .cname { font: var(--type-subtitle1); letter-spacing: -0.02em; color: var(--fg-1); }
.contact-extra dl { margin: 16px 0 0; display: grid; grid-template-columns: auto 1fr; gap: 10px 18px; }
.contact-extra dt { font: var(--type-body2); color: var(--fg-4); }
.contact-extra dd { margin: 0; font: var(--type-body2); color: var(--fg-1); }
.contact-extra dd a { color: var(--logo-accent); }
.contact-extra .map-card { min-height: 260px; }

/* ── About page ──────────────────────────────────────── */
.about-hero { padding-top: clamp(48px, 8vh, 96px); padding-bottom: clamp(8px, 2vh, 20px); }
.about-hero h1 { font: var(--type-large-title); font-size: clamp(36px, 5.4vw, 62px); letter-spacing: -0.04em; line-height: 1.04; color: var(--fg-1); margin: 18px 0 0; max-width: 18ch; text-wrap: balance; }
.about-hero .lead { font: var(--type-subtitle1); font-weight: 400; color: var(--fg-2); margin: 22px 0 0; max-width: 60ch; line-height: 1.5; }

.about-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(18px, 3vw, 40px); margin-top: clamp(40px, 6vh, 64px); padding-top: clamp(32px, 4vh, 44px); border-top: 1px solid var(--stroke-subtle); }
@media (max-width: 700px) { .about-stats { grid-template-columns: 1fr 1fr; gap: 26px; } }
.about-stats .n { font: var(--type-title1); font-size: clamp(28px, 4vw, 44px); letter-spacing: -0.04em; color: var(--fg-1); font-variant-numeric: tabular-nums; line-height: 1; }
.about-stats .n .u { color: var(--c-ksefv); }
.about-stats .l { font: var(--type-body2); color: var(--fg-3); margin-top: 10px; line-height: 1.4; }

.story { max-width: 720px; }
.story > * + * { margin-top: 1.3em; }
.story p { font: var(--type-body1); color: var(--fg-2); line-height: 1.72; }
.story p.lead-p { font: var(--type-subtitle1); font-weight: 400; color: var(--fg-1); line-height: 1.5; }
.story strong { color: var(--fg-1); font-weight: 600; }

.values { margin-top: clamp(36px, 5vh, 56px); display: grid; grid-template-columns: repeat(2, 1fr); gap: clamp(16px, 2vw, 22px); }
@media (max-width: 640px) { .values { grid-template-columns: 1fr; } }
.value {
  display: flex; gap: 18px; align-items: flex-start; background: var(--bg-1);
  border: 1px solid var(--stroke-2); border-radius: var(--card-radius); padding: 26px 24px;
  transition: transform .26s var(--ease-decelerate), box-shadow .26s var(--ease-easy), border-color .26s var(--ease-easy);
}
.value:hover { transform: translateY(-4px); box-shadow: var(--shadow-8); border-color: var(--stroke-1); }
.value .vi { width: 46px; height: 46px; flex: none; border-radius: 12px; display: grid; place-items: center; color: #fff; }
.value .vi svg { width: 24px; height: 24px; }
.value h3 { font: var(--type-subtitle2); letter-spacing: -0.01em; color: var(--fg-1); margin: 2px 0 0; }
.value p { font: var(--type-body2); color: var(--fg-3); line-height: 1.55; margin: 9px 0 0; }
.note-ph { font: var(--type-caption1); color: var(--fg-4); margin-top: 18px; font-style: italic; }
