/* Sistema de Gestión de Casos - Estilo profesional v2 */
:root{
  --primary:#0b3b75; --primary-2:#0f5aa6; --accent:#0097a7; --accent-2:#0fb9b1;
  --bg:#f4f7fb; --surface:#ffffff; --text:#14233b; --muted:#64748b; --border:#dbe5f1;
  --danger:#dc3545; --warning:#f59e0b; --success:#16a34a; --info:#0284c7; --purple:#7c3aed;
  --shadow:0 10px 28px rgba(15, 45, 90, .10); --radius:18px;
}
*{box-sizing:border-box} html{scroll-behavior:smooth} body{margin:0;font-family:Inter,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--text);font-size:15px;line-height:1.45}
a{color:var(--primary-2);text-decoration:none} a:hover{text-decoration:underline}
.app-shell{min-height:100vh;display:flex}.main-content{flex:1;padding:28px;max-width:100%;overflow-x:hidden}.sidebar{width:286px;min-height:100vh;background:linear-gradient(180deg,#082f63 0%,#0a3d78 52%,#08305f 100%);color:#fff;position:sticky;top:0;padding:22px 18px;box-shadow:8px 0 28px rgba(8,47,99,.18);z-index:10}.brand{display:flex;gap:12px;align-items:center;margin-bottom:24px;padding:10px;border-radius:16px;background:rgba(255,255,255,.08)}.brand-logo{width:46px;height:46px;border-radius:14px;background:#fff;display:grid;place-items:center;overflow:hidden;box-shadow:0 6px 15px rgba(0,0,0,.18)}.brand-logo img{width:100%;height:100%;object-fit:contain;padding:4px}.brand-icon{width:46px;height:46px;border-radius:14px;background:linear-gradient(135deg,var(--accent),#fff);display:grid;place-items:center;font-size:24px;color:#062a55}.brand strong{display:block;font-size:17px}.brand span{display:block;color:#b8d8ff;font-size:12px}.menu{display:flex;flex-direction:column;gap:8px}.menu a{color:#eaf5ff;padding:12px 14px;border-radius:12px;display:flex;align-items:center;gap:10px;font-weight:600}.menu a:hover,.menu a.active{background:rgba(255,255,255,.12);text-decoration:none}.menu .menu-section{margin:16px 10px 6px;color:#9ac8f4;font-size:11px;text-transform:uppercase;letter-spacing:.12em}.topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:24px;background:rgba(255,255,255,.84);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow)}.topbar small{display:block;color:var(--muted);margin-top:2px}.mobile-menu-btn{display:none;border:0;background:var(--primary);color:#fff;border-radius:12px;padding:10px 12px;font-weight:700}
.section-title{display:flex;align-items:center;justify-content:space-between;gap:16px;margin:0 0 18px}.section-title h1,.section-title h2{margin:0}.section-title h1{font-size:30px;letter-spacing:-.02em}.section-title h2{font-size:20px}.actions{display:flex;gap:8px;flex-wrap:wrap}.card,.stat,.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.card{padding:20px;margin-bottom:18px}.card h2,.card h3{margin-top:0}.stat{padding:22px;display:flex;align-items:center;justify-content:space-between;gap:14px;position:relative;overflow:hidden}.stat:before{content:"";position:absolute;inset:auto -30px -50px auto;width:120px;height:120px;border-radius:50%;background:rgba(0,151,167,.10)}.stat strong{font-size:34px;color:var(--primary)}.stat span{color:var(--muted);font-weight:700}.grid{display:grid;gap:18px}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}.grid-auto{grid-template-columns:repeat(auto-fit,minmax(230px,1fr))}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:12px;padding:10px 15px;background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff;font-weight:700;cursor:pointer;box-shadow:0 8px 16px rgba(15,90,166,.18)}.btn:hover{text-decoration:none;filter:brightness(1.05)}.btn-outline{background:#fff;color:var(--primary);border:1px solid var(--border);box-shadow:none}.btn-sm{padding:7px 10px;font-size:13px;border-radius:10px}.btn-danger{background:linear-gradient(135deg,#c81e1e,#ef4444)}.btn-success{background:linear-gradient(135deg,#138a42,#16a34a)}.btn-muted{background:#e2e8f0;color:#334155}.pill{display:inline-flex;padding:4px 10px;border-radius:999px;background:#eef6ff;color:var(--primary);font-size:12px;font-weight:700}.badge{display:inline-flex;align-items:center;padding:5px 10px;border-radius:999px;font-size:12px;font-weight:800}.badge-primary{background:#dbeafe;color:#1e40af}.badge-info{background:#e0f2fe;color:#0369a1}.badge-warning{background:#fef3c7;color:#92400e}.badge-success{background:#dcfce7;color:#166534}.badge-danger{background:#fee2e2;color:#991b1b}.badge-secondary{background:#e2e8f0;color:#334155}.badge-purple{background:#ede9fe;color:#5b21b6}.muted{color:var(--muted)}
.table-wrap{overflow:auto;border-radius:14px;border:1px solid var(--border)}.table{width:100%;border-collapse:separate;border-spacing:0}.table th{background:#f1f5f9;color:#334155;text-align:left;padding:12px;border-bottom:1px solid var(--border);font-size:13px;text-transform:uppercase;letter-spacing:.04em}.table td{padding:12px;border-bottom:1px solid #edf2f7;vertical-align:top}.table tr:last-child td{border-bottom:0}.table tr:hover td{background:#fbfdff}
.form-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:7px;font-weight:800;color:#334155}input,select,textarea{width:100%;border:1px solid #cfd9e8;background:#fff;border-radius:12px;padding:12px 13px;font:inherit;color:var(--text);outline:none}textarea{min-height:110px;resize:vertical}input:focus,select:focus,textarea:focus{border-color:var(--primary-2);box-shadow:0 0 0 4px rgba(15,90,166,.12)}.help{font-size:12px;color:var(--muted);margin-top:5px}.alert{padding:13px 15px;border-radius:14px;margin:0 0 16px;font-weight:600;border:1px solid}.alert-success{background:#ecfdf5;color:#166534;border-color:#bbf7d0}.alert-danger{background:#fef2f2;color:#991b1b;border-color:#fecaca}.alert-warning{background:#fffbeb;color:#92400e;border-color:#fde68a}.alert-info{background:#eff6ff;color:#1d4ed8;border-color:#bfdbfe}
.login-page{min-height:100vh;display:grid;place-items:center;padding:26px;background:radial-gradient(circle at top left,#d9f4ff 0,#f7fbff 32%,#eef4fb 100%)}.login-card{width:min(520px,100%);padding:28px}.login-card h1{margin-top:0;color:var(--primary)}.notice{background:#eef6ff;border-left:4px solid var(--primary-2);padding:10px;border-radius:10px;color:#334155}.timeline{border-left:3px solid #dbeafe;padding-left:18px}.timeline-item{position:relative;padding-bottom:16px}.timeline-item:before{content:"";position:absolute;left:-27px;top:4px;width:14px;height:14px;border-radius:50%;background:var(--primary-2);box-shadow:0 0 0 4px #dbeafe}.calendar{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}.calendar-day{min-height:118px;border:1px solid var(--border);border-radius:14px;background:#fff;padding:10px}.calendar-day.is-muted{background:#f8fafc;color:#94a3b8}.calendar-day strong{display:block;margin-bottom:8px}.event{display:block;background:#eef6ff;border-left:4px solid var(--primary-2);padding:6px;border-radius:8px;margin:4px 0;font-size:12px}.event.hearing{background:#fff7ed;border-left-color:#f97316}.finance-total{font-size:28px;color:var(--primary);font-weight:900}.logo-preview{max-width:180px;max-height:90px;border:1px solid var(--border);padding:8px;border-radius:12px;background:#fff}.codebox{background:#0f172a;color:#e2e8f0;border-radius:14px;padding:14px;overflow:auto;font-family:Consolas,monospace;font-size:13px}.no-print{}
@media(max-width:1100px){.grid-4{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(2,1fr)}.sidebar{width:250px}.main-content{padding:20px}}
@media(max-width:860px){.app-shell{display:block}.sidebar{position:fixed;left:-290px;top:0;height:100vh;transition:.25s;z-index:100}.sidebar.open{left:0}.main-content{padding:16px}.mobile-menu-btn{display:inline-flex}.topbar{position:sticky;top:8px;z-index:50}.section-title,.topbar{align-items:flex-start;flex-direction:column}.form-row,.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.calendar{grid-template-columns:1fr}.calendar-day{min-height:auto}.table th,.table td{white-space:nowrap}.login-card{padding:22px}}
@media print{.sidebar,.topbar,.no-print,.btn{display:none!important}.main-content{padding:0}.card{box-shadow:none;border:1px solid #ccc}.app-shell{display:block}body{background:#fff}}

/* Ajustes profesionales v3: formularios rápidos, asignación de casos y mejor vista móvil */
.inline-form{display:inline-flex;margin:0}.inline-status-form{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.inline-status-form select{min-width:140px;width:auto;padding:8px 10px;border-radius:10px}.inline-status-form input{min-width:150px;width:auto;padding:8px 10px;border-radius:10px}.case-assignment-list{display:grid;gap:10px;max-height:360px;overflow:auto;padding:4px}.case-assignment-item{display:flex;align-items:flex-start;gap:10px;padding:12px;border:1px solid var(--border);border-radius:14px;background:#fff}.case-assignment-item input{width:auto;margin-top:4px}.case-assignment-item small{color:var(--muted)}
@media(max-width:860px){.inline-status-form{display:grid;grid-template-columns:1fr;min-width:220px}.inline-status-form select,.inline-status-form input{width:100%;min-width:0}.actions .inline-form{width:100%}.actions .inline-form .btn{width:100%}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.main-content{padding-bottom:72px}.section-title .actions{width:100%}.section-title .actions .btn{flex:1;min-width:140px}.card{padding:16px}.stat strong{font-size:28px}.brand strong{font-size:15px}}
@media(max-width:520px){body{font-size:14px}.main-content{padding:12px}.topbar{padding:12px}.section-title h1{font-size:24px}.card{border-radius:14px}.table th,.table td{padding:10px 9px;font-size:13px}.form-row{gap:10px}.btn{width:100%}.actions{width:100%}.actions .btn{width:100%}.grid{gap:12px}}

/* Actualización V4: finanzas avanzadas y mejor desplazamiento móvil */
.report-filter .form-row{align-items:end}.finance-total{font-weight:800}.notice{background:#fff7ed;border:1px solid #fed7aa;border-radius:12px;padding:12px;color:#7c2d12}.actions{display:flex;flex-wrap:wrap;gap:8px}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.table{min-width:760px}.inline-status-form{min-width:420px}.btn-success{background:#16a34a;color:#fff}.btn-success:hover{background:#15803d}
@media (max-width: 900px){
  .layout{display:block}.sidebar{position:relative;width:100%;min-height:auto}.main{margin-left:0;padding:14px}.menu{display:grid;grid-template-columns:1fr 1fr;gap:6px}.menu-section{grid-column:1/-1}.grid,.grid-2,.grid-3,.grid-4{display:block}.card,.stat{margin-bottom:12px}.section-title{display:block}.section-title .actions{margin-top:10px}.form-row{display:block}.brand{margin-bottom:8px}.table{font-size:13px}.table th,.table td{padding:8px}.btn{width:auto;max-width:100%}
}
@media (max-width: 560px){
  .main{padding:10px}.menu{grid-template-columns:1fr}.card{padding:14px;border-radius:16px}.section-title h1{font-size:24px}.table{min-width:900px}.form-group input,.form-group select,.form-group textarea{font-size:16px}.actions .btn,.btn{display:inline-flex;margin-bottom:6px}.finance-total{font-size:20px}
}
