: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 --------- */
.auth-wrap{
  min-height:100vh;display:grid;grid-template-columns:1.1fr .9fr;
}
.auth-left{
  background:
    linear-gradient(180deg,rgba(0,0,0,.55),rgba(0,0,0,.85)),
    url("hero-bg.jpg") center/cover;
  padding:60px 50px;display:flex;flex-direction:column;justify-content:space-between;
}
.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:center;justify-content:center;padding:40px}
.auth-card{
  width:100%;max-width:440px;
  background:linear-gradient(180deg,var(--glass),rgba(255,255,255,.02));
  border:1px solid var(--border);border-radius:22px;padding:34px;
}
.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}

@media(max-width:1000px){
  .auth-wrap{grid-template-columns:1fr}
  .auth-left{display:none}
}

/* --------- 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}

/* --------- 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:#222;padding:40px;border-radius:12px;
  max-width:860px;margin:0 auto;font-family:Georgia,serif;line-height:1.65;
}
.contract-doc h1{color:#222;text-align:center;margin:0 0 18px}
.contract-doc .sig-box{margin-top:30px;display:grid;grid-template-columns:1fr 1fr;gap:30px}
.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.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) --------- */
@media print{
  .sidebar,.topbar,.no-print{display:none !important}
  .main,.content,.app-shell{display:block;padding:0;background:#fff}
  body{background:#fff;color:#000}
  .invoice,.contract-doc{box-shadow:none;border-radius:0;padding:0}
}
