/* ===============================
   Bampaa — Dark Theme (Default)
   =============================== */

/* ---- Core tokens (dark-only) ---- */
:root{
  /* palette */
  --bg:#0e1422;
  --text:#e6e9ee;
  --muted:#a6b0be;
  --card:#121a2b;
  --border:#1e2840;

  --brand:#6AA59C;
  --brand-strong:#4B7F76;
  --accent:#FF3131;

  /* shadows, plots, misc */
  --shadow-1:0 10px 28px rgba(0,0,0,.35);
  --plot-bg:transparent;
  --plot-paper:transparent;
  --plot-grid:color-mix(in srgb, var(--text) 14%, transparent);
  --plot-font:var(--text);

  /* tutorial helpers */
  --ink:#e6e8ea;
  --codebg:rgba(0,0,0,0.35);

  /* motion & radius (used below) */
  --speed-fast: .18s ease;
  --radius-xl: 18px;

  /* glow used on selected cards */
  --glow-brand: 0 0 0 1px var(--brand) inset, 0 0 18px rgba(106,165,156,.35);
}

/* ---- Page background / base ---- */
html, body, #_dash-app, #react-entry-point {
  background:
    radial-gradient(1200px 700px at -10% -10%, rgba(106,165,156,.08), transparent 45%),
    radial-gradient(900px 520px at 110% -5%, rgba(106,165,156,.06), transparent 40%),
    var(--bg);
  color: var(--text);
  min-height: 100svh;
}

/* Prevent nested containers from reintroducing white */
.page, .container, .app-wrapper, .dash-debug-menu__outer {
  background: transparent !important;
}

/* ---- Header / nav ---- */
.topbar{
  display:flex;align-items:center;justify-content:space-between;padding:12px 24px;
  background: linear-gradient(
    90deg,
    color-mix(in srgb, var(--card) 92%, transparent),
    color-mix(in srgb, var(--card) 86%, transparent)
  );
  border-bottom:1px solid var(--border);
  box-shadow:var(--shadow-1);
}
.brand-wrap{display:flex;align-items:center;gap:10px}
.brand-logo{width:32px;height:32px;border-radius:9px;background:var(--brand);color:#fff;font-weight:800;display:grid;place-items:center;box-shadow:0 0 18px rgba(106,165,156,.45)}
.brand-name{font-weight:800;color:var(--text)!important;}
.nav-desktop{display:flex;align-items:center;gap:14px}
.nav-link{padding:8px 10px;border-radius:10px;color:var(--text)}
.nav-link.active{background:color-mix(in srgb, var(--brand) 16%, transparent)}
.nav-email{color:var(--muted);font-size:13px}

/* ---- Buttons & inputs ---- */
.btn{border-radius:12px;padding:10px 14px;font-weight:700;border:1px solid transparent;transition:var(--speed-fast)}
.btn:active{transform:translateY(1px)}
.btn-primary{background:linear-gradient(135deg,var(--brand),var(--brand-strong));color:#fff;box-shadow:0 0 18px rgba(106,165,156,.45)}
.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--text)}
.btn { transition: transform var(--speed-fast), box-shadow var(--speed-fast); }
.btn:hover { transform: translateY(-2px); box-shadow: 0 10px 22px rgba(106,165,156,.22); }

.label{font-weight:700;font-size:13px;color:var(--text)}
.input{width:100%;padding:10px 12px;border-radius:10px;background:var(--card);color:var(--text);border:1px solid var(--border)}
.input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px color-mix(in srgb,var(--brand) 25%, transparent)}

/* ---- Cards / glass ---- */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-1)}
.glass{background:color-mix(in srgb,var(--card) 70%, transparent);border:1px solid color-mix(in srgb,var(--border) 85%, transparent);backdrop-filter:blur(10px);border-radius:18px;box-shadow:var(--shadow-1)}

/* ---- Hero ---- */
.hero{max-width:1100px;margin:0 auto;border-radius:24px}
.hero-headline{font-size:clamp(28px,4vw,40px);font-weight:800;margin:6px 0 10px}
.hero-sub{color:var(--muted);margin:0 0 18px}

/* ---- Section title ---- */
.section-title{font-weight:800;margin:8px 0 6px}


