/* ============================================================
   DOHA BEAUTY CENTER  ·  Ladies Salon & Spa — Doha, Qatar
   ============================================================
   Bridal-Blush palette #10. Cormorant Garamond display.
   Inter Tight body. Noto Naskh Arabic multilingual.
   Rose-gold accent. EN/AR bilingual toggle.
   ============================================================ */

:root {
  /* Bridal-Blush #10 — champagne + blush + antique gold */
  --bg:           #F8F1EC;
  --bg-2:         #EFE2DA;
  --bg-3:         #E4D3C8;
  --paper:        #FFFFFF;
  --ink:          #3A2A2E;
  --ink-soft:     #6B5A56;
  --ink-mute:     #9E8D88;
  --line:         #DCCDC5;
  --line-soft:    #EDE0D8;

  --copper:       #C7A06A;   /* antique gold — primary accent */
  --copper-deep:  #A8855A;
  --rosegold:     #C49A8A;   /* rose-gold accent */
  --rosegold-deep:#A8806F;
  --spot:         #B6776E;   /* dusty rose */
  --blush:        #D9A496;
  --ink-block:    #3A2A2E;

  /* Remapped for structural CSS compat */
  --magenta:      #B6776E;
  --magenta-deep: #9A6059;
  --blue:         #8B636A;
  --blue-deep:    #6E4D52;
  --honey:        #C7A06A;
  --honey-deep:   #A8855A;
  --plum:         #8B636A;

  --font-display: 'Cormorant Garamond', 'Georgia', serif;
  --font-body:    'Inter Tight', 'Inter', -apple-system, sans-serif;
  --font-arabic:  'Noto Naskh Arabic', 'Arial', sans-serif;
  --font-script:  'Caveat', cursive;

  --r-sm: 8px;
  --r:    18px;
  --r-lg: 32px;

  --border:   1.5px solid var(--ink);
  --sh-soft:  0 8px 28px rgba(58,42,46,0.06);
  --sh-card:  0 14px 40px rgba(58,42,46,0.08);
  --sh-hard:  8px 8px 0 var(--ink);
  --sh-deep:  0 30px 80px rgba(58,42,46,0.18);

  --ease:  cubic-bezier(.22,1,.36,1);
  --max:   1380px;
}
[data-theme="dark"] {
  --bg: #1C1416; --bg-2:#231A1C; --bg-3:#2B2022; --paper:#1C1416;
  --ink:#F8F1EC; --ink-soft:#C9B8B3; --ink-mute:#9E8D88;
  --line:#3A2C2E; --line-soft:#2E2224;
  --sh-hard: 8px 8px 0 var(--ink);
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;}
body{
  font-family:var(--font-body);background:var(--bg);color:var(--ink);
  font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;overflow-x:hidden;
  transition:background .4s ease, color .4s ease;
}
/* Arabic text uses Noto Naskh Arabic */
[lang="ar"], .ar, :lang(ar) { font-family: var(--font-arabic); }
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit;}
::selection{background:var(--copper);color:var(--ink);}
.container{width:min(94%,var(--max));margin-inline:auto;}
.no-scroll{overflow:hidden;}

h1,h2,h3,h4{
  font-family:var(--font-display);font-weight:600;line-height:.94;
  letter-spacing:-.02em;color:var(--ink);
}
.hero-shout{font-size:clamp(4rem,12vw,11rem);line-height:.86;letter-spacing:-.04em;}
h1{font-size:clamp(3.4rem,9vw,8rem);}
h2{font-size:clamp(2.6rem,6vw,5.4rem);}
h3{font-size:clamp(1.4rem,2.4vw,2.2rem);}

.kicker{
  font-family:var(--font-body);font-size:12px;font-weight:600;
  letter-spacing:.24em;text-transform:uppercase;color:var(--ink-soft);
  display:inline-flex;align-items:center;gap:12px;
}
.kicker .dot{width:8px;height:8px;border-radius:50%;background:var(--copper);}
.kicker.magenta .dot{background:var(--magenta);}
.kicker.blue .dot{background:var(--blue);}
.kicker.honey .dot{background:var(--honey);}
.script{
  font-family:var(--font-script);font-weight:500;color:var(--copper-deep);
  font-size:1.5rem;line-height:1.2;transform:rotate(-2deg);display:inline-block;
}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:18px 28px;
  font-family:var(--font-body);font-size:13px;font-weight:600;
  letter-spacing:.12em;text-transform:uppercase;
  border-radius:999px;border:var(--border);
  transition:all .25s var(--ease);white-space:nowrap;
  position:relative;cursor:pointer;
}
.btn-ink{background:var(--ink);color:var(--bg);}
.btn-ink:hover{transform:translate(-3px,-3px);box-shadow:var(--sh-hard);}
.btn-copper{background:var(--copper);color:#fff;border-color:var(--copper);}
.btn-copper:hover{transform:translate(-3px,-3px);box-shadow:6px 6px 0 var(--ink);}
.btn-paper{background:var(--paper);color:var(--ink);}
.btn-paper:hover{transform:translate(-3px,-3px);box-shadow:var(--sh-hard);}
.btn-ghost{background:transparent;color:var(--ink);}
.btn-ghost:hover{background:var(--ink);color:var(--bg);}
.btn-ghost-light{background:transparent;color:#fff;border-color:#fff;}
.btn-ghost-light:hover{background:#fff;color:var(--ink);}
.btn .ic{width:16px;height:16px;}

/* Nav */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:22px 0;transition:all .4s var(--ease);}
.nav.scrolled{
  padding:12px 0;
  background:color-mix(in srgb, var(--bg) 88%, transparent);
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  border-bottom:1.5px solid var(--ink);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--font-display);line-height:1;}
.brand .b-mark{
  display:inline-grid;place-items:center;width:42px;height:42px;
  background:var(--ink);color:var(--copper);border-radius:50%;
  font-family:var(--font-display);font-size:1.3rem;font-weight:700;letter-spacing:-.02em;
}
.brand .b-text{display:flex;flex-direction:column;gap:1px;line-height:1;}
.brand .b-text .t1{font-size:1.1rem;font-weight:700;letter-spacing:.02em;color:var(--ink);}
.brand .b-text .t2{
  font-size:9px;font-weight:600;letter-spacing:.32em;text-transform:uppercase;
  color:var(--ink-mute);font-family:var(--font-body);
}
.nav-links{display:flex;align-items:center;gap:30px;}
.nav-links a{
  font-size:13px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink);padding:6px 0;position:relative;
}
.nav-links a::before{
  content:"";position:absolute;bottom:-3px;left:0;right:0;height:3px;
  background:var(--copper);transform:scaleX(0);transform-origin:left;
  transition:transform .35s var(--ease);
}
.nav-links a:hover::before,.nav-links a.active::before{transform:scaleX(1);}
.nav-cta{display:flex;align-items:center;gap:12px;}
.theme-toggle{
  width:42px;height:42px;display:grid;place-items:center;
  background:var(--paper);border:var(--border);border-radius:50%;
  transition:transform .2s var(--ease);
}
.theme-toggle:hover{transform:rotate(-12deg);}
.theme-toggle .ic{width:18px;height:18px;}
.theme-toggle .moon{display:none;}
[data-theme="dark"] .theme-toggle .sun{display:none;}
[data-theme="dark"] .theme-toggle .moon{display:block;}
.hamburger{
  display:none;width:42px;height:42px;border:var(--border);border-radius:50%;
  place-items:center;background:var(--paper);
}
.hamburger span{width:18px;height:1.5px;background:var(--ink);display:block;position:relative;transition:all .3s var(--ease);}
.hamburger span::before,.hamburger span::after{
  content:"";position:absolute;left:0;width:18px;height:1.5px;background:var(--ink);transition:all .3s var(--ease);
}
.hamburger span::before{top:-6px;}
.hamburger span::after{top:6px;}
.hamburger.open span{background:transparent;}
.hamburger.open span::before{transform:rotate(45deg);top:0;}
.hamburger.open span::after{transform:rotate(-45deg);top:0;}
.mobile-menu{
  position:fixed;inset:0;z-index:99;background:var(--bg);
  display:none;flex-direction:column;padding:100px 28px 36px;
}
.mobile-menu.open{display:flex;}
.mobile-menu a{
  font-family:var(--font-display);font-size:2.4rem;font-weight:600;
  padding:18px 0;border-bottom:1px solid var(--line-soft);
  display:flex;justify-content:space-between;align-items:center;
}
.mobile-menu a small{
  font-family:var(--font-body);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--copper);font-weight:600;
}

