/* =========================================================
   MAISON BELLE — Güzellik & Bakım Atölyesi
   Görsel-odaklı / lüks / akışkan tasarım
   ========================================================= */

:root{
  --ink:        #161013;
  --ink-2:      #1f1418;
  --wine:       #2a161d;
  --cream:      #f6efe7;
  --cream-soft: #d9cabd;
  --muted:      #9a8a82;
  --gold:       #dcb78c;
  --gold-deep:  #c2965f;
  --gold-glow:  #ecd0a8;
  --rose:       #c98b86;

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

  --ease: cubic-bezier(.16,1,.3,1);
  --slow: cubic-bezier(.7,0,.2,1);

  --maxw: 1320px;
  --pad: clamp(20px, 6vw, 110px);
}

*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  font-family: var(--font-sans);
  background: var(--ink);
  color: var(--cream);
  line-height: 1.6; overflow-x: hidden;
  font-weight: 300; letter-spacing:.01em;
  -webkit-font-smoothing: antialiased;
}
::selection{ background: var(--gold); color: var(--ink); }
a{ color: inherit; text-decoration: none; }
img{ display:block; max-width:100%; }

/* ---------- İmleç ---------- */
.cursor, .cursor-dot{
  position: fixed; top:0; left:0; z-index:9999; border-radius:50%;
  pointer-events:none; mix-blend-mode: difference; transform: translate(-50%,-50%);
}
.cursor{ width:38px; height:38px; border:1px solid var(--cream);
  transition: width .35s var(--ease), height .35s var(--ease), background .35s var(--ease); }
.cursor-dot{ width:5px; height:5px; background: var(--cream); }
.cursor.is-active{ width:72px; height:72px; background: var(--cream); }
@media (hover:none), (max-width:900px){ .cursor,.cursor-dot{ display:none; } }

/* ---------- Scroll progress ---------- */
.scroll-progress{ position: fixed; top:0; left:0; height:3px; width:0;
  background: linear-gradient(90deg, var(--gold-deep), var(--gold-glow)); z-index:9000; transition: width .1s linear; }

/* ---------- Preloader ---------- */
.preloader{ position: fixed; inset:0; z-index:10000; background: var(--ink);
  display:flex; align-items:center; justify-content:center;
  transition: opacity .8s var(--ease), visibility .8s; }
.preloader.done{ opacity:0; visibility:hidden; }
.preloader__inner{ text-align:center; }
.preloader__mark{ font-family: var(--font-serif); font-size: clamp(2.5rem,8vw,5rem);
  letter-spacing:.2em; color: var(--gold-glow); display:block; }
.preloader__line{ display:block; height:1px; width:0; margin:18px auto; background: var(--gold);
  animation: pl-line 1.6s var(--ease) forwards; }
.preloader__txt{ font-size:.7rem; letter-spacing:.5em; text-transform:uppercase; color: var(--muted); }
@keyframes pl-line{ to{ width:160px; } }

/* ---------- Navigasyon ---------- */
.nav{ position: fixed; top:0; left:0; width:100%; z-index:1000;
  display:flex; align-items:center; justify-content:space-between; padding: 22px var(--pad);
  transition: padding .5s var(--ease), background .5s var(--ease); }
.nav.scrolled{ padding: 14px var(--pad); background: rgba(22,16,19,.72);
  backdrop-filter: blur(14px); border-bottom:1px solid rgba(220,183,140,.12); }
.nav__brand{ display:flex; gap:.4em; align-items:baseline; }
.nav__mark{ font-family: var(--font-serif); font-size:1.45rem; letter-spacing:.22em; }
.nav__mark--thin{ color: var(--gold); font-weight:400; }
.nav__menu{ display:flex; align-items:center; gap: clamp(18px,3vw,42px); }
.nav__link{ font-size:.82rem; letter-spacing:.14em; text-transform:uppercase;
  position:relative; color: var(--cream-soft); transition: color .4s; }
