/* ============================================================
   GREENDOOR · APPLY PAGE — careers / openings listing
   Mobile-first. Shares design tokens with index.html.
   ============================================================ */

:root{
  --ink:        #0F1B14;
  --moss:       #1F3D2E;
  --leaf:       #426B53;
  --sage:       #94AE9C;
  --cream:      #F4EEDF;
  --paper:      #FAF6E9;
  --bone:       #EBE2CC;
  --shell:      #E1D6B8;
  --coral:      #DC6E4A;
  --ember:      #B94B25;
  --gold:       #C9A35A;
  --mist:       rgba(15,27,20,0.08);

  --serif:      "Fraunces", "Times New Roman", serif;
  --sans:       "Instrument Sans", -apple-system, system-ui, sans-serif;
  --mono:       "JetBrains Mono", ui-monospace, monospace;

  --easing:     cubic-bezier(.22,.61,.36,1);
  --maxw:       1320px;

  --gutter:     20px;
  --section-y:  64px;
  --tap:        44px;
}

@media (min-width:560px){:root{ --gutter:28px; --section-y:80px; }}
@media (min-width:820px){:root{ --gutter:40px; --section-y:100px; }}
@media (min-width:1100px){:root{ --gutter:56px; --section-y:120px; }}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  font-family:var(--sans);
  background:var(--cream);
  color:var(--ink);
  line-height:1.55;
  font-size:16px;
  font-feature-settings:"ss01","cv11";
  overflow-x:hidden;
  -webkit-tap-highlight-color: rgba(220,110,74,.15);
  background-image:
    radial-gradient(700px 500px at -5% -10%, rgba(66,107,83,.08), transparent 60%),
    radial-gradient(600px 600px at 110% 0%, rgba(220,110,74,.06), transparent 60%);
}
@media (min-width:820px){body{font-size:17px;}}

body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;
  opacity:.28;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.06 0 0 0 0 0.11 0 0 0 0 0.08 0 0 0 0.18 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  mix-blend-mode:multiply;
}

::selection{background:var(--moss);color:var(--cream);}
:focus-visible{outline:2px solid var(--coral);outline-offset:3px;border-radius:2px;}

img{display:block;max-width:100%;height:auto;}
a{color:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent;}
button{font:inherit;border:0;background:none;cursor:pointer;color:inherit;}

::-webkit-scrollbar{width:10px;height:10px;}
::-webkit-scrollbar-track{background:var(--cream);}
::-webkit-scrollbar-thumb{background:var(--moss);border:2px solid var(--cream);border-radius:10px;}

/* Typography */
.eyebrow{
  font-family:var(--mono);
  font-size:.68rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--leaf);
  display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{
  content:"";display:inline-block;width:24px;height:1px;background:var(--leaf);
}

/* Layout */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter);position:relative;z-index:2;}
section{position:relative;z-index:2;}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;gap:12px;
  min-height:var(--tap);
  padding:14px 22px 13px;
  border-radius:999px;
  font-family:var(--sans);
  font-weight:500;
  font-size:.95rem;
  letter-spacing:.01em;
  transition:all .35s var(--easing);
  position:relative;
  white-space:nowrap;
}
@media (min-width:820px){.btn{padding:18px 26px 17px;gap:14px;}}
.btn-primary{background:var(--moss);color:var(--cream);}
.btn-primary:hover{background:var(--ink);transform:translateY(-2px);box-shadow:0 18px 36px -18px rgba(15,27,20,.55);}
.btn-coral{background:var(--coral);color:var(--paper);}
.btn-coral:hover{background:var(--ember);transform:translateY(-2px);box-shadow:0 18px 36px -18px rgba(185,75,37,.55);}
.btn-ghost{background:transparent;color:var(--ink);box-shadow:inset 0 0 0 1.5px var(--ink);}
.btn-ghost:hover{background:var(--ink);color:var(--cream);transform:translateY(-2px);}
.btn .arrow{
  width:22px;height:22px;display:inline-grid;place-items:center;
  border-radius:999px;background:rgba(244,238,223,.18);
  transition:transform .4s var(--easing);flex-shrink:0;
}
.btn-ghost .arrow{background:rgba(15,27,20,.08);}
.btn:hover .arrow{transform:translateX(4px) rotate(-8deg);}
.btn .arrow svg{width:11px;height:11px;}

