/* ICU Desk — public platform landing (icudesk.com). Warm brand, self-hosted Manrope. */
@font-face { font-family: 'Manrope'; font-weight: 400; font-display: swap; src: url('fonts/manrope-latin-400-normal.woff2') format('woff2'); }
@font-face { font-family: 'Manrope'; font-weight: 600; font-display: swap; src: url('fonts/manrope-latin-600-normal.woff2') format('woff2'); }
@font-face { font-family: 'Manrope'; font-weight: 700; font-display: swap; src: url('fonts/manrope-latin-700-normal.woff2') format('woff2'); }
@font-face { font-family: 'Manrope'; font-weight: 800; font-display: swap; src: url('fonts/manrope-latin-800-normal.woff2') format('woff2'); }

:root {
  --bg: #f7f5f2;
  --surface: #ffffff;
  --ink: #2d2926;
  --muted: #6f6a63;
  --teal: #4a9e8e;
  --teal-dark: #3d8376;
  --border: #e7e2da;
  --max: 1080px;
}
* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: 'Manrope', system-ui, -apple-system, sans-serif;
  background: var(--bg);
  color: var(--ink);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
.wrap { max-width: var(--max); margin: 0 auto; padding: 0 1.25rem; }
.section { padding: 4.5rem 0; }
.eyebrow { font-size: .72rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--teal-dark); }
h2.title { font-size: clamp(1.6rem, 4vw, 2.2rem); font-weight: 800; letter-spacing: -.02em; margin: .4rem 0 .6rem; }
.lead { color: var(--muted); font-size: 1.05rem; max-width: 46ch; }

/* Wordmark */
.wm { font-weight: 800; letter-spacing: -.02em; }
.wm .icu { color: var(--teal); }

/* Buttons */
.btn { display: inline-flex; align-items: center; gap: .5rem; font-weight: 700; font-size: .95rem;
  padding: .8rem 1.4rem; border-radius: 999px; transition: transform .15s, background .2s, border-color .2s; }
