/* ═══════════════════════════════════════════
   VARIABLES
═══════════════════════════════════════════ */
:root {
  /* Brand rose — ≥4.5:1 on cream backgrounds (WCAG AA body text) */
  --gold:       #c4456a;
  --gold-dark:  #a84362;
  --gold-light: #fef8f1;
  --gold-mist:  rgba(176,125,98,0.08);
  --cream:      #fffef7;
  --cream-warm: #fef6ef;
  --cream-deep: #feeee3;
  --ink:        #2a1f17;
  --ink-mid:    #5a4839;
  /* Secondary text — ≥4.5:1 on cream / cream-warm */
  --ink-soft:   #75665a;
  --border:     #ede0d8;
  --white:      #ffffff;
  --r:          28px;
  --r-sm:       16px;
  --sh:         0 20px 50px rgba(42,31,23,0.09);
  --sh-sm:      0 8px 24px rgba(42,31,23,0.06);
  --ease:       cubic-bezier(0.25,0.46,0.45,0.94);
}

/* ═══════════════════════════════════════════
   RESET
═══════════════════════════════════════════ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;background:var(--cream);color:var(--ink);line-height:1.65;overflow-x:hidden}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
button{font-family:inherit}

/* ═══════════════════════════════════════════
   SCROLL REVEAL – BIDIRECTIONAL
   Items fade-up khi enter, fade-down khi leave
═══════════════════════════════════════════ */
.sr {
  opacity: 0;
  transform: translateY(48px);
  transition: opacity 0.7s var(--ease), transform 0.7s var(--ease);
}
.sr.sr-left  { transform: translateX(-48px); }
.sr.sr-right { transform: translateX(48px); }
.sr.sr-zoom  { transform: scale(0.92); }
.sr.sr-fast  { transition-duration: 0.5s; }
.sr.sr-flip {
  transform: perspective(1000px) rotateX(-12deg) translateY(36px);
  transform-origin: center top;
}
.sr.sr-rise {
  opacity: 0;
  transform: translateY(72px);
  transition-duration: 0.85s;
}
.sr.sr-blur-in {
  opacity: 0;
  filter: blur(10px);
  transform: translateY(28px);
  transition: opacity 0.75s var(--ease), transform 0.75s var(--ease), filter 0.85s var(--ease);
}
.sr.sr-blur-in.visible {
  filter: blur(0);
}

/* visible = fade UP into view */
.sr.visible {
  opacity: 1 !important;
  transform: none !important;
}

/* hidden = fade DOWN out of view (scroll past) */
.sr.hidden-below {
  opacity: 0 !important;
  transform: translateY(-36px) !important;
}
.sr.sr-left.hidden-below  { transform: translateX(-48px) !important; }
.sr.sr-right.hidden-below { transform: translateX(48px) !important; }
.sr.sr-zoom.hidden-below  { transform: scale(0.96) !important; }
.sr.sr-flip.hidden-below {
  transform: perspective(800px) rotateX(8deg) translateY(-28px) !important;
}
.sr.sr-rise.hidden-below { transform: translateY(-40px) !important; }
.sr.sr-blur-in.hidden-below {
  filter: blur(6px);
  transform: translateY(-24px) !important;
}

/* delay helpers */
.d1{transition-delay:0.05s}.d2{transition-delay:0.12s}.d3{transition-delay:0.19s}.d4{transition-delay:0.26s}.d5{transition-delay:0.33s}.d6{transition-delay:0.4s}

/* Scroll-triggered Animate.css (WOW-style) */
.reveal-anim {
  opacity: 1;
  --animate-duration: 0.85s;
}

/* Typing hero line */
.hero-typed-line {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.15rem;
  font-style: italic;
  color: var(--gold-dark);
  margin-bottom: 14px;
  min-height: 1.5em;
  letter-spacing: 0.02em;
}
.typing-cursor {
  display: inline-block;
  width: 2px;
  height: 1.05em;
  margin-left: 3px;
  background: var(--gold);
  vertical-align: -0.12em;
  animation: typing-cursor-blink 0.85s step-end infinite;
}
@keyframes typing-cursor-blink {
  50% { opacity: 0; }
}
.count-up {
  display: inline-block;
  font-variant-numeric: tabular-nums;
}

@media (prefers-reduced-motion: reduce) {
  .sr,
  .sr.visible,
  .sr.hidden-below {
    transition: none !important;
    opacity: 1 !important;
    transform: none !important;
    filter: none !important;
  }
  .reveal-anim,
  .reveal-anim.anim-show {
    opacity: 1 !important;
    animation: none !important;
  }
  .typing-cursor { animation: none; opacity: 0; }
}

/* ═══════════════════════════════════════════
   LAYOUT
═══════════════════════════════════════════ */
.container{max-width:1300px;margin:0 auto;padding:0 44px}
section{padding:96px 0}

/* ═══════════════════════════════════════════
   TYPOGRAPHY
═══════════════════════════════════════════ */
.cg{font-family:'Cormorant Garamond',serif}
.sec-tag{font-size:0.7rem;letter-spacing:3.5px;text-transform:uppercase;color:var(--gold);font-weight:500;display:block;margin-bottom:10px}
.sec-title{font-family:'Cormorant Garamond',serif;font-size:2.7rem;font-weight:500;color:var(--ink);line-height:1.15}
.sec-title.center{text-align:center}
.sec-sub{color:var(--ink-soft);margin-top:12px;font-size:0.93rem;line-height:1.7}
.sec-sub.center{text-align:center;max-width:560px;margin:12px auto 0}

