/* ============================================================
   MO RAN SPA — Stylesheet part 2: sections & components
   ============================================================ */

/* ---------- HERO (editorial split — default) ---------- */
.hero{ position:relative; padding-top:118px; }
.hero-grid{
  display:grid; grid-template-columns:1fr; gap:40px; align-items:center;
  padding-bottom:clamp(48px,7vw,90px);
}
.hero-copy{ position:relative; z-index:2; }
.hero-eyebrow{ margin-bottom:20px; }
.hero h1{
  font-size:clamp(2.5rem,7.4vw,4.5rem);
  line-height:1.0; letter-spacing:-.012em; text-wrap:balance;
}
.hero h1 em{ font-style:italic; color:var(--accent); }
.tagline-ko{ font-family:var(--serif),"Noto Serif KR",serif; font-style:italic; font-size:clamp(1.15rem,3.4vw,1.5rem); color:var(--accent-2); margin:18px 0 4px; font-weight:500; }
.tagline-vi{ color:var(--stone); font-size:.98rem; letter-spacing:.01em; }
.hero-sub{ max-width:30em; color:var(--bark); opacity:.86; font-size:1.08rem; margin:22px 0 0; text-wrap:pretty; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:13px; margin-top:30px; }
.hero-trust{ display:flex; flex-wrap:wrap; gap:9px; margin-top:26px; }
.chip{
  display:inline-flex; align-items:center; gap:7px;
  padding:8px 14px; border-radius:999px; font-size:.85rem; font-weight:600;
  background:color-mix(in srgb,var(--offwhite) 70%, transparent); border:1px solid var(--line); color:var(--bark);
}
.chip svg{ width:15px; height:15px; color:var(--forest-soft); }

/* hero media: tall montage of real photos */
.hero-media{ position:relative; z-index:1; }
.hero-collage{
  display:grid; grid-template-columns:1.15fr .85fr; grid-template-rows:auto auto;
  gap:14px;
}
.hero-collage figure{ margin:0; overflow:hidden; border-radius:var(--radius); box-shadow:var(--shadow); background:var(--sand); }
.hero-collage img{ width:100%; height:100%; object-fit:cover; }
.hero-collage .c1{ grid-row:1 / span 2; aspect-ratio:3/4.5; }
.hero-collage .c2{ aspect-ratio:4/3; }
.hero-collage .c3{ aspect-ratio:4/3.4; }

.rating-badge{
  position:absolute; left:-14px; bottom:26px; z-index:3;
  display:flex; align-items:center; gap:12px;
  background:var(--offwhite); border-radius:16px; padding:13px 18px; box-shadow:var(--shadow-lg);
}
.rating-badge .stars{ color:var(--gold); font-size:1.05rem; letter-spacing:1px; }
.rating-badge b{ display:block; font-family:var(--serif); font-size:1.5rem; color:var(--heading); line-height:1; }
.rating-badge small{ color:var(--stone); font-size:.74rem; font-weight:600; letter-spacing:.03em; }
.rating-badge .edit-note{ font-size:.62rem; color:var(--clay); opacity:.8; }

