/* BOOKING PAGE STYLES - Complete standalone stylesheet */

/* CSS Variables */
:root{
  --bg:#F7F4EF;
  --bg2:#EFEBE3;
  --bg3:#E8E2D8;
  --white:#FDFCFA;
  --ink:#1C1812;
  --ink2:#3A342B;
  --muted:#8C8278;
  --gold:#A8782A;
  --gold2:#C9973E;
  --gold-pale:#F0E4CC;
  --red:#8B2120;
  --border:rgba(168,120,42,.15);
  --border2:rgba(28,24,18,.08);
  --shadow:0 2px 24px rgba(28,24,18,.07);
  --shadow-lg:0 8px 48px rgba(28,24,18,.12);
}

/* Reset */
*,
*::before,
*::after{
  box-sizing:border-box;
  margin:0;
  padding:0;
}

html{
  scroll-behavior:smooth;
  -webkit-tap-highlight-color:transparent;
}

body{
  font-family:'DM Sans',sans-serif;
  background:var(--bg);
  color:var(--ink);
  overflow-x:hidden;
  line-height:1.6;
}

img{
  display:block;
  max-width:100%;
}

a{
  text-decoration:none;
  color:inherit;
}

::-webkit-scrollbar{
  width:3px;
}

::-webkit-scrollbar-track{
  background:var(--bg);
}

::-webkit-scrollbar-thumb{
  background:var(--gold);
  border-radius:2px;
}

/* NAV */
nav{
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:900;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:16px 24px;
  background:rgba(247,244,239,.96);
  backdrop-filter:blur(16px);
  box-shadow:0 1px 0 var(--border2),0 4px 20px rgba(28,24,18,.06);
  transition:background .4s,padding .35s,box-shadow .4s;
}

nav.stuck{
  background:rgba(247,244,239,.96);
  backdrop-filter:blur(16px);
  padding:12px 24px;
  box-shadow:0 1px 0 var(--border2),0 4px 20px rgba(28,24,18,.06);
}

.nav-logo{
  font-family:'Playfair Display',serif;
  font-size:1.25rem;
  letter-spacing:.1em;
  color:var(--ink);
  display:flex;
  align-items:center;
  gap:9px;
  transition:color .35s;
}

.logo-sc{
  color:var(--gold);
  font-size:.9rem;
}

.nav-links{
  display:none;
  gap:26px;
  list-style:none;
}

@media(min-width:768px){
  .nav-links{
    display:flex;
  }
}

.nav-links a{
  font-size:.71rem;
  font-weight:500;
  letter-spacing:.07em;
  color:var(--muted);
  transition:color .25s;
  position:relative;
}

.nav-links a::after{
  content:'';
  position:absolute;
  bottom:-3px;
  left:0;
  width:0;
  height:1.5px;
  background:var(--gold);
  transition:width .25s;
}

.nav-links a:hover::after,
.nav-links a:hover{
  width:100%;
  color:var(--gold);
}

nav.stuck .nav-links a:hover{
  color:var(--gold);
}

.nav-right{
  display:flex;
  align-items:center;
  gap:10px;
}

.nav-phone{
  display:none;
  font-size:.68rem;
  font-weight:500;
  color:var(--muted);
  transition:color .35s;
}

@media(min-width:640px){
  .nav-phone{
    display:block;
  }
}

.nav-cta{
  padding:9px 20px;
  border:1.5px solid rgba(168,120,42,.7);
  color:var(--gold);
  font-family:'DM Sans',sans-serif;
  font-size:.68rem;
  font-weight:600;
  letter-spacing:.18em;
  text-transform:uppercase;
  background:transparent;
  cursor:pointer;
  transition:background .25s,color .25s,border-color .25s;
  white-space:nowrap;
}

.nav-cta:hover{
  background:var(--gold);
  color:var(--white);
  border-color:var(--gold);
}

.hamburger{
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  gap:5px;
  width:40px;
  height:40px;
  cursor:pointer;
  background:rgba(247,244,239,.1);
  backdrop-filter:blur(8px);
  border:1px solid var(--border2);
  border-radius:8px;
  padding:8px;
  transition:all .3s;
}

.hamburger:hover{
  background:var(--gold-pale);
  border-color:var(--gold);
  transform:scale(1.05);
}

@media(min-width:768px){
  .hamburger{
    display:none;
  }
}

.hamburger span{
  width:22px;
  height:2px;
  background:var(--ink);
  transition:all .35s cubic-bezier(.68,-.55,.265,1.55);
  border-radius:2px;
  display:block;
}

.hamburger.open{
  background:rgba(168,120,42,.1);
  border-color:var(--gold);
}

.hamburger.open span{
  background:var(--gold);
}

.hamburger.open span:nth-child(1){
  transform:translateY(7px) rotate(45deg);
}

.hamburger.open span:nth-child(2){
  opacity:0;
  transform:scaleX(0);
}

.hamburger.open span:nth-child(3){
  transform:translateY(-7px) rotate(-45deg);
}

.mobile-menu{
  position:fixed;
  inset:0;
  z-index:850;
  background:linear-gradient(135deg,rgba(247,244,239,.98) 0%,rgba(239,235,227,.98) 100%);
  backdrop-filter:blur(20px);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:100px 24px 60px;
  transform:translateX(100%);
  transition:transform .5s cubic-bezier(.25,.46,.45,.94);
  box-shadow:-4px 0 40px rgba(28,24,18,.1);
}