/* ═══════════════════════════════════════════
   BUTTONS
═══════════════════════════════════════════ */
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 30px;border-radius:60px;font-weight:500;font-size:0.88rem;border:1.5px solid transparent;cursor:pointer;transition:0.3s var(--ease);white-space:nowrap;font-family:'DM Sans',sans-serif}
.btn-solid{border-color:var(--gold)}
.btn-solid:hover{background:var(--gold-dark);border-color:var(--gold-dark);transform:translateY(-2px);box-shadow:0 10px 28px rgba(176,125,98,0.35)}
.btn-outline{background:transparent;color:var(--gold);border-color:var(--gold)}
.btn-outline:hover{background:var(--gold);color:#fff;transform:translateY(-2px)}
.btn-ghost{background:rgba(255,255,255,0.12);color:#fff;border-color:rgba(255,255,255,0.4);backdrop-filter:blur(8px)}
.btn-ghost:hover{background:rgba(255,255,255,0.25);border-color:rgba(255,255,255,0.7)}

/* ═══════════════════════════════════════════
   HEADER
═══════════════════════════════════════════ */
header{
  background:rgba(255,254,247,0.88);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
  border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:1000;
  transition:box-shadow 0.3s;
}
header.scrolled{box-shadow:0 4px 30px rgba(42,31,23,0.07)}
.navbar{display:flex;align-items:center;justify-content:space-between;padding:15px 0;gap:20px}
.logo{display:block;flex-shrink:0;color:inherit}
.logo h2{font-family:'Cormorant Garamond',serif;font-size:1.95rem;font-weight:600;color:var(--gold);line-height:1}
.logo span{font-size:0.67rem;letter-spacing:3px;text-transform:uppercase;color:var(--ink-soft);margin-top:2px;display:block}
.nav-links{display:flex;align-items:center;gap:1.6rem}
.nav-links>li>a{font-size:0.86rem;font-weight:500;color:var(--ink);transition:color 0.2s;display:flex;align-items:center;gap:4px}
.nav-links>li>a:hover,.nav-links>li>a.active{color:var(--gold)}
.nav-caret{font-size:0.6rem;transition:transform 0.2s}
.dropdown:hover .nav-caret{transform:rotate(180deg)}
.dropdown{position:relative}
.dropdown-menu{
  position:absolute;top:calc(100% + 14px);left:0;
  background:var(--white);border-radius:var(--r-sm);
  border:1px solid var(--border);box-shadow:var(--sh);
  min-width:175px;padding:8px 0;
  opacity:0;visibility:hidden;transform:translateY(10px);
  transition:0.25s var(--ease);z-index:99;
}
.dropdown:hover .dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown-menu li a{display:block;padding:9px 20px;font-size:0.84rem;color:var(--ink-mid);transition:0.18s}
.dropdown-menu li a:hover{color:var(--gold);padding-left:25px}
.menu-toggle{display:none;font-size:1.4rem;cursor:pointer;color:var(--gold);background:none;border:none;width:38px;height:38px;align-items:center;justify-content:center;border-radius:8px}

/* ═══════════════════════════════════════════
   HERO
═══════════════════════════════════════════ */
.hero{
  background:linear-gradient(125deg,var(--cream-warm) 0%,#fff9f4 50%,var(--cream-deep) 100%);
  padding:88px 0 96px;position:relative;overflow:hidden;
}
.hero::after{
  content:'';position:absolute;top:-100px;right:-120px;
  width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(176,125,98,0.05) 0%,transparent 70%);
  pointer-events:none;
}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center}
.hero-eyebrow{display:flex;align-items:center;gap:10px;margin-bottom:18px}
.hero-eyebrow-line{width:30px;height:1.5px;background:var(--gold)}
.hero-eyebrow span{font-size:0.72rem;letter-spacing:3px;text-transform:uppercase;color:var(--gold);font-weight:500}
.hero-title{font-family:'Cormorant Garamond',serif;font-size:3.6rem;line-height:1.1;color:var(--ink);margin-bottom:22px;font-weight:500}
.hero-title em{font-style:italic;color:var(--gold)}
.hero-desc{font-size:0.95rem;color:var(--ink-mid);margin-bottom:34px;max-width:430px;line-height:1.75}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:42px}
.hero-divider{width:60px;height:1px;background:var(--border);margin-bottom:28px}
.hero-stats{display:flex;gap:36px}
.stat-num{font-family:'Cormorant Garamond',serif;font-size:2.1rem;font-weight:600;color:var(--gold);display:block;line-height:1}
.stat-label{font-size:0.75rem;color:var(--ink-soft);margin-top:4px}
/* hero image */
.hero-img-wrap{position:relative}
.hero-img-main{border-radius:var(--r);overflow:hidden;box-shadow:0 32px 70px rgba(42,31,23,0.14)}
.hero-img-main img{width:100%;height:580px;object-fit:cover}
.hero-badge{
  position:absolute;bottom:30px;left:-24px;
  background:var(--white);border-radius:20px;padding:16px 22px;
  box-shadow:var(--sh);display:flex;align-items:center;gap:14px;
  border:1px solid var(--border);
}
.badge-icon{font-size:1.6rem}
.badge-strong{font-size:0.88rem;font-weight:600;color:var(--ink);display:block}
.badge-sub{font-size:0.75rem;color:var(--ink-soft)}
.hero-float-img{
  position:absolute;top:40px;right:-28px;
  width:160px;height:200px;border-radius:var(--r-sm);
  overflow:hidden;box-shadow:var(--sh);
  border:3px solid var(--cream);
}
.hero-float-img img{width:100%;height:100%;object-fit:cover}

