/* ── CSS Variables (Neobrutalism Design System) ───────────────────────── */
:root {
  --bg:        #0c0c0c;
  --surface:   #171717;
  --surface-2: #222222;

  --border:     rgba(255,255,255,0.85);
  --border-dim: rgba(255,255,255,0.10);

  --shadow-sm: 2px 2px 0px rgba(255,255,255,0.85);
  --shadow:    4px 4px 0px rgba(255,255,255,0.85);
  --shadow-lg: 6px 6px 0px rgba(255,255,255,0.85);

  --text:     hsl(0,0%,90%);
  --text-dim: hsl(0,0%,48%);

  --yellow: hsl(49,100%,49%);
  --green:  hsl(152,96%,43%);
  --red:    hsl(358,100%,65%);
  --cyan:   hsl(190,100%,47%);
  --blue:   hsl(212,100%,60%);
  --orange: hsl(38,100%,51%);
  --purple: hsl(276,100%,79%);
  --pink:   hsl(332,86%,69%);

  --font: 'Space Grotesk','DM Sans',sans-serif;

  --radius-sm:   4px;
  --radius-base: 8px;
  --radius-lg:  12px;
}

/* ── Reset ───────────────────────────────────────────────────────────────*/
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;-webkit-text-size-adjust:100%}
body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh;padding-bottom:68px;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font-family:var(--font);font-size:inherit}
button{cursor:pointer}
img{display:block;max-width:100%}

/* ── App Container ───────────────────────────────────────────────────────*/
.app{max-width:480px;margin:0 auto;position:relative}
.page{padding:20px 16px 32px}

/* ── Page Header ─────────────────────────────────────────────────────────*/
.page-header{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:var(--bg);border-bottom:1px solid var(--border-dim)}
.page-meta{font-size:11px;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.8px}
.page-title{font-size:20px;font-weight:700;letter-spacing:-.4px;line-height:1.2}

/* ── Bottom Navigation ───────────────────────────────────────────────────*/
.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:68px;background:var(--surface);border-top:1px solid var(--border-dim);display:flex;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;z-index:100}
.bottom-nav::-webkit-scrollbar{display:none}
.nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:0 12px;min-width:52px;flex:1;color:var(--text-dim);text-decoration:none;border:none;background:none;transition:color .1s;flex-shrink:0}
.nav-item:hover,.nav-item.active{color:var(--yellow)}
.nav-item svg{width:20px;height:20px;flex-shrink:0;stroke-width:2}
.nav-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;line-height:1}

/* ── Cards ───────────────────────────────────────────────────────────────*/
.card{background:var(--surface);border:1.5px solid var(--border-dim);border-radius:var(--radius-base);padding:16px}
.card-brutal{background:var(--surface);border:2px solid var(--border);border-radius:var(--radius-base);box-shadow:var(--shadow);padding:16px}

