:root{
  --beige:#F5EDE6;
  --charcoal:#2B2B2B;
  --blush:#C89B8C;
  --white:#FFFFFF;
  --grey:#F2F2F2;
  --radius:12px;
  --radius-sm:10px;
  --shadow:0 14px 34px rgba(43,43,43,.10);
  --shadow-sm:0 8px 18px rgba(43,43,43,.08);
  --max:1120px;
  --pad:18px;
  --font-body:Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  --font-head:"Playfair Display", Georgia, serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth; -webkit-text-size-adjust:100%; -ms-text-size-adjust:100%; text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--charcoal);
  background:linear-gradient(180deg,var(--beige),#fff);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit; text-decoration:none}
a:focus-visible{outline:3px solid var(--blush); outline-offset:2px; border-radius:4px}
.container{width:min(var(--max),100% - (var(--pad)*2)); margin-inline:auto}

.skip-link{
  position:absolute; left:-999px; top:8px;
  background:var(--white); padding:10px 12px; border-radius:10px;
  box-shadow:var(--shadow-sm); z-index:9999;
}
.skip-link:focus{left:12px}

.header{
  position:sticky; top:0; z-index:50;
  -webkit-backdrop-filter:saturate(1.2) blur(10px);
  backdrop-filter:saturate(1.2) blur(10px);
  background:rgba(245,237,230,.82);
  border-bottom:1px solid rgba(43,43,43,.08);
}
.header__inner{display:flex; align-items:center; justify-content:space-between; gap:14px; padding:10px 0}
.brand{display:flex; align-items:center; gap:10px; text-decoration:none}
.brand__logo{border-radius:10px; background:rgba(255,255,255,.7); padding:6px; box-shadow:var(--shadow-sm)}
.brand__name{font-family:var(--font-head); font-size:16px; font-weight:600; letter-spacing:.2px}
.brand__meta{display:block; font-size:12px; opacity:.7; margin-top:1px}
.nav{display:none; align-items:center; gap:18px}
.nav__link{
  text-decoration:none; font-weight:500; font-size:14px; padding:10px 10px;
  border-radius:10px; opacity:.9;
  transition:all 0.2s ease;
  display:inline-block;
  min-height:44px;
  touch-action:manipulation;
}
.nav__link:hover{background:rgba(255,255,255,.55); transform:translateY(-1px)}
.nav__link:active{transform:translateY(0)}
.nav__link:focus-visible{outline:3px solid var(--blush); outline-offset:2px}
.nav__link.is-active{background:rgba(200,155,140,.18); opacity:1}
.header__actions{display:flex; align-items:center; gap:8px}

.icon-btn{
  display:inline-flex; align-items:center; justify-content:center; gap:6px;
  padding:10px 12px; border-radius:999px;
  border:1px solid rgba(43,43,43,.10);
  background:rgba(255,255,255,.65);
  text-decoration:none; font-weight:600; font-size:13px;
  min-height:44px; min-width:44px;
  white-space:nowrap;
  transition:all 0.2s ease;
  touch-action:manipulation;
  cursor:pointer;
}
.icon-btn svg{width:18px; height:18px; fill:currentColor; flex-shrink:0}
.icon-btn:hover{background:rgba(255,255,255,.9); transform:translateY(-1px)}
.icon-btn:active{transform:translateY(0); background:rgba(255,255,255,.8)}
.icon-btn:focus-visible{outline:3px solid var(--blush); outline-offset:2px}
.icon-btn--login{background:rgba(200,155,140,.15); border-color:rgba(200,155,140,.25)}
.icon-btn--login:hover{background:rgba(200,155,140,.25)}
.icon-btn--admin{background:rgba(200,155,140,.2); border-color:rgba(200,155,140,.3)}
.icon-btn--admin:hover{background:rgba(200,155,140,.3)}

.menu-btn{
  width:44px; height:44px;
  border-radius:12px;
  border:1px solid rgba(43,43,43,.10);
  background:rgba(255,255,255,.65);
  display:grid; place-content:center;
  gap:5px; padding:0; cursor:pointer;
  transition:all 0.2s ease;
  touch-action:manipulation;
}
.menu-btn:hover{background:rgba(255,255,255,.9); transform:scale(1.05)}
.menu-btn:active{transform:scale(0.95)}
.menu-btn:focus-visible{outline:3px solid var(--blush); outline-offset:2px}
.menu-btn span{display:block; width:18px; height:2px; background:var(--charcoal); border-radius:99px; opacity:.9; transition:opacity 0.2s ease}

.mobile-menu{position:fixed; inset:0; display:none; z-index:100}
.mobile-menu.is-open{display:block}
.mobile-menu__backdrop{position:absolute; inset:0; background:rgba(0,0,0,.7)}
.mobile-menu__panel{
  position:absolute; right:0; top:0; height:100%;
  width:min(360px, 92vw);
  background-color:#ffffff;
  background:#ffffff;
  box-shadow:-4px 0 24px rgba(0,0,0,.15);
  display:flex; flex-direction:column;
  padding:20px;
  z-index:101;
}
.mobile-menu__top{display:flex; align-items:center; justify-content:space-between; padding-bottom:14px; margin-bottom:8px; border-bottom:1px solid rgba(43,43,43,.1)}
.mobile-menu__title{font-family:var(--font-head); font-size:20px; font-weight:600; color:var(--charcoal)}
.icon-only{width:44px; height:44px; border-radius:12px; border:1px solid rgba(43,43,43,.12); background:var(--grey); cursor:pointer; display:grid; place-content:center}
.icon-only svg{width:20px; height:20px; fill:var(--charcoal)}
.mobile-menu__links{display:grid; gap:8px; padding:14px 0}
.mobile-menu__links a{
  padding:14px 16px; border-radius:12px; text-decoration:none; font-weight:600;
  background-color:#F5EDE6;
  background:#F5EDE6;
  color:var(--charcoal); font-size:16px;
  border:1px solid rgba(43,43,43,.06);
  opacity:1;
}
.mobile-menu__links a:hover, .mobile-menu__links a:focus{
  background-color:#E8D5C4;
  background:#E8D5C4;
  color:var(--charcoal);
  opacity:1;
}
.mobile-menu__cta{margin-top:auto; display:grid; gap:12px; padding-top:16px; border-top:1px solid rgba(43,43,43,.08)}

main{padding-bottom:82px}

.hero{
  position:relative;
  padding:20px 0 8px;
}
.hero__grid{
  display:grid; gap:14px;
}
.hero-card{
  background:rgba(255,255,255,.72);
  border:1px solid rgba(43,43,43,.10);
  border-radius:var(--radius);
  box-shadow:var(--shadow-sm);
  padding:18px;
}
.hero-card.card--content{
  display:flex;
  flex-direction:column;
  padding:24px;
}
.kicker{display:inline-flex; align-items:center; gap:8px; font-size:13px; font-weight:700; letter-spacing:.4px; text-transform:uppercase; opacity:.8}
.kicker .dot{width:8px; height:8px; border-radius:99px; background:var(--blush); display:inline-block}
h1,h2,h3{margin:0 0 10px}
h1{font-family:var(--font-head); font-size:30px; line-height:1.15; letter-spacing:.2px}
.hero p{margin:0 0 14px; font-size:16px; opacity:.9}
.btn-row{display:flex; flex-wrap:wrap; gap:10px}
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  gap:10px;
  padding:12px 14px;
  border-radius:999px;
  border:1px solid transparent;
  text-decoration:none;
  font-weight:700;
  font-size:14px;
  cursor:pointer;
  transition:transform .08s ease, background .15s ease, border-color .15s ease, box-shadow .15s ease;
  min-height:44px;
  touch-action:manipulation;
  -webkit-tap-highlight-color:transparent;
}
.btn:focus-visible{outline:3px solid var(--blush); outline-offset:2px}
.btn:active{transform:scale(0.98)}
  -webkit-user-select:none;
  user-select:none;
  min-height:44px;
  white-space:nowrap;
  text-align:center;
}
.btn:active{transform:translateY(1px)}
.btn--primary{background:var(--blush); color:#1e1e1e; border-color:rgba(43,43,43,.10)}
.btn--primary:hover{filter:brightness(.98)}
.btn--ghost{background:rgba(255,255,255,.8); border-color:rgba(43,43,43,.12)}
.btn--ghost:hover{background:rgba(255,255,255,1)}
.btn--link{background:transparent; border-color:transparent; padding-inline:0; border-radius:0; text-decoration:underline}
.badges{display:flex; flex-wrap:wrap; gap:8px; margin-top:10px}
.badge{
  background:rgba(245,237,230,.9);
  border:1px solid rgba(43,43,43,.10);
  border-radius:999px;
  padding:7px 10px;
  font-weight:600;
  font-size:13px;
}
.hero-visual{
  border-radius:var(--radius);
  overflow:hidden;
  border:1px solid rgba(43,43,43,.10);
  box-shadow:var(--shadow-sm);
  position:relative;
  min-height:450px;
  max-height:650px;
  background:var(--grey);
  display:flex;
  align-items:stretch;
}
.hero-visual picture{
  width:100%;
  display:flex;
  align-items:stretch;
  height:100%;
}
.hero-visual img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  min-height:450px;
}
.hero-visual::after{
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(43,43,43,.08), rgba(43,43,43,.35));
  pointer-events:none;
}
.hero-visual__label{
  position:absolute; left:12px; bottom:12px; right:12px;
  background:rgba(255,255,255,.85);
  border:1px solid rgba(43,43,43,.10);
  border-radius:14px;
  padding:10px 12px;
  display:flex; justify-content:space-between; align-items:center; gap:10px;
}
.hero-visual__label strong{font-family:var(--font-head)}
.hero-visual__label span{font-size:13px; opacity:.8}

