@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap";:root{--primary: #4f46e5;--primary-hover: #4338ca;--secondary: #e5e7eb;--secondary-hover: #d1d5db;--text-main: #111827;--text-muted: #6b7280;--bg-main: #f9fafb;--bg-card: #ffffff;--danger: #ef4444;--success: #10b981;--shadow: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--radius: .5rem;--today-color: #10b981;--today-bg: #ecfdf5;--today-border: #6ee7b7;--upcoming-color: #3b82f6;--upcoming-bg: #eff6ff;--upcoming-border: #93c5fd;--history-color: #6b7280;--history-bg: #f3f4f6;--history-border: #d1d5db}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Plus Jakarta Sans,Segoe UI,sans-serif;background:radial-gradient(circle at 0% 0%,rgba(59,130,246,.08),transparent 28%),radial-gradient(circle at 100% 0%,rgba(16,185,129,.08),transparent 24%),var(--bg-main);color:var(--text-main);line-height:1.5}button{cursor:pointer;border:none;font-family:inherit;font-size:.95rem;transition:all .2s}.app-container{height:100vh;display:flex;flex-direction:column;overflow:hidden}.app-header{position:relative;overflow:hidden;background:linear-gradient(125deg,#0f172a,#1e293b 52%,#111827);border-bottom:1px solid rgba(148,163,184,.25);box-shadow:0 14px 26px #02061747;padding:1.1rem 2rem 1rem;z-index:10;flex-shrink:0}.app-header:before,.app-header:after{content:"";position:absolute;border-radius:999px;pointer-events:none}.app-header:before{width:300px;height:300px;right:-95px;top:-180px;background:radial-gradient(circle,rgba(59,130,246,.45),transparent 68%)}.app-header:after{width:250px;height:250px;left:-100px;top:-140px;background:radial-gradient(circle,rgba(16,185,129,.32),transparent 70%)}.header-content{max-width:1200px;margin:0 auto;display:flex;justify-content:center;align-items:center;position:relative;z-index:1}.header-content h1{font-size:1.68rem;font-weight:800;letter-spacing:.02em;color:#f8fafc;text-shadow:0 8px 16px rgba(15,23,42,.45);text-align:center}.header-content nav{position:absolute;right:0;display:flex;align-items:center}.app-main{flex:1;padding:0 2rem 2rem;max-width:1200px;margin:0 auto;width:100%;overflow-y:auto}.app-footer{position:relative;background:linear-gradient(170deg,#0b1220,#111827 58%,#172554);padding:1.6rem 1.4rem 1.5rem;margin-top:1rem;text-align:center;border-top:1px solid rgba(148,163,184,.22);box-shadow:0 -12px 24px #02061740;color:#bfdbfe;overflow:hidden}.app-footer:before{content:"";position:absolute;top:-90px;left:50%;width:320px;height:180px;transform:translate(-50%);background:radial-gradient(circle,rgba(37,99,235,.35),transparent 70%);pointer-events:none}.footer-credit,.footer-contact{margin-top:.35rem;font-size:.9rem;color:#cbd5e1;position:relative;z-index:1}.app-footer p:first-child{color:#f8fafc;font-weight:600;letter-spacing:.02em;position:relative;z-index:1}.footer-links{margin-top:.85rem;position:relative;z-index:1}.link-button{background:none;color:#dbeafe;text-decoration:none;padding:0;font-size:.9rem;border-bottom:1px solid rgba(191,219,254,.75);font-weight:500}.link-button.discreet{color:#bfdbfe;opacity:.85}.link-button.discreet:hover{opacity:1}.link-button:hover{color:#fff;border-bottom-color:#fff}.badge{padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.admin-badge{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:1px solid rgba(254,202,202,.55);box-shadow:0 8px 16px #7f1d1d59}.status-badge{display:inline-block;padding:.25rem .5rem;border-radius:var(--radius);font-size:.8rem;margin-top:1rem}.status-badge.completed{background-color:var(--secondary);color:var(--text-muted)}.toolbar{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;margin-bottom:2rem;column-gap:1rem;row-gap:.75rem;position:sticky;top:0;z-index:20;padding:0 0 .5rem;background:linear-gradient(180deg,var(--bg-main) 78%,rgba(249,250,251,0))}.filters{display:flex;grid-column:2;justify-self:center;gap:.4rem;background:linear-gradient(180deg,#fff,#f3f4f6);border:1px solid #e5e7eb;padding:.35rem;border-radius:999px;box-shadow:0 8px 20px #0f172a14}.toolbar-actions{grid-column:3;justify-self:end;display:flex;gap:.5rem;flex-wrap:wrap}.filter-btn{background:transparent;padding:.5rem .85rem;border-radius:999px;color:#475569;font-weight:600;display:inline-flex;align-items:center;gap:.45rem;transition:all .2s ease}.filter-label{display:inline-flex;align-items:center;gap:.35rem}.filter-label:before{content:"";width:.5rem;height:.5rem;border-radius:999px;background:#94a3b8}.filter-btn.today .filter-label:before{background:var(--today-color)}.filter-btn.upcoming .filter-label:before{background:var(--upcoming-color)}.filter-btn.history .filter-label:before{background:var(--history-color)}.filter-count{min-width:1.5rem;height:1.5rem;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:#e2e8f0;color:#1e293b;font-size:.78rem;font-weight:700}.filter-btn:hover{background:#fff;color:#0f172a;box-shadow:0 4px 10px #0f172a1a}.filter-btn.active{box-shadow:0 8px 16px #0f172a38;color:#fff}.filter-btn.today.active{background:linear-gradient(135deg,#10b981,#059669)}.filter-btn.upcoming.active{background:linear-gradient(135deg,#3b82f6,#2563eb)}.filter-btn.history.active{background:linear-gradient(135deg,#64748b,#475569)}.filter-btn.active .filter-count{background:#fff3;color:#fff}.tabs{display:flex;gap:.45rem;padding:.35rem;background:#f3f4f6;border-radius:.8rem;margin-bottom:1.2rem;overflow-x:auto}.tab-btn{padding:.65rem 1rem;border-radius:.65rem;color:#475569;font-weight:600;white-space:nowrap;border:1px solid transparent;background:transparent}.tab-btn:hover{background:#fff;color:#1e293b}.tab-btn.active{background:#fff;color:var(--primary);border-color:#dbeafe;box-shadow:0 6px 12px #4f46e524}.btn-primary{background-color:var(--primary);color:#fff;padding:.6rem 1.2rem;border-radius:var(--radius);font-weight:500}.btn-primary:hover{background-color:var(--primary-hover)}.btn-secondary{background-color:var(--secondary);color:var(--text-main);padding:.6rem 1.2rem;border-radius:var(--radius)}.btn-secondary:hover{background-color:var(--secondary-hover)}.btn-action{padding:.6rem 1.2rem;border-radius:var(--radius);font-weight:500;color:#fff;transition:all .2s;box-shadow:0 1px 2px #0000000d}.btn-action:hover{transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000001a}.btn-action.configure{background-color:#4b5563}.btn-action.configure:hover{background-color:#374151}.btn-action.schedule{background-color:#2563eb}.btn-action.schedule:hover{background-color:#1d4ed8}.btn-action.publish{background-color:#059669}.btn-action.publish:hover{background-color:#047857}.add-btn{box-shadow:var(--shadow)}.course-list-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.15rem}.course-card{background:linear-gradient(175deg,#fff,#f8fafc 68%,#f1f5f9);border-radius:1.05rem;padding:1.35rem;box-shadow:0 10px 24px #0f172a1a,0 1px #ffffffd9 inset;border:1px solid rgba(148,163,184,.28);transition:transform .24s ease,box-shadow .24s ease,border-color .24s ease;position:relative;overflow:hidden;isolation:isolate}.course-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:#cbd5e1}.course-card:after{content:"";position:absolute;right:-45px;top:-45px;width:150px;height:150px;border-radius:50%;background:radial-gradient(circle,rgba(148,163,184,.16),transparent 66%);z-index:-1}.course-card.today{border-color:#6ee7b7;background:linear-gradient(140deg,#ecfdf5,#fff 56%,#f0fdf4)}.course-card.today:before{background:linear-gradient(90deg,#10b981,#34d399)}.course-card.upcoming{border-color:#93c5fd;background:linear-gradient(140deg,#eff6ff,#fff 56%,#f0f9ff)}.course-card.upcoming:before{background:linear-gradient(90deg,#3b82f6,#60a5fa)}.course-card.history{border-color:#cbd5e1;background:linear-gradient(140deg,#f8fafc,#f1f5f9 70%,#e2e8f0)}.course-card.history:before{background:linear-gradient(90deg,#64748b,#94a3b8)}.course-card:hover{transform:translateY(-4px) scale(1.01);box-shadow:0 22px 34px #0f172a2b}.course-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.course-code{padding:.3rem .65rem;border-radius:.5rem;font-size:.78rem;font-weight:800;letter-spacing:.03em;border:1px solid transparent}.course-card.today .course-code{background-color:#10b98129;color:#065f46;border-color:#10b98147}.course-card.upcoming .course-code{background-color:#3b82f61f;color:#1d4ed8;border-color:#3b82f63d}.course-card.history .course-code{background-color:#e2e8f0;color:#475569;border-color:#cbd5e1}.course-title{font-size:1.16rem;font-weight:700;line-height:1.4;margin-bottom:.75rem;color:#0f172a}.course-meta{display:flex;flex-wrap:wrap;gap:.45rem;margin-bottom:.8rem}.meta-chip{font-size:.72rem;padding:.24rem .62rem;background:#f8fafcf2;border-radius:999px;color:#334155;font-weight:700;border:1px solid #e2e8f0}.course-details{display:flex;flex-direction:column;gap:.55rem;color:#334155}.detail-row{display:flex;align-items:center;gap:.6rem;padding:.52rem .62rem;background:#fffffff2;border:1px solid rgba(226,232,240,.95);border-radius:.55rem;font-size:.94rem}.icon{min-width:3.25rem;font-size:.72rem;font-weight:700;color:#475569;letter-spacing:.03em;text-transform:uppercase}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background-color:var(--bg-card);padding:2rem;border-radius:1rem;box-shadow:0 20px 25px -5px #0000001a;width:90%;max-width:400px;animation:slideUp .3s ease-out;max-height:90vh;overflow-y:auto}.modal-content.large{max-width:600px}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-content h2{margin-bottom:1.5rem;font-size:1.5rem;color:var(--text-main);text-align:center}.form-group{margin-bottom:1rem}.form-row{display:flex;gap:1rem}.form-row .form-group{flex:1}label{display:block;margin-bottom:.5rem;font-weight:500;font-size:.9rem}input,select{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:var(--radius);font-size:1rem;transition:border-color .2s}input:focus,select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a}.modal-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:1.5rem}.error-message{color:var(--danger);font-size:.9rem;margin-bottom:1rem;text-align:center}@media(max-width:640px){.modal-content{padding:1.5rem;width:95%;border-radius:.5rem}}.empty-state{text-align:center;padding:4rem 2rem;opacity:.6}@media(max-width:640px){.app-header{padding:.95rem 1rem .9rem}.header-content{flex-direction:column;gap:.5rem}.header-content nav{position:static}.toolbar{grid-template-columns:1fr;justify-items:center}.filters{grid-column:1;justify-self:center;width:100%;max-width:100%;justify-content:center;flex-wrap:wrap}.toolbar-actions{grid-column:1;justify-self:center;width:100%;justify-content:center}.modal-overlay{align-items:flex-start;padding:1rem;overflow-y:auto}.modal-content{padding:1.25rem;width:100%;max-width:none;border-radius:.75rem;margin-top:1rem;margin-bottom:1rem;max-height:none}.modal-content h2{font-size:1.25rem;margin-bottom:1rem}.form-group{margin-bottom:.75rem}.form-row{flex-direction:column;gap:0}.hide-mobile{display:none}}.admin-actions{display:flex;gap:.5rem}.icon-btn{border:1px solid #dbe1ea;background:#f8fafc;color:#334155;font-size:1rem;padding:.35rem .45rem;border-radius:.5rem;opacity:1}.icon-btn:hover{background-color:#fff;box-shadow:0 6px 12px #0f172a1f}.delete-btn{color:#b91c1c;border-color:#fecaca}.delete-btn:hover{background:#fef2f2}.flex-column-mobile{display:flex;gap:1rem}.responsive-grid-form{display:grid;grid-template-columns:1fr 2fr 1fr auto;gap:.5rem;align-items:end}.toast-container{position:fixed;top:1rem;right:1rem;z-index:2000;display:flex;flex-direction:column;gap:.6rem;width:min(92vw,360px)}.toast{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.75rem .9rem;border-radius:.5rem;border:1px solid transparent;background:#fff;box-shadow:0 10px 18px #0000001f;animation:toastIn .2s ease-out}.toast-success{border-color:#86efac;background:#f0fdf4;color:#14532d}.toast-error{border-color:#fca5a5;background:#fef2f2;color:#7f1d1d}.toast-info{border-color:#93c5fd;background:#eff6ff;color:#1e3a8a}.toast-close{background:transparent;border:none;color:inherit;font-size:1rem;line-height:1;opacity:.8}.toast-close:hover{opacity:1}@keyframes toastIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}@media(max-width:640px){.flex-column-mobile{flex-direction:column}.responsive-grid-form{grid-template-columns:1fr;align-items:stretch}.responsive-grid-form>button{margin-top:1rem}.course-table-container{overflow-x:auto}.course-table{min-width:600px}.admin-actions{flex-wrap:wrap}}
