/* =========================================================
   Aetherbound Shared Theme (warm mystic galaxy)
   Used by: index.php, dashboard.php, etc.
   ========================================================= */

:root{
  --bg:#0d0b16;

  --text:#f2eefc;
  --muted:rgba(242,238,252,.72);

  /* Base surfaces */
  --panel: rgba(24,16,34,.72);
  --card:  rgba(18,12,26,.62);

  /* Borders + radius */
  --border:  rgba(255,255,255,.08);
  --border2: rgba(190,120,255,.35);
  --radius: 16px;

  /* Shadows */
  --shadow: 0 18px 60px rgba(0,0,0,.55);

  /* Accents */
  --accent1: rgba(205,120,255,1);
  --accent2: rgba(255,140,190,1);
  --accent3: rgba(150,110,255,1);
}

*{ box-sizing:border-box; }

html, body{ height:100%; }

body{
  margin:0;
  color:var(--text);
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  line-height: 1.55;
  letter-spacing: .01em;

  /* Warm galaxy background */
  background:
    radial-gradient(1100px 700px at 20% 15%, rgba(255,140,190,.22), transparent 60%),
    radial-gradient(1200px 900px at 70% 25%, rgba(205,120,255,.20), transparent 60%),
    radial-gradient(900px 700px at 45% 80%, rgba(150,110,255,.14), transparent 62%),
    radial-gradient(800px 600px at 90% 75%, rgba(255,185,130,.08), transparent 60%),
    linear-gradient(180deg, rgba(8,6,12,1), rgba(6,5,10,1) 55%, rgba(7,6,12,1));
  background-attachment: fixed;
}

/* Subtiele “sterren” laag */
body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:-1;
  opacity:.55; /* was .35 */
  background:
    radial-gradient(circle at 10% 18%, rgba(255,255,255,.85) 0 1px, transparent 2px),
    radial-gradient(circle at 74% 14%, rgba(255,255,255,.65) 0 1px, transparent 2px),
    radial-gradient(circle at 30% 72%, rgba(255,255,255,.55) 0 1px, transparent 2px),
    radial-gradient(circle at 88% 62%, rgba(255,255,255,.65) 0 1px, transparent 2px),
    radial-gradient(circle at 56% 46%, rgba(255,255,255,.45) 0 1px, transparent 2px),
    radial-gradient(circle at 42% 28%, rgba(255,200,240,.55) 0 1px, transparent 2px),
    radial-gradient(circle at 20% 86%, rgba(200,170,255,.40) 0 1px, transparent 2px);
  filter: blur(.2px);
}

body::after{
  content:"";
  position:fixed;
  inset:-20%;
  pointer-events:none;
  z-index:-1;
  opacity:.10;
  background:
    radial-gradient(circle at 20% 30%, rgba(255,140,190,.55), transparent 45%),
    radial-gradient(circle at 70% 20%, rgba(205,120,255,.55), transparent 48%),
    radial-gradient(circle at 45% 80%, rgba(150,110,255,.45), transparent 52%);
  animation: ab_shimmer 18s ease-in-out infinite;
}

@keyframes ab_shimmer{
  0%   { transform: translate3d(0,0,0) scale(1);   opacity:.08; }
  50%  { transform: translate3d(-1.5%,1%,0) scale(1.02); opacity:.12; }
  100% { transform: translate3d(0,0,0) scale(1);   opacity:.08; }
}

/* =========================================================
   Shared surfaces: panel / card / hero
   ========================================================= */

.panel{
  background:
    linear-gradient(180deg, rgba(70,30,110,.55), rgba(25,15,45,.55)),
    var(--panel);
  border: 1px solid rgba(180,120,255,.18);
  box-shadow:
    0 18px 60px rgba(0,0,0,.45),
    inset 0 0 0 1px rgba(255,160,220,.05);
  backdrop-filter: blur(10px);
  border-radius: var(--radius);
  padding: 18px 18px 20px;
}

.card{
  background:
    linear-gradient(180deg, rgba(55,25,90,.45), rgba(20,10,35,.45)),
    var(--card);
  border: 1px solid rgba(170,120,255,.16);
  box-shadow: 0 14px 46px rgba(0,0,0,.45);
  border-radius: var(--radius);
  padding: 14px 16px;
}

