/* IHOH DPB — UI Components */

/* ── Resources page ── */
.resources-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-5);padding:0 var(--space-10) var(--space-8);}
.res-card{background:var(--panel-raised);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-5);}
.res-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-3);}
.res-card-name{font-size:14px;font-weight:600;color:var(--ink);}
.res-card-cost{font-family:var(--font-mono);font-size:13px;font-weight:500;color:var(--teal);white-space:nowrap;}
.res-card-cost.res-free{color:var(--success);}
.res-card-cost.res-usage{color:var(--warning);}
.res-card-desc{font-size:12px;color:var(--muted);line-height:1.5;margin-bottom:var(--space-3);}
.res-card-tag{display:inline-flex;align-items:center;font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:2px 7px;border-radius:var(--radius-pill);background:var(--field);color:var(--faint);margin-right:4px;margin-bottom:4px;}
.res-card-tags{display:flex;flex-wrap:wrap;}
.res-add-btn{display:flex;align-items:center;justify-content:center;gap:5px;padding:6px 12px;border-radius:var(--radius);background:var(--field);border:1px solid var(--field-border);color:var(--muted);font-size:12px;font-weight:500;cursor:pointer;transition:all var(--t-fast);}
.res-add-btn:hover{background:var(--panel-raised);color:var(--teal);border-color:var(--teal-soft);}
.res-add-row{padding:var(--space-5) var(--space-10) var(--space-4);}
.res-total-bar{background:var(--panel);border-top:1px solid var(--border-subtle);padding:var(--space-4) var(--space-10);display:flex;align-items:center;gap:var(--space-4);position:sticky;bottom:0;}
.res-total-label{font-size:12px;color:var(--muted);}
.res-total-val{font-family:var(--font-mono);font-size:15px;font-weight:600;color:var(--ink);}
.res-total-period{font-size:11px;color:var(--faint);}
.res-edit-btn{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--muted);background:none;border:none;cursor:pointer;margin-left:auto;}
.res-edit-btn:hover{color:var(--teal);}

/* ── Macro list ── */
.macro-container{margin-bottom:var(--space-6);}
.macro-block{
  border:1px solid var(--border-subtle);
  border-radius:var(--radius-lg);overflow:hidden;
  margin-bottom:3px;
  background:var(--panel);
}
.finale-divider{
  display:flex;align-items:center;gap:var(--space-3);
  padding:var(--space-3) 0 var(--space-2);
}
.finale-line{flex:1;height:1px;background:var(--border-subtle);}
.finale-text{font-size:10px;font-weight:600;letter-spacing:.10em;text-transform:uppercase;color:var(--faint);}

.macro-trigger{
  display:flex;align-items:center;gap:var(--space-5);
  padding:16px var(--space-6);cursor:pointer;
  transition:background var(--t-fast);user-select:none;
}
.macro-trigger:hover{background:var(--panel-raised);}

.m-ind{
  width:3px;height:40px;border-radius:var(--radius-pill);flex-shrink:0;
}
.ind-done  {background:var(--success);}
.ind-wip   {background:var(--teal);}
.ind-next  {background:var(--warning);opacity:.5;}
.ind-locked{background:var(--faint);opacity:.3;}

.m-num{font-family:var(--font-mono);font-size:11px;color:var(--faint);width:24px;flex-shrink:0;}

.m-info{flex:1;min-width:0;}
.m-name{font-size:15px;font-weight:600;color:var(--ink);margin-bottom:3px;}
.m-desc{font-size:12px;color:var(--muted);line-height:1.45;
  overflow:hidden;white-space:nowrap;text-overflow:ellipsis;max-width:600px;}

.m-right{display:flex;align-items:center;gap:var(--space-5);flex-shrink:0;}
.m-micro-dots{display:flex;gap:5px;align-items:center;}
.m-dot{width:8px;height:8px;border-radius:50%;}
.md-done  {background:var(--success);}
.md-wip   {background:var(--teal);}
.md-next  {background:var(--warning);opacity:.5;}
.md-locked{background:var(--panel-raised);border:1px solid var(--field-border);}

.m-pts{text-align:right;min-width:72px;}
.m-pts-val{font-family:var(--font-mono);font-size:15px;font-weight:500;color:var(--ink);}
.m-pts-of {font-family:var(--font-mono);font-size:10px;color:var(--faint);}