.section{padding:18px 0}
.section__head{display:flex; align-items:flex-end; justify-content:space-between; gap:12px; margin-bottom:12px}
.section__title{font-family:var(--font-head); font-size:22px}
.section__desc{margin:0; opacity:.85; max-width:60ch}

.grid{display:grid; gap:12px}
.cards{display:grid; gap:12px}
.card{
  background:rgba(255,255,255,.85);
  border:1px solid rgba(43,43,43,.10);
  border-radius:var(--radius);
  box-shadow:var(--shadow-sm);
  padding:14px;
}
.card .section__title{
  margin-bottom:12px;
  line-height:1.2;
}
.card .section__desc{
  margin-bottom:0;
  line-height:1.6;
}
.card h3{font-size:16px; margin:0 0 6px}
.card p{margin:0; opacity:.85}
.iconline{display:flex; gap:10px; align-items:flex-start}
.icon{
  width:34px; height:34px; border-radius:12px;
  display:grid; place-content:center;
  background:rgba(200,155,140,.18);
  border:1px solid rgba(43,43,43,.10);
}
.icon svg{width:18px; height:18px; fill:currentColor}
.price-row{display:flex; justify-content:space-between; gap:10px; align-items:baseline; margin-top:10px}
.price-row .price{font-weight:800}