.nav__link::after{ content:''; position:absolute; left:0; bottom:-6px; height:1px; width:0;
  background: var(--gold); transition: width .4s var(--ease); }
.nav__link:hover{ color: var(--cream); }
.nav__link:hover::after{ width:100%; }
.nav__cta{ font-size:.78rem; letter-spacing:.16em; text-transform:uppercase;
  border:1px solid var(--gold); color: var(--gold-glow); padding:11px 22px; border-radius:40px;
  transition: all .45s var(--ease); }
.nav__cta:hover{ background: var(--gold); color: var(--ink); box-shadow:0 10px 30px -10px var(--gold-deep); }
.nav__burger{ display:none; flex-direction:column; gap:6px; background:none; border:none; cursor:pointer; padding:8px; z-index:1100; }
.nav__burger span{ width:28px; height:2px; background: var(--cream); transition:.4s var(--ease); }
.nav__burger.open span:nth-child(1){ transform: translateY(8px) rotate(45deg); }
.nav__burger.open span:nth-child(2){ transform: translateY(0) rotate(-45deg); }
@media (max-width:900px){
  .nav__burger{ display:flex; }
  .nav__menu{ position: fixed; inset:0; flex-direction:column; justify-content:center; gap:30px;
    background: rgba(20,12,15,.97); backdrop-filter: blur(10px);
    transform: translateX(100%); transition: transform .6s var(--slow); }
  .nav__menu.open{ transform: translateX(0); }
  .nav__link{ font-size:1.1rem; } .nav__cta{ font-size:.95rem; }
}

/* ---------- Butonlar ---------- */
.btn{ display:inline-flex; align-items:center; gap:10px; font-size:.82rem; letter-spacing:.14em;
  text-transform:uppercase; padding:16px 32px; border-radius:42px; cursor:pointer;
  transition: all .5s var(--ease); position:relative; overflow:hidden; }
.btn--solid{ background: var(--gold); color: var(--ink); font-weight:500; }
.btn--solid::before{ content:''; position:absolute; inset:0; background: var(--gold-glow);
  transform: translateY(101%); transition: transform .5s var(--ease); z-index:0; }
.btn--solid:hover::before{ transform: translateY(0); }
.btn--solid > *{ position:relative; z-index:1; }
.btn--solid:hover{ box-shadow:0 18px 40px -16px var(--gold-deep); }
.btn--ghost{ border:1px solid rgba(220,183,140,.5); color: var(--cream); }
.btn--ghost:hover{ border-color: var(--gold); background: rgba(220,183,140,.1); }
.btn__dot{ width:8px; height:8px; border-radius:50%; background: var(--gold);
  animation: pulse 2s infinite; }
@keyframes pulse{ 0%{ box-shadow:0 0 0 0 rgba(220,183,140,.6);} 70%{ box-shadow:0 0 0 12px rgba(220,183,140,0);} 100%{box-shadow:0 0 0 0 rgba(220,183,140,0);} }

/* =========================================================
   HERO — tam ekran görsel
   ========================================================= */
.hero{ position:relative; min-height:100svh; display:flex; flex-direction:column;
  justify-content:center; padding: 0 var(--pad); overflow:hidden; }
.hero__media{ position:absolute; inset:0; z-index:0; overflow:hidden; }
.hero__img{ position:absolute; inset:0; background-size:cover; background-position:center 22%;
  transform: scale(1.06); animation: heroZoom 9s var(--ease) forwards; }
@keyframes heroZoom{ to{ transform: scale(1); } }
.hero__scrim{ position:absolute; inset:0; z-index:1; background:
  linear-gradient(90deg, rgba(18,11,14,.92) 0%, rgba(18,11,14,.6) 42%, rgba(42,22,29,.25) 72%, transparent 100%),
  linear-gradient(180deg, rgba(18,11,14,.55) 0%, transparent 30%, rgba(18,11,14,.55) 100%); }
