/* ============================================================
   UMDigital — Website (Relaunch, Richtung A „Klar & Hell")
   Shared stylesheet for all pages. Builds on the brand tokens.
   ============================================================ */
@import url('colors_and_type.css');

*, *::before, *::after { 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; text-rendering: optimizeLegibility; }
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
::selection { background: var(--umd-sky-100); color: var(--umd-navy); }

.wrap { max-width: var(--container); margin: 0 auto; padding: 0 28px; }
.eyebrow { font: 700 var(--fs-eyebrow)/1 var(--font-sans); letter-spacing: var(--tracking-eyebrow); text-transform: uppercase; color: var(--accent); display: inline-block; }
.lead { font: 400 var(--fs-lead)/var(--lh-body) var(--font-sans); color: var(--fg-muted); }
.h1 { font: 800 var(--fs-display)/var(--lh-tight) var(--font-sans); letter-spacing: -.02em; color: var(--fg); margin: 0; text-wrap: balance; }
.h2 { font: 800 var(--fs-h2)/var(--lh-snug) var(--font-sans); letter-spacing: -.015em; color: var(--fg); margin: 0; text-wrap: balance; }
.h3 { font: 700 var(--fs-h3)/1.3 var(--font-sans); color: var(--fg); margin: 0; }

/* ---------- Buttons ---------- */
.btn { display: inline-flex; align-items: center; gap: 9px; font-family: var(--font-sans); font-weight: 700; font-size: 15px; line-height: 1; border-radius: 999px; padding: 15px 26px; border: 1.5px solid transparent; cursor: pointer; transition: .16s ease; white-space: nowrap; }
.btn svg { width: 18px; height: 18px; }
.btn-primary { background: var(--umd-sky); color: #fff; }
.btn-primary:hover { background: var(--umd-sky-700); transform: translateY(-1px); }
.btn-secondary { background: transparent; color: var(--umd-navy); border-color: var(--border-strong); }
.btn-secondary:hover { background: var(--umd-navy); color: #fff; border-color: var(--umd-navy); }
.btn-ink { background: #fff; color: var(--umd-navy); }
.btn-ink:hover { background: var(--umd-sky); color: #fff; }
.btn-ghost-ink { background: transparent; color: #fff; border-color: rgba(255,255,255,.4); }
.btn-ghost-ink:hover { background: rgba(255,255,255,.12); }
.btn:active { transform: scale(.985); }

/* ---------- Header ---------- */
.hdr { position: sticky; top: 0; z-index: 60; background: rgba(255,255,255,.82); backdrop-filter: saturate(160%) blur(12px); -webkit-backdrop-filter: saturate(160%) blur(12px); border-bottom: 1px solid transparent; transition: .2s ease; }
.hdr.scrolled { border-bottom-color: var(--border); box-shadow: var(--sh-sm); background: rgba(255,255,255,.92); }
.hdr-in { display: flex; align-items: center; gap: 30px; height: 76px; }
.hdr-logo img { height: 40px; }
.nav { display: flex; gap: 26px; margin-left: 6px; }
.nav a { font-size: 15px; font-weight: 600; color: var(--umd-navy-600); transition: .15s; position: relative; padding: 4px 0; }
.nav a:hover { color: var(--umd-sky); }
.nav a.active { color: var(--umd-navy); }
.nav a.active::after { content: ""; position: absolute; left: 0; right: 0; bottom: -2px; height: 2px; border-radius: 2px; background: var(--umd-sky); }
.hdr-cta { margin-left: auto; display: flex; align-items: center; gap: 14px; }

/* nav dropdown */
.nav-item { position: relative; display: flex; align-items: center; }
.nav-top { display: inline-flex; align-items: center; gap: 5px; cursor: pointer; }
.nav-top svg { width: 15px; height: 15px; transition: transform .18s; }
.nav-item:hover .nav-top svg { transform: rotate(180deg); }
.submenu { position: absolute; top: calc(100% + 10px); left: -14px; min-width: 262px; background: #fff; border: 1px solid var(--border); border-radius: 14px; box-shadow: var(--sh-lg); padding: 8px; display: none; flex-direction: column; gap: 2px; }
.submenu::before { content: ""; position: absolute; top: -12px; left: 0; right: 0; height: 14px; }
.nav-item:hover .submenu { display: flex; }
.submenu a { padding: 11px 14px; border-radius: 9px; font-size: 14.5px; font-weight: 600; color: var(--umd-navy-600); white-space: nowrap; }
.submenu a:hover { background: var(--umd-sky-050); color: var(--umd-sky-700); }
.drawer a.sub { padding-left: 18px; font-size: 15px; font-weight: 500; color: var(--umd-navy-600); border-bottom-color: var(--umd-mist); }
.burger { display: none; background: none; border: 0; color: var(--umd-navy); cursor: pointer; padding: 6px; }
.burger svg { width: 28px; height: 28px; }
.drawer { position: fixed; inset: 76px 0 auto 0; background: #fff; border-bottom: 1px solid var(--border); box-shadow: var(--sh-lg); z-index: 59; padding: 16px 28px 26px; display: none; flex-direction: column; gap: 2px; }
.drawer.open { display: flex; }
.drawer a { padding: 14px 0; font-size: 17px; font-weight: 600; color: var(--umd-navy); border-bottom: 1px solid var(--border); }
.drawer .btn { margin-top: 16px; justify-content: center; }

/* ---------- Sections ---------- */
section { padding: 92px 0; }
.sec-paper { background: var(--bg-subtle); }
.sec-ink { background: var(--bg-ink); color: var(--fg-on-ink); }
.sec-ink .lead { color: var(--fg-on-ink-mut); }
.sec-ink .h2 { color: #fff; }
.sec-head { max-width: 760px; }
.sec-head .h2 { margin: 16px 0 18px; }

/* ---------- Page header (subpages) ---------- */
.pagehead { padding: 72px 0 56px; background: var(--bg-subtle); border-bottom: 1px solid var(--border); }
.pagehead .inner { max-width: 800px; }
.pagehead .h1 { font-size: var(--fs-h1); margin: 16px 0 18px; }
.pagehead .lead { margin: 0; max-width: 38em; }

/* ---------- Hero ---------- */
.hero { padding: 64px 0 96px; }
.hero-grid { display: grid; grid-template-columns: 1.12fr .88fr; gap: 52px; align-items: center; }
.hero h1 { margin: 18px 0 22px; }
.hero .lead { max-width: 30em; }
.hero-cta { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 30px; }
.hero-chips { display: flex; gap: 9px; flex-wrap: wrap; margin-top: 26px; }
.chip { font-size: 12.5px; font-weight: 600; color: var(--umd-navy-600); background: var(--umd-mist); padding: 8px 14px; border-radius: 999px; transition: .15s; }
.chip:hover { background: var(--umd-sky-100); color: var(--umd-sky-700); }
.hero-img { display: flex; justify-content: flex-end; }
.hero-img img { width: 100%; max-width: 360px; filter: drop-shadow(0 26px 46px rgba(32,50,64,.2)); }

/* ---------- Stats ---------- */
.stats { display: grid; grid-template-columns: repeat(4,1fr); gap: 24px; margin-top: 68px; padding-top: 40px; border-top: 1px solid var(--border); }
.stat .fig { font-size: 42px; font-weight: 800; letter-spacing: -.02em; color: var(--umd-navy); line-height: 1; }
.stat .cap { font-size: 14px; color: var(--fg-muted); margin-top: 8px; line-height: 1.45; }
.sec-ink .stat .fig { color: #fff; }
.sec-ink .stat .cap { color: var(--fg-on-ink-mut); }

/* ---------- Clients ---------- */
.clients-sec { padding: 56px 0; }
.clients-sec .eyebrow { display: block; text-align: center; margin-bottom: 30px; color: var(--fg-subtle); }
.clients { display: flex; align-items: center; gap: 52px; flex-wrap: wrap; justify-content: center; filter: grayscale(1); opacity: .72; }
.clients img { height: 42px; }
.clients .wg { height: 76px; }

/* ---------- Tiles (service cards) ---------- */
.tiles { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; margin-top: 46px; }
.tile { display: flex; flex-direction: column; background: #fff; border: 1px solid var(--border); border-radius: 18px; padding: 30px; box-shadow: var(--sh-sm); transition: .18s ease; }
.tile:hover { box-shadow: var(--sh-lg); border-color: var(--border-strong); transform: translateY(-3px); }
.tile .ic { width: 52px; height: 52px; border-radius: 13px; background: var(--umd-sky-050); color: var(--umd-sky); display: flex; align-items: center; justify-content: center; margin-bottom: 18px; }
.tile .ic svg { width: 26px; height: 26px; }
.tile .eb { font-size: 12.5px; font-weight: 700; letter-spacing: .07em; text-transform: uppercase; color: var(--fg-subtle); margin-bottom: 8px; }
.tile h3 { margin: 0 0 10px; }
.tile p { margin: 0; font-size: 15px; line-height: 1.55; color: var(--fg-muted); }
.tile .more { margin-top: auto; padding-top: 18px; font-size: 14px; font-weight: 700; color: var(--umd-sky); display: inline-flex; gap: 6px; align-items: center; }
.tile .more svg { width: 16px; height: 16px; transition: transform .16s; }
.tile:hover .more svg { transform: translateX(3px); }

/* ---------- Offer (numbered KI cards) ---------- */
.offer-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 20px; margin-top: 46px; }
.offer { padding: 28px; border: 1px solid var(--border); border-radius: 16px; background: #fff; transition: .18s ease; }
.offer:hover { box-shadow: var(--sh-md); transform: translateY(-3px); }
.offer .n { display: inline-flex; align-items: center; justify-content: center; width: 38px; height: 38px; border-radius: 10px; background: var(--umd-sky-050); font-size: 16px; font-weight: 800; color: var(--umd-sky); }
.offer h3 { font-size: 18px; margin: 16px 0 8px; }
.offer p { margin: 0; font-size: 14.5px; line-height: 1.55; color: var(--fg-muted); }

/* ---------- Use cases ---------- */
.uc-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; margin-top: 46px; }
.uc { display: flex; gap: 15px; padding: 24px; border-radius: 14px; background: #fff; border: 1px solid var(--border); transition: .16s ease; }
.uc:hover { border-color: var(--umd-sky); box-shadow: var(--sh-sm); }
.uc .ic { color: var(--umd-sky); flex: none; }
.uc .ic svg { width: 26px; height: 26px; }
.uc h4 { margin: 0 0 5px; font-size: 16px; color: var(--umd-navy); }
.uc p { margin: 0; font-size: 14px; line-height: 1.5; color: var(--fg-muted); }

/* ---------- Process ---------- */
.proc { display: grid; grid-template-columns: repeat(5,1fr); gap: 0; margin-top: 52px; }
.proc .step { padding: 0 24px; border-left: 1px solid var(--border); }
.proc .step:first-child { padding-left: 0; border-left: 0; }
.proc .n { font-size: 56px; font-weight: 800; letter-spacing: -.03em; color: var(--umd-sky); line-height: 1; }
.proc h4 { margin: 16px 0 8px; font-size: 19px; color: var(--umd-navy); }
.proc p { margin: 0; font-size: 14px; line-height: 1.5; color: var(--fg-muted); }

/* ---------- FAQ ---------- */
.faq { max-width: 800px; margin-top: 40px; }
.qa { border-bottom: 1px solid var(--border); }
.qa button { width: 100%; text-align: left; background: none; border: 0; padding: 24px 0; font-family: var(--font-sans); font-size: 18px; font-weight: 700; color: var(--umd-navy); cursor: pointer; display: flex; justify-content: space-between; align-items: center; gap: 16px; }
.qa .pm { color: var(--umd-sky); transition: transform .25s; flex: none; display: inline-flex; }
.qa .pm svg { width: 22px; height: 22px; }
.qa.open .pm { transform: rotate(45deg); }
.qa .ans { overflow: hidden; max-height: 0; transition: max-height .3s ease, padding .3s ease; }
.qa .ans p { margin: 0; font-size: 15.5px; line-height: 1.6; color: var(--fg-muted); max-width: 64ch; }
.qa.open .ans { max-height: 260px; }
.qa.open .ans p { padding-bottom: 24px; }

/* ---------- CTA band + form ---------- */
.cta-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }
.cta-grid .eyebrow { color: var(--umd-sky-300); }
.contact-line { display: flex; align-items: center; gap: 13px; margin: 14px 0; font-size: 16px; color: var(--fg-on-ink); }
.contact-line .ic { color: var(--umd-sky); display: inline-flex; }
.contact-line a:hover { color: #fff; }
.field { display: flex; flex-direction: column; gap: 6px; margin-bottom: 16px; }
.field label { font-size: 13px; font-weight: 600; color: #fff; }
.field input, .field textarea { font-family: var(--font-sans); font-size: 15px; color: #fff; padding: 14px 15px; border: 1.5px solid rgba(255,255,255,.22); border-radius: 10px; background: rgba(255,255,255,.06); outline: none; transition: .15s; resize: vertical; }
.field input::placeholder, .field textarea::placeholder { color: var(--fg-on-ink-mut); }
.field input:focus, .field textarea:focus { border-color: var(--umd-sky); background: rgba(255,255,255,.1); }
.form-note { font-size: 12.5px; color: var(--fg-on-ink-mut); margin: 6px 0 0; }

/* light form variant (kontakt page) */
.form-light .field label { color: var(--umd-navy); }
.form-light .field input, .form-light .field textarea { color: var(--umd-navy); border-color: var(--border-strong); background: #fff; }
.form-light .field input::placeholder, .form-light .field textarea::placeholder { color: var(--fg-subtle); }
.form-light .field input:focus, .form-light .field textarea:focus { border-color: var(--umd-sky); box-shadow: var(--sh-focus); }
.form-light .form-note { color: var(--fg-subtle); }

/* ---------- Footer ---------- */
.ftr { background: var(--umd-navy-900); color: var(--fg-on-ink-mut); padding: 72px 0 36px; }
.ftr-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr; gap: 44px; }
.ftr-logo img { height: 40px; margin-bottom: 20px; }
.ftr h5 { font-size: 12.5px; font-weight: 800; letter-spacing: .12em; color: #fff; margin: 0 0 16px; }
.ftr a, .ftr p { font-size: 14.5px; line-height: 1.95; color: var(--fg-on-ink-mut); margin: 0; }
.ftr a { transition: .15s; }
.ftr a:hover { color: #fff; }
.ftr-bottom { border-top: 1px solid rgba(255,255,255,.1); margin-top: 52px; padding-top: 24px; font-size: 13px; color: #7B8C99; display: flex; justify-content: space-between; align-items: center; gap: 20px; flex-wrap: wrap; }
.ftr-bottom a:hover { color: #fff; }
.ftr-bottom-left { display: flex; flex-direction: column; gap: 10px; }
.ftr-verch { display: inline-flex; align-items: center; gap: 9px; color: #7B8C99; font-size: 12.5px; transition: .15s; }
.ftr-verch img { height: 20px; width: auto; opacity: .92; }
.ftr-verch:hover { color: #fff; }
.ftr-partner { margin-top: 26px; }
.ftr-partner-label { display: block; font-size: 11.5px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: #7B8C99; margin-bottom: 10px; }
.ftr-partner img { height: 46px; width: auto; opacity: .95; }

/* ---------- Split / feature rows (Leistungen) ---------- */
.split { display: grid; grid-template-columns: .9fr 1.1fr; gap: 56px; align-items: center; }
.split.flip .split-media { order: 2; }
.split + .split { margin-top: 88px; }
.split-media { border-radius: 18px; overflow: hidden; box-shadow: var(--sh-md); background: var(--umd-mist); }
.split-media img { width: 100%; }
.split-media.mono { box-shadow: none; background: transparent; display: flex; justify-content: center; }
.split-media.mono img { max-width: 300px; filter: drop-shadow(0 22px 40px rgba(32,50,64,.18)); }
.feat-list { list-style: none; padding: 0; margin: 22px 0 0; display: grid; gap: 12px; }
.feat-list li { display: flex; gap: 12px; align-items: flex-start; font-size: 15.5px; line-height: 1.5; color: var(--fg); }
.feat-list .ic { color: var(--umd-sky); flex: none; margin-top: 1px; }
.feat-list .ic svg { width: 20px; height: 20px; }

/* icon media panel for service rows */
.svc-media { aspect-ratio: 4 / 3.2; border-radius: 18px; background: var(--umd-sky-050); border: 1px solid var(--umd-sky-100); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 18px; text-align: center; padding: 32px; }
.svc-media .big { width: 88px; height: 88px; border-radius: 22px; background: #fff; color: var(--umd-sky); display: flex; align-items: center; justify-content: center; box-shadow: var(--sh-sm); }
.svc-media .big svg { width: 42px; height: 42px; }
.svc-media .lbl { font-size: 13px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--umd-navy-500); }
.svc-media.paper { background: var(--umd-paper); border-color: var(--border); }
.svc-media.field { background: var(--umd-field-100); border-color: #DDE6C0; }
.svc-media.field .big { color: var(--umd-field-700); }

/* tools strip */
.tools { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 40px; }
.tool { font-size: 14px; font-weight: 600; color: var(--umd-navy-600); background: #fff; border: 1px solid var(--border); border-radius: 999px; padding: 10px 18px; }

/* ---------- Team / bio ---------- */
.team-photo { border-radius: 18px; overflow: hidden; box-shadow: var(--sh-md); margin-top: 8px; }
.team-photo img { width: 100%; }
.founders { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; margin-top: 46px; }
.founder { background: #fff; border: 1px solid var(--border); border-radius: 16px; padding: 28px; }
.founder .role { font-size: 12.5px; font-weight: 700; letter-spacing: .07em; text-transform: uppercase; color: var(--umd-sky); }
.founder h3 { margin: 10px 0 6px; font-size: 22px; }
.founder p { margin: 0; font-size: 15px; line-height: 1.55; color: var(--fg-muted); }
.values { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; margin-top: 46px; }
.value { padding: 26px; border-radius: 14px; background: var(--umd-paper); border: 1px solid var(--border); }
.value .ic { color: var(--umd-sky); margin-bottom: 14px; }
.value .ic svg { width: 26px; height: 26px; }
.value h4 { margin: 0 0 8px; font-size: 17px; color: var(--umd-navy); }
.value p { margin: 0; font-size: 14.5px; line-height: 1.55; color: var(--fg-muted); }

/* ---------- Video frame (embed placeholder) ---------- */
.videoframe { position: relative; aspect-ratio: 16 / 9; border-radius: 18px; overflow: hidden; background: var(--umd-navy); box-shadow: var(--sh-md); display: flex; align-items: center; justify-content: center; }
.videoframe iframe, .videoframe video { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }
.videoframe .vf-ph { display: flex; flex-direction: column; align-items: center; gap: 16px; color: #fff; text-align: center; padding: 24px; }
.videoframe .vf-play { width: 76px; height: 76px; border-radius: 999px; background: var(--umd-sky); display: flex; align-items: center; justify-content: center; box-shadow: var(--sh-md); }
.videoframe .vf-play svg { width: 32px; height: 32px; margin-left: 3px; }
.videoframe .vf-cap { font-size: 15px; font-weight: 600; color: var(--fg-on-ink); }
.videoframe .vf-sub { font-size: 13px; color: var(--fg-on-ink-mut); }

/* ---------- Mini-flow strip (subpage hero) ---------- */
.miniflow { display: grid; grid-template-columns: repeat(4,1fr); gap: 18px; margin-top: 56px; padding-top: 36px; border-top: 1px solid var(--border); }
.miniflow .mf { display: flex; gap: 14px; align-items: flex-start; }
.miniflow .mf .num { flex: none; width: 34px; height: 34px; border-radius: 999px; background: var(--umd-sky); color: #fff; display: flex; align-items: center; justify-content: center; font-weight: 800; font-size: 15px; }
.miniflow .mf p { margin: 4px 0 0; font-size: 14.5px; line-height: 1.45; color: var(--fg); }
@media (max-width: 760px) { .miniflow { grid-template-columns: 1fr 1fr; gap: 22px; } }
@media (max-width: 460px) { .miniflow { grid-template-columns: 1fr; } }

/* ---------- Team roster ---------- */
.area-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 18px; margin-top: 44px; }
.area { padding: 24px; border-radius: 14px; background: #fff; border: 1px solid var(--border); box-shadow: var(--sh-sm); }
.area .ic { width: 44px; height: 44px; border-radius: 11px; background: var(--umd-sky-050); color: var(--umd-sky); display: flex; align-items: center; justify-content: center; margin-bottom: 14px; }
.area .ic svg { width: 22px; height: 22px; }
.area h4 { margin: 0 0 7px; font-size: 16px; color: var(--umd-navy); }
.area p { margin: 0; font-size: 14px; line-height: 1.5; color: var(--fg-muted); }

.dept { margin-top: 48px; }
.dept:first-of-type { margin-top: 36px; }
.dept-label { font: 700 var(--fs-eyebrow)/1 var(--font-sans); letter-spacing: var(--tracking-eyebrow); text-transform: uppercase; color: var(--umd-navy-500); padding-bottom: 14px; border-bottom: 1px solid var(--border); margin-bottom: 24px; }
.team-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 18px; }
.member { display: flex; flex-direction: column; padding: 24px; border-radius: 16px; background: #fff; border: 1px solid var(--border); transition: .16s ease; }
.member:hover { box-shadow: var(--sh-md); transform: translateY(-3px); border-color: var(--border-strong); }
.member .m-av { width: 76px; height: 76px; border-radius: 16px; background: var(--umd-sky-050); color: var(--umd-sky); display: flex; align-items: center; justify-content: center; font-weight: 800; font-size: 22px; letter-spacing: -.02em; margin-bottom: 16px; overflow: hidden; }
.member .m-av img { width: 100%; height: 100%; object-fit: cover; object-position: top center; }
.member.lead-m .m-av { background: var(--umd-navy); color: #fff; }
.member h4 { margin: 0 0 3px; font-size: 17px; color: var(--umd-navy); }
.member .m-role { font-size: 12.5px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: var(--umd-sky); margin-bottom: 10px; }
.member p { margin: 0; font-size: 13.5px; line-height: 1.5; color: var(--fg-muted); }
@media (max-width: 980px) { .area-grid, .team-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .area-grid, .team-grid { grid-template-columns: 1fr; } }

/* ---------- Karriere ---------- */
.benefits { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; margin-top: 46px; }
.benefit { padding: 26px; border-radius: 14px; background: #fff; border: 1px solid var(--border); box-shadow: var(--sh-sm); }
.benefit .ic { color: var(--umd-sky); margin-bottom: 14px; }
.benefit .ic svg { width: 26px; height: 26px; }
.benefit h4 { margin: 0 0 8px; font-size: 17px; color: var(--umd-navy); }
.benefit p { margin: 0; font-size: 14.5px; line-height: 1.55; color: var(--fg-muted); }

/* ---------- Legal pages ---------- */
.legal { max-width: 800px; padding: 64px 0 96px; }
.legal h2 { font: 800 1.5rem/1.2 var(--font-sans); letter-spacing: -.015em; color: var(--umd-navy); margin: 44px 0 14px; }
.legal h2:first-of-type { margin-top: 12px; }
.legal h3 { font: 700 1.1rem/1.3 var(--font-sans); color: var(--umd-navy); margin: 28px 0 10px; }
.legal p, .legal li { font-size: 15.5px; line-height: 1.7; color: var(--fg); }
.legal p { margin: 0 0 14px; }
.legal ul { margin: 0 0 14px; padding-left: 22px; }
.legal li { margin-bottom: 6px; }
.legal a { color: var(--umd-sky); }
.legal a:hover { text-decoration: underline; }
.legal .ph { background: var(--umd-field-100); color: var(--umd-field-700); padding: 1px 7px; border-radius: 5px; font-weight: 600; font-size: .92em; }

/* ---------- Success state ---------- */
.sent { display: none; background: rgba(39,135,200,.14); border: 1px solid var(--umd-sky); border-radius: 14px; padding: 24px; }
.sent.show { display: block; }
.sent .t { font-size: 22px; font-weight: 800; margin-bottom: 8px; color: var(--umd-navy); }
.sent p { margin: 0; color: var(--fg-muted); }
.sec-ink .sent { color: #fff; }
.sec-ink .sent .t { color: #fff; }
.sec-ink .sent p { color: var(--fg-on-ink-mut); }

/* ---------- Scroll reveal ---------- */
.reveal { opacity: 0; transform: translateY(18px); transition: opacity .6s ease, transform .6s ease; }
.reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
  html { scroll-behavior: auto; }
}

/* ---------- Responsive ---------- */
@media (max-width: 980px) {
  .hero-grid, .cta-grid, .split, .split.flip { grid-template-columns: 1fr; gap: 40px; }
  .hero-img { justify-content: center; }
  .split.flip .split-media { order: 0; }
  .tiles, .offer-grid, .uc-grid, .values, .benefits { grid-template-columns: 1fr 1fr; }
  .founders { grid-template-columns: 1fr; }
  .proc { grid-template-columns: 1fr 1fr; gap: 28px 24px; }
  .proc .step { border-left: 0; padding: 0; }
}
@media (max-width: 880px) {
  .nav, .hdr-cta .btn { display: none; }
  .burger { display: block; }
}
@media (max-width: 620px) {
  section { padding: 64px 0; }
  .hero { padding: 40px 0 64px; }
  .stats { grid-template-columns: 1fr 1fr; row-gap: 30px; }
  .tiles, .offer-grid, .uc-grid, .values, .benefits, .proc { grid-template-columns: 1fr; }
  .hero-img img { max-width: 280px; }
  .ftr-grid { grid-template-columns: 1fr; gap: 34px; }
  .ftr-bottom { flex-direction: column; gap: 8px; }
}
