:root{
  --black:#000000;
  --white:#FFFFFF;
  --accent:#EFB7B7;
  --gray:#F4F4F4;
  --muted:rgba(0,0,0,.65);
  --line:rgba(0,0,0,.12);
  --shadow:0 10px 30px rgba(0,0,0,.08);
  --radius:18px;
  --radius2:28px;
  --max:1160px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji";
  color:var(--black);
  background:var(--white);
  line-height:1.5;
}

a{color:inherit}
img{max-width:100%;height:auto;display:block}

.container{max-width:var(--max);margin:0 auto;padding:0 18px}
.skip{
  position:absolute;left:-999px;top:12px;
  background:var(--black);color:var(--white);
  padding:10px 14px;border-radius:10px;z-index:50;
}
.skip:focus{left:12px}

.header{
  position:sticky;top:0;z-index:40;
  background:rgba(255,255,255,.88);
  backdrop-filter:saturate(1.2) blur(10px);
  border-bottom:1px solid var(--line);
}
.header--simple{position:relative;background:var(--white);backdrop-filter:none}
.header__inner{
  display:flex;align-items:center;justify-content:space-between;
  gap:16px;min-height:72px;
}

.brand{
  display:flex;align-items:center;gap:12px;
  text-decoration:none;
}
.brand__mark{
  width:34px;height:34px;border-radius:12px;
  background:linear-gradient(135deg,var(--accent),rgba(239,183,183,.55));
  border:1px solid rgba(0,0,0,.08);
  box-shadow:0 10px 22px rgba(0,0,0,.08);
}
.brand__text{display:flex;flex-direction:column;line-height:1.05}
.brand__name{font-weight:800;letter-spacing:.2px}
.brand__sub{font-size:12px;color:var(--muted)}

.nav{display:flex;align-items:center;gap:12px}
.nav__toggle{
  display:none;
  border:1px solid var(--line);
  background:var(--white);
  border-radius:14px;
  padding:10px 12px;
  gap:10px;
  align-items:center;
  cursor:pointer;
}
.nav__toggleLines{
  width:18px;height:12px;display:inline-block;
  background:
    linear-gradient(var(--black),var(--black)) 0 0/100% 2px no-repeat,
    linear-gradient(var(--black),var(--black)) 0 50%/100% 2px no-repeat,
    linear-gradient(var(--black),var(--black)) 0 100%/100% 2px no-repeat;
  border-radius:2px;
}
.nav__toggleText{font-size:13px}
.nav__menu{
  display:flex;align-items:center;gap:16px;
}
.nav__menu a{
  text-decoration:none;
  padding:10px 10px;
  border-radius:12px;
}
.nav__menu a:hover{background:var(--gray)}
.nav--simple a{padding:10px 12px;border-radius:12px;text-decoration:none}
.nav--simple a:hover{background:var(--gray)}

.btn{
  display:inline-flex;align-items:center;justify-content:center;
  text-decoration:none;
  background:var(--black);
  color:var(--white);
  padding:14px 18px;
  border-radius:16px;
  border:1px solid var(--black);
  box-shadow:0 12px 26px rgba(0,0,0,.12);
  cursor:pointer;
  font-weight:700;
}
.btn:hover{transform:translateY(-1px)}
.btn--ghost{
  background:var(--white);
  color:var(--black);
  border:1px solid var(--line);
  box-shadow:none;
}
.btn--small{padding:10px 14px;border-radius:14px;font-weight:700}
.btn--wide{width:100%}
.link{
  display:inline-flex;gap:10px;align-items:center;
  text-decoration:none;
  padding:10px 0;
  color:rgba(0,0,0,.85);
}
.link:hover{text-decoration:underline}

.hero{
  padding:54px 0 18px;
  background:
    radial-gradient(900px 240px at 18% 12%, rgba(239,183,183,.45), rgba(239,183,183,0)),
    radial-gradient(900px 240px at 85% 28%, rgba(0,0,0,.06), rgba(0,0,0,0));
}
.hero__grid{
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:28px;
  align-items:stretch;
}
.pill{
  display:inline-flex;align-items:center;gap:10px;
  padding:10px 12px;
  background:rgba(0,0,0,.04);
  border:1px solid var(--line);
  border-radius:999px;
  font-size:13px;
  color:rgba(0,0,0,.78);
}
.dot{
  width:8px;height:8px;border-radius:99px;
  background:var(--accent);
  box-shadow:0 0 0 6px rgba(239,183,183,.28);
}
h1{
  font-size:54px;
  line-height:1.05;
  margin:14px 0 10px;
  letter-spacing:-.6px;
}
.lead{font-size:18px;color:var(--muted);max-width:56ch}
.hero__cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}

