/* ============================================================
   Scribefire — Secure transcript operations
   Brand stylesheet
   ============================================================ */

/* ---- Fonts ---- */
@import url('https://fonts.googleapis.com/css2?family=Spectral:wght@400;500;600;700&family=Public+Sans:wght@400;500;600;700&family=IBM+Plex+Mono:wght@400;500;600&display=swap');

/* ---- Tokens ---- */
:root {
  --navy:        #1E2855;
  --navy-deep:   #071B33;
  --blue:        #87C3D7;
  --blue-ink:    #2F6E86;   /* darker light-blue for text on white (AA) */
  --bluegrey:    #EEF3F7;
  --charcoal:    #1E2933;
  --white:       #FFFFFF;
  --line:        #DCE5ED;
  --line-soft:   #E9EFF4;
  --muted:       #5A6675;

  --font-head: 'Public Sans', -apple-system, 'Helvetica Neue', Arial, sans-serif;
  --font-body: 'Public Sans', -apple-system, 'Helvetica Neue', Arial, sans-serif;
  --font-mono: 'IBM Plex Mono', ui-monospace, 'SFMono-Regular', Menlo, monospace;

  --radius: 6px;
  --radius-lg: 12px;

  --accent: var(--blue);
  --accent-ink: var(--blue-ink);

  --maxw: 1240px;
  --gutter: 40px;

  --shadow-sm: 0 1px 2px rgba(7,27,51,.06), 0 1px 3px rgba(7,27,51,.05);
  --shadow-md: 0 8px 30px rgba(7,27,51,.08), 0 2px 8px rgba(7,27,51,.05);
  --shadow-lg: 0 30px 70px rgba(7,27,51,.16), 0 8px 24px rgba(7,27,51,.10);

  --ease: cubic-bezier(.22,.61,.36,1);
}

/* Accent intensity tweak */
:root[data-accent="subtle"]   { --accent-bg: rgba(135,195,215,.10); --accent-line: rgba(135,195,215,.45); }
:root[data-accent="balanced"] { --accent-bg: rgba(135,195,215,.18); --accent-line: rgba(135,195,215,.70); }
:root[data-accent="bold"]     { --accent-bg: rgba(135,195,215,.30); --accent-line: rgba(135,195,215,1); }
:root { --accent-bg: rgba(135,195,215,.18); --accent-line: rgba(135,195,215,.70); }

/* Heading font tweak */
:root[data-headings="serif"] { --font-head: 'Spectral', Georgia, 'Times New Roman', serif; }

/* Alt section background tweak */
:root { --panel: var(--bluegrey); }
:root[data-bg="white"] { --panel: #F7FAFC; }

/* ---- Reset ---- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: var(--font-body);
  color: var(--charcoal);
  background: var(--white);
  font-size: 17px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; }
h1,h2,h3,h4 { font-family: var(--font-head); color: var(--navy); margin: 0; line-height: 1.12; letter-spacing: -0.01em; font-weight: 600; }
p { margin: 0; }

/* ---- Layout ---- */
.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 var(--gutter); }
.section { padding: 104px 0; }
.section--tight { padding: 80px 0; }
.eyebrow {
  font-family: var(--font-mono);
  font-size: 12.5px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--accent-ink);
  font-weight: 500;
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.eyebrow::before {
  content: "";
  width: 22px; height: 1px;
  background: var(--accent-ink);
  display: inline-block;
  opacity: .8;
}
.section-head { max-width: 760px; }
.section-head .eyebrow { margin-bottom: 22px; }
h2.section-title { font-size: clamp(30px, 3.4vw, 44px); }
.section-head .lede { margin-top: 22px; color: var(--muted); font-size: 19px; max-width: 640px; }

/* ---- Buttons ---- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 9px;
  padding: 14px 24px;
  border-radius: var(--radius);
  font-weight: 600; font-size: 15.5px;
  letter-spacing: .005em;
  border: 1.5px solid transparent;
  transition: background .2s var(--ease), color .2s var(--ease), border-color .2s var(--ease), transform .15s var(--ease);
  white-space: nowrap;
}
.btn .ico { width: 16px; height: 16px; }
.btn--primary { background: var(--navy); color: #fff; border-color: var(--navy); }
.btn--primary:hover { background: var(--navy-deep); border-color: var(--navy-deep); transform: translateY(-1px); }
.btn--ghost { background: transparent; color: var(--navy); border-color: var(--line); }
.btn--ghost:hover { border-color: var(--accent); background: var(--accent-bg); }
.btn--light { background: #fff; color: var(--navy); border-color: #fff; }
.btn--light:hover { background: var(--blue); border-color: var(--blue); color: var(--navy-deep); }
.btn--onnavy { background: transparent; color: #fff; border-color: rgba(255,255,255,.32); }
.btn--onnavy:hover { border-color: var(--blue); color: var(--navy-deep); background: var(--blue); }
.btn--sm { padding: 10px 16px; font-size: 14px; }

.link-arrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-weight: 600; font-size: 15px; color: var(--navy);
  letter-spacing: .005em;
}
.link-arrow .arr { transition: transform .2s var(--ease); }
.link-arrow:hover { color: var(--accent-ink); }
.link-arrow:hover .arr { transform: translateX(4px); }

/* ============================================================
   Header
   ============================================================ */
