/* ============================================================
   Mascot Healthcare — Culture
   Aesthetic: cool editorial · calm · honest · "built without noise"
   Palette: cool paper, deep navy ink, azure accent, steel highlight
   Type: Fraunces (display serif) + Hanken Grotesk (body)
   ============================================================ */

:root{
  --paper:#EFF4FA;
  --paper-2:#E3ECF5;
  --paper-3:#D5E2F0;
  --ink:#102A40;
  --ink-2:#23415F;
  --ink-soft:#516780;
  --blue:#1C4E7E;
  --blue-deep:#0E2D4A;
  --steel:#6E94BE;
  --steel-soft:#AEC6E2;
  --azure:#2384C9;
  --azure-soft:#6FB9EC;
  --gold:#C8A24B;
  --line:rgba(16,42,64,.14);
  --shadow:18px 22px 60px -28px rgba(14,45,74,.45);
  --maxw:1180px;
  --r:18px;
  --ease:cubic-bezier(.2,.7,.2,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family: "Inter", system-ui, sans-serif;   /* ← change this line */
  font-size:clamp(16px,1.05vw,18px);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit}
img{max-width:100%}
em{font-style:italic}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,56px)}

/* grain / atmosphere ---------------------------------------- */
.grain{
  position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.45'/%3E%3C/svg%3E");
  mix-blend-mode:multiply;
}
body::before{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(60vw 50vw at 85% -5%, rgba(110,148,190,.35), transparent 60%),
    radial-gradient(50vw 40vw at -10% 30%, rgba(35,132,201,.10), transparent 55%);
}

/* typography ------------------------------------------------- */
h1,h2,h3,h4{font-family:"Inter", system-ui, sans-serif;font-weight:520;line-height:1.05;letter-spacing:-.015em;color:var(--ink);}
h2{font-size:clamp(1.9rem,4vw,3.1rem);margin:0 0 .4em}
h3{font-size:clamp(1.3rem,2.4vw,1.7rem)}
h4{font-size:1.18rem;letter-spacing:-.01em}
p{margin:0 0 1em}

.kicker,.eyebrow{
  font-family:"Hanken Grotesk",sans-serif;font-weight:600;
  font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--azure);
}
.eyebrow{display:inline-block;margin-bottom:1.1rem;color:var(--blue)}
.eyebrow--light{color:var(--steel-soft)}
.eyebrow::before{content:"";display:inline-block;width:26px;height:1px;background:currentColor;vertical-align:middle;margin-right:.7em;opacity:.7}

/* buttons ---------------------------------------------------- */
.btn{
  display:inline-flex;align-items:center;gap:.5em;
  font-family:"Hanken Grotesk",sans-serif;font-weight:600;font-size:.98rem;
  padding:.85em 1.5em;border-radius:100px;border:1px solid transparent;
  cursor:pointer;text-decoration:none;transition:transform .25s var(--ease),background .25s,color .25s,box-shadow .25s;
}
.btn--solid{background:var(--blue);color:var(--paper);box-shadow:0 12px 30px -14px rgba(14,45,74,.7)}
.btn--solid:hover{background:var(--blue-deep);transform:translateY(-2px)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn--ghost:hover{border-color:var(--ink);transform:translateY(-2px)}
.btn--full{width:100%;justify-content:center;padding:1.05em}

/* nav -------------------------------------------------------- */
.nav{
  position:sticky;top:0;z-index:20;
  display:flex;align-items:center;justify-content:space-between;
  padding:1rem clamp(20px,5vw,56px);
  background:rgba(239,244,250,.78);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.nav__brand{
  display:flex;align-items:center;gap:.6em;
  font-family:"Fraunces",serif;font-weight:600;font-size:1.2rem;text-decoration:none;letter-spacing:-.01em;
}
.nav__pulse{
  width:11px;height:11px;border-radius:50%;background:var(--azure);
  box-shadow:0 0 0 0 rgba(35,132,201,.6);animation:pulse 2.4s infinite var(--ease);
}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(35,132,201,.55)}70%{box-shadow:0 0 0 12px rgba(35,132,201,0)}100%{box-shadow:0 0 0 0 rgba(35,132,201,0)}}
.nav__links{display:flex;align-items:center;gap:clamp(.8rem,2vw,1.8rem)}
.nav__links a{text-decoration:none;font-weight:500;font-size:.95rem;color:var(--ink-soft);transition:color .2s}
.nav__links a:hover{color:var(--ink)}
.nav__cta{color:var(--blue)!important;font-weight:700!important;border:1px solid var(--line);padding:.5em 1em;border-radius:100px}
.nav__cta:hover{background:var(--blue);color:var(--paper)!important}

