:root{
  --primary:#0f2742; --secondary:#1f6f9f; --accent:#00a6d6;
  --bg:#f3f6fa; --card:#ffffff; --text:#1f2937; --muted:#6b7280;
  --success:#16a34a; --danger:#dc2626; --border:#d9e2ec; --soft:#f8fafc;
  --warning:#f59e0b;
}
*{box-sizing:border-box}
body{margin:0;font-family:Arial,Helvetica,sans-serif;background:var(--bg);color:var(--text)}
a{text-decoration:none;color:inherit}
.layout{display:flex;min-height:100vh}
.sidebar{width:260px;background:var(--primary);color:#fff;padding:24px 18px}
.brand{font-size:22px;font-weight:800;letter-spacing:.5px;margin-bottom:6px}
.brand span{color:var(--accent)}
.subtitle{color:#b8c7d9;font-size:13px;margin-bottom:30px}
.menu a{display:block;color:#dbeafe;text-decoration:none;padding:13px 14px;border-radius:10px;margin-bottom:8px;font-size:15px}
.menu a.active,.menu a:hover{background:#17395f;color:#fff}
.main{flex:1;padding:24px}
.topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:22px}
.topbar h1{margin:0;font-size:26px;color:var(--primary)}
.client-box{background:var(--card);border:1px solid var(--border);padding:12px 16px;border-radius:12px;font-size:14px;color:var(--muted)}
.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:22px}
.kpi{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:18px;box-shadow:0 6px 16px rgba(15,39,66,.06)}
.kpi .label{font-size:13px;color:var(--muted)}
.kpi .value{font-size:30px;font-weight:800;margin-top:8px;color:var(--primary)}
.content{display:grid;grid-template-columns:1.15fr .85fr;gap:18px}
.card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:20px;box-shadow:0 6px 16px rgba(15,39,66,.06);margin-bottom:18px}
.card h2{margin:0 0 16px;color:var(--primary);font-size:20px}
label{display:block;font-weight:700;font-size:13px;margin-bottom:7px}
input,select,textarea{width:100%;padding:12px;border:1px solid var(--border);border-radius:10px;font-size:14px;outline:none;background:#fff}
input[readonly]{background:var(--soft);color:#475569}
textarea{resize:vertical;min-height:76px}
.row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.full{margin-bottom:14px}
.inline-row{display:grid;grid-template-columns:1fr 135px;gap:10px;align-items:start}
.small-muted{font-size:12px;color:var(--muted);margin-top:6px}
.container-box{border:1px solid var(--border);border-radius:14px;padding:14px;margin-bottom:14px;background:#fbfdff}
.container-title{font-weight:800;color:var(--primary);margin-bottom:12px}
.validation{font-size:12px;margin-top:6px;font-weight:700}.ok{color:var(--success)}.bad{color:var(--danger)}
.search-wrap{position:relative}
.suggestions{position:absolute;top:46px;left:0;right:145px;background:#fff;border:1px solid var(--border);border-radius:12px;box-shadow:0 12px 24px rgba(15,39,66,.12);overflow:hidden;z-index:10;display:none}
.suggestions button{width:100%;text-align:left;padding:12px;background:#fff;border:0;border-bottom:1px solid #edf2f7;cursor:pointer;font-size:14px}
.suggestions button:hover{background:#f1f5f9}
.selected-pill{display:inline-flex;align-items:center;gap:8px;padding:7px 10px;background:#e0f2fe;color:#075985;border-radius:999px;font-size:12px;font-weight:800;margin-top:8px}
.file-box{border:1px dashed var(--border);background:var(--soft);border-radius:14px;padding:14px;margin-bottom:14px}
.file-item{display:grid;grid-template-columns:1fr 42px;gap:10px;margin-top:10px}
.remove-file{border:1px solid var(--border);background:#fff;color:var(--danger);border-radius:10px;font-weight:900;cursor:pointer}
.btn{border:none;background:var(--secondary);color:#fff;padding:13px 18px;border-radius:12px;font-weight:800;cursor:pointer;width:100%;font-size:15px;display:inline-block;text-align:center}
.btn:hover{background:#185b82}
.btn-light{border:1px solid var(--border);background:#fff;color:var(--primary);padding:12px;border-radius:10px;font-weight:800;cursor:pointer;width:100%;font-size:14px}
.btn-danger{background:#dc2626}
table{width:100%;border-collapse:collapse;font-size:14px}
th,td{padding:12px 10px;border-bottom:1px solid var(--border);text-align:left;vertical-align:middle}
th{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.4px}
.badge{padding:6px 10px;border-radius:999px;font-weight:700;font-size:12px;display:inline-block;white-space:nowrap}
.b-programado{background:#e0f2fe;color:#0369a1}
.b-proceso{background:#fff7ed;color:#c2410c}
.b-terminado{background:#dcfce7;color:#166534}
.b-cancelado{background:#fee2e2;color:#991b1b}
.mini{padding:8px 10px;border-radius:9px;border:1px solid var(--border);background:#fff;cursor:pointer;font-weight:700;color:var(--primary)}
.note{margin-top:14px;font-size:13px;color:var(--muted);background:var(--soft);border:1px dashed var(--border);padding:12px;border-radius:12px}
.filter-box{margin-bottom:12px;display:grid;grid-template-columns:1fr;gap:8px}
.empty{text-align:center;color:var(--muted);padding:18px;background:var(--soft);border-radius:12px;margin-top:10px}
.alert{padding:12px 14px;border-radius:12px;margin-bottom:14px;font-weight:700}
.alert.ok{background:#dcfce7;color:#166534}
.alert.bad{background:#fee2e2;color:#991b1b}
.modal-backdrop{position:fixed;inset:0;background:rgba(15,39,66,.58);display:none;align-items:center;justify-content:center;padding:22px;z-index:50}
.modal{width:min(880px,100%);max-height:92vh;overflow:auto;background:#fff;border-radius:18px;box-shadow:0 24px 70px rgba(0,0,0,.25)}
.modal-header{display:flex;justify-content:space-between;align-items:center;padding:18px 20px;border-bottom:1px solid var(--border)}
.modal-header h3{margin:0;color:var(--primary);font-size:22px}
.close{border:0;background:#f1f5f9;border-radius:10px;width:38px;height:38px;font-size:22px;cursor:pointer;color:var(--primary)}
.modal-body{padding:20px}
.detail-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:18px}
.detail{background:var(--soft);border:1px solid var(--border);border-radius:12px;padding:12px}
.detail span{display:block;color:var(--muted);font-size:12px;margin-bottom:5px}
.detail strong{color:var(--primary);font-size:14px}
.section-title{font-weight:900;color:var(--primary);margin:18px 0 10px}
.file-list{display:grid;gap:8px}
.file-link{display:flex;justify-content:space-between;align-items:center;padding:12px;border:1px solid var(--border);border-radius:12px;background:var(--soft);font-size:14px}
.login{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,#061829,#0f2742,#1f6f9f)}
.login-card{width:min(430px,100%);background:white;border-radius:22px;padding:28px;box-shadow:0 25px 70px rgba(0,0,0,.25)}
.login-card h1{margin:0 0 8px;color:var(--primary)}
@media(max-width:900px){
  .layout{display:block}.sidebar{width:100%}.grid,.content,.row,.inline-row,.detail-grid{grid-template-columns:1fr}.topbar{display:block}.client-box{margin-top:12px}
  .suggestions{right:0} table{font-size:13px} th,td{padding:10px 7px}
}
