:root{
  --bg:#eef3fb;
  --card:#f4f7fc;
  --card-2:#ffffff;
  --text:#10264c;
  --muted:#6b7a96;
  --primary:#0d57d9;
  --primary-2:#2cb34a;
  --danger:#d9534f;
  --line:#dce5f2;
  --shadow: 12px 12px 24px rgba(168,184,210,.45), -12px -12px 24px rgba(255,255,255,.95);
  --inset: inset 8px 8px 14px rgba(197,208,227,.45), inset -8px -8px 14px rgba(255,255,255,.95);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;min-height:100%;font-family:Inter,Segoe UI,Arial,sans-serif;background:linear-gradient(180deg,#f8fbff 0%, #edf3fa 100%);color:var(--text)}
a{color:var(--primary);text-decoration:none}
.hidden{display:none !important}

.app-shell{display:flex;min-height:100vh}
.sidebar{width:270px;background:#02142f;padding:22px 18px;display:flex;flex-direction:column;justify-content:space-between;color:#fff;position:sticky;top:0;height:100vh}
.brand-box{padding:10px 8px 22px}.brand-logo{max-width:180px;width:100%;display:block}
.side-nav{display:flex;flex-direction:column;gap:10px}
.side-link{border:0;display:block;width:100%;text-align:left;padding:14px 16px;border-radius:16px;background:rgba(255,255,255,.06);color:#fff;font-weight:700;cursor:pointer}
.side-link.active,.side-link:hover{background:linear-gradient(90deg,#085fe0,#19b0ff)}
.logout-link{background:rgba(255,255,255,.08)}
.sidebar-footer{padding:16px 10px;border-top:1px solid rgba(255,255,255,.12)}
.user-chip{font-weight:800}.user-role{font-size:12px;color:rgba(255,255,255,.7);margin-top:4px}

.main-area{flex:1;padding:26px 28px 18px;overflow:auto}
.hero-card{display:flex;justify-content:space-between;align-items:center;gap:20px;background:var(--card);border-radius:28px;padding:24px 26px;box-shadow:var(--shadow);margin-bottom:20px}
.hero-brand{display:inline-block;background:#eef5ff;color:#1c4db5;border-radius:999px;padding:6px 12px;font-weight:700;font-size:12px;margin-bottom:10px}
.hero-card h1{margin:0 0 8px;font-size:34px;line-height:1.05}.hero-card p{margin:0;color:var(--muted);max-width:760px}
.koli-hero{width:190px;max-width:28vw}

.section-grid{display:grid;gap:18px}.two-cols{grid-template-columns:460px 1fr}
.panel{background:var(--card);border-radius:26px;box-shadow:var(--shadow)}
.panel-head{padding:20px 22px 8px}.panel-head h2{margin:0;font-size:24px}
.panel-body{padding:0 22px 22px}
label{display:block;font-size:13px;font-weight:700;color:#40526f;margin:0 0 6px}
input,select,textarea{width:100%;padding:13px 14px;border-radius:16px;border:1px solid var(--line);background:#f3f7fc;color:var(--text);outline:none;box-shadow:var(--inset)}
input:focus,select:focus,textarea:focus{border-color:#a5c0f2}
.form-grid{display:grid;gap:12px}.form-grid.two{grid-template-columns:1fr 1fr}.form-grid.three{grid-template-columns:1fr 1fr 1fr}
.btn-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}.btn-row.compact{margin-top:10px}
.btn{border:0;border-radius:16px;background:#f4f7fc;color:var(--text);padding:12px 18px;font-weight:800;cursor:pointer;box-shadow:var(--shadow)}
.btn.sm{padding:8px 12px;border-radius:12px}.btn.wide{width:100%}
.btn.primary{background:linear-gradient(90deg,#0c59da,#34b33b);color:#fff;box-shadow:none}
.btn.danger{background:#fff0f0;color:#b63131;box-shadow:none}
.btn:hover{transform:translateY(-1px)}
.sep{border:none;border-top:1px solid var(--line);margin:16px 0}
.muted{color:var(--muted)}.small{font-size:12px}
.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:18px;background:#fff;margin-top:16px}
table{width:100%;border-collapse:collapse;min-width:760px}th,td{padding:10px 12px;border-bottom:1px solid #ecf0f7;font-size:13px}th{text-align:left;color:var(--muted);background:#f8fbff}td.num{text-align:right;font-variant-numeric:tabular-nums}
.token-box,.info-card{background:#f8fbff;border:1px solid #dfe8f5;border-radius:18px;padding:14px 16px;color:#334869;margin-top:14px}
.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px}.stat-grid.wide{margin-top:10px}
.mini-stat{background:#f8fbff;border-radius:18px;padding:16px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:8px;min-height:92px}.stat-num{font-size:28px;font-weight:800;color:#12387d}
.rate-row{display:grid;grid-template-columns:1fr 1fr auto;gap:10px;margin-top:10px;align-items:center}
.checks{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:8px}.checks label{background:#f8fbff;padding:10px 12px;border-radius:14px;border:1px solid #dfe8f5;font-weight:600}
.subtabs{display:flex;gap:10px;margin-bottom:14px}.subtab{border:0;border-radius:14px;background:#f4f7fc;padding:12px 18px;font-weight:800;box-shadow:var(--shadow);cursor:pointer}.subtab.active{background:linear-gradient(90deg,#0d57d9,#2cb34a);color:#fff;box-shadow:none}
.app-footer{text-align:center;color:var(--muted);font-size:12px;padding:14px 6px 6px}
.toast{position:fixed;right:18px;bottom:18px;max-width:420px;padding:12px 14px;border-radius:14px;background:#11284f;color:#fff;opacity:0;transform:translateY(8px);pointer-events:none;transition:.18s ease;z-index:999}.toast.show{opacity:1;transform:none}.toast.error{background:#9e2e2b}

.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh}
.login-shell{display:grid;grid-template-columns:460px 380px;gap:22px;align-items:center;max-width:980px;width:100%;padding:24px}
.login-card{background:var(--card);border-radius:28px;padding:28px;box-shadow:var(--shadow)}.login-brand img{max-width:220px}.login-card h1{margin:12px 0 8px}.login-form{margin-top:18px;display:grid;gap:10px}.login-illustration img{width:100%;filter:drop-shadow(0 18px 34px rgba(0,0,0,.1))}

.public-shell{display:flex;min-height:100vh;align-items:center;justify-content:center;padding:24px;background:linear-gradient(180deg,#f7fbff,#ebf3fb)}
.public-card{width:min(520px,100%);background:var(--card);border-radius:28px;padding:24px;box-shadow:var(--shadow)}
.public-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.public-logo{width:180px;max-width:60%}.badge-light{background:#eef5ff;color:#1c4db5;border-radius:999px;padding:6px 10px;font-weight:700;font-size:12px}.public-result{margin-top:16px}.quote-big{background:linear-gradient(180deg,#0d57d9,#2192df);color:#fff;border-radius:22px;padding:20px;text-align:center;font-size:18px}.quote-big strong{font-size:42px;display:block;margin-top:4px}.quote-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:14px}.quote-grid div{background:#f8fbff;border-radius:16px;padding:14px}.quote-grid span{display:block;color:var(--muted);font-size:12px}.quote-grid strong{display:block;margin-top:6px;font-size:18px}.public-security{margin-top:16px;background:#eef8f1;color:#2d6b38;border-radius:16px;padding:14px}

@media (max-width: 1100px){ .two-cols{grid-template-columns:1fr} .sidebar{position:static;height:auto;width:100%}.app-shell{flex-direction:column} .main-area{padding:18px} .koli-hero{display:none} }
@media (max-width: 720px){ .hero-card h1{font-size:28px} .form-grid.two,.form-grid.three,.stat-grid,.quote-grid,.checks,.login-shell{grid-template-columns:1fr} .sidebar{padding:14px} .main-area{padding:14px} .panel-head h2{font-size:20px} }

/* Ajustes móviles para cotizador externo */
input, select, textarea { font-size: 16px; }
.public-body{overflow-x:hidden;touch-action:manipulation;}
.fixed-public-shell{align-items:flex-start;padding:18px 12px;min-width:320px;}
.fixed-public-card{width:390px;max-width:calc(100vw - 24px);min-width:320px;margin:0 auto;}
.public-channel-title{display:flex;align-items:center;justify-content:space-between;gap:10px;}
.public-channel-title h1{margin:12px 0 6px;font-size:28px;line-height:1.05;}
.public-koli-small{width:92px;max-width:26%;filter:drop-shadow(0 10px 18px rgba(0,50,120,.15));}
.public-subtitle{color:var(--muted);margin-top:0;}
.public-mini-note{font-size:12px;color:var(--muted);background:#f8fbff;border:1px solid #dfe8f5;border-radius:14px;padding:10px 12px;margin-top:12px;}
.segmented-control{display:grid;grid-template-columns:1fr 1fr;gap:8px;background:#e8f0fa;border-radius:16px;padding:5px;}
.seg-btn{border:0;border-radius:12px;padding:11px 10px;background:transparent;font-weight:800;color:#334869;cursor:pointer;font-size:16px;}
.seg-btn.active{background:linear-gradient(90deg,#0d57d9,#2cb34a);color:#fff;box-shadow:0 8px 18px rgba(13,87,217,.20);}
.public-amort{margin-top:16px;}
.public-amort h3{font-size:16px;margin:0 0 8px;color:var(--text);}
.compact-table table{min-width:520px;font-size:11px;}
.compact-table th,.compact-table td{padding:8px 8px;font-size:11px;}
.token-box .btn-row{margin-top:10px;}

@media (max-width:420px){
  .fixed-public-shell{padding:12px 8px;}
  .fixed-public-card{width:390px;max-width:calc(100vw - 16px);padding:18px;}
  .public-logo{width:150px;}
  .public-channel-title h1{font-size:24px;}
  .quote-big strong{font-size:34px;}
  .quote-grid{grid-template-columns:1fr 1fr;gap:8px;}
  .quote-grid div{padding:11px;}
  .quote-grid strong{font-size:15px;}
}

/* Productos por convenio */
.module-subtitle{margin:0 0 10px;font-size:18px;color:var(--text)}
.product-editor{background:#f8fbff;border:1px solid #dfe8f5;border-radius:20px;padding:14px;margin-top:14px}
.product-list{display:flex;flex-direction:column;gap:8px;margin:8px 0 4px}
.product-pill{border:1px solid #dfe8f5;background:#fff;border-radius:16px;padding:11px 12px;text-align:left;color:var(--text);cursor:pointer;box-shadow:0 6px 14px rgba(18,56,125,.06)}
.product-pill strong{display:block;font-size:14px;margin-bottom:4px}.product-pill span{display:block;color:var(--muted);font-size:12px;line-height:1.3}.product-pill:hover{border-color:#8eb4ee;transform:translateY(-1px)}
.product-preview-list{margin:10px 0 0;padding-left:20px}.product-preview-list li{margin:0 0 10px;line-height:1.35}
.public-card select#pub_product{margin-bottom:12px}

/* Botón para cotización PDF en link externo */
.public-quote-actions{margin:14px 0 2px;}
.public-quote-actions .btn{font-size:15px;}


/* Manual de uso */
.manual-header{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:24px 26px;margin-bottom:18px}
.manual-header h2{margin:8px 0 6px;font-size:32px;line-height:1.05}
.manual-header p{margin:0;color:var(--muted);max-width:820px}
.manual-badge{display:inline-block;background:#eef8ff;color:#0d57d9;border:1px solid #d7e8ff;border-radius:999px;padding:6px 12px;font-size:12px;font-weight:800}
.manual-version{background:linear-gradient(90deg,#0c59da,#19b0ff);color:#fff;border-radius:18px;padding:12px 16px;font-weight:900;white-space:nowrap}
.manual-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;margin-bottom:18px}
.manual-card{background:var(--card);border-radius:26px;box-shadow:var(--shadow);padding:22px;border:1px solid rgba(255,255,255,.55)}
.manual-card-title{font-size:20px;font-weight:900;color:#12387d;margin-bottom:10px}
.manual-card p{color:#334869;line-height:1.45;margin:0 0 12px}
.manual-card ol{margin:0;padding-left:20px;color:#40526f;line-height:1.55}
.manual-card li{margin-bottom:6px}
.manual-note{margin-top:14px;background:#f8fbff;border:1px solid #dfe8f5;border-radius:16px;padding:12px 14px;color:#476080;font-size:13px;line-height:1.4}
.manual-flow-panel{margin-top:4px}
.manual-flow{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
.manual-flow div{background:#f8fbff;border:1px solid #dfe8f5;border-radius:18px;padding:14px;min-height:120px}
.manual-flow strong{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;background:linear-gradient(90deg,#0d57d9,#2cb34a);color:#fff;margin-bottom:10px}
.manual-flow span{display:block;color:#334869;font-weight:700;font-size:13px;line-height:1.35}

@media (max-width: 1100px){
  .manual-grid{grid-template-columns:1fr}
  .manual-flow{grid-template-columns:1fr 1fr}
}
@media (max-width: 720px){
  .manual-header{flex-direction:column;align-items:flex-start;padding:20px}
  .manual-header h2{font-size:26px}
  .manual-version{white-space:normal}
  .manual-flow{grid-template-columns:1fr}
}


/* Mostrar / ocultar contraseña */
.password-field{
  position:relative;
  width:100%;
}
.password-field .password-input{
  padding-right:92px;
}
.password-toggle{
  position:absolute;
  right:8px;
  top:50%;
  transform:translateY(-50%);
  border:0;
  border-radius:12px;
  padding:7px 10px;
  background:#e8f0fa;
  color:#12387d;
  font-size:12px;
  font-weight:800;
  cursor:pointer;
  box-shadow:0 5px 12px rgba(18,56,125,.08);
}
.password-toggle:hover{
  background:#dcecff;
}
.password-toggle:focus{
  outline:2px solid rgba(13,87,217,.28);
  outline-offset:2px;
}