.hero__highlights{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
  margin-top:22px;
}
.stat{
  background:rgba(255,255,255,.75);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:12px 12px;
}
.stat__num{font-size:20px;font-weight:900}
.stat__label{font-size:12px;color:var(--muted)}

.heroCard{
  border-radius:var(--radius2);
  overflow:hidden;
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  background:var(--white);
  height:100%;
  display:flex;
  flex-direction:column;
}
.heroCard__img{flex:1;min-height:340px;background-size:cover;background-position:center}
.heroCard__panel{padding:14px 14px 16px;display:flex;flex-direction:column;gap:10px}
.heroCard__panelRow{display:flex;align-items:center;justify-content:space-between;gap:12px}
.badge{
  display:inline-flex;align-items:center;
  padding:6px 10px;border-radius:999px;
  background:rgba(239,183,183,.35);
  border:1px solid rgba(0,0,0,.08);
  font-size:12px;font-weight:800;
}
.strong{font-weight:900}
.muted{color:var(--muted)}

.trust{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;
  margin-top:18px;
}
.trust__item{
  padding:14px 14px;
  background:var(--white);
  border:1px solid var(--line);
  border-radius:var(--radius);
}
.trust__title{font-weight:900;display:block}
.trust__text{display:block;color:var(--muted);font-size:13px;margin-top:6px}

.section{padding:64px 0}
.section--alt{background:var(--gray)}
.sectionHead{display:flex;flex-direction:column;gap:8px;margin-bottom:22px}
.sectionHead h2{margin:0;font-size:34px;letter-spacing:-.3px}
.sectionHead p{margin:0;color:var(--muted);max-width:70ch}

.cards{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
}
.card{
  background:var(--white);
  border:1px solid var(--line);
  border-radius:var(--radius2);
  padding:18px 18px;
  box-shadow:0 12px 30px rgba(0,0,0,.06);
  min-height:240px;
}
.card h3{margin:0 0 8px;font-size:18px}
.card p{margin:0 0 12px;color:var(--muted)}
.list{margin:0;padding-left:18px;color:rgba(0,0,0,.78)}
.list li{margin:6px 0}
.list--tight li{margin:4px 0}

.featureGrid{
  margin-top:16px;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;
}
.feature{
  display:flex;gap:12px;
  background:rgba(255,255,255,.7);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:14px 14px;
}
.feature__icon{
  width:38px;height:38px;border-radius:14px;
  background:rgba(239,183,183,.35);
  border:1px solid rgba(0,0,0,.08);
}
.feature__body{display:flex;flex-direction:column;gap:4px}

.team{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
}
.person{
  border:1px solid var(--line);
  border-radius:var(--radius2);
  overflow:hidden;
  background:var(--white);
  box-shadow:0 12px 30px rgba(0,0,0,.06);
}
.person__img{height:240px;background-size:cover;background-position:center}
.person__meta{padding:16px 16px 18px}
.person__name{font-weight:900;font-size:18px}
.person__role{color:var(--muted);font-size:13px;margin-top:2px}
.person__text{color:rgba(0,0,0,.78);margin:10px 0 12px}
.chip{
  display:inline-flex;align-items:center;justify-content:center;
  padding:10px 12px;
  border-radius:999px;
  border:1px solid var(--line);
  background:rgba(0,0,0,.03);
  text-decoration:none;
  font-weight:800;
}
.chip:hover{background:rgba(239,183,183,.22);border-color:rgba(0,0,0,.12)}

.gallery{
  margin-top:14px;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;
}
.gallery__item{
  border-radius:var(--radius2);
  border:1px solid var(--line);
  height:180px;
  background-size:cover;
  background-position:center;
  box-shadow:0 12px 26px rgba(0,0,0,.06);
}

.priceGrid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
}
.priceCard{
  background:var(--white);
  border:1px solid var(--line);
  border-radius:var(--radius2);
  padding:18px 18px;
  box-shadow:0 12px 30px rgba(0,0,0,.06);
}
.priceCard--accent{
  border-color:rgba(239,183,183,.9);
  box-shadow:0 18px 40px rgba(239,183,183,.22);
}
.priceCard__top{display:flex;align-items:flex-end;justify-content:space-between;gap:12px}
.priceCard h3{margin:0;font-size:18px}
.price{font-weight:950;font-size:18px}
.divider{height:1px;background:var(--line);margin:12px 0}

