:root{
  --bg:#FFFFFF;
  --text:#1F2933;
  --muted:#52606D;
  --border:#E6E9EE;
  --card:#FFFFFF;
  --soft:#F6F8FB;
  --shadow:0 18px 40px rgba(15, 23, 42, .08);
  --shadow2:0 10px 24px rgba(15, 23, 42, .07);
  --radius:18px;
  --radius2:24px;
  --accentA:#4A6CF7;
  --accentB:#6FA8FF;
  --max:1120px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:"Open Sans", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  line-height:1.7;
  letter-spacing:.01em;
}

img{max-width:100%; height:auto; display:block}
a{color:inherit; text-decoration:underline; text-underline-offset:3px}
a:hover{opacity:.9}

.container{
  width:min(var(--max), calc(100% - 2rem));
  margin-inline:auto;
}

.skip-link{
  position:absolute;
  left:-999px;
  top:auto;
  width:1px;
  height:1px;
  overflow:hidden;
}
.skip-link:focus{
  left:1rem;
  top:1rem;
  width:auto;
  height:auto;
  padding:.75rem 1rem;
  border:1px solid var(--border);
  background:var(--bg);
  border-radius:12px;
  z-index:9999;
}

.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(12px);
  border-bottom:1px solid var(--border);
}

.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding:.9rem 0;
}

.brand{
  display:flex;
  align-items:center;
  gap:.7rem;
  min-width:220px;
}
.brand-mark{
  width:14px;
  height:14px;
  border-radius:999px;
  background:linear-gradient(135deg,var(--accentA),var(--accentB));
  box-shadow:0 8px 18px rgba(74,108,247,.28);
}
.brand-name{
  font-weight:700;
  letter-spacing:.02em;
}

.site-nav{display:none}
.site-nav ul{
  list-style:none;
  display:flex;
  gap:1rem;
  padding:0;
  margin:0;
}
.site-nav a{
  text-decoration:none;
  font-weight:600;
  color:var(--text);
  padding:.45rem .6rem;
  border-radius:12px;
}
.site-nav a:hover{
  background:var(--soft);
}

.nav-toggle{
  border:1px solid var(--border);
  background:var(--bg);
  color:var(--text);
  border-radius:14px;
  padding:.55rem .85rem;
  font-weight:650;
  cursor:pointer;
}

.nav-panel{
  border-top:1px solid var(--border);
  background:var(--bg);
}
.nav-panel nav{
  padding:1rem 0 1.25rem;
}
.nav-panel ul{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  gap:.25rem;
}
.nav-panel a{
  display:block;
  padding:.9rem 1rem;
  border-radius:14px;
  text-decoration:none;
  font-weight:650;
}
.nav-panel a:hover{background:var(--soft)}

.page{
  padding-bottom:4rem;
}

.hero{
  padding:2.25rem 0 2.75rem;
}
.hero-grid{
  display:grid;
  gap:1.75rem;
  align-items:start;
}
.hero-copy{
  padding-top:.25rem;
}
.eyebrow{
  margin:0 0 .75rem;
  color:var(--muted);
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:.78rem;
}
.hero-title{
  margin:0 0 1rem;
  font-family:"Playfair Display", Georgia, "Times New Roman", serif;
  font-weight:700;
  line-height:1.14;
  letter-spacing:.01em;
  font-size:2.05rem;
}
.lead{
  margin:0 0 1.3rem;
  font-size:1.05rem;
  color:var(--text);
  max-width:68ch;
}
.micro-note{
  margin:.85rem 0 0;
  color:var(--muted);
  font-size:.92rem;
  max-width:70ch;
}

.trust-block{
  border:1px solid var(--border);
  border-radius:var(--radius2);
  background:var(--card);
  box-shadow:var(--shadow2);
  padding:1.1rem 1.1rem;
  margin:1.25rem 0 1.1rem;
}
.trust-signals{
  margin:0;
  display:grid;
  gap:.8rem;
}
.trust-signals dt{
  color:var(--muted);
  font-weight:750;
  font-size:.85rem;
  letter-spacing:.02em;
}
.trust-signals dd{
  margin:0;
  font-weight:650;
}

.hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:.7rem;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  border-radius:999px;
  padding:.75rem 1.05rem;
  font-weight:750;
  text-decoration:none;
  border:1px solid transparent;
  cursor:pointer;
  transition:transform .14s ease, box-shadow .14s ease, background .14s ease, border-color .14s ease;
}
.btn:active{transform:translateY(1px)}
.btn.primary{
  color:#fff;
  background:linear-gradient(135deg,var(--accentA),var(--accentB));
  box-shadow:0 16px 30px rgba(74,108,247,.22);
}
.btn.primary:hover{box-shadow:0 22px 44px rgba(74,108,247,.26)}
.btn.ghost{
  background:var(--bg);
  border-color:var(--border);
  color:var(--text);
}
.btn.ghost:hover{background:var(--soft)}

.hero-media{
  border-radius:var(--radius2);
  overflow:hidden;
  border:1px solid var(--border);
  background:var(--soft);
  box-shadow:var(--shadow);
}
.hero-media img{width:100%; aspect-ratio:4/3; object-fit:cover}
.hero-media figcaption{
  padding:.9rem 1rem 1.05rem;
  color:var(--muted);
  font-size:.92rem;
}

.intro-strip{
  padding:1.5rem 0 2.1rem;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  background:linear-gradient(180deg,#fff, #fff);
}
.intro-grid{
  display:grid;
  gap:1.25rem;
}
.h2-like{
  margin:0 0 .65rem;
  font-family:"Playfair Display", Georgia, serif;
  font-weight:750;
  font-size:1.45rem;
  line-height:1.25;
}
.intro-copy p{margin:.75rem 0 0; color:var(--text); max-width:78ch}

.section{
  padding:3rem 0;
}
.section-grid{
  display:grid;
  gap:1.75rem;
  align-items:start;
}
.section-copy h2{
  margin:0 0 1rem;
  font-family:"Playfair Display", Georgia, serif;
  font-size:1.75rem;
  line-height:1.2;
}
.section-copy h3{
  margin:1.6rem 0 .65rem;
  font-size:1.08rem;
  letter-spacing:.01em;
}
.section-copy p{
  margin:.75rem 0 0;
  max-width:78ch;
}
.section-media{
  border-radius:var(--radius2);
  overflow:hidden;
  border:1px solid var(--border);
  background:var(--soft);
  box-shadow:var(--shadow2);
}
.section-media img{width:100%; aspect-ratio:4/3; object-fit:cover}
.section-media figcaption{
  padding:.9rem 1rem 1.05rem;
  color:var(--muted);
  font-size:.92rem;
}

.media-stack{
  display:grid;
  gap:1rem;
}

.quote-band{
  padding:.25rem 0 2.25rem;
}
.quote-card{
  border-radius:var(--radius2);
  padding:1.35rem 1.25rem;
  border:1px solid var(--border);
  box-shadow:var(--shadow2);
  background:var(--card);
}
.gradient-quote{
  background:
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.92)),
    linear-gradient(135deg, rgba(74,108,247,.18), rgba(111,168,255,.18));
  border-color:rgba(74,108,247,.25);
}
.quote-text{
  margin:0;
  font-family:"Playfair Display", Georgia, serif;
  font-size:1.15rem;
  line-height:1.35;
}
.quote-meta{
  margin:.7rem 0 0;
  color:var(--muted);
  font-weight:650;
  font-size:.92rem;
}

.location-grid{
  display:grid;
  gap:1rem;
  margin-top:1.25rem;
}
.card{
  border:1px solid var(--border);
  border-radius:var(--radius2);
  background:var(--card);
  box-shadow:var(--shadow2);
  padding:1.25rem 1.2rem;
}
.card h3{
  margin:0 0 .6rem;
  font-size:1.08rem;
}
.card p{margin:.65rem 0 0; color:var(--text)}
.address-block{
  margin:.3rem 0 .6rem;
  font-style:normal;
  color:var(--text);
}
.inline-metrics{
  list-style:none;
  padding:0;
  margin:.85rem 0 0;
  display:flex;
  flex-wrap:wrap;
  gap:.55rem;
}
.inline-metrics li{
  display:flex;
  align-items:baseline;
  gap:.35rem;
  border:1px solid var(--border);
  background:var(--soft);
  border-radius:999px;
  padding:.5rem .75rem;
}
.inline-metrics span{color:var(--muted); font-weight:650; font-size:.9rem}
.inline-metrics strong{font-weight:800}

.wide-media{
  margin:1.6rem 0 0;
  border-radius:var(--radius2);
  overflow:hidden;
  border:1px solid var(--border);
  background:var(--soft);
  box-shadow:var(--shadow2);
}
.wide-media img{width:100%; aspect-ratio:16/9; object-fit:cover}
.wide-media figcaption{
  padding:.9rem 1rem 1.05rem;
  color:var(--muted);
  font-size:.92rem;
}

