/* ============================================================
   מסע ביתר · מערכת עיצוב v4
   בהיר · אוורירי · פרימיום · זהב ביתר · RTL · מובייל + דסקטוף
   ============================================================ */
:root{
  --bg:#f2efe8; --bg-2:#ece8df;
  --surface:#ffffff; --surface-2:#faf8f3; --surface-3:#f4f1ea;
  --ink:#161519; --body:#2c2a32; --muted:#504c57; --faint:#6a6671;
  --line:#e6e1d7; --line-2:#d6d0c4;
  --gold:#bd8a1c; --gold-2:#a9791a; --gold-ink:#876310; --gold-bright:#e8b53f;
  --gold-grad:linear-gradient(180deg,#f0c95c,#d9a52e);
  --gold-soft:#f8efd6;
  --charcoal:#211f26;
  --good:#2f9e6a; --good-bg:#e6f5ec;
  --warn:#a9791a; --warn-bg:#f8eed3;
  --bad:#cf5246;  --bad-bg:#fbe7e3;
  --r:22px; --r-lg:26px; --r-sm:14px; --r-xs:11px;
  --sh:0 2px 10px rgba(28,24,20,.05),0 10px 30px rgba(28,24,20,.06);
  --sh-sm:0 1px 4px rgba(28,24,20,.05),0 4px 14px rgba(28,24,20,.05);
  --sh-lg:0 20px 50px rgba(28,24,20,.13);
  --font:"Heebo","Assistant",-apple-system,"Segoe UI","Noto Sans Hebrew",system-ui,sans-serif;
  --maxw:1200px;
}
*{box-sizing:border-box;}
html{margin:0;padding:0;overflow-x:hidden;}
body{margin:0;padding:0;overflow-x:clip;}
body{background:var(--bg);color:var(--body);font-family:var(--font);font-size:16.5px;line-height:1.55;
  -webkit-font-smoothing:antialiased;min-height:100vh;}
body::before{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:radial-gradient(90% 60% at 85% -5%, rgba(232,181,63,.10), transparent 55%),
             radial-gradient(80% 50% at 0% 100%, rgba(189,138,28,.05), transparent 60%);}
a{color:inherit;text-decoration:none;}
.tnum{font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1,"lnum" 1;}
.muted{color:var(--muted);} .faint{color:var(--faint);} .sm{font-size:13.5px;}
.center{text-align:center;}
/* מונע מילה בודדת יתומה בסוף פסקה */
p,.hub-sub,.page-sub,.note,.gate-sub,.id-head p,.hero-match,.hub-title,.flight-with,.stay-area,.peek,.cc-match{text-wrap:pretty;}
.vs{font-size:.66em;color:var(--faint);font-weight:600;margin:0 5px;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px;}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;font:inherit;font-weight:700;font-size:15px;
  border-radius:999px;padding:13px 22px;cursor:pointer;border:1px solid transparent;transition:transform .08s,box-shadow .15s,background .15s;}
.btn:active{transform:scale(.98);}
.btn.sm{padding:9px 16px;font-size:13.5px;}
.btn.block{width:100%;}
.btn.gold{background:var(--gold-grad);color:#3a2a04;box-shadow:0 6px 16px rgba(217,165,46,.32);}
.btn.gold:hover{box-shadow:0 8px 22px rgba(217,165,46,.42);}
.btn.glass{background:rgba(255,255,255,.7);border-color:var(--line-2);color:var(--ink);
  -webkit-backdrop-filter:saturate(160%) blur(12px);backdrop-filter:saturate(160%) blur(12px);}
.btn.ghost{background:var(--surface);border-color:var(--line-2);color:var(--ink);}
.btn.ghost:hover{background:var(--surface-2);}

/* ---------- chips ---------- */
.chip{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:700;padding:5px 12px;border-radius:999px;white-space:nowrap;}
.chip::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;}
.chip.good{background:var(--good-bg);color:var(--good);}
.chip.warn{background:var(--warn-bg);color:var(--warn);}
.chip.bad{background:var(--bad-bg);color:var(--bad);}
.chip.neutral{background:var(--surface-3);color:var(--muted);}
.chip.neutral::before{display:none;}

/* ---------- avatars ---------- */
.ava{width:40px;height:40px;border-radius:50%;background:var(--charcoal);color:#fff;font-weight:800;font-size:16px;
  display:flex;align-items:center;justify-content:center;border:2px solid var(--surface);box-shadow:var(--sh-sm);flex:0 0 auto;
  background-size:cover;background-position:center;overflow:hidden;}
.ava.hasphoto{cursor:pointer;}
.ava.hasphoto:active{transform:scale(.95);}
.ava.sm{width:32px;height:32px;font-size:13px;}
.ava.me{box-shadow:0 0 0 2px var(--gold-bright);}
.ava.more{background:var(--surface-3);color:var(--muted);}
.avastack{display:flex;}
.avastack .ava{margin-inline-start:-11px;border:2px solid var(--surface);}
.avastack .ava:first-child{margin-inline-start:0;}
.avarow{display:flex;flex-wrap:wrap;gap:14px;}

.crest{display:inline-block;line-height:0;}
.glass{background:var(--surface);border:1px solid var(--line);box-shadow:var(--sh);}

/* ============================================================
   LOGIN
   ============================================================ */