/* ---- Dropdowns (react-select) ---- */
.Select-control, .Select-menu-outer { background: var(--card)!important; color: var(--text)!important; }
.Select__placeholder { color:#c9d1d9 !important; }
.Select__single-value { color:#f8f9fa !important; }
.VirtualizedSelectOption { color:#e5e7eb !important; }

/* “bright” variant if used */
.dropdown--bright .Select-placeholder,
.dropdown--bright .Select--single > .Select-control .Select-placeholder {
  color:#b8c7ff !important; opacity:1 !important; font-weight:600;
}
.dropdown--bright .Select-control {
  border-color:#5b6b8a; box-shadow:0 0 0 1px #5b6b8a inset; background-color:var(--card);
}
.dropdown--bright .Select-control:hover { border-color:#7b8bb0; }
.dropdown--bright .Select.is-disabled > .Select-control .Select-placeholder { color:#8896b3 !important; }
.dropdown--bright .Select-input > input { color:var(--text); }

/* ---- Pills / badges ---- */
.pill.badge-brand { box-shadow: 0 0 0 1px var(--brand) inset, 0 0 12px rgba(106,165,156,.25); }

/* ---- Tabs ---- */
.tab{
  background:var(--card); color:var(--muted);
  border:none !important; border-bottom:2px solid transparent !important;
  transition: background .15s ease, color .15s ease, border-color .15s ease;
}
.tab:hover{
  background: color-mix(in srgb, var(--card) 90%, transparent);
  color: var(--text);
  border-bottom-color: color-mix(in srgb, var(--brand) 40%, transparent);
}
.tab--selected{
  background: var(--card) !important;
  color: var(--text) !important;
  border-bottom: 2px solid var(--brand) !important;
  font-weight: 700;
}

/* ---- Layout helpers ---- */
.container { max-width:980px; margin:28px auto; padding:24px; }

/* Fix link underlines/arrow doubling in iOS */
a, a:visited { text-decoration:none; }
.btn, .btn * { text-decoration:none !important; }

/* Action row (desktop default) */
.hero-actions { display:flex; align-items:center; gap:12px; flex-wrap:wrap; }

/* Ghost button style for consistency */
.btn-ghost {
  border:1px solid var(--border);
  background: rgba(255,255,255,0.04);
  border-radius:999px;
  padding:12px 18px;
}
.btn-primary { border-radius:999px; padding:12px 18px; }

/* Tighter header on small screens */
.site-nav { display:flex; align-items:center; gap:8px; flex-wrap:wrap; }

/* ---- Category cards ---- */
.cat-card {
  background: var(--card);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 10px 14px;
  box-shadow: var(--shadow-1);
  cursor: pointer;
  transition: transform var(--speed-fast), box-shadow var(--speed-fast), background var(--speed-fast), border-color var(--speed-fast);
  display: inline-flex;
  flex-direction: column;
  gap: 2px;
}
.cat-card:hover { transform: translateY(-1px); box-shadow: 0 12px 26px rgba(0,0,0,.35); }
.cat-card .cat-title { font-weight:800; letter-spacing:.2px; }
.cat-card .cat-sub { font-size:12px; color:var(--muted); }
.cat-selected { border-color:var(--brand); box-shadow:var(--glow-brand); background: color-mix(in srgb, var(--brand) 10%, var(--card)); }

/* ---- Tutorials / code blocks ---- */
.tut-card { background:var(--card); border:1px solid var(--border); border-radius:12px; padding:16px; }
.tut-card .label { font-size:12px; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); margin-bottom:8px; }
.tut-concept { font-weight:600; color:var(--ink); margin-bottom:8px; }
.tut-h { font-weight:600; margin-right:8px; color:var(--ink); }
.code-block {
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 13px;
  background: var(--codebg);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 10px 12px;
  margin: 8px 0;
  white-space: pre-wrap;
}
.tut-row { margin: 8px 0; }
.tut-details summary { cursor: pointer; color: var(--muted); }
.tut-details { margin-top: 6px; }

/* ---- Responsive breakpoints ---- */
@media (max-width: 980px){
  .container { margin:18px auto; padding:18px; }
}
@media (max-width: 768px){
  html { font-size:15px; }
  .container { margin:14px auto; padding:14px; }
  .hero { border-radius:20px; }
  .hero-headline { font-size:1.85rem; line-height:1.2; }
  .hero-sub { font-size:1rem; }

  /* Buttons stack for mobile */
  .hero-actions { flex-direction:column; align-items:stretch; gap:10px; }
  .hero-actions .btn { width:100%; justify-content:center; }

  /* Smaller chips */
  .pill { font-size:.78rem; padding:6px 10px; }
}
@media (max-width: 380px){
  .hero-headline { font-size:1.6rem; }
  .container { padding:12px; }
}

.btn-danger {
  position: relative;
  z-index: 2;
  pointer-events: auto;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}

/* Prevent nav links from breaking into two lines */
.nav-desktop .nav-link,
.nav-email,
#btn-logout {
    white-space: nowrap !important;
}
.nav-desktop .nav-link {
    padding: 0 4px !important;
}
/* ================================
   FUTURISTIC GLASS FOOTER
   ================================ */

.site-footer.glass-footer {
  background: rgba(255,255,255,0.03);
  border-top: 1px solid rgba(255,255,255,0.08);
  backdrop-filter: blur(10px);
  padding: 40px 20px;
  border-radius: 16px 16px 0 0;
  text-align: center;
  color: var(--muted);
  margin-top: 60px;
}

.glass-footer a {
  color: var(--text);
  text-decoration: none;
  margin: 0 12px;
  font-size: 15px;
}

.glass-footer a:hover {
  color: #6AA59C;
  text-shadow: 0 0 6px rgba(106,165,156,0.8);
}

.footer-links-main {
  margin-bottom: 12px;
}

.footer-links-secondary {
  margin-bottom: 16px;
  opacity: 0.85;
}

.footer-copy {
  opacity: 0.55;
  font-size: 13px;
  margin-top: 12px;
}
/* ================================
   CONTACT PAGE STYLES
================================ */

.contact-section {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 32px;
  margin-top: 30px;
}

.contact-info-card,
.contact-form-card {
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 16px;
  padding: 24px;
}

.contact-email {
  color: #6AA59C;
  font-weight: bold;
  text-decoration: none;
  font-size: 16px;
}

.contact-email:hover {
  text-shadow: 0 0 8px rgba(106,165,156,0.7);
}

.form-group {
  margin-bottom: 18px;
}

.contact-input,
.contact-textarea {
  width: 100%;
  background: rgba(255,255,255,0.04);
  color: var(--text);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 8px;
  padding: 12px;
  margin-top: 6px;
  font-size: 15px;
}

.contact-textarea {
  min-height: 120px;
  resize: vertical;
}

.contact-input:focus,
.contact-textarea:focus {
  outline: none;
  border-color: #6AA59C;
  box-shadow: 0 0 0 2px rgba(106,165,156,0.35);
}

.contact-btn {
  width: 100%;
  padding: 14px;
  margin-top: 10px;
  border: none;
  background: #6AA59C;
  color: black;
  font-weight: 700;
  border-radius: 10px;
  cursor: pointer;
  transition: 0.25s ease-in-out;
}

.contact-btn:hover {
  background: #5a958c;
  box-shadow: 0 0 15px rgba(106,165,156,0.5);
}
/* =======================================
   POLICY PAGE THEME (Privacy, Terms, FAQ)
   ======================================= */

.policy-page {
  padding: 40px 24px;
  display: flex;
  justify-content: center;
}

.policy-wrapper {
  max-width: 880px;
  padding: 40px 40px 60px;
  border-radius: 20px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.07);
  box-shadow: 0 0 25px rgba(0,0,0,0.4);
  backdrop-filter: blur(12px);
}

/* Title */
.policy-title {
  font-size: 34px;
  font-weight: 800;
  margin-bottom: 6px;
  color: var(--text);
}

/* Date */
.policy-date {
  color: var(--muted);
  margin-bottom: 20px;
  font-size: 15px;
}

/* Divider */
.policy-divider {
  border: none;
  height: 1px;
  background: linear-gradient(
    to right,
    rgba(255,255,255,0.05),
    rgba(255,255,255,0.18),
    rgba(255,255,255,0.05)
  );
  margin: 20px 0 35px;
}

/* Headings */
.policy-wrapper h2 {
  font-size: 24px;
  font-weight: 700;
  margin-top: 40px;
  margin-bottom: 12px;
  color: var(--text);
}

.policy-wrapper h3 {
  font-size: 19px;
  font-weight: 600;
  margin-top: 26px;
  margin-bottom: 10px;
  color: var(--text);
}

/* Paragraphs */
.policy-wrapper p {
  line-height: 1.65;
  margin-bottom: 14px;
  color: var(--muted);
  font-size: 16px;
}

/* Lists */
.policy-wrapper ul {
  padding-left: 20px;
  margin-bottom: 18px;
}

.policy-wrapper ul li {
  margin-bottom: 6px;
  line-height: 1.5;
  color: var(--text);
  font-size: 15px;
}

/* Smooth vertical rhythm */
.policy-wrapper > * + * {
  margin-top: 6px;
}
/* ===========================
   BLOG PAGE THEME
   =========================== */

.blog-page {
  padding: 40px 24px;
}

.blog-wrapper {
  max-width: 980px;
  margin: 0 auto;
  padding: 40px 40px 60px;
  border-radius: 20px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.07);
  box-shadow: 0 0 25px rgba(0,0,0,0.4);
  backdrop-filter: blur(12px);
}

/* Hero */
.blog-hero {
  margin-bottom: 30px;
}

.blog-kicker {
  text-transform: uppercase;
  font-size: 12px;
  letter-spacing: 0.16em;
  color: var(--muted);
  margin-bottom: 6px;
}

.blog-title {
  font-size: 32px;
  font-weight: 800;
  margin-bottom: 8px;
}

.blog-subtitle {
  font-size: 15px;
  color: var(--muted);
  max-width: 640px;
}

/* Card grid */
.blog-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 20px;
  margin-bottom: 28px;
}