.hero__grain{ position:absolute; inset:0; z-index:2; opacity:.05; pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }
.hero__content{ position:relative; z-index:3; max-width:980px; }
.hero__eyebrow{ display:inline-block; font-size:.74rem; letter-spacing:.42em; text-transform:uppercase;
  color: var(--gold-glow); margin-bottom: clamp(20px,4vh,40px); }
.hero__title{ font-family: var(--font-serif); font-weight:500;
  font-size: clamp(3rem,11vw,9rem); line-height:.95; letter-spacing:-.01em;
  text-shadow:0 4px 40px rgba(0,0,0,.4); }
.hero__title .line{ display:block; overflow:hidden; }
.hero__title .word{ display:inline-block; }
.hero__title .italic{ font-style:italic; color: var(--gold-glow); }
.reveal-word{ transform: translateY(110%); opacity:0; }
.hero__sub{ max-width:520px; margin: clamp(24px,4vh,40px) 0; font-size:1.05rem; color: var(--cream-soft); }
.hero__actions{ display:flex; gap:16px; flex-wrap:wrap; }
.hero__scroll{ position:absolute; bottom:28px; left:var(--pad); z-index:3;
  display:flex; align-items:center; gap:14px; font-size:.7rem; letter-spacing:.3em;
  text-transform:uppercase; color: var(--cream-soft); }
.hero__scroll-line{ width:50px; height:1px; background: rgba(246,239,231,.4); position:relative; overflow:hidden; }
.hero__scroll-line::after{ content:''; position:absolute; inset:0; background: var(--gold);
  transform: translateX(-100%); animation: scrollline 2.4s var(--ease) infinite; }
@keyframes scrollline{ 50%{ transform: translateX(0);} 100%{ transform: translateX(100%);} }

/* ---------- Marquee ---------- */
.marquee{ border-top:1px solid rgba(220,183,140,.16); border-bottom:1px solid rgba(220,183,140,.16);
  padding:16px 0; overflow:hidden; background: var(--ink-2); }
.marquee__track{ display:flex; gap:38px; white-space:nowrap; width:max-content; animation: marquee 32s linear infinite; }
.marquee__track span{ font-family: var(--font-serif); font-size:1.4rem; font-style:italic; color: var(--cream-soft); }
.marquee__track span:nth-child(even){ color: var(--gold); font-style:normal; }
@keyframes marquee{ to{ transform: translateX(-50%); } }
.marquee:hover .marquee__track{ animation-play-state: paused; }

/* =========================================================
   INTRO
   ========================================================= */
.intro{ padding: clamp(80px,15vh,180px) var(--pad); text-align:center; }
.intro__text{ font-family: var(--font-serif); font-size: clamp(1.8rem,5vw,4rem);
  line-height:1.2; max-width:1000px; margin:0 auto; }
.intro__text span{ display:block; }
.intro__text span:nth-child(2){ font-style:italic; color: var(--gold-glow); }
.intro__meta{ margin-top:40px; display:flex; gap:18px; justify-content:center;
  font-size:.72rem; letter-spacing:.34em; text-transform:uppercase; color: var(--muted); }

/* =========================================================
   SECTION HEAD
   ========================================================= */
.section-head{ max-width: var(--maxw); margin:0 auto clamp(40px,7vh,76px); padding:0 var(--pad); }
.section-head--center{ text-align:center; }
.section-head__num{ display:block; font-size:.8rem; letter-spacing:.4em; color: var(--gold); margin-bottom:14px; }
.section-head__title{ font-family: var(--font-serif); font-size: clamp(2.4rem,7vw,5.5rem);
  font-weight:500; line-height:1; letter-spacing:-.01em; }
.section-head__desc{ margin-top:16px; color: var(--cream-soft); max-width:480px; font-size:1rem; }
.section-head--center .section-head__desc{ margin-left:auto; margin-right:auto; }

