/* 1) Typography */
@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap");

/* =========================
   BASE
========================= */
* { box-sizing: border-box; font-family: Arial, sans-serif; }

:root{
  --vh: 1vh; /* JS ile güncelleniyor */
}

html, body{
  height: 100%;
  margin: 0;
  padding: 0;
  overflow: hidden; /* ✅ scroll sadece #app */
}

/* ✅ background body'de değil, fixed katmanda */
body{
  margin:0;
  padding:0;
  min-height:100vh;
  background: none !important;
  background-attachment: initial !important;
}

/* Arka planı sabit katmana al */
body::before{
  content:"";
  position: fixed;
  inset: 0;
  z-index: -1;
  background:
    
    url("./images/bg_7.jpg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

/* Mobilde gerçek ekran yüksekliği */
#app, #authRoot{
  height: calc(var(--vh, 1vh) * 100);
}

.container{
  width: min(650px, 92vw);
  margin: 0 auto;
  padding: 14px 0;
}

h2, h3, h4 { text-align: center; margin-top: 0; }

input, select, button{
  width: 100%;
  padding: 10px;
  margin-top: 8px;
  font-size: 16px;
}

button{
  border: none;
  border-radius: 5px;
  cursor: pointer;
}

/* =========================
   APP / AUTH ROOT
========================= */

/* ✅ Scroll sadece #app */
#app{
  position: fixed;
  inset: 0;
  height: calc(var(--vh, 1vh) * 100);
  overflow-y: auto;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-y: none;
}

/* Auth root overlay */
#authRoot{
  position: fixed;
  inset: 0;
  width: 100vw;
  height: calc(var(--vh, 1vh) * 100);
  display: none;
  place-items: center;
  padding: 20px;
  overflow: hidden;

  background:
    linear-gradient(rgba(0,0,0,.30), rgba(0,0,0,.30)),
    url("./images/bg_7.jpg");
  background-size: cover;
  background-position: center;
}

#authBox{
  width: min(520px, 92vw);
  margin: 0 !important;
}

/* =========================
   GROUPS + SWIPE
========================= */
.group-container{
  background: transparent !important;
  border-radius: 16px;
  overflow: hidden !important;
  padding: 0 !important; /* ✅ peek fix */
  transition: height .25s ease;
}

.group-wrapper{
  display:flex;
  width:100%;
  transition:transform .35s ease;
  touch-action: pan-y;
}

.group{
  flex:0 0 100% !important;
  width:100% !important;
  min-width:100% !important;
  padding:10px !important;
  min-height:150px;
  margin-right:0;
  background: transparent !important;
  border: none !important;
  border-radius:16px;
  color: rgba(234,246,255,.92);

  align-self: flex-start;
}

#chartGroup h4,
#normalGroup h4,
#importantGroup h4 { color:#F0FFF0; }

/* =========================
   GLASS PANELS
========================= */
.tasks-card{
  border-radius:18px;
  padding:12px;
  margin-bottom:15px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.10);
  box-shadow:0 18px 60px rgba(0,0,0,.35);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  color: rgba(234,246,255,.92);
}

.tasks-card input,
.tasks-card select{
  background:transparent;
  border:none;
  outline:none;
  color: rgba(234,246,255,.92);
  padding:10px 8px;
  border-bottom:2px solid rgba(66,215,230,.65);
  border-radius:0;
}

.tasks-card input::placeholder{ color: rgba(234,246,255,.45); }

.tasks-card input:focus,
.tasks-card select:focus{
  border-bottom-color: rgba(66,215,230,.95);
  box-shadow:none;
}

/* =========================
   TASK GLASS CARD
========================= */
.task{
  display:flex;
  gap:12px;
  padding:12px;
  border-radius:16px;
  color:#fff;
  width:100%;
  margin:0 auto 12px;

  background: rgba(255,255,255,.08) !important;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);

  border:1px solid rgba(255,255,255,.18) !important;
  box-shadow:
    0 10px 26px rgba(0,0,0,.40),
    inset 0 1px 0 rgba(255,255,255,.22);

  max-width: 100% !important;
}

.task.completed{ opacity: .92; }
.task.incomplete{ opacity: 1; }

.check{
  width:26px; height:26px;
  border-radius:50%;
  border:3px solid #fff;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  flex-shrink:0;
}

.check.checked{
  background:#fff;
  color:#28a745;
}

/* animasyon sadece özel class gelirse çalışsın */
.check.just-popped{
  animation: checkPop .25s ease;
}

@keyframes checkPop{
  0%{ transform:scale(.7); }
  60%{ transform:scale(1.2); }
  100%{ transform:scale(1); }
}