/* hero ------------------------------------------------------- */
.hero{position:relative;z-index:2;padding:clamp(4rem,11vw,8.5rem) 0 0;overflow:hidden}
.hero__inner{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,56px)}
.hero__title{
  font-size:clamp(3.4rem,13vw,9.5rem);font-weight:340;line-height:.92;margin:.2em 0 .35em;letter-spacing:-.03em;
}
.hero__title em{color:var(--azure);font-weight:400}
.hero__lede{max-width:42ch;font-size:clamp(1.1rem,1.8vw,1.42rem);color:var(--ink-2);margin-bottom:2rem}
.hero__actions{display:flex;gap:.9rem;flex-wrap:wrap}
.pulse-line{position:relative;z-index:2;margin-top:clamp(2.5rem,6vw,5rem);height:120px}
.pulse-line svg{width:100%;height:100%;display:block}
.pulse-line__path{
  fill:none;stroke:var(--blue);stroke-width:2.4;
  stroke-dasharray:2600;stroke-dashoffset:2600;
  animation:draw 3.2s var(--ease) .4s forwards, beat 2.6s ease-in-out 3.6s infinite;
  opacity:.85;
}
@keyframes draw{to{stroke-dashoffset:0}}
@keyframes beat{0%,100%{opacity:.55}45%{opacity:1}}

/* generic section ------------------------------------------- */
.section{position:relative;z-index:2;padding:clamp(4rem,9vw,7.5rem) 0}
.section__title{max-width:18ch}
.section__intro{max-width:54ch;color:var(--ink-2);font-size:1.1rem;margin-bottom:2.5rem}

/* mission ---------------------------------------------------- */
.mission{border-top:1px solid var(--line)}
.mission__grid{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(1.5rem,4vw,4rem);align-items:start;margin-bottom:clamp(3rem,7vw,5.5rem)}
.mission__lead h2{font-size:clamp(2rem,4.4vw,3.6rem);font-weight:340;line-height:1.02}
.mission__lead em{color:var(--azure)}
.mission__body p{color:var(--ink-2)}
.mission__pledge{margin-top:1.4rem;font-family:"Fraunces",serif;font-size:1.28rem;line-height:1.35;color:var(--ink)}
.mission__pledge span{color:var(--blue)}
.howwe h3{margin-bottom:1.6rem}
.howwe__cards{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.howwe__card{
  background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r);
  padding:1.6rem 1.4rem;transition:transform .35s var(--ease),box-shadow .35s,background .35s;
}
.howwe__card:hover{transform:translateY(-5px);box-shadow:var(--shadow);background:var(--paper-3)}
.howwe__num{font-family:"Fraunces",serif;font-size:.95rem;color:var(--azure);font-weight:600;letter-spacing:.05em}
.howwe__card h4{margin:.6rem 0 .5rem}
.howwe__card p{font-size:.94rem;color:var(--ink-soft);margin:0}