/* ── Buttons ─────────────────────────────────────────────────────────────*/
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:11px 18px;font-family:var(--font);font-size:14px;font-weight:700;border-radius:var(--radius-base);border:2px solid var(--border);cursor:pointer;transition:all .1s ease;white-space:nowrap;line-height:1;text-decoration:none}
.btn-primary{background:var(--yellow);color:#000;box-shadow:var(--shadow)}
.btn-primary:hover{box-shadow:var(--shadow-sm);transform:translate(2px,2px)}
.btn-primary:active{box-shadow:none;transform:translate(4px,4px)}
.btn-secondary{background:var(--surface-2);color:var(--text);box-shadow:var(--shadow-sm)}
.btn-secondary:hover{box-shadow:none;transform:translate(2px,2px)}
.btn-danger{background:var(--red);color:#000;box-shadow:var(--shadow-sm)}
.btn-danger:hover{box-shadow:none;transform:translate(2px,2px)}
.btn-green{background:var(--green);color:#000;box-shadow:var(--shadow-sm)}
.btn-green:hover{box-shadow:none;transform:translate(2px,2px)}
.btn-ghost{background:transparent;color:var(--text-dim);border-color:var(--border-dim);box-shadow:none}
.btn-ghost:hover{color:var(--text);border-color:var(--border)}
.btn-full{width:100%}
.btn-sm{padding:7px 12px;font-size:12px}
.btn-lg{padding:15px 24px;font-size:16px}
.btn-icon{padding:8px}

/* ── Form Elements ───────────────────────────────────────────────────────*/
.form-stack{display:flex;flex-direction:column;gap:18px}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text-dim)}
.input,.select,.textarea{width:100%;padding:11px 14px;font-family:var(--font);font-size:15px;font-weight:500;background:var(--surface-2);color:var(--text);border:2px solid var(--border-dim);border-radius:var(--radius-base);outline:none;transition:border-color .1s,box-shadow .1s;appearance:none;-webkit-appearance:none}
.input:focus,.select:focus,.textarea:focus{border-color:var(--border);box-shadow:var(--shadow-sm)}
.input::placeholder,.textarea::placeholder{color:var(--text-dim)}
.select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23777' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:16px;padding-right:36px;cursor:pointer}
.select option{background:var(--surface-2)}
.textarea{resize:vertical;min-height:88px;line-height:1.5}

/* ── Rating Buttons ──────────────────────────────────────────────────────*/
.rating-row{display:flex;gap:8px}
.rating-btn{flex:1;padding:10px 4px;font-family:var(--font);font-size:13px;font-weight:700;background:var(--surface-2);color:var(--text-dim);border:2px solid var(--border-dim);border-radius:var(--radius-sm);cursor:pointer;transition:all .1s;text-align:center}
.rating-btn:hover,.rating-btn.active{background:var(--yellow);color:#000;border-color:var(--border);box-shadow:var(--shadow-sm)}

/* ── Tags Input ──────────────────────────────────────────────────────────*/
.tags-wrap{display:flex;flex-wrap:wrap;gap:6px;padding:10px 12px;background:var(--surface-2);border:2px solid var(--border-dim);border-radius:var(--radius-base);min-height:46px;cursor:text;align-items:center;transition:border-color .1s,box-shadow .1s}
.tags-wrap:focus-within{border-color:var(--border);box-shadow:var(--shadow-sm)}
.tag{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;background:var(--yellow);color:#000;border:1.5px solid rgba(0,0,0,0.4);border-radius:var(--radius-sm);font-size:12px;font-weight:700;line-height:1.4}
.tag-x{background:none;border:none;color:inherit;cursor:pointer;font-size:14px;line-height:1;font-weight:900;padding:0;display:flex;align-items:center}
.tag-input-field{border:none;background:transparent;color:var(--text);font-family:var(--font);font-size:14px;font-weight:500;outline:none;flex:1;min-width:80px}
.tag-input-field::placeholder{color:var(--text-dim)}

/* ── Badges ──────────────────────────────────────────────────────────────*/
.badge{display:inline-block;padding:3px 8px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;border:1.5px solid var(--border);border-radius:var(--radius-sm);line-height:1.4;white-space:nowrap}
.badge-yellow{background:var(--yellow);color:#000}
.badge-green{background:var(--green);color:#000}
.badge-red{background:var(--red);color:#000}
.badge-cyan{background:var(--cyan);color:#000}
.badge-blue{background:var(--blue);color:#000}
.badge-orange{background:var(--orange);color:#000}
.badge-purple{background:var(--purple);color:#000}
.badge-dim{background:var(--surface-2);color:var(--text-dim);border-color:var(--border-dim)}

/* ── Stat Grid ───────────────────────────────────────────────────────────*/
.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.stat-card{background:var(--surface);border:1.5px solid var(--border-dim);border-radius:var(--radius-base);padding:14px}
.stat-card.bold{border-color:var(--border);box-shadow:var(--shadow-sm)}
.stat-num{font-size:36px;font-weight:900;line-height:1;letter-spacing:-2px}
.stat-lbl{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--text-dim);margin-top:4px}

/* ── Section ─────────────────────────────────────────────────────────────*/
.section{margin-bottom:28px}
.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-dim)}

/* ── Divider ─────────────────────────────────────────────────────────────*/
.divider{height:1px;background:var(--border-dim);margin:14px 0}

/* ── Empty State ─────────────────────────────────────────────────────────*/
.empty-state{text-align:center;padding:40px 20px;color:var(--text-dim)}
.empty-icon{font-size:40px;margin-bottom:10px}
.empty-title{font-size:16px;font-weight:700;color:var(--text);margin-bottom:6px}
.empty-text{font-size:13px;line-height:1.5;margin-bottom:20px}

/* ── Bar Chart ───────────────────────────────────────────────────────────*/
.bar-chart{display:flex;align-items:flex-end;gap:5px;height:100px;padding-top:8px}
.bar-col{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:5px;height:100%}
.bar{width:100%;background:var(--yellow);border:1.5px solid var(--border);border-radius:3px 3px 0 0;min-height:3px;transition:height .3s ease}
.bar.gi{background:var(--blue)}
.bar.nogi{background:var(--cyan)}
.bar.drill{background:var(--orange)}
.bar.comp{background:var(--red)}
.bar-lbl{font-size:9px;font-weight:700;color:var(--text-dim);text-transform:uppercase;letter-spacing:.2px;text-align:center;line-height:1}

/* ── Progress Bar ────────────────────────────────────────────────────────*/
.prog-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.prog-label{font-size:13px;font-weight:600;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.prog-count{font-size:12px;color:var(--text-dim);font-weight:700;flex-shrink:0;min-width:28px;text-align:right}
.prog-outer{height:7px;background:var(--surface-2);border:1.5px solid var(--border-dim);border-radius:4px;overflow:hidden;flex:2}
.prog-inner{height:100%;background:var(--yellow);border-radius:4px;transition:width .4s ease}

/* ── Modal ───────────────────────────────────────────────────────────────*/
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:200;display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s}
.modal-overlay.open{opacity:1;pointer-events:auto}
.modal{background:var(--surface);border:2px solid var(--border);border-radius:var(--radius-lg) var(--radius-lg) 0 0;box-shadow:0 -4px 0px var(--border);width:100%;max-width:480px;padding:20px 16px 32px;max-height:85vh;overflow-y:auto;transform:translateY(20px);transition:transform .2s}
.modal-overlay.open .modal{transform:translateY(0)}
.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.modal-title{font-size:18px;font-weight:700}

/* ── Toast ───────────────────────────────────────────────────────────────*/
.toast{position:fixed;top:16px;left:50%;transform:translateX(-50%) translateY(-80px);background:var(--surface);border:2px solid var(--border);box-shadow:var(--shadow);border-radius:var(--radius-base);padding:11px 18px;font-size:14px;font-weight:700;z-index:500;transition:transform .2s ease;white-space:nowrap;max-width:calc(100vw - 40px)}
.toast.show{transform:translateX(-50%) translateY(0)}
.toast-success{color:var(--green)}
.toast-error{color:var(--red)}

/* ── Filter Chips ────────────────────────────────────────────────────────*/
.filter-row{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none}
.filter-row::-webkit-scrollbar{display:none}
.chip{padding:6px 12px;font-size:12px;font-weight:700;border:2px solid var(--border-dim);border-radius:100px;background:var(--surface);color:var(--text-dim);cursor:pointer;white-space:nowrap;transition:all .1s;flex-shrink:0;font-family:var(--font)}
.chip.active{background:var(--yellow);color:#000;border-color:var(--border);box-shadow:var(--shadow-sm)}

/* ── Search Bar ──────────────────────────────────────────────────────────*/
.search-wrap{position:relative}
.search-wrap svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-dim);width:16px;height:16px;pointer-events:none}
.search-wrap .input{padding-left:38px}

/* ── Status Dots ─────────────────────────────────────────────────────────*/
.status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0}
.dot-red{background:var(--red)}
.dot-yellow{background:var(--yellow)}
.dot-green{background:var(--green)}
.dot-cyan{background:var(--cyan)}

/* ── Utilities ───────────────────────────────────────────────────────────*/
.text-yellow{color:var(--yellow)}
.text-green{color:var(--green)}
.text-red{color:var(--red)}
.text-cyan{color:var(--cyan)}
.text-blue{color:var(--blue)}
.text-dim{color:var(--text-dim)}
.font-bold{font-weight:700}
.font-black{font-weight:900}
.text-xs{font-size:11px}
.text-sm{font-size:13px}
.text-lg{font-size:18px}
.text-xl{font-size:24px}
.flex{display:flex}
.flex-col{flex-direction:column}
.items-center{align-items:center}
.justify-between{justify-content:space-between}
.gap-1{gap:4px}
.gap-2{gap:8px}
.gap-3{gap:12px}
.mt-1{margin-top:4px}
.mt-2{margin-top:8px}
.mt-3{margin-top:12px}
.mt-4{margin-top:16px}
.mb-2{margin-bottom:8px}
.mb-3{margin-bottom:12px}
.mb-4{margin-bottom:16px}
.w-full{width:100%}
.pill-row{display:flex;flex-wrap:wrap;gap:6px}