.bullets{
  margin:.85rem 0 0;
  padding-left:1.1rem;
}
.bullets li{margin:.4rem 0}

.room-cards{
  display:grid;
  gap:.9rem;
  margin:1rem 0 0;
}
.mini-card{
  border:1px solid var(--border);
  border-radius:var(--radius2);
  background:var(--soft);
  padding:1rem 1rem;
}
.mini-card h4{
  margin:0 0 .45rem;
  font-size:1.02rem;
}
.mini-card p{margin:0; color:var(--text)}

.room-table{
  margin-top:1.2rem;
  border:1px solid var(--border);
  border-radius:var(--radius2);
  overflow:hidden;
  background:var(--card);
  box-shadow:var(--shadow2);
}
.room-row{
  display:grid;
  grid-template-columns:1.05fr 1.05fr .9fr 1.4fr;
  gap:.75rem;
  padding:.9rem 1rem;
  border-top:1px solid var(--border);
}
.room-row.header{
  border-top:none;
  background:var(--soft);
  font-weight:800;
  color:var(--text);
}
.room-row div{font-weight:650}

.two-col{
  display:grid;
  gap:1.3rem;
}
.two-col h3{margin:0 0 .55rem}
.two-col p{margin:.65rem 0 0; max-width:78ch}

.experience-grid, .persona-grid{
  display:grid;
  gap:1rem;
  margin-top:1.2rem;
}

.site-footer{
  margin-top:2.75rem;
  padding:2rem 0 2.25rem;
  border-top:1px solid var(--border);
  background:var(--bg);
}
.footer-grid{
  display:grid;
  gap:1rem;
  align-items:start;
}
.footer-title{
  margin:0 0 .45rem;
  font-weight:850;
  letter-spacing:.01em;
}
.footer-disclaimer{
  margin:0;
  color:var(--muted);
  max-width:85ch;
}
.footer-links{
  display:flex;
  flex-wrap:wrap;
  gap:.9rem;
  align-items:center;
}
.footer-links a{
  text-decoration:none;
  font-weight:750;
  padding:.55rem .75rem;
  border-radius:999px;
  border:1px solid var(--border);
}
.footer-links a:hover{background:var(--soft)}

.policy-page .policy-hero{
  padding:2.25rem 0 1.25rem;
}
.policy{
  max-width:92ch;
}
.policy h2{
  margin:0 0 .75rem;
  font-family:"Playfair Display", Georgia, serif;
  font-size:1.6rem;
  line-height:1.22;
}
.policy h3{
  margin:1.25rem 0 .45rem;
  font-size:1.08rem;
}
.policy p{margin:.7rem 0 0}
.policy-box{
  margin:1rem 0 0;
  border:1px solid var(--border);
  border-radius:var(--radius2);
  padding:1rem 1rem;
  background:var(--soft);
}
.policy-actions{
  display:flex;
  flex-wrap:wrap;
  gap:.7rem;
  margin-top:1rem;
}
.muted{color:var(--muted)}

.sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

.cookie-banner{
  position:fixed;
  left:0;
  right:0;
  bottom:0;
  z-index:70;
  border-top:1px solid var(--border);
  background:rgba(255,255,255,.94);
  backdrop-filter:saturate(180%) blur(12px);
}
.cookie-inner{
  padding:1rem 0 1.05rem;
  display:grid;
  gap:.85rem;
}
.cookie-text{
  margin:0;
  color:var(--text);
  max-width:110ch;
}
.cookie-link{text-decoration:underline}
.cookie-actions{
  display:flex;
  flex-wrap:wrap;
  gap:.6rem;
}