.header {
  position: sticky; top: 0; z-index: 60;
  background: rgba(255,255,255,.86);
  backdrop-filter: saturate(140%) blur(14px);
  border-bottom: 1px solid transparent;
  transition: border-color .25s var(--ease), background .25s var(--ease), box-shadow .25s var(--ease);
}
.header.is-stuck { border-color: var(--line-soft); box-shadow: 0 1px 0 rgba(7,27,51,.04); }
.header__inner { display: flex; align-items: center; gap: 28px; height: 100px; }
.brand { display: flex; align-items: center; gap: 12px; flex-shrink: 0; }
.brand__mark { width: 38px; height: 38px; flex-shrink: 0; }
.brand__logo { height: 62px; width: auto; display: block; }
.brand__logo--footer { height: 64px; }
@media (max-width: 680px){ .brand__logo { height: 48px; } }
.brand__word { font-family: var(--font-head); font-weight: 600; font-size: 23px; color: var(--navy); letter-spacing: -0.02em; }
.brand__word b { color: var(--accent-ink); font-weight: 600; }

.nav { display: flex; align-items: center; gap: 4px; margin-left: 8px; }
.nav a {
  padding: 9px 13px; border-radius: 6px;
  font-size: 14.5px; font-weight: 500; color: #36404e;
  transition: color .15s, background .15s;
  white-space: nowrap;
}
.nav a:hover { color: var(--navy); background: var(--bluegrey); }
.header__cta { display: flex; align-items: center; gap: 10px; margin-left: auto; }
.header__cta .btn { padding: 11px 18px; font-size: 14.5px; }

