:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:block;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}html,body{width:100%;height:100%;background:var(--gradient-sky);overflow-x:hidden}:root{--color-midnight: #0a1628;--color-navy: #1a2744;--color-navy-light: #2d3a5c;--color-purple-dark: #4a3f6b;--color-gold: #d4af37;--color-gold-light: #f4e4bc;--color-gold-soft: #e8d5a3;--color-emerald: #1e5631;--color-emerald-light: #2d7a46;--color-ivory: #fffff5;--color-white: #ffffff;--color-cream: #faf8f0;--glow-gold: rgba(212, 175, 55, .6);--glow-gold-strong: rgba(212, 175, 55, .9);--glow-moon: rgba(255, 250, 240, .8);--glow-lantern: rgba(255, 180, 100, .7);--gradient-sky: linear-gradient(180deg, #0a1628 0%, #1a2744 30%, #2d3a5c 60%, #4a3f6b 100%);--gradient-card: linear-gradient(135deg, rgba(212, 175, 55, .1) 0%, rgba(255, 255, 255, .05) 100%);--gradient-gold: linear-gradient(135deg, #d4af37 0%, #f4e4bc 50%, #d4af37 100%);--font-primary: "Cairo", "Segoe UI", Tahoma, sans-serif;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-sm: 8px;--radius-md: 16px;--radius-lg: 24px;--radius-xl: 32px;--radius-full: 50%;--transition-fast: .15s ease;--transition-normal: .3s ease;--transition-slow: .5s ease;--z-stars: 1;--z-mosque-far: 3;--z-moon: 5;--z-particles: 2;--z-lanterns: 6;--z-content: 10;--z-modal: 200}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-primary);direction:ltr;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.ramadan-auth-page{position:relative;min-height:100vh;background:var(--gradient-sky);overflow-x:hidden;display:flex;align-items:center;justify-content:center;padding:0}.starfield{position:fixed;inset:0;z-index:var(--z-stars);overflow:hidden}.star{position:absolute;background:var(--color-white);border-radius:var(--radius-full);will-change:opacity,transform}.star--small{width:1px;height:1px;animation:twinkle-small 3s ease-in-out infinite}.star--medium{width:2px;height:2px;animation:twinkle-medium 4s ease-in-out infinite;box-shadow:0 0 4px #fffc}.star--large{width:3px;height:3px;animation:twinkle-large 5s ease-in-out infinite;box-shadow:0 0 8px #fffc}@keyframes twinkle-small{0%,to{opacity:.3}50%{opacity:.8}}@keyframes twinkle-medium{0%,to{opacity:.4;transform:scale(1)}50%{opacity:1;transform:scale(1.2)}}@keyframes twinkle-large{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.3)}}.particles-container{position:fixed;inset:0;z-index:var(--z-particles);pointer-events:none;overflow:hidden}.particle{position:absolute;border-radius:var(--radius-full);will-change:transform,opacity;animation:float-up linear infinite}.particle--light{width:4px;height:4px;background:var(--color-gold-light);box-shadow:0 0 8px var(--glow-gold)}.particle--dust{width:2px;height:2px;background:#fff9}@keyframes float-up{0%{transform:translateY(100vh) translate(0) scale(0);opacity:0}10%{opacity:1;transform:translateY(90vh) translate(10px) scale(1)}90%{opacity:.8}to{transform:translateY(-10vh) translate(-10px) scale(.5);opacity:0}}.moon-container{position:fixed;top:8%;right:12%;z-index:var(--z-moon);animation:moon-float 8s ease-in-out infinite}@keyframes moon-float{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-15px) rotate(3deg)}}.moon{position:relative;width:120px;height:120px}.moon-crescent{position:absolute;width:100%;height:100%;background:linear-gradient(135deg,var(--color-gold-light) 0%,var(--color-gold) 100%);border-radius:var(--radius-full);box-shadow:0 0 30px var(--glow-gold),0 0 60px var(--glow-gold),0 0 90px #d4af374d,inset -10px -10px 20px #0003;animation:moon-glow 4s ease-in-out infinite}.moon-crescent:before{content:"";position:absolute;top:10%;right:-35%;width:100%;height:80%;background:var(--color-navy);border-radius:var(--radius-full);box-shadow:inset -20px 5px 35px #0000004d}@keyframes moon-glow{0%,to{box-shadow:0 0 30px var(--glow-gold),0 0 60px var(--glow-gold),0 0 90px #d4af374d;filter:brightness(1)}50%{box-shadow:0 0 40px var(--glow-gold-strong),0 0 80px var(--glow-gold),0 0 120px #d4af3766;filter:brightness(1.1)}}.moon-star{position:absolute;font-size:24px;color:var(--color-gold);filter:drop-shadow(0 0 8px var(--glow-gold));animation:star-sparkle 2s ease-in-out infinite}.moon-star--1{top:5%;left:90%;animation-delay:0s}.moon-star--2{top:20%;left:145%;animation-delay:.5s;font-size:18px}.moon-star--3{bottom:5%;left:100%;animation-delay:1s;font-size:16px}.moon-star--4{top:95%;left:60%;font-size:28px;animation-delay:.2s}.moon-star--5{top:50%;left:70%;font-size:20px;animation-delay:.7s}@keyframes star-sparkle{0%,to{opacity:.6;transform:scale(1) rotate(0)}50%{opacity:1;transform:scale(1.2) rotate(15deg)}}.lanterns-container{position:fixed;top:0;left:0;width:100%;height:30%;z-index:var(--z-lanterns);pointer-events:none}.lantern{position:absolute;transform-origin:top center;animation:lantern-swing ease-in-out infinite}.lantern--1{left:5%;top:10%;animation-duration:4s}.lantern--2{left:25%;top:5%;animation-duration:4.5s;animation-delay:-1s}.lantern--3{right:25%;top:8%;animation-duration:5s;animation-delay:-2s}.lantern--4{right:5%;top:3%;animation-duration:4.2s;animation-delay:-.5s}@keyframes lantern-swing{0%,to{transform:rotate(-3deg)}50%{transform:rotate(3deg)}}.lantern-body{position:relative;width:40px;height:60px}.lantern-top{position:absolute;top:0;left:50%;transform:translate(-50%);width:40%;height:15%;background:var(--color-gold);border-radius:var(--radius-sm) var(--radius-sm) 0 0}.lantern-hook{position:absolute;top:-20%;left:50%;transform:translate(-50%);width:20%;height:25%;border:2px solid var(--color-gold);border-bottom:none;border-radius:50% 50% 0 0}.lantern-glass{position:absolute;top:15%;left:5%;width:90%;height:70%;background:linear-gradient(180deg,#ffc864e6,#ff9632cc,#ff641ee6);border-radius:var(--radius-sm);box-shadow:0 0 20px var(--glow-lantern),0 0 40px #ff963266,inset 0 0 15px #ffffff4d;animation:lantern-flicker .5s ease-in-out infinite alternate}@keyframes lantern-flicker{0%{opacity:.9}to{opacity:1}}.lantern-bottom{position:absolute;bottom:0;left:50%;transform:translate(-50%);width:50%;height:15%;background:var(--color-gold);border-radius:0 0 var(--radius-sm) var(--radius-sm)}.lantern-tassel{position:absolute;bottom:-30%;left:50%;transform:translate(-50%);width:4px;height:30%;background:linear-gradient(180deg,var(--color-gold),var(--color-gold-light));border-radius:0 0 var(--radius-full) var(--radius-full)}.mosque-layer{position:fixed;bottom:0;left:0;width:100%;pointer-events:none}.mosque-layer--far{z-index:var(--z-mosque-far);opacity:.3}.mosque-svg{width:100%;height:auto;fill:#0d1d33}.main-container{position:fixed;inset:0;z-index:var(--z-content);pointer-events:none}.glass-card{background:var(--gradient-card);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:var(--radius-xl);border:1px solid rgba(212,175,55,.2);padding:var(--spacing-2xl);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100%;max-width:420px;pointer-events:auto}.auth-logo{display:flex;justify-content:center;margin-bottom:-7rem}.auth-logo img{height:80px;width:auto;filter:drop-shadow(0 6px 18px rgba(212,175,55,.35))}.card-mascot{position:absolute;top:-110px;left:50%;transform:translate(-50%);z-index:20;pointer-events:none}.card-mascot img{height:200px;width:auto;filter:drop-shadow(0 20px 35px rgba(0,0,0,.45)) drop-shadow(0 0 25px rgba(212,175,55,.45));animation:mascot-float 4s ease-in-out infinite}@keyframes mascot-float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.glass-card{padding-top:5rem}.glass-card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--color-gold),transparent);opacity:.5}.corner-decoration{position:absolute;width:40px;height:40px;opacity:.4}.corner-decoration--tl{top:10px;left:10px}.corner-decoration--tr{top:10px;right:10px;transform:rotate(90deg)}.corner-decoration--bl{bottom:10px;left:10px;transform:rotate(-90deg)}.corner-decoration--br{bottom:10px;right:10px;transform:rotate(180deg)}.corner-decoration svg{width:100%;height:100%;fill:var(--color-gold)}.auth-header{text-align:center;margin-bottom:var(--spacing-2xl)}.ramadan-lantern-svg{margin:0 auto var(--spacing-lg);display:flex;justify-content:center}.lantern-rotate{animation:rotate 15s linear infinite;transform-origin:center;transform-box:fill-box}@keyframes rotate{to{transform:rotate(360deg)}}.auth-title{font-size:clamp(2rem,5vw,2.5rem);font-weight:700;background:var(--gradient-gold);background-size:200% 200%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:gradient-shift 5s ease infinite;margin-bottom:var(--spacing-sm)}@keyframes gradient-shift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.auth-subtitle{font-size:1.1rem;color:var(--color-gold-soft);letter-spacing:.05em}.auth-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.form-label{display:flex;align-items:center;gap:var(--spacing-sm);font-size:.95rem;color:var(--color-gold-light);font-weight:600}.label-icon{font-size:1.1rem}.form-input{width:100%;padding:14px 18px;background:#1a274499;border:1px solid rgba(212,175,55,.2);border-radius:var(--radius-md);color:var(--color-ivory);font-size:1rem;font-family:var(--font-primary);transition:all var(--transition-normal)}.form-input::placeholder{color:#e8d5a380}.form-input:focus{outline:none;border-color:var(--color-gold);background:#1a2744cc;box-shadow:0 0 0 3px #d4af371a}.password-input-wrapper{position:relative}.password-toggle{position:absolute;left:12px;top:50%;transform:translateY(-50%);background:transparent;border:none;color:var(--color-gold-soft);cursor:pointer;font-size:1.2rem;padding:4px;transition:all var(--transition-normal)}.password-toggle:hover{color:var(--color-gold);transform:translateY(-50%) scale(1.1)}.form-options{display:flex;justify-content:space-between;align-items:center;margin:var(--spacing-sm) 0}.remember-me{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;color:var(--color-gold-soft);font-size:.9rem}.remember-me input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--color-gold)}.forgot-password{color:var(--color-gold);text-decoration:none;font-size:.9rem;transition:all var(--transition-normal)}.forgot-password:hover{color:var(--color-gold-light);text-decoration:underline}.ramadan-submit-btn{position:relative;display:flex;align-items:center;justify-content:center;gap:12px;padding:16px 24px;margin-top:var(--spacing-md);background:linear-gradient(135deg,var(--color-navy),var(--color-navy-light));border:1px solid rgba(231,194,106,.55);border-radius:18px;color:var(--color-gold-light);font-weight:700;font-size:1.1rem;font-family:var(--font-primary);cursor:pointer;overflow:hidden;box-shadow:0 12px 30px #00000059,inset 0 1px #ffffff0f;transition:all var(--transition-normal)}.ramadan-submit-btn:before{content:"";position:absolute;inset:-2px;opacity:.22;background:radial-gradient(circle at 12px 12px,rgba(231,194,106,.25) 0 2px,transparent 2px 12px),radial-gradient(circle at 24px 24px,rgba(231,194,106,.18) 0 2px,transparent 2px 12px),repeating-conic-gradient(from 0deg,rgba(231,194,106,.16) 0 10deg,transparent 10deg 20deg);mix-blend-mode:screen;pointer-events:none}.ramadan-submit-btn:after{content:"";position:absolute;inset:0;background:radial-gradient(140px 70px at 0% 0%,rgba(246,231,176,.22),transparent 60%),radial-gradient(140px 70px at 100% 100%,rgba(231,194,106,.18),transparent 60%);pointer-events:none}.btn-icon{display:grid;place-items:center;width:38px;height:38px;border-radius:14px;background:linear-gradient(135deg,var(--color-gold-light),var(--color-gold));color:var(--color-navy);font-size:20px;box-shadow:0 8px 18px #0000004d,inset 0 1px #ffffff59;z-index:1}.btn-text{z-index:1;text-shadow:0 1px 0 rgba(0,0,0,.4)}.ramadan-submit-btn:hover{transform:translateY(-2px);box-shadow:0 16px 38px #0006,0 0 0 4px #e7c26a1f,inset 0 1px #ffffff14}.ramadan-submit-btn:hover:before{animation:sheen 1.2s ease forwards}@keyframes sheen{0%{transform:translate(-8%) rotate(0);opacity:.18}50%{opacity:.3}to{transform:translate(8%) rotate(8deg);opacity:.22}}.ramadan-submit-btn:active{transform:translateY(0)}.auth-switch{text-align:center;margin-top:var(--spacing-lg)}.auth-switch p{color:var(--color-gold-soft);font-size:.95rem}.switch-btn{background:transparent;border:none;color:var(--color-gold);font-weight:600;cursor:pointer;margin-right:var(--spacing-sm);text-decoration:underline;font-size:.95rem;font-family:var(--font-primary);transition:all var(--transition-normal)}.switch-btn:hover{color:var(--color-gold-light)}.social-divider{position:relative;text-align:center;margin:var(--spacing-xl) 0 var(--spacing-lg)}.social-divider:before,.social-divider:after{content:"";position:absolute;top:50%;width:45%;height:1px;background:linear-gradient(90deg,transparent,rgba(212,175,55,.3),transparent)}.social-divider:before{right:0}.social-divider:after{left:0}.social-divider span{background:#1a2744cc;padding:0 var(--spacing-md);color:var(--color-gold-soft);font-size:.9rem}.social-buttons{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.social-btn{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:12px 16px;background:#1a274499;border:1px solid rgba(212,175,55,.2);border-radius:var(--radius-md);color:var(--color-ivory);font-size:.95rem;font-weight:600;font-family:var(--font-primary);cursor:pointer;transition:all var(--transition-normal)}.social-btn:hover{background:#1a2744cc;border-color:#d4af3766;transform:translateY(-2px);box-shadow:0 8px 20px #0000004d}.social-btn svg{flex-shrink:0}.auth-footer{position:fixed;bottom:var(--spacing-lg);left:50%;transform:translate(-50%);text-align:center;z-index:var(--z-content)}.footer-blessing{font-size:1.2rem;color:var(--color-gold);margin-bottom:var(--spacing-xs);text-shadow:0 0 10px var(--glow-gold);animation:glow-pulse 2s ease-in-out infinite}@keyframes glow-pulse{0%,to{text-shadow:0 0 10px var(--glow-gold)}50%{text-shadow:0 0 20px var(--glow-gold),0 0 30px var(--glow-gold)}}.footer-text{font-size:.85rem;color:#d4af3799}@media(max-width:1200px){.moon-container{top:5%;right:5%}.moon{width:80px;height:80px}.lantern--3,.lantern--4{display:none}.glass-card{padding:var(--spacing-xl)}.auth-title{font-size:1.8rem}.social-buttons{grid-template-columns:1fr}}@media(max-width:480px){.ramadan-auth-page{padding:var(--spacing-md)}.moon-container{width:60px;height:60px}.glass-card{padding:var(--spacing-lg)}.auth-header{margin-bottom:var(--spacing-lg)}.form-options{flex-direction:column;gap:var(--spacing-sm);align-items:flex-start}.ramadan-submit-btn{font-size:1rem;padding:14px 20px}.btn-icon{width:34px;height:34px;font-size:18px}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}:root{--color-midnight: #0a1628;--color-navy: #1a2744;--color-gold: #d4af37;--color-gold-light: #f4e4bc;--color-gold-soft: #e8d5a3;--color-ivory: #fffff5;--gradient-sky: linear-gradient(180deg, #0a1628 0%, #1a2744 30%, #2d3a5c 60%, #4a3f6b 100%);--gradient-card: linear-gradient(135deg, rgba(212, 175, 55, .1) 0%, rgba(255, 255, 255, .05) 100%);--gradient-gold: linear-gradient(135deg, #d4af37 0%, #f4e4bc 50%, #d4af37 100%);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-full: 50%}.room-selection-page{min-height:100vh;background:var(--gradient-sky);padding:32px 16px}.room-starfield{position:fixed;inset:0;z-index:1;background-image:radial-gradient(1px 1px at 20% 30%,white,transparent),radial-gradient(1px 1px at 60% 70%,white,transparent),radial-gradient(1px 1px at 80% 10%,white,transparent);background-size:200% 200%;animation:stars-twinkle 8s ease-in-out infinite}@keyframes stars-twinkle{0%,to{opacity:.5}50%{opacity:1}}.room-particles{display:none}.room-moon-container{position:fixed;top:5%;right:8%;z-index:5}.room-moon{position:relative;width:60px;height:60px}.room-moon-crescent{position:absolute;width:100%;height:100%;background:linear-gradient(135deg,var(--color-gold-light) 0%,var(--color-gold) 100%);border-radius:var(--radius-full);box-shadow:0 0 20px #d4af3799}.room-moon-crescent:before{content:"";position:absolute;top:10%;right:-35%;width:100%;height:80%;background:var(--color-navy);border-radius:var(--radius-full)}.room-moon-star{position:absolute;font-size:12px;color:var(--color-gold)}.room-moon-star--1{top:5%;left:90%}.room-moon-star--2{top:20%;left:130%;font-size:10px}.room-moon-star--3{bottom:5%;left:100%}.room-lanterns-container{position:fixed;top:0;width:100%;z-index:6;pointer-events:none}.room-lantern{position:absolute;animation:lantern-swing 4s ease-in-out infinite}.room-lantern--1{left:10%;top:5%}.room-lantern--2{right:10%;top:3%;animation-delay:-1s}.room-lantern--3{left:50%;top:2%;animation-delay:-2s}@keyframes lantern-swing{0%,to{transform:rotate(-2deg)}50%{transform:rotate(2deg)}}.room-lantern-body{width:25px;height:35px;position:relative}.room-lantern-hook{position:absolute;top:-15%;left:50%;transform:translate(-50%);width:15%;height:20%;border:1px solid var(--color-gold);border-bottom:none;border-radius:50% 50% 0 0}.room-lantern-top,.room-lantern-bottom{position:absolute;left:50%;transform:translate(-50%);width:35%;background:var(--color-gold)}.room-lantern-top{top:0;height:12%;border-radius:4px 4px 0 0}.room-lantern-bottom{bottom:0;height:12%;border-radius:0 0 4px 4px}.room-lantern-glass{position:absolute;top:12%;left:5%;width:90%;height:76%;background:linear-gradient(180deg,#ffc864e6,#ff641ee6);border-radius:4px;box-shadow:0 0 15px #ffb46499}.room-main-container{position:relative;z-index:10;width:100%;max-width:1100px;margin:0 auto;padding:0 40px}@media(max-width:1200px){.room-main-container{left:0;margin:0 auto}}.room-glass-card{background:var(--gradient-card);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:var(--radius-lg);border:1px solid rgba(212,175,55,.2);padding:24px;box-shadow:0 8px 32px #0006;max-width:1100px;margin:0 auto}.room-corner-decoration{position:absolute;width:30px;height:30px;opacity:.3}.room-corner-decoration--tl{top:8px;left:8px}.room-corner-decoration--tr{top:8px;right:8px;transform:rotate(90deg)}.room-corner-decoration--bl{bottom:8px;left:8px;transform:rotate(-90deg)}.room-corner-decoration--br{bottom:8px;right:8px;transform:rotate(180deg)}.room-corner-decoration svg{fill:var(--color-gold)}.room-header{text-align:center;margin-bottom:20px}.room-icon-container{margin:0 auto 8px;width:50px;height:50px;background:linear-gradient(135deg,var(--color-gold-light),var(--color-gold));border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center}.room-icon{font-size:1.8rem}.room-title{font-size:1.6rem;font-weight:700;background:var(--gradient-gold);-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:4px}.room-date{font-size:.85rem;color:var(--color-gold-soft)}.room-summary{display:flex;justify-content:space-around;align-items:center;padding:12px;background:#1a274499;border-radius:var(--radius-md);border:1px solid rgba(212,175,55,.2);margin-bottom:20px}.summary-item{display:flex;align-items:center;gap:8px}.summary-icon{font-size:1.3rem}.summary-info{display:flex;flex-direction:column}.summary-number{font-size:1.1rem;font-weight:700;color:var(--color-gold);line-height:1}.summary-label{font-size:.7rem;color:var(--color-gold-soft)}.summary-divider{width:1px;height:25px;background:linear-gradient(to bottom,transparent,var(--color-gold),transparent)}.room-loading{text-align:center;padding:30px;color:var(--color-gold-soft)}.room-spinner{width:40px;height:40px;margin:0 auto 12px;border:3px solid rgba(212,175,55,.2);border-top-color:var(--color-gold);border-radius:var(--radius-full);animation:spin 1s linear infinite}.rooms-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin-bottom:20px}.room-card{position:relative;background:#1a274499;border:2px solid rgba(212,175,55,.2);border-radius:var(--radius-md);padding:12px;cursor:pointer;transition:all .3s ease}.room-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--room-color)}.room-card:hover{transform:translateY(-2px);border-color:var(--room-color);box-shadow:0 6px 20px #0000004d}.room-card--full{opacity:.5;cursor:not-allowed}.room-card--full:hover{transform:none;box-shadow:none}.room-card-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}.room-card-icon{width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1.3rem;color:#fff;flex-shrink:0}.room-card-title{font-size:1rem;font-weight:700;color:var(--color-gold-light);margin:0}.room-card-description{display:none}.room-card-availability{margin-bottom:10px}.availability-numbers{display:flex;align-items:baseline;gap:6px;margin-bottom:6px}.available-count{font-size:1.5rem;font-weight:700;line-height:1}.available-label{font-size:.75rem;color:var(--color-gold-soft)}.room-progress-bar{height:4px;background:#0a1628cc;border-radius:var(--radius-full);overflow:hidden;margin-bottom:4px}.room-progress-fill{height:100%;transition:width 1s ease-out}.availability-status{font-size:.65rem;font-weight:600;text-transform:uppercase}.room-card-features{display:flex;flex-direction:column;gap:3px;margin-bottom:10px}.feature-tag{display:flex;align-items:center;gap:4px;font-size:.7rem;color:var(--color-ivory);opacity:.7}.feature-bullet{color:var(--color-gold);font-size:.5rem}.room-select-btn{width:100%;padding:10px;background:linear-gradient(135deg,var(--color-gold),#b8941f);color:var(--color-midnight);border:none;border-radius:var(--radius-sm);font-size:.9rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .3s ease}.room-select-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #d4af3766}.room-select-btn.disabled{background:#6464644d;color:#fff6;cursor:not-allowed}.room-select-btn.disabled:hover{transform:none;box-shadow:none}.btn-arrow{font-size:1.1rem}.room-full-overlay{position:absolute;inset:0;background:#0a1628d9;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md)}.full-badge{padding:8px 16px;background:#ef4444;color:#fff;font-size:1.1rem;font-weight:700;border-radius:var(--radius-sm);transform:rotate(-3deg)}.room-notice-container{display:flex;gap:12px;padding:16px;background:linear-gradient(135deg,#ef444426,#fb923c26);border-radius:var(--radius-md);border:2px solid rgba(239,68,68,.4);margin-bottom:16px}.room-notice-icon{font-size:2rem;flex-shrink:0}.room-notice-content{flex:1}.room-notice-title{color:var(--color-gold-light);font-size:1rem;margin-bottom:8px}.notice-highlight{color:#ef4444;font-weight:700}.room-notice-text{display:flex;flex-direction:column;gap:8px}.notice-item{display:flex;gap:8px;align-items:flex-start}.notice-bullet{font-size:1.2rem;flex-shrink:0}.notice-item p{color:var(--color-ivory);font-size:.85rem;line-height:1.4}.time-highlight{color:var(--color-gold)}.warning-text{color:#ef4444;font-weight:600}.room-actions{display:flex;justify-content:center}.room-btn-refresh{display:flex;align-items:center;gap:8px;padding:10px 20px;background:#1a274499;color:var(--color-gold-light);border:1px solid rgba(212,175,55,.3);border-radius:var(--radius-md);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease}.room-btn-refresh:hover{background:#1a2744cc;border-color:var(--color-gold)}.room-footer{position:fixed;bottom:16px;left:50%;z-index:10}.footer-blessing{font-size:1rem;color:var(--color-gold);text-shadow:0 0 10px rgba(212,175,55,.6)}@media(max-width:768px){.room-selection-page{padding:16px}.room-main-container{padding:0 16px}.room-glass-card{padding:16px}.rooms-grid{grid-template-columns:1fr}.summary-divider{width:60px;height:1px}.room-summary{flex-direction:column;gap:8px}.date-picker-section{flex-direction:column;gap:12px}.room-notice-container{flex-direction:column;text-align:center}.room-lantern--3{display:none}}@media(min-width:769px)and (max-width:1200px){.rooms-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1201px){.rooms-grid{grid-template-columns:repeat(4,1fr)}}.date-picker-section{display:flex;align-items:center;justify-content:center;gap:16px;padding:16px;background:#1a274499;border-radius:var(--radius-md);border:1px solid rgba(212,175,55,.2);margin-bottom:20px}.date-picker-label{display:flex;align-items:center;gap:8px;color:var(--color-gold-light);font-size:.95rem;font-weight:600}.date-icon{font-size:1.3rem}.date-picker-input{padding:10px 16px;background:#0a1628cc;border:1px solid rgba(212,175,55,.3);border-radius:var(--radius-sm);color:var(--color-gold-light);font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s ease}.date-picker-input:hover{border-color:var(--color-gold);background:#0a1628e6}.date-picker-input:focus{outline:none;border-color:var(--color-gold);box-shadow:0 0 0 3px #d4af3733}.date-picker-input::-webkit-calendar-picker-indicator{filter:invert(.7) sepia(1) saturate(5) hue-rotate(5deg);cursor:pointer}.qr-modal-overlay{position:fixed;inset:0;background:#0a1628f2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.qr-modal-content{position:relative;background:linear-gradient(135deg,#1a2744f2,#2d3a5cf2);border:2px solid rgba(212,175,55,.3);border-radius:20px;padding:32px;max-width:500px;width:100%;box-shadow:0 20px 60px #00000080;animation:slideUp .4s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.qr-modal-close{position:absolute;top:16px;right:16px;background:#ef444433;border:1px solid rgba(239,68,68,.4);color:#fca5a5;width:32px;height:32px;border-radius:50%;font-size:1.2rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.qr-modal-close:hover{background:#ef44444d;transform:rotate(90deg)}.qr-modal-header{text-align:center;margin-bottom:24px}.qr-modal-icon{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;margin:0 auto 16px;box-shadow:0 4px 16px #0000004d}.qr-modal-title{font-size:1.5rem;font-weight:700;color:var(--color-gold-light);margin:0}.qr-modal-body{margin-bottom:24px}.qr-info-card{background:linear-gradient(135deg,#3b82f626,#2563eb26);border:1px solid rgba(59,130,246,.3);border-radius:12px;padding:20px;margin-bottom:16px;text-align:center}.qr-info-icon{font-size:3rem;display:block;margin-bottom:12px}.qr-info-card h3{font-size:1.2rem;color:var(--color-gold-light);margin-bottom:8px}.qr-info-card p{color:var(--color-ivory);line-height:1.6;margin:0}.qr-warning-card{background:linear-gradient(135deg,#ef444426,#dc262626);border:1px solid rgba(239,68,68,.3);border-radius:12px;padding:16px;margin-bottom:20px;display:flex;gap:12px}.qr-warning-icon{font-size:2rem;flex-shrink:0}.qr-warning-content h4{font-size:1rem;color:#fca5a5;margin:0 0 8px}.qr-warning-content ul{margin:0;padding-left:20px;color:var(--color-ivory);font-size:.9rem}.qr-warning-content li{margin-bottom:4px;line-height:1.4}.qr-room-details{background:#0a162899;border:1px solid rgba(212,175,55,.2);border-radius:12px;padding:16px;margin-bottom:20px}.qr-detail-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid rgba(212,175,55,.1)}.qr-detail-item:last-child{border-bottom:none}.qr-detail-label{color:var(--color-gold-soft);font-size:.9rem}.qr-detail-value{color:var(--color-ivory);font-weight:600;font-size:.95rem}.qr-modal-actions{display:flex;gap:12px}.qr-btn-cancel,.qr-btn-confirm{flex:1;padding:14px 24px;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;border:none;display:flex;align-items:center;justify-content:center;gap:8px}.qr-btn-cancel{background:#1a2744cc;color:var(--color-gold-light);border:1px solid rgba(212,175,55,.3)}.qr-btn-cancel:hover{background:#1a2744;border-color:var(--color-gold)}.qr-btn-confirm{background:linear-gradient(135deg,var(--color-gold),#b8941f);color:var(--color-midnight)}.qr-btn-confirm:hover{transform:translateY(-2px);box-shadow:0 6px 20px #d4af3766}@media(max-width:768px){.qr-modal-content{padding:24px}.qr-modal-title{font-size:1.3rem}.qr-modal-icon{width:56px;height:56px;font-size:1.8rem}.qr-modal-actions{flex-direction:column}.qr-btn-cancel,.qr-btn-confirm{width:100%}}@media(min-width:1200px){.room-main-container{transform:translate(6%)}}@media(max-width:1199px){.room-main-container{transform:translate(3%)}}@media(max-width:768px){.room-main-container{transform:none}}.booking-time-info{display:flex;flex-direction:column;gap:8px;margin-top:12px;padding:12px;background:#0a162866;border-radius:8px}.time-status{font-size:.9rem;font-weight:600;padding:6px 12px;border-radius:6px;display:inline-block}.time-status.before-cutoff{background:#10b98133;color:#10b981;border:1px solid rgba(16,185,129,.3)}.time-status.after-cutoff{background:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.current-time{font-size:.85rem;color:#e8d5a3;text-align:center}.date-picker-input{width:100%;padding:12px 16px;background:#0a162899;border:1px solid rgba(212,175,55,.3);border-radius:10px;color:#fffff5;font-size:1rem;font-family:inherit;transition:all .3s ease;cursor:pointer}.date-picker-input:hover{border-color:#d4af37}.date-picker-input:focus{outline:none;border-color:#d4af37;box-shadow:0 0 0 3px #d4af371a}.booking-page{min-height:100vh;width:100vw;margin-left:calc(50% - 50vw)}.waiting-list-section{margin-top:32px;padding-top:24px;border-top:2px dashed rgba(212,175,55,.3)}.waiting-list-header{display:flex;align-items:center;gap:12px;margin-bottom:20px;padding:16px;background:linear-gradient(135deg,#ef444426,#dc262626);border:1px solid rgba(239,68,68,.3);border-radius:12px}.booking-page{width:100vw;margin-left:calc(50% - 50vw)}.waiting-list-icon{font-size:2rem;animation:pulse-warning 2s ease-in-out infinite}@keyframes pulse-warning{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}.waiting-list-header h3{color:#fca5a5;font-size:1.2rem;font-weight:600;margin:0}.waiting-list-card{background:linear-gradient(135deg,#f59e0b1a,#d977060d);border:2px solid rgba(245,158,11,.3);border-radius:20px;padding:24px;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.waiting-list-card:before{content:"";position:absolute;top:-50%;right:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(245,158,11,.1) 0%,transparent 70%);animation:rotate-gradient 10s linear infinite}@keyframes rotate-gradient{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.waiting-list-card:hover{border-color:#f59e0b;transform:translateY(-4px);box-shadow:0 8px 24px #f59e0b4d}.waiting-list-card-header{display:flex;gap:16px;margin-bottom:20px;position:relative;z-index:1}.waiting-list-card-icon{width:64px;height:64px;background:linear-gradient(135deg,#f59e0b,#d97706);border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:2rem;flex-shrink:0;box-shadow:0 4px 12px #f59e0b66}.waiting-list-card-title-section{flex:1}.waiting-list-card-title{color:#fbbf24;font-size:1.4rem;font-weight:700;margin:0 0 8px}.waiting-list-card-description{color:#e8d5a3;font-size:.95rem;margin:0;line-height:1.5}.waiting-list-info{background:#0a162899;border:1px solid rgba(245,158,11,.2);border-radius:12px;padding:16px;margin-bottom:20px;position:relative;z-index:1}.waiting-count{display:flex;flex-direction:column;align-items:center;gap:8px}.count-number{font-size:2.5rem;font-weight:700;color:#fbbf24;text-shadow:0 2px 8px rgba(251,191,36,.3)}.count-label{color:#e8d5a3;font-size:.95rem}.waiting-list-btn{width:100%;padding:16px 24px;background:linear-gradient(135deg,#f59e0b,#d97706);border:none;border-radius:12px;color:#0a1628;font-size:1.05rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .3s ease;position:relative;z-index:1;font-family:inherit}.waiting-list-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #f59e0b66}.waiting-list-btn .btn-arrow{transition:transform .3s ease}.waiting-list-btn:hover .btn-arrow{transform:translate(4px)}@media(max-width:768px){.waiting-list-card-icon{width:56px;height:56px;font-size:1.8rem}.waiting-list-card-title{font-size:1.2rem}.count-number{font-size:2rem}}.booking-main-container{width:100%;max-width:420px;margin:0 auto;padding:48px 16px}.booking-glass-card{background:linear-gradient(135deg,#d4af371a,#ffffff0d);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;border:1px solid rgba(212,175,55,.2);padding:30px;min-width:650px;box-shadow:0 8px 32px #0006}.booking-header{text-align:center;margin-bottom:32px}.booking-room-icon{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:3rem;margin:0 auto 16px;box-shadow:0 8px 24px #0000004d}.booking-title{font-size:2rem;font-weight:700;color:#f4e4bc;margin-bottom:8px}.booking-subtitle{font-size:1.2rem;color:#e8d5a3}.booking-user-card,.booking-summary-card{background:#1a274499;border:1px solid rgba(212,175,55,.2);border-radius:16px;padding:20px;margin-bottom:20px}.user-card-title,.summary-title{font-size:1.1rem;color:#d4af37;margin-bottom:16px;font-weight:600}.user-info-row,.summary-row{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid rgba(212,175,55,.1)}.user-info-row:last-child,.summary-row:last-child{border-bottom:none}.user-label,.summary-label{color:#e8d5a3;font-size:.95rem}.user-value,.summary-value{color:#fffff5;font-weight:600}.booking-info-box{display:flex;gap:12px;padding:16px;background:linear-gradient(135deg,#3b82f626,#2563eb26);border:1px solid rgba(59,130,246,.3);border-radius:12px;margin-bottom:24px}.info-icon{font-size:1.5rem;flex-shrink:0}.booking-info-box p{color:#fffff5;line-height:1.6;margin:0}.booking-actions{display:flex;gap:12px}.booking-btn{flex:1;padding:16px 24px;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;border:none;display:flex;align-items:center;justify-content:center;gap:8px}.booking-btn--secondary{background:#1a2744cc;color:#f4e4bc;border:1px solid rgba(212,175,55,.3)}.booking-btn--secondary:hover{background:#1a2744;border-color:#d4af37}.booking-btn--primary{background:linear-gradient(135deg,#d4af37,#b8941f);color:#0a1628}.booking-btn--primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #d4af3766}.booking-btn:disabled{opacity:.6;cursor:not-allowed}.btn-spinner{width:16px;height:16px;border:2px solid rgba(10,22,40,.3);border-top-color:#0a1628;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.booking-success-header{text-align:center;margin-bottom:28px}.success-icon{width:80px;height:80px;background:linear-gradient(135deg,#10b981,#059669);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:3rem;color:#fff;margin:0 auto 16px;box-shadow:0 8px 32px #10b98166;animation:success-bounce .6s ease-out}@keyframes success-bounce{0%{transform:scale(0)}50%{transform:scale(1.1)}to{transform:scale(1)}}.success-title{font-size:1.8rem;font-weight:700;color:#10b981;margin-bottom:8px}.success-subtitle{font-size:1rem;color:#e8d5a3}.qr-code-section{text-align:center;margin-bottom:24px}.qr-code-container{position:relative;display:inline-block;padding:16px;background:#fff;border-radius:16px;box-shadow:0 8px 32px #0000004d;margin-bottom:16px}.qr-code-image{display:block;width:170px;height:170px;border-radius:8px}.qr-code-pulse{position:absolute;inset:-8px;border:2px solid #d4af37;border-radius:20px;animation:pulse-border 2s ease-in-out infinite}@keyframes pulse-border{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.05)}}.qr-code-info h3{font-size:1.2rem;color:#d4af37;margin-bottom:6px}.qr-code-info p{color:#e8d5a3;font-size:.95rem}.booking-details-card{background:#1a274499;border:1px solid rgba(212,175,55,.2);border-radius:16px;padding:24px;margin-bottom:20px}.details-title{font-size:1.2rem;color:#d4af37;margin-bottom:18px;font-weight:600}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid rgba(212,175,55,.1)}.detail-row:last-child{border-bottom:none}.detail-row--highlight{background:#d4af371a;padding:12px 16px;margin:12px -16px 0;border-radius:8px;border:1px solid rgba(212,175,55,.3)}.detail-label{color:#e8d5a3;font-size:.95rem}.detail-value{color:#fffff5;font-weight:600;font-size:1rem;text-align:right}.booking-id{font-family:Courier New,monospace;color:#d4af37;font-size:.9rem;background:#0a162899;padding:6px 12px;border-radius:6px}.room-icon{margin-right:8px;font-size:1.2rem}.booking-notice{display:flex;gap:16px;padding:18px;background:linear-gradient(135deg,#ef444426,#dc262626);border:1px solid rgba(239,68,68,.3);border-radius:12px;margin-bottom:24px}.notice-icon{font-size:1.8rem;flex-shrink:0}.notice-content h4{color:#fca5a5;margin-bottom:10px;font-size:1.05rem}.notice-content ul{margin:0;padding-left:20px;color:#fffff5}.notice-content li{margin-bottom:6px;line-height:1.5;font-size:.95rem}.booking-btn--download{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.booking-btn--download:hover{transform:translateY(-2px);box-shadow:0 6px 20px #3b82f666}.booking-btn--return{background:#1a2744cc;color:#f4e4bc;border:1px solid rgba(212,175,55,.3)}.booking-btn--return:hover{background:#1a2744;border-color:#d4af37;transform:translateY(-2px)}.btn-icon{font-size:1.1rem}@media(max-width:768px){.booking-glass-card{padding:24px}.booking-title{font-size:1.6rem}.success-title{font-size:1.5rem}.qr-code-image{width:180px;height:180px}.qr-code-container{padding:12px}.booking-actions{flex-direction:column}.booking-btn{width:100%}.detail-value{font-size:.9rem}}
