/* ==========================================================================
   MindAeon WPA — Bileşen Kütüphanesi (components.css)
   --------------------------------------------------------------------------
   Kurumsal, Salesforce Lightning esintili, MOBİL-ÖNCELİKLİ PWA bileşenleri.
   TÜM renk/ölçü DAİMA :root'taki tasarım token'larından alınır — sabit hex
   GÖMÜLMEZ (tek istisna: --accent tanımsızsa var() içinde --primary fallback).
   Token'lar tema katmanınca [data-theme][data-mode] ile sağlanır.
   ========================================================================== */

/* --- İkon: 24px grid, currentColor çizgi ---------------------------------- */
.ic{
  width:24px;height:24px;
  flex:0 0 auto;
  display:inline-block;
  vertical-align:middle;
  fill:none;
  stroke:currentColor;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
}

/* --- Üst çubuk (appbar): sticky, çentik-güvenli üst boşluk ----------------- */
.appbar{
  position:sticky;top:0;z-index:40;
  display:flex;align-items:center;gap:calc(var(--space)*1);
  min-height:var(--row);
  padding-top:calc(var(--space)*1 + env(safe-area-inset-top));
  padding-right:calc(var(--space)*2);
  padding-bottom:calc(var(--space)*1);
  padding-left:calc(var(--space)*2);
  background:var(--surface);
  border-bottom:1px solid var(--line);
  box-shadow:var(--shadow-1);
  color:var(--ink);
}
.appbar__title{
  font-weight:700;
  font-size:1.05rem;
  letter-spacing:-.01em;
  line-height:1.2;
  margin:0;
  flex:1 1 auto;
  min-width:0;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}

/* --- Alt gezinme (navbar): tek-el, sabit, çentik-güvenli alt boşluk -------- */
.navbar{
  position:fixed;left:0;right:0;bottom:0;z-index:40;
  display:flex;align-items:stretch;
  background:var(--surface);
  border-top:1px solid var(--line);
  padding-bottom:env(safe-area-inset-bottom);
  box-shadow:var(--shadow-2);
}
.navbar__item{
  flex:1 1 0;
  min-height:var(--row);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:calc(var(--space)*.25);
  padding:calc(var(--space)*.75) calc(var(--space)*.5);
  background:none;border:none;
  color:var(--muted);
  font:inherit;font-size:.72rem;font-weight:600;
  text-decoration:none;
  cursor:pointer;
  position:relative;
}
.navbar__item .ic{width:22px;height:22px}
.navbar__item--active{color:var(--accent,var(--primary))}
.navbar__item--active::before{
  content:"";
  position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:32px;height:3px;border-radius:0 0 var(--radius-pill) var(--radius-pill);
  background:var(--accent,var(--primary));
}

/* --- Düğmeler (btn) ve varyantları ---------------------------------------- */
.btn{
  --_btn-bg:var(--surface-2);
  --_btn-fg:var(--ink);
  display:inline-flex;align-items:center;justify-content:center;
  gap:calc(var(--space)*.75);
  min-height:var(--tap);
  padding:0 calc(var(--space)*2);
  border:1px solid transparent;
  border-radius:var(--radius);
  background:var(--_btn-bg);
  color:var(--_btn-fg);
  font:inherit;font-weight:650;font-size:.95rem;line-height:1;
  cursor:pointer;
  text-decoration:none;
  -webkit-tap-highlight-color:transparent;
  transition:filter .15s ease, transform .05s ease, box-shadow .15s ease;
}
.btn .ic{width:20px;height:20px}
.btn:hover{filter:brightness(1.04)}
.btn:active{transform:translateY(1px)}
.btn:focus-visible{outline:2px solid var(--accent,var(--primary));outline-offset:2px}
.btn:disabled,.btn[aria-disabled="true"]{opacity:.5;pointer-events:none}