.mobile-menu.open{
  transform:translateX(0);
}

.mobile-menu::before{
  content:'';
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:1px;
  background:linear-gradient(90deg,transparent 0%,var(--gold) 50%,transparent 100%);
  opacity:.3;
}

.mobile-menu a{
  font-family:'Playfair Display',serif;
  font-size:1.6rem;
  font-weight:400;
  color:var(--ink);
  transition:all .3s;
  padding:16px 24px;
  width:100%;
  max-width:280px;
  text-align:center;
  position:relative;
  border-radius:8px;
}

.mobile-menu a:not(.mm-cta)::before{
  content:'';
  position:absolute;
  left:0;
  top:50%;
  transform:translateY(-50%);
  width:0;
  height:2px;
  background:var(--gold);
  transition:width .3s ease;
  border-radius:2px;
}

.mobile-menu a:not(.mm-cta):hover::before,
.mobile-menu a:not(.mm-cta):active::before{
  width:4px;
}

.mobile-menu a:not(.mm-cta):hover{
  color:var(--gold);
  background:var(--gold-pale);
  transform:translateX(8px);
  padding-left:32px;
}

.mobile-menu a:not(.mm-cta):active{
  transform:translateX(4px) scale(.98);
}

.mm-cta{
  margin-top:24px!important;
  padding:16px 40px!important;
  background:linear-gradient(135deg,var(--gold) 0%,var(--gold2) 100%)!important;
  color:var(--white)!important;
  font-family:'DM Sans',sans-serif!important;
  font-size:.75rem!important;
  font-weight:700!important;
  letter-spacing:.2em!important;
  text-transform:uppercase!important;
  border-radius:8px!important;
  box-shadow:0 4px 20px rgba(168,120,42,.3)!important;
  transition:all .3s!important;
  max-width:280px!important;
}

.mm-cta:hover{
  transform:translateY(-2px)!important;
  box-shadow:0 6px 28px rgba(168,120,42,.4)!important;
  background:linear-gradient(135deg,var(--gold2) 0%,var(--gold) 100%)!important;
}

.mm-cta:active{
  transform:translateY(0)!important;
}

.mobile-close{
  position:absolute;
  top:24px;
  right:24px;
  width:44px;
  height:44px;
  border-radius:50%;
  background:var(--white);
  border:1.5px solid var(--border2);
  color:var(--ink);
  font-size:1.1rem;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:all .3s;
  z-index:10;
  box-shadow:0 2px 12px rgba(28,24,18,.1);
}

.mobile-close:hover{
  background:var(--gold);
  border-color:var(--gold);
  color:var(--white);
  transform:rotate(90deg);
  box-shadow:0 4px 16px rgba(168,120,42,.25);
}

.mobile-close:active{
  transform:rotate(90deg) scale(.95);
}

/* SECTION */
section{padding:65px 24px}
@media(min-width:640px){section{padding:80px 40px}}
@media(min-width:1024px){section{padding:90px 60px}}
.section-tag{font-size:.6rem;font-weight:600;letter-spacing:.4em;text-transform:uppercase;color:var(--gold);display:flex;align-items:center;gap:10px;margin-bottom:10px}
.section-tag::before{content:'';width:22px;height:1.5px;background:var(--gold)}
.section-h2{font-family:'Playfair Display',serif;font-size:clamp(1.6rem,4vw,2.4rem);font-weight:700;line-height:1.1;color:var(--ink);margin-bottom:12px}
.section-h2 em{font-style:italic;color:var(--gold)}
.section-sub{font-size:.82rem;font-weight:300;color:var(--muted);max-width:480px;line-height:1.75}

/* FOOTER */
footer{background:var(--ink);padding:45px 24px 28px;border-top:3px solid var(--gold)}
@media(min-width:640px){footer{padding:52px 40px 30px}}
.footer-grid{display:grid;grid-template-columns:1fr;gap:32px;margin-bottom:38px}
@media(min-width:640px){.footer-grid{grid-template-columns:1.4fr 1fr 1fr;gap:36px}}
.footer-logo{font-family:'Playfair Display',serif;font-size:1.55rem;color:rgba(247,244,239,.9);letter-spacing:.12em;margin-bottom:5px}
.footer-logo span{color:var(--gold)}
.footer-tag{font-size:.58rem;font-weight:600;letter-spacing:.28em;text-transform:uppercase;color:rgba(247,244,239,.22);margin-bottom:16px}
.footer-about{font-size:.78rem;font-weight:300;color:rgba(247,244,239,.32);line-height:1.8;max-width:250px}
.footer-social{display:flex;gap:9px;margin-top:18px}
.soc{width:34px;height:34px;border-radius:50%;border:1px solid rgba(168,120,42,.18);background:transparent;color:rgba(247,244,239,.28);font-size:.78rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s,color .2s,border-color .2s;text-decoration:none}
.soc:hover{background:var(--gold);color:var(--white);border-color:var(--gold)}
.footer-col-title{font-size:.58rem;font-weight:700;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:9px}
.footer-links a{font-size:.78rem;font-weight:300;color:rgba(247,244,239,.32);transition:color .2s}
.footer-links a:hover{color:var(--gold)}
.footer-con{display:flex;flex-direction:column;gap:9px}
.fc-item{display:flex;align-items:flex-start;gap:9px}
.fc-ic{color:var(--gold);font-size:.72rem;margin-top:2px;flex-shrink:0;width:13px}
.fc-txt{font-size:.76rem;font-weight:300;color:rgba(247,244,239,.38);line-height:1.5}
.fc-txt a{color:rgba(168,120,42,.8);transition:color .2s}
.fc-txt a:hover{color:var(--gold2)}
.footer-bottom{padding-top:22px;border-top:1px solid rgba(168,120,42,.09);display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;align-items:center}
.footer-copy{font-size:.6rem;color:rgba(247,244,239,.13)}
.footer-legal{display:flex;gap:16px}
.footer-legal a{font-size:.6rem;color:rgba(247,244,239,.18);transition:color .2s}
.footer-legal a:hover{color:var(--gold)}