.task-content{ flex:1; }
.task-content small{ display:block; margin-top:4px; opacity:.85; }

.task-actions{ display:flex; gap:12px; margin-top:8px; }
.task-actions span{ cursor:pointer; font-size:18px; }

.task-actions button{
  width:auto;
  padding:0;
  background:transparent;
  color:#fff;
  font-size:18px;
  line-height:1;
}

/* =========================
   PAYMENTS + CHART
========================= */
.payment-wrapper{ position:relative; min-width:100%; margin-top:20px; }
.payment-bar{ height:40px; background:#e0e0e0; border-radius:6px; overflow:hidden; }
.payment-fill{ height:100%; width:0%; transition:width .5s, background .5s; }
.payment-text{
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  font-weight:bold; color:#000;
}

.chart-wrap{
  width: 100%;
  min-height: 320px;
  height: 52vh;
  max-height: 700px;
  position: relative;
  overflow: hidden;
  border-radius: 16px;
}

.chart-wrap canvas{
  width: 100% !important;
  height: 100% !important;
  display: block;
}
/* =========================
   COLLAPSIBLE
========================= */
.collapsible-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  cursor:pointer;
}

.collapse-icon{
  font-size:18px;
  transition:transform .3s;
}

.collapsed .collapse-icon{ transform: rotate(-90deg); }

.collapsible-content{
  overflow:hidden;
  max-height:0;
  transition:max-height .4s ease;
}
.collapsible-content.open{ max-height:1000px; }

#taskPanel,
.payment-card{
  background: rgba(255,255,255,.08) !important;
  border: 1px solid rgba(255,255,255,.14) !important;
  box-shadow: 0 18px 60px rgba(0,0,0,.35) !important;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  color: rgba(234,246,255,.92) !important;
}

/* =========================
   METAL BUTTON (logout + save)
========================= */
.logout-btn,
.save-btn{
  width:100%;
  padding:14px 18px;
  border-radius:18px;
  border:1px solid rgba(0,0,0,.45);
  cursor:pointer;

  font-weight:800;
  font-size:16px;
  letter-spacing:.06em;
  color:#1a1a1a;

  position:relative;
  overflow:hidden;

  background:
    radial-gradient(120% 120% at 50% 50%,
      rgba(0,0,0,0) 45%,
      rgba(0,0,0,.28) 100%),
    radial-gradient(70% 85% at 48% 38%,
      rgba(255,255,255,.95) 0%,
      rgba(255,255,255,.45) 22%,
      rgba(255,255,255,0) 60%),
    conic-gradient(from 210deg at 50% 50%,
      #f6f6f6, #bdbdbd, #f2f2f2, #8f8f8f,
      #f7f7f7, #a8a8a8, #f1f1f1, #7f7f7f, #f6f6f6),
    repeating-linear-gradient(90deg,
      rgba(255,255,255,.14) 0px,
      rgba(255,255,255,.14) 1px,
      rgba(0,0,0,.10) 2px,
      rgba(0,0,0,.10) 3px),
    linear-gradient(180deg, #f0f0f0 0%, #b3b3b3 50%, #e9e9e9 100%);

  background-blend-mode: multiply, screen, normal, overlay, normal;

  box-shadow:
    inset 0 2px 2px rgba(255,255,255,.85),
    inset 0 -10px 16px rgba(0,0,0,.35),
    inset 0 0 0 1px rgba(255,255,255,.18),
    0 12px 26px rgba(0,0,0,.55);

  text-shadow:
    0 1px 0 rgba(255,255,255,.70),
    0 -1px 0 rgba(0,0,0,.35),
    0 2px 6px rgba(0,0,0,.25);

  transition: transform .12s ease, filter .12s ease, box-shadow .12s ease;
}

.logout-btn:hover,
.save-btn:hover{ filter: contrast(1.12) brightness(1.06); }

.logout-btn:active,
.save-btn:active{ transform: translateY(2px); }

/* =========================
   SESSIONS LIST
========================= */
.session-item{
  background: rgba(10,16,22,.30);
  border: 1px solid rgba(255,255,255,.12);
  color: rgba(234,246,255,.92);
  border-radius: 14px;
  padding: 12px;
  margin-bottom: 10px;

  box-shadow:
    0 14px 40px rgba(0,0,0,.30),
    inset 0 1px 0 rgba(255,255,255,.16);

  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.session-row, .session-top{
  display:flex;
  justify-content:space-between;
  gap:10px;
}

#sessionsList small{ color: rgba(234,246,255,.70); }
#sessionsList strong{ color: rgba(234,246,255,.95); }

/* =========================
   APP BLUR (remote logout modal için)
========================= */
#app.blurred{
  filter: blur(6px);
  pointer-events: none;
  user-select: none;
}

/* =========================
   ✅ MODAL (SINGLE SOURCE - FINAL)
   - overlay kapalıyken event almaz
   - open iken tam shield
   - closing iken ghost click yutar
========================= */
.modal-overlay{
  position: fixed;
  inset: 0;
  z-index: 999999;
  display: none;
  align-items: center;
  justify-content: center;

  /* safe-area */
  padding: 18px;
  padding-top: calc(18px + env(safe-area-inset-top));
  padding-bottom: calc(18px + env(safe-area-inset-bottom));

  /* kapalıyken asla event almasın */
  pointer-events: none;
  touch-action: none;

  opacity: 0;
  transition: opacity 220ms ease;

  background: rgba(0,0,0,.18);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);

  -webkit-tap-highlight-color: transparent;
}

.modal-overlay.open{
  display: flex;
  opacity: 1;
  pointer-events: auto; /* backdrop event alır */
  touch-action: none;   /* iOS click sızıntısını keser */
}

/* ✅ kapanırken iOS ghost click altta butona düşmesin */
.modal-overlay.closing{
  display: flex;
  opacity: 0;
  pointer-events: auto;          /* click/touch yutsun */
  touch-action: none;
  background: rgba(0,0,0,0.001); /* görünmez ama event yakalar */
}

.modal-card{
  width: min(650px, 100%);
  max-height: calc((var(--vh, 1vh) * 100) - 40px);
  overflow: auto;
  border-radius: 18px;
  padding: 14px;

  background: rgba(20, 28, 36, 0.55);
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: 0 24px 80px rgba(0,0,0,.45);

  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;

  /* modal içi interaction */
  pointer-events: auto;
  touch-action: pan-y;
}

/* Modal içinde panel başlıkları normal görünsün */
.modal-card .tasks-card{ margin-bottom: 0; }

/* Modalde içerikler hep açık kalsın */
.modal-card .collapsible-content,
.modal-card .collapsible-content.open{
  max-height: none !important;
}

/* =========================
   ✅ BACKGROUND LOCK (HARD)
   Modal açıkken #app tamamen pasif, sadece modal etkileşim alır.
========================= */
body.taasky-modal-open #app{
  pointer-events: none !important;
  user-select: none !important;
  -webkit-user-select: none !important;
  touch-action: none !important;
}