.gate-body{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;
  background:linear-gradient(160deg,#26242c,#15141a);}
.gate{width:100%;max-width:380px;text-align:center;padding:40px 28px;border-radius:28px;background:var(--surface);box-shadow:var(--sh-lg);}
.gate .crest{margin-bottom:16px;}
.gate h1{font-size:27px;font-weight:800;letter-spacing:-.02em;color:var(--ink);margin:0 0 5px;}
.gate-sub{color:var(--muted);font-size:14.5px;margin:0 0 24px;}
.gate-input{width:100%;padding:15px;border-radius:14px;border:1.5px solid var(--line-2);background:var(--surface-2);
  color:var(--ink);font-size:16px;text-align:center;margin-bottom:13px;font-family:inherit;}
.gate-input::placeholder{color:var(--faint);}
.gate-err{background:var(--bad-bg);color:var(--bad);font-size:13.5px;font-weight:600;padding:11px;border-radius:12px;margin-bottom:14px;}
.gate-hint{color:var(--faint);font-size:12.5px;margin:20px 0 0;}

/* ============================================================
   IDENTITY
   ============================================================ */
.id-head{padding:34px 0 20px;text-align:center;}
.id-head .crest{margin-bottom:12px;}
.id-head h1{font-size:32px;font-weight:800;letter-spacing:-.02em;color:var(--ink);margin:0 0 7px;}
.id-head p{color:var(--muted);font-size:16px;margin:0 auto;max-width:34ch;}
.idgrid{display:grid;grid-template-columns:1fr 1fr;gap:14px;align-items:stretch;padding-bottom:30px;}
.idf{margin:0;display:flex;}
.idtile{flex:1;width:100%;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:10px;
  padding:24px 12px;cursor:pointer;border-radius:var(--r);background:var(--surface);border:1.5px solid var(--line);
  box-shadow:var(--sh-sm);color:var(--ink);transition:border-color .15s,box-shadow .15s,transform .08s;}
.idtile:hover{box-shadow:var(--sh);transform:translateY(-2px);}
.idtile.cur{border-color:var(--gold-bright);box-shadow:0 0 0 1px var(--gold-bright),var(--sh);}
.idtile .ava{width:58px;height:58px;font-size:23px;}
.idname{font-weight:800;font-size:18px;}
.idtile .chip{margin-top:auto;}

/* ============================================================
   HUB
   ============================================================ */
.topbar{display:flex;align-items:center;justify-content:space-between;padding:24px 0 16px;}
.greet{display:flex;flex-direction:column;line-height:1.1;}
.greet .hi{color:var(--muted);font-size:15px;font-weight:600;}
.greet .name{font-size:25px;font-weight:800;letter-spacing:-.01em;color:var(--ink);}
.id-chip{display:inline-flex;align-items:center;gap:9px;padding:6px 15px 6px 6px;border-radius:999px;font-size:14px;font-weight:700;color:var(--ink);
  background:var(--surface);border:1px solid var(--line);box-shadow:var(--sh-sm);}
.id-chip .ava{width:32px;height:32px;font-size:13px;}
.id-chip .swap{color:var(--gold);font-size:16px;font-weight:700;}

.hub-title{font-size:34px;font-weight:800;letter-spacing:-.025em;line-height:1.08;color:var(--ink);margin:10px 0 6px;}
.hub-title .accent{color:var(--gold-ink);}
.hub-sub{color:var(--muted);font-size:16px;margin:0 0 24px;max-width:40ch;}

.citycards{display:grid;gap:18px;}
.citycard{position:relative;min-height:230px;border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end;
  padding:20px;color:#fff;background-size:cover;background-position:center;box-shadow:var(--sh);isolation:isolate;
  transition:transform .12s,box-shadow .2s;}
.citycard:hover{transform:translateY(-3px);box-shadow:var(--sh-lg);}
.citycard::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(165deg,rgba(12,12,18,.06) 0%,rgba(12,12,18,.45) 48%,rgba(10,10,16,.9) 100%);}
.citycard.dim{filter:saturate(.55) brightness(.7);}
.cc-top{position:absolute;top:18px;right:18px;left:18px;display:flex;justify-content:space-between;align-items:flex-start;}
.cc-country{font-size:13.5px;font-weight:700;color:rgba(255,255,255,.9);text-shadow:0 1px 8px rgba(0,0,0,.5);}
.cc-badge{font-size:12px;font-weight:800;padding:6px 13px;border-radius:999px;}
.cc-badge.in{background:var(--gold-bright);color:#3a2a04;}
.cc-badge.out{background:rgba(255,255,255,.2);color:#fff;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.28);}
.cc-name{font-size:38px;font-weight:800;letter-spacing:-.025em;line-height:1;margin:0;text-shadow:0 2px 16px rgba(0,0,0,.55);}
.cc-match{font-size:14.5px;color:rgba(255,255,255,.92);margin-top:7px;text-shadow:0 1px 8px rgba(0,0,0,.55);}
.cc-foot{display:flex;align-items:center;justify-content:space-between;margin-top:18px;}
.cdown{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:700;padding:7px 14px;border-radius:999px;
  background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.24);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);}
.cdown b{color:var(--gold-bright);font-size:15px;}
.cc-go{display:flex;align-items:center;gap:10px;}
.cc-cnt{font-size:13px;color:rgba(255,255,255,.88);font-weight:600;}

.hub-facts{border-radius:var(--r);padding:22px;margin-top:22px;}
.hub-facts h3{font-size:14px;font-weight:800;color:var(--gold-ink);letter-spacing:.03em;margin:0 0 12px;}
.hub-facts ul{margin:0;padding-inline-start:20px;font-size:14.5px;color:var(--body);}
.hub-facts li{margin-bottom:8px;}
.hub-foot{display:flex;gap:11px;justify-content:center;margin:22px 0 36px;}

/* ============================================================
   CITY (world) — hero + sheet + grid
   ============================================================ */
.hero{position:relative;color:#fff;background-size:cover;background-position:center;overflow:hidden;padding:calc(20px + env(safe-area-inset-top)) 0 60px;}
.hero::after{content:"";position:absolute;inset:0;z-index:0;
  background:linear-gradient(180deg,rgba(10,10,16,.5) 0%,rgba(10,10,16,.32) 36%,rgba(10,10,16,.78) 100%);}
.hero-in{position:relative;z-index:1;max-width:var(--maxw);margin:0 auto;padding:0 20px;}
.hero-top{display:flex;align-items:center;justify-content:space-between;}
.hero-back{font-size:16px;font-weight:700;color:#fff;display:inline-flex;align-items:center;gap:5px;padding:9px 16px;border-radius:999px;
  background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.26);-webkit-backdrop-filter:saturate(150%) blur(12px);backdrop-filter:saturate(150%) blur(12px);}
.hero .id-chip{background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.26);color:#fff;
  -webkit-backdrop-filter:saturate(150%) blur(14px);backdrop-filter:saturate(150%) blur(14px);box-shadow:none;}