/* TRAY & FAB */
.tray{position:fixed;bottom:0;left:0;right:0;z-index:700;background:rgba(247,244,239,.97);backdrop-filter:blur(14px);border-top:2px solid var(--gold);padding:11px 18px;display:flex;align-items:center;justify-content:space-between;gap:12px;transform:translateY(100%);transition:transform .35s cubic-bezier(.25,.46,.45,.94);box-shadow:0 -4px 24px rgba(28,24,18,.1)}
.tray.visible{transform:translateY(0)}
.tray-count{font-size:.6rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-bottom:1px}
.tray-total{font-family:'Playfair Display',serif;font-size:1.02rem;color:var(--ink)}
.tray-btn{padding:10px 18px;background:var(--gold);color:var(--white);font-family:'DM Sans',sans-serif;font-size:.65rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;border:none;cursor:pointer;border-radius:2px;white-space:nowrap;transition:background .2s}
.tray-btn:hover{background:var(--gold2)}
.fab{position:fixed;bottom:22px;right:20px;z-index:800;background:var(--gold);color:var(--white);width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.05rem;box-shadow:0 6px 22px rgba(168,120,42,.35);border:none;cursor:pointer;transition:transform .2s,background .2s}
.fab:hover{background:var(--gold2);transform:scale(1.08)}
.fab.up{bottom:80px}

/* SCROLL REVEAL */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.1s}
.d2{transition-delay:.2s}
.d3{transition-delay:.3s}

/* BOOKING SPECIFIC STYLES */

/* Hizmet seçimi (randevu sayfası) */
.booking-services-block{margin-bottom:28px;padding-bottom:24px;border-bottom:1px solid var(--border2)}
.booking-services-title{font-family:'Playfair Display',serif;font-size:1.1rem;color:var(--ink);margin-bottom:6px;display:flex;align-items:center}
.booking-services-sub{font-size:.78rem;color:var(--muted);margin-bottom:16px;line-height:1.5}
.booking-services-grid{display:grid;grid-template-columns:1fr;gap:10px;align-items:stretch}
@media(min-width:480px){.booking-services-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:640px){.booking-services-grid{grid-template-columns:repeat(3,1fr);gap:12px}}
.booking-services-loading{font-size:.85rem;color:var(--muted);padding:1rem 0}
.booking-service-card{display:flex;flex-direction:column;height:100%;min-height:0;box-sizing:border-box;padding:12px 14px;background:var(--bg);border:2px solid var(--border2);border-radius:10px;cursor:pointer;transition:all .28s ease;position:relative;text-align:left}
.booking-service-card:hover{border-color:var(--gold);background:var(--gold-pale);transform:translateY(-2px);box-shadow:0 4px 14px rgba(28,24,18,.08)}
.booking-service-card.selected{border-color:var(--gold);background:linear-gradient(135deg,rgba(168,120,42,.12) 0%,rgba(201,151,62,.08) 100%);box-shadow:0 2px 12px rgba(168,120,42,.2)}
.booking-service-head{display:flex;flex-direction:row;align-items:flex-start;justify-content:flex-start;gap:8px;flex-shrink:0;margin-bottom:6px}
.booking-service-thumb{width:40px;height:40px;border-radius:8px;overflow:hidden;flex-shrink:0;border:1px solid var(--border2)}
.booking-service-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.booking-service-check{color:var(--muted);font-size:1.05rem;flex-shrink:0;line-height:1;margin-top:2px}
.booking-service-card.selected .booking-service-check{color:var(--gold)}
.booking-service-title{flex:1;min-height:2.75em;display:flex;align-items:flex-start;margin-bottom:4px}
.booking-service-name{display:block;font-weight:600;font-size:.8rem;color:var(--ink);line-height:1.38;word-break:normal;overflow-wrap:break-word;hyphens:auto}
.booking-service-foot{display:flex;flex-direction:row;flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:6px 10px;margin-top:auto;padding-top:10px;border-top:1px solid rgba(28,24,18,.08)}
.booking-service-meta{font-size:.68rem;color:var(--muted);letter-spacing:.02em;white-space:nowrap}
.booking-service-price{font-family:'Playfair Display',serif;font-size:.88rem;font-weight:700;color:var(--gold);white-space:nowrap;margin-left:auto}

