/* pages/listing.css — unique styles not in base.css */

:root{
  --brand:#0c2340; --brand-700:#091a2f; --brand-500:#143a5c; --brand-400:#1d5280; --brand-300:#2a6aa0;
  --brand-100:#e4edf5; --brand-50:#f0f5fa;
  --accent:#0071c2; --accent-h:#005a9e; --accent-light:#e8f4fd;
  --gold:#f0b132; --gold-h:#d99a1a; --gold-light:#fef6e4; --gold-deep:#b8791a;
  --teal:#17a2a8; --teal-light:#e0f5f5;
  --green:#008a05; --green-light:#e8f5e9;
  --red:#d32f2f; --orange:#e67e22; --purple:#7c3aed;
  --white:#fff; --g50:#f8f9fb; --g100:#f0f2f4; --g200:#e2e5e9; --g300:#cdd2d9;
  --g400:#98a2ae; --g500:#6b7785; --g700:#3b4856; --g900:#1a2430;
  --font:'DM Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --font-display:'Playfair Display',Georgia,serif;
  --r:6px; --rm:10px; --rl:14px; --rxl:20px;
  --sh-xs:0 1px 3px rgba(0,0,0,.06);
  --sh-sm:0 2px 8px rgba(0,0,0,.08);
  --sh:0 4px 20px rgba(0,0,0,.10);
  --sh-md:0 8px 30px rgba(0,0,0,.12);
  --sh-lg:0 16px 48px rgba(0,0,0,.14);
  --tr:.2s cubic-bezier(.4,0,.2,1);
}

body{font-family:var(--font);font-size:14px;line-height:1.55;color:var(--g900);background:var(--g50);-webkit-font-smoothing:antialiased;overflow-x:hidden;margin:0}

.logo{display:inline-flex;align-items:baseline;gap:0;flex-shrink:0;text-decoration:none;font-family:'Ubuntu',var(--font)}

.nav-tab{display:flex;align-items:center;gap:6px;padding:0 13px;height:100%;color:rgba(255,255,255,.72);font-size:13px;font-weight:500;border-bottom:3px solid transparent;transition:all var(--tr);white-space:nowrap;position:relative;text-decoration:none}

.hbtn{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border-radius:var(--rm);font-size:13px;font-weight:600;white-space:nowrap;border:none;text-decoration:none;transition:all var(--tr)}

.btn-burger{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);color:#fff;width:42px;height:42px;border-radius:var(--rm);display:none;align-items:center;justify-content:center;padding:0;transition:all var(--tr)}