/* ============================================================
   DEMO-ONLY DISCLAIMER BANNER
   ============================================================ */
.demo-banner{
  position:sticky;
  top:0;left:0;right:0;
  z-index:100;
  background:var(--ink);
  color:var(--cream);
  padding:11px 16px;
  font-family:var(--mono);
  font-size:.78rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  text-align:center;
  line-height:1.45;
  border-bottom:1px solid rgba(220,110,74,.3);
}
@media (min-width:560px){
  .demo-banner{font-size:.88rem;letter-spacing:.12em;padding:12px 20px;}
}
@media (min-width:820px){
  .demo-banner{font-size:.96rem;letter-spacing:.14em;padding:14px 22px;}
}
.demo-banner strong{color:var(--coral);font-weight:500;letter-spacing:.08em;}
.demo-banner .sep{
  display:inline-block;width:4px;height:4px;border-radius:50%;
  background:rgba(244,238,223,.35);
  vertical-align:middle;margin:0 8px 2px;
}

/* ============================================================
   NAVIGATION
   ============================================================ */
.nav{
  position:sticky;
  top:var(--banner-h, 36px);
  left:0;right:0;
  z-index:50;
  padding:14px var(--gutter);
  display:flex;align-items:center;justify-content:space-between;
  background:rgba(244,238,223,.92);
  backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid var(--mist);
}
@media (min-width:820px){.nav{padding:18px var(--gutter);}}

.brand{
  display:flex;align-items:center;gap:10px;
  font-family:var(--serif);
  font-weight:500;font-size:1.1rem;letter-spacing:-0.01em;
  color:var(--ink);flex-shrink:0;
}
@media (min-width:820px){.brand{gap:12px;font-size:1.25rem;}}
.brand-mark{
  width:30px;height:36px;
  background:var(--moss);
  border-radius:18px 18px 3px 3px;
  position:relative;flex-shrink:0;
  transform-origin:left center;
  transition:transform .6s var(--easing);
}
@media (min-width:820px){.brand-mark{width:36px;height:42px;border-radius:20px 20px 4px 4px;}}
.brand-mark::after{
  content:"";position:absolute;right:5px;top:50%;
  width:4px;height:4px;border-radius:50%;background:var(--coral);
  transform:translateY(-50%);
}
.brand:hover .brand-mark{transform:rotateY(-32deg);}
.brand small{
  font-family:var(--mono);font-size:.6rem;letter-spacing:.16em;
  color:var(--leaf);text-transform:uppercase;
  display:block;line-height:1;margin-top:3px;
}

.nav-actions{display:flex;align-items:center;gap:10px;}
.nav-back{
  display:none;
  font-family:var(--mono);font-size:.66rem;
  letter-spacing:.18em;text-transform:uppercase;color:var(--leaf);
  align-items:center;gap:8px;
  padding:8px 14px;border-radius:99px;
  border:1px solid var(--mist);
  transition:all .3s var(--easing);
}
.nav-back:hover{background:var(--ink);color:var(--cream);border-color:var(--ink);}
@media (min-width:560px){.nav-back{display:inline-flex;}}

.nav-actions .btn-coral,
.nav-actions .btn-ghost{padding:11px 18px 10px;font-size:.85rem;}
@media (min-width:820px){
  .nav-actions .btn-coral,
  .nav-actions .btn-ghost{padding:13px 22px 12px;font-size:.9rem;}
}
/* Hide the secondary "Partner With Us" button on the tightest screens so the
   nav doesn't crowd; it's still reachable from the page CTA and footer. */
@media (max-width:439px){.nav-actions .btn-ghost{display:none;}}

/* ============================================================
   APPLY HERO
   ============================================================ */
.apply-hero{
  padding:60px var(--gutter) 40px;
  position:relative;
}
@media (min-width:820px){.apply-hero{padding:90px var(--gutter) 60px;}}

.apply-hero-grid{
  max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:1fr;gap:32px;
  align-items:end;
}
@media (min-width:820px){
  .apply-hero-grid{grid-template-columns:1.5fr 1fr;gap:60px;}
}

