/* Marketing-site UI kit · component styles */

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; background: var(--bg); color: var(--fg); font-family: var(--font-sans); }
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }

.cm-page { overflow-x: hidden; }

/* ---------- Utility text ----------- */
.cm-eyebrow {
  font-family: var(--font-sans); font-weight: 600; font-size: 12px;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--fg-tertiary);
  margin-bottom: 8px;
}
.cm-h1 { font-family: var(--font-display); font-weight: 800; font-size: 56px; line-height: 1.05; letter-spacing: -0.02em; margin: 0 0 16px; color: var(--ink-950); }
.cm-h2 { font-family: var(--font-display); font-weight: 700; font-size: 38px; line-height: 1.15; letter-spacing: -0.01em; margin: 0 0 14px; color: var(--ink-900); }
.cm-lead { font-size: 17px; line-height: 1.6; color: var(--fg-secondary); margin: 0 0 18px; max-width: 56ch; }
.cm-body { font-size: 16px; line-height: 1.6; color: var(--fg); margin: 0 0 18px; max-width: 60ch; }
.cm-small { font-size: 14px; color: var(--fg-tertiary); margin: 0; }

/* ---------- Buttons ----------- */
.cm-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  padding: 13px 26px; border-radius: 999px;
  font-family: var(--font-sans); font-weight: 700; font-size: 13px;
  letter-spacing: 0.06em; text-transform: uppercase;
  border: none; cursor: pointer; user-select: none;
  transition: transform 160ms cubic-bezier(.2,.7,.2,1), background 160ms, box-shadow 160ms, color 160ms;
}
.cm-btn--primary { background: var(--saffron-400); color: var(--ink-950); }
.cm-btn--primary:hover { background: var(--saffron-500); transform: translateY(-1px); box-shadow: 0 12px 28px rgba(217,154,11,.35); }
.cm-btn--accent { background: var(--coral-500); color: #fff; }
.cm-btn--accent:hover { background: var(--coral-600); transform: translateY(-1px); }
.cm-btn--dark { background: var(--ink-950); color: #fff; }
.cm-btn--dark:hover { background: var(--ink-800); }
.cm-btn--ghost { background: transparent; color: var(--ink-950); border: 1.5px solid var(--ink-950); }
.cm-btn--ghost:hover { background: var(--ink-950); color: #fff; }
.cm-btn--sm { padding: 9px 16px; font-size: 11px; }

/* ---------- Logo ----------- */
.cm-logo { display: inline-flex; align-items: center; gap: 10px; }
.cm-logo__mark {
  width: 38px; height: 38px; border-radius: 10px; background: var(--saffron-400);
  font-family: var(--font-display); font-weight: 900; font-size: 24px; color: var(--ink-950);
  display: grid; place-items: center; position: relative; overflow: hidden;
  box-shadow: 0 6px 14px rgba(217,154,11,.32);
}
.cm-logo__mark::after { content: ''; position: absolute; left: 0; right: 0; bottom: 0; height: 6px; background: var(--coral-500); }
.cm-logo__word { font-family: var(--font-display); font-weight: 800; font-size: 18px; letter-spacing: -0.01em; color: var(--ink-950); }
.cm-logo--footer .cm-logo__word { color: #fff; }

/* ---------- Nav ----------- */
.cm-nav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(255,255,255,0.92); backdrop-filter: blur(10px);
  border-bottom: 1px solid transparent;
  transition: border-color 200ms, box-shadow 200ms;
}
.cm-nav--scrolled { border-color: var(--divider); box-shadow: 0 6px 18px rgba(20,18,10,.05); }
.cm-nav__inner {
  max-width: 1180px; margin: 0 auto;
  padding: 14px 24px;
  display: flex; align-items: center; gap: 24px;
}
.cm-nav__links { display: flex; gap: 26px; margin-left: 24px; flex: 1; }
.cm-nav__links a {
  font-weight: 600; font-size: 12.5px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ink-700); transition: color 150ms;
}
.cm-nav__links a:hover { color: var(--coral-500); }

/* ---------- Hero ----------- */
.cm-hero {
  max-width: 1180px; margin: 0 auto;
  padding: 56px 24px 80px;
  display: grid; grid-template-columns: 1.1fr 0.9fr;
  grid-template-areas: 'tiles art' 'copy art';
  gap: 36px 56px; align-items: center;
}
.cm-hero__tiles { grid-area: tiles; display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 14px; }
.cm-hero__copy  { grid-area: copy; }
.cm-hero__art   { grid-area: art; display: flex; justify-content: center; }
.cm-hero__art img { max-height: 540px; width: auto; filter: drop-shadow(0 30px 60px rgba(40,18,2,.28)); }
.cm-hero__title { font-family: var(--font-display); font-weight: 800; font-size: 46px; line-height: 1.05; letter-spacing: -0.02em; color: var(--ink-950); margin: 0 0 14px; text-wrap: balance; }

.cm-pack-tile {
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  padding: 12px 8px 10px; border-radius: 14px;
  background: var(--saffron-50); border: 2px solid transparent;
  cursor: pointer; transition: transform 160ms cubic-bezier(.2,.7,.2,1), border-color 160ms, box-shadow 160ms;
  font: inherit;
}
.cm-pack-tile img { height: 92px; width: auto; filter: drop-shadow(0 8px 14px rgba(40,18,2,.20)); }
.cm-pack-tile__label { font-size: 10.5px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-900); }
.cm-pack-tile--saffron { background: var(--saffron-50); }
.cm-pack-tile--navy { background: var(--navy-50); }
.cm-pack-tile--teal { background: var(--teal-50); }
.cm-pack-tile:hover { transform: translateY(-3px); box-shadow: 0 14px 30px rgba(40,18,2,.14); }
.cm-pack-tile.is-active { border-color: var(--coral-500); box-shadow: 0 14px 30px rgba(209,75,26,.20); }

.cm-cta-row { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; margin-top: 8px; }
.cm-trust { margin-top: 18px; font-size: 13px; color: var(--fg-tertiary); display: flex; gap: 10px; flex-wrap: wrap; }
.cm-trust span:first-child { color: var(--saffron-600); font-weight: 600; }

/* ---------- Feature row ----------- */
.cm-feature {
  max-width: 1180px; margin: 0 auto; padding: 60px 24px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center;
}
.cm-feature--right .cm-feature__media { order: 2; }
.cm-feature__media img { width: 100%; height: auto; border-radius: 18px; }
.cm-bullets { list-style: none; padding: 0; margin: 12px 0 18px; display: flex; flex-direction: column; gap: 8px; }
.cm-bullets li { display: flex; align-items: flex-start; gap: 10px; font-size: 15px; line-height: 1.5; }
.cm-bullets svg { color: var(--success); flex: 0 0 18px; margin-top: 2px; }

/* ---------- Device showcase ----------- */
.cm-device { max-width: 1180px; margin: 0 auto; padding: 60px 24px; text-align: center; }
.cm-device__head { margin-bottom: 28px; }
.cm-device__pills { display: flex; gap: 16px; justify-content: center; margin: 28px 0 36px; flex-wrap: wrap; }
.cm-pill-card {
  display: flex; align-items: center; gap: 12px;
  background: var(--bg-warm); border: 1px solid var(--saffron-100);
  padding: 14px 22px; border-radius: 999px;
}
.cm-pill-card__n { font-family: var(--font-display); font-weight: 800; font-size: 24px; color: var(--coral-500); line-height: 1; }
.cm-pill-card__t { font-size: 13px; font-weight: 600; color: var(--ink-800); }
.cm-device__art img { max-width: 100%; height: auto; }

/* ---------- Pack block (full bleed) ----------- */
.cm-packblock {
  display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center;
  padding: 80px 6vw; color: #fff;
}
.cm-packblock.is-reverse .cm-packblock__art { order: -1; }
.cm-packblock--navy { background: linear-gradient(120deg, var(--navy-800), var(--navy-600)); }
.cm-packblock--teal { background: linear-gradient(120deg, var(--teal-800), var(--teal-600)); }
.cm-packblock__art { display: flex; justify-content: center; }
.cm-packblock__art img { max-height: 440px; width: auto; height: auto; filter: drop-shadow(0 30px 60px rgba(0,0,0,.35)); }
.cm-packblock .cm-btn--primary { margin-top: 8px; }

/* ---------- Pricing ----------- */
.cm-pricing { max-width: 1180px; margin: 0 auto; padding: 80px 24px; }
.cm-pricing__grid { display: grid; grid-template-columns: 1fr 1.1fr 1fr; gap: 18px; align-items: stretch; }
.cm-plan {
  background: #fff; border: 1px solid var(--border); border-radius: 18px;
  padding: 28px 24px; display: flex; flex-direction: column; gap: 12px;
  position: relative; transition: transform 200ms, box-shadow 200ms, border-color 200ms;
  cursor: pointer;
}
.cm-plan:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.cm-plan.is-featured {
  border: 2px solid var(--saffron-400);
  box-shadow: 0 24px 60px rgba(217,154,11,.18);
  transform: translateY(-6px);
}
.cm-plan.is-selected { border-color: var(--coral-500); box-shadow: 0 24px 60px rgba(209,75,26,.18); }
.cm-plan__tag {
  position: absolute; top: -12px; right: 22px;
  background: var(--coral-500); color: #fff;
  font-size: 10.5px; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase;
  padding: 6px 12px; border-radius: 999px;
}
.cm-plan__name { font-weight: 700; font-size: 13px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-700); }
.cm-plan__price {
  font-family: var(--font-display); font-weight: 800; font-size: 46px;
  line-height: 1; color: var(--ink-950); letter-spacing: -0.01em;
}
.cm-plan__unit { font-size: 14px; font-weight: 600; color: var(--fg-tertiary); margin-left: 4px; letter-spacing: 0; }
.cm-plan__strike { font-size: 14px; color: var(--fg-tertiary); text-decoration: line-through; font-weight: 600; }
.cm-plan__copy { font-size: 14px; line-height: 1.55; color: var(--fg-secondary); flex: 1; }
.cm-plan__cta { margin-top: auto; }

