:root{
  --brand:#16a34a; --brand-2:#22c55e; --brand-d:#15803d;
  --ink:#1a2238; --soft:#6b7385; --line:#eef1f6; --bg:#f5f7fb;
  --bekle:#f59e0b; --acil:#e5484d;
  --r:18px; --sh:0 6px 18px rgba(20,40,90,.08);
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%}
body{font-family:-apple-system,'Segoe UI',Roboto,system-ui,sans-serif;background:var(--bg);color:var(--ink);
  font-size:15px;overflow:hidden}
#app{height:100dvh;max-width:560px;margin:0 auto;position:relative;background:var(--bg);overflow:hidden;display:flex;flex-direction:column}
button{font-family:inherit;cursor:pointer}
.hidden{display:none!important}

/* ---------- GİRİŞ ---------- */
.login{height:100dvh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;
  padding:0 30px;background:linear-gradient(160deg,var(--brand-d),var(--brand) 55%,var(--brand-2));color:#fff}
.login .logo{width:84px;height:84px;border-radius:24px;background:rgba(255,255,255,.18);border:2px solid rgba(255,255,255,.5);
  display:flex;align-items:center;justify-content:center;font-size:42px;margin-bottom:20px}
.login h1{font-size:23px;margin-bottom:6px}.login p{opacity:.85;font-size:13px;margin-bottom:28px}
.login input{width:100%;max-width:320px;border:0;border-radius:14px;padding:14px 16px;font-size:15px;margin-bottom:12px;background:#fff;color:#1a2238;-webkit-text-fill-color:#1a2238;caret-color:#1a2238}
.login input:-webkit-autofill,.login input:-webkit-autofill:focus{-webkit-text-fill-color:#1a2238;-webkit-box-shadow:0 0 0 1000px #fff inset}
.login .showpw{display:flex;align-items:center;gap:8px;width:100%;max-width:320px;font-size:13px;opacity:.9;margin:-2px 0 4px;cursor:pointer}
.login .showpw input{width:auto;max-width:none;margin:0}
.login button{width:100%;max-width:320px;background:#0b3d23;color:#fff;border:0;border-radius:14px;padding:15px;font-size:16px;font-weight:650;margin-top:6px}
.login .err{color:#ffe1e1;font-size:13px;margin-bottom:10px;min-height:18px}
.login .hint{margin-top:22px;font-size:12px;opacity:.8;line-height:1.7}

/* ---------- HEADER ---------- */
.hdr{background:linear-gradient(135deg,var(--brand-d),var(--brand) 60%,var(--brand-2));color:#fff;
  padding:max(20px,env(safe-area-inset-top)) 20px 18px;position:relative;flex-shrink:0}
.hdr .t1{font-size:12.5px;opacity:.85}
.hdr .t2{font-size:21px;font-weight:700;letter-spacing:-.4px;margin-top:2px}
.hdr .t3{font-size:12px;opacity:.92;margin-top:5px;display:flex;gap:14px;flex-wrap:wrap}
.hdr .av{position:absolute;top:max(20px,env(safe-area-inset-top));right:20px;width:40px;height:40px;border-radius:50%;
  background:rgba(255,255,255,.22);border:1.5px solid rgba(255,255,255,.5);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px}
.hdr .bell{position:absolute;top:max(24px,calc(env(safe-area-inset-top) + 4px));right:70px;font-size:20px;background:none;border:0;color:#fff}
.hdr .bell .dot{position:absolute;top:-2px;right:-2px;width:9px;height:9px;border-radius:50%;background:var(--acil);border:1.5px solid var(--brand)}

/* segment */
.seg{background:#fff;margin:-32px 18px 0;border-radius:15px;padding:5px;display:flex;box-shadow:var(--sh);position:relative;z-index:5;flex-shrink:0}
.seg button{flex:1;border:0;background:transparent;padding:9px 0;border-radius:11px;font-size:13.5px;font-weight:600;color:var(--soft);transition:.15s}
.seg button.on{background:linear-gradient(135deg,var(--brand-d),var(--brand));color:#fff;box-shadow:0 5px 14px rgba(22,163,74,.4)}

/* ---------- SCROLL ALANI ---------- */
.scroll{flex:1;overflow-y:auto;padding:16px 18px 96px;-webkit-overflow-scrolling:touch}
.gl{font-size:11.5px;font-weight:700;color:var(--soft);text-transform:uppercase;letter-spacing:.5px;margin:6px 2px 11px;display:flex;align-items:center;gap:8px}
.gl .cnt{background:var(--line);color:var(--soft);border-radius:20px;padding:1px 8px;font-size:11px;font-weight:700}
.empty-state{text-align:center;color:#aab1c2;padding:50px 20px;font-size:14px}
.empty-state .em{font-size:40px;display:block;margin-bottom:10px}

/* ---------- PROGRAM KARTI ---------- */
.ev{background:#fff;border-radius:var(--r);padding:13px 15px 13px 17px;margin-bottom:11px;position:relative;display:flex;gap:13px;
  box-shadow:var(--sh);border:1px solid #f0f2f7;transition:.15s}
.ev:active{transform:scale(.987)}
.ev.done{opacity:.55}
.ev .bar{position:absolute;left:0;top:12px;bottom:12px;width:5px;border-radius:6px}
.ev .time{min-width:46px;text-align:center;flex-shrink:0}
.ev .time b{font-size:15px;font-weight:700}.ev .time span{font-size:10.5px;color:var(--soft);display:block}
.ev .body{flex:1;min-width:0}
.ev .body h3{font-size:14.5px;font-weight:650;letter-spacing:-.2px;margin-bottom:4px;display:flex;align-items:center;gap:6px}
.ev .meta{font-size:12px;color:var(--soft);margin-bottom:7px}
.badges{display:flex;gap:5px;flex-wrap:wrap}
.badge{font-size:10px;font-weight:600;padding:3px 8px;border-radius:14px;color:#fff;white-space:nowrap}
.b-press{background:#fef0c7;color:#b54708}.b-assign{background:#e9f7 ee;background:#e7f6ee;color:#15803d}.b-ppl{background:#f2f4f8;color:#6b7385}
.b-tag{background:#eef2ff;color:#4f5bd5}
.now-line{display:flex;align-items:center;gap:8px;margin:2px 2px 14px}
.now-line .pin{width:11px;height:11px;border-radius:50%;background:var(--acil);box-shadow:0 0 0 4px rgba(229,72,77,.16)}
.now-line .ln{flex:1;height:2px;background:linear-gradient(90deg,var(--acil),transparent)}
.now-line span{font-size:11px;font-weight:700;color:var(--acil)}

/* ---------- GELEN KUTUSU ---------- */
.mic-bar{display:flex;align-items:center;gap:11px;background:#fff;border:1px solid #f0f2f7;border-radius:14px;
  padding:11px 13px;margin-bottom:13px;box-shadow:var(--sh)}
.mic-bar .mic{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--acil),#ff7a7e);color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;border:0}
.mic-bar .mic.rec{animation:pulse 1.2s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(229,72,77,.5)}50%{box-shadow:0 0 0 12px rgba(229,72,77,0)}}
.mic-bar input{flex:1;border:0;font-size:13px;color:var(--ink);background:none;outline:none}
.hint-box{background:#fffaf0;border:1px solid #fde9c4;color:#92600c;font-size:12px;border-radius:12px;padding:10px 12px;margin-bottom:14px;line-height:1.5}
.inbox{background:#fff;border-radius:var(--r);padding:13px 15px;margin-bottom:11px;border:1px solid #f0f2f7;border-left:4px dashed var(--bekle);box-shadow:var(--sh)}
.inbox.acil{border-left-color:var(--acil)}
.inbox h3{font-size:14.5px;font-weight:650;margin-bottom:4px}
.inbox .src{font-size:11.5px;color:var(--soft);margin-bottom:11px;display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.inbox .acts{display:flex;gap:8px}
.inbox .acts button{flex:1;border:0;padding:9px;border-radius:11px;font-size:12px;font-weight:650}
.b-primary{background:linear-gradient(135deg,var(--brand-d),var(--brand));color:#fff}
.b-soft{background:#f2f4f8;color:var(--ink)}
.tag-acil{background:#fde7e7;color:#b42318;font-size:10px;font-weight:700;padding:2px 7px;border-radius:10px}

/* ---------- HAFTA ---------- */
.day{background:#fff;border-radius:15px;padding:12px 14px;margin-bottom:9px;border:1px solid #f0f2f7;box-shadow:var(--sh);display:flex;gap:13px}
.day.today{border:1.5px solid var(--brand)}
.day .dnum{text-align:center;min-width:40px}.day .dnum b{font-size:18px;display:block;line-height:1}.day .dnum span{font-size:10px;color:var(--soft);font-weight:600}
.day.today .dnum b{color:var(--brand)}
.day .dlist{flex:1;display:flex;flex-direction:column;gap:5px;justify-content:center;min-width:0}
.chip{font-size:11px;font-weight:600;padding:5px 8px;border-radius:8px;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.day .empt{font-size:12px;color:#aab1c2;font-style:italic}

/* ---------- AY ---------- */
.cal{background:#fff;border-radius:var(--r);padding:14px 12px;border:1px solid #f0f2f7;box-shadow:var(--sh);margin-bottom:13px}
.cal .wk{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;font-size:10px;font-weight:700;color:var(--soft);margin-bottom:7px}
.cal .grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}
.cal .cell{aspect-ratio:1;border-radius:10px;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:13px;font-weight:600;gap:3px;border:0;background:none;color:var(--ink)}
.cal .cell.out{color:#cfd5e0}.cal .cell.today{background:var(--brand);color:#fff}.cal .cell.sel{background:#e7f6ee;color:var(--brand-d);font-weight:750}
.cal .dots{display:flex;gap:2px;height:5px}.cal .dots i{width:5px;height:5px;border-radius:50%}

/* ---------- KİŞİ / SÖZ / EKİP ---------- */
.person{background:#fff;border-radius:15px;padding:12px 14px;margin-bottom:9px;border:1px solid #f0f2f7;display:flex;gap:12px;align-items:center;box-shadow:var(--sh)}
.person .av{width:42px;height:42px;border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex-shrink:0}
.person h3{font-size:14px;margin-bottom:2px}.person .m{font-size:11.5px;color:var(--soft)}
.person .cnt{margin-left:auto;background:var(--line);color:var(--soft);font-size:11px;font-weight:700;border-radius:20px;padding:3px 9px;text-align:right}
.soz{background:#fff;border-radius:15px;padding:13px 15px;margin-bottom:10px;border:1px solid #f0f2f7;border-left:4px solid var(--bekle);box-shadow:var(--sh)}
.soz.gec{border-left-color:var(--acil)}.soz.kapandi{border-left-color:var(--brand);opacity:.6}
.soz h3{font-size:14px;margin-bottom:3px}.soz .m{font-size:11.5px;color:var(--soft);margin-bottom:9px}
.soz .acts{display:flex;gap:8px}.soz .acts button{border:0;padding:8px 12px;border-radius:10px;font-size:12px;font-weight:650}

/* ---------- RAPOR ---------- */
.kpi{display:flex;gap:11px;margin-bottom:15px}
.kpi .box{flex:1;background:#fff;border-radius:15px;padding:14px;border:1px solid #f0f2f7;box-shadow:var(--sh)}
.kpi .box b{font-size:24px;font-weight:750;letter-spacing:-1px;display:block}.kpi .box span{font-size:11px;color:var(--soft);font-weight:600}
.bar-card{background:#fff;border-radius:var(--r);padding:16px;border:1px solid #f0f2f7;box-shadow:var(--sh);margin-bottom:13px}
.bar-card h4{font-size:14px;margin-bottom:15px}
.br{display:flex;align-items:center;gap:10px;margin-bottom:12px;font-size:12.5px}
.br .lab{width:84px;font-weight:600;display:flex;gap:5px;align-items:center}
.br .track{flex:1;height:9px;background:#f0f2f7;border-radius:6px;overflow:hidden}.br .fill{height:100%;border-radius:6px}
.br .num{width:24px;text-align:right;font-weight:700;color:var(--soft)}

/* ---------- BUTONLAR / FORM ---------- */
.btn-full{width:100%;background:linear-gradient(135deg,var(--brand-d),var(--brand));color:#fff;border:0;padding:14px;border-radius:14px;font-size:14px;font-weight:650;box-shadow:0 8px 20px rgba(22,163,74,.32)}
.fl{font-size:10.5px;font-weight:700;color:var(--soft);text-transform:uppercase;letter-spacing:.3px;display:block;margin:13px 2px 6px}
.fi{width:100%;background:#fff;border:1.5px solid var(--line);border-radius:12px;padding:11px 13px;font-size:14px;color:var(--ink);outline:none}
.fi:focus{border-color:var(--brand)}
.frow{display:flex;gap:10px}
.chipset{display:flex;gap:7px;flex-wrap:wrap}
.ct{font-size:12px;font-weight:600;padding:8px 12px;border-radius:20px;border:1.5px solid var(--line);background:#fff;color:var(--soft);display:inline-flex;gap:5px;align-items:center}
.ct.on{color:#fff;border-color:transparent}
.davet-grup{margin-bottom:5px}
.davet-uyeler{display:flex;flex-wrap:wrap;gap:6px;margin:7px 0 6px 12px;padding-left:10px;border-left:2px solid var(--line)}
.uye{font-size:11.5px;padding:6px 10px}
.toggle{display:flex;align-items:center;justify-content:space-between;background:#fff;border:1.5px solid var(--line);border-radius:12px;padding:11px 14px;margin-top:10px;font-size:13.5px;font-weight:600}
.sw{width:44px;height:26px;border-radius:20px;background:#d3d9e3;position:relative;transition:.2s;flex-shrink:0}
.sw.on{background:var(--brand)}
.sw:after{content:'';position:absolute;width:21px;height:21px;border-radius:50%;background:#fff;top:2.5px;left:2.5px;transition:.2s}
.sw.on:after{left:20.5px}

/* ---------- FAB + NAV ---------- */
.fab{position:absolute;bottom:calc(58px + env(safe-area-inset-bottom));left:50%;transform:translateX(-50%);width:58px;height:58px;border-radius:50%;
  background:linear-gradient(135deg,var(--brand-d),var(--brand));color:#fff;font-size:30px;display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 26px rgba(22,163,74,.5);border:4px solid var(--bg);z-index:20}
.nav{position:absolute;bottom:0;left:0;right:0;height:calc(64px + env(safe-area-inset-bottom));padding-bottom:env(safe-area-inset-bottom);
  background:rgba(255,255,255,.96);backdrop-filter:blur(14px);border-top:1px solid var(--line);display:flex;align-items:center;justify-content:space-around;z-index:15}
.nav a{display:flex;flex-direction:column;align-items:center;gap:3px;font-size:10px;color:var(--soft);font-weight:600;border:0;background:none}
.nav a.on{color:var(--brand)}.nav .ic{font-size:20px}

/* ---------- MODAL / SHEET ---------- */
.sheet-bg{position:fixed;inset:0;background:rgba(15,23,41,.5);z-index:60;display:flex;align-items:flex-end;justify-content:center}
.sheet{background:var(--bg);width:100%;max-width:560px;border-radius:24px 24px 0 0;padding:8px 20px calc(24px + env(safe-area-inset-bottom));
  max-height:92dvh;overflow-y:auto;animation:up .25s}
@keyframes up{from{transform:translateY(100%)}to{transform:translateY(0)}}
.sheet .grip{width:42px;height:5px;border-radius:5px;background:#d3d9e3;margin:8px auto 14px}
.sheet h2{font-size:18px;margin-bottom:4px}
.sheet .sub{font-size:12.5px;color:var(--soft);margin-bottom:8px}
.detail-map{height:96px;border-radius:14px;background:linear-gradient(135deg,#d7f0e0,#eef9f2);border:1px solid #d6ecdf;
  display:flex;align-items:center;justify-content:center;color:var(--brand-d);font-size:13px;font-weight:600;margin:8px 0 14px}
.kv{display:flex;gap:10px;padding:10px 2px;border-bottom:1px solid var(--line);font-size:13px}
.kv .k{color:var(--soft);width:90px;flex-shrink:0}.kv .v{color:var(--ink);font-weight:600}
.dbtns{display:flex;gap:8px;margin-top:16px}
.dbtns button{flex:1;border:0;padding:12px;border-radius:13px;font-size:12.5px;font-weight:650}
.b-go{background:linear-gradient(135deg,var(--brand-d),var(--brand));color:#fff}.b-edit{background:#fff;border:1.5px solid var(--line)!important;color:var(--ink)}
.b-del{background:#fff;border:1.5px solid #fbd5d6!important;color:var(--acil)}
.b-done{background:#e7f6ee;color:var(--brand-d)}

/* bildirim listesi */
.ntf{background:#fff;border-radius:14px;padding:12px 13px;margin-bottom:9px;border:1px solid #f0f2f7;display:flex;gap:11px;box-shadow:var(--sh)}
.ntf .ni{width:36px;height:36px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0}
.ntf h3{font-size:13px;margin-bottom:2px}.ntf .m{font-size:11.5px;color:var(--soft)}

/* toast */
.toast{position:fixed;bottom:120px;left:50%;transform:translateX(-50%);background:var(--brand-d);color:#fff;padding:12px 20px;border-radius:30px;
  font-size:13.5px;font-weight:600;z-index:90;box-shadow:0 12px 30px rgba(22,163,74,.5);opacity:0;transition:.3s;pointer-events:none}
.toast.show{opacity:1;bottom:134px}
.toast.err{background:var(--acil)}

/* küçük menü (more) */
.menu-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:8px}
.menu-grid button{background:#fff;border:1px solid #f0f2f7;border-radius:16px;padding:18px 8px;display:flex;flex-direction:column;align-items:center;gap:8px;font-size:12px;font-weight:600;color:var(--ink);box-shadow:var(--sh)}
.menu-grid .mi{font-size:26px}
