/* ===========================================================
   Common Ground Pilates — Private Event Inquiry
   Inherits tokens from studio-hub.css (loaded first on the page).
   =========================================================== */

/* ---- page scaffold ---- */
.inq-main {
  min-height: 100vh;
  background: var(--paper);
}

/* ---- hero section ---- */
.inq-hero {
  position: relative;
  padding: clamp(118px, 16vh, 168px) clamp(20px, 5vw, 72px) clamp(40px, 6vh, 72px);
  max-width: 1180px;
  margin: 0 auto;
  overflow: hidden;
}

.inq-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(60% 50% at 16% 42%, rgba(194, 84, 61, .10), transparent 70%),
    radial-gradient(50% 50% at 94% 30%, rgba(212, 168, 95, .09), transparent 70%);
}

.inq-hero > * {
  position: relative;
  z-index: 1;
}

.inq-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  font: 500 12px/1 "Inter";
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--terracotta);
}

.inq-eyebrow .dot {
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: var(--terracotta);
  box-shadow: 0 0 0 0 rgba(194, 84, 61, .5);
  animation: inqpulse 2.4s cubic-bezier(.16, 1, .3, 1) infinite;
}

@keyframes inqpulse {
  0%   { box-shadow: 0 0 0 0 rgba(194, 84, 61, .45) }
  70%  { box-shadow: 0 0 0 8px rgba(194, 84, 61, 0) }
  100% { box-shadow: 0 0 0 0 rgba(194, 84, 61, 0) }
}

.inq-hero h1 {
  font: 300 clamp(48px, 8.4vw, 104px)/.95 "Fraunces";
  letter-spacing: -.02em;
  color: var(--ink);
  margin: 18px 0 0;
}

.inq-hero h1 em {
  font-weight: 400;
  font-style: italic;
  color: var(--terracotta);
}

.inq-lede {
  font: 400 clamp(16px, 1.5vw, 19px)/1.6 "Inter";
  color: var(--ink-soft);
  max-width: 52ch;
  margin: 18px 0 0;
}

.inq-lede b {
  font-weight: 500;
  color: var(--ink);
}

/* ---- form container ---- */
.inq-body {
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 clamp(20px, 5vw, 72px) clamp(70px, 9vh, 110px);
}

.inq-layout {
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  gap: clamp(48px, 6vw, 96px);
  align-items: start;
}

/* ---- sidebar context ---- */
.inq-sidebar {
  position: sticky;
  top: clamp(88px, 10vh, 120px);
}

.inq-sidebar-rule {
  height: 1px;
  background: var(--rule);
  margin-bottom: 32px;
}

.inq-sidebar h2 {
  font: 300 italic clamp(28px, 3vw, 42px)/1.08 "Fraunces";
  letter-spacing: -.02em;
  color: var(--ink);
  margin: 0 0 20px;
}

.inq-sidebar h2 em {
  font-style: normal;
  color: var(--terracotta);
}

.inq-detail-list {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-top: 28px;
}

.inq-detail {
  display: flex;
  gap: 16px;
  padding: 16px 0;
  border-bottom: 1px solid var(--rule);
}

.inq-detail:first-child {
  border-top: 1px solid var(--rule);
}

.inq-detail .dk {
  font: 500 10.5px/1 "Inter";
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--terracotta);
  flex: none;
  width: 100px;
  padding-top: 2px;
}

.inq-detail .dv {
  font: 400 13.5px/1.5 "Inter";
  color: var(--ink-soft);
}

.inq-sidebar-note {
  margin-top: 28px;
  font: 400 12.5px/1.6 "Inter";
  color: var(--ink-mute);
}

/* ---- form card ---- */
.inq-form-card {
  background: #fff;
  border: 1px solid var(--rule);
  border-radius: 16px;
  padding: clamp(28px, 4vw, 48px);
}

.inq-form-card h3 {
  font: 300 italic clamp(22px, 2.2vw, 30px)/1.1 "Fraunces";
  letter-spacing: -.01em;
  color: var(--ink);
  margin: 0 0 32px;
}

/* ---- field styles ---- */
.inq-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}

.inq-field {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-bottom: 24px;
}

.inq-field label {
  font: 500 10px/1 "Inter";
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-bottom: 8px;
}

.inq-field label .req {
  color: var(--terracotta);
  margin-left: 2px;
}

