@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--bg-color: #f0f4ff;--bg-gradient: linear-gradient(135deg, #e8f0fe 0%, #f5f8ff 60%, #dbeafe 100%);--surface-color: rgba(255, 255, 255, .85);--surface-border: rgba(59, 130, 246, .15);--surface-blur: blur(16px);--text-primary: #1e293b;--text-secondary: #64748b;--accent-color: #2563eb;--accent-hover: #1d4ed8;--primary-color: #2563eb;--success-color: #059669;--danger-color: #dc2626;--radius-lg: 16px;--radius-md: 12px;--radius-sm: 8px;--shadow-sm: 0 1px 3px 0 rgb(37 99 235 / .08);--shadow-lg: 0 10px 30px -4px rgb(37 99 235 / .12), 0 4px 8px -4px rgb(37 99 235 / .08);--border-color: rgba(59, 130, 246, .2)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,sans-serif;background:var(--bg-gradient);background-attachment:fixed;color:var(--text-primary);min-height:100vh;-webkit-font-smoothing:antialiased}.glass-panel{background:var(--surface-color);backdrop-filter:var(--surface-blur);-webkit-backdrop-filter:var(--surface-blur);border:1px solid var(--surface-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}h1,h2,h3,h4{color:var(--text-primary);font-weight:600}h1{font-size:2.25rem;line-height:2.5rem;letter-spacing:-.025em}h2{font-size:1.5rem;line-height:2rem}p{color:var(--text-secondary);line-height:1.5}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.6rem 1.25rem;border-radius:var(--radius-sm);font-weight:500;font-size:.875rem;cursor:pointer;transition:all .2s ease;border:none;text-decoration:none}.btn-primary{background:var(--accent-color);color:#fff}.btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.btn-primary:disabled{background:var(--text-secondary);cursor:not-allowed;transform:none}.btn-secondary{background:#2563eb14;color:var(--accent-color);border:1px solid var(--border-color)}.btn-secondary:hover{background:#2563eb24;transform:translateY(-1px)}.btn-danger{background:#dc26261a;color:#dc2626}.btn-danger:hover{background:#dc26262e}.btn-sm{padding:.35rem .75rem;font-size:.78rem}.input{width:100%;padding:.75rem 1rem;background:#ffffffe6;border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-family:inherit;transition:border-color .2s,box-shadow .2s}.input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #2563eb1f}.select{appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%2364748b' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5em 1.5em;padding-right:2.5rem}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 1.5rem}.page-container{padding:2rem 0;display:flex;flex-direction:column;gap:2rem}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.grid-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fadeIn .4s cubic-bezier(.16,1,.3,1) forwards}.navbar{position:sticky;top:1rem;z-index:100;margin:1rem;padding:.75rem 0;border-radius:var(--radius-lg)}.navbar-inner{height:40px}.navbar-brand{display:flex;align-items:center;gap:.5rem;font-size:1.25rem;font-weight:700;color:var(--accent-color);text-decoration:none}.brand-logo{width:28px;height:28px;object-fit:contain;border-radius:6px}.brand-icon{color:var(--accent-color)}.navbar-actions{display:flex;align-items:center;gap:1rem}.user-badge{display:flex;align-items:center;gap:.75rem;background:#2563eb12;padding:.35rem .75rem;border-radius:999px;border:1px solid var(--border-color)}.user-name{font-weight:500;font-size:.875rem}.role-badge{font-size:.7rem;text-transform:uppercase;font-weight:700;padding:.15rem .5rem;border-radius:4px;letter-spacing:.05em}.role-admin{background:#dc26261f;color:#dc2626}.role-buddy{background:#2563eb1f;color:#2563eb}.role-participant{background:#0596691f;color:#059669}.icon-btn{padding:.5rem;border-radius:50%;display:flex}.login-page{min-height:100vh;padding:1.5rem}.login-card{width:100%;max-width:420px;padding:2.5rem;display:flex;flex-direction:column;gap:2rem}.login-header{flex-direction:column;gap:.5rem;text-align:center}.brand-logo-large{width:72px;height:72px;object-fit:contain;border-radius:16px;margin-bottom:.5rem}.login-header h1{font-size:2rem;margin-bottom:.25rem}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:1rem;color:var(--text-secondary);pointer-events:none}.input.with-icon{padding-left:2.75rem}.login-btn{padding:.85rem;font-size:1rem;margin-top:.5rem}.slot-card{padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem;transition:transform .2s,box-shadow .2s}.slot-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg),0 0 20px #2563eb1f}.slot-booked{opacity:.6;pointer-events:none}.slot-header{display:flex;justify-content:space-between;align-items:flex-start}.slot-time-badge{display:inline-flex;align-items:center;gap:.35rem;background:#2563eb1a;color:var(--accent-color);padding:.25rem .6rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.status-badge{font-size:.65rem;font-weight:700;text-transform:uppercase;padding:.2rem .5rem;border-radius:4px}.status-badge.booked{background:#dc26261f;color:#dc2626}.status-badge.joined{background:#0596691f;color:#059669}.slot-body{display:flex;flex-direction:column;gap:.75rem}.time-row{display:flex;align-items:center;gap:.5rem;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.icon-subtle{color:var(--text-secondary)}.detail-row{display:flex;align-items:center;justify-content:space-between;font-size:.875rem}.detail-row .label{color:var(--text-secondary)}.detail-row .value{font-weight:500}.participant-count{display:flex;align-items:center;gap:.35rem;color:var(--text-primary);font-weight:500}.slot-footer{margin-top:auto;display:flex;gap:.5rem}.w-full{width:100%}.calendar-container{overflow-x:auto;padding:1rem}.calendar-grid{display:grid;grid-template-columns:repeat(5,minmax(130px,1fr));gap:.5rem;min-width:600px}.calendar-column{display:flex;flex-direction:column;background:#2563eb08;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border-color)}.calendar-header{background:#2563eb12;padding:.75rem;text-align:center;font-weight:600;text-transform:uppercase;font-size:.8rem;letter-spacing:.05em;color:var(--accent-color);border-bottom:1px solid var(--border-color)}.calendar-header.today{background:#2563eb2e;border-bottom:2px solid var(--accent-color);color:var(--accent-color)}.calendar-body{padding:.5rem;display:flex;flex-direction:column;gap:.5rem;min-height:100px}.empty-day{text-align:center;color:#64748b66;padding:1rem 0;font-size:.875rem}.calendar-slot{position:relative;background:#2563eb14;border:1px solid rgba(37,99,235,.2);padding:.6rem;border-radius:6px;font-size:.75rem;transition:transform .2s,background .2s;display:flex;flex-direction:column;gap:.4rem;color:var(--text-primary)}.calendar-slot:hover{transform:translateY(-2px);background:#2563eb24;box-shadow:0 4px 12px #2563eb1f}.calendar-slot.booked{background:#05966914;border-color:#05966940;opacity:.9}.calendar-slot .slot-time{display:flex;align-items:center;gap:.3rem;font-weight:500}.calendar-slot .slot-status{font-size:.65rem;font-weight:700;color:#059669;text-transform:uppercase}.delete-btn{position:absolute;top:.25rem;right:.25rem;background:#dc26261a;border:none;color:#dc2626;width:20px;height:20px;border-radius:4px;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transition:opacity .2s,background .2s}.calendar-slot:hover .delete-btn{opacity:1}.delete-btn:hover{background:#dc262633}.calendar-month-container{overflow-x:auto;padding:1rem}.calendar-month-header-title{font-size:1.25rem;font-weight:600;margin-bottom:1rem;text-align:center;color:var(--text-primary)}.calendar-month-grid{display:grid;grid-template-columns:repeat(5,minmax(80px,1fr));gap:4px;background:var(--border-color);border:1px solid var(--border-color);border-radius:var(--radius-sm);overflow:hidden}.calendar-month-day-header{background:#2563eb14;padding:.5rem;text-align:center;font-weight:600;font-size:.8rem;text-transform:uppercase;color:var(--accent-color)}.calendar-month-cell{background:#fff;min-height:100px;padding:.5rem;display:flex;flex-direction:column}.calendar-month-cell.empty{background:#2563eb05}.calendar-month-cell.today{background:#2563eb0d;outline:2px solid rgba(37,99,235,.4);outline-offset:-2px}.calendar-month-cell-header{font-size:.875rem;font-weight:500;margin-bottom:.5rem;text-align:right;color:var(--text-secondary)}.calendar-month-cell-header.today{background:var(--accent-color);color:#fff;border-radius:50%;width:22px;height:22px;display:flex;align-items:center;justify-content:center;margin-left:auto;font-weight:700}.calendar-month-cell-body{display:flex;flex-direction:column;gap:.25rem;flex:1;overflow-y:auto}.calendar-month-slot{background:#2563eb14;border:1.5px solid rgba(37,99,235,.35);padding:.25rem .4rem;border-radius:4px;font-size:.7rem;display:flex;align-items:center;gap:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:transform .15s,box-shadow .15s,background .15s;cursor:pointer;color:var(--accent-color);font-weight:500}.calendar-month-slot:hover{transform:translateY(-1px);background:#2563eb29;box-shadow:0 2px 8px #2563eb2e}.calendar-month-slot.booked{background:#0596691a;border-color:#0596694d;color:#059669}.calendar-month-slot.selected{background:var(--accent-color);border-color:var(--accent-color);color:#fff}.calendar-month-cell-body::-webkit-scrollbar{width:3px}.calendar-month-cell-body::-webkit-scrollbar-track{background:transparent}.calendar-month-cell-body::-webkit-scrollbar-thumb{background:#2563eb33;border-radius:3px}.table-container{overflow-x:auto;padding:1px}.meeting-table{width:100%;border-collapse:collapse;text-align:left}.meeting-table th{padding:1rem 1.5rem;background:#2563eb0d;color:var(--accent-color);font-weight:600;font-size:.875rem;border-bottom:1px solid var(--border-color)}.meeting-table td{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color);vertical-align:middle}.meeting-table tr:last-child td{border-bottom:none}.meeting-table tr:hover td{background:#2563eb08}.slot-time-col{display:flex;flex-direction:column;gap:.25rem}.slot-day{font-weight:600;color:var(--text-primary)}.slot-hours{font-size:.875rem;color:var(--text-secondary)}.buddy-name{font-weight:500;color:var(--text-primary)}.participants-col{display:flex;align-items:center;gap:.6rem;color:var(--text-primary)}.btn-sm{padding:.4rem .8rem;font-size:.8rem}.empty-state{padding:3rem;text-align:center;color:var(--text-secondary)}
