*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{color:#334155;background-color:#f8fafc;font-family:Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.5}.navbar{z-index:1000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:#fffffff2;justify-content:space-between;align-items:center;height:70px;padding:0 4rem;display:flex;position:fixed;top:0;left:0;right:0;box-shadow:0 2px 10px #0000001a}.nav-logo{color:#0f172a;font-size:1.5rem;font-weight:800}.nav-links{gap:2.5rem;list-style:none;display:flex}.nav-links li{color:#475569;cursor:pointer;font-weight:600;transition:color .3s}.nav-links li:hover{color:#3b82f6}.hero{text-align:center;color:#fff;background:linear-gradient(#0f172a99,#0f172a99),url(https://images.unsplash.com/photo-1566073771259-6a8506099945?auto=format&fit=crop&q=80) 50%/cover;justify-content:center;align-items:center;height:100vh;padding-top:70px;display:flex}.hero h1{margin-bottom:1rem;font-size:4.5rem;font-weight:800}.hero p{color:#e2e8f0;margin-bottom:2.5rem;font-size:1.5rem}.hero-buttons{justify-content:center;gap:1.5rem;display:flex}.btn-primary{color:#fff;cursor:pointer;background-color:#3b82f6;border:none;border-radius:.5rem;padding:1rem 2.5rem;font-size:1.125rem;font-weight:700;transition:background-color .3s}.btn-primary:hover{background-color:#2563eb}.btn-secondary-hero{color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background-color:#ffffff1a;border:1px solid #ffffff4d;border-radius:.5rem;padding:1rem 2.5rem;font-size:1.125rem;font-weight:700;transition:background-color .3s}.btn-secondary-hero:hover{background-color:#fff3}.section{max-width:1280px;margin:0 auto;padding:6rem 2rem}.section-title{text-align:center;color:#0f172a;margin-bottom:4rem;font-size:2.5rem;font-weight:800}.about-text{text-align:center;color:#475569;max-width:900px;margin:0 auto;font-size:1.25rem;line-height:1.8}.grid{grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:2.5rem;display:grid}.card{background:#fff;border-radius:1rem;transition:transform .3s;overflow:hidden;box-shadow:0 4px 20px #0000000d}.card:hover{transform:translateY(-10px)}.card-image{object-fit:cover;width:100%;height:250px}.card-content{padding:1.5rem}.card-title{margin-bottom:.5rem;font-size:1.4rem}.card-desc{color:#64748b;margin-bottom:1.5rem;font-size:.95rem}.card-footer{border-top:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding-top:1rem;display:flex}.card-price{color:#3b82f6;font-size:1.2rem;font-weight:800}.btn-secondary.disabled{color:#94a3b8;cursor:not-allowed;background-color:#f1f5f9;border:none;border-radius:.4rem;padding:.5rem 1rem;font-size:.9rem;font-weight:600}.contact-container{background:#fff;border-radius:1.5rem;grid-template-columns:1fr 1.2fr;gap:4rem;padding:4rem;display:grid;box-shadow:0 10px 30px #0000000d}.contact-info h3{margin-bottom:1.5rem;font-size:1.8rem}.contact-info p{margin-bottom:.8rem;font-size:1.1rem}.contact-hint{background:#f8fafc;border-radius:1rem;margin-top:2rem;padding:1.5rem}.footer{color:#94a3b8;text-align:center;background:#0f172a;padding:4rem 2rem}@media (width<=768px){.navbar{padding:0 1.5rem}.nav-links{display:none}.hero h1{font-size:2.8rem}.contact-container{grid-template-columns:1fr;padding:2rem}}.nav-login-btn{border:2px solid #3b82f6;border-radius:2rem;align-items:center;padding:.4rem 1.5rem;font-weight:700;transition:all .3s;display:flex;color:#3b82f6!important;background-color:#0000!important}.nav-login-btn:hover{transform:translateY(-2px);box-shadow:0 4px 10px #3b82f64d;color:#fff!important;background-color:#3b82f6!important}.login-page{background-color:#f8fafc;justify-content:center;align-items:flex-start;min-height:calc(100vh - 150px);padding-top:120px;display:flex}.login-container{background:#fff;border-radius:1rem;width:100%;max-width:450px;padding:2.5rem;box-shadow:0 10px 25px #0000000d}.login-header{text-align:center;margin-bottom:2rem}.login-header h2{color:#0f172a;margin-bottom:.5rem;font-size:1.8rem}.login-header p{color:#64748b}.role-selector{background-color:#f1f5f9;border-radius:.5rem;margin-bottom:2rem;padding:.25rem;display:flex}.role-btn{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:.375rem;flex:1;padding:.75rem;font-weight:600;transition:all .3s}.role-btn.active{color:#3b82f6;background:#fff;box-shadow:0 2px 4px #0000000d}.form-group{margin-bottom:1.5rem}.form-group label{color:#334155;margin-bottom:.5rem;font-size:.95rem;font-weight:600;display:block}.form-group input{border:1px solid #cbd5e1;border-radius:.5rem;width:100%;padding:.75rem 1rem;font-size:1rem;transition:border-color .3s}.form-group input:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61a}.form-options{justify-content:space-between;align-items:center;margin-bottom:2rem;font-size:.9rem;display:flex}.remember-me{color:#475569;align-items:center;gap:.5rem;display:flex}.forgot-password{color:#3b82f6;font-weight:600;text-decoration:none}.w-100{width:100%}.login-footer{text-align:center;color:#64748b;border-top:1px solid #f1f5f9;margin-top:2rem;padding-top:1.5rem;font-size:.95rem}.login-footer a{color:#3b82f6;font-weight:600;text-decoration:none}.admin-layout{background-color:#f4f7fb;min-height:100vh;font-family:Inter,Segoe UI,sans-serif;display:flex}.admin-sidebar{color:#e2e8f0;z-index:10;background-color:#0f172a;border-right:1px solid #1e293b;flex-direction:column;width:280px;display:flex;box-shadow:4px 0 24px #0000000d}.admin-brand{color:#fff;letter-spacing:.5px;align-items:center;gap:1rem;padding:2rem;font-size:1.25rem;font-weight:800;display:flex}.brand-icon{background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:.75rem;justify-content:center;align-items:center;width:36px;height:36px;display:flex;box-shadow:0 4px 10px #3b82f666}.brand-icon svg{color:#fff;width:20px;height:20px}.admin-nav{flex-grow:1;padding:1rem}.admin-menu{flex-direction:column;gap:.5rem;list-style:none;display:flex}.admin-menu li{color:#94a3b8;cursor:pointer;border-radius:.75rem;align-items:center;gap:1rem;padding:1rem 1.25rem;font-size:.95rem;font-weight:600;transition:all .2s;display:flex}.admin-menu li svg{width:20px;height:20px}.admin-menu li:hover{color:#fff;background-color:#1e293b}.admin-menu li.active{color:#60a5fa;background-color:#3b82f626;border-left:3px solid #3b82f6}.admin-sidebar-footer{border-top:1px solid #1e293b;padding:2rem}.admin-logout-btn{color:#f87171;cursor:pointer;background-color:#0000;border:1px solid #f871714d;border-radius:.75rem;justify-content:center;align-items:center;gap:.75rem;width:100%;padding:.85rem;font-weight:600;transition:all .2s;display:flex}.admin-logout-btn svg{width:18px;height:18px}.admin-logout-btn:hover{color:#dc2626;background-color:#fef2f2;border-color:#fca5a5}.admin-main{flex-direction:column;flex-grow:1;gap:2.5rem;padding:2.5rem 3.5rem;display:flex;overflow-y:auto}.admin-topbar{justify-content:space-between;align-items:center;display:flex}.admin-title{color:#0f172a;letter-spacing:-.5px;margin-bottom:.25rem;font-size:2rem;font-weight:800}.admin-subtitle{color:#64748b;text-transform:capitalize;font-weight:500}.admin-profile{align-items:center;gap:1rem;display:flex}.profile-info{text-align:right;flex-direction:column;display:flex}.profile-name{color:#1e293b;font-size:.95rem;font-weight:700}.profile-role{color:#64748b;font-size:.8rem}.profile-avatar{color:#fff;background:linear-gradient(135deg,#1e293b,#0f172a);border:3px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.1rem;font-weight:800;display:flex;box-shadow:0 4px 10px #0000001a}.modern-card{background:#fff;border:1px solid #f1f5f9;border-radius:1.25rem;transition:transform .3s,box-shadow .3s;box-shadow:0 4px 20px #00000008,0 1px 3px #00000005}.modern-card:hover{transform:translateY(-5px);box-shadow:0 10px 25px #0000000d,0 4px 10px #00000008}.admin-stats-container{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;display:grid}.admin-stat-card{flex-direction:column;gap:1.5rem;padding:1.5rem;display:flex}.stat-header{justify-content:space-between;align-items:center;display:flex}.stat-header h3{color:#64748b;font-size:1rem;font-weight:600}.stat-icon-box{border-radius:1rem;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.stat-icon-box svg{width:22px;height:22px}.blue-box{color:#3b82f6;background-color:#eff6ff}.green-box{color:#10b981;background-color:#ecfdf5}.orange-box{color:#f59e0b;background-color:#fffbeb}.stat-body{flex-direction:column;gap:.25rem;display:flex}.stat-value{color:#0f172a;font-size:2.25rem;font-weight:800}.stat-total{color:#94a3b8;font-size:1.25rem;font-weight:600}.stat-trend{align-items:center;gap:.25rem;font-size:.85rem;font-weight:600;display:flex}.stat-trend.positive{color:#10b981}.stat-trend.neutral{color:#64748b}.admin-content-grid{grid-template-columns:2fr 1fr;gap:2rem;display:grid}.admin-panel{flex-direction:column;padding:2rem;display:flex}.panel-header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.panel-header h2{color:#0f172a;font-size:1.25rem;font-weight:700}.btn-text{color:#3b82f6;cursor:pointer;background:0 0;border:none;font-size:.9rem;font-weight:600;transition:color .2s}.btn-text:hover{color:#2563eb;text-decoration:underline}.admin-empty-state-modern{text-align:center;background-color:#f8fafc;border:2px dashed #e2e8f0;border-radius:1rem;flex-direction:column;flex-grow:1;justify-content:center;align-items:center;padding:4rem 2rem;display:flex}.empty-state-icon{color:#64748b;background-color:#e2e8f0;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;margin-bottom:1.5rem;display:flex}.empty-state-icon svg{width:32px;height:32px}.admin-empty-state-modern h4{color:#334155;margin-bottom:.5rem;font-size:1.1rem}.admin-empty-state-modern p{color:#64748b;max-width:300px;font-size:.95rem}.quick-actions{flex-direction:column;gap:1rem;display:flex}.quick-action-btn{cursor:pointer;border:none;border-radius:.75rem;align-items:center;gap:1rem;padding:1rem;font-size:.95rem;font-weight:600;transition:all .2s;display:flex}.quick-action-btn svg{width:20px;height:20px}.quick-action-btn.primary{color:#fff;background-color:#3b82f6;box-shadow:0 4px 10px #3b82f64d}.quick-action-btn.primary:hover{background-color:#2563eb;transform:translateY(-2px)}.quick-action-btn.secondary{color:#334155;background-color:#f1f5f9}.quick-action-btn.secondary:hover{background-color:#e2e8f0}.quick-action-btn.danger-outline{color:#ef4444;background-color:#0000;border:1px solid #fca5a5}.quick-action-btn.danger-outline:hover{background-color:#fef2f2;border-color:#ef4444}@media (width<=1024px){.admin-content-grid{grid-template-columns:1fr}}@media (width<=768px){.admin-layout{flex-direction:column}.admin-sidebar{border-bottom:1px solid #1e293b;border-right:none;width:100%}.admin-main{padding:1.5rem}}.rooms-container{flex-direction:column;gap:2rem;display:flex}.rooms-toolbar{background-color:#fff;border-radius:1rem;justify-content:space-between;align-items:center;padding:1.5rem 2rem;display:flex;box-shadow:0 2px 10px #00000005}.rooms-info{color:#64748b;font-weight:500}.rooms-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;display:grid}.room-card{flex-direction:column;padding:1.5rem;display:flex}.room-card-header{justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;display:flex}.room-number-circle{color:#fff;background:#0f172a;border-radius:50%;justify-content:center;align-items:center;width:50px;height:50px;font-size:1.25rem;font-weight:800;display:flex;box-shadow:0 4px 10px #0f172a33}.status-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:2rem;padding:.4rem 1rem;font-size:.8rem;font-weight:700}.status-green{color:#10b981;background-color:#ecfdf5;border:1px solid #a7f3d0}.status-red{color:#ef4444;background-color:#fef2f2;border:1px solid #fecaca}.status-yellow{color:#f59e0b;background-color:#fffbeb;border:1px solid #fde68a}.status-gray{color:#64748b;background-color:#f1f5f9;border:1px solid #cbd5e1}.room-card-body{flex-grow:1;margin-bottom:1.5rem}.room-type{color:#0f172a;margin-bottom:.25rem;font-size:1.1rem}.room-price{color:#64748b;margin-bottom:1rem;font-size:.95rem}.room-price strong{color:#3b82f6}.room-current-info{color:#475569;background-color:#f8fafc;border-radius:.5rem;align-items:flex-start;gap:.5rem;padding:.75rem;font-size:.85rem;line-height:1.4;display:flex}.room-current-info svg{color:#94a3b8;flex-shrink:0;width:16px;height:16px;margin-top:2px}.room-card-actions{border-top:1px solid #f1f5f9;grid-template-columns:1fr 1fr;gap:.75rem;padding-top:1.25rem;display:grid}.room-card-actions button{cursor:pointer;border:none;border-radius:.5rem;padding:.5rem;font-size:.85rem;font-weight:600;transition:all .2s}.room-btn-edit{color:#334155;background-color:#f1f5f9}.room-btn-edit:hover{background-color:#e2e8f0}.room-btn-block{color:#ef4444;background-color:#fff;border:1px solid #fca5a5!important}.room-btn-block:hover{background-color:#fef2f2}.room-btn-unlock{color:#10b981;background-color:#ecfdf5;border:1px solid #a7f3d0!important}.room-btn-unlock:hover{background-color:#d1fae5}.room-btn-unlock:disabled{color:#94a3b8;cursor:not-allowed;background-color:#f1f5f9;border:none!important}.reservations-container{padding:2rem}.table-responsive{overflow-x:auto}.modern-table{border-collapse:separate;border-spacing:0;text-align:left;width:100%}.modern-table th{color:#64748b;text-transform:uppercase;letter-spacing:.5px;background-color:#f8fafc;border-bottom:2px solid #e2e8f0;padding:1rem;font-size:.85rem;font-weight:600}.modern-table th:first-child{border-top-left-radius:.75rem}.modern-table th:last-child{border-top-right-radius:.75rem}.modern-table td{color:#334155;vertical-align:middle;border-bottom:1px solid #f1f5f9;padding:1.25rem 1rem;font-size:.95rem}.modern-table tr:last-child td{border-bottom:none}.modern-table tr:hover td{background-color:#f8fafc}.text-muted{color:#94a3b8;font-size:.85rem}.source-badge{border-radius:.5rem;padding:.35rem .75rem;font-size:.8rem;font-weight:700}.source-booking{color:#0284c7;background-color:#e0f2fe}.source-web{color:#9333ea;background-color:#f3e8ff}.source-manual{color:#475569;background-color:#f1f5f9}.btn-action{cursor:pointer;border:none;border-radius:.375rem;padding:.4rem .8rem;font-size:.8rem;font-weight:600;transition:all .2s}.btn-history{color:#0284c7;background-color:#e0f2fe}.btn-history:hover{background-color:#bae6fd}.btn-edit{color:#475569;background-color:#f1f5f9}.btn-edit:hover{background-color:#e2e8f0}.btn-delete{color:#ef4444;background-color:#fef2f2}.btn-delete:hover{background-color:#fee2e2}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9999;background-color:#0f172a99;justify-content:center;align-items:center;width:100vw;height:100vh;display:flex;position:fixed;top:0;left:0}.modal-content{background:#fff;border-radius:1rem;width:90%;max-width:700px;animation:.3s ease-out forwards modalFadeIn;overflow:hidden;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}@keyframes modalFadeIn{0%{opacity:0;transform:translateY(20px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-header{background-color:#f8fafc;border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:1.5rem 2rem;display:flex}.modal-header h2{color:#0f172a;margin:0;font-size:1.25rem}.modal-close{color:#94a3b8;cursor:pointer;background:0 0;border:none;font-size:1.2rem;transition:color .2s}.modal-close:hover{color:#ef4444}.modal-body{max-height:60vh;padding:2rem;overflow-y:auto}.gallery-page{background-color:#f8fafc;min-height:calc(100vh - 150px);padding-top:70px}.gallery-header{color:#fff;text-align:center;background:linear-gradient(#0f172acc,#0f172acc),url(https://images.unsplash.com/photo-1582719478250-c89cae4dc85b?auto=format&fit=crop&q=80) 50%/cover;padding:5rem 2rem}.gallery-header h1{margin-bottom:1rem;font-size:3.5rem}.gallery-header p{color:#cbd5e1;font-size:1.2rem}.gallery-content{max-width:1280px;margin:0 auto;padding:4rem 2rem}.gallery-section{border-bottom:1px solid #e2e8f0;margin-bottom:5rem;padding-bottom:5rem}.gallery-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.gallery-section-title{color:#0f172a;margin-bottom:2rem;font-size:2rem;display:inline-block;position:relative}.gallery-section-title:after{content:"";background-color:#3b82f6;border-radius:2px;width:60px;height:4px;position:absolute;bottom:-10px;left:0}.gallery-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;display:grid}.gallery-item{aspect-ratio:4/3;border-radius:1rem;overflow:hidden;box-shadow:0 4px 6px -1px #0000001a}.gallery-item img{object-fit:cover;width:100%;height:100%;transition:transform .5s}.gallery-item:hover img{transform:scale(1.05)}@media (width<=768px){.gallery-header h1{font-size:2.5rem}}
