@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=DM+Sans:wght@300;400;500;600&display=swap');

*{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#0e0f11;--surface:#16181c;--surface2:#1e2126;--surface3:#252930;
  --border:#2e3340;--border2:#3a4050;
  --accent:#4ade80;--accent2:#22c55e;--accent-dim:#1a3a25;
  --red:#f87171;--red-dim:#3a1a1a;
  --blue:#60a5fa;--blue-dim:#1a2a3a;
  --amber:#fbbf24;--amber-dim:#3a2a0a;
  --text:#f0f2f5;--text2:#8b95a5;--text3:#556070;
  --font-display:'Bebas Neue',sans-serif;
  --font:'DM Sans',sans-serif;
  --r:10px;--r2:16px;
}
body{background:var(--bg);color:var(--text);font-family:var(--font);font-size:15px;line-height:1.6;min-height:100vh}

/* ─── LAYOUT ────────────────────────────── */
.app-wrap{display:flex;height:100vh;overflow:hidden}
.sidebar{width:230px;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0}
.main-area{flex:1;display:flex;flex-direction:column;overflow:hidden}
.topbar{height:56px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 24px;flex-shrink:0}
.content{flex:1;overflow-y:auto;padding:28px 32px}

/* ─── SIDEBAR ───────────────────────────── */
.sidebar-logo{padding:18px 20px;font-family:var(--font-display);font-size:30px;color:var(--accent);letter-spacing:2px;border-bottom:1px solid var(--border)}
.sidebar-nav{padding:12px 0;flex:1}
.sidebar-section{padding:8px 20px;font-size:11px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:1.5px;margin-top:6px}
.nav-item{display:flex;align-items:center;gap:10px;padding:10px 20px;cursor:pointer;color:var(--text2);font-size:14px;text-decoration:none;transition:all .15s;border-left:2px solid transparent}
.nav-item:hover{color:var(--text);background:var(--surface2);text-decoration:none}
.nav-item.active{color:var(--accent);background:var(--accent-dim);border-left-color:var(--accent)}
.nav-item svg{flex-shrink:0}
.nav-badge{margin-left:auto;background:var(--accent-dim);color:var(--accent);font-size:10px;font-weight:600;padding:2px 7px;border-radius:10px}
.sidebar-user{padding:14px 16px;border-top:1px solid var(--border);display:flex;align-items:center;gap:10px}
.avatar{width:34px;height:34px;border-radius:50%;background:var(--accent-dim);border:1.5px solid var(--accent);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:var(--accent);flex-shrink:0}
.avatar-sm{width:26px;height:26px;font-size:10px}

/* ─── TOPBAR ────────────────────────────── */
.topbar-title{font-family:var(--font-display);font-size:22px;letter-spacing:1px;color:var(--text)}
.topbar-right{display:flex;align-items:center;gap:12px}
.topbar-user{font-size:13px;color:var(--text2)}

/* ─── BUTTONS ───────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border-radius:var(--r);cursor:pointer;font-family:var(--font);font-size:14px;font-weight:500;border:none;text-decoration:none;transition:all .15s;line-height:1}
.btn:hover{text-decoration:none}
.btn-primary{background:var(--accent);color:#0a1a10}
.btn-primary:hover{background:var(--accent2);color:#0a1a10}
.btn-secondary{background:var(--surface3);color:var(--text);border:1px solid var(--border2)}
.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}
.btn-danger{background:var(--red-dim);color:var(--red);border:1px solid transparent}
.btn-danger:hover{border-color:var(--red)}
.btn-sm{padding:5px 12px;font-size:12px}
.btn-block{width:100%;justify-content:center}
.btn-logout{background:none;border:1px solid var(--border2);color:var(--text2);padding:5px 12px;border-radius:6px;cursor:pointer;font-size:12px;font-family:var(--font)}
.btn-logout:hover{border-color:var(--red);color:var(--red)}

/* ─── CARDS ─────────────────────────────── */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r2);padding:20px}
.card-sm{padding:14px 16px}
.card-title{font-size:11px;color:var(--text3);font-weight:500;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}
.card-value{font-family:var(--font-display);font-size:38px;color:var(--text);letter-spacing:1px;line-height:1}
.card-sub{font-size:12px;color:var(--text2);margin-top:3px}

