  /* ---- Paleta de color (tema claro). Cambia aquí para re-tematizar todo ---- */
  :root{
    --bg:#ffffff; --panel:#f6f7f9; --panel-2:#eceef1; --line:#dcdfe4;
    --ink:#1c2026; --muted:#6b7280; --accent:#e2231a; --accent-2:#b81a12;
    --ok:#2f9e44; --bad:#e2231a;
  }
  *{box-sizing:border-box}
  html,body{margin:0;height:100%;background:var(--bg);color:var(--ink);
    font-family:"Inter",system-ui,Segoe UI,Roboto,Arial,sans-serif;overflow:hidden}

  /* ---- Estructura: barra de contexto arriba + 3 columnas (selector | 3D | manual) ---- */
  #app{display:flex;flex-direction:column;height:100%}
  #ctxbar{display:flex;align-items:center;gap:12px;padding:8px 14px;background:var(--panel);
    border-bottom:1px solid var(--line);flex-wrap:wrap}
  #ctxbar .logo{width:104px;height:auto;margin:0;padding:0;background:none;border:none;border-radius:0}
  #ctxbar .logo-fallback{margin:0;font-size:15px}
  .ctx-field{display:flex;align-items:center;gap:6px}
  .ctx-field label{font-family:"Space Mono",monospace;font-size:9.5px;letter-spacing:.14em;
    text-transform:uppercase;color:var(--muted)}
  .ctx-field select{border:1px solid var(--line);border-radius:8px;padding:5px 8px;font-family:inherit;
    font-size:12.5px;background:#fff;color:var(--ink);max-width:240px}
  .ctx-field strong{font-family:"Space Mono",monospace;font-size:12.5px;color:var(--accent)}
  .spacer{flex:1}
  /* Segundo menú (opciones específicas del selector), bajo la barra superior */
  #selbar{display:flex;align-items:center;gap:10px;padding:7px 14px;background:var(--panel);
    border-bottom:1px solid var(--line);flex-wrap:wrap}
  #ctxbar .ctx-user{font-size:11px;color:var(--muted);white-space:nowrap}
  /* selector de idioma: compacto (anula la regla global select{width:100%}) */
  #ctxbar .lang-select{width:auto;min-width:0;margin:0;border:1px solid var(--line);border-radius:7px;
    padding:4px 6px;font-family:inherit;font-size:11.5px;background:#fff;color:var(--muted);cursor:pointer}
  /* Grupo de navegación principal (Clientes/Ofertas/Selector): pill segmentada con
     iconos Font Awesome, visualmente distinta de los botones de herramienta. */
  #ctxbar .ctx-nav{display:flex;gap:3px;background:var(--panel-2);border:1px solid var(--line);border-radius:11px;padding:3px}
  #ctxbar .ctx-nav .nav-btn{border:1px solid transparent;background:transparent;color:var(--ink);
    font-weight:600;padding:7px 13px;border-radius:8px;gap:7px}
  #ctxbar .ctx-nav .nav-btn:hover{background:#fff;border-color:var(--line)}
  #ctxbar .ctx-nav .nav-btn i{color:var(--accent);font-size:13px}

  /* Navegación por pantallas (clase en #app): se oculta el botón de la pantalla activa
     y el segundo menú #selbar solo se ve en la pantalla del selector. */
  #app.screen-selector #nav-selector{display:none}
  #app.screen-clientes #clientes-view{display:none}
  #app.screen-ofertas  #ofertas{display:none}
  #app.screen-usuarios #usuarios-view{display:none !important}   /* gana al style inline de rol */
  #app:not(.screen-selector) #selbar{display:none}
  #main{display:flex;flex:1;min-height:0}

  /* IZQUIERDA: selector (entrada principal) */
  #selpanel{width:360px;min-width:360px;height:100%;background:var(--panel);border-right:1px solid var(--line);
    display:flex;flex-direction:column;overflow:hidden}
  #selpanel[hidden]{display:none}

  /* DERECHA: parámetros manuales (modo avanzado, colapsable) */
  #panel{width:336px;min-width:336px;height:100%;background:var(--panel);
    border-left:1px solid var(--line);display:flex;flex-direction:column}
  #panel.collapsed{display:none}
  #panel header{padding:16px 20px 14px;border-bottom:1px solid var(--line)}
  #selpanel .sp-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--line)}
  #selpanel .sp-head h2{font-size:15px;margin:0}
  #selpanel .sp-head .kick{font-family:"Space Mono",monospace;font-size:10px;letter-spacing:.18em;color:var(--accent);text-transform:uppercase}
  #selpanel .sp-head .x{border:none;background:none;font-size:20px;line-height:1;cursor:pointer;color:var(--muted)}
  #selpanel .sp-body{flex:1;overflow:auto;padding:14px 18px}
  #selpanel .sp-grid{display:flex;gap:8px;margin-top:6px}
  #selpanel .sp-grid>div{flex:1}
  #selpanel label.sm{font-size:11px;color:var(--muted);display:block;margin-bottom:3px}
  #selpanel input.txt,#selpanel select.txt{width:100%;box-sizing:border-box;border:1px solid var(--line);border-radius:8px;padding:7px 9px;font-family:inherit;font-size:13px;background:#fff}
  #selpanel input.val-in{width:68px}   /* más ancho: cabe la capacidad (hasta 80000) */
  /* En pantallas estrechas, los paneles laterales flotan como cajones (no roban ancho al 3D) */
  @media (max-width:1180px){
    #panel{position:fixed;top:0;right:0;height:100%;z-index:30;box-shadow:-10px 0 30px rgba(20,24,32,.18)}
  }
  @media (max-width:900px){
    #selpanel{position:fixed;top:0;left:0;height:100%;z-index:29;box-shadow:10px 0 30px rgba(20,24,32,.18)}
  }
  @media (max-width:760px){ #selpanel{width:88vw;min-width:0} }

  /* ---- Logotipo (se carga desde la web de JASO; si falla, texto de respaldo) ---- */
  .logo{display:block;width:148px;height:auto;background:#fff;padding:9px 12px;border:1px solid var(--line);border-radius:7px;margin-bottom:13px}
  .logo-fallback{font-weight:800;font-size:20px;letter-spacing:.04em;color:var(--ink);margin-bottom:13px}
  .logo-fallback span{color:var(--accent);margin:0 4px}
  #panel header .kicker{font-family:"Space Mono",monospace;font-size:10px;letter-spacing:.22em;color:var(--accent);text-transform:uppercase}
  #panel header h1{margin:5px 0 0;font-size:18px;font-weight:650;letter-spacing:-.01em}
  #panel header p{margin:4px 0 0;font-size:11.5px;color:var(--muted);line-height:1.5}

  /* ---- Zona de controles (sliders, selects...) con scroll vertical ---- */
  #controls{flex:1;overflow-y:auto;padding:8px 20px 24px}
  #controls::-webkit-scrollbar{width:8px}
  #controls::-webkit-scrollbar-thumb{background:#cdd1d7;border-radius:8px}
  .group{margin-top:18px}
  .group > .g-title{font-family:"Space Mono",monospace;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:8px;margin-bottom:10px}
  .group > .g-title::after{content:"";flex:1;height:1px;background:var(--line)}

  /* ---- Un "campo" = etiqueta + valor + control ---- */
  .field{margin:11px 0}
  .field .row{display:flex;justify-content:space-between;align-items:baseline}
  .field label{font-size:12.5px;color:var(--ink)}
  .field .val{font-family:"Space Mono",monospace;font-size:12px;color:var(--accent)}
  input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:4px;margin:8px 0 0;background:var(--line);border-radius:4px;outline:none}
  input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:15px;height:15px;border-radius:50%;background:var(--accent);cursor:pointer;border:2px solid #fff;box-shadow:0 0 0 1px var(--accent)}
  input[type=range]::-moz-range-thumb{width:13px;height:13px;border-radius:50%;background:var(--accent);cursor:pointer;border:2px solid #fff}
  select{width:100%;margin-top:6px;background:var(--panel-2);color:var(--ink);border:1px solid var(--line);border-radius:8px;padding:8px 10px;font-family:inherit;font-size:12.5px;cursor:pointer}

  /* ---- Selector de opciones tipo "segmented control" (botones) ---- */
  .seg{display:flex;background:var(--panel-2);border:1px solid var(--line);border-radius:8px;padding:3px;margin-top:6px}
  .seg button{flex:1;border:0;background:transparent;color:var(--muted);font-size:12px;padding:7px 0;border-radius:6px;cursor:pointer;font-family:inherit}
  .seg button.on{background:var(--accent);color:#fff;font-weight:600}

  /* ---- Interruptor on/off (checkbox estilizado) ---- */
  .check{display:flex;align-items:center;gap:9px;margin:9px 0;cursor:pointer;font-size:12.5px}
  .check input{appearance:none;width:34px;height:19px;background:var(--line);border-radius:20px;position:relative;cursor:pointer;transition:.15s}
  .check input::after{content:"";position:absolute;width:15px;height:15px;border-radius:50%;background:#fff;top:2px;left:2px;transition:.15s}
  .check input:checked{background:var(--accent)}
  .check input:checked::after{left:17px}

  /* ---- Escena 3D + tarjetas flotantes (cotas y resultados) ---- */
  #stage{flex:1;position:relative}
  #c{display:block;width:100%;height:100%}
  .card{position:absolute;background:rgba(255,255,255,.9);border:1px solid var(--line);border-radius:10px;
    padding:11px 14px;backdrop-filter:blur(6px);box-shadow:0 4px 16px rgba(20,24,32,.08);
    font-family:"Space Mono",monospace;font-size:11.5px;line-height:1.7;color:var(--ink)}
  #readout{left:18px;bottom:16px}
  #calc{left:18px;top:18px;min-width:210px}
  #calc .t{color:var(--muted);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;margin-bottom:5px}
  .card b{color:var(--accent);font-weight:400}
  .card .lbl{color:var(--muted)}
  .pill{display:inline-block;padding:1px 7px;border-radius:20px;font-size:10px;margin-left:6px}
  .pill.ok{background:rgba(47,158,68,.16);color:var(--ok)}
  .pill.bad{background:rgba(226,35,26,.16);color:var(--bad)}
  #hint{position:absolute;right:18px;bottom:16px;font-size:11px;color:var(--muted);text-align:right;line-height:1.6;font-family:"Space Mono",monospace}
  /* etiquetas de cota vivas sobre el 3D */
  #cotas{position:absolute;inset:0;overflow:hidden;pointer-events:none}
  .cota{position:absolute;transform:translate(-50%,-50%);white-space:nowrap;font-family:"Space Mono",monospace;
    font-size:11px;color:var(--ink);background:rgba(255,255,255,.85);border:1px solid var(--line);
    border-radius:6px;padding:1px 6px;box-shadow:0 2px 6px rgba(20,24,32,.1)}
  .cota.bad{color:#fff;background:var(--accent);border-color:var(--accent)}
  .cota.comp{color:#1565c0;border-color:#9cc0ee}   /* etiqueta de componente (polipasto): azul */
  /* barra de presets (arriba del panel de controles) */
  .presets{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:4px}
  .presets .pchip{font-size:11px;padding:5px 9px;border:1px solid var(--line);border-radius:20px;background:var(--panel);
    color:var(--ink);cursor:pointer;font-family:inherit;transition:.12s}
  .presets .pchip:hover{border-color:var(--accent);color:var(--accent)}

  /* ---- Botones de vista (arriba dcha) y de exportación (pie del panel) ---- */
  #topbar{position:absolute;top:16px;right:18px;display:flex;gap:10px}
  .btn{border:1px solid var(--line);background:var(--panel);color:var(--ink);font-family:inherit;font-size:12.5px;padding:9px 14px;border-radius:9px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:7px;transition:.12s}
  .btn:hover{border-color:#c2c6cd;background:var(--panel-2)}
  .btn.primary{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600}
  /* Iconos en botones: rojos sobre fondo claro, blancos sobre el rojo (primary) */
  .btn i{color:var(--accent)}
  .btn.primary i{color:#fff}
  .btn.del i{color:var(--bad)}
  .btn.primary:hover{background:var(--accent-2);border-color:var(--accent-2)}
  #panel footer{padding:13px 18px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:8px}
  .frow{display:flex;gap:8px}
  .frow .btn{flex:1;padding:9px 6px}
  .frow #reset{flex:0 0 42px}
  /* --- Gestor de ofertas (modal) --- */
  .modal-bg{position:fixed;inset:0;background:rgba(20,24,30,.4);display:flex;align-items:center;justify-content:center;z-index:50}
  .modal{background:#fff;border:1px solid var(--line);border-radius:12px;width:460px;max-width:93vw;max-height:88vh;overflow:auto;padding:18px 18px 20px;box-shadow:0 18px 50px rgba(0,0,0,.25)}
  .modal .m-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
  .modal h2{font-size:15px;margin:0}
  .modal .m-head h2 i{color:var(--accent);margin-right:6px}   /* icono FA rojo en el título del modal */
  .modal .x{border:none;background:none;font-size:20px;line-height:1;cursor:pointer;color:var(--muted)}
  .modal label.sm{font-size:11px;color:var(--muted);display:block;margin:8px 0 3px}
  .modal input.txt,.modal select.txt,.modal textarea.txt{width:100%;box-sizing:border-box;border:1px solid var(--line);border-radius:8px;padding:8px 10px;font-family:inherit;font-size:13px;background:#fff}
  .of-list{margin-top:14px;border-top:1px solid var(--line);padding-top:10px}
  .of-empty{color:var(--muted);font-size:12px;padding:8px 0}
  .of-user{font-size:12px;color:var(--muted);background:var(--bg);border:1px solid var(--line);border-radius:8px;padding:7px 10px;margin-bottom:8px}
  .of-user b{color:var(--ink)}
  .of-user .links{display:block;margin-top:3px}
  .of-user .links a{color:var(--accent);cursor:pointer;text-decoration:none}
  .of-user .links a:hover{text-decoration:underline}
  .of-row{display:flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:9px;padding:8px 10px;margin-top:7px}
  .of-row .info{flex:1;min-width:0}
  .of-row .info .num{font-family:"Space Mono",monospace;color:var(--accent);font-size:12px}
  .of-row .info .meta{font-size:11px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .of-row .btn.mini{padding:5px 9px;font-size:11px}
  .of-row .btn.del{color:var(--bad);border-color:rgba(226,35,26,.4)}
  .of-row.clickable{cursor:pointer;transition:background .12s,border-color .12s}
  .of-row.clickable:hover{background:var(--panel-2);border-color:var(--accent)}
  .of-row.sel-on{background:rgba(226,35,26,.07)}
  .of-row.rec-on{border-color:var(--ok);box-shadow:0 0 0 1px var(--ok) inset}   /* polipasto recomendado: borde verde */
  /* chip de rol y filas del panel de usuarios (rol + responsable) */
  .rolechip{display:inline-block;background:var(--accent);color:#fff;border-radius:999px;
    padding:1px 8px;font-size:10px;text-transform:uppercase;letter-spacing:.04em;vertical-align:middle}
  /* chip de permiso de administrador: gris oscuro (estilo JASO), distinto del rol (rojo) */
  .rolechip.admin{background:var(--ink);color:#fff;margin-left:4px}
  .cv-item .nm .rolechip.admin{flex:0 0 auto;padding:1px 6px;min-width:0}
  .user-row{flex-wrap:wrap;row-gap:8px}
  .user-row .info{flex:1 1 100%}          /* nombre/fecha en su propia línea */
  .user-row .ucols{display:flex;flex-direction:column;gap:2px;flex:0 0 auto}
  .user-row .ucols label.sm{font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:.03em;margin:0}
  select.txt.mini{width:auto;padding:4px 6px;font-size:11px;border:1px solid var(--line);border-radius:7px;background:#fff;font-family:inherit}
  /* casilla numérica editable a mano (junto al slider) */
  .valwrap{display:flex;align-items:center;gap:3px}
  input.val-in{width:54px;text-align:right;border:1px solid var(--line);border-radius:6px;padding:2px 5px;
    font-family:"Space Mono",monospace;font-size:12px;color:var(--accent);background:#fff}
  input.val-in:focus{outline:none;border-color:var(--accent)}
  .valwrap .u{font-size:11px;color:var(--muted);min-width:14px}
  /* tabla de configuración de límites */
  .cfg-grp{margin-top:12px}
  .cfg-grp .gt{font-family:"Space Mono",monospace;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:4px}
  .cfg-row{display:grid;grid-template-columns:1fr 54px 52px 52px 48px;gap:5px;align-items:center;margin-top:5px}
  .cfg-row label{font-size:12px}
  .cfg-row input{width:100%;box-sizing:border-box;border:1px solid var(--line);border-radius:6px;padding:4px 5px;font-family:"Space Mono",monospace;font-size:11px}
  .cfg-head{display:grid;grid-template-columns:1fr 54px 52px 52px 48px;gap:5px;font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-top:6px}
  .cfg-row input[data-c="valor"]{border-color:var(--accent);color:var(--accent)}
  .frow #ofertas,.frow #config{flex:1}

  /* ============================================================================
     VISTA DEDICADA DE CLIENTES (pantalla completa: lista + ficha + ofertas)
     ============================================================================ */
  #main[hidden]{display:none}                               /* gana a #main{display:flex} */
  #clientesView,#ofertasView,#usuariosView{display:flex;flex-direction:column;flex:1;min-height:0;background:var(--bg)}
  #clientesView[hidden],#ofertasView[hidden],#usuariosView[hidden]{display:none}
  .cv-head{display:flex;align-items:center;gap:12px;padding:10px 16px;border-bottom:1px solid var(--line);background:var(--panel)}
  .cv-head h2{margin:0;font-size:16px;white-space:nowrap}
  /* iconos de cabecera de pantalla: rojos, iguales a los del menú de navegación */
  .cv-head h2 i,#selpanel .sp-head h2 i{color:var(--accent);margin-right:4px}
  .cv-head .cv-search{flex:1;max-width:340px;border:1px solid var(--line);border-radius:8px;padding:8px 11px;font-family:inherit;font-size:13px;background:#fff}
  .cv-head .spacer{flex:1}
  .cv-body{flex:1;display:flex;min-height:0}
  .cv-list{width:330px;min-width:280px;border-right:1px solid var(--line);overflow:auto;padding:10px;background:var(--panel)}
  .cv-list .cv-empty{color:var(--muted);font-size:12.5px;padding:14px 6px}
  .cv-item{border:1px solid var(--line);border-radius:9px;padding:9px 11px;margin-bottom:7px;cursor:pointer;background:#fff;transition:border-color .12s,box-shadow .12s}
  .cv-item:hover{border-color:var(--accent)}
  .cv-item.on{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent) inset}
  .cv-item .nm{font-weight:600;font-size:13.5px;display:flex;align-items:center;gap:6px}
  .cv-item .nm .tt{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .cv-item .cv-n{flex:0 0 auto;background:var(--accent);color:#fff;border-radius:999px;font-size:10px;
    font-weight:600;padding:1px 7px;min-width:18px;text-align:center}   /* nº de ofertas del cliente */
  .cv-item .sub{font-size:11.5px;color:var(--muted);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .cv-item .own{display:inline-block;font-size:9.5px;text-transform:uppercase;letter-spacing:.04em;color:var(--accent);margin-top:3px}
  .cv-detail{flex:1;overflow:auto;padding:18px 26px 40px}
  .cv-detail .cv-empty{color:var(--muted);font-size:13px;padding:60px 0;text-align:center}
  .cv-title{display:flex;align-items:center;justify-content:space-between;gap:10px}
  .cv-title h3{margin:0;font-size:18px;font-weight:650}
  .cv-sec{font-family:"Space Mono",monospace;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:8px;margin:20px 0 10px}
  .cv-sec::after{content:"";flex:1;height:1px;background:var(--line)}
  .cv-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:11px 16px}
  .cv-grid .f.full{grid-column:1 / -1}
  .cv-grid .f label{display:block;font-size:11px;color:var(--muted);margin-bottom:3px}
  .cv-grid .f input,.cv-grid .f select{width:100%;box-sizing:border-box;border:1px solid var(--line);border-radius:8px;padding:8px 10px;font-family:inherit;font-size:13px;background:#fff}
  .cv-grid .f input:focus,.cv-grid .f select:focus{outline:none;border-color:var(--accent)}
  .cv-actions{display:flex;gap:8px;margin-top:18px;flex-wrap:wrap}
  .cv-comercial{font-size:13px;color:var(--ink);background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:9px 12px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
  .cv-comercial b{color:var(--accent)}
  .cv-comercial .cv-rl{color:var(--muted)}
  .cv-comercial .cv-resel{border:1px solid var(--line);border-radius:7px;padding:5px 8px;font-family:inherit;font-size:13px;background:#fff;color:var(--accent);cursor:pointer}
  .cv-comercial .cv-since{color:var(--muted);font-size:11.5px}
  #clientesView .btn.del,#ofertasView .btn.del{color:var(--bad);border-color:rgba(226,35,26,.4)}
  /* ---- Selector múltiple de zonas (ficha de usuario): chips con casilla ---- */
  .zona-pick{display:flex;flex-wrap:wrap;gap:7px}
  .zona-pick.empty{color:var(--muted);font-size:12.5px;padding:4px 0}
  .zona-pick .zchip{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line);border-radius:999px;
    padding:5px 11px;font-size:12.5px;background:#fff;cursor:pointer;user-select:none}
  .zona-pick .zchip:has(input:checked){border-color:var(--accent);background:rgba(226,35,26,.07);color:var(--accent);font-weight:600}
  .zona-pick .zchip input{accent-color:var(--accent);margin:0}
  /* ---- Modal de gestión de zonas ---- */
  .zm-list{display:flex;flex-direction:column;gap:7px;margin:8px 0;max-height:46vh;overflow:auto}
  .zm-row{display:flex;align-items:center;gap:8px}
  .zm-row .zm-cod{flex:0 0 110px;font-weight:700;color:var(--accent);font-size:13px}
  .zm-row .zm-nm{flex:1;min-width:0}
  .btn.mini{padding:6px 9px;font-size:12px}
  .btn.mini.del{color:var(--bad);border-color:rgba(226,35,26,.4)}
  @media (max-width:820px){ .cv-grid{grid-template-columns:1fr} .cv-list{width:44vw;min-width:0} }

  /* ---- Vista de ofertas: sub-barra (filtros de estado + cuenta), chips de estado ---- */
  .ov-sub{display:flex;align-items:center;gap:12px;padding:7px 16px;border-bottom:1px solid var(--line);background:var(--panel);flex-wrap:wrap}
  .ov-filters{display:flex;gap:6px;flex-wrap:wrap}
  .ov-filters .fchip{font-size:11.5px;padding:4px 10px;border:1px solid var(--line);border-radius:20px;background:#fff;
    color:var(--muted);cursor:pointer;font-family:inherit;transition:.12s}
  .ov-filters .fchip:hover{border-color:var(--accent);color:var(--accent)}
  .ov-filters .fchip.on{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600}
  .ov-account{margin-left:auto;font-size:11.5px;color:var(--muted)}
  .ov-account b{color:var(--ink)} .ov-account a{color:var(--accent);cursor:pointer;text-decoration:none;margin-left:2px}
  .ov-account a:hover{text-decoration:underline}
  /* chip de estado (lista y detalle) */
  .est-chip{display:inline-block;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.03em;
    padding:2px 8px;border-radius:999px;border:1px solid transparent;white-space:nowrap}
  .est-pendiente{background:rgba(107,114,128,.14);color:#5b6472;border-color:rgba(107,114,128,.3)}
  .est-enviada{background:rgba(21,101,192,.12);color:#1565c0;border-color:rgba(21,101,192,.35)}
  .est-aceptada{background:rgba(47,158,68,.16);color:var(--ok);border-color:rgba(47,158,68,.4)}
  .est-rechazada{background:rgba(226,35,26,.13);color:var(--bad);border-color:rgba(226,35,26,.4)}
  .cv-item .est-chip{float:right;margin-left:6px}
  /* segmented de estado en el detalle */
  .est-seg{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}
  .est-seg button{border:1px solid var(--line);background:#fff;color:var(--muted);font-family:inherit;font-size:12px;
    padding:7px 12px;border-radius:8px;cursor:pointer;transition:.12s}
  .est-seg button:hover{border-color:var(--accent)}
  .est-seg button.on.est-pendiente{background:#5b6472;color:#fff;border-color:#5b6472}
  .est-seg button.on.est-enviada{background:#1565c0;color:#fff;border-color:#1565c0}
  .est-seg button.on.est-aceptada{background:var(--ok);color:#fff;border-color:var(--ok)}
  .est-seg button.on.est-rechazada{background:var(--bad);color:#fff;border-color:var(--bad)}
  .ov-meta{font-size:13px;color:var(--ink);line-height:1.9}
  .ov-meta .lbl{color:var(--muted);display:inline-block;min-width:130px}

  /* ---- Avisos propios (toasts) + diálogos mini + campo de contraseña con ojo ---- */
  #toasts{position:fixed;top:14px;right:14px;z-index:9999;display:flex;flex-direction:column;gap:8px;max-width:360px}
  .toast{display:flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line);border-left:4px solid var(--muted);
    border-radius:9px;padding:10px 13px;font-size:13px;color:var(--ink);box-shadow:0 8px 24px rgba(20,24,32,.16);
    opacity:0;transform:translateX(12px);transition:opacity .2s,transform .2s;cursor:pointer}
  .toast.show{opacity:1;transform:none}
  .toast i{font-size:15px;flex:0 0 auto}
  .toast.ok{border-left-color:var(--ok)} .toast.ok i{color:var(--ok)}
  .toast.error{border-left-color:var(--bad)} .toast.error i{color:var(--bad)}
  .toast.info{border-left-color:var(--muted)} .toast.info i{color:var(--muted)}
  .modal.mini{width:380px}
  .dlg-msg{margin:0;font-size:13.5px;color:var(--ink);line-height:1.5}
  .pw-wrap{position:relative;display:block}
  .pw-wrap input{width:100%;box-sizing:border-box;padding-right:38px}
  .pw-eye{position:absolute;right:6px;top:50%;transform:translateY(-50%);border:none;background:none;cursor:pointer;
    color:var(--muted);padding:4px 6px;font-size:13px;line-height:1}
  .pw-eye:hover{color:var(--accent)}
  /* campos de datos comerciales (y textarea de observaciones) en el detalle de oferta */
  .cv-detail .f label{display:block;font-size:11px;color:var(--muted);margin-bottom:3px}
  .cv-detail .f input,.cv-detail .f textarea{width:100%;box-sizing:border-box;border:1px solid var(--line);
    border-radius:8px;padding:8px 10px;font-family:inherit;font-size:13px;background:#fff;resize:vertical}
  .cv-detail .f input:focus,.cv-detail .f textarea:focus{outline:none;border-color:var(--accent)}
  .frow #config{flex:0 0 42px;font-size:15px}
