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

:root {
  --bg-deep:#0a0a0c; --bg-surface:#111116; --bg-card:#18181f; --bg-hover:#1f1f28;
  --border:rgba(255,255,255,.07); --border-glow:rgba(229,57,53,.35);
  --accent:#E53935; --accent-dim:rgba(229,57,53,.15); --accent-glow:rgba(229,57,53,.4);
  --gold:#F5A623; --green:#4CAF50; --green-dim:rgba(76,175,80,.15); --blue:#42A5F5;
  --text-1:#F0F0F0; --text-2:#8888A0; --text-3:#55556A;
  --radius-sm:8px; --radius:14px; --radius-lg:22px;
  --font-display:'Bebas Neue',sans-serif; --font-body:'DM Sans',sans-serif; --font-mono:'Space Mono',monospace;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{font-size:16px;scroll-behavior:smooth;}
body{background:var(--bg-deep);color:var(--text-1);font-family:var(--font-body);line-height:1.6;min-height:100vh;overflow-x:hidden;}
::-webkit-scrollbar{width:5px;}::-webkit-scrollbar-track{background:var(--bg-deep);}::-webkit-scrollbar-thumb{background:var(--accent);border-radius:10px;}
h1,h2,h3{font-family:var(--font-display);letter-spacing:.04em;line-height:1.1;}
h1{font-size:clamp(2rem,5vw,3.5rem);}h2{font-size:clamp(1.4rem,3vw,2rem);}
p{color:var(--text-2);}a{color:var(--accent);text-decoration:none;}

/* ── AUTH ── */
#auth-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse 80% 60% at 50% 0%,rgba(229,57,53,.12) 0%,transparent 60%),var(--bg-deep);padding:1rem;}
.auth-box{width:100%;max-width:420px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2.5rem 2rem;box-shadow:0 4px 24px rgba(0,0,0,.5),0 0 32px rgba(229,57,53,.25);animation:fadeUp .5s ease both;}
.auth-logo{text-align:center;margin-bottom:2rem;}
.auth-logo .logo-mark{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;background:var(--accent);border-radius:18px;font-size:1.8rem;margin-bottom:.75rem;box-shadow:0 0 30px var(--accent-glow);}
.auth-logo h1{font-size:1.9rem;}
.auth-tabs{display:flex;background:var(--bg-surface);border-radius:var(--radius-sm);padding:4px;margin-bottom:1.75rem;}
.auth-tab{flex:1;padding:.55rem;text-align:center;cursor:pointer;border-radius:6px;font-size:.85rem;font-weight:500;color:var(--text-2);transition:all .2s;border:none;background:none;}
.auth-tab.active{background:var(--accent);color:#fff;}

/* ── FORMS ── */
.form-group{margin-bottom:1rem;}
.form-group label{display:block;font-size:.8rem;font-weight:600;color:var(--text-2);margin-bottom:.4rem;text-transform:uppercase;letter-spacing:.08em;}
.form-control{width:100%;background:var(--bg-surface);border:1px solid var(--border);color:var(--text-1);padding:.7rem 1rem;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.95rem;transition:border-color .2s,box-shadow .2s;outline:none;}
.form-control:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim);}
textarea.form-control{resize:vertical;min-height:80px;}select.form-control{cursor:pointer;}
.form-control-sm{padding:.45rem .7rem;font-size:.85rem;}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.7rem 1.4rem;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.9rem;font-weight:600;cursor:pointer;border:none;transition:all .2s;white-space:nowrap;}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 4px 16px var(--accent-glow);}
.btn-primary:hover{filter:brightness(1.15);transform:translateY(-1px);}
.btn-success{background:var(--green);color:#fff;box-shadow:0 4px 16px rgba(76,175,80,.3);}
.btn-success:hover{filter:brightness(1.1);}
.btn-secondary{background:var(--bg-hover);color:var(--text-1);border:1px solid var(--border);}
.btn-secondary:hover{border-color:var(--accent);color:var(--accent);}
.btn-ghost{background:transparent;color:var(--text-2);padding:.4rem .8rem;}
.btn-ghost:hover{color:var(--text-1);}
.btn-danger{background:rgba(229,57,53,.2);color:var(--accent);border:1px solid var(--border-glow);}
.btn-danger:hover{background:var(--accent);color:#fff;}
.btn-full{width:100%;}.btn-sm{padding:.4rem .9rem;font-size:.82rem;}.btn-icon{padding:.55rem;}
.btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important;filter:none!important;}

/* ── APP LAYOUT ── */
#app-screen{display:none;min-height:100vh;}
.sidebar{position:fixed;top:0;left:0;width:220px;height:100vh;background:var(--bg-surface);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:100;padding:1.5rem 1rem;transition:transform .3s;}
.sidebar-logo{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;margin-bottom:2rem;}
.sidebar-logo .mark{width:38px;height:38px;background:var(--accent);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0;}
.sidebar-logo .name{font-family:var(--font-display);font-size:1.05rem;letter-spacing:.06em;line-height:1.15;}
.sidebar-logo .name small{display:block;font-family:var(--font-body);font-size:.7rem;color:var(--text-3);font-weight:400;letter-spacing:0;}
.nav-section{font-size:.7rem;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:.12em;padding:0 .75rem;margin:1rem 0 .4rem;}
.nav-item{display:flex;align-items:center;gap:.75rem;padding:.65rem .75rem;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-2);font-weight:500;font-size:.88rem;transition:all .2s;border:none;background:none;width:100%;text-align:left;}
.nav-item:hover{background:var(--bg-hover);color:var(--text-1);}
.nav-item.active{background:var(--accent-dim);color:var(--accent);}
.nav-item .icon{width:20px;text-align:center;font-size:1rem;}
.sidebar-footer{margin-top:auto;padding-top:1rem;border-top:1px solid var(--border);}
.user-chip{display:flex;align-items:center;gap:.6rem;padding:.5rem .75rem;border-radius:var(--radius-sm);cursor:pointer;}
.user-chip:hover{background:var(--bg-hover);}
.avatar{width:34px;height:34px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;color:#fff;flex-shrink:0;}
.user-chip .info{flex:1;min-width:0;}
.user-chip .info .uname{font-weight:600;font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.user-chip .info .urole{font-size:.72rem;color:var(--text-3);}
.main{margin-left:220px;min-height:100vh;padding:2rem;}
.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;}
.topbar h2{color:var(--text-1);}
.page{display:none;animation:fadeUp .3s ease;}
.page.active{display:block;}

/* ── STAT CARDS ── */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;margin-bottom:2rem;}
.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;position:relative;overflow:hidden;transition:border-color .2s;}
.stat-card:hover{border-color:var(--accent);}
.stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent);opacity:0;transition:opacity .2s;}
.stat-card:hover::before{opacity:1;}
.stat-card .label{font-size:.75rem;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.5rem;}
.stat-card .value{font-family:var(--font-display);font-size:2.2rem;color:var(--text-1);line-height:1;}
.stat-card .unit{font-size:.8rem;color:var(--text-2);margin-top:.2rem;}
.stat-card .stat-icon{position:absolute;top:1rem;right:1rem;font-size:1.6rem;opacity:.25;}