/* Hero bento */
.hero{padding:110px 0 60px;background:var(--bg);position:relative;}
.hero-bento{
  display:grid;grid-template-columns:1.4fr .9fr 1.1fr;
  grid-template-rows:auto auto;gap:18px;margin-top:30px;
}
.bento{
  position:relative;overflow:hidden;border-radius:var(--r-lg);
  border:var(--border);background:var(--paper);min-height:0;
}
.bento img,.bento video{width:100%;height:100%;object-fit:cover;display:block;}
.bento--say{
  grid-column:1 / span 1;grid-row:1 / span 2;
  padding:36px 32px;background:var(--ink);color:var(--bg);
  display:flex;flex-direction:column;justify-content:space-between;
  min-height:460px;
}
.bento--say .top{display:flex;justify-content:space-between;align-items:flex-start;}
.bento--say .top .badge{
  font-family:var(--font-body);font-size:11px;font-weight:600;
  letter-spacing:.22em;text-transform:uppercase;color:var(--copper);
  border:1.5px solid var(--copper);padding:6px 12px;border-radius:999px;
}
.bento--say h1.hero-shout{color:var(--bg);margin-top:16px;}
.bento--say h1.hero-shout em{
  color:var(--copper);font-style:normal;position:relative;display:inline-block;
}
.bento--say .bot{display:flex;flex-direction:column;gap:18px;max-width:440px;}
.bento--say .bot p{font-size:1.02rem;line-height:1.6;color:color-mix(in srgb, var(--bg) 85%, transparent);}
.bento--say .bot .ctas{display:flex;gap:10px;flex-wrap:wrap;}
.bento--portrait1{grid-column:2;grid-row:1;min-height:360px;}
.bento--portrait2{grid-column:3;grid-row:1;min-height:360px;}
.bento--portrait3{grid-column:2;grid-row:2;min-height:360px;}
.bento--reel{grid-column:3;grid-row:2;min-height:360px;background:var(--ink);}
.bento .lbl{
  position:absolute;bottom:14px;left:14px;
  display:inline-flex;align-items:center;gap:8px;
  background:var(--paper);color:var(--ink);
  border-radius:999px;padding:7px 14px;
  font-family:var(--font-body);font-size:10px;font-weight:600;
  letter-spacing:.22em;text-transform:uppercase;
  border:1.5px solid var(--ink);
}
.bento .lbl .swatch{width:10px;height:10px;border-radius:50%;display:inline-block;}
.bento .corner-tag{
  position:absolute;top:16px;right:16px;
  background:var(--copper);color:#fff;
  font-family:var(--font-display);font-size:12px;font-weight:700;
  padding:4px 10px;border-radius:999px;
}
.hero-meta-strip{
  display:flex;align-items:center;justify-content:space-between;
  margin-top:22px;padding:18px 28px;
  background:var(--paper);border:var(--border);border-radius:999px;
  gap:24px;flex-wrap:wrap;
}
.hero-meta-strip .item{display:flex;align-items:center;gap:12px;font-family:var(--font-body);font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);}
.hero-meta-strip .item .val{font-family:var(--font-display);font-weight:700;font-size:1.05rem;letter-spacing:-.01em;text-transform:none;color:var(--copper);}
.hero-meta-strip .sep{width:1px;height:24px;background:var(--line);}

/* Ribbon */
.ribbon{background:var(--ink);color:var(--bg);border-top:var(--border);border-bottom:var(--border);padding:18px 0;overflow:hidden;}
.ribbon-track{display:flex;gap:60px;white-space:nowrap;animation:scroll-x 35s linear infinite;}
.ribbon-item{display:inline-flex;align-items:center;gap:20px;font-family:var(--font-display);font-size:1.6rem;font-weight:600;letter-spacing:-.01em;}
.ribbon-item .sw{width:14px;height:14px;border-radius:50%;display:inline-block;}
@keyframes scroll-x{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* Section base */
section{padding:110px 0;position:relative;}
.sec-head{display:grid;grid-template-columns:1.2fr 1fr;gap:60px;align-items:end;margin-bottom:60px;}
.sec-head h2 .accent{color:var(--copper);}
.sec-head h2 .accent.magenta{color:var(--magenta);}
.sec-head h2 .accent.blue{color:var(--blue);}
.sec-head h2 .accent.honey{color:var(--honey-deep);}
.sec-head .lead p{font-size:1.05rem;line-height:1.65;color:var(--ink-soft);max-width:520px;}

/* Featured look */
.featured{background:var(--bg-2);border-top:var(--border);border-bottom:var(--border);}
.featured-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:70px;align-items:center;}
.featured-img{position:relative;border-radius:var(--r-lg);border:var(--border);overflow:hidden;aspect-ratio:4/5;box-shadow:var(--sh-card);}
.featured-img img{width:100%;height:100%;object-fit:cover;}
.featured-img .tag-tape{
  position:absolute;top:20px;left:50%;transform:translateX(-50%) rotate(-2deg);
  background:#FFF7CC;color:var(--ink);padding:6px 24px;
  font-family:var(--font-script);font-size:1.5rem;font-weight:600;
  box-shadow:0 4px 10px rgba(0,0,0,0.08);
}
.featured-body .kicker{color:var(--copper-deep);}
.featured-body .kicker .dot{background:var(--copper);}
.featured-body h2{margin-top:18px;margin-bottom:26px;}
.featured-body h2 .accent{color:var(--copper-deep);}
.featured-body p{font-size:1.05rem;line-height:1.7;max-width:480px;color:var(--ink-soft);}
.featured-body p + p{margin-top:14px;}
.swatches{display:flex;gap:14px;margin:36px 0 24px;flex-wrap:wrap;}
.swatch-card{
  display:flex;align-items:center;gap:12px;
  background:var(--paper);border:var(--border);border-radius:999px;
  padding:8px 16px 8px 8px;
}
.swatch-card .chip{width:28px;height:28px;border-radius:50%;border:1.5px solid var(--ink);}
.swatch-card .name{font-family:var(--font-display);font-size:14px;font-weight:600;}
.swatch-card .code{font-family:var(--font-body);font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mute);}

/* Services cards */
.services{background:var(--bg);}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.svc-card{
  position:relative;border:var(--border);border-radius:var(--r-lg);
  overflow:hidden;background:var(--paper);
  transition:all .35s var(--ease);cursor:pointer;
  display:flex;flex-direction:column;
}
.svc-card:hover{transform:translate(-4px,-4px);box-shadow:var(--sh-hard);}
.svc-img{aspect-ratio:4/3;overflow:hidden;position:relative;}
.svc-img img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease);}
.svc-card:hover .svc-img img{transform:scale(1.05);}
.svc-img .price-tag{
  position:absolute;top:14px;right:14px;
  background:var(--ink);color:var(--bg);
  font-family:var(--font-display);font-weight:700;
  padding:6px 14px;border-radius:999px;
  font-size:13px;letter-spacing:-.01em;
}
.svc-body{padding:26px 24px 28px;display:flex;flex-direction:column;flex:1;gap:10px;}
.svc-body .svc-no{font-family:var(--font-display);font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--copper);}
.svc-body h3{font-size:1.7rem;}
.svc-body p{color:var(--ink-soft);font-size:.95rem;line-height:1.55;margin-top:6px;flex:1;}
.svc-cta{display:inline-flex;align-items:center;gap:8px;margin-top:14px;font-family:var(--font-body);font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);}
.svc-cta::after{content:"→";transition:transform .25s ease;}
.svc-card:hover .svc-cta::after{transform:translateX(4px);}

/* Diary (dark photo wall) */
.diary{background:var(--ink-block);color:var(--bg);padding:130px 0;border-top:var(--border);}
.diary .sec-head h2,.diary .sec-head .lead p{color:var(--bg);}
.diary .sec-head .lead p{color:color-mix(in srgb, var(--bg) 70%, transparent);}
.diary-row{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:60px;}
.diary-entry{
  position:relative;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:3/4;
  border:1.5px solid color-mix(in srgb, var(--bg) 14%, transparent);
  cursor:pointer;transition:all .35s var(--ease);
}
.diary-entry img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease);}
.diary-entry:hover{transform:scale(1.02);border-color:var(--copper);}
.diary-entry:hover img{transform:scale(1.05);}
.diary-entry::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,0.7) 100%);
}
.diary-entry .meta{position:absolute;bottom:18px;left:18px;right:18px;color:#fff;z-index:2;}
.diary-entry .meta .code{font-family:var(--font-body);font-size:10px;font-weight:600;letter-spacing:.26em;text-transform:uppercase;color:var(--copper);}
.diary-entry .meta .name{font-family:var(--font-display);font-size:1.4rem;font-weight:600;letter-spacing:-.01em;margin-top:6px;}
.diary-foot{margin-top:60px;display:flex;justify-content:space-between;align-items:center;padding-top:36px;border-top:1px solid color-mix(in srgb, var(--bg) 14%, transparent);flex-wrap:wrap;gap:20px;}
.diary-foot p{font-family:var(--font-script);font-size:1.6rem;color:var(--copper);}

/* Polaroid stylists */
.team{background:var(--bg);padding-bottom:130px;}
.poly-row{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;margin-top:70px;align-items:start;}
.poly{
  position:relative;background:var(--paper);
  padding:14px 14px 30px;
  border:var(--border);border-radius:6px;
  box-shadow:var(--sh-card);transition:transform .35s var(--ease);
}
.poly:nth-child(1){transform:rotate(-1.5deg);}
.poly:nth-child(2){transform:rotate(.5deg);margin-top:30px;}
.poly:nth-child(3){transform:rotate(-.8deg);}
.poly:hover{transform:rotate(0deg) translateY(-6px);}
.poly-img{aspect-ratio:4/5;overflow:hidden;border-radius:4px;}
.poly-img img{width:100%;height:100%;object-fit:cover;}
.poly-info{padding:18px 6px 6px;text-align:center;display:flex;flex-direction:column;gap:6px;}
.poly-info .role{font-family:var(--font-body);font-size:10px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--copper);}
.poly-info .name{font-family:var(--font-script);font-size:1.9rem;font-weight:500;color:var(--ink);line-height:1;}
.poly-info .book{
  margin-top:14px;font-family:var(--font-body);font-size:12px;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;color:var(--ink);
  text-decoration:underline;text-underline-offset:4px;
}
.poly .tape{
  position:absolute;top:-10px;left:50%;
  width:70px;height:22px;
  background:rgba(255,221,87,.85);
  border:1px solid rgba(0,0,0,.07);
  transform:translateX(-50%) rotate(-2deg);opacity:.8;
}

