@import url('https://fonts.googleapis.com/css2?family=Archivo+Black&family=Bangers&family=Cinzel:wght@500;700&family=Fraunces:ital,wght@0,400;0,600;1,500&family=Monoton&family=Orbitron:wght@500;700&display=swap');

/* ============================================
   Op. Dr. Yasemin Aydınlı — Stylesheet
   Palette: warm ivory, soft sand, deep plum, rose-gold
   Alt theme: [data-theme="pop"] — pop-art / comic retro
   ============================================ */

:root {
  --ivory: #f7f2ec;
  --sand: #ece2d6;
  --cream: #fbf8f4;
  --plum: #2e2329;
  --plum-soft: #4a3b42;
  --rose: #b08968;
  --rose-deep: #9a6f4d;
  --gold: #c9a87c;
  --line: rgba(46, 35, 41, 0.12);
  --muted: #7a6e6a;
  --white: #ffffff;

  --serif: "Cormorant Garamond", Georgia, serif;
  --sans: "Jost", system-ui, sans-serif;

  --radius: 18px;
  --maxw: 1200px;
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
}

* { margin: 0; padding: 0; box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  font-family: var(--sans);
  color: var(--plum);
  background: var(--ivory);
  line-height: 1.6;
  font-weight: 300;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

h1, h2, h3, h4 { font-family: var(--serif); font-weight: 500; line-height: 1.1; }
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }

.eyebrow {
  font-family: var(--sans);
  text-transform: uppercase;
  letter-spacing: 0.28em;
  font-size: 0.72rem;
  font-weight: 500;
  color: var(--rose-deep);
  margin-bottom: 1rem;
}

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.95rem 2rem;
  font-family: var(--sans);
  font-size: 0.85rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border-radius: 100px;
  border: 1px solid transparent;
  cursor: pointer;
  transition: all 0.4s var(--ease);
}
.btn-primary { background: var(--plum); color: var(--cream); }
.btn-primary:hover { background: var(--rose-deep); transform: translateY(-2px); box-shadow: 0 14px 30px rgba(154, 111, 77, 0.3); }
.btn-ghost { background: transparent; border-color: var(--plum); color: var(--plum); }
.btn-ghost:hover { background: var(--plum); color: var(--cream); }
.btn-block { width: 100%; }

/* ---------- Topbar ---------- */
.topbar {
  background: var(--plum);
  color: var(--sand);
  font-size: 0.74rem;
  letter-spacing: 0.06em;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
  padding: 0.55rem 1.5rem;
  flex-wrap: wrap;
}
.topbar a:hover { color: var(--gold); }
.topbar-divider { opacity: 0.4; }
.topbar-langs { display: flex; gap: 0.25rem; margin-left: 1rem; }
.lang-chip {
  background: transparent;
  border: 1px solid rgba(255,255,255,0.2);
  color: var(--sand);
  font-size: 0.68rem;
  padding: 0.15rem 0.5rem;
  border-radius: 100px;
  cursor: pointer;
  font-family: var(--sans);
  transition: all 0.3s;
}
.lang-chip.active, .lang-chip:hover { background: var(--gold); color: var(--plum); border-color: var(--gold); }
.lang-chip { display: inline-flex; align-items: center; gap: 0.3rem; }
.lang-chip img { width: 15px; height: 11px; object-fit: cover; border-radius: 2px; }

/* ---------- Header ---------- */
.header {
  position: sticky;
  top: 0;
  z-index: 100;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.1rem 2.5rem;
  background: rgba(247, 242, 236, 0.85);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--line);
  transition: padding 0.4s var(--ease);
}
.header.scrolled { padding: 0.7rem 2.5rem; }

.brand { display: flex; align-items: center; gap: 0.8rem; flex-shrink: 0; }
.brand-mark {
  width: 44px; height: 44px;
  display: grid; place-items: center;
  background: var(--plum);
  color: var(--gold);
  border-radius: 50%;
  font-family: var(--serif);
  font-size: 1.1rem;
  font-weight: 600;
  letter-spacing: 0.05em;
}
.brand-text { display: flex; flex-direction: column; line-height: 1.2; }
.brand-text strong { font-family: var(--serif); font-size: 1.15rem; font-weight: 600; white-space: nowrap; }
.brand-text small { font-size: 0.68rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted); }

.nav { display: flex; align-items: center; gap: 1.5rem; }
.nav a { font-size: 0.86rem; letter-spacing: 0.05em; position: relative; transition: color 0.3s; white-space: nowrap; }
.nav a:not(.nav-cta)::after {
  content: ""; position: absolute; left: 0; bottom: -4px;
  width: 0; height: 1px; background: var(--rose-deep); transition: width 0.35s var(--ease);
}
.nav a:not(.nav-cta):hover::after { width: 100%; }
.nav a:not(.nav-cta):hover { color: var(--rose-deep); }
.nav-cta {
  background: var(--plum); color: var(--cream);
  padding: 0.6rem 1.4rem; border-radius: 100px;
  text-transform: uppercase; font-size: 0.76rem; letter-spacing: 0.1em;
  transition: all 0.35s var(--ease);
}
.nav-cta:hover { background: var(--rose-deep); }

.menu-toggle { display: none; flex-direction: column; gap: 5px; background: none; border: none; cursor: pointer; }
.menu-toggle span { width: 26px; height: 2px; background: var(--plum); transition: all 0.3s; }

/* ---------- Hero ---------- */
.hero {
  position: relative;
  min-height: 92vh;
  display: flex;
  align-items: center;
  padding: 4rem 2.5rem;
  overflow: hidden;
}
.hero-bg {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 60% 50% at 75% 30%, rgba(201, 168, 124, 0.28), transparent 60%),
    radial-gradient(ellipse 50% 60% at 15% 80%, rgba(176, 137, 104, 0.2), transparent 55%),
    linear-gradient(160deg, var(--cream), var(--sand));
  z-index: -1;
}
.hero-bg::after {
  content: ""; position: absolute; right: 9%; top: 50%; transform: translate(50%, -50%);
  width: 560px; height: 560px; border-radius: 50%;
  border: 1px solid rgba(154, 111, 77, 0.3);
  box-shadow: 0 0 0 30px rgba(201,168,124,0.05);
  z-index: 0;
}
.hero-inner { max-width: 620px; margin: 0 auto 0 8%; }

/* Hero portrait */
.hero-portrait {
  position: absolute; right: 6%; top: 50%; transform: translateY(-50%);
  width: 38%; max-width: 460px; aspect-ratio: 4/4.4;
  border-radius: 240px 240px 24px 24px; overflow: hidden;
  box-shadow: 0 40px 80px rgba(46,35,41,0.25);
  border: 6px solid rgba(255,255,255,0.6);
  z-index: 1;
}
.hero-portrait img { width: 100%; height: 100%; object-fit: cover; object-position: center 30%; }
.hero h1 { font-size: clamp(2.6rem, 6vw, 4.8rem); line-height: 1.04; margin-bottom: 1.6rem; }
.hero h1 em { font-style: italic; color: var(--rose-deep); }
.hero-sub { font-size: 1.15rem; max-width: 520px; color: var(--plum-soft); margin-bottom: 2.2rem; }
.hero-actions { display: flex; gap: 1rem; flex-wrap: wrap; margin-bottom: 3.5rem; }
.hero-stats { display: flex; gap: 3rem; flex-wrap: wrap; }
.hero-stats div { display: flex; flex-direction: column; }
.hero-stats strong { font-family: var(--serif); font-size: 2.4rem; font-weight: 600; color: var(--plum); }
.hero-stats span { font-size: 0.78rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted); }

.scroll-cue { position: absolute; bottom: 2rem; left: 50%; transform: translateX(-50%); }
.scroll-cue span {
  display: block; width: 24px; height: 40px; border: 1px solid var(--plum-soft); border-radius: 100px; position: relative;
}
.scroll-cue span::after {
  content: ""; position: absolute; top: 7px; left: 50%; transform: translateX(-50%);
  width: 4px; height: 8px; background: var(--rose-deep); border-radius: 4px;
  animation: scrolldot 1.8s infinite;
}
@keyframes scrolldot { 0% { opacity: 0; top: 7px; } 50% { opacity: 1; } 100% { opacity: 0; top: 22px; } }

/* ---------- Marquee ---------- */
.marquee { background: var(--plum); color: var(--sand); padding: 1.1rem 0; overflow: hidden; }
.marquee-track {
  display: flex; gap: 2.5rem; white-space: nowrap; width: max-content;
  animation: marquee 28s linear infinite;
  font-family: var(--serif); font-size: 1.4rem; font-style: italic;
}
.marquee-track span:nth-child(even) { color: var(--gold); }
@keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ---------- Section shells ---------- */
section { padding: 6.5rem 2.5rem; }
.section-head { max-width: 640px; margin: 0 auto 4rem; text-align: center; }
.section-head h2 { font-size: clamp(2rem, 4vw, 3rem); margin-bottom: 1rem; }
.section-lead { color: var(--plum-soft); font-size: 1.05rem; }

/* ---------- About ---------- */
.about {
  max-width: var(--maxw); margin: 0 auto;
  display: grid; grid-template-columns: 0.9fr 1.1fr; gap: 4.5rem; align-items: center;
}
.about-media { position: relative; }
.about-photo {
  border-radius: var(--radius); overflow: hidden; aspect-ratio: 4/5;
  background: linear-gradient(150deg, var(--sand), #d8c4ad);
  position: relative;
  box-shadow: 0 30px 60px rgba(46,35,41,0.12);
}
.about-photo img { width: 100%; height: 100%; object-fit: cover; object-position: center 25%; }
.about-badge {
  position: absolute; bottom: -24px; right: -10px;
  background: var(--plum); color: var(--cream);
  padding: 1.1rem 1.5rem; border-radius: 14px;
  display: flex; flex-direction: column; line-height: 1.2;
  box-shadow: 0 18px 40px rgba(46,35,41,0.25);
}
.about-badge strong { font-family: var(--serif); font-size: 1.3rem; color: var(--gold); }
.about-badge span { font-size: 0.74rem; letter-spacing: 0.08em; text-transform: uppercase; }
.about-content h2 { font-size: clamp(1.9rem, 3.5vw, 2.8rem); margin-bottom: 1.4rem; }
.about-content p { color: var(--plum-soft); margin-bottom: 1.1rem; }
.about-content em { color: var(--rose-deep); font-style: italic; }
.about-list { list-style: none; display: grid; grid-template-columns: 1fr 1fr; gap: 0.7rem; margin: 1.8rem 0; }
.about-list li { position: relative; padding-left: 1.5rem; font-size: 0.95rem; }
.about-list li::before { content: "✦"; position: absolute; left: 0; color: var(--rose); font-size: 0.8rem; }
.link-arrow { font-size: 0.9rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--rose-deep); display: inline-flex; gap: 0.5rem; align-items: center; }
.link-arrow span { transition: transform 0.3s; }
.link-arrow:hover span { transform: translateX(6px); }

/* ---------- Services ---------- */
.services { background: var(--cream); }
.service-grid { max-width: var(--maxw); margin: 0 auto; display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.8rem; }
.service-card {
  background: var(--white); border: 1px solid var(--line); border-radius: var(--radius);
  transition: all 0.45s var(--ease); position: relative; overflow: hidden;
}
.service-card:hover { transform: translateY(-8px); box-shadow: 0 28px 50px rgba(46,35,41,0.1); }
.service-img { position: relative; aspect-ratio: 4/3; overflow: hidden; }
.service-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s var(--ease); }
.service-card:hover .service-img img { transform: scale(1.06); }
.service-num {
  position: absolute; top: 1rem; left: 1rem;
  width: 48px; height: 48px; display: grid; place-items: center;
  background: rgba(46,35,41,0.85); color: var(--gold);
  font-family: var(--serif); font-size: 1.3rem; font-weight: 600; border-radius: 50%;
  backdrop-filter: blur(4px);
}
.service-body { padding: 2rem; }
.service-card h3 { font-size: 1.7rem; margin-bottom: 0.9rem; }
.service-body > p { color: var(--plum-soft); font-size: 0.95rem; margin-bottom: 1.4rem; }
.service-card ul { list-style: none; display: flex; flex-wrap: wrap; gap: 0.5rem; }
.service-card ul li { font-size: 0.78rem; letter-spacing: 0.04em; background: var(--ivory); padding: 0.35rem 0.8rem; border-radius: 100px; border: 1px solid var(--line); }

/* ---------- Philosophy ---------- */
.philosophy { background: var(--plum); color: var(--sand); text-align: center; }
.philosophy-inner { max-width: 800px; margin: 0 auto; position: relative; }
.quote-mark { font-family: var(--serif); font-size: 6rem; line-height: 0.5; color: var(--gold); height: 3rem; }
.philosophy blockquote { font-family: var(--serif); font-size: clamp(1.6rem, 3.5vw, 2.6rem); font-style: italic; line-height: 1.3; margin-bottom: 1.5rem; }
.philosophy cite { font-style: normal; letter-spacing: 0.15em; text-transform: uppercase; font-size: 0.8rem; color: var(--gold); }