/* Overlay + içi aktif */
body.taasky-modal-open .modal-overlay,
body.taasky-modal-open .modal-overlay *{
  pointer-events: auto !important;
}

/* =========================
   FIX: TASK PANEL SELECT DROPDOWN
========================= */
#taskPanel select{
  color: #EAF6FF !important;
  background: rgba(20,28,36,.85) !important;
  border-bottom: 2px solid rgba(66,215,230,.7) !important;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;

  background-image:
    linear-gradient(45deg, transparent 50%, #AFC6C7 50%),
    linear-gradient(135deg, #AFC6C7 50%, transparent 50%);
  background-position:
    calc(100% - 18px) calc(50% - 3px),
    calc(100% - 13px) calc(50% - 3px);
  background-size: 5px 5px, 5px 5px;
  background-repeat: no-repeat;
}

#taskPanel select option{
  color: #EAF6FF !important;
  background: #0f141a !important;
}
#taskPanel select optgroup{
  color: #9FB6B8 !important;
  background: #0f141a !important;
}

/* =========================
   TAASKY PREMIUM UI REVISION (v1)
   Drop-in overrides (append to end of style.css)
========================= */


:root{
  --ui-font: "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;

  /* Premium tokens */
  --glass-bg: rgba(18, 24, 32, 0.34);
  --glass-bg-strong: rgba(18, 24, 32, 0.52);
  --glass-border: rgba(255,255,255,.10);
  --glass-border-strong: rgba(255,255,255,.14);

  --text: rgba(234,246,255,.92);
  --muted: rgba(234,246,255,.68);

  --accent: rgba(66,215,230,.95);
  --accent-soft: rgba(66,215,230,.35);

  --shadow-lg: 0 22px 70px rgba(0,0,0,.42);
  --shadow-md: 0 14px 40px rgba(0,0,0,.35);

  --r-lg: 18px;
  --r-md: 14px;

  --pad: 14px;
  --gap: 12px;
}

*{ font-family: var(--ui-font) !important; }

