/* ============================================================
 *  SAHA SATIŞ CRM — Görsel kimlik
 *  Saha satışçısının aleti: sessiz, net, hızlı okunur, güvenli.
 * ============================================================ */
@import url('fonts/faces.css');

:root {
  --ink:        #0f2942;
  --teal:       #0d7d7d;
  --teal-bright:#14a3a3;
  --amber:      #d98e04;
  --teal-soft:  #e6f2f1;
  --bs-primary: #0d7d7d;
  --bs-body-font-family: 'Jakarta', system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --bs-border-radius: .7rem;
  --bs-border-radius-sm: .5rem;
}
[data-bs-theme="light"] {
  --bs-body-bg:            #eef2f5;
  --bs-body-color:        #1f2e3d;
  --bs-secondary-color:   #64748b;
  --surface:              #ffffff;
  --surface-2:            #f7f9fb;
  --border-soft:          #e2e8ee;
  --shadow-card:          0 1px 2px rgba(15,41,66,.04), 0 6px 20px rgba(15,41,66,.06);
  --shadow-hover:         0 2px 6px rgba(15,41,66,.08), 0 14px 36px rgba(15,41,66,.12);
  --nav-bg:               #0f2942;
  --crm-soft:             #f0f4f7;
}
[data-bs-theme="dark"] {
  --bs-primary: #1bb3b3;
  --teal: #1bb3b3;
  --bs-body-bg:            #0c1620;
  --bs-body-color:        #e3e9ef;
  --bs-secondary-color:   #8499ad;
  --surface:              #14222f;
  --surface-2:            #1a2a38;
  --border-soft:          #243747;
  --shadow-card:          0 1px 2px rgba(0,0,0,.3), 0 6px 20px rgba(0,0,0,.35);
  --shadow-hover:         0 2px 6px rgba(0,0,0,.4), 0 14px 36px rgba(0,0,0,.5);
  --nav-bg:               #0a1219;
  --crm-soft:             #1a2a38;
  --teal-soft:            #15302f;
}
body {
  font-family: var(--bs-body-font-family);
  background-color: var(--bs-body-bg);
  color: var(--bs-body-color);
  -webkit-font-smoothing: antialiased;
  letter-spacing: -.01em;
}
.stat-value, .table td, .table th, .cal-day,
dd, .badge, input, select, textarea {
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum" 1;
}
.brand-mark {
  width: 52px; height: 52px;
  display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, var(--teal), var(--teal-bright));
  color: #fff; font-weight: 800; letter-spacing: .5px;
  border-radius: 15px; font-size: 1.05rem;
  box-shadow: 0 4px 14px rgba(13,125,125,.35);
}
.brand-mark-sm { width: 36px; height: 36px; border-radius: 10px; font-size: .72rem; box-shadow: 0 2px 8px rgba(13,125,125,.4); }
.navbar {
  background: var(--nav-bg) !important;
  border-bottom: none !important;
  box-shadow: 0 1px 0 rgba(255,255,255,.04), 0 4px 20px rgba(15,41,66,.18);
  padding-top: .6rem; padding-bottom: .6rem;
}
.navbar .navbar-brand { color: #fff; }
.navbar .navbar-brand .fw-semibold { color: #fff; font-weight: 700; letter-spacing: -.02em; }
.navbar .nav-link {
  color: rgba(255,255,255,.72); font-weight: 500; font-size: .92rem;
  padding: .45rem .85rem; border-radius: .5rem; margin: 0 .1rem;
  transition: color .15s, background .15s;
}
.navbar .nav-link:hover { color: #fff; background: rgba(255,255,255,.07); }
.navbar .nav-link.active {
  color: #fff; font-weight: 600;
  background: rgba(20,163,163,.22);
  box-shadow: inset 0 0 0 1px rgba(20,163,163,.4);
}
.navbar .btn-outline-secondary { color: rgba(255,255,255,.8); border-color: rgba(255,255,255,.2); }
.navbar .btn-outline-secondary:hover { background: rgba(255,255,255,.12); color: #fff; border-color: transparent; }
.navbar-toggler { border-color: rgba(255,255,255,.25); }
.navbar-toggler-icon { background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(255,255,255,0.85)' stroke-width='2' stroke-linecap='round' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e"); }
.card {
  background: var(--surface);
  border: 1px solid var(--border-soft);
  border-radius: var(--bs-border-radius);
  box-shadow: var(--shadow-card);
}
.card-header { background: transparent; border-bottom: 1px solid var(--border-soft); font-weight: 600; letter-spacing: -.01em; padding: .85rem 1.1rem; }
.card-body { padding: 1.1rem; }
h1, h2, h3, .h4, .h5 { font-weight: 700; letter-spacing: -.025em; color: var(--bs-body-color); }
.page-eyebrow { font-size: .72rem; font-weight: 600; text-transform: uppercase; letter-spacing: .09em; color: var(--teal); }
.stat-card {
  background: var(--surface); border: 1px solid var(--border-soft);
  border-radius: var(--bs-border-radius); box-shadow: var(--shadow-card);
  position: relative; overflow: hidden; transition: transform .15s, box-shadow .15s;
}
.stat-card::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: linear-gradient(90deg, var(--teal), var(--teal-bright)); }
.stat-card.accent-amber::before { background: linear-gradient(90deg, var(--amber), #f0a92a); }
.stat-card.accent-green::before { background: linear-gradient(90deg, #1a9d5a, #2bbd72); }
.stat-card.accent-red::before   { background: linear-gradient(90deg, #c0392b, #e05545); }
.stat-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-hover); }
.stat-card .stat-value { font-size: 1.9rem; font-weight: 800; line-height: 1; letter-spacing: -.04em; }
.stat-card .stat-label { font-size: .72rem; color: var(--bs-secondary-color); text-transform: uppercase; letter-spacing: .06em; font-weight: 600; margin-top: .35rem; }
.btn { font-weight: 600; letter-spacing: -.01em; border-radius: .55rem; }
.btn-primary {
  --bs-btn-bg: var(--teal); --bs-btn-border-color: var(--teal);
  --bs-btn-hover-bg: #0a6a6a; --bs-btn-hover-border-color: #0a6a6a;
  --bs-btn-active-bg: #095a5a; --bs-btn-active-border-color: #095a5a;
  box-shadow: 0 2px 8px rgba(13,125,125,.25);
}
.btn-primary:hover { box-shadow: 0 4px 14px rgba(13,125,125,.35); }
.text-accent { color: var(--teal) !important; }
.table { --bs-table-bg: transparent; margin-bottom: 0; }
.table thead th { font-size: .72rem; text-transform: uppercase; letter-spacing: .05em; color: var(--bs-secondary-color); font-weight: 700; border-bottom: 1px solid var(--border-soft); padding: .7rem .9rem; }
.table tbody td { padding: .85rem .9rem; border-color: var(--border-soft); vertical-align: middle; }
.table-hover tbody tr { transition: background .12s; }
.table-hover tbody tr:hover { background: var(--surface-2); }
.row-link { cursor: pointer; }
.badge { font-weight: 600; font-size: .7rem; padding: .35em .65em; border-radius: .4rem; letter-spacing: .01em; }
.form-control, .form-select { background: var(--surface); border: 1px solid var(--border-soft); border-radius: .55rem; color: var(--bs-body-color); transition: border-color .15s, box-shadow .15s; }
.form-control:focus, .form-select:focus { border-color: var(--teal); box-shadow: 0 0 0 3px rgba(13,125,125,.15); background: var(--surface); color: var(--bs-body-color); }
.form-label { font-weight: 600; font-size: .82rem; color: var(--bs-body-color); margin-bottom: .35rem; }
.form-text { color: var(--bs-secondary-color); }
.filter-card { background: var(--surface-2); }
.list-group-item { background: transparent; border-color: var(--border-soft); padding: .85rem 1.1rem; }
.list-group-item-action:hover { background: var(--surface-2); }
.timeline { position: relative; padding-left: 1.6rem; }
.timeline::before { content: ""; position: absolute; left: .42rem; top: .3rem; bottom: .3rem; width: 2px; background: var(--border-soft); }
.timeline-item { position: relative; padding-bottom: 1.3rem; }
.timeline-item::before { content: ""; position: absolute; left: -1.4rem; top: .3rem; width: 13px; height: 13px; border-radius: 50%; background: var(--teal); border: 3px solid var(--surface); box-shadow: 0 0 0 1px var(--border-soft); }
.timeline-item.is-offer::before { background: var(--amber); }
.detay-baslik-card { border-left: 4px solid var(--teal); }
.cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 5px; }
.cal-head { text-align: center; font-size: .7rem; font-weight: 700; color: var(--bs-secondary-color); padding: 6px 0; text-transform: uppercase; letter-spacing: .05em; }
.cal-cell { min-height: 96px; background: var(--surface-2); border: 1px solid var(--border-soft); border-radius: 9px; padding: 5px; cursor: pointer; overflow: hidden; transition: background .12s, border-color .12s; }
.cal-cell:hover { background: var(--crm-soft); border-color: var(--teal); }
.cal-empty { border: none; cursor: default; background: transparent; }
.cal-empty:hover { background: transparent; }
.cal-today { border-color: var(--teal); border-width: 2px; background: var(--teal-soft); }
.cal-day { font-size: .82rem; font-weight: 700; margin-bottom: 3px; }
.cal-event { font-size: .67rem; color: #fff; border-radius: 5px; padding: 2px 5px; margin-bottom: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; cursor: pointer; font-weight: 600; }
[data-bs-theme="light"] .theme-icon-dark { display: none; }
[data-bs-theme="dark"]  .theme-icon-light { display: none; }
.modal-content { background: var(--surface); border: 1px solid var(--border-soft); border-radius: var(--bs-border-radius); }
.modal-header, .modal-footer { border-color: var(--border-soft); }
.fs-7 { font-size: .82rem; }
.cursor-pointer { cursor: pointer; }
.overdue { color: #d6453a; font-weight: 700; }
.dl-key { color: var(--bs-secondary-color); font-weight: 500; }
.auth-bg {
  background:
    radial-gradient(900px 500px at 100% -10%, rgba(20,163,163,.10), transparent),
    radial-gradient(700px 500px at -10% 110%, rgba(15,41,66,.08), transparent),
    var(--bs-body-bg);
  min-height: 100vh;
}
a:focus-visible, button:focus-visible, .form-control:focus-visible, .form-select:focus-visible { outline: 2px solid var(--teal); outline-offset: 2px; }
@media (prefers-reduced-motion: reduce) { * { transition: none !important; animation: none !important; } }