/* Marquee strip */
.strip{background:var(--bg-2);padding:100px 0;border-top:var(--border);border-bottom:var(--border);overflow:hidden;}
.strip h2{text-align:center;margin-bottom:50px;}
.strip h2 .accent{color:var(--copper);}
.strip-track{display:flex;gap:24px;white-space:nowrap;animation:scroll-x 60s linear infinite;}
.strip-card{flex:0 0 280px;aspect-ratio:3/4;border-radius:var(--r);border:var(--border);overflow:hidden;background:var(--paper);position:relative;}
.strip-card img{width:100%;height:100%;object-fit:cover;}

/* FAQ */
.faq-wrap{padding:120px 0;background:var(--bg);}
.faq-list{max-width:860px;margin:0 auto;}
.faq{
  border:var(--border);border-radius:var(--r);background:var(--paper);
  padding:28px 32px;cursor:pointer;margin-bottom:14px;
  transition:all .25s var(--ease);
}
.faq:hover{transform:translate(-3px,-3px);box-shadow:var(--sh-hard);}
.faq[open]{box-shadow:var(--sh-hard);transform:translate(-3px,-3px);background:var(--bg-2);}
.faq summary{
  display:flex;justify-content:space-between;align-items:center;gap:20px;
  font-family:var(--font-display);font-size:clamp(1.2rem,2vw,1.5rem);font-weight:600;
  list-style:none;
}
.faq summary::-webkit-details-marker{display:none;}
.faq summary .plus{
  width:36px;height:36px;border-radius:50%;border:var(--border);
  background:var(--bg);display:grid;place-items:center;flex-shrink:0;
  transition:all .3s var(--ease);
}
.faq[open] summary .plus{background:var(--copper);border-color:var(--copper);color:#fff;transform:rotate(45deg);}
.faq-body{margin-top:18px;color:var(--ink-soft);line-height:1.7;padding-right:50px;}

/* Locations */
.locs{padding:120px 0;background:var(--bg-2);border-top:var(--border);}
.loc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:60px;}
.loc-card{
  border:var(--border);border-radius:var(--r-lg);background:var(--paper);
  overflow:hidden;display:flex;flex-direction:column;
  transition:all .25s var(--ease);
}
.loc-card:hover{transform:translate(-4px,-4px);box-shadow:var(--sh-hard);}
.loc-img{aspect-ratio:16/10;overflow:hidden;position:relative;}
.loc-img img{width:100%;height:100%;object-fit:cover;}
.loc-img .pin{
  position:absolute;top:16px;left:16px;
  background:var(--ink);color:#fff;padding:6px 14px;border-radius:999px;
  font-family:var(--font-display);font-weight:600;font-size:12px;
}
.loc-body{padding:30px 32px;flex:1;display:flex;flex-direction:column;}
.loc-body .city{font-family:var(--font-body);font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--copper);font-weight:600;margin-bottom:8px;}
.loc-body h3{font-size:2rem;margin-bottom:16px;}
.loc-body .row{display:flex;gap:12px;align-items:flex-start;padding:10px 0;font-size:.95rem;line-height:1.5;color:var(--ink-soft);}
.loc-body .row .ic{width:18px;height:18px;color:var(--copper);flex-shrink:0;margin-top:2px;}
.loc-actions{display:flex;gap:10px;margin-top:20px;flex-wrap:wrap;}
.loc-actions .btn{padding:12px 20px;font-size:11px;}

/* Final CTA */
.cta-block{
  background:var(--copper);color:#fff;padding:150px 0;text-align:center;
  border-top:var(--border);position:relative;overflow:hidden;
}
.cta-block::before,.cta-block::after{content:"";position:absolute;border-radius:50%;background:rgba(255,255,255,.08);pointer-events:none;}
.cta-block::before{width:500px;height:500px;top:-180px;left:-150px;}
.cta-block::after{width:380px;height:380px;bottom:-160px;right:-120px;}
.cta-block .inner{position:relative;z-index:2;}
.cta-block h2{color:#fff;font-size:clamp(2.8rem,7vw,6.5rem);}
.cta-block h2 .accent{color:var(--ink);}
.cta-block p{color:rgba(255,255,255,.85);margin:24px auto 0;font-size:1.05rem;max-width:580px;}
.cta-block .actions{margin-top:42px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}
.cta-block .btn-ink{background:var(--ink);color:var(--copper);border-color:var(--ink);}
.cta-block .btn-ink:hover{background:var(--bg);color:var(--ink);}
.cta-block .btn-ghost-light:hover{background:#fff;color:var(--copper);}

/* Footer */
footer{background:var(--ink-block);color:rgba(250,245,236,.7);padding:100px 0 36px;position:relative;}
.foot-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;padding-bottom:60px;border-bottom:1px solid rgba(250,245,236,.1);}
.foot-brand .brand .b-mark{background:var(--copper);color:var(--ink);}
.foot-brand .brand .b-text .t1{color:#fff;}
.foot-brand .brand .b-text .t2{color:rgba(250,245,236,.5);}
.foot-brand p{margin-top:22px;color:rgba(250,245,236,.6);font-size:.95rem;line-height:1.6;max-width:340px;}
.socials{display:flex;gap:10px;margin-top:24px;}
.socials a{
  width:40px;height:40px;border:1px solid rgba(250,245,236,.15);border-radius:50%;
  display:grid;place-items:center;color:rgba(250,245,236,.7);transition:all .25s ease;
}
.socials a:hover{background:var(--copper);border-color:var(--copper);color:#fff;}
.socials .ic{width:16px;height:16px;}
.foot-col h4{font-family:var(--font-body);font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--copper);font-weight:600;margin-bottom:22px;}
.foot-col ul{list-style:none;}
.foot-col li{margin-bottom:12px;}
.foot-col a{color:rgba(250,245,236,.7);font-size:.95rem;transition:color .2s ease;}
.foot-col a:hover{color:var(--copper);}
.foot-bottom{margin-top:50px;display:flex;justify-content:space-between;align-items:center;font-size:12px;color:rgba(250,245,236,.45);letter-spacing:.08em;}
.foot-credit{margin-top:20px;text-align:center;font-size:11px;color:rgba(250,245,236,.42);letter-spacing:.12em;}
.foot-credit a{color:var(--copper);border-bottom:1px solid transparent;padding-bottom:1px;transition:color .2s ease;}
.foot-credit a:hover{color:#fff;border-color:var(--copper);}

/* Sticky mobile CTA */
.mobile-cta{
  display:none;position:fixed;left:14px;right:14px;bottom:14px;z-index:95;
  background:var(--ink);color:var(--copper);padding:16px 22px;border-radius:999px;
  font-family:var(--font-body);font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:600;
  text-align:center;box-shadow:var(--sh-deep);border:1.5px solid var(--copper);
}

/* Page hero (internal pages) */
.page-hero{background:var(--bg-2);padding:150px 0 90px;border-bottom:var(--border);position:relative;}
.page-hero .crumbs{display:flex;align-items:center;gap:10px;font-family:var(--font-body);font-size:11px;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:30px;}
.page-hero .crumbs a:hover{color:var(--copper);}
.page-hero .crumbs .sep{color:var(--copper);}
.page-hero-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:60px;align-items:end;}
.page-hero h1{font-size:clamp(3rem,8vw,6.5rem);line-height:.9;letter-spacing:-.03em;}
.page-hero h1 .accent{color:var(--copper);}
.page-hero h1 .accent.magenta{color:var(--magenta);}
.page-hero h1 .accent.blue{color:var(--blue);}
.page-hero .lead{font-size:1.05rem;line-height:1.7;color:var(--ink-soft);max-width:480px;margin-top:24px;}
.page-hero-aside{display:flex;flex-direction:column;gap:10px;}
.page-hero-aside .ph-card{background:var(--paper);border:var(--border);border-radius:var(--r);padding:20px 24px;}
.page-hero-aside .ph-card .lbl{font-family:var(--font-body);font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--copper);font-weight:600;}
.page-hero-aside .ph-card .val{font-family:var(--font-display);font-size:1.25rem;font-weight:700;margin-top:6px;letter-spacing:-.01em;}
.page-hero-aside .ph-card .val small{font-family:var(--font-body);display:block;font-size:12px;color:var(--ink-mute);font-weight:500;margin-top:4px;letter-spacing:0;text-transform:none;}

/* Menu detail (services page) */
.menu-section{padding:100px 0;border-bottom:var(--border);}
.menu-section:nth-of-type(even){background:var(--bg-2);}
.menu-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:start;}
.menu-side{position:sticky;top:120px;}
.menu-side .num{font-family:var(--font-display);font-size:5rem;font-weight:700;line-height:1;color:var(--copper);letter-spacing:-.04em;}
.menu-side h2{margin:14px 0 24px;}
.menu-side h2 .accent{color:var(--copper);}
.menu-side p{font-size:1.02rem;line-height:1.7;color:var(--ink-soft);max-width:380px;}
.menu-side .badge-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:22px;}
.menu-side .badge-list span{font-family:var(--font-body);font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:600;padding:6px 14px;background:var(--paper);border:var(--border);border-radius:999px;}
.menu-prices{display:flex;flex-direction:column;gap:14px;}
.menu-prices .group{background:var(--paper);border:var(--border);border-radius:var(--r);padding:22px 26px;}
.menu-prices .group h4{font-family:var(--font-body);font-size:11px;font-weight:700;letter-spacing:.26em;text-transform:uppercase;color:var(--copper);margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid var(--line-soft);}
.menu-prices .item{display:grid;grid-template-columns:1fr auto;gap:16px;align-items:baseline;padding:11px 0;border-bottom:1px dashed var(--line-soft);}
.menu-prices .item:last-child{border-bottom:none;}
.menu-prices .item .name{font-family:var(--font-display);font-size:1.05rem;font-weight:600;letter-spacing:-.005em;}
.menu-prices .item .name small{display:block;font-family:var(--font-body);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-mute);margin-top:3px;font-weight:500;}
.menu-prices .item .price{font-family:var(--font-display);font-size:1.05rem;font-weight:700;color:var(--copper-deep);white-space:nowrap;}

