/* ============================================================================
   Aadyash Shared Styles — layout, components, reusable patterns.
   Requires tokens.css to be loaded first.
   ============================================================================ */

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

html { scroll-behavior: smooth; }
body {
  font-family: var(--aad-font-sans);
  font-size: var(--aad-fs-body);
  line-height: var(--aad-lh-body);
  color: var(--aad-ink);
  background: var(--aad-canvas);
  -webkit-font-smoothing: antialiased;
}
img, svg { display: block; max-width: 100%; }
a { color: var(--aad-accent); text-decoration: none; }
a:hover { color: var(--aad-primary); }
button { font: inherit; cursor: pointer; }

/* Layout primitives */
.aad-container {
  max-width: var(--aad-content-max);
  margin: 0 auto;
  padding: 0 var(--aad-s-5);
}
.aad-section { padding: var(--aad-s-9) 0; }
.aad-section--tight { padding: var(--aad-s-7) 0; }
.aad-section--alt   { background: var(--aad-canvas-2); }
.aad-section--dark  { background: var(--aad-primary); color: var(--aad-canvas); }

/* Typography */
h1, .aad-h1 { font-family: var(--aad-font-display); font-size: var(--aad-fs-display);
  line-height: var(--aad-lh-display); font-weight: var(--aad-w-extra);
  letter-spacing: -0.02em; color: var(--aad-primary); }
h2, .aad-h2 { font-family: var(--aad-font-display); font-size: var(--aad-fs-headline);
  line-height: var(--aad-lh-headline); font-weight: var(--aad-w-bold);
  letter-spacing: -0.015em; color: var(--aad-primary); }
h3, .aad-h3 { font-size: var(--aad-fs-section); line-height: var(--aad-lh-section);
  font-weight: var(--aad-w-semibold); color: var(--aad-primary); }
p { color: var(--aad-muted-2); }
.aad-lede { font-size: 18px; line-height: 1.6; color: var(--aad-muted-2); max-width: 640px; }

/* Tag pill (above headlines) */
.aad-tag {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 12px; border-radius: var(--aad-r-pill);
  font-size: var(--aad-fs-label); font-weight: var(--aad-w-bold);
  letter-spacing: var(--aad-tracking-label); text-transform: uppercase;
  color: var(--aad-signal);
  background: rgba(255,107,107,0.08);
  border: 1px solid rgba(255,107,107,0.25);
  margin-bottom: var(--aad-s-4);
}

