
:root{
  --bg:#ffffff;
  --side:#030303;
  --card:#ffffff;
  --card-soft:#f7f7f7;
  --text:#111111;
  --text-on-dark:#ffffff;
  --muted:#696969;
  --line:#dddddd;
  --line-dark:#222222;
  --ok:#15803d;
  --danger:#dc2626;
  --warn:#b45309;
  --accent:#000000;
}
*{box-sizing:border-box}
body{margin:0;background:#fff;color:var(--text);font-family:Inter,Arial,sans-serif}
a{color:#000}
input,select,textarea{
  width:100%;background:#fff;border:1px solid #cfcfcf;color:#111;border-radius:14px;
  padding:15px;font-size:16px;margin:6px 0 14px;min-height:52px
}
textarea{min-height:112px}
button{
  border:0;border-radius:16px;padding:14px 18px;background:#000;color:#fff;
  font-weight:900;cursor:pointer;font-size:15px;box-shadow:0 8px 22px rgba(0,0,0,.08)
}
button.secondary{background:#f2f2f2;color:#111;border:1px solid #d8d8d8}
button.danger{background:var(--danger);color:#fff}
button.ok{background:var(--ok);color:#fff}
button.warn{background:#f59e0b;color:#111}
.linkbtn{background:transparent;color:#111;text-decoration:underline;box-shadow:none}
.login{
  min-height:100vh;display:grid;place-items:center;padding:22px;
  background:linear-gradient(135deg,#ffffff 0%,#f3f3f3 55%,#e7e7e7 100%)
}
.login-card{
  width:min(520px,100%);background:#fff;border:1px solid #ddd;border-radius:30px;
  padding:34px;box-shadow:0 30px 90px rgba(0,0,0,.14)
}
.login-logo{display:block;max-width:260px;max-height:180px;margin:0 auto 18px;object-fit:contain}
.logo-text{text-align:center;font-size:32px;font-weight:950;letter-spacing:-1px;color:#000}
.sub{text-align:center;color:var(--muted);margin:8px 0 26px}

.app{display:flex;min-height:100vh;background:#fff}
.side{
  width:300px;background:#000;color:#fff;border-right:1px solid #111;padding:22px;
  position:sticky;top:0;height:100vh;overflow:auto;box-shadow:16px 0 42px rgba(0,0,0,.08)
}
.brand-logo{
  width:190px;max-height:140px;object-fit:contain;display:block;margin:0 auto 16px;
  background:#fff;border-radius:22px;padding:12px;border:1px solid #222
}
.brand{font-size:23px;font-weight:950;margin-bottom:8px;color:#fff;text-align:center}
.side .muted{color:#cfcfcf;text-align:center}
.nav button{
  display:block;width:100%;text-align:left;background:#111;color:#fff;margin:8px 0;
  border:1px solid #262626;box-shadow:none
}
.nav button.active{background:#fff;color:#000}
.main{
  flex:1;padding:28px;max-width:1780px;margin:0 auto;background:#fff;color:#111;min-height:100vh
}
.top{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:22px}
.top h1{color:#000;margin:0}
.card{
  background:#fff;border:1px solid #dedede;border-radius:26px;padding:22px;margin-bottom:18px;
  box-shadow:0 14px 34px rgba(0,0,0,.055)
}
.card h3,.card h2{color:#000}
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(245px,1fr));gap:16px}
.kpi{font-size:34px;font-weight:950;color:#000;letter-spacing:-1px}
.kpi small{font-size:13px;color:#666;display:block;margin-top:4px;letter-spacing:0}
.muted{color:var(--muted)}
.badge{
  display:inline-block;border:1px solid #d6d6d6;background:#f6f6f6;border-radius:999px;
  padding:5px 10px;font-size:12px;color:#111
}
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:16px}
.col-2{grid-column:span 2}.col-3{grid-column:span 3}.col-4{grid-column:span 4}.col-5{grid-column:span 5}.col-6{grid-column:span 6}.col-8{grid-column:span 8}.col-12{grid-column:span 12}
.table{width:100%;border-collapse:collapse;background:#fff}
.table th,.table td{border-bottom:1px solid #e5e5e5;padding:12px;text-align:left;vertical-align:top;color:#111}
.table th{background:#f7f7f7;font-size:12px;text-transform:uppercase;letter-spacing:.04em}
.actions{display:flex;gap:8px;flex-wrap:wrap}
.photo{width:56px;height:56px;border-radius:14px;background:#eee;object-fit:cover}
.preview{max-width:120px;max-height:120px;border-radius:18px;object-fit:cover;border:1px solid #ddd}

.modal-back{position:fixed;inset:0;background:rgba(0,0,0,.72);z-index:20;display:flex;align-items:flex-start;justify-content:center;padding:28px;overflow:auto}
.modal{width:min(1240px,100%);background:#fff;color:#111;border:1px solid #ddd;border-radius:28px;padding:24px;box-shadow:0 40px 120px rgba(0,0,0,.25)}
.modal-head{display:flex;justify-content:space-between;align-items:center;gap:16px}
.stepper{display:flex;gap:8px;flex-wrap:wrap;margin:12px 0 20px}
.step{padding:9px 12px;border-radius:999px;background:#f2f2f2;border:1px solid #ddd;color:#555}
.step.active{background:#000;color:#fff;border-color:#000}
.assign-row{
  display:grid;grid-template-columns:1.25fr 1.2fr .75fr .75fr .75fr .75fr .45fr .45fr auto;
  gap:10px;align-items:center;border:1px solid #ddd;border-radius:18px;padding:12px;margin-bottom:10px;background:#fff
}
.calendar{display:grid;grid-template-columns:repeat(7,1fr);gap:10px}
.day{min-height:130px;background:#fff;border:1px solid #ddd;border-radius:18px;padding:10px}
.day .num{font-weight:900;color:#000}
.day.mutedday{opacity:.35}
.event-chip{display:block;background:#f8f8f8;border:1px solid #d6d6d6;border-radius:12px;padding:7px;margin-top:7px;font-size:12px;cursor:pointer;color:#111}
.event-chip.done{border-color:#15803d}
.event-chip.planned{border-color:#111}
.signature-box{background:#fff;border-radius:14px;padding:10px}
.signature-box canvas{width:100%;height:180px;background:white;border:1px solid #ccc;border-radius:10px;touch-action:none}
.rate-card{
  display:grid;grid-template-columns:1.4fr .8fr .8fr .8fr .8fr .45fr .45fr auto;
  gap:10px;align-items:center;border:1px solid #ddd;border-radius:18px;padding:12px;margin-bottom:10px;background:#fff
}
.settings-section{border:1px solid #ddd;border-radius:22px;padding:18px;background:#fff;margin-bottom:16px}
.settings-title{font-size:18px;font-weight:950;margin:0 0 8px;color:#000}
.switchline{display:flex;align-items:center;gap:10px;min-height:52px}
.switchline input{width:auto;min-height:auto;margin:0}
.erp-label{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:#555;font-weight:900}
.chart-wrap{width:100%;overflow:auto}
.chart-svg{width:100%;min-width:760px;height:340px;background:#fff;border:1px solid #e1e1e1;border-radius:22px}
.chart-grid{stroke:#eeeeee;stroke-width:1}
.chart-axis{stroke:#111;stroke-width:1.5}
.chart-line{fill:none;stroke:#000;stroke-width:4;stroke-linecap:round;stroke-linejoin:round}
.chart-dot{fill:#000}
.chart-label{font-size:11px;fill:#333;font-family:Arial,sans-serif}
.chart-value{font-size:12px;fill:#000;font-weight:700;font-family:Arial,sans-serif}

@media(max-width:1100px){.assign-row,.rate-card{grid-template-columns:1fr 1fr}.assign-row button,.rate-card button{grid-column:span 2}}
@media(max-width:900px){
  .app{display:block}.side{width:100%;height:auto;position:relative;border-right:0;border-bottom:1px solid #111}
  .nav{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.main{padding:14px}
  .grid{grid-template-columns:1fr}.col-2,.col-3,.col-4,.col-5,.col-6,.col-8,.col-12{grid-column:span 1}
  .top{display:block}.table,.table thead,.table tbody,.table tr,.table th,.table td{display:block}.table thead{display:none}
  .table tr{border:1px solid #ddd;border-radius:18px;padding:12px;margin-bottom:12px;background:#fff}
  .table td{border:0;padding:7px 0}.table td:before{content:attr(data-label);display:block;color:#777;font-size:12px;margin-bottom:4px}
  button{width:100%;margin:4px 0}.actions button{width:auto}.login-card{padding:22px;border-radius:22px}
  .assign-row,.rate-card{grid-template-columns:1fr}.assign-row button,.rate-card button{grid-column:span 1}
  .modal-back{padding:8px}.modal{padding:16px;border-radius:20px}.brand-logo{margin:auto auto 12px}
  .calendar{grid-template-columns:1fr}.day{min-height:auto}
}


/* ==========================================
   V52 AUDIT COMPLETE - V46 UI PRESERVED
   ========================================== */

.login-logo{
  width:320px !important;
  max-width:100% !important;
  height:auto !important;
  max-height:none !important;
  object-fit:contain !important;
  display:block !important;
  margin:0 auto 18px auto !important;
}

.brand-logo{
  width:230px !important;
  max-width:100% !important;
  height:auto !important;
  max-height:none !important;
  object-fit:contain !important;
  display:block !important;
  margin:0 auto 16px auto !important;
}

.side{
  overflow:auto;
}

.nav button{
  min-height:42px;
  font-weight:900;
  letter-spacing:.01em;
}

.audit-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:14px;
}

.audit-card{
  background:#fff;
  border:1px solid #e7e9ee;
  border-radius:18px;
  padding:16px;
  box-shadow:0 4px 18px rgba(0,0,0,.045);
}

.audit-kpi{
  font-size:32px;
  font-weight:950;
}

.status-badge{
  display:inline-block;
  padding:5px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:900;
}

.status-ok{background:#dcfce7;color:#166534}
.status-warn{background:#ffedd5;color:#9a3412}
.status-bad{background:#fee2e2;color:#991b1b}
.status-blue{background:#dbeafe;color:#1d4ed8}

.production-phase{
  background:#f8fafc;
  border:1px solid #e5e7eb;
  border-radius:16px;
  padding:14px;
  margin-bottom:12px;
}

.production-phase h4{
  margin:0 0 8px 0;
  text-transform:uppercase;
  letter-spacing:.06em;
  font-size:13px;
}

.v52-head{
  display:flex;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
  align-items:flex-start;
}

.v52-sub{
  color:#667085;
  margin-top:4px;
}

.logo-text{
  margin-top:4px;
}


/* ==========================================
   V53 ENTERPRISE STABLE BUILD
   ========================================== */

.login-logo{
  width:330px !important;
  max-width:100% !important;
  height:auto !important;
  max-height:none !important;
  object-fit:contain !important;
  display:block !important;
  margin:0 auto 18px auto !important;
}

.brand-logo{
  width:240px !important;
  max-width:100% !important;
  height:auto !important;
  max-height:none !important;
  object-fit:contain !important;
  display:block !important;
  margin:0 auto 16px auto !important;
}

.v53-kpi-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(150px,1fr));
  gap:10px;
  align-items:stretch;
}

.v53-kpi-card{
  background:#fff;
  border:1px solid #e7e9ee;
  border-radius:16px;
  padding:12px 14px;
  box-shadow:0 3px 14px rgba(0,0,0,.045);
  min-height:92px;
}

.v53-kpi-card .label{
  font-size:12px;
  color:#667085;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.035em;
}

.v53-kpi-card .value{
  font-size:22px;
  font-weight:950;
  margin-top:5px;
  line-height:1.1;
}

.v53-rate-help{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(145px,1fr));
  gap:8px;
  margin:10px 0 16px 0;
}

.v53-help-chip{
  background:#f8fafc;
  border:1px solid #e5e7eb;
  border-radius:14px;
  padding:10px;
  font-size:12px;
}

.v53-help-chip b{
  display:block;
  font-size:18px;
  color:#111;
}

.v53-legend{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin:8px 0 14px 0;
}

.v53-pill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  border-radius:999px;
  padding:6px 10px;
  background:#f1f5f9;
  font-size:12px;
  font-weight:900;
}

.v53-radio-row{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin:12px 0;
}

.v53-radio-row button.active{
  background:#2563eb !important;
}

.v53-chart-wrap{
  position:relative;
  overflow:visible;
  padding-top:26px;
}

.v53-tooltip{
  position:fixed;
  background:#111;
  color:#fff;
  padding:10px 12px;
  border-radius:12px;
  z-index:9999;
  font-size:12px;
  box-shadow:0 12px 40px rgba(0,0,0,.28);
  pointer-events:none;
  min-width:170px;
  display:none;
}

.v53-doc-card{
  background:#fff;
  border:1px solid #e5e7eb;
  border-radius:16px;
  padding:14px;
  margin:10px 0;
}

.v53-a4{
  background:#fff;
  color:#111;
  width:210mm;
  min-height:297mm;
  padding:14mm;
  font-family:Arial, sans-serif;
}

.v53-a4-head{
  border-bottom:2px solid #111;
  padding-bottom:10px;
  margin-bottom:16px;
  display:flex;
  justify-content:space-between;
  gap:20px;
}

.v53-a4-title{
  font-size:22px;
  font-weight:900;
}

@media(max-width:900px){
  .v53-kpi-grid{grid-template-columns:repeat(2,1fr)}
}

@media(max-width:560px){
  .v53-kpi-grid{grid-template-columns:1fr}
}

@media print{
  .v53-a4{
    width:auto;
    min-height:auto;
    padding:0;
  }
}


/* V53.2 Dashboard Graph Restore */
.v532-chart-card{
  overflow:visible !important;
}
.v532-chart{
  height:260px;
  display:flex;
  align-items:end;
  gap:12px;
  padding:42px 18px 24px 18px;
  border:1px solid #e5e7eb;
  border-radius:18px;
  background:linear-gradient(180deg,#fff,#f8fafc);
  overflow:visible;
  position:relative;
}
.v532-bar-wrap{
  flex:1;
  height:200px;
  display:flex;
  align-items:end;
  justify-content:center;
  position:relative;
  min-width:34px;
}
.v532-bar{
  width:100%;
  max-width:54px;
  min-height:8px;
  background:#111;
  border-radius:12px 12px 4px 4px;
  cursor:pointer;
  transition:.15s ease;
  position:relative;
}
.v532-bar:hover{
  transform:translateY(-3px);
  background:#2563eb;
}
.v532-month{
  position:absolute;
  bottom:-22px;
  font-size:11px;
  color:#667085;
  white-space:nowrap;
}
.v532-tooltip{
  position:fixed;
  background:#111;
  color:#fff;
  padding:12px 14px;
  border-radius:14px;
  z-index:99999;
  font-size:12px;
  box-shadow:0 14px 45px rgba(0,0,0,.32);
  pointer-events:none;
  min-width:190px;
  display:none;
  line-height:1.55;
}
.v532-tooltip b{
  font-size:14px;
}
@media(max-width:700px){
  .v532-chart{gap:6px;padding-left:10px;padding-right:10px}
  .v532-month{font-size:10px;transform:rotate(-35deg);transform-origin:center top}
}


/* V53.3 Backup Center + Google-style Calendar */
.v533-backup-list{
  display:grid;
  gap:10px;
}
.v533-backup-item{
  background:#fff;
  border:1px solid #e5e7eb;
  border-radius:16px;
  padding:12px;
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:center;
  flex-wrap:wrap;
}
.v533-calendar-head{
  display:grid;
  grid-template-columns:repeat(7,1fr);
  gap:8px;
  margin-bottom:8px;
}
.v533-calendar-head div{
  font-size:12px;
  font-weight:900;
  color:#667085;
  text-align:center;
  text-transform:uppercase;
}
.v533-calendar{
  display:grid;
  grid-template-columns:repeat(7,1fr);
  gap:8px;
}
.v533-day{
  background:#fff;
  border:1px solid #e5e7eb;
  border-radius:16px;
  min-height:124px;
  padding:9px;
  box-shadow:0 3px 12px rgba(0,0,0,.035);
}
.v533-day.other{
  opacity:.45;
}
.v533-day-num{
  font-weight:950;
  margin-bottom:6px;
  font-size:13px;
}
.v533-event-chip{
  display:block;
  background:#111;
  color:#fff;
  border-radius:10px;
  padding:6px 7px;
  margin:4px 0;
  font-size:11px;
  line-height:1.25;
  cursor:pointer;
}
.v533-event-chip.done{
  background:#16a34a;
}
.v533-event-chip.cancel{
  background:#dc2626;
}
.v533-cal-actions{
  display:flex;
  gap:8px;
  align-items:center;
  flex-wrap:wrap;
}
@media(max-width:850px){
  .v533-calendar,.v533-calendar-head{grid-template-columns:1fr}
  .v533-calendar-head{display:none}
}


/* V55 Google Sync Full Calendar */
.v55-google-panel{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
}
.v55-calendar-toolbar{
  display:flex;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  align-items:center;
}
.v55-view-tabs{
  display:flex;
  gap:6px;
}
.v55-view-tabs button.active{
  background:#2563eb !important;
}
.v55-calendar-grid{
  display:grid;
  grid-template-columns:repeat(7,1fr);
  gap:8px;
}
.v55-week-grid{
  display:grid;
  grid-template-columns:repeat(7,1fr);
  gap:8px;
}
.v55-day-card{
  min-height:132px;
  background:#fff;
  border:1px solid #e5e7eb;
  border-radius:16px;
  padding:10px;
  box-shadow:0 3px 12px rgba(0,0,0,.035);
}
.v55-day-card.other{opacity:.45}
.v55-day-number{
  font-weight:950;
  font-size:13px;
  margin-bottom:7px;
}
.v55-event{
  display:block;
  border-radius:10px;
  padding:6px 7px;
  margin:4px 0;
  color:#fff;
  background:#111;
  font-size:11px;
  cursor:pointer;
  line-height:1.25;
}
.v55-event.google{background:#2563eb}
.v55-event.done{background:#16a34a}
.v55-event.cancel{background:#dc2626}
.v55-day-view{
  display:grid;
  gap:8px;
}
.v55-hour{
  display:grid;
  grid-template-columns:70px 1fr;
  border-bottom:1px solid #eee;
  min-height:44px;
}
.v55-hour-time{
  color:#667085;
  font-size:12px;
  padding-top:8px;
}
.v55-hour-events{
  padding:4px;
}
@media(max-width:850px){
  .v55-calendar-grid,.v55-week-grid{grid-template-columns:1fr}
}


/* V55.3 Calendar Auto View */
.v553-sync-info{
  padding:10px 12px;
  border-radius:14px;
  background:#eff6ff;
  border:1px solid #bfdbfe;
  color:#1e40af;
  font-size:13px;
  font-weight:800;
}
.v55-event.local{background:#111}
.v55-event.google{background:#2563eb}


/* V55.5 Operarios Pro */
.operator-avatar{
  width:54px;
  height:54px;
  border-radius:14px;
  object-fit:cover;
  background:#e5e7eb;
  display:inline-block;
  vertical-align:middle;
  margin-right:10px;
}
.operator-avatar-lg{
  width:110px;
  height:110px;
  border-radius:24px;
  object-fit:cover;
  background:#e5e7eb;
}
.operator-name-line{
  display:flex;
  align-items:center;
  gap:10px;
}
.operator-nickname{
  display:inline-block;
  font-size:12px;
  font-weight:900;
  background:#111;
  color:#fff;
  border-radius:999px;
  padding:4px 8px;
  margin-left:4px;
}
.operator-folder-head{
  display:flex;
  gap:18px;
  align-items:center;
  flex-wrap:wrap;
}


/* V55.6 Operarios UX Cliente Style */
.operator-create-layout{
  display:grid;
  grid-template-columns:1fr;
  gap:16px;
}
.operator-section{
  background:#fff;
  border:1px solid #e5e7eb;
  border-radius:18px;
  padding:16px;
}
.operator-section h4{
  margin:0 0 12px 0;
  font-size:15px;
  font-weight:950;
}
.operator-section .grid{
  margin:0;
}
.operator-form-actions{
  display:flex;
  justify-content:flex-end;
  gap:10px;
  margin-top:12px;
}
.operator-form-help{
  color:#667085;
  font-size:13px;
  margin-top:-4px;
  margin-bottom:10px;
}
.operator-list-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}


/* V55.8 Operarios Redesign Pro */
.operator-toolbar-v558{
  display:flex;
  justify-content:space-between;
  gap:14px;
  align-items:center;
  flex-wrap:wrap;
}
.operator-modal-v558{
  max-width:1120px !important;
}
.operator-form-v558{
  display:grid;
  gap:16px;
}
.operator-block-v558{
  background:#f8fafc;
  border:1px solid #e5e7eb;
  border-radius:18px;
  padding:16px;
}
.operator-block-v558 h4{
  margin:0 0 12px 0;
  font-size:15px;
  font-weight:950;
  letter-spacing:.01em;
}
.operator-checks-v558{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(230px,1fr));
  gap:10px;
}
.operator-check-v558{
  display:flex;
  align-items:center;
  gap:10px;
  background:#fff;
  border:1px solid #e5e7eb;
  border-radius:14px;
  padding:12px;
  font-weight:850;
}
.operator-check-v558 input{
  width:auto !important;
}
.operator-card-v558{
  display:flex;
  gap:12px;
  align-items:center;
}
.operator-small-v558{
  color:#667085;
  font-size:12px;
}
.operator-action-row-v558{
  display:flex;
  justify-content:flex-end;
  gap:10px;
  flex-wrap:wrap;
  padding-top:8px;
}


/* V55.9 Calendar UX + Evento Modal V46 */
.event-modal-v559{
  max-width:1160px !important;
}
.event-form-v559{
  display:grid;
  gap:16px;
}
.event-block-v559{
  background:#f8fafc;
  border:1px solid #e5e7eb;
  border-radius:18px;
  padding:16px;
}
.event-block-v559 h4{
  margin:0 0 12px 0;
  font-size:15px;
  font-weight:950;
}
.event-actions-v559{
  display:flex;
  justify-content:flex-end;
  gap:10px;
  flex-wrap:wrap;
}
.google-popup-note-v559{
  background:#eff6ff;
  border:1px solid #bfdbfe;
  color:#1e40af;
  padding:10px 12px;
  border-radius:14px;
  font-weight:800;
  font-size:13px;
}


/* V56 SMART OPERATOR FORM LAYOUT */
.operator-grid-v56{
  display:grid;
  grid-template-columns:repeat(12,minmax(0,1fr));
  gap:14px;
}

.operator-grid-v56 .field,
.operator-grid-v56 textarea,
.operator-grid-v56 select{
  width:100%;
}

.span-12{grid-column:span 12;}
.span-9{grid-column:span 9;}
.span-8{grid-column:span 8;}
.span-6{grid-column:span 6;}
.span-4{grid-column:span 4;}
.span-3{grid-column:span 3;}
.span-2{grid-column:span 2;}

.operator-block-v558 textarea{
  min-height:120px;
  resize:vertical;
}

@media (max-width:980px){
  .operator-grid-v56{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .span-12,.span-9,.span-8,.span-6,.span-4,.span-3,.span-2{
    grid-column:span 2 !important;
  }
}



/* V56.1 Google Calendar Sync Fix */
.google-sync-debug-v561{
  margin-top:10px;
  padding:10px 12px;
  border-radius:14px;
  background:#f8fafc;
  border:1px solid #e5e7eb;
  color:#334155;
  font-size:13px;
  font-weight:700;
}
.google-sync-debug-v561.bad{
  background:#fee2e2;
  border-color:#fecaca;
  color:#991b1b;
}
.google-sync-debug-v561.ok{
  background:#dcfce7;
  border-color:#bbf7d0;
  color:#166534;
}


/* V56.2 Informes PDF Pro A4 */
.report-panel-v562{
  display:grid;
  grid-template-columns:1fr;
  gap:16px;
}
.report-selector-v562{
  background:#f8fafc;
  border:1px solid #e5e7eb;
  border-radius:18px;
  padding:16px;
}
.report-tabs-v562{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-bottom:14px;
}
.report-tabs-v562 span{
  background:#111;
  color:#fff;
  border-radius:999px;
  padding:7px 12px;
  font-size:12px;
  font-weight:900;
}
.report-a4-v562{
  background:#fff;
  color:#111;
  width:210mm;
  min-height:297mm;
  padding:14mm;
  font-family:Arial, sans-serif;
}
.report-a4-head-v562{
  display:flex;
  justify-content:space-between;
  gap:20px;
  border-bottom:2px solid #111;
  padding-bottom:12px;
  margin-bottom:18px;
}
.report-a4-title-v562{
  font-size:22px;
  font-weight:950;
}
.report-kpis-v562{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:10px;
  margin:14px 0;
}
.report-kpi-v562{
  border:1px solid #ddd;
  border-radius:12px;
  padding:10px;
}
.report-kpi-v562 b{
  display:block;
  font-size:17px;
}
@media print{
  body *{visibility:hidden!important}
  #reportPrintAreaV562, #reportPrintAreaV562 *{visibility:visible!important}
  #reportPrintAreaV562{
    position:absolute;
    left:0;
    top:0;
    width:100%;
  }
  .no-print{display:none!important}
  @page{size:A4 portrait;margin:10mm}
}


/* V56.3 Calendar Force Sync + Event V46 Full */
.sync-modal-v563{
  max-width:720px !important;
}
.sync-box-v563{
  background:#f8fafc;
  border:1px solid #e5e7eb;
  border-radius:16px;
  padding:14px;
  margin:10px 0;
}
.sync-ok-v563{background:#dcfce7;border-color:#bbf7d0;color:#166534}
.sync-bad-v563{background:#fee2e2;border-color:#fecaca;color:#991b1b}
.event-modal-v563{
  max-width:1220px !important;
}
.event-form-v563{
  display:grid;
  gap:16px;
}
.event-block-v563{
  background:#f8fafc;
  border:1px solid #e5e7eb;
  border-radius:18px;
  padding:16px;
}
.event-block-v563 h4{
  margin:0 0 12px 0;
  font-size:15px;
  font-weight:950;
}
.event-grid-v563{
  display:grid;
  grid-template-columns:repeat(12,minmax(0,1fr));
  gap:14px;
}
@media(max-width:980px){
  .event-grid-v563{grid-template-columns:repeat(2,minmax(0,1fr))}
  .span-12,.span-9,.span-8,.span-6,.span-4,.span-3,.span-2{grid-column:span 2!important}
}


/* V56.5 Calendar Sync Hard Fix */
.sync-hard-v565{
  background:#f8fafc;
  border:1px solid #e5e7eb;
  border-radius:16px;
  padding:14px;
  margin:10px 0;
}
.sync-hard-v565.ok{background:#dcfce7;border-color:#bbf7d0;color:#166534}
.sync-hard-v565.bad{background:#fee2e2;border-color:#fecaca;color:#991b1b}
.sync-hard-v565 pre{
  white-space:pre-wrap;
  font-size:12px;
  background:rgba(255,255,255,.7);
  padding:10px;
  border-radius:10px;
}


/* V56.6 V46 Event Modal + Tarifas Roles Pro */
.v46-event-modal-v566{max-width:1240px!important}
.v46-event-form-v566{display:grid;gap:16px}
.v46-event-block-v566{
  background:#f8fafc;
  border:1px solid #e5e7eb;
  border-radius:18px;
  padding:16px;
}
.v46-event-block-v566 h4{
  margin:0 0 12px 0;
  font-size:15px;
  font-weight:950;
}
.v46-grid-v566{
  display:grid;
  grid-template-columns:repeat(12,minmax(0,1fr));
  gap:14px;
}
.role-line-v566{
  display:grid;
  grid-template-columns:3fr 1fr 1fr 1fr 1fr 1fr auto;
  gap:8px;
  align-items:center;
  background:#fff;
  border:1px solid #e5e7eb;
  border-radius:14px;
  padding:10px;
  margin-top:8px;
}
.rate-admin-grid-v566{
  display:grid;
  grid-template-columns:2.2fr 1fr 1fr 1fr 1.5fr auto;
  gap:8px;
  align-items:center;
}
@media(max-width:980px){
  .v46-grid-v566{grid-template-columns:repeat(2,minmax(0,1fr))}
  .role-line-v566,.rate-admin-grid-v566{grid-template-columns:1fr}
  .span-12,.span-9,.span-8,.span-6,.span-4,.span-3,.span-2{grid-column:span 2!important}
}


/* V56.7 Calendar Sync Final Fix */
.sync-final-v567{
  background:#f8fafc;
  border:1px solid #e5e7eb;
  border-radius:16px;
  padding:14px;
  margin:10px 0;
}
.sync-final-v567.ok{background:#dcfce7;border-color:#bbf7d0;color:#166534}
.sync-final-v567.bad{background:#fee2e2;border-color:#fecaca;color:#991b1b}
.sync-final-v567 pre{
  white-space:pre-wrap;
  font-size:12px;
  max-height:260px;
  overflow:auto;
  background:rgba(255,255,255,.75);
  padding:10px;
  border-radius:10px;
}
.force-sync-btn-v567{
  background:#dc2626!important;
  color:white!important;
  font-weight:950!important;
}


/* V56.8 Operarios roles + asignaciones */
.assignment-box-v568{
  display:grid;
  gap:8px;
}
.assignment-row-v568{
  display:grid;
  grid-template-columns:2.3fr 1.6fr 1fr 1fr auto;
  gap:8px;
  align-items:center;
  background:#fff;
  border:1px solid #e5e7eb;
  border-radius:14px;
  padding:10px;
}
.rate-edit-row-v568{
  display:grid;
  grid-template-columns:2fr 2.5fr .8fr .8fr .8fr .8fr auto;
  gap:8px;
  align-items:center;
  margin-bottom:8px;
}
@media(max-width:980px){
  .assignment-row-v568,.rate-edit-row-v568{grid-template-columns:1fr}
}


/* V57 A4 PDF / Print Buttons */
.a4-print-v57{
  background:#fff;
  color:#111;
  width:210mm;
  min-height:297mm;
  padding:14mm;
  font-family:Arial,sans-serif;
}
.a4-head-v57{
  display:flex;
  justify-content:space-between;
  border-bottom:2px solid #111;
  padding-bottom:12px;
  margin-bottom:16px;
}
.a4-title-v57{font-size:24px;font-weight:950}
.pdf-btn-v57{background:#111!important;color:#fff!important;font-weight:950!important}
.backup-box-v57{
  background:#f8fafc;
  border:1px solid #e5e7eb;
  border-radius:16px;
  padding:14px;
  margin:10px 0;
}
@media print{
  body *{visibility:hidden!important}
  #printAreaV57, #printAreaV57 *{visibility:visible!important}
  #printAreaV57{position:absolute;left:0;top:0;width:100%}
  .no-print{display:none!important}
  @page{size:A4 portrait;margin:10mm}
}


/* V57.2 Calendar + Event modal final */
.sync-v572{background:#f8fafc;border:1px solid #e5e7eb;border-radius:16px;padding:14px;margin:10px 0}
.sync-v572.ok{background:#dcfce7;border-color:#bbf7d0;color:#166534}
.sync-v572.bad{background:#fee2e2;border-color:#fecaca;color:#991b1b}
.sync-v572 pre{white-space:pre-wrap;max-height:260px;overflow:auto;font-size:12px;background:rgba(255,255,255,.8);padding:10px;border-radius:10px}
.force-sync-v572{background:#dc2626!important;color:#fff!important;font-weight:950!important}
.assignment-row-v572{display:grid;grid-template-columns:2fr 1.8fr .8fr .8fr .8fr auto;gap:8px;align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:10px;margin:8px 0}
@media(max-width:980px){.assignment-row-v572{grid-template-columns:1fr}}


/* V57.3 Botones PDF A4 Ver / Imprimir */
.pdf-actions-v573{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-top:8px;
}
.btn-view-pdf-v573{
  background:#2563eb!important;
  color:#fff!important;
  font-weight:950!important;
}
.btn-print-pdf-v573{
  background:#111!important;
  color:#fff!important;
  font-weight:950!important;
}


/* V57.4 Calendar no-pattern fix */
.sync-v574{background:#f8fafc;border:1px solid #e5e7eb;border-radius:16px;padding:14px;margin:10px 0}
.sync-v574.ok{background:#dcfce7;border-color:#bbf7d0;color:#166534}
.sync-v574.bad{background:#fee2e2;border-color:#fecaca;color:#991b1b}
.sync-v574 pre{white-space:pre-wrap;max-height:300px;overflow:auto;background:rgba(255,255,255,.8);border-radius:10px;padding:10px;font-size:12px}
.force-sync-v574{background:#7f1d1d!important;color:#fff!important;font-weight:950!important}


/* V57.5 PDF A4 Global Viewer */
.pdf-global-actions-v575{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin:12px 0;
}
.pdf-global-view-v575{
  background:#2563eb!important;
  color:#fff!important;
  font-weight:950!important;
}
.pdf-global-print-v575{
  background:#111!important;
  color:#fff!important;
  font-weight:950!important;
}
.pdf-a4-wrapper-v575{
  width:210mm;
  min-height:297mm;
  background:white;
  color:#111;
  padding:14mm;
  font-family:Arial,sans-serif;
  box-shadow:0 10px 34px rgba(0,0,0,.12);
  margin:auto;
}
.pdf-a4-header-v575{
  display:flex;
  justify-content:space-between;
  gap:20px;
  border-bottom:2px solid #111;
  padding-bottom:12px;
  margin-bottom:18px;
}
.pdf-a4-brand-v575{
  font-size:24px;
  font-weight:950;
}
.pdf-a4-content-v575 h1{
  font-size:24px;
  margin:12px 0;
}
.pdf-a4-content-v575 h2{
  font-size:17px;
  margin-top:18px;
}
@media print{
  body *{visibility:hidden!important}
  #globalPdfPrintAreaV575, #globalPdfPrintAreaV575 *{visibility:visible!important}
  #globalPdfPrintAreaV575{
    position:absolute;
    left:0;
    top:0;
    width:100%;
    box-shadow:none!important;
    margin:0!important;
  }
  .no-print{display:none!important}
  @page{size:A4 portrait;margin:10mm}
}


/* V57.6 Calendar Event Actions */
.event-actions-modal-v576{
  max-width:1040px!important;
}
.event-actions-grid-v576{
  display:grid;
  grid-template-columns:repeat(12,minmax(0,1fr));
  gap:12px;
}
.event-actions-section-v576{
  background:#f8fafc;
  border:1px solid #e5e7eb;
  border-radius:18px;
  padding:16px;
  margin:12px 0;
}
.event-delete-v576{
  background:#dc2626!important;
  color:#fff!important;
  font-weight:950!important;
}
.event-edit-v576{
  background:#2563eb!important;
  color:#fff!important;
  font-weight:950!important;
}
@media(max-width:980px){
  .event-actions-grid-v576{grid-template-columns:1fr}
  .span-12,.span-9,.span-8,.span-6,.span-4,.span-3,.span-2{grid-column:span 1!important}
}


/* V57.7 Calendar Click Fix */
.v55-event,
.calendar-event-click-v577{
  cursor:pointer!important;
  pointer-events:auto!important;
}
.calendar-event-click-v577:hover{
  transform:translateY(-1px);
  filter:brightness(.95);
}


/* V57.8 Calendar Click Hard Fix */
.cal-event-v578{
  display:block;
  border-radius:10px;
  padding:6px 7px;
  margin:4px 0;
  color:#fff;
  background:#111;
  font-size:11px;
  cursor:pointer!important;
  pointer-events:auto!important;
  line-height:1.25;
  user-select:none;
  border:0;
  width:100%;
  text-align:left;
}
.cal-event-v578.google{background:#2563eb}
.cal-event-v578.done{background:#16a34a}
.cal-event-v578.cancel{background:#dc2626}
.cal-event-v578:hover{
  transform:translateY(-1px);
  filter:brightness(.92);
}


/* V57.9 Calendar Click Final Fix */
.cal-clickable-v579,
.v55-event,
.cal-event-v578{
  cursor:pointer!important;
  pointer-events:auto!important;
  position:relative!important;
  z-index:50!important;
}
.cal-clickable-v579{
  outline:2px solid rgba(37,99,235,.25);
}


/* V58 Calendar Edit/Delete Direct */
.event-v58-modal{max-width:1050px!important}
.event-v58-section{background:#f8fafc;border:1px solid #e5e7eb;border-radius:18px;padding:16px;margin:12px 0}
.event-v58-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.event-v58-edit{background:#2563eb!important;color:#fff!important;font-weight:950!important}
.event-v58-delete{background:#dc2626!important;color:#fff!important;font-weight:950!important}
.event-v58-grid{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:12px}
@media(max-width:980px){.event-v58-grid{grid-template-columns:1fr}.span-12,.span-9,.span-8,.span-6,.span-4,.span-3,.span-2{grid-column:span 1!important}}


/* V58.1 Calendar Visible Actions */
.cal-card-v581{
  background:#111;
  color:#fff;
  border-radius:12px;
  padding:7px;
  margin:5px 0;
  font-size:11px;
}
.cal-card-v581.google{background:#2563eb}
.cal-card-v581 .cal-title-v581{
  font-weight:900;
  margin-bottom:6px;
}
.cal-actions-v581{
  display:flex;
  gap:5px;
  flex-wrap:wrap;
}
.cal-actions-v581 button{
  font-size:10px!important;
  padding:5px 7px!important;
  border-radius:8px!important;
}
.cal-edit-v581{background:#f59e0b!important;color:#111!important;font-weight:950!important}
.cal-delete-v581{background:#dc2626!important;color:#fff!important;font-weight:950!important}
.event-list-v581{
  display:grid;
  gap:8px;
}
.event-list-row-v581{
  display:grid;
  grid-template-columns:1.3fr 2fr 1.2fr auto;
  gap:10px;
  align-items:center;
  border:1px solid #e5e7eb;
  border-radius:14px;
  padding:10px;
  background:#fff;
}
@media(max-width:980px){
  .event-list-row-v581{grid-template-columns:1fr}
}


/* V58.2 Calendar Override Real */
.v582-calendar-force-banner{
  background:#111827;
  color:#fff;
  border-radius:18px;
  padding:16px;
  margin-bottom:14px;
  display:flex;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  align-items:center;
}
.v582-calendar-force-banner button{
  background:#f59e0b!important;
  color:#111!important;
  font-weight:950!important;
}
.v582-event-row{
  display:grid;
  grid-template-columns:1.1fr 2fr 1.3fr auto;
  gap:10px;
  align-items:center;
  background:#fff;
  border:1px solid #e5e7eb;
  border-radius:14px;
  padding:10px;
  margin:8px 0;
}
.v582-event-actions{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
}
.v582-edit{background:#2563eb!important;color:#fff!important;font-weight:950!important}
.v582-delete{background:#dc2626!important;color:#fff!important;font-weight:950!important}
.v582-calendar-card{
  background:#f8fafc;
  border:1px solid #e5e7eb;
  border-radius:18px;
  padding:14px;
}
.v582-day{
  border:1px solid #e5e7eb;
  border-radius:14px;
  min-height:120px;
  padding:8px;
  background:#fff;
}
.v582-event-pill{
  display:block;
  width:100%;
  text-align:left;
  border:0;
  border-radius:10px;
  margin:5px 0;
  padding:7px;
  background:#111;
  color:#fff;
  cursor:pointer;
}
.v582-event-pill.google{background:#2563eb}
@media(max-width:980px){.v582-event-row{grid-template-columns:1fr}}


/* V58.3 Sync restored + edit fix */
.v583-sync{background:#f8fafc;border:1px solid #e5e7eb;border-radius:16px;padding:14px;margin:10px 0}
.v583-sync.ok{background:#dcfce7;border-color:#bbf7d0;color:#166534}
.v583-sync.bad{background:#fee2e2;border-color:#fecaca;color:#991b1b}
.v583-sync pre{white-space:pre-wrap;max-height:280px;overflow:auto;background:rgba(255,255,255,.8);border-radius:10px;padding:10px;font-size:12px}
.v583-sync-btn{background:#7f1d1d!important;color:#fff!important;font-weight:950!important}
.v583-edit{background:#2563eb!important;color:#fff!important;font-weight:950!important}
.v583-delete{background:#dc2626!important;color:#fff!important;font-weight:950!important}


/* V58.4 Calendar menu active state */
.menu-active-calendar-v584,
.sidebar button.menu-active-calendar-v584,
.sidebar a.menu-active-calendar-v584,
nav button.menu-active-calendar-v584,
nav a.menu-active-calendar-v584{
  background:#fff!important;
  color:#111!important;
  font-weight:950!important;
  box-shadow:0 8px 24px rgba(255,255,255,.18)!important;
}


/* V58.5 Google Sync Modal Close Fix */
.sync-modal-safe-v585{
  max-width:760px!important;
  position:relative;
}
.sync-modal-head-v585{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.sync-close-v585{
  background:#111!important;
  color:#fff!important;
  font-weight:950!important;
}
.sync-cancel-v585{
  background:#dc2626!important;
  color:#fff!important;
  font-weight:950!important;
}
.sync-status-v585{
  background:#f8fafc;
  border:1px solid #e5e7eb;
  border-radius:16px;
  padding:14px;
  margin:12px 0;
}
.sync-status-v585.ok{
  background:#dcfce7;
  border-color:#bbf7d0;
  color:#166534;
}
.sync-status-v585.bad{
  background:#fee2e2;
  border-color:#fecaca;
  color:#991b1b;
}
.sync-status-v585 pre{
  white-space:pre-wrap;
  max-height:280px;
  overflow:auto;
  background:rgba(255,255,255,.8);
  border-radius:10px;
  padding:10px;
  font-size:12px;
}


/* V58.6 Calendar active menu fix */
body.calendar-view-active-v586 .sidebar button,
body.calendar-view-active-v586 .sidebar a,
body.calendar-view-active-v586 nav button,
body.calendar-view-active-v586 nav a{
  transition:all .15s ease;
}

body.calendar-view-active-v586 .sidebar button.dashboard-active-v586,
body.calendar-view-active-v586 .sidebar a.dashboard-active-v586,
body.calendar-view-active-v586 nav button.dashboard-active-v586,
body.calendar-view-active-v586 nav a.dashboard-active-v586{
  background:transparent!important;
  color:inherit!important;
  box-shadow:none!important;
}

body.calendar-view-active-v586 .menu-calendar-active-v586,
body.calendar-view-active-v586 button.menu-calendar-active-v586,
body.calendar-view-active-v586 a.menu-calendar-active-v586{
  background:#fff!important;
  color:#111!important;
  font-weight:950!important;
  box-shadow:0 10px 24px rgba(255,255,255,.2)!important;
}


/* V58.7 Calendar Edit Fix */
.event-edit-modal-v587{
  max-width:1180px!important;
}
.event-edit-section-v587{
  background:#f8fafc;
  border:1px solid #e5e7eb;
  border-radius:18px;
  padding:16px;
  margin:12px 0;
}
.event-edit-grid-v587{
  display:grid;
  grid-template-columns:repeat(12,minmax(0,1fr));
  gap:12px;
}
.event-edit-save-v587{
  background:#2563eb!important;
  color:#fff!important;
  font-weight:950!important;
}
.event-edit-cancel-v587{
  background:#111!important;
  color:#fff!important;
  font-weight:950!important;
}
@media(max-width:980px){
  .event-edit-grid-v587{grid-template-columns:1fr}
  .span-12,.span-9,.span-8,.span-6,.span-4,.span-3,.span-2{grid-column:span 1!important}
}


/* V58.9 Sync modal hard close */
.sync-hard-close-v589{
  background:#111!important;
  color:#fff!important;
  font-weight:950!important;
  border-radius:12px!important;
  padding:10px 16px!important;
}
.sync-modal-v589{
  max-width:760px!important;
  position:relative;
}
.sync-modal-head-v589{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.sync-status-v589{
  background:#f8fafc;
  border:1px solid #e5e7eb;
  border-radius:16px;
  padding:14px;
  margin:12px 0;
}
.sync-status-v589.ok{
  background:#dcfce7;
  border-color:#bbf7d0;
  color:#166534;
}
.sync-status-v589.bad{
  background:#fee2e2;
  border-color:#fecaca;
  color:#991b1b;
}


/* V61.2 Safe V46 Event Form */
.v612-modal{max-width:1280px!important}
.v612-section{background:#f8fafc;border:1px solid #e5e7eb;border-radius:18px;padding:16px;margin:12px 0}
.v612-grid{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:12px}
.v612-save{background:#16a34a!important;color:#fff!important;font-weight:950!important}
.v612-geo{background:#111!important;color:#fff!important;font-weight:950!important}
.v612-link{background:#2563eb!important;color:#fff!important;font-weight:950!important}
.v612-add{background:#111827!important;color:#fff!important;font-weight:950!important}
.v612-warning{background:#fff7ed;border:1px solid #fed7aa;color:#9a3412;border-radius:14px;padding:10px}
.v612-assignment{display:grid;grid-template-columns:2fr 1.8fr .7fr 1fr 1fr .9fr auto;gap:8px;align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:10px;margin:8px 0}
.v612-teamlead{outline:2px solid #f59e0b}
@media(max-width:980px){
  .v612-grid,.v612-assignment{grid-template-columns:1fr}
  .span-12,.span-9,.span-8,.span-7,.span-6,.span-5,.span-4,.span-3,.span-2{grid-column:span 1!important}
}


/* V61.3 Solo Login Fix */
.v613-login-lock{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
  background:#050505;
  color:#111;
}
.v613-login-card{
  width:min(520px,100%);
  background:#fff;
  border-radius:24px;
  padding:26px;
  box-shadow:0 22px 60px rgba(0,0,0,.28);
}
.v613-login-card h2{margin-top:0}
.v613-login-card button{
  background:#111!important;
  color:#fff!important;
  font-weight:950!important;
}


/* V61.4 Google Calendar Push */
.v614-google-status{
  background:#eff6ff;
  border:1px solid #bfdbfe;
  color:#1e40af;
  border-radius:14px;
  padding:10px;
  margin-top:10px;
}
.v614-google-status.bad{
  background:#fee2e2;
  border-color:#fecaca;
  color:#991b1b;
}


/* ---------- V62.0 PHASE 1 SIDEBAR REORDER ---------- */

.v620-sidebar{
  display:flex;
  flex-direction:column;
  gap:18px;
  padding:12px 8px 20px;
}

.v620-section{
  border-bottom:1px solid rgba(255,255,255,.08);
  padding-bottom:14px;
}

.v620-title{
  font-size:11px;
  letter-spacing:1.6px;
  opacity:.6;
  font-weight:900;
  padding:8px 14px;
  text-transform:uppercase;
}

.v620-body{
  display:flex;
  flex-direction:column;
  gap:6px;
}

.v620-menu-item{
  width:100%;
  border-radius:14px;
  padding:12px 14px;
  transition:.18s ease;
  cursor:pointer;
  font-weight:700;
}

.v620-menu-item:hover{
  background:rgba(255,255,255,.08);
}

.v620-active{
  background:#fff!important;
  color:#111!important;
  font-weight:900!important;
  box-shadow:0 6px 20px rgba(0,0,0,.18);
}


/* ---------- V62.1 SIDEBAR REAL REORDER ---------- */
.v621-menu-root{
  display:flex;
  flex-direction:column;
  gap:17px;
  padding:12px 8px 22px;
}

.v621-menu-group{
  padding-bottom:13px;
  border-bottom:1px solid rgba(255,255,255,.08);
}

.v621-menu-title{
  font-size:10px;
  letter-spacing:1.7px;
  font-weight:950;
  opacity:.55;
  color:#fff;
  padding:8px 12px;
  text-transform:uppercase;
}

.v621-menu-body{
  display:flex;
  flex-direction:column;
  gap:6px;
}

.v621-menu-btn{
  appearance:none;
  border:0;
  width:100%;
  text-align:left;
  border-radius:14px;
  padding:12px 14px;
  background:transparent;
  color:rgba(255,255,255,.72);
  cursor:pointer;
  font-weight:800;
  transition:.16s ease;
}

.v621-menu-btn:hover{
  background:rgba(255,255,255,.08);
  color:#fff;
}

.v621-menu-btn.v621-active{
  background:#fff!important;
  color:#111!important;
  font-weight:950!important;
  box-shadow:0 8px 24px rgba(255,255,255,.18)!important;
}


/* ---------- V62.2 SIDEBAR NATIVE REWRITE ---------- */
.v622-menu-root{
  display:flex;
  flex-direction:column;
  gap:17px;
  padding:16px 8px 24px;
}

.v622-menu-group{
  padding-bottom:14px;
  border-bottom:1px solid rgba(255,255,255,.08);
}

.v622-menu-title{
  font-size:10px;
  letter-spacing:1.8px;
  font-weight:950;
  opacity:.52;
  color:#fff;
  padding:8px 12px;
  text-transform:uppercase;
}

.v622-menu-body{
  display:flex;
  flex-direction:column;
  gap:6px;
}

.v622-menu-btn{
  appearance:none;
  border:0;
  width:100%;
  text-align:left;
  border-radius:14px;
  padding:12px 14px;
  background:transparent;
  color:rgba(255,255,255,.74);
  cursor:pointer;
  font-weight:850;
  transition:.16s ease;
}

.v622-menu-btn:hover{
  background:rgba(255,255,255,.08);
  color:#fff;
}

.v622-menu-btn.v622-active{
  background:#fff!important;
  color:#111!important;
  font-weight:950!important;
  box-shadow:0 8px 24px rgba(255,255,255,.18)!important;
}


/* ---------- V62.3 SIDEBAR STATIC CLEAN FIX ---------- */
.v623-menu-root{
  display:flex;
  flex-direction:column;
  gap:17px;
  padding:16px 8px 24px;
}

.v623-menu-group{
  padding-bottom:14px;
  border-bottom:1px solid rgba(255,255,255,.08);
}

.v623-menu-title{
  font-size:10px;
  letter-spacing:1.8px;
  font-weight:950;
  opacity:.52;
  color:#fff;
  padding:8px 12px;
  text-transform:uppercase;
}

.v623-menu-body{
  display:flex;
  flex-direction:column;
  gap:6px;
}

.v623-menu-btn{
  appearance:none;
  border:0;
  width:100%;
  text-align:left;
  border-radius:14px;
  padding:12px 14px;
  background:transparent;
  color:rgba(255,255,255,.74);
  cursor:pointer;
  font-weight:850;
  transition:background .16s ease, color .16s ease;
}

.v623-menu-btn:hover{
  background:rgba(255,255,255,.08);
  color:#fff;
}

.v623-menu-btn.v623-active{
  background:#fff!important;
  color:#111!important;
  font-weight:950!important;
  box-shadow:0 8px 24px rgba(255,255,255,.18)!important;
}


/* ---------- V62.4 SIDEBAR INSTANT NAVIGATION ---------- */
.v624-menu-root{
  display:flex;
  flex-direction:column;
  gap:17px;
  padding:16px 8px 24px;
  contain:layout style;
}

.v624-menu-group{
  padding-bottom:14px;
  border-bottom:1px solid rgba(255,255,255,.08);
}

.v624-menu-title{
  font-size:10px;
  letter-spacing:1.8px;
  font-weight:950;
  opacity:.52;
  color:#fff;
  padding:8px 12px;
  text-transform:uppercase;
}

.v624-menu-body{
  display:flex;
  flex-direction:column;
  gap:6px;
}

.v624-menu-btn{
  appearance:none;
  border:0;
  width:100%;
  text-align:left;
  border-radius:14px;
  padding:12px 14px;
  background:transparent;
  color:rgba(255,255,255,.74);
  cursor:pointer;
  font-weight:850;
  transition:none!important;
  will-change:auto!important;
}

.v624-menu-btn:hover{
  background:rgba(255,255,255,.08);
  color:#fff;
}

.v624-menu-btn.v624-active{
  background:#fff!important;
  color:#111!important;
  font-weight:950!important;
  box-shadow:none!important;
}


/* ---------- V62.5 SIDEBAR SINGLE ACTIVE FIX ---------- */
.v625-active,
.v624-menu-btn.v625-active,
.v623-menu-btn.v625-active,
.v622-menu-btn.v625-active{
  background:#fff!important;
  color:#111!important;
  font-weight:950!important;
  box-shadow:none!important;
}


/* ---------- V62.6 SIDEBAR GLOBAL SINGLE ACTIVE ---------- */

/* Estado único ganador */
.v626-active,
.v624-menu-btn.v626-active,
.v623-menu-btn.v626-active,
.v622-menu-btn.v626-active,
.v621-menu-btn.v626-active,
.v620-menu-item.v626-active{
  background:#fff!important;
  color:#111!important;
  font-weight:950!important;
  box-shadow:none!important;
}

/* Cualquier activo viejo que NO sea el activo global queda apagado */
.v624-menu-btn.v624-active:not(.v626-active),
.v623-menu-btn.v623-active:not(.v626-active),
.v622-menu-btn.v622-active:not(.v626-active),
.v621-menu-btn.v621-active:not(.v626-active),
.v620-menu-item.v620-active:not(.v626-active),
.sidebar button.active:not(.v626-active),
.sidebar a.active:not(.v626-active),
aside button.active:not(.v626-active),
aside a.active:not(.v626-active),
nav button.active:not(.v626-active),
nav a.active:not(.v626-active),
.selected:not(.v626-active),
.current:not(.v626-active){
  background:transparent!important;
  color:rgba(255,255,255,.74)!important;
  box-shadow:none!important;
  filter:none!important;
}


/* ---------- V62.10 OPERATOR EDIT BUTTON ---------- */
.v6210-edit-operator-btn{
  background:#2563eb!important;
  color:#fff!important;
  font-weight:950!important;
  border-radius:10px!important;
  padding:8px 12px!important;
  margin:2px!important;
}

.v6210-operator-modal{
  max-width:1180px!important;
}

.v6210-section{
  background:#f8fafc;
  border:1px solid #e5e7eb;
  border-radius:18px;
  padding:16px;
  margin:12px 0;
}

.v6210-grid{
  display:grid;
  grid-template-columns:repeat(12,minmax(0,1fr));
  gap:12px;
}

.v6210-save{
  background:#16a34a!important;
  color:#fff!important;
  font-weight:950!important;
}

@media(max-width:980px){
  .v6210-grid{grid-template-columns:1fr}
  .span-12,.span-9,.span-8,.span-7,.span-6,.span-5,.span-4,.span-3,.span-2{grid-column:span 1!important}
}


/* ---------- V62.11 CLIENT EDIT BUTTON FIX ---------- */
.v6211-edit-client-btn{
  background:#2563eb!important;
  color:#fff!important;
  font-weight:950!important;
  border-radius:10px!important;
  padding:8px 12px!important;
  margin:2px!important;
}

.v6211-client-modal{
  max-width:1050px!important;
}

.v6211-section{
  background:#f8fafc;
  border:1px solid #e5e7eb;
  border-radius:18px;
  padding:16px;
  margin:12px 0;
}

.v6211-grid{
  display:grid;
  grid-template-columns:repeat(12,minmax(0,1fr));
  gap:12px;
}

.v6211-save{
  background:#16a34a!important;
  color:#fff!important;
  font-weight:950!important;
}

@media(max-width:980px){
  .v6211-grid{grid-template-columns:1fr}
  .span-12,.span-9,.span-8,.span-7,.span-6,.span-5,.span-4,.span-3,.span-2{grid-column:span 1!important}
}

/* ---------- V62.14 OPERATOR PHOTO DOCS TEAM LEAD ---------- */
.v6214-photo-box{display:flex;gap:16px;align-items:center;flex-wrap:wrap}
.v6214-photo-preview{width:96px;height:96px;border-radius:18px;object-fit:cover;background:#e5e7eb;border:1px solid #d1d5db}
.v6214-doc-list{display:flex;flex-direction:column;gap:8px;margin-top:10px}
.v6214-doc-item{display:flex;justify-content:space-between;gap:12px;align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:10px}
.v6214-teamlead{background:#fffbeb;border:1px solid #fbbf24;color:#92400e;border-radius:14px;padding:12px;font-weight:900}


/* ---------- V62.15 PHOTO ICON + EVENT PERSISTENCE HARD FIX ---------- */
.v6215-operator-avatar{
  width:38px!important;
  height:38px!important;
  border-radius:999px!important;
  object-fit:cover!important;
  border:2px solid rgba(255,255,255,.8)!important;
  background:#e5e7eb!important;
  display:inline-block!important;
  vertical-align:middle!important;
  margin-right:8px!important;
}

/* ---------- V62.20 PASSWORDS EASY EDIT ---------- */
.v6220-toolbar{display:flex;gap:10px;align-items:center;justify-content:space-between;margin-bottom:16px;flex-wrap:wrap}
.v6220-search{min-width:260px;max-width:420px}
.v6220-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:14px}
.v6220-card{background:#fff;border:1px solid #e5e7eb;border-radius:18px;padding:16px;box-shadow:0 6px 20px rgba(0,0,0,.05)}
.v6220-card h3{margin:0 0 6px}.v6220-meta{font-size:13px;color:#6b7280;margin-bottom:10px}
.v6220-row{display:flex;justify-content:space-between;gap:8px;align-items:center;border-top:1px solid #f3f4f6;padding:8px 0}
.v6220-row code{background:#f8fafc;border:1px solid #e5e7eb;border-radius:8px;padding:5px 7px;max-width:170px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.v6220-actions{display:flex;gap:6px;flex-wrap:wrap;margin-top:12px}.v6220-primary{background:#111!important;color:#fff!important;font-weight:950!important}
.v6220-edit{background:#2563eb!important;color:#fff!important;font-weight:950!important}.v6220-copy{background:#f3f4f6!important;color:#111!important}
.v6220-modal{max-width:980px!important}.v6220-form-grid{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:12px}
@media(max-width:900px){.v6220-form-grid{grid-template-columns:1fr}.span-12,.span-8,.span-6,.span-4,.span-3{grid-column:span 1!important}}

/* ---------- V62.21 MAKE ADMIN FUNCTION ---------- */
.v6221-admin-box{background:#eef2ff;border:1px solid #c7d2fe;color:#312e81;border-radius:14px;padding:12px;font-weight:900;margin-top:12px}
.v6221-admin-warning{display:block;font-size:12px;color:#4338ca;margin-top:6px;font-weight:700}

/* ---------- V62.25 CALENDAR SILENT SYNC MONTH NAVIGATION ---------- */
.v6225-cal-nav{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  margin:12px 0 16px;
  padding:12px;
  background:#fff;
  border:1px solid #e5e7eb;
  border-radius:16px;
}
.v6225-cal-nav button{
  border:0;
  border-radius:12px;
  padding:10px 14px;
  font-weight:900;
  cursor:pointer;
}
.v6225-cal-nav .primary{background:#111;color:#fff}
.v6225-cal-nav .secondary{background:#f3f4f6;color:#111}
.v6225-cal-title{font-weight:950;font-size:18px;margin-right:auto}
.v6225-sync-pill{
  font-size:12px;
  background:#ecfdf5;
  color:#166534;
  border:1px solid #bbf7d0;
  border-radius:999px;
  padding:6px 10px;
  font-weight:800;
}

/* ---------- V62.27 USER ROLE SELECTOR ---------- */
.v6227-role-box{background:#f0f9ff;border:1px solid #7dd3fc;color:#075985;border-radius:14px;padding:14px;margin-top:12px;font-weight:900}
.v6227-role-box select{margin-top:8px;width:100%}
.v6227-role-help{display:block;font-size:12px;margin-top:6px;color:#0369a1;font-weight:700}

/* ---------- V62.35 SAFE CALENDAR RESTORE ---------- */
aside,.sidebar,nav{
  visibility:visible!important;
  opacity:1!important;
  pointer-events:auto!important;
}

/* ---------- V62.47 FIX REAL V582/V583 ---------- */
.v582-calendar-card .top input[type="month"].field{
  min-width:170px;
}

/* ---------- V62.48 CALENDAR BUTTONS FIX ---------- */
.v582-calendar-card .top input[type="month"].field{
  min-width:170px;
}

/* ---------- V62.49 CALENDAR BUTTONS USE PICKER ---------- */
#v6249MonthPicker{
  min-width:170px;
}