.status-pill{
  font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  padding:4px 12px;border-radius:var(--radius-pill);
  width:96px;text-align:center;flex-shrink:0;
}
.sp-done  {background:var(--success-soft);color:var(--success);}
.sp-wip   {background:var(--teal-soft);color:var(--teal);}
.sp-next  {background:var(--warning-soft);color:var(--warning);}
.sp-locked{background:var(--panel-raised);color:var(--faint);}

.m-chevron{color:var(--faint);transition:transform var(--t-fast);flex-shrink:0;}
.macro-block.open .m-chevron{transform:rotate(90deg);}

.m-prog{height:2px;background:var(--panel-raised);}
.m-prog-fill{height:100%;transition:width .5s var(--ease);}
.mpf-done  {background:var(--success);}
.mpf-wip   {background:var(--teal);}
.mpf-next  {background:var(--warning);opacity:.4;}
.mpf-locked{background:transparent;}

/* ── Micro list ── */
.micro-list{
  display:none;
  border-top:1px solid var(--border-subtle);
  background:var(--field);
}
.macro-block.open .micro-list{display:block;}

.micro-row{
  display:flex;align-items:center;
  padding:11px var(--space-6) 11px 62px;gap:var(--space-4);
  border-bottom:1px solid var(--border-subtle);
  cursor:pointer;transition:background var(--t-fast);
}
.micro-row:last-child{border-bottom:none;}
.micro-row:hover{background:rgba(255,255,255,.025);}

.mc-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;transition:background var(--t-fast),border-color var(--t-fast);}
.mcd-done  {background:var(--success);}
.mcd-next  {background:transparent;border:1.5px solid var(--field-border);}
.mcd-locked{background:transparent;border:1.5px solid var(--panel-raised);}

.mc-name{flex:1;font-size:13px;}
.mcn-done  {color:var(--ink);}
.mcn-next  {color:var(--muted);}
.mcn-locked{color:var(--faint);}

.mc-pts{font-family:var(--font-mono);font-size:11px;flex-shrink:0;}
.mcp-done  {color:var(--success);}
.mcp-next  {color:var(--faint);}
.mcp-locked{color:var(--panel-raised);}

.mc-hint{font-size:10px;color:var(--faint);opacity:0;transition:opacity var(--t-fast);flex-shrink:0;min-width:90px;text-align:right;}
.micro-row:hover .mc-hint{opacity:1;}

/* ── Status board ── */
.status-grand{
  padding:var(--space-10);
  background:var(--panel);
  border-bottom:1px solid var(--border-subtle);
}
.sg-top{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:var(--space-5);}
.sg-label{font-size:11px;font-weight:600;letter-spacing:.10em;text-transform:uppercase;color:var(--muted);margin-bottom:var(--space-2);}
.sg-pts{font-family:var(--font-mono);font-size:40px;font-weight:500;color:var(--ink);line-height:1;}
.sg-pts span{font-size:16px;color:var(--muted);}
.sg-pct{font-family:var(--font-mono);font-size:16px;color:var(--teal);}
.sg-track{width:100%;height:7px;background:var(--panel-raised);border-radius:var(--radius-pill);overflow:hidden;}
.sg-fill{height:100%;border-radius:var(--radius-pill);background:var(--teal);transition:width 1.2s var(--ease);}
.sg-legend{display:flex;gap:var(--space-6);margin-top:var(--space-4);align-items:center;flex-wrap:wrap;}
.sg-leg-item{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted);}
.sg-leg-dot{width:8px;height:8px;border-radius:50%;}