.btn-burger .bl{display:block;width:20px;height:2px;background:#fff;margin:2.5px auto;border-radius:2px}

.mm-logo-t{font-family:'Ubuntu',var(--font);font-size:22px;font-weight:700;color:#fff;letter-spacing:-.3px;line-height:1}

.mm-logo-d{font-family:'Ubuntu',var(--font);font-size:15px;font-weight:500;color:var(--gold);letter-spacing:-.2px;line-height:1;margin-left:1px}

.mm-search-box{display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.1);border:1.5px solid rgba(255,255,255,.15);border-radius:var(--rm);padding:12px 14px}

.mm-pr{display:flex;align-items:center;gap:8px;padding:14px;border-radius:var(--rm);font-size:13px;font-weight:700;letter-spacing:.3px;text-decoration:none;text-transform:uppercase;position:relative;overflow:hidden}

.mm-sh{font-size:10.5px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:rgba(240,177,50,.7);margin-bottom:10px}

.mm-item{display:flex;align-items:center;gap:14px;padding:13px 14px;color:rgba(255,255,255,.9);font-size:15.5px;font-weight:500;border-radius:var(--rm);transition:all var(--tr);text-decoration:none;opacity:0;transform:translateX(-10px)}

.mm-item:hover{background:rgba(255,255,255,.07)}

.mm-item-badge{background:var(--gold);color:var(--brand);font-size:9px;font-weight:800;padding:2px 6px;border-radius:100px;margin-left:6px}

.mm-auth-btn{padding:13px;border-radius:var(--rm);font-size:14px;font-weight:700;text-align:center;border:none;text-decoration:none;display:flex;align-items:center;justify-content:center;gap:6px}

.mm-prefbtn{background:rgba(255,255,255,.08);color:rgba(255,255,255,.8);border:1px solid rgba(255,255,255,.1);padding:6px 12px;border-radius:100px;font-size:11.5px;font-weight:600}

.sbar{background:#fff;border-bottom:1px solid var(--g200);padding:14px 0;position:sticky;top:60px;z-index:1030;box-shadow:var(--sh-xs)}

.sbar-tabs{display:flex;gap:0;margin-bottom:10px;border-bottom:1px solid var(--g200);padding-bottom:0;overflow-x:auto;scrollbar-width:none}

.sbar-tabs::-webkit-scrollbar{display:none}

.sbar-tab{padding:8px 14px 10px;font-size:12.5px;font-weight:600;color:var(--g500);border:none;background:none;border-bottom:2.5px solid transparent;margin-bottom:-1px;display:flex;align-items:center;gap:6px;white-space:nowrap;font-family:var(--font)}

.sbar-tab i{font-size:14px}

.sbar-tab.active{color:var(--brand);border-bottom-color:var(--accent)}

.sbar-form{display:grid;grid-template-columns:2fr 1fr 1fr 1.1fr auto;gap:10px;align-items:stretch}

.sbar-field{position:relative;background:var(--g50);border:1.5px solid var(--g200);border-radius:var(--rm);height:48px;transition:all var(--tr)}

.sbar-field:focus-within,.sbar-field:hover{border-color:var(--accent);background:#fff}

.sbar-field i.sf-ic{position:absolute;left:14px;top:50%;transform:translateY(-50%);font-size:17px;color:var(--g500);pointer-events:none}

.sbar-field input,.sbar-field .sbar-btn{width:100%;height:100%;border:none;background:none;padding:0 12px 0 40px;font-size:13.5px;font-family:var(--font);color:var(--g900);outline:none;font-weight:500;text-align:left;display:flex;align-items:center}

.sbar-field .sbar-btn{cursor:pointer}

.sbar-field .sbar-btn.placeholder{color:var(--g500);font-weight:400}

.sbar-submit{background:linear-gradient(135deg,var(--accent) 0%,#0083d9 100%);color:#fff;border:none;border-radius:var(--rm);font-weight:700;padding:0 24px;display:flex;align-items:center;gap:7px;font-size:14px;box-shadow:0 3px 12px rgba(0,113,194,.3);white-space:nowrap}

.sbar-submit:hover{filter:brightness(1.05);transform:translateY(-1px)}

.ac-list{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid var(--g200);border-radius:var(--rm);box-shadow:var(--sh-md);max-height:340px;overflow-y:auto;z-index:10000;display:none}

.ac-item{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;border:none;background:none;text-align:left;width:100%;transition:background var(--tr)}

.ac-item i{font-size:16px;color:var(--accent);width:20px;text-align:center}

.ac-item .ac-body{flex:1}

.ac-item .ac-name{font-size:13.5px;font-weight:600;color:var(--g900)}

.ac-item .ac-meta{font-size:11.5px;color:var(--g500)}

.ac-item .ac-tag{font-size:10px;font-weight:700;color:var(--g500);background:var(--g100);padding:2px 7px;border-radius:100px}

.guests-pop{position:absolute;top:calc(100% + 4px);left:0;right:auto;min-width:300px;background:#fff;border:1px solid var(--g200);border-radius:var(--rm);box-shadow:var(--sh-md);padding:14px 16px;z-index:9999;display:none}

.gp-lbl{font-size:13.5px;font-weight:600;color:var(--g900);display:block}

.gp-hint{font-size:11.5px;color:var(--g500)}

.gp-btn{width:30px;height:30px;border-radius:50%;border:1.5px solid var(--accent);background:#fff;color:var(--accent);font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0;transition:all var(--tr);cursor:pointer}

.gp-val{min-width:20px;text-align:center;font-size:14px;font-weight:700}

.dp{position:absolute;top:calc(100% + 4px);left:0;background:#fff;border:1px solid var(--g200);border-radius:var(--rm);box-shadow:var(--sh-md);padding:16px;z-index:9999;display:none;min-width:340px;max-width:92vw}

.dp-nav{background:var(--g50);border:1px solid var(--g200);width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;color:var(--g700);padding:0;transition:all var(--tr);cursor:pointer}

.dp-month-title{font-size:14px;font-weight:700;text-align:center;margin-bottom:10px;text-transform:capitalize}

.dp-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:500;color:var(--g700);background:none;border:none;border-radius:var(--r);padding:0;cursor:pointer}

.dp-day.selected,.dp-day.range-start,.dp-day.range-end{background:var(--accent);color:#fff !important;font-weight:700}

.dp-day.range-start{border-radius:var(--r) 0 0 var(--r)}

.dp-day.range-end{border-radius:0 var(--r) var(--r) 0}

.dp-clear{background:none;border:none;color:var(--g500);font-size:12.5px;font-weight:600;text-decoration:underline;cursor:pointer}

.dp-apply{background:var(--accent);color:#fff;border:none;padding:8px 18px;border-radius:var(--rm);font-size:13px;font-weight:700;cursor:pointer}

.pick-sheet-close{display:none;position:sticky;top:0;background:#fff;z-index:2;margin:-16px -16px 6px;padding:14px 14px 10px;border-bottom:1px solid var(--g100);align-items:center}

.pick-sheet-close .pcs-title{flex:1;font-size:15px;font-weight:700;color:var(--g900);margin:0}

.tb-dd-item{display:flex;align-items:center;gap:8px;width:100%;padding:9px 12px;font-size:13px;color:var(--g700);background:none;border:none;text-align:left;border-radius:var(--r);cursor:pointer;font-weight:500}

.mobfbar{background:#fff;border-bottom:1px solid var(--g200);padding:10px 0;display:none;overflow-x:auto;scrollbar-width:none}

.mobfbar::-webkit-scrollbar{display:none}

.mobfbar .container{display:flex;gap:8px;white-space:nowrap}

.mfb{display:inline-flex;align-items:center;gap:5px;padding:8px 14px;border:1.5px solid var(--g200);border-radius:100px;font-size:12.5px;font-weight:600;color:var(--g700);background:#fff;flex-shrink:0}

.mfb.active{background:var(--brand);border-color:var(--brand);color:#fff}

.mfb i{font-size:14px}

.rhead{padding:24px 0 16px}

.bcrumb{font-size:12.5px;color:var(--g500);margin-bottom:10px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}

.bcrumb a{color:var(--g700)}

.bcrumb a:hover{color:var(--accent)}

.bcrumb i{font-size:10px;opacity:.6}

.rhead h1{font-size:26px;font-weight:700;font-family:var(--font-display);margin:0 0 4px;letter-spacing:-.3px}

.rhead .rcount{font-size:13.5px;color:var(--g500)}

.rhead .rcount strong{color:var(--g900)}

.rhead-row{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;flex-wrap:wrap}

.sort-wrap{display:flex;align-items:center;gap:10px;flex-shrink:0;flex-wrap:wrap}

.sort-wrap label{font-size:12.5px;color:var(--g500);font-weight:500}

.sort-wrap select{border:1.5px solid var(--g200);background:#fff;padding:8px 32px 8px 12px;border-radius:var(--rm);font-size:13px;font-weight:600;color:var(--g900);font-family:var(--font);outline:none;cursor:pointer;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%236b7785'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;background-size:14px}

.view-toggle{display:flex;gap:4px;background:var(--g100);border-radius:var(--rm);padding:3px}

.vt{background:none;border:none;padding:7px 13px;border-radius:var(--r);font-size:12.5px;font-weight:600;color:var(--g500);display:flex;align-items:center;gap:6px;cursor:pointer;transition:all var(--tr)}

.vt:hover{color:var(--g900)}

.vt.active{background:#fff;color:var(--brand);box-shadow:var(--sh-xs)}

.vt i{font-size:14px}

.llayout{display:grid;grid-template-columns:280px 1fr;gap:24px;padding-bottom:40px}

.llayout.map-mode{grid-template-columns:1fr 1.2fr;gap:16px}

.llayout.map-mode .sidebar{display:none}

.llayout.map-mode .rlist{display:flex;flex-direction:column;gap:10px}

.llayout.map-mode .map-pane{display:block !important}

.llayout.map-mode .rw-banner{display:none}

.llayout.map-mode .pag{justify-content:center}

.llayout.map-mode .pcard{flex-direction:column;min-height:0}

.llayout.map-mode .pc-media{flex:0 0 auto;width:100%;max-width:100%;min-width:0;aspect-ratio:16/9}

.llayout.map-mode .pc-info{padding:12px 14px;gap:4px}

.llayout.map-mode .pc-title{font-size:15px}

.llayout.map-mode .pc-desc,.llayout.map-mode .pc-highlights{display:none}

.llayout.map-mode .pc-tags{gap:4px}

.llayout.map-mode .pc-tag{font-size:10.5px;padding:2px 8px}

.llayout.map-mode .pc-price{flex:0 0 auto;max-width:100%;min-width:0;width:100%;border-left:none;border-top:1px solid var(--g200);padding:12px 16px;flex-direction:row;align-items:center;gap:14px;justify-content:space-between}

.llayout.map-mode .pc-score{flex:0 0 auto}

.llayout.map-mode .pc-pbox{flex:1;margin:0}

.llayout.map-mode .pc-cta{flex-shrink:0;padding:9px 16px}

.map-pane{position:sticky;top:160px;height:calc(100vh - 180px);border-radius:var(--rl);overflow:hidden;border:1px solid var(--g200);background:linear-gradient(135deg,#dbe9f7 0%,#c8dff0 30%,#b8d5e9 60%,#d4e4ee 100%)}

.map-pane::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 25% 35%, rgba(23,162,168,.15), transparent 35%),radial-gradient(circle at 70% 60%, rgba(240,177,50,.12), transparent 40%),radial-gradient(circle at 50% 80%, rgba(0,113,194,.1), transparent 30%);pointer-events:none}

.map-pane::after{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.3) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.3) 1px,transparent 1px);background-size:48px 48px;opacity:.5;pointer-events:none}

.mp-label{position:absolute;top:16px;left:16px;background:rgba(255,255,255,.95);backdrop-filter:blur(6px);padding:7px 12px;border-radius:var(--rm);font-size:12.5px;font-weight:700;color:var(--brand);box-shadow:var(--sh-xs);z-index:3;display:flex;align-items:center;gap:6px}

.mp-label i{color:var(--accent);font-size:14px}

.mp-ctrls{position:absolute;top:16px;right:16px;display:flex;flex-direction:column;gap:6px;z-index:3}

.mp-ctrl{width:36px;height:36px;background:rgba(255,255,255,.95);border:none;border-radius:var(--rm);box-shadow:var(--sh-xs);color:var(--g700);display:flex;align-items:center;justify-content:center;font-size:16px;cursor:pointer;transition:all var(--tr);backdrop-filter:blur(6px)}

.mp-ctrl:hover{background:#fff;color:var(--brand);transform:scale(1.05)}

.mp-legend{position:absolute;bottom:16px;left:16px;background:rgba(255,255,255,.95);backdrop-filter:blur(6px);padding:10px 14px;border-radius:var(--rm);font-size:11.5px;color:var(--g700);box-shadow:var(--sh-xs);z-index:3;display:flex;gap:12px;align-items:center;flex-wrap:wrap}

.mp-legend-dot{width:10px;height:10px;border-radius:50%;background:var(--accent);display:inline-block;margin-right:5px}

.mp-pin{position:absolute;background:#fff;color:var(--brand);border:2px solid var(--brand);border-radius:100px;padding:5px 11px;font-size:12.5px;font-weight:800;box-shadow:var(--sh-sm);cursor:pointer;transition:all .2s;z-index:2;white-space:nowrap}

.mp-pin:hover,.mp-pin.active{background:var(--brand);color:#fff;transform:scale(1.08);z-index:5}

.mp-pin::after{content:"";position:absolute;bottom:-6px;left:50%;transform:translateX(-50%);width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top:6px solid var(--brand)}

.mp-pin:hover::after,.mp-pin.active::after{border-top-color:var(--brand)}

.sidebar{display:flex;flex-direction:column;gap:12px;position:sticky;top:170px;align-self:start;max-height:calc(100vh - 180px);overflow-y:auto;padding-right:6px}

.sidebar::-webkit-scrollbar{width:6px}

.sidebar::-webkit-scrollbar-track{background:transparent}

.sidebar::-webkit-scrollbar-thumb{background:var(--g200);border-radius:3px}

.fcard{background:#fff;border:1px solid var(--g200);border-radius:var(--rl);padding:16px 18px}

.fc-title{font-size:13px;font-weight:700;color:var(--g900);margin-bottom:12px;display:flex;align-items:center;justify-content:space-between;gap:8px}

.fc-clear{background:none;border:none;color:var(--accent);font-size:11.5px;font-weight:600;padding:0}

.lang-opt{display:flex;align-items:center;gap:8px;padding:8px 12px;border:1.5px solid var(--g200);border-radius:var(--rm);font-size:13px;font-weight:500;color:var(--g700);margin-bottom:6px;cursor:pointer;transition:all var(--tr)}

.lang-opt span{font-size:18px}

.lang-opt:hover{border-color:var(--accent);color:var(--accent)}

.lang-opt.active{background:var(--accent-light);border-color:var(--accent);color:var(--accent);font-weight:600}

.fc-range{display:flex;align-items:center;gap:8px;margin-bottom:10px}

.fc-range input{flex:1;min-width:0;padding:8px 10px;border:1.5px solid var(--g200);border-radius:var(--r);font-size:13px;outline:none;font-family:var(--font)}

.fc-range input:focus{border-color:var(--accent)}

.fc-range span{color:var(--g400);font-weight:700}

.fc-slider{position:relative;height:4px;background:var(--g200);border-radius:3px;margin:16px 6px 4px}

.fc-slider-fill{position:absolute;height:100%;background:var(--accent);border-radius:3px;left:10%;right:25%}

.fc-slider-h{position:absolute;top:50%;width:14px;height:14px;background:#fff;border:2px solid var(--accent);border-radius:50%;transform:translate(-50%,-50%);cursor:grab;box-shadow:var(--sh-xs)}

.fc-stars{display:flex;flex-wrap:wrap;gap:6px}

.fc-star{padding:6px 11px;border:1.5px solid var(--g200);border-radius:100px;font-size:12px;font-weight:600;color:var(--g700);display:inline-flex;align-items:center;gap:3px;cursor:pointer;transition:all var(--tr);background:#fff}

.fc-star i{color:var(--gold);font-size:11px}

.fc-star:hover{border-color:var(--accent)}

.fc-star.active{background:var(--accent);border-color:var(--accent);color:#fff}

.fc-star.active i{color:#fff}

.fc-opt{display:flex;align-items:center;gap:9px;padding:7px 0;font-size:13px;color:var(--g700);cursor:pointer;user-select:none}

.fc-opt input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);flex-shrink:0}

.fc-count{margin-left:auto;color:var(--g400);font-size:11.5px;font-weight:500}

.fc-show-more{background:none;border:none;color:var(--accent);font-size:12.5px;font-weight:600;padding:8px 0 0;display:inline-flex;align-items:center;gap:4px}

.rlist{display:flex;flex-direction:column;gap:14px}

.rw-banner{background:linear-gradient(135deg,var(--brand) 0%,var(--brand-400) 100%);border-radius:var(--rl);padding:20px 24px;display:flex;align-items:center;gap:18px;color:#fff;position:relative;overflow:hidden}

.rw-banner::after{content:"";position:absolute;top:-30%;right:-5%;width:200px;height:200px;background:radial-gradient(circle,rgba(240,177,50,.2),transparent 70%);pointer-events:none}

.rw-ic{width:48px;height:48px;border-radius:50%;background:rgba(240,177,50,.2);display:flex;align-items:center;justify-content:center;color:var(--gold);font-size:22px;flex-shrink:0;position:relative;z-index:1}

.rw-text{flex:1;position:relative;z-index:1}

.rw-text strong{display:block;font-size:15.5px;font-weight:700;margin-bottom:2px}

.rw-text span{font-size:12.5px;color:rgba(255,255,255,.7)}

.rw-btn{background:var(--gold);color:var(--brand);border:none;padding:10px 18px;border-radius:var(--rm);font-size:13px;font-weight:700;position:relative;z-index:1;white-space:nowrap}

.pcard{
  display:flex !important;
  flex-direction:row;
  flex-wrap:nowrap;
  align-items:stretch;
  width:100%;
  background:#fff;
  border:1px solid var(--g200);
  border-radius:var(--rl);
  overflow:hidden;
  transition:box-shadow var(--tr),transform var(--tr),border-color var(--tr);
  position:relative;
  min-height:260px;
  text-decoration:none;
  color:inherit;
}

.pcard:hover{box-shadow:var(--sh-md);transform:translateY(-2px);border-color:transparent}

.pc-media{
  position:relative;
  flex:0 0 300px;
  max-width:300px;
  min-width:300px;
  overflow:hidden;
  background:var(--g100);
  align-self:stretch;
}

.pc-media-link{display:block;position:absolute;inset:0;z-index:1}

.pc-photo{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  transition:opacity .18s ease;
  z-index:0;
}

.pc-photo.swapping{opacity:.55}

.pc-badge{position:absolute;top:10px;left:10px;font-size:10.5px;font-weight:800;padding:4px 10px;border-radius:4px;letter-spacing:.3px;z-index:3}

.b-top{background:var(--gold);color:var(--brand)}

.pc-fav{position:absolute;top:10px;right:10px;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.95);border:none;color:var(--g700);display:flex;align-items:center;justify-content:center;font-size:16px;transition:all var(--tr);z-index:3;cursor:pointer}

.pc-fav:hover,.pc-fav.active{background:#fff;color:var(--red);transform:scale(1.08)}

.pc-fav.active i::before{content:"\f415"}

.pc-langs{position:absolute;top:10px;right:54px;display:flex;gap:4px;z-index:3}

.pc-langs span{background:rgba(0,0,0,.55);color:#fff;font-size:10px;font-weight:700;padding:3px 7px;border-radius:4px;backdrop-filter:blur(4px)}

.pc-count{position:absolute;bottom:10px;right:10px;background:rgba(0,0,0,.6);color:#fff;font-size:10.5px;font-weight:600;padding:4px 9px;border-radius:4px;display:flex;align-items:center;gap:5px;backdrop-filter:blur(4px);z-index:3;transition:opacity .2s}

.pc-media:hover .pc-count{opacity:0}

.pc-thumbs{
  position:absolute;
  bottom:8px;left:8px;right:8px;
  display:flex;gap:4px;
  z-index:4;
  opacity:0;
  transform:translateY(4px);
  transition:opacity .25s ease,transform .25s ease;
  pointer-events:none;
}

.pc-media:hover .pc-thumbs{opacity:1;transform:translateY(0);pointer-events:auto}

.pc-thumb{
  flex:1 1 0;
  height:42px;
  border:2px solid rgba(255,255,255,.55);
  border-radius:5px;
  overflow:hidden;
  padding:0;
  cursor:pointer;
  background:var(--g200);
  transition:border-color .15s,transform .15s;
  position:relative;
}

.pc-thumb img{width:100%;height:100%;object-fit:cover;display:block}

.pc-thumb:hover{border-color:rgba(255,255,255,.85);transform:translateY(-1px)}

.pc-thumb.active{border-color:#fff;box-shadow:0 0 0 2px var(--accent),0 2px 8px rgba(0,0,0,.3)}

.pc-info{
  flex:1 1 auto;
  min-width:0;
  padding:18px 22px;
  display:flex;
  flex-direction:column;
  gap:6px;
}

.pc-meta{font-size:11px;font-weight:700;color:var(--g500);text-transform:uppercase;letter-spacing:.4px;margin-bottom:2px}

.pc-title{font-size:18px;font-weight:700;color:var(--g900);margin:0;line-height:1.25;font-family:var(--font-display);letter-spacing:-.1px}

.pc-title a{color:inherit;text-decoration:none}

.pc-title a:hover{color:var(--accent)}

.pc-stars{color:var(--gold);font-size:11px;letter-spacing:1px;margin:2px 0 4px}

.pc-loc{display:flex;align-items:center;flex-wrap:wrap;gap:4px 6px;font-size:12.5px;color:var(--g700);margin-bottom:2px}

.pc-loc i{font-size:14px;color:var(--accent)}

.pc-loc a{color:var(--accent);text-decoration:underline;font-weight:500}

.pc-loc .pc-dist{color:var(--g500)}

.pc-desc{font-size:12.5px;color:var(--g500);line-height:1.5;margin:4px 0 2px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

.pc-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}

.pc-tag{font-size:11.5px;font-weight:500;color:var(--g700);background:var(--g100);padding:4px 10px;border-radius:100px;display:inline-flex;align-items:center;gap:4px}

.pc-tag i{font-size:11px;color:var(--g500)}

.pc-highlights{margin-top:auto;padding-top:10px;display:flex;flex-wrap:wrap;gap:5px 16px;font-size:12px;color:var(--g700)}

.pc-highlights span{display:inline-flex;align-items:center;gap:5px}

.pc-highlights span i{color:var(--green);font-size:12px}

.pc-highlight-lang i{color:var(--accent) !important}

.pc-price{
  flex:0 0 240px;
  max-width:240px;
  min-width:240px;
  padding:18px;
  background:var(--g50);
  border-left:1px solid var(--g100);
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  align-self:stretch;
  gap:12px;
}

.pc-score{display:flex;align-items:center;gap:8px;justify-content:flex-end}

.pc-score-text{text-align:right;flex:1;min-width:0}

.pc-score-lbl{font-size:13px;font-weight:700;color:var(--g900);line-height:1.2;display:block}

.pc-score-cnt{font-size:11px;color:var(--g500);display:block;margin-top:1px}

.pc-score-num{background:var(--brand);color:#fff;font-weight:800;padding:7px 10px;border-radius:var(--r) var(--r) var(--r) 0;font-size:14.5px;min-width:42px;text-align:center;flex-shrink:0}

.pc-pbox{text-align:right;margin-top:auto}

.pc-nights{font-size:11.5px;color:var(--g500);margin-bottom:3px}

.pc-old{font-size:12.5px;color:var(--g400);text-decoration:line-through}

.pc-now{font-size:23px;font-weight:800;color:var(--g900);line-height:1.05;font-variant-numeric:tabular-nums;margin:2px 0 3px}

.pc-tax{font-size:11px;color:var(--g500)}

.pc-cta{background:linear-gradient(135deg,var(--accent),#0083d9);color:#fff;border:none;padding:11px 16px;border-radius:var(--rm);font-size:13.5px;font-weight:700;display:flex;align-items:center;justify-content:center;gap:6px;transition:all var(--tr);text-decoration:none;white-space:nowrap;box-shadow:0 2px 8px rgba(0,113,194,.25)}

.pc-cta:hover{filter:brightness(1.06);transform:translateY(-1px);box-shadow:0 4px 14px rgba(0,113,194,.35);color:#fff}

.pag{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:28px;flex-wrap:wrap}

.pag-btn{min-width:36px;height:36px;padding:0 10px;border-radius:var(--rm);border:1.5px solid var(--g200);background:#fff;font-size:13px;font-weight:600;color:var(--g700);display:inline-flex;align-items:center;justify-content:center;gap:4px;transition:all var(--tr)}

.pag-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}

.pag-btn:disabled{opacity:.4;cursor:not-allowed}

.pag-btn.active{background:var(--brand);border-color:var(--brand);color:#fff}

.ft-soc:hover{background:rgba(255,255,255,.12);color:#fff}

.ft-legal a{font-size:11.5px;color:rgba(255,255,255,.35)}

.mn-it{display:flex;flex-direction:column;align-items:center;gap:2px;padding:3px 12px;color:var(--g400);font-size:10px;font-weight:600;text-decoration:none}

.fdrawer{position:fixed;inset:0;z-index:1080;visibility:hidden;pointer-events:none}

.fdrawer.open{visibility:visible;pointer-events:auto}

.fd-bg{position:absolute;inset:0;background:rgba(0,0,0,.5);opacity:0;transition:opacity .3s}

.fdrawer.open .fd-bg{opacity:1}

.fd-pane{position:absolute;left:0;top:0;bottom:0;width:320px;max-width:90vw;background:#fff;overflow-y:auto;transform:translateX(-100%);transition:transform .3s ease;padding:18px}

.fdrawer.open .fd-pane{transform:translateX(0)}

.fd-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}

.fd-top h3{font-size:17px;font-weight:700;margin:0}

.fd-close{background:var(--g100);border:none;width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--g700)}

.fd-apply{position:sticky;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--g200);padding:12px 0;margin:16px -18px -18px;display:flex;gap:10px}

.fd-apply button{flex:1;padding:12px;border-radius:var(--rm);font-size:14px;font-weight:700;border:none}

.fd-clear{background:#fff;border:1.5px solid var(--g200) !important;color:var(--g700)}

.fd-go{background:linear-gradient(135deg,var(--accent),#0083d9);color:#fff}

@media(max-width:1199.98px){
  .llayout{grid-template-columns:240px 1fr;gap:18px}
  .pc-media{flex:0 0 240px;max-width:240px;min-width:240px}
  .pc-price{flex:0 0 210px;max-width:210px;min-width:210px;padding:14px}
  .pc-now{font-size:21px}
  .main-nav .nav-tab{padding:0 10px;font-size:12.5px}
  .llayout.map-mode{grid-template-columns:1fr 1fr}
}

@media(max-width:991.98px){
  .main-nav{display:none}
  .btn-burger{display:flex}
  .llayout,.llayout.map-mode{grid-template-columns:1fr}
  .sidebar{display:none !important}
  .mobfbar{display:block}
  .mob-nav{display:block}
  body{padding-bottom:68px}
  .sbar{top:60px}
  .sbar-form{grid-template-columns:1fr 1fr;gap:8px}
  .sbar-submit{grid-column:span 2}
  
  .pcard{flex-direction:column;min-height:0}
  .pc-media{flex:0 0 auto;width:100%;max-width:100%;min-width:0;aspect-ratio:16/9}
  .pc-price{flex:0 0 auto;width:100%;max-width:100%;min-width:0;border-left:none;border-top:1px solid var(--g200);flex-direction:row;align-items:center;gap:14px;padding:14px 18px;justify-content:space-between}
  .pc-score{flex:0 0 auto}
  .pc-pbox{flex:1;text-align:right;margin:0}
  .pc-cta{flex-shrink:0;padding:11px 22px}
  
  .llayout.map-mode .map-pane{display:none !important}
  .view-toggle{display:none}
  
  .pc-thumbs{opacity:1;transform:none;pointer-events:auto}
  .pc-count{opacity:0}
}

@media(max-width:767.98px){
  .topbar{padding:8px 0}
  .topbar-inner{height:auto;min-height:40px;gap:10px;justify-content:center}
  .tb-right{display:none}
  .tb-left{justify-content:center;gap:8px}
  .tb-premium{padding:6px 14px;font-size:11px;letter-spacing:.3px}
  .rhead h1{font-size:22px}
  .rhead-row{flex-direction:column;align-items:flex-start}
  .sort-wrap{width:100%}
  .sort-wrap select{flex:1}
  .rw-banner{flex-direction:column;text-align:center;padding:22px 20px}
  .pc-price{flex-direction:column;align-items:stretch;gap:10px}
  .pc-score{justify-content:flex-start}
  .pc-pbox{text-align:left}
  .pc-cta{width:100%}
  .sbar{top:0;position:relative}
  .sbar-tabs{overflow-x:auto}
  .sbar-tab{flex:0 0 auto}
  .pc-info{padding:16px 18px}
  .pc-title{font-size:16.5px}
  .pc-thumbs{bottom:6px;left:6px;right:6px;gap:3px}
  .pc-thumb{height:36px}
}

@media(max-width:575.98px){
  .sbar-form{grid-template-columns:1fr}
  .sbar-submit{grid-column:auto}
  .sbar-tab{font-size:11.5px;padding:8px 10px}
  .pc-now{font-size:20px}
  .rlist{gap:10px}
}