/* İlham Alın galerisi */
/* Personel seçimi */
.booking-staff-grid{display:grid;grid-template-columns:1fr;gap:8px}
@media(min-width:480px){.booking-staff-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:640px){.booking-staff-grid{grid-template-columns:repeat(3,1fr)}}
.booking-staff-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border:2px solid var(--border2);background:var(--bg);border-radius:10px;cursor:pointer;transition:all .22s ease}
.booking-staff-item:hover{border-color:var(--gold);background:var(--gold-pale)}
.booking-staff-item.selected{border-color:var(--gold);background:linear-gradient(135deg,rgba(168,120,42,.14) 0%,rgba(201,151,62,.08) 100%);box-shadow:0 2px 10px rgba(168,120,42,.18)}
.booking-staff-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0;box-shadow:0 0 0 3px rgba(255,255,255,.6) inset}
.booking-staff-name{font-size:.86rem;font-weight:600;color:var(--ink);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.booking-staff-role{font-size:.68rem;color:var(--muted);letter-spacing:.04em}

/* KVKK onay satırı ve modalı */
.otp-consent{display:flex;gap:10px;align-items:flex-start;font-size:.78rem;color:var(--ink2);margin-bottom:10px;cursor:pointer;line-height:1.5}
.otp-consent input{margin-top:3px;width:16px;height:16px;accent-color:var(--gold);flex-shrink:0}
.otp-consent .otp-consent-link{color:var(--gold);text-decoration:underline;font-weight:600}
.kvkk-modal-overlay{position:fixed;inset:0;background:rgba(10,8,6,.55);display:flex;align-items:center;justify-content:center;z-index:9000;padding:16px}
.kvkk-modal{background:var(--white);color:var(--ink);max-width:640px;width:100%;max-height:80vh;display:flex;flex-direction:column;border-radius:12px;box-shadow:var(--shadow-lg);overflow:hidden}
.kvkk-modal-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border2)}
.kvkk-modal-head h4{margin:0;font-family:'Playfair Display',serif;font-size:1.05rem}
.kvkk-modal-close{background:none;border:none;font-size:1.4rem;cursor:pointer;color:var(--muted)}
.kvkk-modal-body{padding:18px 20px;overflow:auto;font-size:.84rem;line-height:1.55;white-space:pre-wrap;word-break:normal;overflow-wrap:break-word}

/* OTP blok */
.otp-block{margin:6px 0 14px;padding:12px 14px;background:var(--bg);border:1px dashed var(--border);border-radius:10px}
.otp-block.verified{border-color:rgba(4,120,87,.35);background:rgba(4,120,87,.05)}
.otp-row{display:flex;flex-wrap:wrap;align-items:center;gap:10px}
.btn-otp-send{background:var(--ink);color:var(--white);border:none;border-radius:8px;padding:9px 14px;font-size:.78rem;font-weight:600;cursor:pointer;letter-spacing:.03em;transition:opacity .2s,transform .2s}
.btn-otp-send:hover:not(:disabled){transform:translateY(-1px)}
.btn-otp-send:disabled{opacity:.55;cursor:not-allowed}
.otp-status{font-size:.78rem;color:var(--muted)}
.otp-status.ok{color:#047857;font-weight:600}
.otp-status.error{color:var(--red);font-weight:600}
.otp-code-row{display:flex;gap:8px;margin-top:10px;align-items:stretch}
.otp-input{flex:1;max-width:200px;letter-spacing:.5em;font-size:1.05rem;text-align:center;font-weight:700}
.btn-otp-verify{background:var(--gold);color:var(--white);border:none;border-radius:8px;padding:0 18px;font-size:.82rem;font-weight:700;cursor:pointer;letter-spacing:.04em}
.btn-otp-verify:hover{background:var(--gold2)}

/* Mevcut randevu uyarısı */
.booking-dup-warning{margin:6px 0 14px;padding:12px 14px;background:#fff7ed;border:1px solid #fdba74;color:#7c2d12;border-radius:10px;font-size:.82rem;line-height:1.5}
.booking-dup-warning b{color:#7c2d12}

/* Alternatif personel slot'u (seçilen dolu ama başka müsait) */
.time-slot.alt-staff{border-style:dashed;color:var(--gold);border-color:var(--gold)}
.time-slot.alt-staff .slot-badge{margin-left:4px;font-size:.7rem;color:var(--gold)}

.booking-inspiration-block{margin-bottom:24px;padding:16px 0;border-bottom:1px solid var(--border2)}
.booking-inspiration-title{font-size:.8rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:12px;display:flex;align-items:center}
.booking-inspiration-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;max-height:140px;overflow:hidden;border-radius:10px}
.booking-inspiration-item{aspect-ratio:1;overflow:hidden;border-radius:8px;background:var(--bg2)}
.booking-inspiration-item img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.booking-inspiration-item:hover img{transform:scale(1.08)}
.inspiration-loading,.inspiration-empty{grid-column:1/-1;font-size:.78rem;color:var(--muted);padding:8px 0}
.booking-no-service-hint{margin-top:8px}
.booking-confirm-hint{font-size:.8rem;margin-bottom:12px;padding:10px 14px;border-radius:8px;display:flex;align-items:center}
.booking-hint-error{background:rgba(139,33,32,.08);color:var(--red);border:1px solid rgba(139,33,32,.2)}

/* Booking Section */
.book-sec{background:var(--bg);overflow-x:hidden}
.book-inner{max-width:100%;width:100%;margin:32px 0 0;background:var(--white);border:1px solid var(--border2);box-shadow:0 8px 40px rgba(28,24,18,.12),0 2px 8px rgba(28,24,18,.08);border-radius:16px;overflow:hidden;box-sizing:border-box;position:relative}
.book-inner::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--gold),var(--gold2),var(--gold));opacity:.6}
@media(min-width:640px){.book-inner{max-width:600px;margin:32px auto 0}}
@media(min-width:1024px){.book-inner{max-width:680px}}

