/* =====================================================================
   Av. Hande Hamzaoğlu — Public stil
   Özel tasarım, bağımlılıksız. Accent: turuncu.
   ===================================================================== */

:root{
  --ink:#1f2430;
  --ink-soft:#3a414f;
  --muted:#8a8f99;
  --line:#e9e8e4;
  --bg:#f6f5f2;
  --card:#ffffff;
  --accent:#ea6a1e;
  --accent-dark:#cf5710;
  --accent-soft:#fdeee2;
  --ok:#1f9d57;
  --radius:16px;
  --radius-sm:11px;
  --shadow:0 18px 50px -28px rgba(31,36,48,.45);
  --shadow-sm:0 6px 22px -16px rgba(31,36,48,.5);
  --font:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans",sans-serif;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;font-family:var(--font);color:var(--ink);background:var(--bg);
  line-height:1.55;-webkit-font-smoothing:antialiased;font-size:16px;
}
a{color:inherit;text-decoration:none;}
img,iframe{max-width:100%;}
h1,h2,h3{margin:0;line-height:1.18;letter-spacing:-.02em;}
.container{max-width:1080px;margin:0 auto;padding:0 22px;}
.muted{color:var(--muted);}
.eyebrow{
  display:inline-block;font-size:12.5px;font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;color:var(--accent-dark);margin-bottom:12px;
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-weight:600;font-size:15px;border:0;border-radius:999px;padding:13px 24px;
  cursor:pointer;transition:transform .15s ease, box-shadow .2s ease, background .2s ease;
  font-family:inherit;
}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 10px 24px -12px rgba(234,106,30,.8);}
.btn-primary:hover{background:var(--accent-dark);transform:translateY(-1px);}
.btn-primary:disabled{opacity:.55;cursor:not-allowed;transform:none;}
.btn-block{width:100%;}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--line);}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent-dark);}
.btn-outline{background:transparent;color:var(--accent-dark);border:1px solid var(--accent);}
.btn-outline:hover{background:var(--accent-soft);}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;background:rgba(255,255,255,.86);
  backdrop-filter:saturate(150%) blur(10px);border-bottom:1px solid var(--line);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:70px;}
.brand{display:flex;align-items:center;gap:11px;font-weight:700;}
.brand-mark{
  width:38px;height:38px;border-radius:11px;background:var(--ink);color:#fff;
  display:grid;place-items:center;font-size:14px;letter-spacing:.05em;
  box-shadow:inset 0 0 0 2px var(--accent);
}
.brand-text{font-size:16px;letter-spacing:-.01em;}
.main-nav{display:flex;align-items:center;gap:6px;}
.main-nav a{
  padding:9px 14px;border-radius:999px;font-size:14.5px;font-weight:500;color:var(--ink-soft);
  transition:background .15s,color .15s;
}
.main-nav a:hover{background:#f0efeb;color:var(--ink);}
.main-nav a.nav-cta{background:var(--accent);color:#fff;font-weight:600;}
.main-nav a.nav-cta:hover{background:var(--accent-dark);}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px;}
.nav-toggle span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:.2s;}

