/* ============================================================
   GREENDOOR · PARTNER PAGE — employer inquiry form
   ============================================================ */
: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;}

.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);}

/* 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;
  cursor:pointer;
}
@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;
}

/* Nav */
.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{padding:11px 18px 10px;font-size:.85rem;}
@media (min-width:820px){.nav-actions .btn{padding:13px 22px 12px;font-size:.9rem;}}

/* ============================================================
   PARTNER HERO + FORM
   ============================================================ */
.partner-hero{padding:60px var(--gutter) var(--section-y);position:relative;}
@media (min-width:820px){.partner-hero{padding:90px var(--gutter) var(--section-y);}}

.partner-grid{
  max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:1fr;gap:36px;
}
@media (min-width:900px){
  .partner-grid{grid-template-columns:1fr 1.3fr;gap:60px;align-items:start;}
}
@media (min-width:1100px){.partner-grid{gap:80px;}}

/* Left column — context */
.partner-intro 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){.partner-intro h1{font-size:3rem;}}
@media (min-width:820px){.partner-intro h1{font-size:3.6rem;}}
@media (min-width:1100px){.partner-intro h1{font-size:4.4rem;}}
.partner-intro h1 em{color:var(--moss);font-style:italic;font-variation-settings:"opsz" 144, "SOFT" 100;}
.partner-intro p{
  margin-top:20px;font-size:1rem;line-height:1.6;color:#3a4a40;max-width:42ch;
}
@media (min-width:820px){.partner-intro p{font-size:1.1rem;margin-top:24px;}}

.partner-promises{
  list-style:none;margin-top:32px;display:grid;gap:14px;
  padding-top:28px;border-top:1px solid var(--mist);
}
.partner-promises li{
  display:flex;align-items:flex-start;gap:12px;
  font-size:.95rem;color:var(--ink);
}
.partner-promises li::before{
  content:"";width:14px;height:17px;flex-shrink:0;margin-top:3px;
  background:var(--moss);border-radius:7px 7px 1px 1px;position:relative;
}
.partner-promises li b{
  font-family:var(--serif);font-style:italic;color:var(--moss);
  font-variation-settings:"opsz" 144;font-weight:500;
}

.partner-contact{
  margin-top:32px;padding-top:24px;border-top:1px solid var(--mist);
  display:flex;flex-direction:column;gap:6px;
  font-family:var(--mono);font-size:.64rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--leaf);
}
.partner-contact a{
  font-family:var(--sans);font-size:1rem;letter-spacing:0;text-transform:none;
  color:var(--moss);font-weight:500;
  display:inline-block;padding-bottom:2px;
  border-bottom:1px solid rgba(31,61,46,.25);width:fit-content;
  transition:all .3s var(--easing);
}
.partner-contact a:hover{color:var(--ember);border-color:var(--coral);}

/* Right column — the form card */
.form-card{
  background:var(--paper);
  border:1px solid rgba(15,27,20,.08);
  border-radius:22px;
  padding:28px 24px;
  box-shadow:0 28px 60px -32px rgba(15,27,20,.3);
  position:relative;overflow:hidden;
}
@media (min-width:560px){.form-card{padding:36px 32px;}}
@media (min-width:1100px){.form-card{padding:44px 44px;border-radius:24px;}}

.form-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg, var(--moss), var(--coral), var(--moss));
}

.form-card-head{margin-bottom:24px;}
.form-card-head .eyebrow{margin-bottom:10px;display:inline-flex;}
.form-card-head h2{
  font-family:var(--serif);font-variation-settings:"opsz" 144, "SOFT" 80;
  font-size:1.6rem;line-height:1.05;letter-spacing:-.02em;font-weight:400;
}
@media (min-width:820px){.form-card-head h2{font-size:1.95rem;}}
.form-card-head h2 em{color:var(--moss);font-style:italic;}
.form-card-head p{font-size:.92rem;color:#3a4a40;margin-top:8px;max-width:48ch;}

form{display:grid;gap:18px;}

.field{display:flex;flex-direction:column;gap:6px;position:relative;}
.field label{
  font-family:var(--mono);font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--leaf);
  display:flex;justify-content:space-between;align-items:center;
}
.field label .req{color:var(--coral);font-weight:500;letter-spacing:.1em;}

