/* public/css/style.css
   EclipX — Modern neon theme
   Centered layout and admin reuse. Place this file at /root/website/public/css/style.css
*/
:root{
  --bg-dark:#07020a;
  --card:#0e0810;
  --muted:#c8aee3;
  --accent1:#b84dff;
  --accent2:#6b00ff;
  --glass: rgba(255,255,255,0.03);
  --glass-2: rgba(255,255,255,0.02);
  --success:#7bf0c7;
  --danger:#ff6b6b;
  --max-width:1000px;
}

/* Reset / base */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:Inter, "Segoe UI", Roboto, Arial, sans-serif;
  background: linear-gradient(180deg, #030010 0%, #090017 50%, #060014 100%);
  color:#fff;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  line-height:1.35;
}

/* Accessibility helpers */
.sr-only{position:absolute!important;height:1px;width:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.visually-hidden{display:none !important}

/* Animated background orbs */
.bg{position:fixed;inset:0;overflow:hidden;pointer-events:none;z-index:0}
.orb{position:absolute;border-radius:50%;filter:blur(60px);opacity:0.7;mix-blend-mode:screen}
.orb-1{width:480px;height:480px;left:-10%;top:-10%;background:linear-gradient(180deg,var(--accent1),var(--accent2));animation:float1 18s ease-in-out infinite}
.orb-2{width:360px;height:360px;right:-8%;bottom:-12%;background:linear-gradient(180deg,#00d4ff,#6b00ff);animation:float2 22s ease-in-out infinite}
@keyframes float1{0%{transform:translateY(0) translateX(0)}50%{transform:translateY(24px) translateX(12px)}100%{transform:translateY(0) translateX(0)}}
@keyframes float2{0%{transform:translateY(0) translateX(0)}50%{transform:translateY(-30px) translateX(-10px)}100%{transform:translateY(0) translateX(0)}}

/* CENTERED LAYOUT: page-center will always center content horizontally and vertically */
.page-center{
  position:relative;z-index:1;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:32px;
}
.centered-layout{width:100%;max-width:var(--max-width);display:flex;gap:24px;align-items:flex-start;justify-content:center}

/* Card base */
.card{
  background:linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));
  border-radius:14px;padding:16px;box-shadow:0 12px 40px rgba(107,0,255,0.06);backdrop-filter:blur(6px);
}

/* HERO / MAIN */
.hero-card{
  flex:1;min-width:0;display:flex;flex-direction:column;gap:12px;padding:22px;border-radius:14px;
}
.hero-header{display:flex;gap:12px;align-items:center}
.logo{width:46px;height:46px;flex:0 0 46px}
.brand{margin:0;font-size:28px;color:var(--accent1);line-height:1}
.lead{margin:0;color:var(--muted);font-size:14px}

/* Form */
.hero-body{display:flex;flex-direction:column;gap:8px}
.redeem-form input, textarea, select{
  width:100%;padding:12px 14px;border-radius:12px;border:none;background:var(--glass);color:#fff;font-size:15px;outline:none;box-shadow:inset 0 0 0 1px rgba(255,255,255,0.02);
}
.redeem-form input:focus, textarea:focus, select:focus{box-shadow:0 8px 30px rgba(107,0,255,0.08);}
.controls{display:flex;gap:10px;margin-top:6px;flex-wrap:wrap}
.btn{padding:10px 14px;border-radius:10px;border:none;cursor:pointer;font-weight:600}
.btn-primary{background:linear-gradient(90deg,var(--accent1),var(--accent2));color:white;box-shadow:0 8px 30px rgba(107,0,255,0.12)}
.btn-ghost{background:transparent;border:1px solid rgba(255,255,255,0.04);color:var(--muted)}
.btn-secondary{background:transparent;border:1px dashed rgba(255,255,255,0.04);color:var(--muted)}
.hint{color:var(--muted);font-size:13px;margin-top:6px}

/* message & detail area */
.message{min-height:28px;color:var(--muted);font-size:14px}
.detail-area{background:rgba(0,0,0,0.18);padding:12px;border-radius:10px;color:#fff;white-space:pre-wrap}

/* Sidebar */
.side-card{width:300px;display:flex;flex-direction:column;gap:12px}
.help-card{background:var(--glass-2);padding:14px;border-radius:12px;color:var(--muted);font-size:14px}
.help-card ul{margin:8px 0;padding-left:18px}
.help-card a{color:var(--accent2);text-decoration:underline}

/* admin shell */
.admin-shell{display:flex;gap:18px;padding:20px}
.admin-sidebar{width:220px;background:linear-gradient(180deg,rgba(255,255,255,0.02),rgba(255,255,255,0.01));padding:14px;border-radius:12px}
.admin-main{flex:1;display:flex;flex-direction:column;gap:14px}
.nav-btn{display:block;width:100%;text-align:left;padding:8px;border-radius:8px;border:none;background:transparent;color:var(--muted);margin-bottom:6px;cursor:pointer}
.nav-btn.active{background:linear-gradient(90deg,var(--accent1),var(--accent2));color:#fff}
.table-wrap{overflow:auto;max-height:440px}
.admin-table{width:100%;border-collapse:collapse}
.admin-table th,.admin-table td{padding:8px;border-bottom:1px solid rgba(255,255,255,0.03);text-align:left}
.row{display:flex;gap:10px}
.form-row{display:flex;gap:10px;align-items:center}
textarea, input, select{background:rgba(255,255,255,0.03);color:#fff;border:none;padding:8px;border-radius:8px}
.modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,0.45);z-index:999;opacity:0;pointer-events:none;transition:opacity .15s}
.modal[aria-hidden="false"]{opacity:1;pointer-events:auto}
.modal-panel{width:720px;max-width:94%}
.logbox{background:rgba(0,0,0,0.18);padding:8px;border-radius:8px;white-space:pre-wrap;color:var(--muted)}
.small{font-size:13px;color:var(--muted)}
.muted{color:var(--muted)}
.link{color:var(--accent2);text-decoration:underline}

/* Tiny forms & helpers */
.input-with-action{display:flex;align-items:center;gap:8px}
.input-with-action input{flex:1}
.btn.small{padding:6px 8px}

/* responsive */
@media(max-width:980px){
  .centered-layout{flex-direction:column;align-items:stretch}
  .side-card{width:100%}
  .hero-card{padding:16px}
  .admin-shell{flex-direction:column;padding:10px}
  .admin-sidebar{width:100%}
}

/* focus styles for keyboard users */
:focus{outline:none}
button:focus, a:focus, input:focus, select:focus, textarea:focus{box-shadow:0 0 0 3px rgba(184,77,255,0.12);border-radius:8px}

/* small scrollbar styling for panels */
::-webkit-scrollbar{height:10px;width:8px}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.04);border-radius:8px}

/* utility */
.center{display:flex;align-items:center;justify-content:c