/* ===================================================
   connynaumann.com — v3
   Accent: #0101a8 | No navigation | Page BG colors
   WCAG AAA — all ratios documented
   =================================================== */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --color-bg: #FFFFFF;
  --color-text: #1A1A1A;
  --color-text-muted: #505050;
  --color-accent: #0101a8;
  --color-accent-hover: #020075;
  --color-border: #D0D0D0;
  --color-tag-bg: #EFEFEF;
  --color-focus: #0101a8;
  --font: 'Geist', system-ui, sans-serif;
  --font-mono: 'Geist Mono', ui-monospace, monospace;
  --max-width: 42rem;
  --space-xs: 0.5rem;
  --space-sm: 1rem;
  --space-md: 1.5rem;
  --space-lg: 3rem;
  --space-xl: 5rem;
  --space-2xl: 7rem;
}

html { font-size: 100%; scroll-behavior: smooth; }
body {
  font-family: var(--font); font-size: 1.125rem; line-height: 1.65;
  color: var(--color-text); background-color: var(--color-bg);
  -webkit-font-smoothing: antialiased;
}

.skip-link {
  position: absolute; top: -100%; left: var(--space-sm);
  background: var(--color-accent); color: #fff;
  padding: var(--space-xs) var(--space-sm);
  font-size: 1rem; font-weight: 600; text-decoration: none; z-index: 1000;
}
.skip-link:focus { top: 0; }

:focus-visible { outline: 3px solid var(--color-focus); outline-offset: 3px; }
:focus:not(:focus-visible) { outline: none; }

h1, h2, h3 { font-family: var(--font); line-height: 1.2; color: var(--color-text); max-width: var(--max-width); }
h1 { font-size: clamp(2rem, 5vw, 3.25rem); font-weight: 700; letter-spacing: -0.02em; margin-bottom: var(--space-md); }
h2 { font-size: clamp(1.25rem, 2.5vw, 1.5rem); font-weight: 700; margin-bottom: var(--space-xs); }
p { max-width: var(--max-width); margin-bottom: 1.5em; }

a {
  color: var(--color-accent); text-decoration: underline;
  text-underline-offset: 3px; text-decoration-thickness: 1.5px;
  transition: color 0.15s ease;
}
a:hover { color: var(--color-accent-hover); text-decoration-thickness: 3px; }

.container { max-width: var(--max-width); margin: 0 auto; padding: 0 var(--space-md); }