.field input,
.field textarea{
  width:100%;
  font-family:var(--sans);
  font-size:1rem;
  color:var(--ink);
  background:var(--cream);
  border:1.5px solid rgba(15,27,20,.15);
  border-radius:10px;
  padding:14px 14px;
  min-height:var(--tap);
  transition:border-color .25s var(--easing), background .25s, box-shadow .25s;
  resize:none;
}
.field textarea{ min-height:140px; line-height:1.55; resize:vertical; }

.field input::placeholder,
.field textarea::placeholder{ color:rgba(15,27,20,.4); }

.field input:focus,
.field textarea:focus{
  outline:none;
  border-color:var(--coral);
  background:#FFFCF0;
  box-shadow:0 0 0 4px rgba(220,110,74,.12);
}

.field.invalid input,
.field.invalid textarea{
  border-color:var(--ember);
  background:rgba(185,75,37,.04);
}
.field .err{
  font-family:var(--mono);font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ember);
  margin-top:4px;
  display:none;
}
.field.invalid .err{ display:block; }

.field .hint{
  font-size:.78rem;color:#5a6a5f;line-height:1.4;
}

.form-row{display:grid;grid-template-columns:1fr;gap:18px;}
@media (min-width:560px){.form-row{grid-template-columns:1fr 1fr;}}

.form-actions{
  margin-top:8px;
  display:flex;flex-direction:column;gap:14px;align-items:flex-start;
}
@media (min-width:560px){
  .form-actions{flex-direction:row;align-items:center;justify-content:space-between;}
}
.form-actions .submit{
  background:var(--coral);color:var(--paper);
  width:100%;justify-content:center;
}
@media (min-width:560px){.form-actions .submit{width:auto;}}
.form-actions .submit:hover{background:var(--ember);}
.form-actions .legal{
  font-family:var(--mono);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--leaf);max-width:32ch;line-height:1.4;
}

/* Success state */
.success{
  display:none;
  text-align:left;
  padding:8px 0 4px;
}
.success.show{ display:block; }
.success .icon{
  width:60px;height:72px;
  background:var(--moss);
  border-radius:30px 30px 4px 4px;
  position:relative;
  margin-bottom:20px;
  transform-origin:left center;
  animation:doorOpen 2.6s var(--easing) infinite;
}
.success .icon::after{
  content:"";position:absolute;right:8px;top:50%;
  width:6px;height:6px;border-radius:50%;background:var(--coral);
  transform:translateY(-50%);
}
@keyframes doorOpen{
  0%,40%,100%{transform:perspective(400px) rotateY(0);}
  50%,60%{transform:perspective(400px) rotateY(-38deg);}
}
.success h3{
  font-family:var(--serif);font-variation-settings:"opsz" 144, "SOFT" 80;
  font-size:1.6rem;line-height:1.1;letter-spacing:-.02em;font-weight:400;
}
@media (min-width:820px){.success h3{font-size:2rem;}}
.success h3 em{color:var(--moss);font-style:italic;}
.success p{
  font-size:.95rem;color:#3a4a40;line-height:1.6;margin-top:10px;max-width:42ch;
}
.success .again{
  margin-top:22px;
  font-family:var(--mono);font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--moss);
  border-bottom:1px solid rgba(31,61,46,.3);padding-bottom:3px;
  display:inline-block;
  transition:all .3s var(--easing);
  cursor:pointer;
}
.success .again:hover{color:var(--ember);border-color:var(--coral);}

/* ============================================================
   FOOTER
   ============================================================ */
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:24px auto 0;
  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;
}
@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;}}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:0.01ms!important;transition-duration:0.01ms!important;}
}