.inq-field input,
.inq-field select,
.inq-field textarea {
  appearance: none;
  -webkit-appearance: none;
  font: 400 15px/1.5 "Inter";
  color: var(--ink);
  background: transparent;
  border: none;
  border-bottom: 1.5px solid var(--rule);
  padding: 10px 0 12px;
  border-radius: 0;
  outline: none;
  width: 100%;
  transition: border-color .25s cubic-bezier(.16, 1, .3, 1);
}

.inq-field select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%237a7064' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 2px center;
  padding-right: 22px;
  cursor: pointer;
}

.inq-field input:focus,
.inq-field select:focus,
.inq-field textarea:focus {
  border-color: var(--terracotta);
}

.inq-field input::placeholder,
.inq-field textarea::placeholder {
  color: rgba(26, 24, 22, .32);
}

.inq-field input[type="date"]::-webkit-calendar-picker-indicator {
  opacity: .4;
  cursor: pointer;
}

.inq-field textarea {
  resize: vertical;
  min-height: 120px;
  line-height: 1.6;
}

/* honeypot — visually hidden, screen-reader hidden */
.inq-hp {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  overflow: hidden;
  opacity: 0;
  pointer-events: none;
  tab-index: -1;
}

/* ---- submit row ---- */
.inq-submit-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
  margin-top: 32px;
  padding-top: 28px;
  border-top: 1px solid var(--rule);
}

.inq-submit-note {
  font: 400 12px/1.5 "Inter";
  color: var(--ink-mute);
  max-width: 34ch;
}

.inq-btn {
  appearance: none;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font: 500 11px/1 "Inter";
  letter-spacing: .2em;
  text-transform: uppercase;
  padding: 14px 26px;
  border-radius: 999px;
  border: 0;
  background: var(--ink);
  color: var(--paper);
  cursor: pointer;
  transition: background .35s cubic-bezier(.16, 1, .3, 1), transform .35s cubic-bezier(.16, 1, .3, 1);
  white-space: nowrap;
  flex-shrink: 0;
}

.inq-btn:hover {
  background: var(--terracotta);
  transform: translateY(-2px);
}

.inq-btn:disabled {
  opacity: .6;
  cursor: not-allowed;
  transform: none;
}

.inq-btn .inq-spinner {
  display: none;
  width: 14px;
  height: 14px;
  border: 1.5px solid rgba(239, 234, 224, .4);
  border-top-color: var(--paper);
  border-radius: 50%;
  animation: spin .6s linear infinite;
}

.inq-btn.loading .inq-spinner {
  display: block;
}

@keyframes spin {
  to { transform: rotate(360deg) }
}

/* ---- inline states ---- */
/* success */
.inq-success {
  display: none;
  background: rgba(129, 139, 126, .08);
  border: 1px solid rgba(129, 139, 126, .22);
  border-radius: 12px;
  padding: clamp(28px, 4vw, 44px);
  text-align: center;
}

.inq-success.visible {
  display: block;
}

.inq-success .is-mark {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--sage);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 20px;
}

.inq-success .is-mark svg {
  display: block;
}

.inq-success h3 {
  font: 300 italic clamp(24px, 2.4vw, 32px)/1.1 "Fraunces";
  letter-spacing: -.01em;
  color: var(--ink);
  margin: 0 0 12px;
}

.inq-success p {
  font: 400 15px/1.6 "Inter";
  color: var(--ink-soft);
  margin: 0;
  max-width: 44ch;
  margin: 0 auto;
}

/* error */
.inq-error {
  display: none;
  margin-top: 20px;
  padding: 16px 20px;
  background: rgba(194, 84, 61, .06);
  border: 1px solid rgba(194, 84, 61, .2);
  border-radius: 10px;
  font: 400 13.5px/1.5 "Inter";
  color: var(--ink-soft);
}

.inq-error.visible {
  display: block;
}

