:root{--green:#008f43;--dark:#073f25;--dark2:#003b20;--soft:#eef7f2;--line:#d6e5de;--ink:#0d2438;--muted:#66788a;--white:#fff;--shadow:0 20px 45px #1f3d3020;--blue:#1f4256;--btn:#647684}
*{box-sizing:border-box}body{margin:0;font-family:Arial,Helvetica,sans-serif;color:var(--ink);background:#f3f6f8}a{text-decoration:none}button,input,select,textarea{font-family:inherit}.public-body{background:#f4f6f8}.public-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px}.login-card{width:420px;max-width:100%;background:#fff;border-radius:18px;padding:34px 36px 30px;box-shadow:var(--shadow);text-align:left}.login-logo{display:block;width:255px;max-width:86%;margin:0 auto 12px}.portal-name{text-align:center;font-size:16px;margin:8px 0 30px;color:#08192b}.login-card label{display:block;margin:16px 0 8px;color:#06162a;font-size:14px}.login-card input,.login-card select{width:100%;height:52px;border:1px solid #cfd8e2;border-radius:9px;padding:0 16px;font-size:16px;background:#fff;color:#344357}.login-card select{appearance:auto}.green-btn{width:100%;height:52px;border:0;border-radius:9px;background:#0b8c43;color:#fff;font-size:16px;font-weight:800;cursor:pointer;margin-top:18px}.green-btn:hover{background:#087737}.soft-btn,.btn{display:inline-block;border:0;border-radius:14px;background:#657889;color:#fff;font-weight:800;padding:10px 18px;min-width:105px;cursor:pointer;text-align:center;text-decoration:none}.soft-btn:hover,.btn:hover,.green-btn:hover{filter:brightness(.96)}.otp-area{margin-top:20px;text-align:center;border-top:1px solid #edf1f4;padding-top:18px}.otp-area strong,.otp-area span{display:block;font-size:13px}.otp-area input{height:42px;text-align:center;margin:10px 0}.login-foot{text-align:center;margin:18px 0 8px;color:#4d5a66;font-size:14px}.big-fexpo{font-weight:900;font-size:56px;line-height:.85;color:#777;text-align:center;margin-top:30px;letter-spacing:-3px}.big-fexpo:before{content:'X';color:#009b49;display:inline-block;transform:translate(69px,24px);font-size:58px}.big-fexpo span{color:#909090}.public-flash{width:420px;max-width:100%}.flash{background:#fff8e5;border:1px solid #f2d27a;color:#62420a;border-radius:12px;padding:13px 16px;margin:0 0 18px}.canvas{width:min(920px,100%);min-height:720px;background:#f1f4f9;box-shadow:0 2px 8px #0002;padding:58px 54px}.title{font-size:28px;font-weight:800;text-align:center;margin:10px 0}.subtitle{font-weight:700;text-align:center;margin-bottom:30px}.section-title{font-size:20px;font-weight:800;margin:20px 0 32px}.grid{display:grid;grid-template-columns:1fr 1fr;gap:22px 42px}.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:22px 28px}.field label{display:block;font-size:14px;margin-bottom:8px}.req:before{content:'*';font-weight:800;margin-right:13px}.field input,.field select,.field textarea,.control{width:100%;border:2px solid #203647;height:34px;background:#fff;padding:6px 10px;font-size:14px}.field textarea{height:92px;resize:vertical}.btn-danger{background:#b80000}.btn-ok{background:#0b8c43}.center{text-align:center}.mt{margin-top:28px}.hint{font-style:italic;line-height:1.35;margin-top:40px}.filebox{border:2px solid #203647;background:white;padding:14px;min-height:78px}.people-list{margin-top:40px;background:white;padding:18px}.person-row{display:grid;grid-template-columns:1fr auto;align-items:center;border-bottom:1px solid #edf1f5;padding:13px 0}.person-row:last-child{border-bottom:0}.person-name{font-weight:700}.admin-body{background:linear-gradient(135deg,#edf7f2,#f5fbf8);min-height:100vh}.admin-shell{display:flex;min-height:100vh}.side{width:294px;background:linear-gradient(180deg,#063f26,#00391f);color:#fff;padding:16px 11px;position:sticky;top:0;height:100vh;transition:.22s width;box-shadow:8px 0 30px #0b2f2024}.side-brand{display:flex;align-items:center;gap:12px;border-bottom:1px solid #ffffff22;padding:0 0 16px;margin-bottom:18px}.side-brand img{width:45px;height:45px;object-fit:contain;background:#fff;border-radius:50%;padding:4px}.side-brand strong{display:block;font-size:17px}.side-brand span{display:block;font-size:12px;color:#b8d2c5}.pin{margin-left:auto;background:#ffffff18;border:1px solid #ffffff12;color:#fff;width:39px;height:39px;border-radius:13px;cursor:pointer}.side-nav a,.logout-form button{width:100%;display:flex;align-items:center;gap:12px;color:#c6d9cf;background:transparent;border:0;border-radius:18px;padding:12px 4px 12px 2px;margin:8px 0;font-weight:900;letter-spacing:.2px;cursor:pointer}.side-nav a span,.logout-form span{width:42px;height:42px;display:grid;place-items:center;background:#1d6b49;border-radius:14px;color:#fff;font-size:21px}.side-nav a b,.logout-form b{font-size:13px}.side-nav a em{margin-left:auto;width:26px;height:26px;display:grid;place-items:center;background:#ffffff14;border-radius:50%;font-style:normal}.side-nav a.active,.side-nav a:hover,.logout-form button:hover{background:#ffffff10;color:#fff}.logout-form{position:absolute;left:11px;right:11px;bottom:16px}.side-collapsed .side{width:78px}.side-collapsed .side-brand div,.side-collapsed .side-nav b,.side-collapsed .side-nav em,.side-collapsed .logout-form b{display:none}.admin-main{flex:1;padding:24px 24px 60px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:20px;background:#fff;border:1px solid #dbeee6;border-radius:22px;padding:20px 22px;margin-bottom:22px;box-shadow:0 18px 44px #1d583526}.topbar h1{margin:0;font-size:30px;color:#1a2d40}.topbar p{margin:7px 0 0;color:#657789}.top-actions{display:flex;align-items:center;gap:12px}.top-search{height:48px;min-width:290px;border:1px solid #d3e7df;border-radius:24px;display:flex;align-items:center;gap:10px;padding:0 16px;background:#fbfffd}.top-search input{border:0;outline:0;background:transparent;width:100%;color:#657789}.user-chip{height:48px;background:#fff;border:1px solid #d3e7df;border-radius:24px;display:flex;align-items:center;gap:10px;padding:0 16px;color:#657789;white-space:nowrap}.user-chip span{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;background:#06a84f;color:#fff;font-weight:900}.card{background:white;border:1px solid #dbeee6;border-radius:22px;padding:22px;margin-bottom:20px;box-shadow:0 16px 38px #1d58351a}.toolbar{display:flex;gap:12px;align-items:end;flex-wrap:wrap}.table-wrap{background:#fff;border:1px solid #dbeee6;border-radius:22px;padding:18px 20px;box-shadow:0 16px 38px #1d58351a;overflow:auto}.table{width:100%;border-collapse:collapse;background:white}.table th,.table td{border-bottom:1px solid #dbeee6;padding:15px 14px;text-align:left;font-size:14px}.table th{color:#61748a;font-size:12px;text-transform:uppercase;letter-spacing:.4px;background:#fff}.table tr:last-child td{border-bottom:0}.badge{border-radius:999px;padding:8px 12px;font-weight:900;font-size:12px;display:inline-block}.badge-warn{background:#fff3cd;color:#7a4d00}.badge-ok{background:#dff9ea;color:#057434}.badge-bad{background:#fde8e8;color:#b80000}.badge-info{background:#e8f0f7;color:#203647}.actions{display:flex;gap:10px;flex-wrap:wrap}.small{font-size:12px;color:#607080}.data-grid{display:grid;grid-template-columns:190px 1fr;gap:12px 14px}.data-grid b{color:#203647}.panel-title{font-size:16px;margin:0 0 18px}.page-title{font-size:28px;margin:0 0 8px}.muted{color:var(--muted)}@media(max-width:980px){.admin-shell{display:block}.side{position:relative;width:100%;height:auto}.logout-form{position:static}.topbar,.top-actions{display:block}.top-search,.user-chip{margin-top:12px;min-width:0}.grid,.grid3{grid-template-columns:1fr}.canvas{padding:30px 20px}.public-page{padding:20px}.side-collapsed .side{width:100%}.side-collapsed .side-brand div,.side-collapsed .side-nav b,.side-collapsed .side-nav em,.side-collapsed .logout-form b{display:block}}

/* Ajuste solicitado: tablero simple de solicitudes */
.side{width:300px}.side-nav{margin-top:20px}.side-nav a{padding:12px 10px}.admin-main{padding:28px}.topbar h1{font-size:28px}.pref-panel{background:#fff;border:1px solid #dbeee6;border-radius:20px;padding:22px;margin-bottom:20px;box-shadow:0 14px 36px #1d583516}.pref-panel h2{margin:0 0 8px;color:#14253a}.panel-headline{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.panel-headline p{margin:6px 0 0;color:#14253a}.pref-filter{display:grid;grid-template-columns:minmax(280px,1fr) auto auto;gap:12px;align-items:end;margin:16px 0}.field.compact label,.field.modern label{font-weight:800;font-size:13px;margin-bottom:8px;color:#102238}.field.compact input,.field.modern input,.field.modern select,.field.modern textarea{border:1px solid #cfe1da;border-radius:10px;background:#fff;height:48px;padding:0 14px;color:#23364a;font-size:14px;outline:none}.field.modern textarea{height:96px;padding-top:12px}.green-filter{border:0;border-radius:12px;background:#009b49;color:#fff;font-weight:900;padding:14px 22px;min-height:48px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.clear-filter{border:0;border-radius:12px;background:#e8f8ef;color:#00863e;font-weight:900;padding:14px 22px;min-height:48px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.metric-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:12px 0 18px}.metric-card{border:1px solid #d4e5dd;border-radius:16px;padding:18px;background:#fbfefd}.metric-card b{display:block;font-size:13px;color:#0d1e32}.metric-card strong{display:block;margin-top:12px;font-size:28px;color:#008342}.kanban{display:grid;gap:12px}.kanban-3{grid-template-columns:repeat(3,minmax(0,1fr))}.kanban-col{border:1px solid #d4e5dd;border-radius:16px;background:#fbfefd;min-height:520px;padding:10px}.kanban-title{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.kanban-title h3{margin:0;font-size:16px;color:#0d1e32}.kanban-title span{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;background:#eef3f7;font-weight:900;color:#0d1e32}.kanban-drop{border:1px dashed #cbdbe5;border-radius:14px;min-height:455px;padding:10px;background:#fff}.empty-card{display:grid;place-items:center;text-align:center;color:#55708a;min-height:86px;border:1px dashed #cbdbe5;border-radius:12px;background:#fff}.request-card{border:1px solid #d9e8e1;border-radius:16px;background:#fff;padding:14px;margin-bottom:12px;box-shadow:0 8px 18px #1d58350f}.request-top{display:flex;justify-content:space-between;gap:10px;align-items:start}.request-card strong{color:#0d1e32}.request-card p{margin:8px 0;color:#4d6074;font-size:13px}.request-card small{display:block;margin-bottom:12px;color:#66788a}.review-btn{min-width:100%;border-radius:12px;background:#657889}.modal-backdrop{display:none;position:fixed;inset:0;background:#0b1d2dcc;z-index:50;align-items:center;justify-content:center;padding:22px}.modal-backdrop.show{display:flex}.modal-box{background:#fff;border-radius:22px;max-width:720px;width:100%;max-height:90vh;overflow:auto;padding:24px;box-shadow:0 24px 80px #0006;position:relative}.modal-wide{max-width:1060px}.reject-box{max-width:600px}.modal-close{position:absolute;right:14px;top:12px;border:0;background:#eef3f7;border-radius:50%;width:34px;height:34px;font-size:22px;cursor:pointer}.modal-box h2{margin:0 0 8px;color:#13263a}.modal-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:18px 0}.modal-grid div{border:1px solid #dceae4;border-radius:14px;padding:12px;background:#fbfefd}.modal-grid b{display:block;color:#607084;font-size:12px;text-transform:uppercase;margin-bottom:6px}.modal-grid span{color:#102238}.modal-grid .full{grid-column:1/-1}.modal-subtitle{margin:20px 0 10px}.mini-table-wrap{border:1px solid #dbeee6;border-radius:16px;overflow:auto}.mini-table th,.mini-table td{padding:12px}.link-btn{display:inline-flex;background:#e8f8ef;color:#00813d;border-radius:10px;padding:8px 12px;font-weight:900}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:18px}.btn-danger{background:#b32121!important;color:#fff}.flash{white-space:pre-wrap}

/* Formularios públicos con estilo visual Pre Feria */
.public-body{background:linear-gradient(135deg,#eef8f3,#f7fbf9)}.public-page{justify-content:flex-start}.public-form-page{width:min(1200px,100%);margin:0 auto}.public-form-head{display:flex;align-items:center;gap:18px;background:#fff;border:1px solid #dbeee6;border-radius:22px;padding:18px 22px;margin:0 0 20px;box-shadow:0 14px 36px #1d583516}.public-form-head img{width:190px;max-width:40%;object-fit:contain}.public-form-head h1{margin:0;color:#14253a;font-size:26px}.public-form-head p{margin:6px 0 0;color:#657789}.public-panel{padding:26px}.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}.form-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.upload-card{border:1px dashed #cbdbe5;background:#fbfefd;border-radius:14px;padding:18px;min-height:96px;display:flex;align-items:center}.upload-card input{border:0!important;height:auto!important;padding:0!important}.help-card{border:1px solid #dbeee6;background:#fbfefd;border-radius:14px;padding:18px;font-style:italic;line-height:1.4;color:#33495c;display:flex;align-items:center}.big-action{font-size:15px;min-width:170px}.people-cards{display:grid;gap:10px}.person-card{display:flex;align-items:center;justify-content:space-between;gap:16px;border:1px solid #dbeee6;background:#fff;border-radius:16px;padding:14px}.person-card strong{color:#0d1e32}.person-card p{margin:6px 0;color:#4d6074}.icon-danger{border:0;border-radius:10px;background:#fde8e8;color:#b32121;font-weight:900;padding:10px 14px;cursor:pointer}.req:before{color:#0d1e32}.login-card{border:1px solid #dbeee6}.login-card input,.login-card select{border:1px solid #cfd8e2}.login-card label{font-weight:700}.green-btn{background:#009b49}.portal-name{color:#14253a}

@media(max-width:1100px){.kanban-3,.metric-row,.form-grid-3{grid-template-columns:1fr}.pref-filter{grid-template-columns:1fr}.modal-grid,.form-grid-2{grid-template-columns:1fr}.public-form-head{display:block;text-align:center}.public-form-head img{max-width:80%;margin-bottom:12px}.kanban-col{min-height:auto}.kanban-drop{min-height:160px}}

/* ===== MODERNIZACION FINAL: sidebar hover, usuarios, validaciones visuales ===== */
.admin-body{background:radial-gradient(circle at top left,#e8f6ef 0,#f6fbf8 32%,#eef6f2 100%)}
.admin-shell{display:flex;min-height:100vh;align-items:stretch}
.side{position:fixed!important;left:0;top:0;bottom:0;width:82px!important;min-width:82px!important;background:linear-gradient(180deg,#064828,#003f25)!important;transition:width .28s ease,box-shadow .28s ease;overflow:hidden;z-index:20;box-shadow:16px 0 40px rgba(2,48,27,.13)}
.side:hover{width:292px!important;box-shadow:24px 0 54px rgba(2,48,27,.22)}
.admin-main{margin-left:82px!important;width:calc(100% - 82px)!important;transition:margin-left .28s ease,width .28s ease;padding:28px 32px!important}
.side-brand{height:86px!important;padding:16px 12px!important;display:flex!important;align-items:center!important;gap:12px;border-bottom:1px solid rgba(255,255,255,.14)}
.side-brand img{width:48px!important;height:48px!important;border-radius:16px;background:#fff;padding:4px;object-fit:contain;flex:0 0 48px}
.side-brand div{opacity:0;transform:translateX(-8px);transition:.22s ease;white-space:nowrap;color:#fff;min-width:180px}.side:hover .side-brand div{opacity:1;transform:translateX(0)}
.side-brand strong{display:block;color:#fff;font-size:18px;letter-spacing:.03em}.side-brand span{display:block;color:#bfd9ce;font-size:12px;margin-top:2px}.pin{display:none!important}
.side-nav{padding:18px 8px!important;margin-top:0!important}.side-nav a,.logout-form button{height:56px;display:flex;align-items:center;gap:14px;border-radius:18px;padding:0 10px!important;color:#fff!important;background:transparent;border:0;width:100%;cursor:pointer;transition:.18s ease}.side-nav a:hover,.side-nav a.active,.logout-form button:hover{background:rgba(255,255,255,.11)!important;box-shadow:inset 0 0 0 1px rgba(255,255,255,.04)}
.side-nav span,.logout-form span{width:42px;height:42px;border-radius:14px;background:rgba(31,151,94,.55);display:grid!important;place-items:center;flex:0 0 42px;font-size:18px;color:#fff}.side-nav b,.side-nav em,.logout-form b{opacity:0;transform:translateX(-8px);transition:.2s ease;white-space:nowrap;color:#fff;letter-spacing:.04em}.side:hover .side-nav b,.side:hover .side-nav em,.side:hover .logout-form b{opacity:1;transform:translateX(0)}.side-nav em{margin-left:auto;font-style:normal;background:rgba(255,255,255,.08);width:26px;height:26px;border-radius:50%;display:grid;place-items:center}.logout-form{position:absolute!important;left:8px!important;right:8px!important;bottom:18px!important;width:auto!important}.logout-form button{font-weight:900;text-align:left}.topbar{border:1px solid #dbeee6!important;border-radius:22px!important;background:rgba(255,255,255,.88)!important;backdrop-filter:blur(14px);box-shadow:0 18px 42px rgba(16,61,40,.12)!important}.topbar h1{font-size:26px!important;color:#102238}.topbar p{color:#64798b!important}.top-search,.user-chip{background:#fbfffd!important;border:1px solid #d4eadf!important;border-radius:999px!important;box-shadow:0 8px 18px rgba(0,65,35,.04)}
.pref-panel.modern-module,.pref-panel{border-radius:22px!important;background:rgba(255,255,255,.9)!important;backdrop-filter:blur(10px);box-shadow:0 20px 48px rgba(17,73,44,.11)!important}.kanban-col{background:linear-gradient(180deg,#fbfffd,#f8fcfa)!important;box-shadow:0 10px 25px rgba(19,74,46,.06)}.kanban-drop{background:rgba(255,255,255,.75)!important}.request-card{transition:transform .18s ease,box-shadow .18s ease}.request-card:hover{transform:translateY(-3px);box-shadow:0 16px 28px rgba(20,75,48,.15)}.green-filter{background:linear-gradient(135deg,#00a94f,#008640)!important;box-shadow:0 12px 22px rgba(0,143,67,.22)}.clear-filter{background:#eaf8f0!important}.btn,.soft-btn{transition:.18s ease}.btn:hover,.green-filter:hover,.clear-filter:hover,.soft-btn:hover{transform:translateY(-1px)}
.form-grid-4{display:grid;grid-template-columns:1.2fr 1.2fr .8fr 1fr;gap:16px}.user-create-form{margin-top:8px}.right{text-align:right}.table-modern-wrap{overflow:auto;border:1px solid #dbeee6;border-radius:18px}.modern-table{width:100%;border-collapse:collapse;background:#fff}.modern-table th{background:#f3faf6;color:#496070;font-size:12px;text-transform:uppercase;letter-spacing:.06em}.modern-table th,.modern-table td{padding:15px 16px;border-bottom:1px solid #e5f0eb;text-align:left}.modern-table tr:last-child td{border-bottom:0}.modern-table tbody tr:hover{background:#f9fdfa}
.public-body{background:radial-gradient(circle at top,#ecf8f2 0,#f7faf9 42%,#edf5f1 100%)!important}.portal-login-card{border-radius:24px!important;box-shadow:0 24px 60px rgba(25,57,43,.16)!important;border:1px solid #dbeee6!important;background:rgba(255,255,255,.96)!important}.login-logo{width:285px!important}.fexpo-login-logo{display:block;width:160px;max-width:52%;height:auto;margin:24px auto 0;opacity:.92}.public-form-page{padding-top:20px}.public-form-head{background:rgba(255,255,255,.92)!important;backdrop-filter:blur(12px);box-shadow:0 18px 45px rgba(16,61,40,.12)!important}.public-form-head img{width:250px!important}.public-panel{background:rgba(255,255,255,.93)!important}.field.modern input:valid,.field.modern select:valid,.field.modern textarea:valid{border-color:#b7dfca}.field.modern input:invalid:not(:placeholder-shown){border-color:#e4a6a6;background:#fffafa}.field.modern input:focus,.field.modern select:focus,.field.modern textarea:focus{border-color:#009b49!important;box-shadow:0 0 0 4px rgba(0,155,73,.10)}.field.modern label{color:#12263a!important}.upload-card{background:linear-gradient(180deg,#fff,#f9fdfa)!important}.help-card{background:#f4fbf7!important}.flash{border-radius:14px!important;background:#fff8df!important;border:1px solid #f3c75d!important;color:#634b0b!important;padding:14px 16px!important;margin:16px 0!important}.modal-box{border:1px solid #dbeee6}.modal-close:hover{background:#e3f3eb}.badge{border-radius:999px!important}
@media(max-width:1100px){.form-grid-4{grid-template-columns:1fr}.admin-main{padding:18px!important}.side{position:fixed!important}.topbar{display:block!important}.top-actions{margin-top:14px!important}.kanban-3,.metric-row{grid-template-columns:1fr!important}}
@media(max-width:700px){.admin-main{margin-left:0!important;width:100%!important;padding-left:92px!important}.public-form-head img{width:210px!important}.login-logo{width:240px!important}}

/* Ajustes de logos solicitados */
.side-brand{overflow:hidden!important;align-items:center!important}
.side-brand img{width:44px!important;height:44px!important;object-fit:contain!important;background:rgba(255,255,255,.98)!important;border-radius:14px!important;padding:4px!important;transition:.22s ease!important;box-shadow:0 8px 18px rgba(0,0,0,.12)!important}
.side:hover .side-brand img{width:150px!important;height:auto!important;border-radius:12px!important;padding:8px!important}
.login-logo{object-fit:contain!important;height:auto!important}
.fexpo-login-logo{object-fit:contain!important;height:auto!important}
.public-form-head img{object-fit:contain!important;height:auto!important}
@media(max-width:700px){.side:hover .side-brand img{width:44px!important;height:44px!important}}

/* ===== FIX RESPONSIVO MENU / LOGO SUPERIOR ===== */
.side{
  width:82px!important;
  min-width:82px!important;
  max-width:none!important;
  overflow:hidden!important;
}
.side:hover{
  width:292px!important;
}
.side-brand{
  height:86px!important;
  padding:14px 10px!important;
  gap:12px!important;
  overflow:hidden!important;
}
.side-brand img,
.side:hover .side-brand img{
  width:48px!important;
  height:48px!important;
  min-width:48px!important;
  max-width:48px!important;
  object-fit:contain!important;
  background:#ffffff!important;
  border-radius:16px!important;
  padding:5px!important;
  box-shadow:0 8px 18px rgba(0,0,0,.14)!important;
}
.side-brand div{
  display:block!important;
  min-width:170px!important;
  max-width:170px!important;
  overflow:hidden!important;
  white-space:nowrap!important;
}
.side-brand strong{
  max-width:160px!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
}
.side-brand span{
  max-width:160px!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
}
.admin-main{
  margin-left:82px!important;
  width:calc(100% - 82px)!important;
  transition:margin-left .28s ease,width .28s ease!important;
}
@media(min-width:1201px){
  .side:hover + .admin-main{
    margin-left:292px!important;
    width:calc(100% - 292px)!important;
  }
}
@media(max-width:1200px){
  .side:hover{width:250px!important}
  .side:hover + .admin-main{margin-left:82px!important;width:calc(100% - 82px)!important}
  .kanban-3,.metric-row{grid-template-columns:1fr!important}
  .topbar{align-items:flex-start!important;flex-wrap:wrap!important}
  .top-actions{width:100%!important;flex-wrap:wrap!important}
  .top-search{flex:1 1 260px!important;min-width:220px!important}
  .user-chip{flex:0 1 auto!important;max-width:100%!important}
}
@media(max-width:760px){
  .admin-shell{display:block!important}
  .side{
    position:sticky!important;
    top:0!important;
    left:0!important;
    right:0!important;
    width:100%!important;
    min-width:100%!important;
    height:auto!important;
    min-height:74px!important;
    padding:8px!important;
    border-radius:0!important;
    overflow:visible!important;
  }
  .side:hover{width:100%!important}
  .side-brand{height:auto!important;padding:4px 6px 8px!important;margin-bottom:8px!important}
  .side-brand div{opacity:1!important;transform:none!important;min-width:0!important;max-width:none!important}
  .side-brand img,.side:hover .side-brand img{width:42px!important;height:42px!important;min-width:42px!important;max-width:42px!important}
  .side-nav{display:flex!important;gap:8px!important;padding:0!important;overflow-x:auto!important}
  .side-nav a{width:auto!important;min-width:58px!important;height:50px!important;padding:0 8px!important;margin:0!important;flex:0 0 auto!important}
  .side-nav b,.side-nav em,.logout-form b{opacity:1!important;transform:none!important;display:block!important}
  .side-nav em{display:none!important}
  .logout-form{position:static!important;margin-top:8px!important;left:auto!important;right:auto!important;bottom:auto!important}
  .logout-form button{width:auto!important;height:48px!important;padding:0 10px!important}
  .admin-main,
  .side:hover + .admin-main{
    margin-left:0!important;
    width:100%!important;
    padding:14px!important;
  }
  .topbar{border-radius:18px!important;padding:16px!important}
  .topbar h1{font-size:22px!important}
  .top-actions{display:grid!important;grid-template-columns:1fr!important;gap:10px!important}
  .top-search,.user-chip{width:100%!important;min-width:0!important;margin-top:0!important}
  .pref-filter{grid-template-columns:1fr!important}
  .kanban-col{min-height:auto!important}
  .request-card .btn,.request-card .soft-btn{width:100%!important}
}

/* Respuesta rápida: avisos no bloqueantes */
.system-toast{position:fixed;right:24px;bottom:24px;z-index:9999;max-width:520px;padding:14px 18px;border-radius:16px;font-weight:800;box-shadow:0 18px 45px rgba(12,38,25,.22);opacity:0;transform:translateY(12px);pointer-events:none;transition:.2s ease;background:#102238;color:#fff}
.system-toast.show{opacity:1;transform:translateY(0)}
.system-toast.success{background:#087a3b;color:#fff}.system-toast.error{background:#b32121;color:#fff}.system-toast.info{background:#1f4256;color:#fff}
button:disabled{opacity:.72;cursor:not-allowed;filter:saturate(.75)}