.status-grid{
  display:flex;flex-direction:row;
  overflow-x:auto;overflow-y:clip;
  overscroll-behavior-x:none;
  gap:1px;
  background:var(--border-subtle);
  scrollbar-width:none;
}
.status-grid::-webkit-scrollbar{display:none;}
.status-product-card{
  background:var(--page-bg);padding:var(--space-8) var(--space-8) var(--space-6);
  cursor:pointer;transition:background var(--t-fast);
  min-width:280px;flex:1;
}
.status-product-card:hover{background:var(--panel);}
.spc-eyebrow{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-5);}
.spc-code{font-family:var(--font-mono);font-size:10px;color:var(--faint);letter-spacing:.06em;}
.spc-name{font-size:20px;font-weight:700;letter-spacing:-.01em;color:var(--ink);margin-bottom:4px;}
.spc-platform{font-size:12px;color:var(--muted);margin-bottom:var(--space-6);}
.spc-pts{font-family:var(--font-mono);font-size:28px;font-weight:500;color:var(--ink);line-height:1;margin-bottom:2px;}
.spc-pts span{font-size:13px;color:var(--muted);}
.spc-pct{font-family:var(--font-mono);font-size:12px;color:var(--teal);margin-bottom:var(--space-4);}
.spc-track{width:100%;height:3px;background:var(--panel-raised);border-radius:var(--radius-pill);overflow:hidden;margin-bottom:var(--space-4);}
.spc-fill{height:100%;border-radius:var(--radius-pill);background:var(--teal);transition:width 1.4s var(--ease);}
.spc-dots{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:var(--space-5);}
.spc-macro-stages{display:flex;flex-direction:column;gap:3px;}
.spc-stage-row{display:flex;align-items:center;gap:var(--space-3);}
.spc-stage-ind{width:2px;height:14px;border-radius:var(--radius-pill);flex-shrink:0;}
.spc-stage-label{font-size:11px;color:var(--muted);overflow:hidden;white-space:nowrap;text-overflow:ellipsis;flex:1;}
.spc-stage-pts{font-family:var(--font-mono);font-size:10px;color:var(--faint);margin-left:auto;flex-shrink:0;}

.status-stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:var(--border-subtle);
  border-top:1px solid var(--border-subtle);
}
.stat-cell{
  background:var(--panel);
  padding:var(--space-6) var(--space-8);
}
.stat-label{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);margin-bottom:var(--space-2);}
.stat-val{font-family:var(--font-mono);font-size:32px;font-weight:500;color:var(--ink);line-height:1;margin-bottom:4px;}
.stat-note{font-size:12px;color:var(--muted);}

/* ── Audit banner ── */
.audit-banner{
  margin:var(--space-6) var(--space-10) 0;
  background:var(--info-soft);
  border:1px solid rgba(74,158,255,.2);
  border-radius:var(--radius-lg);
  padding:var(--space-4) var(--space-5);
  display:flex;align-items:flex-start;gap:var(--space-3);
}
.audit-banner-icon{color:var(--info);flex-shrink:0;margin-top:1px;}
/* ── Reference page ── */
.ref-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4);}
.ref-card{
  background:var(--panel);border:1px solid var(--border-subtle);
  border-radius:var(--radius-lg);overflow:hidden;
}
.ref-card-head{
  display:flex;align-items:center;gap:var(--space-3);
  padding:var(--space-4) var(--space-5);
  border-bottom:1px solid var(--border-subtle);
  background:var(--panel-raised);
}
.ref-card-icon{
  width:32px;height:32px;border-radius:var(--radius);
  background:var(--field);display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.ref-card-title{font-size:13px;font-weight:600;color:var(--ink);margin-bottom:1px;}
.ref-card-code{font-family:var(--font-mono);font-size:10px;color:var(--faint);}
/* ── KV page ── */
.kv-layout{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4);}
.kv-card-wide{grid-column:1/-1;}
.kv-card{background:var(--panel);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden;}
.kv-card-head{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-subtle);background:var(--panel-raised);}
.kv-card-title{font-size:13px;font-weight:600;color:var(--ink);flex:1;}
.kv-card-sub{font-size:11px;color:var(--faint);font-family:var(--font-mono);}
/* ── Edit Controls (Add Micro / Add Macro) ── */
.edit-controls{
  padding:var(--space-4) var(--space-6);
  border-top:1px solid var(--border-subtle);
  background:var(--field);
  display:flex;justify-content:flex-start;
}

.add-btn{
  display:inline-flex;align-items:center;gap:5px;
  font-size:11px;font-weight:500;
  color:var(--muted);
  background:var(--panel-raised);
  border:1px solid var(--border-subtle);
  padding:4px 10px;
  border-radius:var(--radius-pill);
  cursor:pointer;
  transition:background var(--t-fast),color var(--t-fast),border-color var(--t-fast);
}
.add-btn:hover{background:var(--teal-dim);color:var(--teal);border-color:var(--teal-soft);}

.add-macro-controls{
  padding:var(--space-4) var(--space-6) var(--space-4);
  display:flex;justify-content:flex-start;
}

