/**
 * Athenian Project Intake AI - compact console frontend.
 */
.aai-intake {
  --aai-bg: var(--shortcode-bg, var(--surface-1, var(--wp--preset--color--base, #f6f9ff)));
  --aai-panel: var(--surface-0, var(--wp--preset--color--background, #ffffff));
  --aai-panel-soft: var(--surface-1, var(--wp--preset--color--tertiary, #f8fbff));
  --aai-panel-strong: var(--surface-2, var(--wp--preset--color--contrast-2, #eef5fb));
  --aai-text: var(--text-high, var(--wp--preset--color--contrast, #152033));
  --aai-muted: var(--text-mid, var(--wp--preset--color--contrast-3, #596579));
  --aai-faint: var(--text-low, #7a8497);
  --aai-border: var(--border, rgba(21, 32, 51, 0.13));
  /* Theme token mapping: solid accents and gradient backgrounds are deliberately separated.
     The site exposes --btn-bg as a gradient, while --ctl-c1/--ctl-c2 are solid colors.
     Keeping this shallow avoids invalid nested var() declarations and keeps borders/icons valid. */
  --aai-accent: var(--ctl-c2, var(--bricks-color-secondary, var(--wp--preset--color--accent, var(--wp--custom--color--accent, var(--ab-accent, var(--athenian-accent, var(--accent-color, #fc5778)))))));
  --aai-accent-2: var(--ctl-c1, var(--bricks-color-primary, var(--wp--preset--color--secondary, var(--wp--custom--color--accent-2, var(--ab-accent-2, var(--athenian-accent-2, var(--accent-2-color, #ffd64f)))))));
  --aai-accent-bg: var(--btn-bg, linear-gradient(135deg, var(--aai-accent-2), var(--aai-accent)));
  --aai-theme-accent: var(--aai-accent);
  --aai-theme-accent-2: var(--aai-accent-2);
  --aai-ring: var(--focus-ring, color-mix(in srgb, var(--aai-accent) 32%, transparent));
  --aai-accent-contrast: var(--btn-fg, var(--wp--custom--color--on-accent, var(--on-accent, var(--accent-contrast, #120d0a))));
  --aai-good: #0f8f61;
  --aai-warn: #b45309;
  --aai-radius: var(--radius-lg, 24px);
  --aai-radius-sm: var(--radius, 14px);
  --aai-shadow: 0 24px 70px rgba(15, 35, 60, 0.13);
  --aai-shadow-soft: 0 14px 38px rgba(15, 35, 60, 0.09);
  color: var(--aai-text);
  font-family: inherit;
  font-size: clamp(15.5px, 0.95vw, 17px);
  max-width: 1180px;
  margin: 1.5rem auto;
}

.aai-intake *,
.aai-intake *::before,
.aai-intake *::after { box-sizing: border-box; }

.aai-intake,
.aai-intake * {
  scrollbar-width: thin;
  scrollbar-color: color-mix(in srgb, var(--aai-accent) 58%, var(--aai-accent-2)) color-mix(in srgb, var(--aai-panel) 72%, transparent);
}

.aai-intake *::-webkit-scrollbar { width: 0.62rem; height: 0.62rem; }
.aai-intake *::-webkit-scrollbar-track {
  border-radius: 999px;
  background: color-mix(in srgb, var(--aai-panel) 76%, transparent);
}
.aai-intake *::-webkit-scrollbar-thumb {
  border: 2px solid transparent;
  border-radius: 999px;
  background: var(--aai-accent-bg) padding-box;
}
.aai-intake *::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(180deg, color-mix(in srgb, var(--aai-accent) 86%, #fff), color-mix(in srgb, var(--aai-accent-2) 86%, #fff)) padding-box;
}

.aai-intake__shell {
  position: relative;
  overflow: hidden;
  padding: clamp(0.9rem, 1.8vw, 1.35rem);
  border: 1px solid var(--aai-border);
  border-radius: var(--aai-radius);
  background:
    radial-gradient(circle at 8% 0%, color-mix(in srgb, var(--aai-accent) 12%, transparent), transparent 28%),
    radial-gradient(circle at 92% 12%, color-mix(in srgb, var(--aai-accent-2) 12%, transparent), transparent 32%),
    linear-gradient(180deg, color-mix(in srgb, var(--aai-bg) 94%, #fff), var(--aai-bg));
  box-shadow: var(--aai-shadow);
}

.aai-hero,
.aai-chat-card,
.aai-form-lane,
.aai-quote-dock {
  border: 1px solid color-mix(in srgb, var(--aai-border) 78%, transparent);
  background: color-mix(in srgb, var(--aai-panel) 82%, transparent);
  box-shadow: var(--aai-shadow-soft);
  backdrop-filter: blur(14px);
}

.aai-hero {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  padding: clamp(0.85rem, 2vw, 1.2rem);
  border-radius: calc(var(--aai-radius) - 6px);
}

.aai-intake__eyebrow {
  margin: 0 0 0.35rem;
  font-size: 0.84rem;
  font-weight: 900;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--aai-accent);
}

.aai-hero h2 {
  margin: 0;
  font-size: clamp(1.55rem, 3vw, 2.45rem);
  line-height: 1.05;
  color: var(--aai-text);
}

.aai-hero p:not(.aai-intake__eyebrow) {
  display:none;
  max-width: 760px;
  margin: 0.6rem 0 0;
  color: var(--aai-muted);
  font-size: 1.03rem;
  line-height: 1.52;
}

.aai-hero__actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 0.45rem;
  min-width: 210px;
}

.aai-intake__status,
.aai-chip-button,
.aai-mini-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 0.48rem 0.7rem;
  border: 1px solid color-mix(in srgb, var(--aai-accent) 38%, var(--aai-border));
  border-radius: 999px;
  background: linear-gradient(135deg, color-mix(in srgb, var(--aai-accent) 18%, var(--aai-panel)), color-mix(in srgb, var(--aai-accent-2) 10%, var(--aai-panel)));
  color: var(--aai-text);
  font: inherit;
  font-size: 1.2rem;
  font-weight: 850;
  text-align: center;
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 18%, transparent);
}

.aai-intake__status {
  white-space: nowrap;
}

.aai-intake__status[data-aai-status-kind="draft"] {
  position: relative;
  flex: 0 0 2.28rem;
  width: 2.28rem;
  min-width: 2.28rem;
  min-height: 2.28rem;
  padding: 0;
  overflow: hidden;
  border-color: color-mix(in srgb, var(--aai-accent) 62%, var(--aai-border));
  background:
    radial-gradient(circle at 35% 25%, color-mix(in srgb, #fff 32%, transparent), transparent 38%),
    linear-gradient(135deg, color-mix(in srgb, var(--aai-accent) 72%, var(--aai-panel)), color-mix(in srgb, var(--aai-accent-2) 68%, var(--aai-panel)));
  color: var(--aai-accent-contrast);
  font-size: 0;
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 28%, transparent), 0 8px 18px color-mix(in srgb, var(--aai-accent) 24%, transparent);
}

.aai-intake__status[data-aai-status-kind="draft"]::before {
  content: "";
  position: relative;
  z-index: 1;
  width: 0.52rem;
  height: 0.86rem;
  margin-top: -0.16rem;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(45deg);
}

.aai-intake__status[data-aai-status-kind="draft"]::after {
  content: "";
  position: absolute;
  inset: 0.42rem;
  border: 1px solid color-mix(in srgb, currentColor 42%, transparent);
  border-radius: 0.42rem;
  opacity: 0.72;
}

.aai-intake__status[data-aai-status-kind="loading"]::before {
  content: "";
  width: 0.76rem;
  height: 0.76rem;
  margin-right: 0.42rem;
  border: 2px solid color-mix(in srgb, currentColor 28%, transparent);
  border-top-color: currentColor;
  border-radius: 50%;
  animation: aai-spin 0.72s linear infinite;
}

.aai-chip-button,
.aai-mini-button { cursor: pointer; transition: transform 160ms ease, box-shadow 160ms ease, background 160ms ease, border-color 160ms ease; }
.aai-chip-button:hover,
.aai-mini-button:hover { transform: translateY(-1px); border-color: color-mix(in srgb, var(--aai-accent) 68%, var(--aai-border)); box-shadow: 0 8px 18px color-mix(in srgb, var(--aai-accent) 22%, transparent); }
.aai-chip-button:active,
.aai-mini-button:active { transform: translateY(0); }

.aai-intake.is-busy .aai-intake__status:not([data-aai-status-kind="loading"]):not([data-aai-status-kind="draft"])::before {
  content: "";
  display: inline-block;
  width: 0.5rem;
  height: 0.5rem;
  margin-right: 0.38rem;
  border-radius: 50%;
  background: currentColor;
  animation: aai-pulse 0.85s infinite alternate;
}

@keyframes aai-pulse { from { opacity: 0.28; transform: scale(0.72); } to { opacity: 1; transform: scale(1); } }
@keyframes aai-spin { to { transform: rotate(360deg); } }
@keyframes aai-rise { from { opacity: 0; transform: translateY(9px) scale(0.985); } to { opacity: 1; transform: translateY(0) scale(1); } }
@keyframes aai-highlight { 0% { box-shadow: 0 0 0 0 transparent; } 45% { box-shadow: 0 0 0 5px var(--aai-ring), 0 0 26px color-mix(in srgb, var(--aai-accent) 18%, transparent); } 100% { box-shadow: 0 0 0 0 transparent; } }
@keyframes aai-shimmer { to { transform: translateX(120%); } }
@keyframes aai-panel-in { from { opacity: 0; transform: translateX(14px) scale(0.992); filter: blur(2px); } to { opacity: 1; transform: translateX(0) scale(1); filter: blur(0); } }

.aai-stepper {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 0.45rem;
  margin: 0.85rem 0 0;
}

.aai-stepper button {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  min-height: 30px;
  border: 1px solid color-mix(in srgb, var(--aai-border) 82%, transparent);
  border-radius: 999px;
  background: linear-gradient(135deg, color-mix(in srgb, var(--aai-panel) 82%, transparent), color-mix(in srgb, var(--aai-panel-soft) 68%, transparent));
  color: var(--aai-muted);
  cursor: pointer;
  font: inherit;
  font-size: 1.3rem;
  font-weight: 850;
  overflow: hidden;
  transition: transform 160ms ease, border-color 160ms ease, box-shadow 160ms ease, background 160ms ease;
}
.aai-stepper button::before {
  content: "";
  position: absolute;
  inset: 1px;
  border-radius: inherit;
  background: linear-gradient(90deg, color-mix(in srgb, var(--aai-accent) 16%, transparent), color-mix(in srgb, var(--aai-accent-2) 12%, transparent));
  opacity: 0;
  transition: opacity 160ms ease;
  pointer-events: none;
}
.aai-stepper button:hover { transform: translateY(-1px); border-color: color-mix(in srgb, var(--aai-accent) 40%, var(--aai-border)); box-shadow: 0 10px 24px color-mix(in srgb, var(--aai-accent) 12%, transparent); }
.aai-stepper button:hover::before { opacity: 1; }
.aai-stepper button > * { position: relative; z-index: 1; }

.aai-stepper button span {
  display: grid;
  place-items: center;
  width: 2.35rem;
  height: 2.35rem;
  border-radius: 50%;
  background: var(--aai-panel-strong);
  color: var(--aai-muted);
  font-size: 1.4rem;
}

.aai-stepper button.is-active {
  border-color: color-mix(in srgb, var(--aai-accent) 54%, var(--aai-border));
  background: linear-gradient(135deg, color-mix(in srgb, var(--aai-accent) 12%, var(--aai-panel)), color-mix(in srgb, var(--aai-accent-2) 10%, var(--aai-panel)));
  color: var(--aai-text);
}

.aai-stepper button.is-active span { background: var(--aai-accent-bg); color: var(--aai-accent-contrast); box-shadow: 0 6px 14px color-mix(in srgb, var(--aai-accent) 28%, transparent); }

.aai-intake__progress {
  height: 7px;
  margin: 0.75rem 0 1rem;
  overflow: hidden;
  border-radius: 999px;
  background: color-mix(in srgb, var(--aai-border) 46%, transparent);
}

.aai-intake__progress span {
  display: block;
  width: 0;
  height: 100%;
  border-radius: inherit;
  background: var(--aai-accent-bg);
  box-shadow: 0 0 22px color-mix(in srgb, var(--aai-accent) 35%, transparent);
  transition: width 260ms cubic-bezier(.2,.8,.2,1);
}

.aai-workspace {
  display: grid;
  grid-template-columns: minmax(0, 1.38fr) minmax(340px, 0.82fr);
  gap: 1rem;
  align-items: stretch;
}

.aai-form-lane,
.aai-chat-card,
.aai-quote-dock {
  border-radius: calc(var(--aai-radius) - 8px);
}

.aai-form-lane {
  display: flex;
  flex-direction: column;
  padding: clamp(0.75rem, 1.6vw, 1rem);
  min-height: 640px;
}

.aai-slider {
  position: relative;
  flex: 1 1 auto;
  min-height: 445px;
  overflow: hidden;
  border-radius: calc(var(--aai-radius) - 12px);
}
.aai-panel {
  display: none;
  animation: aai-panel-in 260ms cubic-bezier(.2,.8,.2,1) both;
  will-change: transform, opacity;
}
.aai-panel.is-active { display: block; }

.aai-panel__head { margin: 0 0 0.85rem; }
.aai-panel__head p {
  margin: 0 0 0.15rem;
  color: var(--aai-accent);
  font-size: 0.84rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.aai-panel__head h3 { margin: 0; font-size: clamp(1.22rem, 1.95vw, 1.6rem); line-height: 1.15; }
.aai-inline-note { display: none; margin-top: 0.42rem; color: var(--aai-muted); font-size: 0.92rem; line-height: 1.4; }

.aai-field-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.72rem;
}
.aai-field-grid--contact { grid-template-columns: repeat(2, minmax(0, 1fr)); }

.aai-field,
.aai-field-grid label { display: block; }
.aai-field--wide { grid-column: 1 / -1; }

.aai-field span,
.aai-field-grid label span {
  display: block;
  margin: 0 0 0.34rem;
  color: var(--aai-muted);
  font-size: 1.2rem;
  font-weight: 900;
  letter-spacing: 0.07em;

}

.aai-intake input,
.aai-intake textarea,
.aai-intake select {
  width: 100%;
  border: 1px solid var(--aai-border);
  border-radius: var(--aai-radius-sm);
  background: color-mix(in srgb, var(--aai-panel) 90%, transparent);
  color: var(--aai-text);
  font: inherit;
  font-size: 1.05rem;
  line-height: 1.42;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.24);
  transition: border-color 160ms ease, box-shadow 160ms ease, background 160ms ease, transform 160ms ease;
}
.aai-intake input,
.aai-intake select { min-height: 46px; padding: 0.72rem 0.84rem; }
.aai-intake textarea { min-height: 92px; resize: vertical; padding: 0.78rem 0.85rem; }

.aai-intake input[type="checkbox"],
.aai-intake input[type="radio"] {
  accent-color: var(--aai-accent);
  display: none;
}

.aai-intake input[type="range"] {
  min-height: 1.25rem;
  padding: 0;
  border: 0;
  background: transparent;
  accent-color: var(--aai-accent);
  box-shadow: none;
}
.aai-intake input[type="range"]::-webkit-slider-runnable-track {
  height: 0.44rem;
  border-radius: 999px;
  background: linear-gradient(90deg, color-mix(in srgb, var(--aai-accent) 70%, var(--aai-panel)), color-mix(in srgb, var(--aai-accent-2) 62%, var(--aai-panel)));
}
.aai-intake input[type="range"]::-webkit-slider-thumb {
  width: 1.15rem;
  height: 1.15rem;
  margin-top: -0.36rem;
  border: 2px solid var(--aai-accent-contrast);
  border-radius: 50%;
  background: var(--aai-accent);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--aai-accent) 18%, transparent);
}

.aai-intake input:focus,
.aai-intake textarea:focus,
.aai-intake select:focus,
.aai-button:focus-visible,
.aai-chip-button:focus-visible,
.aai-mini-button:focus-visible,
.aai-stepper button:focus-visible,
.aai-type-card:focus-within,
.aai-feature-card:focus-within {
  outline: none;
  border-color: color-mix(in srgb, var(--aai-accent) 70%, var(--aai-border));
  box-shadow: 0 0 0 4px var(--aai-ring);
}

.aai-field-updated { animation: aai-highlight 1.15s ease; }

.aai-type-grid,
.aai-feature-grid {
  display: grid;
  align-items: stretch;
  grid-auto-rows: 1fr;
  gap: 0.65rem;
  margin-bottom: 0.85rem;
}

.aai-type-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.aai-feature-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }

.aai-type-card,
.aai-feature-card {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  gap: 0.34rem;
  min-height: 82px;
  padding: 0.74rem 0.68rem;
  border: 1px solid var(--aai-border);
  border-radius: var(--aai-radius-sm);
  background: color-mix(in srgb, var(--aai-panel) 86%, transparent);
  cursor: pointer;
  text-align: center;
  overflow: hidden;
  transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease, background 160ms ease;
}

.aai-type-card::before,
.aai-feature-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 20% 0%, color-mix(in srgb, var(--aai-accent) 12%, transparent), transparent 42%);
  opacity: 0;
  transition: opacity 160ms ease;
  pointer-events: none;
}

.aai-feature-card {
  min-height: 80px;
  border-color: color-mix(in srgb, var(--aai-accent) 42%, var(--aai-border));
  background:
    radial-gradient(circle at 0% 0%, color-mix(in srgb, var(--aai-accent) 14%, transparent), transparent 42%),
    linear-gradient(145deg, color-mix(in srgb, var(--aai-panel) 78%, var(--aai-accent) 8%), color-mix(in srgb, var(--aai-panel) 78%, var(--aai-accent-2) 7%));
}

.aai-type-card input,
.aai-feature-card input { position: absolute; inset: 0; opacity: 0; cursor: pointer; }

.aai-card-icon {
  position: relative;
  z-index: 1;
  display: grid;
  place-items: center;
  width: 3.15rem;
  height: 3.15rem;
  border-radius: 999px;
  background: linear-gradient(135deg, color-mix(in srgb, var(--aai-accent) 18%, var(--aai-panel)), color-mix(in srgb, var(--aai-accent-2) 10%, var(--aai-panel)));
  color: var(--aai-accent);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--aai-accent) 28%, transparent), 0 6px 16px color-mix(in srgb, var(--aai-accent) 10%, transparent);
  line-height: 1;
}

.aai-feature-card .aai-card-icon {
  background: linear-gradient(135deg, color-mix(in srgb, var(--aai-accent) 18%, var(--aai-panel)), color-mix(in srgb, var(--aai-accent-2) 14%, var(--aai-panel)));
  color: color-mix(in srgb, var(--aai-accent) 80%, var(--aai-text));
}

.aai-card-icon__svg {
  display: block;
  width: 1.28rem;
  height: 1.28rem;
  flex: 0 0 auto;
}

.aai-card-icon__svg * {
  vector-effect: non-scaling-stroke;
}

.aai-card-label {
  position: relative;
  z-index: 1;
  display: block;
  color: var(--aai-text);
  font-size: 1.2rem;
  font-weight: 900;
  line-height: 1.15;
}

.aai-type-card small,
.aai-feature-card small {
  position: relative;
  z-index: 1;
  display: block;
  max-width: 95%;
  color: var(--aai-muted);
  font-size: 0.82rem;
  font-weight: 700;
  line-height: 1.25;
}

.aai-type-card:hover,
.aai-feature-card:hover { transform: translateY(-1px); box-shadow: 0 12px 26px rgba(15, 35, 60, 0.1); }
.aai-type-card:hover::before,
.aai-feature-card:hover::before { opacity: 1; }

.aai-type-card.is-selected,
.aai-feature-card.is-selected {
  border-color: color-mix(in srgb, var(--aai-accent) 68%, var(--aai-border));
  background: linear-gradient(135deg, color-mix(in srgb, var(--aai-accent) 18%, var(--aai-panel)), color-mix(in srgb, var(--aai-accent-2) 15%, var(--aai-panel)));
  box-shadow: 0 14px 28px color-mix(in srgb, var(--aai-accent) 18%, transparent);
}

.aai-feature-card.is-selected {
  border-color: color-mix(in srgb, var(--aai-accent-2) 70%, var(--aai-accent));
  background:
    radial-gradient(circle at 16% 0%, color-mix(in srgb, var(--aai-accent) 28%, transparent), transparent 46%),
    linear-gradient(135deg, color-mix(in srgb, var(--aai-accent) 22%, var(--aai-panel)), color-mix(in srgb, var(--aai-accent-2) 22%, var(--aai-panel)));
}

.aai-type-card.is-selected .aai-card-icon,
.aai-feature-card.is-selected .aai-card-icon {
  background: var(--aai-accent-bg);
  color: var(--aai-accent-contrast);
  box-shadow: 0 8px 18px color-mix(in srgb, var(--aai-accent) 26%, transparent);
}

.aai-type-card.is-selected::after,
.aai-feature-card.is-selected::after {
  content: "✓";
  position: absolute;
  top: 0.42rem;
  right: 0.48rem;
  display: grid;
  place-items: center;
  width: 1.24rem;
  height: 1.24rem;
  border-radius: 50%;
  background: var(--aai-accent-bg);
  color: var(--aai-accent-contrast);
  font-size: 0.84rem;
  font-weight: 900;
}

.aai-type-card.aai-field-updated,
.aai-feature-card.aai-field-updated { animation: aai-highlight 1.15s ease; }

.aai-section-title {
  display: none;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1rem;
  margin: 0.95rem 0 0.65rem;
  padding: 0 0 0.55rem;
  border-bottom: 1px solid color-mix(in srgb, var(--aai-border) 62%, transparent);
}
.aai-section-title:first-of-type { margin-top: 0; }
.aai-section-title--spaced { margin-top: 1.05rem; }
.aai-section-title h4 {
  margin: 0;
  color: var(--aai-text);
  font-size: 1.02rem;
  line-height: 1.15;
}
.aai-section-title p {
  max-width: 520px;
  margin: 0;
  color: var(--aai-muted);
  font-size: 0.92rem;
  line-height: 1.35;
  text-align: right;
}

.aai-detail-help {
  margin: 0 0 0.8rem;
  padding: 0.75rem 0.85rem;
  border: 1px solid color-mix(in srgb, var(--aai-accent) 24%, var(--aai-border));
  border-radius: var(--aai-radius-sm);
  background: color-mix(in srgb, var(--aai-panel-soft) 82%, var(--aai-accent) 5%);
  color: var(--aai-muted);
  font-size: 0.94rem;
  line-height: 1.42;
}
.aai-detail-grid {
  display: grid;
  gap: 0.78rem;
}
.aai-detail-group {
  padding: 0.85rem;
  border: 1px solid color-mix(in srgb, var(--aai-border) 82%, transparent);
  border-radius: calc(var(--aai-radius) - 10px);
  background: color-mix(in srgb, var(--aai-panel) 88%, transparent);
  animation: aai-rise 210ms ease both;
}
.aai-detail-group[hidden] { display: none !important; }
.aai-detail-group__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.8rem;
  margin: 0 0 0.72rem;
}
.aai-detail-group__head strong {
  color: var(--aai-text);
  font-size: 1rem;
  line-height: 1.2;
}
.aai-detail-group__head span {
  color: var(--aai-muted);
  font-size: 0.86rem;
  line-height: 1.3;
  text-align: right;
}

.aai-feature-detail-group {
  padding: 0;
  overflow: hidden;
}

.aai-feature-detail-summary {
  display: grid;
  grid-template-columns: minmax(0, 1fr) max-content 1.45rem;
  align-items: center;
  gap: 0.7rem;
  padding: 0.78rem 0.85rem;
  cursor: pointer;
  list-style: none;
}

.aai-feature-detail-summary::-webkit-details-marker {
  display: none;
}

.aai-feature-detail-summary::after {
  content: "+";
  display: grid;
  place-items: center;
  width: 1.45rem;
  height: 1.45rem;
  border-radius: 999px;
  background: var(--aai-accent-bg);
  color: var(--aai-accent-contrast);
  font-weight: 900;
  line-height: 1;
}

.aai-feature-detail-group[open] > .aai-feature-detail-summary::after {
  content: "-";
}

.aai-feature-detail-summary__copy {
  display: grid;
  gap: 0.18rem;
  min-width: 0;
}

.aai-feature-detail-summary strong {
  overflow: hidden;
  color: color-mix(in srgb, var(--aai-accent) 74%, var(--aai-text));
  font-size: 1rem;
  font-weight: 950;
  line-height: 1.15;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.aai-feature-detail-summary em {
  overflow: hidden;
  color: var(--aai-muted);
  font-size: 0.82rem;
  font-style: normal;
  font-weight: 720;
  line-height: 1.25;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.aai-feature-detail-group.has-feature-detail-summary .aai-feature-detail-summary em {
  color: color-mix(in srgb, var(--aai-accent-2) 54%, var(--aai-text));
}

.aai-feature-detail-summary__count {
  justify-self: end;
  padding: 0.22rem 0.52rem;
  border: 1px solid color-mix(in srgb, var(--aai-accent) 28%, var(--aai-border));
  border-radius: 999px;
  background: linear-gradient(135deg, color-mix(in srgb, var(--aai-accent) 10%, var(--aai-panel)), color-mix(in srgb, var(--aai-accent-2) 8%, var(--aai-panel)));
  color: var(--aai-muted);
  font-size: 0.74rem;
  font-weight: 900;
  line-height: 1;
  white-space: nowrap;
}

.aai-feature-detail-group.has-feature-detail-progress .aai-feature-detail-summary__count {
  border-color: color-mix(in srgb, var(--aai-accent-2) 56%, var(--aai-accent));
  color: color-mix(in srgb, var(--aai-accent-2) 58%, var(--aai-text));
}

.aai-feature-detail-body {
  padding: 0 0.85rem 0.85rem;
}

.aai-choice-field {
  margin: 0;
  padding: 0;
  border: 0;
}

.aai-choice-field legend {
  display: block;
  margin: 0 0 0.42rem;
  color: var(--aai-text);
  font-weight: 850;
  line-height: 1.2;
}

.aai-choice-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(132px, 1fr));
  gap: 0.42rem;
}

.aai-choice {
  position: relative;
  display: flex;
  align-items: center;
  gap: 0.42rem;
  min-height: 42px;
  padding: 0.55rem 0.62rem;
  border: 1px solid color-mix(in srgb, var(--aai-border) 78%, transparent);
  border-radius: calc(var(--aai-radius-sm) - 3px);
  background: color-mix(in srgb, var(--aai-panel) 86%, transparent);
  color: var(--aai-muted);
  font-size: 0.86rem;
  font-weight: 760;
  line-height: 1.2;
  cursor: pointer;
}

.aai-choice input {
  flex: 0 0 auto;
  width: 1rem;
  min-height: 1rem;
  margin: 0;
}

.aai-choice span {
  min-width: 0;
}

.aai-choice:has(input:checked) {
  border-color: color-mix(in srgb, var(--aai-accent) 58%, var(--aai-border));
  background: linear-gradient(135deg, color-mix(in srgb, var(--aai-accent) 13%, var(--aai-panel)), color-mix(in srgb, var(--aai-accent-2) 10%, var(--aai-panel)));
  color: var(--aai-text);
  box-shadow: 0 8px 18px color-mix(in srgb, var(--aai-accent) 12%, transparent);
}

.aai-form-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  margin-top: 1rem;
  padding-top: 0.82rem;
  border-top: 1px solid var(--aai-border);
}
.aai-form-nav__right { display: flex; flex-wrap: wrap; gap: 0.55rem; justify-content: flex-end; }

.aai-button {
  appearance: none;
  border: 1px solid color-mix(in srgb, var(--aai-accent) 36%, var(--aai-border));
  border-radius: 999px;
  background: linear-gradient(135deg, color-mix(in srgb, var(--aai-accent) 14%, var(--aai-panel)), color-mix(in srgb, var(--aai-accent-2) 8%, var(--aai-panel)));
  color: var(--aai-text);
  cursor: pointer;
  font: inherit;
  font-size: 1.02rem;
  font-weight: 850;
  padding: 0.72rem 1rem;
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 16%, transparent);
  transition: transform 160ms ease, box-shadow 160ms ease, background 160ms ease, border-color 160ms ease, opacity 160ms ease;
}
.aai-button:hover:not(:disabled) { transform: translateY(-1px); border-color: color-mix(in srgb, var(--aai-accent) 68%, var(--aai-border)); box-shadow: 0 10px 24px color-mix(in srgb, var(--aai-accent) 20%, transparent); }
.aai-button:active:not(:disabled) { transform: translateY(0); }
.aai-button:disabled { opacity: 0.55; cursor: not-allowed; }
.aai-button--primary { background: var(--aai-accent-bg); border-color: color-mix(in srgb, var(--aai-accent) 74%, transparent); color: var(--aai-accent-contrast); box-shadow: 0 10px 26px color-mix(in srgb, var(--aai-accent) 24%, transparent); }
.aai-button--ghost { background: color-mix(in srgb, var(--aai-panel) 72%, transparent); border-color: color-mix(in srgb, var(--aai-accent) 22%, var(--aai-border)); color: var(--aai-muted); }

.aai-chat-lane {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
  position: sticky;
  top: 1rem;
  align-self: stretch;
  height: min(760px, calc(100vh - 2rem));
  min-height: 640px;
}
.aai-assistant-panel {
  flex: 1 1 0;
  min-height: 0;
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}
.aai-chat-card {
  overflow: hidden;
  flex: 1 1 auto;
  min-height: 0;
  display: flex;
  flex-direction: column;
}
.aai-chat-card__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.75rem;
  padding: 0.72rem 0.78rem;
  border-bottom: 1px solid var(--aai-border);
}
.aai-chat-card__head span,
.aai-chat-card__head strong { display: block; }
.aai-chat-card__head span { color: var(--aai-muted); font-size: 0.84rem; font-weight: 900; letter-spacing: 0.09em; text-transform: uppercase; }
.aai-chat-card__head strong { font-size: 1.05rem; }

.aai-intake__messages {
  flex: 1 1 auto;
  min-height: 0;
  max-height: none;
  overflow: auto;
  padding: 0.78rem;
  background: color-mix(in srgb, var(--aai-panel-soft) 75%, transparent);
  scroll-behavior: smooth;
}

.aai-message { display: flex; margin: 0 0 0.7rem; animation: aai-rise 180ms ease both; }
.aai-message:last-child { margin-bottom: 0; }
.aai-message.is-user { justify-content: flex-end; }
.aai-message__bubble {
  position: relative;
  max-width: min(86%, 720px);
  padding: 0.72rem 0.82rem;
  border: 1px solid var(--aai-border);
  border-radius: 17px;
  background: var(--aai-panel);
  box-shadow: 0 8px 22px rgba(15, 35, 60, 0.06);
  color: var(--aai-text);
  white-space: pre-wrap;
}
.aai-message.is-assistant .aai-message__bubble { border-top-left-radius: 6px; }
.aai-message.is-user .aai-message__bubble { border-top-right-radius: 6px; background: var(--aai-accent-bg); border-color: transparent; color: var(--aai-accent-contrast); }
.aai-message__bubble p { margin: 0; line-height: 1.48; }
.aai-message__bubble p + p { margin-top: 0.55rem; }
.aai-message.is-streaming .aai-message__bubble::after { content: ""; display: inline-block; width: 0.5rem; height: 1rem; margin-left: 0.12rem; border-right: 2px solid currentColor; animation: aai-pulse 0.65s infinite alternate; vertical-align: -0.15rem; }

.aai-chat-composer { padding: 0.68rem; border-top: 1px solid var(--aai-border); background: color-mix(in srgb, var(--aai-panel) 78%, transparent); }
.aai-chat-composer textarea { min-height: 68px; }
.aai-intake__buttons { display: flex; flex-wrap: wrap; justify-content: flex-end; gap: 0.55rem; margin-top: 0.62rem; }

.aai-empty-state,
.aai-muted-line {
  margin: 0;
  padding: 0.78rem;
  border: 1px dashed color-mix(in srgb, var(--aai-border) 75%, transparent);
  border-radius: var(--aai-radius-sm);
  color: var(--aai-muted);
  font-size: 0.94rem;
  line-height: 1.45;
  background: color-mix(in srgb, var(--aai-panel-soft) 72%, transparent);
}

.aai-upload__drop {
  display: grid;
  place-items: center;
  min-height: 145px;
  margin: 0 0 0.85rem;
  padding: 1rem;
  border: 1px dashed color-mix(in srgb, var(--aai-accent) 35%, var(--aai-border));
  border-radius: calc(var(--aai-radius) - 10px);
  background: color-mix(in srgb, var(--aai-panel) 82%, var(--aai-accent) 4%);
  cursor: pointer;
  text-align: center;
}
.aai-upload__drop input { display: none; }
.aai-upload__drop span { color: var(--aai-text); font-weight: 900; }
.aai-upload__drop small { display: block; max-width: 540px; margin-top: 0.35rem; color: var(--aai-muted); line-height: 1.45; }
.aai-upload-list { display: grid; gap: 0.5rem; margin-top: 0.75rem; }
.aai-upload-item { display: flex; justify-content: space-between; gap: 0.75rem; padding: 0.65rem 0.75rem; border: 1px solid var(--aai-border); border-radius: var(--aai-radius-sm); background: var(--aai-panel-soft); }
.aai-upload-item span { font-weight: 850; }
.aai-upload-item small { color: var(--aai-muted); }

.aai-ack-list { display: grid; gap: 0.5rem; }
.aai-ack {
  display: flex;
  align-items: flex-start;
  gap: 0.55rem;
  padding: 0.58rem 0.64rem;
  border: 1px solid var(--aai-border);
  border-radius: var(--aai-radius-sm);
  background: color-mix(in srgb, var(--aai-panel) 90%, transparent);
}
.aai-ack input { width: auto; min-height: auto; margin-top: 0.2rem; }
.aai-ack span { color: var(--aai-muted); font-size: 0.86rem; line-height: 1.28; }
.aai-ack strong { display: block; color: var(--aai-text); margin-bottom: 0.12rem; font-size: 0.9rem; line-height: 1.18; }
.aai-policy { margin-top: 0.75rem; border: 1px solid var(--aai-border); border-radius: var(--aai-radius-sm); background: var(--aai-panel-soft); overflow: hidden; }
.aai-policy summary { cursor: pointer; padding: 0.72rem 0.85rem; font-weight: 850; }
.aai-policy iframe { width: 100%; min-height: 280px; border: 0; background: #fff; }
.aai-policy p,
.aai-policy__placeholder { margin: 0; padding: 0.8rem; color: var(--aai-muted); }

.aai-quote-dock {
  position: relative;
  z-index: 4;
  flex: 1 1 0;
  min-height: 0;
  margin-top: 0;
  overflow: auto;
}
.aai-quote-dock.is-estimate-loading {
  border-color: color-mix(in srgb, var(--aai-accent) 46%, var(--aai-border));
  box-shadow: var(--aai-shadow-soft), 0 0 0 1px color-mix(in srgb, var(--aai-accent) 16%, transparent);
}
.aai-estimate-loading {
  position: absolute;
  top: 0.66rem;
  right: 0.72rem;
  z-index: 9;
  display: inline-flex;
  align-items: center;
  gap: 0.42rem;
  min-height: 2rem;
  padding: 0.42rem 0.62rem;
  border: 1px solid color-mix(in srgb, var(--aai-accent) 48%, var(--aai-border));
  border-radius: 999px;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--aai-accent) 18%, var(--aai-panel)), color-mix(in srgb, var(--aai-accent-2) 12%, var(--aai-panel))),
    var(--aai-panel);
  color: var(--aai-text);
  font-size: 0.78rem;
  font-weight: 900;
  line-height: 1;
  pointer-events: none;
  box-shadow: 0 10px 24px color-mix(in srgb, var(--aai-accent) 18%, transparent), inset 0 1px 0 color-mix(in srgb, #fff 20%, transparent);
}
.aai-estimate-loading__spinner {
  width: 0.84rem;
  height: 0.84rem;
  flex: 0 0 auto;
  border: 2px solid color-mix(in srgb, var(--aai-accent) 24%, transparent);
  border-top-color: var(--aai-accent);
  border-right-color: var(--aai-accent-2);
  border-radius: 50%;
  animation: aai-spin 0.72s linear infinite;
}
.aai-quote-dock__empty { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 0.85rem 1rem; }
.aai-quote-dock__empty span,
.aai-estimate-card summary span,
.aai-estimate-grid span {
  display: block;
  color: var(--aai-muted);
  font-size: 0.84rem;
  font-weight: 900;
  letter-spacing: 0.08em;
}
.aai-quote-dock__empty strong { font-size: 1.03rem; }

.aai-estimate-card { position: relative; }
.aai-estimate-card::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 -65%;
  width: 44%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.28), transparent);
  transform: translateX(-100%);
  animation: aai-shimmer 1.05s ease 1;
  pointer-events: none;
}
.aai-estimate-card summary {
  display: grid;
  grid-template-columns: minmax(120px, 1fr) auto auto;
  align-items: center;
  gap: 0.85rem;
  padding: 0.84rem 1rem;
  cursor: pointer;
  list-style: none;
}
.aai-estimate-card summary::-webkit-details-marker { display: none; }
.aai-estimate-card summary strong { font-size: clamp(1.05rem, 2.2vw, 1.55rem); line-height: 1.05; }
.aai-estimate-card summary em { color: var(--aai-muted); font-style: normal; font-weight: 850; }
.aai-estimate-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 0.65rem; padding: 0 1rem 0.8rem; }
.aai-estimate-grid > div,
.aai-estimate-section {
  padding: 0.75rem;
  border: 1px solid color-mix(in srgb, var(--aai-border) 80%, transparent);
  border-radius: var(--aai-radius-sm);
  background: var(--aai-panel-soft);
}
.aai-estimate-grid strong { display: block; margin-top: 0.2rem; font-size: 1.02rem; }
.aai-estimate-section { margin: 0 1rem 0.65rem; }
.aai-estimate-section h3 { margin: 0 0 0.55rem; font-size: 1.02rem; color: var(--aai-text); }
.aai-estimate-section ul { margin: 0; padding-left: 1.1rem; }
.aai-estimate-section li { margin: 0.38rem 0; line-height: 1.42; }
.aai-estimate-section li span,
.aai-estimate-section li em { display: inline-block; margin-left: 0.28rem; padding: 0.1rem 0.4rem; border-radius: 999px; background: color-mix(in srgb, var(--aai-accent) 10%, var(--aai-panel)); color: var(--aai-muted); font-size: 0.8rem; font-style: normal; font-weight: 750; }
.aai-estimate-section li p { margin: 0.16rem 0 0; color: var(--aai-muted); }
.aai-estimate-note { margin: 0 1rem 1rem; color: var(--aai-muted); font-size: 1.02rem; line-height: 1.48; }

.aai-hp,
.aai-hidden-contact { position: absolute !important; left: -9999px !important; width: 1px !important; height: 1px !important; overflow: hidden !important; }
.aai-intake .screen-reader-text { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0; }

@supports not (color: color-mix(in srgb, #000, #fff)) {
  .aai-intake__shell,
  .aai-hero,
  .aai-chat-card,
  .aai-form-lane,
  .aai-quote-dock { background: #fff; }
  .aai-button--primary,
  .aai-stepper button.is-active span,
  .aai-type-card.is-selected::after,
  .aai-feature-card.is-selected::after,
  .aai-intake__progress span { background: var(--aai-accent); }
}

@media (max-width: 980px) {
  .aai-workspace { grid-template-columns: 1fr; }
  .aai-chat-lane { position: static; height: auto; min-height: 0; }
  .aai-assistant-panel,
  .aai-quote-dock { flex: none; min-height: 0; }
  .aai-intake__messages { min-height: 220px; max-height: 320px; }
}

@media (max-width: 760px) {
  .aai-hero { flex-direction: column; }
  .aai-hero__actions {
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: center;
    width: 100%;
    min-width: 0;
  }
  .aai-hero__actions .aai-intake__status:not([data-aai-status-kind="draft"]) {
    flex: 0 1 auto;
    max-width: 42%;
    overflow: hidden;
    text-overflow: ellipsis;
  }
  .aai-hero__actions .aai-chip-button {
    flex: 1 1 0;
    width: auto;
    min-width: 0;
    padding-inline: 0.52rem;
    font-size: 0.88rem;
    line-height: 1.05;
    white-space: nowrap;
  }
  .aai-stepper { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .aai-field-grid,
  .aai-field-grid--contact,
  .aai-type-grid,
  .aai-feature-grid,
  .aai-estimate-grid { grid-template-columns: 1fr; }
  .aai-section-title,
  .aai-detail-group__head { align-items: flex-start; flex-direction: column; }
  .aai-section-title p,
  .aai-detail-group__head span { text-align: left; }
  .aai-estimate-card summary { grid-template-columns: 1fr; align-items: start; }
}

@media (max-width: 520px) {
  .aai-intake { margin: 0.75rem auto; }
  .aai-intake__shell { border-radius: 18px; padding: 0.7rem; }
  .aai-stepper button { justify-content: flex-start; padding-left: 0.55rem; }
  .aai-form-nav,
  .aai-form-nav__right,
  .aai-intake__buttons { align-items: stretch; flex-direction: column; }
  .aai-button { width: 100%; }
  .aai-hero__actions .aai-chip-button { width: auto; }
  .aai-message__bubble { max-width: 94%; }
}

@media (prefers-reduced-motion: reduce) {
  .aai-intake *,
  .aai-intake *::before,
  .aai-intake *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: 0.001ms !important;
  }
}


/* v0.2.7 theme-token accent fixes. The site exposes --btn-bg as a gradient and --ctl-c1/--ctl-c2 as solid colors, so the UI uses the gradient only where a background image is valid. */
.aai-intake :where(.aai-button:not(.aai-button--ghost), .aai-chip-button, .aai-mini-button) {
  border-color: color-mix(in srgb, var(--aai-accent) 42%, transparent);
  background: var(--aai-accent-bg);
  color: var(--aai-accent-contrast);
  box-shadow: var(--btn-shadow, 0 10px 24px color-mix(in srgb, var(--aai-accent) 22%, transparent)), inset 0 1px 0 color-mix(in srgb, #fff 18%, transparent);
}

.aai-intake :where(.aai-button:not(.aai-button--ghost), .aai-chip-button, .aai-mini-button):hover:not(:disabled) {
  border-color: color-mix(in srgb, var(--aai-accent-2) 62%, transparent);
  box-shadow: 0 12px 30px color-mix(in srgb, var(--aai-accent) 30%, transparent), 0 0 0 1px color-mix(in srgb, var(--aai-accent-2) 32%, transparent), inset 0 1px 0 color-mix(in srgb, #fff 24%, transparent);
}

.aai-intake .aai-button--ghost {
  background: color-mix(in srgb, var(--aai-panel) 76%, transparent);
  color: var(--aai-muted);
  border-color: color-mix(in srgb, var(--aai-accent) 24%, var(--aai-border));
}

.aai-intake .aai-button--ghost:hover:not(:disabled) {
  color: var(--aai-text);
  border-color: color-mix(in srgb, var(--aai-accent) 58%, var(--aai-border));
  background: linear-gradient(135deg, color-mix(in srgb, var(--aai-accent) 11%, var(--aai-panel)), color-mix(in srgb, var(--aai-accent-2) 8%, var(--aai-panel)));
}

.aai-stepper button.is-active,
.aai-stepper button.is-active::before {
  background: var(--aai-accent-bg);
}

.aai-stepper button.is-active {
  border-color: color-mix(in srgb, var(--aai-accent-2) 62%, transparent);
  color: var(--aai-accent-contrast);
  box-shadow: 0 12px 26px color-mix(in srgb, var(--aai-accent) 22%, transparent);
}

.aai-stepper button.is-active span {
  background: color-mix(in srgb, var(--aai-accent-contrast) 16%, transparent);
  color: var(--aai-accent-contrast);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--aai-accent-contrast) 34%, transparent);
}

.aai-card-icon {
  background: var(--aai-accent-bg);
  color: var(--aai-accent-contrast);
  border: 1px solid color-mix(in srgb, var(--aai-accent-contrast) 18%, transparent);
  box-shadow: 0 8px 20px color-mix(in srgb, var(--aai-accent) 24%, transparent), inset 0 1px 0 color-mix(in srgb, #fff 18%, transparent);
}

.aai-card-icon__svg,
.aai-card-icon__svg * {
  color: currentColor;
  stroke: currentColor;
}

.aai-type-card,
.aai-feature-card {
  border-color: color-mix(in srgb, var(--aai-accent) 28%, var(--aai-border));
  background:
    radial-gradient(circle at 18% 0%, color-mix(in srgb, var(--aai-accent-2) 10%, transparent), transparent 42%),
    linear-gradient(145deg, color-mix(in srgb, var(--aai-panel) 92%, var(--aai-accent) 5%), color-mix(in srgb, var(--aai-panel) 90%, var(--aai-accent-2) 5%));
}

.aai-type-card:hover,
.aai-feature-card:hover {
  border-color: color-mix(in srgb, var(--aai-accent-2) 62%, var(--aai-accent));
  box-shadow: 0 14px 30px color-mix(in srgb, var(--aai-accent) 18%, transparent);
}

.aai-type-card.is-selected,
.aai-feature-card.is-selected {
  border-color: color-mix(in srgb, var(--aai-accent-2) 72%, var(--aai-accent));
  background:
    radial-gradient(circle at 18% 0%, color-mix(in srgb, var(--aai-accent-2) 22%, transparent), transparent 46%),
    linear-gradient(135deg, color-mix(in srgb, var(--aai-accent) 18%, var(--aai-panel)), color-mix(in srgb, var(--aai-accent-2) 18%, var(--aai-panel)));
  box-shadow: 0 16px 34px color-mix(in srgb, var(--aai-accent) 24%, transparent);
}

.aai-type-card.is-selected .aai-card-icon,
.aai-feature-card.is-selected .aai-card-icon,
.aai-type-card.is-selected::after,
.aai-feature-card.is-selected::after,
.aai-intake__progress span,
.aai-quote-gate__meter span,
.aai-phase-accordion summary::after,
.aai-ai-revision summary::after,
.aai-estimate-mini-section summary::after {
  background: var(--aai-accent-bg);
  color: var(--aai-accent-contrast);
}

.aai-card-label {
  color: var(--aai-text);
}

.aai-type-card small,
.aai-feature-card small {
  color: color-mix(in srgb, var(--aai-muted) 86%, var(--aai-accent-2));
}

.aai-type-card:hover small,
.aai-type-card.is-selected small,
.aai-feature-card:hover small,
.aai-feature-card.is-selected small {
  color: var(--aai-text);
}

.aai-estimate-head {
  border-bottom-color: color-mix(in srgb, var(--aai-accent) 30%, var(--aai-border));
}

.aai-quote-gate { position: relative; }
.aai-quote-gate summary {
  display: grid;
  grid-template-columns: minmax(120px, 1fr) auto auto;
  align-items: center;
  gap: 0.85rem;
  padding: 0.84rem 1rem;
  cursor: pointer;
  list-style: none;
}
.aai-quote-gate summary::-webkit-details-marker { display: none; }
.aai-quote-gate summary span,
.aai-quote-gate summary em {
  color: var(--aai-muted);
  font-size: 0.84rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-style: normal;
}
.aai-quote-gate summary strong { font-size: clamp(1.02rem, 2vw, 1.42rem); line-height: 1.05; }
.aai-quote-gate__body { padding: 0 1rem 1rem; }
.aai-quote-gate__body p { margin: 0 0 0.7rem; color: var(--aai-muted); line-height: 1.45; }
.aai-quote-gate__body ul {
  margin: 0.7rem 0;
  padding: 0.75rem 0.75rem 0.75rem 1.55rem;
  border: 1px dashed color-mix(in srgb, var(--aai-accent) 28%, var(--aai-border));
  border-radius: var(--aai-radius-sm);
  background: color-mix(in srgb, var(--aai-panel-soft) 82%, var(--aai-accent) 3%);
  color: var(--aai-text);
}
.aai-quote-gate__body li { margin: 0.28rem 0; line-height: 1.36; }
.aai-quote-gate__body small { display: block; color: var(--aai-muted); line-height: 1.42; }
.aai-quote-gate__meter {
  height: 7px;
  overflow: hidden;
  border-radius: 999px;
  background: color-mix(in srgb, var(--aai-border) 55%, transparent);
}
.aai-quote-gate__meter span {
  display: block;
  height: 100%;
  min-width: 0;
  border-radius: inherit;
  background: var(--aai-accent-bg);
  transition: width 220ms ease;
}

@media (max-width: 640px) {
  .aai-quote-gate summary { grid-template-columns: 1fr; align-items: start; }
}

/* v0.2.5 compact right-column estimator and phased accordions */
.aai-review-fields { margin-bottom: 0.8rem; }

.aai-estimate-card--compact {
  display: flex;
  flex-direction: column;
  min-height: 100%;
}

.aai-estimate-card--starting {
  min-height: 0;
}

.aai-estimate-card--starting .aai-estimate-head {
  background: linear-gradient(135deg, color-mix(in srgb, var(--aai-accent) 14%, var(--aai-panel)), color-mix(in srgb, var(--aai-accent-2) 10%, var(--aai-panel)));
}

.aai-estimate-card--starting .aai-estimate-note {
  font-weight: 750;
}

.aai-estimate-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.7rem;
  padding: 0.78rem 0.82rem;
  border-bottom: 1px solid var(--aai-border);
  background: linear-gradient(135deg, color-mix(in srgb, var(--aai-accent) 10%, transparent), color-mix(in srgb, var(--aai-accent-2) 7%, transparent));
}

.aai-estimate-head span,
.aai-phase-list > h3,
.aai-ai-revision summary span,
.aai-estimate-grid--compact span {
  display: block;
  color: var(--aai-muted);
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.aai-estimate-head strong {
  display: block;
  margin-top: 0.12rem;
  font-size: clamp(1.1rem, 1.6vw, 1.35rem);
  line-height: 1.05;
}

.aai-estimate-head em {
  display: block;
  margin-top: 0.18rem;
  color: var(--aai-muted);
  font-size: 0.88rem;
  font-style: normal;
  font-weight: 850;
}

.aai-estimate-head .aai-mini-button {
  flex: 0 0 auto;
  min-height: 30px;
  padding: 0.42rem 0.62rem;
  font-size: 1.0rem;
}

.aai-estimate-grid--compact {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.45rem;
  padding: 0.65rem 0.72rem;
}

.aai-estimate-grid--compact > div {
  padding: 0.55rem 0.58rem;
}

.aai-estimate-grid--compact strong {
  font-size: 0.92rem;
  line-height: 1.15;
}

.aai-phase-list {
  padding: 0 0.72rem 0.6rem;
}

.aai-phase-list > h3 {
  margin: 0 0 0.48rem;
  color: var(--aai-text);
  font-size: 0.88rem;
}

.aai-phase-accordion,
.aai-ai-revision,
.aai-estimate-mini-section {
  border: 1px solid color-mix(in srgb, var(--aai-border) 86%, transparent);
  border-radius: var(--aai-radius-sm);
  background: color-mix(in srgb, var(--aai-panel-soft) 84%, transparent);
  overflow: hidden;
}

.aai-phase-accordion + .aai-phase-accordion,
.aai-ai-revision,
.aai-estimate-mini-section { margin-top: 0.5rem; }

.aai-phase-accordion summary,
.aai-ai-revision summary,
.aai-estimate-mini-section summary {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.35rem 0.55rem;
  align-items: center;
  padding: 0.62rem 0.68rem;
  cursor: pointer;
  list-style: none;
}

.aai-phase-accordion summary::-webkit-details-marker,
.aai-ai-revision summary::-webkit-details-marker,
.aai-estimate-mini-section summary::-webkit-details-marker { display: none; }

.aai-phase-accordion summary::after,
.aai-ai-revision summary::after,
.aai-estimate-mini-section summary::after {
  content: "+";
  display: grid;
  place-items: center;
  width: 1.35rem;
  height: 1.35rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--aai-accent) 12%, var(--aai-panel));
  color: var(--aai-accent);
  font-weight: 900;
}

.aai-phase-accordion[open] summary::after,
.aai-ai-revision[open] summary::after,
.aai-estimate-mini-section[open] summary::after { content: "–"; }

.aai-phase-accordion summary span,
.aai-phase-accordion summary strong,
.aai-phase-accordion summary em {
  min-width: 0;
}

.aai-phase-accordion summary span {
  color: var(--aai-text);
  font-size: 0.92rem;
  font-weight: 900;
  line-height: 1.15;
}

.aai-phase-accordion summary strong {
  grid-column: 1;
  color: var(--aai-text);
  font-size: 0.88rem;
  line-height: 1.15;
}

.aai-phase-accordion summary em {
  grid-column: 1;
  color: var(--aai-muted);
  font-size: 0.8rem;
  font-style: normal;
  font-weight: 600;
}

.aai-phase-body {
  padding: 0 0.68rem 0.68rem;
}

.aai-phase-body > p,
.aai-ai-revision > p,
.aai-ai-revision div,
.aai-estimate-mini-section > ul,
.aai-estimate-mini-section > p {
  margin: 0;
  color: var(--aai-muted);
  font-size: 0.88rem;
  line-height: 1.38;
}

.aai-phase-body ul,
.aai-ai-revision ul,
.aai-estimate-mini-section ul {
  display: grid;
  gap: 0.38rem;
  margin: 0.52rem 0 0;
  padding: 0;
  list-style: none;
}

.aai-phase-body li,
.aai-ai-revision li,
.aai-estimate-mini-section li {
  margin: 0;
  padding: 0.48rem 0.52rem;
  border: 1px solid color-mix(in srgb, var(--aai-border) 72%, transparent);
  border-radius: calc(var(--aai-radius-sm) - 4px);
  background: color-mix(in srgb, var(--aai-panel) 84%, transparent);
  line-height: 1.35;
}

.aai-phase-body li div {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.5rem;
}

.aai-phase-body li strong { font-size: 0.88rem; }
.aai-phase-body li em {
  flex: 0 0 auto;
  color: var(--aai-accent);
  font-size: 0.78rem;
  font-style: normal;
  font-weight: 900;
}
.aai-phase-body li p {
  margin: 0.18rem 0 0;
  color: var(--aai-muted);
  font-size: 0.82rem;
}

.aai-ai-phase-note {
  margin: 0.55rem 0;
  padding: 0.55rem 0.62rem;
  border: 1px solid color-mix(in srgb, var(--aai-accent) 26%, var(--aai-border));
  border-radius: calc(var(--aai-radius-sm) - 3px);
  background: color-mix(in srgb, var(--aai-panel) 78%, var(--aai-accent) 7%);
  color: var(--aai-text);
  font-size: 0.84rem;
  line-height: 1.35;
}
.aai-ai-phase-note span {
  display: block;
  margin-bottom: 0.2rem;
  color: var(--aai-accent);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.aai-ai-revision,
.aai-estimate-mini-section {
  margin-left: 0.72rem;
  margin-right: 0.72rem;
}

.aai-ai-revision summary strong {
  color: var(--aai-text);
  font-size: 0.9rem;
}

.aai-ai-revision > p,
.aai-ai-revision div,
.aai-estimate-mini-section > ul,
.aai-estimate-mini-section > p {
  padding: 0 0.68rem 0.68rem;
}

.aai-ai-revision h4 {
  margin: 0.55rem 0 0.32rem;
  color: var(--aai-text);
  font-size: 0.88rem;
}

.aai-estimate-note {
  margin: 0.6rem 0.72rem 0.72rem;
  font-size: 0.84rem;
  line-height: 1.38;
}

.aai-estimate-actions {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.45rem;
  padding: 0.72rem;
  border-top: 1px solid var(--aai-border);
  background: color-mix(in srgb, var(--aai-panel) 78%, transparent);
}

.aai-estimate-actions .aai-button {
  width: 100%;
  padding: 0.62rem 0.78rem;
  font-size: 0.88rem;
}

.aai-quote-gate summary {
  grid-template-columns: 1fr;
  gap: 0.28rem;
}
.aai-quote-gate__body { padding: 0 0.82rem 0.82rem; }
.aai-quote-gate__body p,
.aai-quote-gate__body li,
.aai-quote-gate__body small { font-size: 0.88rem; }

@media (max-width: 980px) {
  .aai-estimate-card--compact { min-height: 0; }
}

/* v0.2.9 expanded service matrix, recurring estimator, compact AI sidebar */
.aai-type-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.52rem;
}
.aai-type-card {
  min-height: 54px;
  padding: 0.68rem 0.58rem;
  gap: 0.35rem;
}
.aai-type-card .aai-card-icon {
  width: 2.92rem;
  height: 2.92rem;
}
.aai-type-card .aai-card-label {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 2.35em;
  font-size: 1.02rem;
  line-height: 1.16;
}
.aai-type-card small {
  font-size: 0.76rem;
  line-height: 1.22;
}
.aai-card-icon__svg {
  width: 2.05rem;
  height: 2.05rem;
}
.aai-message__bubble {
  max-width: min(92%, 680px);
  padding: 0.58rem 0.68rem;
  font-size: 0.94rem;
  line-height: 1.38;
}
.aai-message__bubble p { line-height: 1.38; }
.aai-intake__messages { padding: 0.62rem; }
.aai-chat-composer { padding: 0.58rem; }
.aai-chat-composer textarea {
  min-height: 56px;
  font-size: 0.92rem;
}
.aai-chat-card__head { padding: 0.58rem 0.68rem; }
.aai-chat-card__head strong { font-size: 0.96rem; }
.aai-chat-card__head span { font-size: 0.74rem; }
.aai-recurring-estimate {
  margin: 0.52rem 0.68rem 0;
  border: 1px solid color-mix(in srgb, var(--aai-accent) 28%, var(--aai-border));
  border-radius: var(--aai-radius-sm);
  background: linear-gradient(135deg, color-mix(in srgb, var(--aai-accent) 10%, var(--aai-panel)), color-mix(in srgb, var(--aai-accent-2) 8%, var(--aai-panel)));
  overflow: hidden;
}
.aai-recurring-estimate summary {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.2rem 0.55rem;
  align-items: center;
  padding: 0.5rem 0.58rem;
  cursor: pointer;
  list-style: none;
}
.aai-recurring-estimate summary::-webkit-details-marker { display: none; }
.aai-recurring-estimate summary span,
.aai-recurring-estimate summary em {
  color: var(--aai-muted);
  font-size: 1.1rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-style: normal;
}
.aai-recurring-estimate summary strong {
  grid-column: 1;
  color: var(--aai-text);
  font-size: 1.2rem;
  line-height: 1.1;
}
.aai-recurring-estimate p {
  margin: 0;
  padding: 0 0.58rem 0.58rem;
  color: var(--aai-muted);
  font-size: 0.82rem;
  line-height: 1.32;
}
.aai-estimate-grid--compact {
  gap: 0.36rem;
  padding: 0.52rem 0.68rem;
}
.aai-estimate-grid--compact > div { padding: 0.42rem 0.5rem; }
.aai-estimate-grid--compact span { font-size: 1.0rem; }
.aai-estimate-grid--compact strong { font-size: 1.2rem; }
.aai-estimate-head {
  padding: 0.62rem 0.68rem;
}
.aai-estimate-head span { font-size: 0.7rem; }
.aai-estimate-head strong { font-size: clamp(1.5rem, 1.35vw, 1.8rem); }
.aai-estimate-head em { font-size: 0.76rem; }
.aai-phase-list { padding: 0 0.68rem 0.48rem; }
.aai-phase-list > h3 { margin-bottom: 0.34rem; font-size: 1.2rem; }
.aai-phase-accordion + .aai-phase-accordion,
.aai-ai-revision,
.aai-estimate-mini-section { margin-top: 0.34rem; }
.aai-phase-accordion summary,
.aai-ai-revision summary,
.aai-estimate-mini-section summary { padding: 0.48rem 0.54rem; }
.aai-phase-accordion summary span { font-size: 1.2rem; }
.aai-phase-accordion summary strong { font-size: 1rem; }
.aai-phase-accordion summary em { font-size: 1rem; }
.aai-phase-body { padding: 0 0.54rem 0.54rem; }
.aai-phase-body > p { display: none; }
.aai-phase-body li { padding: 0.38rem 0.42rem; }
.aai-phase-body li strong { font-size: 1.1rem; }
.aai-phase-body li p { font-size: 0.74rem; }
.aai-phase-body li em { font-size: 1rem; }
.aai-estimate-mini-section summary { font-size: 1.1rem; }
.aai-estimate-note { margin: 0.45rem 0.68rem 0.58rem; font-size: 0.76rem; }
.aai-estimate-actions {
  position: sticky;
  bottom: 0;
  z-index: 5;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.5rem;
  padding: 0.68rem;
  border-top: 1px solid color-mix(in srgb, var(--aai-accent) 28%, var(--aai-border));
  background: color-mix(in srgb, var(--aai-panel) 94%, transparent);
  box-shadow: 0 -12px 28px rgba(15, 35, 60, 0.12);
}
.aai-estimate-actions .aai-button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 48px;
  padding: 0.52rem 0.38rem;
  font-size: 12px;
  line-height: 1.12;
  text-align: center;
  white-space: normal;
}

@media (max-width: 980px) {
  .aai-type-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 640px) {
  .aai-type-grid,
  .aai-feature-grid { grid-template-columns: 1fr; }
}

/* v0.3.0 mobile estimator drawer, sticky navigation, and desktop sidebar fill */
@media (min-width: 981px) {
  .aai-chat-lane {
    height: auto;
    max-height: none;
    min-height: 100%;
    align-self: stretch;
  }

  .aai-assistant-panel {
    flex: 0 0 auto;
    display:none;
    min-height: 0;
  }

  .aai-chat-card {
    flex: 0 0 auto;
    max-height: 292px;
  }

  .aai-intake__messages {
    min-height: 96px;
    max-height: 146px;
  }

  .aai-quote-dock {
    flex: 1 1 auto;
    min-height: 0;
  }

  .aai-quote-dock > .aai-estimate-card {
    min-height: 100%;
  }
}

.aai-form-nav {
  position: sticky;
  bottom: 0;
  z-index: 7;
  background: linear-gradient(180deg, transparent, color-mix(in srgb, var(--aai-panel) 94%, transparent) 28%);
  backdrop-filter: blur(12px);
}

.aai-estimator-toggle {
  display: none;
}

@media (max-width: 760px) {
  .aai-intake {
    --aai-mobile-estimator-collapsed: 84px;
    --aai-mobile-nav-height: 56px;
    padding-bottom: calc(var(--aai-mobile-estimator-collapsed) + var(--aai-mobile-nav-height) + 1.15rem + env(safe-area-inset-bottom));
  }

  .aai-stepper {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.38rem;
  }

  .aai-stepper button {
    justify-content: center;
    min-height: 44px;
    padding: 0.42rem 0.25rem;
    gap: 0.24rem;
    font-size: 12px;
    line-height: 1.05;
    text-align: center;
  }

  .aai-stepper button span {
    width: 1.75rem;
    height: 1.75rem;
    font-size: 12px;
  }

  .aai-type-grid,
  .aai-feature-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.42rem;
  }

  .aai-type-card,
  .aai-feature-card {
    min-height: 38px;
    padding: 0.52rem 0.34rem;
    gap: 0.25rem;
  }

  .aai-type-card .aai-card-icon,
  .aai-feature-card .aai-card-icon {
    width: 3.28rem;
    height: 3.28rem;
  }

  .aai-card-icon__svg {
    width: 2.48rem;
    height: 2.48rem;
  }

  .aai-type-card .aai-card-label,
  .aai-feature-card .aai-card-label {
    min-height: 1.25em;
    font-size: 1.1rem;
    line-height: 1.12;
  }

  .aai-type-card small,
  .aai-feature-card small {
    font-size: 0.85rem;
    line-height: 1.14;
  }

  .aai-form-lane {
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }

  .aai-form-nav {
    position: fixed;
    left: 0.65rem;
    right: 0.65rem;
    bottom: env(safe-area-inset-bottom);
    z-index: 998;
    display: grid;
    grid-template-columns: minmax(76px, 0.72fr) minmax(0, 1.45fr);
    gap: 0.42rem;
    align-items: stretch;
    margin: 0;
    padding: 0.5rem;
    border: 1px solid color-mix(in srgb, var(--aai-accent) 26%, var(--aai-border));
    border-radius: 16px;
    background: color-mix(in srgb, var(--aai-panel) 96%, transparent);
    box-shadow: 0 -14px 34px rgba(15, 35, 60, 0.16);
  }

  .aai-form-nav__right {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.42rem;
    justify-content: stretch;
  }

  .aai-form-nav .aai-button {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    width: 100%;
    padding: 0.54rem 0.4rem;
    font-size: 12px;
    line-height: 1.1;
    text-align: center;
    white-space: normal;
  }

  .aai-chat-lane {
    display: contents;
  }

  .aai-assistant-panel {
    margin-top: 0.8rem;
  }

  .aai-quote-dock {
    position: fixed;
    left: 0.65rem;
    right: 0.65rem;
    bottom: calc(var(--aai-mobile-nav-height) + env(safe-area-inset-bottom));
    z-index: 997;
    max-height: var(--aai-mobile-estimator-collapsed);
    min-height: 0;
    overflow: hidden;
    border-radius: 18px 18px 0 0;
    background: color-mix(in srgb, var(--aai-panel) 98%, transparent);
    box-shadow: 0 -18px 42px rgba(15, 35, 60, 0.2);
    transition: max-height 180ms ease;
  }

  .aai-estimate-loading {
    top: 0.5rem;
    right: 0.5rem;
    justify-content: center;
    width: 2rem;
    min-height: 2rem;
    padding: 0;
  }

  .aai-estimate-loading strong {
    display: none;
  }

  .aai-quote-dock.is-estimate-loading .aai-estimator-toggle {
    margin-right: 2.12rem;
  }

  .aai-quote-dock.is-estimator-expanded {
    max-height: min(72vh, 620px);
    overflow: auto;
    padding-bottom: 0.5rem;
  }

  .aai-quote-dock .aai-estimate-head,
  .aai-quote-dock .aai-quote-gate summary {
    position: sticky;
    top: 0;
    z-index: 2;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 0.55rem;
    min-height: var(--aai-mobile-estimator-collapsed);
    background: color-mix(in srgb, var(--aai-panel) 98%, transparent);
  }

  .aai-quote-dock .aai-quote-gate summary span,
  .aai-quote-dock .aai-quote-gate summary strong,
  .aai-quote-dock .aai-quote-gate summary em {
    grid-column: 1;
  }

  .aai-estimator-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    padding: 0.42rem 0.58rem;
    border: 1px solid color-mix(in srgb, var(--aai-accent) 34%, var(--aai-border));
    border-radius: 999px;
    background: var(--aai-accent-bg);
    color: var(--aai-accent-contrast);
    font: inherit;
    font-size: 12px;
    font-weight: 900;
    line-height: 1;
    text-align: center;
    cursor: pointer;
  }

  .aai-quote-dock:not(.is-estimator-expanded) .aai-recurring-estimate,
  .aai-quote-dock:not(.is-estimator-expanded) .aai-estimate-grid,
  .aai-quote-dock:not(.is-estimator-expanded) .aai-phase-list,
  .aai-quote-dock:not(.is-estimator-expanded) .aai-ai-revision,
  .aai-quote-dock:not(.is-estimator-expanded) .aai-estimate-mini-section,
  .aai-quote-dock:not(.is-estimator-expanded) .aai-estimate-note,
  .aai-quote-dock:not(.is-estimator-expanded) .aai-estimate-actions,
  .aai-quote-dock:not(.is-estimator-expanded) .aai-quote-gate__body {
    display: none;
  }
}

/* v0.3.1 popup assistant, sticky estimator, and estimate row refinements */
.aai-chat-card__tools {
  display: flex;
  flex-wrap: wrap;
  gap: 0.38rem;
  justify-content: flex-end;
}

.aai-chat-fab {
  position: fixed;
  right: calc(1rem + env(safe-area-inset-right));
  bottom: calc(1rem + env(safe-area-inset-bottom));
  z-index: 1000;
  display: inline-grid;
  grid-template-columns: auto auto;
  align-items: center;
  gap: 0.45rem;
  min-height: 3.15rem;
  padding: 0.45rem 0.82rem 0.45rem 0.5rem;
  border: 1px solid color-mix(in srgb, var(--aai-accent) 58%, var(--aai-border));
  border-radius: 999px;
  background: var(--aai-accent-bg);
  color: var(--aai-accent-contrast);
  box-shadow: 0 16px 34px color-mix(in srgb, var(--aai-accent) 28%, transparent);
  cursor: pointer;
  font: inherit;
  font-size: 0.88rem;
  font-weight: 900;
  line-height: 1;
  transition: transform 160ms ease, box-shadow 160ms ease;
}

.aai-chat-fab:hover {
  transform: translateY(-1px);
  box-shadow: 0 20px 42px color-mix(in srgb, var(--aai-accent) 34%, transparent);
}

.aai-chat-fab__icon {
  display: grid;
  place-items: center;
  width: 2.22rem;
  height: 2.22rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--aai-accent-contrast) 16%, transparent);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--aai-accent-contrast) 28%, transparent);
}

.aai-chat-fab__icon .aai-card-icon__svg {
  width: 1.2rem;
  height: 1.2rem;
}

.aai-assistant-panel {
  position: fixed;
  right: calc(1rem + env(safe-area-inset-right));
  bottom: calc(5rem + env(safe-area-inset-bottom));
  z-index: 1001;
  display: flex !important;
  width: min(420px, calc(100vw - 1.3rem));
  max-height: min(680px, calc(100dvh - 6.5rem));
  margin: 0 !important;
  opacity: 0;
  pointer-events: none;
  transform: translateY(12px) scale(0.985);
  visibility: hidden;
  transition: opacity 170ms ease, transform 170ms ease, visibility 170ms ease;
}

.aai-intake.is-chat-open .aai-assistant-panel {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0) scale(1);
  visibility: visible;
}

.aai-assistant-panel .aai-chat-card {
  flex: 1 1 auto;
  min-height: min(520px, calc(100dvh - 7rem));
  max-height: inherit !important;
  box-shadow: 0 24px 70px color-mix(in srgb, #000 30%, transparent);
}

.aai-assistant-panel .aai-intake__messages {
  flex: 1 1 auto;
  min-height: 220px;
  max-height: none;
}

.aai-phase-list > h3 {
  color: color-mix(in srgb, var(--aai-accent) 82%, var(--aai-text));
  font-size: 1.05rem;
  letter-spacing: 0;
  text-shadow: 0 0 18px color-mix(in srgb, var(--aai-accent) 18%, transparent);
}

.aai-phase-accordion summary {
  grid-template-columns: minmax(0, 1fr) minmax(62px, max-content) minmax(108px, max-content) 1.35rem;
  gap: 0.35rem 0.55rem;
}

.aai-phase-accordion summary::after {
  grid-column: 4;
  grid-row: 1;
  align-self: center;
  justify-self: end;
  line-height: 1;
}

.aai-ai-revision summary::after,
.aai-estimate-mini-section summary::after {
  grid-column: 2;
  grid-row: 1;
  align-self: center;
  justify-self: end;
  line-height: 1;
}

.aai-phase-accordion summary .aai-phase-summary__title {
  grid-column: 1;
  grid-row: 1;
  overflow: hidden;
  color: color-mix(in srgb, var(--aai-accent) 78%, var(--aai-text));
  font-size: 1.1rem;
  font-weight: 950;
  line-height: 1.12;
  text-overflow: ellipsis;
}

.aai-phase-accordion summary .aai-phase-summary__hours {
  grid-column: 2;
  grid-row: 1;
  justify-self: end;
  min-width: 0;
  padding: 0.16rem 0.42rem;
  border: 1px solid color-mix(in srgb, var(--aai-accent) 24%, var(--aai-border));
  border-radius: 999px;
  background: linear-gradient(135deg, color-mix(in srgb, var(--aai-accent) 12%, var(--aai-panel)), color-mix(in srgb, var(--aai-accent-2) 9%, var(--aai-panel)));
  color: color-mix(in srgb, var(--aai-accent-2) 54%, var(--aai-text));
  font-size: 1.1rem;
  font-style: normal;
  font-weight: 900;
  line-height: 1;
  text-align: right;
  white-space: nowrap;
}

.aai-phase-accordion summary .aai-phase-summary__cost {
  grid-column: 3;
  grid-row: 1;
  justify-self: end;
  min-width: 0;
  color: var(--aai-text);
  font-size: 1rem;
  font-weight: 950;
  line-height: 1.08;
  text-align: right;
  white-space: nowrap;
}

.aai-type-card,
.aai-feature-card,
.aai-choice {
  border-color: color-mix(in srgb, var(--aai-accent) 38%, var(--aai-border));
  background:
    radial-gradient(circle at 18% 0%, color-mix(in srgb, var(--aai-accent-2) 13%, transparent), transparent 46%),
    linear-gradient(145deg, color-mix(in srgb, var(--aai-panel) 89%, var(--aai-accent) 7%), color-mix(in srgb, var(--aai-panel) 88%, var(--aai-accent-2) 7%));
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 10%, transparent);
}

.aai-type-card input[type="checkbox"],
.aai-feature-card input[type="checkbox"],
.aai-choice input[type="checkbox"] {
  display: block;
  position: absolute;
  inset: 0;
  width: 100%;
  min-height: 100%;
  margin: 0;
  opacity: 0;
  cursor: pointer;
}

.aai-choice {
  overflow: hidden;
  padding-right: 1.58rem;
}

.aai-choice::after {
  content: "";
  position: absolute;
  top: 0.54rem;
  right: 0.56rem;
  width: 0.52rem;
  height: 0.52rem;
  border: 1px solid color-mix(in srgb, var(--aai-accent) 32%, var(--aai-border));
  border-radius: 999px;
  background: color-mix(in srgb, var(--aai-panel) 84%, transparent);
}

.aai-choice:has(input:checked) {
  border-color: color-mix(in srgb, var(--aai-accent-2) 74%, var(--aai-accent));
  background:
    radial-gradient(circle at 16% 0%, color-mix(in srgb, var(--aai-accent-2) 24%, transparent), transparent 48%),
    linear-gradient(135deg, color-mix(in srgb, var(--aai-accent) 21%, var(--aai-panel)), color-mix(in srgb, var(--aai-accent-2) 18%, var(--aai-panel)));
  box-shadow: 0 12px 28px color-mix(in srgb, var(--aai-accent) 20%, transparent);
}

.aai-choice:has(input:checked)::after {
  border-color: transparent;
  background: var(--aai-accent-bg);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--aai-accent) 16%, transparent);
}

.aai-ack input[type="checkbox"] {
  display: inline-block !important;
  position: static !important;
  flex: 0 0 auto;
  width: 1.05rem !important;
  height: 1.05rem !important;
  min-height: 1.05rem !important;
  margin: 0.16rem 0 0 !important;
  padding: 0 !important;
  opacity: 1 !important;
  appearance: auto;
  accent-color: var(--aai-accent);
  background: initial;
  box-shadow: none;
  cursor: pointer;
}

@media (min-width: 981px) {
  .aai-intake__shell {
    overflow: visible;
  }

  .aai-chat-lane {
    display: block;
    position: relative;
    top: auto;
    align-self: stretch;
    height: 100%;
    min-height: 100%;
    max-height: none;
  }

  .aai-quote-dock {
    position: sticky;
    top: 1rem;
    max-height: calc(100vh - 2rem);
    overflow: auto;
  }

  .aai-quote-dock > .aai-estimate-card {
    min-height: 0;
  }
}

@media (max-width: 760px) {
  .aai-chat-fab {
    right: calc(0.8rem + env(safe-area-inset-right));
    bottom: calc(var(--aai-mobile-estimator-collapsed) + var(--aai-mobile-nav-height) + 0.95rem + env(safe-area-inset-bottom));
    min-height: 3rem;
    padding: 0.42rem;
  }

  .aai-chat-fab__text {
    display: none;
  }

  .aai-assistant-panel {
    left: 0.65rem;
    right: 0.65rem;
    bottom: calc(var(--aai-mobile-estimator-collapsed) + var(--aai-mobile-nav-height) + 0.75rem + env(safe-area-inset-bottom));
    width: auto;
    max-height: min(70vh, 600px);
  }

  .aai-assistant-panel .aai-chat-card {
    min-height: min(480px, 70vh);
  }

  .aai-form-nav {
    z-index: 996;
  }

  .aai-quote-dock {
    z-index: 997;
  }

  .aai-quote-dock.is-estimator-expanded {
    z-index: 999;
  }
}

@media (max-width: 520px) {
  .aai-feature-detail-summary {
    grid-template-columns: minmax(0, 1fr) 1.45rem;
    gap: 0.42rem 0.55rem;
  }

  .aai-feature-detail-summary::after {
    grid-column: 2;
    grid-row: 1 / span 2;
    align-self: center;
  }

  .aai-feature-detail-summary__count {
    grid-column: 1;
    justify-self: start;
  }

  .aai-phase-accordion summary {
    grid-template-columns: minmax(0, 1fr) minmax(50px, max-content) minmax(78px, max-content) 1.15rem;
    gap: 0.28rem;
    padding: 0.48rem 0.42rem;
  }

  .aai-phase-accordion summary .aai-phase-summary__title {
    font-size: 0.9rem;
  }

  .aai-phase-accordion summary .aai-phase-summary__hours {
    padding: 0.14rem 0.28rem;
    font-size: 0.7rem;
  }

  .aai-phase-accordion summary .aai-phase-summary__cost {
    font-size: 0.74rem;
  }
}
