@charset "UTF-8";
@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Open+Sans:wght@400;500;600&family=Playfair+Display:wght@400;500;600;700&family=Roboto:wght@400;500;600;700&family=Source+Serif+Pro:wght@300;400;600&display=swap";

/* src/styles.scss */
:root {
  --breath-padding-y: clamp(60px, 10vh, 120px);
  --breath-padding-x: clamp(16px, 5vw, 48px);
  --font-hero: clamp(2rem, 5vw, 4.5rem);
  --font-section-title: clamp(1.75rem, 4vw, 2.5rem);
  --font-section-subtitle: clamp(1rem, 2vw, 1.25rem);
  --font-body-large: clamp(1rem, 1.5vw, 1.125rem);
  --orbit-width: clamp(300px, 40vw, 800px);
  --orbit-height: clamp(350px, 45vh, 600px);
  --orbit-glow-spread: clamp(20px, 3vw, 60px);
  --cta-pulse-duration: 3s;
  --cta-pulse-intensity: 0 4px 24px rgba(180, 83, 9, 0.6);
  --logo-height-desktop: 44px;
  --logo-height-tablet: 40px;
  --logo-height-mobile: 36px;
  --logo-height-compact: 32px;
  --tagline-font-size-desktop: 0.8125rem;
  --tagline-font-size-mobile: 0.75rem;
  --tagline-font-weight: 500;
  --tagline-color: #64748b;
  --tagline-letter-spacing: 0.01em;
  --logo-tagline-gap: 0.5rem;
  --header-logo-margin-right: 2rem;
  --header-height-desktop: 72px;
  --header-height-mobile: 64px;
  --header-padding-x-desktop: 2rem;
  --header-padding-x-mobile: 1rem;
  --header-bg-default: rgba(255, 255, 255, 0.98);
  --header-bg-scrolled: rgba(255, 255, 255, 0.95);
  --header-border-color: #e2e8f0;
  --header-shadow-scrolled: 0 2px 12px rgba(0, 0, 0, 0.08);
  --header-nav-font-size: 1rem;
  --header-nav-font-weight: 600;
  --header-nav-color: #334155;
  --header-nav-color-hover: #0d9488;
  --header-nav-gap: 2rem;
  --header-btn-height: 48px;
  --header-btn-padding: 1rem 1.5rem;
  --header-btn-radius: 12px;
  --header-btn-font-size: 1rem;
  --header-btn-font-weight: 600;
  --uzobi-navy: #1a365d;
  --uzobi-slate: #334155;
  --uzobi-stone: #f8fafc;
  --uzobi-warm: #fefdfb;
  --trust-teal: #0d9488;
  --trust-teal-dark: #0f766e;
  --wisdom-gold: #b45309;
  --wisdom-gold-light: #fef3c7;
  --calm-lavender: #7c3aed;
  --life-green: #15803d;
  --orbital-culture: #d97706;
  --orbital-values: #7c3aed;
  --orbital-spirituality: #6366f1;
  --orbital-legacy: #e11d48;
  --orbital-aspirations: #0ea5e9;
  --orbital-preferences: #0d9488;
  --orbital-lifestyle: #16a34a;
  --orbital-identity: #475569;
  --orbital-network: #f59e0b;
  --state-unspoken: #94a3b8;
  --state-emerging: #0d9488;
  --state-anchored: #0f766e;
  --state-sanctified: #d97706;
  --state-unspoken-glow: none;
  --state-unspoken-opacity: 0.5;
  --state-emerging-glow: 0 0 15px rgba(13, 148, 136, 0.2);
  --state-anchored-glow: 0 0 25px rgba(15, 118, 110, 0.3);
  --state-anchored-border: 2px solid #5eead4;
  --state-sanctified-glow: 0 0 40px rgba(217, 119, 6, 0.5);
  --state-sanctified-shadow: 0 12px 48px rgba(217, 119, 6, 0.2);
  --sanctuary-transition-duration: 3000ms;
  --sanctuary-reveal-easing: cubic-bezier(0.4, 0, 0.2, 1);
  --duration-breathe: 4000ms;
  --duration-slow: 300ms;
  --duration-normal: 200ms;
  --easing-default: cubic-bezier(0.4, 0, 0.2, 1);
  --ease-smooth: cubic-bezier(0.25, 0.1, 0.25, 1);
  --ease-out: cubic-bezier(0, 0, 0.2, 1);
  --compass-size: 120px;
  --compass-pulse-idle: 2000ms;
  --compass-pulse-urgent: 1000ms;
  --compass-glow: 0 0 30px rgba(13, 148, 136, 0.3);
  --sanctuary-breathing-room: clamp(24px, 5vh, 80px);
  --headline-authority: clamp(2rem, 4vw, 3.5rem);
  --seal-glow-intensity: 0 0 40px rgba(217, 119, 6, 0.4);
  --entrance-duration: 3000ms;
  --blur-resolve-duration: 1200ms;
  --seal-pulse-duration: 800ms;
  --ambient-fade-duration: 1000ms;
  --guardian-teal: #0a5c54;
  --guardian-teal-dark: #064e45;
  --alert-critical: #dc2626;
  --alert-warning: #d97706;
  --alert-info: #0369a1;
  --alert-success: #15803d;
  --slate-50: #f8fafc;
  --slate-100: #f1f5f9;
  --slate-200: #e2e8f0;
  --slate-300: #cbd5e1;
  --slate-400: #94a3b8;
  --slate-500: #64748b;
  --slate-600: #475569;
  --slate-700: #334155;
  --slate-800: #1e293b;
  --slate-900: #0f172a;
  --container-max: 1100px;
  --container-narrow: 900px;
  --container-wide: 1200px;
  --section-padding-y: 3rem;
  --section-padding-y-lg: 4rem;
  --text-primary: #1e293b;
  --text-secondary: #334155;
  --text-muted: #475569;
  --text-subtle: #64748b;
  --badge-teal-bg: #ccfbf1;
  --badge-teal-text: #0f766e;
  --badge-gold-bg: #fef3c7;
  --badge-gold-text: #92400e;
  --badge-blue-bg: #dbeafe;
  --badge-blue-text: #1e40af;
  --badge-green-bg: #dcfce7;
  --badge-green-text: #166534;
  --badge-red-bg: #fee2e2;
  --badge-red-text: #991b1b;
  --badge-purple-bg: #ede9fe;
  --badge-purple-text: #5b21b6;
  --badge-gray-bg: #f1f5f9;
  --badge-gray-text: #334155;
  --font-sans:
    "Inter",
    -apple-system,
    BlinkMacSystemFont,
    "Segoe UI",
    sans-serif;
  --font-serif:
    "Source Serif Pro",
    Georgia,
    "Times New Roman",
    serif;
  --font-serif-premium:
    "Playfair Display",
    Georgia,
    "Times New Roman",
    serif;
  --font-headline:
    Georgia,
    "Times New Roman",
    serif;
  --font-body:
    "Inter",
    "Open Sans",
    system-ui,
    sans-serif;
  --font-quote:
    "Source Serif Pro",
    Georgia,
    serif;
  --text-xs: 0.875rem;
  --text-sm: 0.9375rem;
  --text-base: 1rem;
  --text-lg: 1.125rem;
  --text-xl: 1.25rem;
  --text-2xl: 1.5rem;
  --text-3xl: 1.875rem;
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-8: 32px;
  --space-10: 40px;
  --space-12: 48px;
  --space-16: 64px;
  --space-xs: 4px;
  --space-sm: 8px;
  --space-md: 16px;
  --space-lg: 24px;
  --space-xl: 32px;
  --space-2xl: 48px;
  --space-3xl: 64px;
  --space-4xl: 80px;
  --space-5xl: 96px;
  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --radius-2xl: 20px;
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.04);
  --shadow-md: 0 2px 8px rgba(0, 0, 0, 0.08);
  --shadow-lg: 0 4px 16px rgba(0, 0, 0, 0.1);
  --shadow-focus: 0 0 0 3px rgba(13, 148, 136, 0.3);
  --touch-target-min: 44px;
  --touch-target-comfortable: 48px;
  --transition-instant: 100ms ease-out;
  --transition-fast: 150ms ease;
  --transition-normal: 200ms ease;
  --transition-slow: 300ms ease-in-out;
  --transition-deliberate: 500ms ease;
  --font-heading:
    "Roboto",
    "Inter",
    -apple-system,
    BlinkMacSystemFont,
    sans-serif;
  --font-body:
    "Open Sans",
    "Inter",
    -apple-system,
    BlinkMacSystemFont,
    sans-serif;
  --color-bg-primary: #ffffff;
  --color-bg-secondary: #f8fafc;
  --color-bg-tertiary: #f3f4f6;
  --color-border: #d1d5db;
  --color-border-light: #e5e7eb;
  --shadow-focus-error: 0 0 0 3px rgba(239, 68, 68, 0.15);
  --radio-checkbox-size: 24px;
  --radio-checkbox-border-radius: 6px;
}
@keyframes sanctified-snap {
  0% {
    transform: scale(0.95);
    box-shadow: 0 0 0px var(--state-sanctified, #d97706);
  }
  90% {
    transform: scale(1.1);
    box-shadow: var(--seal-glow-intensity);
  }
  100% {
    transform: scale(1);
    filter: drop-shadow(0 0 20px var(--state-sanctified, #d97706));
  }
}
@keyframes heartbeat-glow {
  0%, 100% {
    transform: scale(1);
    opacity: 0.6;
  }
  50% {
    transform: scale(1.15);
    opacity: 1;
  }
}
@keyframes flash-burst {
  0% {
    opacity: 0;
    transform: scale(0);
  }
  10% {
    opacity: 1;
    transform: scale(1.5);
  }
  100% {
    opacity: 0;
    transform: scale(3);
  }
}
@keyframes seal-imprint-snap {
  0% {
    transform: translate(-50%, -50%) scale(0);
    opacity: 0;
  }
  60% {
    transform: translate(-50%, -50%) scale(1.2);
    opacity: 1;
  }
  100% {
    transform: translate(-50%, -50%) scale(1);
    opacity: 1;
  }
}
@keyframes light-shaft-fade {
  0%, 100% {
    opacity: 0.3;
  }
  50% {
    opacity: 0.6;
  }
}
.sanctuary-view-entrance {
  animation: sanctified-snap 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275) forwards;
}
.sanctuary-canvas {
  padding: var(--sanctuary-breathing-room);
  transition: all 2s ease-in-out;
  background:
    radial-gradient(
      circle at center,
      var(--guardian-teal),
      var(--guardian-teal-dark));
}
@keyframes pulse-of-presence {
  0%, 100% {
    box-shadow: 0 0 10px rgba(13, 148, 136, 0.1);
    filter: brightness(1);
  }
  50% {
    box-shadow: var(--state-emerging-glow, 0 0 15px rgba(13, 148, 136, 0.2));
    filter: brightness(1.1);
  }
}
.node-emerging {
  border-color: var(--state-emerging) !important;
  color: var(--state-emerging);
  animation: pulse-of-presence var(--duration-breathe, 4000ms) var(--easing-default) infinite;
  will-change: box-shadow, filter;
  backface-visibility: hidden;
}
.constellation-node.node-emerging {
  animation: none;
}
@keyframes resolve-to-anchored {
  0% {
    border-color: var(--state-emerging);
    box-shadow: var(--state-emerging-glow);
  }
  100% {
    border-color: #5eead4;
    box-shadow: var(--state-anchored-glow);
  }
}
.node-anchored {
  animation: resolve-to-anchored var(--duration-slow, 300ms) var(--ease-smooth) forwards;
  font-weight: 600;
  pointer-events: auto;
  cursor: pointer;
  background-color: transparent;
}
.constellation-node.node-anchored {
  animation: none;
}
@keyframes compass-pulse {
  0%, 100% {
    transform: scale(1);
    opacity: 0.8;
  }
  50% {
    transform: scale(1.1);
    opacity: 1;
    box-shadow: 0 0 50px var(--state-emerging, #0d9488);
  }
}
@keyframes compass-pulse-urgent {
  0%, 100% {
    transform: scale(1);
    opacity: 0.9;
    box-shadow: 0 0 30px var(--state-sanctified, #d97706);
  }
  50% {
    transform: scale(1.15);
    opacity: 1;
    box-shadow: 0 0 60px var(--state-sanctified, #d97706);
  }
}
.compass-idle {
  box-shadow: var(--compass-glow);
}
.compass-active {
  animation: compass-pulse var(--compass-pulse-idle, 2000ms) var(--easing-default) infinite;
}
.compass-urgent {
  animation: compass-pulse-urgent var(--compass-pulse-urgent, 1000ms) var(--easing-default) infinite;
}
@keyframes luminous-ripple {
  0% {
    transform: scale(1);
    opacity: 0.6;
  }
  100% {
    transform: scale(2);
    opacity: 0;
  }
}
@media (prefers-reduced-motion: reduce) {
  .node-emerging,
  .node-anchored,
  .compass-active,
  .compass-urgent {
    animation: none;
  }
  .node-emerging {
    box-shadow: var(--state-emerging-glow);
  }
  .node-anchored {
    box-shadow: var(--state-anchored-glow);
    background-color: transparent;
  }
}
*,
*::before,
*::after {
  box-sizing: border-box;
}
html {
  font-size: 18px;
  overflow-x: hidden;
  overflow-y: auto;
  height: 100%;
}
@media screen and (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }
}
body {
  margin: 0;
  padding: 0;
  font-family: var(--font-sans);
  font-size: 1rem;
  line-height: 1.6;
  color: var(--slate-800);
  background: var(--uzobi-stone);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
  overflow-y: auto;
  min-height: 100vh;
}
h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: var(--font-sans);
  color: var(--uzobi-navy);
  margin: 0 0 0.75rem 0;
  line-height: 1.3;
}
h1 {
  font-size: 2rem;
  font-weight: 700;
}
h2 {
  font-size: 1.5rem;
  font-weight: 600;
}
h3 {
  font-size: 1.25rem;
  font-weight: 600;
}
h4 {
  font-size: 1.125rem;
  font-weight: 600;
}
.narrative,
.patient-voice,
.story-text {
  font-family: var(--font-serif);
  line-height: 1.7;
}
a {
  color: var(--trust-teal);
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: color var(--transition-fast);
}
a:hover {
  color: #0f766e;
}
a:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
  border-radius: var(--radius-sm);
}
button {
  font-family: var(--font-sans);
  font-size: 1rem;
  min-height: 44px;
  min-width: 44px;
  cursor: pointer;
  transition: all var(--transition-fast);
}
button:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
}
input,
textarea,
select {
  font-family: var(--font-sans);
  font-size: 1rem;
  min-height: 52px;
  padding: 14px 16px;
  border: 2px solid var(--slate-300);
  border-radius: var(--radius-md);
  background: white;
  color: var(--slate-800);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}
input:focus,
textarea:focus,
select:focus {
  outline: none;
  border-color: var(--trust-teal);
  box-shadow: var(--shadow-focus);
}
input::placeholder,
textarea::placeholder {
  color: var(--text-muted);
}
label {
  font-weight: 500;
  color: var(--slate-700);
  display: block;
  margin-bottom: var(--space-2);
}
:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
}
.radio-control,
.checkbox-control {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  cursor: pointer;
  min-height: var(--touch-target-min);
  padding: var(--space-2) 0;
}
.radio-custom,
.checkbox-custom {
  width: var(--radio-checkbox-size);
  height: var(--radio-checkbox-size);
  min-width: var(--radio-checkbox-size);
  border: 2px solid var(--slate-300);
  background: white;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--transition-fast);
  flex-shrink: 0;
}
.radio-custom {
  border-radius: 50%;
}
.checkbox-custom {
  border-radius: var(--radio-checkbox-border-radius);
}
.radio-control:hover .radio-custom,
.checkbox-control:hover .checkbox-custom {
  border-color: var(--trust-teal);
}
.radio-control.selected .radio-custom,
.checkbox-control.selected .checkbox-custom {
  border-color: var(--trust-teal);
  background: var(--trust-teal);
}
.radio-custom::after {
  content: "";
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: white;
  opacity: 0;
  transition: opacity var(--transition-fast);
}
.radio-control.selected .radio-custom::after {
  opacity: 1;
}
.checkbox-custom::after {
  content: "\2713";
  color: white;
  font-size: 14px;
  font-weight: 700;
  opacity: 0;
  transition: opacity var(--transition-fast);
}
.checkbox-control.selected .checkbox-custom::after {
  opacity: 1;
}
.skip-link {
  position: absolute;
  top: -40px;
  left: 0;
  background: var(--uzobi-navy);
  color: white;
  padding: 8px 16px;
  z-index: 9999;
  transition: top var(--transition-normal);
}
.skip-link:focus {
  top: 0;
}
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}
@media (prefers-contrast: high) {
  body {
    background: white;
  }
  input,
  textarea,
  select {
    border-width: 3px;
  }
}
@media print {
  html {
    font-size: 11pt;
  }
  body {
    background: white !important;
    color: black !important;
    font-size: 11pt;
    line-height: 1.5;
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
  }
  .no-print {
    display: none !important;
  }
  h1 {
    font-size: 18pt;
  }
  h2 {
    font-size: 14pt;
  }
  h3 {
    font-size: 12pt;
  }
  h4 {
    font-size: 11pt;
  }
  * {
    box-shadow: none !important;
    text-shadow: none !important;
  }
  section,
  .section-card,
  .contact-card,
  .critical-section {
    page-break-inside: avoid;
    break-inside: avoid;
  }
  .page-break-before {
    page-break-before: always;
    break-before: page;
  }
  a[href]:after {
    content: none;
  }
  a[href^="tel:"] {
    color: inherit !important;
    text-decoration: none !important;
  }
  .code-status-badge,
  .emergency-banner,
  .allergy-alert {
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
  }
  @page {
    size: letter portrait;
    margin: 0.5in 0.5in 0.75in 0.5in;
  }
  @page :first {
    margin-top: 0.25in;
  }
  @page {
    @bottom-center {
      content: "Page " counter(page) " of " counter(pages);
      font-size: 9pt;
      color: #666;
    }
  }
}

/* angular:styles/global:styles */
/*# sourceMappingURL=styles.css.map */
