html,body.contact-body{
  background:#020203;
  color:#f4f3ef;
  min-height:100%;
}
body.contact-body{
  overflow-x:hidden;
  font-family:var(--font-ui);
}

#ink-canvas{
  position:fixed;inset:0;width:100%;height:100%;
  display:block;z-index:0;pointer-events:none;
}
.contact-vignette{
  position:fixed;inset:0;z-index:1;pointer-events:none;
  background:
    radial-gradient(120% 80% at 50% 0%, transparent 30%, rgba(0,0,0,.55) 100%),
    radial-gradient(80% 60% at 50% 110%, rgba(0,0,0,.7), transparent 60%);
}
.contact-grain{
  position:fixed;inset:0;z-index:1;pointer-events:none;
  opacity:.5;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.10 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

/* Header overrides for contact page */
.contact-header{
  background:
    linear-gradient(135deg,
      rgba(255,255,255,0.08) 0%,
      rgba(255,255,255,0.018) 45%,
      rgba(255,255,255,0.06) 100%);
  border-color:rgba(255,255,255,0.10);
}
.contact-header .logo,
.contact-header .tagline{color:#f4f3ef}
.contact-header .tagline{color:rgba(255,255,255,.55)}
.contact-header .menu span{background:#fff}
.pill--ghost{
  background:transparent!important;
  color:#fff!important;
}
.pill--ghost:hover{background:rgba(255,255,255,.08)!important}

.contact-main{
  position:relative;z-index:2;
  display:flex;align-items:center;justify-content:center;
  min-height:100vh;
  padding:140px 32px 100px;
}
.contact-shell{
  width:100%;max-width:1180px;
  display:grid;grid-template-columns:0.85fr 1.15fr;gap:80px;align-items:start;
}
.contact-copy{padding-top:8px}
.contact-kicker{
  font-family:var(--font-ui);
  font-size:12px;letter-spacing:.42em;font-weight:600;
  color:rgba(255,255,255,.55);margin-bottom:22px;
}
.contact-copy h1{
  font-family:var(--font-ui);
  font-size:clamp(52px, 7vw, 96px);
  line-height:.92;letter-spacing:-0.02em;font-weight:700;
  color:#f4f3ef;
  background:linear-gradient(180deg,#ffffff 0%, #d6d6dc 70%, #9a9aa3 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  margin-bottom:26px;
  text-transform:uppercase;
}
.contact-sub{
  font-family:var(--font-display);
  font-style:italic;
  font-size:clamp(20px,1.9vw,28px);
  color:rgba(255,255,255,.82);
  margin-bottom:18px;
}
.contact-desc{
  font-size:15px;line-height:1.65;color:rgba(255,255,255,.6);
  max-width:380px;
}

/* Glass panel — obsidian, no red */
.contact-form{
  position:relative;
  margin-top:58px;
}
.contact-panel{
  position:relative;
  padding:44px 44px 38px;
  border-radius:26px;
  background:
    linear-gradient(155deg,
      rgba(255,255,255,0.05) 0%,
      rgba(255,255,255,0.015) 45%,
      rgba(255,255,255,0.04) 100%);
  border:1px solid rgba(255,255,255,0.10);
  backdrop-filter:blur(22px) saturate(140%);
  -webkit-backdrop-filter:blur(22px) saturate(140%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.14),
    inset 0 -1px 0 rgba(255,255,255,0.03),
    0 30px 80px rgba(0,0,0,0.55),
    0 8px 24px rgba(0,0,0,0.35);
  overflow:hidden;
}
.contact-panel::before{
  content:'';position:absolute;inset:0;pointer-events:none;border-radius:inherit;
  background:
    radial-gradient(60% 50% at 80% 0%, rgba(180,190,255,.06), transparent 70%),
    radial-gradient(70% 60% at 0% 100%, rgba(200,200,220,.04), transparent 70%);
}

.contact-row{display:grid;gap:24px;margin-bottom:22px;position:relative;z-index:1}
.contact-row--names,
.contact-row--two{grid-template-columns:1fr 1fr}
.contact-row:last-child{margin-bottom:0}

.contact-field{position:relative;display:block}
.contact-label{
  display:block;
  font-family:var(--font-ui);
  font-size:11px;letter-spacing:.28em;font-weight:600;
  color:rgba(255,255,255,.5);
  text-transform:uppercase;
  margin-bottom:10px;
  transition:color .35s ease;
}
.contact-field input,
.contact-field textarea{
  width:100%;
  background:transparent;
  border:none;
  outline:none;
  color:#f4f3ef;
  font-family:var(--font-ui);
  font-size:16px;font-weight:500;
  padding:8px 0 12px;
  border-bottom:1px solid rgba(255,255,255,0.12);
  resize:none;
  transition:border-color .35s ease;
  caret-color:#cfd2da;
}
.contact-field textarea{padding-top:6px;line-height:1.55;min-height:88px}
.contact-field input::placeholder,
.contact-field textarea::placeholder{color:rgba(255,255,255,.52);font-weight:400}
.contact-underline{
  position:absolute;left:0;bottom:0;height:1px;width:100%;
  background:linear-gradient(90deg, rgba(255,255,255,0) 0%, rgba(255,255,255,.7) 50%, rgba(255,255,255,0) 100%);
  transform:scaleX(0);transform-origin:center;
  transition:transform .55s cubic-bezier(.2,.8,.2,1);
  pointer-events:none;
}
.contact-field input:focus ~ .contact-underline,
.contact-field textarea:focus ~ .contact-underline{transform:scaleX(1)}
.contact-field input:focus,
.contact-field textarea:focus{border-bottom-color:rgba(255,255,255,0.04)}
.contact-field:focus-within .contact-label{color:rgba(255,255,255,.9)}

/* Expand */
.contact-expand{
  display:grid;
  grid-template-rows:0fr;
  opacity:0;
  transition:
    grid-template-rows .9s cubic-bezier(.2,.8,.2,1),
    opacity .6s ease .1s;
  overflow:hidden;
}
.contact-expand-inner{
  min-height:0;overflow:hidden;
  transform:translateY(-10px);
  transition:transform .9s cubic-bezier(.2,.8,.2,1);
}
.contact-form.is-open .contact-expand{grid-template-rows:1fr;opacity:1}
.contact-form.is-open .contact-expand-inner{transform:translateY(0)}
.contact-expand-inner > *:first-child{
  padding-top:32px;margin-top:8px;
  border-top:1px solid rgba(255,255,255,.07);
}

/* Submit — obsidian button */
.contact-submit-row{
  margin-top:32px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
}
.contact-form-status{
  min-height:1.5em;
  margin:0;
  color:rgba(255,255,255,.55);
  font-size:13px;
  line-height:1.45;
}
.contact-form-status[data-state="error"]{color:rgba(255,168,168,.92)}
.contact-form.is-submitting .contact-form-status{
  color:rgba(255,255,255,.72);
}
.contact-submit{
  position:relative;overflow:hidden;
  display:inline-flex;align-items:center;gap:12px;
  padding:16px 28px;border-radius:999px;border:1px solid rgba(255,255,255,.16);
  background:linear-gradient(180deg, rgba(255,255,255,.09), rgba(255,255,255,.02));
  color:#fff;font-family:var(--font-ui);
  font-size:13px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;
  cursor:pointer;
  transition:transform .35s ease, border-color .35s ease, background .35s ease;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.18),
    0 10px 30px rgba(0,0,0,.45);
}
.contact-submit:hover{
  transform:translateY(-1px);
  border-color:rgba(255,255,255,.32);
  background:linear-gradient(180deg, rgba(255,255,255,.16), rgba(255,255,255,.04));
}
.contact-submit:disabled{
  cursor:wait;
  opacity:.72;
  transform:none;
}
.contact-submit-arrow{display:inline-flex;transition:transform .4s ease}
.contact-submit:hover .contact-submit-arrow{transform:translateX(4px)}
.contact-submit:disabled .contact-submit-arrow{transform:none}
.contact-submit-shine{
  position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(110deg, transparent 30%, rgba(255,255,255,.16) 50%, transparent 70%);
  transform:translateX(-120%);
  transition:transform .9s ease;
}
.contact-submit:hover .contact-submit-shine{transform:translateX(120%)}

.contact-footer{
  position:relative;z-index:2;
  background:transparent;color:rgba(255,255,255,.55);
  border-top:1px solid rgba(255,255,255,.06);
}

/* Form validation */
.contact-field.has-error input,
.contact-field.has-error textarea{border-bottom-color:rgba(230,80,80,.7)}
.contact-field.has-error .contact-label{color:rgba(230,80,80,.85)}

/* Success state */
.contact-success{
  position:absolute;inset:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:60px 32px;
  opacity:0;visibility:hidden;
  transform:translateY(16px);
  transition:opacity .6s ease .15s,visibility .6s ease .15s,transform .6s cubic-bezier(.2,.8,.2,1) .15s;
}
.contact-shell.is-sent .contact-success{opacity:1;visibility:visible;transform:translateY(0)}
.contact-shell.is-sent .contact-copy,
.contact-shell.is-sent .contact-form{
  opacity:0;pointer-events:none;
  transform:translateY(-12px);
  transition:opacity .4s ease,transform .4s ease;
}
.contact-success-icon{
  width:72px;height:72px;
  border:2px solid rgba(255,255,255,.25);
  border-radius:50%;
  display:grid;place-items:center;
  margin-bottom:28px;
}
.contact-success-icon svg{width:32px;height:32px;color:rgba(255,255,255,.85)}
.contact-success h2{
  font-family:var(--font-ui);
  font-size:clamp(32px,5vw,48px);
  font-weight:700;color:#f4f3ef;
  letter-spacing:-.02em;
  margin-bottom:14px;
}
.contact-success p{
  font-size:16px;line-height:1.55;
  color:rgba(255,255,255,.6);
  max-width:340px;
}

/* Contact footer nav */
.contact-footer .footer-nav a{color:rgba(255,255,255,.7)}
.contact-footer .footer-nav a:hover{opacity:.5}

@media (max-width:980px){
  .contact-main{padding:120px 20px 80px}
  .contact-shell{grid-template-columns:1fr;gap:48px}
  .contact-form{margin-top:0}
  .contact-panel{padding:28px 24px}
  .contact-row--names,
  .contact-row--two{grid-template-columns:1fr}
  .contact-submit-row{
    align-items:flex-start;
    flex-direction:column;
  }
}
