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