/* ---------- Clinic ---------- */
.clinic { max-width: var(--maxw); margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 4.5rem; align-items: center; }
.clinic-content h2 { font-size: clamp(1.9rem, 3.5vw, 2.8rem); margin-bottom: 1.2rem; }
.clinic-content > p { color: var(--plum-soft); margin-bottom: 2rem; }
.clinic-features { display: grid; grid-template-columns: 1fr 1fr; gap: 1.6rem; }
.feature h4 { font-size: 1.2rem; margin-bottom: 0.3rem; color: var(--rose-deep); }
.feature p { font-size: 0.9rem; color: var(--plum-soft); }
.clinic-gallery { display: grid; grid-template-columns: 1fr 1fr; grid-template-rows: 1fr 1fr; gap: 1rem; height: 460px; }
.gallery-tile { border-radius: 14px; background-size: cover; background-position: center; }
.tile-a { grid-row: 1 / 3; background: linear-gradient(160deg, #d8c4ad, var(--rose)); }
.tile-b { background: linear-gradient(160deg, var(--sand), #c9b298); }
.tile-c { background: linear-gradient(160deg, var(--plum-soft), var(--plum)); }

/* ---------- Journal ---------- */
.journal { background: var(--cream); }
.journal-grid { max-width: var(--maxw); margin: 0 auto; display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.8rem; }
.journal-card { background: var(--white); border-radius: var(--radius); overflow: hidden; border: 1px solid var(--line); transition: all 0.45s var(--ease); }
.journal-card:hover { transform: translateY(-6px); box-shadow: 0 24px 44px rgba(46,35,41,0.1); }
.journal-img { height: 200px; background-size: cover; }
.img-1 { background: linear-gradient(150deg, var(--rose), #d8c4ad); }
.img-2 { background: linear-gradient(150deg, var(--gold), var(--sand)); }
.img-3 { background: linear-gradient(150deg, var(--plum-soft), var(--rose-deep)); }
.journal-body { padding: 1.8rem; }
.journal-tag { font-size: 0.7rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--rose-deep); }
.journal-body h3 { font-size: 1.4rem; margin: 0.6rem 0 0.7rem; }
.journal-body p { font-size: 0.9rem; color: var(--plum-soft); margin-bottom: 1rem; }
.journal-meta { font-size: 0.78rem; color: var(--muted); letter-spacing: 0.05em; }

/* ---------- Contact ---------- */
.contact { background: var(--ivory); }
.contact-inner { max-width: var(--maxw); margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 4.5rem; }
.contact-info h2 { font-size: clamp(2rem, 4vw, 3rem); margin-bottom: 1rem; }
.contact-lead { color: var(--plum-soft); margin-bottom: 2.2rem; }
.contact-list { list-style: none; display: grid; gap: 1.6rem; margin-bottom: 2rem; }
.contact-label { display: block; font-size: 0.72rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--rose-deep); margin-bottom: 0.3rem; }
.contact-list a { font-size: 1.05rem; transition: color 0.3s; }
.contact-list a:hover { color: var(--rose-deep); }
.contact-socials { display: flex; flex-wrap: wrap; gap: 0.6rem; }
.contact-socials a { font-size: 0.78rem; letter-spacing: 0.08em; text-transform: uppercase; border: 1px solid var(--line); padding: 0.5rem 1rem; border-radius: 100px; transition: all 0.3s; }
.contact-socials a:hover { background: var(--plum); color: var(--cream); border-color: var(--plum); }

.contact-form { background: var(--white); padding: 2.6rem; border-radius: var(--radius); border: 1px solid var(--line); box-shadow: 0 24px 50px rgba(46,35,41,0.06); }
.field { margin-bottom: 1.3rem; }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.field-consent { margin-bottom: 1.5rem; }
.field-consent .consent-check { display: flex; align-items: flex-start; gap: 0.7rem; cursor: pointer; text-transform: none; letter-spacing: 0; margin: 0; }
.consent-check input[type="checkbox"] { width: 18px; height: 18px; min-width: 18px; margin-top: 2px; accent-color: var(--plum); cursor: pointer; }
.field-consent .consent-check span { font-size: 0.82rem; line-height: 1.55; color: var(--plum-soft); text-transform: none; letter-spacing: 0; }
.consent-check a { color: var(--rose); text-decoration: underline; }
.consent-check a:hover { color: var(--plum); }
.field label { display: block; font-size: 0.78rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--plum-soft); margin-bottom: 0.5rem; }
.field input, .field select, .field textarea {
  width: 100%; padding: 0.85rem 1rem; border: 1px solid var(--line); border-radius: 10px;
  font-family: var(--sans); font-size: 0.95rem; color: var(--plum); background: var(--cream);
  transition: border-color 0.3s, box-shadow 0.3s; resize: vertical;
}
.field input:focus, .field select:focus, .field textarea:focus {
  outline: none; border-color: var(--rose); box-shadow: 0 0 0 3px rgba(176,137,104,0.15);
}
.form-note { margin-top: 1rem; color: var(--rose-deep); font-size: 0.9rem; text-align: center; }

/* ---------- Footer ---------- */
.footer { background: var(--plum); color: var(--sand); padding: 4rem 2.5rem 2rem; }
.footer-inner { max-width: var(--maxw); margin: 0 auto; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 2rem; padding-bottom: 2.5rem; border-bottom: 1px solid rgba(255,255,255,0.12); }
.footer-brand { display: flex; align-items: center; gap: 1rem; }
.footer-brand strong { display: block; font-family: var(--serif); font-size: 1.2rem; }
.footer-brand small { font-size: 0.74rem; letter-spacing: 0.08em; color: var(--gold); }
.footer-nav { display: flex; gap: 1.8rem; flex-wrap: wrap; }
.footer-nav a { font-size: 0.86rem; transition: color 0.3s; }
.footer-nav a:hover { color: var(--gold); }
.footer-socials { display: flex; gap: 0.6rem; flex-wrap: wrap; }
.footer-socials a { font-size: 0.72rem; letter-spacing: 0.08em; text-transform: uppercase; border: 1px solid rgba(255,255,255,0.18); padding: 0.4rem 0.85rem; border-radius: 100px; color: rgba(236,226,214,0.85); transition: all 0.3s; }
.footer-socials a:hover { background: var(--gold); color: var(--plum); border-color: var(--gold); }
.footer-bottom { max-width: var(--maxw); margin: 1.8rem auto 0; display: flex; justify-content: space-between; flex-wrap: wrap; gap: 0.5rem; font-size: 0.78rem; color: rgba(236,226,214,0.6); }

/* ---------- WhatsApp float ---------- */
.wa-float {
  position: fixed; bottom: 1.6rem; right: 1.6rem; z-index: 90;
  width: 56px; height: 56px; border-radius: 50%;
  background: #25d366; color: #fff; display: grid; place-items: center;
  box-shadow: 0 10px 30px rgba(37,211,102,0.4); transition: transform 0.3s;
}
.wa-float:hover { transform: scale(1.1); }

/* ============================================
   INNER PAGES
   ============================================ */

/* Active nav link */
.nav a.active:not(.nav-cta) { color: var(--rose-deep); }
.nav a.active:not(.nav-cta)::after { width: 100%; }

/* Page hero / banner */
.page-hero {
  position: relative;
  padding: 5rem 2.5rem 4rem;
  text-align: center;
  background:
    radial-gradient(ellipse 70% 80% at 50% 0%, rgba(201,168,124,0.25), transparent 60%),
    linear-gradient(160deg, var(--cream), var(--sand));
  overflow: hidden;
}
.page-hero::after {
  content: ""; position: absolute; left: 50%; bottom: -120px; transform: translateX(-50%);
  width: 360px; height: 360px; border-radius: 50%;
  border: 1px solid rgba(154,111,77,0.2);
}
.page-hero .eyebrow { margin-bottom: 0.8rem; }
.page-hero h1 { font-size: clamp(2.4rem, 5vw, 4rem); line-height: 1.05; margin-bottom: 1rem; }
.page-hero h1 em { font-style: italic; color: var(--rose-deep); }
.page-hero p { max-width: 620px; margin: 0 auto; color: var(--plum-soft); font-size: 1.08rem; }
.breadcrumb { display: flex; gap: 0.5rem; justify-content: center; font-size: 0.78rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--muted); margin-top: 1.6rem; }
.breadcrumb a:hover { color: var(--rose-deep); }
.breadcrumb span { opacity: 0.5; }

/* Section CTA (centered button under a grid) */
.section-cta { max-width: var(--maxw); margin: 3rem auto 0; text-align: center; }

/* Generic prose */
.prose { max-width: 760px; margin: 0 auto; }
.prose p { color: var(--plum-soft); margin-bottom: 1.3rem; font-size: 1.05rem; }
.prose h2 { font-size: clamp(1.7rem, 3vw, 2.3rem); margin: 2.6rem 0 1rem; }
.prose h3 { font-size: 1.5rem; margin: 2rem 0 0.8rem; color: var(--rose-deep); }
.prose ul, .prose ol { margin: 0 0 1.4rem 1.2rem; color: var(--plum-soft); }
.prose li { margin-bottom: 0.5rem; }
.prose blockquote {
  border-left: 3px solid var(--rose); padding: 0.6rem 1.4rem; margin: 1.8rem 0;
  font-family: var(--serif); font-size: 1.4rem; font-style: italic; color: var(--plum);
}
.prose img { border-radius: var(--radius); margin: 1.8rem 0; }

/* About page — biography body with summary card */
.about-body { max-width: var(--maxw); margin: 2.5rem auto 0; display: grid; grid-template-columns: minmax(0, 1fr) 340px; gap: 3.5rem; align-items: start; }
.about-prose { max-width: 720px; margin: 0; }
.about-prose p { color: var(--plum); font-size: 1.07rem; line-height: 1.85; margin-bottom: 1.45rem; }
.about-prose .link-arrow { margin-top: 0.4rem; }
.about-card { position: sticky; top: 110px; background: var(--white); border: 1px solid var(--line); border-radius: var(--radius); padding: 2rem 1.85rem; box-shadow: 0 24px 55px rgba(46,35,41,0.09); }
.about-card .eyebrow { margin-bottom: 0.35rem; }
.about-card h3 { font-size: 1.55rem; margin-bottom: 1.4rem; color: var(--plum); }
.fact-list { list-style: none; margin: 0; padding: 0; }
.fact-list li { padding: 0.8rem 0; border-top: 1px solid var(--line); display: flex; flex-direction: column; gap: 0.28rem; }
.fact-list li:first-child { border-top: none; padding-top: 0; }
.fact-list .fk { font-size: 0.71rem; letter-spacing: 0.13em; text-transform: uppercase; color: var(--rose-deep); font-weight: 600; }
.fact-list .fv { font-size: 0.96rem; line-height: 1.5; color: var(--plum); }
.fact-list .fv em { font-style: normal; color: var(--muted); }
.btn-card { display: block; text-align: center; margin-top: 1.6rem; padding: 0.9rem 1rem; background: var(--plum); color: var(--cream); border-radius: 100px; font-size: 0.8rem; letter-spacing: 0.06em; line-height: 1.35; text-transform: uppercase; transition: background 0.3s var(--ease); }
.btn-card span { display: inline-block; margin-left: 0.4rem; transition: transform 0.3s; }
.btn-card:hover { background: var(--rose-deep); }
.btn-card:hover span { transform: translateX(5px); }
@media (max-width: 900px) {
  .about-body { grid-template-columns: 1fr; gap: 2.2rem; }
  .about-prose { max-width: none; }
  .about-card { position: static; }
}

/* Two-column intro (about) */
.split { max-width: var(--maxw); margin: 0 auto; display: grid; grid-template-columns: 0.9fr 1.1fr; gap: 4.5rem; align-items: center; }
.split.reverse { grid-template-columns: 1.1fr 0.9fr; }
.split-media { border-radius: var(--radius); overflow: hidden; aspect-ratio: 4/5; box-shadow: 0 30px 60px rgba(46,35,41,0.12); }
.split-media img { width: 100%; height: 100%; object-fit: cover; object-position: center 25%; }
.split-text h2 { font-size: clamp(1.9rem, 3.5vw, 2.8rem); margin-bottom: 1.3rem; }
.split-text p { color: var(--plum-soft); margin-bottom: 1.1rem; }
.split-text em { color: var(--rose-deep); font-style: italic; }

/* Timeline */
.timeline { max-width: 760px; margin: 0 auto; position: relative; padding-left: 2rem; }
.timeline::before { content: ""; position: absolute; left: 6px; top: 8px; bottom: 8px; width: 2px; background: linear-gradient(var(--rose), var(--sand)); }
.timeline-item { position: relative; padding-bottom: 2.2rem; }
.timeline-item:last-child { padding-bottom: 0; }
.timeline-item::before { content: ""; position: absolute; left: -2rem; top: 6px; width: 14px; height: 14px; border-radius: 50%; background: var(--rose); box-shadow: 0 0 0 4px rgba(176,137,104,0.2); }
.timeline-item .ti-year { font-family: var(--serif); font-size: 1.2rem; color: var(--rose-deep); font-weight: 600; }
.timeline-item h4 { font-size: 1.3rem; margin: 0.2rem 0 0.4rem; }
.timeline-item p { color: var(--plum-soft); font-size: 0.96rem; }

/* Values grid */
.values { max-width: var(--maxw); margin: 0 auto; display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.6rem; }
.value-card { background: var(--white); border: 1px solid var(--line); border-radius: var(--radius); padding: 2.2rem; transition: transform 0.4s var(--ease); }
.value-card:hover { transform: translateY(-6px); }
.value-card .v-icon { font-size: 1.8rem; color: var(--rose); margin-bottom: 0.8rem; }
.value-card h4 { font-size: 1.35rem; margin-bottom: 0.5rem; }
.value-card p { color: var(--plum-soft); font-size: 0.95rem; }

/* Service detail rows */
.svc-detail { max-width: var(--maxw); margin: 0 auto 5rem; display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; }
.svc-detail:last-child { margin-bottom: 0; }
.svc-detail.reverse .svc-detail-media { order: 2; }
.svc-detail-media { border-radius: var(--radius); overflow: hidden; box-shadow: 0 24px 50px rgba(46,35,41,0.14); aspect-ratio: 1/1; }
.svc-detail-media img { width: 100%; height: 100%; object-fit: cover; }
.svc-detail-text .eyebrow { margin-bottom: 0.6rem; }
.svc-detail-text h3 { font-size: clamp(1.8rem, 3vw, 2.4rem); margin-bottom: 1rem; }
.svc-detail-text p { color: var(--plum-soft); margin-bottom: 1.2rem; }
.svc-tags { display: grid; grid-template-columns: 1fr 1fr; gap: 0.6rem 1.4rem; margin-bottom: 1.6rem; list-style: none; }
.svc-tags li { position: relative; padding-left: 1.5rem; font-size: 0.98rem; }
.svc-tags li::before { content: "✦"; position: absolute; left: 0; color: var(--rose); font-size: 0.8rem; }

/* Process steps */
.process { max-width: var(--maxw); margin: 0 auto; display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.6rem; }
.step { text-align: center; padding: 1.5rem; }
.step .step-num { width: 56px; height: 56px; margin: 0 auto 1rem; display: grid; place-items: center; border-radius: 50%; background: var(--plum); color: var(--gold); font-family: var(--serif); font-size: 1.4rem; }
.step h4 { font-size: 1.2rem; margin-bottom: 0.4rem; }
.step p { font-size: 0.9rem; color: var(--plum-soft); }

/* CTA band */
.cta-band { background: var(--plum); color: var(--cream); text-align: center; }
.cta-band h2 { font-size: clamp(2rem, 4vw, 3rem); margin-bottom: 1rem; }
.cta-band p { color: rgba(236,226,214,0.8); max-width: 560px; margin: 0 auto 2rem; }
.cta-band .btn-primary { background: var(--gold); color: var(--plum); }
.cta-band .btn-primary:hover { background: var(--cream); }

/* Map */
.map-embed { max-width: var(--maxw); margin: 0 auto; border-radius: var(--radius); overflow: hidden; box-shadow: 0 24px 50px rgba(46,35,41,0.1); border: 1px solid var(--line); }
.map-embed iframe { width: 100%; height: 420px; border: 0; display: block; filter: grayscale(0.2) contrast(1.05); }

/* Clinic detail gallery */
.gallery-grid { max-width: var(--maxw); margin: 0 auto; display: grid; grid-template-columns: repeat(3, 1fr); grid-auto-rows: 220px; gap: 1rem; }
.gallery-grid .g-item { border-radius: 14px; background-size: cover; background-position: center; }
.gallery-grid .span-2 { grid-column: span 2; }
.gallery-grid .row-2 { grid-row: span 2; }
.g-1 { background: linear-gradient(160deg, #d8c4ad, var(--rose)); }
.g-2 { background: linear-gradient(160deg, var(--sand), #c9b298); }
.g-3 { background: linear-gradient(160deg, var(--plum-soft), var(--plum)); }
.g-4 { background: linear-gradient(160deg, var(--gold), #d8c4ad); }
.g-5 { background: linear-gradient(160deg, var(--rose-deep), var(--plum-soft)); }

/* Info cards row (hours, contact) */
.info-row { max-width: var(--maxw); margin: 0 auto; display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.6rem; }
.info-card { background: var(--white); border: 1px solid var(--line); border-radius: var(--radius); padding: 2.2rem; }
.info-card h4 { font-size: 1.3rem; margin-bottom: 0.8rem; color: var(--rose-deep); }
.info-card p, .info-card li { color: var(--plum-soft); font-size: 0.96rem; }
.info-card ul { list-style: none; }
.info-card li { display: flex; justify-content: space-between; padding: 0.4rem 0; border-bottom: 1px solid var(--line); }
.info-card li:last-child { border-bottom: 0; }
.info-card a { color: var(--plum); }
.info-card a:hover { color: var(--rose-deep); }

/* Blog list */
.blog-list { max-width: var(--maxw); margin: 0 auto; display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.8rem; }
.cat-filter { max-width: var(--maxw); margin: 0 auto 2.5rem; display: flex; gap: 0.6rem; flex-wrap: wrap; justify-content: center; }
.cat-filter button { background: var(--white); border: 1px solid var(--line); padding: 0.5rem 1.2rem; border-radius: 100px; cursor: pointer; font-family: var(--sans); font-size: 0.84rem; letter-spacing: 0.05em; transition: all 0.3s; }
.cat-filter button.active, .cat-filter button:hover { background: var(--plum); color: var(--cream); border-color: var(--plum); }

/* Blog post */
.post-meta { display: flex; gap: 1.2rem; justify-content: center; align-items: center; font-size: 0.85rem; color: var(--muted); margin-top: 1.4rem; }
.post-meta .tag { background: var(--white); border: 1px solid var(--line); padding: 0.3rem 0.9rem; border-radius: 100px; color: var(--rose-deep); letter-spacing: 0.06em; }
.post-cover { max-width: 900px; margin: -2rem auto 3rem; height: 380px; border-radius: var(--radius); background: linear-gradient(150deg, var(--rose), #d8c4ad); box-shadow: 0 30px 60px rgba(46,35,41,0.15); }
.author-box { max-width: 760px; margin: 3rem auto 0; display: flex; gap: 1.4rem; align-items: center; background: var(--cream); border: 1px solid var(--line); border-radius: var(--radius); padding: 1.8rem; }
.author-box img { width: 76px; height: 76px; border-radius: 50%; object-fit: cover; object-position: center 20%; }
.author-box h4 { font-size: 1.2rem; }
.author-box span { font-size: 0.85rem; color: var(--muted); }
.author-box p { font-size: 0.92rem; color: var(--plum-soft); margin-top: 0.3rem; }

/* FAQ */
.faq { max-width: 800px; margin: 0 auto; }
.faq-item { border-bottom: 1px solid var(--line); }
.faq-q { width: 100%; text-align: left; background: none; border: none; cursor: pointer; padding: 1.3rem 2.5rem 1.3rem 0; font-family: var(--serif); font-size: 1.25rem; color: var(--plum); position: relative; }
.faq-q::after { content: "+"; position: absolute; right: 0; top: 50%; transform: translateY(-50%); font-size: 1.5rem; color: var(--rose); transition: transform 0.3s; }
.faq-item.open .faq-q::after { transform: translateY(-50%) rotate(45deg); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height 0.4s var(--ease); }
.faq-item.open .faq-a { max-height: 300px; }
.faq-a p { color: var(--plum-soft); padding: 0 0 1.3rem; }

/* Page section helper */
.bg-cream { background: var(--cream); }

/* ---------- Reveal animation ---------- */
.reveal { opacity: 0; transform: translateY(36px); transition: opacity 0.8s var(--ease), transform 0.8s var(--ease); }
.reveal.visible { opacity: 1; transform: none; }

/* ---------- Responsive ---------- */
@media (max-width: 980px) {
  .about, .clinic, .contact-inner { grid-template-columns: 1fr; gap: 3rem; }
  .about-media { max-width: 440px; margin: 0 auto; }
  .service-grid, .journal-grid, .blog-list { grid-template-columns: 1fr 1fr; }
  .hero-inner { margin: 0 auto; text-align: center; max-width: 760px; }
  .hero-actions, .hero-stats { justify-content: center; }
  .hero-bg::after { display: none; }
  .hero-portrait { display: none; }
  .split, .split.reverse { grid-template-columns: 1fr; gap: 3rem; }
  .split-media { max-width: 440px; margin: 0 auto; }
  .svc-detail, .svc-detail.reverse { grid-template-columns: 1fr; gap: 2.5rem; }
  .svc-detail.reverse .svc-detail-media { order: 0; }
  .values, .process, .info-row { grid-template-columns: 1fr 1fr; }
}
/* Nav drawer kicks in earlier (small laptops/tablets) so the 7-item nav never crowds */
@media (max-width: 900px) {
  .nav {
    position: fixed; inset: 0 0 0 auto; width: 78%; max-width: 320px;
    background: var(--cream); flex-direction: column; align-items: flex-start;
    padding: 6rem 2rem; gap: 1.4rem; transform: translateX(100%);
    transition: transform 0.4s var(--ease); box-shadow: -20px 0 50px rgba(0,0,0,0.1);
    z-index: 95; overflow-y: auto;
  }
  .nav.open { transform: translateX(0); }
  .nav a { font-size: 1.1rem; }
  .menu-toggle { display: flex; z-index: 96; }
  .menu-toggle.active span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
  .menu-toggle.active span:nth-child(2) { opacity: 0; }
  .menu-toggle.active span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
}
@media (max-width: 760px) {
  .header { padding: 1rem 1.3rem; }
  section { padding: 4.5rem 1.3rem; }
  .service-grid, .journal-grid, .about-list, .clinic-features, .field-row,
  .blog-list, .values, .process, .info-row, .svc-tags { grid-template-columns: 1fr; }
  .clinic-gallery { height: 340px; }
  .hero-stats { gap: 2rem; }
  .topbar { font-size: 0.66rem; gap: 0.4rem; }
  .topbar-langs { width: 100%; justify-content: center; margin: 0.3rem 0 0; }
  .footer-inner { flex-direction: column; align-items: flex-start; }
  .gallery-grid { grid-template-columns: 1fr 1fr; grid-auto-rows: 160px; }
  .gallery-grid .span-2 { grid-column: span 2; }
  .author-box { flex-direction: column; text-align: center; }
}

/* ============================================
   POP-ART / COMIC RETRO THEME  [data-theme="pop"]
   ============================================ */
[data-theme="pop"] {
  --ivory: #fdf3df;
  --cream: #fffdf6;
  --sand: #ffe27a;
  --plum: #141414;
  --plum-soft: #2c2c2c;
  --rose: #ff2d95;
  --rose-deep: #ff1f8e;
  --gold: #00d8e0;
  --muted: #5a5a5a;
  --white: #ffffff;
  --line: #141414;
  --radius: 8px;
  --dot: rgba(20,20,20,0.14);
}

/* Halftone dot backdrop on the whole page */
[data-theme="pop"] body {
  background-color: var(--ivory);
  background-image: radial-gradient(var(--dot) 1.6px, transparent 1.7px);
  background-size: 16px 16px;
}

/* Headings — heavy grotesk, uppercase punch */
[data-theme="pop"] h1,
[data-theme="pop"] h2,
[data-theme="pop"] h3,
[data-theme="pop"] .brand-text strong {
  font-family: "Archivo Black", "Jost", sans-serif;
  text-transform: uppercase;
  letter-spacing: -0.01em;
  line-height: 1.02;
}
[data-theme="pop"] h4 { font-family: "Jost", sans-serif; font-weight: 600; }
[data-theme="pop"] h1 em,
[data-theme="pop"] h2 em { font-style: normal; color: var(--rose); -webkit-text-stroke: 1.5px #141414; }
[data-theme="pop"] .eyebrow { color: var(--rose-deep); font-weight: 600; }

/* Hard comic borders + offset shadows on cards/surfaces */
[data-theme="pop"] .service-card,
[data-theme="pop"] .value-card,
[data-theme="pop"] .journal-card,
[data-theme="pop"] .info-card,
[data-theme="pop"] .contact-form,
[data-theme="pop"] .about-photo,
[data-theme="pop"] .split-media,
[data-theme="pop"] .svc-detail-media,
[data-theme="pop"] .map-embed,
[data-theme="pop"] .author-box,
[data-theme="pop"] .post-cover {
  border: 3px solid #141414 !important;
  box-shadow: 8px 8px 0 #141414 !important;
  border-radius: 8px;
}
[data-theme="pop"] .service-card:hover,
[data-theme="pop"] .value-card:hover,
[data-theme="pop"] .journal-card:hover {
  transform: translate(-4px, -4px);
  box-shadow: 12px 12px 0 var(--rose) !important;
}

/* Buttons — chunky with hard shadow */
[data-theme="pop"] .btn {
  border: 3px solid #141414;
  border-radius: 8px;
  font-weight: 600;
  box-shadow: 5px 5px 0 #141414;
  text-transform: uppercase;
}
[data-theme="pop"] .btn:hover { transform: translate(-2px, -2px); box-shadow: 7px 7px 0 #141414; }
[data-theme="pop"] .btn-primary { background: var(--rose); color: #fff; }
[data-theme="pop"] .btn-primary:hover { background: var(--rose-deep); }
[data-theme="pop"] .btn-ghost { background: var(--gold); color: #141414; }
[data-theme="pop"] .btn-ghost:hover { background: #fff; color: #141414; }
[data-theme="pop"] .cta-band .btn-primary { background: var(--sand); color: #141414; box-shadow: 5px 5px 0 var(--rose); }

/* Topbar + header */
[data-theme="pop"] .topbar { background: #141414; color: var(--sand); border-bottom: 3px solid var(--rose); }
[data-theme="pop"] .header { background: var(--sand); border-bottom: 3px solid #141414; backdrop-filter: none; }
[data-theme="pop"] .brand-mark { background: var(--rose); color: #fff; border: 3px solid #141414; box-shadow: 3px 3px 0 #141414; }
[data-theme="pop"] .brand-text small { color: #141414; }
[data-theme="pop"] .nav a:not(.nav-cta):hover,
[data-theme="pop"] .nav a.active:not(.nav-cta) { color: var(--rose-deep); }
[data-theme="pop"] .nav a:not(.nav-cta)::after { background: var(--rose); height: 3px; }
[data-theme="pop"] .nav-cta { background: #141414; color: var(--sand); border: 2px solid #141414; box-shadow: 3px 3px 0 var(--rose); }
[data-theme="pop"] .nav-cta:hover { background: var(--rose); color: #fff; }
[data-theme="pop"] .menu-toggle span { background: #141414; height: 3px; }
[data-theme="pop"] .lang-chip { border-color: rgba(255,255,255,0.4); }

/* Hero — halftone + bold comic circle */
[data-theme="pop"] .hero-bg {
  background-image:
    radial-gradient(rgba(255,45,149,0.18) 2px, transparent 2.1px),
    linear-gradient(180deg, var(--sand), var(--cream));
  background-size: 18px 18px, 100% 100%;
}
[data-theme="pop"] .hero-bg::after {
  background: var(--gold);
  border: 4px solid #141414;
  box-shadow: 12px 12px 0 rgba(20,20,20,0.15);
}
[data-theme="pop"] .hero-portrait {
  border: 4px solid #141414;
  border-radius: 12px;
  box-shadow: 14px 14px 0 var(--rose);
}
[data-theme="pop"] .hero-stats strong { color: var(--rose-deep); }

/* Marquee — comic ticker */
[data-theme="pop"] .marquee { background: var(--rose); color: #fff; border-top: 3px solid #141414; border-bottom: 3px solid #141414; }
[data-theme="pop"] .marquee-track { font-style: normal; font-family: "Archivo Black", sans-serif; text-transform: uppercase; }
[data-theme="pop"] .marquee-track span:nth-child(even) { color: var(--sand); }

/* Service number badge */
[data-theme="pop"] .service-num { background: var(--rose); color: #fff; border: 2px solid #141414; backdrop-filter: none; }
[data-theme="pop"] .service-img { border-bottom: 3px solid #141414; }
[data-theme="pop"] .service-card ul li { background: var(--sand); border: 2px solid #141414; }

/* Page hero */
[data-theme="pop"] .page-hero {
  background-image:
    radial-gradient(rgba(255,45,149,0.16) 2px, transparent 2.1px),
    linear-gradient(180deg, var(--sand), var(--cream));
  background-size: 18px 18px, 100% 100%;
  border-bottom: 3px solid #141414;
}
[data-theme="pop"] .page-hero::after { background: var(--gold); border: 4px solid #141414; }
[data-theme="pop"] .post-meta .tag { background: var(--gold); border: 2px solid #141414; color: #141414; }

/* Philosophy + CTA bands */
[data-theme="pop"] .philosophy { background: var(--gold); color: #141414; border-top: 3px solid #141414; border-bottom: 3px solid #141414; }
[data-theme="pop"] .philosophy .quote-mark,
[data-theme="pop"] .philosophy cite { color: var(--rose-deep); }
[data-theme="pop"] .philosophy blockquote { font-style: normal; }
[data-theme="pop"] .cta-band { background: var(--rose); color: #fff; border-top: 3px solid #141414; border-bottom: 3px solid #141414; }
[data-theme="pop"] .cta-band p { color: rgba(255,255,255,0.92); }

/* Timeline + process accents */
[data-theme="pop"] .timeline-item::before { background: var(--rose); border: 2px solid #141414; box-shadow: none; }
[data-theme="pop"] .timeline::before { background: #141414; }
[data-theme="pop"] .step .step-num { background: var(--rose); color: #fff; border: 3px solid #141414; box-shadow: 4px 4px 0 #141414; }
[data-theme="pop"] .value-card .v-icon { color: var(--rose); }

/* FAQ */
[data-theme="pop"] .faq-item { border-bottom: 3px solid #141414; }
[data-theme="pop"] .faq-q::after { color: var(--rose); }

/* Footer */
[data-theme="pop"] .footer { background: #141414; border-top: 4px solid var(--rose); }
[data-theme="pop"] .footer-brand small { color: var(--gold); }
[data-theme="pop"] .footer-nav a:hover { color: var(--rose); }

/* Inputs */
[data-theme="pop"] .field input,
[data-theme="pop"] .field select,
[data-theme="pop"] .field textarea { border: 2px solid #141414; border-radius: 6px; background: #fff; }
[data-theme="pop"] .field input:focus,
[data-theme="pop"] .field select:focus,
[data-theme="pop"] .field textarea:focus { border-color: var(--rose); box-shadow: 4px 4px 0 var(--rose); }

/* WhatsApp + cat filter + section badges */
[data-theme="pop"] .wa-float { border: 3px solid #141414; box-shadow: 5px 5px 0 #141414; }
[data-theme="pop"] .cat-filter button { border: 2px solid #141414; box-shadow: 3px 3px 0 #141414; font-weight: 600; }
[data-theme="pop"] .cat-filter button.active,
[data-theme="pop"] .cat-filter button:hover { background: var(--rose); color: #fff; }
[data-theme="pop"] .link-arrow { color: var(--rose-deep); font-weight: 600; }
[data-theme="pop"] .prose blockquote { border-left: 4px solid var(--rose); font-style: normal; }

/* Theme switcher (injected into topbar) */
.theme-switch {
  display: inline-flex; align-items: center; gap: 0.4rem; margin-left: 1rem;
  color: inherit; font-size: 0.7rem; letter-spacing: 0.08em; text-transform: uppercase;
}
.theme-switch select {
  background: rgba(255,255,255,0.14); color: inherit;
  border: 1px solid currentColor; border-radius: 100px;
  padding: 0.18rem 0.55rem; font-family: var(--sans); font-size: 0.7rem;
  cursor: pointer; transition: all 0.3s;
}
.theme-switch select:hover { background: rgba(255,255,255,0.24); }
.theme-switch select option { color: #141414; background: #fff; }
[data-theme="pop"] .theme-switch select { border-radius: 6px; border-width: 2px; }

/* ============================================
   70'S VINTAGE THEME  [data-theme="retro70"]
   warm mustard / burnt orange / brown / cream
   ============================================ */
[data-theme="retro70"] {
  --ivory: #f1e3c6;
  --cream: #f7edd6;
  --sand: #e6a31e;
  --plum: #4a2c12;
  --plum-soft: #6e4a26;
  --rose: #cf5b1f;
  --rose-deep: #b34715;
  --gold: #7a8b34;
  --muted: #8c7350;
  --line: rgba(74,44,18,0.18);
  --white: #fbf4e3;
  --radius: 28px;
}
[data-theme="retro70"] body { background: var(--ivory); }
[data-theme="retro70"] h1, [data-theme="retro70"] h2, [data-theme="retro70"] h3,
[data-theme="retro70"] .brand-text strong, [data-theme="retro70"] .philosophy blockquote {
  font-family: "Fraunces", Georgia, serif; font-weight: 600;
}
[data-theme="retro70"] h1 em, [data-theme="retro70"] h2 em { color: var(--rose); font-style: italic; }
[data-theme="retro70"] .topbar { background: #4a2c12; color: #f1e3c6; }
[data-theme="retro70"] .header { background: var(--sand); border-bottom: 2px solid var(--rose-deep); }
[data-theme="retro70"] .brand-mark { background: var(--rose); color: #fff; }
[data-theme="retro70"] .brand-text small { color: #4a2c12; }
[data-theme="retro70"] .nav-cta { background: var(--rose); }
[data-theme="retro70"] .nav-cta:hover { background: var(--rose-deep); }
[data-theme="retro70"] .nav a:not(.nav-cta)::after { background: var(--rose); }
[data-theme="retro70"] .hero-bg {
  background:
    radial-gradient(ellipse 60% 60% at 78% 35%, rgba(207,91,31,0.4), transparent 60%),
    repeating-linear-gradient(180deg, transparent 0 38px, rgba(122,139,52,0.07) 38px 40px),
    linear-gradient(160deg, #f7edd6, #e6a31e);
}
[data-theme="retro70"] .hero-bg::after { background: radial-gradient(circle, #e6a31e 0 55%, #cf5b1f 55%); border: none; box-shadow: 0 0 0 16px rgba(207,91,31,0.18); }
[data-theme="retro70"] .hero-portrait { border: 8px solid #fbf4e3; border-radius: 200px; box-shadow: 0 24px 50px rgba(74,44,18,0.3); }
[data-theme="retro70"] .hero-stats strong { color: var(--rose); }
[data-theme="retro70"] .marquee { background: #4a2c12; color: var(--sand); }
[data-theme="retro70"] .marquee-track span:nth-child(even) { color: var(--rose); }
[data-theme="retro70"] .service-num { background: var(--rose); color: #fff; }
[data-theme="retro70"] .service-card ul li { background: var(--ivory); }
[data-theme="retro70"] .philosophy { background: var(--rose); color: #f7edd6; }
[data-theme="retro70"] .philosophy .quote-mark, [data-theme="retro70"] .philosophy cite { color: var(--sand); }
[data-theme="retro70"] .cta-band { background: #4a2c12; }
[data-theme="retro70"] .cta-band .btn-primary { background: var(--sand); color: #4a2c12; }
[data-theme="retro70"] .page-hero {
  background:
    repeating-linear-gradient(180deg, transparent 0 38px, rgba(122,139,52,0.06) 38px 40px),
    radial-gradient(ellipse 70% 80% at 50% 0%, rgba(207,91,31,0.3), transparent 60%),
    linear-gradient(160deg, var(--cream), var(--sand));
}
[data-theme="retro70"] .page-hero::after { background: radial-gradient(circle, var(--sand) 0 55%, var(--rose) 55%); border: none; }
[data-theme="retro70"] .step .step-num { background: var(--rose); color: #fff; }
[data-theme="retro70"] .timeline-item::before { background: var(--rose); box-shadow: 0 0 0 4px rgba(207,91,31,0.2); }
[data-theme="retro70"] .footer { background: #3a220e; }
[data-theme="retro70"] .footer-brand small { color: var(--sand); }
[data-theme="retro70"] .field input:focus, [data-theme="retro70"] .field select:focus,
[data-theme="retro70"] .field textarea:focus { border-color: var(--rose); box-shadow: 0 0 0 3px rgba(207,91,31,0.15); }

/* ============================================
   80'S VAPORWAVE THEME  [data-theme="vapor"]  (dark)
   neon pink / purple / cyan, grid, sunset
   ============================================ */
[data-theme="vapor"] {
  --ivory: #160a2b;
  --cream: #1e0f3a;
  --sand: #2de2e6;
  --plum: #f3e9ff;
  --plum-soft: #c4a7e6;
  --rose: #ff36ab;
  --rose-deep: #ff36ab;
  --gold: #b537f2;
  --muted: #9a7bc0;
  --line: rgba(45,226,230,0.28);
  --white: #241043;
  --radius: 6px;
}
[data-theme="vapor"] body {
  background-color: var(--ivory);
  background-image: linear-gradient(180deg, #160a2b 0%, #2a0f47 100%);
}
[data-theme="vapor"] h1, [data-theme="vapor"] h2,
[data-theme="vapor"] .page-hero h1 {
  font-family: "Monoton", "Jost", cursive; font-weight: 400; letter-spacing: 0.02em;
  color: var(--rose); text-shadow: 0 0 18px rgba(255,54,171,0.6);
}
[data-theme="vapor"] h3, [data-theme="vapor"] h4, [data-theme="vapor"] .brand-text strong { font-family: "Orbitron", sans-serif; }
[data-theme="vapor"] h1 em, [data-theme="vapor"] h2 em { color: var(--sand); font-style: normal; text-shadow: 0 0 18px rgba(45,226,230,0.6); }
[data-theme="vapor"] .eyebrow { color: var(--sand); }
[data-theme="vapor"] .topbar { background: #0e0620; color: var(--sand); border-bottom: 1px solid var(--rose); }
[data-theme="vapor"] .header { background: rgba(22,10,43,0.85); border-bottom: 1px solid var(--rose); }
[data-theme="vapor"] .brand-mark { background: var(--rose); color: #fff; box-shadow: 0 0 16px rgba(255,54,171,0.7); }
[data-theme="vapor"] .brand-text small { color: var(--sand); }
[data-theme="vapor"] .nav a:not(.nav-cta):hover, [data-theme="vapor"] .nav a.active:not(.nav-cta) { color: var(--sand); }
[data-theme="vapor"] .nav-cta { background: var(--rose); box-shadow: 0 0 16px rgba(255,54,171,0.5); }
[data-theme="vapor"] .menu-toggle span { background: var(--sand); }
[data-theme="vapor"] .hero-bg {
  background:
    linear-gradient(180deg, transparent 55%, rgba(45,226,230,0.12) 100%),
    repeating-linear-gradient(90deg, transparent 0 38px, rgba(45,226,230,0.18) 38px 39px),
    radial-gradient(circle at 50% 22%, #ff36ab, #b537f2 35%, #160a2b 70%);
}
[data-theme="vapor"] .hero-bg::after { background: radial-gradient(circle, #ffd23f, #ff36ab 70%); border: none; box-shadow: 0 0 60px rgba(255,54,171,0.6); }
[data-theme="vapor"] .hero-portrait { border: 2px solid var(--sand); box-shadow: 0 0 30px rgba(45,226,230,0.6); }
[data-theme="vapor"] .hero-stats strong { color: var(--sand); }
[data-theme="vapor"] .hero-sub, [data-theme="vapor"] p { color: var(--plum-soft); }
[data-theme="vapor"] .marquee { background: #0e0620; color: var(--rose); border-top: 1px solid var(--rose); border-bottom: 1px solid var(--sand); }
[data-theme="vapor"] .marquee-track span:nth-child(even) { color: var(--sand); }
[data-theme="vapor"] .service-card, [data-theme="vapor"] .value-card, [data-theme="vapor"] .journal-card,
[data-theme="vapor"] .info-card, [data-theme="vapor"] .contact-form, [data-theme="vapor"] .author-box {
  background: rgba(36,16,67,0.7); border: 1px solid var(--sand); box-shadow: 0 0 22px rgba(45,226,230,0.18);
}
[data-theme="vapor"] .service-card:hover, [data-theme="vapor"] .value-card:hover, [data-theme="vapor"] .journal-card:hover {
  box-shadow: 0 0 32px rgba(255,54,171,0.5); border-color: var(--rose);
}
[data-theme="vapor"] .service-num { background: var(--rose); color: #fff; box-shadow: 0 0 14px rgba(255,54,171,0.6); }
[data-theme="vapor"] .service-card ul li { background: rgba(45,226,230,0.12); border: 1px solid var(--sand); color: var(--plum); }
[data-theme="vapor"] .btn-primary { background: var(--rose); color: #fff; box-shadow: 0 0 20px rgba(255,54,171,0.5); }
[data-theme="vapor"] .btn-ghost { border-color: var(--sand); color: var(--sand); }
[data-theme="vapor"] .btn-ghost:hover { background: var(--sand); color: #160a2b; }
[data-theme="vapor"] .philosophy { background: #0e0620; color: var(--plum); }
[data-theme="vapor"] .philosophy .quote-mark, [data-theme="vapor"] .philosophy cite { color: var(--sand); }
[data-theme="vapor"] .cta-band { background: radial-gradient(circle at 50% 0%, #ff36ab, #2a0f47 70%); }
[data-theme="vapor"] .page-hero {
  background:
    repeating-linear-gradient(90deg, transparent 0 40px, rgba(45,226,230,0.14) 40px 41px),
    radial-gradient(circle at 50% 18%, #ff36ab, #b537f2 40%, #160a2b 75%);
}
[data-theme="vapor"] .page-hero::after { background: radial-gradient(circle, #ffd23f, #ff36ab 70%); border: none; }
[data-theme="vapor"] .gallery-grid .g-item, [data-theme="vapor"] .journal-img, [data-theme="vapor"] .post-cover {
  box-shadow: 0 0 20px rgba(45,226,230,0.2);
}
[data-theme="vapor"] .step .step-num { background: var(--rose); color: #fff; box-shadow: 0 0 16px rgba(255,54,171,0.5); }
[data-theme="vapor"] .timeline-item::before { background: var(--sand); box-shadow: 0 0 12px rgba(45,226,230,0.7); }
[data-theme="vapor"] .timeline::before { background: linear-gradient(var(--rose), var(--sand)); }
[data-theme="vapor"] .footer { background: #0e0620; border-top: 1px solid var(--rose); }
[data-theme="vapor"] .field input, [data-theme="vapor"] .field select, [data-theme="vapor"] .field textarea {
  background: rgba(45,226,230,0.08); border: 1px solid var(--sand); color: var(--plum);
}
[data-theme="vapor"] .field input:focus, [data-theme="vapor"] .field select:focus, [data-theme="vapor"] .field textarea:focus {
  border-color: var(--rose); box-shadow: 0 0 0 3px rgba(255,54,171,0.2);
}
[data-theme="vapor"] .contact-socials a, [data-theme="vapor"] .cat-filter button { border-color: var(--sand); color: var(--plum); }
[data-theme="vapor"] .map-embed iframe { filter: grayscale(0.3) invert(0.9) hue-rotate(180deg) contrast(0.9); }

/* ============================================
   ART DECO THEME  [data-theme="deco"]
   gold / deep emerald / cream, geometric
   ============================================ */
[data-theme="deco"] {
  --ivory: #f3eee0;
  --cream: #faf6ea;
  --sand: #c9a227;
  --plum: #0f3d3e;
  --plum-soft: #2c5253;
  --rose: #c9a227;
  --rose-deep: #a8851a;
  --gold: #0f3d3e;
  --muted: #7c7458;
  --line: rgba(201,162,39,0.4);
  --white: #fbf8ef;
  --radius: 2px;
}
[data-theme="deco"] body { background: var(--ivory); }
[data-theme="deco"] h1, [data-theme="deco"] h2, [data-theme="deco"] h3,
[data-theme="deco"] .brand-text strong {
  font-family: "Cinzel", Georgia, serif; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.06em;
}
[data-theme="deco"] h1 em, [data-theme="deco"] h2 em { color: var(--rose); font-style: normal; }
[data-theme="deco"] .eyebrow { color: var(--rose-deep); }
[data-theme="deco"] .btn { border-radius: 2px; }
[data-theme="deco"] .btn-primary { background: var(--plum); color: var(--sand); border: 1px solid var(--sand); }
[data-theme="deco"] .btn-ghost { border-color: var(--rose); color: var(--plum); }
[data-theme="deco"] .btn-ghost:hover { background: var(--plum); color: var(--sand); }
[data-theme="deco"] .topbar { background: #0f3d3e; color: var(--sand); border-bottom: 1px solid var(--sand); }
[data-theme="deco"] .header { background: var(--cream); border-bottom: 1px solid var(--sand); box-shadow: inset 0 -4px 0 rgba(201,162,39,0.25); }
[data-theme="deco"] .brand-mark { background: var(--plum); color: var(--sand); border: 1px solid var(--sand); }
[data-theme="deco"] .nav-cta { background: var(--plum); color: var(--sand); border-radius: 2px; }
[data-theme="deco"] .nav a:not(.nav-cta)::after { background: var(--rose); }
[data-theme="deco"] .hero-bg {
  background:
    repeating-conic-gradient(from 0deg at 50% 0%, rgba(201,162,39,0.10) 0 3deg, transparent 3deg 9deg),
    linear-gradient(160deg, var(--cream), #ece3c8);
}
[data-theme="deco"] .hero-bg::after { background: transparent; border: 2px solid var(--rose); box-shadow: 0 0 0 8px rgba(201,162,39,0.12), inset 0 0 0 10px rgba(201,162,39,0.12); }
[data-theme="deco"] .hero-portrait { border: 3px solid var(--sand); border-radius: 4px; box-shadow: 0 0 0 8px var(--cream), 0 0 0 10px var(--sand); }
[data-theme="deco"] .hero-stats strong { color: var(--rose-deep); }
[data-theme="deco"] .marquee { background: #0f3d3e; color: var(--sand); border-top: 1px solid var(--sand); border-bottom: 1px solid var(--sand); }
[data-theme="deco"] .marquee-track { font-style: normal; font-family: "Cinzel", serif; text-transform: uppercase; }
[data-theme="deco"] .marquee-track span:nth-child(even) { color: #e9d28f; }
[data-theme="deco"] .service-card, [data-theme="deco"] .value-card, [data-theme="deco"] .journal-card,
[data-theme="deco"] .info-card, [data-theme="deco"] .contact-form {
  border: 1px solid var(--sand); border-radius: 2px; box-shadow: 0 0 0 4px rgba(201,162,39,0.08);
}
[data-theme="deco"] .service-num { background: var(--plum); color: var(--sand); border: 1px solid var(--sand); }
[data-theme="deco"] .service-card ul li { background: var(--cream); border: 1px solid var(--line); }
[data-theme="deco"] .philosophy { background: #0f3d3e; color: var(--cream); }
[data-theme="deco"] .philosophy .quote-mark, [data-theme="deco"] .philosophy cite { color: var(--sand); }
[data-theme="deco"] .cta-band { background: #0f3d3e; }
[data-theme="deco"] .cta-band .btn-primary { background: var(--sand); color: var(--plum); box-shadow: none; }
[data-theme="deco"] .page-hero {
  background:
    repeating-conic-gradient(from 0deg at 50% 0%, rgba(201,162,39,0.1) 0 3deg, transparent 3deg 9deg),
    linear-gradient(160deg, var(--cream), #ece3c8);
  border-bottom: 1px solid var(--sand);
}
[data-theme="deco"] .page-hero::after { background: transparent; border: 2px solid var(--rose); }
[data-theme="deco"] .step .step-num { background: var(--plum); color: var(--sand); border: 1px solid var(--sand); }
[data-theme="deco"] .timeline-item::before { background: var(--sand); box-shadow: 0 0 0 3px rgba(201,162,39,0.25); }
[data-theme="deco"] .timeline::before { background: var(--sand); }
[data-theme="deco"] .footer { background: #0c3132; border-top: 2px solid var(--sand); }
[data-theme="deco"] .footer-brand small { color: var(--sand); }
[data-theme="deco"] .field input:focus, [data-theme="deco"] .field select:focus,
[data-theme="deco"] .field textarea:focus { border-color: var(--rose); box-shadow: 0 0 0 3px rgba(201,162,39,0.18); }

/* ============================================
   FEMININE COMIC THEME  [data-theme="comic"]
   soft blush / rose / rose-gold / plum + comic accents:
   halftone, panel gutter lines, BOOM!/POW!/WOW! bursts, speech bubbles
   ============================================ */
[data-theme="comic"] {
  --ivory: #fff4f7;
  --cream: #ffffff;
  --sand: #f6d68a;       /* soft gold (bursts) */
  --plum: #3d1528;       /* deep plum (ink) */
  --plum-soft: #5e2440;
  --rose: #ec4e7f;       /* rose pink */
  --rose-deep: #d6356a;
  --gold: #c98a5e;       /* rose-gold / caramel */
  --muted: #8a6575;
  --line: #3d1528;
  --white: #ffffff;
  --radius: 14px;
  --ink: #3d1528;
  --c-lav: #c79ad6;      /* lavender */
  --c-berry: #8a2d5a;
}
[data-theme="comic"] body {
  background-color: var(--ivory);
  background-image: radial-gradient(rgba(61,21,40,0.10) 1.5px, transparent 1.6px);
  background-size: 16px 16px;
}

/* Elegant feminine headings; comic flair as accents */
[data-theme="comic"] h1, [data-theme="comic"] h2, [data-theme="comic"] h3 { color: var(--plum); }
[data-theme="comic"] h1 em, [data-theme="comic"] h2 em { color: var(--rose); font-style: italic; }
[data-theme="comic"] .marquee-track { font-family: "Bangers", cursive; font-style: normal; letter-spacing: 0.04em; }

/* Eyebrow = speech-bubble sticker */
[data-theme="comic"] .eyebrow {
  display: inline-block; background: var(--sand); color: var(--ink);
  border: 2px solid var(--ink); padding: 0.28rem 0.9rem; border-radius: 100px;
  box-shadow: 3px 3px 0 var(--ink); font-weight: 600;
}

/* Comic panel gutter lines between sections */
[data-theme="comic"] section:not(.hero):not(.page-hero) { border-top: 4px solid var(--ink); }

/* Action-word bursts (BOOM! / POW! / WOW!) */
[data-theme="comic"] .hero-inner,
[data-theme="comic"] .services .section-head,
[data-theme="comic"] .philosophy .philosophy-inner { position: relative; }
[data-theme="comic"] .hero-inner::after,
[data-theme="comic"] .services .section-head::after,
[data-theme="comic"] .philosophy .philosophy-inner::after {
  font-family: "Bangers", cursive;
  display: grid; place-items: center; text-align: center;
  width: 96px; height: 96px; font-size: 1.05rem; line-height: 1; letter-spacing: 0.03em;
  clip-path: polygon(50% 0%,60% 22%,84% 12%,76% 37%,100% 38%,82% 56%,96% 80%,68% 73%,62% 99%,50% 76%,38% 99%,32% 73%,4% 80%,18% 56%,0% 38%,24% 37%,16% 12%,40% 22%);
  filter: drop-shadow(3px 3px 0 var(--ink));
  position: absolute; z-index: 5; pointer-events: none;
}
[data-theme="comic"] .hero-inner::after { content: "BOOM!"; background: var(--sand); color: var(--ink); top: -14px; right: 2%; transform: rotate(-12deg); }
[data-theme="comic"] .services .section-head::after { content: "POW!"; background: var(--rose); color: #fff; top: -26px; right: 8%; transform: rotate(9deg); }
[data-theme="comic"] .philosophy .philosophy-inner::after { content: "WOW!"; background: var(--sand); color: var(--ink); top: -28px; left: 4%; transform: rotate(-10deg); }

/* Topbar + header */
[data-theme="comic"] .topbar { background: var(--ink); color: #ffe4ee; border-bottom: 3px solid var(--rose); }
[data-theme="comic"] .header { background: #ffe1ea; border-bottom: 4px solid var(--ink); backdrop-filter: none; }
[data-theme="comic"] .brand-mark { background: var(--rose); color: #fff; border: 3px solid var(--ink); box-shadow: 3px 3px 0 var(--ink); }
[data-theme="comic"] .brand-text small { color: var(--ink); }
[data-theme="comic"] .nav a:not(.nav-cta):hover, [data-theme="comic"] .nav a.active:not(.nav-cta) { color: var(--rose-deep); }
[data-theme="comic"] .nav a:not(.nav-cta)::after { background: var(--rose); height: 3px; }
[data-theme="comic"] .nav-cta { background: var(--rose); color: #fff; border: 2px solid var(--ink); box-shadow: 3px 3px 0 var(--ink); }
[data-theme="comic"] .nav-cta:hover { background: var(--rose-deep); }
[data-theme="comic"] .menu-toggle span { background: var(--ink); height: 3px; }

/* Buttons */
[data-theme="comic"] .btn { border: 3px solid var(--ink); border-radius: 10px; font-weight: 600; box-shadow: 5px 5px 0 var(--ink); }
[data-theme="comic"] .btn:hover { transform: translate(-2px,-2px); box-shadow: 7px 7px 0 var(--ink); }
[data-theme="comic"] .btn-primary { background: var(--rose); color: #fff; }
[data-theme="comic"] .btn-ghost { background: #fff; color: var(--ink); }
[data-theme="comic"] .btn-ghost:hover { background: var(--sand); }
[data-theme="comic"] .cta-band .btn-primary { background: #fff; color: var(--rose-deep); box-shadow: 5px 5px 0 var(--ink); }

/* Hero — blush halftone + gold starburst */
[data-theme="comic"] .hero-bg {
  background:
    radial-gradient(rgba(236,78,127,0.12) 2px, transparent 2.1px) 0 0/16px 16px,
    radial-gradient(ellipse 60% 70% at 78% 30%, rgba(246,214,138,0.55), transparent 60%),
    linear-gradient(160deg, #ffe3ec, #ffc8db);
}
[data-theme="comic"] .hero-bg::after {
  background: var(--sand); border: none; width: 380px; height: 380px; border-radius: 0; box-shadow: none;
  clip-path: polygon(50% 0%,60% 22%,84% 12%,76% 37%,100% 38%,82% 56%,96% 80%,68% 73%,62% 99%,50% 76%,38% 99%,32% 73%,4% 80%,18% 56%,0% 38%,24% 37%,16% 12%,40% 22%);
  filter: drop-shadow(6px 6px 0 var(--rose));
}
[data-theme="comic"] .hero-portrait { border: 4px solid var(--ink); border-radius: 14px; box-shadow: 12px 12px 0 var(--rose); }
[data-theme="comic"] .hero-stats strong { color: var(--rose-deep); }

/* Marquee */
[data-theme="comic"] .marquee { background: var(--rose); color: #fff; border-top: 4px solid var(--ink); border-bottom: 4px solid var(--ink); }
[data-theme="comic"] .marquee-track { font-size: 1.6rem; }
[data-theme="comic"] .marquee-track span:nth-child(even) { color: var(--sand); }

/* Cards = soft comic panels */
[data-theme="comic"] .service-card, [data-theme="comic"] .value-card, [data-theme="comic"] .journal-card,
[data-theme="comic"] .info-card, [data-theme="comic"] .contact-form, [data-theme="comic"] .about-photo,
[data-theme="comic"] .split-media, [data-theme="comic"] .svc-detail-media, [data-theme="comic"] .map-embed,
[data-theme="comic"] .author-box, [data-theme="comic"] .post-cover {
  border: 3px solid var(--ink) !important; box-shadow: 8px 8px 0 var(--ink) !important; border-radius: 14px;
}
[data-theme="comic"] .service-card:hover, [data-theme="comic"] .value-card:hover, [data-theme="comic"] .journal-card:hover {
  transform: translate(-4px,-4px); box-shadow: 12px 12px 0 var(--rose) !important;
}
[data-theme="comic"] .service-img { border-bottom: 3px solid var(--ink); }
[data-theme="comic"] .service-num { color: #fff; border: 2px solid var(--ink); backdrop-filter: none; }
[data-theme="comic"] .service-grid .service-card:nth-child(1) .service-num { background: var(--rose); }
[data-theme="comic"] .service-grid .service-card:nth-child(2) .service-num { background: var(--gold); }
[data-theme="comic"] .service-grid .service-card:nth-child(3) .service-num { background: var(--c-lav); }
[data-theme="comic"] .service-card ul li { background: #ffe9f0; border: 2px solid var(--ink); font-weight: 500; }
[data-theme="comic"] .value-card .v-icon { color: var(--rose); }

/* Decorative tiles in soft comic colors */
[data-theme="comic"] .img-1, [data-theme="comic"] .g-1, [data-theme="comic"] .tile-a { background: var(--rose) !important; }
[data-theme="comic"] .img-2, [data-theme="comic"] .g-2, [data-theme="comic"] .tile-b { background: var(--gold) !important; }
[data-theme="comic"] .img-3, [data-theme="comic"] .g-3, [data-theme="comic"] .tile-c { background: var(--c-lav) !important; }
[data-theme="comic"] .g-4 { background: var(--sand) !important; }
[data-theme="comic"] .g-5 { background: var(--c-berry) !important; }
[data-theme="comic"] .journal-img { border-bottom: 3px solid var(--ink); }
[data-theme="comic"] .gallery-grid .g-item, [data-theme="comic"] .clinic-gallery .gallery-tile { border: 3px solid var(--ink); }

/* Bands */
[data-theme="comic"] .philosophy { background: #ffe1ea; color: var(--plum); }
[data-theme="comic"] .philosophy blockquote { font-style: italic; }
[data-theme="comic"] .philosophy .quote-mark, [data-theme="comic"] .philosophy cite { color: var(--rose); }
[data-theme="comic"] .cta-band { background: var(--rose); color: #fff; }
[data-theme="comic"] .cta-band p { color: #fff; }

/* Page hero */
[data-theme="comic"] .page-hero {
  background:
    radial-gradient(rgba(236,78,127,0.12) 2px, transparent 2.1px) 0 0/16px 16px,
    radial-gradient(ellipse 70% 80% at 50% 0%, rgba(246,214,138,0.5), transparent 60%),
    linear-gradient(160deg, #ffe3ec, #ffc8db);
  border-bottom: 4px solid var(--ink);
}
[data-theme="comic"] .page-hero::after {
  background: var(--sand); border: none; border-radius: 0;
  bottom: -220px; z-index: 0; opacity: 0.85;
  clip-path: polygon(50% 0%,60% 22%,84% 12%,76% 37%,100% 38%,82% 56%,96% 80%,68% 73%,62% 99%,50% 76%,38% 99%,32% 73%,4% 80%,18% 56%,0% 38%,24% 37%,16% 12%,40% 22%);
}
/* Hero metnini yıldızın önünde tut (yazıların üstüne binmesin) */
[data-theme="comic"] .page-hero > * { position: relative; z-index: 1; }
[data-theme="comic"] .post-meta .tag { background: var(--sand); border: 2px solid var(--ink); color: var(--ink); }

/* Process / timeline / faq / misc */
[data-theme="comic"] .step .step-num { background: var(--rose); color: #fff; border: 3px solid var(--ink); box-shadow: 4px 4px 0 var(--ink); }
[data-theme="comic"] .timeline-item::before { background: var(--rose); border: 2px solid var(--ink); box-shadow: none; }
[data-theme="comic"] .timeline::before { background: var(--ink); }
[data-theme="comic"] .faq-item { border-bottom: 3px solid var(--ink); }
[data-theme="comic"] .faq-q::after { color: var(--rose); }
[data-theme="comic"] .cat-filter button { border: 2px solid var(--ink); box-shadow: 3px 3px 0 var(--ink); font-weight: 600; }
[data-theme="comic"] .cat-filter button.active, [data-theme="comic"] .cat-filter button:hover { background: var(--rose); color: #fff; }
[data-theme="comic"] .link-arrow { color: var(--rose-deep); font-weight: 600; }
[data-theme="comic"] .prose blockquote { border-left: 4px solid var(--rose); }

/* Footer + inputs */
[data-theme="comic"] .footer { background: var(--ink); border-top: 4px solid var(--rose); }
[data-theme="comic"] .footer-brand small { color: var(--sand); }
[data-theme="comic"] .footer-nav a:hover { color: var(--sand); }
[data-theme="comic"] .field input, [data-theme="comic"] .field select, [data-theme="comic"] .field textarea { border: 2px solid var(--ink); border-radius: 8px; background: #fff; }
[data-theme="comic"] .field input:focus, [data-theme="comic"] .field select:focus, [data-theme="comic"] .field textarea:focus { border-color: var(--rose); box-shadow: 4px 4px 0 var(--rose); }
[data-theme="comic"] .wa-float { border: 3px solid var(--ink); box-shadow: 5px 5px 0 var(--ink); }

/* ============================================
   NEW COMPONENTS (theme-adaptive via tokens)
   trust strip · counters · before/after · testimonials ·
   packages · appointment extras
   ============================================ */

/* Trust strip */
.trust-strip {
  border-top: 1px solid var(--line); border-bottom: 1px solid var(--line);
  background: var(--cream);
}
.trust-inner {
  max-width: var(--maxw); margin: 0 auto; padding: 1.6rem 2.5rem;
  display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 1rem 2.4rem;
}
.trust-badge { display: flex; align-items: center; gap: 0.6rem; font-size: 0.9rem; color: var(--plum-soft); }
.trust-badge b { font-family: var(--serif); font-size: 1.05rem; color: var(--plum); font-weight: 600; }
.trust-badge .tb-icon { color: var(--rose-deep); font-size: 1.1rem; }
.trust-badge .tb-logo { height: 38px; width: auto; max-width: 130px; object-fit: contain; display: block; }
.trust-sep { width: 1px; height: 28px; background: var(--line); }

/* Counters band */
.counters { background: var(--plum); color: var(--cream); }
.counters-grid { max-width: 920px; margin: 0 auto; display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; text-align: center; }
.counter .num { font-family: var(--serif); font-size: clamp(2.4rem, 5vw, 3.4rem); font-weight: 600; color: var(--gold); line-height: 1; }
.counter .num span { font-size: 0.6em; }
.counter .lbl { display: block; margin-top: 0.5rem; font-size: 0.82rem; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(236,226,214,0.85); }

/* Before / After */
.ba-tools { max-width: var(--maxw); margin: 0 auto 2rem; display: flex; justify-content: center; gap: 1rem; align-items: center; }
.ba-toggle { display: inline-flex; align-items: center; gap: 0.5rem; cursor: pointer; font-size: 0.85rem; letter-spacing: 0.06em; text-transform: uppercase; color: var(--plum-soft); }
.ba-toggle input { width: 18px; height: 18px; accent-color: var(--rose-deep); cursor: pointer; }
.ba-grid { max-width: var(--maxw); margin: 0 auto; display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.6rem; }
.ba-card { border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; background: var(--white); transition: transform 0.4s var(--ease); }
.ba-card:hover { transform: translateY(-6px); box-shadow: 0 24px 44px rgba(46,35,41,0.12); }
.ba-pair { display: grid; grid-template-columns: 1fr 1fr; height: 240px; position: relative; }
.ba-half { position: relative; background-size: cover; background-position: center; display: flex; align-items: flex-end; }
.ba-half.before { background: linear-gradient(160deg, #cdbfb0, #a98f78); }
.ba-half.after { background: linear-gradient(160deg, var(--sand), var(--rose)); }
.ba-tag { position: absolute; top: 10px; font-size: 0.66rem; letter-spacing: 0.12em; text-transform: uppercase; background: rgba(46,35,41,0.82); color: #fff; padding: 0.25rem 0.7rem; border-radius: 100px; }
.ba-half.before .ba-tag { left: 10px; }
.ba-half.after .ba-tag { right: 10px; background: var(--rose-deep); }
.ba-pair.blurred .ba-half { filter: blur(9px); }
.ba-body { padding: 1.2rem 1.4rem; }
.ba-body h3 { font-size: 1.25rem; }
.ba-body span { font-size: 0.82rem; color: var(--muted); }
.ba-note { max-width: 760px; margin: 0 auto 2.5rem; text-align: center; color: var(--muted); font-size: 0.9rem; }

/* Testimonials */
.testimonials { background: var(--cream); }
.tlist { max-width: var(--maxw); margin: 0 auto; display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.6rem; }
.tcard { background: var(--white); border: 1px solid var(--line); border-radius: var(--radius); padding: 2rem; position: relative; }
.tcard .stars { color: var(--gold); letter-spacing: 0.15em; margin-bottom: 0.8rem; }
.tcard p { color: var(--plum-soft); font-style: italic; font-family: var(--serif); font-size: 1.15rem; line-height: 1.45; margin-bottom: 1.2rem; }
.tcard .who { display: flex; align-items: center; gap: 0.7rem; }
.tcard .avatar { width: 40px; height: 40px; border-radius: 50%; background: var(--sand); display: grid; place-items: center; font-family: var(--serif); color: var(--plum); font-weight: 600; }
.tcard .who b { font-size: 0.92rem; }
.tcard .who span { display: block; font-size: 0.78rem; color: var(--muted); }
.t-rating { max-width: var(--maxw); margin: 2.5rem auto 0; text-align: center; font-size: 0.9rem; color: var(--plum-soft); }
.t-rating b { color: var(--gold); font-size: 1.1rem; }
.t-rating a { color: inherit; transition: color 0.3s; }
.t-rating a:hover { color: var(--rose-deep); }
.t-rating a span { transition: transform 0.3s; display: inline-block; }
.t-rating a:hover span { transform: translateX(3px); }

/* Packages (health tourism) */
.pkg-grid { max-width: var(--maxw); margin: 0 auto; display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.4rem; }
.pkg-card { background: var(--white); border: 1px solid var(--line); border-radius: var(--radius); padding: 2rem 1.6rem; text-align: center; transition: transform 0.4s var(--ease); }
.pkg-card:hover { transform: translateY(-6px); box-shadow: 0 20px 40px rgba(46,35,41,0.1); }
.pkg-card .pkg-icon { font-size: 1.9rem; margin-bottom: 0.7rem; }
.pkg-card h4 { font-size: 1.2rem; margin-bottom: 0.4rem; }
.pkg-card p { font-size: 0.9rem; color: var(--plum-soft); }
.lang-banner { max-width: var(--maxw); margin: 2.5rem auto 0; text-align: center; display: flex; gap: 0.8rem; justify-content: center; flex-wrap: wrap; }
.lang-banner span { border: 1px solid var(--line); border-radius: 100px; padding: 0.4rem 1.1rem; font-size: 0.82rem; letter-spacing: 0.08em; }

/* Appointment extras */
.appt-hint { font-size: 0.82rem; color: var(--muted); margin-top: 0.4rem; }
.field input[type="file"] { padding: 0.6rem; background: var(--cream); cursor: pointer; }
.field input[type="date"], .field input[type="time"] { cursor: pointer; }

@media (max-width: 980px) {
  .ba-grid, .tlist { grid-template-columns: 1fr 1fr; }
  .counters-grid, .pkg-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 760px) {
  .ba-grid, .tlist, .counters-grid, .pkg-grid { grid-template-columns: 1fr; }
  .trust-sep { display: none; }
}

/* ============================================
   COOKIE CONSENT + FOOTER LEGAL (theme-adaptive)
   ============================================ */
.cookie-banner {
  position: fixed; left: 1.2rem; right: 1.2rem; bottom: 1.2rem; z-index: 200;
  max-width: 760px; margin: 0 auto;
  background: var(--plum); color: var(--cream);
  border-radius: var(--radius); padding: 1.3rem 1.5rem;
  box-shadow: 0 20px 50px rgba(0,0,0,0.3);
  display: flex; align-items: center; gap: 1.2rem; flex-wrap: wrap;
  transform: translateY(150%); transition: transform 0.5s var(--ease);
}
.cookie-banner.show { transform: translateY(0); }
.cookie-banner p { flex: 1 1 300px; font-size: 0.88rem; line-height: 1.5; color: rgba(236,226,214,0.92); margin: 0; }
.cookie-banner p a { color: var(--gold); text-decoration: underline; }
.cookie-actions { display: flex; gap: 0.6rem; }
.cookie-actions button {
  font-family: var(--sans); font-size: 0.8rem; letter-spacing: 0.06em; text-transform: uppercase;
  padding: 0.6rem 1.2rem; border-radius: 100px; cursor: pointer; border: 1px solid var(--gold); transition: all 0.3s;
}
.cookie-actions .c-accept { background: var(--gold); color: var(--plum); }
.cookie-actions .c-accept:hover { filter: brightness(1.1); }
.cookie-actions .c-reject { background: transparent; color: var(--cream); }
.cookie-actions .c-reject:hover { background: rgba(255,255,255,0.12); }

.footer-legal { display: flex; gap: 1.2rem; flex-wrap: wrap; }
.footer-legal a { color: rgba(236,226,214,0.6); }
.footer-legal a:hover { color: var(--gold); }

/* ============================================
   İnteraktif Vücut Haritası (#bodymap)
   ============================================ */
.bodymap {
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 4rem 1.5rem;
}
.bm-layout {
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: 2.5rem;
  align-items: stretch;
  margin-top: 1.75rem;
}

/* --- Sahne --- */
.bm-stage {
  position: relative;
  background: radial-gradient(120% 80% at 50% 0%, var(--white) 0%, var(--sand) 95%);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 1.5rem 1rem 1.25rem;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.bm-gender {
  display: inline-flex;
  background: rgba(46, 35, 41, 0.06);
  border: 1px solid var(--line);
  border-radius: 100px;
  padding: 4px;
  margin-bottom: 0.5rem;
}
.bm-gender button {
  border: 0;
  background: transparent;
  padding: 0.55rem 1.4rem;
  border-radius: 100px;
  font-family: var(--sans);
  font-size: 0.8rem;
  letter-spacing: 0.04em;
  font-weight: 500;
  color: var(--muted);
  cursor: pointer;
  transition: all 0.3s var(--ease);
}
.bm-gender button.active {
  background: var(--white);
  color: var(--plum);
  box-shadow: 0 2px 10px rgba(46, 35, 41, 0.08);
}
.bm-figure-wrap { position: relative; width: 100%; display: grid; place-items: center; }
/* Hem silüet hem foto figür YÜKSEKLİKLE sınırlanır → kadın/erkek aynı ölçek + az scroll */
.bm-figure, .bm-photo { height: clamp(340px, 48vh, 460px); width: auto; max-width: 100%; touch-action: manipulation; }
.bm-sil { fill: var(--ivory); stroke: var(--rose); stroke-width: 2; stroke-linejoin: round; }
.bm-zone {
  fill: transparent;
  stroke: transparent;
  stroke-width: 2;
  cursor: pointer;
  transition: fill 0.25s var(--ease), stroke 0.25s var(--ease);
}
.bm-zone:hover, .bm-zone:focus-visible, .bm-zone.active {
  fill: rgba(176, 137, 104, 0.28);
  stroke: var(--rose-deep);
  outline: none;
}
.bm-tooltip {
  position: absolute;
  transform: translate(-50%, -100%);
  background: var(--plum);
  color: var(--cream);
  font-size: 0.72rem;
  letter-spacing: 0.04em;
  padding: 0.35rem 0.7rem;
  border-radius: 8px;
  white-space: nowrap;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.15s ease;
  z-index: 5;
}
.bm-tooltip.show { opacity: 1; }
.bm-tip {
  font-size: 0.78rem;
  color: var(--muted);
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-top: 0.75rem;
}
.bm-pulse {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--rose-deep);
  box-shadow: 0 0 0 0 rgba(154, 111, 77, 0.5);
  animation: bm-p 1.8s infinite;
}
@keyframes bm-p {
  0% { box-shadow: 0 0 0 0 rgba(154, 111, 77, 0.45); }
  70% { box-shadow: 0 0 0 11px rgba(154, 111, 77, 0); }
  100% { box-shadow: 0 0 0 0 rgba(154, 111, 77, 0); }
}

/* --- Panel --- */
.bm-panel {
  background: var(--cream);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 2rem 2rem 1.75rem;
  min-height: 420px;
}
.bm-eyebrow {
  font-family: var(--sans);
  text-transform: uppercase;
  letter-spacing: 0.22em;
  font-size: 0.68rem;
  font-weight: 500;
  color: var(--rose-deep);
  margin-bottom: 0.5rem;
}
.bm-h3 { font-family: var(--serif); font-size: 1.85rem; margin-bottom: 0.75rem; }
.bm-lead { color: var(--muted); font-size: 0.95rem; max-width: 42ch; margin-bottom: 1.5rem; }
.bm-chips { display: flex; flex-wrap: wrap; gap: 0.6rem; }
.bm-chip {
  border: 1px solid var(--line);
  background: var(--white);
  border-radius: 100px;
  padding: 0.55rem 1.1rem;
  font-family: var(--sans);
  font-size: 0.85rem;
  color: var(--plum);
  cursor: pointer;
  transition: all 0.25s var(--ease);
}
.bm-chip:hover, .bm-chip:focus-visible {
  border-color: var(--rose-deep);
  color: var(--rose-deep);
  transform: translateY(-1px);
  outline: none;
}
.bm-back {
  border: 0; background: none; cursor: pointer;
  color: var(--rose-deep);
  font-family: var(--sans);
  font-size: 0.82rem;
  font-weight: 500;
  padding: 0;
  margin-bottom: 1rem;
  display: inline-flex; align-items: center; gap: 0.35rem;
}
.bm-back:hover { color: var(--plum); }

/* İşlem kartları */
.bm-surglist { display: flex; flex-direction: column; gap: 0.7rem; }
.bm-surg {
  text-align: left;
  width: 100%;
  border: 1px solid var(--line);
  background: var(--white);
  border-radius: 14px;
  padding: 1rem 1.1rem;
  cursor: pointer;
  transition: all 0.25s var(--ease);
  display: flex; flex-direction: column; gap: 0.5rem;
  font-family: var(--sans);
}
.bm-surg:hover {
  border-color: var(--rose);
  transform: translateY(-2px);
  box-shadow: 0 12px 28px rgba(46, 35, 41, 0.07);
}
.bm-surg-top { display: flex; align-items: center; justify-content: space-between; gap: 0.6rem; }
.bm-surg-name { font-family: var(--serif); font-size: 1.1rem; color: var(--plum); }
.bm-surg-desc { font-size: 0.86rem; color: var(--muted); line-height: 1.5; }
.bm-tag {
  font-size: 0.62rem; font-weight: 600; letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 0.22rem 0.6rem; border-radius: 100px; color: var(--white);
  white-space: nowrap;
}
.bm-tag.est { background: var(--rose-deep); }
.bm-tag.fonk { background: #5f7d6a; }
.bm-tag.onar { background: #6a6f8c; }
.bm-chev { font-size: 0.78rem; color: var(--rose-deep); }

/* Detay */
.bm-facts {
  display: grid; grid-template-columns: 1fr 1fr; gap: 0.6rem;
  margin: 1.25rem 0;
}
.bm-fact {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 0.7rem 0.85rem;
  display: flex; flex-direction: column; gap: 0.2rem;
}
.bm-fact .k { font-size: 0.65rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--muted); }
.bm-fact .v { font-size: 0.95rem; font-weight: 500; color: var(--plum); }
.bm-det { font-size: 0.95rem; color: var(--plum-soft); line-height: 1.65; }
.bm-faqs { margin-top: 1.25rem; }
.bm-faq-h { font-family: var(--serif); font-size: 1.15rem; margin-bottom: 0.25rem; }
.bm-faq { border-top: 1px solid var(--line); padding: 0.8rem 0; }
.bm-faq summary { cursor: pointer; font-weight: 500; font-size: 0.92rem; list-style: none; }
.bm-faq summary::-webkit-details-marker { display: none; }
.bm-faq summary::before { content: "+ "; color: var(--rose-deep); }
.bm-faq[open] summary::before { content: "– "; }
.bm-faq p { margin-top: 0.5rem; font-size: 0.88rem; color: var(--muted); }
.bm-panel .btn { margin-top: 1.5rem; }
.bm-disclaim { font-size: 0.72rem; color: var(--muted); text-align: center; margin-top: 1rem; line-height: 1.5; }

@media (max-width: 860px) {
  .bodymap { padding: 4rem 1.25rem; }
  .bm-layout { grid-template-columns: 1fr; gap: 1.5rem; }
  .bm-panel { padding: 1.5rem 1.25rem; min-height: 0; }
  .bm-h3 { font-size: 1.5rem; }
  /* Mobilde figürü genişlikle ölçekle → bölgeler parmakla seçilebilir kalsın */
  .bm-figure, .bm-photo { height: auto; width: auto; max-width: 86vw; max-height: 60vh; }
  /* Minimum dokunma hedefi (WCAG 2.5.8) */
  .bm-hot { min-width: 44px; min-height: 44px; }
}

/* ============================================
   Vücut Haritası — temalı (çizgi film / ikon) görünümler
   Elegant (varsayılan) zarif kalır; data-theme'li modlar
   sitedeki kartoon ikon estetiğine uyarlanır.
   ============================================ */

/* --- Tüm temalı modlar: düz dolgulu, kalın konturlu "ikon" figür --- */
[data-theme] .bm-sil {
  fill: var(--sand);
  stroke: var(--plum);
  stroke-width: 5;
}
[data-theme] .bm-zone:hover,
[data-theme] .bm-zone:focus-visible,
[data-theme] .bm-zone.active {
  fill: var(--rose);
  fill-opacity: 0.5;
  stroke: var(--plum);
  stroke-width: 4;
}
[data-theme] .bm-stage { background: var(--cream); }
[data-theme] .bm-tag.fonk { background: var(--gold); color: var(--white); }
[data-theme] .bm-tag.onar { background: var(--plum-soft); color: var(--white); }
[data-theme] .bm-pulse { box-shadow: none; }

/* --- POP & COMIC: kalın siyah/ink kontur + sert offset gölge --- */
[data-theme="pop"] .bm-stage, [data-theme="pop"] .bm-panel,
[data-theme="comic"] .bm-stage, [data-theme="comic"] .bm-panel {
  border: 3px solid var(--plum);
  box-shadow: 8px 8px 0 var(--plum);
}
[data-theme="pop"] .bm-surg, [data-theme="pop"] .bm-fact, [data-theme="pop"] .bm-chip,
[data-theme="comic"] .bm-surg, [data-theme="comic"] .bm-fact, [data-theme="comic"] .bm-chip {
  border: 2px solid var(--plum);
  box-shadow: 3px 3px 0 var(--plum);
}
[data-theme="pop"] .bm-surg:hover,
[data-theme="comic"] .bm-surg:hover {
  transform: translate(-2px, -2px);
  box-shadow: 6px 6px 0 var(--rose);
}
[data-theme="pop"] .bm-chip:hover,
[data-theme="comic"] .bm-chip:hover {
  transform: translate(-1px, -1px);
  box-shadow: 4px 4px 0 var(--rose);
}
[data-theme="pop"] .bm-gender, [data-theme="comic"] .bm-gender {
  border: 2px solid var(--plum);
}
[data-theme="pop"] .bm-gender button.active,
[data-theme="comic"] .bm-gender button.active {
  box-shadow: 2px 2px 0 var(--plum);
}
[data-theme="pop"] .bm-surg-name, [data-theme="comic"] .bm-surg-name,
[data-theme="pop"] .bm-h3, [data-theme="comic"] .bm-h3 { color: var(--plum); }

/* --- VAPOR: koyu, neon kontur + glow --- */
[data-theme="vapor"] .bm-stage {
  background: rgba(36,16,67,0.6);
  border-color: var(--sand);
  box-shadow: 0 0 22px rgba(45,226,230,0.18);
}
[data-theme="vapor"] .bm-sil {
  fill: rgba(45,226,230,0.08);
  stroke: var(--rose);
  stroke-width: 3;
  filter: drop-shadow(0 0 6px rgba(255,54,171,0.6));
}
[data-theme="vapor"] .bm-zone:hover,
[data-theme="vapor"] .bm-zone:focus-visible,
[data-theme="vapor"] .bm-zone.active {
  fill: var(--gold);
  fill-opacity: 0.35;
  stroke: var(--sand);
}
[data-theme="vapor"] .bm-panel {
  background: rgba(36,16,67,0.7);
  border-color: var(--sand);
  box-shadow: 0 0 22px rgba(45,226,230,0.18);
}
[data-theme="vapor"] .bm-surg, [data-theme="vapor"] .bm-fact, [data-theme="vapor"] .bm-chip {
  background: rgba(36,16,67,0.6);
  border-color: var(--sand);
}
[data-theme="vapor"] .bm-surg:hover { border-color: var(--rose); box-shadow: 0 0 18px rgba(255,54,171,0.4); }

/* --- DECO: ince altın çerçeve, geometrik --- */
[data-theme="deco"] .bm-sil { stroke-width: 3; fill: var(--cream); stroke: var(--sand); }
[data-theme="deco"] .bm-stage, [data-theme="deco"] .bm-panel {
  border: 1px solid var(--sand);
  box-shadow: 0 0 0 4px rgba(201,162,39,0.08);
}
[data-theme="deco"] .bm-zone:hover,
[data-theme="deco"] .bm-zone:focus-visible,
[data-theme="deco"] .bm-zone.active { fill: var(--sand); fill-opacity: 0.3; stroke: var(--plum); }

/* ============================================
   Vücut Haritası — pop-art foto figür + hotspot (temalı modlar)
   ============================================ */
.bm-figure[hidden], .bm-photo-wrap[hidden] { display: none !important; }
.bm-photo-wrap { position: relative; width: fit-content; max-width: 100%; margin: 0 auto; }
.bm-photo { display: block; }
.bm-hotspots { position: absolute; inset: 0; }
.bm-hot {
  position: absolute;
  border: 0;
  margin: 0;
  padding: 0;
  background: transparent;
  border-radius: 50%;
  cursor: pointer;
  transition: background 0.2s var(--ease), box-shadow 0.2s var(--ease);
}
.bm-hot:hover,
.bm-hot:focus-visible,
.bm-hot.active {
  background: rgba(176, 137, 104, 0.32);
  box-shadow: 0 0 0 2px var(--rose-deep) inset;
  outline: none;
}

/* POP & COMIC: figür beyaz comic panelde, sert offset gölge */
[data-theme="pop"] .bm-figure-wrap,
[data-theme="comic"] .bm-figure-wrap {
  background: var(--white);
  border: 3px solid var(--plum);
  border-radius: 12px;
  box-shadow: 5px 5px 0 var(--plum);
  padding: 0.5rem;
}
[data-theme="vapor"] .bm-figure-wrap {
  background: rgba(36,16,67,0.5);
  border: 1px solid var(--sand);
  border-radius: 8px;
  box-shadow: 0 0 22px rgba(45,226,230,0.18);
  padding: 0.4rem;
}

/* ============================================
   Vücut Haritası — smooth panel & hotspot geçişleri
   ============================================ */
.bm-anim { animation: bm-fade-in 0.34s var(--ease) both; }
@keyframes bm-fade-in {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: none; }
}
.bm-hot, .bm-zone { transition: background 0.25s var(--ease), box-shadow 0.25s var(--ease), fill 0.25s var(--ease), stroke 0.25s var(--ease); }
.bm-surg, .bm-chip { transition: transform 0.2s var(--ease), box-shadow 0.2s var(--ease), border-color 0.2s var(--ease), background 0.2s var(--ease); }
@media (prefers-reduced-motion: reduce) {
  .bm-anim { animation: none; }
}

/* ============================================
   Vücut Haritası — tıklanabilirlik ipuçları (ping işaretçiler)
   ============================================ */
/* Foto hotspot: kalıcı STATİK nokta (::after) + halka (::before) yalnızca girişte atar */
.bm-hot::before,
.bm-hot::after {
  content: "";
  position: absolute;
  left: 50%; top: 50%;
  border-radius: 50%;
  transform: translate(-50%, -50%);
  pointer-events: none;
}
.bm-hot::before {
  width: 15px; height: 15px;
  border: 2px solid var(--rose-deep);
  opacity: 0;
}
.bm-hot::after {
  width: 10px; height: 10px;
  background: var(--rose-deep);
  border: 2px solid #fff;
  box-shadow: 0 1px 3px rgba(0,0,0,.3);
}
@keyframes bm-ping {
  0%   { transform: translate(-50%,-50%) scale(.5); opacity: .85; }
  80%  { transform: translate(-50%,-50%) scale(2.3); opacity: 0; }
  100% { opacity: 0; }
}
/* Giriş (figür belirince/değişince): halka 2 kez atar, sonra durur — nokta kalır */
.bm-intro .bm-hot::before { animation: bm-ping 2s ease-out 2; }
.bm-intro .bm-hot:nth-child(2)::before { animation-delay: .12s; }
.bm-intro .bm-hot:nth-child(3)::before { animation-delay: .24s; }
.bm-intro .bm-hot:nth-child(4)::before { animation-delay: .36s; }
.bm-intro .bm-hot:nth-child(5)::before { animation-delay: .48s; }
.bm-intro .bm-hot:nth-child(6)::before { animation-delay: .6s; }
.bm-intro .bm-hot:nth-child(7)::before { animation-delay: .72s; }
.bm-intro .bm-hot:nth-child(8)::before { animation-delay: .84s; }
/* hover/odak: nokta büyür+parlar; seçili: nokta kaybolur (bölge parlar) */
.bm-hot:hover::after, .bm-hot:focus-visible::after { width: 13px; height: 13px; box-shadow: 0 0 0 4px rgba(176,137,104,.3); }
.bm-hot.active::before, .bm-hot.active::after { opacity: 0; }

/* Silüet (elegant) zone işaretçileri — SVG: nokta statik, halka sadece girişte */
.bm-marker-ring { fill: none; stroke: var(--rose-deep); stroke-width: 2; pointer-events: none; opacity: 0; }
.bm-marker-dot  { fill: var(--rose-deep); stroke: #fff; stroke-width: 1.5; pointer-events: none; }
.bm-intro .bm-marker-ring { animation: bm-ping-svg 2s ease-out 2; }
@keyframes bm-ping-svg {
  0%   { r: 4px; opacity: .8; }
  80%  { r: 13px; opacity: 0; }
  100% { opacity: 0; }
}
.bm-zone.active + .bm-marker-ring { animation: none; opacity: 0; }
.bm-zone.active + .bm-marker-ring + .bm-marker-dot { opacity: 0; }

@media (prefers-reduced-motion: reduce) {
  .bm-intro .bm-hot::before, .bm-intro .bm-marker-ring { animation: none; }
}

/* ============================================
   Vücut Haritası — kategori ikonları (canlı siteden)
   ============================================ */
.bm-region-head { display: flex; align-items: center; gap: 0.9rem; margin-bottom: 1rem; }
.bm-region-head > div { min-width: 0; }
.bm-region-head .bm-eyebrow { margin-bottom: 0.2rem; }
.bm-region-head .bm-h3 { margin-bottom: 0; }
.bm-cat-icon {
  width: 56px; height: 56px;
  flex: 0 0 56px;
  object-fit: contain;
  border-radius: 12px;
}
.bm-chip { display: inline-flex; align-items: center; gap: 0.5rem; }
.bm-chip-icon { width: 22px; height: 22px; object-fit: contain; border-radius: 5px; }
[data-theme="pop"] .bm-cat-icon, [data-theme="comic"] .bm-cat-icon {
  border: 2px solid var(--plum); box-shadow: 2px 2px 0 var(--plum);
}

/* ============================================
   Navigasyon Mega Menü — "Operasyonlar"
   ============================================ */
.mega-wrap { position: relative; display: inline-flex; align-items: center; }
.mega-trigger {
  background: none; border: 0; cursor: pointer;
  font-family: var(--sans); font-size: 0.86rem; letter-spacing: 0.05em;
  color: var(--plum); display: inline-flex; align-items: center; gap: 0.3rem;
  padding: 0;
}
.mega-trigger:hover { color: var(--rose-deep); }
.mega-caret { font-size: 0.7rem; transition: transform 0.3s var(--ease); }
.mega-wrap.open .mega-caret { transform: rotate(180deg); }

.mega-menu {
  position: absolute;
  top: 100%;               /* tetikleyiciye bitişik — boşluk yok */
  left: 50%;
  transform: translateX(-50%);
  width: min(1060px, 96vw);
  padding-top: 16px;       /* şeffaf köprü: mouse boşlukta hover kaybetmez */
  opacity: 0; visibility: hidden; pointer-events: none;
  transition: opacity 0.22s var(--ease), visibility 0.22s;
  z-index: 200;
}
.mega-wrap:hover .mega-menu,
.mega-wrap.open .mega-menu {
  opacity: 1; visibility: visible; pointer-events: auto;
}
.mega-inner {
  display: grid; grid-template-columns: 1.5fr 1fr 1fr; gap: 1.6rem;
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: 0 30px 70px rgba(46, 35, 41, 0.18);
  padding: 1.8rem;
}
.mega-col h4 {
  font-family: var(--sans); font-size: 0.72rem; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--rose-deep);
  margin-bottom: 0.9rem; padding-bottom: 0.5rem; border-bottom: 1px solid var(--line);
}
.mega-cats { display: grid; gap: 0.4rem; }
.mega-cat {
  display: flex; align-items: center; gap: 0.7rem; padding: 0.45rem;
  border: 0; background: none; width: 100%; text-align: left; cursor: pointer;
  font-family: var(--sans); border-radius: 12px; transition: background 0.2s var(--ease);
}
.mega-cat > span { flex: 1 1 auto; min-width: 0; }
.mega-chev { font-style: normal; font-size: 1.2rem; color: var(--muted); transition: transform 0.2s var(--ease); }
.mega-cat:hover { background: var(--cream); }
.mega-cat:hover .mega-chev { transform: translateX(3px); color: var(--rose-deep); }

/* İkinci seviye: kategori alt operasyonları */
.mega-back {
  display: inline-flex; align-items: center; gap: 0.3rem;
  border: 0; background: none; cursor: pointer; padding: 0;
  font-family: var(--sans); font-size: 0.78rem; font-weight: 600;
  letter-spacing: 0.06em; color: var(--rose-deep); margin-bottom: 0.8rem;
}
.mega-back:hover { color: var(--plum); }
.mega-l2-title {
  font-family: var(--serif); font-size: 1.3rem; font-weight: 500;
  color: var(--plum); margin-bottom: 0.9rem;
}
.mega-ops { display: grid; grid-template-columns: repeat(auto-fill, minmax(195px, 1fr)); gap: 0.2rem 0.6rem; align-content: start; }
.mega-op { display: flex; align-items: center; gap: 0.7rem; padding: 0.45rem; border-radius: 12px; transition: background 0.2s var(--ease); }
.mega-op:hover { background: var(--cream); }
.mega-op img { width: 40px; height: 40px; flex: 0 0 40px; object-fit: contain; border-radius: 9px; }
.mega-op > span { font-family: var(--serif); font-size: 1.05rem; color: var(--plum); }
.mega-op-dot { width: 7px; height: 7px; flex: 0 0 7px; margin: 0 16px; border-radius: 50%; background: var(--rose); }
[data-theme="pop"] .mega-op img, [data-theme="comic"] .mega-op img { border: 2px solid var(--plum); }
.mega-cat img { width: 42px; height: 42px; flex: 0 0 42px; object-fit: contain; border-radius: 9px; }
.mega-cat b { display: block; font-family: var(--serif); font-size: 1.05rem; font-weight: 500; color: var(--plum); line-height: 1.2; }
.mega-cat small { display: block; font-size: 0.72rem; color: var(--muted); margin-top: 1px; }
.mega-links { display: grid; gap: 0.55rem; }
.mega-links a { font-size: 0.9rem; color: var(--plum-soft); transition: color 0.2s; }
.mega-links a:hover { color: var(--rose-deep); }
.mega-all { display: inline-block; margin-top: 1rem; font-size: 0.8rem; font-weight: 600; letter-spacing: 0.05em; color: var(--rose-deep); }

/* Pop/comic temalarında comic panel görünümü */
[data-theme="pop"] .mega-inner, [data-theme="comic"] .mega-inner { border: 3px solid var(--plum); box-shadow: 8px 8px 0 var(--plum); }

/* Mobil: mega menü açık navigasyon içinde dikey akar */
@media (max-width: 980px) {
  .mega-menu {
    position: static; transform: none; width: 100%;
    padding-top: 0; margin-top: 0.5rem;
    opacity: 1; visibility: visible; pointer-events: auto; display: none;
  }
  .mega-wrap.open .mega-menu { display: block; transform: none; }
  .mega-wrap:hover .mega-menu { transform: none; }
  .mega-wrap { display: block; width: 100%; }
  .mega-inner {
    grid-template-columns: 1fr; gap: 1.2rem;
    background: none; border: 0; border-top: 1px solid var(--line);
    border-radius: 0; box-shadow: none; padding: 1rem 0 0;
  }
}

/* Uzun operasyon/kategori listeleri panelde kaydırılsın (viewport taşmasın) */
.mega-cats, .mega-ops { max-height: 72vh; overflow-y: auto; overflow-x: hidden; padding-right: 4px; }
.mega-ops::-webkit-scrollbar, .mega-cats::-webkit-scrollbar { width: 6px; }
.mega-ops::-webkit-scrollbar-thumb, .mega-cats::-webkit-scrollbar-thumb { background: var(--line); border-radius: 100px; }

/* ============================================
   Operasyon detay sayfası
   ============================================ */
.op-layout { max-width: var(--maxw); margin: 0 auto; display: grid; grid-template-columns: 1.65fr 1fr; gap: 3.2rem; align-items: start; }
.op-layout .prose { max-width: none; margin: 0; }
.op-facts { position: sticky; top: 110px; background: var(--cream); border: 1px solid var(--line); border-radius: var(--radius); padding: 1.8rem; box-shadow: 0 18px 40px rgba(46,35,41,0.06); }
.op-facts h3 { font-size: 1.25rem; margin-bottom: 1.1rem; }
.op-facts .row { display: flex; justify-content: space-between; gap: 1rem; padding: 0.7rem 0; border-bottom: 1px solid var(--line); }
.op-facts .row:last-of-type { border-bottom: 0; }
.op-facts .k { color: var(--muted); font-size: 0.78rem; letter-spacing: 0.04em; text-transform: uppercase; }
.op-facts .v { font-weight: 500; text-align: right; }
.op-facts .btn { margin-top: 1.4rem; }
.op-note { font-size: 0.78rem; color: var(--muted); text-align: center; margin-top: 0.9rem; line-height: 1.5; }
@media (max-width: 980px) {
  .op-layout { grid-template-columns: 1fr; gap: 2rem; }
  .op-facts { position: static; order: -1; }
}

/* ============================================
   Operasyonlar/Hizmetler kataloğu (hizmetler.html)
   ============================================ */
.catalog { max-width: var(--maxw); margin: 0 auto; }
.cat-group { margin-bottom: 3rem; }
.cat-group:last-child { margin-bottom: 0; }
.cat-group-head { display: flex; align-items: center; gap: 0.9rem; margin-bottom: 1.3rem; padding-bottom: 0.9rem; border-bottom: 1px solid var(--line); }
.cat-group-head img { width: 52px; height: 52px; flex: 0 0 52px; object-fit: contain; border-radius: 11px; }
.cat-group-head .eyebrow { margin-bottom: 0.2rem; }
.cat-group-head h3 { font-size: 1.55rem; line-height: 1.1; }
.cat-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)); gap: 0.8rem; }
.cat-card { display: flex; align-items: center; gap: 0.9rem; padding: 0.75rem 1rem; background: var(--white); border: 1px solid var(--line); border-radius: 14px; transition: transform 0.25s var(--ease), box-shadow 0.25s var(--ease), border-color 0.25s var(--ease); }
.cat-card:hover { border-color: var(--rose); transform: translateY(-2px); box-shadow: 0 12px 28px rgba(46,35,41,0.08); }
.cat-card img { width: 48px; height: 48px; flex: 0 0 48px; object-fit: contain; border-radius: 9px; }
.cat-card span { font-family: var(--serif); font-size: 1.06rem; color: var(--plum); line-height: 1.2; }
.cat-more { margin-top: 1rem; font-size: 0.92rem; color: var(--muted); }
[data-theme="pop"] .cat-card img, [data-theme="comic"] .cat-card img { border: 2px solid var(--plum); }
@media (max-width: 600px) { .cat-grid { grid-template-columns: 1fr; } }

/* ============================================
   VINTAGE POP — [data-theme="vintagepop"]
   Hot-pink halftone romance comic: teal + yellow accents,
   thick black ink outlines, cream speech-bubble panels,
   bold condensed display type (Anton / Bangers).
   ============================================ */
[data-theme="vintagepop"] {
  --ivory: #fff1e6;       /* warm cream body */
  --cream: #fff8ef;
  --sand: #ffd23f;        /* splash yellow */
  --plum: #141014;        /* ink */
  --plum-soft: #3a2730;
  --rose: #f5447f;        /* hot pink */
  --rose-deep: #e11d6b;
  --gold: #25c4b8;        /* teal (third accent) */
  --muted: #7a5a66;
  --line: #141014;
  --white: #ffffff;
  --radius: 14px;
  --ink: #141014;
  --c-lav: #25c4b8;       /* teal */
  --c-berry: #009e93;     /* deep teal */
}
[data-theme="vintagepop"] body {
  background-color: var(--ivory);
  background-image: radial-gradient(rgba(245,68,127,0.16) 1.6px, transparent 1.7px);
  background-size: 15px 15px;
}

/* Bold condensed display type */
[data-theme="vintagepop"] h1, [data-theme="vintagepop"] h2, [data-theme="vintagepop"] h3 {
  font-family: "Anton", "Jost", sans-serif; text-transform: uppercase;
  letter-spacing: 0.012em; font-weight: 400; color: var(--ink); line-height: 1.05;
}
[data-theme="vintagepop"] h1 em, [data-theme="vintagepop"] h2 em { color: var(--rose); font-style: normal; }
[data-theme="vintagepop"] .marquee-track { font-family: "Bangers", cursive; font-style: normal; letter-spacing: 0.05em; }

/* Eyebrow = speech-bubble sticker */
[data-theme="vintagepop"] .eyebrow {
  display: inline-block; background: var(--sand); color: var(--ink);
  border: 2px solid var(--ink); padding: 0.28rem 0.9rem; border-radius: 100px;
  box-shadow: 3px 3px 0 var(--ink); font-weight: 600;
}

/* Comic panel gutter lines */
[data-theme="vintagepop"] section:not(.hero):not(.page-hero) { border-top: 4px solid var(--ink); }

/* Action-word bursts */
[data-theme="vintagepop"] .hero-inner,
[data-theme="vintagepop"] .services .section-head,
[data-theme="vintagepop"] .philosophy .philosophy-inner { position: relative; }
[data-theme="vintagepop"] .hero-inner::after,
[data-theme="vintagepop"] .services .section-head::after,
[data-theme="vintagepop"] .philosophy .philosophy-inner::after {
  font-family: "Bangers", cursive;
  display: grid; place-items: center; text-align: center;
  width: 96px; height: 96px; font-size: 1.15rem; line-height: 1; letter-spacing: 0.03em;
  clip-path: polygon(50% 0%,60% 22%,84% 12%,76% 37%,100% 38%,82% 56%,96% 80%,68% 73%,62% 99%,50% 76%,38% 99%,32% 73%,4% 80%,18% 56%,0% 38%,24% 37%,16% 12%,40% 22%);
  filter: drop-shadow(3px 3px 0 var(--ink));
  position: absolute; z-index: 5; pointer-events: none;
}
[data-theme="vintagepop"] .hero-inner::after { content: "WOW!"; background: var(--sand); color: var(--ink); top: -14px; right: 2%; transform: rotate(-12deg); }
[data-theme="vintagepop"] .services .section-head::after { content: "POW!"; background: var(--c-lav); color: #fff; top: -26px; right: 8%; transform: rotate(9deg); }
[data-theme="vintagepop"] .philosophy .philosophy-inner::after { content: "BAM!"; background: var(--rose); color: #fff; top: -28px; left: 4%; transform: rotate(-10deg); }

/* Topbar + header */
[data-theme="vintagepop"] .topbar { background: var(--ink); color: #ffe4ee; border-bottom: 3px solid var(--c-lav); }
[data-theme="vintagepop"] .header { background: #ffe1ea; border-bottom: 4px solid var(--ink); backdrop-filter: none; }
[data-theme="vintagepop"] .brand-mark { background: var(--rose); color: #fff; border: 3px solid var(--ink); box-shadow: 3px 3px 0 var(--ink); }
[data-theme="vintagepop"] .brand-text strong { font-family: "Anton", var(--serif); letter-spacing: 0.02em; }
[data-theme="vintagepop"] .brand-text small { color: var(--ink); }
[data-theme="vintagepop"] .nav a:not(.nav-cta):hover, [data-theme="vintagepop"] .nav a.active:not(.nav-cta) { color: var(--rose-deep); }
[data-theme="vintagepop"] .nav a:not(.nav-cta)::after { background: var(--c-lav); height: 3px; }
[data-theme="vintagepop"] .nav-cta { background: var(--rose); color: #fff; border: 2px solid var(--ink); box-shadow: 3px 3px 0 var(--ink); }
[data-theme="vintagepop"] .nav-cta:hover { background: var(--rose-deep); }
[data-theme="vintagepop"] .menu-toggle span { background: var(--ink); height: 3px; }

/* Buttons */
[data-theme="vintagepop"] .btn { border: 3px solid var(--ink); border-radius: 10px; font-weight: 600; box-shadow: 5px 5px 0 var(--ink); }
[data-theme="vintagepop"] .btn:hover { transform: translate(-2px,-2px); box-shadow: 7px 7px 0 var(--ink); }
[data-theme="vintagepop"] .btn-primary { background: var(--rose); color: #fff; }
[data-theme="vintagepop"] .btn-ghost { background: var(--c-lav); color: #fff; }
[data-theme="vintagepop"] .btn-ghost:hover { background: var(--c-berry); }
[data-theme="vintagepop"] .cta-band .btn-primary { background: var(--sand); color: var(--ink); box-shadow: 5px 5px 0 var(--ink); }

/* Hero — hot pink halftone + yellow starburst */
[data-theme="vintagepop"] .hero-bg {
  background:
    radial-gradient(rgba(20,16,20,0.10) 2px, transparent 2.1px) 0 0/16px 16px,
    radial-gradient(ellipse 60% 70% at 78% 30%, rgba(255,210,63,0.65), transparent 60%),
    linear-gradient(160deg, #f5447f, #e11d6b);
}
[data-theme="vintagepop"] .hero-bg::after {
  background: var(--sand); border: none; width: 380px; height: 380px; border-radius: 0; box-shadow: none;
  clip-path: polygon(50% 0%,60% 22%,84% 12%,76% 37%,100% 38%,82% 56%,96% 80%,68% 73%,62% 99%,50% 76%,38% 99%,32% 73%,4% 80%,18% 56%,0% 38%,24% 37%,16% 12%,40% 22%);
  filter: drop-shadow(6px 6px 0 var(--ink));
}
[data-theme="vintagepop"] .hero h1, [data-theme="vintagepop"] .hero .hero-sub, [data-theme="vintagepop"] .hero .eyebrow { color: #fff; }
[data-theme="vintagepop"] .hero h1 em { color: var(--sand); }
[data-theme="vintagepop"] .hero-portrait { border: 4px solid var(--ink); border-radius: 14px; box-shadow: 12px 12px 0 var(--c-lav); }
[data-theme="vintagepop"] .hero-stats strong { color: #fff; }
[data-theme="vintagepop"] .hero-stats span { color: rgba(255,255,255,0.85); }
[data-theme="vintagepop"] .scroll-cue span { border-color: #fff; }

/* Marquee */
[data-theme="vintagepop"] .marquee { background: var(--c-lav); color: #fff; border-top: 4px solid var(--ink); border-bottom: 4px solid var(--ink); }
[data-theme="vintagepop"] .marquee-track { font-size: 1.7rem; }
[data-theme="vintagepop"] .marquee-track span:nth-child(even) { color: var(--sand); }

/* Cards = comic panels */
[data-theme="vintagepop"] .service-card, [data-theme="vintagepop"] .value-card, [data-theme="vintagepop"] .journal-card,
[data-theme="vintagepop"] .info-card, [data-theme="vintagepop"] .contact-form, [data-theme="vintagepop"] .about-photo,
[data-theme="vintagepop"] .split-media, [data-theme="vintagepop"] .svc-detail-media, [data-theme="vintagepop"] .map-embed,
[data-theme="vintagepop"] .author-box, [data-theme="vintagepop"] .post-cover, [data-theme="vintagepop"] .cat-card {
  border: 3px solid var(--ink) !important; box-shadow: 8px 8px 0 var(--ink) !important; border-radius: 14px;
}
[data-theme="vintagepop"] .service-card:hover, [data-theme="vintagepop"] .value-card:hover, [data-theme="vintagepop"] .journal-card:hover {
  transform: translate(-4px,-4px); box-shadow: 12px 12px 0 var(--rose) !important;
}
[data-theme="vintagepop"] .service-img { border-bottom: 3px solid var(--ink); }
[data-theme="vintagepop"] .service-num { color: #fff; border: 2px solid var(--ink); backdrop-filter: none; }
[data-theme="vintagepop"] .service-grid .service-card:nth-child(1) .service-num { background: var(--rose); }
[data-theme="vintagepop"] .service-grid .service-card:nth-child(2) .service-num { background: var(--c-lav); }
[data-theme="vintagepop"] .service-grid .service-card:nth-child(3) .service-num { background: var(--sand); color: var(--ink); }
[data-theme="vintagepop"] .service-card ul li { background: #fff0f5; border: 2px solid var(--ink); font-weight: 500; }
[data-theme="vintagepop"] .value-card .v-icon { color: var(--rose); }

/* Decorative tiles */
[data-theme="vintagepop"] .img-1, [data-theme="vintagepop"] .g-1, [data-theme="vintagepop"] .tile-a { background: var(--rose) !important; }
[data-theme="vintagepop"] .img-2, [data-theme="vintagepop"] .g-2, [data-theme="vintagepop"] .tile-b { background: var(--c-lav) !important; }
[data-theme="vintagepop"] .img-3, [data-theme="vintagepop"] .g-3, [data-theme="vintagepop"] .tile-c { background: var(--sand) !important; }
[data-theme="vintagepop"] .g-4 { background: var(--c-berry) !important; }
[data-theme="vintagepop"] .g-5 { background: var(--rose-deep) !important; }
[data-theme="vintagepop"] .journal-img { border-bottom: 3px solid var(--ink); }
[data-theme="vintagepop"] .gallery-grid .g-item, [data-theme="vintagepop"] .clinic-gallery .gallery-tile { border: 3px solid var(--ink); }

/* Bands */
[data-theme="vintagepop"] .philosophy { background: var(--sand); color: var(--ink); }
[data-theme="vintagepop"] .philosophy blockquote { font-style: italic; }
[data-theme="vintagepop"] .philosophy .quote-mark, [data-theme="vintagepop"] .philosophy cite { color: var(--rose-deep); }
[data-theme="vintagepop"] .cta-band { background: var(--rose); color: #fff; }
[data-theme="vintagepop"] .cta-band p { color: #fff; }

/* Page hero */
[data-theme="vintagepop"] .page-hero {
  background:
    radial-gradient(rgba(20,16,20,0.10) 2px, transparent 2.1px) 0 0/16px 16px,
    radial-gradient(ellipse 70% 80% at 50% 0%, rgba(255,210,63,0.6), transparent 60%),
    linear-gradient(160deg, #f5447f, #e11d6b);
  border-bottom: 4px solid var(--ink);
}
[data-theme="vintagepop"] .page-hero h1, [data-theme="vintagepop"] .page-hero p, [data-theme="vintagepop"] .page-hero .eyebrow,
[data-theme="vintagepop"] .page-hero .breadcrumb, [data-theme="vintagepop"] .page-hero .breadcrumb a { color: #fff; }
[data-theme="vintagepop"] .page-hero h1 em { color: var(--sand); }
[data-theme="vintagepop"] .page-hero::after {
  background: var(--sand); border: none; border-radius: 0;
  bottom: -220px; z-index: 0; opacity: 0.85;
  clip-path: polygon(50% 0%,60% 22%,84% 12%,76% 37%,100% 38%,82% 56%,96% 80%,68% 73%,62% 99%,50% 76%,38% 99%,32% 73%,4% 80%,18% 56%,0% 38%,24% 37%,16% 12%,40% 22%);
}
[data-theme="vintagepop"] .page-hero > * { position: relative; z-index: 1; }
[data-theme="vintagepop"] .post-meta .tag { background: var(--sand); border: 2px solid var(--ink); color: var(--ink); }

/* Process / faq / misc */
[data-theme="vintagepop"] .step .step-num { background: var(--rose); color: #fff; border: 3px solid var(--ink); box-shadow: 4px 4px 0 var(--ink); }
[data-theme="vintagepop"] .timeline-item::before { background: var(--c-lav); border: 2px solid var(--ink); box-shadow: none; }
[data-theme="vintagepop"] .timeline::before { background: var(--ink); }
[data-theme="vintagepop"] .faq-item { border-bottom: 3px solid var(--ink); }
[data-theme="vintagepop"] .faq-q::after { color: var(--rose); }
[data-theme="vintagepop"] .cat-filter button { border: 2px solid var(--ink); box-shadow: 3px 3px 0 var(--ink); font-weight: 600; }
[data-theme="vintagepop"] .cat-filter button.active, [data-theme="vintagepop"] .cat-filter button:hover { background: var(--rose); color: #fff; }
[data-theme="vintagepop"] .link-arrow { color: var(--rose-deep); font-weight: 600; }
[data-theme="vintagepop"] .prose blockquote { border-left: 4px solid var(--rose); }

/* Trust strip + counters + testimonials accents */
[data-theme="vintagepop"] .trust-strip { background: var(--cream); border-top: 4px solid var(--ink); border-bottom: 4px solid var(--ink); }
[data-theme="vintagepop"] .counters { background: var(--c-lav); }
[data-theme="vintagepop"] .counters .num { color: #fff; }
[data-theme="vintagepop"] .counters .lbl { color: rgba(255,255,255,0.85); }
[data-theme="vintagepop"] .tcard { border: 3px solid var(--ink); box-shadow: 8px 8px 0 var(--ink); }
[data-theme="vintagepop"] .tcard .stars { color: var(--sand); -webkit-text-stroke: 1px var(--ink); }
[data-theme="vintagepop"] .t-rating b { color: var(--rose-deep); }

/* Footer + inputs + WhatsApp */
[data-theme="vintagepop"] .footer { background: var(--ink); border-top: 4px solid var(--c-lav); }
[data-theme="vintagepop"] .footer-brand small { color: var(--sand); }
[data-theme="vintagepop"] .footer-nav a:hover { color: var(--sand); }
[data-theme="vintagepop"] .footer-socials a:hover { background: var(--rose); color: #fff; border-color: var(--rose); }
[data-theme="vintagepop"] .field input, [data-theme="vintagepop"] .field select, [data-theme="vintagepop"] .field textarea { border: 2px solid var(--ink); border-radius: 8px; background: #fff; }
[data-theme="vintagepop"] .field input:focus, [data-theme="vintagepop"] .field select:focus, [data-theme="vintagepop"] .field textarea:focus { border-color: var(--rose); box-shadow: 4px 4px 0 var(--rose); }
[data-theme="vintagepop"] .wa-float { border: 3px solid var(--ink); box-shadow: 5px 5px 0 var(--ink); }

/* ============================================
   COMIC CHROME — "Kadınsı Çizgi Roman" header + hero slider
   (claude.ai/design handoff). Tüm kurallar .cmc altında scope'lu;
   yalnızca [data-theme="comic"] aktifken görünür. Genişliğe göre ölçeklenir.
   ============================================ */
.cmc{
  --pink:#EC4E7F; --pink-deep:#D6356A; --pink-bg:#FFC8DB; --pink-dot:rgba(236,78,127,0.10);
  --teal:#C79AD6; --berry:#8A2D5A; --yellow:#F6D68A; --rose-gold:#C98A5E;
  --cream:#FFFFFF; --c-ink:#3D1528; --plum-soft:#5E2440; --c-muted:#8A6575;
  position:relative; width:100%; overflow:hidden; display:none; font-family:'Jost',sans-serif;
}
[data-theme="comic"] .cmc{ display:block; }
[data-theme="comic"] .header, [data-theme="comic"] .hero{ display:none !important; }
.cmc *{ box-sizing:border-box; }
.cmc section{ padding:0 !important; margin:0 !important; border:0 !important; }
.cmc a{ text-decoration:none; }

.cmc-stage{
  width:1500px; height:910px; position:absolute; top:0; left:0; transform-origin:top left; overflow:hidden;
  background-color:var(--pink-bg);
  background-image:
    radial-gradient(circle at center, var(--pink-dot) 30%, transparent 31%),
    linear-gradient(160deg,#FFE3EC 0%,#FFC8DB 100%);
  background-size:16px 16px,100% 100%; background-repeat:repeat,no-repeat;
}
.cmc-stage::after{ content:""; position:absolute; inset:0; pointer-events:none; box-shadow:inset 0 0 120px rgba(138,45,90,.10); }
.cmc[data-mode="header"] .cmc-stage{ height:200px; }

.cmc .burst{ position:relative; background:var(--c-ink); }
.cmc .burst>.fill{ position:absolute; inset:7px; background:var(--cream); display:flex; align-items:center; justify-content:center; }

/* top nav */
.cmc .cmc-topnav{ position:absolute; top:0; left:0; width:100%; height:104px; z-index:40; }
.cmc .nav-teal{ position:absolute; top:0; left:300px; height:104px; right:0; background:var(--teal); clip-path:polygon(34px 0,100% 0,100% 100%,0 100%); }
.cmc .nav-black-right{ position:absolute; top:0; right:0; width:330px; height:104px; background:var(--c-ink); clip-path:polygon(60px 0,100% 0,100% 100%,0 100%); }
.cmc .randevu{ position:absolute; top:0; right:0; width:266px; height:104px; background:var(--pink); clip-path:polygon(46px 0,100% 0,100% 100%,0 100%); display:flex; align-items:center; justify-content:center; gap:12px; cursor:pointer; transition:background .15s; }
.cmc .randevu:hover{ background:var(--pink-deep); }
.cmc .randevu span{ font-weight:900; font-size:22px; letter-spacing:.04em; color:#fff; padding-left:24px; }
.cmc .randevu svg{ width:26px; height:26px; stroke:#fff; }
.cmc .navlinks{ position:absolute; top:0; left:340px; height:104px; right:300px; z-index:2; display:flex; align-items:center; gap:30px; padding-left:24px; }
.cmc .navlinks a{ font-weight:700; font-size:18px; letter-spacing:.03em; color:var(--c-ink); text-transform:uppercase; white-space:nowrap; transition:color .15s,transform .15s; }
.cmc .navlinks a:hover{ color:#fff; transform:translateY(-2px); }

/* logo blob */
.cmc .logo-blob{ position:absolute; top:0; left:0; width:360px; height:192px; background:var(--c-ink); z-index:42; clip-path:polygon(0 0,100% 0,100% 64%,86% 100%,0 100%); padding:16px 30px 0 34px; display:block; }
.cmc .logo-script{ font-family:'Kaushan Script',cursive; color:#fff; line-height:.82; }
.cmc .logo-script .dr{ display:block; font-size:27px; color:var(--cream); transform:rotate(-4deg); margin-left:4px; margin-bottom:2px; }
.cmc .logo-script .ya{ display:block; font-size:60px; color:var(--pink); text-shadow:2px 2px 0 #fff; }
.cmc .logo-script .ay{ display:block; font-size:54px; color:#fff; margin-left:58px; margin-top:-2px; }
.cmc .logo-sub{ margin-top:20px; font-weight:900; font-size:16px; letter-spacing:.08em; color:var(--teal); line-height:1.3; text-transform:uppercase; }

/* slider */
.cmc #cmcSlider{ position:absolute; top:104px; left:0; width:100%; height:806px; z-index:10; }
.cmc .slide{ position:absolute; inset:0; opacity:0; visibility:hidden; pointer-events:none; }
.cmc .slide.active{ opacity:1; visibility:visible; pointer-events:auto; }
.cmc .pop{ opacity:1; }
.cmc .slide.active .pop{ animation:cmcpopin .34s cubic-bezier(.2,1.5,.35,1) both; }
.cmc .slide.active .pop.d1{ animation-delay:0s; }
.cmc .slide.active .pop.d2{ animation-delay:.07s; }
.cmc .slide.active .pop.d3{ animation-delay:.13s; }
@keyframes cmcpopin{ from{scale:.9;} to{scale:1;} }
@media (prefers-reduced-motion:reduce){ .cmc .slide.active .pop{ animation:none; scale:1; } }

/* headline */
.cmc .headline{ position:absolute; left:78px; top:26px; width:680px; height:432px; transform:rotate(-2deg); }
.cmc .headline .fill{ flex-direction:column; text-align:center; padding:26px 40px; gap:6px; }
.cmc .h-l1{ font-family:'Cormorant Garamond',serif; font-weight:700; font-size:56px; color:var(--c-ink); letter-spacing:.005em; line-height:1.04; }
.cmc .h-l2{ font-family:'Cormorant Garamond',serif; font-weight:700; font-style:italic; font-size:100px; line-height:.96; color:var(--pink); -webkit-text-stroke:1.5px var(--c-ink); paint-order:stroke fill; text-shadow:3px 4px 0 rgba(61,21,40,.16); white-space:nowrap; }
.cmc .h-l3{ font-family:'Cormorant Garamond',serif; font-weight:700; font-size:72px; color:var(--c-ink); line-height:1.0; }
.cmc .slide[data-accent="teal"] .h-l2{ color:var(--berry); }

/* sub box */
.cmc .subbox{ position:absolute; left:56px; top:500px; width:344px; background:var(--yellow); border:4px solid var(--c-ink); padding:15px 20px; transform:rotate(-1.5deg); box-shadow:6px 7px 0 rgba(0,0,0,.25); z-index:8; }
.cmc .subbox p{ margin:0; font-family:'Jost',sans-serif; font-weight:700; font-size:22px; line-height:1.18; color:var(--c-ink); letter-spacing:.005em; text-transform:uppercase; }

/* portrait */
.cmc .portrait{ position:absolute; right:0; top:6px; width:600px; height:800px; overflow:hidden; border-left:6px solid var(--c-ink); border-bottom:6px solid var(--c-ink); box-shadow:-8px 0 0 rgba(0,0,0,.18); }
.cmc .portrait-img{ width:100%; height:100%; object-fit:cover; object-position:center; display:block; }

/* speech bubble */
.cmc .speech{ position:absolute; right:34px; top:34px; width:236px; height:182px; background:var(--cream); border:5px solid var(--c-ink); border-radius:50%; display:flex; align-items:center; justify-content:center; text-align:center; padding:18px 26px; transform:rotate(3deg); z-index:6; box-shadow:5px 6px 0 rgba(0,0,0,.2); }
.cmc .speech::after{ content:""; position:absolute; left:30px; bottom:-26px; width:0; height:0; border:18px solid transparent; border-top:34px solid var(--c-ink); transform:rotate(8deg); }
.cmc .speech::before{ content:""; position:absolute; left:38px; bottom:-12px; width:0; height:0; z-index:1; border:11px solid transparent; border-top:24px solid var(--cream); transform:rotate(8deg); }
.cmc .speech b{ position:relative; z-index:2; font-family:'Cormorant Garamond',serif; font-weight:700; font-style:italic; font-size:34px; line-height:.98; color:var(--c-ink); }

/* badge */
.cmc .badge{ position:absolute; left:856px; top:540px; width:206px; height:206px; z-index:25; transform:rotate(-6deg); }
.cmc .badge .fill{ background:var(--yellow); flex-direction:column; gap:0; }
.cmc .badge .n{ font-family:'Bangers',cursive; font-size:64px; color:var(--pink); -webkit-text-stroke:1.5px var(--c-ink); line-height:.82; letter-spacing:.02em; }
.cmc .badge .t{ font-family:'Jost',sans-serif; font-weight:800; font-size:19px; color:var(--c-ink); line-height:.98; text-align:center; text-transform:uppercase; }

/* stars */
.cmc .star{ position:absolute; background:var(--yellow); z-index:5; }
.cmc .star.s-out{ background:var(--c-ink); }

/* category row */
.cmc .cats{ position:absolute; left:40px; top:712px; width:812px; height:128px; z-index:20; display:flex; gap:12px; }
.cmc .cat{ flex:1; border:4px solid var(--c-ink); display:flex; align-items:center; gap:8px; padding:8px; cursor:pointer; transition:transform .15s; box-shadow:4px 5px 0 rgba(0,0,0,.25); }
.cmc .cat:hover{ transform:translateY(-4px); }
.cmc .cat:nth-child(1){ background:var(--teal); }
.cmc .cat:nth-child(2){ background:var(--pink); }
.cmc .cat:nth-child(3){ background:var(--yellow); }
.cmc .cat:nth-child(4){ background:var(--berry); }
.cmc .cat .thumb{ width:64px; height:100%; flex:none; border:2px solid var(--c-ink); background:#fff; overflow:hidden; display:flex; align-items:center; justify-content:center; }
.cmc .cat .thumb img{ width:100%; height:100%; object-fit:cover; object-position:center top; display:block; }
.cmc .cat .lbl{ font-family:'Jost',sans-serif; font-weight:800; font-size:18px; line-height:1; color:var(--c-ink); text-transform:uppercase; letter-spacing:.01em; }
.cmc .cat:nth-child(1) .lbl, .cmc .cat:nth-child(2) .lbl, .cmc .cat:nth-child(4) .lbl{ color:#fff; -webkit-text-stroke:1px var(--c-ink); }

/* controls */
.cmc .arrow{ position:absolute; top:50%; transform:translateY(-50%); width:64px; height:64px; border-radius:50%; background:var(--cream); border:5px solid var(--c-ink); z-index:60; cursor:pointer; display:flex; align-items:center; justify-content:center; box-shadow:4px 5px 0 rgba(0,0,0,.3); transition:transform .12s,background .15s; }
.cmc .arrow:hover{ background:var(--yellow); }
.cmc .arrow:active{ transform:translateY(-50%) scale(.92); }
.cmc .arrow svg{ width:30px; height:30px; stroke:var(--pink); stroke-width:4; fill:none; }
.cmc .arrow.prev{ left:18px; } .cmc .arrow.next{ right:18px; }
.cmc .dots{ position:absolute; left:50%; bottom:36px; transform:translateX(-50%); z-index:60; display:flex; gap:14px; align-items:center; }
.cmc .dot{ width:18px; height:18px; border-radius:50%; background:var(--cream); border:3px solid var(--c-ink); cursor:pointer; padding:0; transition:all .15s; }
.cmc .dot.on{ width:26px; height:26px; background:var(--pink); box-shadow:0 0 0 4px rgba(255,255,255,.5); }

/* transition flash */
.cmc .flash{ position:absolute; inset:0; z-index:55; display:flex; align-items:center; justify-content:center; pointer-events:none; opacity:0; }
.cmc .flash.go{ animation:cmcflashgo .42s ease-out; }
@keyframes cmcflashgo{ 0%{opacity:1;} 55%{opacity:1;} 100%{opacity:0;} }
.cmc .flash .word{ font-family:'Bangers',cursive; font-size:150px; color:var(--yellow); -webkit-text-stroke:6px var(--c-ink); text-shadow:8px 8px 0 var(--pink); transform:rotate(-8deg) scale(.4); }
.cmc .flash.go .word{ animation:cmcwordpop .42s cubic-bezier(.2,1.6,.4,1); }
@keyframes cmcwordpop{ 0%{transform:rotate(-8deg) scale(.3);} 60%{transform:rotate(-8deg) scale(1.15);} 100%{transform:rotate(-8deg) scale(1);} }

/* mobil: çok küçülmesin diye min ölçek koruması yok; genişliğe göre ölçeklenir */

/* ============================================
   COMPACT / COHESIVE override — hero'yu kısaltıp siteyle dengeler
   (1500×910 → 1500×640). Sonra geldiği için base değerleri ezer.
   ============================================ */
.cmc-stage{ height:640px; }
.cmc[data-mode="header"] .cmc-stage{ height:150px; }
/* iç sayfalarda (header-only) mega menü kısa stage'in dışına taşabilsin */
.cmc[data-mode="header"]{ overflow:visible; position:relative; z-index:60; }
.cmc[data-mode="header"] .cmc-stage{ overflow:visible; }

/* top nav — biraz daha ince */
.cmc .cmc-topnav, .cmc .nav-teal, .cmc .nav-black-right, .cmc .randevu, .cmc .navlinks{ height:88px; }
.cmc .navlinks{ left:330px; right:286px; gap:22px; padding-left:20px; }
.cmc .navlinks a{ font-size:15px; letter-spacing:.02em; }
.cmc .randevu{ width:250px; }
.cmc .randevu span{ font-size:18px; padding-left:18px; }
.cmc .randevu svg{ width:22px; height:22px; }
.cmc .nav-teal{ left:286px; }
.cmc .nav-black-right{ width:300px; }
/* Randevu butonu: çeviri uzunluğuna göre genişlesin, metin kırpılmasın
   (padding-left köşegen kesimi temizler; auto genişlik en uzun çeviride bile siyah slabın içinde kalır) */
.cmc .randevu{ width:auto; min-width:200px; max-width:300px; padding:0 24px 0 52px; gap:10px; justify-content:flex-start; }
.cmc .randevu span{ font-size:16px; letter-spacing:.02em; padding-left:0; white-space:nowrap; }

/* logo blob — daralt */
.cmc .logo-blob{ width:328px; height:150px; padding:12px 26px 0 30px; }
.cmc .logo-script .dr{ font-size:21px; margin-bottom:0; }
.cmc .logo-script .ya{ font-size:48px; }
.cmc .logo-script .ay{ font-size:42px; margin-left:46px; }
.cmc .logo-sub{ margin-top:12px; font-size:13px; }

/* slider alanı */
.cmc #cmcSlider{ top:88px; height:552px; }

/* headline */
.cmc .headline{ left:104px; top:88px; width:548px; height:240px; }
.cmc .headline .fill{ padding:14px 32px; gap:0; }
.cmc .h-l1{ font-size:40px; line-height:1.04; }
.cmc .h-l2{ font-size:74px; }
.cmc .h-l3{ font-size:50px; }

/* sub box — kategori satırının üstünde kalsın */
.cmc .subbox{ left:56px; top:332px; width:330px; padding:11px 18px; }
.cmc .subbox p{ font-size:17px; line-height:1.15; }

/* portrait — sahneye tam otursun (alttan kırpılmasın) */
.cmc .portrait{ top:2px; height:544px; width:540px; }

/* speech */
.cmc .speech{ right:28px; top:100px; width:190px; height:148px; padding:14px 20px; }
.cmc .speech b{ font-size:26px; }

/* badge */
.cmc .badge{ left:824px; top:300px; width:158px; height:158px; }
.cmc .badge .n{ font-size:48px; }
.cmc .badge .t{ font-size:15px; }

/* category row — ikincil hızlı kısayol şeridi (hero ile yarışmasın) */
.cmc .cats{ left:40px; top:510px; width:712px; height:82px; gap:10px; }
.cmc .cat{ padding:6px 7px; gap:7px; border-width:3px; box-shadow:3px 4px 0 rgba(0,0,0,.20); }
.cmc .cat .thumb{ width:38px; border-width:2px; }
.cmc .cat .lbl{ font-size:13px; line-height:1.14; letter-spacing:0; font-weight:800; }
/* okunaklılık: küçük puntoda harfleri dolduran stroke yerine net gölge */
.cmc .cat:nth-child(1) .lbl, .cmc .cat:nth-child(2) .lbl, .cmc .cat:nth-child(4) .lbl{ -webkit-text-stroke:0; text-shadow:0 1px 1.5px rgba(0,0,0,.5); }

/* controls */
.cmc .arrow{ width:52px; height:52px; border-width:4px; }
.cmc .arrow svg{ width:24px; height:24px; }
.cmc .arrow.prev{ left:14px; } .cmc .arrow.next{ right:14px; }
.cmc .dots{ bottom:16px; }
.cmc .flash .word{ font-size:120px; }

/* "Operasyonlar" mega menü — comic nav içinde (script.js enjekte eder) */
.cmc .navlinks .mega-wrap{ height:88px; display:inline-flex; align-items:center; }
.cmc .navlinks .mega-trigger{ font-family:'Jost',sans-serif; font-weight:700; font-size:15px; letter-spacing:.02em; text-transform:uppercase; color:var(--c-ink); gap:4px; transition:color .15s,transform .15s; }
.cmc .navlinks .mega-trigger:hover{ color:#fff; transform:translateY(-2px); }
.cmc .navlinks .mega-caret{ font-size:11px; }
/* menüyü genişlet + logodan başlat (sol/sağ boşluklar dengeli, geniş kolonlar) */
.cmc .navlinks .mega-wrap{ position:static; }
.cmc .mega-menu{ left:14px; right:auto; transform:none; width:1140px; padding-top:10px; }
/* compact sahneye sığsın diye yükseklik sınırı + iç kaydırma (taşma/kırpılma olmaz) */
.cmc .mega-inner{ max-height:540px; overflow-y:auto; padding:1.7rem 1.9rem; gap:1.9rem; }

/* font'ları comic ile uyumlu (hepsi Jost, tutarlı boyut) ve sığacak şekilde */
.cmc .mega-col h4{ font-size:12.5px; letter-spacing:.12em; margin-bottom:.9rem; padding-bottom:.55rem; }
.cmc .mega-cat b, .cmc .mega-op > span, .cmc .mega-links a{ font-family:'Jost',sans-serif; font-size:14px; font-weight:600; color:var(--c-ink); line-height:1.22; }
.cmc .mega-cat small{ font-size:11px; line-height:1.2; }
.cmc .mega-cat img, .cmc .mega-op img{ width:34px; height:34px; flex-basis:34px; }
.cmc .mega-cat, .cmc .mega-op{ gap:.6rem; padding:.45rem .5rem; }
.cmc .mega-l2-title{ font-family:'Jost',sans-serif; font-weight:700; font-size:17px; }
.cmc .mega-back{ font-size:12.5px; }
.cmc .mega-all{ font-size:12.5px; }
.cmc .mega-chev{ font-size:1rem; }
.cmc .mega-ops{ grid-template-columns:1fr; }

/* ============================================================
   Insider — gömülü etkileşim katmanı widget'ları
   (insider.js tarafından enjekte edilen öğeler)
   ============================================================ */

.ins-kicker{
  font-family:var(--sans); font-weight:600; font-size:11px;
  letter-spacing:.18em; text-transform:uppercase; color:var(--rose-deep);
  margin:0 0 .5rem;
}

/* --- Kişiye özel öneriler --- */
.ins-reco{
  max-width:var(--maxw); margin:0 auto; padding:4.5rem 1.5rem;
  text-align:center;
}
.ins-reco-head{ max-width:640px; margin:0 auto 2.25rem; }
.ins-reco-head h2{
  font-family:var(--serif); font-weight:500; font-size:clamp(1.8rem,4vw,2.6rem);
  color:var(--plum); margin:0 0 .6rem; line-height:1.12;
}
.ins-reco-lead{ color:var(--muted); font-size:1.02rem; margin:0; }
.ins-reco-grid{
  display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:1rem; margin:0 auto 2rem; max-width:920px;
}
.ins-reco-card{
  display:flex; flex-direction:column; align-items:flex-start; gap:.5rem;
  text-align:left; text-decoration:none;
  padding:1.5rem 1.4rem; border:1px solid var(--line); border-radius:var(--radius);
  background:var(--white); color:var(--plum);
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), border-color .35s var(--ease);
}
.ins-reco-card:hover{
  transform:translateY(-4px); border-color:var(--rose);
  box-shadow:0 18px 40px -22px rgba(46,35,41,.4);
}
.ins-reco-cat{
  font-family:var(--sans); font-size:11px; font-weight:600;
  letter-spacing:.12em; text-transform:uppercase; color:var(--rose-deep);
}
.ins-reco-card strong{
  font-family:var(--serif); font-weight:500; font-size:1.4rem; line-height:1.15;
}
.ins-reco-go{ font-family:var(--sans); font-size:.9rem; color:var(--muted); margin-top:.2rem; }
.ins-reco-card:hover .ins-reco-go{ color:var(--rose-deep); }

/* --- Exit-intent modal --- */
.ins-modal-ov{
  position:fixed; inset:0; z-index:9998;
  background:rgba(46,35,41,.55); backdrop-filter:blur(4px);
  display:flex; align-items:center; justify-content:center; padding:1.5rem;
  opacity:0; transition:opacity .25s var(--ease);
}
.ins-modal-ov.show{ opacity:1; }
.ins-modal{
  position:relative; background:var(--cream); border-radius:var(--radius);
  max-width:440px; width:100%; padding:2.5rem 2rem 2rem; text-align:center;
  box-shadow:0 40px 90px -30px rgba(46,35,41,.6);
  transform:translateY(16px) scale(.98); transition:transform .3s var(--ease);
}
.ins-modal-ov.show .ins-modal{ transform:none; }
.ins-modal h3{
  font-family:var(--serif); font-weight:500; font-size:1.9rem; color:var(--plum);
  margin:0 0 .6rem;
}
.ins-modal p{ color:var(--muted); font-size:1rem; margin:0 0 1.5rem; }
.ins-modal-actions{ display:flex; flex-direction:column; gap:.6rem; }
.ins-modal-x{
  position:absolute; top:.8rem; right:1rem; border:none; background:none;
  font-size:1.8rem; line-height:1; color:var(--muted); cursor:pointer;
}
.ins-modal-x:hover{ color:var(--plum); }

/* --- İnaktivite WhatsApp nudge --- */
.ins-nudge{
  position:fixed; left:1.2rem; bottom:1.2rem; z-index:9997;
  max-width:300px; background:var(--white); border:1px solid var(--line);
  border-radius:var(--radius); padding:1.2rem 1.3rem 1.3rem;
  box-shadow:0 24px 54px -26px rgba(46,35,41,.5);
  display:flex; flex-direction:column; gap:.5rem;
  transform:translateY(20px); opacity:0;
  transition:transform .4s var(--ease), opacity .4s var(--ease);
}
.ins-nudge.show{ transform:none; opacity:1; }
.ins-nudge strong{ font-family:var(--serif); font-size:1.3rem; color:var(--plum); }
.ins-nudge span{ font-size:.92rem; color:var(--muted); line-height:1.4; }
.ins-nudge .btn{ margin-top:.4rem; }
.ins-nudge-x{
  position:absolute; top:.5rem; right:.7rem; border:none; background:none;
  font-size:1.4rem; line-height:1; color:var(--muted); cursor:pointer;
}
.ins-nudge-x:hover{ color:var(--plum); }

@media (max-width:560px){
  .ins-nudge{ left:.8rem; right:.8rem; max-width:none; }
  .ins-reco{ padding:3.25rem 1.1rem; }
}

/* --- Push opt-in istemi --- */
.ins-push{
  position:fixed; right:1.2rem; bottom:1.2rem; z-index:9997;
  max-width:320px; background:var(--white); border:1px solid var(--line);
  border-radius:var(--radius); padding:1.3rem 1.4rem 1.4rem;
  box-shadow:0 24px 54px -26px rgba(46,35,41,.5);
  display:flex; flex-direction:column; gap:.5rem;
  transform:translateY(20px); opacity:0;
  transition:transform .4s var(--ease), opacity .4s var(--ease);
}
.ins-push.show{ transform:none; opacity:1; }
.ins-push strong{ font-family:var(--serif); font-size:1.35rem; color:var(--plum); }
.ins-push span{ font-size:.92rem; color:var(--muted); line-height:1.45; }
.ins-push-actions{ display:flex; gap:.5rem; margin-top:.5rem; }
.ins-push-actions .btn{ flex:1; padding:.6rem; font-size:.85rem; }
.ins-push-x{
  position:absolute; top:.5rem; right:.7rem; border:none; background:none;
  font-size:1.4rem; line-height:1; color:var(--muted); cursor:pointer;
}
.ins-push-x:hover{ color:var(--plum); }
@media (max-width:560px){ .ins-push{ left:.8rem; right:.8rem; max-width:none; } }

/* --- Inline insertion: operasyon kataloğu kişiselleştirme --- */
.cat-group.ins-promo{
  background:linear-gradient(180deg, rgba(201,168,124,.10), rgba(201,168,124,0));
  border:1px solid rgba(201,168,124,.35); border-radius:var(--radius);
  padding:1.5rem 1.4rem; margin-bottom:2.5rem;
}
.cat-group.ins-promo .cat-group-head{ border-bottom-color:rgba(201,168,124,.4); }
.cat-group.ins-promo .eyebrow{ color:var(--rose-deep); }

/* Ameliyat kartlarının arasına giren CTA kartı */
.cat-card.ins-cta-card{
  background:linear-gradient(135deg, var(--rose), var(--rose-deep));
  border-color:transparent; color:var(--white);
  justify-content:center; text-align:center; min-height:72px;
}
.cat-card.ins-cta-card:hover{ box-shadow:0 14px 32px -10px rgba(154,111,77,.6); border-color:transparent; }
.ins-cta-inner{ display:flex; flex-direction:column; align-items:center; gap:.1rem; line-height:1.25; }
.ins-cta-ico{ font-size:1.1rem; opacity:.9; }
.cat-card.ins-cta-card span{ font-size:.82rem; opacity:.92; }
.cat-card.ins-cta-card strong{ font-family:var(--serif); font-weight:600; font-size:1.18rem; }

/* --- Geri dönen ziyaretçi karşılama şeridi --- */
.ins-welcome{
  display:flex; align-items:center; justify-content:center; gap:1rem; flex-wrap:wrap;
  background:linear-gradient(90deg, var(--plum), var(--plum-soft));
  color:var(--ivory); padding:.7rem 1.2rem; position:relative;
  font-family:var(--sans); font-size:.95rem;
  max-height:0; overflow:hidden; opacity:0;
  transition:max-height .5s var(--ease), opacity .5s var(--ease), padding .5s var(--ease);
  padding-top:0; padding-bottom:0;
}
.ins-welcome.show{ max-height:120px; opacity:1; padding-top:.7rem; padding-bottom:.7rem; }
.ins-welcome .ins-welcome-cta{
  color:var(--gold); font-weight:600; text-decoration:none; white-space:nowrap;
}
.ins-welcome .ins-welcome-cta:hover{ text-decoration:underline; }
.ins-welcome-x{
  position:absolute; right:1rem; top:50%; transform:translateY(-50%);
  border:none; background:none; color:var(--ivory); opacity:.7;
  font-size:1.3rem; line-height:1; cursor:pointer;
}
.ins-welcome[dir="rtl"] .ins-welcome-x{ right:auto; left:1rem; }
.ins-welcome-x:hover{ opacity:1; }

/* --- Birlikte sık tercih edilenler --- */
.ins-related{ max-width:var(--maxw); margin:0 auto; padding:3.5rem 1.5rem; text-align:center; }
.ins-related-head{ margin-bottom:1.8rem; }
.ins-related-head h2{
  font-family:var(--serif); font-weight:500; font-size:clamp(1.6rem,3.5vw,2.2rem);
  color:var(--plum); margin:.3rem 0 0;
}
.ins-related .ins-reco-grid{ max-width:760px; }

/* ============================================
   i18n — Arapça (RTL) için yön düzeltmeleri
   html.i18n-rtl, i18n.js tarafından eklenir.
   ============================================ */
html.i18n-rtl { direction: rtl; }
html.i18n-rtl body { text-align: right; }
html.i18n-rtl .topbar-langs { margin-left: 0; margin-right: 1rem; }
/* Telefon numarası RTL'de ters görünmesin */
html.i18n-rtl .topbar a[href^="tel:"] { direction: ltr; unicode-bidi: embed; display: inline-block; }
html.i18n-rtl .wa-float { right: auto; left: 1.6rem; }
html.i18n-rtl .breadcrumb { direction: rtl; }
html.i18n-rtl .op-facts .row { flex-direction: row-reverse; }
html.i18n-rtl ul, html.i18n-rtl ol { padding-right: 1.2em; padding-left: 0; }
/* Çizgi roman sahnesi mutlak/ölçekli konumlu — yönü LTR kalsın (bozulmasın) */
html.i18n-rtl .cmc, html.i18n-rtl .cmc-stage { direction: ltr; }

/* ============================================================
   Mobil fallback — comic "poster" tema ≤760px'te okunamıyor/dokunulamıyordu
   (1500px sabit sahne scale ediliyordu). Mobilde ölçekli comic sahnesini
   gizleyip semantik, akışkan .header + .hero'yu göster. (UX düzeltmesi)
   ============================================================ */
@media (max-width: 760px) {
  [data-theme="comic"] .cmc { display: none !important; }
  [data-theme="comic"] .header { display: flex !important; }
  [data-theme="comic"] .hero { display: flex !important; }
}

/* --- Tema ipucu popup'ı (kafa karışıklığı → Zarif öner) --- */
.theme-hint{
  position:fixed; left:50%; bottom:1.4rem; transform:translate(-50%, 20px);
  z-index:9996; width:min(420px, calc(100vw - 2rem));
  background:var(--cream); border:1px solid var(--line); border-radius:var(--radius);
  padding:1.3rem 1.5rem 1.4rem; text-align:center;
  box-shadow:0 28px 60px -28px rgba(46,35,41,.55);
  opacity:0; transition:transform .35s var(--ease), opacity .35s var(--ease);
}
.theme-hint.show{ transform:translate(-50%, 0); opacity:1; }
.theme-hint strong{ display:block; font-family:var(--serif); font-weight:600; font-size:1.3rem; color:var(--plum); margin-bottom:.3rem; }
.theme-hint span{ display:block; font-size:.95rem; color:var(--muted); line-height:1.45; margin-bottom:1rem; }
.theme-hint span b{ color:var(--rose-deep); }
.theme-hint-actions{ display:flex; gap:.6rem; justify-content:center; }
.theme-hint-actions .btn{ padding:.6rem 1.1rem; font-size:.88rem; }
.theme-hint-x{
  position:absolute; top:.5rem; right:.7rem; border:none; background:none;
  font-size:1.5rem; line-height:1; color:var(--muted); cursor:pointer;
}
.theme-hint-x:hover{ color:var(--plum); }
@media (max-width:560px){ .theme-hint-actions{ flex-direction:column; } }