/* ── CHART ── */
.chart-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;margin-bottom:1.5rem;}
.chart-card h3{font-size:1rem;font-weight:600;margin-bottom:1.25rem;color:var(--text-1);}
.bar-chart{display:flex;align-items:flex-end;gap:.5rem;height:100px;}
.bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:.3rem;height:100%;justify-content:flex-end;}
.bar-fill{width:100%;background:var(--accent);border-radius:4px 4px 0 0;min-height:3px;transition:height .5s cubic-bezier(.23,1,.32,1);}
.bar-label{font-size:.6rem;color:var(--text-3);font-family:var(--font-mono);}

/* ══════════════════════════════════════════════════════════
   WORKOUT TEMPLATES
══════════════════════════════════════════════════════════ */
.template-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem;}
.template-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:all .25s;position:relative;}
.template-card:hover{border-color:var(--border-glow);transform:translateY(-3px);box-shadow:0 8px 32px rgba(0,0,0,.4);}
.template-card-header{padding:1.25rem 1.25rem .75rem;display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem;}
.template-card-title{flex:1;}
.template-card-title h3{font-size:1.05rem;font-weight:700;color:var(--text-1);margin-bottom:.3rem;}
.template-badges{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:.5rem;}
.badge{display:inline-flex;align-items:center;gap:.25rem;padding:.18rem .55rem;border-radius:99px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;}
.badge-kraft{background:rgba(229,57,53,.15);color:var(--accent);}
.badge-cardio{background:rgba(66,165,245,.15);color:var(--blue);}
.badge-hiit{background:rgba(245,166,35,.15);color:var(--gold);}
.badge-mobility{background:rgba(76,175,80,.15);color:var(--green);}
.badge-oberkörper,.badge-unterkörper,.badge-ganzkörper,.badge-core{background:rgba(255,255,255,.07);color:var(--text-2);}
.template-eq-list{padding:.75rem 1.25rem;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:.4rem;}
.template-eq-item{display:flex;align-items:center;gap:.6rem;font-size:.82rem;color:var(--text-2);}
.template-eq-item .eq-thumb{width:28px;height:28px;border-radius:7px;background:var(--bg-surface);display:flex;align-items:center;justify-content:center;font-size:.9rem;flex-shrink:0;overflow:hidden;}
.template-eq-item .eq-thumb img{width:100%;height:100%;object-fit:cover;}
.template-eq-item .eq-info{flex:1;min-width:0;}
.template-eq-item .eq-info .eq-name{font-weight:500;color:var(--text-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.template-eq-item .eq-info .eq-plan{font-size:.72rem;color:var(--text-3);}
.template-eq-item .lw{font-family:var(--font-mono);font-size:.72rem;color:var(--accent);white-space:nowrap;}
.template-card-footer{padding:.75rem 1.25rem;border-top:1px solid var(--border);display:flex;gap:.5rem;}
.template-card-actions{position:absolute;top:.75rem;right:.75rem;display:flex;gap:.3rem;opacity:0;transition:opacity .2s;}
.template-card:hover .template-card-actions{opacity:1;}

/* ══════════════════════════════════════════════════════════
   ACTIVE TRAINING VIEW
══════════════════════════════════════════════════════════ */
#active-training{display:none;position:fixed;inset:0;background:var(--bg-deep);z-index:500;overflow-y:auto;}
#active-training.visible{display:block;}
/* Sicherheit: Training-Overlay nie über Auth-Screen zeigen */
body:not(.app-active) #active-training{display:none!important;}
.training-topbar{background:var(--bg-surface);border-bottom:1px solid var(--border);padding:1rem 1.5rem;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:10;}
.training-topbar h2{font-size:1.1rem;color:var(--text-1);}
.session-timer{font-family:var(--font-mono);font-size:1.1rem;color:var(--accent);letter-spacing:.05em;}
.training-content{padding:1.5rem;max-width:700px;margin:0 auto;}

/* Circuit progress bar */
.circuit-progress{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.25rem;margin-bottom:1.5rem;}
.circuit-progress-label{display:flex;justify-content:space-between;font-size:.78rem;color:var(--text-2);margin-bottom:.5rem;}
.circuit-progress-bar{height:6px;background:var(--border);border-radius:3px;overflow:hidden;}
.circuit-progress-fill{height:100%;background:var(--accent);border-radius:3px;transition:width .4s ease;}

/* Equipment blocks */
.eq-block{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:1rem;overflow:hidden;transition:border-color .3s;}
.eq-block.current{border-color:var(--accent);box-shadow:0 0 20px var(--accent-dim);}
.eq-block.done{border-color:var(--green);opacity:.7;}
.eq-block-header{padding:1rem 1.25rem;display:flex;align-items:center;gap:1rem;cursor:pointer;}
.eq-block-thumb{width:48px;height:48px;border-radius:12px;background:var(--bg-surface);display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0;overflow:hidden;}
.eq-block-thumb img{width:100%;height:100%;object-fit:cover;}
.eq-block-info{flex:1;min-width:0;}
.eq-block-name{font-weight:700;font-size:1rem;color:var(--text-1);}
.eq-block-meta{font-size:.78rem;color:var(--text-2);margin-top:.1rem;}
.eq-block-status{display:flex;align-items:center;gap:.5rem;}
.sets-done-badge{font-family:var(--font-mono);font-size:.8rem;color:var(--text-2);}
.eq-block-body{border-top:1px solid var(--border);padding:1rem 1.25rem;}

/* Settings strip */
.settings-strip{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1rem;}
.setting-pill{background:var(--bg-surface);border:1px solid var(--border);border-radius:99px;padding:.2rem .65rem;font-size:.72rem;color:var(--text-2);}
.setting-pill strong{color:var(--text-1);}

/* Weight history mini */
.weight-history-mini{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:.75rem;}
.wh-chip{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.25rem .6rem;font-size:.72rem;}
.wh-chip .wh-val{font-family:var(--font-mono);color:var(--accent);font-weight:700;}
.wh-chip .wh-date{color:var(--text-3);margin-left:.3rem;}

/* Set rows */
.set-row{display:grid;grid-template-columns:32px 1fr 1fr auto;gap:.5rem;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--border);}
.set-row:last-child{border-bottom:none;}
.set-num{font-family:var(--font-mono);font-size:.75rem;color:var(--accent);font-weight:700;text-align:center;}
.set-input{background:var(--bg-surface);border:1px solid var(--border);color:var(--text-1);padding:.4rem .6rem;border-radius:var(--radius-sm);font-size:.9rem;text-align:center;outline:none;font-family:var(--font-mono);width:100%;}
.set-input:focus{border-color:var(--accent);}
.set-row.completed .set-input{border-color:var(--green);background:var(--green-dim);}
.set-check-btn{width:36px;height:36px;border-radius:50%;border:2px solid var(--border);background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;transition:all .2s;flex-shrink:0;}
.set-check-btn:hover{border-color:var(--green);background:var(--green-dim);}
.set-check-btn.checked{background:var(--green);border-color:var(--green);color:#fff;}
.set-row-header{display:grid;grid-template-columns:32px 1fr 1fr auto;gap:.5rem;padding:.3rem 0;margin-bottom:.2rem;}
.set-row-header span{font-size:.68rem;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:.08em;text-align:center;}

/* Pause timer */
.pause-timer{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;margin-bottom:1.5rem;display:none;text-align:center;}
.pause-timer.visible{display:block;}
.pause-timer-label{font-size:.78rem;color:var(--text-2);margin-bottom:.25rem;}
.pause-timer-count{font-family:var(--font-display);font-size:3rem;color:var(--gold);line-height:1;}
.pause-timer-bar{height:4px;background:var(--border);border-radius:2px;margin-top:.5rem;overflow:hidden;}
.pause-timer-fill{height:100%;background:var(--gold);border-radius:2px;transition:width .9s linear;}

/* Add equipment to session */
.add-eq-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;background:var(--bg-card);border:2px dashed var(--border);border-radius:var(--radius);padding:1rem;cursor:pointer;color:var(--text-2);font-weight:500;transition:all .2s;width:100%;margin-bottom:1rem;}
.add-eq-btn:hover{border-color:var(--accent);color:var(--accent);}

/* Finish button */
.finish-zone{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;margin-top:1.5rem;}

/* ══════════════════════════════════════════════════════════
   EQUIPMENT
══════════════════════════════════════════════════════════ */
.equipment-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.25rem;}
.equipment-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:all .25s;cursor:pointer;position:relative;}
.equipment-card:hover{border-color:var(--border-glow);transform:translateY(-3px);box-shadow:0 8px 32px rgba(0,0,0,.4);}
.equipment-card .eq-photo{width:100%;height:140px;object-fit:cover;}
.equipment-card .eq-photo-placeholder{width:100%;height:140px;background:var(--bg-surface);display:flex;align-items:center;justify-content:center;font-size:3rem;}
.equipment-card .eq-body{padding:.85rem;}
.equipment-card .eq-type-badge{font-size:.68rem;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.3rem;}
.equipment-card .eq-name{font-weight:700;font-size:.95rem;color:var(--text-1);margin-bottom:.2rem;}
.equipment-card .eq-lw{font-family:var(--font-mono);font-size:.78rem;color:var(--accent);}
.equipment-card .eq-actions{position:absolute;top:.6rem;right:.6rem;display:flex;gap:.3rem;opacity:0;transition:opacity .2s;}
.equipment-card:hover .eq-actions{opacity:1;}
.eq-filter-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;flex-wrap:wrap;}
.eq-filter-tab{padding:.4rem 1rem;border-radius:99px;font-size:.82rem;font-weight:600;cursor:pointer;border:1px solid var(--border);background:var(--bg-card);color:var(--text-2);transition:all .2s;}
.eq-filter-tab:hover{color:var(--text-1);border-color:var(--text-3);}
.eq-filter-tab.active{background:var(--accent);border-color:var(--accent);color:#fff;}
.emoji-grid{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.5rem;}
.emoji-option{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;cursor:pointer;border-radius:8px;background:var(--bg-surface);border:1px solid var(--border);transition:all .15s;}
.emoji-option:hover,.emoji-option.selected{background:var(--accent-dim);border-color:var(--accent);}
.photo-upload-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:1.5rem;text-align:center;cursor:pointer;transition:border-color .2s;position:relative;overflow:hidden;}
.photo-upload-zone:hover{border-color:var(--accent);}
.photo-upload-zone input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;}
.photo-preview{width:100%;max-height:160px;object-fit:cover;border-radius:var(--radius-sm);margin-top:.75rem;display:none;}
.setting-row{display:grid;grid-template-columns:1fr 1fr 70px auto;gap:.5rem;align-items:center;margin-bottom:.5rem;}

