/* Mn Informatica — showcase website styles. Built on design tokens. */
@import url('./colors_and_type.css');

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; font-family: var(--font-sans); color: var(--fg); background: var(--bg); -webkit-font-smoothing: antialiased; }
a { color: inherit; text-decoration: none; }
img, svg { display: block; }
.wrap { max-width: 1180px; margin: 0 auto; padding: 0 32px; }
.section { padding: var(--space-9) 0; }

/* visible focus ring for keyboard users */
a:focus-visible, button:focus-visible, input:focus-visible, .fstep:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
  border-radius: var(--radius-sm);
}

/* ---- shared atoms ---- */
.eyebrow-tag { font-family: var(--font-mono); font-size: 12px; font-weight: 500; letter-spacing: 0.18em; text-transform: uppercase; color: var(--primary); display: inline-block; }
.btn { font-family: var(--font-sans); font-weight: 600; border-radius: var(--radius-md); border: 1.5px solid transparent; cursor: pointer; display: inline-flex; align-items: center; gap: 8px; transition: all var(--dur-fast) var(--ease-out); white-space: nowrap; line-height: 1; }
.btn--md { font-size: 15px; padding: 13px 22px; }
.btn--sm { font-size: 13px; padding: 9px 16px; }
.btn--lg { font-size: 17px; padding: 16px 28px; }
.btn--primary { background: var(--primary); color: var(--primary-fg); }
.btn--primary:hover { background: var(--primary-hover); transform: translateY(-1px); box-shadow: var(--shadow-md); }
.btn--primary:active { background: var(--primary-press); transform: translateY(0); }
.btn--secondary { background: var(--white); color: var(--ink-900); border-color: var(--border-strong); }
.btn--secondary:hover { background: var(--ink-50); border-color: var(--ink-400); }
.btn--ghost { background: transparent; color: var(--primary); }
.btn--ghost:hover { background: var(--orange-50); }
.btn--inverse { background: var(--white); color: var(--ink-950); }
.btn--inverse:hover { background: var(--ink-100); }

.badge { font-family: var(--font-sans); font-weight: 600; font-size: 12px; padding: 4px 11px; border-radius: var(--radius-full); display: inline-flex; align-items: center; gap: 6px; }
.badge--primary { background: var(--orange-50); color: var(--orange-700); }
.badge--neutral { background: var(--ink-100); color: var(--ink-700); }

/* ---- logo ---- */
.logo { display: flex; align-items: center; gap: 11px; }
.logo__wm { display: flex; flex-direction: column; line-height: 1; }
.logo__name { font-family: var(--font-display); font-weight: 600; font-size: 21px; letter-spacing: -0.01em; white-space: nowrap; color: var(--ink-950); }
.logo--light .logo__name { color: var(--ink-50); }
.logo__sub { font-family: var(--font-mono); font-weight: 500; font-size: 8.5px; letter-spacing: 0.2em; color: var(--fg-muted); margin-top: 4px; }

/* ---- header ---- */
.header { position: sticky; top: 0; z-index: 50; background: color-mix(in srgb, var(--white) 82%, transparent); backdrop-filter: blur(12px); border-bottom: 1px solid var(--border); }
.header__inner { display: flex; align-items: center; justify-content: space-between; height: 76px; }
.nav { display: flex; align-items: center; gap: 32px; }
.nav a { font-size: 15px; font-weight: 500; color: var(--ink-700); transition: color var(--dur-fast); }
.nav a:hover { color: var(--primary); }
.header__cta { display: flex; align-items: center; gap: 14px; }
.menu-btn { display: none; background: none; border: 0; color: var(--ink-900); cursor: pointer; padding: 6px; }
.mobile-menu { display: none; flex-direction: column; gap: 4px; padding: 12px 32px 24px; border-bottom: 1px solid var(--border); background: var(--white); }
.mobile-menu a { padding: 12px 0; font-size: 17px; font-weight: 500; border-bottom: 1px solid var(--ink-100); }
.mobile-menu.open { display: flex; }