.apply-hero h1{
  font-family:var(--serif);
  font-variation-settings:"opsz" 144, "SOFT" 80;
  font-size:2.4rem;line-height:.95;letter-spacing:-.03em;
  font-weight:400;color:var(--ink);
  margin-top:18px;
}
@media (min-width:560px){.apply-hero h1{font-size:3rem;}}
@media (min-width:820px){.apply-hero h1{font-size:4rem;}}
@media (min-width:1100px){.apply-hero h1{font-size:5rem;}}
@media (min-width:1320px){.apply-hero h1{font-size:5.8rem;}}
.apply-hero h1 em{
  color:var(--moss);font-style:italic;
  font-variation-settings:"opsz" 144, "SOFT" 100;
}

.apply-hero p{
  font-size:1.02rem;color:#3a4a40;max-width:50ch;margin-top:18px;
}
@media (min-width:820px){.apply-hero p{font-size:1.15rem;margin-top:24px;}}

.apply-stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;
  padding-top:28px;border-top:1px solid var(--mist);
}
@media (min-width:820px){.apply-stats{padding-top:32px;}}
.apply-stat{display:flex;flex-direction:column;gap:6px;}
.apply-stat big{
  font-family:var(--serif);
  font-variation-settings:"opsz" 144, "SOFT" 80;
  font-size:2.4rem;line-height:.85;letter-spacing:-.03em;
  color:var(--ink);font-weight:400;
}
@media (min-width:560px){.apply-stat big{font-size:3rem;}}
@media (min-width:820px){.apply-stat big{font-size:3.4rem;}}
.apply-stat big span{font-style:italic;color:var(--coral);font-size:.6em;}
.apply-stat .lbl{
  font-family:var(--mono);font-size:.62rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--leaf);
}

/* ============================================================
   FILTER RAIL
   ============================================================ */
.filters{
  padding:24px var(--gutter);
  background:var(--paper);
  border-top:1px solid var(--mist);
  border-bottom:1px solid var(--mist);
  position:sticky;top:calc(var(--banner-h, 36px) + 64px);z-index:40;
}
@media (min-width:820px){.filters{padding:30px var(--gutter);top:calc(var(--banner-h, 36px) + 74px);}}

.filters-inner{
  max-width:var(--maxw);margin:0 auto;
  display:flex;flex-direction:column;gap:16px;
}
@media (min-width:820px){.filters-inner{flex-direction:row;align-items:center;justify-content:space-between;gap:30px;}}

.filter-group{
  display:flex;align-items:center;gap:10px;
  overflow-x:auto;
  margin:0 calc(-1 * var(--gutter));
  padding:0 var(--gutter);
  scrollbar-width:none;
  flex-shrink:0;
}
.filter-group::-webkit-scrollbar{display:none;}
@media (min-width:820px){.filter-group{margin:0;padding:0;overflow:visible;}}

.filter-label{
  font-family:var(--mono);font-size:.62rem;
  letter-spacing:.18em;text-transform:uppercase;color:var(--leaf);
  flex-shrink:0;
}

.chip{
  font-family:var(--mono);font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;
  padding:9px 14px 8px;border-radius:99px;
  border:1px solid rgba(15,27,20,.15);background:transparent;color:var(--ink);
  cursor:pointer;transition:all .25s var(--easing);white-space:nowrap;
  min-height:34px;flex-shrink:0;
}
.chip.active{background:var(--moss);color:var(--cream);border-color:var(--moss);}
.chip:hover:not(.active){background:rgba(15,27,20,.06);}

.filter-meta{
  font-family:var(--mono);font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--leaf);
  display:flex;align-items:center;gap:8px;
}
.filter-meta b{color:var(--coral);font-weight:500;}

/* ============================================================
   JOB LISTINGS
   ============================================================ */
.listings{ padding:var(--section-y) var(--gutter); }
.listings-grid{
  max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:1fr;gap:16px;
}
@media (min-width:820px){.listings-grid{grid-template-columns:repeat(2,1fr);gap:20px;}}
@media (min-width:1100px){.listings-grid{grid-template-columns:repeat(3,1fr);gap:22px;}}

.job{
  background:var(--paper);
  border:1px solid rgba(15,27,20,.08);
  border-radius:18px;
  padding:24px;
  display:flex;flex-direction:column;gap:14px;
  transition:transform .4s var(--easing), border-color .3s, box-shadow .4s;
  position:relative;overflow:hidden;
}
@media (min-width:820px){.job{padding:28px;}}

