/* =====================================================================
   SALOON AYTEKIN — Tasarım Sistemi
   Zarif, mürekkep siyahı + tek şampanya aksanı. Mobile-first PWA.
   ===================================================================== */

:root{
  /* mürekkep & kâğıt */
  --ink:#161310;          /* ana metin / koyu yüzey */
  --ink-2:#4d473e;        /* ikincil metin */
  --ink-3:#9a9182;        /* soluk / yardımcı */
  --paper:#FAF8F3;        /* ivory zemin */
  --card:#FFFFFF;         /* kart yüzeyi */
  --line:#ECE7DB;         /* ince çizgi */
  --line-2:#DED7C7;

  /* tek aksan: şampanya/altın */
  --gold:#B6904E;
  --gold-deep:#9A7838;
  --gold-soft:#F4ECD9;    /* seçili zemin tonu */
  --gold-line:#E4D3AC;

  --danger:#9a3b2f;
  --ok:#3f6f4a;

  /* tipografi */
  --display:'Marcellus', Georgia, serif;
  --body:'Manrope', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  /* ölçüler */
  --r-card:14px;
  --r-btn:11px;
  --shadow:0 1px 2px rgba(22,19,16,.04), 0 8px 24px rgba(22,19,16,.05);
  --shadow-soft:0 1px 2px rgba(22,19,16,.03);
  --app-w:440px;          /* telefon genişliği */
  --nav-h:64px;
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
[hidden]{display:none !important}
html,body{margin:0;padding:0}
body{
  font-family:var(--body);
  color:var(--ink);
  background:#E9E4DA;     /* uygulama dışı zemin (masaüstünde telefon çerçevesi) */
  font-size:15px; line-height:1.45;
  -webkit-font-smoothing:antialiased;
}

/* ----- telefon kabuğu: masaüstünde ortalanmış dar sütun ----- */
.app{
  position:relative;
  width:100%; max-width:var(--app-w);
  margin:0 auto; min-height:100vh; min-height:100dvh;
  background:var(--paper);
  display:flex; flex-direction:column;
  box-shadow:0 0 0 1px var(--line), 0 30px 80px rgba(22,19,16,.12);
}

/* ----- üst bar ----- */
.topbar{
  position:sticky; top:0; z-index:40;
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 18px 12px;
  background:rgba(250,248,243,.92);
  backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid var(--line);
}
.topbar .brand{display:flex; flex-direction:column; line-height:1}
.topbar .brand .eyebrow{
  font-family:var(--display); font-size:9px; letter-spacing:.42em;
  color:var(--ink-3); padding-left:2px; margin-bottom:3px;
}
.topbar .brand .name{
  font-family:var(--display); font-size:18px; letter-spacing:.18em;
  color:var(--ink);
}
.icon-btn{
  width:38px; height:38px; border:1px solid var(--line); border-radius:50%;
  background:var(--card); display:grid; place-items:center; cursor:pointer;
  position:relative; color:var(--ink);
}
.icon-btn .dot{position:absolute; top:8px; right:9px; width:7px; height:7px;
  border-radius:50%; background:var(--gold); border:2px solid var(--card)}

/* ----- içerik ----- */
.screen{flex:1; padding:20px 18px calc(var(--nav-h) + 28px); animation:fade .35s ease both}
@keyframes fade{from{opacity:0; transform:translateY(6px)}to{opacity:1; transform:none}}

.eyebrow{
  font-family:var(--display); font-size:11px; letter-spacing:.34em;
  text-transform:uppercase; color:var(--gold-deep);
}
.h1{font-family:var(--display); font-size:26px; letter-spacing:.01em; margin:.15em 0 .1em; font-weight:400}
.h2{font-family:var(--display); font-size:19px; letter-spacing:.02em; margin:0; font-weight:400}
.muted{color:var(--ink-3)}
.sub{color:var(--ink-2); font-size:13.5px}

/* hairline başlık ayıracı (markanın akışkan çizgisini anımsatan ince detay) */
.section-head{display:flex; align-items:baseline; justify-content:space-between; margin:26px 2px 12px}
.section-head .link{font-size:12.5px; color:var(--gold-deep); text-decoration:none; letter-spacing:.02em}

/* ----- greeting ----- */
.greeting{margin:6px 2px 2px}
.greeting .hi{font-family:var(--display); font-size:24px; font-weight:400}
.greeting .note{color:var(--ink-3); font-size:13.5px; margin-top:2px}

/* ----- hero randevu kartı ----- */
.hero{
  margin-top:18px; border-radius:var(--r-card); overflow:hidden;
  background:var(--ink); color:#F3EFE7; position:relative; padding:22px 20px 20px;
  box-shadow:var(--shadow);
}
.hero::after{ /* akışkan ince altın çizgi — imza detayı */
  content:""; position:absolute; right:-40px; top:-30px; width:160px; height:160px;
  border:1px solid rgba(182,144,78,.35); border-radius:50%;
}
.hero .eyebrow{color:var(--gold)}
.hero h3{font-family:var(--display); font-size:21px; font-weight:400; margin:8px 0 6px; letter-spacing:.01em}
.hero p{margin:0 0 16px; color:#C9C2B4; font-size:13px; max-width:80%}

/* ----- butonlar ----- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  font-family:var(--body); font-weight:600; font-size:14.5px; letter-spacing:.01em;
  border:none; border-radius:var(--r-btn); padding:13px 20px; cursor:pointer;
  text-decoration:none; transition:transform .08s ease, opacity .2s;
}
.btn:active{transform:scale(.985)}
.btn-light{background:var(--paper); color:var(--ink)}
.btn-dark{background:var(--ink); color:#F3EFE7; width:100%}
.btn-gold{background:var(--gold); color:#1c1606; width:100%}
.btn-outline{background:transparent; color:var(--ink); border:1px solid var(--line-2); width:100%}
.btn[disabled]{opacity:.4; pointer-events:none}

/* ----- liste kartı (hizmet / popüler) ----- */
.list{display:flex; flex-direction:column; gap:10px}
.row{
  display:flex; align-items:center; gap:14px;
  background:var(--card); border:1px solid var(--line); border-radius:var(--r-card);
  padding:12px 14px; box-shadow:var(--shadow-soft);
}
.row .thumb{
  width:52px; height:52px; border-radius:11px; flex:none;
  background:linear-gradient(135deg,#F0EADD,#E6DECB);
  display:grid; place-items:center; color:var(--gold-deep);
}
.row .body{flex:1; min-width:0}
.row .body .t{font-weight:600; font-size:14.5px}
.row .body .m{color:var(--ink-3); font-size:12.5px; margin-top:2px; display:flex; gap:8px; flex-wrap:wrap}
.row .price{font-family:var(--display); font-size:15px; white-space:nowrap}
.chev{color:var(--ink-3)}

/* hizmet ekle/çıkar düğmesi */
.add{
  width:32px; height:32px; border-radius:9px; flex:none; cursor:pointer;
  border:1px solid var(--line-2); background:var(--card); color:var(--ink);
  display:grid; place-items:center; font-size:18px; line-height:1; transition:.18s;
}
.add.on{background:var(--gold); border-color:var(--gold); color:#1c1606}

/* seçili satır vurgusu */
.row.selected{border-color:var(--gold-line); background:var(--gold-soft)}

/* ----- kategori sekmeleri ----- */
.tabs{display:flex; gap:22px; border-bottom:1px solid var(--line); margin:4px 2px 16px}
.tabs button{
  background:none; border:none; padding:0 0 11px; cursor:pointer;
  font-family:var(--body); font-size:14px; font-weight:600; color:var(--ink-3);
  position:relative;
}
.tabs button.active{color:var(--ink)}
.tabs button.active::after{
  content:""; position:absolute; left:0; right:0; bottom:-1px; height:2px;
  background:var(--gold); border-radius:2px;
}

/* ----- adım göstergesi ----- */
.steps{display:flex; align-items:center; gap:0; margin:2px 2px 18px}
.steps .st{display:flex; align-items:center; gap:8px; flex:none}
.steps .st .n{
  width:24px; height:24px; border-radius:50%; flex:none; font-size:12px; font-weight:700;
  display:grid; place-items:center; border:1px solid var(--line-2); color:var(--ink-3); background:var(--card);
}
.steps .st .lbl{font-size:11.5px; color:var(--ink-3); white-space:nowrap}
.steps .st.active .n{background:var(--ink); border-color:var(--ink); color:#fff}
.steps .st.active .lbl{color:var(--ink); font-weight:600}
.steps .st.done .n{background:var(--gold); border-color:var(--gold); color:#1c1606}
.steps .bar{height:1px; background:var(--line-2); flex:1; margin:0 6px}

/* ----- kuaför kartı ----- */
.staff{
  display:flex; align-items:center; gap:14px; padding:13px 14px;
  background:var(--card); border:1px solid var(--line); border-radius:var(--r-card);
  cursor:pointer; transition:.15s; box-shadow:var(--shadow-soft);
}
.staff.selected{border-color:var(--gold-line); background:var(--gold-soft)}
.staff .ava{width:54px; height:54px; border-radius:50%; flex:none; object-fit:cover;
  background:linear-gradient(135deg,#EFE8DA,#E2D9C6); display:grid; place-items:center;
  font-family:var(--display); color:var(--gold-deep); font-size:20px}
.staff .body{flex:1}
.staff .body .nm{font-weight:600; font-size:15px}
.staff .body .ti{color:var(--ink-3); font-size:12.5px}
.staff .rate{display:flex; align-items:center; gap:4px; font-size:12.5px; color:var(--ink-2)}
.staff .rate b{font-weight:700}
.staff .pick{width:22px; height:22px; border-radius:50%; border:1.5px solid var(--line-2); flex:none}
.staff.selected .pick{border-color:var(--gold); background:var(--gold);
  box-shadow:inset 0 0 0 4px var(--card)}

/* ----- tarih şeridi ----- */
.dates{display:flex; gap:9px; overflow-x:auto; padding:2px 2px 6px; margin:0 -2px 18px;
  scrollbar-width:none}
.dates::-webkit-scrollbar{display:none}
.date{
  flex:none; width:54px; padding:11px 0; border-radius:13px; text-align:center; cursor:pointer;
  background:var(--card); border:1px solid var(--line);
}
.date .dow{font-size:10.5px; color:var(--ink-3); letter-spacing:.06em; text-transform:uppercase}
.date .dnum{font-family:var(--display); font-size:19px; margin-top:3px}
.date .mon{font-size:10px; color:var(--ink-3); margin-top:1px}
.date.selected{background:var(--ink); border-color:var(--ink); color:#F3EFE7}
.date.selected .dow,.date.selected .mon{color:#C9C2B4}
.date.off{opacity:.35; pointer-events:none}

/* ----- saat ızgarası ----- */
.slots{display:grid; grid-template-columns:repeat(3,1fr); gap:10px}
.slot{
  padding:13px 0; text-align:center; border-radius:11px; cursor:pointer;
  background:var(--card); border:1px solid var(--line); font-weight:600; font-size:14px;
  font-variant-numeric:tabular-nums;
}
.slot.selected{background:var(--gold); border-color:var(--gold); color:#1c1606}
.slot.taken{opacity:.32; text-decoration:line-through; pointer-events:none}
.empty-slots{padding:26px 10px; text-align:center; color:var(--ink-3); font-size:13.5px;
  border:1px dashed var(--line-2); border-radius:var(--r-card)}

/* ----- özet / onay ----- */
.summary{background:var(--card); border:1px solid var(--line); border-radius:var(--r-card);
  padding:4px 16px; box-shadow:var(--shadow-soft)}
.summary .ln{display:flex; align-items:center; gap:12px; padding:13px 0; border-bottom:1px solid var(--line)}
.summary .ln:last-child{border-bottom:none}
.summary .ln .ic{width:34px; height:34px; border-radius:9px; flex:none; display:grid; place-items:center;
  background:var(--gold-soft); color:var(--gold-deep)}
.summary .ln .k{font-size:11.5px; color:var(--ink-3); letter-spacing:.04em; text-transform:uppercase}
.summary .ln .v{font-weight:600; font-size:14.5px; margin-top:1px}
.summary .total{display:flex; justify-content:space-between; align-items:center; padding:15px 0}
.summary .total .lbl{color:var(--ink-3); font-size:13px}
.summary .total .amt{font-family:var(--display); font-size:22px}

.success{display:grid; place-items:center; text-align:center; padding:30px 10px 8px}
.success .seal{width:84px; height:84px; border-radius:50%; display:grid; place-items:center;
  background:var(--gold-soft); border:1px solid var(--gold-line); color:var(--gold-deep); margin-bottom:14px}
.success h2{font-family:var(--display); font-size:23px; font-weight:400; margin:0}
.success p{color:var(--ink-2); margin:6px 0 0}

/* ----- sabit alt aksiyon çubuğu ----- */
.footbar{
  position:fixed; left:50%; transform:translateX(-50%);
  bottom:var(--nav-h); width:100%; max-width:var(--app-w); z-index:35;
  padding:12px 18px 14px; background:linear-gradient(to top, var(--paper) 72%, transparent);
  display:flex; align-items:center; gap:14px;
}
.footbar .meta{flex:1; min-width:0}
.footbar .meta .k{font-size:11px; color:var(--ink-3); letter-spacing:.04em}
.footbar .meta .v{font-family:var(--display); font-size:17px}
.footbar .btn{width:auto; flex:none; padding-left:26px; padding-right:26px}

/* ----- alt navigasyon ----- */
.bottomnav{
  position:fixed; left:50%; transform:translateX(-50%); bottom:0; z-index:50;
  width:100%; max-width:var(--app-w); height:var(--nav-h);
  background:rgba(255,255,255,.96); backdrop-filter:blur(10px);
  border-top:1px solid var(--line);
  display:flex; justify-content:space-around; align-items:center;
  padding-bottom:env(safe-area-inset-bottom);
}
.bottomnav a{
  display:flex; flex-direction:column; align-items:center; gap:3px; text-decoration:none;
  color:var(--ink-3); font-size:10.5px; letter-spacing:.02em; flex:1; padding-top:4px;
}
.bottomnav a.active{color:var(--ink)}
.bottomnav a.active svg{stroke:var(--ink)}
.bottomnav a .ind{width:5px; height:5px; border-radius:50%; background:transparent; margin-top:1px}
.bottomnav a.active .ind{background:var(--gold)}

/* ikon boyutu */
svg.i{width:22px; height:22px; stroke:currentColor; fill:none; stroke-width:1.6;
  stroke-linecap:round; stroke-linejoin:round}
svg.i-sm{width:16px; height:16px}

/* ----- flash mesajları ----- */
.flash{margin:12px 18px 0; padding:11px 14px; border-radius:11px; font-size:13.5px; border:1px solid}
.flash-info{background:var(--gold-soft); border-color:var(--gold-line); color:var(--gold-deep)}
.flash-error{background:#F7E9E6; border-color:#E6C4BD; color:var(--danger)}
.flash-ok{background:#E9F1EA; border-color:#C4DDC9; color:var(--ok)}

/* ----- formlar ----- */
.field{margin-bottom:14px}
.field label{display:block; font-size:12px; letter-spacing:.04em; color:var(--ink-2); margin:0 0 6px 2px}
.field input{
  width:100%; padding:13px 14px; font-family:var(--body); font-size:15px; color:var(--ink);
  background:var(--card); border:1px solid var(--line-2); border-radius:var(--r-btn);
}
.field input:focus{border-color:var(--gold); outline:none}
.field .hint{font-size:11.5px; color:var(--ink-3); margin:5px 2px 0}
.auth-foot{text-align:center; margin-top:18px; font-size:13.5px; color:var(--ink-3)}
.auth-foot a{color:var(--gold-deep); text-decoration:none; font-weight:600}

/* ----- profil menü satırları ----- */
.menu{display:flex; flex-direction:column; gap:1px; background:var(--line); border:1px solid var(--line);
  border-radius:var(--r-card); overflow:hidden; margin-top:14px}
.menu a{display:flex; align-items:center; gap:13px; padding:15px 16px; background:var(--card);
  text-decoration:none; color:var(--ink); font-size:14.5px}
.menu a .mi{color:var(--gold-deep); display:grid; place-items:center; width:22px}
.menu a .chev{margin-left:auto; color:var(--ink-3)}

/* ----- randevu kartı / rozet ----- */
.appt{background:var(--card); border:1px solid var(--line); border-radius:var(--r-card);
  padding:14px; box-shadow:var(--shadow-soft); margin-bottom:12px}
.appt .top{display:flex; justify-content:space-between; align-items:flex-start; gap:10px}
.appt .when{font-family:var(--display); font-size:16px}
.appt .svc{font-weight:600; margin-top:6px}
.appt .who{color:var(--ink-3); font-size:13px; margin-top:2px}
.appt .foot{display:flex; justify-content:space-between; align-items:center; margin-top:10px;
  padding-top:10px; border-top:1px solid var(--line)}
.appt .amt{font-family:var(--display); font-size:16px}
.badge{font-size:11px; font-weight:700; letter-spacing:.03em; padding:5px 10px; border-radius:999px; white-space:nowrap}
.badge.pending{background:var(--gold-soft); color:var(--gold-deep)}
.badge.confirmed{background:#E9F1EA; color:var(--ok)}
.badge.completed{background:#EEEAE0; color:var(--ink-2)}
.badge.cancelled,.badge.no_show{background:#F7E9E6; color:var(--danger)}

/* ----- filtre sekmeleri (pill) ----- */
.pills{display:flex; gap:8px; margin:2px 0 16px}
.pills a{padding:8px 16px; border-radius:999px; font-size:13px; font-weight:600; text-decoration:none;
  border:1px solid var(--line-2); color:var(--ink-2); background:var(--card)}
.pills a.active{background:var(--ink); border-color:var(--ink); color:#F3EFE7}

/* ----- boş durum ----- */
.empty{text-align:center; padding:48px 20px; color:var(--ink-3)}
.empty .ic{width:56px; height:56px; border-radius:50%; background:var(--gold-soft); color:var(--gold-deep);
  display:grid; place-items:center; margin:0 auto 14px}
.empty h3{font-family:var(--display); font-weight:400; color:var(--ink); font-size:18px; margin:0 0 4px}
.empty p{margin:0 0 18px; font-size:13.5px}

/* erişilebilirlik */
:focus-visible{outline:2px solid var(--gold); outline-offset:2px}
@media (prefers-reduced-motion:reduce){*{animation:none !important; transition:none !important}}
