:root{
    --bg:#eef3f8;
    --panel:#ffffff;
    --ink:#132235;
    --muted:#667085;
    --line:#e5eaf0;
    --primary:#1057d5;
    --primary2:#0b3d91;
    --success:#13a36b;
    --warning:#f59e0b;
    --danger:#e11d48;
    --dark:#0f172a;
    --shadow:0 18px 40px rgba(15,23,42,.10);
    --radius:24px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:var(--bg);color:var(--ink)}
a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}.hidden{display:none!important}
.app-header{position:sticky;top:0;z-index:20;background:linear-gradient(135deg,#081b3f,#1057d5 65%,#21b6a8);color:#fff;padding:18px clamp(16px,4vw,34px);display:flex;align-items:center;justify-content:space-between;gap:14px;box-shadow:0 12px 24px rgba(8,27,63,.22)}
.brand-block{display:flex;align-items:center;gap:12px}.brand-block strong{display:block;font-size:18px;letter-spacing:.2px}.brand-block span{display:block;font-size:12px;opacity:.82}.brand-mark{width:46px;height:46px;border-radius:16px;background:rgba(255,255,255,.18);display:grid;place-items:center;font-weight:900;letter-spacing:.5px;border:1px solid rgba(255,255,255,.22)}
.user-pill{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.18);border-radius:18px;padding:9px 12px;text-align:right;max-width:220px}.user-pill span{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:800;font-size:13px}.user-pill small{display:block;opacity:.82;font-size:11px}
.top-nav{display:flex;gap:8px;overflow-x:auto;padding:12px clamp(16px,4vw,34px);background:#fff;border-bottom:1px solid var(--line);position:sticky;top:82px;z-index:19}.top-nav a{white-space:nowrap;padding:10px 14px;border-radius:999px;color:#475467;font-weight:800;font-size:13px}.top-nav a.active,.top-nav a:hover{background:#eaf1ff;color:var(--primary)}
.app-main{max-width:1180px;margin:0 auto;padding:22px clamp(14px,4vw,32px) 92px}.page-title{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin:8px 0 20px}.page-title h1{font-size:clamp(26px,5vw,42px);line-height:1;margin:0;font-weight:900;letter-spacing:-.04em}.page-title p{margin:8px 0 0;color:var(--muted)}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}.soft-card{background:#f8fbff;border:1px solid #e7edf7;border-radius:22px;padding:16px}.grid{display:grid;gap:16px}.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))}
.stat-card{padding:18px;border-radius:24px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);position:relative;overflow:hidden}.stat-card:after{content:"";position:absolute;right:-24px;top:-24px;width:90px;height:90px;border-radius:50%;background:linear-gradient(135deg,rgba(16,87,213,.18),rgba(33,182,168,.14))}.stat-card small{display:block;color:var(--muted);font-weight:800;text-transform:uppercase;letter-spacing:.08em;font-size:11px}.stat-card strong{display:block;font-size:34px;line-height:1.1;margin-top:8px}.stat-card span{color:#667085;font-size:13px}
.tabs{display:flex;gap:8px;overflow-x:auto;margin-bottom:18px}.tabs a{padding:11px 14px;border-radius:999px;background:#fff;border:1px solid var(--line);font-weight:900;color:#475467;white-space:nowrap}.tabs a.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.job-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.job-card{background:#fff;border:1px solid var(--line);border-radius:26px;box-shadow:var(--shadow);padding:18px;display:flex;flex-direction:column;gap:14px}.job-card-top{display:flex;justify-content:space-between;gap:12px}.job-number{display:inline-flex;background:#eef4ff;color:#0b4cb9;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:900}.job-card h3{margin:10px 0 3px;font-size:20px;line-height:1.1}.job-card p{margin:0;color:#667085}.job-meta{display:flex;gap:8px;flex-wrap:wrap}.job-meta span,.priority{background:#f4f6f8;border:1px solid #e8edf2;border-radius:999px;padding:7px 10px;font-size:12px;font-weight:800;color:#475467}.job-address{border-left:4px solid #dbeafe;padding:10px 12px;background:#f8fbff;border-radius:14px;color:#344054;font-size:14px}.job-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:auto}
.btn{border:0;border-radius:16px;padding:12px 16px;font-weight:900;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:.16s;background:#eef2f6;color:#344054}.btn:hover{transform:translateY(-1px)}.btn.primary{background:var(--primary);color:#fff}.btn.success{background:var(--success);color:#fff}.btn.danger{background:var(--danger);color:#fff}.btn.warning{background:var(--warning);color:#111827}.btn.dark{background:var(--dark);color:#fff}.btn.ghost{background:#fff;color:#344054;border:1px solid var(--line)}.btn.full{width:100%}.btn.sm{padding:8px 12px;border-radius:12px;font-size:13px}
.status{display:inline-flex;align-items:center;border-radius:999px;padding:7px 11px;font-weight:900;font-size:12px;white-space:nowrap}.st-created{background:#e5e7eb;color:#374151}.st-process{background:#dbeafe;color:#1d4ed8}.st-attending{background:#e0f2fe;color:#0369a1}.st-paused{background:#fef3c7;color:#92400e}.st-reprogrammed{background:#ffedd5;color:#c2410c}.st-returned{background:#fee2e2;color:#b91c1c}.st-closing{background:#f3e8ff;color:#7e22ce}.st-finished{background:#dcfce7;color:#15803d}.st-cancelled,.st-expired{background:#ffe4e6;color:#be123c}.pr-urgent{background:#ffe4e6!important;color:#be123c!important}.pr-high{background:#ffedd5!important;color:#c2410c!important}.pr-medium{background:#fef3c7!important;color:#92400e!important}.pr-low{background:#e0f2fe!important;color:#0369a1!important}
.info-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.info-box{background:#f8fafc;border:1px solid #edf1f6;border-radius:18px;padding:14px}.info-box span{display:block;color:#667085;font-weight:900;text-transform:uppercase;font-size:11px;letter-spacing:.08em}.info-box strong{display:block;margin-top:5px;color:#111827;word-break:break-word}.section-title{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:24px 0 12px}.section-title h2{margin:0;font-size:20px}.section-title small{color:#667085}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.field label{display:block;font-weight:900;margin-bottom:7px;color:#344054}.field input,.field select,.field textarea{width:100%;border:1px solid #d9e2ec;border-radius:16px;background:#fff;padding:13px 14px;outline:none}.field textarea{min-height:110px;resize:vertical}.field input:focus,.field select:focus,.field textarea:focus{border-color:#79a9ff;box-shadow:0 0 0 4px rgba(16,87,213,.12)}
.photo-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.photo-card{border:1px solid var(--line);border-radius:18px;overflow:hidden;background:#fff}.photo-card img{width:100%;height:140px;object-fit:cover;display:block}.photo-card .caption{padding:9px 10px;font-size:12px;color:#667085}.file-card{padding:14px;border:1px solid var(--line);border-radius:18px;background:#fff}
.timeline{border-left:3px solid #dbeafe;margin-left:8px}.timeline-item{position:relative;padding:0 0 16px 18px}.timeline-item:before{content:"";position:absolute;left:-7px;top:4px;width:11px;height:11px;background:var(--primary);border-radius:50%}.timeline-item strong{display:block}.timeline-item small{color:#667085}.timeline-item p{margin:6px 0 0;color:#475467}
.alert{border-radius:18px;padding:14px 16px;margin-bottom:16px;font-weight:800}.alert.success{background:#dcfce7;color:#166534}.alert.error{background:#fee2e2;color:#991b1b}.alert.warning{background:#fef3c7;color:#92400e}.empty{background:#fff;border:1px dashed #cbd5e1;border-radius:24px;padding:34px;text-align:center;color:#667085}.empty strong{display:block;color:#344054;font-size:18px;margin-bottom:6px}
.login-shell{min-height:100vh;display:grid;place-items:center;padding:18px;background:linear-gradient(135deg,#081b3f,#1057d5 58%,#21b6a8)}.login-card{width:min(430px,100%);background:#fff;border-radius:30px;padding:30px;box-shadow:0 30px 70px rgba(0,0,0,.24)}.login-logo{width:72px;height:72px;border-radius:24px;background:linear-gradient(135deg,#1057d5,#21b6a8);display:grid;place-items:center;color:#fff;font-weight:1000;font-size:22px;margin-bottom:18px}.login-card h1{margin:0;font-size:34px;letter-spacing:-.04em}.login-card p{color:#667085;margin:8px 0 24px}.login-foot{text-align:center;color:rgba(255,255,255,.8);font-size:12px;margin-top:16px}
.vp-loader{position:fixed;inset:0;background:rgba(238,243,248,.82);backdrop-filter:blur(6px);z-index:99999;display:flex;align-items:center;justify-content:center;opacity:1;visibility:visible;pointer-events:auto;transition:opacity .24s ease,visibility .24s ease}.vp-loader.is-visible{display:flex!important;opacity:1!important;visibility:visible!important;pointer-events:auto!important}.vp-loader.hidden,.vp-loader.hidden.is-visible{display:none!important;opacity:0!important;visibility:hidden!important;pointer-events:none!important}.vp-loader-box{background:#fff;border:1px solid var(--line);border-radius:24px;padding:24px 34px;text-align:center;box-shadow:var(--shadow)}.vp-spinner{width:42px;height:42px;border-radius:50%;border:4px solid #dce6f2;border-top-color:var(--primary);animation:spin .9s linear infinite;margin:0 auto 10px}.vp-loader-box small{display:block;color:#667085;margin-top:3px}@keyframes spin{to{transform:rotate(360deg)}}
.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--line);display:none;z-index:30;box-shadow:0 -12px 26px rgba(15,23,42,.08)}.bottom-nav a{flex:1;padding:9px 4px 10px;text-align:center;color:#667085;font-weight:900;font-size:11px}.bottom-nav span{display:block;font-size:18px;line-height:1.1;color:var(--primary)}
@media(max-width:900px){.grid-4,.grid-3{grid-template-columns:repeat(2,minmax(0,1fr))}.job-list{grid-template-columns:1fr}.info-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.photo-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.top-nav{top:82px}}
@media(max-width:620px){.app-header{padding:14px 14px}.brand-mark{width:42px;height:42px}.user-pill{display:none}.top-nav{display:none}.app-main{padding:18px 14px 88px}.page-title{display:block}.grid-4,.grid-3,.grid-2,.form-grid,.info-grid{grid-template-columns:1fr}.photo-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.photo-card img{height:120px}.job-card{border-radius:22px;padding:15px}.job-card-top{display:block}.status{margin-top:10px}.bottom-nav{display:flex}.login-card{border-radius:26px;padding:24px}.btn{width:100%}.job-actions .btn{width:auto;flex:1}.section-title{display:block}}


.filter-card{margin-bottom:18px}.filter-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;align-items:end}.filter-actions{display:flex;gap:10px}.history-list{display:grid;gap:12px}.history-card{background:#fff;border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow);padding:16px;display:flex;justify-content:space-between;gap:14px;align-items:center}.history-main h3{margin:9px 0 3px;font-size:19px;line-height:1.12}.history-main p{margin:0 0 10px;color:#667085}.history-side{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}.pagination-wrap{display:flex;justify-content:center;align-items:center;gap:8px;margin:22px 0 0}.page-btn{min-width:42px;height:42px;border-radius:14px;border:1px solid var(--line);background:#fff;color:#344054;display:inline-flex;align-items:center;justify-content:center;font-weight:900;box-shadow:0 6px 14px rgba(15,23,42,.05)}.page-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.page-btn.disabled{opacity:.45;pointer-events:none}.page-btn:hover{transform:translateY(-1px)}
@media(max-width:720px){.filter-grid{grid-template-columns:1fr}.filter-actions{display:grid;grid-template-columns:1fr 1fr}.history-card{display:block}.history-side{margin-top:12px;justify-content:flex-start}.history-side .btn{width:auto}.bottom-nav a{font-size:10px}}


/* VisionPro - logo y acceso al inicio */
.brand-link{ text-decoration:none; color:inherit; }
.brand-link:hover{ color:inherit; opacity:.96; }
.brand-logo-wrap{ background:#ffffff!important; overflow:hidden; padding:5px; border:1px solid rgba(16,87,213,.12); }
.brand-logo-img{ width:100%; height:100%; object-fit:contain; display:block; }
.login-logo{ background:#ffffff!important; border:1px solid rgba(255,255,255,.65); box-shadow:0 18px 35px rgba(0,0,0,.18); padding:8px; overflow:hidden; }
.login-logo img{ width:100%; height:100%; object-fit:contain; display:block; }
@media(max-width:620px){
  .brand-logo-wrap{ width:42px; height:42px; }
}


/* =========================================================
   VisionPro - Logo adaptable con fondo transparente
   ========================================================= */
.brand-link{ text-decoration:none; color:inherit; }
.brand-link:hover{ color:inherit; opacity:.97; }

/* El contenedor ya no fuerza fondo ni tamaño cuadrado; se adapta al alto del header */
.brand-logo-wrap,
.brand-mark.brand-logo-wrap{
    width:auto!important;
    min-width:0!important;
    max-width:178px!important;
    height:46px!important;
    min-height:0!important;
    border-radius:0!important;
    background:transparent!important;
    border:0!important;
    box-shadow:none!important;
    padding:0!important;
    overflow:visible!important;
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
    flex:0 0 auto!important;
}

.brand-logo-img,
.brand-logo-wrap img{
    width:auto!important;
    height:auto!important;
    max-width:178px!important;
    max-height:46px!important;
    object-fit:contain!important;
    display:block!important;
    background:transparent!important;
}

/* Logo del login sin caja blanca, sin fondo y sin deformarse */
.login-logo{
    width:min(235px,72vw)!important;
    height:86px!important;
    border-radius:0!important;
    background:transparent!important;
    border:0!important;
    box-shadow:none!important;
    padding:0!important;
    margin:0 auto 18px auto!important;
    overflow:visible!important;
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
}

.login-logo img{
    width:auto!important;
    height:auto!important;
    max-width:100%!important;
    max-height:86px!important;
    object-fit:contain!important;
    display:block!important;
    background:transparent!important;
}

@media(max-width:620px){
    .brand-logo-wrap,
    .brand-mark.brand-logo-wrap{
        height:40px!important;
        max-width:138px!important;
    }
    .brand-logo-img,
    .brand-logo-wrap img{
        max-height:40px!important;
        max-width:138px!important;
    }
    .brand-block{ gap:10px!important; }
    .login-logo{
        width:min(210px,78vw)!important;
        height:76px!important;
    }
    .login-logo img{
        max-height:76px!important;
    }
}