/* Service page styles */
.service-category-header{margin-bottom:20px}
.service-category-header .section__desc{margin-top:8px; margin-bottom:0}

.service-pricing{margin-bottom:20px; flex:1; display:flex; flex-direction:column;}

.service-list{
  display:grid; gap:8px;
  background:rgba(245,237,230,.55);
  border-radius:var(--radius-sm);
  padding:14px;
  border:1px solid rgba(43,43,43,.06);
  flex:1;
  min-height:180px;
}

.service-item{
  display:flex; justify-content:space-between; align-items:baseline;
  gap:12px; padding:10px 0;
  border-bottom:1px solid rgba(43,43,43,.06);
}
.service-item:last-child{border-bottom:none; padding-bottom:0}
.service-item__name{
  flex:1; font-weight:500; font-size:15px;
  line-height:1.4;
}
.service-item__price{
  font-weight:800; font-size:16px;
  color:var(--charcoal);
  white-space:nowrap;
}

.service-cta{
  margin-top:auto; padding-top:16px;
  border-top:1px solid rgba(43,43,43,.08);
}

.card--highlight{
  background:linear-gradient(135deg, rgba(200,155,140,.12), rgba(245,237,230,.4));
  border:1px solid rgba(200,155,140,.25);
}

.pill{
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 10px; border-radius:999px;
  background:rgba(245,237,230,.9);
  border:1px solid rgba(43,43,43,.08);
  font-weight:700; font-size:13px;
}

