:root{--bg:#0f0f0f;--surface:#1a1a1a;--surface2:#222;--border:#2e2e2e;--accent:#f59e0b;--accent2:#d97706;--text:#f0ede8;--muted:#888;--danger:#ef4444;--success:#22c55e;--font-head:'Barlow Condensed',sans-serif;--font-body:'Barlow',sans-serif;}
*{box-sizing:border-box;margin:0;padding:0;}
body{background:var(--bg);color:var(--text);font-family:var(--font-body);min-height:100vh;}
header{background:var(--surface);border-bottom:3px solid var(--accent);padding:14px 24px 16px;display:flex;align-items:flex-end;justify-content:space-between;gap:20px;position:relative;z-index:100;flex-wrap:wrap;}
.logo-text{min-width:0;}
.header-brand-lockup{font-family:var(--font-head);line-height:1.05;margin:0;font-weight:800;letter-spacing:3px;text-transform:uppercase;}
.header-brand-balance{font-size:26px;color:var(--accent);}
.header-brand-garage{font-size:18px;font-weight:600;color:var(--text);letter-spacing:2px;margin-left:6px;}
.header-product-tag{font-size:11px;color:var(--muted);letter-spacing:3px;text-transform:uppercase;display:block;margin-top:6px;}
.header-product-ver{font-size:9px;color:var(--muted2);letter-spacing:1px;}
.header-right{margin-left:auto;display:flex;flex-direction:column;align-items:flex-end;gap:10px;min-width:0;}
.header-taller-nombre{font-family:var(--font-head);font-size:16px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:#9ca3af;text-align:right;line-height:1.25;max-width:min(100%,480px);margin-top:8px;}
.header-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end;}
#pane-quote .quote-brand,
#pane-ingreso .quote-brand,
#pane-ot .quote-brand{display:none!important;}
.inf-doc-header{text-align:center;margin-bottom:14px;padding:8px 12px 12px;border-bottom:1px solid var(--border);}
.inf-doc-header-product{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--muted2);}
.inf-doc-header-muted{color:var(--muted);font-weight:500;}
.inf-doc-header-taller{margin-top:6px;font-family:var(--font-head);font-size:16px;font-weight:800;letter-spacing:3px;text-transform:uppercase;color:var(--accent);}
@media (max-width:720px){
  header{align-items:flex-start;}
  .header-right{align-items:stretch;width:100%;margin-left:0;}
  .header-taller-nombre{text-align:left;max-width:none;margin-top:10px;}
  .header-actions{justify-content:flex-start;}
}
.app{display:grid;grid-template-columns:360px 1fr;min-height:calc(100vh - 69px);}
.app.no-left .panel-left{width:0;padding:0;overflow:hidden;border:none;}
.app.no-left{grid-template-columns:0 1fr;}
.panel-right{padding:20px;overflow-y:auto;}
.view-tabs{display:flex;gap:4px;margin-bottom:18px;}
.view-tab{padding:8px 18px;border:1px solid var(--border);border-radius:4px;background:transparent;color:var(--muted);cursor:pointer;font-family:var(--font-head);font-size:14px;letter-spacing:1px;text-transform:uppercase;}
.view-tab.active{background:var(--accent);color:#000;border-color:var(--accent);font-weight:700;}
.view-pane{display:none;}
.view-pane.active{display:block;}
.section-title{font-family:var(--font-head);font-size:12px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--accent);margin-bottom:12px;padding-bottom:5px;border-bottom:1px solid var(--border);}
label{display:block;font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin-bottom:4px;}
select,input[type="text"],input[type="number"]{width:100%;background:var(--surface2);border:1px solid var(--border);color:var(--text);padding:9px 11px;border-radius:4px;font-family:var(--font-body);font-size:14px;appearance:none;outline:none;transition:border-color .15s;}
select:focus,input:focus{border-color:var(--accent);}
.form-group{margin-bottom:14px;}
.rate-box{background:var(--surface2);border:1px solid var(--accent);border-radius:6px;padding:12px;margin-bottom:18px;display:flex;align-items:center;gap:10px;}
.rate-box label{margin:0;font-size:11px;}
.rate-box input{background:transparent;border:none;font-size:20px;font-family:var(--font-head);font-weight:700;color:var(--accent);width:130px;padding:0;}
.rate-box input:focus{border:none;}
.service-list{display:flex;flex-direction:column;gap:6px;margin-bottom:14px;max-height:260px;overflow-y:auto;padding-right:2px;}
.service-item{background:var(--surface2);border:1px solid var(--border);border-radius:5px;padding:9px 11px;cursor:pointer;transition:all .15s;display:flex;justify-content:space-between;align-items:center;}
.service-item:hover{border-color:var(--accent);background:#2a2a2a;}
.service-item.selected{border-color:var(--accent);background:rgba(245,158,11,.08);}
.service-name{font-size:13px;font-weight:500;}
.service-meta{display:flex;gap:6px;align-items:center;}
.badge{font-size:10px;padding:2px 6px;border-radius:3px;font-weight:600;letter-spacing:.5px;}
.badge-easy{background:rgba(34,197,94,.15);color:var(--success);}
.badge-med{background:rgba(245,158,11,.15);color:var(--accent);}
.badge-hard{background:rgba(239,68,68,.15);color:var(--danger);}
.service-hrs{font-size:11px;color:var(--muted);}
.parts-row{display:grid;grid-template-columns:1fr 56px 76px 86px auto;gap:6px;align-items:end;margin-bottom:8px;}
.parts-row select{background:var(--surface2);border:1px solid var(--border);color:var(--text);padding:9px 6px;border-radius:4px;font-size:12px;outline:none;width:100%;}
.parts-row button{background:var(--accent);border:none;color:#000;border-radius:4px;padding:9px 13px;cursor:pointer;font-size:16px;font-weight:700;}
.parts-row button:hover{background:var(--accent2);}
.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:4px;border:none;cursor:pointer;font-family:var(--font-head);font-size:14px;font-weight:700;letter-spacing:1px;text-transform:uppercase;transition:all .15s;}
.btn-primary{background:var(--accent);color:#000;}
.btn-primary:hover{background:var(--accent2);}
.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--text);}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent);}
.btn-sm{padding:5px 11px;font-size:12px;}
.btn-danger{background:transparent;border:1px solid var(--border);color:var(--danger);font-size:12px;padding:5px 10px;}
.btn-danger:hover{border-color:var(--danger);background:rgba(239,68,68,.08);}
.quote-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;overflow:hidden;}
.quote-header{background:linear-gradient(135deg,#1a1a1a 0%,#222 100%);border-bottom:3px solid var(--accent);padding:22px 26px;display:grid;grid-template-columns:1fr auto;}
.quote-header h2{font-family:var(--font-head);font-size:30px;font-weight:800;letter-spacing:2px;}
.quote-number{font-size:11px;color:var(--muted);margin-top:4px;}
.quote-vehicle{font-size:18px;font-family:var(--font-head);font-weight:700;color:var(--accent);}
.quote-body{padding:22px 26px;}
.quote-client-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:20px;}
.client-field{background:var(--surface2);border:1px solid var(--border);border-radius:4px;padding:9px 13px;}
.client-field label{font-size:10px;color:var(--muted);letter-spacing:1px;}
.client-field input{background:transparent;border:none;color:var(--text);font-size:14px;width:100%;outline:none;padding:2px 0 0;font-family:var(--font-body);}
.quote-table{width:100%;border-collapse:collapse;margin-bottom:6px;}
.quote-table th{font-family:var(--font-head);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);padding:7px 9px;border-bottom:1px solid var(--border);text-align:left;}
.quote-table td{padding:10px 9px;border-bottom:1px solid var(--border);font-size:13px;}
.quote-table tr:last-child td{border-bottom:none;}
.quote-table .subtotal{color:var(--accent);font-weight:600;text-align:right;}
.remove-btn{background:none;border:none;color:var(--muted);cursor:pointer;font-size:15px;padding:0 3px;}
.remove-btn:hover{color:var(--danger);}
.totals-box{background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:16px 18px;margin-top:14px;}
.total-row{display:flex;justify-content:space-between;padding:4px 0;font-size:13px;color:var(--muted);}
.total-row.grand{border-top:2px solid var(--accent);margin-top:7px;padding-top:9px;font-family:var(--font-head);font-size:22px;font-weight:800;color:var(--text);}
.total-row.grand span:last-child{color:var(--accent);}
.empty-state{text-align:center;padding:50px 20px;color:var(--muted);}
.empty-state .icon{font-size:40px;margin-bottom:10px;opacity:.4;}
.empty-state p{font-size:13px;}
.footer-actions{display:flex;gap:8px;margin-top:18px;justify-content:flex-end;}
.history-search{display:flex;gap:8px;margin-bottom:16px;}
.history-search input{flex:1;}
.history-card{background:var(--surface);border:1px solid var(--border);border-radius:6px;margin-bottom:10px;overflow:hidden;}
.history-card-header{padding:12px 16px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;transition:background .15s;}
.history-card-header:hover{background:var(--surface2);}
.history-card-title{font-family:var(--font-head);font-size:16px;font-weight:700;}
.history-card-meta{font-size:11px;color:var(--muted);margin-top:2px;}
.history-card-total{font-family:var(--font-head);font-size:18px;font-weight:800;color:var(--accent);}
.history-card-body{display:none;border-top:1px solid var(--border);padding:14px 16px;}
.history-card-body.open{display:block;}
.history-entry{background:var(--surface2);border:1px solid var(--border);border-radius:4px;padding:10px 14px;margin-bottom:8px;display:flex;justify-content:space-between;align-items:flex-start;}
.history-entry-info{flex:1;}
.history-entry-date{font-size:11px;color:var(--muted);}
.history-entry-vehicle{font-size:13px;font-weight:600;}
.history-entry-services{font-size:12px;color:var(--muted);margin-top:2px;}
.history-entry-total{font-family:var(--font-head);font-size:16px;font-weight:700;color:var(--accent);}
::-webkit-scrollbar{width:5px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px;}
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:100;align-items:center;justify-content:center;}
.modal-overlay.open{display:flex;}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:8px;display:flex;flex-direction:column;max-height:90vh;}
.modal-header{padding:18px 22px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;flex-shrink:0;}
.modal-header h3{font-family:var(--font-head);font-size:20px;font-weight:700;letter-spacing:1px;}
.modal-close{background:none;border:none;color:var(--muted);font-size:20px;cursor:pointer;}
.modal-body{padding:20px 22px;overflow-y:auto;flex:1;}
.modal-tabs{display:flex;gap:4px;margin-bottom:18px;}
.modal-tab{padding:6px 14px;border:1px solid var(--border);border-radius:4px;background:transparent;color:var(--muted);cursor:pointer;font-family:var(--font-head);font-size:13px;letter-spacing:1px;}
.modal-tab.active{background:var(--accent);color:#000;border-color:var(--accent);font-weight:700;}
.tab-content{display:none;}
.tab-content.active{display:block;}
#configModal .modal{width:700px;max-height:85vh;display:flex;flex-direction:column;}
#configModal .modal-body{overflow-y:auto;flex:1;}
.config-list{display:flex;flex-direction:column;gap:5px;max-height:220px;overflow-y:auto;margin-bottom:10px;}
.config-item{background:var(--surface2);border:1px solid var(--border);border-radius:4px;padding:8px 12px;display:flex;gap:8px;align-items:center;}
.config-item span{font-size:13px;}
#matrixModal .modal{width:min(96vw,960px);}
.matrix-hint{font-size:12px;color:var(--muted);margin-bottom:14px;line-height:1.6;}
.matrix-filters{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px;}
.matrix-table-wrap{overflow:auto;max-height:50vh;border:1px solid var(--border);border-radius:4px;}
.mx-table{border-collapse:collapse;width:100%;}
.mx-table th{font-family:var(--font-head);font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);padding:8px 10px;border-bottom:1px solid var(--border);white-space:nowrap;position:sticky;top:0;background:var(--surface);z-index:1;}
.mx-table th:first-child{min-width:185px;position:sticky;left:0;z-index:3;background:var(--surface);}
.mx-table td{padding:5px 7px;border-bottom:1px solid var(--border);vertical-align:middle;}
.mx-table td:first-child{font-size:12px;font-weight:600;position:sticky;left:0;background:var(--surface2);z-index:2;min-width:185px;padding:6px 10px;border-right:1px solid var(--border);}
.mx-table tr:last-child td{border-bottom:none;}
.mx-cell{display:flex;gap:4px;align-items:center;}
.mx-cell input[type="number"]{width:55px;padding:4px 5px;font-size:12px;}
.mx-cell select{width:78px;padding:4px 5px;font-size:12px;}
.mx-has-custom td:first-child::after{content:" ●";color:var(--success);font-size:9px;}
.quote-brand{text-align:right;line-height:1;}
.quote-brand-letter{font-family:var(--font-head);font-size:42px;font-weight:900;letter-spacing:3px;color:var(--accent);line-height:1;}
.quote-brand-sub{font-family:var(--font-head);font-size:14px;font-weight:600;letter-spacing:4px;color:var(--muted);text-transform:uppercase;margin-top:2px;}
@media print{
  header,.panel-left,.footer-actions,.remove-btn,.view-tabs{display:none!important;}
  .app{display:block;}
  /* Hide ALL panes by default */
  .view-pane{display:none!important;}
  /* Only show the active pane */
  .view-pane.active{display:block!important;}
  .panel-right{padding:0;}
  body{background:white;color:#000;}
  /* Android PDF viewers can drop light/implicit borders: force explicit print lines */
  *{-webkit-print-color-adjust:exact;print-color-adjust:exact;}
  .quote-table,.quote-table th,.quote-table td{
    border:1px solid #666!important;
    border-collapse:collapse!important;
  }
  .ot-card,.ot-field,.ot-task-row,#otTotalBox,.sig-wrap,#otEmpresaInfo{
    border:1px solid #666!important;
  }
  /* Hide non-printable elements inside active pane */
  .taller-kpis,.kanban,.history-search,#historyContainer,
  .stock-kpis,.rep-toolbar,.cat-grid,#repContent,
  .inf-period,.accept-panel,#acceptPanel,
  #acceptedBadge,.ot-section-service-selector{display:none!important;}
  /* Informes — show content, hide controls */
  #infPwGate{display:none!important;}
  #infContent{display:block!important;}
  #informesBody{display:block!important;}
  #infStockSection{display:block!important;}
  .no-print{display:none!important;}
  /* Informes print colors */
  .inf-kpi{background:#f5f5f5!important;border-color:#ddd!important;}
  .inf-kpi-val{color:#000!important;}
  .inf-kpi-lbl,.inf-kpi-sub{color:#555!important;}
  .inf-card{background:#fff!important;border:1px solid #ddd!important;}
  .inf-card-title{color:#d97706!important;}
  .inf-bar-fill{background:#d97706!important;}
  .inf-grid{display:grid!important;}
  table{border-collapse:collapse!important;}
  th,td{color:#000!important;border-color:#ddd!important;}
  thead tr{background:#f5f5f5!important;}
  tfoot tr{background:#f0f0f0!important;}
  .quote-card{border:none;}
  .quote-header{background:#f5f5f5!important;color:#000;}
  .quote-header h2,.quote-vehicle{color:#000;}
  .quote-number{color:#555;}
  .quote-table td,.quote-table th{color:#000;}
  .quote-table .subtotal{color:#d97706;}
  .totals-box{background:#f5f5f5;border-color:#ddd;}
  .total-row{color:#555;}
  .total-row.grand{color:#000;}
  .total-row.grand span:last-child{color:#d97706;}
  .client-field{background:#f5f5f5;border-color:#ddd;}
  .quote-brand-letter{color:#d42b2b!important;}
  .quote-brand-sub{color:#333!important;}
  #otEmpresaInfo{display:block!important;}
  /* OT print styles */
  .ot-card{border:1px solid #ccc;}
  .ot-card-header{background:#f5f5f5!important;color:#000;}
  .ot-field{background:#f5f5f5;border-color:#ccc;}
  .ot-field label{color:#555;}
  .ot-field input,.ot-field select,.ot-field textarea{color:#000;}
  .ot-section{color:#d97706;border-color:#ccc;}
  .ot-task-row{background:#f5f5f5;border-color:#ccc;}
  .ot-task-name{color:#000;}
  canvas#sigPad{border:1px solid #ccc;}
}

/* MECHANIC SELECTOR CARDS */
.mech-sel-card{display:flex;align-items:center;gap:14px;background:var(--surface2);border:2px solid var(--border);border-radius:8px;padding:14px 18px;cursor:pointer;transition:all .15s;text-align:left;}
.mech-sel-card:hover{border-color:#60a5fa;background:rgba(96,165,250,.08);transform:translateY(-1px);}
.mech-sel-card.new-mech{border-style:dashed;border-color:var(--border);}
.mech-sel-card.new-mech:hover{border-color:var(--accent);background:rgba(245,158,11,.06);}
.mech-sel-avatar{width:40px;height:40px;border-radius:50%;background:#60a5fa22;border:2px solid #60a5fa;display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-size:18px;font-weight:900;color:#60a5fa;flex-shrink:0;}
.mech-sel-avatar.new{background:rgba(245,158,11,.1);border-color:var(--accent);color:var(--accent);}
.mech-sel-name{font-family:var(--font-head);font-size:18px;font-weight:800;letter-spacing:1px;}
.mech-sel-sub{font-size:11px;color:var(--muted);margin-top:2px;}

/* PASSWORD SCREEN */
#pwScreen{position:fixed;inset:0;background:var(--bg);z-index:99999;display:flex;align-items:center;justify-content:center;}
#pwScreen.pw-hidden{display:none!important;}
.pw-box{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:40px 48px;text-align:center;width:340px;}
.pw-logo{font-family:var(--font-head);font-size:48px;font-weight:900;letter-spacing:4px;color:var(--accent);line-height:1;}
.pw-sub{font-family:var(--font-head);font-size:14px;letter-spacing:4px;color:var(--muted);text-transform:uppercase;margin-bottom:32px;}
.pw-label{font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);text-align:left;display:block;margin-bottom:5px;}
.pw-input{width:100%;background:var(--surface2);border:1px solid var(--border);color:var(--text);padding:11px 14px;border-radius:5px;font-size:15px;font-family:var(--font-body);outline:none;text-align:center;letter-spacing:3px;transition:border .15s;}
.pw-input:focus{border-color:var(--accent);}
.pw-btn{width:100%;margin-top:14px;padding:12px;background:var(--accent);border:none;border-radius:5px;font-family:var(--font-head);font-size:16px;font-weight:800;letter-spacing:2px;color:#000;cursor:pointer;transition:background .15s;}
.pw-btn:hover{background:var(--accent2);}
.pw-error{color:var(--danger);font-size:12px;margin-top:8px;min-height:18px;}
.pw-hint{font-size:11px;color:var(--muted2);margin-top:20px;}

/* STATUS BADGES */
.status-badge{display:inline-block;padding:3px 10px;border-radius:3px;font-family:var(--font-head);font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;}
.status-pending{background:rgba(245,158,11,.15);color:var(--accent);}
.status-progress{background:rgba(59,130,246,.15);color:#60a5fa;}
.status-done{background:rgba(34,197,94,.15);color:var(--success);}

/* INGRESO / OT CARDS */
.ot-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;overflow:hidden;margin-bottom:14px;}
.ot-card-header{background:linear-gradient(135deg,#1a1a1a,#222);border-bottom:3px solid var(--accent);padding:18px 22px;display:flex;justify-content:space-between;align-items:flex-start;}
.ot-card-header h2{font-family:var(--font-head);font-size:26px;font-weight:800;letter-spacing:2px;}
.ot-card-body{padding:20px 22px;}
.ot-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px;}
.ot-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;margin-bottom:16px;}
.ot-field{background:var(--surface2);border:1px solid var(--border);border-radius:4px;padding:9px 13px;}
.ot-field label{font-size:10px;color:var(--muted);letter-spacing:1px;text-transform:uppercase;display:block;margin-bottom:3px;}
.ot-field input,.ot-field select,.ot-field textarea{background:transparent;border:none;color:var(--text);font-size:14px;width:100%;outline:none;font-family:var(--font-body);resize:none;}
.ot-field textarea{min-height:60px;}
.ot-section{font-family:var(--font-head);font-size:11px;letter-spacing:3px;color:var(--accent);text-transform:uppercase;margin:16px 0 10px;padding-bottom:5px;border-bottom:1px solid var(--border);}
.ot-task-row{background:var(--surface2);border:1px solid var(--border);border-radius:4px;padding:10px 12px;margin-bottom:6px;display:flex;justify-content:space-between;align-items:center;gap:10px;}
.ot-task-name{font-size:13px;font-weight:500;flex:1;}
.ot-task-status select{background:var(--surface);border:1px solid var(--border);color:var(--text);padding:4px 8px;border-radius:3px;font-size:12px;outline:none;font-family:var(--font-body);}
.fuel-bar{display:flex;gap:6px;align-items:center;margin-top:4px;}
.fuel-btn{width:32px;height:18px;border:1px solid var(--border);border-radius:3px;background:var(--surface2);cursor:pointer;font-size:10px;color:var(--muted);display:flex;align-items:center;justify-content:center;transition:all .15s;}
.fuel-btn.active{background:var(--accent);border-color:var(--accent);color:#000;font-weight:700;}

/* SIGNATURE PAD */
.sig-wrap{background:var(--surface2);border:1px solid var(--border);border-radius:4px;overflow:hidden;margin-bottom:8px;}
.sig-label{font-size:10px;color:var(--muted);letter-spacing:1px;text-transform:uppercase;padding:6px 10px;border-bottom:1px solid var(--border);}
canvas#sigPad{display:block;background:#fff;cursor:crosshair;touch-action:none;}
.sig-actions{display:flex;gap:6px;margin-top:6px;}

/* OT LIST in historial */
.ot-list-item{background:var(--surface2);border:1px solid var(--border);border-radius:5px;padding:10px 14px;margin-bottom:6px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;transition:all .15s;}
.ot-list-item:hover{border-color:var(--accent);}

/* PRINT OT */
@media print{
  .no-print{display:none!important;}
  .print-only{display:block!important;}
  .ot-field,.ot-task-row,#otTotalBox,.sig-wrap,#otEmpresaInfo{
    border:1px solid #666!important;
  }
  .quote-table,.quote-table th,.quote-table td{
    border:1px solid #666!important;
    border-collapse:collapse!important;
  }
  canvas#sigPad{border:1px solid #ccc;}
  /* OT compact print */
  .ot-card-body{padding:10px 14px!important;}
  .ot-grid,.ot-grid-3{gap:6px!important;margin-bottom:8px!important;}
  .ot-field{padding:5px 8px!important;}
  .ot-field label{font-size:9px!important;}
  .ot-field input,.ot-field select,.ot-field textarea{font-size:12px!important;}
  .ot-section{margin:8px 0 5px!important;padding-bottom:3px!important;font-size:10px!important;}
  .ot-task-row{padding:5px 8px!important;margin-bottom:3px!important;}
  .ot-task-name{font-size:12px!important;}
  #otTotalBox{padding:8px 12px!important;margin-bottom:8px!important;}
  #otTotalBox > div:first-child{gap:8px!important;margin-bottom:6px!important;}
  #otTotalBox div div:first-child{font-size:8px!important;}
  #otTotalBox div div:last-child{font-size:16px!important;}
  #otTotalFinal{font-size:22px!important;}
  .sig-wrap{margin-top:4px!important;}
  canvas#sigPad{height:80px!important;}
  .ot-card-header{padding:10px 14px!important;}
  .ot-card-header h2{font-size:20px!important;}
  #otVehicle{font-size:14px!important;margin-top:3px!important;}
  .ot-list-item{padding:5px 10px!important;margin-bottom:3px!important;}
  #otPartsList .ot-task-row{padding:4px 8px!important;}
}
.print-only{display:none;}

/* CLIENTES */
.client-search-wrap{position:relative;margin-bottom:10px;}
.client-autocomplete{position:absolute;top:100%;left:0;right:0;background:var(--surface);border:1px solid var(--accent);border-radius:0 0 5px 5px;z-index:50;max-height:200px;overflow-y:auto;display:none;}
.client-autocomplete.open{display:block;}
.ac-item{padding:9px 13px;cursor:pointer;font-size:13px;border-bottom:1px solid var(--border);}
.ac-item:last-child{border-bottom:none;}
.ac-item:hover{background:var(--surface2);}
.ac-item strong{color:var(--accent);}
.ac-item span{color:var(--muted);font-size:11px;margin-left:6px;}

/* FICHA CLIENTE */
.ficha-header{background:linear-gradient(135deg,var(--surface),var(--surface2));border:1px solid var(--border);border-radius:8px;padding:20px 24px;margin-bottom:16px;display:flex;justify-content:space-between;align-items:flex-start;}
.ficha-name{font-family:var(--font-head);font-size:30px;font-weight:800;letter-spacing:1px;}
.ficha-meta{font-size:12px;color:var(--muted);margin-top:4px;display:flex;flex-direction:column;gap:3px;}
.ficha-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:16px;}
.stat-box{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:12px 14px;text-align:center;}
.stat-num{font-family:var(--font-head);font-size:26px;font-weight:800;color:var(--accent);}
.stat-lbl{font-size:10px;color:var(--muted);letter-spacing:1px;text-transform:uppercase;}
.ficha-section{font-family:var(--font-head);font-size:11px;letter-spacing:3px;color:var(--accent);text-transform:uppercase;margin:16px 0 8px;padding-bottom:5px;border-bottom:1px solid var(--border);}
.veh-pill{display:inline-flex;align-items:center;gap:6px;background:var(--surface2);border:1px solid var(--border);border-radius:4px;padding:5px 10px;margin:3px;font-size:12px;cursor:pointer;transition:all .15s;}
.veh-pill:hover{border-color:var(--accent);color:var(--accent);}
.ficha-timeline{display:flex;flex-direction:column;gap:6px;}
.timeline-item{background:var(--surface2);border:1px solid var(--border);border-radius:5px;padding:10px 14px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;transition:all .15s;}
.timeline-item:hover{border-color:var(--accent);}
.timeline-type{font-family:var(--font-head);font-size:10px;letter-spacing:2px;text-transform:uppercase;padding:2px 7px;border-radius:3px;margin-right:8px;}
.type-quote{background:rgba(245,158,11,.15);color:var(--accent);}
.type-ingreso{background:rgba(59,130,246,.15);color:#60a5fa;}
.type-ot{background:rgba(34,197,94,.15);color:var(--success);}
.cliente-card{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:12px 16px;margin-bottom:8px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;transition:all .15s;}
.cliente-card:hover{border-color:var(--accent);}
.cliente-card-name{font-family:var(--font-head);font-size:17px;font-weight:700;}
.cliente-card-meta{font-size:11px;color:var(--muted);margin-top:2px;}

/* INFORMES */
.inf-period{display:flex;gap:8px;align-items:center;margin-bottom:18px;flex-wrap:wrap;}
.inf-period-btn{padding:7px 14px;border:1px solid var(--border);border-radius:4px;background:transparent;color:var(--muted);cursor:pointer;font-family:var(--font-head);font-size:12px;letter-spacing:1px;transition:all .13s;}
.inf-period-btn.act{background:var(--accent);color:#000;border-color:var(--accent);font-weight:700;}
.inf-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px;}
.inf-kpi{background:var(--surface);border:1px solid var(--border);border-radius:7px;padding:14px 16px;}
.inf-kpi-val{font-family:var(--font-head);font-size:28px;font-weight:900;color:var(--accent);line-height:1;}
.inf-kpi-lbl{font-size:10px;color:var(--muted);letter-spacing:1px;text-transform:uppercase;margin-top:3px;}
.inf-kpi-sub{font-size:11px;color:var(--muted);margin-top:2px;}
.inf-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;}
.inf-card{background:var(--surface);border:1px solid var(--border);border-radius:7px;padding:16px 18px;}
.inf-card-title{font-family:var(--font-head);font-size:12px;letter-spacing:2px;color:var(--accent);text-transform:uppercase;margin-bottom:12px;}
.inf-bar-row{display:flex;align-items:center;gap:8px;margin-bottom:7px;}
.inf-bar-label{font-size:12px;width:160px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:0;}
.inf-bar-track{flex:1;height:8px;background:var(--surface2);border-radius:4px;overflow:hidden;}
.inf-bar-fill{height:100%;background:var(--accent);border-radius:4px;transition:width .4s;}
.inf-bar-val{font-size:11px;color:var(--muted);width:50px;text-align:right;flex-shrink:0;}
.inf-ot-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border);font-size:13px;}
.inf-ot-row:last-child{border-bottom:none;}
.inf-donut-wrap{display:flex;align-items:center;gap:16px;}
.inf-legend{display:flex;flex-direction:column;gap:6px;}
.inf-legend-item{display:flex;align-items:center;gap:6px;font-size:12px;}
.inf-legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;}
@media print{
  .inf-period,.no-print{display:none!important;}
  .inf-doc-header{border-bottom-color:#ddd!important;margin-bottom:10px!important;padding-bottom:8px!important;}
  .inf-doc-header-product{color:#777!important;font-size:9px!important;}
  .inf-doc-header-muted{color:#888!important;}
  .inf-doc-header-taller{color:#b45309!important;font-size:13px!important;}
  .inf-kpis{grid-template-columns:repeat(4,1fr);}
  .inf-kpi{background:#f5f5f5!important;border:1px solid #ddd!important;break-inside:avoid;}
  .inf-kpi-val{color:#000!important;}
  .inf-kpi-lbl,.inf-kpi-sub{color:#555!important;}
  .inf-card{background:#fff!important;border:1px solid #ddd!important;break-inside:avoid;margin-bottom:12px!important;}
  .inf-card-title{color:#d97706!important;}
  .inf-bar-track{background:#eee!important;}
  .inf-bar-fill{background:#d97706!important;}
  .inf-grid{display:grid!important;grid-template-columns:1fr 1fr!important;}
  .inf-ot-row{border-color:#ddd!important;}
  #infStockSection{display:block!important;}
  #informesBody{display:block!important;}
}

/* ═══ TABLERO DE TALLER ═══ */
.taller-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:18px;}
.taller-kpi{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:12px 14px;display:flex;align-items:center;gap:10px;}
.taller-kpi-icon{font-size:22px;}
.taller-kpi-val{font-family:var(--font-head);font-size:26px;font-weight:900;color:var(--accent);line-height:1;}
.taller-kpi-lbl{font-size:10px;color:var(--muted);letter-spacing:1px;text-transform:uppercase;}

.kanban{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;align-items:start;}
.kanban-col{background:var(--surface);border:1px solid var(--border);border-radius:7px;overflow:hidden;}
.kanban-col-header{padding:10px 14px;display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--border);}
.kanban-col-title{font-family:var(--font-head);font-size:13px;font-weight:700;letter-spacing:2px;text-transform:uppercase;}
.kanban-col-count{background:var(--surface2);border-radius:10px;padding:2px 8px;font-size:11px;font-family:var(--font-head);font-weight:700;margin-left:auto;}
.kanban-cards{padding:10px;display:flex;flex-direction:column;gap:8px;min-height:80px;}

.kanban-card{background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:12px;cursor:pointer;transition:all .15s;position:relative;}
.kanban-card:hover{border-color:var(--accent);transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.3);}
.kanban-card.urgent{border-left:3px solid var(--danger);}
.kanban-card.normal{border-left:3px solid var(--border);}
.kc-plate{font-family:var(--font-head);font-size:16px;font-weight:800;letter-spacing:1px;color:var(--accent);}
.kc-model{font-size:12px;color:var(--text);margin-top:1px;}
.kc-client{font-size:11px;color:var(--muted);margin-top:3px;}
.kc-priority{position:absolute;top:8px;right:8px;font-size:9px;padding:2px 6px;border-radius:3px;font-family:var(--font-head);font-weight:700;letter-spacing:1px;}
.kc-priority.urgent{background:rgba(239,68,68,.2);color:var(--danger);}
.kc-priority.normal{background:var(--surface);color:var(--muted);}
.kc-progress{margin-top:8px;}
.kc-progress-bar{height:4px;background:var(--border);border-radius:2px;overflow:hidden;margin-top:3px;}
.kc-progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .3s;}
.kc-progress-lbl{font-size:10px;color:var(--muted);display:flex;justify-content:space-between;}
.kc-tasks{margin-top:6px;display:flex;flex-direction:column;gap:2px;}
.kc-task{font-size:10px;color:var(--muted);display:flex;align-items:center;gap:4px;}
.kc-task.done{color:var(--success);}
.kc-task.progress{color:#60a5fa;}
.kc-delivery{font-size:10px;margin-top:6px;display:flex;align-items:center;gap:4px;}
.kc-delivery.overdue{color:var(--danger);}
.kc-delivery.today{color:var(--warn);}
.kc-delivery.ok{color:var(--muted);}
.kc-time{font-size:10px;color:var(--muted2);margin-top:4px;}
.kc-actions{display:flex;gap:4px;margin-top:8px;}
.kanban-empty{text-align:center;padding:20px;color:var(--muted2);font-size:12px;}

/* col headers colors */
.col-accepted .kanban-col-header{border-top:3px solid #a78bfa;}
.col-accepted .kanban-col-count{color:#a78bfa;}
.col-pending .kanban-col-header{border-top:3px solid var(--accent);}
.col-progress .kanban-col-header{border-top:3px solid #60a5fa;}
.col-done    .kanban-col-header{border-top:3px solid var(--success);}
.col-delivered .kanban-col-header{border-top:3px solid var(--muted);}
.col-pending .kanban-col-count{color:var(--accent);}
.col-progress .kanban-col-count{color:#60a5fa;}
.col-done    .kanban-col-count{color:var(--success);}
.col-delivered .kanban-col-count{color:var(--muted);}

.taller-period-btn{padding:5px 12px;border:1px solid var(--border);border-radius:4px;background:transparent;color:var(--muted);cursor:pointer;font-family:var(--font-head);font-size:12px;letter-spacing:1px;transition:all .13s;}
.taller-period-btn.act{background:var(--accent);color:#000;border-color:var(--accent);font-weight:700;}

.last-update{font-size:11px;color:var(--muted);}

/* ═══ MÓDULO REPUESTOS ═══ */
.rep-toolbar{display:flex;gap:8px;align-items:center;margin-bottom:16px;flex-wrap:wrap;}
.rep-search{flex:1;min-width:200px;background:var(--surface2);border:1px solid var(--border);color:var(--text);padding:9px 13px;border-radius:4px;font-size:13px;outline:none;}
.rep-search:focus{border-color:var(--accent);}
/* REPUESTOS — 2-level nav */
.rep-back{display:none;}
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:12px;margin-top:4px;}
.cat-tile{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:18px 20px;cursor:pointer;transition:all .15s;position:relative;overflow:hidden;}
.cat-tile:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,0,0,.3);}
.cat-tile-icon{font-size:30px;margin-bottom:6px;}
.cat-tile-name{font-family:var(--font-head);font-size:15px;font-weight:700;letter-spacing:1px;margin-bottom:4px;}
.cat-tile-count{font-family:var(--font-head);font-size:26px;font-weight:900;color:var(--accent);line-height:1;}
.cat-tile-sub{font-size:10px;color:var(--muted);margin-top:3px;}
.cat-tile-alert{position:absolute;top:8px;right:8px;background:var(--danger);color:#fff;font-size:10px;font-family:var(--font-head);font-weight:700;padding:2px 6px;border-radius:10px;}
.cat-tile.has-low{border-color:rgba(239,68,68,.4);}
.rep-table{width:100%;border-collapse:collapse;}
.rep-table th{font-family:var(--font-head);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);padding:8px 10px;border-bottom:1px solid var(--border);text-align:left;white-space:nowrap;}
.rep-table th.r,.rep-table td.r{text-align:right;}
.rep-table td{padding:9px 10px;border-bottom:1px solid var(--border);font-size:13px;vertical-align:middle;}
.rep-table tr:last-child td{border-bottom:none;}
.rep-table tr:hover td{background:var(--surface2);}
.stock-pill{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:10px;font-size:11px;font-weight:700;}
.stock-pill.ok{background:rgba(34,197,94,.15);color:var(--success);}
.stock-pill.warn{background:rgba(245,158,11,.15);color:var(--warn);}
.stock-pill.low{background:rgba(239,68,68,.15);color:var(--danger);}
.rep-actions{display:flex;gap:4px;justify-content:flex-end;}
.cat-filter{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:14px;}
.cat-btn{padding:4px 12px;border:1px solid var(--border);border-radius:20px;background:transparent;color:var(--muted);cursor:pointer;font-size:12px;font-family:var(--font-head);letter-spacing:1px;transition:all .13s;}
.cat-btn.act{background:var(--accent);color:#000;border-color:var(--accent);font-weight:700;}
.rep-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:10px;}
.rep-card{background:var(--surface);border:1px solid var(--border);border-radius:7px;overflow:hidden;transition:all .13s;}
.rep-card:hover{border-color:var(--border2);}
.rep-card.low-stock{border-color:var(--danger);}
.rep-card.ok-stock{border-color:var(--border);}
.rep-card-header{padding:10px 14px;display:flex;justify-content:space-between;align-items:flex-start;}
.rep-card-name{font-size:14px;font-weight:600;line-height:1.3;}
.rep-card-code{font-size:10px;color:var(--muted);letter-spacing:1px;margin-top:2px;}
.rep-cat-badge{font-size:10px;padding:2px 8px;border-radius:10px;font-family:var(--font-head);letter-spacing:1px;white-space:nowrap;flex-shrink:0;}
.rep-card-body{padding:0 14px 12px;}
.rep-stock-row{display:flex;align-items:center;gap:8px;margin-bottom:8px;}
.rep-stock-num{font-family:var(--font-head);font-size:28px;font-weight:900;line-height:1;}
.rep-stock-lbl{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;}
.rep-stock-bar{flex:1;height:6px;background:var(--border);border-radius:3px;overflow:hidden;}
.rep-stock-fill{height:100%;border-radius:3px;transition:width .3s;}
.rep-prices{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:8px;}
.rep-price-box{background:var(--surface2);border-radius:4px;padding:6px 10px;}
.rep-price-lbl{font-size:9px;color:var(--muted);letter-spacing:1px;text-transform:uppercase;}
.rep-price-val{font-family:var(--font-head);font-size:16px;font-weight:700;color:var(--accent);}
.rep-price-val.cost{color:var(--muted);}
.rep-card-actions{display:flex;gap:5px;padding:0 14px 12px;}
.rep-alert{background:rgba(239,68,68,.1);border:1px solid var(--danger);border-radius:4px;padding:4px 10px;font-size:11px;color:var(--danger);margin-bottom:8px;display:flex;align-items:center;gap:5px;}
.stock-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:18px;}

/* MODAL REPUESTO */
#repModal .modal{width:620px;}
.rep-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px;}
.rep-form-grid .full{grid-column:1/-1;}

/* CATEGORY COLORS */
.cat-lubricantes{background:rgba(245,158,11,.15);color:#f59e0b;}
.cat-filtros{background:rgba(59,130,246,.15);color:#60a5fa;}
.cat-frenos{background:rgba(239,68,68,.15);color:#ef4444;}
.cat-suspension{background:rgba(139,92,246,.15);color:#a78bfa;}
.cat-electricidad{background:rgba(234,179,8,.15);color:#eab308;}
.cat-correas{background:rgba(249,115,22,.15);color:#f97316;}
.cat-refrigeracion{background:rgba(6,182,212,.15);color:#22d3ee;}
.cat-neumaticos{background:rgba(16,185,129,.15);color:#10b981;}
.cat-carroceria{background:rgba(107,114,128,.15);color:#9ca3af;}
.cat-otros{background:rgba(156,163,175,.15);color:#9ca3af;}

/* ═══ AGENDA ═══ */
.agenda-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:1000;display:flex;align-items:flex-start;justify-content:center;padding:20px;overflow-y:auto;}
.agenda-modal{background:var(--surface);border:1px solid var(--border);border-radius:10px;width:100%;max-width:1100px;min-height:min(80vh,calc(100vh - 40px));max-height:calc(100vh - 40px);display:flex;flex-direction:column;overflow:hidden;}
.agenda-modal-header{background:linear-gradient(135deg,#1a1a1a,#222);border-bottom:3px solid var(--accent);padding:16px 22px;display:flex;align-items:center;gap:12px;border-radius:10px 10px 0 0;}
.agenda-modal-header h2{font-family:var(--font-head);font-size:22px;font-weight:800;letter-spacing:2px;flex:1;}
.agenda-nav{display:flex;align-items:center;gap:10px;}
.agenda-nav-btn{background:var(--surface2);border:1px solid var(--border);color:var(--text);width:32px;height:32px;border-radius:4px;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .13s;}
.agenda-nav-btn:hover{border-color:var(--accent);color:var(--accent);}
.agenda-period-label{font-family:var(--font-head);font-size:15px;font-weight:700;letter-spacing:1px;min-width:160px;text-align:center;}
.agenda-view-toggle{display:flex;gap:4px;margin-left:8px;}
.agenda-view-btn{padding:5px 12px;border:1px solid var(--border);border-radius:4px;background:transparent;color:var(--muted);cursor:pointer;font-family:var(--font-head);font-size:11px;letter-spacing:1px;transition:all .13s;}
.agenda-view-btn.act{background:var(--accent);color:#000;border-color:var(--accent);font-weight:700;}
.agenda-body{padding:16px;flex:1 1 auto;min-height:0;overflow-y:auto;overflow-x:auto;scrollbar-gutter:stable;-webkit-overflow-scrolling:touch;border-top:1px solid rgba(46,46,46,.5);scrollbar-width:thin;scrollbar-color:var(--border) var(--surface2);}
.agenda-body::-webkit-scrollbar{width:12px;height:12px;}
.agenda-body::-webkit-scrollbar-track{background:var(--surface2);border-radius:6px;}
.agenda-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:6px;border:2px solid var(--surface2);}
.agenda-body::-webkit-scrollbar-thumb:hover{background:var(--muted);}

/* Monthly grid */
.agenda-month-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:6px;overflow:hidden;}
.agenda-day-header{background:var(--surface2);padding:6px;text-align:center;font-family:var(--font-head);font-size:11px;letter-spacing:2px;color:var(--muted);}
.agenda-day-cell{background:var(--surface);min-height:90px;padding:6px;cursor:pointer;transition:background .13s;position:relative;}
.agenda-day-cell:hover{background:var(--surface2);}
.agenda-day-cell.today{background:rgba(245,158,11,.08);}
.agenda-day-cell.today .agenda-day-num{color:var(--accent);font-weight:700;}
.agenda-day-cell.other-month{opacity:.35;}
.agenda-day-cell.has-events{border-top:2px solid var(--accent);}
.agenda-day-num{font-family:var(--font-head);font-size:14px;font-weight:600;margin-bottom:4px;}
.agenda-event-pill{background:rgba(245,158,11,.2);border:1px solid rgba(245,158,11,.4);border-radius:3px;padding:2px 5px;font-size:10px;color:var(--accent);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;}
.agenda-event-pill.ot-event{background:rgba(96,165,250,.15);border-color:rgba(96,165,250,.4);color:#60a5fa;}
.agenda-more{font-size:10px;color:var(--muted);text-align:right;}

/* Weekly grid */
.agenda-week-grid{display:grid;grid-template-columns:60px repeat(7,1fr);gap:0;border:1px solid var(--border);border-radius:6px;overflow:hidden;}
.agenda-week-day-header{background:var(--surface2);padding:8px 4px;text-align:center;border-bottom:1px solid var(--border);border-right:1px solid var(--border);}
.agenda-week-day-header.today-col{background:rgba(245,158,11,.12);}
.agenda-week-day-name{font-family:var(--font-head);font-size:10px;letter-spacing:1px;color:var(--muted);}
.agenda-week-day-num{font-family:var(--font-head);font-size:18px;font-weight:800;}
.agenda-week-day-num.today{color:var(--accent);}
.agenda-time-col{background:var(--surface2);border-right:1px solid var(--border);}
.agenda-time-slot{height:48px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;padding:2px 4px;}
.agenda-time-label{font-size:10px;color:var(--muted);font-family:var(--font-head);}
.agenda-time-break{height:24px;background:var(--surface2);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:9px;color:var(--muted2);letter-spacing:1px;}
.agenda-day-col{border-right:1px solid var(--border);position:relative;}
.agenda-day-col.today-col{background:rgba(245,158,11,.04);}
.agenda-slot{height:48px;border-bottom:1px solid rgba(46,46,46,.5);cursor:pointer;transition:background .1s;position:relative;}
.agenda-slot:hover{background:rgba(245,158,11,.07);}
.agenda-slot.break-slot{height:24px;background:var(--surface2);cursor:default;}
.agenda-slot.break-slot:hover{background:var(--surface2);}
.agenda-event-block{position:absolute;left:2px;right:2px;border-radius:4px;padding:3px 6px;font-size:10px;z-index:2;cursor:pointer;overflow:hidden;}
.agenda-event-block.quote-evt{background:rgba(245,158,11,.25);border-left:3px solid var(--accent);color:var(--text);}
.agenda-event-block.manual-evt{background:rgba(96,165,250,.2);border-left:3px solid #60a5fa;color:var(--text);}
.agenda-event-block.ot-evt{background:rgba(34,197,94,.15);border-left:3px solid var(--success);color:var(--text);}

/* Event detail modal */
.agenda-detail{background:var(--surface);border:1px solid var(--accent);border-radius:8px;padding:18px;position:fixed;z-index:1100;width:300px;box-shadow:0 8px 32px rgba(0,0,0,.6);}
.agenda-detail-title{font-family:var(--font-head);font-size:14px;font-weight:700;letter-spacing:1px;margin-bottom:10px;color:var(--accent);}

/* ═══ ROLE SELECTOR ═══ */
.role-screen{position:fixed;inset:0;background:var(--bg);z-index:9998;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:32px;}
.role-cards{display:flex;gap:24px;flex-wrap:wrap;justify-content:center;}
.role-card{background:var(--surface);border:2px solid var(--border);border-radius:14px;padding:40px 48px;text-align:center;cursor:pointer;transition:all .2s;min-width:200px;}
.role-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 8px 32px rgba(0,0,0,.4);}
.role-card-icon{font-size:52px;margin-bottom:14px;}
.role-card-title{font-family:var(--font-head);font-size:22px;font-weight:900;letter-spacing:2px;margin-bottom:6px;}
.role-card-sub{font-size:12px;color:var(--muted);letter-spacing:1px;}
.role-card.admin{border-color:rgba(245,158,11,.3);}
.role-card.admin:hover{border-color:var(--accent);}
.role-card.mech{border-color:rgba(96,165,250,.3);}
.role-card.mech:hover{border-color:#60a5fa;}

/* ═══ MECHANIC MODE ═══ */
#mechScreen{position:fixed;inset:0;background:#0a0a0a;z-index:9997;display:none;flex-direction:column;overflow:hidden;}
.mech-header{background:var(--surface);border-bottom:3px solid #60a5fa;padding:14px 20px;display:flex;align-items:center;gap:14px;justify-content:space-between;}
.mech-header-left{display:flex;align-items:center;gap:12px;min-width:0;}
.mech-header-logo{font-family:var(--font-head);font-size:22px;font-weight:900;color:var(--accent);letter-spacing:2px;}
.mech-header-taller-wrap{display:flex;flex-direction:column;gap:2px;align-items:flex-start;min-width:0;}
.mech-header-taller{font-family:var(--font-head);font-size:14px;font-weight:800;letter-spacing:2px;text-transform:uppercase;color:var(--text);max-width:min(42vw,280px);line-height:1.15;}
.mech-header-role{font-family:var(--font-head);font-size:11px;color:#60a5fa;letter-spacing:2px;text-transform:uppercase;}
.mech-header-name{font-size:13px;color:var(--text);margin-left:auto;text-align:right;}
.mech-exit{background:transparent;border:1px solid var(--border);color:var(--muted);padding:6px 14px;border-radius:4px;cursor:pointer;font-size:12px;font-family:var(--font-head);letter-spacing:1px;}

.mech-body{flex:1;overflow-y:auto;padding:16px;}

/* Mechanic vehicle cards */
.mech-vehicles{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px;margin-bottom:20px;}
.mech-veh-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:18px 20px;cursor:pointer;transition:all .15s;position:relative;}
.mech-veh-card:hover{border-color:#60a5fa;transform:translateY(-2px);}
.mech-veh-plate{font-family:var(--font-head);font-size:26px;font-weight:900;letter-spacing:2px;color:var(--accent);}
.mech-veh-model{font-size:14px;color:var(--text);margin-top:2px;}
.mech-veh-client{font-size:12px;color:var(--muted);margin-top:4px;}
.mech-veh-status{position:absolute;top:14px;right:14px;font-size:10px;padding:3px 8px;border-radius:10px;font-family:var(--font-head);font-weight:700;letter-spacing:1px;}
.mech-veh-tasks{margin-top:10px;display:flex;flex-direction:column;gap:4px;}
.mech-veh-task{font-size:12px;display:flex;align-items:center;gap:6px;}
.mech-new-btn{background:#60a5fa;border:none;color:#000;font-family:var(--font-head);font-size:18px;font-weight:900;letter-spacing:2px;padding:18px 32px;border-radius:10px;cursor:pointer;width:100%;margin-bottom:16px;transition:all .15s;}
.mech-new-btn:hover{background:#93c5fd;}

/* Wizard */
.mech-wizard{display:none;}
.mech-wizard.active{display:block;}
.mech-step{display:none;animation:fadeIn .2s ease;}
.mech-step.active{display:block;}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.mech-step-header{font-family:var(--font-head);font-size:13px;letter-spacing:3px;color:#60a5fa;text-transform:uppercase;margin-bottom:20px;display:flex;align-items:center;gap:10px;}
.mech-step-num{background:#60a5fa;color:#000;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:12px;}
.mech-field{margin-bottom:18px;}
.mech-field label{display:block;font-size:11px;color:var(--muted);letter-spacing:2px;text-transform:uppercase;margin-bottom:6px;}
.mech-field input,.mech-field select,.mech-field textarea{width:100%;background:var(--surface);border:1px solid var(--border);color:var(--text);padding:14px 16px;border-radius:8px;font-size:16px;outline:none;font-family:var(--font-body);transition:border .15s;}
.mech-field input:focus,.mech-field select:focus,.mech-field textarea:focus{border-color:#60a5fa;}
.mech-field textarea{min-height:90px;resize:vertical;}
.mech-grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.mech-btn-row{display:flex;gap:12px;margin-top:24px;}
.mech-btn{flex:1;padding:16px;border-radius:8px;font-family:var(--font-head);font-size:16px;font-weight:800;letter-spacing:2px;cursor:pointer;border:none;transition:all .15s;}
.mech-btn-primary{background:#60a5fa;color:#000;}
.mech-btn-primary:hover{background:#93c5fd;}
.mech-btn-ghost{background:var(--surface);color:var(--text);border:1px solid var(--border);}
.mech-btn-ghost:hover{border-color:#60a5fa;}
.mech-btn-success{background:var(--success);color:#000;}
.mech-btn-danger{background:var(--danger);color:#fff;}

/* OT detail in mechanic mode */
.mech-ot-detail{display:none;}
.mech-ot-detail.active{display:block;}
.mech-task-row{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:14px 16px;margin-bottom:10px;display:flex;align-items:center;gap:14px;cursor:pointer;transition:all .15s;}
.mech-task-row:hover{border-color:#60a5fa;}
.mech-task-check{width:28px;height:28px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:14px;transition:all .15s;}
.mech-task-check.done{background:var(--success);border-color:var(--success);color:#000;}
.mech-task-check.progress{background:#60a5fa;border-color:#60a5fa;color:#000;}
.mech-task-check.pending{background:transparent;}
.mech-task-name{font-size:16px;font-weight:500;flex:1;}
.mech-task-price{font-family:var(--font-head);color:var(--accent);font-size:14px;}
.mech-section{font-family:var(--font-head);font-size:11px;letter-spacing:3px;color:#60a5fa;text-transform:uppercase;margin:20px 0 10px;padding-bottom:6px;border-bottom:1px solid var(--border);}
.mech-part-row{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:12px 16px;margin-bottom:8px;display:flex;justify-content:space-between;align-items:center;}
.fuel-bar-mech{display:flex;gap:8px;margin-top:6px;}
.fuel-btn-mech{flex:1;height:44px;border:1px solid var(--border);border-radius:6px;background:var(--surface);cursor:pointer;font-size:13px;font-family:var(--font-head);color:var(--muted);display:flex;align-items:center;justify-content:center;transition:all .15s;}
.fuel-btn-mech.active{background:#60a5fa;border-color:#60a5fa;color:#000;font-weight:700;}

/* ═══ ESTADO DE CUENTA ═══ */
.ec-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:20px;}
.ec-kpi{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:14px 16px;}
.ec-kpi-val{font-family:var(--font-head);font-size:26px;font-weight:900;line-height:1;}
.ec-kpi-lbl{font-size:10px;color:var(--muted);letter-spacing:1px;text-transform:uppercase;margin-top:4px;}
.ec-bar{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:14px 16px;margin-bottom:16px;}
.ec-bar-title{font-size:11px;color:var(--muted);letter-spacing:2px;text-transform:uppercase;margin-bottom:8px;}
.ec-bar-track{height:24px;background:var(--surface2);border-radius:4px;overflow:hidden;display:flex;}
.ec-bar-paid{height:100%;background:var(--success);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#000;transition:width .4s;}
.ec-bar-pending{height:100%;background:var(--danger);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;transition:width .4s;}
.ec-methods{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px;margin-bottom:16px;}
.ec-method{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:10px 14px;text-align:center;}
.ec-method-icon{font-size:20px;margin-bottom:4px;}
.ec-method-val{font-family:var(--font-head);font-size:16px;font-weight:800;color:var(--accent);}
.ec-method-lbl{font-size:10px;color:var(--muted);}
.ec-table{width:100%;border-collapse:collapse;font-size:13px;}
.ec-table th{font-family:var(--font-head);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);padding:8px 10px;border-bottom:1px solid var(--border);text-align:left;}
.ec-table td{padding:10px;border-bottom:1px solid var(--border);vertical-align:middle;}
.ec-table tr:last-child td{border-bottom:none;}
.ec-table tr:hover td{background:var(--surface2);}
.ec-pay-badge{font-size:10px;padding:3px 8px;border-radius:10px;font-family:var(--font-head);font-weight:700;white-space:nowrap;}
.ec-pay-paid{background:rgba(34,197,94,.15);color:var(--success);}
.ec-pay-partial{background:rgba(245,158,11,.15);color:var(--warn);}
.ec-pay-pending{background:rgba(239,68,68,.15);color:var(--danger);}

/* ═══ HISTORIAL MATRÍCULA ═══ */
.vh-overlay{position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:1200;display:flex;align-items:flex-start;justify-content:center;padding:20px;overflow-y:auto;}
.vh-modal{background:var(--surface);border:1px solid var(--border);border-radius:10px;width:100%;max-width:780px;margin:auto;}
.vh-header{background:linear-gradient(135deg,#1a1a1a,#222);border-bottom:3px solid var(--accent);padding:16px 22px;display:flex;align-items:center;gap:12px;border-radius:10px 10px 0 0;}
.vh-plate{font-family:var(--font-head);font-size:28px;font-weight:900;letter-spacing:3px;color:var(--accent);}
.vh-meta{font-size:13px;color:var(--muted);}
.vh-body{padding:20px;}
.vh-entry{border:1px solid var(--border);border-radius:8px;margin-bottom:12px;overflow:hidden;}
.vh-entry-header{background:var(--surface2);padding:12px 16px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;}
.vh-entry-date{font-family:var(--font-head);font-size:14px;font-weight:700;color:var(--accent);}
.vh-entry-km{font-size:12px;color:var(--muted);}
.vh-entry-total{font-family:var(--font-head);font-size:16px;font-weight:800;}
.vh-entry-body{padding:14px 16px;display:none;}
.vh-entry-body.open{display:block;}
.vh-service-list{margin-bottom:10px;}
.vh-service-item{display:flex;align-items:center;gap:8px;padding:5px 0;border-bottom:1px solid var(--border);font-size:13px;}
.vh-service-item:last-child{border:none;}
.vh-service-icon{font-size:14px;}
.vh-part-item{display:flex;justify-content:space-between;padding:4px 0 4px 20px;font-size:12px;color:var(--muted);border-bottom:1px dotted var(--border);}
.vh-part-item:last-child{border:none;}
.vh-type-badge{font-size:10px;padding:2px 7px;border-radius:10px;font-family:var(--font-head);font-weight:700;}
.vh-type-ot{background:rgba(34,197,94,.15);color:var(--success);}
.vh-type-quote{background:rgba(245,158,11,.15);color:var(--accent);}
.vh-empty{text-align:center;padding:40px;color:var(--muted);font-size:14px;}