.btn--primary{
  background:linear-gradient(135deg,var(--primary),var(--primary-600));
  color:var(--on-primary);
  box-shadow:var(--shadow-1);
}
.btn--ghost{
  background:var(--surface);
  color:var(--ink);
  border-color:var(--line);
}
.btn--ok{background:var(--ok);color:var(--on-primary);border-color:transparent}
.btn--warn{background:var(--warn);color:var(--on-primary);border-color:transparent}
.btn--danger{background:var(--bad);color:var(--on-primary);border-color:transparent}
.btn--block{display:flex;width:100%}
.btn--sm{min-height:calc(var(--tap) - 8px);padding:0 calc(var(--space)*1.5);font-size:.85rem;border-radius:var(--radius)}
.btn--sm .ic{width:18px;height:18px}

/* --- Kart (card) ---------------------------------------------------------- */
.card{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-1);
  overflow:hidden;
  margin-bottom:calc(var(--space)*1.5);
}
.card__head{
  display:flex;align-items:center;gap:calc(var(--space)*1);
  padding:calc(var(--space)*1.5) calc(var(--space)*2);
  border-bottom:1px solid var(--line);
  font-weight:700;font-size:.95rem;
  color:var(--ink);
}
.card__head .ic{color:var(--muted)}
.card__body{
  padding:calc(var(--space)*2);
  color:var(--ink);
}
.card__body > :first-child{margin-top:0}
.card__body > :last-child{margin-bottom:0}