/* Bridal packages */
.bridal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:60px;}
.pkg{background:var(--paper);border:var(--border);border-radius:var(--r-lg);padding:40px 32px;display:flex;flex-direction:column;transition:all .3s var(--ease);position:relative;}
.pkg:hover{transform:translate(-4px,-4px);box-shadow:var(--sh-hard);}
.pkg.featured{background:var(--ink);color:#fff;transform:translateY(-16px);}
.pkg.featured:hover{transform:translateY(-20px) translate(-2px,-2px);}
.pkg.featured h3,.pkg.featured .pkg-price{color:#fff;}
.pkg.featured .pkg-price small{color:rgba(250,245,236,.6);}
.pkg.featured p,.pkg.featured li{color:rgba(250,245,236,.78);}
.pkg.featured .ribbon-tag{position:absolute;top:-12px;right:24px;background:var(--copper);color:#fff;padding:5px 14px;border-radius:999px;font-family:var(--font-display);font-size:11px;font-weight:700;letter-spacing:.04em;}
.pkg h3{font-size:1.7rem;}
.pkg h3 .accent{color:var(--copper);}
.pkg .sub{font-family:var(--font-body);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--copper);margin:8px 0 22px;font-weight:600;}
.pkg .pkg-price{font-family:var(--font-display);font-size:2.6rem;font-weight:700;line-height:1;margin-bottom:28px;letter-spacing:-.02em;}
.pkg .pkg-price em{font-style:normal;color:var(--copper);font-size:.5em;vertical-align:middle;}
.pkg .pkg-price small{display:block;font-family:var(--font-body);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mute);margin-top:8px;font-weight:500;}
.pkg ul{list-style:none;padding:22px 0 28px;border-top:1px solid var(--line-soft);margin-top:16px;flex:1;}
.pkg.featured ul{border-color:rgba(250,245,236,.15);}
.pkg li{display:flex;gap:12px;align-items:flex-start;font-size:.95rem;line-height:1.5;padding:8px 0;color:var(--ink-soft);}
.pkg li::before{content:"";display:block;width:8px;height:8px;border-radius:50%;background:var(--copper);flex-shrink:0;margin-top:7px;}
.pkg .btn{width:100%;justify-content:center;}
.timeline{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:80px;}
.tl-step{border:var(--border);border-radius:var(--r);padding:30px 26px;background:var(--paper);position:relative;transition:all .3s var(--ease);}
.tl-step:hover{transform:translate(-3px,-3px);box-shadow:var(--sh-hard);}
.tl-step .num{font-family:var(--font-display);font-weight:700;font-size:2.4rem;color:var(--copper);line-height:1;margin-bottom:18px;letter-spacing:-.02em;}
.tl-step h4{font-family:var(--font-display);font-size:1.2rem;font-weight:600;margin-bottom:10px;}
.tl-step p{color:var(--ink-soft);font-size:.92rem;line-height:1.55;}

/* Booking form */
.book-wrap{display:grid;grid-template-columns:1.1fr 1fr;gap:80px;padding:100px 0;}
.book-form{background:var(--paper);border:var(--border);border-radius:var(--r-lg);padding:48px;}
.book-form .form-title{font-family:var(--font-display);font-size:2.4rem;font-weight:700;margin-bottom:8px;letter-spacing:-.02em;}
.book-form .form-title .accent{color:var(--copper);}
.book-form .form-intro{font-size:.98rem;color:var(--ink-soft);margin-bottom:32px;line-height:1.65;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;}
.form-field{display:flex;flex-direction:column;gap:8px;}
.form-field.full{grid-column:1/-1;}
.form-field label{font-family:var(--font-body);font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:var(--copper);font-weight:700;}
.form-field input,.form-field select,.form-field textarea{
  font-family:var(--font-body);font-size:1rem;background:var(--bg);color:var(--ink);
  border:var(--border);border-radius:var(--r-sm);padding:14px 16px;transition:all .2s ease;
}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{
  outline:none;border-color:var(--copper);box-shadow:4px 4px 0 var(--copper);
}
.form-field textarea{resize:vertical;min-height:120px;}
.book-form button[type=submit]{
  margin-top:12px;background:var(--ink);color:#fff;padding:18px;
  font-family:var(--font-body);font-size:13px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;
  border-radius:999px;cursor:pointer;width:100%;border:var(--border);
  display:inline-flex;justify-content:center;gap:10px;align-items:center;
  transition:all .25s var(--ease);
}
.book-form button[type=submit]:hover{transform:translate(-3px,-3px);box-shadow:var(--sh-hard);background:var(--copper);}
.book-form .small-note{margin-top:14px;text-align:center;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mute);}
.book-side .kicker{color:var(--copper-deep);}
.book-side .kicker .dot{background:var(--copper);}
.book-side h2{margin:16px 0 18px;}
.book-side h2 .accent{color:var(--copper);}
.book-side > p{color:var(--ink-soft);font-size:1rem;line-height:1.65;}
.book-side .quick{margin-top:32px;display:flex;flex-direction:column;gap:14px;}
.quick-row{display:flex;gap:16px;align-items:flex-start;background:var(--paper);border:var(--border);border-radius:var(--r);padding:22px 26px;transition:all .2s ease;}
.quick-row:hover{transform:translate(-3px,-3px);box-shadow:var(--sh-hard);}
.quick-row .ic{width:22px;height:22px;color:var(--copper);flex-shrink:0;margin-top:3px;}
.quick-row h4{font-family:var(--font-display);font-size:1.2rem;margin-bottom:4px;font-weight:600;}
.quick-row p{font-size:.92rem;color:var(--ink-soft);line-height:1.45;}

