:root{--duam-red:#c50013;--duam-red-dark:#751712;--duam-blue:#002750;--duam-sky:#679bba;--duam-cream:#fdf0d7;--ink:#172338;--text:#26374c;--muted:#718197;--line:#dce5ef;--line-soft:#edf2f7;--surface:#fff;--surface-soft:#f6f9fc;--background:#f2f6fa;--success:#0f8f63;--warning:#b35b00;--danger:#b42318;--radius:18px;--shadow:0 18px 55px rgba(0,39,80,.08);--shadow-soft:0 8px 28px rgba(0,39,80,.06)}
*{box-sizing:border-box}html{min-height:100%}body{min-height:100%;margin:0;background:linear-gradient(180deg,#f7fafc 0%,var(--background) 100%);color:var(--text);font-family:Montserrat,Calibri,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;line-height:1.42;-webkit-font-smoothing:antialiased}a{color:var(--duam-blue)}
.landing-page{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at 20% 10%,#eef7fb 0,transparent 32%),linear-gradient(180deg,#f8fbfd,#eef4f8)}.login-card{width:min(520px,100%);padding:34px;border:1px solid var(--line);border-radius:28px;background:rgba(255,255,255,.94);box-shadow:var(--shadow);text-align:center}.login-logo{width:88px;height:88px;object-fit:contain;border:1px solid var(--line);border-radius:24px;background:#fff;padding:10px;margin-bottom:14px}.login-card h1{font-size:44px}.login-form{display:grid;gap:14px;text-align:left;margin:24px 0 16px}.google{width:100%;gap:10px}.gmark{display:grid;place-items:center;width:24px;height:24px;border:1px solid var(--line);border-radius:50%;background:#fff;color:#4285f4;font-weight:900}
.app-shell{display:flex;min-height:100vh}.sidebar{width:260px;flex:0 0 260px;padding:18px 16px;border-right:1px solid var(--line);background:rgba(255,255,255,.94);position:sticky;top:0;height:100vh;display:flex;flex-direction:column;gap:16px;z-index:40}.brand-card,.session-card,.card,.tablewrap,.form fieldset{border:1px solid var(--line);background:rgba(255,255,255,.96);box-shadow:var(--shadow-soft)}.brand-card{padding:18px;display:flex;gap:13px;align-items:center;border-radius:16px;text-decoration:none;color:inherit}.brand-logo-wrap{width:58px;height:58px;border-radius:15px;background:#fff;border:1px solid #edf0f4;display:grid;place-items:center;overflow:hidden;box-shadow:0 5px 14px rgba(0,39,80,.08)}.brand-logo{width:46px;height:46px;object-fit:contain;display:block}.brand-copy{display:flex;flex-direction:column;min-width:0}.brand-copy strong{font-size:18px;line-height:1.05;color:var(--ink)}.brand-copy small,.session-card span{color:var(--muted);font-weight:700;font-size:11px}.eyebrow{display:block;color:var(--duam-sky);text-transform:uppercase;letter-spacing:.11em;font-size:10px;font-weight:900;margin-bottom:4px}.side-nav{display:flex;flex-direction:column;gap:8px;margin-top:2px}.side-nav a{text-decoration:none;color:#66758a;padding:12px 14px;border-radius:12px;font-weight:850;transition:.16s ease}.side-nav a:hover{background:#f1f7fb;color:var(--duam-blue)}.side-nav a.active{background:linear-gradient(90deg,#2f9dac 0%,#43a5b2 100%);color:#fff;box-shadow:0 10px 24px rgba(47,157,172,.25)}.nav-separator{font-size:11px;text-transform:uppercase;color:#8a99ab;font-weight:900;margin:12px 8px 2px;letter-spacing:.1em}.sidebar-foot{margin-top:auto;border-radius:14px;padding:12px;background:#fbfdff}.sidebar-foot strong{display:block;color:var(--duam-blue);margin-top:2px;overflow-wrap:anywhere}.sidebar-foot small{display:block;margin-top:3px}.logout{display:inline-block;margin-top:8px;font-size:12px;font-weight:900;text-decoration:none;color:var(--duam-red)}
.content-shell{min-width:0;flex:1;display:flex;flex-direction:column}.topbar{height:74px;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:0 28px;background:rgba(255,255,255,.92);border-bottom:1px solid var(--line);backdrop-filter:blur(12px);position:sticky;top:0;z-index:30}.topbar h1{margin:0;font-size:20px;color:#172338;letter-spacing:-.02em}.mobile-menu-btn{display:none;border:1px solid var(--line);background:#fff;border-radius:12px;padding:9px 11px;color:var(--duam-blue);font-weight:900}.session-card{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:16px;background:#fff}.session-card strong{display:block;color:var(--ink);font-size:12px;overflow-wrap:anywhere}.mini-logo{width:38px;height:38px;border-radius:50%;background:#fff;display:grid;place-items:center;border:1px solid var(--line);overflow:hidden;flex:0 0 auto}.mini-logo img{width:30px;height:30px;object-fit:contain}
.main{padding:26px 28px 44px;max-width:1360px;width:100%;margin:0 auto}.footer{padding:18px 28px 24px;text-align:center;color:var(--muted);font-size:12px}h1{font-size:clamp(30px,5vw,50px);line-height:1.05;margin:0 0 14px;color:var(--ink);letter-spacing:-.04em}h2{margin-top:0;color:var(--ink);letter-spacing:-.02em}h3{color:var(--duam-blue);margin-top:0}p{margin-top:0}.lead{font-size:18px;color:var(--muted);max-width:920px}.page-head{margin-bottom:22px}.support-hero{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:24px;align-items:stretch;margin-bottom:22px}.hero-copy{background:linear-gradient(135deg,#ffffff 0%,#fbfdff 68%,#eef7fb 100%)}.card{border-radius:18px;padding:22px;margin-bottom:18px;min-width:0}.warning{background:#fff7ed}.success{background:#ecfdf5}.soft-card{background:#fff8ed}.alert{padding:14px;border-radius:12px;margin:14px 0}.error{background:#fef3f2;color:var(--danger);border:1px solid #fecdca}.support-note{border-left:4px solid var(--duam-sky);background:#f4f9fc;padding:14px 16px;border-radius:12px;margin:18px 0;color:#31445a}.grid{display:grid;gap:18px;margin-bottom:18px}.grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(190px,1fr))!important}.stat{display:flex;align-items:center;justify-content:space-between;gap:10px}.stat span{font-weight:800;color:var(--muted)}.stat strong{font-size:30px;color:var(--duam-blue)}.actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px}.btn{appearance:none;display:inline-flex;align-items:center;justify-content:center;min-height:42px;padding:10px 15px;border-radius:12px;border:1px solid var(--line);background:#fff;color:var(--duam-blue);cursor:pointer;font-weight:900;text-decoration:none;text-align:center;transition:.16s ease;box-shadow:0 4px 12px rgba(0,39,80,.04)}.btn:hover{transform:translateY(-1px);box-shadow:0 9px 18px rgba(0,39,80,.08)}.btn.primary{background:linear-gradient(180deg,var(--duam-red) 0%,#a90010 100%);border-color:#a90010;color:#fff}.btn.secondary{background:#eef7fb;border-color:#cfe4ee;color:var(--duam-blue)}.btn.small{min-height:34px;padding:7px 10px;font-size:12px}.brand-aside{text-align:left}.brand-mark{width:86px;height:86px;border:1px solid var(--line);border-radius:22px;background:#fff;display:grid;place-items:center;box-shadow:var(--shadow-soft);margin-bottom:16px}.brand-mark img{width:68px;height:68px;object-fit:contain}.clean-list{margin:0;padding-left:18px}.clean-list li{margin-bottom:10px}
.form{display:grid;gap:18px;width:100%;min-width:0}.form fieldset{border-radius:18px;padding:20px;min-width:0;max-width:100%;overflow:hidden}.form legend{font-weight:900;color:var(--duam-blue);padding:0 8px}.form label{display:grid;gap:7px;font-weight:850;color:#425168;font-size:13px;min-width:0}.form input,.form select,.form textarea,input,select,textarea{width:100%;min-width:0;max-width:100%;border:1px solid var(--line);border-radius:12px;padding:11px 12px;font:inherit;background:#fff;color:var(--ink);outline:none;box-shadow:inset 0 1px 0 rgba(0,39,80,.02)}textarea{resize:vertical}.form input:focus,.form select:focus,.form textarea:focus,input:focus,select:focus,textarea:focus{border-color:var(--duam-sky);box-shadow:0 0 0 4px rgba(103,155,186,.16)}.row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;min-width:0}.row.two{grid-template-columns:repeat(2,minmax(0,1fr))}.check{display:flex!important;align-items:center;gap:9px}.check input{width:auto;min-width:auto}.emphasized{background:#f3f8fb;border:1px solid #d5e8f0;border-radius:12px;padding:12px}.hint{font-size:13px;color:var(--muted);margin:8px 0 0}.compact{gap:12px}.sticky-actions{position:sticky;bottom:0;background:rgba(242,246,250,.94);backdrop-filter:blur(10px);border:1px solid var(--line);border-radius:18px;padding:14px;display:flex;gap:12px;z-index:20}.complaint-form{padding-bottom:22px}
.tablewrap{overflow:auto;border-radius:16px;margin-bottom:18px}.embedded{box-shadow:none;border-radius:12px}table{border-collapse:collapse;width:100%;background:#fff}th,td{padding:12px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}th{background:#f8fafc;color:var(--duam-blue);font-size:12px;text-transform:uppercase;letter-spacing:.06em}.pill{display:inline-flex;align-items:center;background:#eef7fb;color:var(--duam-blue);border:1px solid #cfe4ee;border-radius:999px;padding:5px 9px;font-weight:900;font-size:12px}.muted-pill{background:#f3f4f6;color:#6b7280;border-color:#e5e7eb}.casecode{font-size:38px;font-weight:900;color:var(--duam-blue);letter-spacing:.03em;margin:12px 0}.split{display:flex;justify-content:space-between;gap:20px;align-items:center;margin-bottom:18px}.right{text-align:right}dl{display:grid;grid-template-columns:190px minmax(0,1fr);gap:8px 14px}dt{font-weight:900;color:#475569}dd{margin:0;white-space:pre-wrap;overflow-wrap:anywhere}.timeline{display:grid;gap:12px;padding-left:20px}.timeline li{padding-bottom:10px;border-bottom:1px solid var(--line)}code{background:#eef2f7;padding:2px 6px;border-radius:6px}.muted{color:var(--muted)}
@media(max-width:1100px){.support-hero,.grid.two,.grid.three{grid-template-columns:1fr}.row,.row.two{grid-template-columns:1fr 1fr}}
@media(max-width:920px){.sidebar{position:fixed;left:-280px;transition:.18s ease}.sidebar-open .sidebar{left:0}.mobile-menu-btn{display:inline-flex}.topbar{padding:0 16px}.main{padding:22px 16px 38px}.row,.row.two{grid-template-columns:1fr}.session-card{display:none}.split{display:block}.right{text-align:left;margin-top:12px}dl{grid-template-columns:1fr}.footer{padding-left:16px;padding-right:16px}.sticky-actions{position:static}.login-card h1{font-size:36px}}
@media(max-width:600px){.topbar h1{font-size:16px}.topbar .eyebrow{font-size:9px}h1{font-size:34px}.card,.form fieldset{padding:16px}.login-card{padding:24px}}


/* Dashboard refinado: inicio */
.sidebar{padding-bottom:18px}.side-nav{gap:10px}.side-nav a{display:flex;align-items:center;gap:12px;padding:13px 15px;color:#53657e}.side-nav a .nav-icon{width:22px;min-width:22px;height:22px;display:inline-grid;place-items:center;font-size:17px;line-height:1;color:#53657e}.side-nav a.active .nav-icon,.side-nav a.active{color:#fff}.nav-separator{margin-top:18px}.session-card{min-width:272px;justify-content:flex-start;padding:10px 13px;border-radius:16px}.top-logout{margin-left:auto;text-decoration:none;color:#6c7a8e;font-weight:900;font-size:18px;line-height:1;transform:translateY(-1px)}
.dashboard-hero{padding:0;margin:0 0 26px;background:transparent;border:0;box-shadow:none;max-width:980px}.dashboard-hero h2{font-size:28px;margin:0 0 16px;color:var(--ink)}.dashboard-hero p{margin:0 0 6px;color:#31445a;font-size:15px;max-width:960px}
.kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:24px;margin:20px 0 28px}.kpi-card{position:relative;overflow:hidden;border:1px solid var(--line);border-radius:20px;background:rgba(255,255,255,.98);box-shadow:0 18px 55px rgba(0,39,80,.07);padding:24px 24px 22px;min-height:150px}.kpi-main{display:flex;align-items:center;gap:20px}.kpi-icon{width:70px;height:70px;min-width:70px;border-radius:50%;display:grid;place-items:center;font-size:35px;font-weight:900}.kpi-label{display:block;font-size:15px;font-weight:800;color:#27364d;margin-bottom:3px}.kpi-card strong{display:block;font-size:56px;line-height:.92;letter-spacing:-.06em}.kpi-note{display:block;margin-top:22px;padding:10px 14px;border-radius:13px;text-align:center;font-size:13px;font-weight:800}.kpi-teal .kpi-icon{background:#e0f5f3;color:#087f86}.kpi-teal strong{color:#008b91}.kpi-teal .kpi-note{background:#def3f1;color:#087f86}.kpi-blue .kpi-icon{background:#eaf4ff;color:#0b63b6}.kpi-blue strong{color:#0b63b6}.kpi-blue .kpi-note{background:#edf6ff;color:#0b63b6}.kpi-purple .kpi-icon{background:#f0eafb;color:#6040aa}.kpi-purple strong{color:#6040aa}.kpi-purple .kpi-note{background:#f2eefa;color:#6040aa}.kpi-red .kpi-icon{background:#fde9e9;color:#c73535}.kpi-red strong{color:#c73535}.kpi-red .kpi-note{background:#fde4e4;color:#b42318}.dashboard-panels{gap:26px}.dashboard-panel{padding:26px 28px;border-radius:20px;min-height:245px}.panel-head{display:flex;align-items:flex-start;gap:18px;margin-bottom:18px;padding-bottom:20px;border-bottom:1px solid var(--line)}.panel-head h3{margin:0 0 8px;color:var(--duam-blue);font-size:21px}.panel-head p{margin:0;color:#3d4f66}.panel-icon{width:58px;height:58px;min-width:58px;border-radius:50%;display:grid;place-items:center;font-size:30px;font-weight:900}.panel-icon-teal{background:#e0f5f3;color:#087f86}.panel-icon-purple{background:#eef1ff;color:#5544b0}.dashboard-panel .tablewrap{box-shadow:none;border:0;background:transparent}.dashboard-panel table{background:transparent}.dashboard-panel th{display:none}.dashboard-panel td{border-bottom:0;text-align:center;color:#7a8799;padding:26px 12px}.dashboard-panel td:only-child{font-size:15px}.stats-grid{display:grid}.stat-card{border:1px solid var(--line);border-radius:18px;background:#fff;padding:18px;box-shadow:var(--shadow-soft)}
@media(max-width:1250px){.kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:700px){.kpi-grid{grid-template-columns:1fr}.kpi-card{padding:20px}.kpi-card strong{font-size:48px}.kpi-icon{width:62px;height:62px;min-width:62px}.dashboard-hero h2{font-size:23px}.panel-head{gap:13px}.panel-icon{width:50px;height:50px;min-width:50px}.session-card{min-width:auto}}

/* UI v2 - dashboard como mockup */
:root{--dash-teal:#078a92;--dash-blue:#0b63b6;--dash-purple:#6040aa;--dash-red:#c73535;--sidebar-w:260px}
.app-shell{background:linear-gradient(180deg,#f8fbff 0%,#f2f6fa 100%)}
.sidebar{width:260px;flex-basis:260px;background:rgba(255,255,255,.97);padding:16px 14px 20px;box-shadow:10px 0 30px rgba(0,39,80,.025)}
.brand-card{height:116px;border-radius:16px;padding:18px 18px;gap:13px;box-shadow:0 10px 30px rgba(0,39,80,.06)}
.brand-copy strong{font-size:18px;line-height:1.05;color:#15213a}.brand-copy small{font-size:11px;line-height:1.25;color:#52657e}.brand-logo-wrap{width:56px;height:56px}.brand-logo{width:44px;height:44px}
.side-nav{margin-top:6px;gap:10px}.side-nav a{height:52px;display:flex;align-items:center;gap:13px;padding:0 16px;border-radius:12px;font-size:15px;font-weight:850;color:#5a6d86}.side-nav a.active{background:linear-gradient(90deg,#209ba7 0%,#45a9b4 100%);box-shadow:0 16px 30px rgba(32,155,167,.24)}.side-nav a .nav-icon{font-size:20px;width:22px;height:22px}.nav-separator{margin:18px 8px 6px;letter-spacing:.16em;font-size:10px;color:#8190a5}
.topbar{height:74px;padding:0 28px 0 36px;background:rgba(255,255,255,.95);border-bottom:1px solid #dce5ef}.topbar h1{font-size:20px;letter-spacing:-.02em;color:#142139}.topbar .eyebrow{font-size:10px;color:#2c82ae;letter-spacing:.16em}.session-card{border-radius:16px;min-width:288px;height:56px;box-shadow:0 8px 24px rgba(0,39,80,.045)}.session-card strong{font-size:12px;color:#102044}.mini-logo{width:40px;height:40px}
.main{max-width:1540px;padding:54px 48px 42px}.footer{font-size:12px;color:#8491a5;padding-bottom:28px}.dashboard-hero{max-width:980px;margin:0 0 34px}.dashboard-hero .eyebrow{font-size:11px;letter-spacing:.18em;color:#1b80ad;margin-bottom:12px}.dashboard-hero h2{font-size:27px;line-height:1.15;margin:0 0 18px;color:#101d35}.dashboard-hero p{font-size:15.5px;color:#30435a;line-height:1.5;margin-bottom:3px}
.kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(220px,1fr));gap:32px;margin:0 0 34px}.kpi-card{border-radius:18px;padding:28px 26px 24px;min-height:164px;background:#fff;border:1px solid #dce5ef;box-shadow:0 16px 46px rgba(0,39,80,.065)}.kpi-main{display:flex;align-items:center;gap:22px}.kpi-icon,.panel-icon{display:grid;place-items:center;border-radius:999px;flex:0 0 auto}.kpi-icon{width:78px;height:78px}.kpi-icon svg,.panel-icon svg,.empty-icon svg{width:45px;height:45px;fill:none;stroke:currentColor;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round}.kpi-label{font-size:16px;color:#26364d;font-weight:750;margin-bottom:8px}.kpi-card strong{font-size:58px;line-height:.85;font-weight:800;letter-spacing:-.06em}.kpi-note{margin-top:26px;display:block;border-radius:12px;padding:10px 12px;text-align:center;font-size:13.5px;font-weight:760}.kpi-teal .kpi-icon{background:#dff4f2;color:var(--dash-teal)}.kpi-teal strong{color:var(--dash-teal)}.kpi-teal .kpi-note{background:#ddf3f1;color:#087982}.kpi-blue .kpi-icon{background:#eaf4ff;color:var(--dash-blue)}.kpi-blue strong{color:var(--dash-blue)}.kpi-blue .kpi-note{background:#ecf5ff;color:var(--dash-blue)}.kpi-purple .kpi-icon{background:#f0eafb;color:var(--dash-purple)}.kpi-purple strong{color:var(--dash-purple)}.kpi-purple .kpi-note{background:#f1ecfa;color:var(--dash-purple)}.kpi-red .kpi-icon{background:#fde9e9;color:var(--dash-red)}.kpi-red strong{color:var(--dash-red)}.kpi-red .kpi-note{background:#fde4e4;color:#b42318}
.dashboard-panels{display:grid;grid-template-columns:1fr 1fr;gap:32px}.dashboard-panel{border-radius:18px;min-height:238px;margin-bottom:0;background:#fff;border:1px solid #dce5ef;box-shadow:0 16px 46px rgba(0,39,80,.055);padding:28px}.panel-head{display:flex;gap:18px;align-items:flex-start;border-bottom:1px solid #dbe4ee;padding-bottom:22px;margin-bottom:0}.panel-icon{width:62px;height:62px}.panel-icon svg{width:35px;height:35px}.panel-icon-teal{background:#dff4f2;color:var(--dash-teal)}.panel-icon-purple{background:#eef1ff;color:#5544b0}.panel-head h3{font-size:22px;line-height:1.1;margin:4px 0 10px;color:#102044}.panel-head p{font-size:14.5px;color:#354861;margin:0}.empty-state{min-height:108px;display:flex;align-items:center;justify-content:center;gap:18px;color:#7d8ca0;text-align:left}.empty-state p{margin:0;color:#7d8ca0;font-size:14.5px}.empty-icon{color:#b9c4d2}.empty-icon svg{width:48px;height:48px;stroke-width:1.8}.dashboard-panel .tablewrap{margin-top:18px;margin-bottom:0;box-shadow:none;border:0}.dashboard-panel .embedded{border-radius:0}.dashboard-panel table{font-size:14px}.dashboard-panel th{background:#f8fafc}.dashboard-panel td,.dashboard-panel th{padding:12px 10px}
.sidebar-foot{display:none!important}
@media(max-width:1300px){.kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.main{padding:44px 34px}.dashboard-panels{grid-template-columns:1fr}}
@media(max-width:760px){.main{padding:28px 18px}.kpi-grid{grid-template-columns:1fr;gap:18px}.kpi-card{padding:22px}.kpi-icon{width:66px;height:66px}.kpi-card strong{font-size:50px}.dashboard-hero h2{font-size:24px}.dashboard-panel{padding:22px}.empty-state{flex-direction:column;text-align:center}.session-card{display:none}}

/* Gestión de licencias */
.license-picker{border:1px solid var(--line);border-radius:18px;background:linear-gradient(180deg,#fbfdff 0%,#fff 100%);padding:20px;margin:8px 0 4px}.license-picker-head{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:16px}.license-picker-head h3{margin:0 0 6px;color:var(--ink)}.license-picker-head p{margin:0;color:var(--muted);max-width:820px}.license-check-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.license-check{display:flex;gap:12px;align-items:flex-start;border:1px solid #dce5ef;border-radius:14px;background:#fff;padding:14px;cursor:pointer;min-height:82px;transition:.16s ease}.license-check:hover{transform:translateY(-1px);box-shadow:0 10px 22px rgba(0,39,80,.06)}.license-check input{width:18px;height:18px;margin-top:2px;accent-color:#209ba7}.license-check-body{display:flex;flex-direction:column;gap:4px;min-width:0}.license-check-body strong{color:#172338;font-size:14px;line-height:1.2}.license-check-body small{color:#718197;font-weight:700}.license-check.over-capacity{border-color:#fecdca;background:#fff8f7}.license-kpis{grid-template-columns:repeat(2,minmax(260px,1fr));max-width:760px}.license-admin-card{padding:26px}.license-admin-list{display:grid;gap:12px}.license-admin-row{display:grid;grid-template-columns:94px minmax(260px,1fr) 90px 150px 110px;gap:16px;align-items:center;border:1px solid var(--line);border-radius:16px;background:#fff;padding:16px}.license-admin-row.inactive{opacity:.58;background:#f8fafc}.license-admin-row.over-capacity{border-color:#fecdca;background:#fff8f7}.license-admin-main strong{display:block;color:#172338;margin-bottom:3px}.license-admin-main small,.license-usage small,.license-available small{display:block;color:#718197;font-size:12px;font-weight:800}.license-bar{height:8px;border-radius:999px;background:#edf2f7;overflow:hidden;margin-top:9px}.license-bar span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#209ba7,#0b63b6)}.license-usage,.license-available{text-align:center}.license-usage strong,.license-available strong{display:block;font-size:25px;color:#0b63b6;line-height:1}.license-total{font-size:12px;font-weight:900;color:#53657e}.license-total input{margin-top:5px}.active-check{margin:0}.licenses-cell{max-width:360px;color:#52657e;font-size:12px;line-height:1.35}.stat-card small{display:block;margin-top:5px;color:#718197;font-weight:800}.section-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:18px}.section-title-row h3{margin-bottom:5px}
@media(max-width:1100px){.license-check-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.license-admin-row{grid-template-columns:1fr 1fr;align-items:start}.license-admin-main{grid-column:1/-1}.license-kpis{grid-template-columns:1fr}}
@media(max-width:650px){.license-check-grid{grid-template-columns:1fr}.license-picker-head,.section-title-row{flex-direction:column}.license-admin-row{grid-template-columns:1fr}.license-usage,.license-available{text-align:left}}

/* Ajustes personal/licencias v2 */
.license-admin-row{grid-template-columns:minmax(300px,1fr) 90px 150px 110px 140px;}
.license-actions{text-align:right;}
.personnel-note{color:var(--muted);font-size:13px;}
.table-wrap table td .btn.small{white-space:nowrap;}
@media(max-width:1100px){.license-admin-row{grid-template-columns:1fr 1fr}.license-actions{text-align:left}.license-admin-main{grid-column:1/-1}}
@media(max-width:650px){.license-admin-row{grid-template-columns:1fr}.license-actions{text-align:left}}
/* Funcionalidades finales: conexiones, alertas y bloqueo administrativo */
.danger-pill{background:#fff1f0;color:#b42318;border-color:#fecdca}.info-strip{border:1px solid var(--line);border-radius:12px;background:#f8fafc;color:#52657e;padding:12px 14px;font-weight:800}.remote-action-box{border:1px solid #dce5ef;border-radius:18px;background:linear-gradient(135deg,#fbfdff,#f4f9fc);padding:18px;margin:12px 0 20px;display:grid;grid-template-columns:minmax(260px,1fr) minmax(320px,1.3fr);gap:18px;align-items:end}.remote-action-box h3{margin:0 0 6px;color:var(--ink)}.remote-action-box p{margin:0}.remote-action-form{display:grid;grid-template-columns:180px minmax(180px,1fr) auto;gap:10px;align-items:center}.remote-action-form select,.remote-action-form input{height:42px}.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:16px}.page-head.section-title-row{align-items:center}@media(max-width:950px){.remote-action-box,.remote-action-form{grid-template-columns:1fr}.remote-action-form .btn{width:100%}}

/* Google Sign-In / SSO */
.google-auth-card {
  max-width: 460px;
  text-align: center;
}
.google-login-button {
  display: flex;
  justify-content: center;
  margin: 22px 0 10px;
  min-height: 44px;
}
.muted.small {
  font-size: 13px;
  color: var(--muted, #64748b);
}


/* Login Google centrado, inspirado en VT Flash */
.auth-overlay-page{
  min-height:100vh;
  width:100vw;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
  background:rgba(0,39,80,.68);
  background:linear-gradient(135deg,rgba(0,39,80,.70),rgba(103,155,186,.78));
}
.auth-card-duam{
  width:min(440px,calc(100vw - 32px));
  background:#fff;
  border:1px solid var(--line);
  border-radius:28px;
  box-shadow:0 30px 90px rgba(0,39,80,.24);
  padding:34px;
  text-align:center;
}
.auth-logo-duam{
  width:72px;
  height:72px;
  object-fit:contain;
  border-radius:20px;
  border:1px solid var(--line);
  background:#fff;
  padding:8px;
  margin:0 auto 14px;
  display:block;
}
.auth-card-duam h1{
  font-size:22px;
  line-height:1.18;
  letter-spacing:-.02em;
  margin:10px 0 20px;
  color:#172338;
}
.auth-card-duam p{
  color:#697d96;
  font-size:15px;
  line-height:1.45;
  margin:0 auto 14px;
  max-width:330px;
}
.auth-card-duam small{
  color:#718197;
  display:block;
  font-size:12px;
  line-height:1.45;
  margin-top:16px;
}
.auth-card-duam .eyebrow{
  text-align:center;
  margin-top:4px;
}
.auth-card-duam .google-login-button{
  display:flex;
  justify-content:center;
  align-items:center;
  margin:22px 0 10px;
  min-height:44px;
}
.auth-card-duam #auth-status{
  font-size:12px;
  margin:10px auto 0;
  min-height:18px;
}
@media(max-width:560px){
  .auth-card-duam{padding:26px 18px;border-radius:22px}
  .auth-card-duam h1{font-size:20px}
}
.assignment-panel{border:1px solid var(--line);border-radius:18px;background:linear-gradient(180deg,#f7fbff 0%,#fff 100%);padding:20px;margin:8px 0 4px}.assignment-panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:14px}.assignment-panel-head h3{margin:0 0 6px;color:var(--ink)}.assignment-panel-head p{margin:0;color:var(--muted);max-width:900px}.assignment-panel label{display:block}.assignment-panel select{margin-top:7px}
.assignment-help{margin:8px 0 0;color:var(--muted);font-size:13px;line-height:1.4}
input[readonly]{background:#f8fbff;color:#4b5d73;border-color:#d9e5f2;cursor:not-allowed}

/* Panel administrador refinado */
.admin-hero{border:1px solid var(--line);border-radius:24px;background:linear-gradient(135deg,#fff 0%,#fbfdff 60%,#eef7fb 100%);box-shadow:0 18px 55px rgba(0,39,80,.06);padding:28px 30px;margin-bottom:22px}.admin-hero-row{display:flex;align-items:flex-end;justify-content:space-between;gap:24px}.admin-hero h2{font-size:30px;line-height:1.15;margin:0 0 10px;color:#102044;letter-spacing:-.035em}.admin-hero p{font-size:15px;color:#53657e;max-width:820px;margin:0}.admin-hero-badge{border:1px solid #d5e8f0;background:#fff;border-radius:16px;padding:12px 16px;min-width:150px;text-align:right;box-shadow:0 8px 22px rgba(0,39,80,.05)}.admin-hero-badge span{display:block;font-size:11px;font-weight:900;color:#718197;text-transform:uppercase;letter-spacing:.08em}.admin-hero-badge strong{display:block;color:#0f8f63;font-size:20px;margin-top:2px}.admin-kpi-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:16px;margin-bottom:18px}.admin-kpi-card{border:1px solid var(--line);border-radius:20px;background:#fff;box-shadow:0 14px 38px rgba(0,39,80,.055);padding:18px;min-height:150px;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden;position:relative}.admin-kpi-card:after{content:"";position:absolute;right:-28px;top:-28px;width:95px;height:95px;border-radius:50%;background:currentColor;opacity:.08}.admin-kpi-top{display:flex;align-items:center;gap:14px;position:relative;z-index:1}.admin-kpi-icon{width:50px;height:50px;border-radius:16px;display:grid;place-items:center;flex:0 0 auto;background:#edf7fb;color:#209ba7}.admin-kpi-icon svg{width:29px;height:29px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.admin-kpi-card span{display:block;font-size:13px;font-weight:850;color:#53657e;line-height:1.2}.admin-kpi-card strong{display:block;font-size:42px;line-height:.9;letter-spacing:-.06em;color:currentColor;margin-top:7px}.admin-kpi-card small{display:block;position:relative;z-index:1;color:#718197;font-size:12px;font-weight:800;background:#f8fafc;border-radius:10px;padding:8px 10px}.admin-kpi-card.kpi-teal{color:#0b8c95}.admin-kpi-card.kpi-blue{color:#0b63b6}.admin-kpi-card.kpi-purple{color:#6f42c1}.admin-kpi-card.kpi-red{color:#b42318}.admin-kpi-card.kpi-orange{color:#b35b00}.admin-kpi-card.kpi-teal .admin-kpi-icon{background:#dff4f2;color:#0b8c95}.admin-kpi-card.kpi-blue .admin-kpi-icon{background:#eaf4ff;color:#0b63b6}.admin-kpi-card.kpi-purple .admin-kpi-icon{background:#f0eafb;color:#6f42c1}.admin-kpi-card.kpi-red .admin-kpi-icon{background:#fde9e9;color:#b42318}.admin-kpi-card.kpi-orange .admin-kpi-icon{background:#fff3df;color:#b35b00}.admin-actions-card{border:1px solid var(--line);border-radius:20px;background:#fff;box-shadow:0 12px 34px rgba(0,39,80,.05);padding:18px 20px;margin-bottom:18px;display:flex;align-items:center;justify-content:space-between;gap:18px}.admin-actions-card h3{margin:2px 0 0;color:#102044;font-size:18px}.admin-actions-grid{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.admin-content-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:18px}.admin-table-card{padding:22px;min-height:360px}.compact-title{align-items:center;margin-bottom:14px}.compact-title h3{margin:2px 0 0;font-size:20px;color:#102044}.admin-table-card .tablewrap.embedded{border:1px solid #e5edf5;border-radius:16px;box-shadow:none;max-height:440px;overflow:auto}.admin-table-card table{font-size:13px}.admin-table-card th{background:#f8fbff;color:#31445a;font-size:11px;letter-spacing:.08em;text-transform:uppercase}.admin-table-card td,.admin-table-card th{padding:13px 12px;vertical-align:top}.admin-table-card tbody tr:hover{background:#fbfdff}.admin-table-card .licenses-cell{max-width:230px;font-size:11.5px;line-height:1.25}.admin-table-card .pill{display:inline-flex;align-items:center;border-radius:999px;padding:5px 9px;background:#eaf4ff;color:#0b63b6;font-size:11px;font-weight:900;white-space:nowrap}.admin-table-card .empty-state{min-height:230px;flex-direction:column;text-align:center;gap:10px}.admin-table-card .empty-icon svg{width:56px;height:56px}
@media(max-width:1280px){.admin-kpi-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.admin-content-grid{grid-template-columns:1fr}.admin-actions-card{align-items:flex-start;flex-direction:column}.admin-actions-grid{justify-content:flex-start}}
@media(max-width:760px){.admin-hero{padding:22px}.admin-hero-row{flex-direction:column;align-items:flex-start}.admin-hero-badge{text-align:left}.admin-kpi-grid{grid-template-columns:1fr}.admin-actions-grid{width:100%;display:grid;grid-template-columns:1fr}.admin-actions-grid .btn{width:100%}}
.info-box.soft-note{border:1px solid #dbe7f3;border-radius:18px;background:linear-gradient(180deg,#f8fbff 0%,#ffffff 100%);padding:20px;margin:8px 0 4px}.info-box.soft-note h3{margin:6px 0;color:#172338}.info-box.soft-note p{margin:0 0 14px;color:#66788f;max-width:920px;line-height:1.55}.actions-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}

/* Personal como fuente de licencias */
.license-only-panel{margin-top:18px}.license-only-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px}.license-person-card{border:1px solid var(--line);border-radius:16px;background:linear-gradient(180deg,#fff 0%,#f8fbff 100%);padding:16px;display:grid;gap:9px;box-shadow:0 8px 22px rgba(0,39,80,.04)}.license-person-card strong{display:block;color:var(--ink);font-size:15px}.license-person-card span{display:block;color:#61738a;font-size:12px;margin-top:2px;overflow-wrap:anywhere}.license-person-card small{width:max-content;border-radius:999px;background:#eef7fb;border:1px solid #cfe4ee;color:var(--duam-blue);font-weight:900;font-size:11px;padding:4px 8px}.license-person-card p{color:#53657e;font-size:13px;line-height:1.35;margin:0;overflow-wrap:anywhere}.danger-zone{border-color:#f5c2c7;background:linear-gradient(180deg,#fff 0%,#fff8f8 100%)}.btn.danger{background:#b42318;color:#fff;border-color:#9f1f17}.btn.danger:hover{box-shadow:0 10px 22px rgba(180,35,24,.18)}
