:root{
  --bg:#0c0b09;
  --panel:#14120e;
  --panel-2:#181510;
  --glass:rgba(255,255,255,.06);
  --border:rgba(255,255,255,.10);
  --border-strong:rgba(255,255,255,.18);
  --gold:#f2c14e;
  --gold-soft:rgba(242,193,78,.15);
  --text:#f4f4f4;
  --muted:#9a968d;
  --danger:#ff6b6b;
  --success:#4ade80;
  --info:#4facfe;
}

*{box-sizing:border-box}
body{
  margin:0;font-family:Poppins,system-ui,sans-serif;
  background:
    radial-gradient(900px 500px at 0% -10%, #241608, transparent),
    radial-gradient(700px 400px at 100% 0%, #1a120a, transparent),
    var(--bg);
  color:var(--text);
  min-height:100vh;
}
a{color:inherit}
img{max-width:100%;display:block}

/* --------- APP SHELL --------- */
.app-shell{display:grid;grid-template-columns:250px 1fr;min-height:100vh}

.sidebar{
  background:linear-gradient(180deg,#0f0e0c,#070605);
  border-right:1px solid var(--border);
  padding:26px 16px;position:sticky;top:0;height:100vh;overflow:auto;
}
.brand{margin-bottom:28px;padding:0 6px}
.brand h2{margin:0;letter-spacing:4px;color:var(--gold)}
.brand span{font-size:.72rem;color:var(--muted);letter-spacing:2px}

.sidebar nav{display:flex;flex-direction:column;gap:4px}
.sidebar a{
  display:flex;align-items:center;gap:12px;
  padding:11px 14px;border-radius:12px;
  color:#d9d6ce;text-decoration:none;font-size:.92rem;
  transition:.2s;
}
.sidebar a i{width:18px;text-align:center}
.sidebar a:hover{background:var(--glass);color:#fff}
.sidebar a.active{background:var(--gold-soft);color:var(--gold)}
.sidebar a.logout{margin-top:18px;border-top:1px solid var(--border);border-radius:0;padding-top:18px;color:#d4a4a4}

.main{display:flex;flex-direction:column;min-height:100vh}

.topbar{
  display:flex;align-items:center;gap:18px;
  padding:18px 36px;
  border-bottom:1px solid var(--border);
  background:rgba(10,9,7,.7);
  backdrop-filter:blur(10px);
  position:sticky;top:0;z-index:20;
}
.top-title{font-weight:500;font-size:1.1rem;flex:1}
.top-user{display:flex;align-items:center;gap:12px}
.avatar{
  width:40px;height:40px;border-radius:50%;
  background:var(--gold);color:#000;display:flex;align-items:center;justify-content:center;
  font-weight:700;
}
.u-meta strong{display:block;font-size:.88rem}
.u-meta span{font-size:.72rem;color:var(--muted)}

.hamburger{display:none;background:none;border:none;color:#fff;font-size:20px;cursor:pointer}

.content{padding:32px 36px;flex:1}

/* --------- FLASH --------- */
.flash{padding:12px 16px;border-radius:10px;margin-bottom:16px;font-size:.9rem}
.flash-info{background:rgba(79,172,254,.12);border:1px solid rgba(79,172,254,.35);color:#cfe6ff}
.flash-success{background:rgba(74,222,128,.12);border:1px solid rgba(74,222,128,.35);color:#d1f9dd}
.flash-error{background:rgba(255,107,107,.12);border:1px solid rgba(255,107,107,.35);color:#ffd3d3}

/* --------- CARDS --------- */
.card{
  background:linear-gradient(180deg,var(--glass),rgba(255,255,255,.01));
  border:1px solid var(--border);border-radius:18px;
  padding:24px;margin-bottom:22px;
}
.card h2,.card h3{margin:0 0 14px}
.card-title{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:18px}
.card-title h3{margin:0}
.muted{color:var(--muted)}
.grid-2{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:22px}
.grid-3{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px}
.grid-4{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:18px}

/* --------- STAT CARDS --------- */
.stat{
  padding:22px;border-radius:18px;
  background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.01));
  border:1px solid var(--border);
  display:flex;gap:16px;align-items:center;
}
.stat .ico{
  width:50px;height:50px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;font-size:20px;
  background:var(--gold-soft);color:var(--gold);flex:0 0 auto;
}
.stat h2{margin:0;font-size:1.6rem}
.stat p{margin:0;color:var(--muted);font-size:.82rem}

/* --------- TIMELINE --------- */
.timeline{position:relative;padding:10px 0 10px 34px}
.timeline:before{
  content:"";position:absolute;left:14px;top:0;bottom:0;width:2px;
  background:var(--border);
}
.timeline-item{position:relative;padding:0 0 26px 0}
.timeline-item:last-child{padding-bottom:0}
.timeline-dot{
  position:absolute;left:-34px;top:3px;
  width:30px;height:30px;border-radius:50%;
  background:var(--panel);border:2px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  color:var(--muted);font-size:12px;
}
.timeline-item.done .timeline-dot{
  background:var(--gold);border-color:var(--gold);color:#000;
}
.timeline-item.current .timeline-dot{
  border-color:var(--gold);color:var(--gold);
  box-shadow:0 0 0 6px rgba(242,193,78,.18);
}
.timeline-item h4{margin:0 0 4px;font-size:1rem}
.timeline-item p{margin:0;color:var(--muted);font-size:.82rem}
.timeline-sub{margin-top:10px;display:flex;flex-wrap:wrap;gap:8px}
.badge{
  font-size:.72rem;padding:4px 10px;border-radius:999px;
  background:var(--glass);border:1px solid var(--border);color:#ddd;
}
.badge.ok{background:rgba(74,222,128,.14);border-color:rgba(74,222,128,.35);color:#b9f6c9}
.badge.proc{background:rgba(79,172,254,.14);border-color:rgba(79,172,254,.35);color:#cfe6ff}
.badge.pending{background:rgba(255,255,255,.04);color:var(--muted)}

/* --------- FORMS --------- */
input,textarea,select{
  width:100%;padding:12px 14px;border-radius:10px;
  border:1px solid var(--border);background:#0e0d0a;color:#fff;
  margin-bottom:12px;font-family:inherit;font-size:.92rem;
}
textarea{min-height:90px;resize:vertical}
label{display:block;font-size:.82rem;color:var(--muted);margin-bottom:6px}
.field{margin-bottom:14px}
.row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:700px){.row{grid-template-columns:1fr}}

button,.btn{
  padding:12px 22px;border-radius:12px;border:none;cursor:pointer;
  background:var(--gold);color:#000;font-weight:600;
  text-decoration:none;display:inline-flex;align-items:center;gap:8px;
  font-size:.92rem;
}
.btn:hover{filter:brightness(1.08)}
.btn-outline{background:transparent;border:1px solid var(--gold);color:var(--gold)}
.btn-ghost{background:transparent;border:1px solid var(--border);color:#eee}
.btn-danger{background:var(--danger);color:#fff}
.btn-disabled{background:#2a2824;color:#777;cursor:not-allowed}
.btn-sm{padding:8px 14px;font-size:.82rem}
.btn-block{display:flex;justify-content:center;width:100%}

/* --------- TABLES --------- */
table{width:100%;border-collapse:collapse;font-size:.9rem}
th,td{padding:14px 12px;border-bottom:1px solid var(--border);text-align:left;vertical-align:middle}
th{color:var(--muted);font-weight:500;font-size:.78rem;letter-spacing:.05em;text-transform:uppercase}
tr:last-child td{border-bottom:none}
.table-wrap{overflow-x:auto}

/* --------- AUTH LAYOUT --------- */
/* Base split defined below (grid-template-columns:1fr 1fr) so left &
   right panels are exactly 50/50. This keeps the registration form
   roomy on laptops/desktops, per client feedback. */
.auth-left{
  position:relative;
  overflow:hidden;
  background:
    linear-gradient(180deg,rgba(0,0,0,.58),rgba(0,0,0,.88)),
    radial-gradient(800px 600px at 10% 15%, rgba(242,193,78,.16), transparent 55%),
    radial-gradient(700px 500px at 92% 70%, rgba(210,120,70,.10), transparent 50%),
    linear-gradient(145deg,#1a1510 0%,#0c0b09 45%,#120e0b 100%);
  padding:60px 50px;display:flex;flex-direction:column;justify-content:space-between;
}
.auth-left::before{
  content:"";
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 120% 70% at 18% 88%, rgba(242,193,78,.08), transparent 45%),
    radial-gradient(ellipse 90% 55% at 82% 12%, rgba(255,200,120,.06), transparent 48%);
  animation:authMesh 22s ease-in-out infinite alternate;
  pointer-events:none;
}
.auth-left > *{position:relative;z-index:1}
@keyframes authMesh{
  0%{opacity:.75;transform:scale(1)}
  100%{opacity:1;transform:scale(1.05) translate(-1%,1%)}
}
.auth-left h1{font-size:2.6rem;line-height:1.1;margin:0 0 18px}
.auth-left h1 span{color:var(--gold)}
.auth-left p{color:#ddd;max-width:420px}
.auth-left .auth-features{list-style:none;padding:0;margin:40px 0 0;display:flex;flex-direction:column;gap:14px}
.auth-left .auth-features li{display:flex;gap:14px;align-items:center;color:#eee;font-size:.95rem}
.auth-left .auth-features i{color:var(--gold)}
.auth-right{
  display:flex;align-items:flex-start;justify-content:center;
  padding:40px 36px;overflow-y:auto;min-width:0;
}
.auth-card{
  width:100%;max-width:480px;
  background:linear-gradient(180deg,var(--glass),rgba(255,255,255,.02));
  border:1px solid var(--border);border-radius:22px;padding:34px;
  box-sizing:border-box;
}
/* Wider variant used by the multi-field registration form. The right
   panel is already 50% of the viewport, so we let the card itself fill
   most of that panel (up to ~720px) so the email field is wide enough
   to read long addresses without horizontal scrolling. */
.auth-card.auth-card-wide{max-width:720px;width:100%}
.auth-card h2{margin:0 0 6px}
.auth-card .muted{margin-bottom:22px}
.auth-alt{text-align:center;margin-top:16px;font-size:.88rem;color:var(--muted)}
.auth-alt a{color:var(--gold);text-decoration:none}

/* Prevent the form itself from becoming a scrollable micro-window by
   making it grow naturally and letting the page own the scroll. */
.auth-card form{overflow:visible}
.auth-card input,
.auth-card textarea,
.auth-card select{
  font-size:16px;padding:14px 16px;min-width:0;
}
/* Email-specific: always show the full value, never truncated. */
.auth-card input[type="email"]{font-size:16px;letter-spacing:.1px}

/* 50/50 split on large screens (client asked for equal-width panels) */
.auth-wrap{
  min-height:100vh;display:grid;grid-template-columns:1fr 1fr;
}

/* OTP-row: input + inline action button. Allow wrapping on narrow
   widths so the email box doesn't get squeezed next to the button. */
.otp-row{display:flex;gap:8px;align-items:stretch;flex-wrap:wrap}
.otp-row > input{flex:1 1 220px;margin-bottom:0;min-width:0}
.otp-row > button{flex:0 0 auto;padding:12px 16px;border-radius:10px;white-space:nowrap}
.otp-verify{margin-top:8px}
.otp-status{font-size:.8rem;margin-top:6px;min-height:1.1em}

/* On tablets (right panel narrower than 560px), drop the 2-column
   field rows to 1 column so nothing clips. */
@media(max-width:1280px){
  .auth-card.auth-card-wide .row{grid-template-columns:1fr}
}

@media(max-width:1000px){
  .auth-wrap{grid-template-columns:1fr}
  .auth-left{display:none}
  .auth-right{padding:24px 18px}
  .auth-card{max-width:100%;padding:26px 22px}
  .auth-card.auth-card-wide{max-width:100%}
}

/* --------- PLAN CARDS --------- */
.plans{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:22px}
.plan{
  border:1px solid var(--border);border-radius:18px;padding:28px;
  background:linear-gradient(180deg,var(--glass),rgba(255,255,255,.01));
  display:flex;flex-direction:column;
}
.plan.featured{border-color:var(--gold)}
.plan .price{font-size:2rem;color:var(--gold);font-weight:600}
.plan .price small{font-size:.82rem;color:var(--muted);font-weight:400}
.plan ul{list-style:none;padding:0;margin:16px 0;display:flex;flex-direction:column;gap:8px}
.plan ul li{font-size:.88rem;color:#ddd;display:flex;gap:8px}
.plan ul li i{color:var(--gold)}
.plan .schedule{background:rgba(0,0,0,.25);border:1px solid var(--border);border-radius:12px;padding:14px;margin-top:14px;font-size:.84rem}
.plan .schedule strong{display:block;font-size:.72rem;color:var(--muted);letter-spacing:.1em;margin-bottom:8px}
.plan .schedule div{display:flex;justify-content:space-between;padding:3px 0}
.plan .cta{margin-top:auto;padding-top:18px}

/* Promo-code apply row (inside apply.php "Promo code" section) */
.promo-row{display:flex;gap:10px;align-items:stretch;max-width:420px}
.promo-row > input{flex:1;margin-bottom:0;text-transform:uppercase;letter-spacing:.05em}
.promo-row > button{flex:0 0 auto;padding:12px 16px;border-radius:10px;white-space:nowrap}

/* --------- RESOURCE CARDS --------- */
.resources{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px}
.res-card{
  border:1px solid var(--border);border-radius:16px;padding:22px;
  background:linear-gradient(180deg,var(--glass),rgba(255,255,255,.01));
  display:flex;flex-direction:column;gap:10px;transition:.2s;
}
.res-card:hover{border-color:var(--gold);transform:translateY(-2px)}
.res-card .ri{font-size:22px;color:var(--gold);margin-bottom:4px}
.res-card h4{margin:0;font-size:1rem}
.res-card p{margin:0;color:var(--muted);font-size:.84rem}
.locked{opacity:.5;pointer-events:none;position:relative}
.locked:after{
  content:"\f023";font-family:"Font Awesome 6 Free";font-weight:900;
  position:absolute;top:12px;right:14px;color:#888;
}

/* --------- SHOP --------- */
.products-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px}
.prod-card{
  border:1px solid var(--border);border-radius:16px;overflow:hidden;
  background:linear-gradient(180deg,var(--glass),rgba(255,255,255,.01));
  display:flex;flex-direction:column;
}
.prod-card .thumb{height:160px;background:#1a1812 center/cover;display:flex;align-items:center;justify-content:center;color:#3a3832;font-size:40px}
.prod-card .body{padding:16px;display:flex;flex-direction:column;gap:6px;flex:1}
.prod-card .name{font-size:.96rem;font-weight:500}
.prod-card .cat{font-size:.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:.1em}
.prod-card .price{color:var(--gold);font-weight:600}
.prod-card .actions{margin-top:auto;display:flex;gap:8px;align-items:center}
.prod-card input[type=number]{width:70px;margin:0}

/* --------- CONTRACT --------- */
.contract-doc{
  background:#fff;color:#1d1d1d;padding:44px 52px;border-radius:12px;
  max-width:900px;margin:0 auto;font-family:"Times New Roman",Georgia,serif;line-height:1.72;
  font-size:15px;
  border:1px solid #ececec;
}
.contract-doc h1{
  color:#111;text-align:center;margin:0 0 16px;
  font-size:1.65rem;letter-spacing:.04em;text-transform:uppercase;
}
.contract-doc h3{
  margin:24px 0 8px;
  font-size:1rem;
  color:#111;
  letter-spacing:.03em;
  text-transform:uppercase;
  border-top:1px solid #e8e8e8;
  padding-top:10px;
}
.contract-doc p{margin:0 0 10px;text-align:justify}
.contract-doc ol,.contract-doc ul{margin:8px 0 10px 22px}
.contract-doc li{margin:0 0 6px}
.contract-doc strong{color:#111}
.contract-doc em{color:#4a4a4a}
.contract-doc .sig-box{margin-top:30px;display:grid;grid-template-columns:1fr 1fr;gap:30px}
.contract-doc .sig-box p{margin:0 0 8px;text-align:left}
.sig-pad-wrap{background:#111;border:1px dashed var(--border);border-radius:12px;padding:14px}
#sigPad{background:#fff;border-radius:8px;width:100%;height:180px;touch-action:none}

/* --------- INVOICE --------- */
.invoice{
  max-width:860px;margin:0 auto;background:#fff;color:#222;padding:40px;border-radius:12px;
  font-family:Arial,sans-serif;
}
.invoice h1{margin:0 0 6px}
.invoice .inv-head{display:flex;justify-content:space-between;margin-bottom:24px}
.invoice table{color:#222}
.invoice th,.invoice td{border-bottom:1px solid #ddd;color:#222;text-transform:none}
.invoice .totals{margin-top:18px;display:flex;justify-content:flex-end}
.invoice .totals table{width:320px}

/* --------- STATUS CHIPS --------- */
.chip{display:inline-flex;align-items:center;gap:6px;font-size:.74rem;padding:4px 10px;border-radius:999px;background:var(--glass);border:1px solid var(--border);color:#ddd}
.chip.ok{background:rgba(74,222,128,.14);border-color:rgba(74,222,128,.35);color:#b9f6c9}
.chip.warn{background:rgba(242,193,78,.14);border-color:rgba(242,193,78,.4);color:var(--gold)}
.chip.danger{background:rgba(255,99,99,.14);border-color:rgba(255,99,99,.4);color:#ffb5b5}
.chip.err{background:rgba(255,107,107,.14);border-color:rgba(255,107,107,.35);color:#ffd3d3}
.chip.proc{background:rgba(79,172,254,.14);border-color:rgba(79,172,254,.35);color:#cfe6ff}

/* --------- EMPTY --------- */
.empty{text-align:center;padding:40px 20px;color:var(--muted)}
.empty i{font-size:44px;color:#3a3832;margin-bottom:12px}

/* --------- RESPONSIVE --------- */
@media(max-width:980px){
  .app-shell{grid-template-columns:1fr}
  .sidebar{
    position:fixed;left:0;top:0;width:250px;height:100vh;z-index:99;
    transform:translateX(-100%);transition:.3s;
  }
  .sidebar.show{transform:translateX(0)}
  .hamburger{display:block}
  .content{padding:20px}
  .topbar{padding:14px 18px}
  .top-user .u-meta{display:none}
}

/* --------- PRINT (invoice/contract) --------- */
@page{
  size:A4;
  margin:14mm 12mm;
}
@media print{
  html,body{background:#fff !important;color:#000 !important;margin:0;padding:0}
  .sidebar,.topbar,.no-print{display:none !important}
  .main,.content,.app-shell{display:block;padding:0;margin:0;background:#fff}

  /* Make the document fill the page */
  .invoice,.contract-doc{
    box-shadow:none !important;
    border-radius:0 !important;
    background:#fff !important;
    color:#000 !important;
    max-width:100% !important;
    width:100% !important;
    min-height:calc(100vh - 28mm);
    padding:0 !important;
    margin:0 !important;
  }
  .invoice table{page-break-inside:avoid}
  .invoice .inv-head{page-break-after:avoid}
  .contract-doc h1,.contract-doc h3{page-break-after:avoid}
  .contract-doc p,.contract-doc li{orphans:3;widows:3}
  .contract-doc .sig-box{page-break-inside:avoid}

  /* Pagination calibration for 4-page legal print */
  .contract-doc{
    font-size:14.25px !important;
    line-height:1.58 !important;
    padding:0 !important;
  }
  .contract-doc h1{
    font-size:20px !important;
    margin:0 0 10px !important;
  }
  .contract-doc h3{
    font-size:13.5px !important;
    margin:14px 0 6px !important;
    padding-top:6px !important;
    page-break-after:avoid !important;
  }
  .contract-doc p{
    margin:0 0 6px !important;
  }
  .contract-doc ol,.contract-doc ul{
    margin:6px 0 6px 20px !important;
  }
  .contract-doc li{
    margin:0 0 3px !important;
  }
}

/* ---- Light theme (homepage toggle uses same localStorage key) ---- */
html[data-theme="light"]{
  --bg:#f4efe6;
  --panel:#ffffff;
  --panel-2:#faf7f2;
  --glass:rgba(0,0,0,.04);
  --border:rgba(28,24,18,.12);
  --border-strong:rgba(28,24,18,.2);
  --gold:#b8892a;
  --gold-soft:rgba(184,137,42,.14);
  --text:#000000;
  --muted:rgba(0,0,0,.72);
  --danger:#d64545;
  --success:#2d8a54;
  --info:#1a6fb3;
}
html[data-theme="light"] body{
  background:
    radial-gradient(900px 500px at 0% -10%, rgba(184,137,42,.08), transparent),
    radial-gradient(700px 400px at 100% 0%, rgba(200,170,120,.06), transparent),
    var(--bg);
}
html[data-theme="light"] .sidebar{
  background:linear-gradient(180deg,#faf7f2,#ebe4d8);
  border-right-color:var(--border);
}
html[data-theme="light"] .sidebar a{color:#000}
html[data-theme="light"] .sidebar a:hover{background:rgba(0,0,0,.05);color:#000}
html[data-theme="light"] .sidebar a.active{background:var(--gold-soft);color:var(--gold)}
html[data-theme="light"] .topbar{
  background:rgba(255,252,247,.92);
  border-bottom-color:var(--border);
}
html[data-theme="light"] .hamburger{color:var(--text)}
html[data-theme="light"] input,
html[data-theme="light"] textarea,
html[data-theme="light"] select{
  background:#fff;
  color:var(--text);
  border-color:var(--border);
}
html[data-theme="light"] .auth-left{
  background:
    linear-gradient(180deg,rgba(255,255,255,.35),rgba(244,239,230,.92)),
    radial-gradient(800px 600px at 12% 18%, rgba(184,137,42,.12), transparent 55%),
    radial-gradient(700px 500px at 88% 60%, rgba(200,160,100,.10), transparent 50%),
    linear-gradient(145deg,#faf6ef 0%,#ebe4d8 50%,#f2ebe0 100%);
}
html[data-theme="light"] .auth-left::before{opacity:.5}
html[data-theme="light"] .auth-left h1{color:#000}
html[data-theme="light"] .auth-left p{color:#000}
html[data-theme="light"] .auth-left .auth-features li{color:#000}

.theme-toggle-nav{
  flex:0 0 auto;
  width:40px;height:40px;border-radius:50%;
  border:1px solid var(--border);
  background:var(--glass);
  color:var(--gold);
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  font-size:1rem;
}
.theme-toggle-nav:hover{filter:brightness(1.06)}