/* Steps Bar */
.steps-bar{display:flex;background:linear-gradient(135deg,var(--ink) 0%,#2a241f 100%);padding:6px;gap:6px;width:100%;box-sizing:border-box;border-radius:12px 12px 0 0;position:relative;overflow:hidden}
.steps-bar::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:.3}
.step-tab{flex:1;padding:18px 10px;display:flex;flex-direction:column;align-items:center;gap:8px;background:rgba(247,244,239,.04);border-radius:8px;cursor:pointer;transition:all .35s cubic-bezier(.4,0,.2,1);min-width:0;box-sizing:border-box;position:relative;overflow:hidden}
.step-tab::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--gold) 0%,var(--gold2) 100%);opacity:0;transition:opacity .35s}
@media(max-width:480px){.step-tab{padding:14px 6px;gap:6px}.step-lbl{font-size:.5rem}}
.step-tab:hover:not(.active):not(.done){background:rgba(247,244,239,.08);transform:translateY(-1px)}
.step-tab.active{background:var(--gold);box-shadow:0 4px 16px rgba(168,120,42,.4),inset 0 1px 0 rgba(255,255,255,.2);transform:translateY(-2px)}
.step-tab.active::before{opacity:1}
.step-tab.done{background:rgba(168,120,42,.12);border:1px solid rgba(168,120,42,.2)}
.step-dot{width:32px;height:32px;border-radius:50%;border:2.5px solid rgba(247,244,239,.25);color:rgba(247,244,239,.4);font-size:.75rem;font-weight:700;display:flex;align-items:center;justify-content:center;transition:all .35s cubic-bezier(.4,0,.2,1);background:transparent;position:relative;z-index:1}
.step-tab.active .step-dot,
.step-tab.done .step-dot{
  border-color:var(--white);
  background:var(--white);
  color:var(--gold);
  box-shadow:0 2px 8px rgba(0,0,0,.15);
  transform:scale(1.1);
}
.step-tab.done .step-dot::after{content:'✓';position:absolute;font-size:.7rem;color:var(--gold)}
.step-tab.active .step-dot{box-shadow:0 0 0 4px rgba(255,255,255,.3),0 2px 8px rgba(0,0,0,.2)}
.step-lbl{font-size:.58rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:rgba(247,244,239,.35);transition:all .35s;position:relative;z-index:1;text-align:center}
.step-tab.active .step-lbl{color:var(--white);font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.1)}
.step-tab.done .step-lbl{color:rgba(247,244,239,.7)}

/* Form Panels */
.form-panels{background:var(--white);}
.panel{display:none;padding:36px 28px 40px;box-sizing:border-box;min-height:fit-content}
@media(max-width:480px){.panel{padding:28px 20px 32px}}
.panel.active{display:block;animation:pIn .5s cubic-bezier(.4,0,.2,1)}
@keyframes pIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

/* Calendar */
.cal-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;padding-bottom:16px;border-bottom:2px solid var(--border2);position:relative}
.cal-nav::after{content:'';position:absolute;bottom:-2px;left:50%;transform:translateX(-50%);width:80px;height:2px;background:var(--gold);border-radius:2px}
.cal-month{font-family:'Playfair Display',serif;font-size:1.15rem;color:var(--ink);font-weight:700;letter-spacing:.02em}
.cal-arrow{width:38px;height:38px;border:2px solid var(--border2);background:var(--white);cursor:pointer;font-size:.85rem;color:var(--ink);display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 6px rgba(28,24,18,.06)}
.cal-arrow:hover{background:var(--gold);border-color:var(--gold);color:var(--white);transform:scale(1.08) rotate(5deg);box-shadow:0 4px 12px rgba(168,120,42,.3)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;padding:8px 0;max-width:100%;box-sizing:border-box}
.cal-dn{text-align:center;font-size:.58rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);padding:8px 0 4px}
.cal-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:600;color:var(--ink);border-radius:10px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;margin:3px;border:2px solid transparent;background:var(--bg)}
.cal-day:hover:not(.empty):not(.past):not(.selected){background:var(--gold-pale);border-color:var(--gold);transform:scale(1.08) translateY(-2px);box-shadow:0 4px 12px rgba(168,120,42,.2)}
.cal-day.today{border:2.5px solid var(--gold);background:linear-gradient(135deg,var(--gold-pale) 0%,rgba(168,120,42,.08) 100%);font-weight:700;color:var(--gold);box-shadow:0 2px 8px rgba(168,120,42,.15)}
.cal-day.selected{background:linear-gradient(135deg,var(--gold) 0%,var(--gold2) 100%)!important;color:var(--white)!important;font-weight:700;box-shadow:0 4px 16px rgba(168,120,42,.4),inset 0 1px 0 rgba(255,255,255,.2);transform:scale(1.1) translateY(-2px);border-color:var(--gold)}
.cal-day.selected::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at center,transparent 30%,rgba(0,0,0,.1) 100%);border-radius:10px}
.cal-day.past{color:rgba(28,24,18,.2);cursor:default;pointer-events:none;opacity:.4;background:var(--bg2)}
.cal-day.empty{pointer-events:none;opacity:0}
.cal-day.busy::after{content:'';position:absolute;bottom:5px;left:50%;transform:translateX(-50%);width:5px;height:5px;border-radius:50%;background:var(--red);box-shadow:0 0 0 2px var(--white)}

