/* =======================================================================
   THEME — central variables: change a few lines per city and all follows
   ======================================================================= */
:root{
  --accent:#0a6ebd;          /* Atlantic blue — city accent colour */
  --accent-dark:#074e85;
  --ink:#16202b;
  --muted:#566373;
  --bg:#ffffff;
  --bg-soft:#f4f7fa;
  --bg-card:#ffffff;
  --border:#e3e8ee;
  --gold:#b8860b;
  --radius:16px;
  --shadow:0 6px 28px rgba(20,30,45,.08);
  --shadow-lg:0 18px 50px rgba(20,30,45,.16);
  --max:1180px;
  --font:"Segoe UI",system-ui,-apple-system,Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font);color:var(--ink);background:var(--bg);line-height:1.65;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--max);margin:0 auto;padding:0 22px}
section{padding:72px 0}
h2{font-size:clamp(1.7rem,3vw,2.4rem);line-height:1.2;margin-bottom:8px;letter-spacing:-.5px}
.eyebrow{display:inline-block;font-size:.78rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--accent);margin-bottom:10px}
.lead{color:var(--muted);font-size:1.05rem;max-width:680px;margin-bottom:36px}

/* ---------- NAV ---------- */
header.nav{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{font-weight:800;font-size:1.15rem;letter-spacing:-.5px}
.brand span{color:var(--accent)}
.navlinks{display:flex;gap:22px;align-items:center}
.navlinks a{font-size:.92rem;font-weight:600;color:var(--muted);transition:color .2s}
.navlinks a:hover{color:var(--accent)}
.burger{display:none;font-size:1.5rem;background:none;border:0;cursor:pointer}

/* ---------- NAV DROPDOWN (La Rochelle site menu) ---------- */
.dropdown{position:relative}
.dropdown>.dropbtn{font-size:.92rem;font-weight:700;color:#fff;background:var(--accent);border:0;border-radius:50px;padding:8px 16px;cursor:pointer;font-family:inherit;display:inline-flex;align-items:center;gap:6px}
.dropdown>.dropbtn:hover{background:var(--accent-dark)}
.dropmenu{position:absolute;top:calc(100% + 10px);right:0;background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-lg);padding:14px;width:520px;max-width:88vw;display:none;grid-template-columns:repeat(3,1fr);gap:16px;z-index:200;max-height:70vh;overflow-y:auto}
.dropdown.open .dropmenu{display:grid}
.dropcol h5{font-size:.72rem;text-transform:uppercase;letter-spacing:1px;color:var(--accent);margin-bottom:8px;border-bottom:1px solid var(--border);padding-bottom:5px}
.dropcol a{display:block;font-size:.86rem;font-weight:500;color:var(--ink);padding:4px 0;transition:color .15s}
.dropcol a:hover{color:var(--accent)}
.subacc{border:0}
.subacc summary{list-style:none;cursor:pointer;font-size:.86rem;font-weight:600;color:var(--ink);padding:4px 0;display:flex;align-items:center;gap:6px;transition:color .15s}
.subacc summary::-webkit-details-marker{display:none}
.subacc summary::before{content:"▸";color:var(--accent);font-size:.85rem;transition:transform .2s}
.subacc[open] summary::before{transform:rotate(90deg)}
.subacc summary:hover{color:var(--accent)}
.subacc-body{margin:4px 0 0 14px;padding-left:10px;border-left:1px solid var(--border);max-height:260px;overflow-y:auto}
.subacc-body a{font-size:.82rem;font-weight:500;padding:3px 0}
@media(max-width:860px){
  .navlinks{position:absolute;top:64px;left:0;right:0;background:#fff;flex-direction:column;gap:0;padding:8px 0;border-bottom:1px solid var(--border);box-shadow:var(--shadow);transform:translateY(-150%);transition:transform .3s;pointer-events:none;align-items:stretch;max-height:85vh;overflow-y:auto}
  .navlinks.open{transform:translateY(0);pointer-events:auto}
  .navlinks>a{padding:14px 22px;border-bottom:1px solid var(--bg-soft)}
  .burger{display:block}
  .dropdown{width:100%}
  .dropdown>.dropbtn{width:calc(100% - 44px);margin:10px 22px;justify-content:center}
  .dropmenu{position:static;width:auto;grid-template-columns:1fr 1fr;box-shadow:none;border:0;border-top:1px solid var(--bg-soft);border-radius:0;margin:0 12px}
}

/* ---------- HERO (Wikimedia Commons photo) ---------- */
.hero{position:relative;min-height:78vh;display:flex;align-items:center;color:#fff;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;
  /* WIKIMEDIA COMMONS photo — DIRECT upload.wikimedia.org URL (stable, displays reliably in CSS) */
  background-image:url("https://upload.wikimedia.org/wikipedia/commons/thumb/9/91/Entrance_La_Rochelle_old_harbor.jpg/3840px-Entrance_La_Rochelle_old_harbor.jpg");
  transform:scale(1.05)}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,16,28,.32) 0%,rgba(8,16,28,.5) 55%,rgba(8,16,28,.76) 100%)}