/* Studios detail */
.studio-block{display:grid;grid-template-columns:1.2fr 1fr;gap:60px;padding:110px 0;border-bottom:var(--border);align-items:start;}
.studio-block.reverse{grid-template-columns:1fr 1.2fr;}
.studio-block.reverse .studio-photos{order:2;}
.studio-photos{display:grid;grid-template-columns:2fr 1fr;gap:14px;height:560px;}
.studio-photos .main{grid-row:span 2;border:var(--border);border-radius:var(--r-lg);overflow:hidden;position:relative;}
.studio-photos .main img{width:100%;height:100%;object-fit:cover;}
.studio-photos .main .pin{position:absolute;top:16px;left:16px;background:var(--copper);color:#fff;padding:6px 14px;border-radius:999px;font-family:var(--font-display);font-weight:700;font-size:12px;}
.studio-photos .stack{display:grid;grid-template-rows:1fr 1fr;gap:14px;}
.studio-photos .stack > div{border:var(--border);border-radius:var(--r);overflow:hidden;}
.studio-photos .stack img{width:100%;height:100%;object-fit:cover;}
.studio-info .kicker{color:var(--copper-deep);}
.studio-info .kicker .dot{background:var(--copper);}
.studio-info h2{margin:14px 0 18px;}
.studio-info h2 .accent{color:var(--copper);}
.studio-info p{font-size:1.02rem;line-height:1.7;color:var(--ink-soft);}
.studio-facts{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:32px 0;}
.fact-card{background:var(--paper);border:var(--border);border-radius:var(--r);padding:22px;}
.fact-card .lbl{font-family:var(--font-body);font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:var(--copper);font-weight:700;margin-bottom:6px;}
.fact-card .val{font-family:var(--font-display);font-size:1.05rem;font-weight:600;line-height:1.4;}
.studio-map{margin-top:14px;border:var(--border);border-radius:var(--r);overflow:hidden;height:280px;}
.studio-map iframe{width:100%;height:100%;border:0;filter:grayscale(.4) contrast(.95);}
.studio-actions{display:flex;gap:10px;margin-top:26px;flex-wrap:wrap;}

/* Atelier values */
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:70px;}
.value-card{padding:36px 32px;background:var(--paper);border:var(--border);border-radius:var(--r-lg);transition:all .3s var(--ease);}
.value-card:hover{transform:translate(-4px,-4px);box-shadow:var(--sh-hard);}
.value-card .num{font-family:var(--font-display);font-size:2rem;font-weight:700;color:var(--copper);margin-bottom:18px;line-height:1;}
.value-card h3{font-size:1.5rem;margin-bottom:12px;}
.value-card h3 .accent{color:var(--copper);}
.value-card p{color:var(--ink-soft);font-size:.96rem;line-height:1.65;}

/* Testimonials */
.tests{background:var(--bg-2);border-top:var(--border);padding:120px 0;}
.test-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:60px;}
.test-card{background:var(--paper);border:var(--border);border-radius:var(--r-lg);padding:36px 32px;transition:all .3s var(--ease);}
.test-card:hover{transform:translate(-4px,-4px);box-shadow:var(--sh-hard);}
.test-stars{color:var(--copper);margin-bottom:18px;font-size:1.1rem;letter-spacing:4px;}
.test-quote{font-family:var(--font-display);font-size:1.2rem;line-height:1.5;color:var(--ink);margin-bottom:26px;font-weight:500;}
.test-author{display:flex;align-items:center;gap:14px;padding-top:22px;border-top:1px solid var(--line-soft);}
.test-avatar{width:44px;height:44px;border-radius:50%;background:var(--copper);color:#fff;display:grid;place-items:center;font-family:var(--font-display);font-weight:700;font-size:1.05rem;flex-shrink:0;}
.test-name{font-weight:600;color:var(--ink);font-size:.95rem;}
.test-service{font-size:11px;color:var(--ink-mute);letter-spacing:.14em;text-transform:uppercase;margin-top:2px;}

/* RESPONSIVE */
@media (max-width:1024px){
  .hero-bento{grid-template-columns:1fr 1fr;grid-template-rows:auto auto auto;}
  .bento--say{grid-column:1 / span 2;grid-row:1;min-height:380px;}
  .bento--portrait1{grid-column:1;grid-row:2;}
  .bento--portrait2{grid-column:2;grid-row:2;}
  .bento--portrait3{grid-column:1;grid-row:3;}
  .bento--reel{grid-column:2;grid-row:3;}
  .sec-head{grid-template-columns:1fr;gap:24px;}
  .svc-grid{grid-template-columns:1fr 1fr;}
  .diary-row{grid-template-columns:1fr 1fr;}
  .poly-row{grid-template-columns:1fr;gap:50px;max-width:460px;margin:60px auto 0;}
  .poly:nth-child(n){transform:rotate(0deg);margin-top:0;}
  .loc-grid{grid-template-columns:1fr;}
  .featured-grid{grid-template-columns:1fr;gap:50px;}
  .nav-links{display:none;}
  .hamburger{display:grid;}
  .timeline,.bridal-grid{grid-template-columns:1fr;}
  .pkg.featured{transform:none;}
  .menu-grid{grid-template-columns:1fr;gap:40px;}
  .menu-side{position:static;}
  .menu-side .num{font-size:4rem;}
  .book-wrap{grid-template-columns:1fr;gap:50px;padding:60px 0;}
  .book-form{padding:32px 24px;}
  .form-row{grid-template-columns:1fr;}
  .test-grid{grid-template-columns:1fr;}
  .values-grid{grid-template-columns:1fr;gap:16px;}
  .studio-block,.studio-block.reverse{grid-template-columns:1fr;gap:40px;}
  .studio-block.reverse .studio-photos{order:0;}
  .studio-photos{height:400px;}
  .page-hero-grid{grid-template-columns:1fr;gap:30px;}
}
@media (max-width:640px){
  section{padding:80px 0;}
  .hero{padding:90px 0 40px;}
  .hero-bento{gap:12px;grid-template-columns:1fr;}
  .bento--say,.bento--portrait1,.bento--portrait2,.bento--portrait3,.bento--reel{
    grid-column:1;grid-row:auto;min-height:320px;
  }
  .hero-meta-strip{padding:16px 18px;gap:14px;}
  .hero-meta-strip .sep{display:none;}
  .svc-grid{grid-template-columns:1fr;}
  .diary-row{grid-template-columns:1fr 1fr;gap:12px;}
  .strip-card{flex:0 0 220px;}
  .studio-photos{grid-template-columns:1fr;height:auto;}
  .studio-photos .main{aspect-ratio:4/3;grid-row:auto;}
  .studio-photos .stack{grid-template-columns:1fr 1fr;grid-template-rows:auto;}
  .studio-photos .stack > div{aspect-ratio:1/1;}
  .studio-facts{grid-template-columns:1fr;}
  .mobile-cta{display:block;}
  .nav-cta > .btn:not(.btn-icon-only){display:none;}
  .nav-inner{gap:12px;}
  .book-form{padding:24px 18px;}
  .ribbon-item{font-size:1.2rem;}
  .ribbon-track{gap:36px;}
  .foot-top{grid-template-columns:1fr;gap:32px;}
  .foot-bottom{flex-direction:column;gap:14px;text-align:center;}
  .featured-img .tag-tape{font-size:1.2rem;padding:4px 18px;}
}

.reveal{opacity:1;}

/* ============================================================
   PREMIUM POLISH (v13)
   Native smooth scroll, custom scrollbar, subtle grain on dark
   surfaces, refined focus states, anti-flash on initial paint.
   ============================================================ */

html {
  scroll-behavior: smooth;
}
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
}

/* Custom scrollbar — copper accent, lives in the brand palette */
* {
  scrollbar-width: thin;
  scrollbar-color: var(--copper) transparent;
}
*::-webkit-scrollbar { width: 11px; height: 11px; }
*::-webkit-scrollbar-track { background: var(--bg-2); }
*::-webkit-scrollbar-thumb {
  background: var(--copper);
  border: 3px solid var(--bg-2);
  border-radius: 999px;
}
*::-webkit-scrollbar-thumb:hover { background: var(--copper-deep); }

/* Refined focus states — keyboard users get a copper ring, mouse users don't */
:focus { outline: none; }
:focus-visible {
  outline: 2.5px solid var(--copper);
  outline-offset: 3px;
  border-radius: 4px;
}
.btn:focus-visible {
  outline-offset: 4px;
}

/* Subtle film grain on the dark hero cell — that handcrafted print-poster feel.
   SVG noise via a 1KB inline data-URI. Invisible on its own; reads as texture. */
.bento--say,
.diary,
.ribbon,
footer,
.cta-block,
.page-hero,
.pkg.featured,
.cta-block.cta-block /* specificity boost */ {
  position: relative;
}
.bento--say::after,
.diary::after,
.cta-block::after,
.page-hero::after,
footer::after {
  /* Keep existing pseudo-elements where present by scoping noise to its own layer */
}
.bento--say > *,
.diary > *,
.cta-block > *,
.page-hero > *,
footer > * { position: relative; z-index: 2; }