/* principles ------------------------------------------------- */
.principle-group{margin-bottom:clamp(2.5rem,5vw,4rem)}
.principle-group__label{
  display:flex;align-items:center;gap:.8rem;font-size:1rem;font-family:"Hanken Grotesk",sans-serif;
  font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--blue);margin-bottom:1.4rem;
}
.principle-group__label span{flex:1;height:1px;background:var(--line)}
.principle-list{display:grid;gap:.9rem}
.principle{
  position:relative;display:grid;grid-template-columns:auto 1fr auto;gap:clamp(1rem,3vw,2.2rem);align-items:start;
  background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r);
  padding:clamp(1.3rem,3vw,2rem);cursor:pointer;outline:none;
  transition:transform .3s var(--ease),box-shadow .3s,border-color .3s,background .3s;
}
.principle:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:rgba(28,78,126,.4)}
.principle:focus-visible{border-color:var(--blue);box-shadow:0 0 0 3px rgba(28,78,126,.2)}
.principle__numeral{
  font-family:"Fraunces",serif;font-size:clamp(1.8rem,4vw,2.7rem);font-weight:340;
  color:var(--steel);line-height:1;min-width:2.2ch;transition:color .3s;
}
.principle__title{margin:0 0 .35rem;font-weight:500}
.principle__essence{margin:0 0 .7rem;font-family:"Fraunces",serif;font-style:italic;color:var(--azure);font-size:1.05rem}
.principle__body{margin:0;color:var(--ink-soft);font-size:.97rem;max-width:60ch}
.principle__check{
  display:flex;flex-direction:column;align-items:center;gap:.4rem;
  align-self:center;color:var(--ink-soft);opacity:.6;transition:opacity .3s,color .3s;
}
.principle__check svg{
  width:30px;height:30px;border-radius:50%;padding:5px;border:1.5px solid var(--line);
  fill:none;stroke:currentColor;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round;
  stroke-dasharray:30;stroke-dashoffset:30;transition:stroke-dashoffset .35s var(--ease),background .3s,border-color .3s;
}
.principle__check-label{font-size:.72rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase}

/* aligned state */
.principle.is-aligned{background:linear-gradient(180deg,var(--blue),var(--blue-deep));border-color:var(--blue-deep)}
.principle.is-aligned .principle__title,
.principle.is-aligned .principle__body{color:var(--paper)}
.principle.is-aligned .principle__essence{color:var(--azure-soft)}
.principle.is-aligned .principle__numeral{color:var(--steel-soft)}
.principle.is-aligned .principle__check{opacity:1;color:var(--paper)}
.principle.is-aligned .principle__check svg{stroke-dashoffset:0;border-color:var(--steel-soft);background:rgba(255,255,255,.08)}

