.modal-overlay{z-index:1100;background:#00000080;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.hotel-detail-modal{background:#fff;border:1px solid #e5e7eb;border-radius:8px;flex-direction:column;width:100%;max-width:1200px;max-height:95vh;display:flex;overflow:hidden;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal-header{background:#fff;border-bottom:1px solid #e5e7eb;flex-shrink:0;justify-content:space-between;align-items:center;padding:10px 16px;display:flex}.back-btn{color:#007bff;cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;gap:6px;padding:6px 10px;font-size:13px;font-weight:500;transition:all .2s;display:flex}.back-btn:hover{background:#f3f4f6}.header-actions{gap:8px;display:flex}.action-btn{color:#374151;cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:6px;align-items:center;gap:4px;padding:6px 12px;font-size:13px;font-weight:500;transition:all .2s;display:flex}.action-btn:hover{color:#007bff;background:#f9fafb;border-color:#007bff}.hotel-detail-modal .modal-body{flex:auto;grid-template-rows:1fr;gap:0;min-width:0;min-height:0;overflow:hidden;grid-template-columns:1fr 320px!important;display:grid!important}.modal-main-content{z-index:10;background:#fff;grid-column:1;min-height:0;padding:12px 16px;position:relative;overflow-y:auto}.hotel-category{color:var(--text-secondary);margin-bottom:4px;font-size:11px}.hotel-name{color:var(--text-main);margin:0 0 6px;font-size:20px;font-weight:700;line-height:1.2}.hotel-meta{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:10px;display:flex}.rating-badge{border-radius:var(--radius-sm);color:#92400e;background:#fef3c7;align-items:center;gap:4px;padding:4px 10px;font-size:13px;font-weight:600;display:flex}.rating-score{font-weight:700}.rating-text{font-weight:500}.location-info,.distance-info{color:var(--text-secondary);align-items:center;gap:6px;font-size:13px;display:flex}.location-info svg{color:var(--primary-blue)}.hotel-gallery{margin:16px 0}.main-image-container{border-radius:8px;width:100%;height:280px;margin-bottom:8px;position:relative;overflow:hidden}.main-image{object-fit:cover;width:100%;height:100%}.image-counter{color:#fff;background:#000000b3;border-radius:6px;padding:6px 12px;font-size:13px;font-weight:500;position:absolute;bottom:16px;right:16px}.thumbnail-gallery{gap:8px;padding-bottom:4px;display:flex;overflow-x:auto}.thumbnail{cursor:pointer;background:0 0;border:2px solid #0000;border-radius:6px;flex-shrink:0;width:80px;height:55px;padding:0;transition:all .2s;overflow:hidden}.thumbnail:hover{border-color:#007bff;transform:scale(1.05)}.thumbnail.active{border-color:#007bff}.thumbnail img{object-fit:cover;width:100%;height:100%}.modal-tabs{border-bottom:2px solid #e5e7eb;gap:16px;margin:8px 0;display:flex}.tab{color:#6b7280;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;padding:6px 0;font-size:13px;font-weight:600;transition:all .2s;position:relative;bottom:-2px}.tab:hover{color:#374151}.tab.active{color:#007bff;border-bottom-color:#007bff}.tab-content{flex:1;min-height:0;padding-bottom:0;overflow-y:auto}.overview-section{padding-bottom:0}.overview-section .section{border-bottom:1px solid #f3f4f6;margin-bottom:16px;padding-bottom:12px}.overview-section .section:last-child{border-bottom:none;margin-bottom:0}.overview-section h3{color:var(--text-main);align-items:center;margin:0 0 8px;font-size:14px;font-weight:700;display:flex}.hotel-description{color:var(--text-secondary);margin:0;font-size:14px;line-height:1.6}.hotel-description .desc-title{color:var(--text-main);align-items:center;gap:8px;margin:16px 0 8px;font-size:16px;font-weight:700;display:flex}.hotel-description .desc-title:first-child{margin-top:0}.hotel-description .desc-section{margin-bottom:12px}.hotel-description .desc-list{margin:8px 0;padding:0;list-style:none}.hotel-description .desc-list li{align-items:flex-start;gap:8px;margin-bottom:6px;font-size:13px;line-height:1.5;display:flex}.hotel-description .desc-list li .icon{color:#10b981;flex-shrink:0;margin-top:2px}.hotel-description .desc-paragraph{margin-bottom:12px;font-size:13px;line-height:1.5}.policies-grid{grid-template-columns:repeat(2,1fr);gap:10px;display:grid}.policy-item{border:1px solid var(--border-color,#e5e7eb);background:var(--surface-gray,#f9fafb);border-radius:8px;gap:10px;padding:10px;display:flex}.policy-icon{color:#007bff;background:#fff;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.policy-content h4{color:#111827;margin:0 0 4px;font-size:13px;font-weight:600}.policy-content p{color:#6b7280;margin:0;font-size:12px;line-height:1.5}.policy-link{color:#007bff;cursor:pointer;background:0 0;border:none;margin-top:6px;padding:0;font-size:12px;text-decoration:underline;display:inline-block}.policy-link:hover{color:#0056b3}.metapolicy-notice{background:linear-gradient(135deg,#fff3cd 0%,#ffeaa7 100%);border:1px solid #ffc107;border-radius:8px;align-items:flex-start;gap:10px;margin-bottom:12px;padding:12px;display:flex}.metapolicy-notice svg{color:#856404;flex-shrink:0;margin-top:1px}.metapolicy-notice p{color:#856404;margin:0;font-size:12px;font-weight:500;line-height:1.5}.metapolicy-html-content{color:#856404;flex:1;font-size:12px;line-height:1.5}.metapolicy-html-content p{color:#856404;margin:0 0 8px;font-size:12px;line-height:1.5}.metapolicy-html-content p:last-child{margin-bottom:0}.metapolicy-html-content b,.metapolicy-html-content strong{color:#856404;font-weight:600}.metapolicy-html-content ul{margin:8px 0;padding-left:16px}.metapolicy-html-content li{color:#856404;margin-bottom:4px;font-size:12px}.metapolicy-html-content br{margin:4px 0;display:block}.metapolicy-list{flex-direction:column;gap:8px;display:flex}.metapolicy-item{background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;padding:10px 12px}.metapolicy-content{flex:1}.metapolicy-content h4{color:#111827;margin:0 0 4px;font-size:12px;font-weight:600}.metapolicy-content p{color:#6b7280;margin:0;font-size:11px;line-height:1.5}.metapolicy-content ul{color:#6b7280;margin:4px 0 0;padding-left:16px;font-size:11px;line-height:1.5}.metapolicy-content ul li{margin-bottom:2px}.metapolicy-nested{flex-direction:column;gap:6px;margin-top:4px;display:flex}.metapolicy-subitem{color:#6b7280;font-size:12px;line-height:1.6}.metapolicy-subitem strong{color:#374151;font-weight:600}.contact-info{flex-direction:column;gap:10px;display:flex}.contact-item{color:#374151;align-items:center;gap:10px;font-size:13px;display:flex}.contact-item svg{color:#007bff;flex-shrink:0}.contact-item a{color:#007bff;text-decoration:none}.contact-item a:hover{text-decoration:underline}.rooms-section{padding-bottom:0}.rooms-section h3{color:var(--text-main);margin:0 0 16px;font-size:18px;font-weight:700}.rooms-list{flex-direction:column;gap:16px;padding-bottom:0;display:flex}.room-card-detailed{background:#fff;border:1px solid #e5e7eb;border-radius:12px;grid-template-columns:280px 1fr 200px;gap:24px;padding:20px;transition:all .2s;display:grid;position:relative}.room-card-detailed:hover{border-color:#d1d5db;box-shadow:0 8px 24px #0000001a}.room-card-detailed.room-selected{background:#f0f8ff;border-color:#007bff;box-shadow:0 4px 12px #007bff26}.room-selection-checkbox{z-index:10;position:absolute;top:16px;left:16px}.room-selection-checkbox input[type=checkbox]{cursor:pointer;accent-color:#007bff;width:20px;height:20px}.room-selection-checkbox label{cursor:pointer}.room-image-container{border-radius:8px;width:100%;height:160px;overflow:hidden}.room-image{object-fit:cover;width:100%;height:100%}.room-info{flex-direction:column;gap:12px;display:flex}.room-type{color:#111827;margin:0;font-size:16px;font-weight:700}.room-description{color:#6b7280;margin:0;font-size:14px;line-height:1.6}.room-features-list{flex-wrap:wrap;gap:16px;display:flex}.feature-item{color:#374151;align-items:center;gap:6px;font-size:13px;display:flex}.feature-item svg{color:#10b981;flex-shrink:0}.room-amenities{flex-wrap:wrap;gap:8px;margin-top:8px;display:flex}.amenity-tag{color:#374151;background:#f3f4f6;border-radius:6px;align-items:center;gap:4px;padding:4px 10px;font-size:12px;font-weight:500;display:inline-flex}.amenity-tag svg{color:#007bff;flex-shrink:0}.cancellation-note{color:#10b981;align-items:center;gap:6px;margin:8px 0 0;font-size:13px;display:flex}.cancellation-note svg{flex-shrink:0}.room-booking{background:#f9fafb;border-radius:10px;flex-direction:column;justify-content:space-between;align-items:center;gap:16px;padding:16px;display:flex}.room-price-info{text-align:center}.price-label{color:#6b7280;margin-bottom:4px;font-size:12px;display:block}.price-amount{justify-content:center;align-items:baseline;gap:2px;display:flex}.currency{color:#111827;font-size:18px;font-weight:600}.amount{color:#111827;font-size:32px;font-weight:700;line-height:1}.price-period{color:#6b7280;margin-top:4px;font-size:13px;display:block}.total-price-info{text-align:center;border-top:1px solid #e5e7eb;margin-top:12px;padding-top:12px}.total-label{color:#6b7280;margin-bottom:4px;font-size:12px;display:block}.total-amount{color:#111827;font-size:16px;font-weight:700;display:block}.btn-select-room{color:#fff;cursor:pointer;background:#007bff;border:none;border-radius:8px;width:100%;padding:12px 24px;font-size:15px;font-weight:600;transition:all .2s}.btn-select-room:hover:not(:disabled){background:#0056b3;transform:translateY(-2px);box-shadow:0 8px 16px #007bff4d}.btn-select-room:disabled{cursor:not-allowed;opacity:.6;background:#6c757d}.btn-select-room.selected{color:#fff;background:#28a745}.btn-select-room.selected:hover{background:#218838}.room-availability{color:#10b981;align-items:center;gap:6px;font-size:13px;font-weight:500;display:flex}.room-availability svg{flex-shrink:0}.no-rooms{text-align:center;color:#6b7280;padding:60px 20px;font-size:15px}.amenities-section{padding-bottom:0}.amenities-section h3{color:var(--text-main);margin:0 0 16px;font-size:18px;font-weight:700}.amenities-grid{grid-template-columns:repeat(3,1fr);gap:12px;padding-bottom:0;display:grid}.amenity-item{color:#374151;background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;align-items:center;gap:12px;padding:16px;font-size:14px;font-weight:500;display:flex}.amenity-item svg{color:#737373;flex-shrink:0}[data-theme=dark] .amenity-item svg{color:#a3a3a3}.reviews-section{padding-bottom:0}.reviews-section h3{color:var(--text-main);margin:0 0 16px;font-size:18px;font-weight:700}.reviews-header{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;display:flex}.overall-rating{align-items:center;gap:16px;display:flex}.rating-score-large{color:#111827;font-size:48px;font-weight:700;line-height:1}.rating-details{flex-direction:column;gap:4px;display:flex}.rating-details .stars{gap:2px;display:flex}.reviews-count{color:#6b7280;font-size:14px}.reviews-list{flex-direction:column;gap:16px;padding-bottom:0;display:flex}.review-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:20px}.review-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.review-author{color:#111827;font-size:15px;font-weight:600}.review-rating{gap:2px;display:flex}.review-date{color:#6b7280;margin:0 0 12px;font-size:13px}.review-comment{color:#374151;margin:0;font-size:14px;line-height:1.6}.no-reviews{text-align:center;color:#6b7280;padding:60px 20px;font-size:15px}.pricing-sidebar{border-left:1px solid var(--border-subtle,#e5e7eb);z-index:1;background:var(--surface-white,#fff);grid-column:2;padding:12px;position:relative;overflow-y:auto}.pricing-card{background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:12px;position:sticky;top:12px;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.price-header{border-bottom:1px solid #e5e7eb;margin-bottom:10px;padding-bottom:10px}.price-header .price-amount{align-items:baseline;gap:4px;margin-bottom:4px;display:flex}.price-header .currency{color:var(--text-main);font-size:16px;font-weight:700}.price-header .amount{color:var(--text-main);font-size:24px;font-weight:700;line-height:1}.price-header .period{color:var(--text-secondary);font-size:13px;font-weight:500}.price-details{border-top:1px solid var(--border-color,#e5e5e5);margin-top:8px;padding-top:8px}.price-per-room{color:var(--text-secondary);font-size:12px;line-height:1.4}.price-total{color:var(--primary);margin-top:4px;font-size:13px;font-weight:600}.selected-rooms-summary{color:#374151;border-bottom:1px solid #e5e5e5;margin-bottom:8px;padding-bottom:8px;font-size:13px}.selected-room-line{color:#6b7280;justify-content:space-between;margin:4px 0;font-size:12px;display:flex}.selected-room-line span:last-child{color:#374151;font-weight:600}.booking-info{flex-direction:column;gap:6px;margin-bottom:12px;display:flex}.info-item{color:var(--text-main);align-items:center;gap:6px;font-size:12px;display:flex}.info-item svg{color:var(--success-text);flex-shrink:0;width:14px;height:14px}.btn-book-now{color:#fff;cursor:pointer;background:#0056b3;border:none;border-radius:6px;width:100%;margin-bottom:8px;padding:10px;font-size:14px;font-weight:700;transition:all .2s;box-shadow:0 4px 8px -2px #007bff66}.btn-book-now:hover:not(:disabled){background:#003d7a;transform:translateY(-1px);box-shadow:0 6px 12px -2px #007bff80}.btn-book-now:disabled{cursor:not-allowed;opacity:.8;background:#94a3b8}.secondary-actions{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px;display:grid}.btn-secondary{color:#374151;cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:6px;justify-content:center;align-items:center;gap:4px;padding:8px;font-size:12px;font-weight:600;transition:all .2s;display:flex}.btn-secondary:hover{color:#007bff;background:#f9fafb;border-color:#007bff}.booking-note{color:#6b7280;background:#f3f4f6;border-radius:6px;align-items:center;gap:6px;padding:8px;font-size:11px;display:flex}.booking-note svg{color:#007bff;flex-shrink:0;width:14px;height:14px}.policy-modal{background:#fff;border-radius:16px;width:90%;max-width:600px;max-height:80vh;overflow-y:auto;box-shadow:0 25px 50px #0000004d}.policy-modal-header{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:24px;display:flex}.policy-modal-header h3{color:#111827;margin:0;font-size:20px;font-weight:700}.close-btn{color:#6b7280;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px;transition:all .2s}.close-btn:hover{color:#111827;background:#f3f4f6}.policy-modal-content{padding:24px}.policy-modal-content .policy-section{margin-bottom:24px}.policy-modal-content .policy-section:last-child{margin-bottom:0}.policy-modal-content h4{color:#111827;margin:0 0 8px;font-size:16px;font-weight:600}.policy-modal-content p{color:#6b7280;margin:0;font-size:14px;line-height:1.6}.compliance-notice{background:#f0fdf4;border:1px solid #86efac;border-radius:10px;align-items:flex-start;gap:12px;margin-top:24px;padding:16px;display:flex}.compliance-notice svg{color:#10b981;flex-shrink:0;margin-top:2px}.compliance-notice p{color:#065f46;margin:0;font-size:13px}.policy-modal-footer{border-top:1px solid #e5e7eb;justify-content:flex-end;padding:20px 24px;display:flex}.btn-primary{color:#fff;cursor:pointer;background:linear-gradient(135deg,#6366f1 0%,#8b5cf6 100%);border:none;border-radius:8px;padding:12px 32px;font-size:15px;font-weight:600;transition:all .2s}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}@media (width<=1024px){.modal-body{grid-template-columns:1fr 300px}.room-card-detailed{grid-template-columns:1fr}.room-image-container{height:200px}.amenities-grid{grid-template-columns:repeat(2,1fr)}.policies-grid{grid-template-columns:1fr}}@media (width<=768px){.hotel-detail-modal{border-radius:0;max-height:-webkit-fill-available;margin:0}.modal-header{padding:8px 12px}.back-btn span,.action-btn span{display:none}.modal-body{grid-template-columns:1fr 260px}.modal-main-content{padding:8px 12px}.hotel-name{font-size:18px}.main-image-container{border-radius:6px;height:150px}.thumbnail{width:60px;height:44px}.modal-tabs{-webkit-overflow-scrolling:touch;gap:12px;margin:8px 0;overflow-x:auto}.tab{white-space:nowrap;padding:4px 0;font-size:12px}.amenities-grid{grid-template-columns:1fr}.pricing-sidebar,.pricing-card{padding:8px}.price-header .amount{font-size:24px}.secondary-actions{grid-template-columns:1fr}}[data-theme=dark] .hotel-detail-modal{background:var(--surface-white,#1a1f2e);border-color:var(--border-subtle,#2d333b)}[data-theme=dark] .modal-header{background:var(--surface-white,#1a1f2e);border-bottom-color:var(--border-subtle,#2d333b)}[data-theme=dark] .back-btn{color:var(--primary-blue,#4a9eff)}[data-theme=dark] .back-btn:hover{background:var(--button-bg-hover,#2d333b)}[data-theme=dark] .action-btn{background:var(--surface-white,#1a1f2e);color:var(--text-secondary,#b8bdc3);border-color:var(--border-subtle,#2d333b)}[data-theme=dark] .action-btn:hover{background:var(--button-bg-hover,#2d333b);border-color:var(--primary-blue,#4a9eff);color:var(--primary-blue,#4a9eff)}[data-theme=dark] .modal-main-content{background:var(--surface-white,#1a1f2e)}[data-theme=dark] .hotel-category{color:var(--text-muted,#8a9199)}[data-theme=dark] .hotel-name{color:var(--text-main,#e8eaed)}[data-theme=dark] .tab{color:var(--text-secondary,#b8bdc3)}[data-theme=dark] .tab:hover{color:var(--text-main,#e8eaed)}[data-theme=dark] .tab.active{color:var(--primary-blue,#4a9eff);border-bottom-color:var(--primary-blue,#4a9eff)}[data-theme=dark] .policy-item{background:var(--input-bg,#1a1f2e);border-color:var(--border-subtle,#2d333b)}[data-theme=dark] .policy-item h4{color:var(--text-main,#e8eaed)}[data-theme=dark] .policy-item p{color:var(--text-secondary,#b8bdc3)}[data-theme=dark] .metapolicy-notice{background:linear-gradient(135deg,#3a3000 0%,#4a4000 100%);border-color:#6a5a00}[data-theme=dark] .metapolicy-notice svg{color:#ffc107}[data-theme=dark] .metapolicy-notice p{color:#ffeaa7}[data-theme=dark] .metapolicy-item{background:var(--input-bg,#1a1f2e);border-color:var(--border-subtle,#2d333b)}[data-theme=dark] .metapolicy-item:hover{background:var(--surface-white,#1f2937);border-color:var(--border-color,#374151)}[data-theme=dark] .metapolicy-icon{background:var(--surface-white,#1f2937);color:var(--primary-blue,#4a9eff)}[data-theme=dark] .metapolicy-content h4{color:var(--text-main,#e8eaed)}[data-theme=dark] .metapolicy-content p,[data-theme=dark] .metapolicy-content ul,[data-theme=dark] .metapolicy-subitem{color:var(--text-secondary,#b8bdc3)}[data-theme=dark] .metapolicy-subitem strong{color:var(--text-main,#e8eaed)}[data-theme=dark] .pricing-sidebar{background:var(--modal-sidebar-bg,#151a23);border-left-color:var(--border-subtle,#2d333b)}[data-theme=dark] .pricing-card{background:var(--surface-white,#1a1f2e);border-color:var(--border-subtle,#2d333b)}[data-theme=dark] .price-amount .amount{color:var(--text-main,#e8eaed)}[data-theme=dark] .price-per-room{color:var(--text-secondary,#b8bdc3)}[data-theme=dark] .price-total{color:var(--primary,#4a9eff)}[data-theme=dark] .info-item{color:var(--text-secondary,#b8bdc3)}[data-theme=dark] .btn-book-now{background:var(--primary-blue,#4a9eff)}[data-theme=dark] .btn-book-now:hover{background:var(--primary-blue-hover,#6bb0ff)}[data-theme=dark] .btn-book-now:disabled{background:var(--text-muted,#64748b);opacity:.6}[data-theme=dark] .btn-secondary{background:var(--surface-white,#1a1f2e);color:var(--text-secondary,#b8bdc3);border-color:var(--border-subtle,#2d333b)}[data-theme=dark] .btn-secondary:hover{background:var(--button-bg-hover,#2d333b);border-color:var(--primary-blue,#4a9eff);color:var(--primary-blue,#4a9eff)}[data-theme=dark] .booking-note{background:var(--input-bg,#1a1f2e);color:var(--text-muted,#8a9199)}[data-theme=dark] .room-card-detailed{background:var(--surface-white,#1a1f2e);border-color:var(--border-subtle,#2d333b)}[data-theme=dark] .room-type{color:var(--text-main,#e8eaed)}[data-theme=dark] .room-description{color:var(--text-secondary,#b8bdc3)}[data-theme=dark] .amenity-item{background:var(--input-bg,#1a1f2e);border-color:var(--border-subtle,#2d333b);color:var(--text-secondary,#b8bdc3)}[data-theme=dark] .review-card{background:var(--surface-white,#1a1f2e);border-color:var(--border-subtle,#2d333b)}[data-theme=dark] .reviewer-name{color:var(--text-main,#e8eaed)}[data-theme=dark] .review-text{color:var(--text-secondary,#b8bdc3)}