/* Hero specifics (zonder layout/padding; dat blijft per pagina) */
.hero{
  background:
    linear-gradient(180deg, rgba(70,30,110,.55), rgba(25,15,45,.55)),
    var(--panel);
  border: 1px solid rgba(180,120,255,.18);
  box-shadow:
    0 18px 60px rgba(0,0,0,.45),
    inset 0 0 0 1px rgba(255,160,220,.05);
  backdrop-filter: blur(10px);
  border-radius: var(--radius);
  padding: 18px 18px 20px;

  position: relative;
  overflow: hidden;
}

/* =========================================================
   Hero art layer (CSS-only)
   ========================================================= */
/* Nebula ribbons + soft bloom */
.hero::before{
  content:"";
  position:absolute;
  inset:-40px;
  pointer-events:none;
  z-index:0;

  background:
    radial-gradient(900px 520px at 18% 12%, rgba(255,140,190,.22), transparent 62%),
    radial-gradient(760px 520px at 70% 22%, rgba(205,120,255,.20), transparent 64%),
    radial-gradient(680px 520px at 52% 88%, rgba(150,110,255,.16), transparent 68%),
    conic-gradient(from 210deg at 60% 30%,
      rgba(255,140,190,.10),
      rgba(205,120,255,.10),
      rgba(150,110,255,.08),
      rgba(255,185,130,.06),
      rgba(255,140,190,.10)
    );

  opacity:.95;
  filter: blur(.2px);
  transform: translateZ(0);
}

/* Rune-ish shimmer overlay (subtle) */
.hero::after{
  content:"";
  position:absolute;
  inset:-1px;
  pointer-events:none;
  z-index:1;

  /* two layers:
     - faint diagonal "runes"
     - tiny star dust
  */
  background:
    repeating-linear-gradient(
      115deg,
      rgba(255,255,255,.06) 0px,
      rgba(255,255,255,.06) 1px,
      transparent 1px,
      transparent 18px
    ),
    radial-gradient(circle at 12% 28%, rgba(255,255,255,.55) 0 1px, transparent 2px),
    radial-gradient(circle at 78% 22%, rgba(255,255,255,.45) 0 1px, transparent 2px),
    radial-gradient(circle at 40% 70%, rgba(255,255,255,.35) 0 1px, transparent 2px),
    radial-gradient(circle at 66% 78%, rgba(255,255,255,.30) 0 1px, transparent 2px);

  opacity:.10;
  mix-blend-mode: screen;
  animation: ab_hero_drift 22s ease-in-out infinite;
}

@keyframes ab_hero_drift{
  0%   { transform: translate3d(0,0,0); opacity:.08; }
  50%  { transform: translate3d(-1.2%,0.8%,0); opacity:.12; }
  100% { transform: translate3d(0,0,0); opacity:.08; }
}

/* Ensure hero content stays above the art layers */
.hero > *{
  position:relative;
  z-index:2;
}

/* Zachte rand-glow laag */
.panel,
.hero,
.card{
  position: relative;
}

.panel::after,
.hero::after,
.card::after{
  content:"";
  position:absolute;
  inset:-1px;
  border-radius: inherit;
  pointer-events:none;
  background:
    radial-gradient(700px 260px at 12% 0%, rgba(255,140,200,.16), transparent 60%),
    radial-gradient(520px 220px at 85% 15%, rgba(205,120,255,.12), transparent 62%),
    linear-gradient(180deg, rgba(255,255,255,.06), transparent 28%);
  opacity:.95;
  mix-blend-mode: screen;
}

.panel:hover,
.card:hover{
  filter: brightness(1.03);
}

/* =========================================================
   Typography
   ========================================================= */

h1,h2,h3{ margin:0; }
h2{
  margin: 26px 0 14px;
  font-size: 26px;
  font-weight: 650;
}

/* Links */
a{ color: inherit; }
a:hover{ text-decoration: none; }

/* =========================================================
   Utilities
   ========================================================= */

.muted{ color:var(--muted); }