/* Grain layer — applied via background-image so it doesn't conflict with existing ::before/::after */
.bento--say,
.diary,
footer {
  background-image:
    linear-gradient(transparent, transparent),  /* placeholder for var() composability */
    url("data:image/svg+xml;utf8,<svg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.55 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.18'/></svg>");
  background-blend-mode: normal, overlay;
}

/* Reset for places where we explicitly want clean — diary keeps its background */
.diary { background: var(--ink-block); }
.bento--say { background: var(--ink); }
footer { background: var(--ink-block); }
.diary, .bento--say, footer {
  background-image:
    url("data:image/svg+xml;utf8,<svg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.55 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.22'/></svg>"),
    linear-gradient(var(--ink-block), var(--ink-block));
  background-size: 200px 200px, 100% 100%;
}
.bento--say {
  background-image:
    url("data:image/svg+xml;utf8,<svg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.55 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.22'/></svg>"),
    linear-gradient(var(--ink), var(--ink));
  background-size: 200px 200px, 100% 100%;
}

/* Refined hero badge dot — pulse animation */
.bento--say .badge {
  position: relative;
}
.bento--say .badge::before {
  content: ""; display: inline-block;
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--copper);
  margin-right: 8px; vertical-align: middle;
  animation: pulse 2s var(--ease) infinite;
}
.bento--say .badge::first-letter { visibility: hidden; margin-right: -10px; } /* hide ● */
@keyframes pulse {
  0%, 100% { box-shadow: 0 0 0 0 color-mix(in srgb, var(--copper) 70%, transparent); }
  50% { box-shadow: 0 0 0 6px transparent; }
}

