
:root{
  --bg:#f7efe9;
  --bg-soft:#f1dfd7;
  --bg-deep:#e9d2ca;
  --card:#fffaf7;
  --text:#523a34;
  --muted:#8a6e66;
  --accent:#b9786b;
  --accent-dark:#a7695b;
  --line:#e6d5cd;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: Georgia, "Times New Roman", serif;
  color:var(--text);
  background:var(--bg);
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
.container{width:min(1180px, calc(100% - 32px)); margin:0 auto}
.topbar{
  position:sticky; top:0; z-index:20;
  background:rgba(250,244,240,.96);
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--line);
}
.nav{
  display:flex; align-items:center; justify-content:space-between;
  gap:20px; min-height:82px;
}
.brand{display:flex;align-items:center;gap:12px}
.brand img{width:60px;height:60px;object-fit:cover;border-radius:50%}
.brand-text strong{display:block;font-size:1.45rem;line-height:1}
.brand-text span{
  display:block; margin-top:4px;
  font-family: Arial, Helvetica, sans-serif;
  text-transform:uppercase; letter-spacing:.18em; font-size:.68rem;
  color:#b78779;
}
.nav-links{
  display:flex; gap:30px; align-items:center;
  font-family: Arial, Helvetica, sans-serif;
  text-transform:uppercase; letter-spacing:.14em; font-size:.7rem; font-weight:600;
  color:#6b514b;
}
.nav-links a.active,.nav-links a:hover{color:var(--accent)}
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  border:1px solid transparent;
  background:var(--accent); color:white;
  padding:14px 22px;
  font-family: Arial, Helvetica, sans-serif;
  text-transform:uppercase; letter-spacing:.14em; font-size:.68rem; font-weight:700;
  transition:.2s ease; cursor:pointer;
}
.btn:hover{background:var(--accent-dark)}
.btn.outline{background:transparent;color:var(--accent);border-color:#c99a8d}
.btn.outline:hover{background:#f8f0eb}
.mobile-toggle{display:none}
.mobile-menu{display:none}
.hero{
  background:var(--bg-deep);
  border-bottom:1px solid var(--line);
}
.hero-grid{
  display:grid; grid-template-columns: 0.95fr 1.05fr; align-items:center;
}
.hero-copy{padding:66px 26px 66px 10px}
.eyebrow{
  font-family: Arial, Helvetica, sans-serif;
  text-transform:uppercase; letter-spacing:.22em; font-size:.68rem; font-weight:700;
  color:#c08b7d;
}
.hero h1{font-size:4rem; line-height:.98; margin:14px 0 0}
.rule{width:110px;height:1px;background:#b77a6d;margin:24px 0}
.subhero{font-size:2rem; line-height:1.15; margin:0}
.lead{
  font-family: Arial, Helvetica, sans-serif;
  font-size:.96rem; line-height:1.9; color:#6d564e;
}
.hero-image-wrap{
  padding:26px 18px 18px;
}
.hero-card{
  background:#ecd7cf;
  border-left:1px solid rgba(255,255,255,.35);
  display:flex; justify-content:center; align-items:flex-end;
  min-height:520px; overflow:hidden;
}
.hero-card img{
  width:min(590px, 100%);
  max-height:520px;
  object-fit:cover; object-position:center top;
  filter: saturate(1.02) contrast(1.01);
}
.page-hero{
  background:linear-gradient(180deg,#f4e6df 0%,#f8f1ec 100%);
  border-bottom:1px solid var(--line);
  padding:54px 0;
}
.page-hero h1{font-size:3.2rem; margin:10px 0}
.page-hero p{
  max-width:720px;
  font-family: Arial, Helvetica, sans-serif;
  color:var(--muted); line-height:1.85; font-size:1rem;
}
.section{padding:72px 0}
.section.soft{background:#f8f1ec}
.section.deep{background:#ecd7cf}
.section-title{text-align:center; margin-bottom:28px}
.section-title h2{font-size:3rem; margin:12px 0 0}
.section-title p{
  font-family: Arial, Helvetica, sans-serif; color:var(--muted);
  max-width:720px; margin:14px auto 0; line-height:1.85
}
.service-strip{
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:0; background:#f9f2ed; border-bottom:1px solid var(--line)
}
.service-item{
  padding:28px 24px; text-align:center; border-right:1px solid var(--line)
}
.service-item:last-child{border-right:0}
.service-item h3{margin:8px 0 6px; font-size:1.45rem}
.service-item p{
  margin:0;
  font-family: Arial, Helvetica, sans-serif; color:var(--muted); font-size:.82rem; line-height:1.7
}
.about-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:56px;align-items:center}
.logo-panel{display:flex;justify-content:center}
.logo-panel img{max-width:360px}
.about-copy h2{font-size:3.2rem; line-height:1.02; margin:10px 0 0}
.about-copy h2 span{display:block;color:#c08578;font-style:italic;font-weight:400}
.about-copy p, .text-block p{
  font-family: Arial, Helvetica, sans-serif;
  color:#6c554d; line-height:1.9; font-size:.96rem;
}
.gallery-grid{
  display:grid; gap:18px;
  grid-template-columns: repeat(4, minmax(0,1fr));
}
.gallery-card{
  border:1px solid var(--line); background:white; overflow:hidden;
  border-radius:16px; box-shadow: 0 8px 20px rgba(90,62,54,.06);
}
.gallery-card img{
  width:100%; height:100%; min-height:280px; object-fit:cover; object-position:center;
}
.gallery-grid.featured .gallery-card:nth-child(1){grid-column:span 2; grid-row:span 2}
.gallery-grid.featured .gallery-card:nth-child(1) img{min-height:578px}
.booking-grid{display:grid;grid-template-columns:1.04fr .96fr;gap:34px;align-items:start}
.price-card, .card{
  background:var(--card); border:1px solid #dfc7bf; border-radius:22px; padding:30px;
  box-shadow:0 8px 18px rgba(85,56,49,.06);
}
.price-row{
  display:flex; justify-content:space-between; gap:16px; padding:15px 0; border-bottom:1px solid var(--line);
  font-family: Arial, Helvetica, sans-serif; color:#6e564e; font-size:.95rem;
}
.price-row:last-child{border-bottom:0}
.feature-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:26px;align-items:center}
.feature-image{
  border-radius:26px; overflow:hidden; border:1px solid var(--line); box-shadow: 0 10px 22px rgba(83,57,49,.08);
}
.feature-image img{width:100%; height:100%; min-height:420px; object-fit:cover}
.feature-cards{display:grid; gap:18px}
.service-card{
  background:var(--card); border:1px solid var(--line); border-radius:22px; padding:24px;
  box-shadow:0 8px 18px rgba(85,56,49,.05);
}
.service-card h3{font-size:1.8rem; margin:0 0 8px}
.service-card p{
  margin:0;
  font-family: Arial, Helvetica, sans-serif; color:var(--muted); line-height:1.8; font-size:.93rem
}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.contact-box{
  display:flex; flex-direction:column; gap:12px;
  font-family: Arial, Helvetica, sans-serif; color:#6c554d; font-size:.95rem; line-height:1.7
}
.contact-box a{color:#7e5d54}
.contact-box a:hover{color:var(--accent)}
footer{
  border-top:1px solid var(--line); background:#f8f1ec; padding:30px 0
}
.footer-inner{
  display:flex; align-items:center; justify-content:space-between; gap:18px;
  font-family: Arial, Helvetica, sans-serif; color:#7f635a; font-size:.88rem
}
.footer-brand{display:flex;align-items:center;gap:12px}
.footer-brand img{width:44px;height:44px;border-radius:50%;object-fit:cover}
.spaced-list{
  display:grid; gap:14px; font-family: Arial, Helvetica, sans-serif; color:#6c554d; font-size:.95rem; line-height:1.8
}
.tagline{
  font-family: Arial, Helvetica, sans-serif; text-transform:uppercase; letter-spacing:.18em; font-size:.68rem; color:#b78779
}
@media (max-width: 980px){
  .nav-links,.nav .btn{display:none}
  .mobile-toggle{display:inline-flex; align-items:center; justify-content:center; width:46px;height:46px; border-radius:999px; border:1px solid #dcc8c0; background:white; color:#7b5f56}
  .mobile-menu.open{
    display:grid; gap:14px; padding:0 0 20px;
    font-family: Arial, Helvetica, sans-serif; text-transform:uppercase; letter-spacing:.12em; font-size:.76rem
  }
  .hero-grid,.about-grid,.feature-grid,.booking-grid,.two-col{grid-template-columns:1fr}
  .service-strip{grid-template-columns:repeat(2,1fr)}
  .service-item:nth-child(2){border-right:0}
  .gallery-grid,.gallery-grid.featured{grid-template-columns:repeat(2, minmax(0,1fr))}
  .gallery-grid.featured .gallery-card:nth-child(1){grid-column:span 2; grid-row:span 1}
  .gallery-grid.featured .gallery-card:nth-child(1) img{min-height:360px}
  .hero-card{min-height:unset}
  .hero-card img{max-height:460px}
  .page-hero h1,.section-title h2,.about-copy h2{font-size:2.5rem}
}
@media (max-width: 640px){
  .container{width:min(100% - 20px, 1180px)}
  .brand-text{display:none}
  .hero-copy{padding:40px 0 24px}
  .hero h1{font-size:3rem}
  .subhero{font-size:1.65rem}
  .hero-image-wrap{padding:0 0 18px}
  .service-strip{grid-template-columns:1fr}
  .service-item{border-right:0;border-bottom:1px solid var(--line)}
  .service-item:last-child{border-bottom:0}
  .gallery-grid,.gallery-grid.featured{grid-template-columns:1fr}
  .gallery-grid.featured .gallery-card:nth-child(1){grid-column:span 1}
  .gallery-grid.featured .gallery-card:nth-child(1) img{min-height:320px}
  .gallery-card img{min-height:240px}
  .page-hero{padding:42px 0}
  .page-hero h1,.section-title h2,.about-copy h2{font-size:2.05rem}
  .footer-inner{flex-direction:column;text-align:center}
}


.feature-grid{
  display:grid;
  grid-template-columns: minmax(320px, 420px) 1fr;
  gap:36px;
  align-items:center;
}
.feature-image img{
  width:100%;
  border-radius:28px;
  object-fit:cover;
  max-height:540px;
  box-shadow:0 12px 30px rgba(98,68,59,.08);
}
.text-block h2{
  line-height:1.08;
}
.service-photo-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:24px;
}
.service-photo-card{
  overflow:hidden;
  border:1px solid var(--line);
  border-radius:26px;
  background:#fffaf7;
  box-shadow:0 12px 30px rgba(98,68,59,.06);
}
.service-photo-card img{
  width:100%;
  height:330px;
  object-fit:cover;
}
.service-photo-copy{
  padding:22px 22px 24px;
}
.service-photo-copy h3{
  margin:8px 0 10px;
  font-size:2rem;
}
.service-photo-copy p{
  margin:0;
  font-family:Arial, Helvetica, sans-serif;
  color:#6c554d;
  line-height:1.85;
}
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}
.gallery-card{
  overflow:hidden;
  border-radius:20px;
  border:1px solid var(--line);
  background:#fff;
  box-shadow:0 10px 24px rgba(98,68,59,.05);
}
.gallery-card img{
  width:100%;
  height:340px;
  object-fit:cover;
}
@media (max-width: 980px){
  .feature-grid,
  .service-photo-grid,
  .gallery-grid{
    grid-template-columns:1fr 1fr;
  }
}
@media (max-width: 720px){
  .feature-grid,
  .service-photo-grid,
  .gallery-grid{
    grid-template-columns:1fr;
  }
}

.brand img{width:auto;height:56px;object-fit:contain;border-radius:0}
.footer-brand img{width:auto;height:58px;border-radius:0;object-fit:contain}
.logo-panel img{max-width:420px;width:100%;height:auto;object-fit:contain}
.hero-card img{width:min(520px,92%);max-height:500px;object-fit:cover;object-position:center top}
.gallery-stock-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:26px}
.gallery-stock-strip .gallery-card img{min-height:180px;height:180px}
@media (max-width: 980px){.gallery-stock-strip{grid-template-columns:repeat(2,1fr)}}
@media (max-width: 640px){.gallery-stock-strip{grid-template-columns:1fr}.brand img{height:48px}.footer-brand img{height:48px}}


.service-cards-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;
}
.service-stock-card{
  overflow:hidden;
  border:1px solid var(--line);
  border-radius:22px;
  background:#f9f3ef;
  box-shadow:0 10px 24px rgba(98,68,59,.05);
}
.service-stock-card img{
  width:100%;
  height:280px;
  object-fit:cover;
  object-position:center;
  display:block;
}
.service-stock-copy{
  padding:16px 18px 18px;
  text-align:center;
}
.service-stock-title{
  font-family:Arial,Helvetica,sans-serif;
  text-transform:uppercase;
  letter-spacing:.16em;
  font-weight:700;
  color:#c08376;
  font-size:1rem;
  line-height:1.45;
  margin-bottom:10px;
}
.service-stock-copy p{
  margin:0 0 10px;
  color:#5d4b45;
  font-family:Arial,Helvetica,sans-serif;
  line-height:1.8;
}
.service-stock-copy ul{
  list-style:none;
  padding:0;
  margin:0;
  color:#5d4b45;
  font-family:Arial,Helvetica,sans-serif;
  line-height:1.9;
}
.service-stock-copy li::before{
  content:"• ";
  color:#c08376;
}
@media (max-width: 1100px){
  .service-cards-grid{grid-template-columns:repeat(2,1fr);}
}
@media (max-width: 680px){
  .service-cards-grid{grid-template-columns:1fr;}
  .service-stock-card img{height:260px;}
}


.home-feature-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
  margin-top:34px;
}
.home-feature-card{
  border:1px solid var(--line);
  border-radius:24px;
  background:#fffaf7;
  box-shadow:0 10px 24px rgba(98,68,59,.05);
  padding:28px 24px;
  text-align:center;
}
.home-feature-icon{
  width:44px;
  height:44px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:#f0ddd6;
  color:#b9786b;
  font-size:1.25rem;
  margin-bottom:14px;
}
.home-feature-card h3{
  margin:0 0 10px;
  font-size:1.7rem;
}
.home-feature-card p{
  margin:0;
  color:#6c554d;
  font-family:Arial,Helvetica,sans-serif;
  line-height:1.85;
}
.home-cta-band{
  margin-top:28px;
  border:1px solid var(--line);
  border-radius:24px;
  background:#ecd7cf;
  padding:26px 28px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
}
.home-cta-band h3{
  margin:8px 0 0;
  font-size:2rem;
}
.home-cta-buttons{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}
@media (max-width: 900px){
  .home-feature-grid{grid-template-columns:1fr;}
  .home-cta-band{flex-direction:column;align-items:flex-start;}
}


.booking-layout{
  display:grid;
  grid-template-columns: minmax(0,1.2fr) minmax(320px,.8fr);
  gap:26px;
  align-items:start;
}
.booking-card,.booking-info-card{
  border:1px solid var(--line);
  border-radius:24px;
  background:#fffaf7;
  box-shadow:0 10px 24px rgba(98,68,59,.05);
  padding:28px;
}
.booking-card h2,.booking-info-card h3{
  margin:10px 0 14px;
  font-size:2.1rem;
}
.booking-form .form-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
}
.booking-form label{
  display:flex;
  flex-direction:column;
  gap:8px;
  font-family:Arial,Helvetica,sans-serif;
  color:#6c554d;
  font-size:.92rem;
}
.booking-form .full-width{
  margin-top:16px;
}
.booking-form input,
.booking-form select,
.booking-form textarea{
  width:100%;
  border:1px solid #ddc7be;
  border-radius:14px;
  background:#fff;
  padding:14px 15px;
  font:inherit;
  color:#523a34;
}
.booking-form input:focus,
.booking-form select:focus,
.booking-form textarea:focus{
  outline:none;
  border-color:#b9786b;
  box-shadow:0 0 0 3px rgba(185,120,107,.14);
}
.form-actions{
  margin-top:18px;
}
.hidden-field{
  position:absolute;
  left:-9999px;
}
.booking-side{
  display:grid;
  gap:20px;
}
.payment-line{
  font-family:Arial,Helvetica,sans-serif;
  color:#6c554d;
  line-height:1.9;
  margin-bottom:8px;
}
.booking-buttons{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:18px;
}
.policy-list{
  margin:0;
  padding-left:18px;
  font-family:Arial,Helvetica,sans-serif;
  color:#6c554d;
  line-height:1.9;
}
@media (max-width: 900px){
  .booking-layout{grid-template-columns:1fr;}
  .booking-form .form-grid{grid-template-columns:1fr;}
}


.center-hero{text-align:center;}
.center-hero h1,.center-hero p{margin-left:auto;margin-right:auto;}
.center-text{text-align:center;}
.about-copy .btn{display:inline-flex;}
.page-hero h1{
  font-size:clamp(2.4rem, 5vw, 4.5rem);
  line-height:1.06;
  max-width:1100px;
  margin:10px auto 0;
}
.page-hero p{
  max-width:980px;
  margin-left:auto;
  margin-right:auto;
  text-align:center;
}
.section-title{text-align:center;}
.section-title h2,.section-title p{margin-left:auto;margin-right:auto;}
.service-cards-grid{align-items:start;}
.service-stock-copy{text-align:center;}
.service-stock-copy ul{display:inline-block;text-align:left;}
.gallery-grid{margin-top:10px;}
.footer-inner{text-align:center;}
@media (max-width:900px){
  .footer-inner{display:flex;flex-direction:column;align-items:center;}
}




/* Services page: keep all 5 cards in one row on desktop */
.service-cards-grid-5{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:14px;
  align-items:start;
}
.service-stock-card{
  border:1px solid var(--line);
  background:#fffaf7;
  overflow:hidden;
  border-radius:18px;
  box-shadow:0 8px 18px rgba(90,62,54,.05);
}
.service-stock-card img{
  width:100%;
  height:220px;
  object-fit:cover;
  object-position:center;
  display:block;
}
.service-stock-copy{
  padding:14px 14px 16px;
  text-align:center;
}
.service-stock-title{
  font-family:Arial,Helvetica,sans-serif;
  text-transform:uppercase;
  letter-spacing:.1em;
  font-weight:700;
  color:#c08376;
  font-size:.9rem;
  line-height:1.3;
  margin-bottom:8px;
}
.service-stock-copy p{
  margin:0 0 8px;
  font-family:Arial,Helvetica,sans-serif;
  color:#5d4b45;
  line-height:1.6;
  font-size:.9rem;
}
.service-stock-copy ul{
  display:inline-block;
  text-align:left;
  margin:6px 0 0;
  padding-left:16px;
  font-family:Arial,Helvetica,sans-serif;
  color:#5d4b45;
  line-height:1.65;
  font-size:.88rem;
}
@media (max-width: 1350px){
  .service-cards-grid-5{grid-template-columns:repeat(5,minmax(0,1fr)); gap:12px;}
  .service-stock-card img{height:200px;}
  .service-stock-copy{padding:12px;}
  .service-stock-title{font-size:.84rem;}
  .service-stock-copy p,.service-stock-copy ul{font-size:.82rem;}
}
@media (max-width: 1100px){
  .service-cards-grid-5{grid-template-columns:repeat(3,minmax(0,1fr));}
  .service-stock-card img{height:230px;}
}
@media (max-width: 760px){
  .service-cards-grid-5{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media (max-width: 520px){
  .service-cards-grid-5{grid-template-columns:1fr;}
}

/* Stronger Services layout override */
.services-wide{
  width:min(1520px, calc(100% - 24px));
  margin:0 auto;
}
.service-cards-grid.service-cards-grid-5{
  display:grid !important;
  grid-template-columns:repeat(5, minmax(0, 1fr)) !important;
  gap:12px !important;
  align-items:start !important;
}
.service-cards-grid.service-cards-grid-5 .service-stock-card{
  min-width:0;
}
.service-cards-grid.service-cards-grid-5 .service-stock-card img{
  height:170px !important;
}
.service-cards-grid.service-cards-grid-5 .service-stock-copy{
  padding:12px 10px 14px !important;
}
.service-cards-grid.service-cards-grid-5 .service-stock-title{
  font-size:.78rem !important;
  letter-spacing:.08em !important;
  margin-bottom:6px !important;
}
.service-cards-grid.service-cards-grid-5 .service-stock-copy p{
  font-size:.78rem !important;
  line-height:1.45 !important;
  margin:0 0 6px !important;
}
.service-cards-grid.service-cards-grid-5 .service-stock-copy ul{
  font-size:.76rem !important;
  line-height:1.45 !important;
  padding-left:14px !important;
  margin-top:4px !important;
}
@media (max-width: 980px){
  .service-cards-grid.service-cards-grid-5{
    grid-template-columns:repeat(3, minmax(0, 1fr)) !important;
  }
  .service-cards-grid.service-cards-grid-5 .service-stock-card img{
    height:210px !important;
  }
}
@media (max-width: 700px){
  .service-cards-grid.service-cards-grid-5{
    grid-template-columns:repeat(2, minmax(0, 1fr)) !important;
  }
}
@media (max-width: 480px){
  .service-cards-grid.service-cards-grid-5{
    grid-template-columns:1fr !important;
  }
}


.footer-socials{
  display:flex;
  gap:18px;
  align-items:center;
  justify-content:center;
  flex-wrap:wrap;
  font-family:Arial,Helvetica,sans-serif;
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:.72rem;
}
.footer-socials a{
  color:#7b5f56;
  transition:.2s ease;
}
.footer-socials a:hover{
  color:#b9786b;
}
.footer-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  flex-wrap:wrap;
}
@media (max-width:900px){
  .footer-inner{
    justify-content:center;
    text-align:center;
  }
}


.pricing-list{
  display:grid;
  gap:10px;
  margin-top:6px;
}
.pricing-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:12px 0;
  border-bottom:1px solid var(--line);
  font-family:Arial,Helvetica,sans-serif;
  color:#5d4b45;
  line-height:1.5;
}
.pricing-row:last-child{
  border-bottom:0;
  padding-bottom:0;
}
.pricing-row strong{
  color:#523a34;
  font-weight:700;
}
