/* ============================================================
   Darsouk — Prototype (Direction A · "Souk Vif")
   Marché algérien · responsive via container queries
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  --bg:#FCFBF8; --bg2:#F6F1E8; --card:#FFFFFF;
  --ink:#1A1714; --sub:#5C544C; --muted:#8C8278; --faint:#B4ABA0;
  --red:#F83332; --red-dark:#DC1E22; --red-tint:#FEECEA;
  --teal:#0E7C66; --teal-tint:#E5F2EE; --amber:#E0922F; --gold:#E8B23C;
  --sand:#F2ECE2; --line:rgba(26,23,20,0.10); --line2:rgba(26,23,20,0.06); --line3:rgba(26,23,20,0.16);
  --disp:'Bricolage Grotesque', system-ui, sans-serif;
  --body:'Plus Jakarta Sans', system-ui, sans-serif;
  --r-sm:10px; --r-md:14px; --r-lg:18px; --r-xl:24px; --r-pill:999px;
  --sh-sm:0 2px 6px rgba(26,23,20,0.05);
  --sh-md:0 8px 24px rgba(26,23,20,0.08);
  --sh-lg:0 18px 44px rgba(26,23,20,0.12);
  --sh-red:0 10px 24px rgba(248,51,50,0.28);
  --maxw:1200px;
}

*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{background:var(--bg);font-family:var(--body);color:var(--ink);-webkit-font-smoothing:antialiased;}
button{font-family:inherit;cursor:pointer;border:none;background:none;}
a{color:inherit;text-decoration:none;}
img{display:block;max-width:100%;}
input,select,textarea{font-family:inherit;}

/* App container — container queries respond to THIS width (toggle bureau/mobile) */
.dk{container-type:inline-size;width:100%;min-height:100vh;background:var(--bg);position:relative;}

/* ---------- Type utilities ---------- */
.h-disp{font-family:var(--disp);font-weight:800;letter-spacing:-0.03em;line-height:1.02;color:var(--ink);}
.h1{font-family:var(--disp);font-weight:800;font-size:clamp(34px,4.4cqw,54px);letter-spacing:-0.03em;line-height:1.03;color:var(--ink);margin:0;}
.h2{font-family:var(--disp);font-weight:700;font-size:clamp(26px,2.8cqw,32px);letter-spacing:-0.02em;line-height:1.08;color:var(--ink);margin:0;}
.h3{font-family:var(--disp);font-weight:700;font-size:20px;letter-spacing:-0.01em;color:var(--ink);margin:0;}
.h4{font-family:var(--disp);font-weight:700;font-size:17px;color:var(--ink);margin:0;}
.eyebrow{font-family:var(--body);font-weight:700;font-size:12px;letter-spacing:0.14em;text-transform:uppercase;color:var(--red);}
.lead{font-size:17px;line-height:1.55;color:var(--sub);}
.body{font-size:15px;line-height:1.55;color:var(--sub);}
.small{font-size:13px;color:var(--muted);}
.tiny{font-size:12px;color:var(--muted);}
.tnum{font-variant-numeric:tabular-nums;}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--body);font-weight:700;
  font-size:14.5px;padding:12px 20px;border-radius:var(--r-pill);transition:transform .15s,box-shadow .2s,background .2s,color .2s;white-space:nowrap;}