/* Better selection on dark contexts */
.bento--say ::selection,
.diary ::selection,
.cta-block ::selection,
footer ::selection { background: var(--copper); color: #fff; }

/* Anti-flash white during font swap */
@supports (font-display: swap) {
  body { font-display: swap; }
}

/* Image lazy-load smoothness */
img { content-visibility: auto; }

/* Slightly elevate the polaroid shadow on hover for depth feel */
.poly:hover { box-shadow: 0 28px 60px rgba(26,24,21,0.18); }

/* Diary entry — add hand-drawn corner numeral that reads as marginalia */
.diary-entry .meta .code::before {
  content: "★ ";
  color: var(--copper);
}

/* Refined CTA block — diagonal stripes feel of a fashion poster */
.cta-block {
  background:
    linear-gradient(135deg, var(--copper) 0%, var(--copper) 60%, var(--copper-deep) 100%);
}

/* Service card price tag — micro-rotation for the handmade feel */
.svc-img .price-tag {
  transform: rotate(2deg);
  transition: transform .25s var(--ease);
}
.svc-card:hover .svc-img .price-tag {
  transform: rotate(-2deg) scale(1.05);
}

/* Strip card — slight rotation for editorial pinboard feel */
.strip-card:nth-child(2n) { transform: rotate(-1deg); }
.strip-card:nth-child(3n) { transform: rotate(0.6deg); }

/* Page-hero — add a subtle copper underline accent under H1 */
.page-hero h1 { position: relative; }

/* Print-style separator for menu side */
.menu-side h2::after {
  content: ""; display: block;
  width: 60px; height: 4px;
  background: var(--copper);
  margin-top: 20px;
}

/* Loading spinner for video reels (graceful fallback if reel doesn't load) */
.bento--reel { background: linear-gradient(135deg, var(--ink) 0%, #2A2419 100%); }
.bento--reel::before {
  content: "▶";
  position: absolute; inset: 0;
  display: grid; place-items: center;
  color: rgba(212,97,42,0.4);
  font-size: 4rem;
  z-index: 0;
}
.bento--reel video { position: relative; z-index: 1; }


/* ============================================================
   REAL LUXE WORDMARK — the actual brand identity
   Renders BARIKS / LUXE / SALON with gold droplet over LUXE
   ============================================================ */
.brand-luxe {
  display:inline-flex; flex-direction:column; align-items:center;
  line-height: 1;
  font-family: var(--font-display);
  color: var(--ink);
  text-align: center;
  gap: 1px;
  text-decoration: none;
}
.brand-luxe .pre {
  font-size: 9px; font-weight: 600;
  letter-spacing: .5em; text-transform: uppercase;
  color: var(--ink-soft);
  margin-bottom: 1px;
  padding-left: .5em;  /* compensate letter-spacing */
}
.brand-luxe .mid {
  position: relative;
  font-family: var(--font-display);
  font-size: 1.65rem; font-weight: 700;
  letter-spacing: .04em;
  color: var(--ink);
  padding-top: 4px;
}
.brand-luxe .mid::before {
  content: "";
  position: absolute;
  left: 50%; top: -3px;
  transform: translateX(-50%);
  width: 7px; height: 11px;
  background: var(--copper);
  border-radius: 50% 50% 50% 50% / 30% 30% 70% 70%;
  /* teardrop shape pointing up */
}
.brand-luxe .post {
  font-size: 9px; font-weight: 600;
  letter-spacing: .42em; text-transform: uppercase;
  color: var(--ink-soft);
  padding-left: .42em;
  margin-top: -2px;
}

/* Mobile — slimmer */
@media (max-width: 640px) {
  .brand-luxe .mid { font-size: 1.35rem; }
  .brand-luxe .pre, .brand-luxe .post { font-size: 8px; letter-spacing: .42em; }
}

/* Footer brand — white version */
.foot-brand .brand-luxe { color: #fff; }
.foot-brand .brand-luxe .mid { color: #fff; }
.foot-brand .brand-luxe .pre,
.foot-brand .brand-luxe .post { color: rgba(255,255,255,.55); }

/* Inverse: when nav is over dark hero & not yet scrolled */
.nav:not(.scrolled) .brand-luxe .mid { color: var(--ink); }  /* default kept */

/* Subtle Calicut-now badge in hero */
.calicut-badge {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--copper); color: var(--ink);
  border-radius: 999px;
  padding: 6px 14px;
  font-family: var(--font-body);
  font-size: 11px; font-weight: 700;
  letter-spacing: .14em; text-transform: uppercase;
  margin-bottom: 12px;
}
.calicut-badge::before {
  content: ""; width: 8px; height: 8px; border-radius: 50%;
  background: var(--ink);
  animation: pulse 2s var(--ease) infinite;
}

/* Featured location card (Calicut first, badged) */
.loc-card.featured {
  border-width: 2.5px;
  position: relative;
}
.loc-card.featured::before {
  content: "Now booking";
  position: absolute; top: -12px; left: 24px; z-index: 5;
  background: var(--copper); color: var(--ink);
  font-family: var(--font-display);
  font-size: 11px; font-weight: 700;
  letter-spacing: .04em; text-transform: uppercase;
  padding: 5px 14px; border-radius: 999px;
}

/* ============================================================
   SOCIAL ICONS — explicit colors + inline SVG fallback
   Ensures the footer social icons always render even if Lucide
   fails to inject SVGs (e.g., on slow network or CDN block).
   ============================================================ */
.socials a {
  position: relative;
  font-size: 0;  /* hide any text inside */
}
.socials a::before {
  content: "";
  display: inline-block;
  width: 16px; height: 16px;
  background-color: rgba(250,245,236,.7);
  -webkit-mask-size: contain; mask-size: contain;
  -webkit-mask-repeat: no-repeat; mask-repeat: no-repeat;
  -webkit-mask-position: center; mask-position: center;
  transition: background-color .25s ease;
}
.socials a[aria-label="Instagram"]::before {
  -webkit-mask-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><rect x='2' y='2' width='20' height='20' rx='5' ry='5'/><path d='M16 11.37A4 4 0 1 1 12.63 8 4 4 0 0 1 16 11.37z'/><line x1='17.5' y1='6.5' x2='17.51' y2='6.5'/></svg>");
  mask-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><rect x='2' y='2' width='20' height='20' rx='5' ry='5'/><path d='M16 11.37A4 4 0 1 1 12.63 8 4 4 0 0 1 16 11.37z'/><line x1='17.5' y1='6.5' x2='17.51' y2='6.5'/></svg>");
}
.socials a[aria-label="Facebook"]::before {
  -webkit-mask-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black' stroke='none'><path d='M22 12c0-5.523-4.477-10-10-10S2 6.477 2 12c0 4.991 3.657 9.128 8.438 9.878v-6.987h-2.54V12h2.54V9.797c0-2.506 1.492-3.89 3.777-3.89 1.094 0 2.238.195 2.238.195v2.46h-1.26c-1.243 0-1.63.771-1.63 1.562V12h2.773l-.443 2.89h-2.33v6.988C18.343 21.128 22 16.991 22 12z'/></svg>");
  mask-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black' stroke='none'><path d='M22 12c0-5.523-4.477-10-10-10S2 6.477 2 12c0 4.991 3.657 9.128 8.438 9.878v-6.987h-2.54V12h2.54V9.797c0-2.506 1.492-3.89 3.777-3.89 1.094 0 2.238.195 2.238.195v2.46h-1.26c-1.243 0-1.63.771-1.63 1.562V12h2.773l-.443 2.89h-2.33v6.988C18.343 21.128 22 16.991 22 12z'/></svg>");
}
.socials a[aria-label="YouTube"]::before {
  -webkit-mask-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black' stroke='none'><path d='M23.498 6.186a3.016 3.016 0 0 0-2.122-2.136C19.505 3.545 12 3.545 12 3.545s-7.505 0-9.377.505A3.017 3.017 0 0 0 .502 6.186C0 8.07 0 12 0 12s0 3.93.502 5.814a3.016 3.016 0 0 0 2.122 2.136c1.871.505 9.376.505 9.376.505s7.505 0 9.377-.505a3.015 3.015 0 0 0 2.122-2.136C24 15.93 24 12 24 12s0-3.93-.502-5.814zM9.545 15.568V8.432L15.818 12l-6.273 3.568z'/></svg>");
  mask-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black' stroke='none'><path d='M23.498 6.186a3.016 3.016 0 0 0-2.122-2.136C19.505 3.545 12 3.545 12 3.545s-7.505 0-9.377.505A3.017 3.017 0 0 0 .502 6.186C0 8.07 0 12 0 12s0 3.93.502 5.814a3.016 3.016 0 0 0 2.122 2.136c1.871.505 9.376.505 9.376.505s7.505 0 9.377-.505a3.015 3.015 0 0 0 2.122-2.136C24 15.93 24 12 24 12s0-3.93-.502-5.814zM9.545 15.568V8.432L15.818 12l-6.273 3.568z'/></svg>");
}
.socials a[aria-label="WhatsApp"]::before {
  -webkit-mask-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black' stroke='none'><path d='M17.472 14.382c-.297-.149-1.758-.867-2.03-.967-.273-.099-.471-.148-.67.15-.197.297-.767.966-.94 1.164-.173.199-.347.223-.644.075-.297-.15-1.255-.463-2.39-1.475-.883-.788-1.48-1.761-1.653-2.059-.173-.297-.018-.458.13-.606.134-.133.298-.347.446-.52.149-.174.198-.298.298-.497.099-.198.05-.371-.025-.52-.075-.149-.669-1.612-.916-2.207-.242-.579-.487-.5-.669-.51-.173-.008-.371-.01-.57-.01-.198 0-.52.074-.792.372-.272.297-1.04 1.016-1.04 2.479 0 1.462 1.065 2.875 1.213 3.074.149.198 2.096 3.2 5.077 4.487.709.306 1.262.489 1.694.625.712.227 1.36.195 1.871.118.571-.085 1.758-.719 2.006-1.413.248-.694.248-1.289.173-1.413-.074-.124-.272-.198-.57-.347m-5.421 7.403h-.004a9.87 9.87 0 0 1-5.031-1.378l-.361-.214-3.741.982.998-3.648-.235-.374a9.86 9.86 0 0 1-1.51-5.26c.001-5.45 4.436-9.884 9.888-9.884 2.64 0 5.122 1.03 6.988 2.898a9.825 9.825 0 0 1 2.893 6.994c-.003 5.45-4.437 9.884-9.885 9.884m8.413-18.297A11.815 11.815 0 0 0 12.05 0C5.495 0 .16 5.335.157 11.892c0 2.096.547 4.142 1.588 5.945L.057 24l6.305-1.654a11.882 11.882 0 0 0 5.683 1.448h.005c6.554 0 11.89-5.335 11.893-11.893A11.821 11.821 0 0 0 20.885 3.488'/></svg>");
  mask-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black' stroke='none'><path d='M17.472 14.382c-.297-.149-1.758-.867-2.03-.967-.273-.099-.471-.148-.67.15-.197.297-.767.966-.94 1.164-.173.199-.347.223-.644.075-.297-.15-1.255-.463-2.39-1.475-.883-.788-1.48-1.761-1.653-2.059-.173-.297-.018-.458.13-.606.134-.133.298-.347.446-.52.149-.174.198-.298.298-.497.099-.198.05-.371-.025-.52-.075-.149-.669-1.612-.916-2.207-.242-.579-.487-.5-.669-.51-.173-.008-.371-.01-.57-.01-.198 0-.52.074-.792.372-.272.297-1.04 1.016-1.04 2.479 0 1.462 1.065 2.875 1.213 3.074.149.198 2.096 3.2 5.077 4.487.709.306 1.262.489 1.694.625.712.227 1.36.195 1.871.118.571-.085 1.758-.719 2.006-1.413.248-.694.248-1.289.173-1.413-.074-.124-.272-.198-.57-.347m-5.421 7.403h-.004a9.87 9.87 0 0 1-5.031-1.378l-.361-.214-3.741.982.998-3.648-.235-.374a9.86 9.86 0 0 1-1.51-5.26c.001-5.45 4.436-9.884 9.888-9.884 2.64 0 5.122 1.03 6.988 2.898a9.825 9.825 0 0 1 2.893 6.994c-.003 5.45-4.437 9.884-9.885 9.884m8.413-18.297A11.815 11.815 0 0 0 12.05 0C5.495 0 .16 5.335.157 11.892c0 2.096.547 4.142 1.588 5.945L.057 24l6.305-1.654a11.882 11.882 0 0 0 5.683 1.448h.005c6.554 0 11.89-5.335 11.893-11.893A11.821 11.821 0 0 0 20.885 3.488'/></svg>");
}
/* Hover — flips to gold */
.socials a:hover::before { background-color: var(--copper); }
/* Hide the original Lucide <i> since CSS-mask version always works */
.socials a .ic { display: none; }

/* ===== v17 — hero say-tile refinements + poly disclaimer ===== */
.bento--say .top {
  align-items: center;
  margin-bottom: 6px;
}
.say-coords {
  font-family: var(--font-body);
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--bg) 55%, transparent);
  font-feature-settings: "tnum" 1;
}
.bento--say h1.hero-shout {
  font-size: clamp(2.4rem, 4.6vw, 4.2rem);
  line-height: .96;
  letter-spacing: -0.03em;
  margin-top: 8px;
  margin-bottom: 18px;
}
.bento--say .bot { gap: 14px; }
.say-lede {
  font-size: 1.05rem !important;
  line-height: 1.55;
  color: color-mix(in srgb, var(--bg) 88%, transparent) !important;
}
.say-lede strong {
  color: var(--copper);
  font-weight: 700;
  letter-spacing: .01em;
}
.poly-note {
  margin-top: 26px;
  font-family: var(--font-body);
  font-size: 12px;
  line-height: 1.55;
  color: color-mix(in srgb, var(--ink) 55%, transparent);
  max-width: 760px;
  font-style: italic;
  border-left: 2px solid var(--copper);
  padding-left: 14px;
}

/* ===== v18 — say-tile cover redesign (no more black void) ===== */
.bento--say {
  position: relative;
  overflow: hidden;
  justify-content: flex-start !important;
  gap: 28px;
  min-height: 540px;
  padding: 32px 30px 34px !important;
  background:
    linear-gradient(180deg,
      rgba(20,18,16,0.78) 0%,
      rgba(20,18,16,0.62) 35%,
      rgba(20,18,16,0.55) 55%,
      rgba(20,18,16,0.88) 100%),
    url("assets/best/studio-marble-mirror.jpg") center/cover no-repeat,
    var(--ink) !important;
}
/* big ghosted DBC watermark */
.bento--say::before {
  content: "DBC";
  position: absolute;
  left: -8px;
  bottom: 38%;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(120px, 22vw, 240px);
  line-height: .8;
  letter-spacing: -0.06em;
  color: rgba(212, 97, 42, 0.10);
  pointer-events: none;
  z-index: 1;
  mix-blend-mode: screen;
}
/* tiny serial mark in corner */
.bento--say::after {
  content: "DOHA BEAUTY CENTER · EST. 1990";
  position: absolute;
  right: 26px;
  bottom: 18px;
  font-family: var(--font-body);
  font-size: 9px;
  letter-spacing: .3em;
  color: rgba(250,247,242,0.35);
  z-index: 2;
  writing-mode: horizontal-tb;
}
.bento--say > * { position: relative; z-index: 3; }
.bento--say .top { margin-bottom: 0; }
.bento--say h1.hero-shout {
  margin-top: auto !important;
  text-shadow: 0 2px 18px rgba(0,0,0,0.35);
}
.bento--say .bot {
  margin-top: 6px;
  gap: 16px;
}
.bento--say .bot .say-lede {
  background: rgba(20,18,16,0.35);
  backdrop-filter: blur(2px);
  padding: 10px 14px;
  border-left: 2px solid var(--copper);
  border-radius: 2px;
}
.say-coords {
  color: rgba(250,247,242,0.65) !important;
  background: rgba(20,18,16,0.5);
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 9px !important;
}

/* ===== v20 — 5-branch location grid + real reviews + readability ===== */
/* Calicut featured card spans full width, image + info side by side */
.loc-card.featured { grid-column: 1 / -1; flex-direction: row; }
.loc-card.featured .loc-img { flex: 1 1 52%; aspect-ratio: auto; min-height: 340px; }
.loc-card.featured .loc-body { flex: 1 1 48%; justify-content: center; }
.loc-card.featured .loc-body h3 { font-size: 2.6rem; }
.loc-card.featured .pin { background: var(--copper); color: var(--ink); }
@media (max-width: 760px){
  .loc-card.featured { flex-direction: column; }
  .loc-card.featured .loc-img { aspect-ratio: 16/10; min-height: 0; }
}

/* Real reviews */
.reviews { padding: 110px 0; border-top: var(--border); }
.rev-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; margin-top: 56px; }
.rev-card {
  border: var(--border); border-radius: var(--r-lg); background: var(--paper);
  padding: 34px 32px; display: flex; flex-direction: column; gap: 18px;
  transition: transform .25s var(--ease), box-shadow .25s var(--ease);
}
.rev-card:hover { transform: translate(-4px,-4px); box-shadow: var(--sh-hard); }
.rev-stars { color: var(--copper); letter-spacing: 4px; font-size: 1.05rem; }
.rev-card blockquote {
  font-family: var(--font-display); font-weight: 500;
  font-size: 1.28rem; line-height: 1.42; color: var(--ink); margin: 0;
}
.rev-card figcaption { display: flex; flex-direction: column; gap: 3px; margin-top: auto; }
.rev-name { font-family: var(--font-display); font-weight: 700; font-size: 1rem; color: var(--ink); }
.rev-meta { font-family: var(--font-body); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--copper); font-weight: 600; }
@media (max-width: 900px){ .rev-grid { grid-template-columns: 1fr; } }