.noteBox{
  margin-top:14px;
  border-radius:var(--radius2);
  border:1px solid rgba(0,0,0,.1);
  background:rgba(239,183,183,.18);
  padding:18px 18px;
}

.booking{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:14px;
}
.form{
  border:1px solid var(--line);
  border-radius:var(--radius2);
  padding:18px 18px;
  background:var(--white);
  box-shadow:0 12px 30px rgba(0,0,0,.06);
}
.form__row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
.field{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}
label{font-weight:800}
input,select,textarea{
  width:100%;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid rgba(0,0,0,.16);
  background:rgba(0,0,0,.02);
  font:inherit;
}
textarea{resize:vertical}
input:focus,select:focus,textarea:focus{outline:2px solid rgba(239,183,183,.85);border-color:rgba(0,0,0,.2);background:var(--white)}
.field__hint{font-size:12px;color:var(--muted)}

.consent{display:flex;flex-direction:column;gap:10px;margin:10px 0 14px}
.check{display:flex;gap:10px;align-items:flex-start;color:rgba(0,0,0,.8)}
.check input{margin-top:4px;width:auto}

.formMsg{
  margin-top:12px;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid var(--line);
  background:rgba(0,0,0,.02);
  color:rgba(0,0,0,.8);
  display:none;
}

.bookingInfo{display:flex;flex-direction:column;gap:12px}
.bookingInfo__card{
  border:1px solid var(--line);
  border-radius:var(--radius2);
  padding:16px 16px;
  background:var(--white);
  box-shadow:0 12px 30px rgba(0,0,0,.06);
}
.hours{display:flex;flex-direction:column;gap:8px;margin-top:10px}
.hours__row{display:flex;justify-content:space-between;gap:12px}
.contactList{display:flex;flex-direction:column;gap:10px;margin-top:12px}
.contactItem__k{color:var(--muted);font-size:12px}
.contactItem__v a{text-decoration:none}
.contactItem__v a:hover{text-decoration:underline}

.quotes{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
}
.quote{
  margin:0;
  border:1px solid var(--line);
  border-radius:var(--radius2);
  padding:18px 18px;
  background:var(--white);
  box-shadow:0 12px 30px rgba(0,0,0,.06);
}
.quote blockquote{margin:0;font-weight:850;letter-spacing:-.2px}
.quote figcaption{margin-top:10px;color:var(--muted)}

.accordion{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
.acc{
  border:1px solid var(--line);
  border-radius:var(--radius2);
  background:var(--white);
  padding:14px 14px;
  box-shadow:0 12px 30px rgba(0,0,0,.06);
}
.acc summary{cursor:pointer;font-weight:900}
.acc__body{margin-top:10px;color:rgba(0,0,0,.78)}

.contact{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  align-items:start;
}
.contactCard{
  border:1px solid var(--line);
  border-radius:var(--radius2);
  padding:18px 18px;
  background:var(--white);
  box-shadow:0 12px 30px rgba(0,0,0,.06);
}
.contactCard__row{display:flex;align-items:center;justify-content:space-between;gap:12px}
.contactCard__grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
.mapWrap{
  border-radius:var(--radius2);
  overflow:hidden;
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  background:var(--white);
}
.mapWrap iframe{width:100%;height:420px;border:0;display:block}
.mapMeta{padding:12px 14px;border-top:1px solid var(--line);background:rgba(0,0,0,.02)}
.mapMeta .link{padding:0}

.ctaBand{
  margin-top:12px;
  border-radius:var(--radius2);
  border:1px solid rgba(0,0,0,.1);
  background:linear-gradient(135deg,rgba(239,183,183,.3),rgba(0,0,0,.03));
  padding:18px 18px;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
}
.ctaBand__text{display:flex;flex-direction:column;gap:2px}

.footer{
  border-top:1px solid var(--line);
  padding:24px 0;
  background:var(--white);
}
.footer__inner{display:flex;align-items:center;justify-content:space-between;gap:12px}
.footer__right{display:flex;gap:14px;flex-wrap:wrap}
.footer__right a{text-decoration:none;padding:8px 10px;border-radius:12px}
.footer__right a:hover{background:var(--gray)}
.brand--footer .brand__mark{width:26px;height:26px;border-radius:10px}

.cookie{
  position:fixed;
  left:14px;right:14px;bottom:14px;
  display:none;
  z-index:60;
}
.cookie__inner{
  max-width:var(--max);
  margin:0 auto;
  border:1px solid rgba(0,0,0,.14);
  border-radius:var(--radius2);
  background:rgba(255,255,255,.95);
  backdrop-filter:saturate(1.2) blur(10px);
  box-shadow:0 18px 60px rgba(0,0,0,.16);
  padding:14px 14px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
}
.cookie__text{display:flex;flex-direction:column;gap:6px;max-width:72ch}
.cookie__actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}

