@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--primary:#6366f1;--primary-hover:#4f46e5;--bg:#0f172a;--surface:#1e293b;--surface-hover:#334155;--text:#f8fafc;--text-dim:#94a3b8;--text-muted:#64748b;--border:#334155;--border-light:#ffffff0d;--danger:#ef4444;--success:#10b981;--warning:#f59e0b;--info:#3b82f6;--radius:16px;--radius-sm:8px;--shadow:0 4px 6px -1px #0000004d, 0 2px 4px -2px #0000004d;--shadow-lg:0 10px 15px -3px #0006, 0 4px 6px -4px #0006;--shadow-glow:0 0 20px #6366f133}*{box-sizing:border-box}body{background-color:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;background-image:radial-gradient(at 0 0,#6366f126 0,#0000 50%),radial-gradient(at 100% 0,#10b98126 0,#0000 50%);background-attachment:fixed;min-height:100vh;margin:0;padding:0;font-family:Inter,sans-serif}h1,h2,h3,h4,h5,h6,p{margin:0}button{cursor:pointer;background:0 0;border:none;font-family:inherit;font-size:14px}input,textarea,select{background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:var(--radius-sm);width:100%;padding:10px 14px;font-family:inherit;font-size:14px;transition:all .2s}select option{color:#f8fafc;background:#1e293b}input:focus,textarea:focus,select:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #6366f133}.btn-primary{background-color:var(--primary);color:#fff;border-radius:var(--radius-sm);padding:10px 16px;font-weight:500;transition:all .2s}.btn-primary:hover{background-color:var(--primary-hover);box-shadow:var(--shadow-glow);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background-color:var(--surface-hover);color:var(--text);border-radius:var(--radius-sm);padding:10px 16px;font-weight:500;transition:all .2s}.btn-secondary:hover{background-color:var(--border)}.btn-danger{color:var(--danger);border-radius:var(--radius-sm);background-color:#ef44441a;border:1px solid #ef444433;padding:8px 12px;font-weight:500;transition:all .2s}.btn-danger:hover{background-color:var(--danger);color:#fff}.btn-success{color:var(--success);border-radius:var(--radius-sm);background-color:#10b9811a;border:1px solid #10b98133;padding:8px 12px;font-weight:500;transition:all .2s}.btn-success:hover{background-color:var(--success);color:#fff}.card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border-light);border-radius:var(--radius);box-shadow:var(--shadow);background:#1e293bb3;padding:24px}.container{max-width:1200px;margin:0 auto;padding:40px 24px}.header{justify-content:space-between;align-items:center;margin-bottom:40px;display:flex}.header h1{background:linear-gradient(135deg,#fff,#94a3b8);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:28px;font-weight:700}.events-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:24px;display:grid}.event-card{flex-direction:column;gap:16px;transition:transform .2s,box-shadow .2s;display:flex}.event-card:hover{box-shadow:var(--shadow-lg), var(--border-light);transform:translateY(-4px)}.event-header{justify-content:space-between;align-items:flex-start;display:flex}.event-title{color:var(--text);margin-bottom:4px;font-size:18px;font-weight:600}.event-date{color:var(--text-dim);align-items:center;gap:6px;font-size:14px;display:flex}.badge{text-transform:uppercase;letter-spacing:.5px;border-radius:99px;padding:4px 10px;font-size:12px;font-weight:600}.badge-pending{color:var(--warning);background:#f59e0b26}.badge-approved{color:var(--success);background:#10b98126}.badge-rejected{color:var(--danger);background:#ef444426}.calendar-container{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border-light);border-radius:var(--radius);box-shadow:var(--shadow);background:#1e293bb3;flex-direction:column;display:flex;overflow:hidden}.calendar-header{border-bottom:1px solid var(--border-light);background:#0003;justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.calendar-header h2{font-size:20px;font-weight:600}.calendar-grid{background:var(--border-light);grid-template-columns:repeat(7,1fr);gap:1px;display:grid}.calendar-day-header{text-align:center;color:var(--text-dim);background:var(--surface);text-transform:uppercase;letter-spacing:1px;padding:12px 0;font-size:13px;font-weight:600}.calendar-day{background:var(--surface);cursor:pointer;flex-direction:column;min-height:80px;padding:10px;transition:background .2s;display:flex;position:relative;overflow:visible}.calendar-day-muted{color:var(--text-muted);background:#1e293b66}.calendar-day:hover{background:var(--surface-hover)}.calendar-date-number{color:var(--text-dim);margin-bottom:8px;font-size:14px;font-weight:500;display:inline-block}.calendar-day-today .calendar-date-number{background:var(--primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;display:flex}.calendar-event-chip{color:#c7d2fe;white-space:nowrap;text-overflow:ellipsis;cursor:pointer;background:#6366f133;border:1px solid #6366f14d;border-radius:4px;flex-shrink:0;max-width:100%;margin-bottom:3px;padding:3px 6px;font-size:11px;transition:opacity .15s;display:block;overflow:hidden}.calendar-event-chip:hover{opacity:.8}.calendar-more-btn{color:var(--text-muted);cursor:pointer;text-align:center;background:#ffffff0f;border:1px solid #ffffff14;border-radius:4px;flex-shrink:0;margin-top:2px;padding:2px 6px;font-size:10px;transition:background .15s,color .15s}.calendar-more-btn:hover{color:var(--text);background:#ffffff1f}.calendar-overflow-popover{z-index:500;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);min-width:180px;max-width:260px;box-shadow:var(--shadow-lg);flex-direction:column;gap:3px;padding:6px;display:flex;position:absolute;bottom:calc(100% + 4px);left:0}.calendar-overflow-popover .calendar-event-chip{margin-bottom:0}.calendar-event-chip.approved{color:#a7f3d0;background:#10b98133;border-color:#10b9814d}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:.4s ease-out forwards fadeIn}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0f172acc;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:500px;max-height:90vh;box-shadow:var(--shadow-lg);flex-direction:column;gap:20px;padding:32px;display:flex;overflow-y:auto}.comments-section{border-top:1px solid var(--border-light);margin-top:16px;padding-top:16px}.comment-item{border-radius:var(--radius-sm);background:#00000026;flex-direction:column;gap:8px;margin-bottom:8px;padding:12px;display:flex}.comment-author{color:var(--info);font-size:13px;font-weight:600}.comment-text{color:var(--text);font-size:14px}