/* ---------- Appointment ---------- */
.appointment-section{padding:44px 0 34px;}
.appt-card{
  display:grid;grid-template-columns:0.85fr 1.15fr;gap:0;background:var(--card);
  border:1px solid var(--line);border-radius:calc(var(--radius) + 4px);
  box-shadow:var(--shadow);overflow:hidden;
}
.appt-intro{
  padding:42px 38px;background:linear-gradient(165deg,#20242f 0%,#2c3242 100%);color:#fff;
}
.appt-intro .eyebrow{color:#ffb27d;}
.appt-intro h1{font-size:30px;font-weight:700;margin-bottom:14px;}
.appt-intro .lead{font-size:16px;color:#cdd1da;margin:0 0 18px;}
.appt-intro .intro-text{font-size:14.5px;color:#aab0bd;margin:0 0 22px;}
.intro-points{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px;}
.intro-points li{position:relative;padding-left:28px;font-size:14.5px;color:#dfe2e9;}
.intro-points li::before{
  content:"";position:absolute;left:0;top:3px;width:17px;height:17px;border-radius:50%;
  background:var(--accent);box-shadow:0 0 0 4px rgba(234,106,30,.18);
}
.intro-points li::after{content:"✓";position:absolute;left:4px;top:1px;color:#fff;font-size:11px;font-weight:700;}

.appt-booking{padding:34px 36px;min-height:420px;position:relative;}
.booking-step{margin-bottom:22px;}
.step-head{display:flex;align-items:center;gap:10px;font-weight:600;font-size:15px;margin-bottom:14px;}
.step-no{
  width:24px;height:24px;border-radius:50%;background:var(--accent-soft);color:var(--accent-dark);
  display:grid;place-items:center;font-size:13px;font-weight:700;
}
.selected-date,.selected-slot{margin-left:auto;font-size:13px;font-weight:600;color:var(--accent-dark);}

/* Calendar */
.calendar{border:1px solid var(--line);border-radius:var(--radius-sm);padding:14px;}
.cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
.cal-title{font-weight:700;font-size:15px;}
.cal-nav{
  width:34px;height:34px;border-radius:9px;border:1px solid var(--line);background:#fff;
  cursor:pointer;font-size:18px;line-height:1;color:var(--ink-soft);transition:.15s;
}
.cal-nav:hover{border-color:var(--accent);color:var(--accent-dark);}
.cal-nav:disabled{opacity:.35;cursor:not-allowed;}
.cal-weekdays,.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px;}
.cal-weekdays span{text-align:center;font-size:11px;font-weight:700;color:var(--muted);padding:4px 0;}
.cal-cell{
  aspect-ratio:1/1;border:0;background:#f7f6f3;border-radius:9px;cursor:pointer;
  font-size:14px;font-weight:500;color:var(--ink);transition:.13s;font-family:inherit;
}
.cal-cell:hover:not(:disabled){background:var(--accent-soft);color:var(--accent-dark);}
.cal-cell.empty{background:transparent;cursor:default;}
.cal-cell:disabled{color:#c7c7c3;background:#faf9f6;cursor:not-allowed;}
.cal-cell.today{box-shadow:inset 0 0 0 1.5px var(--accent);}
.cal-cell.selected{background:var(--accent);color:#fff;font-weight:700;}

/* Müsaitlik renkleri: açık=soft yeşil, dolu/kapalı=soft kırmızı */
.cal-cell.day-open{background:#e7f6ee;color:#1a7a45;}
.cal-cell.day-open:hover:not(:disabled){background:#d6efe1;color:#156236;}
.cal-cell.day-full{background:#fbe9e9;color:#b13b3b;}
.cal-cell.day-closed{background:#fbe9e9;color:#b13b3b;text-decoration:line-through;}
.cal-cell.day-full:hover:not(:disabled),
.cal-cell.day-closed:hover:not(:disabled){background:#f6dada;color:#9a2f2f;}
.cal-cell.selected.day-open,
.cal-cell.selected.day-full,
.cal-cell.selected.day-closed{background:var(--accent);color:#fff;text-decoration:none;}

/* Takvim açıklama (legend) */
.cal-legend{display:flex;gap:16px;flex-wrap:wrap;margin-top:12px;font-size:12.5px;color:var(--ink-soft);}
.cal-legend span{display:inline-flex;align-items:center;gap:6px;}
.cal-legend i{width:12px;height:12px;border-radius:4px;display:inline-block;}
.cal-legend .lg-open{background:#cdeeda;}
.cal-legend .lg-full{background:#f4cccc;}

/* Logo */
.brand-logo{max-height:46px;max-width:220px;width:auto;display:block;object-fit:contain;}

/* Slots */
.slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(82px,1fr));gap:9px;}
.slots .muted{grid-column:1/-1;margin:4px 0;font-size:14px;}
.slot-btn{
  border:1px solid var(--line);background:#fff;border-radius:10px;padding:11px 6px;cursor:pointer;
  font-size:14px;font-weight:600;color:var(--ink);transition:.13s;font-family:inherit;
}
.slot-btn:hover{border-color:var(--accent);color:var(--accent-dark);background:var(--accent-soft);}
.slot-btn.selected{background:var(--accent);border-color:var(--accent);color:#fff;}
.slot-btn.booked{background:#f3f2ef;color:#b6b6b2;cursor:not-allowed;border-style:dashed;}

/* Form */
.field{margin-bottom:14px;}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:13px;}
.field label{display:block;font-size:13px;font-weight:600;color:var(--ink-soft);margin-bottom:6px;}
.field input,.field textarea{
  width:100%;border:1px solid var(--line);border-radius:10px;padding:11px 13px;font-size:15px;
  font-family:inherit;color:var(--ink);background:#fff;transition:.15s;
}
.field input:focus,.field textarea:focus{outline:0;border-color:var(--accent);box-shadow:0 0 0 3px rgba(234,106,30,.15);}
.field input.invalid,.field textarea.invalid{border-color:#d6452f;box-shadow:0 0 0 3px rgba(214,69,47,.13);}
.check{display:flex;gap:10px;align-items:flex-start;font-size:13.5px;color:var(--ink-soft);margin:6px 0 18px;cursor:pointer;}
.check input{margin-top:3px;flex:0 0 auto;width:17px;height:17px;accent-color:var(--accent);}
.check a{color:var(--accent-dark);text-decoration:underline;}
.form-note{font-size:12.5px;color:var(--muted);text-align:center;margin:12px 0 0;}
.hp-field{position:absolute;left:-9999px;top:-9999px;height:0;overflow:hidden;}

/* Success / error */
.booking-success{text-align:center;padding:30px 10px;}
.success-icon{
  width:62px;height:62px;border-radius:50%;background:var(--accent-soft);color:var(--ok);
  font-size:30px;display:grid;place-items:center;margin:0 auto 16px;font-weight:700;
}
.booking-success h3{font-size:20px;margin-bottom:8px;}
.booking-success p{color:var(--muted);margin:0 0 20px;}
.booking-error{
  background:#fdecea;border:1px solid #f3c7bf;color:#b23a25;border-radius:11px;
  padding:12px 15px;font-size:14px;margin-top:14px;
}

/* ---------- Sections shared ---------- */
.section-head{text-align:center;max-width:560px;margin:0 auto 30px;}
.section-head h2{font-size:26px;}
.contact-section,.about-section,.services-section{padding:30px 0;}
.services-section{padding-bottom:60px;}

/* Contact */
.contact-card{
  display:grid;grid-template-columns:0.9fr 1.1fr;gap:26px;background:var(--card);
  border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);
  padding:30px;align-items:stretch;
}
.contact-info h3{font-size:19px;margin-bottom:18px;}
.info-list{list-style:none;margin:0 0 22px;padding:0;display:flex;flex-direction:column;gap:14px;}
.info-list li{display:flex;gap:13px;align-items:flex-start;font-size:15px;color:var(--ink-soft);}
.info-list .ico{flex:0 0 auto;font-size:17px;line-height:1.4;}
.info-list a:hover{color:var(--accent-dark);}
.contact-map iframe,.map-placeholder{
  width:100%;height:100%;min-height:280px;border:0;border-radius:var(--radius-sm);
  box-shadow:0 8px 28px -20px rgba(31,36,48,.5);
}
.map-placeholder{
  background:#f1f0ec;display:grid;place-items:center;text-align:center;color:var(--muted);
}
.map-placeholder span{font-size:34px;display:block;}

/* About */
.about-card{
  background:linear-gradient(165deg,#fff 0%,#fdf7f2 100%);border:1px solid var(--line);
  border-left:4px solid var(--accent);border-radius:var(--radius);padding:38px 40px;box-shadow:var(--shadow-sm);
}
.about-text h2{font-size:25px;margin-bottom:14px;}
.about-text p{font-size:16px;color:var(--ink-soft);max-width:720px;margin:0;}

/* Services */
.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:18px;}
.service-item{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:24px 22px;transition:.18s;
}
.service-item:hover{border-color:var(--accent);box-shadow:var(--shadow-sm);transform:translateY(-2px);}
.service-item h3{font-size:17px;margin-bottom:9px;position:relative;padding-left:14px;}
.service-item h3::before{content:"";position:absolute;left:0;top:4px;width:4px;height:16px;background:var(--accent);border-radius:2px;}
.service-item p{font-size:14.5px;color:var(--muted);margin:0;}

/* Footer */
.site-footer{background:var(--ink);color:#cdd1da;padding:34px 0;}
.footer-inner{display:flex;flex-wrap:wrap;gap:18px;align-items:center;justify-content:space-between;}
.footer-brand{display:flex;align-items:center;gap:11px;color:#fff;}
.footer-contact{display:flex;flex-wrap:wrap;gap:18px;font-size:13.5px;}
.footer-copy{font-size:13px;color:#8a8f99;width:100%;border-top:1px solid #333845;padding-top:16px;margin-top:6px;}

/* ---------- Responsive ---------- */
@media (max-width:860px){
  .appt-card{grid-template-columns:1fr;}
  .appt-intro{padding:32px 28px;}
  .appt-intro h1{font-size:25px;}
  .contact-card{grid-template-columns:1fr;}
  .contact-map iframe,.map-placeholder{min-height:240px;}
}
@media (max-width:680px){
  .nav-toggle{display:flex;}
  .main-nav{
    position:absolute;top:70px;left:0;right:0;background:#fff;border-bottom:1px solid var(--line);
    flex-direction:column;align-items:stretch;padding:10px 16px;gap:4px;display:none;
    box-shadow:var(--shadow-sm);
  }
  .main-nav.open{display:flex;}
  .main-nav a{padding:12px 14px;}
  .field-row{grid-template-columns:1fr;}
  .appt-booking{padding:26px 22px;}
}
@media (prefers-reduced-motion:reduce){
  *{scroll-behavior:auto !important;transition:none !important;}
}

/* ===================== İLETİŞİM FORMU ===================== */
.contact-form-card{margin-top:28px;background:#fff;border:1px solid var(--line,#e7e3da);border-radius:18px;padding:26px 26px 28px;box-shadow:0 8px 30px rgba(20,20,20,.05);}
.cf-intro{margin-bottom:18px;}
.cf-intro h3{margin:6px 0 6px;font-size:22px;}
.cf-intro p{margin:0;color:var(--muted,#76706a);}
.contact-form-card .field{margin-bottom:14px;}
.contact-form-card .field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.captcha-field{background:#faf7f2;border:1px dashed #e0d6c6;border-radius:12px;padding:13px 15px;}
.captcha-field label{font-weight:600;}
.captcha-field input{max-width:130px;}
.hp-field{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden;}
.msg-success{margin-top:14px;background:#e7f6ee;border:1px solid #bfe6cf;color:#157a42;border-radius:10px;padding:13px 15px;font-weight:600;}

@media(max-width:560px){ .contact-form-card .field-row{grid-template-columns:1fr;} }

/* ===================== KVKK MODAL ===================== */
.kvkk-modal{position:fixed;inset:0;z-index:1000;display:none;align-items:center;justify-content:center;padding:20px;background:rgba(20,18,16,.55);backdrop-filter:blur(2px);}
.kvkk-modal.open{display:flex;}
.kvkk-card{background:#fff;border-radius:18px;max-width:620px;width:100%;max-height:82vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.3);}
.kvkk-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:20px 24px;border-bottom:1px solid #efe9e0;}
.kvkk-card-head h3{margin:0;font-size:18px;}
.kvkk-close{border:0;background:#f1ece4;width:34px;height:34px;border-radius:50%;font-size:22px;line-height:1;cursor:pointer;color:#6a635c;transition:.15s;}
.kvkk-close:hover{background:#e6dfd4;color:#1f1c19;}
.kvkk-body{padding:22px 24px;overflow-y:auto;line-height:1.7;color:#4a443e;font-size:14.5px;}
.kvkk-contact{margin-top:16px;padding-top:14px;border-top:1px solid #efe9e0;font-weight:600;}
.kvkk-contact a{color:var(--accent,#ea6a1e);}