.uuidmono{
  color: rgba(242,238,252,.92);
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas,
               "Liberation Mono", "Courier New", monospace;
  font-size: 12px;
}

.mutedline{
  color: var(--muted);
  font-size: 13px;
}

/* Badge (used on index + dashboard) */
.badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 10px;
  border-radius:999px;
  background: rgba(20,12,35,.65);
  border: 1px solid rgba(190,120,255,.30);
  font-size:12px;
}

/* =========================================================
   Topbar / Nav (shared)
   ========================================================= */

.topbar{
  display:grid;
  grid-template-columns: 1fr auto 1fr;
  align-items:center;
  gap:18px;
  padding:12px 14px;
  border-radius: var(--radius);
  background:
    linear-gradient(180deg, rgba(70,30,110,.55), rgba(25,15,45,.55)),
    var(--panel);
  border: 1px solid rgba(190,120,255,.25);
  box-shadow: 0 18px 60px rgba(0,0,0,.35);
  backdrop-filter: blur(10px);
}

.navleft{
  display:flex;
  gap:18px;
  align-items:center;
}

.navright{
  display:flex;
  gap:18px;
  align-items:center;
  justify-content:flex-end;   /* 👈 force right alignment */
}

.navleft a, .navright a{
  color: var(--muted);
  text-decoration:none;
  font-size:14px;
}

.navleft a:hover, .navright a:hover{
  color: var(--text);
}

.brand{
  display:flex;
  flex-direction:column;
  align-items:center;
  line-height:1;
  user-select:none;
}

.brand .title{
  font-size:28px;
  letter-spacing:.06em;
}

.brand .sub{
  font-size:11px;
  letter-spacing:.22em;
  color: var(--muted);
  margin-top:4px;
}

.topbarSub{
  grid-column: 1 / -1;
  display:flex;
  justify-content:space-between;
  gap:12px;
  margin-top:8px;
  padding-top:10px;
  border-top:1px solid rgba(255,255,255,.08);
  flex-wrap:wrap;
}

.pillrow{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

/* =========================================================
   Buttons (shared to keep index+dashboard identical)
   ========================================================= */

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 14px;
  border-radius:12px;
  background: linear-gradient(180deg, rgba(70,40,115,.78), rgba(28,18,48,.78));
  border: 1px solid rgba(190,120,255,.35);
  color: var(--text);
  text-decoration:none;
  font-size:14px;
  box-shadow: 0 14px 40px rgba(0,0,0,.40);
  cursor:pointer;
  transition: transform .08s ease, filter .16s ease;
}

.btn:hover{
  filter: brightness(1.06);
  transform: translateY(-1px);
}

.btn:active{
  transform: translateY(1px);
}

.btn.ghost{
  background: rgba(10,8,16,.35);
  border: 1px solid rgba(190,120,255,.22);
  color: rgba(242,238,252,.82);
  box-shadow: none;
}

.btn[disabled]{
  opacity:.55;
  cursor:not-allowed;
  transform:none;
}

/* =========================================================
   Grids / stacks (shared building blocks)
   ========================================================= */

.grid3{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:14px;
}

.mainGrid{
  display:grid;
  grid-template-columns: 2fr 1fr;
  gap:14px;
  align-items:start;
}

.qaStack{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-top:12px;
}
.qaStack .btn{ width:100%; }

/* Stat helpers (optional but used on dashboard) */
.label{
  display:flex;
  gap:10px;
  align-items:center;
  color: var(--muted);
  font-size:14px;
}
.value{
  margin-top:12px;
  font-size:28px;
  font-weight:700;
  display:flex;
  gap:8px;
  align-items:baseline;
}
.value span{
  font-size:14px;
  color: var(--muted);
  font-weight:500;
}
.sub{
  margin-top:8px;
  font-size:13px;
  color: var(--muted);
}

/* =========================================================
   Tables (shared; supports .table class AND plain table)
   ========================================================= */

table,
.table{
  width:100%;
  border-collapse:collapse;
  font-size:14px;
  margin-top:6px;
}

table th,
.table th{
  text-align:left;
  color:var(--muted);
  font-weight:600;
  padding:10px 10px;
  border-bottom:1px solid rgba(255,255,255,.08);
}