/* Readability: ensure meta-strip labels have enough contrast */
.hero-meta-strip .item { color: #6B6258; }

/* ===== v20 — signature motion polish (fail-open, reduced-motion safe) ===== */
/* Image hover-zoom on real-photo cards */
.diary-entry, .svc-img, .loc-img, .featured-img, .strip-card { overflow: hidden; }
.diary-entry img, .svc-img img, .loc-img img, .featured-img img, .strip-card img {
  transition: transform .65s cubic-bezier(.22,1,.36,1);
  will-change: transform;
}
.diary-entry:hover img,
.svc-card:hover .svc-img img,
.loc-card:hover .loc-img img,
.featured-img:hover img { transform: scale(1.055); }

/* Magnetic buttons get a smooth return */
.btn-copper, .btn-ink { transition: transform .35s cubic-bezier(.22,1,.36,1), background .25s var(--ease), color .25s var(--ease); }

@media (prefers-reduced-motion: reduce){
  .diary-entry img,.svc-img img,.loc-img img,.featured-img img,.strip-card img{ transition: none; }
  .btn-copper,.btn-ink{ transition: none; }
}

/* ============================================================
   DOHA BEAUTY CENTER — Arabic / RTL bilingual additions
   ============================================================ */

/* Language toggle button */
.lang-toggle {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 7px 14px;
  font-family: var(--font-body); font-size: 11px; font-weight: 600;
  letter-spacing: .14em; text-transform: uppercase;
  color: var(--ink); border: var(--border); border-radius: 999px;
  background: var(--paper); cursor: pointer;
  transition: all .25s var(--ease);
  white-space: nowrap;
}
.lang-toggle:hover { background: var(--ink); color: var(--bg); }
.lang-toggle .ar-label { font-family: var(--font-arabic); font-size: 13px; letter-spacing: 0; text-transform: none; }

/* Bilingual text pairs — show EN by default, swap on [dir=rtl] */
.bi-en { display: block; }
.bi-ar { display: none; font-family: var(--font-arabic); }

html[dir="rtl"] .bi-en { display: none; }
html[dir="rtl"] .bi-ar { display: block; }

html[dir="rtl"] .bi-en.inline { display: none; }
html[dir="rtl"] .bi-ar.inline { display: inline; }
.bi-ar.inline { display: none; }
.bi-en.inline { display: inline; }

/* RTL layout adjustments */
html[dir="rtl"] body { font-family: var(--font-arabic); }
html[dir="rtl"] h1, html[dir="rtl"] h2, html[dir="rtl"] h3,
html[dir="rtl"] h4, html[dir="rtl"] .kicker,
html[dir="rtl"] .svc-body .svc-no { font-family: var(--font-arabic); }
html[dir="rtl"] .faq summary { font-family: var(--font-arabic); }
html[dir="rtl"] .rev-card blockquote { font-family: var(--font-arabic); }
html[dir="rtl"] .mobile-menu a { font-family: var(--font-arabic); font-size: 1.8rem; }

/* RTL flips */
html[dir="rtl"] .kicker { flex-direction: row-reverse; }
html[dir="rtl"] .bento--say .bot .say-lede { border-left: none; border-right: 2px solid var(--copper); }
html[dir="rtl"] .poly-note { border-left: none; border-right: 2px solid var(--copper); padding-left: 0; padding-right: 14px; }
html[dir="rtl"] .svc-cta::after { content: "←"; }
html[dir="rtl"] .loc-card.featured { direction: rtl; }
html[dir="rtl"] .menu-prices .item { direction: rtl; }
html[dir="rtl"] .foot-top { direction: rtl; }
html[dir="rtl"] .nav-links { direction: rtl; }
html[dir="rtl"] .foot-col ul { direction: rtl; }
html[dir="rtl"] .ribbon-track { animation-direction: reverse; }

/* Hero-say watermark replaces LUXE text in AR mode */
html[dir="rtl"] .bento--say::before { content: "جمال"; font-family: var(--font-arabic); }

/* Hero watermark in RTL */
html[dir="rtl"] .bento--say::after { content: "مركز دوحة للتجميل"; right: auto; left: 26px; font-family: var(--font-arabic); letter-spacing: .08em; }

/* Brand monogram (DBC) in nav */
.brand-dbc {
  display: inline-flex; flex-direction: column; align-items: center;
  line-height: 1; font-family: var(--font-display);
  color: var(--ink); text-align: center; gap: 1px; text-decoration: none;
}
.brand-dbc .pre { font-size: 9px; font-weight: 600; letter-spacing: .5em; text-transform: uppercase; color: var(--ink-soft); padding-left: .5em; }
.brand-dbc .mid {
  position: relative; font-family: var(--font-display);
  font-size: 1.65rem; font-weight: 700; letter-spacing: .04em; color: var(--ink); padding-top: 4px;
}
.brand-dbc .mid::before {
  content: ""; position: absolute; left: 50%; top: -3px;
  transform: translateX(-50%); width: 7px; height: 11px;
  background: var(--rosegold); border-radius: 50% 50% 50% 50% / 30% 30% 70% 70%;
}
.brand-dbc .post { font-size: 9px; font-weight: 600; letter-spacing: .42em; text-transform: uppercase; color: var(--ink-soft); padding-left: .42em; margin-top: -2px; }

.foot-brand .brand-dbc { color: #fff; }
.foot-brand .brand-dbc .mid { color: #fff; }
.foot-brand .brand-dbc .pre, .foot-brand .brand-dbc .post { color: rgba(255,255,255,.55); }
@media (max-width: 640px) {
  .brand-dbc .mid { font-size: 1.35rem; }
  .brand-dbc .pre, .brand-dbc .post { font-size: 8px; letter-spacing: .38em; }
  .lang-toggle { padding: 6px 10px; font-size: 10px; }
}

/* DBC hero tile — replace background image with spa-appropriate warm tone */
.bento--say {
  background:
    linear-gradient(180deg,
      rgba(30,20,18,0.75) 0%,
      rgba(30,20,18,0.55) 40%,
      rgba(30,20,18,0.52) 60%,
      rgba(30,20,18,0.88) 100%),
    url("assets/r/model-1.jpg") center/cover no-repeat,
    var(--ink) !important;
}

/* Calicut → Doha badge rename */
.calicut-badge {
  background: var(--rosegold); color: var(--paper);
}

/* Rose-gold accents for bridal/beauty feel */
.bento--portrait1 .corner-tag,
.bento--portrait2 .corner-tag,
.bento--portrait3 .corner-tag { background: var(--rosegold); color: var(--paper); }

/* Loc card featured override — primary branch */
.loc-card.featured::before { content: "D-Ring Road · Flagship"; background: var(--copper); color: var(--ink); }

/* Review card — set Cormorant for blockquotes */
.rev-card blockquote { font-size: 1.18rem; font-style: italic; }