/* =========================================================
   HİZMET KARTLARI (görsel)
   ========================================================= */
.services{ padding-bottom: clamp(80px,12vh,140px); }
.cards{ max-width: var(--maxw); margin:0 auto; padding:0 var(--pad);
  display:grid; grid-template-columns: repeat(2,1fr); gap: clamp(14px,1.6vw,22px); }
.card{
  position:relative; min-height: clamp(320px,42vw,440px); border-radius:10px; overflow:hidden;
  background-size:cover; background-position:center; display:flex; align-items:flex-end;
  isolation:isolate; cursor:pointer;
}
.card--lg{ grid-column: span 2; min-height: clamp(360px,40vw,520px); }
.card::before{ content:''; position:absolute; inset:0; z-index:0; background-size:cover; background-position:center;
  background-image: inherit; transform: scale(1.04); transition: transform 1.1s var(--ease); }
.card:hover::before{ transform: scale(1.12); }
.card::after{ content:''; position:absolute; inset:0; z-index:1;
  background: linear-gradient(180deg, rgba(18,11,14,.05) 25%, rgba(18,11,14,.55) 62%, rgba(18,11,14,.92));
  transition: background .5s; }
.card:hover::after{ background: linear-gradient(180deg, rgba(201,139,134,.18) 10%, rgba(18,11,14,.5) 55%, rgba(18,11,14,.92)); }
.card__body{ position:relative; z-index:2; padding: clamp(22px,3vw,38px); }
.card__tag{ display:inline-block; font-size:.64rem; letter-spacing:.22em; text-transform:uppercase;
  color: var(--ink); background: var(--gold); padding:6px 14px; border-radius:30px; margin-bottom:14px; }
.card__title{ font-family: var(--font-serif); font-size: clamp(1.7rem,3.4vw,3rem); font-weight:500; line-height:1.02; }
.card__desc{ color: var(--cream-soft); font-size:.95rem; max-width:480px; margin-top:10px;
  max-height:0; opacity:0; overflow:hidden; transition: max-height .6s var(--ease), opacity .5s, margin .5s; }
.card:hover .card__desc{ max-height:160px; opacity:1; }
@media (max-width:680px){
  .cards{ grid-template-columns: 1fr; }
  .card, .card--lg{ grid-column: span 1; min-height: 340px; }
  .card__desc{ max-height:160px; opacity:.9; } /* mobilde göster */
}

/* =========================================================
   GÖRSEL BANT (tam genişlik parallax)
   ========================================================= */
.band{ position:relative; height: clamp(420px,70vh,720px); overflow:hidden;
  display:flex; align-items:center; justify-content:center; text-align:center; }
.band--short{ height: clamp(340px,52vh,540px); }
.band__img{ position:absolute; inset:-22% 0; z-index:0; background-size:cover; background-position:center;
  will-change: transform; }
.band__overlay{ position:absolute; inset:0; z-index:1;
  background: radial-gradient(60% 60% at 50% 50%, rgba(18,11,14,.45), rgba(18,11,14,.78)); }
.band__quote{ position:relative; z-index:2; font-family: var(--font-serif);
  font-size: clamp(1.8rem,5.5vw,4.4rem); line-height:1.15; max-width:1000px; padding:0 var(--pad); font-weight:500; }
.band__quote span{ color: var(--gold-glow); }
.band__quote em{ font-style:italic; color: var(--gold); }

/* =========================================================
   SPLIT / FELSEFE
   ========================================================= */
.split{ display:grid; grid-template-columns: 1fr 1fr; align-items:center;
  gap: clamp(30px,5vw,80px); max-width: var(--maxw); margin:0 auto;
  padding: clamp(70px,11vh,130px) var(--pad); }
.split__visual{ position:relative; aspect-ratio: 4/5; border-radius:10px; overflow:hidden; }
.split__img{ position:absolute; inset:-12%; background-size:cover; background-position:center; will-change:transform; }
.split__visual::after{ content:''; position:absolute; inset:14px; border:1px solid rgba(246,239,231,.25);
  border-radius:6px; z-index:2; pointer-events:none; }