/* ── Inline Forms ── */
.inline-form{
  background:var(--panel-raised);
  border:1px solid var(--border-subtle);
  border-radius:var(--radius);
  padding:var(--space-4);
  margin:var(--space-3) var(--space-6);
  animation:fadeInUp .2s var(--ease);
}
.inline-form-title{font-size:12px;font-weight:600;color:var(--muted);margin-bottom:var(--space-3);letter-spacing:.04em;text-transform:uppercase;}
.inline-form input,
.inline-form textarea{
  width:100%;
  background:var(--field);
  border:1px solid var(--field-border);
  border-radius:var(--radius);
  padding:8px 10px;
  font-family:var(--font-sans);
  font-size:12px;
  color:var(--ink);
  outline:none;
  transition:border-color var(--t-fast);
  margin-bottom:var(--space-2);
  display:block;
}
.inline-form input:focus,
.inline-form textarea:focus{border-color:var(--teal);}
.inline-form input::placeholder,
.inline-form textarea::placeholder{color:var(--faint);}
.inline-form textarea{resize:vertical;min-height:60px;font-family:var(--font-sans);}
.inline-form-label{font-size:11px;font-weight:600;color:var(--faint);letter-spacing:.05em;text-transform:uppercase;display:block;margin-bottom:4px;margin-top:var(--space-2);}
.inline-form-section{margin-top:var(--space-3);border-top:1px solid var(--border-subtle);padding-top:var(--space-3);}
.inline-form-section-title{font-size:11px;color:var(--faint);font-weight:600;letter-spacing:.06em;text-transform:uppercase;margin-bottom:var(--space-2);}
.inline-form-actions{
  display:flex;gap:var(--space-2);
  justify-content:flex-end;
  margin-top:var(--space-3);
}
.inline-form-actions .kv-btn{padding:6px 14px;font-size:12px;}

/* ── Reference Spotlight editing ── */
.ref-item-editable{position:relative;}
.ref-item-actions{
  display:flex;gap:4px;align-items:center;flex-shrink:0;
  opacity:0;transition:opacity var(--t-fast);
  margin-left:var(--space-3);
}
.ref-item-editable:hover .ref-item-actions{opacity:1;}
.ref-action-btn{
  width:24px;height:24px;border-radius:6px;
  display:flex;align-items:center;justify-content:center;
  background:var(--panel-raised);color:var(--muted);
  border:1px solid var(--border-subtle);
  cursor:pointer;transition:background var(--t-fast),color var(--t-fast);
  flex-shrink:0;
}
.ref-action-btn:hover{background:var(--field);color:var(--ink);}
.ref-action-del:hover{background:var(--error-soft);color:var(--error);border-color:rgba(255,95,95,.2);}
.ref-add-note-btn{
  display:inline-flex;align-items:center;gap:5px;
  font-size:11px;font-weight:500;color:var(--muted);
  background:var(--panel-raised);border:1px solid var(--border-subtle);
  padding:4px 10px;border-radius:var(--radius-pill);
  cursor:pointer;transition:background var(--t-fast),color var(--t-fast);
  flex-shrink:0;
}
.ref-add-note-btn:hover{background:var(--teal-dim);color:var(--teal);border-color:var(--teal-soft);}
.ref-card-head{align-items:center;}

/* ── Add Product Button on Status Board ── */
.add-product-row{
  padding:var(--space-6) var(--space-8);
  background:var(--page-bg);
  border-top:1px solid var(--border-subtle);
  display:flex;justify-content:flex-start;
}
.add-product-btn{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--teal);color:var(--on-teal);
  font-size:13px;font-weight:600;
  padding:9px 20px;border-radius:var(--radius);
  cursor:pointer;
  transition:background var(--t-fast);
  border:none;
}
.add-product-btn:hover{background:var(--teal-hover);}

