/* V23 Identidad Visual Pro - Opción Industrial */
:root{
  --oi-blue:#003b70;
  --oi-blue-dark:#071a2f;
  --oi-red:#c90000;
  --oi-cyan:#009db5;
  --oi-white:#ffffff;
  --oi-bg:#f4f7fb;
  --oi-card:#ffffff;
  --oi-border:#d8e0e8;
  --oi-text:#102033;
  --oi-muted:#64748b;
  --oi-shadow:0 14px 35px rgba(7,26,47,.10);
  --oi-radius:18px;
}
*{box-sizing:border-box}
body{margin:0;background:var(--oi-bg);font-family:Inter,Arial,Helvetica,sans-serif;color:var(--oi-text)}
.oi-app{min-height:100vh;display:grid;grid-template-columns:280px 1fr}
.oi-sidebar{background:linear-gradient(180deg,var(--oi-blue-dark),var(--oi-blue));color:#fff;padding:20px 16px;position:sticky;top:0;height:100vh;overflow:auto}
.oi-brand{display:flex;align-items:center;gap:12px;padding:10px 8px 22px;border-bottom:1px solid rgba(255,255,255,.14);margin-bottom:18px}
.oi-brand img{width:74px;height:auto;object-fit:contain;background:#fff;border-radius:14px;padding:6px}
.oi-brand-title{font-weight:900;line-height:1.05;font-size:18px;letter-spacing:.2px}
.oi-brand-sub{font-size:11px;opacity:.8;margin-top:4px}
.oi-menu{display:flex;flex-direction:column;gap:6px}
.oi-menu a{color:#dbeafe;text-decoration:none;padding:11px 12px;border-radius:12px;font-weight:700;font-size:14px;display:flex;align-items:center;gap:8px}
.oi-menu a:hover,.oi-menu a.active{background:rgba(255,255,255,.12);color:#fff}
.oi-main{min-width:0}
.oi-topbar{height:74px;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--oi-border);display:flex;align-items:center;justify-content:space-between;padding:0 28px;position:sticky;top:0;z-index:10}
.oi-page-title{font-size:20px;font-weight:900;color:var(--oi-blue-dark)}
.oi-user-pill{display:flex;align-items:center;gap:10px;background:#f8fafc;border:1px solid var(--oi-border);border-radius:999px;padding:8px 12px;font-weight:700}
.oi-content{padding:26px;max-width:1500px;margin:0 auto}
.card{background:var(--oi-card);border:1px solid var(--oi-border);border-radius:var(--oi-radius);box-shadow:var(--oi-shadow);padding:22px;margin-bottom:18px}
.card h1,.card h2,.card h3{color:var(--oi-blue-dark);margin-top:0}
h1{font-size:28px;letter-spacing:-.02em}
h2{font-size:20px}
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}
table{width:100%;border-collapse:separate;border-spacing:0;background:#fff;border-radius:16px;overflow:hidden;border:1px solid var(--oi-border);box-shadow:var(--oi-shadow);margin-bottom:18px}
th{background:linear-gradient(135deg,var(--oi-blue),var(--oi-blue-dark));color:#fff;text-align:left;padding:12px;font-size:13px;letter-spacing:.02em}
td{padding:12px;border-bottom:1px solid #e8eef5;font-size:14px}
tr:last-child td{border-bottom:0}
.btn,button.btn,a.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;text-decoration:none;border:0;border-radius:12px;padding:10px 14px;background:var(--oi-blue);color:#fff;font-weight:800;cursor:pointer;box-shadow:0 8px 18px rgba(0,59,112,.18);margin:2px}
.btn:hover{filter:brightness(1.05)}
.btn.green{background:#16a34a}.btn.gray{background:#64748b}.btn.yellow{background:#f59e0b;color:#111827}.btn.red{background:var(--oi-red)}
input,select,textarea{width:100%;border:1px solid #cbd5e1;border-radius:12px;padding:11px 12px;font-size:15px;background:#fff}
label{font-weight:800;color:var(--oi-blue-dark);display:block;margin:8px 0}
.alert,.toast{border-radius:14px;padding:12px 14px;font-weight:800;margin-bottom:12px}
.alert.green,.toast.success{background:#dcfce7;color:#166534}
.alert.red,.toast.danger{background:#fee2e2;color:#991b1b}
.badge{display:inline-block;border-radius:999px;padding:4px 10px;font-weight:800;font-size:12px}
.badge.red{background:#fee2e2;color:#991b1b}.badge.green{background:#dcfce7;color:#166534}.badge.yellow{background:#fef3c7;color:#92400e}
.kpi{font-size:34px;font-weight:950;color:var(--oi-blue);margin:8px 0}
.oi-doc-header{display:flex;align-items:center;justify-content:space-between;border-bottom:3px solid var(--oi-blue);padding-bottom:12px;margin-bottom:20px}
.oi-doc-header img{height:64px;max-width:280px;object-fit:contain}
.oi-doc-title{text-align:right;color:var(--oi-blue-dark)}
.oi-doc-title h1{font-size:20px;margin:0;color:var(--oi-red)}
.oi-watermark{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none;opacity:.035;z-index:0}
.oi-watermark img{width:65%;max-width:650px}
@media(max-width:980px){
  .oi-app{display:block}
  .oi-sidebar{height:auto;position:relative;border-radius:0 0 24px 24px}
  .oi-menu{display:grid;grid-template-columns:repeat(2,1fr)}
  .oi-topbar{height:62px;padding:0 16px}
  .oi-content{padding:16px}
}
@media print{
  .oi-sidebar,.oi-topbar,.btn,button{display:none!important}
  .oi-app{display:block}
  .oi-content{padding:0}
  body{background:#fff}
  .card,table{box-shadow:none;border-color:#111}
}

.ux-hero{background:linear-gradient(135deg,#ffffff,#eef7fb);border-top:5px solid var(--oi-red)}
.ux-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.ux-shortcuts{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:12px}
.ux-shortcuts a{display:block;text-decoration:none;background:#f8fafc;border:1px solid var(--oi-border);border-radius:14px;padding:16px;font-weight:900;color:var(--oi-blue-dark);box-shadow:0 8px 18px rgba(15,23,42,.05)}
.ux-shortcuts a:hover{background:#eef7fb;border-color:var(--oi-cyan)}
.ux-steps{line-height:1.8;font-weight:700}
.badge.red{background:#fee2e2;color:#991b1b}
.badge.yellow{background:#fef3c7;color:#92400e}
.badge.green{background:#dcfce7;color:#166534}


/* V28.1 Menu por secciones */
.oi-menu-sections{
    padding-bottom:28px;
}
.menu-section{
    margin:11px 10px 14px;
    padding:8px 7px 10px;
    border-radius:16px;
    background:rgba(255,255,255,.055);
    border:1px solid rgba(255,255,255,.08);
}
.menu-title{
    font-size:10px;
    letter-spacing:.11em;
    text-transform:uppercase;
    color:#9bd8ef;
    font-weight:900;
    margin:4px 7px 7px;
    opacity:.95;
}
.oi-menu-sections .menu-section a{
    margin:3px 0;
    padding:9px 10px;
    border-radius:12px;
    font-size:13px;
    line-height:1.15;
}
.oi-menu-sections .menu-section a:hover{
    background:rgba(0,157,181,.18);
    transform:translateX(2px);
}
.oi-sidebar{
    overflow-y:auto;
}
.oi-sidebar::-webkit-scrollbar{
    width:7px;
}
.oi-sidebar::-webkit-scrollbar-thumb{
    background:rgba(255,255,255,.22);
    border-radius:20px;
}
.oi-brand-sub{
    font-size:10.5px;
    opacity:.82;
}
@media(max-width:900px){
    .menu-section{margin:8px 8px 10px}
    .oi-menu-sections .menu-section a{font-size:12.5px;padding:8px 9px}
}



/* V28.6 Supervisor portal único responsive */
.supervisor-checklist{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(230px,1fr));
    gap:8px;
    max-height:340px;
    overflow:auto;
    border:1px solid var(--oi-border,#d8e0e8);
    border-radius:14px;
    padding:10px;
    background:#fff;
    margin:10px 0 16px;
}
.supervisor-checklist label{
    display:block;
    padding:10px;
    border-radius:10px;
    background:#f8fafc;
    font-weight:800;
}
.supervisor-form details{
    background:#f8fafc;
    border:1px solid var(--oi-border,#d8e0e8);
    border-radius:14px;
    padding:12px;
    margin:12px 0;
}
.supervisor-form summary{
    font-weight:900;
    color:var(--oi-blue,#003b70);
}
@media(max-width:900px){
    .oi-app{display:block}
    .oi-sidebar{position:relative;width:100%;height:auto}
    .oi-main{margin-left:0}
    .oi-content{padding:14px}
    .oi-topbar{position:sticky;top:0;z-index:5}
    table{font-size:12px}
    .supervisor-checklist{grid-template-columns:1fr;max-height:300px}
}


/* V29 accesos por usuario */
.access-section{border:1px solid var(--oi-border,#d8e0e8);border-radius:16px;padding:14px;margin:14px 0;background:#fff}
.access-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px}
.access-option{display:block;border:1px solid var(--oi-border,#d8e0e8);border-radius:14px;padding:12px;background:#f8fafc;font-weight:800}
.access-option small{display:block;color:#64748b;font-size:11px;margin-top:4px;font-weight:600}
.access-option input{margin-right:8px}

.access-section{border:1px solid var(--oi-border,#d8e0e8);border-radius:16px;padding:14px;margin:14px 0;background:#fff}
.access-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:10px}
.access-option{display:block;border:1px solid var(--oi-border,#d8e0e8);border-radius:14px;padding:12px;background:#f8fafc;font-weight:800;cursor:pointer}
.access-option:hover{border-color:var(--oi-cyan,#009db5);background:#eef7fb}
.access-option small{display:block;color:#64748b;font-size:11px;margin-top:4px;font-weight:600}
.access-option input{margin-right:8px}


/* =========================================================
   V31 REDISEÑO VISUAL PRO
   Dashboard ejecutivo, ficha 360 tabs, tablas modernas
   ========================================================= */
:root{
    --oi-blue:#003b70;
    --oi-blue-dark:#071a2f;
    --oi-red:#c90000;
    --oi-cyan:#009db5;
    --oi-bg:#f3f6fb;
    --oi-card:#ffffff;
    --oi-border:#d8e0e8;
    --oi-muted:#64748b;
    --oi-success:#16a34a;
    --oi-warning:#d97706;
    --oi-danger:#dc2626;
    --oi-shadow:0 16px 35px rgba(15,23,42,.10);
}
body{
    background:radial-gradient(circle at top left,#eef9fc 0,#f5f7fb 35%,#eef2f7 100%);
}
.oi-sidebar{
    background:linear-gradient(180deg,#071a2f 0%,#08233f 55%,#03101f 100%);
    box-shadow:10px 0 28px rgba(7,26,47,.22);
}
.oi-brand{
    border-bottom:1px solid rgba(255,255,255,.12);
    margin-bottom:8px;
}
.menu-section{
    background:rgba(255,255,255,.06)!important;
    border:1px solid rgba(255,255,255,.10)!important;
    backdrop-filter:blur(8px);
}
.menu-title{
    color:#8fe6ff!important;
}
.oi-menu a{
    transition:.18s ease;
}
.oi-menu a:hover{
    background:rgba(0,157,181,.22)!important;
    transform:translateX(3px);
}
.oi-topbar{
    background:rgba(255,255,255,.92);
    backdrop-filter:blur(10px);
    border-bottom:1px solid rgba(216,224,232,.8);
    box-shadow:0 6px 20px rgba(15,23,42,.06);
}
.card{
    border:1px solid rgba(216,224,232,.9)!important;
    border-radius:22px!important;
    box-shadow:0 10px 30px rgba(15,23,42,.07)!important;
}
.ux-hero{
    background:
        linear-gradient(135deg,rgba(255,255,255,.98),rgba(238,247,251,.98)),
        radial-gradient(circle at top right,rgba(0,157,181,.16),transparent 45%)!important;
    border-top:0!important;
    position:relative;
    overflow:hidden;
}
.ux-hero:before{
    content:"";
    position:absolute;
    inset:0 auto 0 0;
    width:7px;
    background:linear-gradient(180deg,var(--oi-red),var(--oi-cyan));
}
.ux-hero h1{
    font-size:30px;
    letter-spacing:-.03em;
    margin-bottom:4px;
}
.kpi{
    font-size:32px!important;
    letter-spacing:-.04em;
    color:var(--oi-blue-dark);
}
.oi-kpi-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(210px,1fr));
    gap:16px;
}
.oi-kpi-card{
    background:linear-gradient(135deg,#fff,#f8fbff);
    border:1px solid var(--oi-border);
    border-radius:22px;
    padding:18px;
    box-shadow:var(--oi-shadow);
    position:relative;
    overflow:hidden;
}
.oi-kpi-card:after{
    content:"";
    position:absolute;
    right:-25px;
    top:-25px;
    width:90px;
    height:90px;
    border-radius:50%;
    background:rgba(0,157,181,.10);
}
.oi-kpi-label{
    font-size:12px;
    text-transform:uppercase;
    letter-spacing:.08em;
    color:var(--oi-muted);
    font-weight:900;
}
.oi-kpi-value{
    font-size:32px;
    font-weight:950;
    color:var(--oi-blue-dark);
    margin-top:8px;
}
.oi-kpi-sub{
    color:var(--oi-muted);
    font-size:13px;
    font-weight:700;
}
.oi-command-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(190px,1fr));
    gap:14px;
}
.oi-command{
    display:block;
    text-decoration:none;
    color:var(--oi-blue-dark);
    background:#fff;
    border:1px solid var(--oi-border);
    border-radius:20px;
    padding:18px;
    box-shadow:0 12px 26px rgba(15,23,42,.06);
    font-weight:950;
}
.oi-command small{
    display:block;
    margin-top:5px;
    color:var(--oi-muted);
    font-weight:650;
}
.oi-command:hover{
    border-color:var(--oi-cyan);
    transform:translateY(-2px);
}
.oi-tabs{
    display:flex;
    gap:8px;
    flex-wrap:wrap;
    margin:14px 0 20px;
}
.oi-tab{
    border:1px solid var(--oi-border);
    border-radius:999px;
    padding:10px 15px;
    background:#fff;
    color:var(--oi-blue-dark);
    text-decoration:none;
    font-weight:900;
}
.oi-tab.active,.oi-tab:hover{
    background:var(--oi-blue);
    color:#fff;
    border-color:var(--oi-blue);
}
.oi-profile-card{
    display:grid;
    grid-template-columns:78px 1fr auto;
    gap:16px;
    align-items:center;
}
.oi-avatar{
    width:78px;height:78px;border-radius:22px;
    background:linear-gradient(135deg,var(--oi-blue),var(--oi-cyan));
    color:#fff;display:flex;align-items:center;justify-content:center;
    font-size:30px;font-weight:950;
    box-shadow:0 12px 24px rgba(0,59,112,.23);
}
.oi-profile-title{
    font-size:24px;
    font-weight:950;
    letter-spacing:-.025em;
}
.oi-profile-meta{
    display:flex;gap:8px;flex-wrap:wrap;margin-top:7px;
}
.oi-chip{
    display:inline-flex;
    align-items:center;
    gap:5px;
    border-radius:999px;
    background:#eef7fb;
    color:#075985;
    padding:6px 10px;
    font-size:12px;
    font-weight:850;
}
.table-toolbar{
    display:flex;gap:10px;align-items:center;justify-content:space-between;flex-wrap:wrap;margin-bottom:12px;
}
.table-search{
    max-width:340px;
    border:1px solid var(--oi-border);
    border-radius:14px;
    padding:10px 12px;
}
table{
    border-collapse:separate!important;
    border-spacing:0!important;
    overflow:hidden;
    border-radius:16px;
}
th{
    background:#f1f5f9!important;
    color:#0f172a;
    font-size:12px;
    letter-spacing:.04em;
    text-transform:uppercase;
}
td,th{
    border-bottom:1px solid #e5edf5!important;
}
tr:hover td{
    background:#f8fbff;
}
.empty-state{
    text-align:center;
    padding:38px 18px;
    background:#f8fafc;
    border:1px dashed var(--oi-border);
    border-radius:20px;
}
.empty-state h2{
    margin:0 0 8px;
}
.empty-state p{
    color:var(--oi-muted);
}
.supervisor-app-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
    gap:14px;
}
.supervisor-app-button{
    display:block;
    background:linear-gradient(135deg,#fff,#f8fbff);
    border:1px solid var(--oi-border);
    border-radius:24px;
    padding:22px;
    text-decoration:none;
    color:var(--oi-blue-dark);
    font-size:18px;
    font-weight:950;
    box-shadow:var(--oi-shadow);
}
.supervisor-app-button span{
    display:block;
    font-size:30px;
    margin-bottom:8px;
}
@media(max-width:900px){
    .oi-profile-card{grid-template-columns:60px 1fr}
    .oi-profile-actions{grid-column:1/-1}
    .oi-avatar{width:60px;height:60px;border-radius:18px}
    .oi-profile-title{font-size:20px}
    .ux-hero h1{font-size:24px}
    .oi-kpi-value{font-size:27px}
}

/* V34 FICHA360 COMPLETA */
.oi-tabs{gap:7px}
.oi-tab{font-size:13px;padding:9px 12px}
.oi-profile-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
@media(max-width:900px){.oi-tabs{overflow:auto;flex-wrap:nowrap;padding-bottom:6px}.oi-tab{white-space:nowrap}}

/* V34_1 DOTACION DOCS */
.badge.red{background:#fee2e2;color:#991b1b}.badge.yellow{background:#fef3c7;color:#92400e}.badge.green{background:#dcfce7;color:#166534}


/* V36 UX EMPRESARIAL PRO */
.oi-enterprise-ui{
    background:
      radial-gradient(circle at top left, rgba(0,157,181,.15), transparent 35%),
      linear-gradient(135deg,#f7f9fb 0%,#eef4f8 50%,#f9fbfd 100%);
}
.oi-global-commandbar{
    position:sticky;
    top:0;
    z-index:90;
    display:flex;
    gap:8px;
    justify-content:center;
    padding:8px;
    background:rgba(7,26,47,.92);
    backdrop-filter:blur(12px);
    box-shadow:0 10px 24px rgba(7,26,47,.18);
}
.oi-global-commandbar a{
    color:#fff;
    text-decoration:none;
    font-weight:800;
    font-size:13px;
    padding:8px 12px;
    border-radius:999px;
    background:rgba(255,255,255,.08);
}
.oi-global-commandbar a:hover{
    background:#009db5;
}
.oi-pro-hero{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:22px;
    padding:28px;
    border-radius:24px;
    background:
      linear-gradient(135deg,rgba(0,59,112,.98),rgba(7,26,47,.98)),
      radial-gradient(circle at top right,rgba(0,157,181,.35),transparent 40%);
    color:#fff;
    box-shadow:0 22px 48px rgba(7,26,47,.24);
    margin-bottom:18px;
}
.oi-pro-hero h1{
    margin:4px 0 8px;
    font-size:34px;
    letter-spacing:-.8px;
}
.oi-pro-hero p{
    margin:0;
    color:rgba(255,255,255,.82);
}
.oi-eyebrow{
    text-transform:uppercase;
    letter-spacing:.14em;
    color:#8ce9f4;
    font-size:12px;
    font-weight:900;
}
.oi-hero-actions{
    display:flex;
    gap:10px;
    flex-wrap:wrap;
    justify-content:flex-end;
}
.oi-kpi-grid-pro{
    grid-template-columns:repeat(auto-fit,minmax(210px,1fr));
}
.oi-click-card{
    text-decoration:none;
    color:inherit;
    transition:transform .18s ease, box-shadow .18s ease;
}
.oi-click-card:hover{
    transform:translateY(-3px);
    box-shadow:0 22px 42px rgba(0,59,112,.16);
}
.oi-dashboard-layout{
    display:grid;
    grid-template-columns:minmax(280px,.9fr) minmax(320px,1.1fr);
    gap:18px;
    margin:18px 0;
}
.oi-section-title{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:12px;
    margin-bottom:12px;
}
.oi-section-title h2{
    margin:0;
}
.oi-section-title a{
    color:#009db5;
    font-weight:900;
    text-decoration:none;
}
.oi-alert-list{
    display:flex;
    flex-direction:column;
    gap:10px;
}
.oi-alert{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:14px;
    padding:14px;
    border-radius:16px;
    text-decoration:none;
    border:1px solid rgba(216,224,232,.75);
    background:#fff;
    color:#071a2f;
}
.oi-alert small{
    display:block;
    color:#64748b;
    margin-top:3px;
}
.oi-alert span{
    font-weight:950;
    padding:6px 10px;
    border-radius:999px;
    background:#f1f5f9;
}
.oi-alert-danger{border-left:5px solid #c90000}
.oi-alert-warning{border-left:5px solid #f59e0b}
.oi-alert-info{border-left:5px solid #009db5}
.oi-alert-success{border-left:5px solid #16a34a}
.oi-quick-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(125px,1fr));
    gap:12px;
}
.oi-quick-grid-wide{
    grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
}
.oi-quick-action{
    display:flex;
    flex-direction:column;
    gap:6px;
    padding:16px;
    border-radius:18px;
    text-decoration:none;
    background:linear-gradient(180deg,#fff,#f8fafc);
    border:1px solid #e5eaf0;
    color:#071a2f;
    box-shadow:0 10px 22px rgba(7,26,47,.06);
}
.oi-quick-action span{
    font-size:25px;
}
.oi-quick-action b{
    font-size:14px;
}
.oi-quick-action small{
    color:#64748b;
}
.oi-quick-action:hover{
    border-color:#009db5;
    transform:translateY(-2px);
}
.oi-module-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
    gap:14px;
}
.oi-module-card{
    display:flex;
    gap:14px;
    align-items:flex-start;
    padding:18px;
    background:#fff;
    border:1px solid #e5eaf0;
    border-radius:20px;
    text-decoration:none;
    color:#071a2f;
    box-shadow:0 12px 28px rgba(7,26,47,.06);
}
.oi-module-card:hover{
    border-color:#009db5;
    box-shadow:0 20px 40px rgba(0,59,112,.12);
}
.oi-module-icon{
    display:grid;
    place-items:center;
    min-width:44px;
    height:44px;
    border-radius:16px;
    background:#eef7fa;
    font-size:24px;
}
.oi-module-card small{
    display:block;
    color:#64748b;
    margin-top:4px;
}
.oi-wizard-strip{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
    gap:12px;
    margin:18px 0;
}
.oi-wizard-strip a{
    padding:18px;
    border-radius:18px;
    background:linear-gradient(135deg,#003b70,#071a2f);
    color:#fff;
    text-decoration:none;
    box-shadow:0 18px 38px rgba(7,26,47,.18);
}
.oi-wizard-strip small{
    display:block;
    color:rgba(255,255,255,.75);
    margin-top:5px;
}
.oi-mobile-shell{
    max-width:560px;
    margin:0 auto;
    padding:14px;
}
.oi-mobile-header{
    display:flex;
    justify-content:space-between;
    align-items:center;
    color:#fff;
    background:linear-gradient(135deg,#003b70,#071a2f);
    border-radius:26px;
    padding:22px;
    box-shadow:0 20px 44px rgba(7,26,47,.2);
}
.oi-mobile-header h1{
    margin:3px 0 0;
}
.oi-mobile-header a{
    color:#fff;
    text-decoration:none;
    background:rgba(255,255,255,.12);
    padding:9px 12px;
    border-radius:999px;
    font-weight:800;
}
.oi-mobile-grid{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:14px;
    margin:16px 0;
}
.oi-mobile-tile{
    min-height:122px;
    display:flex;
    flex-direction:column;
    justify-content:center;
    gap:6px;
    padding:18px;
    border-radius:24px;
    background:#fff;
    color:#071a2f;
    text-decoration:none;
    box-shadow:0 12px 28px rgba(7,26,47,.08);
    border:1px solid #e5eaf0;
}
.oi-mobile-tile span{
    font-size:34px;
}
.oi-mobile-tile small{
    color:#64748b;
}
.oi-mobile-note{
    background:#fff;
    border-radius:22px;
    padding:18px;
    box-shadow:0 12px 28px rgba(7,26,47,.06);
}
.table-toolbar{
    position:sticky;
    top:50px;
    background:#fff;
    z-index:20;
    border-radius:16px;
    padding:10px;
}
table tr:hover td{
    background:#f8fbfd;
}
.badge.green,.badge.red,.badge.yellow{
    font-weight:900;
    border-radius:999px;
    padding:5px 10px;
}
@media(max-width:900px){
    .oi-pro-hero,.oi-dashboard-layout{
        grid-template-columns:1fr;
        flex-direction:column;
        align-items:flex-start;
    }
    .oi-global-commandbar{
        overflow:auto;
        justify-content:flex-start;
    }
}
@media(max-width:560px){
    .oi-mobile-grid{
        grid-template-columns:1fr;
    }
    .oi-pro-hero h1{
        font-size:26px;
    }
}