.btn-primary { background: var(--teal); color: #fff; }
.btn-primary:hover { background: var(--teal-dark); transform: translateY(-1px); }
.btn-ghost { border: 1.5px solid var(--border); color: var(--ink); }
.btn-ghost:hover { border-color: var(--teal); }

/* Header */
header.nav { position: sticky; top: 0; z-index: 50; background: rgba(247,245,242,.85); backdrop-filter: blur(10px); border-bottom: 1px solid var(--border); }
.nav-inner { display: flex; align-items: center; justify-content: space-between; height: 64px; }
.brand { display: flex; align-items: center; gap: .55rem; }
.brand img { width: 30px; height: 30px; }
.brand .wm { font-size: 1.15rem; }
.nav-links { display: flex; align-items: center; gap: 1.5rem; }
.nav-links a.lnk { font-weight: 600; font-size: .9rem; color: var(--muted); }
.nav-links a.lnk:hover { color: var(--ink); }
@media (max-width: 720px) { .nav-links .lnk { display: none; } }

/* Hero */
.hero { position: relative; overflow: hidden; text-align: center; padding: 4.5rem 0 4rem; }
.hero .chip { width: 64px; height: 64px; border-radius: 18px; background: var(--surface); box-shadow: 0 4px 20px rgba(0,0,0,.06); border: 1px solid var(--border);
  display: inline-flex; align-items: center; justify-content: center; margin-bottom: 1.25rem; }
.hero .chip img { width: 40px; height: 40px; }
.hero .wm { font-size: clamp(2.6rem, 9vw, 4.2rem); line-height: 1; }
.hero .statement { margin-top: .9rem; font-size: clamp(1.1rem, 3.2vw, 1.5rem); font-weight: 700; color: var(--ink); }
.hero .sub { margin: 1rem auto 0; color: var(--muted); max-width: 52ch; font-size: 1.05rem; }
.hero .cta { margin-top: 1.8rem; display: flex; gap: .75rem; justify-content: center; flex-wrap: wrap; }
.ecg { display: block; width: 100%; height: 28px; color: var(--teal); opacity: .35; margin-top: 2.5rem; }

/* Mission band */
.mission { background: linear-gradient(135deg, #eaf4f1, #f7f5f2); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.mission p { font-size: clamp(1.15rem, 3vw, 1.5rem); font-weight: 600; max-width: 60ch; margin: 0 auto; text-align: center; line-height: 1.5; }
.mission .who { display: flex; gap: .5rem; flex-wrap: wrap; justify-content: center; margin-top: 1.5rem; }
.mission .who span { font-size: .8rem; font-weight: 600; color: var(--teal-dark); background: #fff; border: 1px solid var(--border); border-radius: 999px; padding: .35rem .85rem; }

/* Cards grid */
.grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; margin-top: 2rem; }
@media (max-width: 860px) { .grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .grid { grid-template-columns: 1fr; } }
.card { background: var(--surface); border: 1px solid var(--border); border-radius: 18px; padding: 1.5rem; transition: border-color .2s, transform .15s; position: relative; overflow: hidden; }
.card .accent { position: absolute; left: 0; top: 0; bottom: 0; width: 4px; }
a.card:hover { border-color: var(--teal); transform: translateY(-2px); }
.card .ic { display: inline-flex; align-items: center; justify-content: center; width: 46px; height: 46px; border-radius: 12px; }
.card .ic svg { width: 24px; height: 24px; }
.card h3 { font-size: 1.15rem; font-weight: 700; margin: .6rem 0 .3rem; }
.card p { color: var(--muted); font-size: .92rem; }
.card .go { margin-top: .9rem; font-weight: 700; font-size: .85rem; color: var(--teal-dark); }
.card.soon { opacity: .85; }
.card.soon .tag { font-size: .68rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--muted); }

/* Toolkit chips */
.chips { display: flex; flex-wrap: wrap; gap: .5rem; margin-top: 1.5rem; }
.chips span { font-size: .82rem; font-weight: 600; color: var(--muted); background: var(--surface); border: 1px solid var(--border); border-radius: 999px; padding: .4rem .8rem; }

/* About */
.about { display: grid; grid-template-columns: 220px 1fr; gap: 2.5rem; align-items: start; }
@media (max-width: 720px) { .about { grid-template-columns: 1fr; gap: 1.5rem; } }
.about .photo { aspect-ratio: 1; border-radius: 20px; overflow: hidden; border: 1px solid var(--border); background: #e6f4f1; }
.about .photo img { width: 100%; height: 100%; object-fit: cover; object-position: center; display: block; }
.about h3 { font-size: 1.5rem; font-weight: 800; letter-spacing: -.01em; }
.about .role { color: var(--teal-dark); font-weight: 700; margin: .25rem 0 1rem; }
.about p { color: var(--ink); margin-bottom: 1rem; max-width: 60ch; }
.about .creds { display: flex; flex-direction: column; gap: .5rem; margin-top: 1rem; }
.about .creds li { list-style: none; padding-left: 1.5rem; position: relative; color: var(--muted); font-size: .95rem; }
.about .creds li::before { content: '✚'; position: absolute; left: 0; color: var(--teal); font-weight: 700; }

/* Contact */
.contact { background: var(--ink); color: #f3efe9; text-align: center; }
.contact h2.title { color: #fff; }
.contact .lead { color: #c9c3ba; margin: 0 auto; }
.contact .purposes { display: flex; gap: .5rem; flex-wrap: wrap; justify-content: center; margin: 1.5rem 0; }
.contact .purposes span { font-size: .82rem; color: #c9c3ba; border: 1px solid #4a443d; border-radius: 999px; padding: .35rem .85rem; }
.contact .btn-primary { margin-top: .5rem; }

/* Footer */
footer.foot { padding: 2.5rem 0; border-top: 1px solid var(--border); }
.foot-inner { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 1rem; }
.foot .brand .wm { font-size: 1rem; }
.foot-links { display: flex; gap: 1.25rem; font-size: .85rem; color: var(--muted); font-weight: 600; }
.foot-links a:hover { color: var(--teal-dark); }
.foot .copy { font-size: .8rem; color: var(--muted); width: 100%; }
.disclaimer { font-size: .72rem; color: var(--muted); max-width: 70ch; margin-top: .5rem; }