/* ─── GRID ──────────────────────────────── */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.gap16{gap:16px}

/* ─── SECTION HEAD ──────────────────────── */
.section-head{display:flex;align-items:baseline;gap:14px;margin-bottom:24px}
.section-head h1{font-family:var(--font-display);font-size:42px;letter-spacing:2px;line-height:1}
.section-tag{font-size:13px;color:var(--text3)}

/* ─── FORMS ─────────────────────────────── */
.form-group{margin-bottom:14px}
.form-label{display:block;font-size:12px;color:var(--text2);margin-bottom:5px;font-weight:500}
.form-input{width:100%;background:var(--surface2);border:1px solid var(--border2);color:var(--text);padding:9px 12px;border-radius:var(--r);font-family:var(--font);font-size:14px;outline:none;transition:border .15s}
.form-input:focus{border-color:var(--accent)}
.form-select{width:100%;background:var(--surface2);border:1px solid var(--border2);color:var(--text);padding:9px 12px;border-radius:var(--r);font-family:var(--font);font-size:14px;outline:none}
.form-select:focus{border-color:var(--accent)}
.form-textarea{width:100%;background:var(--surface2);border:1px solid var(--border2);color:var(--text);padding:9px 12px;border-radius:var(--r);font-family:var(--font);font-size:14px;outline:none;resize:vertical;min-height:80px}
.form-textarea:focus{border-color:var(--accent)}
select option{background:var(--surface2)}
.form-error{color:var(--red);font-size:13px;padding:10px 12px;background:var(--red-dim);border-radius:var(--r);margin-bottom:14px}
.form-success{color:var(--accent);font-size:13px;padding:10px 12px;background:var(--accent-dim);border-radius:var(--r);margin-bottom:14px}

/* ─── BADGES ────────────────────────────── */
.badge{display:inline-block;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:600;letter-spacing:.3px}
.badge-green{background:var(--accent-dim);color:var(--accent)}
.badge-red{background:var(--red-dim);color:var(--red)}
.badge-blue{background:var(--blue-dim);color:var(--blue)}
.badge-amber{background:var(--amber-dim);color:var(--amber)}

/* ─── PROGRESS ──────────────────────────── */
.progress-bar{height:6px;background:var(--surface3);border-radius:3px;overflow:hidden}
.progress-fill{height:100%;border-radius:3px;background:var(--accent);transition:width .5s}

/* ─── STAT BARS ─────────────────────────── */
.stat-bar-row{display:flex;align-items:center;gap:10px;margin-bottom:10px;font-size:13px}
.stat-bar-label{width:100px;color:var(--text2);flex-shrink:0}
.stat-bar-bg{flex:1;height:8px;background:var(--surface3);border-radius:4px;overflow:hidden}
.stat-bar-fill{height:100%;border-radius:4px;background:var(--accent)}
.stat-bar-val{width:80px;text-align:right;color:var(--text);font-weight:500;font-size:12px}

/* ─── BMI GAUGE ─────────────────────────── */
.bmi-gauge{display:flex;height:10px;border-radius:5px;overflow:hidden;margin:10px 0 6px}
.bmi-seg{flex:1;opacity:.4}
.bmi-seg.active{opacity:1}

/* ─── TABLE ─────────────────────────────── */
.data-table{width:100%;border-collapse:collapse;font-size:13px}
.data-table th{text-align:left;color:var(--text3);font-weight:500;font-size:11px;text-transform:uppercase;letter-spacing:.8px;padding:8px 12px;border-bottom:1px solid var(--border)}
.data-table td{padding:10px 12px;border-bottom:1px solid var(--border);color:var(--text)}
.data-table tr:last-child td{border-bottom:none}
.data-table tr:hover td{background:var(--surface2)}