.split__badge{ position:absolute; bottom:20px; left:20px; z-index:3; font-size:.66rem; letter-spacing:.28em;
  text-transform:uppercase; color: var(--cream); background: rgba(22,16,19,.6); backdrop-filter: blur(6px);
  padding:10px 16px; border-radius:30px; border:1px solid rgba(220,183,140,.3); }
.split__title{ font-family: var(--font-serif); font-size: clamp(2rem,5vw,3.6rem); line-height:1.1;
  font-weight:500; margin:16px 0 22px; }
.split__title em{ color: var(--gold-glow); font-style:italic; }
.split__points{ list-style:none; margin:26px 0 32px; }
.split__points li{ padding:14px 0; border-bottom:1px solid rgba(220,183,140,.14);
  display:flex; align-items:center; gap:14px; color: var(--cream-soft); }
.split__points li::before{ content:'✦'; color: var(--gold); font-size:.8rem; }
@media (max-width:860px){ .split{ grid-template-columns:1fr; } .split__visual{ max-height:64vh; } }

/* =========================================================
   STATS
   ========================================================= */
.stats{ display:grid; grid-template-columns: repeat(4,1fr); max-width: var(--maxw); margin:0 auto;
  padding: 0 var(--pad) clamp(80px,12vh,120px); gap: clamp(20px,3vw,40px); }
.stat{ border-left:1px solid rgba(220,183,140,.2); padding:10px 0 10px 24px; }
.stat__num{ font-family: var(--font-serif); font-size: clamp(2.6rem,7vw,5rem); line-height:1;
  color: var(--cream); display:block; }
.stat__label{ font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color: var(--muted); }
@media (max-width:680px){ .stats{ grid-template-columns: repeat(2,1fr); row-gap:36px; } }

/* =========================================================
   GALERİ / MOZAİK
   ========================================================= */
.gallery{ padding-bottom: clamp(20px,4vh,40px); }
.mosaic{ max-width: var(--maxw); margin:0 auto; padding:0 var(--pad);
  display:grid; grid-template-columns: repeat(4,1fr); grid-auto-rows: 200px; gap:14px; }
.m{ position:relative; border-radius:8px; overflow:hidden; cursor:pointer;
  background-size:cover; background-position:center; }
.m::before{ content:''; position:absolute; inset:0; z-index:0; background-image:inherit;
  background-size:cover; background-position:center; transform: scale(1.04); transition: transform 1.1s var(--ease); }
.m:hover::before{ transform: scale(1.14); }
.m::after{ content:''; position:absolute; inset:0; z-index:1;
  background: linear-gradient(180deg, rgba(18,11,14,.05) 35%, rgba(18,11,14,.72)); transition: background .5s; }
.m:hover::after{ background: linear-gradient(180deg, rgba(201,139,134,.14) 20%, rgba(18,11,14,.6)); }
.m figcaption{ position:absolute; z-index:2; bottom:16px; left:16px; font-family: var(--font-serif);
  font-style:italic; font-size:1.25rem; color: var(--cream); transform: translateY(8px); opacity:.85;
  transition: all .5s var(--ease); }
.m:hover figcaption{ transform: translateY(0); opacity:1; }
.m--tall{ grid-row: span 2; }
.m--wide{ grid-column: span 2; }
@media (max-width:820px){
  .mosaic{ grid-template-columns: repeat(2,1fr); grid-auto-rows:160px; }
  .m--wide{ grid-column: span 2; }
}

/* =========================================================
   CTA
   ========================================================= */
