:root {
  --fg: #111;
  --muted: #666;
  --border: #e8e8e8;
  --bg: #fff;
  --card: #fafafa;
  --radius: 12px;
  --shadow: 0 2px 16px rgba(0,0,0,0.06);
  --navy: #0b1f3b; /* brand navy */
  --sky: #3aa0ff;  /* accent sky */
  --gold: #c7a324; /* highlight gold */
  --reveal-duration: 520ms;
  --reveal-distance: 14px;
  --reveal-ease: cubic-bezier(.22,.61,.36,1);
  --menu-bg: var(--bg);
  --menu-link: var(--fg);
}
* { box-sizing: border-box; }
body { margin:0; font-family: "Noto Sans", system-ui, -apple-system, Segoe UI, Roboto, Arial; color: var(--fg); background: var(--bg); }
.container { max-width: 1100px; margin: 0 auto; padding: 0 20px; }
.site-header { border-bottom: 1px solid var(--border); background: var(--menu-bg); position: sticky; top:0; z-index: 2; border-bottom-color: rgba(11,31,59,0.12); }
.header-inner { display:flex; align-items:center; justify-content:space-between; height:64px; }
.brand { font-size: 18px; margin: 0; color: var(--navy); }
.nav a { color: var(--menu-link); text-decoration: none; margin-left: 16px; font-weight: 600; }
.nav a:hover { color: var(--sky); text-decoration: none; }
.about { padding: 48px 0; }
.about-grid { display:grid; grid-template-columns: 320px 1fr; gap: 28px; align-items: start; }
.about-photo img { width:100%; height:auto; border-radius: var(--radius); box-shadow: var(--shadow); }
.about-copy h2 { margin: 0 0 12px; font-size: 28px; }
.about-copy p { margin:0; line-height:1.7; white-space: pre-wrap; }
.memberships { padding: 48px 0; background: #f7f9fc; }
.membership-list { margin: 0 0 16px; padding-left: 20px; }
.membership-list li { margin: 6px 0; }
.section-title { margin: 0 0 20px; font-size: 24px; position: relative; padding-bottom: 10px; }
.section-title::after {
  content: ""; position: absolute; left: 0; bottom: 0;
  width: 64px; height: 3px; background: var(--gold); border-radius: 2px;
}
.membership-grid { display:grid; grid-template-columns: repeat(6,1fr); gap:16px; }
.membership-grid img { width:100%; height: 80px; object-fit: contain; background: #fff; border-radius: 10px; border:1px solid var(--border); padding:10px; }
.site-footer { border-top:1px solid var(--border); margin-top: 48px; }
.footer-inner { height:60px; display:flex; align-items:center; justify-content:space-between; }
.admin-link { opacity: .7; }
.card { background: var(--card); border:1px solid var(--border); border-radius: var(--radius); padding: 20px; margin: 24px 0; box-shadow: var(--shadow); }
.field { margin-bottom: 16px; }
.label { display:block; font-weight:700; margin-bottom:8px; }
.textarea { width: 100%; padding: 10px 12px; border:1px solid var(--border); border-radius: 8px; resize: vertical; font: inherit; line-height:1.5; }
.btn { appearance:none; border:0; background:#111; color:#fff; padding:10px 16px; border-radius: 8px; font-weight:700; cursor:pointer; }
.btn:hover { filter: brightness(0.92); background: var(--gold); color: #0b1f3b; }
.status { margin-left: 12px; color: var(--muted); }
.thumb-row { display:flex; gap:16px; align-items:center; }
.thumb { width: 120px; height: 120px; object-fit: cover; border-radius: 10px; border:1px solid var(--border); background:#fff; }
.hint { color: var(--muted); font-size: 12px; margin:6px 0 0; }
.topbar { background: linear-gradient(0deg, #f9fafb, #f9fafb); border-bottom-color: rgba(11,31,59,0.12); }
.topbar-inner { height:36px; display:flex; align-items:center; color: var(--muted); }
.lang-toggle { display:flex; gap:8px; margin-left:16px; }
.lang-toggle button { padding:6px 10px; border:1px solid var(--border); background:#fff; border-radius:8px; cursor:pointer; }
.lang-toggle button.active { background:#111; color:#fff; }
.hero { padding:64px 0; border-bottom:1px solid var(--border); }
.hero .container { display:grid; grid-template-columns: 1.2fr .8fr; gap:28px; align-items:center; }
.hero h1 { margin:0 0 10px; font-size:32px; }
.hero p { margin:0 0 16px; color: var(--muted); }
.hero .cta { display:flex; gap:12px; }
.services .grid, .testimonials .grid { display:grid; grid-template-columns: repeat(3,1fr); gap:16px; }
.services .item, .testimonials .item { border:1px solid var(--border); border-radius:10px; padding:16px; background:#fff; border-color: var(--svc-color, rgba(11,31,59,0.12)); }
.services .item::before { content:""; position:absolute; left:0; top:0; bottom:0; width:4px; background: var(--svc-color, var(--sky)); border-radius: 8px 0 0 8px; }
.appointment form { display:grid; gap:12px; grid-template-columns: 1fr 1fr; }
.appointment form textarea { grid-column: 1 / -1; }
.appointment .status { margin:0; }
.contact .cols { display:grid; grid-template-columns: 1fr 1fr; gap:16px; }
.contact iframe { width:100%; height:320px; border:0; border-radius:10px; border:1px solid var(--border); }
/* Reveal-on-scroll animation */
.reveal { opacity: 0; transform: translateY(var(--reveal-distance)); transition: opacity var(--reveal-duration) var(--reveal-ease), transform var(--reveal-duration) var(--reveal-ease); }
.reveal.in { opacity: 1; transform: translateY(0); }
/* image hover micro-interaction */
.membership-grid img, .about-photo img { transition: transform 200ms ease; }
.membership-grid img:hover, .about-photo img:hover { transform: translateY(-2px); }
/* service card header with icon */
.svc-head { display:flex; align-items:center; gap:12px; margin-bottom:10px; }
.svc-icon { flex:0 0 auto; width:44px; height:44px; display:grid; place-items:center; border-radius:10px; background:#f6f8fb; border:1px solid var(--border); }
.services .item { position: relative; overflow: hidden; transition: transform 220ms ease, box-shadow 220ms ease; }
.services .item.reveal { transition-delay: calc(var(--i, 0) * var(--services-stagger, 60ms)), opacity var(--reveal-duration) var(--reveal-ease), transform var(--reveal-duration) var(--reveal-ease); }
.services .item:hover { transform: translateY(calc(-1 * var(--services-hover-lift, 4px))); box-shadow: 0 6px 24px rgba(0,0,0,0.08); }
.appointment { background: var(--appt-bg); border:1px solid var(--appt-border); border-radius: var(--radius); padding:24px; box-shadow: var(--shadow); }
.appointment .textarea { background:#fff; border-color: var(--appt-border); }
.appointment .textarea:focus { outline: none; box-shadow: 0 0 0 3px color-mix(in oklab, var(--appt-focus) 30%, transparent); border-color: var(--appt-focus); }
.appointment .btn { background: linear-gradient(180deg, var(--appt-btn-start), var(--appt-btn-end)); color: var(--navy); }
.appointment .btn:hover { filter: brightness(0.98); transform: translateY(-1px); }
@media (max-width: 860px){
  .about-grid { grid-template-columns: 1fr; }
  .membership-grid { grid-template-columns: repeat(3, 1fr); }
  .hero .container { grid-template-columns: 1fr; }
  .hero .cta { flex-direction: column; }
  .btn, .btn.outline { width: 100%; }
  .nav { display: flex; flex-wrap: wrap; gap: 8px 12px; }
  .nav a { margin-left: 0; padding: 6px 0; }
}