@import url('https://fonts.googleapis.com/css2?family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,600;9..40,700&family=Cormorant+Garamond:wght@600&display=swap');

.afb-hotel-wrap, .afb-hotel-wrap * { box-sizing: border-box; font-family: 'DM Sans', sans-serif; }
.afb-hotel-wrap {
  background: linear-gradient(135deg, #0a1628 0%, #0f2040 45%, #1a3a6e 100%);
  padding: 36px 18px;
  border-radius: 22px;
  position: relative;
  overflow: hidden;
}
.afb-hotel-wrap::before,
.afb-hotel-results::before,
.afb-hotel-room-wrap::before,
.afb-hotel-thankyou::before {
  content: '';
  position: absolute;
  inset: auto -60px -80px auto;
  width: 240px;
  height: 240px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(245,158,11,.14) 0%, transparent 70%);
  pointer-events: none;
}
.afb-hotel-dots {
  position: absolute;
  top: 18px; left: 18px;
  width: 84px; height: 84px;
  background-image: radial-gradient(circle, rgba(255,255,255,.09) 1.5px, transparent 1.5px);
  background-size: 14px 14px;
  pointer-events: none;
}
.afb-hotel-heading { text-align:center; margin-bottom: 24px; position:relative; z-index:1; }
.afb-hotel-heading h2 {
  margin: 0 0 8px;
  color: #fff;
  line-height: 1.15;
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(28px, 4.5vw, 42px);
}
.afb-hotel-heading h2 span { color: #f59e0b; }
.afb-hotel-heading p { margin:0; color: rgba(255,255,255,.7); font-size: 15px; }

.afb-hotel-card {
  position: relative;
  z-index: 1;
  background: #fff;
  border-radius: 22px;
  padding: 26px;
  box-shadow: 0 26px 60px rgba(10,22,40,.24);
  max-width: 980px;
  margin: 0 auto;
}
.afb-hotel-grid { display:grid; grid-template-columns: 1.35fr 1fr; gap:14px; }
.afb-hotel-field { display:flex; flex-direction:column; gap:6px; }
.afb-hotel-field label {
  font-size: 12px; font-weight: 700; color:#94a3b8; letter-spacing: .08em; text-transform: uppercase;
}
.afb-hotel-input-wrap { position: relative; }
.afb-hotel-input-wrap .afb-icon {
  position:absolute; left:14px; top:50%; transform:translateY(-50%); font-size:16px; opacity:.7;
}
.afb-hotel-card input[type="text"],
.afb-hotel-card input[type="email"],
.afb-hotel-card input[type="tel"],
.afb-hotel-card input[type="number"],
.afb-hotel-card select,
.afb-hotel-card textarea {
  width:100%; border:1.5px solid #e2e8f0; background:#f8fafc; color:#1e293b;
  border-radius: 14px; padding: 15px 16px 15px 42px; font-size:15px; min-height:54px;
  transition: .2s ease;
}
.afb-hotel-card textarea { min-height: 110px; padding-left: 16px; resize: vertical; }
.afb-hotel-card input:focus,
.afb-hotel-card select:focus,
.afb-hotel-card textarea:focus {
  outline:none; border-color:#2563eb; background:#fff; box-shadow:0 0 0 4px rgba(37,99,235,.09);
}
.afb-hotel-inline { display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:14px; margin-top: 14px; }
.afb-hotel-search-btn,
.afb-hotel-primary-btn,
.afb-hotel-secondary-btn {
  display:inline-flex; align-items:center; justify-content:center; gap:10px; min-height:56px;
  border-radius:16px; text-decoration:none; font-weight:700; border:none; cursor:pointer; transition:.2s ease;
}
.afb-hotel-search-btn,
.afb-hotel-primary-btn {
  background: linear-gradient(135deg, #ff7a00 0%, #ffb000 100%);
  color:#fff; box-shadow: 0 14px 26px rgba(255,122,0,.25);
}
.afb-hotel-search-btn:hover,
.afb-hotel-primary-btn:hover { transform: translateY(-1px); filter: brightness(1.03); }
.afb-hotel-secondary-btn {
  background:#eff6ff; color:#2563eb; border:1.5px solid #cfe0ff;
}
.afb-hotel-submit-wrap { margin-top: 18px; }
.afb-hotel-submit-wrap .afb-hotel-search-btn { width:100%; font-size: 20px; }

.afb-hotel-results,
.afb-hotel-room-wrap,
.afb-hotel-thankyou {
  position:relative;
  background: linear-gradient(135deg, #0a1628 0%, #0f2040 45%, #1a3a6e 100%);
  padding: 18px;
  border-radius: 20px;
  overflow:hidden;
}
.afb-hotel-results-inner,
.afb-hotel-room-inner,
.afb-hotel-thankyou-inner { position:relative; z-index:1; }
.afb-hotel-summary {
  display:flex; justify-content:space-between; gap:12px; align-items:flex-start; flex-wrap:wrap;
  color:#fff; margin-bottom:18px; padding:22px; border-radius:18px; background: rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08);
}
.afb-hotel-summary h3 { margin:0 0 8px; font-size: clamp(20px, 3.5vw, 28px); }
.afb-hotel-summary-meta { display:flex; flex-wrap:wrap; gap:10px; color:rgba(255,255,255,.7); font-size:14px; }
.afb-hotel-pill { display:inline-flex; align-items:center; gap:8px; padding:8px 14px; border-radius:999px; background:rgba(245,158,11,.14); color:#f59e0b; border:1px solid rgba(245,158,11,.28); font-weight:700; }
.afb-hotel-list { display:grid; gap:16px; }
.afb-hotel-result-card,
.afb-room-card,
.afb-hotel-panel {
  background:#fff; border:1px solid #e8edf5; border-radius:18px; overflow:hidden; box-shadow:0 2px 14px rgba(10,22,40,.07);
}
.afb-hotel-result-grid { display:grid; grid-template-columns: 280px 1fr; }
.afb-hotel-thumb { width:100%; height:100%; min-height:220px; object-fit:cover; display:block; background:#f1f5f9; }
.afb-hotel-result-body { padding:20px; }
.afb-hotel-result-top { display:flex; justify-content:space-between; gap:14px; align-items:flex-start; margin-bottom:12px; }
.afb-hotel-result-title { margin:0 0 8px; font-size:24px; color:#0f172a; }
.afb-hotel-address { margin:0; color:#64748b; line-height:1.55; }
.afb-hotel-price { text-align:right; white-space:nowrap; }
.afb-hotel-price strong { display:block; font-size:34px; line-height:1; color:#2563eb; }
.afb-hotel-price span { color:#94a3b8; font-size:14px; }
.afb-hotel-meta-row { display:flex; flex-wrap:wrap; gap:10px; margin:14px 0 18px; }
.afb-hotel-meta-chip { padding:9px 12px; border-radius:999px; background:#f8fafc; border:1px solid #e2e8f0; color:#334155; font-size:13px; font-weight:600; }
.afb-hotel-actions { display:flex; gap:12px; flex-wrap:wrap; }
.afb-hotel-actions > * { flex:1 1 180px; }

.afb-room-card { padding:22px; }
.afb-room-top { display:flex; justify-content:space-between; gap:16px; align-items:flex-start; margin-bottom:10px; }
.afb-room-card h3 { margin:0; font-size:22px; color:#0f172a; }
.afb-room-desc { color:#64748b; line-height:1.6; margin:0 0 16px; }
.afb-room-specs { display:flex; flex-wrap:wrap; gap:10px; margin: 0 0 18px; }
.afb-room-price strong { display:block; color:#2563eb; font-size:30px; }

.afb-hotel-columns { display:grid; grid-template-columns: 1.08fr .92fr; gap:18px; }
.afb-hotel-panel { padding:22px; }
.afb-hotel-panel h3 { margin:0 0 14px; color:#0f172a; font-size:22px; }
.afb-hotel-panel p { color:#475569; line-height:1.65; }

.afb-confirm-list { display:grid; gap:12px; }
.afb-confirm-item { display:flex; justify-content:space-between; gap:12px; border-bottom:1px solid #eef2f7; padding-bottom:10px; }
.afb-confirm-item:last-child { border-bottom:0; padding-bottom:0; }
.afb-confirm-label { color:#94a3b8; font-size:13px; text-transform:uppercase; letter-spacing:.06em; font-weight:700; }
.afb-confirm-value { text-align:right; color:#0f172a; font-weight:700; }

.afb-thankyou-box { background:#fff; border-radius:18px; padding:24px; box-shadow:0 2px 14px rgba(10,22,40,.08); }
.afb-thankyou-title { color:#fff; margin:0 0 18px; font-size: clamp(24px,4vw,34px); }
.afb-thankyou-sub { color:rgba(255,255,255,.72); margin:0 0 20px; }
.afb-pnr-banner { display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap; align-items:center; background:rgba(245,158,11,.14); border:1px solid rgba(245,158,11,.28); padding:16px 18px; border-radius:16px; color:#fff; margin-bottom:18px; }
.afb-pnr-code { font-size:30px; font-weight:800; letter-spacing:.06em; color:#fbbf24; }
.afb-note-box { background:#fff7ed; border:1px solid #fed7aa; color:#9a3412; border-radius:14px; padding:14px 16px; margin-top:16px; }

@media (max-width: 900px) {
  .afb-hotel-grid,
  .afb-hotel-columns,
  .afb-hotel-result-grid { grid-template-columns: 1fr; }
  .afb-hotel-price { text-align:left; }
}
@media (max-width: 640px) {
  .afb-hotel-wrap, .afb-hotel-results, .afb-hotel-room-wrap, .afb-hotel-thankyou { padding:14px; border-radius:16px; }
  .afb-hotel-card, .afb-hotel-panel, .afb-room-card, .afb-thankyou-box { padding:18px; border-radius:16px; }
  .afb-hotel-inline { grid-template-columns: 1fr; }
  .afb-hotel-result-top, .afb-room-top, .afb-confirm-item { flex-direction:column; }
  .afb-confirm-value { text-align:left; }
  .afb-hotel-actions > * { flex-basis: 100%; }
}