.blog-card {
  padding: 20px 18px;
  border-radius: 14px;
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.06);
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.blog-tag {
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
}

.blog-card h3 {
  font-size: 18px;
  margin: 4px 0;
}

.blog-card p {
  font-size: 14px;
  color: var(--muted);
}

.blog-card-meta {
  display: flex;
  gap: 10px;
  font-size: 12px;
  color: var(--muted);
}

.blog-card-link {
  margin-top: 6px;
  font-size: 14px;
  text-decoration: none;
  color: #6AA59C;
  font-weight: 600;
}

.blog-card-link:hover {
  text-shadow: 0 0 8px rgba(106,165,156,0.7);
}

/* TOC */
.blog-toc {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(15,23,42,0.7);
  border: 1px solid rgba(148,163,184,0.25);
  margin-bottom: 30px;
  font-size: 13px;
}

.blog-toc-label {
  font-weight: 600;
  color: var(--muted);
}

.blog-toc a {
  text-decoration: none;
  color: var(--text);
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(15,23,42,0.9);
}

.blog-toc a:hover {
  color: #6AA59C;
}

/* Articles */
.blog-article {
  margin-top: 30px;
  padding-top: 10px;
  border-top: 1px solid rgba(148,163,184,0.25);
}

.blog-article:first-of-type {
  border-top: none;
  padding-top: 0;
}

