/* ============================================================
   AWOLASEE Design System — colors_and_type.css
   ------------------------------------------------------------
   Single source of truth for tokens (colors, type, radii,
   shadows) and semantic element styles. Import into any HTML:

       <link rel="stylesheet" href="/colors_and_type.css">

   Fonts are pulled from Google Fonts. Swap to self-hosted
   @font-face if you ship fonts/ locally.
   ============================================================ */

@import url("https://fonts.googleapis.com/css2?family=Chakra+Petch:wght@400;500;600;700&family=Sora:wght@300;400;500;600;700;800&display=swap");

:root {
  /* ----- Core surface palette ----- */
  --aw-bg-0: #060b14;       /* page base, deepest navy */
  --aw-bg-1: #0b1220;       /* secondary surface */
  --aw-surface: #0f172a;    /* card surface (alt) */
  --aw-surface-2: #111c33;  /* raised / hover surface */
  --aw-card: #0b1424;       /* canonical card fill (matches index-home.css) */
  --aw-card-raised: #0f1a2f;/* nested card / list row */

  /* ----- Text ----- */
  --aw-fg-1: #f5f8ff;       /* primary text */
  --aw-fg-2: #d7e4ff;       /* secondary text / button outline label */
  --aw-fg-3: #96aac8;       /* muted body */
  --aw-fg-4: #7fa2ca;       /* deep muted / small label */
  --aw-fg-5: #82a4cb;       /* stat kicker */

  /* ----- Lines / dividers ----- */
  --aw-line-1: rgba(120, 152, 205, 0.20);
  --aw-line-2: rgba(109, 140, 189, 0.26);
  --aw-line-3: rgba(120, 170, 255, 0.34);
  --aw-line-hover: rgba(120, 170, 255, 0.55);

  /* ----- Brand (warm) ----- */
  --aw-brand: #ff7a45;
  --aw-brand-strong: #d65422;
  --aw-brand-deep: #bc441a;
  --aw-brand-glow: rgba(255, 122, 69, 0.12);

  /* ----- Accent (cool) ----- */
  --aw-accent: #18c3ae;
  --aw-accent-soft: #9cf4bc;

  /* ----- Notification / info ----- */
  --aw-info-1: #2563eb;
  --aw-info-2: #22d3ee;
  --aw-info-border: rgba(59, 130, 246, 0.55);
  --aw-info-bg: rgba(59, 130, 246, 0.12);

  /* ----- Semantic ----- */
  --aw-ok: #22c55e;
  --aw-ok-soft: #9cf4bc;
  --aw-danger: #ef4444;
  --aw-danger-strong: #b91c1c;
  --aw-danger-soft: #ffd1d1;

  /* ----- Radii ----- */
  --aw-radius-pill: 999px;
  --aw-radius-xl: 18px;
  --aw-radius-lg: 14px;
  --aw-radius-md: 11px;
  --aw-radius-sm: 9px;
  --aw-radius-xs: 8px;
  --aw-radius-card: 16px;

  /* ----- Shadows ----- */
  --aw-shadow-lg: 0 16px 42px rgba(0, 0, 0, 0.30);
  --aw-shadow-md: 0 10px 24px rgba(0, 0, 0, 0.22);
  --aw-shadow-sm: 0 8px 18px rgba(22, 30, 49, 0.34);
  --aw-shadow-btn: 0 8px 18px rgba(22, 30, 49, 0.34);
  --aw-shadow-inset-chrome: inset 0 0 0 1px rgba(147, 197, 255, 0.12);

  /* ----- Signature body background ----- */
  --aw-bg-image:
    radial-gradient(circle at 9% 12%, rgba(255, 122, 69, 0.12), transparent 30%),
    radial-gradient(circle at 89% 6%, rgba(47, 176, 255, 0.09), transparent 32%),
    linear-gradient(180deg, #070d18 0%, #0a1324 100%);

  /* ----- Gradients ----- */
  --aw-grad-brand:   linear-gradient(135deg, #ff7a45, #d65422);
  --aw-grad-brand-strong: linear-gradient(135deg, #d65422, #bc441a);
  --aw-grad-avatar:  linear-gradient(135deg, #ff6a3d, #18c3ae);
  --aw-grad-info:    linear-gradient(135deg, #2563eb, #22d3ee);
  --aw-grad-danger:  linear-gradient(135deg, #ef4444, #b91c1c);
  --aw-grad-surface: linear-gradient(160deg, #111a2f, #0d1628);

  /* ----- Type ----- */
  --aw-font-display: "Chakra Petch", "Segoe UI", sans-serif;
  --aw-font-body: "Sora", "Segoe UI", Tahoma, Arial, sans-serif;
  --aw-font-mono: "Consolas", "Cascadia Mono", "Courier New", monospace;

  --aw-ls-kicker: 0.08em;
  --aw-ls-logo: 0.12em;

  /* ----- Type scale ----- */
  --aw-fs-hero: clamp(1.9rem, 4.4vw, 2.95rem);
  --aw-fs-h1:   1.56rem;
  --aw-fs-h2:   1.14rem;
  --aw-fs-h3:   1.04rem;
  --aw-fs-h4:   0.94rem;
  --aw-fs-body: 0.92rem;
  --aw-fs-body-s: 0.86rem;
  --aw-fs-small: 0.78rem;
  --aw-fs-micro: 0.72rem;
  --aw-fs-kicker: 0.72rem;
  --aw-fs-badge:  0.68rem;
  --aw-fs-stat:   1.27rem;

  /* ----- Layout ----- */
  --aw-container-max: min(1180px, 92%);

  /* ----- Motion ----- */
  --aw-ease-standard: cubic-bezier(0.4, 0, 0.2, 1);
  --aw-dur-fast: 0.16s;
  --aw-dur-normal: 0.20s;
  --aw-dur-slow: 0.28s;
}

/* ============================================================
   Base resets (opt-in: scope to .aw-reset or apply to body)
   ============================================================ */

body.aw-body,
.aw-body {
  margin: 0;
  min-height: 100vh;
  color: var(--aw-fg-1);
  font-family: var(--aw-font-body);
  background-color: var(--aw-bg-0);
  background: var(--aw-bg-image);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.aw * { box-sizing: border-box; }

/* ============================================================
   Semantic typography — class-scoped to avoid polluting host pages.
   Wrap typography examples in .aw to use.
   ============================================================ */

.aw h1, .aw .aw-h1 {
  font-family: var(--aw-font-display);
  font-weight: 700;
  font-size: var(--aw-fs-hero);
  line-height: 1.04;
  color: var(--aw-fg-1);
  margin: 0;
  letter-spacing: 0;
}

.aw h2, .aw .aw-h2 {
  font-family: var(--aw-font-display);
  font-weight: 700;
  font-size: var(--aw-fs-h1);
  line-height: 1.1;
  color: var(--aw-fg-1);
  margin: 0;
}

.aw h3, .aw .aw-h3 {
  font-family: var(--aw-font-display);
  font-weight: 700;
  font-size: var(--aw-fs-h2);
  line-height: 1.2;
  color: var(--aw-fg-1);
  margin: 0;
}

.aw h4, .aw .aw-h4 {
  font-family: var(--aw-font-display);
  font-weight: 600;
  font-size: var(--aw-fs-h3);
  color: var(--aw-fg-2);
  margin: 0;
}

.aw p, .aw .aw-body-text {
  font-family: var(--aw-font-body);
  font-size: var(--aw-fs-body);
  line-height: 1.6;
  color: var(--aw-fg-3);
  margin: 0;
}

.aw small, .aw .aw-small {
  font-family: var(--aw-font-body);
  font-size: var(--aw-fs-small);
  color: var(--aw-fg-3);
  line-height: 1.45;
}

.aw .aw-kicker {
  display: inline-flex;
  align-items: center;
  font-family: var(--aw-font-display);
  font-size: var(--aw-fs-kicker);
  font-weight: 700;
  letter-spacing: var(--aw-ls-kicker);
  text-transform: uppercase;
  color: #b8d1f0;
}

.aw .aw-badge {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 10px;
  border-radius: var(--aw-radius-pill);
  border: 1px solid var(--aw-line-2);
  background: var(--aw-card-raised);
  color: #b8d1f0;
  font-family: var(--aw-font-display);
  font-size: var(--aw-fs-micro);
  font-weight: 700;
  letter-spacing: var(--aw-ls-kicker);
  text-transform: uppercase;
  white-space: nowrap;
}

.aw .aw-badge.is-brand {
  color: #ffd2b8;
  border-color: rgba(255, 122, 69, 0.40);
  background: rgba(255, 122, 69, 0.10);
}
.aw .aw-badge.is-online { color: var(--aw-ok-soft); border-color: rgba(90, 225, 143, 0.34); }
.aw .aw-badge.is-danger { color: var(--aw-danger-soft); border-color: rgba(255, 131, 131, 0.30); }
.aw .aw-badge.is-info   { color: #dbeafe; border-color: var(--aw-info-border); background: var(--aw-info-bg); }

.aw .aw-stat {
  font-family: var(--aw-font-display);
  font-size: var(--aw-fs-stat);
  font-weight: 700;
  line-height: 1;
  color: var(--aw-fg-1);
}

.aw code, .aw .aw-mono {
  font-family: var(--aw-font-mono);
  font-size: 0.86em;
  color: #e3ecff;
  background: rgba(15, 26, 47, 0.8);
  padding: 2px 6px;
  border-radius: var(--aw-radius-sm);
  border: 1px solid var(--aw-line-1);
}

/* ============================================================
   Reusable atoms
   ============================================================ */

.aw .aw-card {
  border: 1px solid var(--aw-line-2);
  border-radius: var(--aw-radius-card);
  background: var(--aw-card);
  padding: 16px;
}

.aw .aw-card.is-raised {
  box-shadow: var(--aw-shadow-lg);
  background: var(--aw-grad-surface);
}

.aw .aw-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 0 14px;
  border-radius: var(--aw-radius-md);
  border: 1px solid transparent;
  font-family: var(--aw-font-body);
  font-size: var(--aw-fs-body-s);
  font-weight: 700;
  cursor: pointer;
  transition:
    transform var(--aw-dur-normal) var(--aw-ease-standard),
    background var(--aw-dur-normal) var(--aw-ease-standard),
    border-color var(--aw-dur-normal) var(--aw-ease-standard),
    box-shadow var(--aw-dur-normal) var(--aw-ease-standard);
}

.aw .aw-btn:hover { transform: translateY(-1px); }

.aw .aw-btn--primary {
  color: #fff;
  background: var(--aw-grad-brand);
  box-shadow: var(--aw-shadow-btn);
}
.aw .aw-btn--primary:hover { background: var(--aw-grad-brand-strong); }

.aw .aw-btn--outline {
  color: var(--aw-fg-2);
  border-color: rgba(120, 170, 255, 0.22);
  background: rgba(255, 255, 255, 0.03);
}
.aw .aw-btn--outline:hover {
  border-color: var(--aw-line-hover);
  background: rgba(120, 170, 255, 0.08);
}

.aw .aw-btn--ghost {
  color: var(--aw-fg-2);
  background: transparent;
  border-color: transparent;
}
.aw .aw-btn--ghost:hover {
  background: rgba(120, 170, 255, 0.10);
}

.aw .aw-btn--danger {
  color: #fff;
  background: var(--aw-grad-danger);
}

.aw .aw-btn--sm { min-height: 32px; padding: 0 10px; font-size: var(--aw-fs-small); }

/* Input */
.aw .aw-input {
  width: 100%;
  min-height: 40px;
  padding: 0 12px;
  border-radius: var(--aw-radius-md);
  border: 1px solid var(--aw-line-2);
  background: var(--aw-card-raised);
  color: var(--aw-fg-1);
  font-family: var(--aw-font-body);
  font-size: var(--aw-fs-body);
  transition: border-color var(--aw-dur-normal) var(--aw-ease-standard);
}
.aw .aw-input::placeholder { color: var(--aw-fg-4); }
.aw .aw-input:focus {
  outline: none;
  border-color: var(--aw-line-hover);
  box-shadow: 0 0 0 3px rgba(120, 170, 255, 0.12);
}

/* Simple container */
.aw .aw-container { width: var(--aw-container-max); margin-inline: auto; }

/* ============================================================
   Animation primitive
   ============================================================ */
@keyframes aw-menu-open {
  from { opacity: 0; transform: translateY(-5px); }
  to   { opacity: 1; transform: translateY(0); }
}
