:root{
  --bg:#0b1020;
  --card:#0f1730;
  --muted:#9aa7c7;
  --text:#e7ecff;
  --border:rgba(255,255,255,.08);
  --ok:#1f9d55;
  --err:#e11d48;
  --warn:#f59e0b;
  --primary:#6d28d9;
  --cyan:#22d3ee;
  --pink:#f472b6;
  --surface:rgba(15,23,48,.82);
  --shadow:0 10px 30px rgba(0,0,0,.35);
}
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif;background:radial-gradient(circle at 18% -10%,rgba(109,40,217,.22),transparent 26%),radial-gradient(circle at 90% 8%,rgba(34,211,238,.12),transparent 26%),linear-gradient(180deg,#060a16,#0b1020);color:var(--text)}
a{color:inherit;text-decoration:none}
.muted{color:var(--muted)}
.svg-sprite{position:absolute;width:0;height:0;overflow:hidden}
.btn-ico{width:17px;height:17px;fill:currentColor;flex:0 0 auto}
.iconbtn svg,.side-nav svg,.brand-avatar svg,.title-mark svg,.kpi-ico svg{width:20px;height:20px;fill:currentColor}
.container{max-width:1100px;margin:0 auto;padding:16px 16px 92px}

/* Topbar */
.topbar{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:14px}
.topbar h1{font-size:22px;margin:0}
.topbar p{margin:6px 0 0;color:var(--muted);font-size:13px}
.topbar-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;justify-content:flex-end}