table td,
.table td{
  padding:10px 10px;
  border-bottom:1px solid rgba(255,255,255,.06);
  vertical-align:top;
}

/* =========================================================
   Toast + spinner (shared)
   ========================================================= */

.toast{
  display:none;
  margin-top:12px;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(15,13,22,.65);
  color: rgba(242,238,252,.92);
  font-size:13px;
}

.toast.info{ border-color: rgba(255,255,255,.18); }
.toast.ok  { border-color: rgba(120,255,180,.28); }
.toast.err { border-color: rgba(255,120,120,.28); }

.spin{
  display:inline-block;
  width:12px;
  height:12px;
  margin-right:8px;
  border-radius:50%;
  border:2px solid rgba(242,238,252,.35);
  border-top-color: rgba(242,238,252,.90);
  vertical-align:-2px;
  animation: ab_spin .8s linear infinite;
}

@keyframes ab_spin{
  to{ transform: rotate(360deg); }
}

/* =========================================================
   Modal (shared)
   ========================================================= */

.backdrop{
  display:none;
  position:fixed;
  inset:0;
  background: rgba(0,0,0,.55);
  z-index:9998;
}

.modal{
  display:none;
  position:fixed;
  left:50%;
  top:50%;
  transform: translate(-50%,-50%);
  width: min(560px, calc(100vw - 24px));
  border-radius:16px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(15,13,22,.92);
  box-shadow: 0 18px 60px rgba(0,0,0,.55);
  padding:16px;
  z-index:9999;
}

/* =========================================================
   Footer (shared)
   ========================================================= */

.footer{
  margin-top:22px;
  color:var(--muted);
  font-size:12px;
  text-align:center;
}

/* =========================================================
   Responsive
   ========================================================= */

@media (max-width: 900px){
  .grid3{ grid-template-columns: 1fr; }
  .mainGrid{ grid-template-columns: 1fr; }
  .topbarSub{ justify-content:flex-start; }
}

/* =========================================================
   Rune divider (section separator)
   Usage: <div class="rune-divider" aria-hidden="true"></div>
   ========================================================= */

.rune-divider{
  position: relative;
  height: 28px;
  margin: 26px 0 18px;
  opacity: .95;
}

.rune-divider::before{
  /* main line */
  content:"";
  position:absolute;
  left: 0;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  height: 1px;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(190,120,255,.22),
    rgba(255,140,190,.16),
    rgba(190,120,255,.22),
    transparent
  );
  box-shadow: 0 0 18px rgba(205,120,255,.10);
}

.rune-divider::after{
  /* center rune glyph + glow */
  content:"✧";
  position:absolute;
  left:50%;
  top:50%;
  transform: translate(-50%,-52%);
  width: 44px;
  height: 22px;
  display:flex;
  align-items:center;
  justify-content:center;

  color: rgba(242,238,252,.82);
  font-size: 14px;
  letter-spacing: .14em;

  background:
    radial-gradient(circle at 50% 50%, rgba(205,120,255,.20), transparent 62%),
    radial-gradient(circle at 50% 50%, rgba(255,140,190,.10), transparent 70%);
  border: 1px solid rgba(190,120,255,.18);
  border-radius: 999px;

  box-shadow:
    0 0 22px rgba(205,120,255,.16),
    inset 0 0 0 1px rgba(255,255,255,.06);
}

/* optional subtle side runes */
.rune-divider i{
  display:none; /* enabled if you add <i></i> inside */
}

/* =========================================================
   Topbar mobile fix (prevent navright overflow)
   ========================================================= */

.topbar {
  /* helps prevent children from visually escaping rounded corners */
  overflow: hidden;
}

@media (max-width: 720px){
  .topbar{
    grid-template-columns: 1fr;
    grid-auto-rows: auto;
    gap: 10px;
    padding: 10px 12px;
  }

  .brand{
    min-width: 0;               /* important: allow shrink */
    order: 1;
  }

  .navleft{
    order: 2;
    justify-content: center;
    flex-wrap: wrap;
  }

  .navright{
    order: 3;
    justify-content: center;
    flex-wrap: wrap;
  }
}