/* ── SESSIONS HISTORY ── */
.session-history-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.25rem;display:flex;align-items:center;gap:1rem;margin-bottom:.75rem;cursor:pointer;transition:all .2s;}
.session-history-item:hover{border-color:var(--border-glow);transform:translateX(3px);}
.session-history-icon{width:44px;height:44px;border-radius:12px;background:var(--accent-dim);display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0;}
.session-history-info{flex:1;min-width:0;}
.session-history-name{font-weight:600;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.session-history-meta{display:flex;gap:.75rem;margin-top:.2rem;}
.session-history-meta span{font-size:.75rem;color:var(--text-2);}
.session-rating{color:var(--gold);font-size:.78rem;}

/* ── MODAL ── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.75);display:flex;align-items:center;justify-content:center;z-index:300;padding:1rem;backdrop-filter:blur(4px);animation:fadeIn .2s ease;}
.modal-overlay.hidden{display:none;}
.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:560px;max-height:92vh;overflow-y:auto;box-shadow:0 24px 60px rgba(0,0,0,.8);animation:slideUp .3s cubic-bezier(.23,1,.32,1);}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.4rem 1.75rem;border-bottom:1px solid var(--border);}
.modal-header h3{font-size:1.1rem;}
.modal-body{padding:1.5rem 1.75rem;}
.modal-footer{padding:1rem 1.75rem;border-top:1px solid var(--border);display:flex;gap:.75rem;justify-content:flex-end;}

/* Segment control */
.segment-control{display:flex;background:var(--bg-surface);border-radius:var(--radius-sm);padding:4px;gap:2px;}
.segment-btn{flex:1;padding:.45rem .5rem;text-align:center;cursor:pointer;border-radius:6px;font-size:.78rem;font-weight:600;color:var(--text-2);transition:all .2s;border:none;background:none;}
.segment-btn.active{background:var(--accent);color:#fff;}

/* Star Rating */
.star-rating{display:flex;gap:.2rem;margin-top:.25rem;}
.star{font-size:1.4rem;cursor:pointer;color:var(--text-3);transition:color .1s;line-height:1;}
.star.active,.star:hover{color:var(--gold);}

/* ── WEIGHT PAGE ── */
.weight-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem;}
.weight-entry-row{display:flex;align-items:center;justify-content:space-between;padding:.65rem .75rem;border-bottom:1px solid var(--border);font-size:.88rem;}
.weight-entry-row:last-child{border-bottom:none;}
.weight-val{font-family:var(--font-mono);color:var(--accent);font-weight:700;}

/* ── MOBILE NAV (inside app-screen) ── */
.mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--bg-surface);border-top:1px solid var(--border);z-index:200;padding:.5rem 0 calc(.5rem + env(safe-area-inset-bottom));}
.mobile-nav-items{display:flex;justify-content:space-around;}
.mobile-nav-item{display:flex;flex-direction:column;align-items:center;gap:.2rem;padding:.4rem .6rem;color:var(--text-3);font-size:.65rem;cursor:pointer;transition:color .2s;border:none;background:none;}
.mobile-nav-item .micon{font-size:1.25rem;}
.mobile-nav-item.active{color:var(--accent);}