/* 2) Background overlay refinement (daha premium koyuluk) */
body::before{
  background:
    radial-gradient(1200px 700px at 30% 10%, rgba(66,215,230,.10), rgba(0,0,0,0) 60%),
    linear-gradient(rgba(0,0,0,.30), rgba(0,0,0,.30)),
    url("./images/bg_7.jpg");
  background-size: cover;
  background-position: center;
}

/* 3) Cards: daha rafine cam */
.tasks-card{
  border-radius: var(--r-lg);
  padding: var(--pad);
  border: 1px solid var(--glass-border);
  background: var(--glass-bg) !important;
  box-shadow: var(--shadow-lg);
}

.tasks-card:hover{
  border-color: var(--glass-border-strong);
}

/* Header typography */
h3, h4{
  letter-spacing: .01em;
}
h4{
  font-weight: 700;
  font-size: 15px;
  color: var(--text);
}
h3{
  font-weight: 800;
  font-size: 16px;
  color: var(--text);
}

/* Inputs: daha “Apple-like” çizgi */
.tasks-card input,
.tasks-card select{
  border-bottom: 1px solid rgba(255,255,255,.14);
}
.tasks-card input:focus,
.tasks-card select:focus{
  border-bottom-color: var(--accent);
}

/* 4) Task card: daha temiz layout + contrast */
.task{
  border-radius: var(--r-md);
  background: rgba(255,255,255,.07) !important;
  border: 1px solid rgba(255,255,255,.14) !important;
  box-shadow: var(--shadow-md);
  padding: 12px;
}

.task-content strong{
  font-weight: 700;
  letter-spacing: .01em;
}
.task-content small{
  color: var(--muted);
  font-weight: 500;
}

/* Check: daha premium ring */
.check{
  border: 2px solid rgba(255,255,255,.85);
  width: 26px;
  height: 26px;
}

/* 5) Badge: “son ödeme” baloncuk standardı */
/* SON ÖDEME BADGE */

.payment-badge{
  display:inline-block;

  padding:4px 10px;
  margin-left:8px;

  font-size:12px;
  font-weight:700;
  letter-spacing:.02em;

  color:#EAF6FF;

  /* dikdörtgen ama yuvarlak köşeli */
  border-radius:8px;

  background:rgba(66,215,230,.18);
  border:1px solid rgba(66,215,230,.45);

  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);

  /* bölünmesin */
  white-space:nowrap;

  /* satır hizası */
  vertical-align:middle;
}

/* küçük “dot” ile premium vurgu */
.badge-last::before{
  content:"";
  width: 7px;
  height: 7px;
  border-radius: 99px;
  background: var(--accent);
  box-shadow: 0 0 0 4px rgba(66,215,230,.16);
}

/* 6) Actions: ikonlar daha sakin */
.task-actions button{
  opacity: .9;
  transform: translateY(0);
  transition: opacity .12s ease, transform .12s ease;
}
.task-actions button:hover{
  opacity: 1;
  transform: translateY(-1px);
}

/* 7) Buttons: metal hissi yumuşat (premium-sade) */

.save-btn,
.logout-btn{
  background: rgba(255,255,255,.86);
  color: #1a1a1a;
}

/* 8) Collapsible header: daha zarif */
.collapsible-header{
  padding: 4px 2px;
}
.collapse-icon{
  opacity: .9;
}

/* 9) Payment bar: daha modern */
.payment-bar{
  border-radius: 12px;
  background: rgba(255,255,255,.14);
}
.payment-text{
  color: rgba(10,16,22,.95);
  font-weight: 800;
}

/* 10) Sessions items: daha premium kart içi */
.session-item{
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: var(--shadow-md);
}

/* Optional: reduce emoji “toy” vibe a bit */
#sessionsTitle, #monthTitle, .payment-card h4{
  letter-spacing: .01em;
}

/* ===== Task Action Sheet (long press) ===== */
#taskActionSheet{
  position: fixed;
  inset: 0;
  display: none;
  align-items: flex-end;
  justify-content: center;
  z-index: 1200000;
  padding: 16px;
  padding-bottom: calc(16px + env(safe-area-inset-bottom));
  background: rgba(0,0,0,.35);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

#taskActionSheet.open{ display:flex; }

.task-sheet-card{
  width: min(520px, 100%);
  border-radius: 18px;
  padding: 12px;
  background: rgba(18,24,32,.72);
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 24px 80px rgba(0,0,0,.45);
}

.task-sheet-title{
  text-align:center;
  font-weight: 800;
  font-size: 14px;
  color: rgba(234,246,255,.92);
  margin: 6px 0 10px;
  letter-spacing:.01em;
}