/* Time Slots */
.time-lbl{font-size:.64rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:24px;margin-bottom:12px;padding-top:16px;border-top:1px solid var(--border2)}
.time-slots{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;max-width:100%;box-sizing:border-box}
@media(max-width:480px){.time-slots{grid-template-columns:repeat(2,1fr)}}
.time-slot{padding:14px 8px;text-align:center;border:2px solid var(--border2);font-size:.78rem;font-weight:600;color:var(--ink);cursor:pointer;border-radius:10px;transition:all .3s cubic-bezier(.4,0,.2,1);background:var(--white);box-shadow:0 2px 6px rgba(28,24,18,.05);position:relative;overflow:hidden}
.time-slot::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--gold) 0%,var(--gold2) 100%);opacity:0;transition:opacity .3s}
.time-slot span{display:block;position:relative;z-index:1}
.time-slot:hover:not(.full):not(.sel){background:var(--gold-pale);border-color:var(--gold);transform:translateY(-3px);box-shadow:0 4px 12px rgba(168,120,42,.2)}
.time-slot.sel{background:var(--gold);border-color:var(--gold);color:var(--white);font-weight:700;box-shadow:0 4px 16px rgba(168,120,42,.35);transform:translateY(-3px) scale(1.02)}
.time-slot.sel::before{opacity:1}
.time-slot.sel span{color:var(--white)}
.time-slot.full{background:var(--bg2);color:rgba(28,24,18,.25);cursor:default;pointer-events:none;font-size:.7rem;opacity:.5;border-color:var(--bg2)}
.time-slot.full::after{content:'Dolu';display:block;font-size:.55rem;font-weight:700;color:var(--red);margin-top:4px;letter-spacing:.05em;position:relative;z-index:1}

