/* Electro — 02-layout.css */
  /* TOPBAR */
  .topbar { background: var(--surface); border-bottom: 0.5px solid var(--border); padding: 0 24px; display: flex; align-items: center; justify-content: space-between; height: 52px; position: sticky; top: 0; z-index: 100; }
  .logo { display: flex; align-items: center; gap: 8px; font-size: 16px; font-weight: 500; color: var(--text); }
  .logo i { color: var(--blue); font-size: 20px; }
  .role-tabs { display: flex; gap: 3px; background: var(--bg); border-radius: var(--radius); padding: 3px; border: 0.5px solid var(--border); }
  .role-tab { padding: 5px 16px; border-radius: 6px; font-size: 13px; cursor: pointer; border: none; background: transparent; color: var(--muted); font-family: 'DM Sans', sans-serif; display: flex; align-items: center; gap: 6px; transition: all .15s; }
  .role-tab.active { background: var(--surface); color: var(--text); font-weight: 500; box-shadow: 0 1px 3px rgba(0,0,0,0.08); }
  .user-area { display: flex; align-items: center; gap: 10px; }
  .notif-wrap { position: relative; display: flex; align-items: center; }
  .notif-dot { position: absolute; top: -1px; right: -1px; width: 7px; height: 7px; border-radius: 50%; background: #D85A30; border: 1.5px solid var(--surface); }
  .avatar { width: 30px; height: 30px; border-radius: 50%; background: var(--blue-light); color: var(--blue-text); display: flex; align-items: center; justify-content: center; font-size: 11px; font-weight: 500; flex-shrink: 0; }

  /* LAYOUT */
  .main { display: flex; height: calc(100vh - 52px); }
  .sidebar { width: 260px; background: var(--surface); border-right: 0.5px solid var(--border); display: flex; flex-direction: column; flex-shrink: 0; }
  .sidebar-head { padding: 14px 16px; border-bottom: 0.5px solid var(--border); display: flex; align-items: center; justify-content: space-between; }
  .sidebar-label { font-size: 11px; font-weight: 500; color: var(--hint); text-transform: uppercase; letter-spacing: .06em; }
  .btn-new { background: var(--blue); color: var(--blue-light); border: none; border-radius: var(--radius); padding: 5px 11px; font-size: 12px; cursor: pointer; display: flex; align-items: center; gap: 4px; font-family: 'DM Sans', sans-serif; transition: background .15s; }
  .btn-new:hover { background: var(--blue-dark); }
  .filters { display: flex; gap: 5px; padding: 10px 12px; border-bottom: 0.5px solid var(--border); flex-wrap: wrap; }
  .chip { font-size: 11px; padding: 3px 10px; border-radius: 20px; cursor: pointer; border: 0.5px solid var(--border); background: transparent; color: var(--muted); font-family: 'DM Sans', sans-serif; transition: all .15s; }
  .chip:hover { border-color: var(--border-md); color: var(--text); }
  .chip.active { background: var(--blue); color: var(--blue-light); border-color: var(--blue); }
  .pedido-list { flex: 1; overflow-y: auto; }
  .pedido-item { padding: 12px 16px; border-bottom: 0.5px solid var(--border); cursor: pointer; transition: background .12s; border-left: 2px solid transparent; }
  .pedido-item:hover { background: var(--bg); }
  .pedido-item.active { background: var(--blue-light); border-left-color: var(--blue); }
  .ped-id { font-size: 11px; color: var(--hint); font-family: 'DM Mono', monospace; margin-bottom: 2px; }
  .ped-name { font-size: 13px; font-weight: 500; color: var(--text); margin-bottom: 5px; }
  .ped-footer { display: flex; justify-content: space-between; align-items: center; }
  .badge { font-size: 11px; padding: 2px 8px; border-radius: 20px; font-weight: 500; }
  .s-pendiente { background: var(--amber-light); color: var(--amber); }
  .s-en-curso { background: var(--blue-light); color: var(--blue-text); }
  .s-completado { background: var(--green-light); color: var(--green); }
  .s-problema { background: var(--red-light); color: var(--red); }
  .s-urgente { background: #fff0f0; color: #c0392b; font-weight: 700; border: 1px solid #f5c6c6; }
  .s-urgente::before { content: '🔴 '; font-size: 9px; }
  .ped-date { font-size: 11px; color: var(--hint); }

  /* CONTENT */
  .content { flex: 1; display: flex; flex-direction: column; overflow: hidden; }
  .content-head { background: var(--surface); border-bottom: 0.5px solid var(--border); padding: 16px 24px; display: flex; align-items: flex-start; justify-content: space-between; }
  .content-title { font-size: 17px; font-weight: 500; margin-bottom: 3px; }
  .content-sub { font-size: 12px; color: var(--muted); display: flex; align-items: center; gap: 4px; }
  .head-actions { display: flex; gap: 8px; }
  .btn { padding: 6px 14px; border-radius: var(--radius); font-size: 13px; cursor: pointer; border: 0.5px solid var(--border-md); background: var(--surface); color: var(--text); display: inline-flex; align-items: center; gap: 6px; font-family: 'DM Sans', sans-serif; transition: background .15s; }
  .btn:hover { background: var(--bg); }
  .btn-primary { background: var(--blue); color: var(--blue-light); border-color: var(--blue); }
  .btn-primary:hover { background: var(--blue-dark); }
  .content-body { padding: 20px 24px; flex: 1; overflow-y: auto; display: flex; flex-direction: column; gap: 14px; }

  /* CARDS */
  .card { background: var(--surface); border: 0.5px solid var(--border); border-radius: var(--radius-lg); padding: 16px; }
  .card-label { font-size: 11px; font-weight: 500; color: var(--hint); text-transform: uppercase; letter-spacing: .06em; margin-bottom: 12px; }
  .info-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
  .info-row { display: flex; flex-direction: column; gap: 2px; }
  .info-key { font-size: 11px; color: var(--hint); }
  .info-val { font-size: 13px; font-weight: 500; color: var(--text); }
  .assign-row { display: flex; align-items: center; gap: 10px; }
  .inst-name { font-size: 13px; font-weight: 500; }
  .inst-avail { font-size: 12px; color: var(--muted); display: flex; align-items: center; gap: 4px; }
  select { border: 0.5px solid var(--border-md); border-radius: var(--radius); padding: 5px 8px; font-size: 12px; background: var(--surface); color: var(--text); font-family: 'DM Sans', sans-serif; cursor: pointer; }
  #status-sel { font-weight: 500; transition: background .2s, color .2s, border-color .2s; }
  #status-sel.s-col-pendiente  { background: var(--amber-light);  color: var(--amber);    border-color: var(--amber); }
  #status-sel.s-col-completado { background: var(--green-light);  color: var(--green);    border-color: var(--green); }
  #status-sel.s-col-problema   { background: var(--red-light);    color: var(--red);      border-color: var(--red); }
  #status-sel.s-col-urgente    { background: #fff0f0;            color: #c0392b;         border-color: #e74c3c; font-weight:700; }
  .ml-auto { margin-left: auto; }

  /* TIMELINE */
  .timeline { display: flex; flex-direction: column; }
  .tl-item { display: flex; gap: 12px; padding-bottom: 14px; }
  .tl-line { display: flex; flex-direction: column; align-items: center; }
  .tl-dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; margin-top: 3px; }
  .dot-done { background: #1D9E75; }
  .dot-active { background: var(--blue); outline: 3px solid var(--blue-light); }
  .dot-pending { background: var(--border-md); }
  .tl-connector { width: 1px; flex: 1; background: var(--border); margin-top: 4px; }
  .tl-action { font-size: 13px; font-weight: 500; }
  .tl-time { font-size: 11px; color: var(--hint); }

  /* FILES */
  
  .upload-zone { border: 1.5px dashed var(--border-md); border-radius: var(--radius); padding: 14px 8px; display: flex; flex-direction: column; align-items: center; gap: 5px; cursor: pointer; color: var(--hint); transition: background .12s; text-align: center; }
  .upload-zone:hover { background: var(--bg); }
  .upload-zone i { font-size: 22px; }
  .upload-zone span { font-size: 11px; }

  /* NOTES */
  textarea { width: 100%; font-size: 13px; padding: 10px; border: 0.5px solid var(--border-md); border-radius: var(--radius); background: var(--surface); color: var(--text); resize: none; font-family: 'DM Sans', sans-serif; }
  .send-row { display: flex; justify-content: flex-end; margin-top: 8px; }

  /* MODAL OVERLAY */
  .modal-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.35); z-index: 200; align-items: center; justify-content: center; }
  .modal-overlay.open { display: flex; }
  .modal { background: var(--surface); border-radius: var(--radius-lg); border: 0.5px solid var(--border); width: 540px; max-height: 90vh; overflow-y: auto; display: flex; flex-direction: column; }
  .modal-head { padding: 18px 20px 14px; border-bottom: 0.5px solid var(--border); display: flex; align-items: center; justify-content: space-between; }
  .modal-title { font-size: 16px; font-weight: 500; }
  .modal-close { background: none; border: none; cursor: pointer; color: var(--muted); font-size: 20px; display: flex; align-items: center; }
  .modal-body { padding: 20px; display: flex; flex-direction: column; gap: 14px; }
  .modal-footer { padding: 14px 20px; border-top: 0.5px solid var(--border); display: flex; justify-content: flex-end; gap: 8px; }
  .field-label { font-size: 12px; font-weight: 500; color: var(--muted); margin-bottom: 5px; display: block; }
  .field { margin-bottom: 0; }
  input[type=text], input[type=tel], input[type=date] { width: 100%; font-size: 13px; padding: 8px 10px; border: 0.5px solid var(--border-md); border-radius: var(--radius); background: var(--surface); color: var(--text); font-family: 'DM Sans', sans-serif; transition: border-color .15s; }
  input.field-error, select.field-error { border-color: var(--red) !important; background: var(--red-light) !important; }
  .field-err-msg { font-size: 11px; color: var(--red); margin-top: 4px; display: none; }
  .field-err-msg.show { display: block; }
  .field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
  .inst-pick { display: flex; flex-direction: column; gap: 8px; }
  .inst-opt { display: flex; align-items: center; gap: 10px; padding: 10px 12px; border: 0.5px solid var(--border); border-radius: var(--radius); cursor: pointer; transition: all .15s; background: none; color: inherit; font-family: 'DM Sans', sans-serif; text-align: left; box-sizing: border-box; width: 100%; }
  .inst-opt:hover { border-color: var(--border-md); }
  .inst-opt.selected { border-color: var(--blue); background: var(--blue-light); }
  .inst-opt.inst-ocupado { border-color: #e74c3c; background: #fff0f0; }
  .inst-opt.inst-ocupado.selected { border-color: #e74c3c; background: #ffe1e1; }
  .inst-busy-badge { margin-left: auto; flex-shrink: 0; font-size: 10px; font-weight: 600; color: #c0392b; background: #ffd9d9; padding: 2px 7px; border-radius: 6px; white-space: nowrap; }
  .inst-busy-badge + .inst-check { margin-left: 8px; }
  .inst-check { margin-left: auto; color: var(--blue); font-size: 18px; opacity: 0; flex-shrink: 0; }
  .inst-opt.selected .inst-check { opacity: 1; }
  .inst-opt-info { flex: 1; }
  .inst-opt-name { font-size: 13px; font-weight: 500; }
  .inst-opt-meta { font-size: 11px; color: var(--muted); }
  .inst-opt-sched { font-size: 11px; color: var(--muted); margin-top: 2px; font-variant-numeric: tabular-nums; letter-spacing: .02em; }
  .inst-opt.inst-ocupado .inst-opt-sched { color: #c0392b; }
  .avail-ok { background: var(--green-light); color: var(--green); font-size: 11px; padding: 2px 8px; border-radius: 20px; }
  .avail-busy { background: var(--amber-light); color: var(--amber); font-size: 11px; padding: 2px 8px; border-radius: 20px; }
  .av-teal { background: var(--teal-light); color: var(--teal-dark); }
  .av-amber { background: var(--amber-av); color: var(--amber-av-dark); }
  .av-coral { background: var(--coral-light); color: var(--coral-dark); }
  .av-blue { background: var(--blue-light); color: var(--blue-text); }
  .av-purple { background: var(--purple-light); color: var(--purple-dark); }
  .av-green { background: var(--green-light); color: var(--green); }
  .success-msg { display: flex; flex-direction: column; align-items: center; gap: 10px; padding: 12px 0 4px; text-align: center; }
  .success-icon { width: 48px; height: 48px; border-radius: 50%; background: var(--green-light); color: var(--green); display: flex; align-items: center; justify-content: center; font-size: 22px; }

  /* Toggle urgente en modal nuevo pedido */
  .urgente-toggle-row { display: flex; align-items: center; justify-content: space-between; padding: 10px 14px; border-radius: var(--radius); border: 1.5px solid var(--border); background: var(--surface); cursor: pointer; transition: border-color .15s, background .15s; user-select: none; }
  .urgente-toggle-row:hover { border-color: var(--border-md); }
  .urgente-toggle-row.urgente-on { border-color: #e74c3c; background: #fff0f0; }
  [data-theme="dark"] .urgente-toggle-row.urgente-on { background: #2e1010; border-color: #c0392b; }
  .urgente-toggle-left { display: flex; align-items: center; gap: 10px; }
  .urgente-toggle-icon { font-size: 18px; width: 32px; height: 32px; border-radius: 50%; display: flex; align-items: center; justify-content: center; background: var(--bg); border: 0.5px solid var(--border); color: var(--hint); transition: background .15s, color .15s, border-color .15s; flex-shrink: 0; }
  .urgente-on .urgente-toggle-icon { background: #ffd6d6; color: #c0392b; border-color: #f5a0a0; }
  .urgente-toggle-text strong { font-size: 13px; font-weight: 500; color: var(--text); }
  .urgente-toggle-text span { font-size: 11px; color: var(--muted); display: block; }
  .urgente-on .urgente-toggle-text strong { color: #c0392b; }
  .urgente-switch { width: 40px; height: 22px; border-radius: 11px; border: none; cursor: pointer; position: relative; transition: background .2s; background: var(--border-md); flex-shrink: 0; }
  .urgente-switch.on { background: #e74c3c; }
  .urgente-switch-thumb { position: absolute; top: 3px; left: 3px; width: 16px; height: 16px; border-radius: 50%; background: white; transition: transform .2s; display: block; box-shadow: 0 1px 3px rgba(0,0,0,0.2); }
  .urgente-switch.on .urgente-switch-thumb { transform: translateX(18px); }

  /* INSTALLER VIEW */
