.container { width: min(calc(100% - var(--space-8)), var(--container)); margin-inline: auto; }
.container--wide { width: min(calc(100% - var(--space-8)), var(--container-wide)); margin-inline: auto; }
.eyebrow { font-family: var(--font-ui); font-size: var(--text-eyebrow); font-weight: var(--weight-bold); letter-spacing: .18em; text-transform: uppercase; color: var(--color-lavender); }
.asterisk { color: var(--color-accent); font-family: var(--font-ui); }
.section-head { display: grid; gap: var(--space-4); max-width: 760px; margin-bottom: var(--space-10); }
.section-head--center { margin-inline: auto; text-align: center; }
.site-header { position: fixed; top: 0; left: 0; right: 0; z-index: 50; }
.promo { background: var(--color-accent); color: var(--color-background); font-family: var(--font-ui); font-weight: var(--weight-bold); font-size: var(--text-caption); }
.promo__inner { display: flex; justify-content: center; align-items: center; gap: var(--space-2); min-height: 36px; }
.navbar { background: var(--color-nav-glass); border-bottom: 1px solid var(--color-border); backdrop-filter: blur(18px); }
.navbar__inner { min-height: 72px; display: flex; align-items: center; justify-content: space-between; gap: var(--space-4); }
.brand { display: inline-flex; align-items: center; gap: var(--space-3); font-family: var(--font-ui); font-weight: var(--weight-bold); letter-spacing: -.02em; }
.brand__mark { width: 34px; height: 34px; background: var(--color-accent); border: 1px solid var(--color-border-strong); }
.navbar__links { display: none; align-items: center; gap: var(--space-5); font-family: var(--font-ui); font-size: var(--text-caption); color: var(--color-text-muted); }
.navbar__links a[aria-current="page"] { color: var(--color-text); }
.navbar__actions { display: flex; align-items: center; gap: var(--space-3); }
.menu-button { display: inline-grid; place-items: center; width: 42px; height: 42px; background: var(--color-transparent); border: 1px solid var(--color-border); border-radius: var(--radius-pill); }
.menu-button__line, .menu-button__line::before, .menu-button__line::after { content: ""; display: block; width: 18px; height: 1px; background: var(--color-text); transition: transform var(--duration-fast) var(--ease-out); }
.menu-button__line::before { transform: translateY(-6px); }
.menu-button__line::after { transform: translateY(5px); }
.mobile-panel { display: none; background: var(--color-mobile-panel); border-bottom: 1px solid var(--color-border); padding: var(--space-4); }
.mobile-panel.is-open { display: block; }
.mobile-panel a { display: block; padding: var(--space-4); border-bottom: 1px solid var(--color-border); color: var(--color-text-muted); }
.button { display: inline-flex; align-items: center; justify-content: center; gap: var(--space-2); min-height: 44px; padding: var(--space-3) var(--space-5); border-radius: var(--radius-pill); border: 1px solid var(--color-transparent); font-family: var(--font-ui); font-weight: var(--weight-bold); transition: transform var(--duration-fast) var(--ease-out), background var(--duration-fast) var(--ease-out), border-color var(--duration-fast) var(--ease-out); }
.button:hover { transform: translateY(-1px); }
.button:active { transform: translateY(0); }
.button--primary { background: var(--color-primary); color: var(--color-background); }
.button--primary:hover { background: var(--color-primary-hover); color: var(--color-background); }
.button--secondary { border-color: var(--color-border-strong); background: var(--color-transparent); color: var(--color-text); }
.button--secondary:hover { border-color: var(--color-primary); color: var(--color-text); }
.button--tertiary { padding-inline: 0; background: var(--color-transparent); color: var(--color-lavender); }
.button--loading { position: relative; color: var(--color-transparent); }
.button--loading::after { content: ""; width: 16px; height: 16px; border: 2px solid var(--color-background); border-top-color: var(--color-transparent); animation: spin 900ms linear infinite; }
.hero { min-height: 100svh; display: grid; align-items: center; padding-top: 132px; }
.hero__grid { display: grid; gap: var(--space-8); }
.hero__visual { position: relative; min-height: 360px; border: 1px solid var(--color-border); background: var(--color-surface); overflow: hidden; }
.hero__image { width: 100%; height: 100%; min-height: 360px; object-fit: cover; display: block; }
.hero__visual--suite { padding: 0; }
.logo-suite { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; background: var(--color-border); height: 100%; min-height: 360px; }
.logo-suite img { width: 100%; height: 100%; object-fit: cover; display: block; background: var(--color-surface); }
.hero__visual::before { content: none; }
.hero__mark { position: absolute; inset: 0; display: grid; place-items: center; font-family: var(--font-ui); font-size: 7rem; color: var(--color-text); }
.hero__content { display: grid; align-content: center; gap: var(--space-6); min-width: 0; }
.hero__actions { display: flex; flex-wrap: wrap; gap: var(--space-3); }
.marquee { overflow: hidden; border-block: 1px solid var(--color-border); background: var(--color-background); }
.marquee__track { display: flex; gap: var(--space-8); width: max-content; animation: marquee 28s linear infinite; }
.logo-pill { min-width: 170px; padding: var(--space-4) var(--space-6); border: 1px solid var(--color-border); border-radius: var(--radius-pill); text-align: center; color: var(--color-text-muted); font-family: var(--font-ui); text-transform: uppercase; letter-spacing: .12em; font-size: var(--text-caption); }
.grid { display: grid; gap: var(--space-4); }
.grid > * { min-width: 0; }
.grid--2, .grid--3, .grid--4 { grid-template-columns: 1fr; }
.card { position: relative; display: grid; gap: var(--space-4); padding: var(--space-6); border: 1px solid var(--color-border); background: var(--color-surface); transition: border-color var(--duration-fast) var(--ease-out), transform var(--duration-fast) var(--ease-out), background var(--duration-fast) var(--ease-out); }
.card:hover { border-color: var(--color-border-strong); transform: translateY(-3px); background: var(--color-panel); }
.card--accent { background: var(--color-panel); border-color: var(--color-border-strong); }
.product-logo { width: 56px; height: 56px; border-radius: var(--radius-md); object-fit: cover; border: 1px solid var(--color-border); }
.stat { padding: var(--space-6); border-left: 1px solid var(--color-border); }
.stat__value { font-family: var(--font-display); font-size: clamp(2.4rem, 7vw, 4.8rem); line-height: 1; }
.process { counter-reset: step; display: grid; gap: var(--space-4); }
.process__item { counter-increment: step; padding: var(--space-6); border: 1px solid var(--color-border); border-radius: var(--radius-lg); background: var(--color-surface); }
.process__item::before { content: counter(step, decimal-leading-zero); display: block; margin-bottom: var(--space-4); color: var(--color-accent); font-family: var(--font-ui); font-size: var(--text-caption); letter-spacing: .14em; }
.panel-ui { min-height: 280px; border: 1px solid var(--color-border); background: var(--color-surface); padding: var(--space-5); overflow: hidden; }
.panel-ui__bar { height: 12px; width: 42%; border-radius: var(--radius-pill); background: var(--color-border-strong); margin-bottom: var(--space-4); }
.panel-ui__rows { display: grid; gap: var(--space-3); }
.panel-ui__row { height: 38px; background: var(--color-panel); border: 1px solid var(--color-border); }
.badge { display: inline-flex; width: fit-content; align-items: center; gap: var(--space-2); padding: var(--space-2) var(--space-3); border: 1px solid var(--color-border); border-radius: var(--radius-pill); color: var(--color-lavender); font-family: var(--font-ui); font-size: var(--text-caption); }
.accordion { display: grid; gap: var(--space-3); }
.accordion__item { border: 1px solid var(--color-border); border-radius: var(--radius-lg); background: var(--color-surface); overflow: hidden; }
.accordion__button { width: 100%; display: flex; justify-content: space-between; gap: var(--space-4); padding: var(--space-5); background: var(--color-transparent); border: 0; text-align: left; }
.accordion__panel { display: none; padding: 0 var(--space-5) var(--space-5); }
.accordion__item.is-open .accordion__panel { display: block; }
.form { display: grid; gap: var(--space-4); }
.form__field { display: grid; gap: var(--space-2); }
.form label { font-family: var(--font-ui); font-size: var(--text-caption); color: var(--color-lavender); }
.form input, .form textarea, .form select { width: 100%; border: 1px solid var(--color-border); border-radius: var(--radius-md); background: var(--color-surface); padding: var(--space-3) var(--space-4); }
.form input[aria-invalid="true"], .form textarea[aria-invalid="true"] { border-color: var(--color-error); }
.form__error { min-height: 1.2em; color: var(--color-error); font-size: var(--text-caption); }
.alert { padding: var(--space-4); border-radius: var(--radius-md); border: 1px solid var(--color-border); background: var(--color-surface); }
.alert--success { border-color: var(--color-success); }
.alert--error { border-color: var(--color-error); }
.tabs { display: grid; gap: var(--space-5); }
.tabs__list { display: flex; flex-wrap: wrap; gap: var(--space-2); }
.tabs__button { border: 1px solid var(--color-border); border-radius: var(--radius-pill); background: var(--color-transparent); padding: var(--space-2) var(--space-4); }
.tabs__button[aria-selected="true"] { background: var(--color-primary); color: var(--color-background); }
.tooltip { border-bottom: 1px dotted var(--color-lavender); }
.cta { text-align: center; background: var(--color-surface); }
.cta .hero__actions { justify-content: center; }
.site-footer { position: relative; z-index: 2; border-top: 1px solid var(--color-border); background: var(--color-background); }
.footer__grid { display: grid; gap: var(--space-8); padding: var(--space-16) 0; }
.footer__links { display: grid; gap: var(--space-3); }
.footer__links a { color: var(--color-text-muted); }
.footer__bottom { display: flex; flex-wrap: wrap; justify-content: space-between; gap: var(--space-4); padding: var(--space-6) 0; border-top: 1px solid var(--color-border); color: var(--color-text-muted); font-size: var(--text-caption); }
.fade-up { opacity: 0; transform: translateY(16px); transition: opacity var(--duration-normal) var(--ease-out), transform var(--duration-normal) var(--ease-out); }
.fade-up.is-visible { opacity: 1; transform: translateY(0); }
.filterbar { display: flex; flex-wrap: wrap; gap: var(--space-3); margin-bottom: var(--space-6); }
.filterbar select { border: 1px solid var(--color-border); border-radius: var(--radius-pill); background: var(--color-surface); padding: var(--space-3) var(--space-4); }
@media (max-width: 767px) { .promo { display: none; } .hero { padding-top: 92px; } .navbar__actions .button--secondary { display: none; } .hero__grid > * { min-width: 0; } }
@media (min-width: 768px) { .grid--2 { grid-template-columns: repeat(2, minmax(0, 1fr)); } .grid--3 { grid-template-columns: repeat(2, minmax(0, 1fr)); } .footer__grid { grid-template-columns: 1.4fr repeat(3, 1fr); } }
@media (min-width: 1024px) { .navbar__links { display: flex; } .menu-button { display: none; } .hero__grid { grid-template-columns: 1fr 1fr; } .grid--3 { grid-template-columns: repeat(3, minmax(0, 1fr)); } .grid--4 { grid-template-columns: repeat(4, minmax(0, 1fr)); } .process { grid-template-columns: repeat(4, minmax(0, 1fr)); } }
@keyframes marquee { to { transform: translateX(-50%); } }
@keyframes drift { to { transform: rotate(16deg) scale(1.08); } }
@keyframes spin { to { transform: rotate(360deg); } }