.btn:active{transform:scale(0.97);}
.btn-red{background:var(--red);color:#fff;box-shadow:var(--sh-red);}
.btn-red:hover{background:var(--red-dark);}
.btn-ink{background:var(--ink);color:#fff;}
.btn-ink:hover{background:#000;}
.btn-ghost{background:var(--card);color:var(--ink);border:1px solid var(--line);}
.btn-ghost:hover{border-color:var(--line3);background:#fff;}
.btn-soft{background:var(--red-tint);color:var(--red-dark);}
.btn-soft:hover{background:#FDE0DC;}
.btn-lg{padding:15px 26px;font-size:15.5px;}
.btn-sm{padding:9px 15px;font-size:13.5px;}
.btn-block{width:100%;}

/* ---------- Chips ---------- */
.chip{display:inline-flex;align-items:center;gap:7px;padding:9px 15px;border-radius:var(--r-pill);font-weight:600;font-size:13.5px;
  background:var(--card);color:var(--sub);border:1px solid var(--line);transition:all .15s;white-space:nowrap;cursor:pointer;}
.chip:hover{border-color:var(--line3);color:var(--ink);}
.chip.active{background:var(--ink);color:#fff;border-color:var(--ink);}
.chip-sm{padding:6px 12px;font-size:12.5px;}

/* ---------- Inputs ---------- */
.field{display:flex;flex-direction:column;gap:7px;}
.label{font-weight:600;font-size:13px;color:var(--ink);}
.input{display:flex;align-items:center;gap:9px;background:var(--card);border:1px solid var(--line);border-radius:var(--r-md);
  padding:12px 14px;font-size:14.5px;color:var(--ink);transition:border .15s,box-shadow .15s;width:100%;}
.input input,.input select{border:none;outline:none;background:none;font-size:14.5px;color:var(--ink);width:100%;}
.input input::placeholder{color:var(--faint);}
.input:focus-within{border-color:var(--red);box-shadow:0 0 0 3px var(--red-tint);}
.input svg{color:var(--muted);flex-shrink:0;}

/* ---------- Layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;}
.section{padding:44px 0;}
.row{display:flex;align-items:center;}
.between{display:flex;align-items:center;justify-content:space-between;gap:16px;}
.gap8{gap:8px;}.gap12{gap:12px;}.gap16{gap:16px;}.gap24{gap:24px;}
.wrapf{flex-wrap:wrap;}
.grid{display:grid;gap:18px;}
.cols-4{grid-template-columns:repeat(4,1fr);}
.cols-3{grid-template-columns:repeat(3,1fr);}
.cols-2{grid-template-columns:repeat(2,1fr);}
.spacer{flex:1;}

/* ---------- Top nav ---------- */
.nav{position:sticky;top:0;z-index:40;background:rgba(252,251,248,0.82);backdrop-filter:blur(18px);border-bottom:1px solid var(--line2);}
.nav-in{max-width:var(--maxw);margin:0 auto;height:68px;display:flex;align-items:center;gap:32px;padding:0 28px;}
.nav-logo{height:24px;cursor:pointer;}
.nav-links{display:flex;gap:24px;font-weight:600;font-size:14.5px;color:var(--sub);}
.nav-links a{transition:color .15s;cursor:pointer;}
.nav-links a:hover,.nav-links a.on{color:var(--ink);}
.nav-right{display:flex;align-items:center;gap:14px;margin-left:auto;}
.nav-pro{display:inline-flex;align-items:center;gap:6px;font-weight:600;font-size:14px;color:var(--sub);cursor:pointer;}
.nav-pro:hover{color:var(--ink);}
.nav-burger{display:none;width:42px;height:42px;border-radius:var(--r-md);align-items:center;justify-content:center;color:var(--ink);border:1px solid var(--line);background:var(--card);}

/* ---------- Search bar ---------- */
.searchbar{display:flex;align-items:center;background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:8px;box-shadow:var(--sh-md);gap:0;}
.searchbar .sb-seg{display:flex;align-items:center;gap:9px;padding:9px 14px;flex:1;min-width:0;}
.searchbar .sb-seg input{border:none;outline:none;background:none;font-size:15px;color:var(--ink);width:100%;font-weight:500;}
.searchbar .sb-seg input::placeholder{color:var(--faint);font-weight:500;}
.searchbar .sb-div{width:1px;height:28px;background:var(--line);flex-shrink:0;}
.sb-loc{font-weight:600;color:var(--ink);white-space:nowrap;}

/* ---------- Listing card ---------- */
.lcard{background:var(--card);border-radius:var(--r-xl);border:1px solid var(--line);overflow:hidden;box-shadow:var(--sh-sm);transition:transform .25s,box-shadow .25s;cursor:pointer;display:flex;flex-direction:column;}
.lcard:hover{transform:translateY(-3px);box-shadow:var(--sh-lg);}
.lcard-media{padding:8px;position:relative;}
.lcard-fav{position:absolute;right:16px;top:16px;width:34px;height:34px;border-radius:var(--r-pill);background:rgba(255,255,255,0.92);display:flex;align-items:center;justify-content:center;color:var(--ink);box-shadow:var(--sh-sm);transition:color .15s,transform .15s;}
.lcard-fav:hover{transform:scale(1.08);}
.lcard-fav.on{color:var(--red);}
.lcard-cat{position:absolute;left:16px;top:16px;background:rgba(255,255,255,0.92);color:var(--ink);font-weight:600;font-size:12px;padding:5px 11px;border-radius:var(--r-pill);}
.lcard-body{padding:6px 16px 18px;display:flex;flex-direction:column;flex:1;}
.lcard-row{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;}
.lcard-name{font-family:var(--disp);font-weight:700;font-size:18px;color:var(--ink);letter-spacing:-0.01em;}
.lcard-rate{display:flex;align-items:center;gap:3px;font-weight:700;font-size:14px;flex-shrink:0;}
.lcard-meta{display:flex;align-items:center;gap:5px;color:var(--muted);font-size:13px;margin-top:4px;}
.lcard-foot{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:14px;}
.lcard-price b{color:var(--ink);}
.status{display:inline-flex;align-items:center;gap:5px;font-weight:600;font-size:12.5px;}
.status .dot{width:7px;height:7px;border-radius:var(--r-pill);}
.status.open{color:var(--teal);} .status.open .dot{background:var(--teal);}
.status.soon{color:var(--amber);} .status.soon .dot{background:var(--amber);}

/* media placeholder (category-tinted gradient) */
.ph{position:relative;border-radius:var(--r-lg);overflow:hidden;display:flex;align-items:center;justify-content:center;}
.ph svg{opacity:0.5;}
.ph .ph-label{position:absolute;left:12px;top:12px;background:rgba(255,255,255,0.9);color:var(--ink);font-weight:600;font-size:12px;padding:5px 10px;border-radius:var(--r-pill);}

/* ---------- Star rating ---------- */
.stars{display:inline-flex;gap:2px;}

/* ---------- Category tile ---------- */
.cat-tile{display:flex;flex-direction:column;align-items:center;gap:10px;cursor:pointer;}
.cat-ic{width:64px;height:64px;border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;background:var(--card);border:1px solid var(--line);color:var(--ink);transition:all .18s;}
.cat-tile:hover .cat-ic{transform:translateY(-3px);box-shadow:var(--sh-md);border-color:var(--line3);}
.cat-tile .cat-nm{font-weight:600;font-size:13px;color:var(--ink);}

/* ---------- Footer ---------- */
.footer{background:var(--ink);color:#fff;margin-top:40px;}
.footer-in{max-width:var(--maxw);margin:0 auto;padding:48px 28px 28px;}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:32px;}
.footer h5{font-family:var(--disp);font-weight:700;font-size:14px;color:#fff;margin:0 0 14px;}
.footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px;}
.footer a{color:rgba(255,255,255,0.6);font-size:14px;}
.footer a:hover{color:#fff;}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;margin-top:40px;padding-top:20px;border-top:1px solid rgba(255,255,255,0.12);color:rgba(255,255,255,0.5);font-size:13px;}

/* ---------- Mobile bottom tabbar ---------- */
.tabbar{display:none;position:sticky;bottom:0;z-index:40;background:rgba(252,251,248,0.92);backdrop-filter:blur(18px);border-top:1px solid var(--line);}
.tabbar-in{display:flex;justify-content:space-around;padding:8px 0 10px;}
.tab{display:flex;flex-direction:column;align-items:center;gap:3px;color:var(--muted);font-size:10.5px;font-weight:600;cursor:pointer;flex:1;}
.tab.on{color:var(--red);}

/* ============================================================
   Container-query responsive — the .dk wrapper is the size
   container, so these breakpoints react to the real viewport
   width on desktop, tablet and mobile.
   ============================================================ */
@container (max-width: 880px){
  .cols-4{grid-template-columns:repeat(2,1fr);}
  .cols-3{grid-template-columns:repeat(2,1fr);}
}
@container (max-width: 720px){
  .nav-links,.nav-pro,.nav-cta-text{display:none;}
  .nav-burger{display:flex;}
  .nav-in{height:60px;gap:14px;}
  .tabbar{display:block;}
  .wrap{padding:0 18px;}
  .nav-in{padding:0 18px;}
  .footer-grid{grid-template-columns:1fr 1fr;gap:24px;}
  .searchbar{flex-direction:column;align-items:stretch;gap:6px;padding:10px;}
  .searchbar .sb-div{width:100%;height:1px;}
  .searchbar .sb-seg{padding:11px 8px;}
  .hide-m{display:none!important;}
}
@container (max-width: 520px){
  .cols-4,.cols-3,.cols-2{grid-template-columns:1fr;}
  .section{padding:30px 0;}
}

/* ============================================================
   Screen-specific
   ============================================================ */
/* HERO */
.hero{display:grid;grid-template-columns:1.05fr 0.95fr;gap:44px;align-items:center;padding:48px 0 36px;}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--line);border-radius:var(--r-pill);padding:7px 14px;font-weight:600;font-size:12.5px;color:var(--sub);}
.hero-badge .dot{width:7px;height:7px;border-radius:var(--r-pill);background:var(--teal);}
.hero-collage{position:relative;height:440px;}
.hero-collage .pc{position:absolute;border-radius:20px;box-shadow:0 22px 55px rgba(26,23,20,0.22);overflow:hidden;border:5px solid #fff;}
.hero-float{position:absolute;left:10px;bottom:14px;background:#fff;border-radius:16px;padding:12px 16px;box-shadow:var(--sh-lg);border:1px solid var(--line2);display:flex;align-items:center;gap:12px;}
.pop-chips{display:flex;gap:9px;margin-top:18px;flex-wrap:wrap;align-items:center;}
.pop-chips .pc{font-weight:600;font-size:13px;color:var(--sub);background:#fff;border:1px solid var(--line);border-radius:var(--r-pill);padding:6px 13px;cursor:pointer;}
.pop-chips .pc:hover{border-color:var(--line3);color:var(--ink);}
@container (max-width: 880px){ .hero{grid-template-columns:1fr;gap:24px;} .hero-collage{display:none;} }

/* category tiles rail */
.cat-rail{display:flex;gap:28px;overflow-x:auto;padding:4px 0 8px;scrollbar-width:none;}
.cat-rail::-webkit-scrollbar{display:none;}

/* PRO band */
.pro-band{background:var(--ink);border-radius:var(--r-xl);padding:36px 40px;display:flex;align-items:center;justify-content:space-between;gap:24px;color:#fff;flex-wrap:wrap;}
.pro-stats{display:flex;gap:40px;flex-wrap:wrap;}
.pro-stat .v{font-family:var(--disp);font-weight:800;font-size:32px;letter-spacing:-0.02em;}
.pro-stat .l{font-size:13px;color:rgba(255,255,255,0.6);margin-top:3px;}

/* steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.step{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:24px;}
.step-n{width:38px;height:38px;border-radius:12px;background:var(--red-tint);color:var(--red-dark);display:flex;align-items:center;justify-content:center;font-family:var(--disp);font-weight:800;font-size:17px;}

/* SEARCH / CATEGORY */
.search-layout{display:grid;grid-template-columns:288px 1fr;gap:28px;align-items:start;}
.filters{position:sticky;top:84px;background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:20px;display:flex;flex-direction:column;gap:18px;}
.filter-h{font-weight:700;font-size:13.5px;color:var(--ink);margin-bottom:10px;}
.cat-banner{position:relative;border-radius:var(--r-xl);overflow:hidden;padding:36px 36px;color:#fff;display:flex;flex-direction:column;justify-content:flex-end;min-height:200px;}
.cat-banner-ov{position:absolute;inset:0;background:linear-gradient(180deg,rgba(26,23,20,0) 30%,rgba(26,23,20,0.72) 100%);}
.cat-city-select{display:inline-flex;align-items:center;gap:8px;background:#fff;border-radius:var(--r-pill);padding:9px 14px;box-shadow:var(--sh-sm);}
.cat-city-select select{border:none;outline:none;background:none;font-weight:700;font-size:14.5px;color:var(--ink);cursor:pointer;-webkit-appearance:none;appearance:none;padding-right:2px;}
.map-ph{border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);position:relative;background:
  linear-gradient(0deg,rgba(14,124,102,0.05),rgba(14,124,102,0.05)),
  repeating-linear-gradient(0deg,#EAE7DF 0 1px,transparent 1px 40px),
  repeating-linear-gradient(90deg,#EAE7DF 0 1px,transparent 1px 40px),#F3F0E8;}
.seg{display:inline-flex;background:var(--bg2);border:1px solid var(--line);border-radius:var(--r-pill);padding:3px;}
.seg button{padding:8px 14px;border-radius:var(--r-pill);font-weight:600;font-size:13px;color:var(--sub);display:flex;align-items:center;gap:6px;}
.seg button.on{background:var(--card);color:var(--ink);box-shadow:var(--sh-sm);}
@container (max-width: 880px){ .search-layout{grid-template-columns:1fr;} .filters{position:static;} .filters.drawer{display:none;} }

/* DETAIL */
.detail-gallery{display:grid;grid-template-columns:2fr 1fr 1fr;grid-template-rows:1fr 1fr;gap:10px;height:380px;}
.detail-gallery .g0{grid-row:1 / span 2;}
.detail-layout{display:grid;grid-template-columns:1fr 360px;gap:32px;align-items:start;margin-top:28px;}
.booking-box{position:sticky;top:84px;background:var(--card);border:1px solid var(--line);border-radius:var(--r-xl);padding:22px;box-shadow:var(--sh-md);}
.amenity{display:flex;align-items:center;gap:10px;color:var(--sub);font-size:14px;}
.amenity .ai{width:36px;height:36px;border-radius:10px;background:var(--bg2);display:flex;align-items:center;justify-content:center;color:var(--ink);}
.review{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:18px;}
.avatar{width:40px;height:40px;border-radius:var(--r-pill);display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-family:var(--disp);}
@container (max-width: 880px){ .detail-layout{grid-template-columns:1fr;} .booking-box{position:static;} .detail-gallery{grid-template-columns:1fr 1fr;grid-template-rows:160px 120px;height:auto;} .detail-gallery .g0{grid-column:1 / span 2;grid-row:1;} .detail-gallery .g4{display:none;} }

/* BOOKING */
.booking-wrap{max-width:720px;margin:0 auto;}
.stepper{display:flex;align-items:center;gap:8px;margin:24px 0 28px;}
.stepper .sd{flex:1;height:4px;border-radius:4px;background:var(--line);}
.stepper .sd.on{background:var(--red);}
.counter{display:flex;align-items:center;gap:14px;}
.counter button{width:38px;height:38px;border-radius:var(--r-pill);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--ink);background:var(--card);}
.counter button:hover{border-color:var(--line3);}
.timeslot{padding:11px 0;border:1px solid var(--line);border-radius:var(--r-md);text-align:center;font-weight:600;font-size:14px;color:var(--ink);cursor:pointer;transition:all .15s;}
.timeslot:hover{border-color:var(--line3);}
.timeslot.on{background:var(--ink);color:#fff;border-color:var(--ink);}
.daypick{min-width:64px;padding:12px 0;border:1px solid var(--line);border-radius:var(--r-md);text-align:center;cursor:pointer;transition:all .15s;}
.daypick.on{background:var(--red-tint);border-color:var(--red);}

/* AUTH */
.auth{display:grid;grid-template-columns:1fr 1fr;min-height:100vh;}
.auth-brand{position:relative;overflow:hidden;background:var(--ink);color:#fff;padding:48px;display:flex;flex-direction:column;}
.auth-form{display:flex;align-items:center;justify-content:center;padding:48px;background:var(--bg);}
.auth-card{width:100%;max-width:400px;}
.oauth{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:12px;border:1px solid var(--line);border-radius:var(--r-md);background:var(--card);font-weight:600;font-size:14px;}
.oauth:hover{border-color:var(--line3);}
@container (max-width: 880px){ .auth{grid-template-columns:1fr;} .auth-brand{display:none;} }

/* PRICING */
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:start;}
.plan{background:var(--card);border:1px solid var(--line);border-radius:var(--r-xl);padding:28px;display:flex;flex-direction:column;gap:6px;}
.plan.feat{border:2px solid var(--red);box-shadow:var(--sh-lg);position:relative;}
.plan .price{font-family:var(--disp);font-weight:800;font-size:42px;letter-spacing:-0.03em;}
.plan-feat{display:flex;align-items:flex-start;gap:10px;color:var(--sub);font-size:14px;line-height:1.4;}
.plan-feat .pi{color:var(--teal);flex-shrink:0;margin-top:1px;}
.faq-item{border-bottom:1px solid var(--line);padding:18px 0;cursor:pointer;}
@container (max-width: 880px){ .plans{grid-template-columns:1fr;} }

/* PRO DASHBOARD */
.pro-shell{display:grid;grid-template-columns:248px 1fr;min-height:100vh;}
.pro-side{background:var(--ink);color:#fff;padding:22px 16px;display:flex;flex-direction:column;gap:6px;}
.pro-side .pl{display:flex;align-items:center;gap:11px;padding:11px 13px;border-radius:var(--r-md);color:rgba(255,255,255,0.66);font-weight:600;font-size:14px;cursor:pointer;transition:all .15s;}
.pro-side .pl:hover{background:rgba(255,255,255,0.06);color:#fff;}
.pro-side .pl.on{background:var(--red);color:#fff;}
.pro-main{padding:28px 32px;background:var(--bg2);overflow:auto;}
.stat-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:20px;}
.stat-card .sv{font-family:var(--disp);font-weight:800;font-size:30px;letter-spacing:-0.02em;color:var(--ink);}
.delta{display:inline-flex;align-items:center;gap:3px;font-weight:700;font-size:12.5px;padding:3px 8px;border-radius:var(--r-pill);}
.delta.up{background:var(--teal-tint);color:var(--teal);}
.panel{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:22px;}
.tbl{width:100%;border-collapse:collapse;}
.tbl th{text-align:left;font-size:12px;text-transform:uppercase;letter-spacing:0.06em;color:var(--muted);font-weight:700;padding:0 0 12px;}
.tbl td{padding:13px 0;border-top:1px solid var(--line2);font-size:14px;}
.badge-st{display:inline-flex;align-items:center;gap:5px;font-weight:700;font-size:12px;padding:4px 10px;border-radius:var(--r-pill);}
.bars{display:flex;align-items:flex-end;gap:10px;height:140px;}
.bars .bar{flex:1;background:linear-gradient(180deg,var(--red),#FF7A6B);border-radius:6px 6px 0 0;min-height:6px;position:relative;}
.upload{aspect-ratio:1;border:2px dashed var(--line3);border-radius:12px;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--muted);cursor:pointer;background:var(--bg2);min-height:96px;transition:all .15s;}
.upload:hover{border-color:var(--red);color:var(--red);background:var(--red-tint);}
/* Mobile sub-navigation (account / pro) — hidden on desktop, where the sidebar is used. */
.mobile-subnav{display:none;}
.msub-badge{min-width:16px;height:16px;padding:0 4px;border-radius:999px;background:var(--red);color:#fff;font-size:10px;font-weight:800;display:inline-flex;align-items:center;justify-content:center;}

@container (max-width: 880px){
  /* Mobile: drop the dark sidebar; the bottom tab bar + a labeled sub-nav take over.
     Fill the viewport minus the 56px tab bar so the sticky bottom nav pins to the bottom
     even when the content is short (e.g. a short conversation list). */
  .pro-shell{display:block;min-height:calc(100dvh - 56px);}
  .pro-side{display:none;}
  .pro-main{padding:14px 16px 80px;overflow:visible;min-height:calc(100dvh - 56px);}
  .mobile-subnav{display:flex;gap:8px;overflow-x:auto;padding:4px 0 12px;position:sticky;top:0;z-index:30;background:var(--bg2);scrollbar-width:none;}
  .mobile-subnav::-webkit-scrollbar{display:none;}
  .mobile-subnav button{display:inline-flex;align-items:center;gap:7px;flex-shrink:0;padding:9px 14px;border-radius:var(--r-pill);font-weight:600;font-size:13.5px;color:var(--sub);background:var(--card);border:1px solid var(--line);white-space:nowrap;}
  .mobile-subnav button.on{background:var(--ink);color:#fff;border-color:var(--ink);}
}
/* Dashboard inner content uses inline multi-column grids: force them to stack
   and let wide tables scroll within their panel on narrow screens. */
@container (max-width: 760px){
  .pro-main .grid{grid-template-columns:1fr !important;}
  .pro-main .panel{overflow-x:auto;}
  .pro-main .tbl{min-width:440px;}
}

/* ---------- Messaging ---------- */
.msg-layout{display:grid;grid-template-columns:340px 1fr;height:calc(100vh - 0px);background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;}
.conv-list{border-right:1px solid var(--line);display:flex;flex-direction:column;min-height:0;background:var(--card);}
.conv-search{padding:14px;border-bottom:1px solid var(--line2);}
.conv-scroll{overflow-y:auto;flex:1;min-height:0;}
.conv{display:flex;gap:12px;padding:14px 16px;cursor:pointer;border-bottom:1px solid var(--line2);transition:background .12s;position:relative;}
.conv:hover{background:var(--bg2);}
.conv.on{background:var(--red-tint);}
.conv-thumb{width:48px;height:48px;border-radius:12px;overflow:hidden;flex-shrink:0;}
.conv-body{flex:1;min-width:0;}
.conv-name{font-weight:700;font-size:14px;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.conv-prev{font-size:13px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:2px;}
.conv-unread{width:18px;height:18px;border-radius:999px;background:var(--red);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.thread{display:flex;flex-direction:column;min-height:0;min-width:0;background:var(--bg);}
.thread-head{display:flex;align-items:center;gap:12px;padding:14px 18px;border-bottom:1px solid var(--line);background:var(--card);flex-shrink:0;min-width:0;}
.thread-head>div[style*="flex: 1"],.thread-head>div{min-width:0;}
.conv-search input{min-width:0;}
.thread-ad{display:flex;align-items:center;gap:12px;padding:12px 18px;background:var(--bg2);border-bottom:1px solid var(--line2);flex-shrink:0;}
.thread-scroll{flex:1;overflow-y:auto;min-height:0;padding:20px 18px;display:flex;flex-direction:column;gap:10px;}
.bubble{max-width:74%;padding:11px 15px;border-radius:18px;font-size:14.5px;line-height:1.45;}
.bubble.them{background:var(--card);border:1px solid var(--line);color:var(--ink);align-self:flex-start;border-bottom-left-radius:5px;}
.bubble.me{background:var(--red);color:#fff;align-self:flex-end;border-bottom-right-radius:5px;}
.bubble-time{font-size:11px;color:var(--faint);margin:2px 6px 6px;}
.bubble-time.me{align-self:flex-end;}
.bubble-time.them{align-self:flex-start;}
.day-sep{align-self:center;font-size:12px;font-weight:600;color:var(--muted);background:var(--bg2);padding:4px 12px;border-radius:999px;margin:6px 0;}
.composer{display:flex;align-items:center;gap:10px;padding:12px 16px;border-top:1px solid var(--line);background:var(--card);flex-shrink:0;}
.composer input{flex:1;min-width:0;border:1px solid var(--line);border-radius:var(--r-pill);padding:12px 16px;font-size:14.5px;outline:none;background:var(--bg);}
.composer input:focus{border-color:var(--red);}
.msg-send{width:44px;height:44px;border-radius:999px;background:var(--red);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.quick-replies{display:flex;gap:8px;padding:0 16px 12px;flex-wrap:wrap;background:var(--card);}
.empty-thread{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--muted);text-align:center;padding:40px;}
.thread-head .msg-back{display:none;}
@container (max-width: 880px){
  .msg-layout{grid-template-columns:1fr;height:auto;border:none;border-radius:0;background:transparent;}
  .msg-layout:not(.has-active) .thread{display:none;}
  .conv-list{border-right:none;height:auto;border:1px solid var(--line);border-radius:var(--r-lg);}
  .conv-scroll{max-height:none;}
  .thread-head .msg-back{display:flex;}
  /* An open conversation becomes a full-screen chat (back button returns to the list). */
  .msg-layout.has-active .thread{position:fixed;inset:0;z-index:60;height:100dvh;border-radius:0;border:none;}
}
/* Hide the bottom tab bar while a full-screen mobile chat is open. */
.dk:has(.msg-layout.has-active) .tabbar{display:none;}

/* ---------- My listings (account) ---------- */
.myad{display:flex;gap:16px;padding:16px;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--card);align-items:center;}
.myad-thumb{width:96px;height:96px;border-radius:12px;overflow:hidden;flex-shrink:0;}
.myad-stats{display:flex;gap:18px;}
.myad-stat{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--muted);font-weight:600;}
.myad-actions{display:flex;gap:8px;flex-shrink:0;}
.iconbtn{width:38px;height:38px;border-radius:10px;border:1px solid var(--line);background:var(--card);display:flex;align-items:center;justify-content:center;color:var(--sub);transition:all .15s;}
.iconbtn:hover{border-color:var(--line3);color:var(--ink);}
.iconbtn.danger:hover{border-color:var(--red);color:var(--red);background:var(--red-tint);}
@container (max-width: 720px){
  .myad{flex-wrap:wrap;}
  .myad-thumb{width:72px;height:72px;}
  .myad-actions{width:100%;justify-content:flex-end;}
}

/* ---------- Toggle switch ---------- */
.switch{width:46px;height:27px;border-radius:999px;background:var(--line3);position:relative;cursor:pointer;transition:background .2s;flex-shrink:0;}
.switch.on{background:var(--teal);}
.switch .knob{position:absolute;top:3px;left:3px;width:21px;height:21px;border-radius:999px;background:#fff;box-shadow:var(--sh-sm);transition:transform .2s;}
.switch.on .knob{transform:translateX(19px);}
.setrow{display:flex;align-items:center;gap:16px;padding:16px 0;border-top:1px solid var(--line2);}
.setrow:first-child{border-top:none;}
.setrow-ic{width:40px;height:40px;border-radius:10px;background:var(--bg2);display:flex;align-items:center;justify-content:center;color:var(--ink);flex-shrink:0;}
.seg-tabs{display:inline-flex;background:var(--bg2);border:1px solid var(--line);border-radius:var(--r-pill);padding:3px;}
.seg-tabs button{padding:9px 18px;border-radius:var(--r-pill);font-weight:600;font-size:13.5px;color:var(--sub);}
.seg-tabs button.on{background:var(--card);color:var(--ink);box-shadow:var(--sh-sm);}

/* ---------- Reservation card ---------- */
.resa{display:flex;gap:16px;padding:16px;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--card);align-items:center;}
.resa-date{width:62px;height:62px;border-radius:12px;background:var(--red-tint);color:var(--red-dark);display:flex;flex-direction:column;align-items:center;justify-content:center;flex-shrink:0;}
.resa-date .d{font-family:var(--disp);font-weight:800;font-size:22px;line-height:1;}
.resa-date .m{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.06em;margin-top:2px;}
.resa-date.past{background:var(--bg2);color:var(--muted);}
@container (max-width: 720px){ .resa{flex-wrap:wrap;} .resa .resa-actions{width:100%;justify-content:flex-end;} }

/* empty state */
.empty{text-align:center;padding:56px 24px;}
.empty-ic{width:64px;height:64px;border-radius:18px;background:var(--bg2);display:inline-flex;align-items:center;justify-content:center;color:var(--faint);}

/* Villes */
.city-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;}
.city-card{display:flex;align-items:center;gap:12px;padding:14px 16px;border:1px solid var(--line);border-radius:var(--r-md);background:var(--card);cursor:pointer;transition:border-color .15s,box-shadow .15s,transform .15s;}
.city-card:hover{border-color:var(--line3);box-shadow:var(--sh-sm);transform:translateY(-1px);}
.city-card-ic{width:38px;height:38px;border-radius:10px;background:var(--bg2);display:flex;align-items:center;justify-content:center;color:var(--red);flex-shrink:0;}
.city-card-name{font-weight:700;font-size:14.5px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}

/* Notifications bell */
.bell-btn{position:relative;}
.notif-badge{position:absolute;top:-4px;right:-4px;min-width:17px;height:17px;padding:0 4px;border-radius:999px;background:var(--red);color:#fff;font-size:10.5px;font-weight:800;display:flex;align-items:center;justify-content:center;line-height:1;}
.notif-pop{position:absolute;right:0;top:calc(100% + 8px);width:340px;max-width:88vw;background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-lg);z-index:120;overflow:hidden;}
.notif-pop-head{padding:14px 16px;border-bottom:1px solid var(--line);}
.notif-pop-list{max-height:380px;overflow-y:auto;}
.notif-item{display:flex;gap:11px;align-items:flex-start;padding:12px 16px;cursor:pointer;border-bottom:1px solid var(--line);transition:background .12s;}
.notif-item:last-child{border-bottom:none;}
.notif-item:hover{background:var(--bg2);}
.notif-item.unread{background:rgba(248,51,50,0.04);}
.notif-ic{width:34px;height:34px;border-radius:9px;background:var(--bg2);display:flex;align-items:center;justify-content:center;color:var(--ink);flex-shrink:0;}
.notif-dot{width:8px;height:8px;border-radius:999px;background:var(--red);flex-shrink:0;margin-top:6px;}