.burger { display: none; width: 44px; height: 44px; border: 1px solid var(--line); background: #fff; border-radius: 8px; align-items: center; justify-content: center; margin-left: auto; }
.burger span { display: block; width: 18px; height: 2px; background: var(--navy); position: relative; }
.burger span::before, .burger span::after { content: ""; position: absolute; left: 0; width: 18px; height: 2px; background: var(--navy); }
.burger span::before { top: -6px; } .burger span::after { top: 6px; }

/* mobile drawer */
.drawer { display: none; }

/* ============================================================
   Hero
   ============================================================ */
.hero { position: relative; overflow: hidden; background:
   radial-gradient(1100px 540px at 82% -8%, rgba(135,195,215,.18), transparent 60%),
   linear-gradient(180deg, #fff 0%, #FAFCFD 100%);
}
.hero__inner { position: relative; z-index: 2; display: grid; grid-template-columns: 1.02fr .98fr; gap: 64px; align-items: center; padding: 92px 0 96px; }
.hero__eyebrow { margin-bottom: 26px; }
.hero h1 { font-size: clamp(38px, 4.6vw, 60px); line-height: 1.04; letter-spacing: -0.022em; font-weight: 600; }
.hero h1 .hl { color: var(--accent-ink); }
.hero__sub { margin-top: 26px; font-size: 19.5px; line-height: 1.62; color: #3b4655; max-width: 540px; }
.hero__cta { margin-top: 34px; display: flex; gap: 14px; flex-wrap: wrap; }
.hero__trust { margin-top: 40px; display: flex; flex-wrap: wrap; gap: 10px 20px; align-items: center; padding-top: 26px; border-top: 1px solid var(--line); }
.trust-chip { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-mono); font-size: 12px; letter-spacing: .04em; color: #44505f; }
.trust-chip .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 0 3px var(--accent-bg); }

/* ---- Hero portal/workflow visual ---- */
.portal {
  position: relative;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  overflow: hidden;
}
.portal__bar { display: flex; align-items: center; gap: 8px; padding: 13px 16px; background: var(--navy-deep); color: #fff; }
.portal__dots { display: flex; gap: 6px; }
.portal__dots i { width: 9px; height: 9px; border-radius: 50%; background: rgba(255,255,255,.3); }
.portal__dots i:first-child { background: var(--blue); }
.portal__title { font-family: var(--font-mono); font-size: 12px; letter-spacing: .06em; color: rgba(255,255,255,.78); margin-left: 6px; }
.portal__lock { margin-left: auto; font-family: var(--font-mono); font-size: 11px; color: var(--blue); display: inline-flex; align-items: center; gap: 6px; }
.portal__body { padding: 22px; background:
   linear-gradient(180deg, #fff, #FBFDFE); }

.pipe { display: flex; flex-direction: column; gap: 0; }
.pipe__step { display: grid; grid-template-columns: 40px 1fr auto; gap: 14px; align-items: center; padding: 13px 4px; position: relative; }
.pipe__rail { position: absolute; left: 19px; top: 40px; bottom: -13px; width: 2px; background: var(--line); z-index: 0; }
.pipe__step:last-child .pipe__rail { display: none; }
.pipe__node { position: relative; z-index: 1; width: 40px; height: 40px; border-radius: 9px; background: var(--bluegrey); border: 1px solid var(--line); display: flex; align-items: center; justify-content: center; color: var(--navy); transition: all .4s var(--ease); }
.pipe__node svg { width: 19px; height: 19px; }
.pipe__txt b { display: block; font-size: 15px; color: var(--navy); font-weight: 600; }
.pipe__txt span { font-size: 12.5px; color: var(--muted); }
.pipe__state { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .08em; text-transform: uppercase; color: #9aa6b4; padding: 4px 9px; border: 1px solid var(--line); border-radius: 100px; transition: all .4s var(--ease); }
/* active (animated) state */
.pipe__step.is-active .pipe__node { background: var(--navy); border-color: var(--navy); color: #fff; box-shadow: 0 6px 16px rgba(30,40,85,.28); }
.pipe__step.is-done .pipe__node { background: var(--accent-bg); border-color: var(--accent); color: var(--navy); }
.pipe__step.is-active .pipe__state { color: var(--accent-ink); border-color: var(--accent); background: var(--accent-bg); }
.pipe__step.is-done .pipe__state { color: var(--blue-ink); border-color: var(--accent-line); }
.pipe__step.is-active .pipe__rail { background: linear-gradient(var(--accent), var(--line)); }
.pipe__step.is-done .pipe__rail { background: var(--accent); }

.portal__foot { display: flex; align-items: center; justify-content: space-between; padding: 14px 22px; border-top: 1px solid var(--line); background: #fff; }
.portal__foot .meta { font-family: var(--font-mono); font-size: 11px; color: var(--muted); letter-spacing: .03em; }
.portal__chip { font-size: 12px; font-weight: 600; color: var(--blue-ink); background: var(--accent-bg); border: 1px solid var(--accent-line); padding: 5px 11px; border-radius: 100px; }

/* hero variant: horizontal flow */
:root[data-hero="flow"] .portal--card { display: none; }
:root .portal--flow { display: none; }
:root[data-hero="flow"] .portal--flow { display: block; }

/* ============================================================
   Logo strip / trust
   ============================================================ */
.proofstrip { border-top: 1px solid var(--line-soft); border-bottom: 1px solid var(--line-soft); background: #fff; }
.proofstrip__inner { display: flex; align-items: center; gap: 40px; padding: 26px 0; flex-wrap: wrap; }
.proofstrip__label { font-family: var(--font-mono); font-size: 11.5px; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); }
.proofstrip__items { display: flex; flex-wrap: wrap; gap: 14px 30px; align-items: center; }
.proof-item { display: inline-flex; align-items: center; gap: 10px; font-size: 14px; font-weight: 600; color: var(--navy); }
.proof-item .badge { width: 30px; height: 30px; border-radius: 7px; background: var(--bluegrey); border: 1px solid var(--line); display: flex; align-items: center; justify-content: center; color: var(--accent-ink); }
.proof-item .badge svg { width: 16px; height: 16px; }

/* ============================================================
   Credibility
   ============================================================ */
.cred__grid { display: grid; grid-template-columns: 1fr; gap: 56px; }
.cred__points { display: grid; grid-template-columns: repeat(2, 1fr); gap: 2px; background: var(--line-soft); border: 1px solid var(--line-soft); border-radius: var(--radius-lg); overflow: hidden; }
.cred__point { background: #fff; padding: 26px 28px; display: flex; gap: 16px; align-items: flex-start; }
.cred__point--wide { grid-column: 1 / -1; }
.cred__point .num { font-family: var(--font-mono); font-size: 12px; color: var(--accent-ink); padding-top: 3px; }
.cred__point h4 { font-family: var(--font-body); font-size: 16px; font-weight: 600; color: var(--navy); margin-bottom: 4px; }
.cred__point p { font-size: 14.5px; color: var(--muted); }

/* ============================================================
   Signature workflow
   ============================================================ */
.flow { background: var(--panel); }
.flow__head { display: flex; justify-content: space-between; align-items: flex-end; gap: 40px; margin-bottom: 56px; }
.flow__diagram { position: relative; }
.flow__track { position: absolute; top: 33px; left: 8%; right: 8%; height: 2px; background: var(--line); z-index: 0; }
.flow__track .fill { position: absolute; inset: 0 100% 0 0; background: linear-gradient(90deg, var(--accent), var(--navy)); transition: right 1.2s var(--ease); }
.flow__steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; position: relative; z-index: 1; }
.flow__step { text-align: left; }
.flow__node {
  width: 68px; height: 68px; border-radius: 16px; background: #fff;
  border: 1.5px solid var(--line); display: flex; align-items: center; justify-content: center;
  color: var(--navy); margin-bottom: 22px; position: relative;
  transition: all .5s var(--ease); box-shadow: var(--shadow-sm);
}
.flow__node svg { width: 28px; height: 28px; }
.flow__node .step-no { position: absolute; top: -9px; right: -9px; width: 24px; height: 24px; border-radius: 50%; background: var(--navy); color: #fff; font-family: var(--font-mono); font-size: 11px; display: flex; align-items: center; justify-content: center; font-weight: 600; }
.flow__step.is-in .flow__node { border-color: var(--accent); color: var(--navy); box-shadow: 0 12px 30px rgba(30,40,85,.14); transform: translateY(-3px); }
.flow__step.is-in .flow__node .step-no { background: var(--accent-ink); }
.flow__step h3 { font-size: 20px; margin-bottom: 8px; }
.flow__step p { font-size: 14.5px; color: var(--muted); }
.flow__cap { margin-top: 14px; font-family: var(--font-mono); font-size: 11px; letter-spacing: .07em; text-transform: uppercase; color: var(--accent-ink); opacity: 0; transition: opacity .5s; }
.flow__step.is-in .flow__cap { opacity: 1; }

/* ============================================================
   Sectors
   ============================================================ */
.sectors__grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 20px; }
.sector {
  background: #fff; border: 1px solid var(--line); border-radius: var(--radius-lg);
  padding: 30px 28px; display: flex; flex-direction: column; gap: 14px;
  transition: border-color .25s var(--ease), box-shadow .25s var(--ease), transform .25s var(--ease);
  position: relative; overflow: hidden;
}
.sector:hover { border-color: var(--accent-line); box-shadow: var(--shadow-md); transform: translateY(-3px); }
.sector--lg { grid-column: span 3; }
.sector--sm { grid-column: span 2; }
.sector__ico { width: 46px; height: 46px; border-radius: 11px; background: var(--bluegrey); border: 1px solid var(--line); display: flex; align-items: center; justify-content: center; color: var(--navy); }
.sector__ico svg { width: 23px; height: 23px; }
.sector h3 { font-size: 21px; }
.sector p { font-size: 14.5px; color: var(--muted); flex: 1; }
.sector .link-arrow { margin-top: 4px; font-size: 14px; }
@media (max-width: 980px){ .sectors__grid { grid-template-columns: 1fr 1fr; } .sector--lg, .sector--sm { grid-column: span 1; } }

/* ============================================================
   Security & Compliance (deep navy)
   ============================================================ */
.security { background: var(--navy-deep); color: #cdd8e4; position: relative; overflow: hidden; }
.watermark { position: absolute; z-index: 0; pointer-events: none; user-select: none; width: 560px; max-width: 60%; height: auto; opacity: .05; }
.watermark--br { right: -110px; bottom: -130px; transform: rotate(-8deg); }
.watermark--tl { left: -120px; top: -120px; transform: rotate(6deg); }
.security .wrap, .procure .wrap { position: relative; z-index: 1; }
.security::before { content:""; position:absolute; inset:0; background:
   radial-gradient(800px 420px at 90% 0%, rgba(135,195,215,.16), transparent 60%); pointer-events:none; }
.security .eyebrow { color: var(--blue); }
.security .eyebrow::before { background: var(--blue); }
.security h2 { color: #fff; }
.security__grid { position: relative; display: grid; grid-template-columns: 1fr 1.05fr; gap: 64px; align-items: center; }
.security__lede { color: #aebccd; font-size: 18px; margin-top: 22px; }
.security__certs { display: flex; gap: 14px; margin-top: 34px; flex-wrap: wrap; }
.cert-card { background: rgba(255,255,255,.05); border: 1px solid rgba(135,195,215,.28); border-radius: 10px; padding: 18px 20px; min-width: 180px; }
.cert-card .k { font-family: var(--font-mono); font-size: 11px; letter-spacing: .06em; color: var(--blue); }
.cert-card .v { font-size: 15px; color: #fff; font-weight: 600; margin-top: 6px; }
.seclist { display: grid; grid-template-columns: 1fr 1fr; gap: 2px; background: rgba(135,195,215,.12); border: 1px solid rgba(135,195,215,.16); border-radius: var(--radius-lg); overflow: hidden; }
.seclist__item { background: rgba(7,27,51,.55); padding: 20px 22px; display: flex; gap: 13px; align-items: flex-start; }
.seclist__item .tick { flex-shrink: 0; width: 22px; height: 22px; border-radius: 6px; background: rgba(135,195,215,.18); display: flex; align-items: center; justify-content: center; color: var(--blue); }
.seclist__item .tick svg { width: 13px; height: 13px; }
.seclist__item span { font-size: 14.5px; color: #d4dee9; line-height: 1.45; }

/* ============================================================
   Quality management
   ============================================================ */
.quality__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; margin-top: 56px; }
.qcard { background: #fff; border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 28px 24px; position: relative; transition: border-color .25s, box-shadow .25s; }
.qcard:hover { border-color: var(--accent-line); box-shadow: var(--shadow-md); }
.qcard__no { font-family: var(--font-mono); font-size: 12px; color: var(--accent-ink); letter-spacing: .08em; }
.qcard h4 { font-family: var(--font-head); font-size: 19px; color: var(--navy); margin: 16px 0 10px; }
.qcard p { font-size: 14px; color: var(--muted); }
.qcard__bar { height: 3px; background: var(--line-soft); border-radius: 2px; margin-top: 20px; overflow: hidden; }
.qcard__bar i { display: block; height: 100%; width: 0; background: var(--accent); transition: width 1s var(--ease); }
.qcard.is-in .qcard__bar i { width: var(--w, 70%); }

/* ============================================================
   Client portals
   ============================================================ */
.portals { background: var(--panel); }
.portals__grid { display: grid; grid-template-columns: 1fr 1.08fr; gap: 64px; align-items: center; }
.portals__list { list-style: none; padding: 0; margin: 28px 0 0; display: grid; gap: 2px; }
.portals__list li { display: flex; gap: 13px; align-items: center; font-size: 15.5px; color: var(--charcoal); padding: 11px 0; border-bottom: 1px solid var(--line-soft); }
.portals__list li .tick { width: 22px; height: 22px; border-radius: 6px; background: var(--accent-bg); color: var(--accent-ink); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.portals__list li .tick svg { width: 13px; height: 13px; }
.portals__cta { margin-top: 32px; display: flex; gap: 14px; flex-wrap: wrap; }

/* portal app mock */
.appmock { background: #fff; border: 1px solid var(--line); border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); overflow: hidden; cursor: pointer; transition: box-shadow .25s var(--ease), transform .25s var(--ease), border-color .25s var(--ease); }
.appmock:hover { transform: translateY(-4px); border-color: var(--accent-line); }
.appmock:focus-visible { outline: 2px solid var(--accent-ink); outline-offset: 3px; }
.appmock:hover .appmock__open { color: var(--accent-ink); }
.appmock:hover .appmock__open .ext { transform: translate(2px,-2px); }
.appmock__open { display: inline-flex; gap: 6px; align-items: center; font-family: var(--font-mono); font-size: 11px; color: var(--muted); letter-spacing: .03em; transition: color .2s; }
.appmock__open .ext { transition: transform .2s var(--ease); }
.appmock__bar { display: flex; align-items: center; gap: 10px; padding: 14px 18px; border-bottom: 1px solid var(--line); }
.appmock__bar .pad { margin-left: auto; display:flex; gap: 8px; align-items:center; font-family: var(--font-mono); font-size: 11px; color: var(--blue-ink); }
.appmock__tabs { display: flex; gap: 4px; padding: 12px 16px 0; border-bottom: 1px solid var(--line); }
.appmock__tab { padding: 9px 15px; font-size: 13px; font-weight: 600; color: var(--muted); border-radius: 7px 7px 0 0; cursor: pointer; transition: color .2s, background .2s; border: 1px solid transparent; border-bottom: none; }
.appmock__tab.is-active { color: var(--navy); background: var(--bluegrey); border-color: var(--line); }
.appmock__panel { padding: 22px; display: none; }
.appmock__panel.is-active { display: block; }

.upzone { border: 1.5px dashed var(--accent-line); border-radius: 10px; background: var(--accent-bg); padding: 30px; text-align: center; color: var(--navy); }
.upzone .ic { width: 42px; height: 42px; margin: 0 auto 12px; border-radius: 11px; background: #fff; border:1px solid var(--line); display:flex; align-items:center; justify-content:center; color: var(--accent-ink); }
.upzone b { display:block; font-size: 15px; }
.upzone span { font-size: 13px; color: var(--muted); }
.upmeta { display:grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 16px; }
.upmeta .f { background: var(--bluegrey); border:1px solid var(--line); border-radius: 8px; padding: 11px 13px; }
.upmeta .f label { font-family: var(--font-mono); font-size: 10px; letter-spacing:.06em; text-transform: uppercase; color: var(--muted); }
.upmeta .f div { font-size: 14px; color: var(--navy); font-weight: 600; margin-top: 3px; }

.orderrow { display: grid; grid-template-columns: 1fr auto auto; gap: 12px; align-items: center; padding: 14px 4px; border-bottom: 1px solid var(--line-soft); }
.orderrow:last-child { border-bottom: none; }
.orderrow .o-id { font-family: var(--font-mono); font-size: 12px; color: var(--muted); }
.orderrow .o-name { font-size: 14px; font-weight: 600; color: var(--navy); }
.orderrow .o-sub { font-size: 12px; color: var(--muted); }
.pill { font-size: 11px; font-family: var(--font-mono); letter-spacing: .04em; padding: 4px 10px; border-radius: 100px; font-weight: 500; }
.pill--prep { background: #FFF4E0; color: #9A6B12; }
.pill--qa { background: var(--accent-bg); color: var(--blue-ink); }
.pill--done { background: #E4F3EA; color: #2C7A4B; }

/* ============================================================
   Procurement summary
   ============================================================ */
.procure { background: var(--navy); color: #d4dce8; position: relative; overflow:hidden; }
.procure::before{content:"";position:absolute;inset:0;background:radial-gradient(700px 400px at 10% 110%, rgba(135,195,215,.14), transparent 60%);}
.procure__inner { position: relative; display: grid; grid-template-columns: 1.1fr .9fr; gap: 60px; align-items: center; }
.procure .eyebrow { color: var(--blue); } .procure .eyebrow::before { background: var(--blue); }
.procure h2 { color: #fff; }
.procure p { color: #aebccd; font-size: 18px; margin-top: 22px; }
.procure__proof { display: grid; gap: 12px; }
.proofrow { display: flex; gap: 14px; align-items: center; background: rgba(255,255,255,.04); border: 1px solid rgba(135,195,215,.2); border-radius: 10px; padding: 16px 18px; }
.proofrow .n { font-family: var(--font-mono); font-size: 12px; color: var(--blue); width: 28px; }
.proofrow b { color: #fff; font-size: 16px; font-weight: 600; }

/* ============================================================
   Final CTA
   ============================================================ */
.finalcta { text-align: center; background:
  radial-gradient(700px 400px at 50% 0%, rgba(135,195,215,.16), transparent 65%), #fff; }
.finalcta h2 { font-size: clamp(30px, 3.6vw, 46px); max-width: 760px; margin: 0 auto; }
.finalcta p { color: var(--muted); font-size: 19px; margin: 22px auto 36px; max-width: 540px; }
.finalcta__btns { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }

/* ============================================================
   Quote modal
   ============================================================ */
.modal { position: fixed; inset: 0; z-index: 200; display: none; }
.modal.is-open { display: block; }
.modal__scrim { position: absolute; inset: 0; background: rgba(7,27,51,.55); backdrop-filter: blur(3px); opacity: 0; transition: opacity .3s; }
.modal.is-open .modal__scrim { opacity: 1; }
.modal__card {
  position: relative; max-width: 720px; margin: 5vh auto; background: #fff; border-radius: 14px;
  box-shadow: var(--shadow-lg); overflow: hidden; max-height: 90vh; display: flex; flex-direction: column;
  transform: translateY(16px) scale(.98); opacity: 0; transition: transform .35s var(--ease), opacity .3s;
}
.modal.is-open .modal__card { transform: none; opacity: 1; }
.modal__head { padding: 24px 28px; border-bottom: 1px solid var(--line); display: flex; align-items: flex-start; gap: 16px; }
.modal__head .eyebrow { margin-bottom: 8px; }
.modal__head h3 { font-size: 24px; }
.modal__head p { font-size: 14px; color: var(--muted); margin-top: 6px; }
.modal__close { margin-left: auto; width: 38px; height: 38px; border-radius: 8px; border: 1px solid var(--line); background: #fff; color: var(--navy); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.modal__close:hover { background: var(--bluegrey); }
.modal__body { padding: 24px 28px; overflow-y: auto; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.field { display: flex; flex-direction: column; gap: 6px; }
.field.col-2 { grid-column: span 2; }
.field label { font-size: 13px; font-weight: 600; color: var(--navy); }
.field label .req { color: #C0392B; }
.field input, .field select, .field textarea {
  font-family: inherit; font-size: 14.5px; color: var(--charcoal);
  padding: 11px 13px; border: 1.5px solid var(--line); border-radius: 8px; background: #fff;
  transition: border-color .2s, box-shadow .2s; width: 100%;
}
.field textarea { resize: vertical; min-height: 84px; }
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-bg); }
.field.has-error input, .field.has-error select, .field.has-error textarea { border-color: #C0392B; }
.field .err { font-size: 12px; color: #C0392B; display: none; }
.field.has-error .err { display: block; }
.field .opt { font-weight: 500; color: var(--muted); font-size: 12px; }

/* file attachment */
.filedrop {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 16px; border: 1.5px dashed var(--line); border-radius: 8px;
  background: #fff; cursor: pointer; transition: border-color .2s, background .2s;
}
.filedrop:hover, .filedrop.is-drag { border-color: var(--accent); background: var(--accent-bg); }
.filedrop input[type="file"] { position: absolute; width: 1px; height: 1px; opacity: 0; pointer-events: none; }
.filedrop__ic { flex-shrink: 0; width: 38px; height: 38px; border-radius: 9px; background: var(--bluegrey); border: 1px solid var(--line); display: flex; align-items: center; justify-content: center; color: var(--accent-ink); }
.filedrop__txt b { display: block; font-size: 14px; color: var(--navy); }
.filedrop__txt span { font-size: 12.5px; color: var(--muted); }
.field.has-error .filedrop { border-color: #C0392B; }
.filelist { margin-top: 10px; display: flex; flex-direction: column; gap: 8px; }
.filechip { display: flex; align-items: center; gap: 12px; padding: 10px 12px; background: var(--bluegrey); border: 1px solid var(--line); border-radius: 8px; }
.filechip__ic { flex-shrink: 0; width: 30px; height: 30px; border-radius: 7px; background: #fff; border: 1px solid var(--line); display: flex; align-items: center; justify-content: center; color: var(--navy); font-family: var(--font-mono); font-size: 9.5px; font-weight: 600; letter-spacing: .02em; }
.filechip__meta { flex: 1; min-width: 0; }
.filechip__meta b { display: block; font-size: 13.5px; color: var(--navy); font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.filechip__meta span { font-size: 12px; color: var(--muted); font-family: var(--font-mono); }
.filechip__rm { flex-shrink: 0; width: 28px; height: 28px; border-radius: 6px; border: 1px solid var(--line); background: #fff; color: var(--muted); display: flex; align-items: center; justify-content: center; }
.filechip__rm:hover { border-color: #C0392B; color: #C0392B; }
.form-foot { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-top: 22px; padding-top: 20px; border-top: 1px solid var(--line); }
.form-foot .note { font-size: 12px; color: var(--muted); font-family: var(--font-mono); display: flex; align-items: center; gap: 8px; }
.form-success { text-align: center; padding: 30px 10px; display: none; }
.form-success.is-on { display: block; }
.form-success .ok { width: 64px; height: 64px; border-radius: 50%; background: var(--accent-bg); color: var(--blue-ink); display: flex; align-items: center; justify-content: center; margin: 0 auto 20px; }
.form-success .ok svg { width: 30px; height: 30px; }
.form-success h3 { font-size: 24px; margin-bottom: 12px; }
.form-success p { color: var(--muted); font-size: 15.5px; max-width: 420px; margin: 0 auto; }

/* ============================================================
   Supplier band
   ============================================================ */
.supplier { background: var(--panel); border-top: 1px solid var(--line-soft); }
.supplier__inner { display: flex; align-items: center; justify-content: space-between; gap: 48px; padding: 56px 0; }
.supplier__copy { max-width: 620px; }
.supplier__title { font-size: clamp(24px, 2.4vw, 30px); margin-top: 14px; }
.supplier__copy p { margin-top: 14px; color: var(--muted); font-size: 16px; }
.supplier__action { display: flex; flex-direction: column; align-items: flex-end; gap: 10px; flex-shrink: 0; }
.supplier__note { font-family: var(--font-mono); font-size: 11.5px; color: var(--muted); letter-spacing: .02em; }
@media (max-width: 880px){
  .supplier__inner { flex-direction: column; align-items: flex-start; gap: 24px; }
  .supplier__action { align-items: flex-start; }
}

/* ============================================================
   Footer
   ============================================================ */
.footer { background: var(--navy-deep); color: #97a6b8; padding: 72px 0 34px; }
.footer__top { display: grid; grid-template-columns: 1.4fr repeat(4, 1fr); gap: 40px; padding-bottom: 48px; border-bottom: 1px solid rgba(255,255,255,.08); }
.footer__brand .brand__word { color: #fff; }
.footer__brand p { margin-top: 18px; font-size: 14px; color: #8092a6; max-width: 300px; line-height: 1.6; }
.footer__brand .f-certs { display: flex; gap: 10px; margin-top: 22px; }
.footer__brand .f-certs span { font-family: var(--font-mono); font-size: 10.5px; color: var(--blue); border: 1px solid rgba(135,195,215,.3); padding: 6px 10px; border-radius: 6px; }
.footer__col h5 { font-family: var(--font-mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--blue); margin: 0 0 16px; font-weight: 500; }
.footer__col ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 11px; }
.footer__col a { font-size: 14px; color: #97a6b8; transition: color .15s; }
.footer__col a:hover { color: #fff; }
.footer__bot { display: flex; justify-content: space-between; align-items: center; gap: 20px; padding-top: 28px; flex-wrap: wrap; }
.footer__bot p { font-size: 12.5px; color: #6f8093; }
.footer__bot .f-meta { display: flex; gap: 20px; font-size: 12.5px; }

/* ============================================================
   Reveal animation
   ============================================================ */
.reveal { opacity: 0; transform: translateY(22px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.is-in { opacity: 1; transform: none; }
.reveal[data-d="1"] { transition-delay: .08s; }
.reveal[data-d="2"] { transition-delay: .16s; }
.reveal[data-d="3"] { transition-delay: .24s; }
@media (prefers-reduced-motion: reduce) { .reveal { opacity: 1; transform: none; transition: none; } html { scroll-behavior: auto; } }

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 1080px){
  .nav { display: none; }
  .header__cta { display: none; }
  .burger { display: flex; }
  .hero__inner { grid-template-columns: 1fr; gap: 48px; padding: 64px 0 72px; }
  .security__grid, .portals__grid, .procure__inner { grid-template-columns: 1fr; gap: 44px; }
  .quality__grid { grid-template-columns: 1fr 1fr; }
  .flow__steps { grid-template-columns: 1fr 1fr; gap: 36px 22px; }
  .flow__track { display: none; }
  .flow__head { flex-direction: column; align-items: flex-start; gap: 20px; }
}
@media (max-width: 680px){
  :root { --gutter: 22px; }
  .section { padding: 72px 0; }
  .cred__points { grid-template-columns: 1fr; }
  .seclist, .upmeta { grid-template-columns: 1fr; }
  .quality__grid, .flow__steps { grid-template-columns: 1fr; }
  .form-grid { grid-template-columns: 1fr; }
  .field.col-2 { grid-column: span 1; }
  .footer__top { grid-template-columns: 1fr 1fr; gap: 32px; }
  .footer__brand { grid-column: span 2; }
  .hero__trust { gap: 10px 14px; }
}

/* mobile drawer active */
.drawer.is-open { display: block; position: fixed; inset: 100px 0 0; z-index: 55; background: #fff; padding: 24px var(--gutter); overflow-y: auto; }
.drawer nav { display: flex; flex-direction: column; gap: 2px; }
.drawer nav a { padding: 14px 4px; font-size: 17px; font-weight: 500; color: var(--navy); border-bottom: 1px solid var(--line-soft); }
.drawer__cta { margin-top: 24px; display: flex; flex-direction: column; gap: 12px; }