/* ── Modal ── */
.modal-overlay{
  position:fixed;inset:0;
  background:rgba(0,0,0,.7);
  z-index:500;
  display:flex;align-items:flex-start;justify-content:center;
  padding:var(--space-8) var(--space-4);
  overflow-y:auto;
  animation:fadeInUp .2s var(--ease);
}
.modal-overlay.hidden{display:none!important;}
.modal{
  background:var(--panel);
  border:1px solid var(--border-subtle);
  border-radius:var(--radius-xl);
  width:100%;max-width:560px;
  box-shadow:var(--shadow-md);
  overflow:hidden;
  margin:auto;
}
.modal-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:var(--space-5) var(--space-6);
  border-bottom:1px solid var(--border-subtle);
  background:var(--panel-raised);
}
.modal-title{font-size:16px;font-weight:700;color:var(--ink);letter-spacing:-.01em;}
.modal-close{
  width:28px;height:28px;display:flex;align-items:center;justify-content:center;
  border-radius:var(--radius);background:var(--field);color:var(--muted);
  cursor:pointer;transition:background var(--t-fast),color var(--t-fast);
  border:1px solid var(--border-subtle);font-size:16px;line-height:1;
}
.modal-close:hover{background:var(--error-soft);color:var(--error);}
/* ── Form fields inside modal ── */
.form-field{margin-bottom:var(--space-4);}
.form-field label{
  display:block;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  color:var(--muted);margin-bottom:var(--space-2);
}
.form-field input,
.form-field select,
.form-field textarea{
  width:100%;
  background:var(--field);
  border:1px solid var(--field-border);
  border-radius:var(--radius);
  padding:9px 12px;
  font-family:var(--font-mono);
  font-size:12px;
  color:var(--ink);
  outline:none;
  transition:border-color var(--t-fast);
}
.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus{border-color:var(--teal);}
.form-field input::placeholder,
.form-field textarea::placeholder{color:var(--faint);}
.form-field select{appearance:none;cursor:pointer;}
.form-field select option{background:var(--panel);color:var(--ink);}
.form-field textarea{resize:vertical;min-height:70px;font-family:var(--font-sans);font-size:13px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4);}
.form-section-title{
  font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:var(--teal);margin:var(--space-5) 0 var(--space-3);
  padding-top:var(--space-4);border-top:1px solid var(--border-subtle);
}
.form-macro-block{
  background:var(--field);border:1px solid var(--border-subtle);
  border-radius:var(--radius);padding:var(--space-4);margin-bottom:var(--space-3);
}
.form-macro-num{font-size:11px;font-weight:600;color:var(--teal);margin-bottom:var(--space-3);font-family:var(--font-mono);}

/* ── Sync Status Pill ── */
.sync-pill{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--font-mono);font-size:11px;font-weight:600;
  padding:5px 12px;border-radius:var(--radius-pill);
  border:1px solid transparent;
  transition:all var(--t-med);
  flex-shrink:0;
  letter-spacing:.02em;
}
.sync-pill-dot{
  width:7px;height:7px;border-radius:50%;flex-shrink:0;
}
.sync-pill.pulling{
  background:var(--warning-soft);color:var(--warning);
  border-color:rgba(245,166,35,.3);
}
.sync-pill.pulling .sync-pill-dot{background:var(--warning);animation:pulse .8s infinite;}
.sync-pill.synced{
  background:var(--success-soft);color:var(--success);
  border-color:rgba(0,196,140,.3);
}
.sync-pill.synced .sync-pill-dot{background:var(--success);}
.sync-pill.offline{
  background:var(--error-soft);color:var(--error);
  border-color:rgba(255,95,95,.3);
}
.sync-pill.offline .sync-pill-dot{background:var(--error);}
.sync-pill.not-configured{
  background:var(--field);color:var(--muted);
  border-color:var(--field-border);
}
.sync-pill.not-configured .sync-pill-dot{background:var(--muted);opacity:.6;}

/* ── Changelog Section ── */
.changelog-section{
  border-top:1px solid var(--border-subtle);
  padding:var(--space-10);
}
.changelog-header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:var(--space-6);
}
.changelog-title{
  font-size:11px;font-weight:600;letter-spacing:.10em;text-transform:uppercase;
  color:var(--muted);
}
.changelog-add-btn{
  display:inline-flex;align-items:center;gap:5px;
  font-size:11px;font-weight:500;color:var(--muted);
  background:var(--panel-raised);border:1px solid var(--border-subtle);
  padding:5px 12px;border-radius:var(--radius-pill);
  cursor:pointer;transition:background var(--t-fast),color var(--t-fast);
}
.changelog-add-btn:hover{background:var(--teal-dim);color:var(--teal);border-color:var(--teal-soft);}
.changelog-list{
  display:flex;flex-direction:column;gap:1px;
}
.changelog-entry{
  display:flex;gap:var(--space-5);
  padding:var(--space-5) var(--space-6);
  background:var(--panel);
  border-radius:var(--radius);
  position:relative;
  transition:background var(--t-fast);
}
.changelog-entry:hover{background:var(--panel-raised);}
.changelog-entry:hover .changelog-entry-actions{opacity:1;}
.changelog-timeline{
  display:flex;flex-direction:column;align-items:center;flex-shrink:0;
  padding-top:3px;
}
.changelog-dot{
  width:10px;height:10px;border-radius:50%;flex-shrink:0;
  border:2px solid var(--panel);
}
.changelog-line{
  width:2px;min-height:40px;flex:1;background:var(--border-subtle);
  margin-top:6px;border-radius:1px;
}