/* ---- hero ---- */
.hero { position: relative; overflow: hidden; padding: var(--space-9) 0 var(--space-8); }
.hero__grid { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 56px; align-items: center; }
.hero h1 { font-family: var(--font-display); font-weight: 600; font-size: clamp(2.6rem, 1.8rem + 3vw, 4rem); line-height: 1.05; letter-spacing: -0.02em; color: var(--ink-950); margin: 18px 0 0; text-wrap: balance; }
.hero h1 em { font-style: italic; color: var(--primary); }
.hero__lead { font-size: 19px; line-height: 1.6; color: var(--fg-muted); margin: 22px 0 30px; max-width: 30em; text-wrap: pretty; }
.hero__actions { display: flex; gap: 14px; flex-wrap: wrap; }
.hero__meta { display: flex; gap: 28px; margin-top: 40px; }
.hero__meta .stat { display: flex; flex-direction: column; gap: 2px; }
.hero__meta .num { font-family: var(--font-display); font-weight: 600; font-size: 30px; color: var(--ink-950); }
.hero__meta .lbl { font-size: 13px; color: var(--fg-muted); }
.hero__bg { position: absolute; inset: 0; background: radial-gradient(900px 420px at 88% -8%, var(--orange-50), transparent 60%); pointer-events: none; }

