/* Harvey W James — faithful replica chrome. Tokens captured from live site. */
@font-face{font-family:"Brittany Signature";src:url("assets/fonts/BrittanySignature.ttf") format("truetype");font-weight:100 900;font-style:normal;font-display:swap}
:root{--dark:#262626;--accent:#FF6933;--ink:#1A1A1A;--head:#333333;--body:#212121;--paper:#F9F9F9;--soft:#F8F8F8;--line:#E4DFD6;--mut:#6F6A60}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Sen,system-ui,-apple-system,Arial,sans-serif;color:var(--body);background:#fff;-webkit-font-smoothing:antialiased;font-size:15px;line-height:1.5}
a{color:inherit;text-decoration:none}
img{max-width:100%}
.in{max-width:1440px;margin:0 auto;padding:0 16px}
.flag{background:#111;color:#fff;text-align:center;font-size:12px;letter-spacing:.05em;text-transform:uppercase;padding:7px 10px}
.flag b{color:#FF9466}
/* ---------- HEADER ---------- */
.site-h{background:var(--dark);position:sticky;top:0;z-index:50}
.site-h .bar{display:flex;align-items:center;justify-content:space-between;gap:18px;max-width:1440px;margin:0 auto;padding:8px 16px}
.logo img{height:80px;width:auto;display:block}
.logo.txt{font-family:Lato;font-weight:900;font-size:20px;color:#fff;letter-spacing:.02em}
.logo.txt b{color:var(--accent)}
.nav{display:flex;align-items:center;gap:26px;list-style:none;margin:0;padding:0}
.nav>li{position:relative}
.nav>li>a{color:#fff;font-size:17px;font-weight:700;padding:24px 0;display:inline-block;white-space:nowrap;text-shadow:0 1px 3px rgba(0,0,0,.4);letter-spacing:-.025em}
.nav>li>a .c{font-size:10px;opacity:.85;margin-left:3px}
.nav>li>a:hover,.nav>li>a.on{color:var(--accent)}
.drop{position:absolute;top:100%;left:-16px;min-width:250px;background:#fff;border-radius:6px;box-shadow:0 18px 50px rgba(0,0,0,.22);padding:8px;display:none}
.nav>li:hover .drop{display:block}
.drop a{display:block;color:var(--ink);font-size:14px;font-weight:600;padding:10px 14px;border-radius:5px}
.drop a:hover{background:#F6F1E8;color:var(--accent)}
.icons{display:flex;gap:10px;align-items:center}
.ic{width:40px;height:40px;border-radius:50%;border:1.5px solid var(--accent);display:flex;align-items:center;justify-content:center;color:#fff}
.ic svg{width:17px;height:17px;fill:currentColor}
.ic:hover{background:var(--accent)}
.burger{display:none;background:none;border:0;cursor:pointer;width:42px;height:42px}
.burger span{display:block;height:2px;background:#fff;margin:5px auto;width:24px;transition:.2s}
.langswbox-mob{display:none}  /* mobile-only EN|中文 toggle in the top bar (desktop uses the copy inside .icons) */
/* home hero header: fixed, transparent at top, turns solid dark on scroll (matches live) */
.site-h.over{position:fixed;top:0;left:0;right:0;background:transparent;z-index:40;transition:background .25s}
.site-h.over.scrolled{background:var(--dark);box-shadow:0 2px 14px rgba(0,0,0,.18)}
/* content-page hero card image */
.prose .phero-img{width:100%;border-radius:8px;margin:0 0 28px;display:block}
/* home hero — full-viewport cover bg with 10% overlay, content vertically centred (matches live) */
.hero-wrap{position:relative;background:#EDE7DC url(assets/hero-london-map.png) center center/cover no-repeat;min-height:100vh;display:flex;align-items:center}
.hero-wrap::before{content:"";position:absolute;inset:0;background:linear-gradient(rgba(0,0,0,.10),rgba(0,0,0,.10));pointer-events:none;z-index:1}
.hero-inner{position:relative;z-index:2;width:100%;max-width:1440px;margin:0 auto;padding:0 16px}
.hero-inner h1{font-family:Lato;font-weight:900;font-size:45px;color:#1A1A1A;margin:0;line-height:1;letter-spacing:-.025em}
.hero-inner .scriptL{display:block;font-family:"Brittany Signature",cursive;font-weight:200;font-size:67.5px;color:var(--accent);line-height:1;letter-spacing:-1.125px;margin:-4px 0 6px}
.hero-inner .subL{display:block;font-family:Lato;font-weight:900;font-size:22.5px;color:#1A1A1A;line-height:1.33;letter-spacing:-.025em;margin:0 0 26px}
.hero-inner .btns{display:flex;gap:14px;flex-wrap:wrap}
.btn-out{background:transparent;color:#1A1A1A;border:1px solid var(--accent);font-weight:900;font-size:16.875px;padding:13px 26px;border-radius:999px}
/* home feature tiles */
.tiles{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;padding:56px 0 18px}
.tile{position:relative;aspect-ratio:1/1;border-radius:8px;overflow:hidden;display:flex;align-items:flex-end;color:#fff}
.tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.tile::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 38%,rgba(0,0,0,.62))}
.tile span{position:relative;z-index:2;padding:18px;font-family:Lato;font-weight:900;font-size:18px}
/* home about */
.habout{display:grid;grid-template-columns:1.05fr 1fr;gap:46px;align-items:center;padding:42px 0 56px}
.habout img{width:100%;aspect-ratio:1.63/1;object-fit:cover;border-radius:10px;display:block}
.habout h2{font-family:Lato;font-weight:700;font-size:21px;color:var(--head);margin:0 0 16px;line-height:1.1;letter-spacing:-.025em}
.habout p{margin:0 0 14px;font-size:15px;line-height:1.5}
.habout a.more{display:inline-block;margin-top:8px;background:var(--accent);color:#fff;font-weight:800;padding:13px 28px;border-radius:999px;text-decoration:none}
.habout p a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}
/* about page */
.about-herotext{text-align:center;padding:58px 28px 26px}
.about-herotext h1{font-family:Lato;font-weight:900;font-size:46px;color:var(--ink);letter-spacing:.05em;margin:0 0 12px}
.about-herotext p{font-size:18px;color:var(--mut);margin:0}
.about-img{width:100%;border-radius:10px;display:block}
.twoimg{display:grid;grid-template-columns:1fr 1fr;gap:24px;padding:22px 0 6px}
.twoimg img{width:100%;border-radius:10px;display:block}
@media(max-width:700px){.twoimg{grid-template-columns:1fr}.about-herotext h1{font-size:32px}}
/* testimonials */
.tmon{background:var(--paper);border-top:1px solid var(--line)}
.tmon .in{padding:56px 28px}
.tmon h2{font-family:Lato;font-weight:800;font-size:28.125px;color:var(--head);text-align:center;margin:0 0 30px;letter-spacing:-.025em}
.tgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.tcard{background:#fff;border:1px solid var(--line);border-radius:10px;padding:24px;display:flex;flex-direction:column;align-items:center}
.tcard .stars{display:none}
.tcard p{font-size:16.875px;font-style:normal;color:#333;margin:0 0 14px;line-height:1.25;text-align:center}
.tcard .who{font-weight:800;color:var(--head);font-size:14px;text-align:center}
@media(max-width:1024px){.tiles{grid-template-columns:repeat(2,1fr)}.tgrid{grid-template-columns:1fr}.habout{grid-template-columns:1fr;gap:24px}}
@media(max-width:560px){.tiles{grid-template-columns:1fr 1fr;gap:12px}.hero-inner h1{font-size:32px}.hero-inner .scriptL{font-size:48px}.hero-inner .subL{font-size:18px}}
/* blog post hero (image or banner) */
.prose .bhero-img{width:100%;border-radius:8px;margin:0 0 24px;display:block}
.bhero{background:#211d19;border-radius:8px;padding:40px 38px;margin:0 0 26px;position:relative;overflow:hidden}
.bhero::before{content:"";position:absolute;right:-70px;top:-70px;width:260px;height:260px;background:radial-gradient(circle,rgba(255,105,51,.28),transparent 70%)}
.bhero-wm{font-size:11px;letter-spacing:.14em;color:#fff;font-weight:800;border-bottom:2px solid var(--accent);padding-bottom:5px;display:inline-block}
.bhero-pill{position:absolute;top:40px;right:38px;background:var(--accent);color:#fff;font-size:11px;font-weight:800;letter-spacing:.08em;padding:5px 12px;border-radius:4px;text-transform:uppercase}
.bhero-t{font-family:Lato;font-weight:900;font-size:29px;color:#fff;line-height:1.14;margin-top:28px;max-width:92%;position:relative}
.ndate{font-size:12px;color:var(--accent);font-weight:800;text-transform:uppercase;letter-spacing:.06em;margin-bottom:14px}
@media(max-width:560px){.bhero-t{font-size:22px}.bhero{padding:30px 24px}.bhero-pill{top:auto;bottom:24px;right:24px}}
/* home search bar */
.hsearch{background:var(--soft);border-bottom:1px solid var(--line)}
.hsearch .in{padding:48px 16px 42px;text-align:center}
.hsearch h2{font-family:Lato;font-weight:800;font-size:28.125px;color:var(--body);margin:0 0 22px;letter-spacing:-.025em}
.searchbar{display:inline-flex;align-items:center;background:#fff;border:1px solid var(--line);border-radius:999px;padding:6px 6px 6px 4px;max-width:720px;width:100%;box-shadow:0 10px 26px rgba(0,0,0,.06)}
.searchbar .mag{padding:0 8px 0 16px;color:var(--mut);display:flex}
.searchbar input{flex:1;border:0;background:transparent;padding:14px 10px;font:inherit;min-width:0;outline:none}
.searchbar .searchbtn{border:0;cursor:pointer}
/* help cards */
.help{background:var(--soft)}
.help .in{padding:50px 16px 50px}
.help-h{font-family:Lato;font-weight:800;font-size:28.125px;color:var(--head);margin:0 0 26px;letter-spacing:-.025em}
.hcards{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.hcard{position:relative;aspect-ratio:33/40.5;border-radius:10px;overflow:hidden;display:flex;flex-direction:column;align-items:center;text-align:center;text-decoration:none;background:#F3EEE2;padding:28px 24px 0;transition:background .2s}
.hcard-wm{align-self:flex-start;font-size:9px;letter-spacing:.12em;color:#8a8276;font-weight:800;border-bottom:1.5px solid var(--accent);padding-bottom:5px}
.hcard-h{margin-top:auto;font-family:Lato;font-weight:900;font-size:30px;line-height:1.05;letter-spacing:-.02em}
.hcard-h b{display:block;color:var(--ink)}
.hcard-h i{display:block;color:var(--accent);font-style:normal}
.hcard-sub{margin:12px 0 auto;color:var(--mut);font-size:15px;line-height:1.45}
.hcard-btn{align-self:stretch;margin:22px -24px 0;background:var(--accent);color:#fff;font-weight:800;font-size:15px;padding:15px}
.hcard-more{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);background:#fff;color:var(--ink);font-weight:800;font-size:15px;padding:11px 26px;border-radius:999px;opacity:0;transition:opacity .2s;white-space:nowrap;z-index:3}
.hcard:hover{background:var(--accent)}
.hcard:hover .hcard-wm,.hcard:hover .hcard-h,.hcard:hover .hcard-sub,.hcard:hover .hcard-btn{opacity:0;transition:opacity .2s}
.hcard:hover .hcard-more{opacity:1}
/* videos */
.vids{border-top:1px solid var(--line)}
.vids .in{padding:54px 28px}
.vids h2,.lnews h2{font-family:Lato;font-weight:800;font-size:28.125px;color:var(--head);margin:0 0 26px;letter-spacing:-.025em}
.vgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.vcard{display:block;text-decoration:none}
.vthumb{position:relative;aspect-ratio:16/9;border-radius:8px;overflow:hidden;background:#000}
.vthumb img{width:100%;height:100%;object-fit:cover;opacity:.92;transition:.2s}
.vcard:hover .vthumb img{opacity:1;transform:scale(1.03)}
.vplay{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:58px;height:58px;border-radius:50%;background:rgba(255,105,51,.94);display:flex;align-items:center;justify-content:center}
.vplay::after{content:"";border-left:18px solid #fff;border-top:11px solid transparent;border-bottom:11px solid transparent;margin-left:5px}
.vtitle{font-family:Lato;font-weight:700;font-size:16px;color:var(--ink);margin:12px 0 0;line-height:1.3}
/* latest news */
.lnews{background:#fff;border-top:1px solid var(--line)}
.lnews .in{padding:54px 16px}
.lncards{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.lncard{background:#fff;border:1px solid var(--line);border-radius:10px;overflow:hidden;display:flex;flex-direction:column}
.lncard-img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block;background:#211d19}
.lncard-body{padding:22px;display:flex;flex-direction:column;flex:1}
.lncard .d{font-size:12px;color:var(--accent);font-weight:800;margin-bottom:10px}
.lncard h3{font-family:Lato;font-weight:700;font-size:19px;color:var(--ink);margin:0 0 10px;line-height:1.25}
.lncard p{font-size:14px;color:#555;margin:0 0 16px;flex:1;line-height:1.55}
.lncard .rm{color:var(--accent);font-weight:800;font-size:13px}
.viewarch{text-align:center;margin-top:32px}
.pager{display:flex;gap:8px;justify-content:center;padding:6px 0 54px}
.pager .pg{min-width:40px;height:40px;padding:0 10px;border-radius:8px;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-weight:800;color:var(--ink);text-decoration:none}
.pager a.pg:hover{border-color:var(--accent);color:var(--accent)}
.pager .pg.on{background:var(--accent);color:#fff;border-color:var(--accent)}
@media(max-width:1024px){.hcards{grid-template-columns:repeat(2,1fr)}.vgrid,.lncards{grid-template-columns:1fr}}
@media(max-width:1024px){.hcard{min-height:300px}}
@media(max-width:560px){.hcards{grid-template-columns:1fr}.hcard{min-height:0;padding:24px}}
/* ---------- TITLE BAND ---------- */
.titleband{background:var(--paper);border-bottom:1px solid var(--line)}
.titleband .in{display:flex;align-items:center;justify-content:space-between;gap:20px;padding-top:46px;padding-bottom:46px;flex-wrap:wrap}
.titleband h1{font-family:Lato;font-weight:800;font-size:45px;color:var(--head);margin:0 0 8px;letter-spacing:-.025em;line-height:1}
.titleband.article h1{font-size:33.75px;line-height:1.05}
.crumb{font-size:14px;color:var(--mut)}
.crumb a{color:var(--accent)}
.searchbtn{background:var(--accent);color:#fff;font-weight:700;font-size:15px;padding:13px 40px;border-radius:999px;white-space:nowrap}
.hero-inner .searchbtn,.searchbar .searchbtn{font-size:16.875px}
/* ---------- CONTENT ---------- */
.layout{display:grid;grid-template-columns:1fr 360px;gap:48px;padding:54px 0 64px}
.prose{font-size:15px;line-height:1.5;color:var(--body);max-width:820px}
.prose h2,.prose h3{font-family:Lato;font-weight:700;color:var(--head);line-height:1.2;margin:30px 0 10px}
.prose h3{font-size:19.5px}
.prose h2{font-size:21px}
.prose p{margin:0 0 16px}
.prose ul,.prose ol{margin:0 0 18px;padding-left:22px}
.prose li{margin:0 0 8px}
.prose a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}
.prose strong{color:var(--ink)}
/* enquiry form */
.enq{align-self:start;position:sticky;top:96px;border:1px solid var(--line);border-radius:14px;padding:28px;background:#fff;box-shadow:0 10px 30px rgba(0,0,0,.05)}
.enq h3{font-family:Lato;font-weight:700;font-size:22.5px;text-align:center;color:var(--head);margin:0 0 18px;letter-spacing:-.025em}
.enq input,.enq textarea{width:100%;border:1px solid var(--line);border-radius:999px;padding:14px 18px;margin:0 0 14px;font:inherit;color:var(--ink)}
.enq textarea{border-radius:18px;min-height:120px;resize:vertical}
.enq .send{display:block;width:auto;margin:6px auto 0;background:var(--accent);color:#fff;border:0;font-weight:800;font-size:15px;padding:14px 32px;border-radius:999px;cursor:pointer}
/* ---------- LISTINGS ---------- */
.controls{display:flex;flex-wrap:wrap;gap:10px;align-items:center;padding:22px 0;border-bottom:1px solid var(--line);font-size:14px}
.seg{display:inline-flex;border:1px solid var(--line);border-radius:999px;overflow:hidden;background:#fff}
.seg button{border:0;background:transparent;padding:9px 18px;cursor:pointer;font:inherit;color:var(--mut)}
.seg button.on{background:var(--dark);color:#fff}
.controls label{color:var(--mut);margin-left:8px}
.controls select{font:inherit;padding:9px 12px;border:1px solid var(--line);border-radius:8px;background:#fff}
.count{margin-left:auto;color:var(--mut)}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;padding:34px 0 60px}
.card{border:1px solid var(--line);border-radius:6px;overflow:hidden;background:#fff;display:flex;flex-direction:column;transition:.18s}
.card:hover{box-shadow:0 12px 32px rgba(0,0,0,.12);transform:translateY(-2px)}
.ph{position:relative;aspect-ratio:16/10;background:#EEE9DF;overflow:hidden}
.ph img{width:100%;height:100%;object-fit:cover}
.pill{position:absolute;top:12px;left:12px;font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;padding:5px 10px;border-radius:999px;background:#fff;color:var(--ink)}
.pill.tolet{background:var(--accent);color:#fff}
.pill.agreed{background:#fff;color:var(--mut);border:1px solid var(--line)}
.cbody{padding:16px 18px 20px;display:flex;flex-direction:column;gap:9px;flex:1}
.rent{font-family:Lato;font-weight:900;font-size:23px;color:var(--ink)}
.rent small{font-size:12px;color:var(--mut);font-weight:700}
.addr{font-size:16px}
.pc{display:inline-block;font-size:12px;color:var(--mut);border:1px solid var(--line);border-radius:4px;padding:2px 7px}
.meta{display:flex;gap:14px;font-size:13px;color:var(--mut);border-top:1px solid var(--line);padding-top:11px}
.tags{display:flex;gap:6px;flex-wrap:wrap}
.tag{font-size:11px;color:var(--mut);background:#F4F1EA;border-radius:4px;padding:3px 8px}
/* detail */
.detail{padding:30px 0 60px}
.detail .crumb{margin-bottom:10px}
.dt{font-family:Lato;font-weight:900;font-size:34px;color:var(--ink);margin:6px 0 4px}
.dtsub{color:var(--mut);margin-bottom:18px}
.dgallery{aspect-ratio:16/9;background:#EEE9DF;border-radius:8px;overflow:hidden;border:1px solid var(--line)}
.dgallery img{width:100%;height:100%;object-fit:cover}
.dlayout{display:grid;grid-template-columns:1fr 330px;gap:40px;padding-top:28px}
.facts{display:flex;gap:28px;flex-wrap:wrap;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:16px 0;margin-bottom:22px}
.fact b{display:block;font-family:Lato;font-weight:900;font-size:19px;color:var(--ink)}
.fact span{font-size:12px;color:var(--mut);text-transform:uppercase;letter-spacing:.05em}
.prose-d{font-size:16.5px}
.prose-d h3{font-family:Lato;font-weight:900;color:var(--ink);margin:22px 0 8px}
.side{align-self:start;position:sticky;top:96px;border:1px solid var(--line);border-radius:12px;background:#fff;padding:24px}
.side .rent{font-size:28px}
.side .muted{color:var(--mut);font-size:13px;margin-bottom:8px}
.cta{display:block;text-align:center;background:var(--accent);color:#fff;font-weight:800;padding:14px;border-radius:999px;margin-top:12px}
.cta.ghost{background:#fff;color:var(--ink);border:1px solid var(--line)}
.kvs{margin-top:16px;font-size:14px}
.kv{display:flex;justify-content:space-between;padding:8px 0;border-top:1px solid var(--line);color:var(--mut)}
.kv b{color:var(--ink)}
/* hero + featured (home) */
.phero{padding:50px 0 18px}
.phero .kick{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);font-weight:800;margin-bottom:12px}
.phero h1{font-family:Lato;font-weight:900;font-size:40px;color:var(--ink);margin:0 0 12px}
.phero .lede{font-size:18px;color:var(--mut);max-width:680px}
.ngrid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;padding:30px 0 60px}
.ncard{border:1px solid var(--line);border-radius:8px;padding:22px;transition:.18s;display:block}
.ncard:hover{box-shadow:0 10px 26px rgba(0,0,0,.08);transform:translateY(-2px)}
.ndate{font-size:12px;color:var(--accent);font-weight:800;text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px}
.ntitle{font-family:Lato;font-weight:700;font-size:19px;color:var(--ink);line-height:1.25}
/* popular locations (collapsible bar above footer — matches live) */
.poploc{background:#fff;border-top:1px solid #d1d5db;padding:32px 0}
.poploc h3{font-family:Lato;font-weight:800;font-size:22.5px;color:var(--body);text-align:center;letter-spacing:-.02em;margin:0;cursor:pointer;position:relative}
.poploc h3 .tg{font-size:14px;margin-left:8px}
.poploc .ploc-list{display:flex;flex-wrap:wrap;gap:10px 22px;justify-content:center;padding:22px 16px 0;font-size:14px}
.poploc .ploc-list a{color:var(--mut)}
.poploc .ploc-list a:hover{color:var(--accent)}
.poploc.collapsed .ploc-list{display:none}
/* ---------- FOOTER ---------- */
.site-f{background:var(--dark);color:#cbc6bd;margin-top:0}
.news{border-bottom:1px solid #3a3a3a}
.news .in{display:flex;align-items:center;justify-content:space-between;gap:28px;padding:40px 28px;flex-wrap:wrap}
.news h3{font-family:Lato;font-weight:800;color:#fff;font-size:28.125px;margin:0;letter-spacing:-.025em}
.news .sub{color:#a39d93;font-size:14px;margin-top:4px}
.news form{display:flex;gap:0;background:#fff;border-radius:999px;padding:6px;flex:1;max-width:620px;min-width:280px}
.news input{border:0;background:transparent;padding:12px 16px;font:inherit;flex:1;color:#222;min-width:0}
.news .signup{background:var(--accent);color:#fff;border:0;font-weight:800;padding:12px 26px;border-radius:999px;cursor:pointer;white-space:nowrap}
.fcols{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;padding:46px 16px 30px;max-width:1440px;margin:0 auto}
.fcol h4{color:#fff;font-family:Lato;font-weight:700;font-size:16.875px;margin:0 0 14px;letter-spacing:-.025em}
.fcol a,.fcol p{display:block;color:#bbb6ad;font-size:14px;margin:0 0 9px}
.fcol a:hover{color:var(--accent)}
.fcol .reg{color:#8f8a81;line-height:1.5}
.acc{border-top:1px solid #3a3a3a;padding:34px 16px;display:flex;flex-wrap:wrap;gap:30px 40px;align-items:center;justify-content:center;max-width:1440px;margin:0 auto}
.acc img{height:45px;width:auto;opacity:.92}
.legal{border-top:1px solid #3a3a3a;text-align:center;color:#8f8a81;font-size:12.5px;padding:22px}
/* social rail */
.rail{position:fixed;right:18px;bottom:84px;display:flex;flex-direction:column;gap:10px;z-index:40}
.rail a{width:42px;height:42px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;box-shadow:0 6px 16px rgba(0,0,0,.2)}
/* ---------- RESPONSIVE ---------- */
@media(max-width:1024px){
  .layout{grid-template-columns:1fr 300px;gap:30px}
  .grid{grid-template-columns:repeat(2,1fr)}
  .dlayout{grid-template-columns:1fr 290px}
  .fcols{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:820px){
  .nav,.icons{display:none}
  .burger{display:block}
  .langswbox-mob{display:inline-flex;align-items:center;gap:3px;margin-left:auto;margin-right:6px}
  .site-h .bar{padding:14px 20px}
  .mobnav{display:none;background:var(--dark);border-top:1px solid #3a3a3a}
  body.menu-open .mobnav{display:block}
  .mobnav ul{list-style:none;margin:0;padding:8px 0}
  .mobnav>ul>li>a{display:block;color:#fff;font-weight:700;padding:13px 24px;font-size:16px}
  .mobnav .sub a{display:block;color:#bbb6ad;padding:9px 38px;font-size:14px}
  .mobnav .sub{border-left:2px solid var(--accent);margin:0 24px 8px}
  .layout{grid-template-columns:1fr;gap:30px;padding:34px 0 50px}
  .enq{position:static}
  .titleband h1{font-size:34px}
  .titleband .in{padding-top:32px;padding-bottom:32px}
  .grid{grid-template-columns:1fr 1fr}
  .dlayout{grid-template-columns:1fr}
  .side{position:static}
  .ngrid{grid-template-columns:1fr}
  .news .in{flex-direction:column;align-items:flex-start}
  .news form{max-width:none;width:100%}
}
@media(max-width:560px){
  .in{padding:0 18px}
  .grid{grid-template-columns:1fr}
  .fcols{grid-template-columns:1fr;gap:24px}
  .phero h1{font-size:30px}
  .titleband h1{font-size:28px}
  .searchbtn{width:100%;text-align:center}
  .rail{bottom:14px;right:12px}
  .rail a{width:38px;height:38px}
  .acc img{height:34px}
}
.mobnav{display:none}
@media(min-width:821px){.mobnav{display:none!important}}
/* ============ SESSION 52 — structural exact-match to live ============ */
/* home hero block sits ~50px lower than live; nudge up (desktop only) */
.hero-inner{transform:translateY(-90px)}
@media(max-width:820px){.hero-inner{transform:translateY(-14vh)}}
@media(max-width:560px){.hero-inner .btns{flex-direction:column}.hero-inner .btn-out,.hero-inner .searchbtn{width:100%;text-align:center}}
html,body{overflow-x:clip}
/* help cards — cream typographic cards, hover turns orange + shows "View more" (matches live) */
/* ---- LISTINGS (live): dark filter bar + price-on-image cards, no title band ---- */
.lfilter{background:var(--dark)}
.lfilter .in{padding:18px 16px}
.lfbar{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.lf-loc{position:relative;flex:1;min-width:220px;display:flex;align-items:center;background:#fff;border-radius:8px;padding:0 12px}
.lf-ic{width:18px;height:18px;color:var(--mut);flex:none}
.lf-loc input{flex:1;border:0;background:transparent;padding:13px 10px;font:inherit;outline:none;min-width:0}
.lf-sel{border:0;border-radius:8px;background:#fff;padding:13px 14px;font:inherit;color:var(--ink);cursor:pointer;min-width:150px}
.lf-btn{border:0;border-radius:8px;padding:13px 28px;font:inherit;font-weight:800;cursor:pointer;background:var(--accent);color:#fff}
.lf-btn.ghost{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.42)}
.listhead{font-family:Lato;font-weight:800;font-size:28.125px;color:var(--head);letter-spacing:-.025em;margin:34px 0 22px}
.pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;padding:0 0 60px}
.pcard{display:flex;flex-direction:column;border-radius:10px;overflow:hidden;background:#fff;border:1px solid var(--line);transition:.18s}
.pcard:hover{box-shadow:0 12px 32px rgba(0,0,0,.12);transform:translateY(-2px)}
.pcard-img{position:relative;aspect-ratio:3/2;background:#EEE9DF;overflow:hidden}
.pcard-img img{width:100%;height:100%;object-fit:cover;display:block}
.pcard-price{position:absolute;left:0;bottom:0;background:rgba(26,26,26,.82);color:#fff;font-family:Lato;font-weight:800;font-size:18px;padding:8px 14px;border-top-right-radius:10px}
.pcard-price small{font-size:11px;font-weight:700;opacity:.85}
.pcard-heart{position:absolute;top:12px;right:12px;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.92);display:flex;align-items:center;justify-content:center}
.pcard-heart svg{width:18px;height:18px;fill:none;stroke:var(--mut);stroke-width:2}
.pc-badge{position:absolute;top:12px;left:12px;font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;padding:5px 11px;border-radius:999px;color:#fff}
.pc-badge.agreed{background:var(--dark)}
.pc-badge.soon{background:var(--accent)}
.pcard-body{padding:16px 18px 20px}
.pcard-addr{font-family:Lato;font-weight:700;font-size:16px;color:var(--ink);line-height:1.3}
.pcard-loc{font-size:13px;color:var(--mut);margin:3px 0 12px}
.pcard-meta{display:flex;gap:16px;font-size:13px;color:var(--mut);border-top:1px solid var(--line);padding-top:11px}
@media(max-width:1024px){.pgrid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:820px){.lf-loc{flex:1 1 100%}.lf-sel{flex:1}.pgrid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.pgrid{grid-template-columns:1fr}.lfbar>*{flex:1 1 100%}.lf-btn{flex:1}}
/* ---- NEWS ARTICLE (live): centred single-column, no title band/breadcrumb/sidebar ---- */
.nart-head{text-align:center;max-width:820px;margin:0 auto;padding:50px 0 6px}
.nart-head h1{font-family:Lato;font-weight:800;font-size:33.75px;color:var(--head);letter-spacing:-.025em;line-height:1.12;margin:0 0 12px}
.nart-date{font-size:13px;color:var(--accent);font-weight:800;text-transform:uppercase;letter-spacing:.06em}
.nart-body{max-width:820px;margin:0 auto;padding:24px 0 64px}
.nart-body.prose{max-width:820px}
.nart-body .bhero-img{margin:6px 0 30px}
@media(max-width:560px){.nart-head h1{font-size:27px}.nart-head{padding:34px 0 4px}}
/* ---- CONTACT (live): centred hero, no title band ---- */
.chero{background:var(--paper);border-bottom:1px solid var(--line);text-align:center}
.chero .in{padding:54px 16px 44px}
.chero h1{font-family:Lato;font-weight:800;font-size:45px;color:var(--head);letter-spacing:-.025em;line-height:1.05;margin:0 0 14px}
.chero .cmeta{font-size:18px;color:var(--body)}
.chero .cmeta a{color:var(--accent)}.cmap{margin:18px 0 22px;border-radius:10px;overflow:hidden;line-height:0}.cmap iframe{width:100%;height:260px;border:0;display:block}
@media(max-width:560px){.chero h1{font-size:30px}}

/* ===== BATCH 2: live-style listing controls + card carousel + detail gallery ===== */
.lcontrols{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin:30px 0 18px}
.lcontrols .listhead{margin:0}
.lctl-r{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.lctl{display:inline-flex;align-items:center;gap:7px;background:#fff;border:1px solid var(--line);border-radius:8px;padding:9px 14px;font:inherit;font-size:13px;font-weight:700;color:var(--ink);cursor:pointer}
.lctl svg{width:15px;height:15px}
.lctl:hover{border-color:var(--accent);color:var(--accent)}
.lctl.on{background:var(--accent);color:#fff;border-color:var(--accent)}
.sortwrap{gap:6px}
.sortwrap select{border:0;background:transparent;font:inherit;font-weight:800;color:var(--accent);cursor:pointer;outline:none}
/* card image carousel */
.pcard-img .pcs{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .25s}
.pcard-img .pcs.on{opacity:1}
.pcarw{position:absolute;top:50%;transform:translateY(-50%);width:32px;height:32px;border-radius:50%;border:0;background:rgba(255,255,255,.86);color:var(--ink);font-size:18px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s;z-index:3}
.pcard:hover .pcarw{opacity:1}
.pcarw.prev{left:10px}.pcarw.next{right:10px}
.pcard-dots{position:absolute;left:0;right:0;bottom:8px;display:flex;gap:5px;justify-content:center;z-index:3}
.pcard-dots i{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.55)}
.pcard-dots i.on{background:#fff}
/* ---- detail page ---- */
.detailx{padding:26px 0 64px}
.dxtop{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}
.dxback{color:var(--accent);font-weight:700;font-size:14px}
.dxrefr{color:var(--mut);font-size:13px}
.dxtabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}
.dxtab{border:0;background:#F1ECE2;color:var(--ink);font:inherit;font-weight:700;font-size:13px;padding:9px 16px;border-radius:8px 8px 0 0;cursor:pointer}
.dxtab.on{background:var(--dark);color:#fff}
.dxpane{display:none}
.dxpane.on{display:block}
.dxstage{position:relative;aspect-ratio:16/10;background:#EEE9DF;border-radius:10px;overflow:hidden}
.dxs{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .3s}
.dxs.on{opacity:1}
.dxnoimg{opacity:1}
.dxnav{position:absolute;top:50%;transform:translateY(-50%);width:46px;height:46px;border-radius:50%;border:0;background:rgba(255,255,255,.9);color:var(--ink);font-size:24px;cursor:pointer;z-index:3;display:flex;align-items:center;justify-content:center}
.dxnav.prev{left:14px}.dxnav.next{right:14px}
.dxcount{position:absolute;right:14px;bottom:14px;background:rgba(26,26,26,.8);color:#fff;font-size:13px;font-weight:700;padding:5px 12px;border-radius:999px;z-index:3}
.dxbadge{position:absolute;top:14px;left:14px;font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;padding:6px 12px;border-radius:999px;color:#fff;z-index:3}
.dxbadge.tolet{background:var(--accent)}.dxbadge.agreed{background:var(--dark)}.dxbadge.soon{background:var(--accent)}
.dxthumbs{display:flex;gap:8px;overflow-x:auto;padding:10px 0 2px}
.dxt{flex:0 0 auto;width:88px;height:62px;border:2px solid transparent;border-radius:6px;overflow:hidden;background:#EEE9DF;cursor:pointer;padding:0}
.dxt.on{border-color:var(--accent)}
.dxt img{width:100%;height:100%;object-fit:cover}
.dxfp{width:100%;border-radius:10px;border:1px solid var(--line);margin-bottom:12px}
.dxvt,.dxmap{position:relative;aspect-ratio:16/9;border-radius:10px;overflow:hidden;background:#000}
.dxvt iframe,.dxmap iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.dxmap{aspect-ratio:16/8;background:#e8e8e8}
.dxlayout{display:grid;grid-template-columns:1fr 360px;gap:44px;padding-top:30px}
.dxh1{font-family:Lato;font-weight:900;font-size:30px;color:var(--ink);margin:20px 0 4px;letter-spacing:-.02em;line-height:1.1}
.dxsub{color:var(--mut);font-size:15px;margin-bottom:18px}
.dxfacts{display:flex;gap:30px;flex-wrap:wrap;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:16px 0;margin-bottom:8px}
.dxfact b{display:block;font-family:Lato;font-weight:900;font-size:20px;color:var(--ink)}
.dxfact span{font-size:12px;color:var(--mut);text-transform:uppercase;letter-spacing:.05em}
.dxsec{font-family:Lato;font-weight:900;font-size:21px;color:var(--head);margin:30px 0 12px}
.prose-d{font-size:15.5px;line-height:1.6}
.prose-d p{margin:0 0 14px}
.dxfeatures{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:8px 24px}
.dxfeatures li{position:relative;padding-left:22px;font-size:15px;line-height:1.4}
.dxfeatures li::before{content:"";position:absolute;left:0;top:7px;width:9px;height:9px;border-radius:2px;background:var(--accent)}
.dxside{align-self:start;position:sticky;top:96px;border:1px solid var(--line);border-radius:14px;background:#fff;padding:24px;box-shadow:0 10px 30px rgba(0,0,0,.05)}
.dxprice{font-family:Lato;font-weight:900;font-size:30px;color:var(--ink)}
.dxprice small{font-size:13px;color:var(--mut);font-weight:700}
.dxsstatus{display:inline-block;font-size:12px;font-weight:800;color:var(--accent);text-transform:uppercase;letter-spacing:.05em;margin:4px 0 16px}
.dxcta{display:block;text-align:center;background:var(--accent);color:#fff;font-weight:800;padding:14px;border-radius:999px;margin-bottom:10px}
.dxcta.alt{background:#fff;color:var(--ink);border:1px solid var(--line)}
.dxcta-row{display:flex;gap:10px}
.dxcta2{flex:1;background:#fff;border:1px solid var(--line);border-radius:999px;padding:11px;font:inherit;font-weight:700;color:var(--ink);cursor:pointer}
.dxcta2.on{background:var(--accent);color:#fff;border-color:var(--accent)}
.dxkvs{margin-top:18px;font-size:14px}
.dxkv{display:flex;justify-content:space-between;gap:12px;padding:9px 0;border-top:1px solid var(--line);color:var(--mut)}
.dxkv b{color:var(--ink);text-align:right}
.dxenqsec{margin-top:10px}
.dxenqsec .enq{position:static;box-shadow:none;padding:0;border:0}
.dxblock{padding-top:10px}
.dxsimilar{padding-top:14px}
.dxsimilar .pgrid{padding-bottom:0}
@media(max-width:980px){.dxlayout{grid-template-columns:1fr;gap:28px}.dxside{position:static}.dxfeatures{grid-template-columns:1fr}}
@media(max-width:560px){.dxstage{aspect-ratio:4/3}.dxh1{font-size:24px}.lcontrols{flex-direction:column;align-items:flex-start}}


/* S53d: home Compliance-first rebuilt as a responsive HTML card (was a baked PNG whose text hugged the edge); internal padding keeps text inset at any width */
.habout-card{background:#F3EEE2;border-radius:10px;padding:46px 44px;display:flex;flex-direction:column;justify-content:center;min-height:360px}
.habout-card .hc-wm{align-self:flex-start;font-size:11px;letter-spacing:.14em;color:#8a8276;font-weight:800;border-bottom:1.6px solid var(--accent);padding-bottom:6px;margin-bottom:30px}
.habout-card .hc-h{font-family:Lato;font-weight:900;font-size:40px;line-height:1.06;letter-spacing:-.02em}
.habout-card .hc-h b{display:block;color:var(--ink);font-weight:900}
.habout-card .hc-h i{display:block;color:var(--accent);font-style:normal;font-weight:900}
.habout-card .hc-sub{margin:22px 0 0;color:var(--mut);font-size:15px;line-height:1.5}
@media(max-width:560px){.habout-card{padding:34px 26px;min-height:0}.habout-card .hc-h{font-size:30px}}

/* lead-capture forms */
.enq .lead-msg,.news .lead-msg{margin-top:10px;font-size:14px;line-height:1.4;min-height:1px}
.lead-msg.ok{color:#1a7f37}
.lead-msg.err{color:#b42318}
.hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden}
form.lead-form button[disabled],form.news-form button[disabled]{opacity:.6;cursor:default}

/* ---------- mobile calibration ---------- */
@media(max-width:1024px){.rail{display:none}}
@media(max-width:640px){.in{padding:0 20px}.hero-inner{padding:0 20px}}
@media(max-width:640px){.detailx{padding-bottom:48px}}
/* iOS Safari auto-zooms inputs <16px on focus — force 16px on touch widths (no desktop change) */
@media(max-width:820px){input,textarea,select{font-size:16px!important}}
@media(max-width:820px){
  body.menu-open{overflow:hidden}
  body.menu-open .mobnav{max-height:calc(100vh - 96px);overflow-y:auto;-webkit-overflow-scrolling:touch}
  .mobnav>ul>li.has-sub{position:relative}
  .mobnav .msub{position:absolute;top:3px;right:10px;background:none;border:0;color:#fff;font-size:22px;line-height:1;width:46px;height:46px;cursor:pointer;opacity:.85}
  .mobnav>ul>li.open>.msub{transform:rotate(180deg);color:var(--accent)}
  .mobnav .sub{display:none}
  .mobnav>ul>li.open>.sub{display:block}
}

/* ---------- Street View launch panel (keyless fallback) ---------- */
.dxsv{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:9px;min-height:420px;background:#f1efe9;border:1px solid var(--line);border-radius:8px;color:var(--ink);text-align:center;text-decoration:none;transition:background .15s,color .15s}
.dxsv:hover{background:#e9e5dc;color:var(--accent)}
.dxsv b{font-family:Lato;font-weight:900;font-size:20px}
.dxsv-sub{color:var(--mut);font-size:14px;max-width:300px;padding:0 16px}
@media(max-width:640px){.dxsv{min-height:320px}}

/* ---------- home search autocomplete ---------- */
.hsr{position:relative;flex:1;min-width:0;display:flex}
.hsr>input{flex:1;border:0;background:transparent;padding:14px 10px;font:inherit;min-width:0;outline:none}
.hsr-drop{display:none;position:absolute;top:calc(100% + 12px);left:0;right:0;min-width:240px;background:#fff;border:1px solid var(--line);border-radius:10px;box-shadow:0 18px 50px rgba(0,0,0,.18);z-index:30;overflow:hidden;text-align:left}
.hsr-drop.on{display:block}
.hsr-drop button{display:block;width:100%;text-align:left;background:none;border:0;border-bottom:1px solid #F1ECE3;padding:13px 18px;font:inherit;font-weight:700;color:var(--ink);cursor:pointer}
.hsr-drop button:last-child{border-bottom:0}
.hsr-drop button:hover{background:#F6F1E8;color:var(--accent)}
@media(max-width:640px){.searchbar .searchbtn{width:auto;padding:13px 22px}}

/* ---------- saved properties (shortlist) + share popover (S58) ---------- */
.pcard-heart{cursor:pointer;transition:transform .12s,background .12s}
.pcard-heart:hover{background:#fff;transform:scale(1.08)}
.pcard-heart.on svg{fill:var(--accent);stroke:var(--accent)}
.ic-saved{position:relative;text-decoration:none}
.ic-saved svg{width:17px;height:17px;fill:none;stroke:currentColor;stroke-width:2}
.ic-saved.has svg{fill:#fff}
.ic-saved .saved-count{position:absolute;top:-4px;right:-4px;min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:#fff;color:var(--dark);font-size:10px;font-weight:800;line-height:16px;text-align:center}
.mob-saved .saved-count{color:var(--accent);margin-left:4px}
.dxsave{display:flex;align-items:center;justify-content:center;gap:7px}
.dxsave svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:2}
.dxsave.on{background:var(--accent);color:#fff;border-color:var(--accent)}
.dxsave.on svg{fill:#fff;stroke:#fff}
.dxshare{position:relative;flex:1;display:flex}
.dxshare-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:7px}
.dxshare-btn svg{width:15px;height:15px}
.dxshare-pop{position:absolute;bottom:calc(100% + 8px);left:0;right:0;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:0 16px 38px rgba(0,0,0,.17);padding:6px;z-index:30;display:flex;flex-direction:column;gap:1px}
.dxshare-pop[hidden]{display:none}
.dxsh{display:block;text-align:left;padding:11px 14px;border-radius:8px;border:0;background:none;font:inherit;font-size:14px;font-weight:700;color:var(--ink);cursor:pointer;text-decoration:none}
.dxsh:hover{background:#F6F1E8;color:var(--accent)}
.dxsh.dxcopy.ok{color:var(--accent)}
.savedx{padding-top:30px;padding-bottom:64px}
.savedx .listhead{margin:8px 0 22px}
.savedempty{background:var(--soft);border:1px solid var(--line);border-radius:12px;padding:32px;color:var(--mut);font-size:15px;line-height:1.6;max-width:600px}
.savedempty a{color:var(--accent);font-weight:800;text-decoration:none}
.pcard-saved .pcard-img{display:block}
.pcard-saved .pcard-addr{display:block;text-decoration:none}
.pcard-saved .savedrm{margin-top:13px;background:none;border:1px solid var(--line);border-radius:999px;padding:8px 16px;font:inherit;font-size:13px;font-weight:700;color:var(--mut);cursor:pointer}
.pcard-saved .savedrm:hover{border-color:var(--accent);color:var(--accent)}
.savemodal{position:fixed;inset:0;z-index:1000;background:rgba(26,26,26,.55);display:flex;align-items:center;justify-content:center;padding:20px}
.savemodal[hidden]{display:none}
.savemodal-card{background:#fff;border-radius:16px;max-width:418px;width:100%;padding:32px 28px 26px;position:relative;text-align:center;box-shadow:0 24px 64px rgba(0,0,0,.32)}
.savemodal-x{position:absolute;top:12px;right:15px;background:none;border:0;font-size:26px;line-height:1;color:var(--mut);cursor:pointer}
.savemodal-ic{width:54px;height:54px;border-radius:50%;background:#F6F1E8;display:flex;align-items:center;justify-content:center;margin:0 auto 14px}
.savemodal-ic svg{width:26px;height:26px;fill:var(--accent);stroke:var(--accent)}
.savemodal-card h3{font-family:Lato;font-weight:900;font-size:22px;color:var(--ink);margin:0 0 8px}
.savemodal-card>p{color:var(--body);font-size:14.5px;line-height:1.5;margin:0 0 16px}
.savemodal-benefits{list-style:none;padding:0;margin:0 0 18px;text-align:left}
.savemodal-benefits li{position:relative;padding:5px 0 5px 27px;font-size:14px;color:var(--body)}
.savemodal-benefits li:before{content:"\2713";position:absolute;left:2px;top:5px;color:var(--accent);font-weight:900}
.save-form input:not(.hp){width:100%;border:1px solid var(--line);border-radius:999px;padding:13px 18px;margin:0 0 11px;font:inherit;color:var(--ink)}
.save-form .send{display:block;width:100%;background:var(--accent);color:#fff;border:0;font-weight:800;font-size:15px;padding:14px;border-radius:999px;cursor:pointer}
.savemodal-skip{display:block;width:100%;background:none;border:0;color:var(--mut);font:inherit;font-size:13px;font-weight:700;padding:11px 0 0;cursor:pointer;text-decoration:underline}
body.modal-lock{overflow:hidden}
/* ---------- tour pop-out lightbox (full-screen, matches live) ---------- */
.dxtab-lb{position:relative;padding-right:30px}
.dxtab-lb:after{content:"\2197";position:absolute;right:11px;top:50%;transform:translateY(-50%);font-size:12px;opacity:.7}
.dxlb{position:fixed;inset:0;z-index:1200;background:#fff;display:flex;flex-direction:column}
.dxlb[hidden]{display:none}
.dxlb-head{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:15px 22px;border-bottom:1px solid var(--line);flex:none}
.dxlb-title{font-family:Lato;font-weight:900;font-size:20px;color:var(--ink)}
.dxlb-x{background:none;border:0;font-size:30px;line-height:1;color:var(--ink);cursor:pointer;width:44px;height:44px;flex:none}
.dxlb-body{flex:1;position:relative;background:#000;min-height:0}
.dxlb-body iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* S65: cap detail photo gallery height so the photo + thumbnail strip fit the viewport on desktop (16/10 overflowed wide screens) */
@media(min-width:561px){.dxstage{max-height:max(380px,calc(100vh - 330px))}}
/* S65b: detail gallery moved into the left grid column beside the booking sidebar; min-width:0 lets the 1fr track shrink so the thumbnail strip can't blow out the grid */
.dxinfo{min-width:0}
.dxthumbs{min-width:0}
/* S65d: detail refinements - photo full column width (flush with the thumbnail wheel) + slightly taller; Bed/Bath/Size/Reception moved into the sidebar and centred evenly across */
.dxstage{width:100%}
.dxlayout{padding-top:12px}
@media(min-width:561px){.dxstage{max-height:max(380px,calc(100vh - 315px))}}
.dxside .dxfacts{display:flex;justify-content:space-between;gap:6px;flex-wrap:nowrap;margin:8px 0 4px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:14px 0}
.dxside .dxfacts>*{flex:1 1 0;min-width:0;text-align:center}
/* S65g: gallery photos pulled at full hi-res (uncropped); expand button (top-right of the stage) opens the WHOLE photo in the full-screen lightbox with prev/next. Gallery itself stays edge-to-edge (cover). */
.dxexpand{position:absolute;top:12px;right:12px;z-index:5;width:38px;height:38px;display:flex;align-items:center;justify-content:center;border:0;border-radius:8px;background:rgba(0,0,0,.5);color:#fff;cursor:pointer;transition:background .15s}
.dxexpand:hover{background:rgba(0,0,0,.72)}
.dxlb-img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain}
.dxlb-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:2;width:46px;height:46px;border:0;border-radius:50%;background:rgba(255,255,255,.92);color:#1a1a1a;font-size:24px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center}
.dxlb-nav:hover{background:#fff}
.dxlb-nav.prev{left:16px}
.dxlb-nav.next{right:16px}
@media(max-width:560px){.dxexpand{top:8px;right:8px}.dxlb-nav{width:40px;height:40px;font-size:20px}}

/* ---- Meet The Team roster (S71) ---- */
.tm-h{font-family:Lato,system-ui,sans-serif;font-weight:900;font-size:26px;letter-spacing:.02em;color:var(--ink);margin:38px 0 20px}
.tmgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px 22px;margin:18px 0 12px}
.tmcard{margin:0;text-align:center}
.tmpic{width:100%;aspect-ratio:1/1;overflow:hidden;background:transparent}
.tmpic img{width:100%;height:100%;object-fit:cover;display:block}
.tmcard figcaption{margin-top:13px}
.tmname{display:block;font-family:Lato,system-ui,sans-serif;font-weight:800;font-size:16px;color:var(--ink)}
.tmrole{display:block;color:var(--mut);font-size:13.5px;line-height:1.4;margin-top:3px}
@media(max-width:860px){.tmgrid{grid-template-columns:repeat(3,1fr);gap:24px 18px}}
@media(max-width:560px){.tmgrid{grid-template-columns:1fr 1fr;gap:20px 14px}.tm-h{font-size:23px}}

/* Accessibility: keyboard skip link (offscreen until focused) */
.skip-link{position:absolute;left:-9999px;top:0;z-index:200;background:var(--accent);color:#fff;padding:10px 16px;font-weight:700;text-decoration:none;border-radius:0 0 6px 0}
.skip-link:focus{left:0}
