:root{
  --cream:#faf6f1;--cream-deep:#f3ece2;--beige:#e7dccd;--nude:#d8c3ad;
  --gold:#b8945f;--gold-deep:#9c7c4d;--ink:#2b2622;--ink-soft:#5c544c;
  --line:#e4d9c9;--white:#fff;--maxw:1140px;--radius:14px;--radius-lg:22px;
  --shadow:0 18px 40px -24px rgba(60,45,30,.45);--shadow-sm:0 8px 20px -14px rgba(60,45,30,.4);
  --font-head:"Fraunces","Georgia",serif;--font-body:"Inter",system-ui,-apple-system,"Segoe UI",sans-serif;
}
*{box-sizing:border-box}html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font-body);color:var(--ink);background:var(--cream);line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:var(--font-head);font-weight:500;line-height:1.12;color:var(--ink);margin:0 0 .5em;letter-spacing:-.01em}
h1{font-size:clamp(2.2rem,5vw,3.6rem)}h2{font-size:clamp(1.7rem,3.4vw,2.5rem)}h3{font-size:clamp(1.2rem,2vw,1.45rem)}
p{margin:0 0 1rem}a{color:var(--gold-deep);text-decoration:none}a:hover{text-decoration:underline}img{max-width:100%;display:block}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 1.25rem}
.section{padding:clamp(3rem,7vw,5.5rem) 0}.section--tint{background:var(--cream-deep)}
.section--ink{background:var(--ink);color:var(--cream)}.section--ink h2,.section--ink h3{color:var(--cream)}
.eyebrow{font-family:var(--font-body);text-transform:uppercase;letter-spacing:.18em;font-size:.72rem;font-weight:600;color:var(--gold-deep);margin:0 0 .9rem}
.section--ink .eyebrow{color:var(--nude)}
.lead{font-size:1.12rem;color:var(--ink-soft);max-width:60ch}.section--ink .lead{color:var(--beige)}
.section-head{max-width:62ch;margin-bottom:2.5rem}.section-head--center{margin-left:auto;margin-right:auto;text-align:center}
.btn{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;font-size:.98rem;padding:.85rem 1.6rem;border-radius:999px;border:1.5px solid transparent;cursor:pointer;transition:transform .15s,background .2s,color .2s;text-decoration:none;line-height:1}
.btn:hover{text-decoration:none;transform:translateY(-2px)}
.btn--primary{background:var(--gold);color:#fff}.btn--primary:hover{background:var(--gold-deep);color:#fff}
.btn--outline{background:transparent;color:var(--ink);border-color:var(--nude)}.btn--outline:hover{background:var(--white);border-color:var(--gold)}
.btn--light{background:var(--cream);color:var(--ink)}.btn--light:hover{background:#fff}
.btn--ghost{background:transparent;color:var(--gold-deep);padding-left:0;padding-right:0}
.grid{display:grid;gap:1.5rem}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}
.card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden}
.tag{display:inline-block;font-size:.72rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--gold-deep);background:var(--cream-deep);padding:.3rem .7rem;border-radius:999px}
.center{text-align:center}.muted{color:var(--ink-soft)}
.ph{background:linear-gradient(135deg,var(--beige),var(--nude));position:relative}
.ph::after{content:attr(data-label);position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-size:.9rem;color:rgba(43,38,34,.55);text-align:center;padding:1rem}
.figure{width:100%;border-radius:inherit;overflow:hidden}.figure img{width:100%;height:100%;object-fit:cover;position:relative;z-index:1}
.narrow{max-width:720px}.page-intro{padding-bottom:1.5rem}
.legal h1{margin-bottom:.25rem}.legal h2{margin-top:1.75rem;font-size:1.3rem}.legal p{color:var(--ink-soft)}
/* header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(250,246,241,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;justify-content:space-between;min-height:70px;position:relative}
.brand{display:flex;align-items:center;gap:.65rem}.brand-mark{width:40px;height:40px;border-radius:50%;background:var(--ink);color:var(--cream);display:grid;place-items:center;font-family:var(--font-head);font-size:1rem}
.brand-text{display:flex;flex-direction:column;line-height:1.05}.brand-text strong{font-family:var(--font-head);font-weight:500;font-size:1.15rem;color:var(--ink)}
.brand-text small{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-deep)}
.site-nav{display:flex;align-items:center;gap:1.35rem}.site-nav a{color:var(--ink);font-weight:500;font-size:.95rem}
.site-nav a:hover{color:var(--gold-deep);text-decoration:none}.site-nav a.is-active{color:var(--gold-deep)}.nav-cta{color:#fff!important}
.nav-toggle,.nav-burger{display:none}
@media(max-width:880px){
 .nav-burger{display:flex;flex-direction:column;gap:5px;cursor:pointer;padding:8px}
 .nav-burger span{width:24px;height:2px;background:var(--ink);border-radius:2px}
 .site-nav{position:absolute;top:70px;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;background:var(--cream);border-bottom:1px solid var(--line);max-height:0;overflow:hidden;transition:max-height .25s}
 .site-nav a{padding:.9rem 1.25rem;border-top:1px solid var(--line)}
 .nav-cta{margin:.9rem 1.25rem;text-align:center;justify-content:center}
 .nav-toggle:checked~.site-nav{max-height:560px}
}
/* footer */
.site-footer{background:var(--ink);color:var(--beige);padding:3.5rem 0 1.75rem}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:2rem}
.site-footer h4{color:var(--cream);font-size:1rem;margin-bottom:.9rem}
.brand-line{display:flex;align-items:center;gap:.55rem;margin-bottom:.75rem}.brand-line strong{font-family:var(--font-head);font-size:1.2rem;color:var(--cream)}
.footer-grid .brand-mark{width:34px;height:34px;background:var(--gold);color:#fff;font-size:.85rem}
.muted-light{color:#bdb1a0;font-size:.92rem}
ul.plain{list-style:none;padding:0;margin:0}ul.plain li{margin-bottom:.5rem}ul.plain a{color:var(--beige)}ul.plain a:hover{color:var(--cream)}
.footer-base{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem;margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.12);font-size:.85rem;color:#a99d8c}
.legal-links a{color:#a99d8c}.legal-links span{margin:0 .4rem}
@media(max-width:760px){.footer-grid{grid-template-columns:1fr 1fr}}@media(max-width:460px){.footer-grid{grid-template-columns:1fr}}
/* hero */
.hero{background:linear-gradient(180deg,var(--cream),var(--cream-deep));padding:clamp(2.5rem,6vw,5rem) 0 clamp(3rem,7vw,5.5rem)}
.hero-inner{display:grid;grid-template-columns:1.05fr .95fr;gap:3rem;align-items:center}
.hero-actions{display:flex;gap:.9rem;flex-wrap:wrap;margin:1.75rem 0 1.5rem}
.hero-trust{list-style:none;display:flex;flex-wrap:wrap;gap:.5rem 1.4rem;padding:0;margin:0;font-size:.9rem;color:var(--ink-soft)}
.hero-trust li{position:relative;padding-left:1.1rem}.hero-trust li::before{content:"";position:absolute;left:0;top:.55em;width:7px;height:7px;border-radius:50%;background:var(--gold)}
.hero-media{position:relative;min-height:420px}
.hero-img-1{border-radius:var(--radius-lg);box-shadow:var(--shadow);width:76%}
.hero-img-2{position:absolute;right:0;bottom:-1.5rem;width:46%;border-radius:var(--radius-lg);box-shadow:var(--shadow);border:5px solid var(--cream)}
@media(max-width:880px){.hero-inner{grid-template-columns:1fr;gap:2rem}.hero-media{min-height:340px;max-width:460px}}
/* service card */
.service-card{display:flex;flex-direction:column;transition:transform .18s,box-shadow .18s}
.service-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-sm)}
.service-body{padding:1.35rem 1.4rem 1.5rem;display:flex;flex-direction:column;flex:1}
.service-head{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.service-head h3{margin:0 0 .35rem}
.ticks{list-style:none;padding:0;margin:.5rem 0 1rem}.ticks li{position:relative;padding-left:1.4rem;margin-bottom:.35rem;font-size:.92rem;color:var(--ink-soft)}
.ticks li::before{content:"";position:absolute;left:0;top:.45em;width:8px;height:8px;border-radius:50%;border:2px solid var(--gold)}
.service-body .btn--ghost{margin-top:auto;align-self:flex-start}
/* review */
.review-card{padding:1.5rem 1.6rem;display:flex;flex-direction:column;gap:.75rem;height:100%}
.stars{color:var(--gold);letter-spacing:.12em;font-size:1rem}.review-card blockquote{margin:0;font-size:1.02rem;color:var(--ink)}
.review-card figcaption{display:flex;flex-direction:column;margin-top:auto}.review-card figcaption strong{font-family:var(--font-head);font-weight:500}
.review-card figcaption .muted{font-size:.86rem}
/* faq */
.faq-list{max-width:760px;margin:0 auto}.faq-item{border-bottom:1px solid var(--line)}
.faq-item summary{list-style:none;cursor:pointer;padding:1.15rem 0;display:flex;justify-content:space-between;align-items:center;gap:1rem;font-family:var(--font-head);font-size:1.1rem;color:var(--ink)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-icon{position:relative;width:16px;height:16px;flex:none}
.faq-icon::before,.faq-icon::after{content:"";position:absolute;background:var(--gold-deep);top:50%;left:50%;transform:translate(-50%,-50%)}
.faq-icon::before{width:16px;height:2px}.faq-icon::after{width:2px;height:16px;transition:transform .2s}
.faq-item[open] .faq-icon::after{transform:translate(-50%,-50%) scaleY(0)}
.faq-answer{padding:0 0 1.2rem;color:var(--ink-soft);max-width:65ch}.faq-answer p{margin:0}
/* cta */
.cta-inner{display:grid;grid-template-columns:1.4fr 1fr;gap:2rem;align-items:center}
.cta-actions{display:flex;flex-direction:column;gap:.75rem;align-items:flex-start}
.cta-actions .btn{width:100%;justify-content:center;max-width:320px}
@media(max-width:760px){.cta-inner{grid-template-columns:1fr}.cta-actions .btn{max-width:none}}
/* home extras */
.gallery-preview{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.gp-item{border-radius:var(--radius)}
@media(max-width:600px){.gallery-preview{grid-template-columns:repeat(2,1fr)}}
.why-item{padding:1.5rem;background:var(--white);border:1px solid var(--line);border-radius:var(--radius)}.why-item h3{font-size:1.15rem}
.step{padding:1.5rem}.step-num{display:grid;place-items:center;width:46px;height:46px;border-radius:50%;background:var(--cream-deep);color:var(--gold-deep);font-family:var(--font-head);font-size:1.3rem;margin-bottom:.9rem;border:1px solid var(--line)}
.areas-band{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;align-items:center}
.area-chips{list-style:none;display:flex;flex-wrap:wrap;gap:.6rem;padding:0;margin:0}
.area-chips li{background:var(--white);border:1px solid var(--line);border-radius:999px;padding:.5rem 1rem;font-size:.9rem;color:var(--ink-soft)}
.area-chips li.primary{background:var(--ink);color:var(--cream);border-color:var(--ink)}
@media(max-width:760px){.areas-band{grid-template-columns:1fr;gap:1.5rem}}
/* services page */
.service-list{display:flex;flex-direction:column;gap:3.5rem}
.service-row{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;align-items:center;scroll-margin-top:90px}
.service-media{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.media-right{order:2}
.service-title{display:flex;align-items:center;gap:.75rem}.service-title h2{margin:0}
.row-actions{display:flex;gap:.9rem;flex-wrap:wrap}
@media(max-width:800px){.service-row{grid-template-columns:1fr;gap:1.25rem}.media-right{order:0}}
/* prices */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;align-items:start}
.price-card{padding:1.6rem 1.7rem}.price-card h2{font-size:1.4rem;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:2px solid var(--gold);display:inline-block}
.price-list{list-style:none;padding:0;margin:0}.price-list li{display:flex;align-items:baseline;gap:.5rem;padding:.6rem 0;border-bottom:1px dashed var(--line)}
.p-name{color:var(--ink)}.p-dots{flex:1;border-bottom:1px dotted var(--nude);transform:translateY(-3px)}.p-price{font-weight:600;color:var(--gold-deep);white-space:nowrap}
@media(max-width:880px){.price-grid{grid-template-columns:1fr}}
/* gallery */
.filters{display:flex;gap:.6rem;flex-wrap:wrap;margin-bottom:1.75rem}
.filter-btn{border:1.5px solid var(--nude);background:transparent;color:var(--ink);padding:.5rem 1.2rem;border-radius:999px;cursor:pointer;font-weight:500;font-size:.92rem;transition:.18s}
.filter-btn:hover{border-color:var(--gold)}.filter-btn.is-active{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.masonry{columns:3;column-gap:1rem}.masonry-item{break-inside:avoid;margin:0 0 1rem}.masonry-item figure{margin:0}
.masonry-item .figure{border-radius:var(--radius)}.masonry-item figcaption{font-size:.82rem;color:var(--ink-soft);padding:.5rem .2rem 0}
@media(max-width:800px){.masonry{columns:2}}@media(max-width:500px){.masonry{columns:1}}
/* reviews page */
.rating-summary{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-top:1.25rem}
.rating-num{font-family:var(--font-head);font-size:2.2rem;color:var(--ink)}.rating-stars{color:var(--gold);letter-spacing:.1em;font-size:1.2rem}
.leave-review{margin-top:2.5rem}.leave-review p{margin-bottom:1rem}
/* about */
.about-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:3rem;align-items:center}
.about-media{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow)}
.about-points{display:flex;flex-wrap:wrap;gap:1.5rem;margin:1.5rem 0}.about-points div{display:flex;flex-direction:column}
.about-points strong{font-family:var(--font-head);font-weight:500;color:var(--gold-deep);font-size:.95rem}.about-points span{color:var(--ink-soft);font-size:.92rem}
@media(max-width:800px){.about-grid{grid-template-columns:1fr;gap:1.5rem}}
/* areas page */
.areas-layout{display:grid;grid-template-columns:1.4fr 1fr;gap:2.5rem;align-items:start}
.areas-note{padding:1.6rem}.areas-note h3{font-size:1.1rem}
@media(max-width:800px){.areas-layout{grid-template-columns:1fr}}
/* book */
.book-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:2.5rem;align-items:start}
.book-side h2,.book-form h2{font-size:1.4rem}
.contact-link{display:flex;flex-direction:column;padding:.9rem 1.1rem;border:1px solid var(--line);border-radius:var(--radius);background:var(--white);margin-bottom:.75rem}
.contact-link:hover{border-color:var(--gold);text-decoration:none}.cl-label{font-weight:600;color:var(--ink)}
.hours{padding:1.2rem 1.3rem;margin-top:1rem}.hours h3{font-size:1.05rem;margin-bottom:.6rem}
.hours ul{list-style:none;padding:0;margin:0}.hours li{display:flex;justify-content:space-between;padding:.3rem 0;font-size:.9rem;border-bottom:1px dashed var(--line)}
.book-form{padding:1.8rem}.field{margin-bottom:1rem;display:flex;flex-direction:column}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
label{font-size:.9rem;font-weight:500;margin-bottom:.35rem}
input,select,textarea{font-family:inherit;font-size:1rem;padding:.7rem .85rem;border:1px solid var(--nude);border-radius:10px;background:var(--cream)}
input:focus,select:focus,textarea:focus{outline:2px solid var(--gold);border-color:var(--gold)}
.form-note{font-size:.82rem;margin-top:.9rem}
@media(max-width:800px){.book-grid{grid-template-columns:1fr}.field-row{grid-template-columns:1fr}}
/* contact */
.contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.contact-tile{padding:1.5rem}.contact-tile:hover{text-decoration:none;border-color:var(--gold);transform:translateY(-3px);transition:.18s}.contact-tile h3{margin-bottom:.3rem}
.studio-note{margin-top:1.5rem}.studio-note .card{padding:1.5rem}
@media(max-width:760px){.contact-grid{grid-template-columns:1fr 1fr}}@media(max-width:460px){.contact-grid{grid-template-columns:1fr}}

/* ===== Mobile overflow guards (added in QC pass) ===== */
html, body { max-width: 100%; overflow-x: hidden; }
body { overflow-wrap: break-word; }
img, svg, video { max-width: 100%; height: auto; }
/* stop grid/flex children forcing the row wider than the screen */
.grid > *, .cta-inner > *, .book-grid > *, .areas-layout > *,
.about-grid > *, .footer-grid > *, .hero-inner > *, .service-row > * { min-width: 0; }
.price-list li { flex-wrap: wrap; }
.visually-hidden {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0;
}
.skip-link {
  position: absolute; left: -999px; top: 0; z-index: 100;
  background: var(--ink); color: var(--cream); padding: 0.6rem 1rem; border-radius: 0 0 8px 0;
}
.skip-link:focus { left: 0; }

/* ===== Real mobile fixes at narrow widths (QC pass 2) ===== */
.rating-summary { flex-wrap: wrap; }
.hours li { gap: 0.75rem; }
@media (max-width: 600px) {
  /* hero overlay image was the main clip culprit: make it flow instead of absolute */
  .hero-media { min-height: 0; }
  .hero-img-1 { width: 100%; }
  .hero-img-2 { position: static; }
  .cta-actions .btn { max-width: none; }
  .footer-base { flex-direction: column; align-items: flex-start; }
}


/* ===== QC pass 3: bulletproof mobile (no horizontal clipping) ===== */
input, select, textarea { width: 100%; max-width: 100%; }
.book-form, .book-side, .field, .field-row, .hero-copy, .section-head, .card { min-width: 0; max-width: 100%; }
@media (max-width: 600px) {
  .hero-img-2 { display: none; }            /* hide secondary overlay image on phones */
  .hero-media { max-width: 100%; min-height: 0; }
  .hero-img-1 { width: 100%; }
}


/* ===== Visible keyboard focus (a11y) ===== */
a:focus-visible, button:focus-visible, .btn:focus-visible, summary:focus-visible,
.filter-btn:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible {
  outline: 3px solid var(--gold-deep); outline-offset: 2px; border-radius: 4px;
}


/* ===== Local SEO service pages ===== */
.crumb { font-size: .85rem; color: var(--ink-soft); margin: 0; }
.crumb a { color: var(--gold-deep); }
.crumb span { margin: 0 .45rem; color: var(--nude); }
.svc-hero { display: grid; grid-template-columns: 1.1fr .9fr; gap: 2.5rem; align-items: center; }
.svc-media { border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-sm); }
.svc-grid { display: grid; grid-template-columns: 1.45fr 1fr; gap: 2.5rem; align-items: start; }
.svc-grid .price-card { padding: 1.6rem 1.7rem; }
.care-row { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; margin-top: 2.25rem; }
.care-col h3 { font-size: 1.1rem; }
.svc-links { display: flex; flex-wrap: wrap; gap: .75rem; justify-content: center; }
@media (max-width: 800px) { .svc-hero, .svc-grid, .care-row { grid-template-columns: 1fr; } }

/* Preserve treatment photos in cards; nail tips are more important than edge-to-edge cropping. */
.service-card .figure img,
.gallery-preview .figure img,
.masonry-item .figure img,
.service-detail .figure img{object-fit:contain;background:linear-gradient(135deg,var(--beige),var(--nude))}


/* picture wrapper should not affect layout (img behaves as direct child) */
picture{display:contents}

/* cookie consent banner */
.cookie-banner{position:fixed;left:1rem;right:1rem;bottom:1rem;max-width:680px;margin:0 auto;background:var(--white);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:var(--radius);padding:1rem 1.2rem;z-index:9999;display:flex;flex-direction:column;gap:.85rem}
.cookie-banner .cookie-text{margin:0;font-size:.92rem;color:var(--ink-soft)}
.cookie-banner .cookie-actions{display:flex;gap:.6rem;flex-wrap:wrap}
.cookie-banner .btn{padding:.6rem 1.2rem;font-size:.9rem}
@media(min-width:600px){.cookie-banner{flex-direction:row;align-items:center;justify-content:space-between}.cookie-banner .cookie-text{flex:1}}