/* ── TOAST ── */
.toast-container{position:fixed;bottom:1.5rem;right:1.5rem;z-index:600;display:flex;flex-direction:column;gap:.5rem;}
.toast{background:var(--bg-card);border:1px solid var(--border);border-left:3px solid var(--accent);padding:.8rem 1.2rem;border-radius:var(--radius-sm);font-size:.85rem;box-shadow:0 4px 24px rgba(0,0,0,.5);animation:slideRight .3s ease,fadeOut .3s ease 2.7s forwards;max-width:280px;}
.toast.success{border-left-color:var(--green);}
.toast.error{border-left-color:var(--accent);}

/* ── ANIMATIONS ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideRight{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}
@keyframes fadeOut{to{opacity:0}}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}

/* ── RESPONSIVE ── */
@media(max-width:768px){
  .sidebar{transform:translateX(-100%);}
  .sidebar.open{transform:translateX(0);}
  .main{margin-left:0;padding:1rem;padding-bottom:5rem;}
  .mobile-nav{display:block;}
  .template-grid{grid-template-columns:1fr;}
  .equipment-grid{grid-template-columns:repeat(auto-fill,minmax(155px,1fr));}
  .training-content{padding:1rem;}
  .weight-grid{grid-template-columns:1fr;}
  .setting-row{grid-template-columns:1fr 1fr 60px auto;}
}

/* ── UTILITY ── */
.hidden{display:none!important;}
.text-accent{color:var(--accent);}.text-muted{color:var(--text-2);}.text-sm{font-size:.85rem;}
.flex{display:flex;}.flex-center{display:flex;align-items:center;justify-content:center;}.gap-1{gap:.5rem;}
.mt-1{margin-top:.5rem;}.mt-2{margin-top:1rem;}.mb-1{margin-bottom:.5rem;}.mb-2{margin-bottom:1rem;}
.tag{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .6rem;background:var(--accent-dim);color:var(--accent);border-radius:99px;font-size:.75rem;font-weight:600;}
.divider{border:none;border-top:1px solid var(--border);margin:1.25rem 0;}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.empty-state{text-align:center;padding:3rem 1rem;}
.empty-state .emoji{font-size:3rem;margin-bottom:.75rem;}
.empty-state h3{color:var(--text-1);margin-bottom:.5rem;}
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;}
.section-header h3{font-size:1rem;font-weight:600;}
@media(max-width:480px){.two-col{grid-template-columns:1fr;}}