/* Header — name + theme toggle */
.site-header { padding: var(--space-md) 0 var(--space-lg); }
.site-header .container { display: flex; justify-content: space-between; align-items: center; }
.site-name {
  font-size: 1rem; font-weight: 400; text-decoration: none;
  text-transform: uppercase; letter-spacing: 0.15em;
  color: #fff; background-color: var(--color-accent);
  padding: 0.25em 0.5em;
}
.site-name:hover { background-color: var(--color-accent-hover); color: #fff; text-decoration: none; }

/* Theme toggle — round button, matches site-name pill height */
.theme-toggle {
  background: none; cursor: pointer; padding: 0;
  width: 1.75rem; height: 1.75rem; border-radius: 50%;
  border: 1.5px solid var(--color-text-muted);
  color: var(--color-text-muted);
  display: inline-flex; align-items: center; justify-content: center;
  transition: color 0.15s ease, border-color 0.15s ease;
}
.theme-toggle:hover { color: var(--color-text); border-color: var(--color-text); }
.theme-toggle .material-symbols-outlined { font-size: 1rem; }

/* Hero */
.hero { padding: var(--space-xl) 0; }
.hero__heading { font-size: clamp(2.25rem, 6vw, 3.5rem); letter-spacing: -0.025em; margin-bottom: var(--space-md); max-width: 18ch; }
.hero__intro { font-size: 1.125rem; color: var(--color-text); margin-bottom: var(--space-lg); }
.hero__available { font-size: 1.125rem; font-weight: 700; color: var(--color-text); margin-bottom: var(--space-md); }
.hero__cta {
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 1rem; font-weight: 600; min-height: 44px;
  padding: 0.625rem 1.5rem; border-radius: 999px;
  border: 1.5px solid var(--color-accent); color: var(--color-accent);
  text-decoration: none; transition: background-color 0.15s ease, color 0.15s ease;
}
.hero__cta:hover { background-color: var(--color-accent); color: #fff; text-decoration: none; }

/* Section */
.section { padding: var(--space-xl) 0; border-top: 1px solid var(--color-border); }
.section__label { font-size: 1.125rem; font-weight: 700; color: var(--color-text); margin-bottom: var(--space-lg); }
.section__cta { margin-top: var(--space-xl); margin-bottom: var(--space-xl); }
.section .section__cta:last-child { margin-bottom: 0; }
.section__cta p { font-size: 1.125rem; font-weight: 700; color: var(--color-text); margin-bottom: var(--space-md); }

/* Projects */
.projects { display: grid; gap: var(--space-xl); }
.project__meta { font-size: 0.875rem; color: var(--color-text-muted); margin-bottom: 0.25rem; }
.project__title { font-size: 1.5rem; font-weight: 700; margin-bottom: var(--space-sm); line-height: 1.3; }
.project__title a { color: var(--color-text); }
.project__title a:hover { color: var(--color-accent); }
.project__summary { font-size: 1.0625rem; color: var(--color-text); margin-bottom: var(--space-sm); max-width: 60ch; }

/* Tile metrics — structured label-value rows */
.tile-metrics {
  font-family: var(--font-mono);
  font-size: 0.8125rem;
  letter-spacing: 0.02em;
  color: var(--color-text);
  border-top: 1px solid var(--color-border);
  margin-bottom: 1.25rem;
}
.tile-metrics .metric {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 0.625rem 0;
  border-bottom: 1px solid var(--color-border);
}
.metric-label {
  color: var(--color-text-muted);
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.metric-value {
  font-weight: 500;
  font-size: 0.875rem;
}

/* Tile tags — pill-shaped, border-only */
.tile-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.375rem;
}
.tile-tags span {
  font-size: 0.875rem;
  color: var(--color-text-muted);
  border: 1px solid var(--color-text-muted);
  border-radius: 6px;
  padding: 0.25rem 0.625rem;
  line-height: 1;
}

/* About */
.about__credentials { font-size: 0.9375rem; color: var(--color-text-muted); margin-top: var(--space-md); }
.about__links { margin-top: var(--space-md); }
.about__links a { font-size: 1rem; font-weight: 600; min-height: 44px; display: inline-flex; align-items: center; }

/* Contact */
.contact-links { display: flex; flex-direction: column; gap: var(--space-xs); }
.contact-links a { font-size: 1rem; min-height: 44px; display: inline-flex; align-items: center; }

/* Back to top */
.back-to-top-wrapper { padding: var(--space-lg) 0; border-top: 1px solid var(--color-border); }
.back-to-top {
  font-size: 1.125rem; font-weight: 400; margin-bottom: 0;
}
.back-to-top a { min-height: 44px; display: inline-flex; align-items: center; }

/* Footer */
.site-footer { padding: var(--space-lg) 0; border-top: 1px solid var(--color-border); font-size: 0.875rem; color: var(--color-text-muted); }
.site-footer .container { display: flex; flex-direction: column; gap: var(--space-md); }
.site-footer .footer__bottom { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: var(--space-xs); }
.footer__links { display: flex; justify-content: space-between; align-items: baseline; flex-wrap: wrap; gap: var(--space-xs); }
.footer__links a { font-weight: 600; min-height: 44px; display: inline-flex; align-items: center; }
.footer__links-left { display: flex; gap: var(--space-md); }
.site-version { font-family: var(--font-mono); font-size: 0.6875rem; letter-spacing: 0.04em; color: var(--color-text-muted); white-space: nowrap; }
.site-footer p { margin-bottom: 0; }

/* === Case Study BG colors === */
/* Pink: Rebranding — #ffb7bb */
/* #0101a8 on #ffb7bb = ~8.1:1 AAA, #1A1A1A on #ffb7bb = ~10.6:1 AAA, #333 on #ffb7bb = ~7.7:1 AAA */
.page-bg--pink {
  --color-bg: #ffb7bb; --color-text-muted: #333333;
  --color-tag-bg: rgba(255,255,255,0.55); --color-border: rgba(0,0,0,0.12);
  background-color: #ffb7bb;
}
/* Blue: Design System — #c0d8f0 */
/* #0101a8 on #c0d8f0 = ~9.1:1 AAA, #1A1A1A on #c0d8f0 = ~11.9:1 AAA, #333 on #c0d8f0 = ~8.6:1 AAA */
.page-bg--blue {
  --color-bg: #c0d8f0; --color-text-muted: #333333;
  --color-tag-bg: rgba(255,255,255,0.55); --color-border: rgba(0,0,0,0.12);
  background-color: #c0d8f0;
}

/* Case study layout */
.case-hero { padding: var(--space-xl) 0 var(--space-lg); }
.case-hero__back { display: inline-flex; align-items: center; min-height: 44px; font-size: 1rem; font-weight: 600; margin-bottom: var(--space-md); }
.case-hero h1, .case-hero h2 { font-family: var(--font); font-weight: 700; }
.case-meta {
  font-family: var(--font-mono);
  font-size: 0.8125rem;
  letter-spacing: 0.02em;
  border-top: 1px solid var(--color-border);
  max-width: var(--max-width);
  margin-top: var(--space-md);
  margin-bottom: 0;
}
.case-meta-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 0.625rem 0;
  border-bottom: 1px solid var(--color-border);
}
.case-meta-label {
  color: var(--color-text-muted);
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.case-meta-value {
  font-weight: 500;
  font-size: 0.875rem;
  text-align: right;
}
/* TL;DR — two inverted containers, label above */
.case-tldr { max-width: var(--max-width); margin-top: var(--space-md); margin-bottom: var(--space-xl); }
.case-tldr-label {
  font-family: var(--font);
  font-size: 1.125rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-text-muted);
  display: block;
  margin-bottom: 0.375rem;
}
.case-tldr-body {
  background-color: var(--color-text); color: var(--color-bg);
  padding: var(--space-lg);
  border-radius: 6px;
}
.case-tldr-body ul {
  font-size: 1.125rem; line-height: 1.875rem;
  margin: 0; padding-left: 1.25rem;
}
.case-tldr-body li + li { margin-top: 0.5rem; }

.case-section { padding: var(--space-lg) 0; border-top: 1px solid var(--color-border); }
.case-section:first-of-type { border-top: none; padding-top: 0; }
.case-section:last-of-type { border-bottom: none; }
.case-section__label { font-size: 1.125rem; font-weight: 700; color: var(--color-text); margin-bottom: var(--space-sm); }
.evidence-note { font-size: 0.9375rem; color: var(--color-text-muted); font-style: italic; border-left: 2px solid var(--color-border); padding-left: var(--space-sm); margin-top: var(--space-sm); max-width: var(--max-width); }
.case-nav { padding: var(--space-lg) 0; border-top: 1px solid var(--color-border); display: flex; justify-content: space-between; flex-wrap: wrap; gap: var(--space-sm); }
.case-nav a { min-height: 44px; display: inline-flex; align-items: center; }

/* === Figures & Images === */
.figure {
  margin: var(--space-lg) 0;
  max-width: var(--max-width);
}
.figure img {
  display: block;
  width: 100%;
  aspect-ratio: 2/1;
  object-fit: cover;
  border-radius: 2px;
}
.figure figcaption {
  font-size: 0.8125rem;
  color: var(--color-text-muted);
  margin-top: var(--space-xs);
}

/* Project card images */
.project__image {
  display: block;
  width: 100%;
  aspect-ratio: 2 / 1;
  object-fit: cover;
  border-radius: 2px;
  margin-bottom: var(--space-sm);
}


/* Green: Breaking Silos — #c8e6c0 */
/* #0101a8 on #c8e6c0 = ~9.6:1 AAA, #1A1A1A on #c8e6c0 = ~12.6:1 AAA, #333 on #c8e6c0 = ~9.1:1 AAA */
.page-bg--green {
  --color-bg: #c8e6c0; --color-text-muted: #333333;
  --color-tag-bg: rgba(255,255,255,0.55); --color-border: rgba(0,0,0,0.12);
  background-color: #c8e6c0;
}

/* === Dark Mode (toggled via data-theme attribute) === */
/* #E8E8E8 on #1e2124 = ~13.1:1 AAA, #B0B0B0 on #1e2124 = ~7.5:1 AAA, #00d4c8 on #1e2124 = ~8.7:1 AAA */
[data-theme="dark"] {
  --color-bg: #1e2124;
  --color-text: #E8E8E8;
  --color-text-muted: #B0B0B0;
  --color-accent: #00d4c8;
  --color-accent-hover: #33E0D6;
  --color-border: rgba(255,255,255,0.12);
  --color-tag-bg: rgba(255,255,255,0.08);
  --color-focus: #00d4c8;
  background-color: var(--color-bg);
}
/* Site name badge: dark text on light accent */
[data-theme="dark"] .site-name { color: #1e2124; }
[data-theme="dark"] .site-name:hover { color: #1e2124; }
/* Pink: Rebranding — dark tinted */
/* #8AB4F8 on #2d2224 = ~7.5:1 AAA, #E8E8E8 on #2d2224 = ~11.5:1 AAA */
[data-theme="dark"].page-bg--pink {
  --color-bg: #2d2224; --color-text-muted: #B0B0B0;
  --color-tag-bg: rgba(255,255,255,0.08); --color-border: rgba(255,255,255,0.12);
  background-color: #2d2224;
}
/* Blue: Design System — dark tinted */
/* #8AB4F8 on #222a32 = ~7.6:1 AAA, #E8E8E8 on #222a32 = ~11.7:1 AAA */
[data-theme="dark"].page-bg--blue {
  --color-bg: #222a32; --color-text-muted: #B0B0B0;
  --color-tag-bg: rgba(255,255,255,0.08); --color-border: rgba(255,255,255,0.12);
  background-color: #222a32;
}
/* Green: Breaking Silos — dark tinted */
/* #8AB4F8 on #242d23 = ~7.7:1 AAA, #E8E8E8 on #242d23 = ~12.0:1 AAA */
[data-theme="dark"].page-bg--green {
  --color-bg: #242d23; --color-text-muted: #B0B0B0;
  --color-tag-bg: rgba(255,255,255,0.08); --color-border: rgba(255,255,255,0.12);
  background-color: #242d23;
}

/* === Process Visuals (Case Study Approach sections) === */
.process-visual { margin-bottom: var(--space-lg); }

/* Visual 1: Phase Timeline — inverted rows (Rebranding) */
.process-visual.timeline-rows {
  display: flex; flex-direction: column;
  max-width: var(--max-width);
  background-color: var(--color-text);
  overflow: hidden;
}
.phase-row {
  display: flex; align-items: baseline; gap: 1.5rem;
  padding: 1.25rem var(--space-md);
  border-bottom: 1px solid rgba(255,255,255,0.1);
}
.phase-row:last-child { border-bottom: none; }
.phase-row .phase-number {
  font-family: var(--font); font-size: 1.125rem;
  color: rgba(255,255,255,0.45); flex-shrink: 0; min-width: 4.5rem;
}
.phase-row--accent .phase-number { color: rgba(255,255,255,0.45); }
.phase-content { display: flex; flex-direction: column; }
.phase-row .phase-name {
  font-family: var(--font); font-weight: 600; font-size: 1.125rem;
  color: var(--color-bg); line-height: 1.4;
}
.phase-row--accent .phase-name { color: var(--color-bg); }
.phase-row .phase-output {
  font-family: var(--font); font-size: 1.125rem;
  color: rgba(255,255,255,0.5); line-height: 1.4; margin-top: 0.125rem;
}

/* Visual 2: Layer Stack (Design System) */
.process-visual.stack {
  display: flex; flex-direction: column; gap: 2px; max-width: 480px;
}
.layer {
  display: flex; justify-content: space-between; align-items: center;
  padding: 0.5rem 0.75rem; border: 1px solid var(--color-border); border-radius: 2px;
}
.layer--accent { border-color: var(--color-accent); border-width: 2px; }
.layer-name { font-weight: 500; font-size: 0.875rem; color: var(--color-text); }
.layer--accent .layer-name { color: var(--color-accent); }
.layer-status {
  font-family: var(--font-mono); font-size: 0.6875rem;
  text-transform: uppercase; letter-spacing: 0.06em;
}
.layer-status--delivered { color: var(--color-accent); }
.layer-status--documented { color: var(--color-text-muted); }

/* Visual 3: Diagnostic Flow (Breaking Silos) */
.process-visual.flow {
  display: flex; align-items: flex-start; gap: 0.25rem; max-width: 640px;
}
.flow-node {
  flex: 1; display: flex; flex-direction: column; align-items: center; text-align: center;
  padding: 0.75rem 0.5rem; border: 1px solid var(--color-border); border-radius: 4px;
}
.flow-node--accent { border-color: var(--color-accent); border-width: 2px; }
.flow-metric {
  font-family: var(--font-mono); font-size: 1.5rem; font-weight: 600;
  color: var(--color-text); line-height: 1; margin-bottom: 0.25rem;
}
.flow-node--accent .flow-metric { color: var(--color-accent); }
.flow-label { font-size: 0.75rem; font-weight: 500; color: var(--color-text); }
.flow-sublabel {
  font-family: var(--font-mono); font-size: 0.625rem;
  color: var(--color-text-muted); margin-top: 0.125rem;
}
.flow-arrow {
  display: flex; align-items: center; color: var(--color-border);
  font-size: 1rem; padding-top: 0.75rem; flex-shrink: 0;
}

@media (max-width: 480px) {
  .process-visual.flow { flex-direction: column; gap: 0; }
  .flow-arrow { transform: rotate(90deg); padding: 0.25rem 0; justify-content: center; }
}

@media (max-width: 640px) { :root { --space-xl: 3rem; --space-2xl: 4rem; } }
@media print { body { font-size: 12pt; } .skip-link, .back-to-top-wrapper { display: none; } a { color: var(--color-text); } }

/* === CONTACT DRAWER === */

/* Trigger CTA — uses existing .hero__cta ellipse style, class added for JS binding */
.cta-drawer-trigger {
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--font); font-size: 1rem; font-weight: 600;
  line-height: 1.5; min-height: 44px;
  padding: 0.625rem 1.5rem; border-radius: 999px;
  border: 1.5px solid var(--color-accent); color: var(--color-accent);
  background: none; cursor: pointer;
  text-decoration: none; transition: background-color 0.15s ease, color 0.15s ease;
}
.cta-drawer-trigger:hover { background-color: var(--color-accent); color: #fff; text-decoration: none; }
.cta-drawer-trigger:focus-visible { outline: 3px solid var(--color-focus); outline-offset: 3px; }

/* Overlay */
.drawer-overlay {
  position: fixed; inset: 0;
  background: rgba(0, 0, 0, 0); z-index: 900;
  pointer-events: none; transition: background 0.35s ease;
}
.drawer-overlay.is-active { background: rgba(0, 0, 0, 0.72); pointer-events: auto; }

/* Drawer panel */
.drawer {
  position: fixed; top: 0; right: 0; bottom: 0;
  width: min(28rem, 92vw); z-index: 1000;
  background: #ffffff; box-shadow: -4px 0 32px rgba(0, 0, 0, 0.2);
  transform: translateX(100%); transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  display: flex; flex-direction: column;
}
.drawer.is-open { transform: translateX(0); }

/* Drawer header */
.drawer-header { flex-shrink: 0; display: flex; justify-content: space-between; align-items: flex-start; padding: 1.75rem 2rem 0; }
.drawer-header-text { padding-right: 1rem; }
.drawer-header h2 { font-size: 1.375rem; font-weight: 700; line-height: 1.3; color: #1a1a1a; margin-bottom: 0.375rem; }
.drawer-header .drawer-intro { font-size: 0.9375rem; line-height: 1.5; color: #666; margin: 0; }

/* Close button */
.drawer-close {
  display: flex; align-items: center; justify-content: center;
  width: 40px; height: 40px; min-width: 40px;
  background: #f2f2f2; border: none; border-radius: 50%;
  cursor: pointer; color: #666;
  transition: color 0.15s ease, background 0.15s ease; margin-top: 0.125rem;
}
.drawer-close:hover { color: #1a1a1a; background: #e4e4e4; }
.drawer-close:focus-visible { outline: 3px solid var(--color-focus); outline-offset: 2px; }
.drawer-close svg { width: 16px; height: 16px; }

/* Scrollable form area */
.drawer-scroll { flex: 1; overflow-y: auto; -webkit-overflow-scrolling: touch; padding: 1.5rem 2rem 1rem; }
@media (max-width: 480px) {
  .drawer-header { padding: 1.25rem 1.25rem 0; }
  .drawer-scroll { padding: 1.25rem 1.25rem 1rem; }
}

/* Section labels inside drawer */
.drawer-form .section-label {
  font-size: 0.8125rem; font-weight: 600; letter-spacing: 0.05em;
  text-transform: uppercase; color: #999;
  margin-top: 2rem; margin-bottom: 1rem;
  padding-bottom: 0.375rem; border-bottom: 1px solid #e8e8e8;
}
.drawer-form .section-label:first-child { margin-top: 0; }

/* Form fields */
.drawer-form .field { margin-bottom: 1.25rem; }
.drawer-form label { display: block; font-size: 0.9375rem; font-weight: 600; line-height: 1.5; margin-bottom: 0.25rem; color: #1a1a1a; }
.drawer-form .hint { display: block; font-size: 0.8125rem; font-weight: 400; color: #888; line-height: 1.4; margin-bottom: 0.25rem; }
.drawer-form input[type="text"],
.drawer-form input[type="email"],
.drawer-form select,
.drawer-form textarea {
  display: block; width: 100%; font-family: var(--font);
  font-size: 0.9375rem; line-height: 1.5;
  padding: 0.5rem 0.625rem; border: 1.5px solid #ccc; border-radius: 3px;
  background: #fff; color: #1a1a1a;
  transition: border-color 0.15s ease;
  -webkit-appearance: none; appearance: none;
}
.drawer-form input:focus,
.drawer-form select:focus,
.drawer-form textarea:focus { outline: 3px solid var(--color-focus); outline-offset: 1px; border-color: var(--color-accent); }
.drawer-form select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0.5 0.5l4.5 4.5 4.5-4.5' stroke='%23888' stroke-width='1.25' fill='none'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 0.625rem center; padding-right: 2rem;
}
.drawer-form textarea { min-height: 4.5rem; resize: vertical; }

/* Checkboxes */
.drawer-form .checkbox-group { margin-top: 0.25rem; }
.drawer-form .checkbox-item { display: flex; align-items: flex-start; gap: 0.5rem; margin-bottom: 0.5rem; line-height: 1.45; }
.drawer-form .checkbox-item input[type="checkbox"] {
  -webkit-appearance: none; appearance: none;
  width: 1.125rem; height: 1.125rem; min-width: 1.125rem;
  border: 1.5px solid #ccc; border-radius: 2px; background: #fff;
  margin-top: 0.15rem; cursor: pointer; position: relative;
  transition: border-color 0.1s ease, background-color 0.1s ease;
}
.drawer-form .checkbox-item input[type="checkbox"]:focus-visible { outline: 3px solid var(--color-focus); outline-offset: 1px; }
.drawer-form .checkbox-item input[type="checkbox"]:checked { background-color: var(--color-accent); border-color: var(--color-accent); }
.drawer-form .checkbox-item input[type="checkbox"]:checked::after {
  content: ''; position: absolute; left: 3px; top: 0px;
  width: 5px; height: 9px; border: solid #fff; border-width: 0 2px 2px 0; transform: rotate(45deg);
}
.drawer-form .checkbox-item label { font-weight: 400; font-size: 0.9375rem; margin-bottom: 0; cursor: pointer; }
.drawer-form .other-text-wrapper { margin-top: 0.125rem; margin-left: 1.625rem; margin-bottom: 0.5rem; }
.drawer-form .other-text-wrapper label { font-size: 0.8125rem; font-weight: 400; color: #888; }
.drawer-form fieldset { border: none; padding: 0; margin: 0; }
.drawer-form legend { font-size: 0.9375rem; font-weight: 600; line-height: 1.5; margin-bottom: 0.25rem; color: #1a1a1a; }

/* Sticky footer */
.drawer-footer { flex-shrink: 0; padding: 1rem 2rem 1.5rem; border-top: 1px solid #e8e8e8; background: #fff; }
@media (max-width: 480px) { .drawer-footer { padding: 1rem 1.25rem 1.5rem; } }
.drawer-footer button[type="submit"] {
  font-family: var(--font); font-size: 1rem; font-weight: 600; line-height: 1.5;
  width: 100%; padding: 0.75rem 2rem;
  background-color: var(--color-accent); color: #fff;
  border: 2px solid var(--color-accent); border-radius: 4px;
  cursor: pointer; transition: background-color 0.15s ease; min-height: 44px;
}
.drawer-footer button[type="submit"]:hover { background-color: var(--color-accent-hover); border-color: var(--color-accent-hover); }
.drawer-footer button[type="submit"]:focus-visible { outline: 3px solid var(--color-focus); outline-offset: 3px; }
.drawer-footer .privacy-note { font-size: 0.75rem; color: #888; line-height: 1.45; margin-top: 0.625rem; }

/* Scroll lock */
body.drawer-is-open { overflow: hidden; }

/* Dark mode overrides for drawer */
[data-theme="dark"] .drawer { background: #1e2124; box-shadow: -4px 0 32px rgba(0, 0, 0, 0.5); }
[data-theme="dark"] .drawer-header h2 { color: var(--color-text); }
[data-theme="dark"] .drawer-header .drawer-intro { color: var(--color-text-muted); }
[data-theme="dark"] .drawer-close { background: rgba(255,255,255,0.08); color: var(--color-text-muted); }
[data-theme="dark"] .drawer-close:hover { color: var(--color-text); background: rgba(255,255,255,0.14); }
[data-theme="dark"] .drawer-form label,
[data-theme="dark"] .drawer-form legend { color: var(--color-text); }
[data-theme="dark"] .drawer-form .hint { color: var(--color-text-muted); }
[data-theme="dark"] .drawer-form .section-label { color: var(--color-text-muted); border-bottom-color: var(--color-border); }
[data-theme="dark"] .drawer-form input[type="text"],
[data-theme="dark"] .drawer-form input[type="email"],
[data-theme="dark"] .drawer-form select,
[data-theme="dark"] .drawer-form textarea { background: rgba(255,255,255,0.06); color: var(--color-text); border-color: var(--color-border); }
[data-theme="dark"] .drawer-form .checkbox-item input[type="checkbox"] { background: rgba(255,255,255,0.06); border-color: var(--color-border); }
[data-theme="dark"] .drawer-footer { background: #1e2124; border-top-color: var(--color-border); }
[data-theme="dark"] .drawer-footer .privacy-note { color: var(--color-text-muted); }
[data-theme="dark"] .drawer-form .other-text-wrapper label { color: var(--color-text-muted); }