/* ─── GOAL CARDS ────────────────────────── */
.goal-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(155px,1fr));gap:12px}
.goal-card{background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--r2);padding:16px;cursor:pointer;transition:all .2s;position:relative}
.goal-card:hover{border-color:var(--border2);transform:translateY(-2px)}
.goal-card.selected{border-color:var(--accent);background:var(--accent-dim)}
.goal-card .goal-icon{font-size:26px;margin-bottom:8px}
.goal-card .goal-name{font-size:14px;font-weight:600;color:var(--text)}
.goal-card .goal-desc{font-size:12px;color:var(--text2);margin-top:4px;line-height:1.4}
.goal-check{position:absolute;top:10px;right:10px;width:18px;height:18px;border-radius:50%;background:var(--accent);display:none;align-items:center;justify-content:center;font-size:10px;color:#0a1a10;font-weight:700}
.goal-card.selected .goal-check{display:flex}

/* ─── TIP BOX ───────────────────────────── */
.tip-box{padding:12px 14px;border-radius:var(--r);font-size:13px;display:flex;align-items:flex-start;gap:8px}
.tip-green{background:var(--accent-dim);border:1px solid var(--accent);color:var(--accent)}
.tip-blue{background:var(--blue-dim);border:1px solid var(--blue);color:var(--blue)}
.tip-amber{background:var(--amber-dim);border:1px solid var(--amber);color:var(--amber)}
.tip-red{background:var(--red-dim);border:1px solid var(--red);color:var(--red)}

/* ─── PROGRAM BOX ───────────────────────── */
.program-box{background:var(--surface2);border:1px solid var(--border);border-radius:var(--r2);padding:20px}
.program-day{margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--border)}
.program-day:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.program-day-title{font-size:12px;font-weight:600;color:var(--accent);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}
.program-ex{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid var(--border);font-size:13px}
.program-ex:last-child{border-bottom:none}

/* ─── AUTH ──────────────────────────────── */
.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:24px}
.auth-box{width:100%;max-width:420px}
.auth-logo{font-family:var(--font-display);font-size:54px;color:var(--accent);letter-spacing:3px;text-align:center;margin-bottom:6px}
.auth-sub{text-align:center;color:var(--text2);font-size:14px;margin-bottom:28px}
.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r2);padding:28px}
.auth-tabs{display:flex;margin-bottom:20px;border-bottom:1px solid var(--border)}
.auth-tab{flex:1;padding:10px;text-align:center;cursor:pointer;color:var(--text2);font-size:14px;font-weight:500;text-decoration:none;display:block}
.auth-tab.active{color:var(--accent);border-bottom:2px solid var(--accent);margin-bottom:-1px}

/* ─── CHART BARS ────────────────────────── */
.bar-chart{display:flex;align-items:flex-end;gap:6px;height:100px}
.bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px}
.bar-block{width:100%;border-radius:3px 3px 0 0;background:var(--accent);min-height:4px;transition:height .4s}
.bar-label{font-size:9px;color:var(--text3);text-align:center}
.bar-val{font-size:10px;color:var(--text2);font-weight:500}

/* ─── UTILS ─────────────────────────────── */
.mt8{margin-top:8px}.mt12{margin-top:12px}.mt16{margin-top:16px}.mt20{margin-top:20px}.mt24{margin-top:24px}
.mb8{margin-bottom:8px}.mb12{margin-bottom:12px}.mb16{margin-bottom:16px}
.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}
.gap8{gap:8px}.gap12{gap:12px}.gap16{gap:16px}
.text-muted{color:var(--text2);font-size:13px}
.text-sm{font-size:13px}
.text-xs{font-size:11px}
.fw500{font-weight:500}
.color-green{color:var(--accent)}
.color-red{color:var(--red)}
.color-blue{color:var(--blue)}
.color-amber{color:var(--amber)}
.color-muted{color:var(--text2)}
.display-font{font-family:var(--font-display)}
hr.divider{border:none;border-top:1px solid var(--border);margin:20px 0}
.spinner{display:inline-block;width:18px;height:18px;border:2px solid var(--surface3);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ─── RESPONSIVE ────────────────────────── */
@media(max-width:900px){
  .sidebar{width:60px}
  .sidebar-logo{font-size:18px;padding:16px 0;text-align:center;letter-spacing:0}
  .nav-item span.nav-label{display:none}
  .nav-badge{display:none}
  .sidebar-user .user-info{display:none}
  .grid4{grid-template-columns:1fr 1fr}
  .content{padding:16px}
}
@media(max-width:600px){
  .grid2,.grid3,.grid4{grid-template-columns:1fr}
  .section-head h1{font-size:30px}
}