.legal{padding:48px 0}
.legalHead{margin-bottom:18px}
.legalHead h1{font-size:40px;margin:0 0 8px}
.legalBlock{
  border:1px solid var(--line);
  border-radius:var(--radius2);
  background:var(--white);
  box-shadow:0 12px 30px rgba(0,0,0,.06);
  padding:18px 18px;
  margin-bottom:12px;
}
.legalBlock h2{margin:0 0 10px;font-size:18px}
.legalBlock p{margin:0 0 10px;color:rgba(0,0,0,.8)}
.legalActions{display:flex;gap:12px;flex-wrap:wrap;margin-top:10px}
.legalBack{margin-top:16px}
.tableWrap{overflow:auto;border-radius:16px;border:1px solid var(--line)}
.table{width:100%;border-collapse:collapse;min-width:720px;background:var(--white)}
.table th,.table td{padding:12px 12px;border-bottom:1px solid var(--line);text-align:left}
.table th{background:rgba(0,0,0,.03);font-weight:900}

@media (max-width:1024px){
  h1{font-size:44px}
  .hero__grid{grid-template-columns:1fr}
  .heroCard__img{min-height:300px}
  .cards{grid-template-columns:repeat(2,1fr)}
  .featureGrid{grid-template-columns:repeat(2,1fr)}
  .trust{grid-template-columns:repeat(2,1fr)}
  .team{grid-template-columns:1fr}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .priceGrid{grid-template-columns:repeat(2,1fr)}
  .quotes{grid-template-columns:1fr}
  .accordion{grid-template-columns:1fr}
  .contact{grid-template-columns:1fr}
  .booking{grid-template-columns:1fr}
}

@media (max-width:720px){
  .nav__toggle{display:inline-flex}
  .nav__menu{
    position:absolute;
    right:18px;
    top:72px;
    flex-direction:column;
    align-items:stretch;
    background:rgba(255,255,255,.98);
    border:1px solid var(--line);
    border-radius:18px;
    box-shadow:var(--shadow);
    padding:10px;
    min-width:220px;
    display:none;
  }
  .nav__menu a{padding:12px 12px}
  .nav__menu.is-open{display:flex}
  .form__row{grid-template-columns:1fr}
  .hero__highlights{grid-template-columns:1fr}
  .footer__inner{flex-direction:column;align-items:flex-start}
  .cookie__inner{flex-direction:column;align-items:flex-start}
  h1{font-size:38px}
}

.section--tallBg{padding:0}
.tallBg{
  position:relative;
  min-height:86vh;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  background-size:cover;
  background-position:center;
  background-attachment:fixed;
  display:flex;
  align-items:center;
}
.tallBg__overlay{
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, rgba(255,255,255,.92) 0%, rgba(255,255,255,.72) 45%, rgba(255,255,255,.18) 100%),
    radial-gradient(900px 320px at 20% 40%, rgba(239,183,183,.38), rgba(239,183,183,0));
}
.tallBg__content{
  position:relative;
  width:100%;
  padding:66px 18px;
}
.tallBg__card{
  max-width:640px;
  background:rgba(255,255,255,.88);
  backdrop-filter:saturate(1.2) blur(10px);
  border:1px solid rgba(0,0,0,.12);
  box-shadow:0 18px 60px rgba(0,0,0,.16);
  border-radius:var(--radius2);
  padding:22px 22px;
}
.tallBg__card h2{
  margin:14px 0 10px;
  font-size:36px;
  letter-spacing:-.3px;
}
.tallBg__points{
  margin-top:14px;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
}
.point{
  border:1px solid var(--line);
  border-radius:16px;
  background:rgba(0,0,0,.02);
  padding:12px 12px;
}
.point__k{font-size:12px;color:var(--muted)}
.point__v{font-weight:900}
.tallBg__cta{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:16px;
}

@media (max-width:1024px){
  .tallBg{background-attachment:scroll}
}
@media (max-width:720px){
  .tallBg__card h2{font-size:30px}
  .tallBg__points{grid-template-columns:1fr}
}