/* --- Liste (list / list-item) --------------------------------------------- */
.list{
  list-style:none;margin:0;padding:0;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  overflow:hidden;
}
.list-item{
  display:flex;align-items:center;gap:calc(var(--space)*1.5);
  min-height:var(--row);
  padding:calc(var(--space)*1.5) calc(var(--space)*2);
  border-bottom:1px solid var(--line);
  color:var(--ink);text-decoration:none;
  background:none;
  cursor:pointer;
  width:100%;text-align:left;font:inherit;
}
.list-item:last-child{border-bottom:0}
.list-item:active{background:var(--surface-2)}
.list-item:focus-visible{outline:2px solid var(--accent,var(--primary));outline-offset:-2px}
.list-item__main{
  flex:1 1 auto;min-width:0;
  display:flex;flex-direction:column;gap:calc(var(--space)*.25);
}
.list-item__main > strong{font-weight:650;font-size:.95rem}
.list-item__main > span{color:var(--muted);font-size:.82rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.list-item__meta{
  flex:0 0 auto;
  display:flex;flex-direction:column;align-items:flex-end;gap:calc(var(--space)*.25);
  color:var(--muted);font-size:.82rem;
  text-align:right;
}

/* --- Aşama şeridi (path): yatay done/current/todo -------------------------- */
.path{
  display:flex;align-items:flex-start;
  gap:0;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  padding:calc(var(--space)*1) 0;
}
.path__step{
  flex:1 1 0;min-width:64px;
  display:flex;flex-direction:column;align-items:center;
  gap:calc(var(--space)*.75);
  position:relative;
  font-size:.75rem;color:var(--muted);text-align:center;
}
/* Bağlayıcı çizgi: adımın solundan bir öncekine uzanır */
.path__step::before{
  content:"";
  position:absolute;top:11px;left:-50%;width:100%;height:2px;
  background:var(--line);z-index:0;
}
.path__step:first-child::before{display:none}
/* Yuvarlak düğüm */
.path__step::after{
  content:"";
  position:relative;z-index:1;
  width:24px;height:24px;border-radius:var(--radius-pill);
  background:var(--surface);border:2px solid var(--line);
  order:-1;
}
.path__step--done{color:var(--ink)}
.path__step--done::before{background:var(--ok)}
.path__step--done::after{background:var(--ok);border-color:var(--ok)}
.path__step--current{color:var(--ink);font-weight:700}
.path__step--current::after{
  background:var(--accent,var(--primary));
  border-color:var(--accent,var(--primary));
  box-shadow:0 0 0 4px var(--primary-100);
}
.path__step--todo{color:var(--muted)}

/* --- Form alanı (fld) ----------------------------------------------------- */
.fld{
  display:flex;flex-direction:column;gap:calc(var(--space)*.5);
  margin-bottom:calc(var(--space)*1.5);
}
.fld__label{
  font-size:.78rem;font-weight:600;color:var(--muted);
  letter-spacing:.01em;
}
.fld input,
.fld select,
.fld textarea{
  width:100%;
  min-height:var(--tap);
  padding:calc(var(--space)*1.25) calc(var(--space)*1.5);
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:var(--surface-2);
  color:var(--ink);
  font:inherit;font-size:.95rem;
  outline:none;
  transition:border-color .15s ease, box-shadow .15s ease;
}
.fld textarea{min-height:88px;resize:vertical}
.fld input::placeholder,
.fld textarea::placeholder{color:var(--muted)}
.fld input:focus,
.fld select:focus,
.fld textarea:focus{
  border-color:var(--accent,var(--primary));
  box-shadow:0 0 0 3px var(--primary-100);
}
.fld select{
  appearance:none;-webkit-appearance:none;
  background-image:linear-gradient(45deg,transparent 50%,var(--muted) 50%),
                   linear-gradient(135deg,var(--muted) 50%,transparent 50%);
  background-position:calc(100% - 18px) 20px,calc(100% - 13px) 20px;
  background-size:5px 5px;
  background-repeat:no-repeat;
  padding-right:calc(var(--space)*4);
}

/* --- Rozet (badge) -------------------------------------------------------- */
.badge{
  display:inline-flex;align-items:center;gap:calc(var(--space)*.5);
  padding:calc(var(--space)*.25) calc(var(--space)*1);
  border-radius:var(--radius-pill);
  font-size:.72rem;font-weight:700;line-height:1.4;
  white-space:nowrap;
  background:var(--surface-2);color:var(--muted);
}
.badge .ic{width:14px;height:14px}
.badge--ok{background:var(--ok-bg);color:var(--ok)}
.badge--warn{background:var(--warn-bg);color:var(--warn)}
.badge--bad{background:var(--bad-bg);color:var(--bad)}
.badge--info{background:var(--info-bg);color:var(--info)}
.badge--muted{background:var(--surface-2);color:var(--muted)}

/* --- Segment kontrol (seg) ------------------------------------------------ */
.seg{
  display:inline-flex;
  width:100%;
  padding:calc(var(--space)*.5);
  background:var(--surface-2);
  border:1px solid var(--line);
  border-radius:var(--radius);
  gap:calc(var(--space)*.5);
}
.seg__item{
  flex:1 1 0;
  min-height:calc(var(--tap) - 6px);
  display:inline-flex;align-items:center;justify-content:center;
  gap:calc(var(--space)*.5);
  padding:0 calc(var(--space)*1);
  border:none;border-radius:calc(var(--radius) - 3px);
  background:none;color:var(--muted);
  font:inherit;font-size:.85rem;font-weight:600;
  cursor:pointer;
  transition:background .15s ease, color .15s ease;
}
.seg__item .ic{width:18px;height:18px}
.seg__item--active{
  background:var(--surface);
  color:var(--ink);
  box-shadow:var(--shadow-1);
}

/* --- Bildirim (toast): ui.js tarafından yaratılır ------------------------- */
.toast{
  position:fixed;left:50%;
  bottom:calc(72px + env(safe-area-inset-bottom));
  transform:translateX(-50%) translateY(8px);
  z-index:80;
  max-width:min(92vw,420px);
  display:flex;align-items:center;gap:calc(var(--space)*1);
  padding:calc(var(--space)*1.25) calc(var(--space)*1.75);
  border-radius:var(--radius);
  background:var(--surface-3);
  color:var(--ink);
  border:1px solid var(--line);
  border-left:3px solid var(--info);
  box-shadow:var(--shadow-2);
  font-size:.88rem;
  opacity:0;pointer-events:none;
  transition:opacity .2s ease, transform .2s ease;
}
.toast .ic{width:20px;height:20px}
.toast--show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast--ok{border-left-color:var(--ok)}
.toast--ok .ic{color:var(--ok)}
.toast--warn{border-left-color:var(--warn)}
.toast--warn .ic{color:var(--warn)}
.toast--bad{border-left-color:var(--bad)}
.toast--bad .ic{color:var(--bad)}
.toast--info{border-left-color:var(--info)}
.toast--info .ic{color:var(--info)}

/* --- Alt-sheet (sheet): aşağıdan kayar ------------------------------------ */
.sheet{
  position:fixed;inset:0;z-index:70;
  display:flex;align-items:flex-end;justify-content:center;
  background:var(--scrim);
  opacity:0;pointer-events:none;
  transition:opacity .2s ease;
}
.sheet__panel{
  width:100%;max-width:640px;
  max-height:88vh;overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  background:var(--surface);
  border-radius:var(--radius-lg) var(--radius-lg) 0 0;
  border-top:1px solid var(--line);
  box-shadow:var(--shadow-2);
  padding:calc(var(--space)*2);
  padding-bottom:calc(var(--space)*2 + env(safe-area-inset-bottom));
  transform:translateY(100%);
  transition:transform .25s ease;
}
/* Sürükleme tutamağı */
.sheet__panel::before{
  content:"";
  display:block;
  width:40px;height:4px;margin:0 auto calc(var(--space)*1.5);
  border-radius:var(--radius-pill);
  background:var(--line);
}
.sheet--open{opacity:1;pointer-events:auto}
.sheet--open .sheet__panel{transform:translateY(0)}

/* --- Modal (modal): ortada ------------------------------------------------ */
.modal{
  position:fixed;inset:0;z-index:75;
  display:flex;align-items:center;justify-content:center;
  padding:calc(var(--space)*2);
  background:var(--scrim);
  opacity:0;pointer-events:none;
  transition:opacity .2s ease;
}
.modal__panel{
  width:100%;max-width:440px;
  max-height:86vh;overflow-y:auto;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-2);
  padding:calc(var(--space)*2.5);
  transform:translateY(12px) scale(.98);
  transition:transform .2s ease;
}
.modal--open{opacity:1;pointer-events:auto}
.modal--open .modal__panel{transform:translateY(0) scale(1)}

