*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Segoe UI',system-ui,-apple-system,sans-serif;background:#f5f7fa;color:#1e293b;line-height:0;min-height:100vh}
body *{line-height:1.4}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}

/* Header */
.pub-header{background:#fff;color:#1e293b;padding:0 24px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;height:64px;box-shadow:0 1px 4px rgba(0,0,0,.06)}
.pub-header .logo{font-size:22px;font-weight:800;letter-spacing:-0.5px;display:flex;align-items:center;gap:8px;color:#0c1a2d}
.pub-header .logo i{color:#f5b342;font-size:26px}
.pub-header nav{display:flex;gap:8px;align-items:center}
.pub-header nav a{font-size:14px;font-weight:500;padding:8px 16px;border-radius:8px;transition:all .15s;color:#475569}
.pub-header nav a:hover{background:#f1f5f9;color:#0c1a2d}
.pub-header nav .btn-ghost{border:1px solid #e2e8f0;padding:7px 16px}
.pub-header nav .btn-ghost:hover{border-color:#f5b342;background:#fff}
.pub-header nav .btn-solid{background:#f5b342;color:#0c1a2d;font-weight:700}
.pub-header nav .btn-solid:hover{background:#e8a530;color:#0c1a2d}

/* Hero */
.hero{position:relative;background:linear-gradient(135deg,#0c1a2d 0%,#1a3a5c 50%,#2d4a6f 100%);color:#fff;padding:80px 24px 100px;text-align:center;overflow:hidden}
.hero::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1440 320"><path fill="rgba(255,255,255,0.03)" d="M0,160L48,138.7C96,117,192,75,288,80C384,85,480,139,576,165.3C672,192,768,192,864,170.7C960,149,1056,107,1152,106.7C1248,107,1344,149,1392,170.7L1440,192L1440,320L1392,320C1344,320,1248,320,1152,320C1056,320,960,320,864,320C768,320,672,320,576,320C480,320,384,320,288,320C192,320,96,320,48,320L0,320Z"/></svg>') no-repeat bottom;background-size:cover;opacity:.6;pointer-events:none}
.hero .badge{display:inline-block;background:rgba(245,179,66,.2);color:#f5b342;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1px;padding:6px 16px;border-radius:20px;margin-bottom:16px}
.hero h1{font-size:44px;font-weight:800;margin-bottom:10px;letter-spacing:-1px;line-height:1.15;position:relative}
.hero h1 span{color:#f5b342}
.hero p{font-size:17px;opacity:.85;margin-bottom:36px;max-width:580px;margin-left:auto;margin-right:auto;position:relative}
.hero .search-box{background:#fff;border-radius:16px;padding:8px;display:flex;gap:0;flex-wrap:wrap;align-items:stretch;max-width:880px;margin:0 auto;box-shadow:0 16px 48px rgba(0,0,0,.25);position:relative}
.hero .search-box .field{flex:1;min-width:150px;display:flex;flex-direction:column;gap:2px;padding:10px 16px;border-right:1px solid #e2e8f0;text-align:left}
.hero .search-box .field:last-of-type{border-right:none}
.hero .search-box .field label{font-size:10px;font-weight:700;text-transform:uppercase;color:#64748b;letter-spacing:.6px}
.hero .search-box .field input,.hero .search-box .field select{padding:6px 0;border:none;font-size:14px;color:#1e293b;background:transparent;outline:none;width:100;font-weight:500}
.hero .search-box .field input::placeholder{color:#94a3b8;font-weight:400}
.hero .search-box .field select{cursor:pointer;appearance:none;-webkit-appearance:none;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E") no-repeat right center}
.hero .search-box button{padding:12px 32px;background:#f5b342;color:#0c1a2d;font-weight:700;border:none;border-radius:12px;font-size:15px;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:8px;white-space:nowrap;margin:4px}
.hero .search-box button:hover{background:#e8a530;transform:scale(1.02)}
.hero .search-box button i{font-size:18px}

/* Section */
.section{padding:5px;max-width:1200px;margin:0 auto}
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px}
.section-header h2{font-size:26px;font-weight:800;letter-spacing:-0.5px}
.section-header h2 span{color:#f5b342}
.section-header .view-all{font-size:14px;color:#f5b342;font-weight:600;display:flex;align-items:center;gap:4px;transition:gap .15s}
.section-header .view-all:hover{gap:8px}

/* Destination Cards */
.dest-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;margin-bottom:48px}
.dest-card{position:relative;border-radius:16px;overflow:hidden;height:200px;cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,.08);transition:transform .3s,box-shadow .3s}
.dest-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,.15)}
.dest-card img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.dest-card:hover img{transform:scale(1.08)}
.dest-card .overlay{position:absolute;bottom:0;left:0;right:0;padding:20px;background:linear-gradient(transparent,rgba(0,0,0,.7))}
.dest-card .overlay h3{color:#fff;font-size:18px;font-weight:700}
.dest-card .overlay p{color:rgba(255,255,255,.8);font-size:13px}

/* Hotel Grid */
.hotel-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}
.hotel-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 1px 4px rgba(0,0,0,.06);transition:transform .25s,box-shadow .25s;cursor:pointer}
.hotel-card:hover{transform:translateY(-6px);box-shadow:0 12px 32px rgba(0,0,0,.1)}
.hotel-card .card-img{width:100%;height:210px;object-fit:cover;background:#e2e8f0}
.hotel-card .card-img-placeholder{width:100%;height:210px;background:linear-gradient(135deg,#e2e8f0,#cbd5e1);display:flex;align-items:center;justify-content:center;font-size:44px;color:#94a3b8}
.hotel-card .card-body{padding:18px;display:flex;gap:16px}
.hotel-card .card-body .cb-left{flex:1;min-width:0}
.hotel-card .card-body .cb-left h3{font-size:18px;font-weight:700;margin-bottom:4px}
.hotel-card .card-body .cb-left .location{font-size:13px;color:#64748b;display:flex;align-items:center;gap:6px;margin-bottom:6px}
.hotel-card .card-body .cb-right{text-align:right;flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;justify-content:space-between;min-width:140px}
.hotel-card .card-body .cb-right .price{font-size:20px;font-weight:800;color:#0c1a2d;line-height:1.2}
.hotel-card .card-body .cb-right .price small{font-size:13px;font-weight:400;color:#64748b}
.hotel-card .card-body .cb-right .up-to{font-size:11px;color:#94a3b8;margin-top:1px}
.hotel-card .card-body .cb-right .btn-book{padding:8px 20px;background:#f5b342;color:#0c1a2d;font-weight:700;border:none;border-radius:10px;font-size:12px;cursor:pointer;transition:background .15s;display:inline-block;margin-top:8px}
.hotel-card .card-body .cb-right .btn-book:hover{background:#e8a530}
.hotel-card .card-badge{position:absolute;top:12px;left:12px;background:#f5b342;color:#0c1a2d;font-size:11px;font-weight:700;padding:4px 10px;border-radius:6px}
.hotel-card .card-img-wrap{position:relative}

/* Hotel Detail Page */
.detail-hero{position:relative;width:100%;height:400px;overflow:hidden;background:#e2e8f0}
.detail-hero img{width:100%;height:100%;object-fit:cover}
.detail-hero .overlay{position:absolute;bottom:0;left:0;right:0;padding:40px 24px 24px;background:linear-gradient(transparent,rgba(0,0,0,.7))}
.detail-hero .overlay h1{font-size:32px;font-weight:800;color:#fff;margin-bottom:4px}
.detail-hero .overlay .meta{display:flex;gap:16px;color:rgba(255,255,255,.85);font-size:14px;align-items:center}
.detail-hero .overlay .meta .stars{color:#f5b342}
.detail-content{max-width:1100px;margin:0 auto;padding:24px;display:grid;grid-template-columns:1fr 340px;gap:28px;align-items:start}
.detail-main{min-width:0}
.detail-main h2{font-size:20px;font-weight:700;margin:24px 0 12px}
.detail-main p{color:#475569;font-size:15px;line-height:1.7}

/* Room Type Cards */
.room-list{display:flex;flex-direction:column;gap:12px}
.room-card{display:flex;gap:16px;background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:16px;transition:border-color .15s}
.room-card:hover{border-color:#f5b342}
.room-card .room-img{width:140px;height:100px;border-radius:8px;object-fit:cover;flex-shrink:0;background:#e2e8f0}
.room-card .room-img-placeholder{width:140px;height:100px;border-radius:8px;background:#f1f5f9;display:flex;align-items:center;justify-content:center;color:#94a3b8;font-size:28px;flex-shrink:0}
.room-card .room-info{flex:1;min-width:0}
.room-card .room-info h4{font-size:16px;font-weight:700;margin-bottom:2px}
.room-card .room-info .desc{font-size:13px;color:#64748b;margin-bottom:4px}
.room-card .room-info .meta{display:flex;gap:12px;font-size:13px;color:#94a3b8}
.room-card .room-price{text-align:right;flex-shrink:0;display:flex;flex-direction:column;justify-content:center;align-items:end}
.room-card .room-price .amount{font-size:22px;font-weight:800;color:#0c1a2d}
.room-card .room-price small{font-size:12px;color:#64748b}

/* Sidebar Availability Checker */
.side-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:20px;position:sticky;top:80px}
.side-card h3{font-size:15px;font-weight:700;margin-bottom:16px}
.side-card .field{margin-bottom:12px}
.side-card .field label{font-size:12px;font-weight:600;display:block;margin-bottom:4px;color:#475569}
.side-card .field input{padding:10px 12px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;width:100%;outline:none;transition:border-color .15s}
.side-card .field input:focus{border-color:#f5b342}
.side-card .btn-check{padding:12px;background:#f5b342;color:#0c1a2d;font-weight:700;border:none;border-radius:8px;font-size:14px;cursor:pointer;width:100%;transition:background .15s}
.side-card .btn-check:hover{background:#e8a530}

/* Availability Results */
.avail-result{margin-top:16px}
.avail-result .item{display:flex;justify-content:space-between;align-items:center;padding:12px;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:8px}
.avail-result .item .info h4{font-size:14px;font-weight:600}
.avail-result .item .info small{color:#64748b;font-size:12px}
.avail-result .item .price{font-size:18px;font-weight:800;color:#0c1a2d}
.avail-result .item .btn-select{padding:6px 14px;background:#f5b342;color:#0c1a2d;font-weight:600;border:none;border-radius:6px;font-size:12px;cursor:pointer;margin-left:8px}

/* Empty State */
.empty-state{text-align:center;padding:64px 24px;color:#94a3b8}
.empty-state i{font-size:56px;display:block;margin-bottom:16px}
.empty-state p{font-size:16px}

/* Features Strip */
.features-wrap{background:#f8f7f4;padding:4px 24px;border-top:1px solid #efede8;border-bottom:1px solid #efede8}
.features{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;max-width:1000px;margin:0 auto}
.features .feat{text-align:center;padding:0;border-radius:12px;transition:all .25s}
.features .feat:hover{background:#fff;box-shadow:0 4px 20px rgba(0,0,0,.06)}
.features .feat .fi{width:48px;height:48px;border-radius:12px;background:#fff;display:flex;align-items:center;justify-content:center;margin:0 auto 12px;box-shadow:0 2px 8px rgba(0,0,0,.04);transition:all .25s}
.features .feat:hover .fi{background:#f5b342;box-shadow:0 4px 16px rgba(245,179,66,.25)}
.features .feat .fi i{font-size:22px;color:#c9952a;transition:color .25s}
.features .feat:hover .fi i{color:#fff}
.features .feat h4{font-size:14px;font-weight:700;color:#0c1a2d;margin-bottom:2px}
.features .feat p{font-size:12px;color:#6b6762;margin:0;line-height:1.5}

/* Footer */
.pub-footer{background:#0c1a2d;color:rgba(255,255,255,.7);padding:48px 24px 32px;margin-top:64px}
.pub-footer .inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:32px}
.pub-footer .inner h4{color:#fff;font-size:14px;font-weight:700;margin-bottom:12px}
.pub-footer .inner p{font-size:13px;line-height:1.8}
.pub-footer .inner a{display:block;font-size:13px;line-height:2;transition:color .15s}
.pub-footer .inner a:hover{color:#f5b342}
.pub-footer .bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:32px;padding-top:20px;text-align:center;font-size:13px;max-width:1200px;margin-left:auto;margin-right:auto}

/* Responsive */
@media(max-width:768px){
  .hero h1{font-size:28px}
  .hero .search-box{flex-direction:column;padding:12px}
  .hero .search-box .field{min-width:100%;border-right:none;border-bottom:1px solid #e2e8f0;padding:10px 12px}
  .hero .search-box .field:last-of-type{border-bottom:none}
  .hero .search-box button{width:100%;justify-content:center;margin:8px 0 4px}
  .hotel-grid{grid-template-columns:1fr}
  .hotel-card .card-img,.hotel-card .card-img-placeholder{height:180px}
  .hotel-card .card-body{gap:10px}
  .hotel-card .card-body .cb-right{min-width:120px}
  .hotel-card .card-body .cb-right .price{font-size:17px}
  .hotel-card .card-body .cb-right .btn-book{margin-top:4px}
  .hotel-card .card-body .cb-left{min-width:0}
  .detail-content{grid-template-columns:1fr}
  .room-card{flex-direction:column}
  .room-card .room-img,.room-card .room-img-placeholder{width:100%;height:160px}
  .room-card .room-price{text-align:left;flex-direction:row;align-items:center;gap:12px;margin-top:8px}
  .pub-footer .inner{grid-template-columns:1fr 1fr}
  .dest-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}
  .dest-card{height:140px}
  .pub-header{height:56px;padding:0 16px}
}
