:root {
  --gold: #C9973A;
  --gold-light: #F0C96A;
  --gold-dim: rgba(201,151,58,0.15);
  --dark: #0C0C0C;
  --dark2: #141414;
  --dark3: #1C1C1C;
  --dark4: #232323;
  --cream: #F2E8D5;
  --green: #2A7355;
  --green-light: #38A876;
  --text: #D8CCB8;
  --text-muted: #6E6252;
  --border: rgba(201,151,58,0.18);
}
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior: smooth; }
body {
  background:
    radial-gradient(70% 60% at 20% 20%, rgba(201,151,58,0.08), transparent 55%),
    radial-gradient(60% 60% at 80% 0%, rgba(100,140,200,0.06), transparent 55%),
    radial-gradient(80% 80% at 50% 110%, rgba(42,115,85,0.12), transparent 70%),
    linear-gradient(180deg, #0c0c0c 0%, #090909 18%, #0c0c0c 38%, #0a0f0d 100%);
  color: var(--text);
  font-family: 'DM Sans', sans-serif;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

nav {
  position: fixed; top:0; width:100%; z-index:200;
  padding: 0 40px; height: 64px;
  display: flex; align-items: center; justify-content: space-between;
  background: rgba(12,12,12,0.82);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--border);
}
.logo-pill { display:flex; align-items:center; gap:8px; }
.logo-box {
  height: 32px; padding: 0 12px; border-radius: 6px;
  display:flex; align-items:center; justify-content:center;
  font-family: 'DM Sans', sans-serif; font-size:12px; font-weight:700; letter-spacing:0.5px; text-transform:uppercase;
}
.logo-img { display:block; max-height:26px; width:auto; max-width:100%; object-fit:contain; }
.logo-qcnet {
  background: linear-gradient(135deg,#1a3a2a,#2A7355);
  color:#7DFFC0; border:1px solid rgba(56,168,118,0.35);
  font-family:'Playfair Display',serif; font-style:normal; font-weight:400; font-size:14px; letter-spacing:0.5px;
}
.logo-megadata {
  background: linear-gradient(135deg,#0a1628,#152847);
  color:#7FB3F5; border:1px solid rgba(100,160,240,0.35);
}
.logo-sep { width:1px; height:20px; background:var(--border); }
.nav-links { display:flex; align-items:center; gap:6px; }
.nav-links a {
  color:var(--text-muted); text-decoration:none;
  font-size:13px; font-weight:500; padding:6px 14px; border-radius:50px; transition:all 0.2s;
}
.nav-links a:hover { color:var(--cream); background:rgba(255,255,255,0.05); }
.nav-links a.active { color:var(--gold-light); background:var(--gold-dim); }
@media(max-width:540px){ nav{padding:0 16px;} .logo-box{font-size:9px;padding:0 8px;height:28px;} .nav-links a{font-size:11px;padding:5px 9px;} }

.hero {
  min-height: 100vh; padding: 120px 24px 80px;
  display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center;
  position:relative; overflow:hidden;
}
.hero-bg { position:absolute; inset:0; pointer-events:none; }
.hero-bg-grad {
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse 70% 50% at 50% -10%, rgba(201,151,58,0.22) 0%, transparent 70%),
    radial-gradient(ellipse 40% 40% at 10% 80%, rgba(42,115,85,0.12) 0%, transparent 60%),
    radial-gradient(ellipse 35% 35% at 90% 70%, rgba(201,151,58,0.08) 0%, transparent 60%);
}
.hero-bg-veil {
  position:absolute; inset:-20% -10% 10% -10%;
  background:
    radial-gradient(60% 50% at 50% 20%, rgba(255,255,255,0.035), transparent 70%),
    radial-gradient(45% 35% at 20% 30%, rgba(201,151,58,0.08), transparent 65%),
    radial-gradient(65% 40% at 80% 25%, rgba(100,140,200,0.07), transparent 70%),
    conic-gradient(from 210deg at 50% 60%, rgba(201,151,58,0.06), transparent 50%);
  filter: blur(32px);
  opacity: 0.9;
}
.hero-bg-vignette {
  position:absolute; inset:-10%;
  background: radial-gradient(circle at 50% 55%, transparent 45%, rgba(0,0,0,0.45) 90%);
  mix-blend-mode: multiply;
}
.hero-noise {
  position:absolute; inset:0; opacity:0.08; mix-blend-mode:soft-light;
  background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="120" height="120" viewBox="0 0 120 120"><filter id="n"><feTurbulence type="fractalNoise" baseFrequency="0.65" numOctaves="2" stitchTiles="stitch"/></filter><rect width="120" height="120" filter="url(%23n)" opacity="0.45"/></svg>');
  pointer-events:none;
}
.hero-ring {
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  width:700px; height:700px;
  border:1px solid rgba(201,151,58,0.07); border-radius:50%;
  animation: spin 40s linear infinite;
}
.hero-ring::before { content:''; position:absolute; inset:60px; border:1px solid rgba(201,151,58,0.05); border-radius:50%; }
.hero-ring::after  { content:''; position:absolute; inset:120px; border:1px dashed rgba(201,151,58,0.04); border-radius:50%; }
@keyframes spin { to{ transform:translate(-50%,-50%) rotate(360deg); } }

.hero-logo {
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  width:220px; max-width:32vw; opacity:0; pointer-events:none;
  filter: drop-shadow(0 12px 24px rgba(0,0,0,0.45));
  animation: heroLogoIn 1.2s 0.25s ease-out forwards;
  transition: filter 0.7s ease;
}
.hero:hover .hero-logo {
  filter: drop-shadow(0 14px 30px rgba(201,151,58,0.26)) drop-shadow(0 0 24px rgba(201,151,58,0.14));
}

.star {
  position:absolute; width:3px; height:3px;
  background:var(--gold); border-radius:50%; opacity:0;
  animation: twinkle var(--d,3s) var(--delay,0s) ease-in-out infinite;
}
@keyframes twinkle { 0%,100%{opacity:0;transform:scale(0.5);} 50%{opacity:0.7;transform:scale(1.2);} }

.hero-eyebrow {
  display:inline-flex; align-items:center; gap:12px;
  background:rgba(201,151,58,0.1); border:1px solid rgba(201,151,58,0.3);
  color:var(--gold-light); font-size:14px; font-weight:700; letter-spacing:2.5px; text-transform:uppercase;
  padding:12px 28px; border-radius:50px; margin-bottom:28px; position:relative;
  animation: riseUp 0.9s 0.1s cubic-bezier(0.22,1,0.36,1) both;
}
.hero-eyebrow svg { width:18px; height:18px; fill:none; stroke:currentColor; stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; }

.hero-title {
  font-family:'Playfair Display',serif; font-size:clamp(52px,10vw,108px);
  font-weight:900; line-height:1.05; letter-spacing:-1px; position:relative;
  animation: riseUp 0.9s 0.2s cubic-bezier(0.22,1,0.36,1) both;
}
.hero-title .t1 { display:block; color:var(--cream); }
.hero-title .t2 {
  display:block; font-style:normal; font-weight:700;
  background:linear-gradient(135deg,#b8832a 0%,#F0C96A 45%,#C9973A 100%);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}

.hero-sub {
  margin-top:14px; font-size:clamp(13px,2.5vw,17px);
  color:var(--text-muted); letter-spacing:5px; text-transform:uppercase; position:relative;
  animation: riseUp 0.9s 0.3s cubic-bezier(0.22,1,0.36,1) both;
}
.hero-sub strong { color:#7FB3F5; font-weight:700; }

@keyframes sheen { from{transform:translateX(-50%);} to{transform:translateX(60%);} }
@keyframes heroLogoIn { from{opacity:0; transform:translate(-50%,-50%) scale(0.94);} to{opacity:0.9; transform:translate(-50%,-50%) scale(1);} }

.event-cards {
  display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-top:52px; max-width:560px; width:100%; position:relative;
  animation: riseUp 0.9s 0.4s cubic-bezier(0.22,1,0.36,1) both;
}
.ecard {
  background:rgba(255,255,255,0.025); border:1px solid var(--border); border-radius:18px;
  padding:20px 22px; text-align:left;
  transition:all 0.3s cubic-bezier(0.22,1,0.36,1); cursor:default;
}
.ecard:hover { background:rgba(201,151,58,0.07); border-color:rgba(201,151,58,0.4); transform:translateY(-6px); box-shadow:0 16px 40px rgba(0,0,0,0.4); }
.ecard-icon {
  width:36px; height:36px; background:var(--gold-dim); border-radius:10px;
  display:flex; align-items:center; justify-content:center; margin-bottom:12px;
}
.ecard-icon svg { width:18px; height:18px; fill:none; stroke:var(--gold-light); stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; }
.ecard-label { font-size:9px; letter-spacing:2.5px; text-transform:uppercase; color:var(--text-muted); margin-bottom:5px; }
.ecard-val { font-size:14px; font-weight:600; color:var(--cream); line-height:1.4; }
.ecard-sub { font-size:11px; color:var(--text-muted); margin-top:2px; }

.hero-cta {
  margin-top:44px; display:flex; gap:14px; flex-wrap:wrap; justify-content:center; position:relative;
  animation: riseUp 0.9s 0.5s cubic-bezier(0.22,1,0.36,1) both;
}
.btn-gold {
  display:inline-flex; align-items:center; gap:8px;
  background:linear-gradient(135deg,#b8832a,#F0C96A,#b8832a); background-size:200% 100%;
  color:#1a0e00; font-family:'DM Sans',sans-serif; font-size:14px; font-weight:700;
  padding:15px 36px; border-radius:50px; border:none; cursor:pointer; text-decoration:none;
  transition:all 0.4s; box-shadow:0 8px 32px rgba(201,151,58,0.35);
}
.btn-gold:hover { background-position:100% 0; transform:translateY(-3px); box-shadow:0 14px 40px rgba(201,151,58,0.5); }
.btn-gold svg { width:16px; height:16px; fill:none; stroke:currentColor; stroke-width:2.2; stroke-linecap:round; stroke-linejoin:round; }
.btn-ghost {
  display:inline-flex; align-items:center; gap:8px; background:transparent;
  border:1px solid var(--border); color:var(--text); font-family:'DM Sans',sans-serif;
  font-size:14px; font-weight:500; padding:15px 28px; border-radius:50px; cursor:pointer; text-decoration:none; transition:all 0.3s;
}
.btn-ghost:hover { border-color:rgba(201,151,58,0.4); color:var(--gold-light); background:var(--gold-dim); }
.btn-ghost svg { width:15px; height:15px; fill:none; stroke:currentColor; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }

@keyframes riseUp { from{opacity:0;transform:translateY(40px);} to{opacity:1;transform:translateY(0);} }

.hr { width:100%; height:1px; background:linear-gradient(90deg,transparent 0%,rgba(201,151,58,0.25) 30%,rgba(201,151,58,0.25) 70%,transparent 100%); }

.section { padding:88px 24px; }
.section.alt { background:var(--dark2); }
.section-inner { max-width:920px; margin:0 auto; }
.s-eyebrow { font-size:9px; letter-spacing:4px; text-transform:uppercase; color:var(--gold); font-weight:700; margin-bottom:10px; }
.s-title { font-family:'Playfair Display',serif; font-size:clamp(26px,5vw,42px); color:var(--cream); line-height:1.1; margin-bottom:36px; }

.carousel-wrap { position:relative; overflow:hidden; border-radius:20px; user-select:none; }
.carousel-track {
  display:flex; transition:transform 0.55s cubic-bezier(0.77,0,0.175,1); will-change:transform;
}
.carousel-slide {
  min-width:100%; position:relative; aspect-ratio:16/7;
  background:var(--dark3); overflow:hidden; border-radius:20px;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.carousel-slide .ph {
  position:absolute; inset:0;
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:12px;
}
.slide-ph-1 { background:linear-gradient(135deg,#0f1e14,#1a3a25,#0a1510); }
.slide-ph-2 { background:linear-gradient(135deg,#1a1208,#2e1e0a,#120d04); }
.slide-ph-3 { background:linear-gradient(135deg,#0d1520,#1a2a3a,#080f18); }
.slide-ph-4 { background:linear-gradient(135deg,#1a0f0a,#3a1f10,#120a06); }
.slide-ph-5 { background:linear-gradient(135deg,#12100a,#261e08,#0e0c04); }
.ph-grid {
  position:absolute; inset:0;
  background-image: linear-gradient(rgba(255,255,255,0.02) 1px,transparent 1px), linear-gradient(90deg,rgba(255,255,255,0.02) 1px,transparent 1px);
  background-size:40px 40px;
}
.ph-icon {
  width:56px; height:56px; border-radius:16px;
  display:flex; align-items:center; justify-content:center; position:relative; z-index:1;
}
.ph-icon svg { width:28px; height:28px; fill:none; stroke-width:1.5; stroke-linecap:round; stroke-linejoin:round; }
.ph-year {
  font-family:'Playfair Display',serif; font-size:56px; font-weight:900;
  line-height:1; opacity:0.12; position:relative; z-index:1;
}
.ph-label { font-size:11px; letter-spacing:3px; text-transform:uppercase; opacity:0.3; margin-top:4px; position:relative; z-index:1; }
.ph-badge {
  position:absolute; bottom:16px; left:50%; transform:translateX(-50%);
  font-size:10px; letter-spacing:2px; text-transform:uppercase;
  background:rgba(0,0,0,0.5); border:1px solid rgba(255,255,255,0.08);
  padding:4px 14px; border-radius:50px; white-space:nowrap; z-index:5;
  color:rgba(255,255,255,0.3);
}
.carousel-slide::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(to top,rgba(0,0,0,0.6) 0%,transparent 50%);
  pointer-events:none; z-index:3;
}
.slide-caption { position:absolute; bottom:24px; left:28px; z-index:4; }
.slide-caption .cap-year { font-family:'Playfair Display',serif; font-size:22px; font-weight:700; color:var(--cream); }
.slide-caption .cap-desc { font-size:11px; color:rgba(255,255,255,0.45); letter-spacing:1px; margin-top:3px; }

.car-btn {
  position:absolute; top:50%; transform:translateY(-50%); z-index:10;
  width:44px; height:44px; background:rgba(12,12,12,0.7);
  border:1px solid var(--border); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:all 0.25s; backdrop-filter:blur(8px);
}
.car-btn:hover { background:rgba(201,151,58,0.2); border-color:var(--gold); }
.car-btn svg { width:16px; height:16px; stroke:var(--text); fill:none; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }
.car-btn:hover svg { stroke:var(--gold-light); }
.car-prev { left:16px; }
.car-next { right:16px; }
.car-dots { display:flex; justify-content:center; gap:8px; margin-top:20px; }
.dot { width:6px; height:6px; border-radius:50%; background:rgba(255,255,255,0.15); cursor:pointer; transition:all 0.3s; }
.dot.active { width:24px; border-radius:3px; background:var(--gold); }

.form-card { background:var(--dark3); border:1px solid var(--border); border-radius:24px; padding:40px; }
@media(max-width:600px){ .form-card{padding:24px 20px;} }
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
@media(max-width:580px){ .form-grid{grid-template-columns:1fr;} }
.fgroup { display:flex; flex-direction:column; gap:7px; margin-bottom:4px; }
.fgroup.full { grid-column:1/-1; }
.fgroup label {
  font-size:10px; letter-spacing:2px; text-transform:uppercase;
  color:var(--text-muted); font-weight:600; display:flex; align-items:center; gap:6px;
}
.fgroup label svg { width:12px; height:12px; fill:none; stroke:var(--text-muted); stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }
.fgroup input, .fgroup select {
  background:rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.08);
  border-radius:12px; padding:13px 16px; color:var(--cream);
  font-family:'DM Sans',sans-serif; font-size:14px; outline:none; transition:all 0.25s; appearance:none;
}
.fgroup input::placeholder { color:var(--text-muted); opacity:0.6; }
.fgroup input:focus, .fgroup select:focus {
  border-color:var(--gold); background:rgba(201,151,58,0.05); box-shadow:0 0 0 3px rgba(201,151,58,0.1);
}
.fgroup select option { background:#1C1C1C; color:var(--cream); }
.btn-register {
  width:100%; display:flex; align-items:center; justify-content:center; gap:10px;
  background:linear-gradient(135deg,var(--green),var(--green-light));
  color:#fff; border:none; border-radius:14px; padding:17px;
  font-size:15px; font-weight:700; font-family:'DM Sans',sans-serif; cursor:pointer;
  margin-top:24px; transition:all 0.3s; box-shadow:0 6px 24px rgba(42,115,85,0.35);
}
.btn-register:hover { transform:translateY(-3px); box-shadow:0 12px 32px rgba(42,115,85,0.45); }
.btn-register svg { width:18px; height:18px; fill:none; stroke:#fff; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }

.stats-row { display:flex; gap:14px; margin-bottom:28px; flex-wrap:wrap; }
.stat-card { flex:1; min-width:110px; background:var(--dark3); border:1px solid var(--border); border-radius:16px; padding:20px 22px; }
.stat-num { font-family:'Playfair Display',serif; font-size:40px; font-weight:900; color:var(--gold-light); line-height:1; }
.stat-lbl { font-size:10px; letter-spacing:2px; text-transform:uppercase; color:var(--text-muted); margin-top:6px; }
.tbl-wrap { overflow-x:auto; border-radius:16px; border:1px solid rgba(255,255,255,0.05); }
table { width:100%; border-collapse:collapse; font-size:13px; min-width:640px; }
thead tr { background:rgba(201,151,58,0.07); }
th { padding:14px 18px; text-align:left; font-size:9px; letter-spacing:2.5px; text-transform:uppercase; color:var(--gold); font-weight:700; border-bottom:1px solid var(--border); white-space:nowrap; }
td { padding:13px 18px; border-bottom:1px solid rgba(255,255,255,0.04); color:var(--text); vertical-align:middle; }
tr:last-child td { border-bottom:none; }
tbody tr:hover td { background:rgba(255,255,255,0.02); }
.chip { display:inline-flex; align-items:center; gap:5px; padding:4px 12px; border-radius:50px; font-size:11px; font-weight:600; white-space:nowrap; }
.chip-hadir { background:rgba(42,115,85,0.2); color:#5DD9A4; border:1px solid rgba(42,115,85,0.4); }
.chip-belum { background:rgba(255,255,255,0.04); color:var(--text-muted); border:1px solid rgba(255,255,255,0.08); }
.chip svg { width:10px; height:10px; fill:none; stroke:currentColor; stroke-width:2.5; stroke-linecap:round; stroke-linejoin:round; }
.reg-num-cell { font-family:'Playfair Display',serif; font-size:16px; font-weight:700; color:var(--gold-light); }
.empty-row td { text-align:center; padding:60px 20px; color:var(--text-muted); font-size:13px; }

.overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,0.88); z-index:500; align-items:center; justify-content:center; padding:20px; backdrop-filter:blur(12px); }
.overlay.show { display:flex; }
.modal {
  background:var(--dark2); border:1px solid rgba(201,151,58,0.25); border-radius:28px;
  padding:44px 36px 36px; max-width:420px; width:100%; text-align:center; position:relative;
  animation:popIn 0.45s cubic-bezier(0.34,1.56,0.64,1) both;
}
@keyframes popIn { from{opacity:0;transform:scale(0.75) translateY(30px);} to{opacity:1;transform:scale(1) translateY(0);} }
.modal-x {
  position:absolute; top:16px; right:16px; width:30px; height:30px; border-radius:50%;
  background:rgba(255,255,255,0.05); border:none; color:var(--text-muted); cursor:pointer;
  display:flex; align-items:center; justify-content:center; font-size:15px; transition:all 0.2s;
}
.modal-x:hover { background:rgba(255,255,255,0.1); color:var(--cream); }
.modal-eyebrow { font-size:9px; letter-spacing:3px; text-transform:uppercase; color:var(--text-muted); margin-bottom:6px; }
.modal-regnum {
  font-family:'Playfair Display',serif; font-size:52px; font-weight:900; line-height:1;
  background:linear-gradient(135deg,var(--gold) 0%,var(--gold-light) 60%);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.modal-name { font-size:19px; font-weight:700; color:var(--cream); margin-top:10px; }
.modal-org  { font-size:12px; color:var(--text-muted); margin-top:4px; }
.qr-container { display:inline-block; background:#fff; border-radius:16px; padding:14px; margin:22px 0 8px; box-shadow:0 8px 40px rgba(201,151,58,0.2); }
.modal-hint { font-size:11px; color:var(--text-muted); letter-spacing:0.3px; line-height:1.6; }
.btn-dl {
  display:inline-flex; align-items:center; gap:8px; background:var(--gold-dim);
  border:1px solid rgba(201,151,58,0.3); color:var(--gold-light);
  padding:10px 24px; border-radius:50px; font-size:13px; font-weight:600;
  font-family:'DM Sans',sans-serif; cursor:pointer; margin-top:14px; transition:all 0.2s;
}
.btn-dl:hover { background:rgba(201,151,58,0.2); }
.btn-dl svg { width:14px; height:14px; fill:none; stroke:currentColor; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }

#scan-page { display:none; min-height:100vh; align-items:center; justify-content:center; padding:40px 20px; background:var(--dark); }
#scan-page.active { display:flex; }
.scan-card { background:var(--dark2); border:1px solid var(--border); border-radius:28px; padding:52px 40px 44px; max-width:460px; width:100%; text-align:center; }
@media(max-width:480px){ .scan-card{padding:36px 24px 32px;} }
.scan-icon-wrap {
  width:72px; height:72px; border-radius:20px; background:var(--gold-dim); border:1px solid rgba(201,151,58,0.25);
  display:flex; align-items:center; justify-content:center; margin:0 auto 20px;
}
.scan-icon-wrap svg { width:32px; height:32px; fill:none; stroke:var(--gold-light); stroke-width:1.6; stroke-linecap:round; stroke-linejoin:round; }
.scan-title { font-family:'Playfair Display',serif; font-size:28px; color:var(--cream); margin-bottom:8px; }
.scan-person { font-size:15px; color:var(--text-muted); line-height:1.5; }
.scan-person strong { color:var(--gold-light); }
.code-field {
  width:100%; background:rgba(255,255,255,0.03); border:2px solid rgba(255,255,255,0.08);
  border-radius:14px; padding:16px; color:var(--cream); font-family:'DM Sans',sans-serif;
  font-size:16px; text-align:center; letter-spacing:3px; outline:none; transition:all 0.3s; margin:24px 0 14px;
}
.code-field:focus { border-color:var(--gold); background:rgba(201,151,58,0.05); box-shadow:0 0 0 4px rgba(201,151,58,0.1); }
.scan-feedback { display:none; margin-top:20px; padding:18px 20px; border-radius:14px; font-size:14px; line-height:1.6; text-align:left; }
.scan-feedback.ok { display:block; background:rgba(42,115,85,0.15); border:1px solid rgba(42,115,85,0.4); color:#6EEAB0; }
.scan-feedback.err { display:block; background:rgba(180,50,50,0.15); border:1px solid rgba(180,50,50,0.4); color:#FF8080; }

.toast {
  position:fixed; bottom:28px; left:50%; transform:translateX(-50%) translateY(80px);
  background:var(--dark3); border:1px solid var(--border); color:var(--cream);
  padding:12px 24px; border-radius:50px; font-size:13px; z-index:9999;
  transition:transform 0.4s cubic-bezier(0.34,1.56,0.64,1); white-space:nowrap; pointer-events:none;
}
.toast.show { transform:translateX(-50%) translateY(0); }

footer { padding:40px 24px; text-align:center; border-top:1px solid var(--border); }
footer p { font-size:12px; color:var(--text-muted); letter-spacing:0.5px; }
.foot-logos { display:inline-flex; align-items:center; gap:10px; margin-bottom:12px; }
.foot-logos .logo-img { max-height:26px !important; }