/* --- İskelet (skeleton): shimmer yükleme yer tutucusu --------------------- */
.skeleton{
  position:relative;overflow:hidden;
  min-height:14px;border-radius:var(--radius);
  background:var(--surface-2);
}
.skeleton::after{
  content:"";position:absolute;inset:0;
  transform:translateX(-100%);
  background:linear-gradient(90deg,transparent,var(--surface-3),transparent);
  animation:mind-shimmer 1.3s infinite;
}

/* --- Boş durum (empty) ---------------------------------------------------- */
.empty{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:calc(var(--space)*1);
  text-align:center;
  padding:calc(var(--space)*5) calc(var(--space)*2);
  color:var(--muted);
}
.empty .ic{width:44px;height:44px;color:var(--muted);opacity:.7}
.empty strong{color:var(--ink);font-size:1rem;font-weight:650}
.empty p{margin:0;font-size:.88rem;max-width:34ch}

/* --- KPI kutusu (kpi) ----------------------------------------------------- */
.kpi{
  display:flex;flex-direction:column;gap:calc(var(--space)*.25);
  padding:calc(var(--space)*1.75) calc(var(--space)*2);
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-1);
}
.kpi__value{
  font-size:1.6rem;font-weight:750;line-height:1.1;
  color:var(--ink);
  font-variant-numeric:tabular-nums;
  font-feature-settings:"tnum" 1;
}
.kpi__label{
  font-size:.78rem;font-weight:600;color:var(--muted);
  text-transform:uppercase;letter-spacing:.03em;
}

/* --- Animasyonlar --------------------------------------------------------- */
@keyframes mind-shimmer{100%{transform:translateX(100%)}}

/* Hareket azaltma tercihi: animasyonları kıs ------------------------------- */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.001ms !important;
  }
  .skeleton::after{display:none}
}