.hero .id-chip .ava{box-shadow:0 0 0 2px rgba(255,255,255,.4);}
.hero .id-chip .swap{color:var(--gold-bright);}
.hero-eyebrow{font-size:13px;font-weight:700;color:var(--gold-bright);letter-spacing:.02em;margin-top:26px;text-shadow:0 1px 6px rgba(0,0,0,.4);}
.hero-city{font-size:44px;font-weight:800;letter-spacing:-.03em;line-height:1;margin:8px 0 0;text-shadow:0 2px 18px rgba(0,0,0,.5);}
.hero-match{font-size:16px;color:rgba(255,255,255,.92);margin-top:10px;text-shadow:0 1px 8px rgba(0,0,0,.5);}
.hero-meta{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px;}
.hero-pill{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:700;padding:8px 15px;border-radius:999px;
  background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.24);
  -webkit-backdrop-filter:saturate(150%) blur(12px);backdrop-filter:saturate(150%) blur(12px);}
.hero-pill.cd b{color:var(--gold-bright);}

.sheet{position:relative;z-index:2;margin-top:-40px;background:var(--bg);border-radius:26px 26px 0 0;
  padding-top:14px;min-height:60vh;box-shadow:0 -10px 30px rgba(28,24,20,.06);}
.sheet::before{content:"";display:block;width:44px;height:5px;border-radius:3px;background:var(--line-2);margin:0 auto 16px;}

.appgrid{max-width:var(--maxw);margin:0 auto;padding:6px 20px calc(120px + env(safe-area-inset-bottom));}
.content{min-width:0;}

.page-h1{font-size:27px;font-weight:800;letter-spacing:-.01em;color:var(--ink);margin:6px 0 4px;}
.page-sub{color:var(--muted);font-size:16px;margin:0 0 18px;}

.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:20px;margin-bottom:16px;box-shadow:var(--sh-sm);}
.card .ttl{font-size:16.5px;font-weight:800;color:var(--ink);margin:0 0 14px;}
.note{font-size:15px;color:var(--muted);line-height:1.6;}
.dash-cols,.docs-cols,.pred-cols,.flights-grid,.gen-grid{display:grid;gap:16px;}
.pred-cols{max-width:680px;margin-inline:auto;}

/* dashboard */
.dash-eyebrow{font-size:13.5px;font-weight:800;color:var(--gold-ink);letter-spacing:.04em;margin:2px 0 14px;}
.predcard{display:block;}
.pc-head{display:flex;justify-content:space-between;align-items:center;}
.pc-k{font-size:13px;font-weight:700;color:var(--muted);}
.pc-score{font-size:28px;font-weight:800;letter-spacing:-.01em;color:var(--ink);margin-top:10px;}
.statgrid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:16px;}
.stat{padding:18px;border-radius:var(--r);background:var(--surface);border:1px solid var(--line);box-shadow:var(--sh-sm);
  display:flex;flex-direction:column;gap:12px;}
.stat-k{font-size:13px;font-weight:700;color:var(--muted);}
.stat-main{display:flex;align-items:center;gap:13px;}
.stat-v{font-size:17px;font-weight:800;color:var(--ink);}
.ring{--p:0;--c:var(--gold);position:relative;width:56px;height:56px;border-radius:50%;flex:0 0 auto;
  background:conic-gradient(var(--c) calc(var(--p)*1%),var(--surface-3) 0);display:flex;align-items:center;justify-content:center;}
.ring::after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:42px;height:42px;border-radius:50%;background:var(--surface);}
.ring span{position:relative;z-index:1;font-size:13.5px;font-weight:800;color:var(--ink);}

