@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,600;1,300&family=Jost:wght@300;400;500;600;700&display=swap');

/* ── VARIABLES ─────────────────────────────────────────────── */
:root{
  --gold:#C9A84C; --gold-l:#E8C97A; --gold-d:#9A7A2E;
  --green:#0D1F0F; --green-m:#1A3A1E; --green-l:#2C5530;
  --cream:#F5F0E8; --bg:#F0EDE6; --card:#fff; --border:#E2D9C8;
  --text:#1C1C1C; --muted:#7A7060;
  --danger:#C0392B; --success:#27AE60; --warning:#E67E22; --info:#2980B9;
  --radius:10px; --shadow:0 4px 20px rgba(0,0,0,.08);
  --sw:240px; /* sidebar width */
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

html,body{
  height:100%;
  font-family:'Jost',sans-serif;
  background:var(--bg);
  color:var(--text);
}

/* ── SIDEBAR ────────────────────────────────────────────────── */
#sidebar{
  width:var(--sw);
  min-height:100vh;
  background:var(--green);
  border-right:1px solid rgba(201,168,76,.15);
  display:flex;
  flex-direction:column;
  position:fixed;
  left:0; top:0; bottom:0;
  z-index:200;
  box-shadow:4px 0 24px rgba(0,0,0,.28);
  overflow-y:auto;
  transition:transform .25s;
}
.sb-logo{
  padding:20px 18px 16px;
  border-bottom:1px solid rgba(201,168,76,.12);
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0;
}
.sb-logo img{height:46px;width:auto;object-fit:contain}
.sb-nav{flex:1;padding:10px 0;list-style:none}
.sb-section{
  padding:12px 18px 3px;
  font-size:.58rem; font-weight:700; letter-spacing:.18em;
  text-transform:uppercase; color:rgba(201,168,76,.38);
}
.sb-nav li a{
  display:flex; align-items:center; gap:10px;
  padding:9px 18px;
  color:rgba(245,240,232,.62);
  text-decoration:none;
  font-size:.82rem; font-weight:500;
  border-left:3px solid transparent;
  transition:all .18s;
}
.sb-nav li a i{width:16px;text-align:center;font-size:.85rem;opacity:.8}
.sb-nav li a:hover{background:rgba(201,168,76,.10);color:var(--gold-l);border-left-color:rgba(201,168,76,.35)}
.sb-nav li a.active{background:rgba(201,168,76,.14);color:var(--gold);border-left-color:var(--gold);font-weight:600}
.sb-nav li a.active i{opacity:1}
.sb-badge{
  display:inline-flex; align-items:center; justify-content:center;
  min-width:18px; height:18px; padding:0 5px; border-radius:9px;
  background:var(--danger); color:#fff; font-size:.63rem; font-weight:700;
  margin-left:auto;
}
.sb-user{border-top:1px solid rgba(201,168,76,.12);padding:12px 16px 14px;flex-shrink:0}
.sb-user-row{display:flex;align-items:center;gap:9px;margin-bottom:9px}
.sb-avatar{
  width:34px; height:34px; border-radius:50%;
  background:rgba(201,168,76,.12); border:1.5px solid rgba(201,168,76,.28);
  display:flex; align-items:center; justify-content:center;
  color:var(--gold); font-size:.72rem; font-weight:700; flex-shrink:0; letter-spacing:.04em;
}
.sb-user-name{font-size:.79rem;font-weight:600;color:var(--cream);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-rol{
  display:inline-flex; align-items:center; gap:4px; margin-top:2px;
  padding:2px 7px; border-radius:20px;
  font-size:.58rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase;
}
.rol-root{background:rgba(192,57,43,.25);color:#ff8a80;border:1px solid rgba(192,57,43,.4)}
.rol-admin{background:rgba(41,128,185,.25);color:#82c4f8;border:1px solid rgba(41,128,185,.4)}
.rol-tecnico{background:rgba(230,126,34,.22);color:#ffc07a;border:1px solid rgba(230,126,34,.4)}
.rol-area{background:rgba(39,174,96,.20);color:#7de3a8;border:1px solid rgba(39,174,96,.35)}
.sb-logout{
  width:100%; display:flex; align-items:center; justify-content:center; gap:7px;
  padding:7px; border-radius:7px;
  background:rgba(192,57,43,.16); border:1px solid rgba(192,57,43,.28);
  color:#ff8a80; font-family:'Jost',sans-serif; font-size:.73rem; font-weight:600;
  letter-spacing:.07em; text-transform:uppercase; cursor:pointer; transition:all .2s;
}
.sb-logout:hover{background:rgba(192,57,43,.34);color:#fff}

/* Hamburger (mobile) */
.sb-toggle{
  display:none; position:fixed; top:12px; left:12px; z-index:300;
  width:38px; height:38px; border-radius:8px;
  background:var(--green); border:1px solid rgba(201,168,76,.3);
  color:var(--gold); font-size:1rem; cursor:pointer;
  align-items:center; justify-content:center;
}
.sb-overlay{
  display:none; position:fixed; inset:0; background:rgba(0,0,0,.5);
  z-index:150;
}

/* ── MAIN CONTENT ───────────────────────────────────────────── */
#main-content{
  margin-left:var(--sw);
  flex:1;
  min-height:100vh;
  min-width:0;
  overflow-x:hidden;
}
.page-wrap{
  max-width:1280px;
  margin:0 auto;
  padding:26px 24px 40px;
}
.page-title{
  font-family:'Cormorant Garamond',serif;
  font-size:1.75rem; color:var(--green);
  margin-bottom:3px;
  display:flex; align-items:center; gap:9px;
}
.page-subtitle{color:var(--muted);font-size:.84rem;margin-bottom:22px}

/* ── CARDS ──────────────────────────────────────────────────── */
.card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:20px;
}
.card-header{
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:14px; gap:10px; flex-wrap:wrap;
}
.card-title{font-weight:600;font-size:.94rem}

/* ── STATS ──────────────────────────────────────────────────── */
.stats-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(150px,1fr));
  gap:12px;
  margin-bottom:20px;
}
.stat-card{
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--radius); padding:16px;
  display:flex; align-items:center; gap:12px; box-shadow:var(--shadow);
  min-width:0;
}
.stat-icon{
  width:44px; height:44px; border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  font-size:1.2rem; flex-shrink:0;
}
.si-gold{background:rgba(201,168,76,.12);color:var(--gold)}
.si-green{background:rgba(39,174,96,.12);color:var(--success)}
.si-red{background:rgba(192,57,43,.12);color:var(--danger)}
.si-orange{background:rgba(230,126,34,.12);color:var(--warning)}
.si-blue{background:rgba(41,128,185,.12);color:var(--info)}
.stat-val{font-size:1.6rem;font-weight:700;line-height:1}
.stat-lbl{font-size:.70rem;color:var(--muted);margin-top:2px}

/* ── BUTTONS ────────────────────────────────────────────────── */
.btn{
  display:inline-flex; align-items:center; gap:6px;
  padding:7px 14px; border-radius:7px; border:none;
  font-family:'Jost',sans-serif; font-size:.82rem; font-weight:600;
  cursor:pointer; transition:all .2s; text-decoration:none; white-space:nowrap;
  flex-shrink:0;
}
.btn-gold{background:var(--gold);color:var(--green)}.btn-gold:hover{background:var(--gold-l)}
.btn-green{background:var(--green);color:var(--cream)}.btn-green:hover{background:var(--green-m)}
.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#a93226}
.btn-info{background:var(--info);color:#fff}.btn-info:hover{background:#1a6fa0}
.btn-success{background:var(--success);color:#fff}.btn-success:hover{background:#1e8449}
.btn-warning{background:var(--warning);color:#fff}.btn-warning:hover{background:#ca6010}
.btn-outline{background:transparent;border:1.5px solid var(--border);color:var(--text)}.btn-outline:hover{border-color:var(--gold);color:var(--gold)}
.btn-sm{padding:5px 10px;font-size:.75rem}
.btn-xs{padding:3px 7px;font-size:.70rem}
.btn:disabled{opacity:.5;cursor:not-allowed}

/* ── TABLE ──────────────────────────────────────────────────── */
.table-wrap{overflow-x:auto;border-radius:var(--radius);width:100%}
table{width:100%;border-collapse:collapse;font-size:.83rem}
thead th{
  background:var(--green); color:var(--cream);
  padding:9px 12px; text-align:left;
  font-weight:600; letter-spacing:.04em; font-size:.72rem; text-transform:uppercase;
  white-space:nowrap;
}
thead th:first-child{border-radius:8px 0 0 0}
thead th:last-child{border-radius:0 8px 0 0}
tbody tr{border-bottom:1px solid var(--border);transition:background .14s}
tbody tr:hover{background:rgba(201,168,76,.05)}
tbody td{padding:8px 12px;vertical-align:middle}
.td-actions{display:flex;gap:4px;flex-wrap:nowrap}

/* ── BADGES ─────────────────────────────────────────────────── */
.badge{
  display:inline-flex; align-items:center; gap:3px;
  padding:2px 8px; border-radius:20px;
  font-size:.68rem; font-weight:600; letter-spacing:.03em; white-space:nowrap;
}
.b-green{background:rgba(39,174,96,.13);color:#1e8449}
.b-orange{background:rgba(230,126,34,.13);color:#b7570e}
.b-red{background:rgba(192,57,43,.13);color:#a93226}
.b-blue{background:rgba(41,128,185,.13);color:#1a5276}
.b-gray{background:rgba(0,0,0,.07);color:#555}
.b-gold{background:rgba(201,168,76,.15);color:#7a5c10}
.b-purple{background:rgba(142,68,173,.12);color:#6c3483}

/* ── MODAL ──────────────────────────────────────────────────── */
.modal-overlay{
  display:none; position:fixed; inset:0;
  background:rgba(0,0,0,.55); z-index:1000;
  align-items:center; justify-content:center; padding:16px;
  overflow-y:auto;
}
.modal-overlay.open{display:flex}
.modal{
  background:var(--card); border-radius:14px; padding:26px;
  max-width:560px; width:100%;
  box-shadow:0 24px 60px rgba(0,0,0,.25);
  animation:mIn .22s cubic-bezier(.16,1,.3,1);
  max-height:90vh; overflow-y:auto;
  margin:auto;
}
.modal-lg{max-width:800px}
.modal-xl{max-width:960px}
.modal-sm{max-width:400px}
@keyframes mIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.modal-title{
  font-family:'Cormorant Garamond',serif;
  font-size:1.3rem; margin-bottom:16px; color:var(--green);
  display:flex; align-items:center; gap:8px;
}
.modal-footer{display:flex;gap:8px;justify-content:flex-end;margin-top:20px;flex-wrap:wrap}

/* ── FORM ───────────────────────────────────────────────────── */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.fg-full{grid-column:1/-1}
.form-group{display:flex;flex-direction:column;gap:4px}
label{font-size:.72rem;font-weight:600;color:var(--muted);letter-spacing:.06em;text-transform:uppercase}
input,select,textarea{
  padding:8px 10px; border:1.5px solid var(--border); border-radius:7px;
  font-family:'Jost',sans-serif; font-size:.85rem; color:var(--text);
  background:#faf9f7; transition:border-color .2s,box-shadow .2s; outline:none;
  width:100%;
}
input:focus,select:focus,textarea:focus{
  border-color:var(--gold); box-shadow:0 0 0 3px rgba(201,168,76,.10);
}
textarea{resize:vertical;min-height:70px}

/* ── SEARCH BAR ─────────────────────────────────────────────── */
.search-bar{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:12px}
.si-wrap{position:relative;flex:1;min-width:160px}
.si-wrap i{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--muted);font-size:.80rem;pointer-events:none}
.si-wrap input{padding-left:30px}

/* ── FILTROS ROW ────────────────────────────────────────────── */
.filtros-row{
  display:flex; gap:8px; flex-wrap:wrap;
  align-items:flex-end; margin-bottom:12px;
}
.filtros-row .si-wrap{min-width:180px;flex:2}
.filtros-row select{flex:1;min-width:130px}
.filtros-row .btn{flex-shrink:0}

/* ── TABS ───────────────────────────────────────────────────── */
.tabs{display:flex;gap:1px;border-bottom:2px solid var(--border);margin-bottom:16px;flex-wrap:wrap}
.tab-btn{
  padding:8px 16px; border:none; background:none;
  font-family:'Jost',sans-serif; font-size:.82rem; font-weight:500;
  color:var(--muted); cursor:pointer;
  border-bottom:2px solid transparent; margin-bottom:-2px;
  transition:all .18s; white-space:nowrap;
}
.tab-btn.active{color:var(--green);border-bottom-color:var(--gold);font-weight:600}
.tab-panel{display:none}.tab-panel.active{display:block}

/* ── KANBAN ─────────────────────────────────────────────────── */
.kanban{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.kanban-col{background:#f7f5f0;border-radius:var(--radius);padding:12px}
.kanban-col-header{
  font-size:.75rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase;
  margin-bottom:10px; display:flex; align-items:center; justify-content:space-between;
}
.kanban-card{
  background:var(--card); border:1px solid var(--border); border-radius:8px;
  padding:11px; margin-bottom:8px; cursor:pointer; transition:box-shadow .15s;
}
.kanban-card:hover{box-shadow:0 4px 14px rgba(0,0,0,.10)}
.kanban-card-title{font-size:.80rem;font-weight:600;margin-bottom:3px;line-height:1.3}
.kanban-card-sub{font-size:.72rem;color:var(--muted)}

/* ── PAGINACIÓN ─────────────────────────────────────────────── */
.pag-wrap{display:flex;align-items:center;justify-content:center;gap:4px;padding:12px 0 2px;flex-wrap:wrap}

/* ── BITÁCORA ───────────────────────────────────────────────── */
.bitacora-item{display:flex;gap:11px;padding:11px 0;border-bottom:1px solid var(--border)}
.bitacora-item:last-child{border-bottom:none}
.bitacora-avatar{
  width:32px; height:32px; border-radius:50%;
  background:var(--green); color:var(--gold);
  display:flex; align-items:center; justify-content:center;
  font-size:.68rem; font-weight:700; flex-shrink:0;
}
.bitacora-body{flex:1;min-width:0}
.bitacora-header{display:flex;align-items:center;gap:7px;flex-wrap:wrap;margin-bottom:3px}
.bitacora-autor{font-size:.80rem;font-weight:600}
.bitacora-tiempo{font-size:.70rem;color:var(--muted)}
.bitacora-tipo{font-size:.63rem;padding:1px 6px;border-radius:20px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}
.btype-comentario{background:rgba(41,128,185,.1);color:var(--info)}
.btype-estado{background:rgba(230,126,34,.1);color:var(--warning)}
.btype-sistema{background:rgba(0,0,0,.06);color:var(--muted)}
.btype-confirmacion{background:rgba(39,174,96,.12);color:var(--success)}
.bitacora-texto{font-size:.83rem;color:var(--text);line-height:1.5}

/* ── ADJUNTOS ───────────────────────────────────────────────── */
.adjunto-item{
  display:flex; align-items:center; gap:9px;
  padding:8px 11px; border:1px solid var(--border);
  border-radius:8px; background:#faf9f7; margin-bottom:7px;
}
.adjunto-ico{
  width:32px; height:32px; border-radius:7px;
  display:flex; align-items:center; justify-content:center;
  font-size:.95rem; flex-shrink:0;
}
.adjunto-ico-img{background:rgba(39,174,96,.12);color:var(--success)}
.adjunto-ico-doc{background:rgba(41,128,185,.12);color:var(--info)}
.adjunto-ico-pdf{background:rgba(192,57,43,.12);color:var(--danger)}
.adjunto-ico-other{background:rgba(0,0,0,.06);color:var(--muted)}
.adjunto-nombre{font-size:.80rem;font-weight:600;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.adjunto-meta{font-size:.70rem;color:var(--muted);white-space:nowrap}
.upload-area{
  border:2px dashed var(--border); border-radius:9px;
  padding:22px; text-align:center; cursor:pointer;
  transition:border-color .2s,background .2s; margin-bottom:10px;
}
.upload-area:hover,.upload-area.drag-over{border-color:var(--gold);background:rgba(201,168,76,.04)}
.upload-area i{font-size:1.5rem;color:var(--border);display:block;margin-bottom:7px}
.upload-area p{font-size:.80rem;color:var(--muted);margin:0}
.upload-area input{display:none}

/* ── DETALLE ORDEN ──────────────────────────────────────────── */
.detalle-section{margin-bottom:20px}
.detalle-section-title{
  font-size:.68rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase;
  color:var(--muted); margin-bottom:9px; padding-bottom:5px;
  border-bottom:1px solid var(--border); display:flex; align-items:center; gap:6px;
}
.detalle-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:9px}
.detalle-field{display:flex;flex-direction:column;gap:2px}
.detalle-label{font-size:.66rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.detalle-value{font-size:.85rem;font-weight:500;color:var(--text)}

/* ── NOTIFICACIONES ─────────────────────────────────────────── */
.notif-item{
  display:flex; gap:12px; align-items:flex-start;
  padding:13px; border-bottom:1px solid var(--border); transition:background .14s;
  cursor:pointer;
}
.notif-item:hover{background:#faf8f4}
.notif-item.unread{background:rgba(201,168,76,.05)}
.notif-title{font-size:.83rem;font-weight:600;margin-bottom:2px}
.notif-sub{font-size:.76rem;color:var(--muted)}
.notif-time{font-size:.68rem;color:var(--muted);margin-top:3px}

/* ── CHART BOX ──────────────────────────────────────────────── */
.chart-box{
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--radius); padding:18px; box-shadow:var(--shadow);
}
.chart-title{font-size:.84rem;font-weight:600;margin-bottom:12px}

/* ── TOAST ──────────────────────────────────────────────────── */
#toast{position:fixed;bottom:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:7px;max-width:320px}
.toast-msg{
  background:var(--green); color:var(--cream);
  padding:10px 16px; border-radius:8px; font-size:.82rem;
  box-shadow:0 8px 24px rgba(0,0,0,.25);
  display:flex; align-items:center; gap:8px;
  animation:tIn .3s ease; border-left:4px solid var(--gold);
}
.toast-msg.error{background:var(--danger);border-color:#ff6b6b}
.toast-msg.success{background:#145a32;border-color:var(--success)}
.toast-msg.warning{background:#7d4e00;border-color:var(--warning)}
.toast-msg.info{background:#0d3a5c;border-color:var(--info)}
@keyframes tIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}

/* ── EMPTY STATE ────────────────────────────────────────────── */
.empty-state{text-align:center;padding:44px 24px;color:var(--muted)}
.empty-state i{font-size:2.2rem;color:var(--border);display:block;margin-bottom:12px}
.empty-state h3{font-family:'Cormorant Garamond',serif;font-size:1.2rem;color:var(--green);font-weight:400;margin-bottom:6px}
.empty-state p{font-size:.83rem;max-width:320px;margin:0 auto 16px;line-height:1.6}

/* ── TIMELINE (confirmaciones) ──────────────────────────────── */
.timeline{position:relative;padding-left:28px}
.timeline::before{content:'';position:absolute;left:10px;top:6px;bottom:6px;width:2px;background:var(--border)}
.tl-item{position:relative;margin-bottom:18px}
.tl-dot{
  position:absolute;left:-22px;top:3px;
  width:14px;height:14px;border-radius:50%;
  border:2px solid var(--border);background:var(--card);
  display:flex;align-items:center;justify-content:center;font-size:.5rem;
}
.tl-dot.done{border-color:var(--success);background:var(--success);color:#fff}
.tl-dot.active{border-color:var(--gold);background:var(--gold);color:var(--green)}
.tl-dot.pending{border-color:var(--border);background:var(--card);color:var(--muted)}
.tl-content{font-size:.83rem}
.tl-title{font-weight:600;margin-bottom:2px}
.tl-meta{font-size:.72rem;color:var(--muted)}

/* ── SOLICITUD CARD (vista usuario de área) ─────────────────── */
.solicitud-card{
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--radius); padding:16px; margin-bottom:10px;
  box-shadow:var(--shadow); cursor:pointer; transition:box-shadow .15s,border-color .15s;
}
.solicitud-card:hover{box-shadow:0 8px 28px rgba(0,0,0,.12);border-color:var(--gold)}
.solicitud-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:10px}
.solicitud-card-folio{font-family:monospace;font-size:.78rem;background:#f3f0ea;padding:2px 8px;border-radius:4px;font-weight:600}
.solicitud-card-title{font-weight:600;font-size:.9rem;margin-bottom:4px}
.solicitud-card-meta{font-size:.76rem;color:var(--muted);display:flex;gap:12px;flex-wrap:wrap}

/* ── CONFIRMAR LLEGADA/SALIDA ───────────────────────────────── */
.confirm-btn{
  display:flex;align-items:center;gap:8px;
  padding:10px 18px;border-radius:8px;border:none;
  font-family:'Jost',sans-serif;font-size:.84rem;font-weight:600;
  cursor:pointer;transition:all .2s;width:100%;justify-content:center;
  margin-bottom:8px;
}
.confirm-llegada{background:rgba(39,174,96,.12);border:1.5px solid var(--success);color:var(--success)}
.confirm-llegada:hover{background:var(--success);color:#fff}
.confirm-llegada:disabled{opacity:.5;cursor:default}
.confirm-salida{background:rgba(192,57,43,.1);border:1.5px solid var(--danger);color:var(--danger)}
.confirm-salida:hover{background:var(--danger);color:#fff}
.confirm-salida:disabled{opacity:.5;cursor:default}

/* ── RESPONSIVE ─────────────────────────────────────────────── */
@media(max-width:1024px){
  :root{--sw:220px}
  .page-wrap{padding:20px 18px 30px}
}

@media(max-width:768px){
  :root{--sw:0px}
  #sidebar{transform:translateX(-100%);width:240px}
  #sidebar.open{transform:translateX(0)}
  .sb-toggle{display:flex}
  .sb-overlay.open{display:block}
  #main-content{margin-left:0}
  .page-wrap{padding:16px 14px 28px;padding-top:58px}
  .form-grid{grid-template-columns:1fr}
  .fg-full{grid-column:1/-1}
  .kanban{grid-template-columns:1fr}
  .filtros-row{flex-direction:column}
  .filtros-row .si-wrap,.filtros-row select{min-width:0;width:100%}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  table{font-size:.76rem}
  thead th,tbody td{padding:7px 8px}
  .detalle-grid{grid-template-columns:1fr}
}

@media(max-width:480px){
  .stats-grid{grid-template-columns:1fr 1fr}
  .modal{padding:18px}
  .card{padding:14px}
}