.inq-error a {
  color: var(--terracotta);
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* ---- responsive ---- */
@media (max-width: 900px) {
  .inq-layout {
    grid-template-columns: 1fr;
    gap: 40px;
  }

  .inq-sidebar {
    position: static;
  }
}

@media (max-width: 600px) {
  .inq-row {
    grid-template-columns: 1fr;
    gap: 0;
  }

  .inq-submit-row {
    flex-direction: column;
    align-items: flex-start;
  }

  .inq-btn {
    width: 100%;
    justify-content: center;
  }
}

@media (prefers-reduced-motion: reduce) {
  .inq-eyebrow .dot {
    animation: none;
  }

  .inq-btn,
  .inq-field input,
  .inq-field select,
  .inq-field textarea {
    transition: none;
  }
}


/* ===========================================================
   HEADER — copied from the homepage (site.css) so the inquiry
   page nav matches index.html exactly. inquiry.html does not
   load site.css, so these rules live here.
   =========================================================== */
header.site{
  position:fixed;top:0;left:0;right:0;z-index:100;
  border-bottom:1px solid transparent;
  transition:background .4s ease,backdrop-filter .4s ease,border-color .4s ease;
}
header.site.scrolled{
  background:rgba(244,239,230,.45);
  backdrop-filter:blur(22px) saturate(1.6);-webkit-backdrop-filter:blur(22px) saturate(1.6);
  border-bottom:1px solid rgba(28,26,23,.08);
  box-shadow:inset 0 -1px 0 rgba(255,255,255,.3);
}
header.site .nav{
  max-width:1280px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  padding:15px 32px;
}
header.site .brand{display:flex;align-items:center;gap:13px;text-decoration:none}
header.site .brand img{height:42px;width:auto;flex:none}
header.site .menu{display:flex;align-items:center;gap:38px}
header.site .menu nav{display:flex;gap:32px}
header.site .menu nav a{
  font:inherit;font-size:13px;letter-spacing:.13em;text-transform:uppercase;color:var(--ink-soft);
  position:relative;padding:4px 0;text-decoration:none;
}
header.site .menu nav a::after{
  content:"";position:absolute;left:0;right:100%;bottom:0;height:1px;
  background:var(--terracotta);transition:right .35s cubic-bezier(.4,0,.2,1);
}
header.site .menu nav a:hover{color:var(--ink)}
header.site .menu nav a:hover::after{right:0}
header.site .btn{
  display:inline-flex;align-items:center;gap:10px;
  font-size:12.5px;letter-spacing:.16em;text-transform:uppercase;font-family:inherit;
  white-space:nowrap;line-height:1;
  padding:14px 26px;border-radius:999px;border:1px solid var(--ink);
  background:transparent;color:var(--ink);cursor:pointer;text-decoration:none;
  transition:background .35s ease,color .35s ease,border-color .35s ease,transform .35s ease;
}
header.site .btn:hover{transform:translateY(-2px)}
header.site .btn.solid{background:var(--terracotta);border-color:var(--terracotta);color:var(--paper)}
header.site .btn.solid:hover{background:var(--ink);border-color:var(--ink)}
.menu-toggle{display:none;background:none;border:0;cursor:pointer;flex-direction:column;gap:5px;padding:6px}
.menu-toggle span{display:block;width:24px;height:1.5px;background:var(--ink);transition:.3s}
.mobile-nav{
  position:fixed;inset:0;z-index:99;background:var(--paper);
  display:flex;flex-direction:column;justify-content:center;gap:6px;padding:32px;
  transform:translateY(-100%);transition:transform .6s cubic-bezier(.16,1,.3,1);
}
.mobile-nav.open{transform:none}
.mobile-nav a{font-family:"Fraunces",Georgia,serif;font-size:34px;padding:6px 0;color:var(--ink);text-decoration:none}
.mobile-nav .btn{
  margin-top:22px;align-self:flex-start;
  display:inline-flex;align-items:center;gap:10px;
  font-size:12.5px;letter-spacing:.16em;text-transform:uppercase;
  padding:14px 26px;border-radius:999px;border:1px solid var(--terracotta);
  background:var(--terracotta);color:var(--paper);text-decoration:none;
}
@media (max-width:760px){
  header.site .menu nav,header.site .menu .btn{display:none}
  .menu-toggle{display:flex}
}

/* official brand lockup in the header (icon + wordmark) */
header.site .brand .brand-icon{height:40px;width:auto;flex:none}
header.site .brand .brand-name{
  font-family:"Fraunces",Georgia,serif;font-weight:400;font-size:19px;line-height:1.1;
  letter-spacing:-.01em;color:var(--ink);white-space:nowrap;
}
header.site .brand .brand-name em{font-style:italic;color:#a64a3a}
@media (max-width:560px){
  header.site .brand .brand-name{white-space:normal;text-align:center;line-height:1.02;font-size:15px}
  header.site .brand .brand-name em{display:block}
}
header.site.scrolled .brand .brand-icon{height:34px}