/* flights / boarding pass */
.flight{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:18px 20px;margin-bottom:14px;box-shadow:var(--sh-sm);position:relative;}
.flight.mine{border-color:var(--gold-bright);box-shadow:0 0 0 1px var(--gold-bright),var(--sh-sm);}
.flight-top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:16px;flex-wrap:wrap;}
.leg-tag{font-size:14px;font-weight:800;padding:6px 14px;border-radius:999px;}
.leg-tag.out{background:var(--gold-soft);color:var(--gold-ink);}
.leg-tag.back{background:#e9edf4;color:#3a4763;}
.bp{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;direction:ltr;}
.bp-end{text-align:center;}
.bp-code{font-size:32px;font-weight:800;letter-spacing:-.02em;line-height:1;color:var(--ink);}
.bp-time{font-size:15.5px;font-weight:700;color:var(--body);margin-top:6px;}
.bp-mid{position:relative;display:flex;flex-direction:column;align-items:center;min-width:92px;}
.bp-mid::before{content:"";position:absolute;top:9px;left:0;right:0;border-top:2px dashed var(--line-2);}
.bp-plane{color:var(--gold);background:var(--surface);padding:0 7px;position:relative;z-index:1;}
.bp-date{font-size:12.5px;color:var(--muted);font-weight:600;margin-top:9px;white-space:nowrap;}
.flight-route{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:13px;}
.fr-city{flex:1;text-align:center;}
.fr-city b{display:block;font-size:21px;font-weight:800;color:var(--ink);line-height:1.12;letter-spacing:-.01em;}
.fr-city span{font-size:12.5px;color:var(--muted);font-weight:700;letter-spacing:.04em;}
.fr-arrow{flex:0 0 auto;display:flex;align-items:center;}
.fr-arrow .bp-plane{width:28px;height:28px;background:none;padding:0;color:var(--gold);transform:scaleX(-1);}
.flight-when{display:flex;flex-wrap:wrap;gap:10px;align-items:center;padding-top:13px;border-top:1px solid var(--line);font-size:14px;}
.fw-date{font-weight:800;color:var(--ink);}
.fw-time{color:var(--body);font-weight:600;}
.fw-time.tbd{color:var(--muted);}
.flight-meta{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-top:11px;}
.flight-leg{font-size:13px;color:var(--muted);font-weight:600;}
.flight-air{font-size:13px;color:var(--muted);font-weight:600;}
.flight-price{font-size:14px;font-weight:800;color:var(--ink);margin-inline-start:auto;}
.flight-with{font-size:13.5px;color:var(--body);font-weight:600;margin-top:11px;}

/* listings */
.stays{display:grid;gap:18px;}
.stay{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--sh-sm);transition:transform .12s,box-shadow .2s;}
.stay:hover{transform:translateY(-3px);box-shadow:var(--sh);}
.stay.mine{border-color:var(--gold-bright);box-shadow:0 0 0 1px var(--gold-bright),var(--sh-sm);}
.stay-img{aspect-ratio:16/10;background-size:cover;background-position:center;position:relative;}
.stay-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.06),transparent 30%,transparent 60%,rgba(0,0,0,.4));}
.stay-plat{position:absolute;top:13px;right:13px;z-index:1;font-size:11.5px;font-weight:800;padding:5px 11px;border-radius:999px;
  background:rgba(255,255,255,.92);color:var(--ink);}
