@import "https://fonts.googleapis.com/css2?family=DM+Sans:ital,wght@0,400;0,500;0,600;0,700&family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,600;0,9..144,700;1,9..144,400&display=swap";:root{--bg:#faf7f2;--bg-card:#fff;--bg-muted:#f3ede4;--bg-hero:#1b1410;--text:#2c1810;--text-secondary:#7a6b5d;--text-muted:#a89888;--border:#e6ddd0;--border-strong:#d4c8b8;--accent:#b45309;--accent-hover:#92400e;--accent-light:#fef3c7;--accent-bg:#fffbeb;--green:#047857;--green-bg:#ecfdf5;--red:#b91c1c;--red-bg:#fef2f2;--blue:#1d4ed8;--blue-bg:#eff6ff;--amber:#d97706;--amber-bg:#fffbeb;--radius:10px;--radius-sm:6px;--radius-lg:16px;--shadow-sm:0 1px 3px #2c18100f;--shadow:0 4px 16px #2c181014;--shadow-lg:0 12px 40px #2c18101f;--font-display:"Fraunces", Georgia, serif;--font-body:"DM Sans", system-ui, sans-serif;--nav-height:64px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:15px}body{font-family:var(--font-body);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;line-height:1.6}a{color:var(--accent);cursor:pointer;text-decoration:none}a:hover{color:var(--accent-hover)}button{cursor:pointer;border:none;font-family:inherit}input,select,textarea{font-family:inherit;font-size:.93rem}table{border-collapse:collapse;width:100%}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes slideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes toastIn{0%{opacity:0;transform:translate(100px)}to{opacity:1;transform:translate(0)}}.fade-in{animation:.3s fadeIn}.spin{animation:.8s linear infinite spin}.navbar{z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);height:var(--nav-height);background:#faf7f2eb;position:sticky;top:0}.navbar-inner{justify-content:space-between;align-items:center;max-width:1200px;height:100%;margin:0 auto;padding:0 24px;display:flex}.navbar-brand{font-family:var(--font-display);color:var(--text);align-items:center;gap:10px;font-size:1.2rem;font-weight:700;text-decoration:none;display:flex}.brand-icon{background:var(--accent);color:#fff;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.navbar-links{align-items:center;gap:4px;display:flex}.nav-link{border-radius:var(--radius-sm);color:var(--text-secondary);align-items:center;gap:6px;padding:8px 14px;font-size:.88rem;font-weight:500;transition:all .2s;display:flex}.nav-link:hover{background:var(--bg-muted);color:var(--text)}.nav-link.active{background:var(--accent-bg);color:var(--accent)}.admin-link.active{color:#6d28d9;background:#ede9fe}.navbar-user-section{border-left:1px solid var(--border);align-items:center;gap:12px;margin-left:12px;padding-left:12px;display:flex}.navbar-greeting{color:var(--text-secondary);font-size:.85rem;font-weight:500}.btn-logout{background:var(--red-bg);color:var(--red);border-radius:var(--radius-sm);align-items:center;gap:6px;padding:6px 14px;font-size:.82rem;font-weight:600;transition:all .2s;display:flex}.btn-logout:hover{background:#fecaca}.btn-register-nav{background:var(--accent);border-radius:var(--radius);padding:8px 18px;font-size:.88rem;font-weight:600;transition:all .2s;color:#fff!important}.btn-register-nav:hover{background:var(--accent-hover);color:#fff}.mobile-toggle{color:var(--text);background:0 0;padding:8px;display:none}.main-content{min-height:calc(100vh - var(--nav-height))}.btn-primary{background:var(--accent);color:#fff;border-radius:var(--radius);align-items:center;gap:8px;padding:10px 22px;font-size:.9rem;font-weight:600;transition:all .2s;display:inline-flex;box-shadow:0 2px 8px #b4530933}.btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 16px #b453094d}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-secondary{background:var(--bg-muted);color:var(--text);border-radius:var(--radius);align-items:center;gap:8px;padding:10px 22px;font-size:.9rem;font-weight:600;transition:all .2s;display:inline-flex}.btn-secondary:hover{background:var(--border)}.btn-ghost{color:#fff;border-radius:var(--radius);background:0 0;border:1.5px solid #ffffff4d;align-items:center;gap:8px;padding:10px 22px;font-size:.9rem;font-weight:600;transition:all .2s;display:inline-flex}.btn-ghost:hover{background:#ffffff1a;border-color:#ffffff80}.btn-full{justify-content:center;width:100%}.btn-lg{padding:14px 32px;font-size:1rem}.btn-icon-danger{color:var(--text-muted);background:0 0;border-radius:6px;padding:6px;transition:all .2s}.btn-icon-danger:hover{color:var(--red);background:var(--red-bg)}.form-group{margin-bottom:18px}.form-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:6px;margin-bottom:6px;font-size:.82rem;font-weight:600;display:flex}.form-group input,.form-group select{border:1.5px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);background:#fff;outline:none;padding:11px 14px;font-size:.93rem;transition:all .2s}.form-group input:focus,.form-group select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #b453091a}.form-group input:disabled{background:var(--bg-muted);color:var(--text-secondary)}.form-group input.input-error{border-color:var(--red)}.field-error{color:var(--red);margin-top:4px;font-size:.78rem;display:block}.form-row{grid-template-columns:1fr 1fr;gap:14px;display:grid}.form-error-banner{background:var(--red-bg);color:var(--red);border-radius:var(--radius-sm);border:1px solid #fecaca;margin-bottom:18px;padding:12px 16px;font-size:.88rem}.form-actions{justify-content:flex-end;gap:12px;margin-top:8px;display:flex}.hero-section{background:var(--bg-hero);color:#fff;justify-content:center;align-items:center;gap:60px;max-width:100%;padding:80px 24px 100px;display:flex;position:relative;overflow:hidden}.hero-bg-pattern{opacity:.06;background:repeating-linear-gradient(45deg,#0000,#0000 40px,#ffffff1a 40px 42px);position:absolute;inset:0}.hero-content{z-index:1;max-width:540px;animation:.6s fadeInUp;position:relative}.hero-badge{color:#fbbf24;letter-spacing:.5px;background:#b4530933;border-radius:20px;margin-bottom:20px;padding:6px 16px;font-size:.8rem;font-weight:600;display:inline-block}.hero-content h1{font-family:var(--font-display);margin-bottom:18px;font-size:clamp(2.2rem,4vw,3.2rem);font-weight:700;line-height:1.15}.text-accent{color:#fbbf24}.hero-desc{color:#ffffffb3;margin-bottom:32px;font-size:1.05rem;line-height:1.7}.hero-actions{flex-wrap:wrap;gap:14px;display:flex}.hero-visual{z-index:1;flex-direction:column;gap:16px;animation:.6s .2s both fadeInUp;display:flex;position:relative}.hero-card{border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff12;border:1px solid #ffffff1a;align-items:center;gap:16px;padding:20px 28px;transition:transform .3s;display:flex}.hero-card:hover{transform:translate(6px)}.hero-card strong{color:#fff;font-size:1.2rem;display:block}.hero-card span{color:#ffffff80;font-size:.82rem}.hc-1{color:#fbbf24}.hc-2{color:#34d399}.hc-3{color:#818cf8}.features-section{text-align:center;max-width:1000px;margin:0 auto;padding:80px 24px}.features-section h2{font-family:var(--font-display);margin-bottom:48px;font-size:2rem}.features-grid{grid-template-columns:repeat(3,1fr);gap:28px;display:grid}.feature-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:left;padding:40px 28px 32px;transition:all .3s;animation:.5s both fadeInUp;position:relative;overflow:hidden}.feature-card:hover{box-shadow:var(--shadow-lg);border-color:var(--accent);transform:translateY(-4px)}.feature-icon{background:var(--accent-bg);width:52px;height:52px;color:var(--accent);border-radius:12px;justify-content:center;align-items:center;margin-bottom:18px;display:flex}.feature-card h3{font-family:var(--font-display);margin-bottom:10px;font-size:1.2rem}.feature-card p{color:var(--text-secondary);font-size:.9rem;line-height:1.6}.feature-step{font-family:var(--font-display);color:var(--bg-muted);font-size:2.4rem;font-weight:700;position:absolute;top:16px;right:20px}.auth-page{min-height:calc(100vh - var(--nav-height));justify-content:center;align-items:center;padding:32px 24px;display:flex}.auth-container{border-radius:var(--radius-lg);width:100%;max-width:900px;box-shadow:var(--shadow-lg);background:#fff;grid-template-columns:1fr 1fr;animation:.5s fadeInUp;display:grid;overflow:hidden}.auth-hero{background:var(--bg-hero);color:#fff;flex-direction:column;justify-content:center;padding:48px 40px;display:flex;position:relative;overflow:hidden}.auth-hero-content{z-index:1;position:relative}.auth-hero-content svg{color:#fbbf24;margin-bottom:20px}.auth-hero-content h1{font-family:var(--font-display);margin-bottom:12px;font-size:1.8rem}.auth-hero-content p{color:#fff9;font-size:.95rem;line-height:1.6}.auth-demo-hint{border-radius:var(--radius-sm);color:#fff9;background:#ffffff14;margin-top:28px;padding:14px 18px;font-size:.82rem;line-height:1.7}.auth-demo-hint strong{color:#fbbf24}.auth-hero-pattern{opacity:.05;background:repeating-linear-gradient(135deg,#0000,#0000 30px,#ffffff1a 30px 32px);position:absolute;inset:0}.auth-form-panel{align-items:center;padding:48px 40px;display:flex}.auth-form-wrapper{width:100%}.auth-form-wrapper h2{font-family:var(--font-display);margin-bottom:4px;font-size:1.5rem}.auth-subtitle{color:var(--text-muted);margin-bottom:28px;font-size:.9rem}.auth-switch{text-align:center;color:var(--text-secondary);margin-top:24px;font-size:.88rem}.auth-switch a{font-weight:600}.dashboard-page,.seats-page,.bookings-page,.profile-page,.admin-page{max-width:1100px;margin:0 auto;padding:36px 24px 60px}.page-header{margin-bottom:32px}.page-header h1{font-family:var(--font-display);align-items:center;gap:10px;font-size:1.8rem;display:flex}.page-header p{color:var(--text-secondary);margin-top:4px}.dashboard-header{justify-content:space-between;align-items:center;margin-bottom:32px;display:flex}.dashboard-header h1{font-family:var(--font-display);font-size:1.8rem}.dashboard-header p{color:var(--text-secondary);margin-top:2px}.stats-grid{grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:36px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);align-items:center;gap:16px;padding:22px;transition:all .2s;animation:.4s both fadeInUp;display:flex}.stat-card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}.stat-icon{border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.stat-icon.blue{background:var(--blue-bg);color:var(--blue)}.stat-icon.green{background:var(--green-bg);color:var(--green)}.stat-icon.amber{background:var(--amber-bg);color:var(--amber)}.stat-icon.red{background:var(--red-bg);color:var(--red)}.stat-number{font-family:var(--font-display);font-size:1.6rem;font-weight:700;line-height:1}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:.8rem;font-weight:500}.stat-info{flex-direction:column;gap:4px;display:flex}.dashboard-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px}.section-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.section-header h2{font-family:var(--font-display);font-size:1.15rem}.link-more{color:var(--accent);align-items:center;gap:4px;font-size:.85rem;font-weight:600;display:flex}.empty-state{text-align:center;color:var(--text-muted);padding:48px 24px}.empty-state svg{opacity:.4;margin-bottom:16px}.empty-state h3{font-family:var(--font-display);color:var(--text);margin-bottom:8px}.empty-state p{margin-bottom:20px}.bookings-table-wrapper{overflow-x:auto}.data-table{width:100%}.data-table th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.6px;border-bottom:1.5px solid var(--border);padding:12px 16px;font-size:.75rem;font-weight:600}.data-table td{border-bottom:1px solid var(--bg-muted);padding:14px 16px;font-size:.9rem}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--bg-muted)}.seat-cell{align-items:center;gap:8px;font-weight:600;display:flex}.status-badge{text-transform:uppercase;letter-spacing:.3px;border-radius:12px;padding:3px 10px;font-size:.75rem;font-weight:600;display:inline-block}.status-confirmed{background:var(--green-bg);color:var(--green)}.status-completed{background:var(--blue-bg);color:var(--blue)}.status-cancelled{background:var(--red-bg);color:var(--red)}.role-badge{text-transform:uppercase;letter-spacing:.3px;border-radius:12px;padding:3px 10px;font-size:.72rem;font-weight:600;display:inline-block}.role-admin{color:#6d28d9;background:#ede9fe}.role-user{background:var(--blue-bg);color:var(--blue)}.filter-bar{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);flex-wrap:wrap;align-items:flex-end;gap:14px;margin-bottom:28px;padding:20px 24px;display:flex}.filter-group{flex-direction:column;flex:1;gap:4px;min-width:120px;display:flex}.filter-group label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;align-items:center;gap:4px;font-size:.75rem;font-weight:600;display:flex}.filter-group input,.filter-group select{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:#fff;padding:9px 12px;font-size:.88rem}.filter-group input:focus,.filter-group select:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #b453091a}.filter-pills{flex-wrap:wrap;gap:8px;margin-bottom:24px;display:flex}.pill{background:var(--bg-muted);color:var(--text-secondary);border:1.5px solid #0000;border-radius:20px;padding:8px 18px;font-size:.82rem;font-weight:600;transition:all .2s}.pill:hover{background:var(--border)}.pill-active{background:var(--accent-bg);color:var(--accent);border-color:var(--accent)}.seats-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:18px;display:grid}.seat-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:22px;transition:all .3s;animation:.4s both fadeInUp}.seat-card:hover{box-shadow:var(--shadow);border-color:var(--accent);transform:translateY(-3px)}.seat-card.seat-booked{opacity:.55}.seat-card.seat-booked:hover{box-shadow:none;border-color:var(--border);transform:none}.seat-card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.seat-number{font-family:var(--font-display);font-size:1.2rem;font-weight:700}.seat-type-badge{text-transform:uppercase;letter-spacing:.3px;border-radius:10px;padding:3px 10px;font-size:.7rem;font-weight:600}.seat-type-badge.individual{background:var(--blue-bg);color:var(--blue)}.seat-type-badge.study_room{color:var(--green);background:#f0fdf4}.seat-card-details{flex-direction:column;gap:8px;margin-bottom:18px;display:flex}.seat-detail{color:var(--text-secondary);align-items:center;gap:8px;font-size:.85rem;display:flex}.btn-book{background:var(--green-bg);width:100%;color:var(--green);border-radius:var(--radius-sm);justify-content:center;align-items:center;gap:8px;padding:10px;font-size:.88rem;font-weight:600;transition:all .2s;display:flex}.btn-book:hover{background:#d1fae5}.seat-unavailable{text-align:center;background:var(--bg-muted);color:var(--text-muted);border-radius:var(--radius-sm);padding:10px;font-size:.85rem;font-weight:500}.bookings-list{flex-direction:column;gap:12px;display:flex}.booking-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);align-items:center;gap:20px;padding:18px 22px;transition:all .2s;animation:.4s both fadeInUp;display:flex}.booking-card:hover{box-shadow:var(--shadow-sm)}.booking-card-left{flex:1}.booking-seat-tag{font-family:var(--font-display);align-items:center;gap:8px;margin-bottom:4px;font-size:1.05rem;font-weight:700;display:flex}.booking-meta{color:var(--text-muted);align-items:center;gap:4px;font-size:.82rem;display:flex}.booking-card-center{text-align:center;min-width:140px}.booking-date{font-size:.9rem;font-weight:600;display:block}.booking-time{color:var(--text-secondary);font-size:.82rem}.booking-card-right{align-items:center;gap:12px;display:flex}.btn-cancel-sm{background:var(--red-bg);color:var(--red);border-radius:var(--radius-sm);align-items:center;gap:4px;padding:6px 14px;font-size:.78rem;font-weight:600;transition:all .2s;display:inline-flex}.btn-cancel-sm:hover{background:#fecaca}.btn-cancel-sm:disabled{opacity:.5}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#1b141080;justify-content:center;align-items:center;padding:24px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal{border-radius:var(--radius-lg);width:100%;max-width:440px;box-shadow:var(--shadow-lg);background:#fff;padding:32px;animation:.3s fadeInUp;position:relative}.modal-close{color:var(--text-muted);background:0 0;padding:4px;position:absolute;top:16px;right:16px}.modal-close:hover{color:var(--text)}.modal h2{font-family:var(--font-display);margin-bottom:20px;font-size:1.3rem}.modal-details{flex-direction:column;gap:12px;margin-bottom:28px;display:flex}.modal-detail-row{background:var(--bg-muted);border-radius:var(--radius-sm);justify-content:space-between;padding:10px 14px;display:flex}.modal-detail-row span{color:var(--text-secondary);font-size:.85rem}.modal-detail-row strong{font-size:.9rem}.modal-actions{justify-content:flex-end;gap:12px;display:flex}.profile-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);align-items:center;gap:24px;margin-bottom:24px;padding:32px;display:flex}.profile-avatar{background:var(--accent);color:#fff;width:72px;height:72px;font-family:var(--font-display);border-radius:50%;justify-content:center;align-items:center;font-size:2rem;font-weight:700;display:flex}.profile-info h2{font-family:var(--font-display);margin-bottom:2px}.profile-email{color:var(--text-secondary);margin-bottom:6px;font-size:.9rem;display:block}.profile-form-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px}.admin-tabs{background:var(--bg-muted);border-radius:var(--radius);gap:4px;margin-bottom:28px;padding:4px;display:flex}.admin-tab{color:var(--text-secondary);border-radius:var(--radius-sm);text-align:center;background:0 0;flex:1;padding:10px;font-size:.88rem;font-weight:600;transition:all .2s}.admin-tab.active{color:var(--text);box-shadow:var(--shadow-sm);background:#fff}.admin-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px}.add-seat-form{background:var(--bg-muted);border-radius:var(--radius);flex-wrap:wrap;align-items:flex-end;gap:10px;margin-bottom:20px;padding:16px;display:flex}.add-seat-form input,.add-seat-form select{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:#fff;flex:1;min-width:100px;padding:9px 12px;font-size:.88rem}.toast-container{z-index:300;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:24px;right:24px}.toast{border-radius:var(--radius);box-shadow:var(--shadow-lg);background:#fff;border-left:4px solid;align-items:center;gap:10px;min-width:260px;padding:14px 20px;animation:.3s toastIn;display:flex}.toast-success{border-color:var(--green)}.toast-success span{color:var(--green);font-size:1.1rem;font-weight:700}.toast-error{border-color:var(--red)}.toast-error span{color:var(--red);font-size:1.1rem;font-weight:700}.toast-info{border-color:var(--blue)}.toast-info span{color:var(--blue);font-weight:700}.toast p{color:var(--text);font-size:.88rem}.page-loading{min-height:300px;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:12px;display:flex}@media (width<=768px){.hero-section{text-align:center;flex-direction:column;gap:36px;padding:48px 20px 60px}.hero-actions{justify-content:center}.hero-visual{flex-flow:wrap;justify-content:center}.features-grid,.auth-container{grid-template-columns:1fr}.auth-hero{display:none}.auth-form-panel{padding:36px 28px}.stats-grid{grid-template-columns:repeat(2,1fr)}.dashboard-header{flex-direction:column;align-items:flex-start;gap:16px}.filter-bar{flex-direction:column}.filter-group{min-width:auto}.seats-grid{grid-template-columns:1fr}.booking-card{flex-direction:column;align-items:flex-start}.booking-card-center{text-align:left}.booking-card-right{justify-content:space-between;width:100%}.mobile-toggle{display:block}.navbar-links{top:var(--nav-height);border-bottom:1px solid var(--border);box-shadow:var(--shadow-lg);background:#fff;flex-direction:column;padding:16px;display:none;position:fixed;left:0;right:0}.navbar-links.open{display:flex}.navbar-user-section{border-left:none;border-top:1px solid var(--border);width:100%;margin-left:0;padding-top:12px;padding-left:0}.navbar-greeting{display:none}.admin-tabs{flex-wrap:wrap}.add-seat-form{flex-direction:column}.form-row{grid-template-columns:1fr}.modal{margin:16px}}