.job:hover{
  transform:translateY(-4px);
  border-color:var(--coral);
  box-shadow:0 22px 50px -28px rgba(15,27,20,.35);
}
.job::before{
  content:"";position:absolute;top:0;left:0;right:0;height:2px;
  background:var(--coral);
  transform:scaleX(0);transform-origin:left;
  transition:transform .55s var(--easing);
}
.job:hover::before{transform:scaleX(1);}

.job-top{
  display:flex;justify-content:space-between;align-items:center;gap:10px;
  font-family:var(--mono);font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--leaf);
}
.job-badge{
  background:var(--coral);color:var(--paper);
  padding:5px 10px 4px;border-radius:99px;letter-spacing:.14em;font-size:.58rem;
}
.job-badge.cold{background:rgba(15,27,20,.07);color:var(--leaf);}
.job-badge.hot{background:var(--moss);color:var(--cream);}

.job h3{
  font-family:var(--serif);
  font-variation-settings:"opsz" 144, "SOFT" 80;
  font-size:1.4rem;line-height:1.08;letter-spacing:-.02em;font-weight:400;
  color:var(--ink);
  margin-top:2px;
}
@media (min-width:820px){.job h3{font-size:1.55rem;}}

.job .hospital{
  font-family:var(--serif);font-style:italic;color:var(--moss);
  font-variation-settings:"opsz" 144, "SOFT" 100;
  font-size:1.02rem;
  margin-top:-2px;
}

.job-meta{
  display:flex;flex-wrap:wrap;gap:12px;
  font-size:.85rem;color:#3a4a40;
}
.job-meta span{display:inline-flex;align-items:center;gap:6px;}
.job-meta svg{width:13px;height:13px;color:var(--coral);flex-shrink:0;}

.job-desc{
  font-size:.9rem;color:#3a4a40;line-height:1.55;
}

.job-benefits{
  list-style:none;display:flex;flex-wrap:wrap;gap:6px;
  padding-top:4px;
}
.job-benefits li{
  font-family:var(--mono);font-size:.58rem;letter-spacing:.14em;text-transform:uppercase;
  padding:5px 9px 4px;
  background:rgba(31,61,46,.08);
  color:var(--moss);
  border-radius:99px;
}

.job-salary{
  font-family:var(--serif);font-style:italic;
  font-variation-settings:"opsz" 144;
  color:var(--moss);font-size:1.3rem;
  padding-top:10px;
  border-top:1px dashed rgba(15,27,20,.12);
}
.job-salary small{
  font-family:var(--sans);font-style:normal;font-size:.66rem;
  color:#3a4a40;letter-spacing:.1em;text-transform:uppercase;margin-left:6px;
}

.job-actions{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  margin-top:auto;padding-top:8px;
}
.job-apply{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--moss);color:var(--cream);
  padding:11px 16px 10px;
  border-radius:99px;font-size:.82rem;font-weight:500;
  transition:all .3s var(--easing);
  min-height:38px;
}
.job-apply:hover{background:var(--ink);transform:translateY(-1px);}
.job-apply svg{width:11px;height:11px;}

.job-share{
  font-family:var(--mono);font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--leaf);
  padding-bottom:3px;border-bottom:1px solid rgba(15,27,20,.18);
  transition:all .3s var(--easing);
}
.job-share:hover{color:var(--ember);border-color:var(--coral);}

/* ============================================================
   WORKABLE CTA BAND
   ============================================================ */
.workable-cta{
  padding:var(--section-y) var(--gutter);
  background:var(--ink);color:var(--cream);
  position:relative;overflow:hidden;
}
.workable-cta::before{
  content:"";position:absolute;
  width:500px;height:500px;
  background:radial-gradient(circle, rgba(220,110,74,.18), transparent 65%);
  top:-150px;left:50%;transform:translateX(-50%);
  pointer-events:none;
}

.workable-cta-inner{
  max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:1fr;gap:32px;
  align-items:end;
  position:relative;z-index:2;
}
@media (min-width:820px){
  .workable-cta-inner{
    grid-template-columns:1.5fr 1fr;gap:60px;align-items:end;
  }
}