.gallery-grid{
  display:grid; gap:10px;
  grid-template-columns:repeat(2,1fr);
}
.gallery-item{
  position:relative; border-radius:14px; overflow:hidden;
  border:1px solid rgba(43,43,43,.10);
  background:var(--grey);
}
.gallery-item img{width:100%; height:100%; object-fit:cover; aspect-ratio:1/1; transition:transform .25s ease}
.gallery-item:hover img{transform:scale(1.03)}
.gallery-item button{
  all:unset; cursor:pointer; display:block;
}
.gallery-item .tag{
  position:absolute; left:10px; bottom:10px;
  background:rgba(255,255,255,.88);
  border:1px solid rgba(43,43,43,.10);
  padding:6px 10px; border-radius:999px; font-weight:700; font-size:12px;
}

.lightbox{
  position:fixed; inset:0; display:none; z-index:120;
  background:rgba(0,0,0,.72);
}
.lightbox.is-open{display:grid}
.lightbox__inner{
  place-self:center; width:min(940px, 94vw); height:min(86vh, 720px);
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.18);
  border-radius:18px;
  overflow:hidden;
  display:grid;
  grid-template-rows:auto 1fr;
}
.lightbox__top{
  display:flex; justify-content:space-between; align-items:center; gap:10px;
  padding:10px 12px;
  background:rgba(0,0,0,.35);
  color:#fff;
}
.lightbox__top span{font-weight:800}
.lightbox__imgwrap{position:relative}
.lightbox__imgwrap img{width:100%; height:100%; object-fit:contain; background:rgba(0,0,0,.35)}
.lightbox__controls{
  position:absolute; inset:0; display:flex; justify-content:space-between; align-items:center;
  padding:0 8px; pointer-events:none;
}
.lbbtn{
  pointer-events:auto;
  width:42px; height:42px; border-radius:999px;
  border:1px solid rgba(255,255,255,.30);
  background:rgba(0,0,0,.35);
  color:#fff; cursor:pointer;
  display:grid; place-content:center;
}
.lbbtn:hover{background:rgba(0,0,0,.55)}