/* ---------- FAQ ----------- */
.cm-faq { max-width: 800px; margin: 0 auto; padding: 60px 24px; }
.cm-faq__list { background: #fff; border: 1px solid var(--border); border-radius: 18px; overflow: hidden; }
.cm-faq__row { border-bottom: 1px solid var(--divider); }
.cm-faq__row:last-child { border-bottom: none; }
.cm-faq__q {
  width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 16px;
  background: none; border: none; cursor: pointer;
  padding: 18px 22px;
  font-family: var(--font-sans); font-weight: 700; font-size: 15.5px;
  color: var(--ink-900); text-align: left;
}
.cm-faq__chev { width: 18px; height: 18px; color: var(--saffron-500); transition: transform 200ms; }
.cm-faq__row.is-open .cm-faq__chev { transform: rotate(45deg); }
.cm-faq__a { padding: 0 22px 18px; font-size: 14.5px; line-height: 1.6; color: var(--fg-secondary); }

/* ---------- Contact ----------- */
.cm-contact { max-width: 920px; margin: 0 auto; padding: 60px 24px 100px; }
.cm-contact__head { text-align: center; margin-bottom: 32px; }
.cm-form { background: #fff; border: 1px solid var(--border); border-radius: 18px; padding: 28px; display: flex; flex-direction: column; gap: 14px; box-shadow: var(--shadow-sm); }
.cm-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.cm-field { display: flex; flex-direction: column; gap: 6px; }
.cm-field label { font-size: 11px; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-700); }
.cm-field input, .cm-field textarea {
  font-family: var(--font-sans); font-size: 14.5px; color: var(--ink-900);
  padding: 12px 14px; border: 1px solid var(--border); border-radius: 10px;
  background: #fff; outline: none; transition: border-color 150ms, box-shadow 150ms;
  resize: vertical;
}
.cm-field input:focus, .cm-field textarea:focus { border-color: var(--saffron-400); box-shadow: 0 0 0 3px var(--ring); }
.cm-form__ok { background: var(--teal-50); color: var(--teal-800); padding: 10px 14px; border-radius: 10px; font-size: 14px; }

/* ---------- Footer ----------- */
.cm-footer { background: var(--ink-950); color: rgba(255,255,255,0.8); padding: 56px 24px 24px; }
.cm-footer__inner { max-width: 1180px; margin: 0 auto; display: grid; grid-template-columns: 1fr 2fr; gap: 48px; }
.cm-footer__cols { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
footer.cm-footer .cm-footer__cols h3 { font-size: 11px; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(255,255,255,0.6); margin: 0 0 12px; }
.cm-footer__cols a { display: block; font-size: 14px; color: rgba(255,255,255,0.85); padding: 5px 0; transition: color 150ms; }
.cm-footer__cols a:hover { color: var(--saffron-400); }
.cm-footer__bottom { max-width: 1180px; margin: 32px auto 0; padding-top: 18px; border-top: 1px solid rgba(255,255,255,0.1); font-size: 12.5px; color: rgba(255,255,255,0.5); }

/* ---------- Responsive ----------- */
@media (max-width: 880px) {
  .cm-hero { grid-template-columns: 1fr; grid-template-areas: 'tiles' 'art' 'copy'; }
  .cm-feature, .cm-feature--right .cm-feature__media { grid-template-columns: 1fr; }
  .cm-feature__media { order: 0; }
  .cm-packblock { grid-template-columns: 1fr; padding: 60px 24px; }
  .cm-pricing__grid { grid-template-columns: 1fr; }
  .cm-plan.is-featured { transform: none; }
  .cm-footer__inner { grid-template-columns: 1fr; }
  .cm-nav__links { display: none; }
  .cm-form__row { grid-template-columns: 1fr; }
}
