/* =========================================================
   Alsec — site styles
   Tokens from assets/colors_and_type.css
   ========================================================= */
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; background: var(--bg-1); color: var(--ink-900); font-family: var(--font-sans); -webkit-font-smoothing: antialiased; }
img { max-width: 100%; display: block; }

.wrap { max-width: 1184px; margin: 0 auto; padding: 0 48px; }

/* ---------- Atoms ---------- */
.rule { width: 32px; height: 1px; background: var(--ink-900); }
.rule--orange { background: var(--color-orange); }

.eyebrow { font: 500 12px/1 var(--font-sans); letter-spacing: var(--tracking-eyebrow); text-transform: uppercase; color: var(--fg-3); display: inline-block; }
.eyebrow--orange { color: var(--color-orange); }

.btn { font: 500 15px/1 var(--font-sans); padding: 16px 24px; border-radius: 2px; cursor: pointer; border: 1.5px solid transparent; text-decoration: none; display: inline-flex; align-items: center; justify-content: space-between; gap: 14px; transition: background var(--dur-base) var(--ease-out), color var(--dur-base) var(--ease-out), border-color var(--dur-base) var(--ease-out); }
.btn__arrow { font-size: 18px; line-height: 1; }
.btn--primary { background: var(--color-orange); color: #fff; }
.btn--primary:hover { background: var(--color-orange-600); }
.btn--primary:active { background: var(--color-orange-700); }
.btn--secondary { background: transparent; color: var(--ink-900); border-color: var(--ink-900); }
.btn--secondary:hover { background: var(--ink-900); color: #fff; }
.btn--ghost { background: transparent; color: var(--ink-900); padding: 6px 0; border: none; gap: 8px; }
.btn--ghost:hover { color: var(--color-orange); }
.btn--portal { background: transparent; color: var(--ink-900); border-color: var(--ink-200); white-space: nowrap; }
.btn--portal:hover { border-color: var(--ink-900); }
.btn--portal .btn__arrow { font-size: 16px; }
.btn--on-dark { color: #fff; }
.btn--block { width: 100%; }
.btn:focus-visible { outline: 2px solid var(--color-orange); outline-offset: 3px; }

.section { padding: 112px 0; border-bottom: var(--border-hair); }
.section--tight { padding: 80px 0; }
.section--paper { background: var(--bg-2); }
.section--dark { background: var(--ink-900); color: #fff; border-bottom: none; }

.head { display: flex; flex-direction: column; align-items: flex-start; gap: 14px; margin-bottom: 56px; max-width: 760px; }
.head__title { font: 600 clamp(30px, 3.6vw, 48px)/1.08 var(--font-sans); letter-spacing: -0.02em; margin: 0; text-wrap: balance; }
.head__title em { font-style: normal; color: var(--color-orange); }
.head__lead { font: 400 18px/1.55 var(--font-sans); color: var(--fg-2); margin: 0; max-width: 52ch; }

/* ---------- Header ---------- */
.header { position: sticky; top: 0; z-index: 40; background: rgba(255,255,255,0.85); backdrop-filter: saturate(140%) blur(12px); border-bottom: var(--border-hair); }
.header .wrap { max-width: none; padding: 0 28px; }
.header__inner { height: 76px; display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.header__logo { display: flex; align-items: center; }
.header__logo img { height: 34px; display: block; }
.header__nav { display: flex; gap: 28px; flex: 1; justify-content: center; }
.header__link { font: 500 14px/1 var(--font-sans); color: var(--ink-700); text-decoration: none; padding: 28px 0; position: relative; white-space: nowrap; transition: color var(--dur-fast) var(--ease-out); }
.header__link:hover { color: var(--ink-900); }
.header__link::after { content:""; position: absolute; left: 0; right: 0; bottom: -1px; height: 2px; background: var(--color-orange); transform: scaleX(0); transform-origin: left; transition: transform var(--dur-base) var(--ease-out); }
.header__link:hover::after { transform: scaleX(1); }
.header__cta { display: flex; align-items: center; gap: 10px; }
.header__cta .btn { height: 44px; padding: 0 16px; justify-content: center; gap: 0; font-size: 14px; white-space: nowrap; }
.header__cta .btn--primary { padding: 0 20px; }
.header__cta .btn__arrow { display: none; }
.header__burger { display: none; background: none; border: none; cursor: pointer; padding: 8px; }
.header__burger span { display: block; width: 22px; height: 2px; background: var(--ink-900); margin: 4px 0; }

/* ---------- Hero ---------- */
.hero { background: var(--bg-2); padding: 80px 0 0; overflow: hidden; }
.hero__inner { display: grid; grid-template-columns: 1.05fr 1fr; gap: 56px; align-items: center; }
.hero__title { font: 600 clamp(44px, 5.4vw, 80px)/1.02 var(--font-sans); letter-spacing: -0.035em; margin: 22px 0 26px; text-wrap: balance; }
.hero__title em { font-style: normal; color: var(--color-orange); }
.hero__lead { font: 400 19px/1.55 var(--font-sans); color: var(--fg-2); max-width: 46ch; margin: 0 0 32px; }
.hero__stat { display: flex; align-items: baseline; gap: 14px; padding-top: 28px; margin-top: 8px; border-top: 1px solid var(--ink-900); }
.hero__stat-num { font: 600 48px/1 var(--font-sans); letter-spacing: -0.03em; }
.hero__stat-label { font: 500 13px/1.3 var(--font-sans); color: var(--fg-3); max-width: 12ch; }
.hero__media { position: relative; align-self: stretch; }
.hero__media image-slot { width: 100%; height: 100%; min-height: 460px; }
.hero__img { width: 100%; height: 100%; min-height: 460px; object-fit: cover; }
.hero__pill { position: absolute; left: 24px; bottom: 24px; background: rgba(31,28,24,0.78); backdrop-filter: blur(8px); color: #fff; font: 500 12px/1 var(--font-sans); letter-spacing: var(--tracking-eyebrow); text-transform: uppercase; padding: 12px 16px; }

/* ---------- Dual CTA banner ---------- */
.cta-banner { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; padding: 28px 0 0; }
.cta-card { display: flex; align-items: center; justify-content: space-between; gap: 20px; padding: 26px 28px; text-decoration: none; border: 1.5px solid var(--ink-900); transition: background var(--dur-base) var(--ease-out), color var(--dur-base) var(--ease-out); }
.cta-card span { font: 600 19px/1.25 var(--font-sans); letter-spacing: -0.01em; }
.cta-card .btn__arrow { font-size: 22px; }
.cta-card--ghost { color: var(--ink-900); }
.cta-card--ghost:hover { background: var(--ink-900); color: #fff; }
.cta-card--solid { background: var(--color-orange); border-color: var(--color-orange); color: #fff; }
.cta-card--solid:hover { background: var(--color-orange-600); border-color: var(--color-orange-600); }

/* ---------- Audience split ---------- */
.audience { display: grid; grid-template-columns: 1fr 1fr; gap: 0; border: var(--border-hair); }
.audience__col { padding: 44px 40px; background: #fff; display: flex; flex-direction: column; gap: 16px; }
.audience__col:first-child { border-right: var(--border-hair); }
.audience__col h3 { font: 600 28px/1.12 var(--font-sans); letter-spacing: -0.015em; margin: 6px 0 0; }
.audience__col h3 em { font-style: normal; color: var(--color-orange); }
.audience__col p { font: 400 15px/1.6 var(--font-sans); color: var(--fg-2); margin: 0; max-width: 44ch; }
.audience__col .btn { margin-top: 10px; align-self: flex-start; }

/* ---------- Services ---------- */
.services__grid { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: 64px; align-items: start; }
.services__list { display: flex; flex-direction: column; gap: 10px; }
.service-row { display: flex; align-items: center; justify-content: space-between; gap: 20px; padding: 22px 24px; background: var(--color-orange); color: #fff; text-decoration: none; transition: background var(--dur-base) var(--ease-out), transform var(--dur-base) var(--ease-out); }
.service-row:hover { background: var(--color-orange-600); }
.service-row__label { display: flex; align-items: center; gap: 18px; }
.service-row__num { font-family: var(--font-mono); font-size: 12px; opacity: 0.7; min-width: 22px; }
.service-row__name { font: 600 18px/1.2 var(--font-sans); letter-spacing: -0.01em; }
.service-row__arrow { font-size: 20px; transition: transform var(--dur-base) var(--ease-out); }
.service-row:hover .service-row__arrow { transform: translateX(5px); }

/* ---------- Stats / trust ---------- */
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px; }
.stat { display: flex; flex-direction: column; gap: 10px; padding-top: 18px; border-top: 1px solid var(--ink-900); }
.stat__num { font: 600 clamp(36px, 4vw, 52px)/1 var(--font-sans); letter-spacing: -0.03em; }
.stat__label { font: 400 13px/1.45 var(--font-sans); color: var(--fg-3); max-width: 18ch; }
.logos { display: flex; flex-wrap: wrap; align-items: center; gap: 18px; margin-top: 56px; padding-top: 40px; border-top: var(--border-hair); }
.logos__label { font: 500 12px/1 var(--font-sans); letter-spacing: var(--tracking-eyebrow); text-transform: uppercase; color: var(--fg-3); margin-right: 8px; }
.logo-chip { font: 600 16px/1 var(--font-sans); letter-spacing: 0.02em; color: var(--ink-500); padding: 12px 18px; border: var(--border-hair); }

/* ---------- Vision (two-col text) ---------- */
.vision { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: start; }
.vision__title { font: 600 clamp(30px, 3.4vw, 44px)/1.08 var(--font-sans); letter-spacing: -0.02em; margin: 16px 0 0; text-wrap: balance; }
.vision__title em { font-style: normal; color: var(--color-orange); }
.vision__body { display: flex; flex-direction: column; gap: 18px; }
.vision__body p { font: 400 17px/1.6 var(--font-sans); color: var(--fg-2); margin: 0; }

/* ---------- Durable / accordion ---------- */
.durable { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: 64px; align-items: start; }
.durable__media image-slot { width: 100%; height: 100%; min-height: 360px; }
.durable__img { width: 100%; height: 100%; min-height: 360px; object-fit: cover; }
.durable__intro h2 { font: 600 clamp(28px, 3.2vw, 40px)/1.1 var(--font-sans); letter-spacing: -0.02em; margin: 14px 0 18px; text-wrap: balance; }
.durable__intro h2 em { font-style: normal; color: var(--color-orange); }
.durable__intro p { font: 400 16px/1.6 var(--font-sans); color: var(--fg-2); margin: 0; max-width: 42ch; }
.accordion { border-top: var(--border-hair); margin-top: 8px; }
.acc-item { border-bottom: var(--border-hair); }
.acc-trigger { width: 100%; background: none; border: none; cursor: pointer; display: flex; align-items: center; gap: 16px; padding: 22px 0; text-align: left; font: 500 18px/1.3 var(--font-sans); color: var(--ink-900); }
.acc-trigger .acc-check { color: var(--color-orange); font-size: 18px; }
.acc-trigger .acc-sign { margin-left: auto; font-size: 22px; color: var(--fg-3); transition: transform var(--dur-base) var(--ease-out); font-weight: 300; }
.acc-item.is-open .acc-sign { transform: rotate(45deg); }
.acc-panel { overflow: hidden; max-height: 0; transition: max-height var(--dur-slow) var(--ease-out); }
.acc-panel__inner { padding: 0 0 24px 34px; font: 400 15px/1.6 var(--font-sans); color: var(--fg-2); max-width: 56ch; }

/* ---------- Engagements ---------- */
.engage__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; border: var(--border-hair); }
.engage-card { padding: 32px 26px 28px; display: flex; flex-direction: column; gap: 12px; min-height: 230px; border-right: var(--border-hair); }
.engage-card:last-child { border-right: none; }
.engage-card:nth-child(1) { background: #fff; }
.engage-card:nth-child(2) { background: #FDF6EF; }
.engage-card:nth-child(3) { background: #FBEADB; }
.engage-card:nth-child(4) { background: var(--color-skin); }
.engage-card__num { font: 600 34px/1 var(--font-sans); letter-spacing: -0.03em; color: var(--color-orange); opacity: 0.85; }
.engage-card__title { font: 600 18px/1.2 var(--font-sans); letter-spacing: -0.01em; margin: 8px 0 0; }
.engage-card__body { font: 400 14px/1.55 var(--font-sans); color: var(--fg-2); margin: 0; }

/* ---------- Clients ---------- */
.clients__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 48px; }
.client-card { border: var(--border-hair); border-top: 2px solid var(--color-orange); padding: 28px 26px; background: #fff; }
.client-card h4 { font: 600 18px/1.2 var(--font-sans); margin: 0 0 10px; }
.client-card p { font: 400 14px/1.55 var(--font-sans); color: var(--fg-2); margin: 0; }

/* ---------- Quote band ---------- */
.quote__inner { display: grid; grid-template-columns: 1.3fr 1fr; gap: 72px; align-items: center; }
.quote__text { font: 500 clamp(24px, 2.8vw, 36px)/1.3 var(--font-sans); letter-spacing: -0.015em; color: #fff; margin: 20px 0 0; text-wrap: balance; }
.quote__text span { color: var(--color-orange); }
.quote__aside h3 { font: 500 13px/1 var(--font-sans); letter-spacing: var(--tracking-eyebrow); text-transform: uppercase; color: var(--color-steel); margin: 0 0 14px; }
.quote__aside p { font: 400 16px/1.6 var(--font-sans); color: var(--color-steel); margin: 0 0 28px; }
.quote__actions { display: flex; flex-direction: column; gap: 12px; }

/* ---------- Contact ---------- */
.contact__inner { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: start; }
.contact__title { font: 600 clamp(32px, 3.6vw, 52px)/1.06 var(--font-sans); letter-spacing: -0.02em; margin: 16px 0 22px; color: #fff; text-wrap: balance; }
.contact__lead { font: 400 18px/1.55 var(--font-sans); color: var(--color-steel); max-width: 38ch; margin: 0 0 40px; }
.contact__details { display: flex; flex-direction: column; gap: 0; margin: 0; }
.contact__details > div { display: grid; grid-template-columns: 96px 1fr; gap: 16px; padding: 18px 0; border-bottom: 1px solid rgba(255,255,255,0.12); }
.contact__details dt { font: 500 12px/1.3 var(--font-sans); letter-spacing: var(--tracking-eyebrow); text-transform: uppercase; color: var(--color-orange); margin: 0; }
.contact__details dd { font: 400 16px/1.4 var(--font-sans); color: #fff; margin: 0; }
.contact__details a { color: #fff; text-decoration: none; }
.contact__details a:hover { color: var(--color-orange); }

.form { display: flex; flex-direction: column; gap: 18px; background: #fff; color: var(--ink-900); padding: 36px; }
.form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.field { display: flex; flex-direction: column; gap: 8px; }
.field label { font: 500 12px/1 var(--font-sans); letter-spacing: var(--tracking-eyebrow); text-transform: uppercase; color: var(--fg-2); }
.field input, .field textarea, .field select { font: 400 15px/1.4 var(--font-sans); font-family: var(--font-sans); color: var(--ink-900); background: #fff; border: 1px solid var(--ink-200); border-radius: 2px; padding: 13px 14px; outline: none; transition: border-color var(--dur-base) var(--ease-out); width: 100%; }
.field input:focus, .field textarea:focus, .field select:focus { border-color: var(--ink-900); }
.field input::placeholder, .field textarea::placeholder { color: var(--fg-mute); }
.form__consent { display: flex; gap: 10px; align-items: flex-start; font: 400 12px/1.5 var(--font-sans); color: var(--fg-3); }
.form__consent input { width: 16px; height: 16px; margin-top: 2px; flex-shrink: 0; accent-color: var(--color-orange); }
.form .btn { align-self: flex-start; margin-top: 4px; }
.form__note { font: 400 12px/1.4 var(--font-sans); color: var(--fg-mute); }
.form-success { background: #fff; color: var(--ink-900); padding: 44px 36px; }
.form-success h3 { font: 600 28px/1.12 var(--font-sans); letter-spacing: -0.02em; margin: 14px 0 12px; }
.form-success p { font: 400 16px/1.6 var(--font-sans); color: var(--fg-2); margin: 0; }
.form-success .btn { margin-top: 22px; color: var(--ink-900); }
.is-hidden { display: none !important; }

/* ---------- FAQ ---------- */
.faq__grid { display: grid; grid-template-columns: 0.6fr 1.4fr; gap: 64px; align-items: start; }

/* ---------- Footer ---------- */
.footer { background: var(--ink-900); color: #fff; padding: 72px 0 0; }
.footer__top { display: grid; grid-template-columns: 1.1fr 1fr 1fr; gap: 48px; padding-bottom: 48px; border-bottom: 1px solid rgba(255,255,255,0.1); }
.footer__contact { display: flex; flex-direction: column; gap: 8px; }
.footer__phone { font: 600 30px/1 var(--font-sans); letter-spacing: -0.02em; color: #fff; text-decoration: none; }
.footer__phone:hover { color: var(--color-orange); }
.footer__addr { font: 400 14px/1.6 var(--font-sans); color: var(--color-steel); margin: 8px 0 0; }
.footer__addr strong { color: #fff; font-weight: 500; }
.footer__col .eyebrow { color: var(--color-orange); margin-bottom: 14px; }
.footer__col { display: flex; flex-direction: column; gap: 10px; }
.footer__col a { font: 400 14px/1.5 var(--font-sans); color: #fff; text-decoration: none; }
.footer__col a:hover { color: var(--color-orange); }
.footer__social { display: flex; gap: 12px; margin-top: 6px; }
.footer__social a { width: 40px; height: 40px; border: 1px solid rgba(255,255,255,0.2); display: flex; align-items: center; justify-content: center; color: #fff; transition: background var(--dur-base) var(--ease-out), border-color var(--dur-base) var(--ease-out); }
.footer__social a:hover { background: var(--color-orange); border-color: var(--color-orange); }
.footer__brand { padding: 40px 0; display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; }
.footer__wordmark { height: 64px; }
.footer__legal { font: 400 12px/1.6 var(--font-sans); color: var(--color-steel); max-width: 40ch; text-align: right; }

/* ---------- Responsive ---------- */
@media (max-width: 1024px) {
  .header__nav { display: none; }
  .header__burger { display: block; }
  .header__cta .btn--primary { display: none; }
}
@media (max-width: 920px) {
  .wrap { padding: 0 24px; }
  .section { padding: 72px 0; }
  .hero { padding: 48px 0 0; }
  .hero__inner, .services__grid, .vision, .durable, .quote__inner, .contact__inner, .faq__grid { grid-template-columns: 1fr; gap: 36px; }
  .cta-banner, .audience, .stats, .engage__grid, .clients__grid, .footer__top { grid-template-columns: 1fr; }
  .stats { gap: 0; }
  .stat { padding: 18px 0; }
  .audience__col:first-child { border-right: none; border-bottom: var(--border-hair); }
  .engage-card { border-right: none; border-bottom: var(--border-hair); min-height: 0; }
  .engage-card:last-child { border-bottom: none; }
  .hero__media image-slot, .durable__media image-slot,
  .hero__img, .durable__img { min-height: 300px; }
  .form__row { grid-template-columns: 1fr; }
  .footer__brand { flex-direction: column; align-items: flex-start; }
  .footer__legal { text-align: left; }
  .footer__wordmark { height: 44px; }
}