/* Buttons */
.aad-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 22px; border-radius: var(--aad-r-sm);
  font-size: 15px; font-weight: var(--aad-w-semibold);
  border: 1.5px solid transparent;
  transition: all 0.18s ease;
}
.aad-btn-primary { background: var(--aad-signal); color: white; }
.aad-btn-primary:hover { background: #ff5252; box-shadow: var(--aad-glow-signal); transform: translateY(-1px); }
.aad-btn-dark    { background: var(--aad-primary); color: var(--aad-canvas); }
.aad-btn-dark:hover { background: #15123a; color: var(--aad-canvas); }
.aad-btn-ghost   { background: transparent; color: var(--aad-primary); border-color: var(--aad-primary); }
.aad-btn-ghost:hover { background: var(--aad-primary); color: var(--aad-canvas); }

/* Cards */
.aad-card {
  background: var(--aad-surface);
  border: 1px solid var(--aad-border);
  border-radius: var(--aad-r-lg);
  padding: var(--aad-s-6);
  box-shadow: var(--aad-shadow-sm);
}
.aad-card-feature {
  background: var(--aad-surface);
  border: 1px solid var(--aad-border);
  border-radius: var(--aad-r-lg);
  padding: var(--aad-s-6);
  transition: all 0.2s;
}
.aad-card-feature:hover { transform: translateY(-3px); box-shadow: var(--aad-shadow-md); border-color: var(--aad-border-strong); }

.aad-card-credential {
  background: var(--aad-surface);
  border: 1px solid var(--aad-border);
  border-radius: var(--aad-r-lg);
  padding: var(--aad-s-6);
  display: flex; flex-direction: column; gap: var(--aad-s-4);
}
.aad-card-credential .doc-num {
  font-family: var(--aad-font-mono);
  font-size: 17px;
  color: var(--aad-primary);
  background: var(--aad-canvas-2);
  padding: 10px 14px;
  border-radius: var(--aad-r-sm);
  display: inline-block;
  font-variant-numeric: tabular-nums;
  word-break: break-all;
}

/* ── Top navigation ── */
.aad-nav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(250,247,240,0.85);
  backdrop-filter: saturate(180%) blur(14px);
  -webkit-backdrop-filter: saturate(180%) blur(14px);
  border-bottom: 1px solid var(--aad-border);
}
.aad-nav-inner {
  max-width: var(--aad-content-max);
  margin: 0 auto;
  padding: 14px var(--aad-s-5);
  display: flex; align-items: center; gap: var(--aad-s-6);
}
.aad-nav-brand { display: flex; align-items: center; gap: 8px; }
.aad-nav-brand img { height: 28px; }
.aad-nav-links { display: flex; align-items: center; gap: var(--aad-s-5); margin-left: auto; }
.aad-nav-links a {
  color: var(--aad-primary); font-weight: var(--aad-w-medium); font-size: 14px;
}
.aad-nav-links a.active { color: var(--aad-signal); }
.aad-nav-cta { margin-left: var(--aad-s-3); }

@media (max-width: 740px) {
  .aad-nav-links a:not(.aad-nav-cta) { display: none; }
}

/* ── Footer ── */
.aad-footer {
  background: var(--aad-primary);
  color: var(--aad-canvas);
  padding: var(--aad-s-8) 0 var(--aad-s-6);
  margin-top: var(--aad-s-9);
}
.aad-footer .aad-container { display: grid; gap: var(--aad-s-7); }
.aad-footer-top { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: var(--aad-s-6); }
.aad-footer h4 {
  font-size: var(--aad-fs-label); letter-spacing: var(--aad-tracking-label);
  text-transform: uppercase; color: rgba(250,247,240,0.6);
  font-weight: var(--aad-w-bold); margin-bottom: var(--aad-s-3);
}
.aad-footer a { color: var(--aad-canvas); opacity: 0.85; font-size: 14px; line-height: 2; }
.aad-footer a:hover { opacity: 1; color: var(--aad-signal); }
.aad-footer-creds { font-family: var(--aad-font-mono); font-size: 12px;
  color: rgba(250,247,240,0.65); line-height: 1.9; }
.aad-footer-creds strong { color: rgba(250,247,240,0.9); font-weight: var(--aad-w-semibold); }
.aad-footer-bottom {
  border-top: 1px solid rgba(250,247,240,0.12);
  padding-top: var(--aad-s-5);
  display: flex; justify-content: space-between; align-items: center;
  font-size: 12px; color: rgba(250,247,240,0.6);
  flex-wrap: wrap; gap: var(--aad-s-3);
}

@media (max-width: 800px) {
  .aad-footer-top { grid-template-columns: 1fr 1fr; }
}

/* ── Hero (reusable across pages) ── */
.aad-hero {
  padding: var(--aad-s-9) 0 var(--aad-s-8);
  background:
    radial-gradient(ellipse at 15% 20%, rgba(79,70,229,0.08), transparent 60%),
    radial-gradient(ellipse at 90% 30%, rgba(255,107,107,0.07), transparent 50%),
    var(--aad-canvas);
}
.aad-hero h1 { max-width: 920px; }
.aad-hero .aad-lede { margin-top: var(--aad-s-4); }
.aad-hero-actions { margin-top: var(--aad-s-6); display: flex; gap: var(--aad-s-3); flex-wrap: wrap; }

/* Grids */
.aad-grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--aad-s-5); }
.aad-grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--aad-s-5); }
.aad-grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--aad-s-4); }
@media (max-width: 900px) { .aad-grid-3, .aad-grid-4 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .aad-grid-2, .aad-grid-3, .aad-grid-4 { grid-template-columns: 1fr; } }

/* Trust strip (used on multiple pages) */
.aad-trust-strip {
  display: flex; flex-wrap: wrap; gap: var(--aad-s-6) var(--aad-s-7);
  justify-content: center; align-items: center;
  padding: var(--aad-s-5) var(--aad-s-6);
  background: var(--aad-canvas-2);
  border-radius: var(--aad-r-lg);
}
.aad-trust-item { font-size: 12px; color: var(--aad-muted-2); }
.aad-trust-item strong { display: block; font-family: var(--aad-font-mono); color: var(--aad-primary);
  font-size: 14px; margin-top: 2px; letter-spacing: -0.01em; }
