:root{
  /* Keep current palette */
  --bg:#faf9f7;
  --card:#ffffff;
  --text:#2f2f2f;
  --muted:#6a6a6a;
  --border:#ece8e0;
  --accent:#7a6fa6;
  --beige:#f3efe8;

  /* Magazine polish */
  --radius-lg:22px;
  --radius-md:16px;
  --radius-sm:12px;
  --shadow:0 18px 40px rgba(0,0,0,.07);
}

*{box-sizing:border-box}


html, body{
height:100%;
  min-height:100vh;
  display:flex;
  flex-direction:column;
}
body{
  margin:0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background:var(--bg);
  color:var(--text);
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
}

a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}

.container{max-width:1100px;margin:0 auto;padding:0 20px}

/* Typography */
.h1, h1{font-family:"Playfair Display", serif;letter-spacing:-.02em;line-height:1.05}
.h1{font-size:clamp(34px,4.5vw,56px);margin:0 0 12px}
h2{font-family:"Playfair Display", serif;letter-spacing:-.015em}
p{line-height:1.75}
.muted{color:var(--muted)}
.small{color:var(--muted);font-size:13px}

/* Header (public) */
.mbc-header{border-bottom:1px solid rgba(230,224,214,.9)}

/* Buttons */
.button,
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:12px 16px;
  border-radius:14px;
  border:1px solid transparent;
  font-weight:650;
  cursor:pointer;
  transition:transform .12s ease, box-shadow .12s ease, filter .12s ease, background .12s ease;
  text-decoration:none !important;
  line-height:1;
}
.button,
.btn.btn--primary,
.btn.primary{
  background:var(--accent);
  color:#fff;
  box-shadow:0 10px 26px rgba(122,111,166,.22);
}
.button:hover,
.btn.btn--primary:hover{filter:brightness(.97);transform:translateY(-1px)}

.button--ghost,
.btn{
  background:rgba(255,255,255,.72);
  border-color:rgba(230,224,214,1);
  color:var(--text);
  box-shadow:0 10px 24px rgba(0,0,0,.04);
}
.button--ghost:hover,
.btn:hover{background:#fff;transform:translateY(-1px)}

.link{font-weight:650}

/* Cards / grid */
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px}
.card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:22px;
  box-shadow:0 10px 30px rgba(0,0,0,.03);
}
.card-body{padding:18px}
.mbc-card{transition:transform .14s ease, box-shadow .14s ease}
.mbc-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}

.pill{
  font-size:11px;
  padding:4px 10px;
  border-radius:999px;
  border:1px solid rgba(122,111,166,.20);
  background:rgba(122,111,166,.10);
  color:rgba(47,47,47,.88);
}

.section{padding:72px 0}

@media (max-width:900px){
  .section{padding:64px 0}
}

/* Treatment detail */
.page{padding:34px 0 72px}
.breadcrumb{margin:0 0 18px;color:var(--muted)}
.breadcrumb a{color:var(--accent)}

.treatment{display:grid;grid-template-columns:1.15fr .85fr;gap:22px;align-items:start}
.card--pad{padding:24px}
.lead{font-size:16px;color:var(--muted);margin:0 0 10px}
.treatment__meta{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin:10px 0 12px}
.meta{padding:6px 10px;border:1px solid var(--border);border-radius:999px;background:rgba(0,0,0,.02)}
.badge{padding:6px 10px;border-radius:999px;background:rgba(122,111,166,.14);border:1px solid rgba(122,111,166,.22);font-weight:700;font-size:12px}
.btnrow{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}
.treatment__img{width:100%;height:auto;border-radius:16px;display:block}
.treatment__img--placeholder{height:320px;border-radius:16px;background:linear-gradient(135deg, rgba(0,0,0,.03), rgba(0,0,0,.01))}

@media (max-width:900px){
  .treatment{grid-template-columns:1fr}
}