/* ============ Per-page hero variants (flat) ============ */
.hero--center .hero__grid { grid-template-columns: 1fr; max-width: 960px; margin-inline: auto; text-align: center; justify-items: center; }
.hero--wide .hero__grid { grid-template-columns: 1fr; }
.hero--narrow .hero__grid { grid-template-columns: 1fr; max-width: 760px; margin-inline: auto; }
.hero__content { min-width: 0; }
.hero__kicker { display: block; font-family: var(--font-ui); font-size: var(--text-caption); color: var(--color-text-muted); }
.hero__stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--color-border); border: 1px solid var(--color-border); width: 100%; }
.hero__stats > div { background: var(--color-surface); padding: var(--space-5); }
.hero__stats .num { font-family: var(--font-display); font-size: clamp(2rem, 5vw, 3.4rem); line-height: 1; display: block; margin-bottom: var(--space-2); }
.hero__rows { display: grid; gap: 1px; background: var(--color-border); border: 1px solid var(--color-border); width: 100%; }
.hero__rows > div { background: var(--color-surface); padding: var(--space-4) var(--space-5); display: flex; justify-content: space-between; gap: var(--space-4); }
.hero__rows .k { color: var(--color-lavender); font-family: var(--font-ui); font-size: var(--text-caption); text-transform: uppercase; letter-spacing: .08em; }
.hero__rows .v { color: var(--color-text-muted); text-align: right; }
.hero__chips { display: flex; flex-wrap: wrap; gap: var(--space-2); }
.hero__chip { border: 1px solid var(--color-border); padding: var(--space-2) var(--space-4); font-family: var(--font-ui); font-size: var(--text-caption); color: var(--color-text-muted); }
.hero__chip--on { background: var(--color-primary); color: var(--color-background); border-color: var(--color-primary); }
.hero__band { width: 100%; display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--color-border); border: 1px solid var(--color-border); }
.hero__band img { width: 100%; aspect-ratio: 1/1; object-fit: cover; display: block; background: var(--color-surface); }
.hero__bignum { font-family: var(--font-display); font-size: clamp(5rem, 20vw, 13rem); line-height: .82; letter-spacing: -.05em; color: var(--color-text); }
.hero__meta { display: flex; flex-wrap: wrap; gap: var(--space-5); color: var(--color-text-muted); font-family: var(--font-ui); font-size: var(--text-caption); border-top: 1px solid var(--color-border); border-bottom: 1px solid var(--color-border); padding: var(--space-4) 0; }
.hero__labeled { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; background: var(--color-border); border: 1px solid var(--color-border); width: 100%; }
.hero__labeled figure { margin: 0; background: var(--color-surface); }
.hero__labeled img { width: 100%; height: 132px; object-fit: cover; display: block; }
.hero__labeled figcaption { padding: var(--space-3) var(--space-4); font-family: var(--font-ui); font-size: var(--text-caption); border-top: 1px solid var(--color-border); display: flex; justify-content: space-between; }
.hero__stack { display: grid; gap: 1px; background: var(--color-border); border: 1px solid var(--color-border); width: 100%; }
.hero__stack > div { background: var(--color-surface); padding: var(--space-4) var(--space-5); display: flex; gap: var(--space-4); align-items: baseline; }
.hero__stack .idx { font-family: var(--font-ui); color: var(--color-accent); font-size: var(--text-caption); min-width: 28px; }
.hero__list { display: grid; gap: 1px; background: var(--color-border); border: 1px solid var(--color-border); width: 100%; list-style: none; padding: 0; margin: 0; }
.hero__list li { background: var(--color-surface); padding: var(--space-4) var(--space-5); color: var(--color-text); }
.hero__seg { display: grid; gap: var(--space-3); }
.hero__seg .card { padding: var(--space-5); }
.hero__rule { width: 100%; height: 1px; background: var(--color-border); }
.hero__formcard { border: 1px solid var(--color-border); background: var(--color-surface); padding: var(--space-6); display: grid; gap: var(--space-4); width: 100%; }
.hero__bigmark { width: 100%; max-width: 320px; aspect-ratio: 1/1; object-fit: cover; border: 1px solid var(--color-border); display: block; }
.hero__feed { display: grid; gap: 1px; background: var(--color-border); border: 1px solid var(--color-border); width: 100%; }
.hero__feed article { background: var(--color-surface); padding: var(--space-5); display: grid; gap: var(--space-2); }
.hero__feed .tag { font-family: var(--font-ui); font-size: var(--text-eyebrow); text-transform: uppercase; letter-spacing: .14em; color: var(--color-accent); }
@media (min-width: 768px) { .hero__seg { grid-template-columns: repeat(3, 1fr); } .hero__stats { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 767px) { .hero__band, .hero__labeled { grid-template-columns: repeat(2, 1fr); } .hero__stats { grid-template-columns: 1fr; } }