/* ═══════════════════════════════════════════
   ABOUT
═══════════════════════════════════════════ */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-img-wrap{position:relative}
.about-img-main{border-radius:var(--r);overflow:hidden;box-shadow:var(--sh)}
.about-img-main img{width:100%;height:560px;object-fit:cover}
.about-img-accent{
  position:absolute;bottom:-24px;right:-24px;
  width:190px;height:190px;border-radius:var(--r-sm);
  overflow:hidden;box-shadow:var(--sh);
  border:4px solid var(--cream);
}
.about-img-accent img{width:100%;height:100%;object-fit:cover}
.about-pills{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:20px}
.pill{background:var(--cream-warm);border:1px solid var(--border);border-radius:60px;padding:6px 16px;font-size:0.78rem;color:var(--gold);font-weight:500}
.quote-open{font-family:'Cormorant Garamond',serif;font-size:6rem;line-height:0.5;color:var(--gold);opacity:0.35;margin-bottom:4px}
.about-quote{font-family:'Cormorant Garamond',serif;font-size:1.22rem;font-style:italic;color:var(--ink-mid);line-height:1.75;margin-bottom:24px}
.about-sig{display:flex;align-items:center;gap:14px}
.sig-line{width:40px;height:1.5px;background:var(--gold)}
.sig-name{font-weight:600;font-size:0.88rem}
.sig-role{font-size:0.78rem;color:var(--ink-soft)}

/* ═══════════════════════════════════════════
   STUDIO / TABS
═══════════════════════════════════════════ */
.bg-warm{background:var(--cream-warm)}
.tabs-pill{
  display:flex;width:fit-content;margin:36px auto;
  background:var(--white);border:1.5px solid var(--border);
  border-radius:60px;overflow:hidden;gap:0;
}
.tab-btn{
  padding:11px 32px;background:none;border:none;
  font-size:0.87rem;font-weight:500;color:var(--ink-soft);
  cursor:pointer;transition:0.25s var(--ease);
  font-family:'DM Sans',sans-serif;
}
.tab-btn.active{background:var(--gold);color:#fff}
.tab-pane{display:none}.tab-pane.active{display:block}
.card-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
.studio-card{
  background:var(--white);border-radius:var(--r-sm);overflow:hidden;
  border:1px solid var(--border);box-shadow:var(--sh-sm);
  transition:0.35s var(--ease);
}
.studio-card:hover{transform:translateY(-7px);box-shadow:var(--sh)}
.studio-card-img{overflow:hidden;height:250px}
.studio-card-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.55s var(--ease)}
.studio-card:hover .studio-card-img img{transform:scale(1.06)}
.studio-card-body{padding:18px 22px 22px}
.studio-card h4{font-family:'Cormorant Garamond',serif;font-size:1.18rem;color:var(--ink);margin-bottom:6px}
.studio-card p{font-size:0.84rem;color:var(--ink-soft)}

