/* ============================================================
   Veritide Health Portal — shared styles
   Palette pulled from the logo: navy, teal, leaf green.
   ============================================================ */
:root{
  --navy:#1C3F5F; --navy-deep:#16314A;
  --teal:#2A7E97; --teal-light:#8FC9D8;
  --green:#5BAB4E; --ink:#14222E; --slate:#54677A;
  --clinical:#F6F9FA; --line:#E3ECF0; --white:#FFFFFF;
  --shadow:0 1px 2px rgba(20,34,46,.04), 0 8px 28px rgba(28,63,95,.07);
  --shadow-lift:0 4px 10px rgba(20,34,46,.06), 0 20px 48px rgba(28,63,95,.13);
  --radius:16px;
}
@import url('https://fonts.googleapis.com/css2?family=Newsreader:opsz,wght@6..72,400;6..72,500;6..72,600&family=Inter:wght@400;500;600;700&display=swap');

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;color:var(--ink);background:var(--clinical);line-height:1.55;-webkit-font-smoothing:antialiased}
.wrap{max-width:1120px;margin:0 auto;padding:0 24px}
a{color:var(--teal)}

/* Header */
header{background:var(--white);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.brand .word b{font-family:'Newsreader',serif;font-weight:500;font-size:23px;color:var(--navy);letter-spacing:.3px;display:block;line-height:1}
.brand .word span{font-size:11px;letter-spacing:3.5px;color:var(--teal);font-weight:600;text-transform:uppercase;display:block;margin-top:1px}
.nav-right{display:flex;align-items:center;gap:18px}
.pill{font-size:12px;font-weight:600;color:var(--teal);background:#EAF4F7;border:1px solid #D5E8EE;border-radius:999px;padding:5px 12px;display:inline-flex;align-items:center;gap:6px}
.pill .dot{width:6px;height:6px;border-radius:50%;background:var(--green)}
.ghost-btn{font-size:13px;font-weight:600;color:var(--navy);background:none;border:1px solid var(--line);border-radius:8px;padding:7px 14px;cursor:pointer;font-family:inherit}
.ghost-btn:hover{border-color:var(--teal);color:var(--teal)}

/* Generic page */
.page{padding:48px 0}
.eyebrow{font-size:12px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;color:var(--teal);margin-bottom:14px}
h1.title{font-family:'Newsreader',serif;font-weight:400;font-size:clamp(30px,4.5vw,46px);line-height:1.1;color:var(--navy);letter-spacing:-.5px;margin-bottom:14px}
.lead{font-size:16px;color:var(--slate);max-width:56ch}

/* Cards / forms */
.card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:32px}
.field{margin-bottom:14px}
.field label{display:block;font-size:12.5px;font-weight:600;color:var(--ink);margin-bottom:6px}
.field input{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:10px;font-size:14.5px;font-family:inherit;color:var(--ink);background:var(--clinical)}
.field input:focus{outline:none;border-color:var(--teal);background:var(--white);box-shadow:0 0 0 3px rgba(42,126,151,.13)}
.btn{width:100%;border:none;border-radius:10px;padding:13px;font-size:15px;font-weight:600;font-family:inherit;color:var(--white);background:var(--teal);cursor:pointer}
.btn:hover{filter:brightness(1.06)}
.btn:disabled{opacity:.55;cursor:not-allowed}
.btn.navy{background:var(--navy)}
.btn.navy:hover{filter:brightness(1.12)}
.msg{font-size:13.5px;border-radius:10px;padding:11px 14px;margin-bottom:14px;line-height:1.5;display:none}
.msg.show{display:block}
.msg.error{background:#FCEDEC;border:1px solid #F3CFCB;color:#9E2B23}
.msg.ok{background:#EDF5EA;border:1px solid #CFE6C7;color:#2F6B27}
.msg.info{background:#EAF4F7;border:1px solid #D5E8EE;color:var(--navy)}
.muted{font-size:13px;color:var(--slate)}
.center-narrow{max-width:440px;margin:0 auto}

/* Dashboard */
.dash-head{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px;margin-bottom:28px}
.tile-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px}
.tile{background:var(--white);border:1px solid var(--line);border-radius:12px;padding:22px}
.tile h3{font-family:'Newsreader',serif;font-weight:500;font-size:18px;color:var(--navy);margin-bottom:6px}
.tile p{font-size:13.5px;color:var(--slate);line-height:1.55}
.badge{display:inline-block;font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;padding:4px 9px;border-radius:6px;background:#EAF4F7;color:var(--teal)}
.empty{background:var(--white);border:1px dashed var(--line);border-radius:12px;padding:30px;text-align:center;color:var(--slate);font-size:14px}

footer{margin-top:54px;background:var(--navy-deep);color:#9FB4C2;font-size:12.5px}
footer .wrap{padding:26px 24px;line-height:1.6}

@media(prefers-reduced-motion:reduce){*{transition:none!important}}