.blog-article-tag {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--muted);
}

.blog-article h2 {
  font-size: 24px;
  margin: 6px 0 4px;
}

.blog-article-meta {
  display: flex;
  gap: 16px;
  font-size: 13px;
  color: var(--muted);
  margin-bottom: 14px;
}

.blog-article p {
  font-size: 15px;
  line-height: 1.7;
  color: var(--muted);
  margin-bottom: 10px;
}

.blog-article ul {
  padding-left: 20px;
  margin-bottom: 14px;
}

.blog-article li {
  font-size: 14px;
  line-height: 1.6;
}

/* Mobile tweaks */
@media (max-width: 640px) {
  .blog-wrapper {
    padding: 26px 18px 40px;
  }

  .blog-title {
    font-size: 26px;
  }
}


html {
  scroll-behavior: smooth;
}

/* So titles aren't hidden under any sticky header */
.blog-article {
  scroll-margin-top: 120px;  /* adjust based on your navbar height */
}
/* Bottom nav: back on left, practice on right */
.blog-footer-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 28px;
  padding-top: 16px;
  border-top: 1px solid rgba(148, 163, 184, 0.35);
}

.blog-footer-back {
  font-size: 14px;
  text-decoration: none;
  color: #6AA59C;
}

.blog-footer-back:hover {
  text-decoration: underline;
}

/* Start practicing pill on bottom right */
.blog-footer-practice {
  font-size: 14px;
  font-weight: 600;
  text-decoration: none;
  padding: 8px 16px;
  border-radius: 999px;
  background: #6AA59C;
  color: #020617;
  box-shadow: 0 0 18px rgba(106, 165, 156, 0.6);
}

.blog-footer-practice:hover {
  filter: brightness(1.05);
  box-shadow: 0 0 24px rgba(106, 165, 156, 0.9);
}

/* Mobile: stack vertically, practice under back link */
@media (max-width: 640px) {
  .blog-footer-nav {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }

  .blog-footer-practice {
    align-self: flex-end;
  }
}