.stay-rate{position:absolute;bottom:13px;right:13px;z-index:1;display:flex;align-items:center;gap:5px;font-size:14px;font-weight:800;color:#fff;text-shadow:0 1px 6px rgba(0,0,0,.6);}
.stay-rate .star{color:var(--gold-bright);}
.stay-mine{position:absolute;bottom:13px;left:13px;z-index:1;font-size:11.5px;font-weight:800;padding:5px 12px;border-radius:999px;background:var(--gold-bright);color:#3a2a04;}
.stay-body{padding:18px;}
.stay-h{display:flex;justify-content:space-between;align-items:flex-start;gap:11px;}
.stay-name{font-size:17px;font-weight:800;color:var(--ink);margin:0;letter-spacing:-.01em;}
.stay-price{text-align:left;white-space:nowrap;}
.stay-price b{font-size:21px;font-weight:800;color:var(--ink);}
.stay-price small{display:block;font-size:11.5px;color:var(--muted);}
.stay-area{font-size:13px;color:var(--muted);margin-top:4px;}
.stay-perks{display:flex;flex-wrap:wrap;gap:7px;margin-top:13px;}
.perk{font-size:12px;background:var(--surface-3);padding:5px 11px;border-radius:999px;color:var(--body);}
.stay-actions{display:flex;align-items:center;gap:11px;margin-top:16px;}
.stay-tally{margin-inline-start:auto;display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted);font-weight:600;}
.stay-tally .bar{width:54px;height:7px;border-radius:999px;background:var(--surface-3);overflow:hidden;}
.stay-tally .bar>span{display:block;height:100%;background:var(--gold-grad);}
.stay-voters{display:flex;flex-wrap:wrap;gap:6px;margin-top:11px;}
.mini{font-size:11.5px;font-weight:700;padding:3px 10px;border-radius:999px;background:color-mix(in srgb,var(--c) 16%,#fff);color:color-mix(in srgb,var(--c) 70%,#000);border:1px solid color-mix(in srgb,var(--c) 26%,#fff);}
.mini.meX{background:var(--gold-soft);color:var(--gold-ink);border-color:color-mix(in srgb,var(--gold) 30%,#fff);}
/* lodging v2 */
.stay.leader{border-color:color-mix(in srgb,var(--gold) 45%,#fff);}
.stay-lead{position:absolute;bottom:13px;left:13px;z-index:1;font-size:11.5px;font-weight:800;padding:5px 12px;border-radius:999px;background:rgba(255,255,255,.92);color:var(--gold-ink);}
.stay-facts{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-top:13px;padding:13px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);text-align:center;}
.fact b{display:block;font-size:17px;font-weight:800;color:var(--ink);font-variant-numeric:tabular-nums;}
.fact span{font-size:11.5px;color:var(--muted);}
.stay-split{font-size:13.5px;font-weight:800;color:var(--gold-ink);margin-top:12px;}
.stay-link{font-size:13px;color:var(--muted);font-weight:700;margin-inline-start:auto;}
.vote-btn{min-width:130px;}
.stay-tally{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--muted);font-weight:600;margin-top:13px;}
.stay-tally .bar{flex:1;height:8px;border-radius:999px;background:var(--surface-3);overflow:hidden;}
.stay-tally .bar>span{display:block;height:100%;background:var(--gold-grad);}
.lead-banner{background:var(--gold-soft);border:1px solid color-mix(in srgb,var(--gold) 26%,#fff);border-radius:var(--r);padding:18px 20px;margin-bottom:16px;}
.lead-k{font-size:12.5px;font-weight:800;color:var(--gold-ink);letter-spacing:.03em;}
.lead-name{font-size:21px;font-weight:800;color:var(--ink);margin-top:4px;letter-spacing:-.01em;}
.lead-cost{font-size:14px;color:var(--body);font-weight:700;margin-top:6px;font-variant-numeric:tabular-nums;}
.lead-miss{font-size:13.5px;color:var(--muted);margin-top:9px;}
.vote-confirm{background:var(--good-bg);color:var(--good);font-size:13.5px;font-weight:700;padding:12px 16px;border-radius:14px;margin-bottom:16px;}

/* docs */
.readybanner{display:flex;align-items:center;gap:14px;padding:17px 19px;border-radius:var(--r);margin-bottom:16px;background:var(--surface);border:1px solid var(--line);box-shadow:var(--sh-sm);}
.rb-txt{font-size:15px;font-weight:800;color:var(--ink);}
.rb-sub{font-size:12.5px;color:var(--bad);font-weight:700;margin-top:2px;}
.pcard{padding:18px 20px;border-radius:var(--r);margin-bottom:0;background:var(--surface);border:1px solid var(--line);box-shadow:var(--sh-sm);}
.pcard.me{border-color:var(--gold-bright);}
.pc-top{display:flex;align-items:center;gap:14px;margin-bottom:14px;}
.pc-id{min-width:0;}
.pc-id b{font-size:16.5px;font-weight:800;color:var(--ink);display:block;}
.pc-ratio{font-size:12.5px;color:var(--muted);font-weight:700;}
.pc-ring{margin-inline-start:auto;}
.slot{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 0;border-top:1px solid var(--line);}
.slot:first-of-type{border-top:none;}
.slot-l{min-width:0;}
.slot-name{font-size:14.5px;font-weight:700;color:var(--ink);}
.slot-hint{font-size:12.5px;color:var(--muted);}
.slot-file{font-size:13px;color:var(--gold-ink);font-weight:700;display:inline-block;max-width:190px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;vertical-align:bottom;}
.slot-r{display:flex;align-items:center;gap:10px;flex:0 0 auto;}
.slot-by{font-size:11.5px;color:var(--faint);}
.up{margin:0;}
.up-btn{display:inline-flex;align-items:center;font-size:12.5px;font-weight:800;color:var(--gold);background:var(--gold-soft);
  border:1px solid color-mix(in srgb,var(--gold) 30%,#fff);border-radius:999px;padding:7px 14px;cursor:pointer;}
.up-btn:hover{background:#f3e6c2;}
.up-btn input{display:none;}
.x{background:none;border:none;color:var(--bad);font-size:12px;font-weight:700;cursor:pointer;}
.genup{display:flex;flex-direction:column;gap:13px;margin-top:18px;}
.genup-title{width:100%;padding:13px 14px;border-radius:12px;border:1px solid var(--line-2);background:var(--surface-2);color:var(--ink);font-family:inherit;font-size:14px;}
.genup-actions{display:flex;gap:10px;justify-content:flex-start;}
.genup-title::placeholder{color:var(--faint);}

/* predictions */
.predform{text-align:center;}
.pred-preview{font-size:32px;font-weight:800;color:var(--ink);letter-spacing:-.01em;}
.pred-outcome{display:inline-block;font-size:13px;font-weight:800;padding:5px 13px;border-radius:999px;margin:10px 0 18px;}
.pred-outcome.win{background:var(--good-bg);color:var(--good);}
.pred-outcome.lose{background:var(--bad-bg);color:var(--bad);}
.pred-outcome.draw{background:var(--surface-3);color:var(--muted);}
.pf-row{display:flex;align-items:flex-start;justify-content:center;gap:22px;margin-bottom:18px;}
.pf-side{display:flex;flex-direction:column;align-items:center;gap:10px;}
.pf-team{font-size:15px;font-weight:800;color:var(--ink);}
.pf-x{font-size:30px;font-weight:800;color:var(--faint);padding-top:36px;}
.stepper{display:flex;flex-direction:column;align-items:center;gap:8px;}
.step{width:50px;height:44px;border-radius:14px;border:1px solid var(--line-2);background:var(--gold-soft);color:var(--gold-ink);font-size:24px;font-weight:800;cursor:pointer;line-height:1;}
.step:active{background:#f0e2bc;}
.step-num{width:78px;height:70px;text-align:center;font-size:40px;font-weight:800;border-radius:16px;border:1.5px solid var(--line-2);
  background:var(--surface-2);color:var(--ink);font-family:inherit;font-variant-numeric:tabular-nums;-moz-appearance:textfield;}
.step-num::-webkit-outer-spin-button,.step-num::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}
.quick-label{font-size:13px;font-weight:700;color:var(--muted);margin-bottom:9px;}
.quick-picks{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin-bottom:18px;}
.quick{background:var(--gold-soft);color:var(--gold-ink);border:1px solid color-mix(in srgb,var(--gold) 26%,#fff);border-radius:999px;padding:8px 15px;font-size:14px;font-weight:800;cursor:pointer;font-family:inherit;font-variant-numeric:tabular-nums;}
.quick:active{background:#f0e2bc;}
.lock-note{font-size:13px;color:var(--muted);margin-top:12px;}
.consensus-lead{font-size:19px;font-weight:800;color:var(--ink);margin-bottom:6px;}
.consensus-pop{font-size:13.5px;color:var(--gold-ink);font-weight:700;background:var(--gold-soft);border-radius:12px;padding:9px 13px;display:inline-block;margin-bottom:8px;}
.pgroup{margin-top:18px;}
.pg-title{display:flex;align-items:center;gap:9px;margin-bottom:11px;}
.pg-cnt{font-size:13px;font-weight:800;color:var(--muted);}
.pg-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(158px,1fr));gap:11px;}
.pgcard{background:var(--surface-2);border:1px solid var(--line);border-radius:16px;padding:14px;}
.pgcard.me{border-color:var(--gold-bright);box-shadow:0 0 0 1px var(--gold-bright);}
.pgc-top{display:flex;align-items:center;gap:8px;font-size:14.5px;color:var(--ink);margin-bottom:7px;}
.cdot{width:11px;height:11px;border-radius:50%;flex:0 0 auto;}
.bold-tag{font-size:11px;font-weight:800;color:var(--gold-ink);background:var(--gold-soft);padding:2px 8px;border-radius:999px;}
.me-tag{font-size:11px;font-weight:800;color:var(--gold-ink);}
.pgc-score{font-size:20px;font-weight:800;color:var(--ink);white-space:nowrap;}
.pg-names{display:flex;flex-wrap:wrap;gap:6px;}
.oc{font-size:12px;font-weight:800;padding:4px 11px;border-radius:999px;}
.oc.win{background:var(--good-bg);color:var(--good);}
.oc.lose{background:var(--bad-bg);color:var(--bad);}
.oc.draw{background:var(--surface-3);color:var(--muted);}
.peek{padding:14px 18px;border-radius:var(--r);background:var(--surface);border:1px dashed var(--line-2);font-size:14px;color:var(--muted);text-align:center;margin-bottom:16px;}

/* ============================================================
   FLOATING NAV (mobile)
   ============================================================ */
.navpill{position:fixed;bottom:calc(14px + env(safe-area-inset-bottom));left:50%;transform:translateX(-50%);width:calc(100% - 20px);max-width:600px;z-index:40;display:flex;justify-content:space-around;gap:1px;padding:7px 5px;border-radius:24px;
  background:rgba(255,255,255,.92);border:1px solid var(--line);-webkit-backdrop-filter:saturate(160%) blur(18px);backdrop-filter:saturate(160%) blur(18px);
  box-shadow:0 10px 30px rgba(28,24,20,.18);}
.nav-i{display:flex;flex:1;flex-direction:column;align-items:center;gap:3px;padding:8px 2px;border-radius:16px;color:var(--body);font-size:10px;font-weight:700;min-width:0;white-space:nowrap;letter-spacing:-.02em;}
.nav-i svg{width:21px;height:21px;}
.nav-i.on{background:var(--gold-grad);color:#3a2a04;}

/* ============================================================
   DESKTOP
   ============================================================ */
@media (min-width:760px){
  .citycards{grid-template-columns:1fr 1fr;}
  .idgrid{grid-template-columns:repeat(3,1fr);}
  .stays{grid-template-columns:1fr 1fr;}
}
@media (min-width:1000px){
  body{font-size:17px;}
  .hero{padding-bottom:74px;}
  .hero-city{font-size:60px;}
  .hero-eyebrow{font-size:14px;margin-top:30px;}
  .hero-match{font-size:18px;}
  .page-h1{font-size:32px;}
  .page-sub{font-size:16.5px;}
  .hub-title{font-size:44px;}
  .hub-sub{font-size:18px;}

  /* content + right sidebar nav, fills the canvas */
  .appgrid{display:grid;grid-template-columns:240px 1fr;gap:34px;padding-bottom:48px;align-items:start;}
  .navpill{grid-column:1;grid-row:1;position:sticky;top:26px;transform:none;left:auto;right:auto;width:auto;max-width:none;bottom:auto;flex-direction:column;justify-content:flex-start;gap:5px;padding:13px;
    border-radius:22px;background:var(--surface);border:1px solid var(--line);box-shadow:var(--sh);backdrop-filter:none;-webkit-backdrop-filter:none;align-self:start;}
  .content{grid-column:2;grid-row:1;}
  .nav-i{flex:none;flex-direction:row;justify-content:flex-start;gap:13px;min-width:0;width:100%;padding:13px 16px;font-size:16px;font-weight:700;color:var(--ink);border-radius:14px;}
  .nav-i svg{width:23px;height:23px;}
  .nav-i.on{background:var(--gold-soft);color:var(--gold-ink);font-weight:800;}

  /* two-column page bodies fill the width */
  .shab-cols{display:grid;grid-template-columns:1fr 1fr;gap:18px 20px;align-items:start;}
  .shab-cols>.page-h1,.shab-cols>.page-sub,.shab-cols>.shab-times{grid-column:1 / -1;}
  .shab-cols>.card{margin-bottom:0;}
  .pred-cols{max-width:none;margin-inline:0;grid-template-columns:360px 1fr;gap:22px;align-items:start;}
  .pred-cols>.page-h1,.pred-cols>.page-sub{grid-column:1 / -1;margin-bottom:0;}
  .pred-cols>.page-sub{margin-bottom:6px;}
  .dash-cols{display:grid;grid-template-columns:1.25fr 1fr;gap:18px;align-items:start;}
  .docs-cols{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:stretch;}
  .gen-grid{grid-template-columns:1fr 1fr;align-items:stretch;}
  .flights-grid{grid-template-columns:1fr 1fr;}
  .stays{grid-template-columns:1fr 1fr 1fr;}
  .statgrid{grid-template-columns:1fr 1fr;}
}
@media (min-width:1280px){
  .hero-city{font-size:68px;}
  .stays{grid-template-columns:1fr 1fr 1fr;}
}

/* ============================================================
   MOTION · עדין ופרימיום · transform/opacity בלבד
   ============================================================ */
:root{--ease-settle:cubic-bezier(.16,1,.3,1);--ease-snap:cubic-bezier(.4,0,.2,1);}

/* תמונת ה-hero נושמת לאט (ken-burns, פעם אחת ונחה) */
.hero::before{content:"";position:absolute;inset:0;z-index:0;background-image:var(--hero);background-size:cover;background-position:center;
  filter:brightness(.92) saturate(.95);transform-origin:center;animation:kenburns 34s var(--ease-snap) both;}
.hero::after{z-index:1;}
.hero-in{z-index:2;}
@keyframes kenburns{from{transform:scale(1.02)}to{transform:scale(1.09) translate3d(-1.4%,-1%,0)}}

@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes popIn{0%{opacity:0;transform:scale(.92)}60%{opacity:1;transform:scale(1.02)}100%{opacity:1;transform:scale(1)}}

/* כניסות עמוד */
.hero-eyebrow{animation:fadeUp .7s var(--ease-settle) .08s both;}
.hero-city{animation:fadeUp .8s var(--ease-settle) .16s both;}
.hero-match{animation:fadeUp .8s var(--ease-settle) .24s both;}
.hero-meta{animation:fadeUp .8s var(--ease-settle) .32s both;}
.sheet{animation:fadeIn .7s var(--ease-settle) .12s both;}
.topbar{animation:fadeUp .7s var(--ease-settle) both;}
.hub-title{animation:fadeUp .7s var(--ease-settle) .06s both;}
.hub-sub{animation:fadeUp .7s var(--ease-settle) .12s both;}
.id-head{animation:fadeUp .7s var(--ease-settle) both;}

/* חשיפת כרטיסים עם stagger קל */
.card,.flight,.stay,.stat,.pcard,.pgcard,.citycard,.idtile,.lead-banner,.vote-confirm,.readybanner,.peek{animation:fadeUp .55s var(--ease-settle) both;}
.citycards>.citycard:nth-child(2){animation-delay:.1s;}
.stays>.stay:nth-child(2){animation-delay:.09s;}
.stays>.stay:nth-child(3){animation-delay:.18s;}
.idgrid>.idf:nth-child(2) .idtile{animation-delay:.05s;}
.idgrid>.idf:nth-child(3) .idtile{animation-delay:.1s;}
.idgrid>.idf:nth-child(4) .idtile{animation-delay:.15s;}
.idgrid>.idf:nth-child(5) .idtile{animation-delay:.2s;}
.idgrid>.idf:nth-child(6) .idtile{animation-delay:.25s;}

/* ספירה לאחור · פופ עדין בטעינה */
.hero-pill.cd{animation:popIn .7s var(--ease-settle) .42s both;}
.cdown{animation:popIn .7s var(--ease-settle) .3s both;}

/* משוב מגע */
.btn,.nav-i,.quick,.step,.up-btn,.idtile,.stay,.citycard,.flight{transition:transform .14s var(--ease-snap),box-shadow .2s var(--ease-snap),filter .2s var(--ease-snap);}
.btn:active,.quick:active,.up-btn:active{transform:scale(.97);}
.step:active{transform:scale(.9);}
.nav-i:active{transform:scale(.94);}
@media (hover:hover) and (pointer:fine){
  .btn.gold:hover{transform:translateY(-2px);filter:brightness(1.03);}
  .btn.ghost:hover{transform:translateY(-2px);}
  .citycard:hover,.stay:hover,.idtile:hover{transform:translateY(-3px);}
}

/* אישור בחירה · פופ */
.stay.mine .stay-mine{animation:popIn .42s var(--ease-settle) both;}

/* פוקוס מקלדת */
:where(.btn,.nav-i,.quick,.step,.up-btn,.idtile,.vote-btn,.stay-link,.hero-back,.id-chip):focus-visible{outline:none;box-shadow:0 0 0 3px rgba(232,181,63,.55);}

/* כיבוד העדפת תנועה מופחתת */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;}
  .hero::before{animation:none!important;transform:none!important;}
}

/* ============================================================
   PWA / MOBILE POLISH
   ============================================================ */
html{overscroll-behavior-y:none;}
*{-webkit-tap-highlight-color:transparent;}
.navpill,.nav-i,.btn,.chip,.hero-back,.id-chip,.step,.quick,.up-btn,.leg-tag,.cc-badge,.hero-pill,.cdown,.idtile,.vote-btn,.cbar,.tab{
  -webkit-user-select:none;user-select:none;-webkit-touch-callout:none;}
.gate-body{background:#15141a;background:linear-gradient(160deg,#26242c,#15141a);}
.citycard:active,.stay:active{transform:scale(.985);transition-duration:.09s;}
.cdown b,.hero-pill.cd b{font-variant-numeric:tabular-nums;}
/* כותרת-עיר מכווצת שמופיעה בגלילה */
.cbar{position:fixed;top:0;left:0;right:0;z-index:45;display:flex;align-items:center;gap:12px;
  padding:calc(env(safe-area-inset-top) + 9px) 16px 9px;
  background:rgba(247,245,241,.9);-webkit-backdrop-filter:saturate(160%) blur(18px);backdrop-filter:saturate(160%) blur(18px);
  border-bottom:1px solid var(--line);transform:translateY(-101%);transition:transform .28s var(--ease-settle);}
.cbar.show{transform:none;}
.cbar-back{font-size:23px;font-weight:800;color:var(--ink);line-height:1;}
.cbar-city{font-weight:800;font-size:17px;color:var(--ink);}
.cbar .id-chip{margin-inline-start:auto;box-shadow:none;}
@media (min-width:1000px){ .cbar{display:none;} .navpill{bottom:auto;} }

/* ---------- install banner (A2HS) ---------- */
.a2hs{position:fixed;top:calc(env(safe-area-inset-top) + 10px);left:12px;right:12px;z-index:60;max-width:520px;margin:0 auto;
  display:flex;align-items:center;gap:12px;padding:11px 13px;border-radius:18px;
  background:var(--surface);border:1px solid var(--line);box-shadow:var(--sh-lg);
  transform:translateY(calc(-100% - 26px));opacity:0;transition:transform .32s var(--ease-settle),opacity .32s;
  -webkit-user-select:none;user-select:none;}
.a2hs.show{transform:none;opacity:1;}
.a2hs[hidden]{display:none;}
.a2hs-ic{width:42px;height:42px;border-radius:11px;flex:0 0 auto;}
.a2hs-tx{display:flex;flex-direction:column;line-height:1.25;min-width:0;flex:1;}
.a2hs-tx b{font-size:14.5px;color:var(--ink);}
.a2hs-tx span{font-size:12px;color:var(--muted);}
.a2hs .btn{flex:0 0 auto;}
.a2hs-x{background:none;border:none;color:var(--faint);font-size:15px;cursor:pointer;padding:6px;flex:0 0 auto;line-height:1;}
@media(min-width:1000px){.a2hs{display:none!important;}}

/* ---------- overview info sections (אצטדיון + עיר) ---------- */
.infosec{display:grid;gap:16px;margin-top:22px;align-items:stretch;}
.imgcard{position:relative;min-height:216px;height:100%;border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end;
  padding:20px 20px 22px;color:#fff;background-size:cover;background-position:center;box-shadow:var(--sh);isolation:isolate;}
.imgcard::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(to top,rgba(8,8,14,.84) 0%,rgba(8,8,14,.52) 34%,rgba(8,8,14,.06) 74%);}
.ic-eyebrow{font-size:12.5px;font-weight:800;color:var(--gold-bright);letter-spacing:.04em;text-shadow:0 1px 6px rgba(0,0,0,.55);}
.ic-title{font-size:23px;font-weight:800;letter-spacing:-.02em;margin:5px 0 0;line-height:1.1;text-shadow:0 2px 14px rgba(0,0,0,.55);}
.ic-meta{font-size:14px;color:rgba(255,255,255,.94);margin-top:8px;font-weight:700;text-shadow:0 1px 8px rgba(0,0,0,.6);}
.ic-sub{font-size:12.5px;color:rgba(255,255,255,.82);margin-top:4px;text-shadow:0 1px 8px rgba(0,0,0,.55);}
.ic-text{font-size:13.5px;color:rgba(255,255,255,.94);margin:9px 0 0;line-height:1.55;text-shadow:0 1px 10px rgba(0,0,0,.65);}
@media (min-width:760px){ .infosec{grid-template-columns:1fr 1fr;} }

/* stadium waze + capacity */
.ic-foot{display:flex;align-items:center;gap:12px;margin-top:15px;}
.waze-btn{display:inline-flex;align-items:center;gap:7px;font-size:13.5px;font-weight:800;color:#0c6f7e;background:#fff;
  padding:9px 16px;border-radius:999px;box-shadow:0 3px 11px rgba(0,0,0,.3);-webkit-user-select:none;user-select:none;}
.waze-btn svg{color:#1cb6c9;}
.waze-btn:active{transform:scale(.97);}
/* clear separation: shared-docs section away from per-person docs */
.gen-grid{margin-top:28px;}

/* ============================================================
   SHABBAT PAGE
   ============================================================ */
.shab-times{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:16px;}
.shab-t{background:linear-gradient(165deg,#fffaf0,#fbf3df);border:1px solid var(--gold-soft);border-radius:var(--r);padding:18px 16px;text-align:center;box-shadow:var(--sh-sm);}
.shab-flame{font-size:24px;display:block;}
.shab-t-k{display:block;font-size:12.5px;font-weight:700;color:var(--gold-ink);margin-top:4px;}
.shab-t-v{display:block;font-size:34px;font-weight:800;color:var(--ink);letter-spacing:-.01em;line-height:1.1;margin-top:4px;}
.shab-t-d{display:block;font-size:12px;color:var(--muted);margin-top:3px;}
.shab-name{font-size:16.5px;font-weight:800;color:var(--ink);display:block;}
.shab-addr{display:flex;align-items:center;gap:6px;font-size:14px;color:var(--body);font-weight:600;margin-top:7px;}
.shab-addr svg{color:var(--gold);flex:0 0 auto;}
.shab-rabbi{font-size:13.5px;color:var(--muted);margin-top:3px;}
.map-btns{display:flex;gap:10px;margin-top:14px;}
.mapbtn{display:inline-flex;align-items:center;justify-content:center;gap:7px;flex:1;font-size:14px;font-weight:800;padding:12px;border-radius:14px;}
.mapbtn.waze{background:#33ccff;color:#06283b;}
.mapbtn.gmaps{background:var(--surface-2);border:1px solid var(--line-2);color:var(--ink);}
.shab-contact{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px;}
.cbtn{flex:1;min-width:70px;text-align:center;font-size:13.5px;font-weight:700;color:var(--ink);background:var(--surface-2);border:1px solid var(--line-2);border-radius:12px;padding:11px 8px;}
.shab-meals{margin-top:14px;}
.shab-prayer{margin-top:14px;background:var(--surface-2);border-radius:12px;padding:12px 14px;font-size:13.5px;}
.shab-block{margin-bottom:16px;}
.shab-block:last-child{margin-bottom:0;}
.shab-block b{font-size:14.5px;color:var(--ink);display:block;margin-bottom:5px;}
.shab-block .dots{margin:0;}
.shab-foot{margin-top:12px;font-size:13px;}
@media (min-width:760px){ .shab-times{max-width:520px;} }

/* ---------- lightbox (enlarge photo) ---------- */
.lb{position:fixed;inset:0;z-index:200;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;
  background:rgba(10,10,16,.93);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:28px;opacity:0;transition:opacity .25s;}
.lb.show{opacity:1;}
.lb[hidden]{display:none;}
.lb-img{max-width:90vw;max-height:74vh;border-radius:18px;box-shadow:0 24px 70px rgba(0,0,0,.6);object-fit:contain;}
.lb-name{color:#fff;font-size:21px;font-weight:800;letter-spacing:-.01em;}
.lb-x{position:absolute;top:calc(env(safe-area-inset-top) + 16px);left:18px;width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,.16);color:#fff;border:none;font-size:18px;font-weight:700;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);}