.workable-cta .eyebrow{color:var(--coral);}
.workable-cta .eyebrow::before{background:var(--coral);}
.workable-cta h2{
  font-family:var(--serif);
  font-variation-settings:"opsz" 144, "SOFT" 70;
  font-size:2rem;line-height:.95;letter-spacing:-.025em;font-weight:400;
  color:var(--cream);
  margin-top:18px;max-width:24ch;
}
@media (min-width:560px){.workable-cta h2{font-size:2.6rem;}}
@media (min-width:820px){.workable-cta h2{font-size:3.4rem;}}
@media (min-width:1100px){.workable-cta h2{font-size:4.2rem;}}
.workable-cta h2 em{
  color:var(--coral);font-style:italic;
  font-variation-settings:"opsz" 144, "SOFT" 100;
}
.workable-cta p{
  color:rgba(244,238,223,.78);font-size:1rem;margin-top:18px;max-width:42ch;
}
.workable-cta-actions{
  display:flex;flex-direction:column;align-items:flex-start;gap:14px;
}
.workable-cta-actions .btn-coral{background:var(--coral);color:var(--paper);}
.workable-cta-actions .btn-coral:hover{background:var(--ember);}
.workable-cta-actions .meta{
  font-family:var(--mono);font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--sage);
}

/* ============================================================
   FOOTER (mirrors index.html)
   ============================================================ */
footer{
  background:var(--ink);
  color:var(--cream);
  padding:60px var(--gutter) 32px;
  position:relative;
}
@media (min-width:820px){footer{padding:80px var(--gutter) 40px;}}

.footer-grid{
  max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:1fr;gap:36px;
  padding-bottom:36px;border-bottom:1px solid rgba(244,238,223,.12);
}
@media (min-width:560px){.footer-grid{grid-template-columns:1fr 1fr;gap:36px;}}
@media (min-width:1100px){.footer-grid{grid-template-columns:2fr 1fr 1fr;gap:60px;padding-bottom:48px;}}

.footer-brand .brand-mark{width:40px;height:48px;border-radius:20px 20px 4px 4px;}
.footer-brand{grid-column:1 / -1;}
@media (min-width:1100px){.footer-brand{grid-column:auto;}}

.footer-brand h3{
  font-family:var(--serif);
  font-variation-settings:"opsz" 144, "SOFT" 80;
  font-size:1.7rem;line-height:1;margin:20px 0 10px;font-weight:400;
}
.footer-brand h3 em{color:var(--coral);font-style:italic;}
.footer-brand p{color:rgba(244,238,223,.7);max-width:36ch;font-size:.95rem;}

.footer-col h4{
  font-family:var(--mono);font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--sage);margin-bottom:18px;font-weight:500;
}
.footer-col ul{list-style:none;display:grid;gap:10px;}
.footer-col a{
  color:rgba(244,238,223,.8);font-size:.92rem;
  transition:color .3s;display:inline-flex;align-items:center;gap:6px;min-height:30px;
}
.footer-col a:hover{color:var(--coral);}

.footer-office{font-size:.92rem;color:rgba(244,238,223,.8);line-height:1.6;}
.footer-office strong{
  color:var(--coral);font-family:var(--serif);font-style:italic;
  font-size:1.05rem;font-weight:500;display:block;margin-bottom:6px;
}

.footer-bottom{
  max-width:var(--maxw);margin:0 auto;
  display:flex;flex-direction:column;justify-content:space-between;align-items:flex-start;
  font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--sage);gap:16px;margin-top:24px;
}
@media (min-width:560px){.footer-bottom{flex-direction:row;align-items:center;gap:20px;flex-wrap:wrap;}}

.footer-bottom a{color:var(--cream);}
.footer-bottom .links{display:flex;gap:18px;flex-wrap:wrap;}
@media (min-width:820px){.footer-bottom .links{gap:24px;}}

/* ============================================================
   REVEAL
   ============================================================ */
[data-reveal]{
  opacity:0;transform:translateY(20px);
  transition:opacity .8s var(--easing), transform .8s var(--easing);
}
[data-reveal].in-view{opacity:1;transform:none;}
[data-reveal][data-delay="1"]{transition-delay:.08s;}
[data-reveal][data-delay="2"]{transition-delay:.16s;}
[data-reveal][data-delay="3"]{transition-delay:.24s;}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:0.01ms!important;
    transition-duration:0.01ms!important;
  }
  [data-reveal]{opacity:1;transform:none;}
}
