/* ============================================================
   PONT DE L'ALPE — Design System
   Auberges & hôtels dans les grandes villes de France
   Palette & type calqués sur mythailand.fr (teal + or premium)
   ============================================================ */

/* ---------- Tokens ---------- */
:root {
  --primary:#0d9488;        --primary-light:#56b4ac;   --primary-dark:#0b7970;
  --primary-glow:#7ac4be;   --primary-softer:#ecf6f5;  --primary-soft:#d3ebe8;
  --secondary:#c9a24a;      --secondary-light:#d7b977; --secondary-dark:#9d7e3a;
  --secondary-soft:#eadcba; --secondary-softer:#f6f0e2;
  --navy:#16243d;           --navy-deep:#101b30;       --navy-light:#213459;
  --text:#1c2740;           --text-light:#5a6680;
  --bg:#ffffff;             --bg-light:#f6f8fb;        --bg-soft:#eef1f7;
  --border:#e4e8f0;         --border-soft:#e9edf4;
  --success:#16a34a;        --footer:#16243d;
  --radius-sm:10px; --radius:14px; --radius-lg:20px; --radius-xl:26px;
  --shadow-card:0 1px 3px rgba(15,23,42,.04), 0 4px 16px rgba(15,23,42,.03);
  --shadow-card-lg:0 4px 12px rgba(15,23,42,.06), 0 16px 40px rgba(15,23,42,.06);
  --shadow-pop:0 18px 50px rgba(16,27,48,.16);
  --glow-primary:0 8px 22px rgba(13,148,136,.32);
  --glow-secondary:0 8px 22px rgba(201,162,74,.36);
  --max:1180px;
  --font-display:'Plus Jakarta Sans', system-ui, -apple-system, sans-serif;
  --font-body:'Inter', system-ui, -apple-system, sans-serif;
  --ease:cubic-bezier(.4,0,.2,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
html,body { max-width:100%; overflow-x:hidden; }
body {
  font-family:var(--font-body);
  color:var(--text);
  background:var(--bg);
  line-height:1.65;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  overflow-wrap:break-word;
}
img,svg,video { max-width:100%; height:auto; display:block; }
a { color:var(--primary-dark); text-decoration:none; transition:color .15s var(--ease); }
a:hover { color:var(--primary); }
ul { list-style:none; }
h1,h2,h3,h4 { font-family:var(--font-display); color:var(--navy); line-height:1.15; font-weight:800; letter-spacing:-.02em; }
:focus-visible { outline:2px solid var(--secondary); outline-offset:2px; border-radius:4px; }
::selection { background:var(--primary-soft); color:var(--navy); }

.container { max-width:var(--max); margin:0 auto; padding:0 24px; }

/* ---------- Eyebrow / chips ---------- */
.eyebrow {
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-display); font-weight:700; font-size:.74rem;
  letter-spacing:.14em; text-transform:uppercase; color:var(--primary-dark);
}
.eyebrow::before { content:""; width:22px; height:2px; border-radius:2px; background:var(--secondary); }
.eyebrow.on-dark { color:var(--secondary-light); }
.badge {
  display:inline-flex; align-items:center; gap:6px;
  padding:5px 12px; border-radius:999px; font-size:.78rem; font-weight:600;
  background:var(--primary-softer); color:var(--primary-dark);
}

/* ---------- Buttons ---------- */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  padding:14px 26px; border-radius:999px; border:1.5px solid transparent;
  font-family:var(--font-display); font-weight:700; font-size:.97rem;
  cursor:pointer; transition:transform .18s var(--ease), box-shadow .18s var(--ease), background .18s var(--ease);
  white-space:nowrap; line-height:1;
}
.btn svg { width:18px; height:18px; }
.btn-lg { padding:17px 32px; font-size:1.03rem; }
.btn-primary { background:var(--primary); color:#fff; box-shadow:var(--glow-primary); }
.btn-primary:hover { background:var(--primary-dark); color:#fff; transform:translateY(-2px); box-shadow:0 12px 28px rgba(13,148,136,.4); }
.btn-secondary { background:var(--secondary); color:#fff; box-shadow:var(--glow-secondary); }
.btn-secondary:hover { background:var(--secondary-dark); color:#fff; transform:translateY(-2px); box-shadow:0 12px 28px rgba(201,162,74,.45); }
.btn-ghost { background:transparent; color:var(--navy); border-color:var(--border); }
.btn-ghost:hover { background:var(--bg-light); color:var(--navy); border-color:var(--primary-light); transform:translateY(-2px); }
.btn-light { background:#fff; color:var(--navy); box-shadow:0 8px 22px rgba(0,0,0,.14); }
.btn-light:hover { color:var(--primary-dark); transform:translateY(-2px); }
.btn-outline-light { background:rgba(255,255,255,.08); color:#fff; border-color:rgba(255,255,255,.4); backdrop-filter:blur(4px); }
.btn-outline-light:hover { background:rgba(255,255,255,.16); color:#fff; border-color:#fff; }

/* ---------- Header ---------- */
.site-header {
  position:sticky; top:0; z-index:100; background:rgba(255,255,255,.88);
  backdrop-filter:saturate(180%) blur(12px);
  border-bottom:1px solid var(--border-soft);
}
.header-inner { max-width:var(--max); margin:0 auto; padding:0 24px; height:74px; display:flex; align-items:center; justify-content:space-between; gap:24px; }
.brand { display:flex; align-items:center; gap:11px; }
.brand-mark { width:42px; height:42px; flex-shrink:0; border-radius:12px; box-shadow:0 4px 12px rgba(13,148,136,.25); }
.brand-text { display:flex; flex-direction:column; line-height:1.05; }
.brand-name { font-family:var(--font-display); font-weight:800; font-size:1.18rem; color:var(--navy); letter-spacing:-.02em; }
.brand-tag { font-size:.62rem; font-weight:600; letter-spacing:.13em; text-transform:uppercase; color:var(--secondary-dark); }
.main-nav .nav-list { display:flex; align-items:center; gap:4px; }
.main-nav a { display:block; padding:9px 14px; border-radius:10px; color:var(--text); font-weight:600; font-size:.95rem; transition:all .15s var(--ease); }
.main-nav a:hover { color:var(--primary-dark); background:var(--primary-softer); }
.header-actions { display:flex; align-items:center; gap:12px; }
.menu-toggle { display:none; width:44px; height:44px; border:none; background:none; cursor:pointer; flex-direction:column; gap:5px; align-items:center; justify-content:center; }
.menu-toggle span { width:24px; height:2px; background:var(--navy); border-radius:2px; transition:all .25s var(--ease); }

/* ---------- Hero ---------- */
.hero { position:relative; color:#fff; overflow:hidden; isolation:isolate; }
.hero-bg { position:absolute; inset:0; z-index:-2; background-size:cover; background-position:center; }
.hero-overlay {
  position:absolute; inset:0; z-index:-1;
  background:linear-gradient(104deg, rgba(16,27,48,.95) 0%, rgba(16,27,48,.82) 42%, rgba(11,121,112,.55) 100%);
}
.hero-inner { max-width:var(--max); margin:0 auto; padding:84px 24px 92px; }
.hero-content { max-width:660px; }
.hero .eyebrow { color:var(--secondary-light); }
.hero .eyebrow::before { background:var(--secondary); }
.hero h1 { color:#fff; font-size:3.3rem; line-height:1.06; margin:20px 0 0; letter-spacing:-.03em; }
.hero h1 .accent { color:var(--secondary-light); }
.hero-sub { font-size:1.18rem; color:rgba(255,255,255,.86); margin-top:20px; max-width:560px; line-height:1.55; }
.hero-actions { display:flex; flex-wrap:wrap; gap:14px; margin-top:32px; }

/* Hero city search */
.hero-search {
  margin-top:30px; display:flex; gap:10px; align-items:center;
  background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.22);
  backdrop-filter:blur(8px); padding:10px; border-radius:999px; max-width:520px;
}
.hero-search .field { display:flex; align-items:center; gap:10px; flex:1; padding-left:14px; color:#fff; }
.hero-search .field svg { width:20px; height:20px; opacity:.85; }
.hero-search select {
  flex:1; appearance:none; background:transparent; border:none; color:#fff;
  font-family:var(--font-body); font-size:1rem; font-weight:600; cursor:pointer; outline:none;
}
.hero-search select option { color:var(--navy); }

.hero-stats { display:flex; flex-wrap:wrap; gap:34px; margin-top:42px; }
.hero-stat strong { display:block; font-family:var(--font-display); font-size:1.9rem; font-weight:800; color:#fff; line-height:1; }
.hero-stat span { font-size:.85rem; color:rgba(255,255,255,.72); margin-top:5px; display:block; }

/* ---------- Trust bar ---------- */
.trustbar { background:var(--navy-deep); color:rgba(255,255,255,.86); }
.trustbar-inner { max-width:var(--max); margin:0 auto; padding:16px 24px; display:flex; flex-wrap:wrap; justify-content:center; gap:14px 38px; }
.trust-item { display:inline-flex; align-items:center; gap:10px; font-size:.9rem; font-weight:500; }
.trust-item svg { width:19px; height:19px; color:var(--primary-glow); flex-shrink:0; }

/* ---------- Section scaffolding ---------- */
.section { padding:84px 0; }
.section-alt { background:var(--bg-light); }
.section-navy { background:var(--navy); color:#fff; }
.section-head { max-width:680px; margin:0 auto 52px; text-align:center; }
.section-head.left { margin-left:0; text-align:left; }
.section-head h2 { font-size:2.3rem; margin:14px 0 0; }
.section-navy .section-head h2 { color:#fff; }
.section-head .lead { font-size:1.1rem; color:var(--text-light); margin-top:16px; line-height:1.6; }
.section-navy .section-head .lead { color:rgba(255,255,255,.8); }

/* ---------- Tool cards ---------- */
.tools-grid { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:22px; }
.tool-card {
  background:var(--bg); border:1px solid var(--border); border-radius:var(--radius-lg);
  padding:28px 24px; box-shadow:var(--shadow-card); transition:transform .25s var(--ease), box-shadow .25s var(--ease), border-color .25s var(--ease);
  display:flex; flex-direction:column;
}
.tool-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-card-lg); border-color:var(--primary-light); }
.tool-ic {
  width:54px; height:54px; border-radius:15px; display:grid; place-items:center; margin-bottom:18px;
  background:linear-gradient(135deg, var(--primary-softer), var(--primary-soft)); color:var(--primary-dark);
}
.tool-ic svg { width:27px; height:27px; }
.tool-card h3 { font-size:1.18rem; }
.tool-card p { color:var(--text-light); font-size:.94rem; margin-top:9px; flex:1; }
.tool-link { display:inline-flex; align-items:center; gap:7px; margin-top:18px; font-family:var(--font-display); font-weight:700; font-size:.9rem; color:var(--primary-dark); }
.tool-link svg { width:16px; height:16px; transition:transform .2s var(--ease); }
.tool-card:hover .tool-link svg { transform:translateX(4px); }

/* ---------- City cards ---------- */
.cities-grid { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:22px; }
.city-card {
  position:relative; border-radius:var(--radius-lg); overflow:hidden; background:var(--navy);
  box-shadow:var(--shadow-card); transition:transform .28s var(--ease), box-shadow .28s var(--ease);
  min-height:300px; display:flex; flex-direction:column; justify-content:flex-end; color:#fff;
}
.city-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-pop); }
.city-card-img { position:absolute; inset:0; z-index:0; background-size:cover; background-position:center; transition:transform .5s var(--ease); }
.city-card:hover .city-card-img { transform:scale(1.06); }
.city-card::after { content:""; position:absolute; inset:0; z-index:1; background:linear-gradient(to top, rgba(11,18,32,.92) 4%, rgba(11,18,32,.45) 42%, rgba(11,18,32,.05) 78%); }
.city-card-body { position:relative; z-index:2; padding:20px; }
.price-pill {
  position:absolute; top:16px; right:16px; z-index:2;
  background:rgba(255,255,255,.94); color:var(--navy); padding:7px 13px; border-radius:999px;
  font-family:var(--font-display); font-weight:800; font-size:.82rem; box-shadow:0 4px 14px rgba(0,0,0,.2);
}
.price-pill span { color:var(--text-light); font-weight:600; }
.city-card h3 { color:#fff; font-size:1.42rem; }
.city-tags { display:flex; flex-wrap:wrap; gap:7px; margin-top:11px; }
.tag { font-size:.72rem; font-weight:600; padding:4px 10px; border-radius:999px; background:rgba(255,255,255,.16); color:#fff; backdrop-filter:blur(3px); }
.city-link { display:inline-flex; align-items:center; gap:7px; margin-top:15px; font-family:var(--font-display); font-weight:700; font-size:.88rem; color:#fff; }
.city-link svg { width:16px; height:16px; color:var(--secondary-light); transition:transform .2s var(--ease); }
.city-card:hover .city-link svg { transform:translateX(4px); }

/* ---------- Feature cards ---------- */
.features-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:22px; }
.feature-card {
  background:var(--bg); border:1px solid var(--border); border-radius:var(--radius-lg); padding:30px 26px;
  box-shadow:var(--shadow-card); transition:transform .25s var(--ease), box-shadow .25s var(--ease), border-color .25s var(--ease);
}
.feature-card:hover { transform:translateY(-5px); box-shadow:var(--shadow-card-lg); border-color:var(--secondary-light); }
.feature-ic { width:52px; height:52px; border-radius:14px; display:grid; place-items:center; margin-bottom:18px; background:linear-gradient(135deg, var(--secondary-softer), var(--secondary-soft)); color:var(--secondary-dark); }
.feature-ic svg { width:26px; height:26px; }
.feature-card h3 { font-size:1.2rem; }
.feature-card p { color:var(--text-light); font-size:.96rem; margin-top:10px; }
.feature-card .tool-link { color:var(--secondary-dark); }

/* ---------- Comparison (vs) ---------- */
.compare-wrap { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:24px; max-width:920px; margin:0 auto; }
.compare-col { border-radius:var(--radius-lg); padding:32px 30px; border:1px solid var(--border); background:var(--bg); }
.compare-col.win { border-color:var(--primary-light); background:linear-gradient(180deg, var(--primary-softer), #fff 60%); box-shadow:var(--shadow-card-lg); position:relative; }
.compare-col.win::before { content:"Notre approche"; position:absolute; top:-13px; left:30px; background:var(--primary); color:#fff; font-family:var(--font-display); font-weight:700; font-size:.74rem; letter-spacing:.05em; padding:5px 14px; border-radius:999px; }
.compare-col h3 { font-size:1.25rem; margin-bottom:18px; }
.compare-col.muted h3 { color:var(--text-light); }
.compare-row { display:flex; align-items:flex-start; gap:12px; padding:11px 0; font-size:.97rem; border-top:1px solid var(--border-soft); }
.compare-row:first-of-type { border-top:none; }
.ic-check,.ic-cross { flex-shrink:0; width:22px; height:22px; border-radius:999px; display:grid; place-items:center; margin-top:1px; }
.ic-check { background:var(--primary-softer); color:var(--primary-dark); }
.ic-cross { background:#fbeaea; color:#c0392b; }
.ic-check svg,.ic-cross svg { width:13px; height:13px; }
.compare-col.muted .compare-row { color:var(--text-light); }

/* ---------- Steps ---------- */
.steps { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:22px; counter-reset:step; }
.step { position:relative; padding:30px 24px; border-radius:var(--radius-lg); background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.1); }
.step-num { width:46px; height:46px; border-radius:13px; display:grid; place-items:center; background:var(--secondary); color:#fff; font-family:var(--font-display); font-weight:800; font-size:1.2rem; margin-bottom:16px; box-shadow:var(--glow-secondary); }
.step h3 { color:#fff; font-size:1.12rem; }
.step p { color:rgba(255,255,255,.72); font-size:.93rem; margin-top:9px; }

/* ---------- CTA band ---------- */
.cta-band { position:relative; overflow:hidden; background:linear-gradient(120deg, var(--primary-dark), var(--primary)); color:#fff; border-radius:var(--radius-xl); padding:56px 48px; text-align:center; box-shadow:var(--shadow-pop); }
.cta-band::before,.cta-band::after { content:""; position:absolute; border-radius:50%; }
.cta-band::before { width:280px; height:280px; background:rgba(255,255,255,.07); top:-120px; right:-60px; }
.cta-band::after { width:200px; height:200px; background:rgba(201,162,74,.18); bottom:-100px; left:8%; }
.cta-band h2 { color:#fff; font-size:2.1rem; position:relative; }
.cta-band p { color:rgba(255,255,255,.88); font-size:1.08rem; margin:14px auto 0; max-width:560px; position:relative; }
.cta-band .hero-actions { justify-content:center; position:relative; }

/* ---------- FAQ ---------- */
.faq-list { max-width:780px; margin:0 auto; display:flex; flex-direction:column; gap:12px; }
.faq-item { border:1px solid var(--border); border-radius:var(--radius); background:var(--bg); overflow:hidden; transition:border-color .2s var(--ease), box-shadow .2s var(--ease); }
.faq-item.open { border-color:var(--primary-light); box-shadow:var(--shadow-card); }
.faq-q { width:100%; text-align:left; background:none; border:none; cursor:pointer; padding:20px 22px; display:flex; align-items:center; justify-content:space-between; gap:16px; font-family:var(--font-display); font-weight:700; font-size:1.04rem; color:var(--navy); }
.faq-q .chev { flex-shrink:0; width:26px; height:26px; border-radius:999px; display:grid; place-items:center; background:var(--primary-softer); color:var(--primary-dark); transition:transform .25s var(--ease); }
.faq-item.open .chev { transform:rotate(180deg); background:var(--primary); color:#fff; }
.faq-a { max-height:0; overflow:hidden; transition:max-height .3s var(--ease); }
.faq-a-inner { padding:0 22px 20px; color:var(--text-light); font-size:.99rem; }

/* ---------- Footer ---------- */
.site-footer { background:var(--footer); color:rgba(255,255,255,.72); padding:64px 0 28px; }
.footer-grid { max-width:var(--max); margin:0 auto; padding:0 24px; display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:40px; }
.footer-brand .brand-name { color:#fff; }
.footer-brand p { font-size:.93rem; line-height:1.65; margin-top:16px; max-width:300px; }
.footer-col h4 { color:#fff; font-size:.82rem; letter-spacing:.1em; text-transform:uppercase; margin-bottom:16px; }
.footer-col li { margin-bottom:10px; }
.footer-col a { color:rgba(255,255,255,.66); font-size:.93rem; }
.footer-col a:hover { color:var(--secondary-light); }
.footer-bottom { max-width:var(--max); margin:44px auto 0; padding:24px 24px 0; border-top:1px solid rgba(255,255,255,.12); display:flex; flex-wrap:wrap; justify-content:space-between; gap:12px; font-size:.84rem; color:rgba(255,255,255,.55); }
.footer-bottom a { color:rgba(255,255,255,.55); }
.footer-bottom a:hover { color:#fff; }

/* ---------- Responsive ---------- */
@media (max-width:1024px){
  .tools-grid,.cities-grid,.steps { grid-template-columns:repeat(2,minmax(0,1fr)); }
  .features-grid { grid-template-columns:repeat(2,minmax(0,1fr)); }
  .hero h1 { font-size:2.8rem; }
}
@media (max-width:768px){
  .menu-toggle { display:flex; }
  .main-nav { position:fixed; top:74px; left:0; right:0; background:#fff; border-bottom:1px solid var(--border); box-shadow:var(--shadow-card-lg); transform:translateY(-130%); opacity:0; visibility:hidden; transition:all .28s var(--ease); max-height:calc(100vh - 74px); overflow-y:auto; z-index:99; }
  .main-nav.open { transform:translateY(0); opacity:1; visibility:visible; }
  .main-nav .nav-list { flex-direction:column; align-items:stretch; padding:14px; gap:2px; }
  .main-nav a { padding:14px 16px; min-height:44px; font-size:1rem; }
  .header-actions .btn:not(.menu-toggle) { display:none; }
  .section { padding:60px 0; }
  .section-head { margin-bottom:38px; }
  .section-head h2 { font-size:1.85rem; }
  .hero-inner { padding:60px 24px 66px; }
  .hero h1 { font-size:2.3rem; }
  .hero-sub { font-size:1.05rem; }
  .hero-stats { gap:24px; }
  .hero-stat strong { font-size:1.55rem; }
  .tools-grid,.cities-grid,.features-grid,.steps,.compare-wrap { grid-template-columns:minmax(0,1fr); }
  .footer-grid { grid-template-columns:repeat(2,minmax(0,1fr)); gap:30px; }
  .cta-band { padding:42px 26px; }
  .cta-band h2 { font-size:1.7rem; }
  .hero-actions .btn { width:100%; }
}
@media (max-width:480px){
  .container,.header-inner,.hero-inner { padding-left:18px; padding-right:18px; }
  .hero h1 { font-size:2rem; }
  .brand-tag { display:none; }
  .footer-grid { grid-template-columns:minmax(0,1fr); }
  .hero-search { flex-direction:column; padding:14px; border-radius:var(--radius-lg); }
  .hero-search .btn { width:100%; }
}

/* ---------- Interactive budget simulator ---------- */
.simulator {
  display:grid; grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr); gap:0;
  background:#fff; border:1px solid var(--border); border-radius:var(--radius-xl);
  overflow:hidden; box-shadow:var(--shadow-card-lg); max-width:980px; margin:0 auto;
}
.sim-form { padding:36px 38px; }
.sim-field { margin-bottom:22px; }
.sim-field > label { display:block; font-family:var(--font-display); font-weight:700; font-size:.9rem; color:var(--navy); margin-bottom:10px; }
.sim-select { width:100%; padding:13px 16px; border:1.5px solid var(--border); border-radius:12px; font-family:var(--font-body); font-size:1rem; color:var(--text); background:#fff; cursor:pointer; transition:border-color .15s var(--ease), box-shadow .15s var(--ease); }
.sim-select:focus { outline:none; border-color:var(--primary-light); box-shadow:0 0 0 3px rgba(13,148,136,.12); }
.sim-chips { display:flex; gap:8px; }
.sim-chip { flex:1; min-width:0; padding:12px 8px; border:1.5px solid var(--border); border-radius:12px; background:#fff; cursor:pointer; font-family:var(--font-display); font-weight:600; font-size:.86rem; color:var(--text); text-align:center; transition:all .15s var(--ease); }
.sim-chip small { display:block; font-family:var(--font-body); font-weight:500; font-size:.7rem; color:var(--text-light); margin-top:3px; }
.sim-chip:hover { border-color:var(--primary-light); }
.sim-chip.active { border-color:var(--primary); background:var(--primary-softer); color:var(--primary-dark); box-shadow:0 4px 12px rgba(13,148,136,.14); }
.sim-chip.active small { color:var(--primary-dark); }
.sim-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.sim-stepper { display:flex; align-items:center; border:1.5px solid var(--border); border-radius:12px; overflow:hidden; }
.sim-stepper button { width:46px; height:48px; flex-shrink:0; border:none; background:var(--bg-light); color:var(--navy); font-size:1.3rem; cursor:pointer; font-family:var(--font-display); transition:background .15s, color .15s; }
.sim-stepper button:hover { background:var(--primary-softer); color:var(--primary-dark); }
.sim-stepper input { flex:1; min-width:0; text-align:center; border:none; background:#fff; font-family:var(--font-display); font-weight:700; font-size:1.05rem; color:var(--navy); -moz-appearance:textfield; }
.sim-stepper input:focus { outline:none; }
.sim-stepper input::-webkit-outer-spin-button, .sim-stepper input::-webkit-inner-spin-button { -webkit-appearance:none; margin:0; }
.sim-result { background:linear-gradient(162deg,var(--navy),var(--navy-deep)); color:#fff; padding:36px 34px; display:flex; flex-direction:column; justify-content:center; }
.sim-result .eyebrow { color:var(--secondary-light); }
.sim-result .eyebrow::before { background:var(--secondary); }
.sim-total { font-family:var(--font-display); font-weight:800; font-size:3.3rem; line-height:1; margin:14px 0 6px; letter-spacing:-.03em; }
.sim-total span { color:var(--secondary-light); font-size:2.2rem; }
.sim-sub { color:rgba(255,255,255,.84); font-size:1rem; }
.sim-breakdown { margin-top:22px; padding-top:18px; border-top:1px solid rgba(255,255,255,.16); display:flex; flex-direction:column; gap:9px; }
.sim-line { display:flex; justify-content:space-between; gap:12px; font-size:.92rem; color:rgba(255,255,255,.8); }
.sim-line strong { color:#fff; font-weight:600; white-space:nowrap; }
.sim-cta { margin-top:22px; width:100%; }
.sim-note { margin-top:14px; font-size:.76rem; line-height:1.5; color:rgba(255,255,255,.55); }
@media (max-width:768px){
  .simulator { grid-template-columns:minmax(0,1fr); }
  .sim-form { padding:26px 20px; }
  .sim-result { padding:28px 22px; }
  .sim-total { font-size:2.7rem; }
  .sim-chip { font-size:.8rem; }
}

/* ---------- Pillar / article (city pages) ---------- */
.hero-pillar .hero-inner { padding:52px 24px 58px; }
.hero-pillar h1 { font-size:2.7rem; }
.hero-pillar .hero-content { max-width:720px; }
.breadcrumb { display:flex; flex-wrap:wrap; gap:8px; align-items:center; font-size:.84rem; color:rgba(255,255,255,.72); margin-bottom:16px; }
.breadcrumb a { color:rgba(255,255,255,.8); }
.breadcrumb a:hover { color:#fff; }
.breadcrumb .sep { opacity:.45; }
.hero-pillar .hero-stats { margin-top:26px; gap:30px; }

.article-wrap { max-width:840px; margin:0 auto; padding:54px 24px 24px; }
.article-meta { display:flex; flex-wrap:wrap; align-items:center; gap:14px; margin:0 0 28px; padding-bottom:18px; border-bottom:1px solid var(--border); font-size:.87rem; color:var(--text-light); }
.article-meta .am-author { display:inline-flex; align-items:center; gap:9px; font-weight:600; color:var(--navy); }
.article-meta .am-author img { width:34px; height:34px; border-radius:50%; }
.article-meta time::before { content:"🗓️"; margin-right:5px; }

.toc-box { background:var(--bg-light); border:1px solid var(--border); border-radius:var(--radius); padding:20px 24px; margin:0 0 38px; }
.toc-box .toc-h { font-family:var(--font-display); font-size:.78rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--text-light); margin-bottom:13px; }
.toc-box ul { display:flex; flex-wrap:wrap; gap:8px; }
.toc-box a { display:inline-block; padding:7px 14px; background:#fff; border:1px solid var(--border); border-radius:999px; font-size:.85rem; font-weight:600; color:var(--primary-dark); }
.toc-box a:hover { border-color:var(--primary-light); background:var(--primary-softer); }

.prose { font-size:1.05rem; color:var(--text); }
.prose > p { margin:0 0 18px; line-height:1.72; }
.prose .lead-p { font-size:1.16rem; line-height:1.65; color:var(--navy-light); }
.prose h2 { font-size:1.62rem; margin:44px 0 16px; scroll-margin-top:90px; }
.prose h3 { font-size:1.18rem; margin:26px 0 9px; color:var(--navy-light); }
.prose strong { color:var(--navy); font-weight:700; }
.prose ul { margin:0 0 18px; padding-left:0; display:flex; flex-direction:column; gap:9px; }
.prose ul li { position:relative; padding-left:28px; line-height:1.6; }
.prose ul li::before { content:""; position:absolute; left:7px; top:10px; width:7px; height:7px; border-radius:50%; background:var(--secondary); }
.prose a:not(.btn) { color:var(--primary-dark); font-weight:600; text-decoration:underline; text-decoration-color:var(--primary-soft); text-underline-offset:3px; }
.prose a:not(.btn):hover { color:var(--primary); text-decoration-color:var(--primary); }

.table-wrap { overflow-x:auto; margin:8px 0 26px; }
.data-table { width:100%; border-collapse:separate; border-spacing:0; font-size:.94rem; border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; }
.data-table th { background:var(--navy); color:#fff; font-family:var(--font-display); font-weight:600; text-align:left; padding:12px 15px; font-size:.82rem; }
.data-table td { padding:11px 15px; border-top:1px solid var(--border); }
.data-table tr:nth-child(even) td { background:var(--bg-light); }
.data-table td strong { color:var(--navy); }

.infobox { border-radius:var(--radius); padding:20px 24px; margin:26px 0; border-left:4px solid; }
.infobox.tip { background:var(--primary-softer); border-color:var(--primary); }
.infobox.note { background:var(--secondary-softer); border-color:var(--secondary); }
.infobox h3 { font-size:1.04rem; margin:0 0 5px; }
.infobox p { margin:0; font-size:.98rem; color:var(--text); line-height:1.6; }

.guide-cards { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:16px; margin:14px 0 8px; }
.guide-card { display:flex; align-items:center; gap:14px; padding:18px 20px; background:#fff; border:1px solid var(--border); border-radius:var(--radius); box-shadow:var(--shadow-card); transition:transform .2s var(--ease), border-color .2s var(--ease); }
.guide-card:hover { transform:translateY(-3px); border-color:var(--primary-light); }
.guide-card .gc-ic { flex-shrink:0; width:42px; height:42px; border-radius:11px; display:grid; place-items:center; background:var(--primary-softer); color:var(--primary-dark); }
.guide-card .gc-ic svg { width:21px; height:21px; }
.guide-card h3 { font-size:1rem; margin:0; color:var(--navy); }
.guide-card p { font-size:.82rem; color:var(--text-light); margin:2px 0 0; }

.author-card { display:flex; gap:20px; align-items:flex-start; margin:46px 0 8px; padding:26px; background:var(--bg-light); border:1px solid var(--border); border-radius:var(--radius-lg); }
.author-card img { flex-shrink:0; width:84px; height:84px; border-radius:50%; }
.author-card .ac-label { font-size:.72rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--secondary-dark); }
.author-card h3 { font-size:1.16rem; margin:3px 0; }
.author-card .ac-role { font-size:.88rem; color:var(--primary-dark); font-weight:600; margin-bottom:8px; }
.author-card p { font-size:.93rem; color:var(--text-light); margin:0; line-height:1.6; }

@media (max-width:768px){
  .hero-pillar h1 { font-size:1.9rem; }
  .article-wrap { padding:36px 18px 18px; }
  .prose { font-size:1rem; }
  .prose h2 { font-size:1.38rem; }
  .prose .lead-p { font-size:1.08rem; }
  .guide-cards { grid-template-columns:minmax(0,1fr); }
  .author-card { flex-direction:column; gap:14px; }
}

/* ---------- Section / hub pages ---------- */
.hero-flat { background:linear-gradient(118deg, var(--navy-deep) 0%, var(--navy) 52%, var(--primary-dark) 100%); }
.citylinks { display:grid; grid-template-columns:repeat(auto-fill,minmax(210px,1fr)); gap:12px; margin:16px 0 8px; }
.citylink { display:flex; align-items:center; justify-content:space-between; gap:10px; padding:14px 18px; background:#fff; border:1px solid var(--border); border-radius:var(--radius); font-family:var(--font-display); font-weight:700; font-size:1rem; color:var(--navy); box-shadow:var(--shadow-card); transition:transform .18s var(--ease), border-color .18s var(--ease), color .18s var(--ease); }
.citylink:hover { transform:translateY(-2px); border-color:var(--primary-light); color:var(--primary-dark); }
.citylink svg { width:17px; height:17px; color:var(--secondary); flex-shrink:0; transition:transform .18s var(--ease); }
.citylink:hover svg { transform:translateX(3px); }
.prose .cities-grid { margin:18px 0 8px; }
