/* ============================================================
   eBooking — OTA Mobile-First Design System (NEW)
   Direction: white bg, deep-blue primary, premium gradients,
   rounded cards, mobile-first. 100% original (no Booking.com assets).
   ============================================================ */

:root{
  /* Brand — deep blue */
  --pri:#1452e6; --pri-600:#0f43c4; --pri-700:#0c3399; --pri-050:#eef3ff; --pri-100:#dbe6ff;
  --accent:#ff5a3c; --accent-050:#fff0ec;
  --ink:#0c1322; --ink-2:#384357; --muted:#6b7790; --line:#e7ebf2; --line-2:#eef1f6;
  --bg:#ffffff; --bg-soft:#f6f8fc; --white:#fff;
  --ok:#10936b; --ok-050:#e6f6ef; --warn:#c47d05; --warn-050:#fff6e3; --star:#ffb400;
  --hero-1:#1452e6; --hero-2:#0c2a8a;
  /* Spacing scale */
  --s-1:4px; --s-2:8px; --s-3:12px; --s-4:16px; --s-5:20px; --s-6:24px; --s-7:32px; --s-8:40px; --s-9:56px;
  /* Radius */
  --r-1:8px; --r-2:12px; --r-3:16px; --r-4:20px; --r-5:28px; --r-full:999px;
  /* Type scale */
  --t-xs:11px; --t-sm:13px; --t-base:15px; --t-md:17px; --t-lg:20px; --t-xl:24px; --t-2xl:30px; --t-3xl:36px;
  /* Shadow */
  --sh-1:0 1px 2px rgba(12,19,34,.06),0 1px 3px rgba(12,19,34,.05);
  --sh-2:0 4px 14px rgba(12,19,34,.08);
  --sh-3:0 10px 30px rgba(12,19,34,.12);
  --sh-pri:0 8px 22px rgba(20,82,230,.30);
  /* z */
  --z-nav:50; --z-sticky:60; --z-sheet:90; --z-overlay:85;
  --hh:60px; --bn:64px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;-webkit-text-size-adjust:100%}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  color:var(--ink);background:var(--bg);line-height:1.5;-webkit-font-smoothing:antialiased;
  padding-bottom:calc(var(--bn) + env(safe-area-inset-bottom,0px));overflow-x:hidden}
body.lock{overflow:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
ul{list-style:none}
.wrap{max-width:1180px;margin:0 auto;padding:0 var(--s-4)}
.scroll-x{display:flex;gap:var(--s-3);overflow-x:auto;scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;padding:var(--s-1) var(--s-4) var(--s-2);scrollbar-width:none}
.scroll-x::-webkit-scrollbar{display:none}
.scroll-x>*{scroll-snap-align:start;flex:0 0 auto}
.sec{padding:var(--s-6) 0}
.sec-head{display:flex;align-items:center;justify-content:space-between;padding:0 var(--s-4);margin-bottom:var(--s-4)}
.sec-head h2{font-size:var(--t-lg);font-weight:800;letter-spacing:-.02em}
.sec-head a{font-size:var(--t-sm);font-weight:700;color:var(--pri)}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:700;
  border-radius:var(--r-2);padding:0 var(--s-5);min-height:48px;transition:transform .12s,box-shadow .2s,background .2s}