/* ═══════════════════════════════════════════
   COLLECTION SLIDER (double carousel)
═══════════════════════════════════════════ */
.watermark{
  font-family:'Cormorant Garamond',serif;
  font-size:11rem;font-weight:700;letter-spacing:12px;
  text-align:center;color:rgba(176,125,98,0.07);
  line-height:1;margin-bottom:-80px;
  pointer-events:none;user-select:none;
}
.outer-track-wrap{overflow:hidden;border-radius:var(--r)}
.outer-track{display:flex;transition:transform 0.65s var(--ease);will-change:transform}
.col-slide{flex:0 0 100%;padding:44px 0}
.col-layout{display:grid;grid-template-columns:1.05fr 1.95fr;gap:64px;align-items:center}
.col-num{font-family:'Cormorant Garamond',serif;font-size:5.5rem;font-weight:700;color:rgba(176,125,98,0.6);line-height:0.8;margin-bottom:8px}
.col-title{font-family:'Cormorant Garamond',serif;font-size:2.2rem;font-weight:500;color:var(--ink);line-height:1.2;margin-bottom:14px}
.col-desc{font-size:0.91rem;color:var(--ink-mid);line-height:1.75;margin-bottom:28px}
.col-actions{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.link-arr{color:var(--gold);font-weight:500;font-size:0.88rem;display:flex;align-items:center;gap:6px;transition:0.2s}
.link-arr:hover{gap:11px;color:var(--gold-dark)}
/* inner image carousel */
.inner-wrap{overflow:hidden;border-radius:var(--r-sm);position:relative}
.inner-track{display:flex;gap:16px;transition:transform 0.5s var(--ease);will-change:transform}
.in-slide{flex:0 0 calc(33.333% - 11px);border-radius:18px;overflow:hidden;position:relative}
.in-slide img{width:100%;height:430px;object-fit:cover;transition:transform 0.55s var(--ease)}
.in-slide:hover img{transform:scale(1.05)}
/* inner nav arrows */
.in-nav{
  position:absolute;top:50%;transform:translateY(-50%);
  width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,0.92);
  border:none;cursor:pointer;font-size:0.9rem;color:var(--gold);
  box-shadow:0 4px 14px rgba(0,0,0,0.12);display:flex;align-items:center;justify-content:center;
  transition:0.25s;z-index:5;
}
.in-nav:hover{background:var(--gold);color:#fff;transform:translateY(-50%) scale(1.08)}
.in-nav.prev{left:14px}.in-nav.next{right:14px}
/* outer nav */
.outer-nav{display:flex;justify-content:space-between;align-items:center;margin-top:44px}
.outer-btns{display:flex;gap:12px}
.outer-btn{
  width:50px;height:50px;border-radius:50%;background:var(--white);
  border:1.5px solid var(--border);cursor:pointer;color:var(--gold);
  display:flex;align-items:center;justify-content:center;font-size:0.95rem;
  transition:0.25s var(--ease);box-shadow:var(--sh-sm);
}
.outer-btn:hover{background:var(--gold);color:#fff;border-color:var(--gold)}
.outer-dots{display:flex;gap:10px;align-items:center}
.odot{width:8px;height:8px;border-radius:60px;background:var(--border);cursor:pointer;transition:0.3s}
.odot.active{width:30px;background:var(--gold)}

/* ═══════════════════════════════════════════
   VIDEO SECTION
═══════════════════════════════════════════ */
.video-section{background:var(--ink);padding:0;overflow:hidden;position:relative}
.video-inner{position:relative;height:620px;display:flex;align-items:center;justify-content:center}
.video-bg{position:absolute;inset:0;z-index:0}
.video-bg img{width:100%;height:100%;object-fit:cover;opacity:0.35}
.video-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(42,31,23,0.4) 0%,rgba(42,31,23,0.7) 100%);
  z-index:1;
}
.video-content{position:relative;z-index:2;text-align:center;padding:0 24px}
.video-tag{font-size:0.7rem;letter-spacing:4px;text-transform:uppercase;color:var(--gold-light);margin-bottom:20px;display:block}
.video-title{font-family:'Cormorant Garamond',serif;font-size:3.4rem;font-weight:400;color:#fff;line-height:1.2;margin-bottom:12px;font-style:italic}
.video-sub{color:rgba(255,255,255,0.78);font-size:0.93rem;margin-bottom:40px}
.play-btn{
  width:84px;height:84px;border-radius:50%;
  background:rgba(255,255,255,0.12);border:1.5px solid rgba(255,255,255,0.5);
  display:inline-flex;align-items:center;justify-content:center;
  color:#fff;font-size:1.5rem;cursor:pointer;
  transition:0.3s var(--ease);backdrop-filter:blur(8px);
  margin-bottom:36px;
}
.play-btn:hover{background:var(--gold);border-color:var(--gold);transform:scale(1.08);box-shadow:0 0 0 14px rgba(176,125,98,0.15)}
/* pulse ring */
.play-btn::before{
  content:'';position:absolute;width:84px;height:84px;border-radius:50%;
  border:1.5px solid rgba(176,125,98,0.5);
  animation:pulse-ring 2.5s ease-out infinite;
}
@keyframes pulse-ring{
  0%{transform:scale(1);opacity:0.8}
  100%{transform:scale(1.8);opacity:0}
}
.video-stats{
  display:flex;gap:56px;justify-content:center;margin-top:10px;
  padding-top:36px;border-top:1px solid rgba(255,255,255,0.12);
}
.vs-num{font-family:'Cormorant Garamond',serif;font-size:2.2rem;font-weight:600;color:#fff;display:block;line-height:1}
.vs-label{font-size:0.75rem;color:rgba(255,255,255,0.62);margin-top:4px;letter-spacing:1px}
/* modal video */
.video-modal{
  position:fixed;inset:0;background:rgba(0,0,0,0.92);z-index:9999;
  display:none;align-items:center;justify-content:center;
}
.video-modal.open{display:flex}
.video-modal-inner{position:relative;width:min(860px,94vw);border-radius:16px;overflow:hidden}
.video-modal-inner iframe{width:100%;aspect-ratio:16/9;border:none;display:block}
.modal-close{
  position:absolute;top:-44px;right:0;background:none;border:none;
  color:#fff;font-size:1.4rem;cursor:pointer;opacity:0.7;transition:0.2s;
}
.modal-close:hover{opacity:1;transform:rotate(90deg)}

/* ═══════════════════════════════════════════
   PRICING
═══════════════════════════════════════════ */
.price-intro{
  background:var(--white);border-radius:var(--r);
  border:1px solid var(--border);padding:38px 44px;
  max-width:800px;margin:0 auto 60px;text-align:center;
  box-shadow:var(--sh-sm);
}
.price-intro i{font-size:1.8rem;color:var(--gold);margin-bottom:14px;display:block}
.price-intro h3{font-family:'Cormorant Garamond',serif;font-size:1.5rem;color:var(--ink);margin-bottom:10px}
.price-intro p{font-size:0.9rem;color:var(--ink-mid);line-height:1.7}
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.price-card{
  background:var(--white);border-radius:var(--r);
  border:1.5px solid var(--border);padding:38px 30px;
  text-align:center;transition:0.35s var(--ease);
  box-shadow:var(--sh-sm);position:relative;overflow:hidden;
}
.price-card:hover{transform:translateY(-7px);box-shadow:var(--sh);border-color:var(--gold-light)}
.price-card.featured{
  border-color:var(--gold);
  background:linear-gradient(160deg,#fffef7,var(--cream-warm));
}
.price-card.featured::before{
  content:'Được chọn nhiều nhất';
  position:absolute;top:-1px;left:50%;transform:translateX(-50%);
  background:var(--gold);color:#fff;font-size:0.68rem;letter-spacing:2px;
  text-transform:uppercase;padding:5px 18px;border-radius:0 0 14px 14px;
  font-family:'DM Sans',sans-serif;font-weight:500;white-space:nowrap;
}
.price-name{font-family:'Cormorant Garamond',serif;font-size:1.45rem;color:var(--ink);margin-bottom:8px;margin-top:8px}
.price-amount{font-family:'Cormorant Garamond',serif;font-size:2.5rem;font-weight:600;color:var(--gold);margin:16px 0;line-height:1}
.price-amount small{font-size:1rem;font-weight:400}
.price-features{text-align:left;margin:20px 0 26px}
.price-features li{font-size:0.85rem;color:var(--ink-mid);padding:6px 0;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:9px}
.price-features li:last-child{border:none}
.price-features li::before{content:'✦';color:var(--gold);font-size:0.65rem;flex-shrink:0}

/* ═══════════════════════════════════════════
   REVIEWS
═══════════════════════════════════════════ */
.review-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.rev-card{
  background:var(--white);border-radius:var(--r);
  border:1px solid var(--border);padding:32px 30px;
  box-shadow:var(--sh-sm);transition:0.35s var(--ease);
  position:relative;overflow:hidden;
}
.rev-card::before{
  content:'❝';font-family:'Cormorant Garamond',serif;font-size:5rem;
  color:rgba(176,125,98,0.08);position:absolute;top:-4px;right:18px;line-height:1;
}
.rev-card:hover{transform:translateY(-5px);box-shadow:var(--sh)}
.rev-stars{color:#e9b35f;letter-spacing:2px;margin-bottom:14px;font-size:0.9rem}
.rev-text{font-size:0.9rem;color:var(--ink-mid);line-height:1.75;margin-bottom:22px;font-style:italic;position:relative;z-index:1}
.rev-author{display:flex;align-items:center;gap:13px}
.rev-author img{width:48px;height:48px;border-radius:50%;object-fit:cover;border:2px solid var(--border)}
.rev-name{font-weight:600;font-size:0.87rem}
.rev-role{font-size:0.77rem;color:var(--ink-soft)}

/* ═══════════════════════════════════════════
   WORKFLOW
═══════════════════════════════════════════ */
.steps-row{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:0;margin-top:56px;position:relative;
}
.steps-row::before{
  content:'';position:absolute;top:38px;left:calc(12.5%);
  width:75%;height:1.5px;
  background:linear-gradient(90deg,var(--gold-light),var(--border),var(--gold-light));
  z-index:0;
}
.step-item{text-align:center;padding:0 16px;position:relative;z-index:1}
.step-circle{
  width:56px;height:56px;border-radius:50%;
  background:var(--gold);color:#fff;
  font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:600;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 20px;box-shadow:0 6px 20px rgba(176,125,98,0.35);
  border:3px solid var(--cream);
}
.step-item h3{font-family:'Cormorant Garamond',serif;font-size:1.1rem;color:var(--ink);margin-bottom:8px}
.step-item p{font-size:0.83rem;color:var(--ink-soft);line-height:1.6}

/* ═══════════════════════════════════════════
   CTA BANNER
═══════════════════════════════════════════ */
.cta-band{
  background:linear-gradient(130deg,#3a2518 0%,#2a1c11 60%,#1e1509 100%);
  border-radius:var(--r);padding:76px 60px;
  display:grid;grid-template-columns:1fr auto;
  gap:40px;align-items:center;position:relative;overflow:hidden;
}
.cta-band::before{
  content:'SORA';font-family:'Cormorant Garamond',serif;
  font-size:14rem;font-weight:700;color:rgba(255,255,255,0.025);
  position:absolute;right:-30px;bottom:-40px;line-height:1;
  pointer-events:none;user-select:none;
}
.cta-tag{font-size:0.7rem;letter-spacing:3.5px;text-transform:uppercase;color:var(--gold-light);margin-bottom:14px;display:block}
.cta-title{font-family:'Cormorant Garamond',serif;font-size:2.3rem;color:#fff;line-height:1.25;margin-bottom:12px}
.cta-sub{color:rgba(255,255,255,0.72);font-size:0.9rem;line-height:1.65}
.cta-right{text-align:center;flex-shrink:0}
.cta-offer{
  background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.15);
  border-radius:var(--r-sm);padding:24px 30px;margin-bottom:18px;
}
.cta-pct{font-family:'Cormorant Garamond',serif;font-size:3.5rem;font-weight:700;color:var(--gold-light);line-height:1;display:block}
.cta-pct-label{font-size:0.78rem;color:rgba(255,255,255,0.72);margin-top:4px}
.cta-note{font-size:0.78rem;color:rgba(255,255,255,0.58);margin-top:12px}
.cta-chat-link{color:rgba(255,255,255,0.88) !important}
.cta-chat-link:hover{color:#fff !important}

/* ═══════════════════════════════════════════
   BLOG
═══════════════════════════════════════════ */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.blog-card{
  background:var(--white);border-radius:var(--r);
  border:1px solid var(--border);overflow:hidden;
  box-shadow:var(--sh-sm);transition:0.35s var(--ease);
}
.blog-card:hover{transform:translateY(-6px);box-shadow:var(--sh)}
.blog-img{overflow:hidden;height:230px}
.blog-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.55s var(--ease)}
.blog-card:hover .blog-img img{transform:scale(1.06)}
.blog-body{padding:22px 24px 26px}
.blog-cat{font-size:0.7rem;letter-spacing:2px;text-transform:uppercase;color:var(--gold);font-weight:500;margin-bottom:8px;display:block}
.blog-body h4{font-family:'Cormorant Garamond',serif;font-size:1.18rem;color:var(--ink);margin-bottom:8px;line-height:1.35}
.blog-body p{font-size:0.84rem;color:var(--ink-soft);margin-bottom:16px;line-height:1.65}
.read-more{font-size:0.84rem;color:var(--gold);font-weight:500;display:inline-flex;align-items:center;gap:6px;transition:0.2s}
.read-more:hover{gap:11px;color:var(--gold-dark)}

/* ═══════════════════════════════════════════
   FOOTER
═══════════════════════════════════════════ */
footer{background:#1b1510;color:#cdc5bc;padding:68px 0 32px}
.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.5fr;gap:52px;margin-bottom:52px}
.f-logo{font-family:'Cormorant Garamond',serif;font-size:2rem;font-weight:500;color:#fff;display:block;margin-bottom:12px}
.f-tagline{font-size:0.86rem;color:#9a8e86;line-height:1.75;margin-bottom:20px}
.f-socials{display:flex;gap:12px}
.f-soc{
  width:38px;height:38px;border-radius:50%;
  border:1px solid #3a3028;color:#9a8e86;
  display:flex;align-items:center;justify-content:center;font-size:0.84rem;
  transition:0.22s;
}
.f-soc:hover{background:var(--gold);border-color:var(--gold);color:#fff}
footer h4{font-family:'Cormorant Garamond',serif;font-size:1.1rem;color:#fff;margin-bottom:20px}
footer ul li{margin-bottom:11px}
footer ul li a{font-size:0.84rem;color:#9a8e86;transition:0.18s}
footer ul li a:hover{color:var(--gold);padding-left:5px}
.f-contact-item{display:flex;align-items:flex-start;gap:10px;font-size:0.84rem;color:#9a8e86;margin-bottom:12px}
.f-contact-item i{color:var(--gold-light);margin-top:3px;width:14px;flex-shrink:0}
footer hr{border:none;border-top:1px solid #2b2318;margin-bottom:24px}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;font-size:0.8rem;color:#5a5048}

/* ═══════════════════════════════════════════
   VIEW ALL LINK
═══════════════════════════════════════════ */
.view-all{text-align:center;margin-top:52px}
.va-link{font-size:0.88rem;font-weight:500;color:var(--gold);border-bottom:1px solid var(--gold);padding-bottom:3px;transition:0.2s}
.va-link:hover{color:var(--gold-dark);border-color:var(--gold-dark)}

/* ═══════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════ */
@media(max-width:1100px){
  .hero-grid,.about-grid,.col-layout{grid-template-columns:1fr;gap:50px}
  .hero-title{font-size:2.8rem}
  .hero-img-main img{height:420px}
  .cta-band{grid-template-columns:1fr;text-align:center}
  .cta-right{max-width:320px;margin:0 auto}
  .footer-top{grid-template-columns:repeat(2,1fr)}
  .steps-row::before{display:none}
}
@media(max-width:768px){
  .container{padding:0 20px}
  section{padding:64px 0}
  .menu-toggle{display:flex}
  .nav-links{
    position:fixed;top:65px;left:-100%;width:82%;height:100vh;
    background:var(--cream);flex-direction:column;padding:32px 24px;
    transition:0.35s var(--ease);gap:18px;z-index:999;
    border-right:1px solid var(--border);box-shadow:var(--sh);
  }
  .nav-links.open{left:0}
  .dropdown-menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;padding:6px 0 0 14px;display:none}
  .dropdown.open .dropdown-menu{display:block}
  .hero-title{font-size:2.2rem}
  .watermark{font-size:4.5rem;margin-bottom:-34px}
  .card-grid,.price-grid,.review-grid,.blog-grid{grid-template-columns:1fr}
  .steps-row{grid-template-columns:1fr 1fr;gap:28px}
  .in-slide{flex:0 0 calc(80% - 8px)}
  .footer-top{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;gap:8px;text-align:center}
  .video-inner{height:500px}
  .video-title{font-size:2.2rem}
  .video-stats{gap:28px}
  .cta-band{padding:48px 28px}
  .cta-title{font-size:1.8rem}
  .ba-slider-wrap{height:400px}
}

/* ═══════════════════════════════════════════
   BEFORE / AFTER SLIDER
═══════════════════════════════════════════ */
.ba-section{padding:96px 0;background:var(--cream)}
.ba-header{text-align:center;margin-bottom:56px}
.ba-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:44px;align-items:start}
@media(max-width:900px){.ba-grid{grid-template-columns:1fr}}
.ba-card{border-radius:var(--r);overflow:hidden;box-shadow:var(--sh)}
.ba-card-label{font-family:'Cormorant Garamond',serif;font-size:1.4rem;color:var(--ink);margin-bottom:18px;font-weight:500}
.ba-slider-wrap{
  position:relative;height:500px;border-radius:var(--r);overflow:hidden;
  user-select:none;cursor:ew-resize;box-shadow:var(--sh);
}
.ba-img{position:absolute;inset:0;width:100%;height:100%}
.ba-img img{width:100%;height:100%;object-fit:cover}
.ba-img.after{clip-path:inset(0 50% 0 0);transition:clip-path 0s}
.ba-handle{
  position:absolute;top:0;bottom:0;left:50%;transform:translateX(-50%);
  width:3px;background:var(--white);z-index:10;cursor:ew-resize;
}
.ba-handle-circle{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:48px;height:48px;border-radius:50%;
  background:var(--white);box-shadow:0 4px 20px rgba(0,0,0,0.25);
  display:flex;align-items:center;justify-content:center;gap:2px;
  color:var(--gold);font-size:0.85rem;
}
.ba-label-before,.ba-label-after{
  position:absolute;bottom:18px;z-index:11;
  background:rgba(0,0,0,0.55);color:#fff;
  font-size:0.73rem;letter-spacing:2px;text-transform:uppercase;
  padding:5px 14px;border-radius:30px;backdrop-filter:blur(6px);
}
.ba-label-before{left:18px}
.ba-label-after{right:18px}
.ba-intro{max-width:620px;margin:0 auto 60px;text-align:center}
.ba-intro p{color:var(--ink-mid);font-size:0.93rem;line-height:1.75}
.ba-single{max-width:860px;margin:0 auto}

/* ═══════════════════════════════════════════
   SUBPAGE OVERLAY SYSTEM
═══════════════════════════════════════════ */
.page-overlay{
  position:fixed;inset:0;background:var(--cream);z-index:2000;
  overflow-y:auto;display:none;
}
.page-overlay.open{display:block}
.page-bar{
  background:rgba(255,254,247,0.93);backdrop-filter:blur(18px);
  border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:10;
  display:flex;align-items:center;gap:16px;
  padding:14px 44px;
}
.page-bar-back{
  background:none;border:1.5px solid var(--border);border-radius:60px;
  padding:7px 18px;font-size:0.83rem;color:var(--ink-mid);cursor:pointer;
  display:flex;align-items:center;gap:7px;font-family:'DM Sans',sans-serif;
  transition:0.22s;
}
.page-bar-back:hover{border-color:var(--gold);color:var(--gold)}
.page-bar-title{font-family:'Cormorant Garamond',serif;font-size:1.3rem;color:var(--ink);font-weight:500}
.page-content{padding:64px 44px 100px;max-width:1300px;margin:0 auto}
@media(max-width:768px){
  .page-bar{padding:12px 20px}
  .page-content{padding:40px 20px 80px}
}

/* Subpage hero */
.sp-hero{
  background:linear-gradient(135deg,var(--cream-warm) 0%,#fff9f4 60%,var(--cream-deep) 100%);
  border-radius:var(--r);padding:64px 56px;margin-bottom:60px;
  position:relative;overflow:hidden;
}
.sp-hero::after{
  content:'';position:absolute;top:-60px;right:-60px;
  width:320px;height:320px;border-radius:50%;
  background:radial-gradient(circle,rgba(176,125,98,0.07),transparent 70%);
  pointer-events:none;
}
.sp-hero h1{font-family:'Cormorant Garamond',serif;font-size:3rem;font-weight:500;color:var(--ink);margin-bottom:14px;line-height:1.15}
.sp-hero p{color:var(--ink-mid);max-width:560px;line-height:1.75;font-size:0.95rem}

/* Subpage profile/team grid */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-bottom:60px}
@media(max-width:900px){.team-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.team-grid{grid-template-columns:1fr}}
.team-card{
  background:var(--white);border-radius:var(--r-sm);
  border:1px solid var(--border);overflow:hidden;
  box-shadow:var(--sh-sm);text-align:center;padding:32px 24px;
  transition:0.3s var(--ease);
}
.team-card:hover{transform:translateY(-6px);box-shadow:var(--sh)}
.team-avatar{width:100px;height:100px;border-radius:50%;margin:0 auto 16px;object-fit:cover;border:3px solid var(--border)}
.team-name{font-family:'Cormorant Garamond',serif;font-size:1.35rem;color:var(--ink);margin-bottom:4px}
.team-role{font-size:0.8rem;color:var(--gold);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:12px}
.team-bio{font-size:0.85rem;color:var(--ink-soft);line-height:1.65}

/* Subpage gallery */
.sp-gallery{columns:3;gap:20px;margin-bottom:60px}
@media(max-width:900px){.sp-gallery{columns:2}}
@media(max-width:600px){.sp-gallery{columns:1}}
.sp-gal-item{
  break-inside:avoid;border-radius:var(--r-sm);overflow:hidden;
  margin-bottom:20px;box-shadow:var(--sh-sm);
  transition:0.35s var(--ease);
}
.sp-gal-item:hover{transform:scale(1.02);box-shadow:var(--sh)}
.sp-gal-item img{width:100%;display:block}

/* Subpage highlight blocks */
.sp-feature-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:32px;margin-bottom:60px}
@media(max-width:768px){.sp-feature-grid{grid-template-columns:1fr}}
.sp-feature{
  background:var(--white);border-radius:var(--r-sm);
  border:1px solid var(--border);padding:36px 32px;
  box-shadow:var(--sh-sm);
}
.sp-feature-icon{font-size:2.2rem;margin-bottom:16px}
.sp-feature h3{font-family:'Cormorant Garamond',serif;font-size:1.45rem;color:var(--ink);margin-bottom:10px}
.sp-feature p{font-size:0.88rem;color:var(--ink-mid);line-height:1.7}

/* Concept cards */
.concept-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-bottom:60px}
@media(max-width:900px){.concept-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.concept-grid{grid-template-columns:1fr}}
.concept-card{border-radius:var(--r);overflow:hidden;box-shadow:var(--sh-sm);position:relative;cursor:pointer;transition:0.35s var(--ease)}
.concept-card:hover{transform:translateY(-7px);box-shadow:var(--sh)}
.concept-card img{width:100%;height:340px;object-fit:cover;display:block;transition:transform 0.55s var(--ease)}
.concept-card:hover img{transform:scale(1.06)}
.concept-card-body{
  position:absolute;bottom:0;left:0;right:0;
  padding:28px 24px;
  background:linear-gradient(0deg,rgba(30,18,10,0.82) 0%,transparent 100%);
}
.concept-card h4{font-family:'Cormorant Garamond',serif;font-size:1.25rem;color:#fff;margin-bottom:4px}
.concept-card p{font-size:0.8rem;color:rgba(255,255,255,0.88)}

/* Wardrobe / dress cards */
.dress-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-bottom:60px}
@media(max-width:1100px){.dress-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:768px){.dress-grid{grid-template-columns:repeat(2,1fr)}}
.dress-card{border-radius:var(--r-sm);overflow:hidden;box-shadow:var(--sh-sm);background:var(--white);border:1px solid var(--border);transition:0.3s var(--ease)}
.dress-card:hover{transform:translateY(-5px);box-shadow:var(--sh)}
.dress-img{height:320px;overflow:hidden}
.dress-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.55s var(--ease)}
.dress-card:hover .dress-img img{transform:scale(1.06)}
.dress-body{padding:16px 18px}
.dress-name{font-family:'Cormorant Garamond',serif;font-size:1.05rem;color:var(--ink);margin-bottom:4px}
.dress-type{font-size:0.77rem;color:var(--gold);letter-spacing:1.5px;text-transform:uppercase}

/* Album grid */
.album-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:32px;margin-bottom:60px}
@media(max-width:768px){.album-grid{grid-template-columns:1fr}}
.album-card{border-radius:var(--r);overflow:hidden;box-shadow:var(--sh);position:relative}
.album-card img{width:100%;height:380px;object-fit:cover;display:block}
.album-card-info{padding:22px 26px 26px;background:var(--white)}
.album-card h4{font-family:'Cormorant Garamond',serif;font-size:1.3rem;color:var(--ink);margin-bottom:6px}
.album-card p{font-size:0.85rem;color:var(--ink-soft)}

/* FAQ */
.faq-list{max-width:780px;margin:0 auto 60px}
.faq-item{border-bottom:1px solid var(--border);padding:22px 0}
.faq-q{
  font-family:'Cormorant Garamond',serif;font-size:1.18rem;color:var(--ink);
  cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:16px;
}
.faq-q:hover{color:var(--gold)}
.faq-icon{font-size:1.1rem;color:var(--gold);transition:transform 0.3s;flex-shrink:0}
.faq-item.open .faq-icon{transform:rotate(45deg)}
.faq-a{font-size:0.88rem;color:var(--ink-mid);line-height:1.75;max-height:0;overflow:hidden;transition:max-height 0.4s var(--ease),padding 0.3s}
.faq-item.open .faq-a{max-height:300px;padding-top:12px}

/* Blog full page */
.blog-full-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
@media(max-width:900px){.blog-full-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.blog-full-grid{grid-template-columns:1fr}}

/* Contact / booking */
.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:60px;align-items:start}
@media(max-width:900px){.contact-grid{grid-template-columns:1fr}}
.contact-info-item{display:flex;align-items:flex-start;gap:16px;margin-bottom:28px}
.contact-icon{width:48px;height:48px;border-radius:50%;background:var(--gold-mist);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--gold);font-size:1.1rem;flex-shrink:0}
.contact-info-item h4{font-weight:600;font-size:0.92rem;color:var(--ink);margin-bottom:3px}
.contact-info-item p{font-size:0.85rem;color:var(--ink-soft)}
.booking-form{background:var(--white);border-radius:var(--r);border:1px solid var(--border);padding:40px 36px;box-shadow:var(--sh-sm)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px}
@media(max-width:600px){.form-row{grid-template-columns:1fr}}
.form-group{margin-bottom:18px}
.form-group label{display:block;font-size:0.82rem;font-weight:500;color:var(--ink-mid);margin-bottom:6px;letter-spacing:0.5px}
.form-group input,.form-group select,.form-group textarea{
  width:100%;padding:11px 16px;border:1.5px solid var(--border);
  border-radius:10px;font-family:'DM Sans',sans-serif;font-size:0.88rem;
  color:var(--ink);background:var(--cream);
  transition:border-color 0.2s;outline:none;
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--gold)}
.form-group textarea{resize:vertical;min-height:100px}
.form-submit{width:100%;padding:14px;background:var(--gold);color:#fff;border:none;border-radius:60px;font-size:0.9rem;font-weight:500;cursor:pointer;font-family:'DM Sans',sans-serif;transition:0.25s var(--ease)}
.form-submit:hover{background:var(--gold-dark);transform:translateY(-2px);box-shadow:0 10px 28px rgba(176,125,98,0.35)}

/* Inner routes — compact hero */
.page-hero{
  padding:56px 0 48px;
  background:linear-gradient(165deg, var(--cream-warm) 0%, var(--cream) 58%);
  border-bottom:1px solid var(--border);
}
.page-hero-inner{max-width:760px}
.page-hero-title{
  font-family:'Cormorant Garamond',serif;
  font-size:2.75rem;
  font-weight:500;
  color:var(--ink);
  line-height:1.12;
  margin-top:10px;
}
.page-hero-sub{
  margin-top:14px;
  font-size:0.95rem;
  color:var(--ink-mid);
  line-height:1.75;
  max-width:600px;
}
.page-lead{
  font-size:0.95rem;
  color:var(--ink-mid);
  max-width:720px;
  line-height:1.75;
  margin-bottom:40px;
}
.client-gallery{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:22px;
}
.client-gallery a{
  border-radius:var(--r-sm);
  overflow:hidden;
  box-shadow:var(--sh-sm);
  aspect-ratio:4/5;
  transition:0.3s var(--ease);
}
.client-gallery a:hover{
  transform:translateY(-5px);
  box-shadow:var(--sh);
}
.client-gallery img{width:100%;height:100%;object-fit:cover}
@media(max-width:900px){.client-gallery{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){
  .page-hero-title{font-size:2.05rem}
  .client-gallery{grid-template-columns:1fr}
}