/* Notices */
.notice{border-radius:16px;padding:12px 14px;border:1px solid var(--border);background:#fff}
.notice--error{border-color:rgba(176,0,32,.20);background:rgba(176,0,32,.04)}

/* Footer (magazine-style) */
.mbc-footer{background:#fff;border-top:1px solid var(--border)}
.mbc-footer__inner{display:grid;grid-template-columns:1.2fr .8fr;gap:26px;padding:44px 0}
.mbc-footer__logo{font-family:"Playfair Display", serif;font-size:22px;letter-spacing:-.01em}
.mbc-footer__tag{margin:8px 0 0;color:var(--muted);max-width:52ch}
.mbc-footer__meta{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:16px;color:var(--muted);font-size:13px}
.mbc-footer__meta a{color:var(--text)}
.mbc-footer__links{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.mbc-footer__heading{font-size:11px;letter-spacing:.10em;text-transform:uppercase;color:var(--muted);margin:6px 0 10px}
.mbc-footer__col a{display:block;color:var(--text);padding:7px 0;text-decoration:none}
.mbc-footer__col a:hover{text-decoration:underline}
.mbc-footer__small{font-size:13px;color:var(--muted);margin:0 0 10px;line-height:1.6}

.mbc-footer__bottom{border-top:1px solid var(--border);background:rgba(0,0,0,.01)}
.mbc-footer__bottominner{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;padding:14px 0;color:var(--muted);font-size:13px}
.mbc-footer__bottomlinks{display:flex;gap:10px;align-items:center}
.mbc-footer__bottomlinks a{color:var(--muted)}
.mbc-footer__bottomlinks a:hover{color:var(--text)}

@media (max-width:900px){
  .mbc-footer__inner{grid-template-columns:1fr}
  .mbc-footer__meta{grid-template-columns:1fr}
  .mbc-footer__links{grid-template-columns:1fr}
}

/* 404 */
.mbc-error{padding:22px;border-radius:var(--radius-lg);background:radial-gradient(800px 240px at 20% 10%, rgba(122,111,166,.16), transparent 60%), #fff;border:1px solid var(--border);box-shadow:var(--shadow)}
.mbc-error__code{font-family:"Playfair Display", serif;font-size:54px;opacity:.35;letter-spacing:-.03em}

/* Sticky footer: ensure footer sits at viewport bottom on short pages */
main{flex:1 0 auto;}
footer{flex-shrink:0;}
/* Contact page layout + form (restored) */
.mbc-two-col{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:start}
@media (max-width:900px){.mbc-two-col{grid-template-columns:1fr}}

.contact-form{display:grid;grid-template-columns:1fr;gap:12px;margin:0}
.contact-form .small{display:flex;gap:10px;align-items:flex-start}
.contact-form .small input[type="checkbox"]{margin-top:3px}

.input{
  width:100%;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid var(--border);
  background:#fff;
  color:var(--text);
  font:inherit;
  line-height:1.3;
  outline:none;
  transition:border-color .12s ease, box-shadow .12s ease;
}
textarea.input{resize:vertical;min-height:120px}
select.input{appearance:none;background-image:linear-gradient(45deg, transparent 50%, rgba(0,0,0,.45) 50%),linear-gradient(135deg, rgba(0,0,0,.45) 50%, transparent 50%);background-position:calc(100% - 18px) calc(50% - 2px), calc(100% - 13px) calc(50% - 2px);background-size:5px 5px,5px 5px;background-repeat:no-repeat;padding-right:38px}

.input:focus{
  border-color:rgba(28,121,126,.55);
  box-shadow:0 0 0 4px rgba(28,121,126,.12);
}

/* --- iOS Safari input focus zoom prevention ---
   Safari will auto-zoom when focusing form fields whose computed font-size is < 16px.
   Setting mobile form controls to 16px prevents the zoom while keeping layout stable.
   Scoped to <=768px to avoid affecting desktop typography.
*/
html{ -webkit-text-size-adjust: 100%; }

@media (max-width: 768px){
  input[type="text"],
  input[type="search"],
  input[type="email"],
  input[type="tel"],
  input[type="url"],
  input[type="number"],
  textarea,
  select{
    font-size:16px !important;
  }
  /* Common class used across the site */
  .input{ font-size:16px !important; }
}