.cookie-modal{
  position:fixed;
  inset:0;
  z-index:90;
  display:grid;
  place-items:center;
  padding:1.25rem;
}
.cookie-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(15,23,42,.45);
}
.cookie-modal-panel{
  position:relative;
  width:min(720px, 100%);
  border-radius:var(--radius2);
  background:var(--bg);
  border:1px solid var(--border);
  box-shadow:var(--shadow);
  overflow:hidden;
}
.cookie-modal-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding:1.1rem 1.1rem;
  border-bottom:1px solid var(--border);
  background:var(--soft);
}
.cookie-modal-title{
  margin:0;
  font-family:"Playfair Display", Georgia, serif;
  font-size:1.4rem;
  line-height:1.2;
}
.icon-btn{
  width:40px;
  height:40px;
  border-radius:999px;
  border:1px solid var(--border);
  background:var(--bg);
  cursor:pointer;
  font-size:1.4rem;
  line-height:1;
  display:grid;
  place-items:center;
}
.cookie-modal-body{
  padding:1.1rem 1.1rem 1.25rem;
}
.cookie-option{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:1rem;
  padding:1rem 0;
  border-top:1px solid var(--border);
}
.cookie-option:first-of-type{border-top:none}
.cookie-option h3{margin:0 0 .25rem; font-size:1.06rem}
.cookie-option p{margin:0; color:var(--muted)}
.cookie-option-control{padding-top:.15rem}

.pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  border:1px solid var(--border);
  padding:.45rem .65rem;
  font-weight:800;
  background:var(--soft);
}
.pill.locked{
  background:linear-gradient(135deg, rgba(74,108,247,.14), rgba(111,168,255,.14));
  border-color:rgba(74,108,247,.25);
}

.switch{
  display:inline-flex;
  align-items:center;
  gap:.55rem;
}
.switch input{
  position:absolute;
  opacity:0;
  width:1px;
  height:1px;
}
.switch-ui{
  width:50px;
  height:30px;
  border-radius:999px;
  background:#E6E9EE;
  border:1px solid var(--border);
  position:relative;
  flex:0 0 auto;
  transition:background .15s ease, border-color .15s ease;
}
.switch-ui::after{
  content:"";
  position:absolute;
  top:50%;
  left:4px;
  transform:translateY(-50%);
  width:22px;
  height:22px;
  border-radius:999px;
  background:#fff;
  box-shadow:0 8px 18px rgba(15,23,42,.12);
  transition:left .15s ease;
}
.switch input:checked + .switch-ui{
  background:linear-gradient(135deg, rgba(74,108,247,.35), rgba(111,168,255,.35));
  border-color:rgba(74,108,247,.35);
}
.switch input:checked + .switch-ui::after{left:24px}

.cookie-modal-footer{
  padding:1rem 1.1rem 1.15rem;
  border-top:1px solid var(--border);
  background:var(--soft);
  display:flex;
  justify-content:flex-end;
  gap:.7rem;
  flex-wrap:wrap;
}

.reveal{
  opacity:0;
  transform:translateY(14px);
  transition:opacity .6s ease, transform .6s ease;
}
.reveal.is-visible{
  opacity:1;
  transform:translateY(0);
}

@media (min-width: 880px){
  .site-nav{display:block}
  .nav-toggle{display:none}
  .hero{padding:3rem 0 3.25rem}
  .hero-grid{grid-template-columns:1.1fr .9fr; gap:2.2rem; align-items:center}
  .hero-title{font-size:2.65rem}
  .intro-grid{grid-template-columns:1.2fr .8fr; align-items:start}
  .section-grid{grid-template-columns:1.1fr .9fr; gap:2.2rem}
  .two-col{grid-template-columns:1fr 1fr; gap:2rem}
  .experience-grid{grid-template-columns:1fr 1fr 1fr}
  .persona-grid{grid-template-columns:1fr 1fr 1fr 1fr}
  .location-grid{grid-template-columns:1fr 1fr; gap:1.1rem}
  .footer-grid{grid-template-columns:1.2fr .8fr; align-items:center}
  .cookie-inner{grid-template-columns:1.2fr .8fr; align-items:center}
  .cookie-actions{justify-content:flex-end}
}

@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  .reveal{opacity:1; transform:none; transition:none}
  .btn{transition:none}
}
[hidden]{
  display:none !important;
}

.brand{
  display:flex;
  align-items:center;
  gap:.75rem;
  min-width:220px;
  text-decoration:none;
  color:var(--text);
}

.brand-logo{
  width:40px;
  height:40px;
  border-radius:12px;
  object-fit:cover;
  border:1px solid var(--border);
  background:var(--soft);
  box-shadow:0 10px 22px rgba(15, 23, 42, .08);
  flex:0 0 auto;
}

.brand-text{
  display:flex;
  flex-direction:column;
  line-height:1.1;
  gap:.18rem;
}

.brand-name{
  font-weight:800;
  letter-spacing:.01em;
}

.brand-tagline{
  font-size:.86rem;
  color:var(--muted);
  font-weight:650;
}