/* hero full-bleed variant */
[data-hero="full"] .hero{ padding-top:0; min-height:100svh; display:flex; align-items:flex-end; }
[data-hero="full"] .hero-bg{ position:absolute; inset:0; z-index:0; }
[data-hero="full"] .hero-bg img{ width:100%; height:100%; object-fit:cover; }
[data-hero="full"] .hero-bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(20,30,22,.42) 0%, rgba(20,30,22,.15) 35%, rgba(20,30,22,.78) 100%); }
[data-hero="full"] .hero-grid{ grid-template-columns:1fr; padding-bottom:clamp(70px,9vw,120px); padding-top:140px; }
[data-hero="full"] .hero-media{ display:none; }
[data-hero="full"] .hero h1,[data-hero="full"] .hero-sub{ color:#fff; }
[data-hero="full"] .hero h1 em{ color:var(--clay-soft); }
[data-hero="full"] .hero-sub{ opacity:.92; }
[data-hero="full"] .tagline-vi{ color:rgba(255,255,255,.8); }
[data-hero="full"] .chip{ background:rgba(255,255,255,.14); border-color:rgba(255,255,255,.28); color:#fff; backdrop-filter:blur(6px); }
[data-hero="full"] .chip svg{ color:var(--clay-soft); }
.hero-bg{ display:none; }
[data-hero="full"] .hero-bg{ display:block; }

/* ---------- About / USP ---------- */
.about-grid{ display:grid; grid-template-columns:1fr; gap:48px; align-items:start; }
.usp-list{ display:grid; grid-template-columns:1fr; gap:4px; margin-top:34px; }
.usp{ display:flex; gap:18px; padding:22px 0; border-top:1px solid var(--line); }
.usp:last-child{ border-bottom:1px solid var(--line); }
.usp-ico{ flex:none; width:48px; height:48px; border-radius:50%; display:grid; place-items:center; background:color-mix(in srgb,var(--accent) 12%, transparent); color:var(--accent); }
.usp-ico svg{ width:24px; height:24px; }
.usp h3{ font-size:1.32rem; margin-bottom:5px; }
.usp p{ margin:0; color:var(--stone); font-size:.98rem; }
.about-photos{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.about-photos figure{ margin:0; overflow:hidden; border-radius:var(--radius); box-shadow:var(--shadow); background:var(--sand); }
.about-photos img{ width:100%; height:100%; object-fit:cover; }
.about-photos .tall{ grid-row:span 2; aspect-ratio:3/5; }
.about-photos .wide{ aspect-ratio:4/3; }

/* ---------- Services ---------- */
.services{ background:var(--bg-alt); transition:background .4s ease; }
.services-layout{ display:grid; grid-template-columns:1fr; gap:44px; margin-top:48px; align-items:start; }
.menu{ display:flex; flex-direction:column; }
.svc{
  display:flex; align-items:baseline; gap:16px; justify-content:space-between;
  padding:20px 0; border-bottom:1px solid var(--line);
}
.svc:first-child{ border-top:1px solid var(--line); }
.svc-main{ display:flex; flex-direction:column; gap:3px; }
.svc-main b{ font-family:var(--serif); font-weight:600; font-size:1.4rem; color:var(--heading); line-height:1.1; }
.svc-main small{ color:var(--stone); font-size:.92rem; }
.svc-dots{ flex:1; border-bottom:1.5px dotted color-mix(in srgb,var(--bark) 28%, transparent); transform:translateY(-5px); min-width:18px; }
.svc-price{ font-family:var(--serif); font-weight:600; font-size:1.32rem; color:var(--accent); white-space:nowrap; }
.svc-price small{ font-family:var(--sans); font-size:.7rem; font-weight:700; letter-spacing:.05em; color:var(--stone); display:block; text-align:right; }
.services-aside{ position:sticky; top:96px; display:flex; flex-direction:column; gap:16px; }
.services-aside figure{ margin:0; overflow:hidden; border-radius:var(--radius); box-shadow:var(--shadow); aspect-ratio:4/5; background:var(--sand); }
.services-aside img{ width:100%; height:100%; object-fit:cover; }
.svc-note{ background:var(--offwhite); border-radius:var(--radius); padding:20px 22px; box-shadow:var(--shadow-sm); }
.svc-note b{ font-family:var(--serif); font-size:1.15rem; color:var(--heading); }
.svc-note p{ margin:6px 0 14px; font-size:.92rem; color:var(--stone); }

/* ---------- Promo band (AI image) ---------- */
.promo-band{ position:relative; min-height:clamp(340px,46vw,520px); display:grid; place-items:center; overflow:hidden; }
.promo-band img.bg{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.promo-band::after{ content:""; position:absolute; inset:0; background:linear-gradient(90deg, rgba(20,30,22,.55), rgba(20,30,22,.15)); }
.promo-inner{ position:relative; z-index:2; text-align:center; color:#fff; padding:0 24px; }
.promo-inner .eyebrow{ color:var(--clay-soft); justify-content:center; }
.promo-inner .eyebrow::before{ background:var(--clay-soft); }
.promo-inner h2{ color:#fff; font-size:clamp(2rem,5vw,3.4rem); margin:.3em 0; text-shadow:0 2px 20px rgba(0,0,0,.3); }
.promo-inner p{ font-size:1.1rem; opacity:.92; max-width:30em; margin:0 auto; }

/* ---------- Gallery ---------- */
.gallery-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:12px; margin-top:44px; }
.gallery-grid figure{ margin:0; overflow:hidden; border-radius:var(--radius-sm); cursor:pointer; position:relative; background:var(--sand); aspect-ratio:1; }
.gallery-grid img{ width:100%; height:100%; object-fit:cover; transition:transform .6s cubic-bezier(.2,.7,.2,1); }
.gallery-grid figure::after{ content:""; position:absolute; inset:0; background:rgba(43,38,32,0); transition:background .3s; }
.gallery-grid figure:hover img{ transform:scale(1.06); }
.gallery-grid figure:hover::after{ background:rgba(43,38,32,.12); }
.gallery-grid .g-zoom{ position:absolute; top:12px; right:12px; width:34px; height:34px; border-radius:50%; background:rgba(255,255,255,.85); display:grid; place-items:center; opacity:0; transform:scale(.8); transition:.25s; z-index:2; }
.gallery-grid figure:hover .g-zoom{ opacity:1; transform:scale(1); }
.g-zoom svg{ width:16px; height:16px; color:var(--bark); }

/* lightbox */
.lightbox{ position:fixed; inset:0; z-index:90; background:rgba(20,18,15,.92); display:none; align-items:center; justify-content:center; padding:24px; }
.lightbox.open{ display:flex; }
.lightbox img{ max-width:92vw; max-height:86vh; border-radius:10px; box-shadow:0 30px 90px rgba(0,0,0,.5); }
.lb-btn{ position:absolute; top:50%; transform:translateY(-50%); width:52px; height:52px; border-radius:50%; border:none; background:rgba(255,255,255,.14); color:#fff; font-size:1.5rem; display:grid; place-items:center; transition:background .2s; }
.lb-btn:hover{ background:rgba(255,255,255,.28); }
.lb-prev{ left:18px; } .lb-next{ right:18px; }
.lb-close{ top:22px; right:22px; transform:none; }

/* ---------- Atmosphere ---------- */
.atmo{ background:var(--bg-alt); transition:background .4s ease; }
.atmo-grid{ display:grid; grid-template-columns:1fr; gap:40px; align-items:center; }
.atmo-photos{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.atmo-photos figure{ margin:0; overflow:hidden; border-radius:var(--radius); box-shadow:var(--shadow); aspect-ratio:3/4; background:var(--sand); }
.atmo-photos img{ width:100%; height:100%; object-fit:cover; }
.atmo-quote{ font-family:var(--serif); font-style:italic; font-size:1.4rem; color:var(--heading); line-height:1.4; margin-top:18px; }

/* ---------- Reviews ---------- */
.reviews-grid{ display:grid; grid-template-columns:1fr; gap:18px; margin-top:44px; }
.review-card{ background:var(--offwhite); border-radius:var(--radius); padding:28px 26px; box-shadow:var(--shadow-sm); border:1px solid var(--line); }
.review-card .stars{ color:var(--gold); letter-spacing:2px; font-size:1.05rem; }
.review-card b{ display:block; font-family:var(--serif); font-size:1.35rem; color:var(--heading); margin:10px 0 8px; }
.review-card p{ margin:0; color:var(--stone); }
.embed-slot{
  margin-top:26px; border:1.5px dashed color-mix(in srgb,var(--accent) 45%, transparent);
  border-radius:var(--radius); padding:24px; text-align:center; color:var(--stone);
  background:color-mix(in srgb,var(--accent) 5%, transparent); font-size:.92rem;
}
.embed-slot b{ color:var(--accent); font-weight:700; }

/* ---------- Expat / Offer band ---------- */
.expat{ background:var(--deepband); color:var(--deepband-text); transition:background .4s ease; }
.expat-grid{ display:grid; grid-template-columns:1fr; gap:40px; align-items:center; }
.expat figure{ margin:0; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-lg); aspect-ratio:4/3; }
.expat figure img{ width:100%; height:100%; object-fit:cover; }
.expat .eyebrow{ color:var(--clay-soft); }
.expat .eyebrow::before{ background:var(--clay-soft); }
.expat h2{ color:#fff; font-size:clamp(2rem,4.6vw,3rem); margin:.3em 0; }
.expat p{ opacity:.85; font-size:1.06rem; max-width:34em; }
.expat .btn-light{ margin-top:8px; }
.expat strong{ color:var(--clay-soft); }

/* ---------- Offer ribbon (urgency) ---------- */
.offer-ribbon{
  display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:10px 22px;
  background:var(--accent); color:#fff; text-align:center; padding:14px 24px; font-weight:600; font-size:.96rem;
}
.offer-ribbon .countdown{ font-variant-numeric:tabular-nums; font-weight:800; background:rgba(255,255,255,.18); padding:4px 12px; border-radius:8px; letter-spacing:.04em; }

/* ---------- FAQ ---------- */
.faq-list{ margin-top:40px; max-width:820px; }
.faq-item{ border-bottom:1px solid var(--line); }
.faq-q{ width:100%; background:none; border:none; text-align:left; display:flex; align-items:center; justify-content:space-between; gap:18px; padding:22px 0; font-family:var(--serif); font-size:1.32rem; font-weight:600; color:var(--heading); }
.faq-q .pm{ flex:none; width:28px; height:28px; border-radius:50%; border:1.5px solid var(--accent); color:var(--accent); display:grid; place-items:center; position:relative; transition:transform .3s; }
.faq-q .pm::before,.faq-q .pm::after{ content:""; position:absolute; background:var(--accent); border-radius:2px; }
.faq-q .pm::before{ width:12px; height:2px; }
.faq-q .pm::after{ width:2px; height:12px; transition:transform .3s; }
.faq-item.open .pm::after{ transform:rotate(90deg); opacity:0; }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .35s ease; }
.faq-a p{ margin:0 0 22px; color:var(--stone); max-width:62ch; }

/* ---------- Contact ---------- */
.contact{ background:var(--bg-alt); transition:background .4s ease; }
.contact-grid{ display:grid; grid-template-columns:1fr; gap:40px; }
.contact-cards{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.contact-card{ background:var(--offwhite); border-radius:var(--radius); padding:18px 20px; box-shadow:var(--shadow-sm); display:flex; flex-direction:column; gap:3px; transition:transform .18s, box-shadow .18s; }
a.contact-card:hover{ transform:translateY(-3px); box-shadow:var(--shadow); }
.contact-card strong{ font-size:.74rem; text-transform:uppercase; letter-spacing:.12em; color:var(--accent); font-weight:800; }
.contact-card span{ font-size:1.05rem; color:var(--bark); font-weight:600; }
.contact-map{ border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); min-height:280px; border:1px solid var(--line); }
.contact-map iframe{ width:100%; height:100%; min-height:280px; border:0; display:block; filter:saturate(.92) contrast(.96); }
.contact-actions{ display:flex; flex-wrap:wrap; gap:12px; margin-top:24px; }

/* lead capture */
.lead{ background:var(--offwhite); border-radius:var(--radius); padding:24px; box-shadow:var(--shadow-sm); border:1px solid var(--line); margin-top:6px; }
.lead b{ font-family:var(--serif); font-size:1.3rem; color:var(--heading); }
.lead p{ font-size:.9rem; color:var(--stone); margin:5px 0 14px; }
.lead form{ display:flex; gap:10px; flex-wrap:wrap; }
.lead input{ flex:1; min-width:180px; padding:13px 16px; border-radius:999px; border:1.5px solid var(--line); background:var(--bg); font:inherit; font-size:.95rem; color:var(--bark); }
.lead input:focus{ outline:none; border-color:var(--accent); }
.lead .ok{ color:var(--forest-soft); font-weight:700; font-size:.95rem; margin-top:10px; display:none; }
.lead.done .ok{ display:block; }

/* ---------- Footer ---------- */
.footer{ background:var(--forest-deep); color:#E9E6D2; padding:64px 0 120px; }
.footer-grid{ display:grid; grid-template-columns:1fr; gap:36px; }
.footer img.flogo{ height:74px; width:auto; filter:brightness(0) saturate(100%) invert(86%) sepia(18%) saturate(360%) hue-rotate(2deg) brightness(95%); opacity:.95; }
.footer p{ opacity:.78; font-size:.95rem; max-width:38ch; }
.footer h4{ color:#fff; font-family:var(--sans); font-size:.78rem; letter-spacing:.14em; text-transform:uppercase; margin-bottom:14px; opacity:.7; }
.footer .fcol a,.footer .fcol span{ display:block; opacity:.82; padding:5px 0; font-size:.96rem; }
.footer .fcol a:hover{ opacity:1; color:var(--clay-soft); }
.footer-bottom{ margin-top:48px; padding-top:24px; border-top:1px solid rgba(255,255,255,.12); font-size:.84rem; opacity:.6; }

/* ---------- Floating WhatsApp ---------- */
.fab{
  position:fixed; right:18px; bottom:96px; z-index:50;
  width:58px; height:58px; border-radius:50%; background:#25D366; color:#fff;
  display:grid; place-items:center; box-shadow:0 12px 34px rgba(37,211,102,.45);
  transition:transform .2s; animation:fabIn .5s .8s both;
}
.fab:hover{ transform:scale(1.08); }
.fab svg{ width:30px; height:30px; }
@keyframes fabIn{ from{ transform:scale(0); } to{ transform:scale(1); } }

/* ---------- Mobile bottom action bar ---------- */
.bottom-bar{
  position:fixed; inset:auto 0 0 0; z-index:52;
  display:grid; grid-template-columns:1fr 1fr; gap:10px; padding:10px 14px calc(10px + env(safe-area-inset-bottom));
  background:color-mix(in srgb,var(--bg) 94%, transparent); backdrop-filter:blur(14px);
  border-top:1px solid var(--line); box-shadow:0 -8px 24px rgba(43,38,32,.08);
  transform:translateY(120%); transition:transform .35s ease;
}
.bottom-bar.show{ transform:translateY(0); }
.bottom-bar .btn{ min-height:50px; font-size:.96rem; }

/* ---------- Motion ---------- */
.reveal{ opacity:0; transform:translateY(18px); transition:opacity .7s ease, transform .7s cubic-bezier(.2,.7,.2,1); }
.reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){ .reveal{ opacity:1; transform:none; transition:none; } *{ scroll-behavior:auto; } }

/* ---------- Responsive ---------- */
@media (min-width:560px){
  .gallery-grid{ grid-template-columns:repeat(3,1fr); }
  .reviews-grid{ grid-template-columns:repeat(3,1fr); }
  .lead form{ flex-wrap:nowrap; }
}
@media (min-width:768px){
  :root{ --pad:40px; }
  .brand-name{ display:block; font-family:var(--serif); font-weight:600; font-size:1.15rem; color:var(--heading); letter-spacing:.02em; }
  .usp-list{ grid-template-columns:1fr 1fr; gap:0 36px; }
  .contact-cards{ grid-template-columns:repeat(3,1fr); }
  .footer-grid{ grid-template-columns:1.6fr 1fr 1fr; }
}
@media (min-width:1024px){
  .nav-links{ display:flex; }
  .nav-cta{ display:inline-flex; }
  .hamburger{ display:none; }
  .bottom-bar{ display:none; }
  .lang-full{ display:flex; }
  .lang-compact{ display:none; }
  .fab{ bottom:24px; right:24px; }
  .hero-grid{ grid-template-columns:1.04fr .96fr; gap:54px; }
  [data-hero="full"] .hero-grid{ grid-template-columns:1fr; }
  .about-grid{ grid-template-columns:1fr 1fr; gap:64px; }
  .services-layout{ grid-template-columns:1.5fr 1fr; gap:60px; }
  .atmo-grid{ grid-template-columns:1fr 1fr; gap:60px; }
  .expat-grid{ grid-template-columns:1fr 1fr; }
  .contact-grid{ grid-template-columns:1.1fr 1fr; gap:54px; }
}
@media (min-width:1024px){
  [data-hero="full"] .hero-sub{ max-width:38em; }
}

/* ============================================================
   PREMIUM LAYER
   ============================================================ */

/* botanical leaf accent on dark/centered eyebrows */
.promo-inner .eyebrow::before,.expat .eyebrow::before{ background:var(--clay-soft); }
.promo-inner .eyebrow::after,.expat .eyebrow::after{ background:var(--clay-soft); opacity:.5; }

/* hero ken-burns on the lead image */
@media (prefers-reduced-motion:no-preference){
  .hero-collage .c1 img{ animation:kenburns 16s ease-in-out infinite alternate; }
}
@keyframes kenburns{ from{ transform:scale(1) translateY(0); } to{ transform:scale(1.07) translateY(-1.5%); } }
.hero-collage figure{ position:relative; }
.hero-collage .c1::after{ content:""; position:absolute; inset:0; box-shadow:inset 0 0 90px rgba(43,38,32,.25); border-radius:var(--radius); pointer-events:none; }

/* gold hairline detail under the rating badge */
.rating-badge{ border:1px solid color-mix(in srgb,var(--gold) 35%, transparent); }

/* ---- Signature Ritual feature ---- */
.signature{
  display:grid; grid-template-columns:1fr; gap:0; margin:0 0 8px;
  background:var(--offwhite); border-radius:calc(var(--radius) + 4px); overflow:hidden;
  box-shadow:var(--shadow); border:1px solid var(--line);
}
.signature .sig-media{ position:relative; aspect-ratio:16/10; overflow:hidden; }
.signature .sig-media img{ width:100%; height:100%; object-fit:cover; }
.signature .sig-tag{
  position:absolute; top:16px; left:16px; z-index:2;
  display:inline-flex; align-items:center; gap:7px;
  background:color-mix(in srgb,var(--offwhite) 88%, transparent); backdrop-filter:blur(6px);
  padding:7px 14px; border-radius:999px; font-size:.7rem; font-weight:800; letter-spacing:.16em; text-transform:uppercase; color:var(--accent); white-space:nowrap;
}
.signature .sig-tag b{ width:13px; height:13px; background:var(--accent); -webkit-mask:var(--leaf) center/contain no-repeat; mask:var(--leaf) center/contain no-repeat; }
.signature .sig-body{ padding:28px 30px 30px; display:flex; flex-direction:column; gap:6px; }
.signature h3{ font-size:clamp(1.7rem,3vw,2.3rem); }
.signature .sig-desc{ color:var(--stone); margin:4px 0 0; max-width:46ch; }
.signature .sig-foot{ display:flex; align-items:center; flex-wrap:wrap; gap:18px; margin-top:18px; }
.signature .sig-price{ font-family:var(--serif); font-size:1.7rem; color:var(--accent); font-weight:600; }
.signature .sig-price small{ display:block; font-family:var(--sans); font-size:.68rem; font-weight:700; letter-spacing:.06em; color:var(--stone); }
.signature .sig-meta{ display:flex; gap:8px; flex-wrap:wrap; }
.signature .sig-meta span{ font-size:.82rem; color:var(--stone); border:1px solid var(--line); border-radius:999px; padding:5px 12px; }
@media (min-width:760px){
  .signature{ grid-template-columns:1.1fr 1fr; align-items:stretch; }
  .signature .sig-media{ aspect-ratio:auto; }
  .signature .sig-body{ padding:38px 40px; justify-content:center; }
}

/* ---- Brand monogram watermark on deep band ---- */
.expat{ position:relative; overflow:hidden; }
.brand-watermark{
  position:absolute; right:-4%; bottom:-12%; width:min(46%,440px); z-index:0;
  opacity:.07; pointer-events:none; user-select:none;
  filter:brightness(0) saturate(100%) invert(64%) sepia(38%) saturate(620%) hue-rotate(350deg) brightness(92%);
}
.expat .wrap{ position:relative; z-index:1; }

/* ---- Credibility strip ---- */
.cred-strip{
  display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:14px 30px;
  margin-top:38px; padding-top:30px; border-top:1px solid var(--line);
}
.cred-strip .cred-lead{ font-size:.78rem; letter-spacing:.14em; text-transform:uppercase; color:var(--stone); font-weight:700; }
.cred-item{ display:inline-flex; align-items:center; gap:8px; font-family:var(--serif); font-size:1.15rem; color:var(--heading); font-weight:600; opacity:.82; }
.cred-item .stars{ color:var(--gold); font-size:.8rem; letter-spacing:1px; }
.cred-item svg{ width:18px; height:18px; color:var(--accent); }

/* ---- Refined map block ---- */
.contact-map{ position:relative; }
.map-label{
  position:absolute; left:14px; top:14px; z-index:2;
  background:color-mix(in srgb,var(--offwhite) 92%, transparent); backdrop-filter:blur(8px);
  border-radius:12px; padding:11px 15px; box-shadow:var(--shadow-sm); max-width:78%;
}
.map-label strong{ display:flex; align-items:center; gap:7px; font-family:var(--serif); font-size:1.05rem; color:var(--heading); }
.map-label strong svg{ width:16px; height:16px; color:var(--accent); flex:none; }
.map-label span{ font-size:.82rem; color:var(--stone); }
.map-dir{
  position:absolute; right:14px; bottom:14px; z-index:2; min-height:44px; padding:0 18px; font-size:.92rem;
}