.reviews{
  display:flex; gap:12px;
  overflow:auto;
  scroll-snap-type:x mandatory;
  padding-bottom:6px;
}
.review{
  min-width:min(320px, 86vw);
  scroll-snap-align:start;
  background:rgba(255,255,255,.86);
  border:1px solid rgba(43,43,43,.10);
  border-radius:var(--radius);
  box-shadow:var(--shadow-sm);
  padding:18px;
  position:relative;
  display:flex;
  flex-direction:column;
}
.review__quote-icon{
  position:absolute; top:18px; right:18px;
  width:32px; height:32px;
  opacity:.12;
  color:var(--blush);
}
.review__quote-icon svg{
  width:100%; height:100%;
}
.stars{
  display:flex; gap:4px; margin-bottom:12px;
  color:#FFB800;
}
.stars svg{
  width:18px; height:18px;
  flex-shrink:0;
}
.review p{
  margin:0 0 16px; 
  opacity:.88;
  line-height:1.6;
  font-size:15px;
}
.review .who{
  margin-top:auto;
  display:flex;
  align-items:center;
  gap:10px;
  padding-top:12px;
  border-top:1px solid rgba(43,43,43,.08);
}
.who__avatar{
  width:40px; height:40px;
  border-radius:50%;
  background:linear-gradient(135deg, var(--blush), #D4A99A);
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  color:var(--white);
}
.who__avatar svg{
  width:22px; height:22px;
}
.review .who > div:last-child{
  flex:1;
}
.review .who strong{
  display:block;
  font-weight:700;
  font-size:14px;
  margin-bottom:2px;
}
.review .who span{
  display:block;
  font-weight:500;
  opacity:.65;
  font-size:12px;
}

.faq{display:grid; gap:10px}
.faq details{
  background:rgba(255,255,255,.86);
  border:1px solid rgba(43,43,43,.10);
  border-radius:var(--radius);
  box-shadow:var(--shadow-sm);
  padding:12px 14px;
}
.faq summary{
  cursor:pointer; font-weight:800;
}
.faq p{margin:10px 0 0; opacity:.9}

.form{
  display:grid; gap:10px;
}
.field{display:grid; gap:6px}
label{font-weight:700; font-size:13px}
input, select, textarea{
  font:inherit;
  padding:12px 12px;
  border-radius:12px;
  border:1px solid rgba(43,43,43,.14);
  background:rgba(255,255,255,.92);
  outline:none;
  width:100%;
  box-sizing:border-box;
}
textarea{min-height:120px; resize:vertical}
input:focus, select:focus, textarea:focus{box-shadow:0 0 0 4px rgba(200,155,140,.22); border-color:rgba(200,155,140,.55)}
input[type="date"], input[type="time"]{min-height:44px}
.form-note{font-size:13px; opacity:.78; margin:0}
.success{
  display:none; margin-top:10px;
  padding:12px 14px;
  border-radius:14px;
  background:rgba(200,155,140,.18);
  border:1px solid rgba(43,43,43,.10);
  font-weight:700;
}
.success.is-visible{display:block}

.two-col{
  display:grid; gap:12px;
  align-items:stretch;
}
.card--content{
  display:flex;
  flex-direction:column;
  padding:24px;
  min-height:450px;
}
.card--image{
  padding:0;
  overflow:hidden;
}
.card--content .form{
  flex:1;
  display:flex;
  flex-direction:column;
}
.card--content .form .field:last-of-type{
  flex:1;
  display:flex;
  flex-direction:column;
}
.card--content .form .field:last-of-type textarea{
  flex:1;
}
.map{
  border-radius:var(--radius);
  overflow:hidden;
  border:1px solid rgba(43,43,43,.10);
  box-shadow:var(--shadow-sm);
  background:var(--grey);
}
.map iframe{width:100%; height:280px; border:0}
.mini-map iframe{width:100%; height:180px; border:0}
.muted{opacity:.75}
.small{font-size:13px}
.footer{
  margin-top:40px;
}
/* Footer CTA Banner */
.footer__cta{
  background:linear-gradient(135deg, var(--blush), #d4a594);
  padding:32px 0;
}
.footer__cta-inner{
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  gap:20px;
}
.footer__cta-title{
  font-family:var(--font-head);
  font-size:24px;
  color:var(--white);
  margin:0;
  text-shadow:0 1px 2px rgba(0,0,0,.1);
}
.footer__cta-text{
  font-size:15px;
  color:rgba(255,255,255,.9);
  margin:4px 0 0;
}
.footer__cta-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  justify-content:center;
}
.footer__cta .btn--primary{
  background:var(--white);
  color:var(--charcoal);
  border-color:transparent;
}
.footer__cta .btn--primary:hover{
  background:rgba(255,255,255,.9);
  transform:translateY(-2px);
  box-shadow:var(--shadow);
}
.footer__cta .btn--ghost{
  background:transparent;
  color:var(--white);
  border-color:rgba(255,255,255,.4);
}
.footer__cta .btn--ghost:hover{
  background:rgba(255,255,255,.15);
  border-color:rgba(255,255,255,.6);
}
/* Footer Main */
.footer__main{
  background:var(--charcoal);
  padding:48px 0 32px;
}
.footer__grid{
  display:grid;
  gap:32px;
  grid-template-columns:1fr;
}
.footer__col{
  display:flex;
  flex-direction:column;
}
.footer__col--brand{
  align-items:flex-start;
}
.footer__logo-link{
  display:block;
  margin-bottom:12px;
}
.footer__logo{
  border-radius:14px;
  background:rgba(255,255,255,.1);
  padding:10px;
  transition:transform .2s ease;
}
.footer__logo-link:hover .footer__logo{
  transform:scale(1.05);
}
.footer__brand-name{
  font-family:var(--font-head);
  font-size:20px;
  display:block;
  margin-bottom:6px;
  color:var(--white);
}
.footer__tagline{
  font-size:14px;
  margin:0 0 16px;
  color:rgba(255,255,255,.6);
  font-style:italic;
}
.footer__social{
  display:flex;
  gap:10px;
}
.footer__social-icon{
  width:40px;
  height:40px;
  border-radius:10px;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.1);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--white);
  text-decoration:none;
  transition:all .2s ease;
}
.footer__social-icon:hover{
  background:var(--blush);
  border-color:var(--blush);
  transform:translateY(-2px);
}
.footer__social-icon svg{
  width:20px;
  height:20px;
}
.footer__title{
  font-family:var(--font-head);
  font-size:16px;
  margin:0 0 16px;
  color:var(--white);
  font-weight:600;
  letter-spacing:.3px;
}
.footer__list{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  gap:10px;
}
.footer__list a{
  text-decoration:none;
  color:rgba(255,255,255,.7);
  transition:all .15s ease;
  font-size:14px;
  display:inline-block;
}
.footer__list a:hover{
  color:var(--blush);
  padding-left:4px;
}
/* Opening Hours */
.footer__hours{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  gap:8px;
}
.footer__hours li{
  display:flex;
  justify-content:space-between;
  font-size:13px;
  color:rgba(255,255,255,.7);
  padding-bottom:8px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.footer__hours li:last-child{
  border-bottom:none;
  padding-bottom:0;
}
.footer__hours li span:first-child{
  font-weight:600;
  color:rgba(255,255,255,.85);
}
/* Contact List */
.footer__contact-list{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  gap:14px;
}
.footer__contact-list li{
  display:flex;
  align-items:flex-start;
  gap:12px;
  font-size:14px;
}
.footer__contact-list svg{
  width:18px;
  height:18px;
  color:var(--blush);
  flex-shrink:0;
  margin-top:2px;
}
.footer__contact-list a{
  color:rgba(255,255,255,.7);
  text-decoration:none;
  transition:color .15s ease;
  line-height:1.5;
}
.footer__contact-list a:hover{
  color:var(--blush);
}
/* Footer Bottom */
.footer__bottom{
  background:rgba(0,0,0,.15);
  padding:18px 0;
  background:linear-gradient(180deg, rgba(30,30,30,1), rgba(25,25,25,1));
}
.footer__bottom-inner{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:12px;
  text-align:center;
}
.footer__copyright{
  font-size:13px;
  color:rgba(255,255,255,.5);
  margin:0;
}
.footer__legal-links{
  display:flex;
  align-items:center;
  gap:16px;
  flex-wrap:wrap;
  justify-content:center;
}
.footer__legal-links a{
  font-size:13px;
  color:rgba(255,255,255,.5);
  text-decoration:none;
  transition:color .15s ease;
}
.footer__legal-links a:hover{
  color:var(--blush);
}

.sticky-bar{
  position:fixed;
  left:12px; right:12px; bottom:12px;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
  z-index:60;
}
.sticky-bar__btn{
  display:flex; align-items:center; justify-content:center; gap:8px;
  padding:12px 10px;
  border-radius:16px;
  text-decoration:none;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(43,43,43,.12);
  box-shadow:var(--shadow);
  font-weight:800;
}
.sticky-bar__btn:hover{background:#fff}
.sticky-bar__icon{font-size:16px}

/* Mobile-first responsive improvements */
@media (max-width: 480px){
  :root{--pad:12px}
  .container{padding-inline:var(--pad)}
  h1{font-size:24px; line-height:1.2}
  .section__title{font-size:20px}
  .hero-card{padding:16px}
  .hero-card.card--content{padding:18px}
  .card{padding:14px}
  .card--content{padding:18px}
  .btn{padding:14px 16px; font-size:15px; min-height:48px; width:100%}
  .btn-row{flex-direction:column; gap:10px}
  .btn-row .btn{width:100%}
  .icon-btn{padding:10px 10px; font-size:12px; min-width:44px}
  .icon-btn span{display:none}
  .brand__name{font-size:14px}
  .brand__meta{font-size:11px}
  .brand__logo{width:36px; height:36px}
  .header__inner{padding:8px 0}
  .gallery-grid{grid-template-columns:1fr}
  .price-row{font-size:14px; flex-wrap:wrap}
  .service-item{flex-direction:column; align-items:flex-start; gap:4px}
  .service-item__name{font-size:14px}
  .service-item__price{font-size:15px}
  .service-list{padding:12px}
  .form input, .form select, .form textarea{font-size:16px; padding:14px; width:100%}
  .form .two-col{grid-template-columns:1fr; gap:10px}
  .two-col{grid-template-columns:1fr}
  .section{padding:14px 0}
  .footer__cta{padding:24px 0}
  .footer__cta-title{font-size:20px}
  .footer__cta-actions{flex-direction:column; width:100%}
  .footer__cta-actions .btn{width:100%}
  .footer__main{padding:32px 0 24px}
  .footer__grid{gap:28px}
  .footer__col--brand{align-items:center; text-align:center}
  .footer__tagline{margin-bottom:12px}
  .sticky-bar{left:8px; right:8px; bottom:8px; gap:8px}
  .sticky-bar__btn{padding:10px 8px; font-size:11px; border-radius:12px; min-height:44px}
  .sticky-bar__icon{font-size:14px}
  .mobile-menu__panel{width:100vw; padding:16px}
  .hero-visual{min-height:280px; max-height:400px}
  .hero-visual img{min-height:280px}
  .card--content{min-height:280px}
  .map iframe{height:240px}
  .review{min-width:100%}
  .reviews{padding-bottom:8px}
  .badges{flex-direction:column; align-items:flex-start}
  .hero__grid{grid-template-columns:1fr}
}

@media (min-width: 481px) and (max-width: 859px){
  :root{--pad:16px}
  h1{font-size:32px}
  .section__title{font-size:22px}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .two-col{grid-template-columns:1fr}
  .hero__grid{grid-template-columns:1fr}
  .card--content{padding:20px; min-height:350px}
  .hero-card.card--content{padding:22px}
  .hero-visual{min-height:350px; max-height:500px}
  .hero-visual img{min-height:350px}
  .footer__grid{grid-template-columns:repeat(2,1fr); gap:28px}
  .footer__col--brand{grid-column:span 2; align-items:center; text-align:center}
  .footer__cta-inner{flex-direction:row; justify-content:space-between; text-align:left}
  .footer__cta-content{flex:1}
  .footer__cta-actions{flex-direction:row}
  .footer__bottom-inner{flex-direction:row; justify-content:space-between}
  .map iframe{height:300px}
}

@media (min-width: 860px){
  .nav{display:flex}
  .menu-btn{display:none}
  .sticky-bar{display:none}
  .hero__grid{grid-template-columns:1.25fr .95fr; align-items:stretch}
  h1{font-size:42px}
  .grid.cards{grid-template-columns:repeat(3,1fr)}
  .cards.two{grid-template-columns:repeat(2,1fr)}
  .gallery-grid{grid-template-columns:repeat(4,1fr)}
  .two-col{grid-template-columns:1fr 1fr; align-items:stretch}
  .card--content{padding:28px; min-height:500px}
  .hero-visual{min-height:500px; max-height:700px}
  .hero-visual img{min-height:500px}
  .hero-card.card--content{padding:28px}
  .footer__grid{grid-template-columns:1.5fr 1fr 1fr 1.3fr; align-items:start}
  .footer__col--brand{grid-column:span 1; align-items:flex-start; text-align:left}
  .footer__cta-title{font-size:26px}
  .map iframe{height:360px}
}

/* Touch-friendly improvements */
@media (hover: none) and (pointer: coarse){
  .btn, .icon-btn, .nav__link{min-height:44px; min-width:44px}
  .menu-btn{min-height:44px; min-width:44px}
  input, select, textarea{min-height:44px; font-size:16px}
  .mobile-menu__links a{min-height:48px; padding:12px 16px}
  .card{cursor:pointer}
  .gallery-item{cursor:pointer}
  .faq summary{min-height:44px; padding:12px 14px}
  .price-row{min-height:44px}
  .service-item{min-height:44px; padding:12px 0}
  a, button{min-height:44px; display:inline-flex; align-items:center}
  .sticky-bar__btn{min-height:48px}
}

/* Keyboard navigation improvements */
*:focus-visible{
  outline:3px solid var(--blush);
  outline-offset:2px;
  border-radius:4px;
}
button:focus-visible, a:focus-visible{
  outline:3px solid var(--blush);
  outline-offset:2px;
}
input:focus-visible, select:focus-visible, textarea:focus-visible{
  outline:3px solid var(--blush);
  outline-offset:2px;
}

/* Mouse optimization */
@media (hover: hover) and (pointer: fine){
  .btn:hover{transform:translateY(-2px); box-shadow:0 4px 12px rgba(43,43,43,.15)}
  .icon-btn:hover{transform:translateY(-1px)}
  .card:hover{box-shadow:0 12px 28px rgba(43,43,43,.12); transform:translateY(-2px)}
  .gallery-item:hover{transform:scale(1.02)}
  a:hover{opacity:0.85}
}

/* Landscape mobile optimization */
@media (max-width: 859px) and (orientation: landscape){
  .hero{padding:12px 0 6px}
  .section{padding:12px 0}
  .sticky-bar{bottom:8px}
  .hero-visual{min-height:250px; max-height:350px}
  .hero-visual img{min-height:250px}
  .card--content{min-height:250px}
}

/* Additional mobile optimizations */
@media (max-width: 480px) {
  html {
    -webkit-text-size-adjust: 100%;
    -ms-text-size-adjust: 100%;
  }
  
  body {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }
  
  /* Prevent horizontal scroll */
  * {
    max-width: 100%;
  }
  
  /* Better touch targets for small screens */
  .mobile-menu__links a {
    min-height: 48px;
    padding: 14px 16px;
    display: flex;
    align-items: center;
    touch-action: manipulation;
  }
  
  /* Improve button spacing on mobile */
  .btn-row {
    gap: 12px;
  }
  
  /* Better form spacing */
  .form .field {
    margin-bottom: 16px;
  }
}

@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *{transition:none !important; animation:none !important}
}