.btn:active{transform:translateY(1px)}
.btn-pri{background:var(--pri);color:#fff;box-shadow:var(--sh-pri)}
.btn-pri:hover{background:var(--pri-600)}
.btn-block{width:100%}
.btn-ghost{background:var(--pri-050);color:var(--pri)}
.chip{display:inline-flex;align-items:center;gap:6px;height:34px;padding:0 var(--s-4);border-radius:var(--r-full);
  background:var(--bg-soft);border:1px solid var(--line);font-size:var(--t-sm);font-weight:600;white-space:nowrap}

/* ---- Header (TODO-006) ---- */
.hd{position:sticky;top:0;z-index:var(--z-nav);background:rgba(255,255,255,.92);backdrop-filter:saturate(180%) blur(12px);
  border-bottom:1px solid var(--line-2);height:var(--hh);display:flex;align-items:center}
.hd .wrap{display:flex;align-items:center;gap:var(--s-3);width:100%}
.logo{font-weight:900;font-size:var(--t-md);letter-spacing:-.03em;color:var(--ink)}
.logo b{color:var(--pri)}
.hd-spacer{flex:1}
.hd-ic{width:42px;height:42px;border-radius:var(--r-full);display:grid;place-items:center;font-size:18px;color:var(--ink-2)}
.hd-ic:hover{background:var(--bg-soft)}
.hd-pill{display:inline-flex;align-items:center;gap:6px;height:36px;padding:0 12px;border-radius:var(--r-full);
  border:1px solid var(--line);font-size:var(--t-sm);font-weight:700}

/* ---- Hero + search (TODO-007/008) ---- */
.hero{position:relative;padding:var(--s-7) 0 var(--s-9);
  background:radial-gradient(120% 90% at 80% -10%,#2f6bff 0%,var(--hero-1) 38%,var(--hero-2) 100%);
  color:#fff;border-bottom-left-radius:var(--r-5);border-bottom-right-radius:var(--r-5);overflow:hidden}
.hero::after{content:"";position:absolute;inset:0;background:
  radial-gradient(60% 40% at 15% 20%,rgba(255,255,255,.12),transparent 60%);pointer-events:none}
.hero-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.16);
  padding:6px 12px;border-radius:var(--r-full);font-size:var(--t-xs);font-weight:700;letter-spacing:.02em;margin-bottom:var(--s-4)}
.hero h1{font-size:var(--t-2xl);font-weight:900;line-height:1.12;letter-spacing:-.03em;margin-bottom:var(--s-3)}
.hero p{font-size:var(--t-base);opacity:.92;max-width:30ch}
.search-card{position:relative;margin:calc(-1 * var(--s-8)) var(--s-4) 0;background:#fff;border-radius:var(--r-4);
  box-shadow:var(--sh-3);padding:var(--s-3);z-index:2}
.sfield{display:flex;align-items:center;gap:var(--s-3);padding:var(--s-3) var(--s-4);border:1px solid var(--line);
  border-radius:var(--r-2);margin-bottom:var(--s-2);min-height:56px;width:100%;text-align:left;background:#fff}
.sfield:active{background:var(--bg-soft)}
.sfield .si{width:24px;text-align:center;font-size:18px;color:var(--pri)}
.sfield .sl{font-size:var(--t-xs);color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.sfield .sv{font-size:var(--t-base);font-weight:700;color:var(--ink)}
.sfield .sv.ph{color:var(--muted);font-weight:600}
.sfield-row{display:flex;gap:var(--s-2)}
.sfield-row .sfield{flex:1}

/* ---- Property type (TODO-012) ---- */
.ptype{display:flex;flex-direction:column;align-items:center;gap:8px;width:84px}
.ptype .ic{width:64px;height:64px;border-radius:var(--r-3);display:grid;place-items:center;font-size:26px;
  background:var(--pri-050);border:1px solid var(--pri-100)}
.ptype span{font-size:var(--t-sm);font-weight:700}

/* ---- Cards: deals (TODO-013) ---- */
.dcard{width:240px;background:#fff;border:1px solid var(--line);border-radius:var(--r-3);overflow:hidden;box-shadow:var(--sh-1)}
.dcard .ph{position:relative;height:140px;background:linear-gradient(135deg,#cfe0ff,#a9c4ff);display:grid;place-items:center;font-size:40px;color:#3a63c9}
.badge-deal{position:absolute;top:10px;left:10px;background:var(--accent);color:#fff;font-size:var(--t-xs);font-weight:800;padding:4px 9px;border-radius:var(--r-full)}
.badge-sample{position:absolute;top:10px;left:10px;background:#0c1322;color:#fff;font-size:var(--t-xs);font-weight:800;padding:4px 9px;border-radius:var(--r-full);opacity:.85}
.fav{position:absolute;top:8px;right:8px;width:36px;height:36px;border-radius:var(--r-full);background:rgba(255,255,255,.92);display:grid;place-items:center;font-size:16px;box-shadow:var(--sh-1)}
.dcard .bd{padding:var(--s-3) var(--s-4) var(--s-4)}
.dcard .nm{font-size:var(--t-base);font-weight:800;letter-spacing:-.01em;line-height:1.25;margin-bottom:2px}
.dcard .loc{font-size:var(--t-sm);color:var(--muted);margin-bottom:var(--s-2)}
.rscore{display:inline-flex;align-items:center;gap:6px;font-size:var(--t-sm);font-weight:700}
.rscore b{background:var(--pri);color:#fff;border-radius:6px;padding:2px 7px;font-size:var(--t-xs)}
.dcard .pr{display:flex;align-items:baseline;gap:6px;margin-top:var(--s-3)}
.dcard .pr .now{font-size:var(--t-lg);font-weight:900;color:var(--ink)}
.dcard .pr .old{font-size:var(--t-sm);color:var(--muted);text-decoration:line-through}
.dcard .pr .pn{font-size:var(--t-xs);color:var(--muted)}
.tag-free{display:inline-flex;align-items:center;gap:5px;color:var(--ok);font-size:var(--t-xs);font-weight:700;margin-top:6px}

/* ---- Destination cards (TODO-014) ---- */
.dest{position:relative;width:150px;height:190px;border-radius:var(--r-3);overflow:hidden;display:flex;align-items:flex-end;
  background:linear-gradient(160deg,#274690,#1b2e6b);color:#fff}
.dest .em{position:absolute;top:14px;left:14px;font-size:30px}
.dest .ov{position:absolute;inset:0;background:linear-gradient(transparent 40%,rgba(7,13,32,.78))}
.dest .in{position:relative;padding:var(--s-4);z-index:2}
.dest .ci{font-size:var(--t-md);font-weight:800}
.dest .fr{font-size:var(--t-xs);opacity:.85}

/* ---- Trust strip (TODO-015) ---- */
.trust{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--s-3);padding:0 var(--s-4)}
.trust .it{display:flex;align-items:center;gap:var(--s-3);background:var(--bg-soft);border:1px solid var(--line-2);
  border-radius:var(--r-2);padding:var(--s-3) var(--s-4)}
.trust .it .ic{font-size:22px}
.trust .it b{display:block;font-size:var(--t-sm);font-weight:800}
.trust .it span{font-size:var(--t-xs);color:var(--muted)}

/* ---- Bottom nav (TODO-016) ---- */
.bnav{position:fixed;left:0;right:0;bottom:0;z-index:var(--z-nav);height:calc(var(--bn) + env(safe-area-inset-bottom,0px));
  padding-bottom:env(safe-area-inset-bottom,0px);background:rgba(255,255,255,.96);backdrop-filter:blur(12px);
  border-top:1px solid var(--line-2);display:flex}
.bnav a{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;min-height:var(--bn);
  font-size:var(--t-xs);font-weight:700;color:var(--muted)}
.bnav a .bi{font-size:21px}
.bnav a.on{color:var(--pri)}

/* ---- Bottom sheet (TODO-009/010/011) ---- */
.ovl{position:fixed;inset:0;background:rgba(7,13,32,.5);z-index:var(--z-overlay);opacity:0;visibility:hidden;transition:.25s}
.ovl.open{opacity:1;visibility:visible}
.sheet{position:fixed;left:0;right:0;bottom:0;z-index:var(--z-sheet);background:#fff;border-top-left-radius:var(--r-5);
  border-top-right-radius:var(--r-5);padding:var(--s-3) var(--s-4) calc(var(--s-6) + env(safe-area-inset-bottom,0px));
  transform:translateY(100%);transition:transform .28s cubic-bezier(.22,1,.36,1);max-height:86vh;overflow:auto}
.sheet.open{transform:translateY(0)}
.sheet .grip{width:42px;height:5px;border-radius:99px;background:var(--line);margin:4px auto var(--s-4)}
.sheet h3{font-size:var(--t-md);font-weight:800;margin-bottom:var(--s-4)}
.opt{display:flex;align-items:center;gap:var(--s-3);width:100%;padding:var(--s-4);border-radius:var(--r-2);text-align:left}
.opt:hover,.opt:active{background:var(--bg-soft)}
.opt .ic{font-size:20px}
.stepper{display:flex;align-items:center;justify-content:space-between;padding:var(--s-4) 0;border-bottom:1px solid var(--line-2)}
.stepper b{font-size:var(--t-base)}
.stepper small{display:block;color:var(--muted);font-size:var(--t-xs);font-weight:600}
.stp{display:flex;align-items:center;gap:var(--s-4)}
.stp button{width:40px;height:40px;border-radius:var(--r-full);border:1.5px solid var(--pri);color:var(--pri);font-size:20px;font-weight:700;display:grid;place-items:center}
.stp button:disabled{opacity:.35;border-color:var(--line);color:var(--muted)}
.stp span{min-width:22px;text-align:center;font-weight:800}
.field-in{width:100%;height:52px;border:1px solid var(--line);border-radius:var(--r-2);padding:0 var(--s-4);font-size:var(--t-base);font-weight:600}
.field-in:focus{outline:none;border-color:var(--pri);box-shadow:0 0 0 3px var(--pri-050)}

/* preview banner */
.pv-banner{background:var(--warn-050);color:#7a5200;border:1px dashed #e0b25a;border-radius:var(--r-2);
  padding:var(--s-3) var(--s-4);margin:var(--s-4);font-size:var(--t-sm);font-weight:700;text-align:center}

/* tablet/desktop */
@media(min-width:768px){
  .hero h1{font-size:var(--t-3xl)}
  .search-card{max-width:880px;margin-left:auto;margin-right:auto}
  .sfield-row{flex-wrap:nowrap}
  .search-card .grid4{display:flex;gap:var(--s-2)}
  .search-card .grid4>*{flex:1;margin-bottom:0}
  .trust{grid-template-columns:repeat(4,1fr)}
  .bnav{display:none}
  body{padding-bottom:0}
}
@media(min-width:1024px){ .hero h1{font-size:42px} }