.task-sheet-actions{
  display:flex;
  gap:10px;
}

.task-sheet-btn{
  flex:1;
  border-radius: 14px;
  padding: 12px 14px;
  font-weight: 900;
  border: 1px solid rgba(255,255,255,.12);
  cursor:pointer;
}

/* ===== Task Action Sheet (minimal buttons) ===== */
.task-sheet-actions{
  display:flex;
  gap:10px;
}

.task-sheet-btn{
  flex:1;
  border-radius: 14px;
  padding: 12px 14px;
  font-weight: 800;

  background: transparent;
  color: rgba(234,246,255,.92);

  border: 1px solid rgba(255,255,255,.14);

  cursor: pointer;
  -webkit-tap-highlight-color: transparent;

  transition: background .12s ease, border-color .12s ease, transform .12s ease;
}

/* Hover (desktop) */
.task-sheet-btn:hover{
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.22);
}

/* Press / active (mobile + desktop) */
.task-sheet-btn:active{
  background: rgba(255,255,255,.14);
  border-color: rgba(255,255,255,.28);
  transform: translateY(1px);
}

/* Focus (klavye) */
.task-sheet-btn:focus-visible{
  outline: none;
  box-shadow: 0 0 0 3px rgba(66,215,230,.22);
}

/* ===== Kebab hint on task ===== */
.task{
  position: relative;
}
.task .task-kebab{
  position:absolute;
  top:10px;
  right:10px;
  width:auto;
  padding: 6px 10px;
  border-radius: 12px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  color: rgba(234,246,255,.75);
  font-weight: 900;
  letter-spacing: .12em;
  line-height: 1;
  opacity: .55;
  pointer-events: none; /* sadece ipucu */
}

/* ===== Task Action Sheet (CENTER + NO SELECTION + TRANSPARENT BUTTONS) ===== */

/* Sheet artık ortada */
#taskActionSheet{
  align-items: center !important;      /* flex-end yerine */
  justify-content: center !important;
  padding: 18px !important;
  padding-top: calc(18px + env(safe-area-inset-top)) !important;
  padding-bottom: calc(18px + env(safe-area-inset-bottom)) !important;

  /* iOS selection/callout kapat */
  -webkit-user-select: none;
  user-select: none;
  -webkit-touch-callout: none;

  /* iOS tap highlight kapat */
  -webkit-tap-highlight-color: transparent;

  /* Sheet açıkken scroll/gesture sızıntısı olmasın */
  touch-action: none;
}

/* Kart */
.task-sheet-card{
  width: min(520px, 100%);
  max-width: 520px;
  border-radius: 18px;

  /* text seçilmesin */
  -webkit-user-select: none;
  user-select: none;
  -webkit-touch-callout: none;
}

/* Başlık da seçilmesin */
.task-sheet-title{
  -webkit-user-select: none;
  user-select: none;
  -webkit-touch-callout: none;
}

/* Aksiyonlar blok gibi dursun */
.task-sheet-actions{
  display: flex;
  gap: 10px;
}

/* Butonlar: şeffaf */
.task-sheet-btn{
  background: transparent !important;
  color: rgba(234,246,255,.92) !important;
  border: 1px solid rgba(255,255,255,.14) !important;
  box-shadow: none !important;
}

/* Dokununca hafif beyazlaşsın */
.task-sheet-btn:active{
  background: rgba(255,255,255,.10) !important;
  border-color: rgba(255,255,255,.22) !important;
}

/* iOS’ta hover yok ama desktop için de */
.task-sheet-btn:hover{
  background: rgba(255,255,255,.08) !important;
}

/* Cancel butonu tamamen kapalı */
#taskSheetCancel{ display:none !important; }

/* Task içindeki text selection da kökten kapansın (mor handle’lar için) */
.task, .task *{
  -webkit-user-select: none;
  user-select: none;
  -webkit-touch-callout: none;
}

.task{
  transition: transform .12s ease, box-shadow .12s ease;
}

.task:active{
  transform: scale(.98);
  box-shadow:
    0 6px 18px rgba(0,0,0,.35),
    inset 0 1px 0 rgba(255,255,255,.15);
}

@keyframes checkPop{
  0%{ transform:scale(.7); }
  60%{ transform:scale(1.2); }
  100%{ transform:scale(1); }
}

.payment-fill{
  transition: width .6s cubic-bezier(.4,0,.2,1),
              background .4s ease;
}

.payment-fill{
  transition: width .6s cubic-bezier(.4,0,.2,1),
              background .4s ease;
}