.hero .wrap{position:relative;z-index:2}
.hero h1{font-size:clamp(2.4rem,6vw,4.4rem);line-height:1.05;font-weight:800;letter-spacing:-1.5px;max-width:15ch;text-shadow:0 2px 30px rgba(0,0,0,.4)}
.hero h1 em{color:#bfe3ff;font-style:italic;font-weight:800}
.hero p{font-size:clamp(1rem,2vw,1.25rem);max-width:54ch;margin:20px 0 32px;color:#f0f4f8;text-shadow:0 1px 12px rgba(0,0,0,.5)}
.hero-badge{display:inline-block;font-size:.75rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.3);padding:6px 16px;border-radius:50px;margin-bottom:22px}
.btns{display:flex;gap:14px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border-radius:50px;font-weight:700;font-size:.95rem;cursor:pointer;transition:transform .18s,box-shadow .18s;border:0}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 8px 24px rgba(10,110,189,.4)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(10,110,189,.5)}
.btn-ghost{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.4);backdrop-filter:blur(4px)}
.btn-ghost:hover{background:rgba(255,255,255,.22)}
.hero-credit{position:absolute;bottom:8px;right:12px;z-index:3;font-size:.66rem;color:rgba(255,255,255,.6)}
.hero-credit a{text-decoration:underline}