/* Modern Form Styles */
.form-header-modern{
  text-align:center;
  margin-bottom:32px;
  padding-bottom:24px;
  border-bottom:2px solid var(--border2);
  position:relative;
}
.form-header-modern::after{
  content:'';
  position:absolute;
  bottom:-2px;
  left:50%;
  transform:translateX(-50%);
  width:60px;
  height:2px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
}
.form-header-icon{
  width:56px;
  height:56px;
  margin:0 auto 14px;
  background:linear-gradient(135deg,var(--gold-pale) 0%,rgba(168,120,42,.08) 100%);
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:1.4rem;
  color:var(--gold);
  box-shadow:0 4px 16px rgba(168,120,42,.15);
}
.form-header-title{
  font-family:'Playfair Display',serif;
  font-size:1.35rem;
  color:var(--ink);
  margin-bottom:6px;
  font-weight:700;
}
.form-header-sub{
  font-size:.75rem;
  color:var(--muted);
  font-weight:300;
}
.form-group-modern{
  margin-bottom:24px;
  position:relative;
}
.form-row-modern{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
  margin-bottom:24px;
}
@media(max-width:480px){
  .form-row-modern{
    grid-template-columns:1fr;
    gap:24px;
  }
}
.input-wrapper,.textarea-wrapper{
  position:relative;
  width:100%;
}
.input-icon{
  position:absolute;
  left:16px;
  top:50%;
  transform:translateY(-50%);
  color:var(--muted);
  font-size:.85rem;
  transition:all .3s;
  z-index:2;
  pointer-events:none;
}
.textarea-icon{
  top:20px;
  transform:none;
}
.floating-label{
  position:absolute;
  left:48px;
  top:50%;
  transform:translateY(-50%);
  font-size:.8rem;
  color:var(--muted);
  font-weight:500;
  pointer-events:none;
  transition:all .3s cubic-bezier(.4,0,.2,1);
  background:var(--white);
  padding:0 6px;
  z-index:1;
}
.textarea-label{
  top:28px;
  transform:none;
}
.form-input-modern,.form-textarea-modern{
  width:100%;
  padding:16px 16px 16px 48px;
  background:var(--white);
  border:2px solid var(--border2);
  border-radius:10px;
  font-family:'DM Sans',sans-serif;
  font-size:.88rem;
  color:var(--ink);
  outline:none;
  transition:all .3s cubic-bezier(.4,0,.2,1);
  -webkit-appearance:none;
  appearance:none;
  box-shadow:0 2px 8px rgba(28,24,18,.04);
}
.form-textarea-modern{
  padding-top:20px;
  min-height:110px;
  resize:vertical;
  line-height:1.7;
}
.form-input-modern:focus,.form-textarea-modern:focus{
  border-color:var(--gold);
  box-shadow:0 4px 16px rgba(168,120,42,.15),0 0 0 4px rgba(168,120,42,.08);
  background:var(--white);
  transform:translateY(-2px);
}
.form-input-modern:focus+.floating-label,.form-input-modern:not(:placeholder-shown)+.floating-label,
.form-textarea-modern:focus+.floating-label,.form-textarea-modern:not(:placeholder-shown)+.floating-label{
  top:0;
  left:40px;
  font-size:.7rem;
  color:var(--gold);
  font-weight:600;
  transform:translateY(-50%);
  background:var(--white);
  padding:0 8px;
}
.textarea-label{
  top:20px;
}
.form-textarea-modern:focus+.textarea-label,.form-textarea-modern:not(:placeholder-shown)+.textarea-label{
  top:0;
  transform:translateY(-50%);
}
.form-input-modern:focus~.input-icon,.form-textarea-modern:focus~.input-icon{
  color:var(--gold);
  transform:translateY(-50%) scale(1.1);
}
.textarea-wrapper .input-icon{
  transform:none;
  top:20px;
}
.textarea-wrapper .form-textarea-modern:focus~.input-icon{
  transform:scale(1.1);
  top:20px;
}
.input-underline{
  position:absolute;
  bottom:0;
  left:48px;
  right:16px;
  height:2px;
  background:var(--gold);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .3s cubic-bezier(.4,0,.2,1);
  border-radius:2px;
}
.form-input-modern:focus~.input-underline,.form-textarea-modern:focus~.input-underline{
  transform:scaleX(1);
}
.form-input-modern::placeholder,.form-textarea-modern::placeholder{
  color:transparent;
  opacity:0;
}
.form-actions-modern{
  display:flex;
  gap:12px;
  margin-top:32px;
  padding-top:24px;
  border-top:1px solid var(--border2);
}
.btn-prev-modern,.btn-next-modern{
  flex:1;
  padding:16px 24px;
  font-family:'DM Sans',sans-serif;
  font-size:.75rem;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  border:none;
  cursor:pointer;
  border-radius:10px;
  transition:all .3s cubic-bezier(.4,0,.2,1);
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  position:relative;
  overflow:hidden;
}
.btn-prev-modern{
  background:var(--white);
  color:var(--muted);
  border:2px solid var(--border2);
  box-shadow:0 2px 8px rgba(28,24,18,.06);
}
.btn-prev-modern:hover{
  border-color:var(--gold);
  color:var(--gold);
  background:var(--gold-pale);
  transform:translateY(-2px);
  box-shadow:0 4px 16px rgba(168,120,42,.2);
}
.btn-next-modern{
  background:linear-gradient(135deg,var(--gold) 0%,var(--gold2) 100%);
  color:var(--white);
  box-shadow:0 4px 20px rgba(168,120,42,.3);
}
.btn-next-modern::before{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,var(--gold2) 0%,var(--gold) 100%);
  opacity:0;
  transition:opacity .3s;
}
.btn-next-modern:hover::before{
  opacity:1;
}
.btn-next-modern:hover{
  transform:translateY(-3px);
  box-shadow:0 6px 28px rgba(168,120,42,.4);
}
.btn-next-modern span,.btn-prev-modern span{
  position:relative;
  z-index:1;
}
.btn-next-modern i,.btn-prev-modern i{
  position:relative;
  z-index:1;
  transition:transform .3s;
}
.btn-next-modern:hover i{
  transform:translateX(3px);
}
.btn-prev-modern:hover i{
  transform:translateX(-3px);
}

/* Summary Card */
.sum-card{background:linear-gradient(135deg,var(--white) 0%,var(--bg) 100%);border:2px solid var(--border2);border-left:5px solid var(--gold);padding:28px;margin-bottom:24px;border-radius:12px;box-shadow:0 4px 20px rgba(28,24,18,.08),inset 0 1px 0 rgba(255,255,255,.5);position:relative;overflow:hidden}
.sum-card::before{content:'';position:absolute;top:0;right:0;width:120px;height:120px;background:radial-gradient(circle,var(--gold-pale) 0%,transparent 70%);opacity:.3;pointer-events:none}
.sum-row{display:flex;justify-content:space-between;align-items:flex-start;padding:12px 0;border-bottom:1px solid var(--border2);gap:16px;transition:padding .2s}
.sum-row:hover{padding-left:4px;padding-right:4px}
.sum-row:last-child{border-bottom:none;padding-top:16px;margin-top:8px;border-top:2px solid var(--gold);background:linear-gradient(135deg,var(--gold-pale) 0%,transparent 100%);margin-left:-28px;margin-right:-28px;padding-left:28px;padding-right:28px;border-radius:0 0 10px 10px}
.sum-key{font-size:.66rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);flex-shrink:0;display:flex;align-items:center;gap:6px}
.sum-key::before{content:'';width:3px;height:3px;background:var(--gold);border-radius:50%;opacity:.5}
.sum-val{font-size:.85rem;font-weight:600;color:var(--ink);text-align:right;line-height:1.5}
.sum-val.gold{color:var(--gold);font-family:'Playfair Display',serif;font-size:1.15rem;font-weight:700;text-shadow:0 1px 2px rgba(168,120,42,.1)}