/* journey / timeline ---------------------------------------- */
.journey{background:var(--paper-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.timeline{list-style:none;margin:0;padding:0;position:relative;display:grid;gap:1.2rem;counter-reset:t}
.timeline::before{content:"";position:absolute;left:7px;top:8px;bottom:8px;width:2px;background:linear-gradient(var(--steel),var(--azure));opacity:.5}
.timeline__item{position:relative;padding:0 0 .4rem 2.4rem}
.timeline__item::before{
  content:"";position:absolute;left:0;top:.45rem;width:16px;height:16px;border-radius:50%;
  background:var(--paper);border:3px solid var(--steel);
}
.timeline__item--goal::before{border-color:var(--azure);background:var(--azure)}
.timeline__year{font-family:"Hanken Grotesk",sans-serif;font-weight:700;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--azure)}
.timeline__item h4{margin:.25rem 0 .35rem}
.timeline__item p{margin:0;color:var(--ink-soft);max-width:60ch}

/* align / form ---------------------------------------------- */
.align{background:var(--blue-deep);color:var(--paper);overflow:hidden}
.align::before{
  content:"";position:absolute;inset:0;opacity:.5;pointer-events:none;
  background:radial-gradient(40vw 40vw at 90% 10%,rgba(35,132,201,.25),transparent 60%),
             radial-gradient(40vw 40vw at 0% 90%,rgba(110,148,190,.22),transparent 60%);
}
.align__wrap{position:relative;display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(2rem,6vw,5rem);align-items:start}
.align__intro h2{color:var(--paper);font-weight:340;font-size:clamp(2rem,4.5vw,3.4rem)}
.align__intro p{color:rgba(239,244,250,.8)}
.align__counter{display:flex;align-items:baseline;gap:.6rem;margin-top:1.6rem}
.align__counter strong{font-family:"Fraunces",serif;font-size:2.6rem;font-weight:400;color:var(--azure-soft);line-height:1}
.align__counter span{color:rgba(239,244,250,.7);font-size:.95rem}

.align__form{
  background:rgba(239,244,250,.05);border:1px solid rgba(239,244,250,.16);
  border-radius:var(--r);padding:clamp(1.5rem,3.5vw,2.4rem);backdrop-filter:blur(4px);
}
.field{margin-bottom:1.2rem}
.field label,.field legend{display:block;font-weight:600;font-size:.9rem;margin-bottom:.5rem;color:var(--paper)}
.field legend span{font-weight:400;color:rgba(239,244,250,.6);letter-spacing:0;text-transform:none}
.field input,.field textarea{
  width:100%;padding:.85em 1em;border-radius:12px;border:1px solid rgba(239,244,250,.2);
  background:rgba(239,244,250,.06);color:var(--paper);font:inherit;font-size:1rem;transition:border-color .2s,background .2s;
}
.field input::placeholder,.field textarea::placeholder{color:rgba(239,244,250,.4)}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--azure-soft);background:rgba(239,244,250,.1)}
.field textarea{resize:vertical;min-height:96px}
.field--principles{border:none;padding:0;margin:0 0 1.2rem}
.chips{display:flex;flex-wrap:wrap;gap:.5rem;max-height:172px;overflow:auto;padding:.2rem .2rem .4rem 0}
.chips::-webkit-scrollbar{width:6px}
.chips::-webkit-scrollbar-thumb{background:rgba(239,244,250,.2);border-radius:6px}
.chip{position:relative}
.chip input{position:absolute;opacity:0;pointer-events:none}
.chip span{
  display:inline-block;padding:.45em .85em;border-radius:100px;font-size:.82rem;line-height:1.2;
  border:1px solid rgba(239,244,250,.22);color:rgba(239,244,250,.78);cursor:pointer;transition:all .2s;
}
.chip span:hover{border-color:var(--steel-soft)}
.chip input:checked + span{background:var(--azure);border-color:var(--azure);color:#fff;font-weight:600}
.chip input:focus-visible + span{box-shadow:0 0 0 3px rgba(111,185,236,.4)}

.align__formnote{font-size:.82rem;color:rgba(239,244,250,.55);margin:.9rem 0 0;text-align:center}
.form-feedback{
  margin-top:1rem;padding:.9em 1.1em;border-radius:12px;font-weight:600;font-size:.95rem;text-align:center;
}
.form-feedback[data-state="ok"]{background:rgba(46,160,110,.16);border:1px solid #2EA06E;color:#8FD3AE}
.form-feedback[data-state="err"]{background:rgba(201,74,74,.16);border:1px solid #C94A4A;color:#EBA0A0}

/* footer ----------------------------------------------------- */
.foot{position:relative;z-index:2;background:var(--paper);padding:clamp(3rem,6vw,4.5rem) 0;border-top:1px solid var(--line);text-align:center}
.foot__wrap{display:flex;flex-direction:column;align-items:center;gap:.4rem}
.foot__brand{display:flex;align-items:center;gap:.6em;font-family:"Fraunces",serif;font-size:1.4rem;font-weight:600}
.foot__tag{font-family:"Fraunces",serif;font-style:italic;color:var(--azure);margin:.2rem 0 .8rem}
.foot__meta{color:var(--ink-soft);font-size:.92rem;margin:0}
.foot__meta a{text-decoration:none;color:var(--blue);font-weight:600}
.foot__links{display:flex;gap:1.4rem;flex-wrap:wrap;justify-content:center;margin:1.2rem 0}
.foot__links a{text-decoration:none;color:var(--ink-soft);font-size:.92rem;font-weight:500;border-bottom:1px solid transparent;transition:.2s}
.foot__links a:hover{color:var(--ink);border-color:var(--azure)}
.foot__copy{font-size:.82rem;color:var(--ink-soft);opacity:.7;margin:.6rem 0 0}

/* honeypot --------------------------------------------------- */
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}

/* reveal animation ------------------------------------------ */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* responsive ------------------------------------------------- */
@media (max-width:900px){
  .mission__grid{grid-template-columns:1fr}
  .howwe__cards{grid-template-columns:repeat(2,1fr)}
  .align__wrap{grid-template-columns:1fr}
  .nav__links a:not(.nav__cta){display:none}
}
@media (max-width:560px){
  .howwe__cards{grid-template-columns:1fr}
  .principle{grid-template-columns:auto 1fr;gap:1rem}
  .principle__check{grid-column:1 / -1;flex-direction:row;justify-content:flex-start;margin-top:.4rem}
  .hero__actions{flex-direction:column;align-items:stretch}
  .btn{justify-content:center}
}

/* reduced motion -------------------------------------------- */
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
  .pulse-line__path{stroke-dashoffset:0}
}