/* ---------- BOOKING ENGINE ---------- */
.booking{background:var(--bg-soft);position:relative;margin-top:-1px}
.booking-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:28px;margin-top:-90px;position:relative;z-index:5}
.tabs{display:flex;gap:6px;margin-bottom:22px;flex-wrap:wrap}
.tab{padding:10px 20px;border-radius:50px;font-weight:700;font-size:.9rem;cursor:pointer;background:var(--bg-soft);color:var(--muted);border:1px solid transparent;transition:.2s}
.tab.active{background:var(--accent);color:#fff}
.bform{display:grid;grid-template-columns:2fr 1fr 1fr auto;gap:14px;align-items:end}
@media(max-width:820px){.bform{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.bform{grid-template-columns:1fr}}
.field label{display:block;font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin-bottom:6px}
.field input{width:100%;padding:13px 14px;border:1px solid var(--border);border-radius:10px;font-size:.95rem;font-family:inherit;background:var(--bg-soft)}
.field input:focus{outline:none;border-color:var(--accent);background:#fff}
.search-btn{display:inline-flex;align-items:center;justify-content:center;padding:13px 26px;background:var(--accent);color:#fff;border:0;border-radius:10px;font-weight:700;cursor:pointer;font-size:.95rem;white-space:nowrap;transition:.2s;text-decoration:none;line-height:1.2}
.search-btn:hover{background:var(--accent-dark)}
.compare{margin-top:18px;font-size:.85rem;color:var(--muted);display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.compare a{color:var(--accent);font-weight:600}
.compare a:hover{text-decoration:underline}

/* ---------- PLACE CARDS ---------- */
.grid{display:grid;gap:20px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
@media(max-width:860px){.grid-3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.grid-3,.grid-2{grid-template-columns:1fr}}
.place{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:24px;transition:transform .2s,box-shadow .2s;display:block;height:100%}
.place:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:transparent}
.place .ico{font-size:2rem;margin-bottom:12px}
.place .kicker{font-size:.7rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent);margin-bottom:6px}
.place h3{font-size:1.15rem;margin-bottom:8px}
.place p{font-size:.92rem;color:var(--muted)}
.place .tag{display:inline-block;margin-top:12px;font-size:.78rem;font-weight:600;color:var(--ink);background:var(--bg-soft);padding:4px 12px;border-radius:50px}

/* ---------- PARTNERS ---------- */
.partners{background:var(--bg-soft)}
.partner{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:26px;transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column;height:100%}
.partner:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.partner .ptitle{font-weight:800;font-size:1.1rem;margin-bottom:6px;display:flex;align-items:center;gap:9px}
.partner .ptitle img{width:22px;height:22px;border-radius:5px;flex-shrink:0;object-fit:contain}
.partner p{font-size:.9rem;color:var(--muted);flex:1;margin-bottom:16px}
.partner .go{font-weight:700;color:var(--accent);font-size:.9rem}

/* ---------- HISTORY / TEXT ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
@media(max-width:820px){.split{grid-template-columns:1fr;gap:28px}}
.prose p{margin-bottom:16px;color:var(--muted)}
.prose p strong{color:var(--ink)}
.factbox{background:var(--bg-soft);border-radius:var(--radius);padding:28px;border-left:4px solid var(--accent)}
.factbox h4{margin-bottom:16px;text-transform:uppercase;letter-spacing:1px;font-size:.85rem;color:var(--accent)}
.factrow{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--border);font-size:.92rem}
.factrow:last-child{border:0}
.factrow b{color:var(--ink)}

/* ---------- PRACTICAL INFO (accordion) ---------- */
.acc{border:1px solid var(--border);border-radius:12px;margin-bottom:12px;overflow:hidden;background:#fff}
.acc summary{padding:18px 22px;font-weight:700;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;font-size:1rem}
.acc summary::-webkit-details-marker{display:none}
.acc summary::after{content:"+";font-size:1.4rem;color:var(--accent);transition:transform .2s}
.acc[open] summary::after{transform:rotate(45deg)}
.acc .body{padding:0 22px 20px;color:var(--muted);font-size:.93rem}
.acc .body ul{margin:8px 0 0 18px}
.acc .body li{margin-bottom:6px}

/* ---------- EMERGENCY ---------- */
.emergency{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:24px}
@media(max-width:620px){.emergency{grid-template-columns:repeat(2,1fr)}}
.ecard{background:#fff;border:1px solid var(--border);border-radius:12px;padding:18px;text-align:center}
.ecard .num{font-size:1.9rem;font-weight:800;color:var(--accent)}
.ecard .lbl{font-size:.82rem;color:var(--muted);margin-top:4px}

/* ---------- WEATHER WIDGET ---------- */
.weather-card{background:linear-gradient(135deg,#102234 0%,#15324d 100%);border-radius:var(--radius);padding:32px;color:#fff;box-shadow:var(--shadow-lg);position:relative;overflow:hidden}
.weather-top{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:18px}
.weather-main{display:flex;align-items:center;gap:20px}
.weather-icon{font-size:3.6rem;line-height:1}
.weather-temp{font-size:3rem;font-weight:800;letter-spacing:-1px;line-height:1}
.weather-temp sup{font-size:1.3rem;font-weight:600;top:-1.1em}
.weather-desc{color:#a9c2d8;font-size:1rem;margin-top:2px}
.weather-place{text-align:right;font-size:.95rem}
.weather-place .city{font-weight:700;font-size:1.05rem}
.weather-place .meta{color:#85a0b8;font-size:.82rem;margin-top:2px}
.weather-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:28px}
@media(max-width:620px){.weather-grid{grid-template-columns:repeat(2,1fr)}}
.weather-cell{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:16px;text-align:center}
.weather-cell .ci{font-size:1.5rem;margin-bottom:6px}
.weather-cell .cl{font-size:.72rem;text-transform:uppercase;letter-spacing:1px;color:#85a0b8}
.weather-cell .cv{font-size:1.25rem;font-weight:800;margin-top:3px}
.weather-foot{display:flex;gap:12px;flex-wrap:wrap;margin-top:20px;align-items:center}
.weather-foot a,.weather-foot button{font-size:.85rem;font-weight:600;color:#fff;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:50px;padding:8px 18px;cursor:pointer;transition:.2s;text-decoration:none;display:inline-flex;align-items:center;gap:6px;font-family:inherit}
.weather-foot a:hover,.weather-foot button:hover{background:rgba(255,255,255,.2)}
.weather-src{font-size:.72rem;color:#85a0b8;margin-left:auto}
.weather-src a{color:#a9c2d8;text-decoration:underline}
.weather-loading,.weather-error{color:#a9c2d8;font-size:.95rem;padding:10px 0}

/* ---------- HISTORICAL GREY CARDS (Culture & Heritage) ---------- */
.histsec{background:var(--bg-soft)}
.histgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:860px){.histgrid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.histgrid{grid-template-columns:1fr}}
.histcard{background:#eef1f3;border:1px solid var(--border);border-radius:var(--radius);padding:26px;height:100%;transition:transform .2s,box-shadow .2s}
.histcard:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.histcard .hico{font-size:1.8rem;margin-bottom:10px}
.histcard h3{font-size:1.15rem;margin-bottom:10px}
.histcard p{font-size:.93rem;color:var(--muted);margin-bottom:12px}
.histcard .links{display:flex;flex-wrap:wrap;gap:6px 14px;font-size:.86rem;font-weight:600}
.histcard .links a{color:var(--accent)}
.histcard .links a:hover{text-decoration:underline}

/* ---------- GLOBAL VISIT LIST BADGE SECTION ---------- */
.gvl{background:var(--bg-soft);border-top:1px solid var(--border)}
.gvl-card{display:flex;align-items:center;gap:26px;flex-wrap:wrap;justify-content:center;text-align:center;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow);max-width:760px;margin:0 auto}
.gvl-badge{flex-shrink:0;width:78px;height:78px;border-radius:18px;background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:#fff;display:flex;align-items:center;justify-content:center;font-size:2.4rem;box-shadow:0 8px 22px rgba(10,110,189,.35)}
.gvl-body{flex:1;min-width:240px;text-align:left}
.gvl-body .kick{font-size:.72rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent);margin-bottom:6px}
.gvl-body h3{font-size:1.3rem;margin-bottom:8px;letter-spacing:-.3px}
.gvl-body p{font-size:.95rem;color:var(--muted);margin-bottom:14px}
.gvl-body p a{color:var(--accent);font-weight:600;text-decoration:underline}
.gvl-body a.gvl-link{display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:.92rem;color:#fff;background:var(--accent);padding:11px 22px;border-radius:50px;text-decoration:none;transition:transform .18s,box-shadow .18s}
.gvl-body a.gvl-link:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(10,110,189,.4)}
.gvl-links{margin:4px 0 18px;font-size:.9rem;color:var(--muted);display:flex;gap:6px 10px;flex-wrap:wrap;align-items:center}
.gvl-links a{color:var(--accent);font-weight:600}
.gvl-links a:hover{text-decoration:underline}
@media(max-width:560px){.gvl-card{flex-direction:column;text-align:center}.gvl-body{text-align:center}}

/* ---------- DOMAIN FOR SALE ---------- */
.domain{background:linear-gradient(135deg,var(--ink) 0%,#13344a 60%,var(--accent-dark) 130%);color:#fff;position:relative;overflow:hidden}
.domain::before{content:"";position:absolute;top:-40%;right:-10%;width:480px;height:480px;background:radial-gradient(circle,rgba(10,110,189,.4),transparent 70%);pointer-events:none}
.domain .wrap{position:relative;z-index:2}
.domain .eyebrow{color:#8fd0ff}
.domain-inner{display:grid;grid-template-columns:1.3fr 1fr;gap:48px;align-items:center}
@media(max-width:820px){.domain-inner{grid-template-columns:1fr;gap:32px}}
.domain h2{color:#fff;font-size:clamp(1.8rem,3.2vw,2.6rem)}
.domain .dom-name{color:#8fd0ff;font-weight:800}
.domain p.dlead{color:#c5d2de;font-size:1.05rem;margin:14px 0 26px;max-width:54ch}
.domain-points{display:flex;flex-direction:column;gap:14px;margin-bottom:30px}
.dpoint{display:flex;gap:12px;align-items:flex-start;font-size:.95rem;color:#dbe3eb}
.dpoint .dico{font-size:1.2rem;flex-shrink:0;line-height:1.4}
.dpoint b{color:#fff}
.domain-cta{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:var(--radius);padding:30px;text-align:center;backdrop-filter:blur(4px)}
.domain-cta .price-label{font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:#92a3b4}
.domain-cta .dom-big{font-size:1.5rem;font-weight:800;margin:8px 0 4px;word-break:break-all}
.domain-cta .dom-sub{font-size:.88rem;color:#92a3b4;margin-bottom:22px}
.btn-domain{display:inline-flex;align-items:center;justify-content:center;gap:9px;width:100%;padding:16px 24px;background:var(--accent);color:#fff;border-radius:50px;font-weight:800;font-size:1rem;text-decoration:none;transition:transform .18s,box-shadow .18s;box-shadow:0 10px 30px rgba(10,110,189,.45)}
.btn-domain:hover{transform:translateY(-2px);box-shadow:0 14px 36px rgba(10,110,189,.55)}
.domain-cta .secure{font-size:.78rem;color:#92a3b4;margin-top:14px}

/* ---------- FOOTER ---------- */
footer{background:var(--ink);color:#c2cdd9;padding:56px 0 28px}
footer .brand{color:#fff;font-size:1.3rem;margin-bottom:10px}
footer p{font-size:.9rem;max-width:42ch;margin-bottom:22px;color:#92a0b0}
.flinks{display:flex;gap:22px;flex-wrap:wrap;margin-bottom:28px}
.flinks a{font-size:.9rem;color:#c2cdd9;transition:color .2s}
.flinks a:hover{color:#fff}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:20px;font-size:.82rem;color:#7a8696}
.disclaimer{font-size:.78rem;color:#7a8696;margin-top:10px;max-width:80ch}

.toplink{position:fixed;bottom:24px;right:24px;width:46px;height:46px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.3rem;box-shadow:var(--shadow-lg);opacity:0;pointer-events:none;transition:opacity .3s;z-index:90}
.toplink.show{opacity:1;pointer-events:auto}

/* ============== SUBPAGE COMPONENTS (added by Site de claude) ============== */
.subhero{position:relative;min-height:38vh;display:flex;align-items:flex-end;color:#fff;overflow:hidden}
.subhero .hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.04)}
.subhero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,16,28,.30) 0%,rgba(8,16,28,.55) 60%,rgba(8,16,28,.82) 100%)}
.subhero .wrap{position:relative;z-index:2;padding-top:46px;padding-bottom:30px}
.subhero .eyebrow{color:#bfe3ff}
.subhero h1{font-size:clamp(1.8rem,4.4vw,3rem);line-height:1.08;font-weight:800;letter-spacing:-1px;max-width:20ch;text-shadow:0 2px 24px rgba(0,0,0,.4)}
.subhero p.sub{color:#eaf1f8;font-size:1.02rem;margin-top:10px;max-width:60ch;text-shadow:0 1px 10px rgba(0,0,0,.5)}

/* breadcrumb */
.crumb{background:var(--bg-soft);border-bottom:1px solid var(--border)}
.crumb .wrap{display:flex;flex-wrap:wrap;gap:6px;align-items:center;padding-top:12px;padding-bottom:12px;font-size:.85rem;color:var(--muted)}
.crumb a{color:var(--accent);font-weight:600}
.crumb a:hover{text-decoration:underline}
.crumb span.sep{color:var(--border)}
.crumb b{color:var(--ink);font-weight:600}

/* generic content section */
.page section:first-of-type{padding-top:40px}
.contentcard{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.contentcard .pad{padding:28px}
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:760px){.gallery{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.gallery{grid-template-columns:1fr}}
.gallery figure{margin:0;border-radius:12px;overflow:hidden;border:1px solid var(--border);background:var(--bg-soft)}
.gallery figure img{width:100%;height:220px;object-fit:cover;display:block;transition:transform .4s}
.gallery figure:hover img{transform:scale(1.05)}
.gallery figcaption{font-size:.8rem;color:var(--muted);padding:8px 10px}

/* info side panel */
.info-split{display:grid;grid-template-columns:1.4fr 1fr;gap:32px;align-items:start}
@media(max-width:860px){.info-split{grid-template-columns:1fr}}
.infocard{background:var(--bg-soft);border-radius:var(--radius);padding:26px;border-left:4px solid var(--accent)}
.infocard h4{margin-bottom:14px;text-transform:uppercase;letter-spacing:1px;font-size:.82rem;color:var(--accent)}
.inforow{display:flex;justify-content:space-between;gap:14px;padding:9px 0;border-bottom:1px solid var(--border);font-size:.92rem}
.inforow:last-child{border:0}
.inforow span{color:var(--muted)}
.inforow b,.inforow a{color:var(--ink);font-weight:600;text-align:right}
.inforow a{color:var(--accent)}
.badge-stars{color:var(--gold);letter-spacing:2px}
.btn-book{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;margin-top:16px;padding:14px 22px;background:var(--accent);color:#fff;border-radius:50px;font-weight:700;text-decoration:none;transition:transform .18s,box-shadow .18s}
.btn-book:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(10,110,189,.45)}
.social-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.social-row a{font-size:.85rem;font-weight:600;color:var(--accent);background:#fff;border:1px solid var(--border);border-radius:50px;padding:7px 15px;transition:.2s;display:inline-flex;align-items:center;gap:6px}
.social-row a:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.mapframe{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--border);margin-top:8px}
.mapframe iframe{width:100%;height:380px;border:0;display:block}
.prose-block{font-size:1rem;color:var(--ink);line-height:1.75}
.prose-block p{margin-bottom:16px;color:var(--muted)}
.prose-block h3{font-size:1.2rem;margin:24px 0 10px;color:var(--ink)}
.prose-block a{color:var(--accent);font-weight:600}
.prose-block a:hover{text-decoration:underline}
.lead-img{width:100%;max-height:440px;object-fit:cover;border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);margin-bottom:6px}
figure.framed{margin:0 0 18px}
figure.framed img{width:100%;border-radius:12px;border:1px solid var(--border)}
figure.framed figcaption{font-size:.84rem;color:var(--muted);margin-top:7px}
.artwork{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:center;margin:26px 0}
@media(max-width:680px){.artwork{grid-template-columns:1fr}}
.artwork img{width:100%;border-radius:12px;border:1px solid var(--border);box-shadow:var(--shadow)}
.artwork .cap{font-size:.95rem}
.artwork .cap b{color:var(--ink)}
.artwork .cap p{color:var(--muted);margin-top:6px;font-size:.9rem}

/* hub card grid (hotels / museums) */
.hubgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:900px){.hubgrid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.hubgrid{grid-template-columns:1fr}}
.hubcard{display:flex;flex-direction:column;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:transform .2s,box-shadow .2s;height:100%}
.hubcard:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.hubcard .ph{height:188px;overflow:hidden;background:var(--bg-soft)}
.hubcard .ph img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.hubcard:hover .ph img{transform:scale(1.06)}
.hubcard .bd{padding:18px 20px;display:flex;flex-direction:column;flex:1}
.hubcard .bd .stars{color:var(--gold);font-size:.82rem;letter-spacing:1px;margin-bottom:4px}
.hubcard h3{font-size:1.08rem;margin-bottom:6px}
.hubcard p{font-size:.88rem;color:var(--muted);flex:1}
.hubcard .meta{font-size:.8rem;color:var(--muted);margin-top:10px}
.hubcard .go{margin-top:12px;font-weight:700;color:var(--accent);font-size:.9rem}

/* ad slots (AdSense-ready) */
.adslot{margin:30px auto;max-width:var(--max);padding:0 22px}
.adslot ins{display:block}
.adnote{font-size:.66rem;letter-spacing:1px;text-transform:uppercase;color:#b3bcc7;text-align:center;margin-bottom:4px}

/* cross-promo footer block */
.promo{background:var(--bg-soft);border-top:1px solid var(--border)}
.promo .wrap{text-align:center}
.promo .logos{display:flex;gap:26px;flex-wrap:wrap;justify-content:center;align-items:center;margin-top:18px}
.promo .logos a img{height:54px;width:auto;opacity:.92;transition:opacity .2s}
.promo .logos a:hover img{opacity:1}
.promo p{color:var(--muted);font-size:.92rem;max-width:60ch;margin:0 auto}

/* table (fr / wine list) */
.tablewrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius);margin-top:14px}
table.data{width:100%;border-collapse:collapse;font-size:.9rem;background:#fff}
table.data th,table.data td{text-align:left;padding:11px 14px;border-bottom:1px solid var(--border);vertical-align:top}
table.data th{background:var(--bg-soft);font-size:.78rem;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}
table.data tr:hover td{background:var(--bg-soft)}
table.data a{color:var(--accent);font-weight:600}
#tableSearch{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:10px;font-size:.95rem;font-family:inherit;margin-bottom:12px;background:var(--bg-soft)}
.footer-extra{display:flex;gap:30px;flex-wrap:wrap;margin-bottom:26px}
.footer-extra .col h5{font-size:.74rem;text-transform:uppercase;letter-spacing:1.5px;color:#8c98a8;margin-bottom:10px}
.footer-extra .col a{display:block;font-size:.86rem;color:#c2cdd9;padding:3px 0}
.footer-extra .col a:hover{color:#fff}
.mapcredit{font-size:.74rem;color:var(--muted);padding:7px 2px 0;text-align:right}
.mapcredit a{color:var(--accent)}
.subhero .hero-credit{position:absolute;bottom:6px;right:12px;z-index:3;font-size:.66rem;color:rgba(255,255,255,.72)}
.subhero .hero-credit a{color:#cfe6ff;text-decoration:underline}
.menu-disabled{color:var(--muted)!important;cursor:not-allowed;opacity:.6}

/* SEE section: place cards with runtime Wikipedia thumbnails + actions */
.place.has-thumb{padding:0;overflow:hidden;display:flex;flex-direction:column}
.place-thumb{position:relative;height:172px;background:var(--bg-soft);overflow:hidden}
.place-thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;z-index:1}
.place-thumb .ph-fallback{position:absolute;inset:0;z-index:0;display:flex;align-items:center;justify-content:center;font-size:3.2rem;background:linear-gradient(135deg,#eef3f8,#dde8f1)}
.place-thumb .wiki-credit{position:absolute;bottom:8px;right:8px;z-index:2;width:27px;height:27px;border-radius:50%;background:rgba(8,16,28,.62);color:#fff;display:flex;align-items:center;justify-content:center;font-family:Georgia,'Times New Roman',serif;font-style:italic;font-weight:700;font-size:.95rem;text-decoration:none;backdrop-filter:blur(2px);box-shadow:0 2px 8px rgba(0,0,0,.25);transition:.2s}
.place-thumb .wiki-credit:hover{background:var(--accent);transform:scale(1.08)}
.place-body{padding:18px 20px;display:flex;flex-direction:column;flex:1}
.place-body .kicker{margin-top:0}
.place-body .tag{margin-top:10px;align-self:flex-start}
.place-actions{display:flex;gap:8px;margin-top:auto;padding-top:16px}
.btn-mini{flex:1;text-align:center;font-size:.82rem;font-weight:700;padding:9px 10px;border-radius:50px;transition:background .2s,color .2s,border-color .2s;white-space:nowrap}
.btn-official{background:var(--bg-soft);color:var(--ink);border:1px solid var(--border)}
.btn-official:hover{background:#fff;border-color:var(--accent);color:var(--accent)}
.btn-tickets{background:var(--accent);color:#fff;border:1px solid var(--accent)}
.btn-tickets:hover{background:var(--accent-dark);border-color:var(--accent-dark)}
