:root{--bg-color:#fff;--bg-mesh:#f8fafc;--text-main:#0f172a;--text-muted:#64748b;--primary:#2563eb;--primary-hover:#1d4ed8;--accent:#0ea5e9;--surface-color:#ffffffd9;--surface-border:#e2e8f0cc;--surface-shadow:0 10px 30px #0f172a0a;--surface-hover-shadow:0 20px 40px #2563eb14;--success:#10b981;--success-bg:#10b9811a;--warning:#f59e0b;--warning-bg:#f59e0b1a}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-color);color:var(--text-main);font-family:Inter,sans-serif;line-height:1.6;position:relative;overflow-x:hidden}.bg-mesh{z-index:-2;background-image:linear-gradient(90deg,#e2e8f066 1px,#0000 1px),linear-gradient(#e2e8f066 1px,#0000 1px);background-size:32px 32px;position:fixed;inset:0}.bg-orb{filter:blur(120px);z-index:-1;opacity:.5;border-radius:50%;animation:20s ease-in-out infinite alternate float;position:fixed}.orb-1{background:radial-gradient(circle,#38bdf833 0%,#2563eb1a 100%);width:50vw;height:50vw;top:-10%;left:10%}.orb-2{background:radial-gradient(circle,#6366f126 0%,#ec48990d 100%);width:40vw;height:40vw;animation-delay:-5s;bottom:10%;right:-5%}@keyframes float{0%{transform:translate(0)scale(1)}to{transform:translate(5%,5%)scale(1.05)}}.navbar{z-index:50;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--surface-border);background:#fffc;position:fixed;top:0;left:0;right:0}.nav-container{justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:1rem 2rem;display:flex}.logo{align-items:center;gap:.75rem;display:flex}.logo-icon{background:linear-gradient(135deg, var(--primary), var(--accent));color:#fff;border-radius:12px;justify-content:center;align-items:center;width:40px;height:40px;display:flex;box-shadow:0 4px 15px #2563eb4d}.logo-text{letter-spacing:-.5px;font-size:1.25rem;font-weight:800}.logo-img{object-fit:contain;width:auto;height:90px;display:block}.login-logo-img{object-fit:contain;width:auto;height:140px;margin:0 auto;display:block}.nav-links{display:none}@media (width>=768px){.nav-links{gap:2rem;display:flex}}.nav-links a{color:var(--text-muted);font-size:.95rem;font-weight:600;text-decoration:none;transition:all .3s}.nav-links a:hover,.nav-links a.active{color:var(--primary)}.nav-actions{gap:1rem;display:flex}.btn{cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;gap:.5rem;padding:.6rem 1.5rem;font-size:.9rem;font-weight:600;transition:all .3s;display:inline-flex}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 4px 15px #2563eb33}.btn-primary:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 6px 20px #2563eb4d}.btn-ghost{color:var(--text-main);background:0 0}.btn-ghost:hover{background:#0f172a0d}.hero-split-wrapper{grid-template-columns:1fr auto 1fr;align-items:center;gap:1.5rem;max-width:1400px;margin:0 auto;padding:7rem 2rem 2rem;display:grid}.hero-img-panel{grid-template-columns:1fr 1fr;align-items:start;gap:.6rem;display:grid}.hero-img-panel .hero-gallery-item{aspect-ratio:4/3;border-radius:12px;position:relative;overflow:hidden;box-shadow:0 4px 16px #0000001a}.hero-img-panel .hero-gallery-item img{object-fit:cover;width:100%;height:100%;transition:transform .35s;display:block}.hero-img-panel .hero-gallery-item:hover img{transform:scale(1.05)}.hero-img-panel .hero-gallery-item:nth-child(odd){margin-top:1rem}.hero-gallery-delete{color:#fff;cursor:pointer;opacity:0;background:#ef4444d9;border:none;border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;font-size:.8rem;transition:opacity .2s;display:flex;position:absolute;top:6px;right:6px}.hero-gallery-item:hover .hero-gallery-delete{opacity:1}.hero{text-align:center;max-width:800px;margin:0 auto;padding:10rem 2rem 4rem}.hero.hero-center{max-width:420px;margin:0;padding:0 1.5rem}.hero-badge{color:var(--primary);text-transform:uppercase;letter-spacing:1px;background:#2563eb14;border:1px solid #2563eb26;border-radius:50px;align-items:center;gap:.5rem;margin-bottom:1.5rem;padding:.4rem 1rem;font-size:.75rem;font-weight:700;display:inline-flex}.hero h1{letter-spacing:-1px;background:linear-gradient(90deg,#0f172a,#334155);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:1rem;font-size:clamp(1.6rem,3vw,2.4rem);font-weight:800;line-height:1.15}.hero p{color:var(--text-muted);max-width:600px;margin:0 auto;font-size:.9rem;line-height:1.6}.hero-upload-btn{background:var(--primary);color:#fff;cursor:pointer;border-radius:10px;align-items:center;gap:.5rem;padding:.5rem 1.1rem;font-size:.8rem;font-weight:600;transition:background .2s;display:inline-flex}.hero-upload-btn:hover{background:#1d4ed8}.content-container{max-width:1200px;margin:0 auto;padding:0 2rem 5rem}.filters-container{justify-content:center;margin-bottom:3rem;display:flex}.filters{background:var(--surface-color);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--surface-border);box-shadow:var(--surface-shadow);border-radius:16px;flex-wrap:wrap;gap:.5rem;padding:.5rem;display:flex}.filter-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:10px;padding:.6rem 1.25rem;font-size:.875rem;font-weight:600;transition:all .3s}.filter-btn:hover{color:var(--text-main);background:#0f172a08}.filter-btn.active{color:var(--primary);border-color:var(--surface-border);background:#fff;box-shadow:0 4px 10px #00000008}.facilities-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:2rem;display:grid}.card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--surface-border);box-shadow:var(--surface-shadow);background:#ffffffb3;border-radius:24px;flex-direction:column;transition:all .4s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden}.card:hover{box-shadow:var(--surface-hover-shadow);background:#fffffff2;border-color:#2563eb4d;transform:translateY(-5px)}.card:before{content:"";opacity:0;pointer-events:none;background:radial-gradient(circle at 100% 0,#2563eb1a,#0000 70%);width:150px;height:150px;transition:opacity .4s;position:absolute;top:0;right:0}.card:hover:before{opacity:1}.card-image{border-bottom:1px solid var(--surface-border);background:linear-gradient(135deg,#f8fafc,#f1f5f9);justify-content:center;align-items:center;height:140px;display:flex;position:relative;overflow:hidden}.card:hover .card-image{background:linear-gradient(135deg,#eff6ff,#e0f2fe)}.card-icon{border:1px solid var(--surface-border);width:64px;height:64px;color:var(--text-muted);z-index:2;background:#fff;border-radius:16px;justify-content:center;align-items:center;transition:all .4s;display:flex;box-shadow:0 8px 20px #0000000d}.card:hover .card-icon{color:var(--primary);border-color:#2563eb33;transform:scale(1.1);box-shadow:0 10px 25px #2563eb26}.status-badge{z-index:2;text-transform:uppercase;letter-spacing:1px;border:1px solid var(--surface-border);background:#fff;border-radius:50px;align-items:center;gap:.4rem;padding:.3rem .8rem;font-size:.65rem;font-weight:700;display:inline-flex;position:absolute;top:1rem;left:1rem;box-shadow:0 4px 10px #0000000d}.status-badge.available{color:var(--success);border-color:#10b98133}.status-badge.reserved{color:var(--warning);border-color:#f59e0b33}.status-dot{border-radius:50%;width:6px;height:6px}.status-dot.available{background:var(--success);box-shadow:0 0 8px var(--success);animation:2s infinite pulse}.status-dot.reserved{background:var(--warning)}@keyframes pulse{0%{transform:scale(1);box-shadow:0 0 #2563eb66}70%{transform:scale(1.05);box-shadow:0 0 0 8px #2563eb00}to{transform:scale(1);box-shadow:0 0 #2563eb00}}.card-body{flex-direction:column;flex:1;padding:1.5rem;display:flex}.card-title{color:var(--text-main);margin-bottom:.5rem;font-size:1.1rem;font-weight:700}.card-desc{color:var(--text-muted);-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;margin-bottom:1.5rem;font-size:.85rem;display:-webkit-box;overflow:hidden}.card-footer{flex-direction:column;gap:1rem;margin-top:auto;display:flex}.capacity{color:var(--text-muted);border:1px solid var(--surface-border);background:#f8fafc;border-radius:8px;align-items:center;gap:.5rem;width:fit-content;padding:.4rem .8rem;font-size:.75rem;font-weight:600;display:inline-flex}.divider{background:linear-gradient(to right, transparent, var(--surface-border), transparent);height:1px;margin:4rem 0}.feed-section{flex-direction:column;align-items:center;display:flex}.feed-header{text-align:center;margin-bottom:3rem}.feed-badge{background:var(--success-bg);color:var(--success);text-transform:uppercase;letter-spacing:1px;border:1px solid #10b98133;border-radius:50px;align-items:center;gap:.4rem;margin-bottom:1rem;padding:.3rem 1rem;font-size:.7rem;font-weight:700;display:inline-flex}.feed-header h2{letter-spacing:-.5px;font-size:2rem;font-weight:800}.feed-container{width:100%;max-width:800px;position:relative}.feed-line{z-index:0;background:linear-gradient(#0000,#e2e8f0,#0000);width:2px;position:absolute;top:2rem;bottom:2rem;left:2rem}@media (width<=640px){.feed-line{display:none}}.feed-list{z-index:1;flex-direction:column;gap:1rem;display:flex;position:relative}.feed-item{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--surface-border);box-shadow:var(--surface-shadow);background:#fffc;border-radius:20px;align-items:flex-start;gap:1.5rem;padding:1.5rem;transition:all .3s;display:flex}.feed-item:hover{box-shadow:var(--surface-hover-shadow);border-color:#2563eb33;transform:translateY(-2px)scale(1.01)}.feed-icon{border:1px solid var(--surface-border);width:48px;height:48px;color:var(--primary);background:#f8fafc;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.feed-content{flex:1}.feed-top{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.feed-title{color:var(--text-main);font-weight:700}.feed-status{text-transform:uppercase;letter-spacing:1px;border-radius:50px;padding:.2rem .6rem;font-size:.65rem;font-weight:700}.feed-status.approved{background:var(--success-bg);color:var(--success)}.feed-status.pending{background:var(--warning-bg);color:var(--warning)}.feed-desc{color:var(--text-muted);margin-bottom:.8rem;font-size:.9rem}.feed-meta{color:#94a3b8;gap:1.5rem;font-size:.75rem;font-weight:600;display:flex}.feed-meta span{align-items:center;gap:.4rem;display:flex}.animate-slide-up{opacity:0;animation:.8s cubic-bezier(.16,1,.3,1) forwards slideUp}.animate-fade{opacity:0;animation:1s forwards fade}.delay-1{animation-delay:.1s}.delay-2{animation-delay:.2s}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fade{0%{opacity:0}to{opacity:1}}.modal-overlay{z-index:100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);opacity:0;pointer-events:none;background:#0f172a4d;justify-content:center;align-items:center;transition:all .4s cubic-bezier(.16,1,.3,1);display:flex;position:fixed;inset:0}.modal-overlay.active{opacity:1;pointer-events:auto}.modal{-webkit-backdrop-filter:blur(25px);backdrop-filter:blur(25px);border:1px solid var(--surface-border);background:#ffffffe6;border-radius:28px;width:90%;max-width:500px;max-height:90vh;padding:2rem;transition:all .4s cubic-bezier(.16,1,.3,1);position:relative;overflow-y:auto;transform:scale(.95)translateY(10px);box-shadow:0 30px 60px #0f172a26}.modal-overlay.active .modal{transform:scale(1)translateY(0)}.modal-close{border:1px solid var(--surface-border);cursor:pointer;width:36px;height:36px;color:var(--text-muted);background:#f8fafc;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex;position:absolute;top:1.5rem;right:1.5rem}.modal-close:hover{color:var(--text-main);background:#f1f5f9;transform:rotate(90deg)}.modal-header{margin-bottom:2rem}.modal-badge{color:var(--primary);text-transform:uppercase;letter-spacing:1px;background:#2563eb14;border:1px solid #2563eb26;border-radius:50px;align-items:center;gap:.4rem;margin-bottom:.75rem;padding:.3rem .8rem;font-size:.65rem;font-weight:700;display:inline-flex}#modalFacilityTitle{letter-spacing:-.5px;color:var(--text-main);font-size:1.5rem;font-weight:800}#modalFacilityCapacity{color:var(--text-muted);align-items:center;gap:.4rem;margin-top:.25rem;font-size:.85rem;display:flex}.modal-form{scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent;flex-direction:column;gap:1.25rem;display:flex}.modal-form::-webkit-scrollbar{width:5px}.modal-form::-webkit-scrollbar-track{background:0 0}.modal-form::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:10px}.modal-form::-webkit-scrollbar-thumb:hover{background:#94a3b8}.form-group{flex-direction:column;gap:.5rem;display:flex}.form-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.form-group label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-size:.75rem;font-weight:700}.date-selector{scrollbar-width:none;gap:.6rem;padding:.25rem .25rem .5rem;display:flex;overflow-x:auto}.date-selector::-webkit-scrollbar{display:none}.date-card{border:1px solid var(--surface-border);text-align:center;cursor:pointer;-webkit-user-select:none;user-select:none;background:#fffc;border-radius:14px;flex:0 0 68px;padding:.75rem .5rem;transition:all .3s}.date-card:hover{background:#f8fafc;border-color:#2563eb4d}.date-card.active{background:var(--primary);border-color:var(--primary);color:#fff;transform:translateY(-2px);box-shadow:0 8px 20px #2563eb40}.date-card.disabled{opacity:.55;cursor:not-allowed;border-color:var(--surface-border);background:#f1f5f999}.date-card.disabled:hover{border-color:var(--surface-border);background:#f1f5f999}.date-card-day{text-transform:uppercase;opacity:.6;font-size:.65rem;font-weight:700}.date-card.active .date-card-day{opacity:.9}.date-card-num{margin:.1rem 0;font-size:1.25rem;font-weight:800}.date-card-month{opacity:.6;font-size:.65rem;font-weight:700}.date-card.active .date-card-month{opacity:.9}.input-wrapper{align-items:center;gap:.75rem;display:flex;position:relative}.input-wrapper>i{width:18px;height:18px;color:var(--text-muted);pointer-events:none;flex-shrink:0;position:static}.input-wrapper input{border:1px solid var(--surface-border);color:var(--text-main);background:#fffc;border-radius:12px;outline:none;flex:1;padding:.7rem 1rem;font-family:inherit;font-size:.88rem;font-weight:500;transition:all .3s}.input-wrapper input:focus{border-color:var(--primary);background:#fff;box-shadow:0 0 0 4px #2563eb14}.btn-submit{border-radius:12px;margin-top:.5rem;padding:.9rem}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;margin-bottom:3.5rem;display:grid}.stat-card{-webkit-backdrop-filter:blur(25px);backdrop-filter:blur(25px);border:1px solid var(--surface-border);box-shadow:var(--surface-shadow);background:#ffffffb3;border-radius:20px;align-items:center;gap:1.25rem;padding:1.5rem;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex}.stat-card:hover{box-shadow:var(--surface-hover-shadow);border-color:#2563eb33;transform:translateY(-2px)}.stat-icon{border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;font-size:1.25rem;display:flex}.stat-icon.pending{background:var(--warning-bg);color:var(--warning)}.stat-icon.approved{background:var(--success-bg);color:var(--success)}.stat-icon.total{color:var(--primary);background:#2563eb14}.stat-icon i{width:22px;height:22px}.stat-details{flex-direction:column;display:flex}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:.2rem;font-size:.72rem;font-weight:700}.stat-val{color:var(--text-main);font-size:1.85rem;font-weight:800;line-height:1}.admin-table-container{-webkit-backdrop-filter:blur(25px);backdrop-filter:blur(25px);border:1px solid var(--surface-border);box-shadow:var(--surface-shadow);background:#ffffffbf;border-radius:24px;margin-bottom:1.5rem;overflow:hidden}.admin-table{border-collapse:collapse;text-align:left;width:100%}.admin-table th{border-bottom:1px solid var(--surface-border);text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);background:#0f172a04;padding:1.25rem 1.5rem;font-size:.72rem;font-weight:800}.admin-table td{border-bottom:1px solid var(--surface-border);color:var(--text-main);vertical-align:middle;padding:1.35rem 1.5rem;font-size:.88rem}.admin-table tr:last-child td{border-bottom:none}.requester-name{color:var(--text-main);font-weight:700}.requester-role{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-top:.15rem;font-size:.72rem;font-weight:600}.actions-cell{gap:.6rem;display:flex}.btn-action{cursor:pointer;border:1px solid #0000;border-radius:10px;justify-content:center;align-items:center;width:38px;height:38px;transition:all .25s;display:inline-flex}.btn-approve{background:var(--success-bg);color:var(--success);border-color:#10b98126}.btn-approve:hover{background:var(--success);color:#fff;border-color:var(--success);transform:translateY(-1px);box-shadow:0 4px 12px #10b98140}.btn-reject{color:#ef4444;background:#ef444414;border-color:#ef444426}.btn-reject:hover{color:#fff;background:#ef4444;border-color:#ef4444;transform:translateY(-1px);box-shadow:0 4px 12px #ef444440}.admin-grid{grid-template-columns:1.6fr 1fr;align-items:start;gap:2rem;display:grid}@media (width<=1024px){.admin-grid{grid-template-columns:1fr}}.admin-panel{-webkit-backdrop-filter:blur(25px);backdrop-filter:blur(25px);border:1px solid var(--surface-border);box-shadow:var(--surface-shadow);background:#ffffffb3;border-radius:24px;margin-bottom:2rem;padding:1.75rem}.panel-badge.approved{background:var(--success-bg);color:var(--success)}.panel-badge.warning{color:#d97706;background:#f59e0b1a}.upcoming-list{flex-direction:column;gap:1rem;display:flex}.upcoming-card{border:1px solid var(--surface-border);background:#ffffff80;border-radius:16px;justify-content:space-between;align-items:center;gap:1rem;padding:1.15rem 1.35rem;transition:all .25s;display:flex}.upcoming-card:hover{background:#ffffffd9;border-color:#2563eb33;transform:translate(4px);box-shadow:0 4px 12px #0f172a08}.upcoming-main-info{flex-direction:column;gap:.2rem;display:flex}.upcoming-facility{color:var(--text-main);font-weight:700}.upcoming-purpose{color:var(--text-muted);font-size:.8rem}.upcoming-meta{text-align:right;flex-shrink:0;align-items:center;gap:1rem;display:flex}.upcoming-datetime{flex-direction:column;font-size:.85rem;font-weight:600;display:flex}.upcoming-time{color:var(--text-muted);font-size:.75rem}.leaderboard{flex-direction:column;gap:1.25rem;display:flex}.leaderboard-item{flex-direction:column;gap:.4rem;display:flex}.leaderboard-info{justify-content:space-between;font-size:.85rem;font-weight:600;display:flex}.leaderboard-name{color:var(--text-main);font-weight:700}.leaderboard-count{color:var(--text-muted)}.leaderboard-bar-bg{background:#f1f5f9;border-radius:4px;height:8px;overflow:hidden}.leaderboard-bar-fill{background:linear-gradient(90deg, var(--primary) 0%, #3b82f6 100%);border-radius:4px;width:0;height:100%;transition:width .8s cubic-bezier(.16,1,.3,1)}.peak-timings{flex-direction:column;gap:1rem;display:flex}.peak-time-row{align-items:center;gap:1rem;display:flex}.peak-time-label{width:90px;color:var(--text-muted);font-size:.78rem;font-weight:700}.peak-time-bar-container{background:#f1f5f9;border-radius:6px;flex-grow:1;height:20px;position:relative;overflow:hidden}.peak-time-bar-fill{background:#2563ebb3;border-radius:6px;width:0;height:100%;transition:width .8s cubic-bezier(.16,1,.3,1)}.peak-time-percentage{color:var(--text-muted);font-size:.68rem;font-weight:800;position:absolute;top:50%;right:.6rem;transform:translateY(-50%)}.peak-time-bar-container.active .peak-time-bar-fill{background:linear-gradient(90deg,#f59e0b 0%,#eab308 100%)}.peak-time-bar-container.active .peak-time-percentage{color:#78350f}.cancellation-summary{flex-direction:column;gap:1rem;display:flex}.cancellation-log-card{background:#ef444408;border:1px solid #ef44441a;border-radius:14px;padding:1rem 1.25rem}.cancellation-log-header{color:#ef4444;justify-content:space-between;align-items:center;margin-bottom:.3rem;font-size:.85rem;font-weight:700;display:flex}.cancellation-log-body{color:var(--text-muted);font-size:.78rem;line-height:1.4}.login-logo{justify-content:center;align-items:center;gap:.6rem;display:flex}.login-card h2{letter-spacing:-.6px;color:var(--text-main);margin-top:1.25rem;font-size:1.65rem;font-weight:800}.login-subtitle{color:var(--text-muted);margin-top:.35rem;margin-bottom:2rem;font-size:.85rem;font-weight:500;line-height:1.4}.login-tabs{background:#f1f5f9;border:1px solid #0f172a08;border-radius:14px;grid-template-columns:1fr 1fr;margin-bottom:2rem;padding:.3rem;display:grid}.login-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:11px;padding:.75rem;font-family:inherit;font-size:.85rem;font-weight:700;transition:all .25s cubic-bezier(.4,0,.2,1)}.login-tab:hover:not(.active){color:var(--text-main)}.login-tab.active{color:var(--primary);background:#fff;box-shadow:0 4px 15px #0f172a0f}.login-form{text-align:left;flex-direction:column;gap:1.8rem;display:flex}.login-footer{color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;margin-top:2.25rem;font-size:.7rem;font-weight:700}.user-badge i{color:var(--primary)}.feed-status.rejected{color:#ef4444;background:#ef444414}.hidden{display:none!important}.login-container{justify-content:center;align-items:center;min-height:100vh;padding:2rem 1.5rem;display:flex}.login-card{-webkit-backdrop-filter:blur(35px);backdrop-filter:blur(35px);border:1px solid var(--surface-border);text-align:center;background:#fffc;border-radius:32px;width:100%;max-width:460px;padding:3rem 2.5rem;box-shadow:0 30px 70px #0f172a1a}.login-logo{justify-content:center;align-items:center;gap:.6rem;margin-bottom:1.5rem;display:flex}.login-card h2{letter-spacing:-.6px;color:var(--text-main);margin-bottom:.4rem;font-size:1.75rem;font-weight:800}.login-subtitle{color:var(--text-muted);margin-bottom:2.5rem;font-size:.88rem}.role-selector{flex-direction:column;gap:1rem;margin-bottom:2rem;display:flex}.role-card{border:1.5px solid var(--surface-border);cursor:pointer;text-align:left;background:#ffffffb3;border-radius:20px;align-items:center;gap:1.25rem;padding:1.25rem 1.5rem;font-family:inherit;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden}.role-card:hover{border-color:var(--primary);background:#2563eb08;transform:translateY(-2px);box-shadow:0 10px 30px #2563eb1a}.role-icon{border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;display:flex}.faculty-icon{color:var(--primary);background:#2563eb1a}.admin-icon{color:var(--success);background:#10b9811a}.role-label{color:var(--text-main);letter-spacing:-.3px;font-size:1rem;font-weight:800}.role-desc{color:var(--text-muted);margin-top:.15rem;font-size:.78rem;font-weight:500}.role-arrow{color:var(--text-muted);margin-left:auto;transition:transform .25s}.role-card:hover .role-arrow{color:var(--primary);transform:translate(4px)}.login-footer{color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;font-size:.7rem;font-weight:600}.calendar-view-icon{color:#0891b2;background:#06b6d41a}.cal-view-topbar{z-index:50;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--surface-border);background:#ffffffd9;position:fixed;top:0;left:0;right:0}.cal-view-topbar-inner{justify-content:space-between;align-items:center;gap:1rem;max-width:1200px;margin:0 auto;padding:.85rem 2rem;display:flex}.cal-view-topbar-title{color:var(--text-main);align-items:center;gap:.5rem;font-size:.95rem;font-weight:700;display:flex}.cal-view-badge{color:#0891b2;text-transform:uppercase;letter-spacing:.8px;background:#06b6d41a;border:1px solid #06b6d440;border-radius:50px;align-items:center;margin-left:.25rem;padding:.15rem .65rem;font-size:.65rem;font-weight:700;display:inline-flex}.cal-view-content{padding-top:0}.user-badge{color:var(--text-main);border:1px solid var(--surface-border);background:#0f172a08;border-radius:12px;align-items:center;gap:.5rem;padding:.45rem .9rem;font-size:.85rem;font-weight:700;display:flex}.recent-section{margin-top:4rem}.section-header{margin-bottom:2rem}.section-header h2{letter-spacing:-.5px;margin-top:.75rem;font-size:1.75rem;font-weight:800}.recent-list{flex-direction:column;gap:1rem;display:flex}.recent-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--surface-border);box-shadow:var(--surface-shadow);background:#ffffffbf;border-radius:18px;justify-content:space-between;align-items:center;gap:1rem;padding:1.25rem 1.5rem;transition:all .25s;display:flex}.recent-card:hover{box-shadow:var(--surface-hover-shadow);border-color:#2563eb33;transform:translate(4px)}.recent-facility{color:var(--text-main);font-size:.95rem;font-weight:700}.recent-purpose{color:var(--text-muted);margin:.15rem 0 .5rem;font-size:.82rem}.recent-meta{color:#94a3b8;gap:1rem;font-size:.72rem;font-weight:600;display:flex}.recent-meta span{align-items:center;gap:.3rem;display:flex}.cal-day-group{margin-bottom:2.5rem}.cal-day-label{text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin-bottom:.85rem;padding-left:.25rem;font-size:.78rem;font-weight:800}.cal-events{flex-direction:column;gap:.75rem;display:flex}.cal-event{border:1px solid var(--surface-border);box-shadow:var(--surface-shadow);background:#fffc;border-left:3px solid #0000;border-radius:16px;align-items:center;gap:1.25rem;padding:1.1rem 1.4rem;transition:all .25s;display:flex}.cal-event.approved{border-left-color:var(--success)}.cal-event.pending{border-left-color:var(--warning)}.cal-event:hover{box-shadow:var(--surface-hover-shadow);transform:translate(4px)}.cal-event-time{color:var(--text-muted);flex-shrink:0;min-width:100px;font-size:.78rem;font-weight:700}.cal-event-body{flex:1}.cal-event-title{color:var(--text-main);font-size:.95rem;font-weight:700}.cal-event-purpose{color:var(--text-muted);margin-top:.15rem;font-size:.78rem}.my-bookings-filters{flex-wrap:wrap;gap:.5rem;margin-bottom:2rem;display:flex}.my-booking-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--surface-border);box-shadow:var(--surface-shadow);background:#fffc;border-radius:20px;justify-content:space-between;align-items:center;gap:1.5rem;margin-bottom:1rem;padding:1.5rem;transition:all .25s;display:flex}.my-booking-card:hover{box-shadow:var(--surface-hover-shadow);border-color:#2563eb26;transform:translateY(-2px)}.my-booking-facility{color:var(--text-main);letter-spacing:-.3px;font-size:1.05rem;font-weight:800}.my-booking-purpose{color:var(--text-muted);margin:.2rem 0 .75rem;font-size:.85rem}.my-booking-meta{color:#94a3b8;gap:1.25rem;font-size:.75rem;font-weight:600;display:flex}.my-booking-meta span{align-items:center;gap:.35rem;display:flex}.my-booking-status-col{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:.4rem;display:flex}.my-booking-note{color:var(--text-muted);align-items:center;gap:.3rem;font-size:.7rem;font-weight:600;display:flex}.stat-icon.danger{color:#ef4444;background:#ef444414}.empty-row{text-align:center;color:var(--text-muted);padding:3rem;font-weight:500}.empty-row i{margin:0 auto .75rem;display:block}.admin-panel{-webkit-backdrop-filter:blur(25px);backdrop-filter:blur(25px);border:1px solid var(--surface-border);box-shadow:var(--surface-shadow);background:#ffffffb3;border-radius:24px;padding:1.75rem}.panel-header{margin-bottom:1.5rem}.panel-header h3{color:var(--text-main);letter-spacing:-.4px;margin-top:.4rem;font-size:1.25rem;font-weight:800}.panel-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:50px;align-items:center;gap:.4rem;padding:.3rem .7rem;font-size:.65rem;font-weight:700;display:inline-flex}.panel-badge.pending{background:var(--warning-bg);color:var(--warning)}.panel-badge.total{color:var(--primary);background:#2563eb14}.panel-badge.danger{color:#ef4444;background:#ef444414}.time-slots-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:.6rem;margin-top:.4rem;display:grid}.time-slot-chip{border:1px solid var(--surface-border);color:var(--text-main);cursor:pointer;background:#fffc;border-radius:12px;flex-direction:column;align-items:center;gap:.1rem;padding:.6rem .5rem;font-size:.8rem;font-weight:600;transition:all .3s;display:flex;position:relative;overflow:hidden}.time-slot-chip:hover:not(.booked){background:#f8fafc;border-color:#2563eb4d}.time-slot-chip.active{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 4px 12px #2563eb33}.time-slot-chip.booked{opacity:.45;cursor:not-allowed;border-color:var(--surface-border);color:var(--text-muted);background:#f1f5f999}.time-slot-chip .status-lbl{text-transform:uppercase;color:#ef4444;margin-top:.1rem;font-size:.6rem;font-weight:700}.time-slot-chip:not(.booked) .status-lbl{color:var(--success)}.search-container{width:100%;max-width:520px;margin:0 auto 2.2rem}.search-input-wrapper{align-items:center;display:flex;position:relative}.search-input-wrapper .search-icon{width:18px;height:18px;color:var(--text-muted);pointer-events:none;position:absolute;left:1.1rem}.search-input-wrapper input{border:1px solid var(--surface-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);width:100%;color:var(--text-main);box-shadow:var(--surface-shadow);background:#ffffffb3;border-radius:16px;outline:none;padding:.85rem 2.8rem .85rem 2.85rem;font-size:.9rem;font-weight:500;transition:all .3s}.search-input-wrapper input:focus{border-color:var(--primary);background:#fff;box-shadow:0 8px 24px #2563eb14}.clear-search-btn{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:.25rem;transition:all .2s;display:flex;position:absolute;right:1rem}.clear-search-btn:hover{color:var(--text-main);background:#0000000d}.custom-calendar{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--surface-border);box-shadow:var(--surface-shadow);background:#fff9;border-radius:20px;flex-direction:column;gap:1.5rem;width:100%;padding:1.5rem;display:flex}.calendar-header-bar{border-bottom:1px solid var(--surface-border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;padding-bottom:1rem;display:flex}.calendar-nav-group{align-items:center;gap:.5rem;display:flex}.calendar-title-display{color:var(--text-main);text-align:center;min-width:180px;font-size:1.15rem;font-weight:800}.calendar-controls-right{flex-wrap:wrap;align-items:center;gap:1rem;display:flex}.calendar-view-btn-group{border:1px solid var(--surface-border);background:#0000000a;border-radius:12px;padding:.25rem;display:flex}.calendar-view-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:.4rem .9rem;font-size:.82rem;font-weight:700;transition:all .2s}.calendar-view-btn.active{color:var(--primary);background:#fff;box-shadow:0 4px 12px #0000000d}.calendar-filter-select{border:1px solid var(--surface-border);color:var(--text-main);cursor:pointer;box-shadow:var(--surface-shadow);background:#fff;border-radius:12px;outline:none;padding:.45rem 1rem;font-size:.82rem;font-weight:700}.calendar-month-grid{border:1px solid var(--surface-border);background:#fff;border-radius:14px;grid-template-columns:repeat(7,1fr);display:grid;overflow:hidden}.calendar-weekday-header{border-bottom:1px solid var(--surface-border);text-align:center;color:var(--text-muted);text-transform:uppercase;background:#00000005;grid-column:span 7;grid-template-columns:repeat(7,1fr);padding:.75rem 0;font-size:.78rem;font-weight:700;display:grid}.calendar-weekday-header div{border-right:1px solid var(--surface-border)}.calendar-weekday-header div:last-child{border-right:none}.calendar-day-cell{border-right:1px solid var(--surface-border);border-bottom:1px solid var(--surface-border);background:#fff;flex-direction:column;gap:.35rem;min-height:100px;padding:.5rem;transition:background .2s;display:flex;position:relative}.calendar-day-cell:nth-child(7n){border-right:none}.calendar-day-cell.other-month{color:#cbd5e1;background:#f8fafc66}.calendar-day-cell.today{background:#2563eb08}.calendar-day-number{color:var(--text-main);border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:.82rem;font-weight:700;display:inline-flex}.calendar-day-cell.today .calendar-day-number{background:var(--primary);color:#fff}.calendar-day-cell.other-month .calendar-day-number{color:#94a3b8;opacity:.5}.calendar-day-events{flex-direction:column;gap:.25rem;max-height:80px;display:flex;overflow-y:auto}.calendar-event-chip{white-space:nowrap;text-overflow:ellipsis;cursor:pointer;border-left:3px solid #0000;border-radius:6px;padding:.2rem .4rem;font-size:.68rem;font-weight:700;line-height:1.2;transition:transform .15s,opacity .15s;overflow:hidden}.calendar-event-chip:hover{opacity:.9;transform:translateY(-1px)}.calendar-event-chip.approved{color:#047857;background:#10b9811a;border-left-color:#10b981}.calendar-event-chip.pending{color:#b45309;background:#f59e0b1a;border-left-color:#f59e0b}.calendar-event-chip.rejected{color:#b91c1c;background:#ef44441a;border-left-color:#ef4444}.calendar-event-chip.cancelled{color:#475569;background:#64748b1a;border-left-color:#64748b}.calendar-week-grid{grid-template-columns:repeat(7,1fr);gap:.75rem;display:grid}@media (width<=768px){.calendar-week-grid{grid-template-columns:1fr}}.calendar-week-day-card{border:1px solid var(--surface-border);background:#fff;border-radius:14px;flex-direction:column;min-height:220px;display:flex;overflow:hidden;box-shadow:0 4px 12px #00000005}.calendar-week-day-header{border-bottom:1px solid var(--surface-border);text-align:center;background:#00000005;padding:.75rem}.calendar-week-day-title{color:var(--text-main);text-transform:uppercase;font-size:.82rem;font-weight:700}.calendar-week-day-subtitle{color:var(--text-muted);font-size:.72rem;font-weight:600}.calendar-week-day-events{flex-direction:column;flex:1;gap:.5rem;padding:.6rem;display:flex;overflow-y:auto}.calendar-day-view-container{border:1px solid var(--surface-border);background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 4px 12px #00000005}.calendar-day-view-header{border-bottom:1px solid var(--surface-border);color:var(--text-main);background:#00000005;padding:1rem 1.5rem;font-size:.95rem;font-weight:700}.calendar-day-view-slots{flex-direction:column;display:flex}.calendar-day-view-slot{border-bottom:1px solid var(--surface-border);display:flex}.calendar-day-view-slot:last-child{border-bottom:none}.calendar-day-view-time-col{border-right:1px solid var(--surface-border);width:120px;color:var(--text-muted);text-align:right;background:#00000003;padding:1.25rem 1rem;font-size:.78rem;font-weight:700}.calendar-day-view-events-col{flex-direction:column;flex:1;justify-content:center;gap:.5rem;padding:.75rem;display:flex}.recurring-day-btn{border:1px solid var(--surface-border);width:32px;height:32px;color:var(--text-main);cursor:pointer;-webkit-user-select:none;user-select:none;background:#fff;border-radius:50%;justify-content:center;align-items:center;font-size:.78rem;font-weight:700;transition:all .2s;display:flex}.recurring-day-btn:hover{border-color:var(--primary);background:#2563eb0a}.recurring-day-btn.active{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 4px 10px #2563eb40}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes slideDownBanner{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDownMenu{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.auth-form{flex-direction:column;gap:1.1rem;margin-top:1.5rem;display:flex}.auth-form .form-group label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:.4rem;font-size:.72rem;font-weight:700;display:block}.auth-error{color:#ef4444;background:#ef444412;border:1px solid #ef444433;border-radius:10px;align-items:center;gap:.4rem;padding:.6rem .9rem;font-size:.82rem;font-weight:600;line-height:1.4;display:flex}.pwd-toggle-btn{cursor:pointer;color:var(--text-muted);z-index:2;background:0 0;border:none;justify-content:center;align-items:center;padding:.25rem;transition:color .2s;display:flex;position:absolute;top:50%;right:.6rem;transform:translateY(-50%)}.pwd-toggle-btn:hover{color:var(--primary)}.pwd-toggle-btn svg{width:16px;height:16px}.pwd-strength-wrap{background:#e2e8f0cc;border-radius:4px;height:4px;margin-top:-.4rem;overflow:hidden}.pwd-strength-bar{border-radius:4px;width:0%;height:100%;transition:width .4s,background .4s}.pwd-strength-label{text-align:right;min-height:1rem;font-size:.7rem;font-weight:700;transition:color .3s}.warning-banner{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:#fff;z-index:40;background:linear-gradient(135deg,#f59e0bf2,#d97706f2);border:1px solid #fff3;border-radius:16px;justify-content:space-between;align-items:center;width:calc(100% - 4rem);max-width:1200px;margin:6.5rem auto 1rem;padding:1rem 1.5rem;animation:.5s cubic-bezier(.16,1,.3,1) forwards slideDownBanner;display:flex;box-shadow:0 10px 25px #f59e0b33}.warning-banner.hidden{display:none!important}.warning-banner-content{align-items:center;gap:.75rem;font-size:.95rem;font-weight:600;display:flex}.warning-banner-icon{stroke-width:2.5px;color:#fef08a;flex-shrink:0;width:20px;height:20px}.warning-banner-actions{align-items:center;gap:1rem;display:flex}.btn-warning-banner{color:#b45309;cursor:pointer;background:#fff;border:none;border-radius:8px;padding:.5rem 1rem;font-size:.85rem;font-weight:700;transition:all .2s;box-shadow:0 4px 12px #0000001a}.btn-warning-banner:hover{background:#fef3c7;transform:translateY(-1px)}.btn-warning-banner-close{color:#fff;cursor:pointer;opacity:.8;background:0 0;border:none;justify-content:center;align-items:center;padding:.25rem;transition:opacity .2s;display:flex}.btn-warning-banner-close:hover{opacity:1}.btn-warning-banner-close i,.btn-warning-banner-close svg{width:18px;height:18px}.profile-dropdown{display:inline-block;position:relative}.dropdown-menu{border:1px solid var(--surface-border);z-index:60;background:#fff;border-radius:12px;flex-direction:column;gap:.25rem;min-width:170px;padding:.5rem;animation:.2s forwards slideDownMenu;display:flex;position:absolute;top:calc(100% + .5rem);right:0;box-shadow:0 10px 25px #00000014}.dropdown-menu.hidden{display:none!important}.dropdown-item{color:var(--text-muted);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:.6rem;width:100%;padding:.6rem .8rem;font-size:.85rem;font-weight:600;transition:all .2s;display:flex}.dropdown-item:hover{color:var(--primary);background:#2563eb0d}.dropdown-item i,.dropdown-item svg{width:14px;height:14px}.settings-card{max-width:600px;margin:0 auto}#calendarViewPortal{background:#f8fafc;min-height:100vh}.cal-view-topbar-right{align-items:center;gap:.85rem;display:flex}.cal-view-user-chip{background:#06b6d40f;border:1px solid #06b6d438;border-radius:50px;align-items:center;gap:.5rem;padding:.3rem .85rem .3rem .4rem;display:flex}.cal-view-user-icon{color:#0891b2;background:#06b6d41f;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;display:flex}.cal-view-user-name{color:var(--text-main);text-overflow:ellipsis;white-space:nowrap;max-width:160px;font-size:.8rem;font-weight:700;overflow:hidden}.cal-exit-btn{color:var(--text-muted);border:1px solid var(--surface-border);background:#0f172a0a;border-radius:10px;padding:.42rem 1rem;font-size:.82rem;font-weight:700;transition:all .2s}.cal-exit-btn:hover{color:#ef4444;background:#ef44440f;border-color:#ef444440;transform:none}.cal-view-page-body{padding-top:72px}.cal-view-hero-strip{background:linear-gradient(135deg,#0f172a 0%,#162040 55%,#0f2a45 100%);padding:2.75rem 0 2.5rem;position:relative;overflow:hidden}.cal-view-hero-strip:before{content:"";pointer-events:none;background-image:linear-gradient(90deg,#ffffff06 1px,#0000 1px),linear-gradient(#ffffff06 1px,#0000 1px);background-size:32px 32px;position:absolute;inset:0}.cal-view-hero-strip:after{content:"";pointer-events:none;background:radial-gradient(#2563eb47 0%,#0000 68%);width:45%;height:160%;position:absolute;top:-30%;right:-5%}.cal-view-hero-inner{z-index:2;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:2.5rem;display:flex;position:relative}.cal-view-hero-left{flex:1;min-width:260px}.cal-view-hero-eyebrow{text-transform:uppercase;letter-spacing:1.3px;color:#94a3b8bf;align-items:center;gap:.4rem;margin-bottom:.65rem;font-size:.68rem;font-weight:700;display:inline-flex}.cal-view-hero-title{letter-spacing:-.8px;color:#fff;margin-bottom:.55rem;font-size:clamp(1.65rem,3vw,2.5rem);font-weight:800;line-height:1.12;background:0 0!important;-webkit-background-clip:unset!important;-webkit-text-fill-color:#fff!important}.cal-view-hero-sub{color:#94a3b8d1;max-width:400px;margin-bottom:1rem;font-size:.86rem;line-height:1.58}.cal-view-live-date{color:#94a3b8bf;letter-spacing:.1px;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:8px;align-items:center;gap:.45rem;padding:.32rem .75rem;font-size:.75rem;font-weight:600;display:inline-flex}.cal-view-stats-row{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:.85rem;display:flex}.cal-view-stat-card{text-align:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffff0f;border:1px solid #ffffff1a;border-radius:16px;min-width:92px;padding:1rem 1.35rem;transition:background .2s,border-color .2s}.cal-view-stat-card:hover{background:#ffffff1a;border-color:#ffffff2e}.cal-view-stat-value{color:#fff;letter-spacing:-1px;font-size:1.75rem;font-weight:800;line-height:1;display:block}.cal-view-stat-label{text-transform:uppercase;letter-spacing:.8px;color:#94a3b8a6;justify-content:center;align-items:center;gap:.3rem;margin-top:.3rem;font-size:.65rem;font-weight:700;display:flex}.cal-view-stat-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px;display:inline-block}.cal-view-calendar-section{padding-top:2.25rem;padding-bottom:4rem}@media (width<=768px){.cal-view-hero-inner{flex-direction:column;gap:1.5rem}.cal-view-stats-row{justify-content:flex-start;width:100%}.cal-view-topbar-right .cal-view-user-name{max-width:100px}}@media (width<=1024px){.nav-container{padding:.9rem 1.25rem}.hero-split-wrapper{grid-template-columns:1fr;gap:2rem;padding:6rem 1.5rem 2rem}.hero-img-panel{display:none}.hero.hero-center{text-align:center;max-width:100%;margin:0 auto}.facilities-grid{grid-template-columns:repeat(2,1fr);gap:1.25rem}.admin-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}.cal-view-hero-inner{gap:1.5rem}.cal-view-stats-row{justify-content:flex-start}.warning-banner{flex-wrap:wrap;gap:.75rem;width:calc(100% - 2.5rem);margin:5.5rem 1.25rem 1rem}}@media (width<=640px){body{font-size:15px}.nav-container{flex-wrap:nowrap;gap:.5rem;padding:.75rem 1rem}.logo-img{height:56px}.logo-text{font-size:1rem}.nav-links{display:none!important}.nav-actions{gap:.5rem}.user-badge{padding:.35rem .6rem;font-size:.75rem}.user-badge span{display:none}.hero-split-wrapper{grid-template-columns:1fr;padding:5.5rem 1rem 1.5rem}.hero-img-panel{display:none}.hero.hero-center{text-align:center;max-width:100%;margin:0 auto;padding:0 .5rem}.hero h1{font-size:clamp(1.5rem,6vw,2rem)}.content-container{padding:0 1rem 3rem}.facilities-grid{grid-template-columns:1fr;gap:1rem}.filters-container{margin-bottom:1.75rem}.filters{scrollbar-width:none;flex-wrap:nowrap;gap:.35rem;padding:.4rem;overflow-x:auto}.filters::-webkit-scrollbar{display:none}.filter-btn{white-space:nowrap;padding:.5rem 1rem;font-size:.82rem}.search-container{max-width:100%}.stats-grid{grid-template-columns:repeat(2,1fr);gap:.85rem;margin-bottom:2rem}.stat-val{font-size:1.5rem}.admin-table-container{-webkit-overflow-scrolling:touch;overflow-x:auto}.admin-table{min-width:640px}.admin-table th,.admin-table td{padding:.85rem 1rem;font-size:.8rem}.admin-panel{border-radius:18px;padding:1.25rem 1rem}.admin-grid{grid-template-columns:1fr;gap:1rem}.recent-card{flex-direction:column;align-items:flex-start;gap:.75rem;padding:1rem}.my-booking-card{flex-direction:column;align-items:flex-start;gap:.75rem;padding:1.1rem}.my-booking-status-col{flex-flow:wrap;align-items:flex-start;gap:.5rem}.my-booking-meta{flex-wrap:wrap;gap:.5rem}.feed-item{flex-direction:column;gap:.85rem;padding:1rem}.feed-top{flex-wrap:wrap;gap:.4rem}.feed-meta{flex-wrap:wrap;gap:.75rem}.cal-event{flex-direction:column;gap:.5rem;padding:.85rem 1rem}.cal-event-time{min-width:unset}.modal{border-radius:20px;width:96%;max-height:94vh;padding:1.5rem 1.25rem}.form-row{grid-template-columns:1fr}.login-container{padding:1rem .75rem}.login-card{border-radius:24px;padding:2rem 1.25rem}.login-logo-img{height:100px}.warning-banner{flex-direction:column;align-items:flex-start;gap:.85rem;width:calc(100% - 1.5rem);margin:5rem .75rem .75rem;padding:1rem}.warning-banner-actions{justify-content:flex-end;width:100%}.cal-view-topbar-inner{gap:.5rem;padding:.7rem 1rem}.cal-view-topbar-title{font-size:.82rem}.cal-view-badge{display:none}.cal-view-user-name{max-width:80px;font-size:.72rem}.cal-view-page-body{padding-top:60px}.cal-view-hero-strip{padding:1.75rem 0 1.5rem}.cal-view-hero-inner{flex-direction:column;gap:1.25rem;padding:0 1rem}.cal-view-hero-title{font-size:clamp(1.4rem,5vw,1.85rem)}.cal-view-hero-sub{font-size:.82rem}.cal-view-stats-row{justify-content:flex-start;gap:.6rem}.cal-view-stat-card{min-width:78px;padding:.75rem 1rem}.cal-view-stat-value{font-size:1.35rem}.cal-view-calendar-section{padding-top:1.5rem;padding-bottom:2.5rem}.calendar-header-bar{flex-direction:column;align-items:flex-start;gap:.75rem}.calendar-controls-right{flex-wrap:wrap;width:100%}.calendar-title-display{min-width:unset;font-size:1rem}.calendar-day-cell{min-height:64px;padding:.25rem}.calendar-day-number{width:18px;height:18px;font-size:.72rem}.calendar-day-events{max-height:48px}.calendar-event-chip{padding:.15rem .3rem;font-size:.6rem}.calendar-weekday-header{padding:.5rem 0;font-size:.65rem}.calendar-week-grid{grid-template-columns:1fr}.calendar-day-view-time-col{width:72px;padding:.85rem .5rem;font-size:.7rem}.upcoming-card{flex-direction:column;align-items:flex-start;gap:.5rem}.upcoming-meta{text-align:left;flex-direction:row}.settings-card{max-width:100%}.section-header h2{font-size:1.35rem}}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;opacity:1;pointer-events:auto;background:#0f172a99;justify-content:center;align-items:center;padding:1.5rem;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.modal{-webkit-backdrop-filter:blur(25px);backdrop-filter:blur(25px);border:1px solid var(--surface-border);background:#ffffffe6;border-radius:24px;width:100%;animation:.3s cubic-bezier(.34,1.56,.64,1) scaleUp;position:relative;overflow:hidden;box-shadow:0 20px 50px #0f172a26}.modal-close{width:28px;height:28px;color:var(--text-muted);cursor:pointer;background:#0f172a0d;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:.8rem;transition:all .2s;display:flex;position:absolute;top:1rem;right:1rem}.modal-close:hover{color:#ef4444;background:#ef44441a}.modal-header{padding:1.5rem 1.5rem .5rem}.modal-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:50px;align-items:center;padding:.25rem .65rem;font-size:.65rem;font-weight:700;display:inline-flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleUp{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}