.cta{ position:relative; padding: clamp(100px,17vh,200px) var(--pad); text-align:center; overflow:hidden; }
.cta__img{ position:absolute; inset:0; z-index:0; background-size:cover; background-position:center; }
.cta__glow{ position:absolute; inset:0; z-index:1; background:
  linear-gradient(180deg, rgba(18,11,14,.86), rgba(42,22,29,.8)),
  radial-gradient(45% 60% at 50% 38%, rgba(220,183,140,.22), transparent 70%); }
.cta__inner{ position:relative; z-index:2; max-width:760px; margin:0 auto; }
.cta__eyebrow{ font-size:.74rem; letter-spacing:.42em; text-transform:uppercase; color: var(--gold); }
.cta__title{ font-family: var(--font-serif); font-size: clamp(2.6rem,8vw,6rem); line-height:1.02;
  font-weight:500; margin:18px 0; }
.cta__title em{ font-style:italic; color: var(--gold-glow); }
.cta__sub{ color: var(--cream-soft); max-width:480px; margin:0 auto 36px; }
.cta__phone{ display:inline-flex; align-items:center; gap:16px; font-family: var(--font-serif);
  font-size: clamp(2rem,6vw,3.4rem); color: var(--cream); transition: color .4s, letter-spacing .5s var(--ease); }
.cta__phone:hover{ color: var(--gold-glow); letter-spacing:.02em; }
.cta__phone-ico{ font-size:.7em; color: var(--gold); }
.cta__row{ display:flex; align-items:center; gap:24px; justify-content:center; flex-wrap:wrap; margin-top:34px; }
.cta__hours{ font-size:.78rem; letter-spacing:.12em; color: var(--cream-soft); text-transform:uppercase; }

/* =========================================================
   FOOTER
   ========================================================= */
.footer{ padding: clamp(50px,8vh,90px) var(--pad) 36px; border-top:1px solid rgba(220,183,140,.14); }
.footer__top{ text-align:center; margin-bottom:40px; }
.footer__brand{ font-family: var(--font-serif); font-size: clamp(2rem,6vw,3.4rem); letter-spacing:.16em; }
.footer__tag{ color: var(--gold); font-style:italic; font-family: var(--font-serif); font-size:1.2rem; margin-top:8px; }
.footer__links{ display:flex; gap: clamp(18px,4vw,46px); justify-content:center; flex-wrap:wrap; padding:28px 0;
  border-top:1px solid rgba(220,183,140,.12); border-bottom:1px solid rgba(220,183,140,.12); }
.footer__links a{ font-size:.8rem; letter-spacing:.16em; text-transform:uppercase; color: var(--cream-soft); transition: color .4s; }
.footer__links a:hover{ color: var(--gold); }
.footer__bottom{ display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap; margin-top:28px;
  font-size:.74rem; letter-spacing:.1em; color: var(--muted); text-transform:uppercase; }

/* ---------- FAB ---------- */
.fab{ position:fixed; right:18px; bottom:18px; z-index:900; width:58px; height:58px; border-radius:50%;
  display:none; align-items:center; justify-content:center; background: var(--gold); color: var(--ink);
  font-size:1.4rem; box-shadow:0 14px 34px -8px rgba(0,0,0,.6); animation: pulse 2.5s infinite; }
@media (max-width:900px){ .fab{ display:flex; } }

/* =========================================================
   REVEAL
   ========================================================= */
.reveal{ opacity:0; transform: translateY(40px); transition: opacity 1s var(--ease), transform 1s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal-lines span{ opacity:0; transform: translateY(40px); transition: opacity .9s var(--ease), transform .9s var(--ease); }
.reveal-lines.in span{ opacity:1; transform:none; }
.reveal-lines.in span:nth-child(2){ transition-delay:.15s; }
.reveal-lines.in span:nth-child(3){ transition-delay:.3s; }

@media (prefers-reduced-motion: reduce){
  .reveal,.reveal-lines span,.reveal-word{ opacity:1 !important; transform:none !important; }
  .marquee__track,.fab,.btn__dot,.hero__img{ animation:none !important; }
}