.badge{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border:1px solid var(--border);border-radius:999px;color:var(--muted);font-size:12px;background:rgba(255,255,255,.03)}
.chip{display:inline-flex;align-items:center;padding:5px 10px;border-radius:999px;font-size:12px;border:1px solid var(--border)}
.chip.draft{background:rgba(109,40,217,.12);color:#cdb5ff}
.chip.active{background:rgba(31,157,85,.12);color:#b7f7d3}
.chip.closed{background:rgba(245,158,11,.12);color:#ffe2b3}
.chip.used{background:rgba(255,255,255,.10);color:#d5ddff}
.chip.cancelled{background:rgba(225,29,72,.14);color:#ffd0db}

.row{display:flex;gap:12px;align-items:stretch}
.card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:14px;box-shadow:var(--shadow)}
.kpi{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:14px;flex:1;box-shadow:var(--shadow)}
.kpi .n{font-size:34px;font-weight:800;margin:10px 0 6px}

hr{border:none;border-top:1px solid var(--border);margin:14px 0}

label{display:block;color:var(--muted);font-size:12px;margin:0 0 6px}
input,select,textarea{width:100%;padding:12px;border-radius:12px;border:1px solid var(--border);background:rgba(255,255,255,.03);color:var(--text);outline:none}
textarea{min-height:86px;resize:vertical}

button{border:1px solid rgba(255,255,255,.1);background:linear-gradient(135deg,var(--primary),#8b5cf6);color:#fff;padding:12px 14px;border-radius:12px;font-weight:800;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 12px 28px rgba(109,40,217,.18);transition:transform .16s ease, border-color .16s ease, background .16s ease}
button:hover{transform:translateY(-1px);border-color:rgba(255,255,255,.18)}
button.secondary{background:rgba(255,255,255,.06);box-shadow:none}
button.danger{background:rgba(225,29,72,.18);border-color:rgba(225,29,72,.35)}
button:disabled{opacity:.55;cursor:not-allowed}

/* Tabs / botones de navegación internos (Dashboard) */
.tabbar{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.tabbar a{display:inline-flex;align-items:center;gap:8px;padding:12px 14px;border-radius:14px;border:1px solid var(--border);background:rgba(255,255,255,.03);color:#fff;font-weight:800;font-size:13px}
.tabbar a .ico{font-size:16px;line-height:1}
.tabbar a:active{transform:translateY(1px)}

.notice{border:1px solid var(--border);padding:12px 14px;border-radius:14px;display:none;margin-top:10px;font-weight:800;line-height:1.35;box-shadow:0 10px 24px rgba(0,0,0,.18)}
.notice.ok{border-color:rgba(31,157,85,.42);background:linear-gradient(135deg,rgba(31,157,85,.22),rgba(31,157,85,.08))}
.notice.err{border-color:rgba(225,29,72,.42);background:linear-gradient(135deg,rgba(225,29,72,.22),rgba(225,29,72,.08))}
.notice.warn{border-color:rgba(245,158,11,.42);background:linear-gradient(135deg,rgba(245,158,11,.22),rgba(245,158,11,.08))}
.notice.muted{border-color:var(--border);background:rgba(255,255,255,.04);color:var(--muted);font-weight:700}
.notice.pulse{animation:noticePulse .45s ease}

/* Tables */
.table{width:100%;border-collapse:collapse}
.table th,.table td{padding:10px;border-bottom:1px solid var(--border);text-align:left;font-size:13px}
.table th{color:var(--muted);font-weight:700}

/* Responsive cards list */
.list{display:flex;flex-direction:column;gap:10px}
.item{border:1px solid var(--border);border-radius:14px;padding:12px;background:rgba(255,255,255,.03)}
.item-title{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}
.item-title h3{margin:0;font-size:15px}
.item-meta{color:var(--muted);font-size:12px;margin-top:6px;line-height:1.35}
.item-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}

/* Bottom nav (mobile) */
.bottomnav{position:fixed;left:0;right:0;bottom:0;background:rgba(8,12,24,.92);backdrop-filter: blur(10px);border-top:1px solid var(--border);padding:8px 10px;display:flex;gap:8px;justify-content:space-around;z-index:50}
.bottomnav a{flex:1;text-align:center;padding:10px 8px;border-radius:14px;border:1px solid transparent;color:var(--muted);font-size:12px;display:flex;flex-direction:column;align-items:center;gap:4px}
.bottomnav .nav-ico{font-size:18px;line-height:1}
.bottomnav .nav-txt{font-size:12px;line-height:1}
.bottomnav a.active{border-color:var(--border);background:rgba(255,255,255,.04);color:#fff}

/* Toasts */
.toast-wrap{position:fixed;left:0;right:0;bottom:78px;display:flex;flex-direction:column;gap:10px;align-items:center;z-index:220;padding:0 12px;pointer-events:none}
.toast{max-width:560px;width:100%;border:1px solid var(--border);border-radius:16px;padding:13px 15px;background:rgba(12,18,38,.96);box-shadow:0 18px 44px rgba(0,0,0,.38);color:#fff;font-size:14px;pointer-events:auto;display:flex;align-items:flex-start;gap:10px;animation:toastIn .22s ease}
.toast::before{content:"";width:10px;height:10px;border-radius:999px;margin-top:5px;background:var(--muted);box-shadow:0 0 0 5px rgba(255,255,255,.04)}
.toast.ok{border-color:rgba(41, 201, 95, .45);background:linear-gradient(135deg,rgba(20,88,58,.96),rgba(12,18,38,.96))}
.toast.ok::before{background:#29c95f}
.toast.err{border-color:rgba(255, 77, 77, .45);background:linear-gradient(135deg,rgba(112,28,45,.96),rgba(12,18,38,.96))}
.toast.err::before{background:#ff4d4d}
.toast.warn{border-color:rgba(245,158,11,.48);background:linear-gradient(135deg,rgba(117,74,12,.96),rgba(12,18,38,.96))}
.toast.warn::before{background:#f59e0b}
.toast.muted{border-color:var(--border)}
.toast.out{opacity:0;transform:translateY(6px);transition:opacity .2s ease, transform .2s ease}
.is-selected-event{outline:2px solid rgba(41,201,95,.7);box-shadow:0 0 0 5px rgba(41,201,95,.11), var(--shadow)}

@keyframes toastIn{from{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes noticePulse{0%{transform:translateY(-2px);box-shadow:0 0 0 rgba(41,201,95,0)}60%{transform:translateY(0);box-shadow:0 0 0 5px rgba(41,201,95,.11)}100%{box-shadow:0 10px 24px rgba(0,0,0,.18)}}

/* Modal */
.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.55);display:none;align-items:flex-end;justify-content:center;z-index:80}
.modal{width:100%;max-width:720px;background:var(--card);border:1px solid var(--border);border-radius:18px 18px 0 0;padding:14px;box-shadow:var(--shadow)}
.modal h2{margin:0 0 10px;font-size:16px}
.modal .footer{display:flex;gap:10px;justify-content:flex-end;margin-top:12px}

/* Modal (overlay) usado por openModal() en app.js */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.62);backdrop-filter: blur(10px);display:flex;align-items:flex-end;justify-content:center;z-index:180;padding:12px}
.modal-overlay .modal{width:100%;max-width:min(760px, calc(100vw - 24px));max-height:calc(100vh - 24px);border-radius:18px 18px 0 0;padding:0;overflow:hidden;display:flex;flex-direction:column}
.modal-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 16px 12px;border-bottom:1px solid var(--border);background:rgba(255,255,255,.025)}
.modal-head h2{margin:0;font-size:17px;line-height:1.25}
.modal-head .icon{width:42px;height:42px;border-radius:14px;border:1px solid var(--border);background:rgba(255,255,255,.04);color:#fff;font-size:22px;line-height:1}
.modal-body{padding:16px;overflow:auto;min-height:0}
.modal-actions{display:flex;gap:10px;justify-content:flex-end;padding:12px 16px;border-top:1px solid var(--border);background:rgba(8,12,24,.82);flex-wrap:wrap}
.modal-actions button:only-child{min-width:180px}
.modal-actions .danger{background:#ff4d4d;border-color:transparent}
.modal-form{display:grid;gap:14px}
.modal-section{border:1px solid var(--border);background:rgba(255,255,255,.025);border-radius:16px;padding:14px}
.modal-section-title{font-weight:900;margin:0 0 4px;font-size:14px}
.modal-section-help{color:var(--muted);font-size:12px;line-height:1.4;margin:0 0 12px}
.modal-body .form{display:grid;gap:12px}
.modal-body .actions{display:flex;gap:10px;flex-wrap:wrap}
.modal-body .tablewrap{width:100%;overflow-x:auto;border:1px solid var(--border);border-radius:14px;background:rgba(255,255,255,.025)}
.modal-body .tablewrap table{min-width:620px;width:100%;border-collapse:collapse}
.modal-body .tablewrap th,
.modal-body .tablewrap td{padding:10px;border-bottom:1px solid var(--border);vertical-align:middle}
.modal-body .tablewrap tr:last-child td{border-bottom:0}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.form-grid.one{grid-template-columns:1fr}
.field-full{grid-column:1 / -1}
.color-field{display:flex;align-items:center;gap:10px}
.color-field input[type="color"]{width:54px;height:44px;padding:4px;flex:0 0 auto}
.field-hint{display:block;color:var(--muted);font-size:11px;margin-top:6px;line-height:1.35}
.modal-body > .grid{display:grid!important;grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:14px!important}
.modal-body > .grid > div:has(textarea),
.modal-body > .grid > div:has(input[type="file"]),
.modal-body > .grid > div:has(img),
.modal-body > .grid > div:has(.notice){grid-column:1 / -1}
.modal-body .row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;align-items:end}
.modal-body label{font-weight:800;color:#c6d1ee;letter-spacing:.1px}
.modal-body input,
.modal-body select,
.modal-body textarea{min-height:46px;background:rgba(255,255,255,.045)}
.modal-body textarea{line-height:1.45}
.modal-body input[type="color"]{height:46px;padding:4px}
.modal-body small.muted{display:block;margin-top:8px;line-height:1.35}
.modal-body img[id$="_preview"]{border:1px solid var(--border);background:rgba(255,255,255,.035)}

@media (min-width: 860px){
  .modal-overlay{align-items:center}
  .modal-overlay .modal{border-radius:18px}
}

@media (max-width: 640px){
  .modal-overlay{padding:0;align-items:stretch}
  .modal-overlay .modal{max-width:100%;max-height:100vh;border-radius:0}
  .modal-head{padding:14px}
  .modal-body{padding:14px 12px 18px}
  .modal-actions{position:sticky;bottom:0;display:grid;grid-template-columns:1fr 1fr;padding:10px 12px}
  .modal-actions button{width:100%;min-height:46px}
  .modal-actions button:only-child{grid-column:1 / -1;min-width:0}
  .form-grid{grid-template-columns:1fr}
  .modal-body > .grid{grid-template-columns:1fr!important}
  .modal-body .row{grid-template-columns:1fr}
  .modal-section{padding:12px}
}

@media (min-width: 860px){
  .container{padding-bottom:24px}
  .modal-backdrop{align-items:center}
  .modal{border-radius:18px}
  .bottomnav{display:none}
}

@media (max-width: 860px){
  .row{flex-direction:column}
  .topbar{flex-direction:column;align-items:stretch}
  .topbar-actions{justify-content:space-between}
}

/* ---------------- Dashboard v2 (shell + sidebar) ---------------- */

.shell{min-height:100vh;display:flex}

.sidebar{width:260px;flex:0 0 260px;background:linear-gradient(180deg,rgba(16,24,48,.92),rgba(9,14,29,.94));border-right:1px solid var(--border);padding:18px 14px;position:sticky;top:0;height:100vh;box-shadow:24px 0 60px rgba(0,0,0,.18)}
.side-profile{display:flex;align-items:center;gap:12px;padding:14px 10px 18px;border-bottom:1px solid var(--border)}
.avatar{width:54px;height:54px;border-radius:18px;border:1px solid var(--border);background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));box-shadow:var(--shadow)}
.brand-avatar{display:grid;place-items:center;background:radial-gradient(circle at 30% 20%,rgba(34,211,238,.9),transparent 28%),linear-gradient(135deg,#6d28d9,#0f766e);color:#fff;border-color:rgba(255,255,255,.18)}
.brand-avatar svg{width:30px;height:30px;filter:drop-shadow(0 8px 16px rgba(0,0,0,.24))}
.side-name{font-weight:900;letter-spacing:-.02em}
.side-sub{font-size:12px}

.side-nav{display:flex;flex-direction:column;gap:10px;padding:18px 8px}
.side-nav a{display:flex;align-items:center;gap:12px;padding:13px 12px;border-radius:16px;color:#dce6ff;border:1px solid transparent;background:transparent;font-weight:850;position:relative;overflow:hidden;transition:background .18s ease, border-color .18s ease, transform .18s ease, box-shadow .18s ease}
.side-nav a::before{content:"";position:absolute;inset:0 auto 0 0;width:0;background:linear-gradient(180deg,var(--cyan),var(--primary));opacity:0;transition:width .18s ease, opacity .18s ease}
.side-nav a::after{content:"";position:absolute;right:-34px;top:-34px;width:96px;height:96px;border-radius:999px;background:radial-gradient(circle,rgba(34,211,238,.14),transparent 68%);opacity:0;transition:opacity .18s ease}
.side-nav a .ico{width:34px;height:34px;border-radius:12px;display:grid;place-items:center;color:#b9c7ef;background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.055);position:relative;z-index:1;transition:background .18s ease, color .18s ease, transform .18s ease}
.side-nav a span:not(.ico){position:relative;z-index:1}
.side-nav a:hover{background:rgba(255,255,255,.055);border-color:var(--border);transform:translateX(2px)}
.side-nav a.active{background:linear-gradient(135deg,rgba(109,40,217,.32),rgba(34,211,238,.13),rgba(15,23,48,.74));border-color:rgba(34,211,238,.24);box-shadow:0 14px 34px rgba(0,0,0,.22), inset 0 0 0 1px rgba(255,255,255,.035);transform:none}
.side-nav a.active::before{width:4px;opacity:1}
.side-nav a.active::after{opacity:1}
.side-nav a.active .ico{color:#fff;background:linear-gradient(135deg,var(--primary),var(--cyan));border-color:rgba(255,255,255,.16);box-shadow:0 10px 24px rgba(34,211,238,.15);transform:scale(1.03)}

.side-footer{padding:10px 8px;margin-top:auto}
.side-footer button{width:100%}

.main{flex:1;min-width:0}

.topbar2{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:18px 20px;border-bottom:1px solid var(--border);background:rgba(8,12,24,.72);backdrop-filter: blur(14px);position:sticky;top:0;z-index:40}
.top-left{display:flex;align-items:center;gap:12px;min-width:0}
.top-title{font-size:19px;font-weight:950;line-height:1.1;display:flex;align-items:center;gap:10px;letter-spacing:-.02em}
.title-mark{width:34px;height:34px;border-radius:12px;display:inline-grid;place-items:center;background:linear-gradient(135deg,var(--primary),var(--cyan));color:#fff;box-shadow:0 12px 28px rgba(34,211,238,.14)}
.top-sub{font-size:13px}
.top-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}

.iconbtn{width:42px;height:42px;border-radius:14px;border:1px solid var(--border);background:rgba(255,255,255,.04);color:#fff;font-size:18px;display:inline-flex;align-items:center;justify-content:center}
.iconbtn:hover{background:rgba(255,255,255,.06)}

.select{appearance:none;-webkit-appearance:none;background:rgba(255,255,255,.04);border:1px solid var(--border);color:#fff;border-radius:14px;padding:10px 12px;min-width:240px}

.dash-grid{display:grid;grid-template-columns:repeat(4, minmax(0,1fr));gap:16px;margin-top:14px}
.kpi2{position:relative;overflow:hidden;background:linear-gradient(145deg,rgba(24,33,66,.92),rgba(13,20,43,.92));border-color:rgba(255,255,255,.09)}
.kpi2::before{content:"";position:absolute;inset:0 auto auto 0;width:4px;height:100%;background:linear-gradient(180deg,var(--primary),var(--cyan));opacity:.9}
.kpi2::after{content:"";position:absolute;right:-34px;top:-34px;width:110px;height:110px;border-radius:999px;background:radial-gradient(circle,rgba(255,255,255,.08),transparent 64%)}
.kpi2 .kpi-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.kpi-label{color:#aebcf0;font-size:12px;font-weight:900;letter-spacing:.08em;text-transform:uppercase}
.kpi-value{font-size:32px;font-weight:950;margin-top:8px;letter-spacing:-.04em}
.kpi-ico{width:48px;height:48px;border-radius:17px;border:1px solid rgba(255,255,255,.1);background:linear-gradient(135deg,rgba(255,255,255,.1),rgba(255,255,255,.025));display:flex;align-items:center;justify-content:center;font-size:20px;color:#dbeafe}

.ring{--p:0;width:44px;height:44px;border-radius:999px;border:1px solid var(--border);background:conic-gradient(rgba(41, 201, 95, .9) calc(var(--p) * 1%), rgba(255,255,255,.06) 0);position:relative}
.ring::after{content:"";position:absolute;inset:6px;border-radius:999px;background:rgba(8,12,24,.92);border:1px solid rgba(255,255,255,.04)}

.dash-split{display:grid;grid-template-columns:1.2fr .8fr;gap:16px;margin-top:16px}
.card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.h2{margin:0;font-size:17px;letter-spacing:-.02em}

.event-summary{padding:16px;border:1px solid rgba(255,255,255,.09);border-radius:18px;background:linear-gradient(135deg,rgba(255,255,255,.055),rgba(255,255,255,.018));margin-top:14px;position:relative;overflow:hidden}
.event-summary::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,var(--cyan),var(--primary))}
.event-title{font-size:21px;font-weight:950;letter-spacing:-.03em}
.event-meta{margin-top:6px;line-height:1.35}

.quick-actions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:14px}
.quick-actions .btnlink, .quick-actions button{min-width:0}
.btnlink{border:1px solid var(--border);background:rgba(255,255,255,.06);border-radius:12px;padding:12px 14px;font-weight:850;display:inline-flex;align-items:center;justify-content:center;gap:8px}
.btnlink:hover{border-color:rgba(255,255,255,.16);background:rgba(255,255,255,.085)}
.btnlink-ghost{background:transparent;border-color:transparent;padding:4px 0;color:#fff}
.quick-actions button:first-child{grid-column:span 1;background:linear-gradient(135deg,#7c3aed,#9333ea)}
.quick-actions #btnExport{grid-column:span 1}

.mini-bars{height:140px;display:flex;align-items:flex-end;gap:8px;padding:12px;border:1px solid var(--border);border-radius:16px;background:rgba(255,255,255,.02);margin-top:12px}
.mini-bars .bar{flex:1;border-radius:10px;background:rgba(41, 201, 95, .35);border:1px solid rgba(41, 201, 95, .25)}

/* Responsive behavior */
@media (max-width: 980px){
  .dash-grid{grid-template-columns:repeat(2, minmax(0,1fr))}
  .dash-split{grid-template-columns:1fr}
  .quick-actions{grid-template-columns:repeat(2,minmax(0,1fr))}
  .select{min-width:200px}
}

@media (max-width: 860px){
  .sidebar{position:fixed;left:0;top:0;bottom:0;transform:translateX(-105%);transition:transform .2s ease;z-index:60;background:rgba(8,12,24,.98)}
  .shell.side-open .sidebar{transform:translateX(0)}
  .sidebar::after{content:"";position:fixed;inset:0;background:rgba(0,0,0,.45);left:260px;display:none}
  .shell.side-open .sidebar::after{display:block}
  .topbar2{padding:12px 12px}
  .top-right{gap:8px}
  .select{min-width:160px}
  .quick-actions{grid-template-columns:1fr}
  .title-mark{display:none}
}

@media (min-width: 861px){
  #btnMenu{display:none}
}


/* === Iter3 fixes: selects + modal/drawer === */
.select{font-size:16px; line-height:1.2;}
select option{color:#111; background:#fff;}
/* prevent oversized select in tight areas */
.topbar2 .select{min-width:0; max-width:360px;}
@media (max-width: 640px){
  .topbar2 .top-right{flex-wrap:wrap; gap:8px;}
  .topbar2 .top-right .select{width:100%;}
}
/* modal selects should fit */
.modal .select{min-width:0; width:100%;}
/* contextual event bar */
.eventbar{display:flex;gap:12px;align-items:center;justify-content:space-between;margin:16px 0 10px 0;flex-wrap:wrap;background:linear-gradient(135deg,rgba(24,33,66,.9),rgba(14,22,46,.9));border-radius:18px}
.eventbar .eventbar-left{display:flex;gap:10px;align-items:center;flex:1;min-width:260px}
.eventbar label{color:var(--muted);font-size:12px}
.eventbar .select{width:100%}
.eventbar .eventbar-actions{display:flex;gap:10px;align-items:center}
@media (max-width: 640px){
  .eventbar{gap:8px}
  .eventbar .eventbar-left{min-width:100%}
  .eventbar .eventbar-actions{width:100%}
  .eventbar .eventbar-actions .secondary,
  .eventbar .eventbar-actions .primary{flex:1}
}


/* === Iter4: Próximos eventos === */
.upcoming-list{display:flex;flex-direction:column;gap:10px;margin-top:12px}
.upcoming-item{display:flex;justify-content:space-between;gap:12px;border:1px solid var(--border);background:rgba(255,255,255,.035);padding:13px;border-radius:16px}
.upcoming-item .title{font-weight:800}
.upcoming-item .meta{font-size:12px}
.badge{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:800;padding:4px 10px;border-radius:999px;border:1px solid var(--border);background:rgba(255,255,255,.03)}
.badge.active{border-color:rgba(31,157,85,.35);background:rgba(31,157,85,.12)}
.badge.draft{border-color:rgba(99,102,241,.35);background:rgba(99,102,241,.12)}
.badge.final{border-color:rgba(225,29,72,.35);background:rgba(225,29,72,.12)}

/* === Admin visual system: applied to all modules === */
.main{
  position:relative;
  background:
    radial-gradient(circle at 78% 0%, rgba(34,211,238,.11), transparent 30%),
    radial-gradient(circle at 10% 18%, rgba(109,40,217,.12), transparent 28%),
    linear-gradient(180deg, rgba(7,11,23,.98), rgba(8,13,27,.98));
}
.main::before{
  content:"";
  position:fixed;
  inset:0 0 auto 260px;
  height:220px;
  pointer-events:none;
  background:linear-gradient(90deg, rgba(109,40,217,.08), rgba(34,211,238,.08), transparent);
  opacity:.72;
  mask-image:linear-gradient(#000, transparent);
}
.container > .card:first-child,
.container > .card.section-hero{
  position:relative;
  overflow:hidden;
  border-radius:20px;
  padding:20px;
  background:
    radial-gradient(circle at 92% 12%, rgba(139,92,246,.22), transparent 28%),
    linear-gradient(145deg, rgba(21,31,63,.94), rgba(14,22,46,.92));
  border-color:rgba(255,255,255,.1);
}
.container > .card:first-child::after,
.container > .card.section-hero::after{
  content:"";
  position:absolute;
  right:-42px;
  top:-42px;
  width:150px;
  height:150px;
  border-radius:999px;
  background:radial-gradient(circle, rgba(34,211,238,.16), transparent 68%);
}
.container > .card:first-child > *,
.container > .card.section-hero > *{position:relative;z-index:1}

.grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:14px;
}
.grid > .card,
#tplList > .card,
#attendeesList > .card,
#typesList > .card,
#eventsList > .card{
  background:linear-gradient(145deg,rgba(19,29,60,.92),rgba(13,20,43,.92));
  border-color:rgba(255,255,255,.09);
}
#tplList,
#attendeesList{
  display:grid;
  gap:12px;
}

.card h2,.card h3{
  letter-spacing:-.025em;
}
.card h2{
  font-size:clamp(22px,2.2vw,30px);
  line-height:1.05;
}
.card h3{
  font-size:20px;
}
.card .muted b{color:#dce6ff}

input:focus,
select:focus,
textarea:focus{
  border-color:rgba(34,211,238,.46);
  box-shadow:0 0 0 4px rgba(34,211,238,.1);
}
button.primary,
.primary{
  background:linear-gradient(135deg,#7c3aed,#22d3ee);
  border-color:rgba(255,255,255,.16);
}
.actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
}
.actions button,
.actions .btnlink{
  min-height:44px;
}

.tablewrap{
  width:100%;
  overflow-x:auto;
  border:1px solid var(--border);
  border-radius:16px;
  background:rgba(255,255,255,.025);
}
.tablewrap table{
  min-width:620px;
  width:100%;
  border-collapse:collapse;
}
.tablewrap th,
.tablewrap td{
  padding:11px 12px;
  border-bottom:1px solid var(--border);
  text-align:left;
}
.tablewrap tr:last-child td{border-bottom:0}
.tablewrap th{color:#aebcf0;font-size:12px;text-transform:uppercase;letter-spacing:.08em}

.side-nav svg,
.bottomnav svg,
.top-title svg,
.iconbtn svg{
  width:20px;
  height:20px;
  fill:currentColor;
  display:block;
}
.bottomnav{
  background:linear-gradient(180deg,rgba(13,20,43,.94),rgba(7,11,23,.98));
}
.bottomnav a{
  min-width:0;
}
.bottomnav .nav-ico{
  width:26px;
  height:22px;
  display:grid;
  place-items:center;
}
.bottomnav a.active{
  background:linear-gradient(135deg,rgba(109,40,217,.28),rgba(34,211,238,.1));
  box-shadow:inset 0 2px 0 rgba(34,211,238,.5);
}

.eventbar{
  position:relative;
  overflow:hidden;
}
.eventbar::before{
  content:"";
  position:absolute;
  inset:0 auto 0 0;
  width:4px;
  background:linear-gradient(180deg,var(--cyan),var(--primary));
}
.eventbar > *{position:relative;z-index:1}

@media (max-width: 860px){
  .main::before{inset:0;height:180px}
  .container{padding-left:12px;padding-right:12px}
  .container > .card:first-child{padding:16px}
}

@media (max-width: 430px){
  .bottomnav{gap:4px;padding-left:6px;padding-right:6px}
  .bottomnav a{padding:8px 4px}
  .bottomnav .nav-txt{font-size:10.5px}
}