/* dashboard mock visual */
.mock { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius-xl); box-shadow: var(--shadow-xl); overflow: hidden; }
.mock__bar { display: flex; align-items: center; gap: 8px; padding: 13px 16px; border-bottom: 1px solid var(--border); background: var(--ink-50); }
.mock__dot { width: 11px; height: 11px; border-radius: 50%; }
.mock__title { margin-left: 8px; font-family: var(--font-mono); font-size: 12px; color: var(--fg-muted); }
.mock__body { padding: 20px; display: flex; flex-direction: column; gap: 14px; }
.mock__row { display: flex; align-items: center; gap: 12px; padding: 12px 14px; border: 1px solid var(--border); border-radius: var(--radius-md); }
.mock__ic { width: 36px; height: 36px; border-radius: 9px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.mock__txt { flex: 1; display: flex; flex-direction: column; gap: 4px; }
.mock__txt b { font-size: 14px; font-weight: 600; }
.mock__txt span { font-size: 12px; color: var(--fg-muted); }
.mock__pct { font-family: var(--font-mono); font-size: 13px; font-weight: 500; }

/* ---- generic section head ---- */
.shead { max-width: 620px; margin-bottom: var(--space-7); }
.shead h2 { font-family: var(--font-display); font-weight: 600; font-size: var(--text-3xl); line-height: 1.1; letter-spacing: -0.02em; color: var(--ink-950); margin: 14px 0 0; text-wrap: balance; }
.shead p { font-size: 18px; line-height: 1.6; color: var(--fg-muted); margin: 16px 0 0; }
.shead--center { margin-left: auto; margin-right: auto; text-align: center; }

/* ---- services ---- */
.svc-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.svc { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 28px; transition: all var(--dur-base) var(--ease-out); }
.svc:hover { border-color: var(--orange-200); box-shadow: var(--shadow-lg); transform: translateY(-3px); }
.svc__ic { width: 50px; height: 50px; border-radius: var(--radius-md); background: var(--orange-50); color: var(--orange-600); display: flex; align-items: center; justify-content: center; margin-bottom: 18px; }
.svc h3 { font-family: var(--font-display); font-weight: 600; font-size: 22px; color: var(--ink-950); margin: 0 0 8px; }
.svc p { font-size: 15px; line-height: 1.6; color: var(--fg-muted); margin: 0; }

/* ---- logistics flow ---- */
.flow { background: var(--ink-950); color: var(--ink-50); border-radius: var(--radius-xl); padding: 48px; }
.flow .eyebrow-tag { color: var(--orange-300); }
.flow h2 { color: var(--white); }
.flow__steps { display: grid; grid-template-columns: repeat(5, 1fr); gap: 0; margin-top: 36px; }
.fstep { padding: 20px; border-radius: var(--radius-lg); cursor: pointer; transition: background var(--dur-base); position: relative; }
.fstep.active { background: var(--ink-900); }
.fstep__n { font-family: var(--font-mono); font-size: 12px; color: var(--orange-300); }
.fstep__ic { width: 44px; height: 44px; border-radius: var(--radius-md); background: var(--ink-800); color: var(--orange-300); display: flex; align-items: center; justify-content: center; margin: 14px 0 12px; transition: all var(--dur-base); }
.fstep.active .fstep__ic { background: var(--primary); color: var(--white); }
.fstep h4 { font-family: var(--font-sans); font-size: 16px; font-weight: 600; color: var(--white); margin: 0 0 6px; }
.fstep p { font-size: 13px; line-height: 1.5; color: var(--ink-400); margin: 0; }
.fstep__arrow { position: absolute; right: -8px; top: 54px; color: var(--ink-700); }

/* ---- app / mobile ---- */
.app { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: 56px; align-items: center; }
.app__list { display: flex; flex-direction: column; gap: 18px; margin-top: 26px; }
.app__item { display: flex; gap: 14px; align-items: flex-start; }
.app__check { width: 26px; height: 26px; border-radius: 50%; background: var(--orange-50); color: var(--orange-600); display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: 2px; }
.app__item b { font-weight: 600; font-size: 16px; color: var(--ink-950); }
.app__item p { margin: 4px 0 0; font-size: 14px; color: var(--fg-muted); line-height: 1.5; }
.phones { display: flex; gap: 18px; justify-content: center; }
.phone { width: 200px; height: 410px; background: var(--ink-950); border-radius: 34px; padding: 9px; box-shadow: var(--shadow-xl); }
.phone__screen { width: 100%; height: 100%; background: var(--white); border-radius: 26px; overflow: hidden; display: flex; flex-direction: column; }
.phone--2 { margin-top: 36px; }
.pscr__top { background: var(--ink-950); color: var(--white); padding: 18px 16px 16px; }
.pscr__top .eyebrow-tag { color: var(--orange-300); font-size: 9px; }
.pscr__top h5 { font-family: var(--font-display); font-size: 20px; margin: 8px 0 0; color: var(--white); }
.pscr__list { padding: 12px; display: flex; flex-direction: column; gap: 9px; }
.pscr__row { display: flex; align-items: center; gap: 10px; padding: 10px; border: 1px solid var(--border); border-radius: 10px; }
.pscr__row .d { width: 28px; height: 28px; border-radius: 7px; background: var(--orange-50); color: var(--orange-600); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.pscr__row .t { flex: 1; }
.pscr__row .t b { font-size: 12px; display: block; }
.pscr__row .t span { font-size: 10px; color: var(--fg-muted); }

/* ---- contact CTA ---- */
.cta { background: var(--orange-500); border-radius: var(--radius-xl); padding: 56px; display: grid; grid-template-columns: 1fr auto; gap: 40px; align-items: center; position: relative; overflow: hidden; }
.cta h2 { font-family: var(--font-display); font-weight: 600; font-size: var(--text-3xl); line-height: 1.1; color: var(--white); margin: 0; letter-spacing: -0.02em; }
.cta p { font-size: 18px; color: rgba(255,255,255,.88); margin: 14px 0 0; max-width: 28em; }
.cta__form { display: flex; gap: 10px; }
.cta__form input { font-family: var(--font-sans); font-size: 15px; padding: 14px 16px; border: 0; border-radius: var(--radius-md); width: 240px; outline: none; }
.cta__sent { display: flex; align-items: center; gap: 10px; color: #fff; font-weight: 600; }

/* ---- footer ---- */
.footer { background: var(--ink-950); color: var(--ink-300); padding: var(--space-8) 0 var(--space-6); }
.footer__grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 40px; }
.footer h6 { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-500); margin: 0 0 16px; }
.footer ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
.footer ul a { font-size: 14px; color: var(--ink-300); transition: color var(--dur-fast); }
.footer ul a:hover { color: var(--orange-300); }
.footer__intro { font-size: 14px; line-height: 1.6; color: var(--ink-400); margin: 16px 0 0; max-width: 26em; }
.footer__bottom { display: flex; justify-content: space-between; align-items: center; margin-top: var(--space-7); padding-top: 24px; border-top: 1px solid var(--ink-800); font-size: 13px; color: var(--ink-500); }

/* ---- responsive ---- */
@media (max-width: 1024px) {
  .nav, .header__cta .btn { display: none; }
  .menu-btn { display: block; }
  .hero__grid, .app, .cta { grid-template-columns: 1fr; }
  .svc-grid { grid-template-columns: 1fr; }
  .flow__steps { grid-template-columns: 1fr 1fr; }
  .footer__grid { grid-template-columns: 1fr 1fr; }
  .cta__form { flex-direction: column; }
  .cta__form input { width: 100%; }
  .fstep__arrow { display: none; }
}