/* Buttons */
.btn-next,.btn-prev,.btn-confirm{padding:16px 28px;font-family:'DM Sans',sans-serif;font-size:.72rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;border:none;cursor:pointer;border-radius:12px;transition:all .3s cubic-bezier(.4,0,.2,1);width:100%;margin-top:8px;display:flex;align-items:center;justify-content:center;gap:10px;position:relative;overflow:hidden}
.btn-confirm::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--gold2) 0%,var(--gold) 100%);opacity:0;transition:opacity .3s}
.btn-next,.btn-confirm{background:linear-gradient(135deg,var(--gold) 0%,var(--gold2) 100%);color:var(--white);box-shadow:0 2px 8px rgba(168,120,42,.25)}
.btn-next:hover,.btn-confirm:hover{background:linear-gradient(135deg,var(--gold2) 0%,var(--gold) 100%);transform:translateY(-2px);box-shadow:0 4px 12px rgba(168,120,42,.35)}
.btn-prev{background:transparent;color:var(--muted);border:1.5px solid var(--border2);margin-top:0;margin-bottom:10px}
.btn-prev:hover{border-color:var(--gold);color:var(--gold);background:var(--gold-pale);transform:translateY(-1px)}

/* Success Screen */
.success-screen{display:none;flex-direction:column;align-items:center;justify-content:center;padding:50px 24px;text-align:center;min-height:320px;background:linear-gradient(135deg,var(--white) 0%,var(--bg) 100%)}
.success-screen.show{display:flex;animation:pIn .5s ease}
.suc-icon{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--gold-pale) 0%,rgba(168,120,42,.1) 100%);border:3px solid var(--gold);display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:var(--gold);margin-bottom:18px;box-shadow:0 4px 16px rgba(168,120,42,.2);animation:successPulse 2s ease infinite}
@keyframes successPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}
.suc-h{font-family:'Playfair Display',serif;font-size:1.45rem;color:var(--ink);margin-bottom:8px;font-weight:700}
.suc-sub{font-size:.8rem;color:var(--muted);max-width:300px;line-height:1.75}
.suc-ref{margin-top:20px;padding:11px 22px;background:linear-gradient(135deg,var(--ink) 0%,#2a241f 100%);color:var(--gold);font-family:'Playfair Display',serif;font-size:.95rem;letter-spacing:.12em;border-radius:4px;box-shadow:0 2px 8px rgba(28,24,18,.2)}
.btn-reset{margin-top:16px;background:transparent;border:1.5px solid var(--border2);padding:10px 24px;font-family:'DM Sans',sans-serif;font-size:.66rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;color:var(--muted);border-radius:4px;transition:all .25s}
.btn-reset:hover{border-color:var(--gold);color:var(--gold);background:var(--gold-pale);transform:translateY(-1px)}
.btn-cancel-appointment{display:inline-flex;align-items:center;justify-content:center;background:transparent;border:1.5px solid #b91c1c;padding:10px 24px;font-family:'DM Sans',sans-serif;font-size:.66rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;color:#b91c1c;border-radius:4px;transition:all .25s}
.btn-cancel-appointment:hover{background:#fef2f2;color:#991b1b;border-color:#991b1b;transform:translateY(-1px)}
.btn-manage-booking{background:transparent;border:1.5px solid var(--gold);color:var(--gold);padding:10px 20px;font-family:'DM Sans',sans-serif;font-size:.7rem;font-weight:600;letter-spacing:.08em;cursor:pointer;border-radius:4px;transition:all .25s}
.btn-manage-booking:hover{background:var(--gold-pale);transform:translateY(-1px)}
.manage-booking-panel{max-width:520px;margin:24px auto 0;padding:28px 24px;background:var(--white);border-radius:12px;box-shadow:var(--shadow-lg);border:1px solid var(--border2)}
.manage-booking-inner .manage-booking-title{font-family:'Playfair Display',serif;font-size:1.2rem;color:var(--ink);margin-bottom:6px}
.manage-booking-sub{font-size:.8rem;color:var(--muted);margin-bottom:20px;line-height:1.5}
.manage-form{display:flex;flex-wrap:wrap;align-items:flex-end;gap:12px;margin-bottom:16px}
.manage-form .form-group-modern{flex:1;min-width:140px}
.manage-result{margin-top:20px;padding-top:20px;border-top:1px solid var(--border2)}
.manage-detail{font-size:.9rem;color:var(--ink2);line-height:1.8;margin-bottom:16px}
.manage-detail .md-row{display:flex;gap:8px}
.manage-detail .md-key{color:var(--muted);min-width:90px}
.manage-edit-form{margin-top:16px}
.manage-edit-title{font-size:.95rem;color:var(--ink);margin-bottom:12px}
.manage-edit-form .form-group-modern{margin-bottom:12px}
.manage-edit-form .form-label{display:block;font-size:.75rem;color:var(--muted);margin-bottom:4px}
.manage-message{padding:12px;border-radius:8px;margin-top:12px;font-size:.85rem}
.manage-message.success{background:#dcfce7;color:#166534}
.manage-message.error{background:#fef2f2;color:#b91c1c}

