/* ============ TOKENS ============ */
:root{
  --bg:#FAF7F5;            /* warm off-white background */
  --surface:#FFFFFF;       /* cards */
  --soft:#FBEDED;          /* soft-red wash */
  --soft-2:#F6DDDD;        /* deeper soft-red wash */
  --soft-line:#F0CFCF;     /* soft-red hairline */
  --ink:#15171C;           /* near-black headings (logo MEDI) */
  --body:#4C4954;          /* muted body text */
  --faint:#857F8A;         /* captions */
  --line:#ECE3E1;          /* neutral hairline */
  --brand:#BC1B26;         /* wordmark CALLS red */
  --brand-deep:#9A1620;    /* hover/pressed */
  --brand-bright:#EF3B3F;  /* heart bright — pulse/accents */
  --soft-red:#E0989A;      /* soft red mid-tone (icon strokes on tints) */
  --shadow:0 1px 2px rgba(21,23,28,.04), 0 12px 32px -12px rgba(154,22,32,.10);
  --shadow-lg:0 2px 4px rgba(21,23,28,.05), 0 30px 60px -24px rgba(154,22,32,.18);
  --r-sm:10px; --r:16px; --r-lg:24px; --r-xl:32px;
  --maxw:1180px;
  --ease:cubic-bezier(.2,.7,.2,1);
  --disp:"Bricolage Grotesque", ui-sans-serif, system-ui, sans-serif;
  --sans:"Hanken Grotesk", ui-sans-serif, system-ui, -apple-system, sans-serif;
  --mono:"IBM Plex Mono", ui-monospace, "SF Mono", Menlo, monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans); color:var(--body); background:var(--bg);
  font-size:17px; line-height:1.62; -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility; overflow-x:hidden;
}
img,svg{display:block; max-width:100%}
a{color:inherit; text-decoration:none}
::selection{background:var(--brand); color:#fff}

h1,h2,h3,h4{font-family:var(--disp); color:var(--ink); line-height:1.06; letter-spacing:-.02em; font-weight:700}
h1{font-size:clamp(2.4rem,5.4vw,4.1rem); font-weight:800}
h2{font-size:clamp(1.9rem,3.6vw,2.9rem)}
h3{font-size:clamp(1.15rem,1.8vw,1.45rem); letter-spacing:-.01em}
p{max-width:64ch}
.wrap{max-width:var(--maxw); margin-inline:auto; padding-inline:24px}

/* eyebrow / technical labels — encode the infrastructure domain */
.eyebrow{
  font-family:var(--mono); font-size:.72rem; font-weight:500; letter-spacing:.16em;
  text-transform:uppercase; color:var(--brand);
  display:inline-flex; align-items:center; gap:.6em;
}
.eyebrow::before{content:""; width:22px; height:1.5px; background:var(--brand); display:inline-block}

/* ============ BUTTONS ============ */
.btn{
  font-family:var(--sans); font-weight:600; font-size:.97rem; cursor:pointer;
  display:inline-flex; align-items:center; gap:.55em; line-height:1;
  padding:.92em 1.4em; border-radius:999px; border:1px solid transparent;
  transition:transform .25s var(--ease), background .25s, box-shadow .25s, color .25s, border-color .25s;
  white-space:nowrap;
}
.btn svg{width:18px;height:18px}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--brand); color:#fff; box-shadow:0 10px 24px -10px rgba(188,27,38,.55)}
.btn-primary:hover{background:var(--brand-deep); transform:translateY(-2px); box-shadow:0 16px 30px -12px rgba(188,27,38,.6)}
.btn-ghost{background:var(--surface); color:var(--ink); border-color:var(--line)}
.btn-ghost:hover{border-color:var(--soft-line); background:#fff; transform:translateY(-2px); box-shadow:var(--shadow)}
.btn-soft{background:var(--soft); color:var(--brand); border-color:var(--soft-line)}
.btn-soft:hover{background:var(--soft-2); transform:translateY(-2px)}
.btn-lg{padding:1.05em 1.7em; font-size:1.02rem}
.btn-link{color:var(--brand); font-weight:600; display:inline-flex; align-items:center; gap:.4em}
.btn-link svg{width:16px;height:16px; transition:transform .25s var(--ease)}
.btn-link:hover svg{transform:translateX(4px)}

/* ============ HEADER ============ */
header{
  position:sticky; top:0; z-index:50;
  background:rgba(250,247,245,.82); backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid transparent; transition:border-color .3s, box-shadow .3s, background .3s;
}
header.scrolled{border-bottom-color:var(--line); box-shadow:0 8px 24px -20px rgba(21,23,28,.5)}
.nav{display:flex; align-items:center; gap:28px; height:74px}
.brand{display:flex; align-items:center; gap:11px; flex-shrink:0}
.brand .mark{width:34px;height:34px}
.brand .word{font-family:var(--disp); font-weight:800; font-size:1.42rem; letter-spacing:-.02em; color:var(--ink)}
.brand .word b{color:var(--brand); font-weight:800}
.nav-links{display:flex; align-items:center; gap:4px; margin-left:8px}
.nav-links a{
  font-size:.93rem; font-weight:500; color:var(--body); padding:.55em .72em; border-radius:8px;
  transition:color .2s, background .2s; position:relative; white-space:nowrap;
}
.nav-links a:hover{color:var(--ink); background:rgba(188,27,38,.05)}
.nav-links a.active{color:var(--brand)}
.nav-cta{margin-left:auto; display:flex; align-items:center; gap:10px}
.menu-toggle{display:none; background:none; border:1px solid var(--line); border-radius:10px; width:44px;height:44px; cursor:pointer; align-items:center; justify-content:center; color:var(--ink)}
.menu-toggle svg{width:22px;height:22px}
.mobile-menu{display:none}

/* ============ PAGE ROUTER ============ */
.page{display:none; animation:fade .5s var(--ease)}
.page.is-active{display:block}
@keyframes fade{from{opacity:0; transform:translateY(8px)} to{opacity:1; transform:none}}

section{padding:clamp(56px,8vw,104px) 0}
.section-soft{background:linear-gradient(180deg,var(--soft) 0%, #FCEFEF 100%); border-block:1px solid var(--soft-line)}
.lead{font-size:clamp(1.05rem,1.6vw,1.22rem); color:var(--body); max-width:60ch}
.center{text-align:center; margin-inline:auto}
.center.lead{margin-inline:auto}

/* ============ HERO ============ */
.hero{padding:clamp(40px,6vw,80px) 0 clamp(56px,7vw,96px); position:relative; overflow:hidden}
.hero-grid{display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(28px,5vw,64px); align-items:center}
.hero h1{margin:.5rem 0 .1rem}
.hero h1 .hl{color:var(--brand); position:relative; white-space:nowrap}
.hero .lead{margin:1.3rem 0 2rem}
.hero-cta{display:flex; flex-wrap:wrap; gap:12px}
.hero-trust{display:flex; flex-wrap:wrap; gap:8px 26px; margin-top:2.2rem; align-items:center}
.hero-trust span{font-family:var(--mono); font-size:.74rem; letter-spacing:.04em; color:var(--faint); display:inline-flex; align-items:center; gap:.5em}
.hero-trust span svg{width:15px;height:15px;color:var(--brand)}

/* monitoring console (hero visual, no stock imagery) */
.console{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg);
  box-shadow:var(--shadow-lg); padding:22px; position:relative; overflow:hidden;
}
.console::before{content:""; position:absolute; inset:0; background:
  radial-gradient(120% 90% at 100% 0%, rgba(239,59,63,.07), transparent 55%); pointer-events:none}
.console-top{display:flex; align-items:center; justify-content:space-between; margin-bottom:16px}
.console-top .t{font-family:var(--mono); font-size:.74rem; letter-spacing:.06em; color:var(--faint); text-transform:uppercase}
.live{display:inline-flex; align-items:center; gap:7px; font-family:var(--mono); font-size:.72rem; color:var(--brand); font-weight:500}
.live .dot{width:8px;height:8px;border-radius:50%; background:var(--brand-bright); box-shadow:0 0 0 0 rgba(239,59,63,.6); animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(239,59,63,.5)}70%{box-shadow:0 0 0 8px rgba(239,59,63,0)}100%{box-shadow:0 0 0 0 rgba(239,59,63,0)}}
.ecg{background:linear-gradient(180deg,#fff,#FFF7F7); border:1px solid var(--soft-line); border-radius:var(--r); padding:14px 8px; margin-bottom:14px}
.ecg svg{width:100%; height:84px}
.ecg .pulse-path{stroke:var(--brand-bright); stroke-width:2.4; fill:none; stroke-linecap:round; stroke-linejoin:round;
  stroke-dasharray:1400; stroke-dashoffset:1400; animation:trace 4s linear infinite}
@keyframes trace{to{stroke-dashoffset:0}}
.metric-row{font-family:var(--mono); font-size:.7rem; color:var(--faint); display:flex; justify-content:space-between; padding:0 6px 4px}
.statlist{display:flex; flex-direction:column; gap:9px}
.statrow{display:flex; align-items:center; gap:12px; background:#fff; border:1px solid var(--line); border-radius:12px; padding:11px 13px}
.statrow .ic{width:36px;height:36px;flex-shrink:0; border-radius:10px; background:var(--soft); color:var(--brand); display:grid; place-items:center}
.statrow .ic svg{width:19px;height:19px}
.statrow .lbl{font-weight:600; color:var(--ink); font-size:.92rem; line-height:1.2}
.statrow .sub{font-size:.78rem; color:var(--faint)}
.statrow .badge{margin-left:auto; font-family:var(--mono); font-size:.66rem; letter-spacing:.05em; text-transform:uppercase; color:var(--brand); background:var(--soft); border:1px solid var(--soft-line); padding:.35em .6em; border-radius:999px; display:inline-flex; align-items:center; gap:.4em}
.statrow .badge svg{width:12px;height:12px}

/* ============ LOGO STRIP ============ */
.strip{padding:30px 0; border-bottom:1px solid var(--line)}
.strip p{font-family:var(--mono); font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--faint); text-align:center; margin-bottom:18px}
.strip-items{display:flex; flex-wrap:wrap; justify-content:center; gap:14px 38px}
.strip-items span{font-family:var(--disp); font-weight:600; color:#B7AEB0; font-size:1.02rem; letter-spacing:-.01em; display:flex; align-items:center; gap:.5em}
.strip-items span svg{width:18px;height:18px;color:var(--soft-red)}

/* ============ SECTION HEAD ============ */
.shead{max-width:720px; margin-bottom:46px}
.shead.center{margin-inline:auto; text-align:center}
.shead h2{margin:.6rem 0 .9rem}

/* ============ CARD GRID ============ */
.grid{display:grid; gap:20px}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}
.card{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg);
  padding:30px; transition:transform .35s var(--ease), box-shadow .35s, border-color .35s;
  position:relative;
}
.card:hover{transform:translateY(-5px); box-shadow:var(--shadow-lg); border-color:var(--soft-line)}
.card .ic{
  width:52px;height:52px;border-radius:14px; display:grid; place-items:center; margin-bottom:18px;
  background:var(--soft); color:var(--brand); border:1px solid var(--soft-line);
  transition:background .35s, color .35s;
}
.card:hover .ic{background:var(--brand); color:#fff; border-color:var(--brand)}
.card .ic svg{width:25px;height:25px}
.card h3{margin-bottom:10px}
.card p{font-size:.97rem}

/* feature list with checks */
.feat{list-style:none; display:flex; flex-direction:column; gap:11px; margin-top:4px}
.feat li{display:flex; gap:11px; align-items:flex-start; font-size:.97rem; color:var(--body)}
.feat li svg{width:19px;height:19px;flex-shrink:0;margin-top:2px;color:var(--brand)}
.feat.tight li{font-size:.95rem}

/* two-col content blocks (services/security/pacs pages) */
.block{display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(24px,5vw,68px); align-items:start; padding:clamp(34px,5vw,56px) 0; border-bottom:1px solid var(--line)}
.block:last-child{border-bottom:none}
.block .bhead .num{font-family:var(--mono); font-size:.8rem; color:var(--soft-red); font-weight:500; letter-spacing:.08em}
.block .bhead h3{font-size:clamp(1.4rem,2.4vw,1.9rem); font-family:var(--disp); margin:.4rem 0 .7rem}
.block .bhead p{font-size:1rem}
.block .bhead .ic{width:54px;height:54px;border-radius:15px; background:var(--soft); color:var(--brand); display:grid;place-items:center; margin-bottom:18px; border:1px solid var(--soft-line)}
.block .bhead .ic svg{width:26px;height:26px}
.feat-2{columns:2; column-gap:30px}
.feat-2 li{break-inside:avoid; margin-bottom:11px; display:flex; gap:10px; align-items:flex-start; font-size:.96rem}
.feat-2 li svg{width:18px;height:18px;flex-shrink:0;margin-top:3px;color:var(--brand)}

/* quote / emphasis line */
.pull{font-family:var(--disp); font-weight:500; font-size:clamp(1.2rem,2.2vw,1.6rem); color:var(--ink); letter-spacing:-.01em; line-height:1.3; max-width:30ch}
.pull .accent{color:var(--brand)}

/* ============ STATS BAND ============ */
.stats{display:grid; grid-template-columns:repeat(4,1fr); gap:24px; text-align:center}
.stats .s .n{font-family:var(--disp); font-weight:800; font-size:clamp(2.2rem,4vw,3rem); color:var(--brand); line-height:1; letter-spacing:-.03em}
.stats .s .l{font-size:.9rem; color:var(--body); margin-top:8px}

/* ============ CTA BAND ============ */
.cta-band{background:var(--ink); border-radius:var(--r-xl); padding:clamp(40px,6vw,72px); position:relative; overflow:hidden; color:#fff}
.cta-band::after{content:""; position:absolute; right:-60px; top:-60px; width:340px;height:340px; border-radius:50%;
  background:radial-gradient(circle, rgba(239,59,63,.32), transparent 65%)}
.cta-band h2{color:#fff; max-width:18ch}
.cta-band p{color:#C8C4CC; margin-top:14px}
.cta-band .btns{margin-top:28px; display:flex; flex-wrap:wrap; gap:12px; position:relative}
.cta-band .btn-ghost{background:transparent; color:#fff; border-color:rgba(255,255,255,.25)}
.cta-band .btn-ghost:hover{background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.4)}
.cta-pulse{position:absolute; left:0; bottom:0; width:100%; opacity:.5}
.cta-pulse svg{width:100%; height:60px}
.cta-pulse path{stroke:var(--brand-bright); stroke-width:2; fill:none; stroke-dasharray:1600; stroke-dashoffset:1600; animation:trace 5s linear infinite}

/* ============ FORMS ============ */
.form-grid{display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(28px,4vw,52px); align-items:start}
.form-card{background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); padding:clamp(26px,3vw,38px); box-shadow:var(--shadow)}
.field{margin-bottom:16px}
.field.row{display:grid; grid-template-columns:1fr 1fr; gap:16px}
label{display:block; font-size:.82rem; font-weight:600; color:var(--ink); margin-bottom:7px; letter-spacing:.005em}
label .opt{color:var(--faint); font-weight:400; font-size:.78rem}
input,select,textarea{
  width:100%; font-family:var(--sans); font-size:.96rem; color:var(--ink);
  background:var(--bg); border:1px solid var(--line); border-radius:11px; padding:.8em .95em;
  transition:border-color .2s, box-shadow .2s, background .2s;
}
textarea{resize:vertical; min-height:108px}
input:focus,select:focus,textarea:focus{outline:none; border-color:var(--brand); background:#fff; box-shadow:0 0 0 3px rgba(188,27,38,.12)}
input::placeholder,textarea::placeholder{color:#A79FA8}
.form-aside .feat{margin-top:22px}
.aside-card{background:var(--soft); border:1px solid var(--soft-line); border-radius:var(--r); padding:24px; margin-top:20px}
.aside-card h4{font-family:var(--disp); color:var(--ink); font-size:1.1rem; margin-bottom:6px}
.aside-card p{font-size:.92rem}
.contact-line{display:flex; align-items:center; gap:12px; margin-top:14px; font-size:.95rem; color:var(--ink)}
.contact-line svg{width:18px;height:18px;color:var(--brand); flex-shrink:0}
.form-note{font-size:.8rem; color:var(--faint); margin-top:10px}
.formmsg{display:none; background:var(--soft); border:1px solid var(--soft-line); color:var(--brand); border-radius:12px; padding:14px 16px; font-weight:600; font-size:.92rem; margin-bottom:16px}
.formmsg.show{display:block; animation:fade .4s var(--ease)}

/* ============ SUPPORT PORTAL ============ */
.portal-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:20px}
.portal-card{background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); padding:30px; display:flex; flex-direction:column; transition:transform .35s var(--ease),box-shadow .35s, border-color .35s}
.portal-card:hover{transform:translateY(-5px); box-shadow:var(--shadow-lg); border-color:var(--soft-line)}
.portal-card .ic{width:48px;height:48px;border-radius:13px;background:var(--soft);color:var(--brand);display:grid;place-items:center;margin-bottom:16px;border:1px solid var(--soft-line)}
.portal-card .ic svg{width:23px;height:23px}
.portal-card h3{margin-bottom:8px}
.portal-card p{font-size:.95rem; flex-grow:1; margin-bottom:18px}
.login-card{background:var(--ink); color:#fff; border-radius:var(--r-lg); padding:clamp(28px,3vw,40px); box-shadow:var(--shadow-lg)}
.login-card h3{color:#fff}
.login-card label{color:#D8D4DB}
.login-card input{background:rgba(255,255,255,.06); border-color:rgba(255,255,255,.16); color:#fff}
.login-card input::placeholder{color:#8B8690}
.login-card input:focus{border-color:var(--brand-bright); background:rgba(255,255,255,.1); box-shadow:0 0 0 3px rgba(239,59,63,.2)}
.login-card .row-between{display:flex; justify-content:space-between; align-items:center; font-size:.85rem; color:#C8C4CC; margin-bottom:18px}
.login-card a{color:var(--brand-bright)}

/* ============ PAGE HEADER (inner pages) ============ */
.page-head{padding:clamp(48px,6vw,80px) 0 clamp(28px,4vw,44px); background:linear-gradient(180deg,var(--soft) 0%, var(--bg) 100%); border-bottom:1px solid var(--line)}
.page-head .eyebrow{margin-bottom:16px}
.page-head h1{font-size:clamp(2.1rem,4.4vw,3.3rem); max-width:18ch}
.page-head p{margin-top:18px; font-size:clamp(1.02rem,1.5vw,1.18rem); max-width:60ch}
.crumb{font-family:var(--mono); font-size:.74rem; letter-spacing:.06em; color:var(--faint); margin-bottom:18px}
.crumb a:hover{color:var(--brand)}

/* ============ ABOUT VALUES ============ */
.values{display:grid; grid-template-columns:repeat(3,1fr); gap:18px}
.value{background:var(--surface); border:1px solid var(--line); border-radius:var(--r); padding:24px}
.value .k{font-family:var(--disp); font-weight:700; color:var(--brand); font-size:1.15rem; margin-bottom:8px; display:flex; align-items:center; gap:.5em}
.value .k svg{width:20px;height:20px}
.value p{font-size:.93rem}
.principle{font-family:var(--disp); font-weight:700; font-size:clamp(1.5rem,3vw,2.2rem); color:var(--ink); letter-spacing:-.02em; text-align:center; margin-inline:auto}
.principle .dot{color:var(--brand)}

/* ============ FOOTER ============ */
footer{background:var(--ink); color:#C8C4CC; padding:clamp(48px,6vw,76px) 0 32px; margin-top:0}
.foot-grid{display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px}
footer .brand .word{color:#fff}
footer .fdesc{font-size:.92rem; color:#9C97A2; max-width:34ch; margin-top:16px}
.foot-col h5{font-family:var(--mono); font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:#7E7986; margin-bottom:16px}
.foot-col a{display:block; font-size:.93rem; color:#C8C4CC; padding:5px 0; transition:color .2s}
.foot-col a:hover{color:#fff}
.foot-contact{font-size:.92rem; line-height:1.9; color:#C8C4CC}
.foot-contact a:hover{color:#fff}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1); margin-top:48px; padding-top:24px; display:flex; flex-wrap:wrap; gap:14px; justify-content:space-between; align-items:center; font-size:.83rem; color:#7E7986}
.foot-bottom .ssl{display:inline-flex; align-items:center; gap:.5em; font-family:var(--mono); letter-spacing:.04em}
.foot-bottom .ssl svg{width:14px;height:14px;color:var(--brand-bright)}

/* reveal on scroll */
.reveal{opacity:0; transform:translateY(22px); transition:opacity .7s var(--ease), transform .7s var(--ease)}
.reveal.in{opacity:1; transform:none}

/* ============ RESPONSIVE ============ */
@media (max-width:960px){
  .hero-grid{grid-template-columns:1fr; gap:36px}
  .console{order:2}
  .block{grid-template-columns:1fr; gap:18px}
  .g-4{grid-template-columns:repeat(2,1fr)}
  .form-grid{grid-template-columns:1fr}
  .portal-grid{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:repeat(2,1fr); gap:30px 20px}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .nav-links, .nav-cta .btn-soft{display:none}
  .menu-toggle{display:flex}
  .nav-cta{margin-left:auto}
  .mobile-menu{display:none; position:fixed; inset:74px 0 0; background:var(--bg); z-index:49; padding:24px; flex-direction:column; gap:6px; border-top:1px solid var(--line); animation:fade .3s var(--ease)}
  .mobile-menu.open{display:flex}
  .mobile-menu a{font-family:var(--disp); font-size:1.4rem; font-weight:600; color:var(--ink); padding:14px 4px; border-bottom:1px solid var(--line)}
  .mobile-menu a.active{color:var(--brand)}
  .mobile-menu .btn{margin-top:18px; justify-content:center}
}
@media (max-width:600px){
  body{font-size:16px}
  .hero h1 .hl{white-space:normal}
  .g-2,.g-3,.g-4,.values,.portal-grid{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr}
  .feat-2{columns:1}
  .field.row{grid-template-columns:1fr}
  .hero-cta .btn{flex:1 1 auto; justify-content:center}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none !important; transition:none !important; scroll-behavior:auto !important}
  .reveal{opacity:1; transform:none}
}
