/* ===== AI Strategy Playbook — tasarım sistemi (token-first, sakin/kurumsal) ===== */
:root{
  /* Volt marka paleti (demo.volt.calik.com): mor + lime */
  --bg:#faf7ff; --surface:#ffffff; --surface-2:#f7f4ff;
  --ink:#1f2430; --muted:#5b5570; --line:#ece8f6; --line-2:#f3eefb;
  --accent:#4C1D95; --accent-2:#6D28D9; --accent-weak:#efe7ff; --accent-ink:#3b1675;
  --lime:#84CC16; --target:#84CC16; --importance:#F59E0B;
  --danger:#c0392b; --ok:#1c8a5b;
  --radius:14px; --radius-sm:10px; --shadow:0 1px 2px rgba(20,30,60,.05),0 6px 24px rgba(20,30,60,.06);
  --maxw:1240px;
}
*{box-sizing:border-box}
html,body{margin:0}
body{
  background:var(--bg); color:var(--ink);
  font:15px/1.55 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  -webkit-font-smoothing:antialiased;
}
h1{font-size:24px;letter-spacing:-.02em;margin:0 0 4px}
h2{font-size:16px;letter-spacing:-.01em;margin:0 0 10px}
p{margin:0 0 10px}
.muted{color:var(--muted)} .small{font-size:13px} .fineprint{color:var(--muted);font-size:12px;margin-top:18px}
a{color:var(--accent)}
strong{font-weight:650}

/* ---- topbar ---- */
#topbar{
  position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;
  gap:12px;padding:12px 20px;background:rgba(255,255,255,.85);backdrop-filter:saturate(1.6) blur(8px);
  border-bottom:1px solid var(--line);
}
.brand{display:flex;align-items:center;gap:9px;font-weight:650;letter-spacing:-.01em}
.brandmark{display:inline-grid;place-items:center;width:26px;height:26px;border-radius:8px;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;font-size:13px}
.topright{display:flex;align-items:center;gap:12px}
.savestatus{color:var(--muted);font-size:12px;min-width:84px;text-align:right}
.langsw{display:inline-flex;border:1px solid var(--line);border-radius:999px;overflow:hidden}
.langsw button{border:0;background:transparent;padding:5px 11px;font-size:12px;font-weight:600;color:var(--muted);cursor:pointer}
.langsw button.sel{background:var(--accent);color:#fff}

/* ---- layout ---- */
#view{min-height:60vh}
.wrap{max-width:var(--maxw);margin:0 auto;padding:26px 20px 80px}
.page-head{margin-bottom:18px}
.row-between{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}
.center-card{max-width:520px;margin:8vh auto;text-align:center;padding:0 20px}
.center-col{display:flex;flex-direction:column;align-items:center;justify-content:center}

/* ---- cards ---- */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:20px;margin:16px 0;box-shadow:var(--shadow)}
.grid2{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:760px){.grid2{grid-template-columns:1.15fr .85fr;align-items:start}}

/* ---- buttons ---- */
.btn{border:1px solid transparent;border-radius:var(--radius-sm);padding:10px 18px;font:inherit;font-weight:600;
  cursor:pointer;background:var(--surface-2);color:var(--ink)}
.btn.primary{background:var(--accent);color:#fff}
.btn.primary:disabled{background:#c7cbe8;cursor:not-allowed}
.btn.ghost{background:transparent;border-color:var(--line);color:var(--ink)}
.btn.ghost:hover{background:var(--surface-2)}
.btn.danger{background:transparent;border-color:#f0c9c4;color:var(--danger)}
.btn.sm{padding:7px 13px;font-size:13px}
.btn:hover{filter:brightness(.99)}
.actions{max-width:var(--maxw);margin:8px auto 0;padding:0 20px;display:flex;justify-content:flex-end}
.iconbtn{border:1px solid var(--line);background:var(--surface);border-radius:8px;width:32px;height:32px;
  cursor:pointer;color:var(--muted);font-size:15px;line-height:1}
.iconbtn:hover{color:var(--ink)}
.gear{font-size:16px}

/* ---- option cards / segmented ---- */
.opts{display:grid;gap:10px;margin-top:6px}
.opts.two{grid-template-columns:1fr} .opts.three{grid-template-columns:1fr}
@media(min-width:620px){.opts.two{grid-template-columns:1fr 1fr}.opts.three{grid-template-columns:1fr 1fr 1fr}}
.opt{display:flex;flex-direction:column;gap:3px;text-align:left;padding:14px 15px;border:1.5px solid var(--line);
  background:var(--surface);border-radius:var(--radius-sm);cursor:pointer;transition:border-color .12s,background .12s}
.opt:hover{border-color:#cdd3e6}
.opt.sel{border-color:var(--accent);background:var(--accent-weak)}
.opt-t{font-weight:650} .opt-d{font-size:12.5px;color:var(--muted)}
.segment{display:inline-flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.segbtn{border:1.5px solid var(--line);background:var(--surface);border-radius:999px;padding:7px 15px;
  font:inherit;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer}
.segbtn.sel{border-color:var(--accent);background:var(--accent-weak);color:var(--accent-ink)}

/* ---- form fields ---- */
.fld{display:block;margin:14px 0}
.fld>span{display:block;font-weight:600;font-size:13.5px;margin-bottom:5px}
.row2{display:grid;grid-template-columns:1fr;gap:12px}
@media(min-width:620px){.row2{grid-template-columns:1fr 1fr}}
input[type=text],select,textarea{width:100%;background:var(--surface);color:var(--ink);
  border:1px solid var(--line);border-radius:9px;padding:10px 12px;font:inherit}
input[type=text]:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-weak)}
.nodes{margin-top:8px}
.noderow{display:flex;gap:8px;margin-bottom:7px}
.noderow input{flex:1}

/* ---- sliders / maturity ---- */
.sliders{margin-top:6px}
.srow{display:grid;grid-template-columns:120px 1fr 24px;align-items:center;gap:10px;padding:6px 0}
.srow label{font-size:13.5px;font-weight:600}
.srow .sval{text-align:center;font-variant-numeric:tabular-nums;color:var(--accent-ink);font-weight:700}
input[type=range]{-webkit-appearance:none;appearance:none;height:5px;border-radius:999px;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));outline:none}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:17px;height:17px;border-radius:50%;
  background:#fff;border:2px solid var(--accent);cursor:pointer;box-shadow:var(--shadow)}

/* ---- radar / overall ---- */
.radarbox{width:100%;max-width:400px;margin:0 auto}
.overall{margin-top:10px;font-weight:700;font-size:30px;line-height:1;color:var(--ink)}
.overall small{display:block;font-size:12px;font-weight:500;color:var(--muted);margin-top:4px}
.pill{display:inline-block;margin-top:8px;padding:4px 12px;border-radius:999px;background:var(--accent-weak);
  color:var(--accent-ink);font-size:12.5px;font-weight:650}

/* ---- modules ---- */
.modgrid{display:grid;grid-template-columns:1fr;gap:10px;margin-top:6px}
@media(min-width:560px){.modgrid{grid-template-columns:1fr 1fr}}
@media(min-width:860px){.modgrid{grid-template-columns:1fr 1fr 1fr}}
.modcard{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px 15px;
  border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface-2)}
.modname{font-weight:600;font-size:13.5px}
.badge{font-size:11px;font-weight:700;padding:3px 9px;border-radius:999px}
.badge.soon{background:#fff4e6;color:#b5731a}

/* ---- modal ---- */
.overlay{position:fixed;inset:0;background:rgba(16,22,38,.45);display:grid;place-items:center;z-index:50;padding:16px}
.modal{width:100%;max-width:440px;margin:0;max-height:88vh;overflow:auto}

/* ---- in-app bildirimler (toast + dialog) ---- */
.toast-root{position:fixed;left:0;right:0;bottom:18px;z-index:200;display:flex;flex-direction:column;align-items:center;gap:8px;pointer-events:none;padding:0 16px}
.toast{pointer-events:auto;display:flex;align-items:center;gap:10px;max-width:440px;background:var(--surface);border:1px solid var(--line);
  border-left:4px solid var(--muted);border-radius:10px;padding:11px 16px;box-shadow:0 8px 28px rgba(20,30,60,.16);font-size:13.5px;color:var(--ink);
  opacity:0;transform:translateY(10px);transition:opacity .2s,transform .2s;cursor:pointer}
.toast.in{opacity:1;transform:translateY(0)}
.toast-ic{font-weight:800;font-size:14px;line-height:1}
.toast-success{border-left-color:var(--target)}.toast-success .toast-ic{color:#4d7c0f}
.toast-warn{border-left-color:var(--importance)}.toast-warn .toast-ic{color:#b4530a}
.toast-error{border-left-color:var(--danger)}.toast-error .toast-ic{color:var(--danger)}
.toast-info{border-left-color:var(--accent)}.toast-info .toast-ic{color:var(--accent-ink)}
.dlg-ov{position:fixed;inset:0;background:rgba(16,22,38,.5);display:grid;place-items:center;z-index:300;padding:16px}
.dlg{width:100%;max-width:420px;max-height:88vh;overflow:auto;padding:22px 24px}
.dlg-h{display:flex;align-items:center;gap:10px;margin:0 0 10px;font-size:16px}
.dlg-ic{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;background:var(--accent-weak);color:var(--accent-ink);font-weight:800;font-size:14px;flex:0 0 auto}
.dlg-ic.danger{background:#fbe7e3;color:var(--danger)}
.dlg-body{font-size:13.5px;color:var(--ink);line-height:1.5}
.dlg-body p{margin:0 0 6px}
.dlg-list{margin:8px 0 0;padding-left:20px}.dlg-list li{margin:4px 0}
.dlg-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:18px}
.setbtns{display:flex;flex-wrap:wrap;gap:8px}
.filebtn{display:inline-flex;align-items:center}
hr{border:0;border-top:1px solid var(--line);margin:16px 0}

/* ---- iki sütun: solda sabit radar, sağda kayan sorular ---- */
.dash-split{display:grid;grid-template-columns:1fr;gap:18px}
@media(min-width:920px){
  .dash-split{grid-template-columns:400px 1fr;align-items:start}
  .dash-left{position:sticky;top:72px}
}
.capcard{scroll-margin-top:80px}   /* açılınca sticky topbar altına hizalansın */

/* ---- radar legend ---- */
.radar-legend{display:flex;gap:18px;margin-top:12px;font-size:13px;color:var(--muted)}
.radar-legend b{color:var(--ink)}
.sw{display:inline-block;width:13px;height:13px;vertical-align:-1px;margin-right:6px}
.sw.cur{background:var(--accent);border-radius:50%}
.sw.tgt{background:var(--target);border-radius:2px;transform:rotate(45deg)}
.targetnote{margin-top:12px;font-size:12px;color:var(--muted);text-align:center;max-width:300px}

/* ---- başlık detay istatistik satırı (Mevcut/Hedef/Fark/Önem) ---- */
.capstats{display:flex;flex-wrap:wrap;gap:10px;margin:12px 0 4px}
.capstats span{flex:1;min-width:62px;background:var(--surface-2);border:1px solid var(--line-2);
  border-radius:9px;padding:8px 6px;text-align:center;font-size:11px;color:var(--muted);line-height:1.3}
.capstats b{display:block;font-size:17px;color:var(--ink);font-weight:700}
.capstats .imp b{color:var(--importance)}
.capstats .cur{background:var(--accent-weak);border-color:#d9cdf5}.capstats .cur b{color:var(--accent-ink)}
.capstats .tgt{background:#f1f8e2;border-color:#cfe8a3}.capstats .tgt b{color:#4d7c0f}
.capstats .gap{background:#fdf3e1;border-color:#f3d9a6}.capstats .gap b{color:#b4530a}

/* öncelik rozeti (qctrl içinde) */
.prio{display:inline-grid;place-items:center;width:20px;height:20px;border-radius:6px;background:var(--accent-weak);color:var(--accent-ink);font-size:11px;font-weight:700;margin-bottom:1px}

/* açık başlığın aktivite bar chart'ı (radar altında) */
.barchart .bc-head{font-weight:650;font-size:13px;margin-bottom:6px}
.bc-legend{display:flex;flex-wrap:wrap;gap:12px;font-size:11px;color:var(--muted);margin-bottom:10px;align-items:center}
.bc-legend .d{display:inline-block;width:10px;height:10px;border-radius:2px;margin-right:4px;vertical-align:-1px}
.bc-fill.cur{background:#cdbff0}.bc-dot.cur,.bc-legend .d.cur{background:var(--accent)}
.bc-fill.tgt{background:#d6ecb0}.bc-dot.tgt,.bc-legend .d.tgt{background:#5f9412}
.bc-legend .d.imp{background:var(--importance);transform:rotate(45deg);width:9px;height:9px;border-radius:1px}
.bc-act{padding:7px 0;border-bottom:1px solid var(--line-2)}
.bc-act:last-child{border-bottom:0}
.bc-act.skipped{opacity:.45}
.bc-name{font-size:12px;font-weight:600;margin-bottom:4px;display:flex;align-items:center;gap:6px}
.bc-rank{display:inline-grid;place-items:center;width:16px;height:16px;border-radius:4px;background:var(--accent-weak);color:var(--accent-ink);font-size:10px;font-weight:700;flex:0 0 auto}
.bc-line{display:flex;align-items:center;gap:6px;margin:2px 0}
.bc-track{flex:1;height:8px;background:var(--line);border-radius:999px;position:relative;
  background-image:repeating-linear-gradient(90deg,rgba(31,36,48,.10) 0 1px,transparent 1px,transparent 20%)}
.bc-fill{height:100%;border-radius:999px;transition:width .15s}
/* değer = barla aynı renk ama koyu nokta (ölçek hizasında) */
.bc-dot{position:absolute;top:50%;width:10px;height:10px;border-radius:50%;
  transform:translate(-50%,-50%);border:1.6px solid #fff;box-shadow:0 1px 2px rgba(0,0,0,.22);transition:left .15s}
/* önem = yeşil (hedef) barın üstünde turuncu karo */
.bc-diamond{position:absolute;top:50%;width:11px;height:11px;background:var(--importance);
  border:1.6px solid #fff;border-radius:1px;transform:translate(-50%,-50%) rotate(45deg);
  box-shadow:0 1px 2px rgba(0,0,0,.18);transition:left .15s}
/* alt ölçek 1–5 */
.bc-scale{position:relative;height:14px;margin-top:8px}
.bc-scale span{position:absolute;transform:translateX(-50%);font-size:10px;color:var(--muted);font-variant-numeric:tabular-nums}
.bc-v{width:14px;text-align:right;font-size:10px;color:var(--muted);font-variant-numeric:tabular-nums}
.bc-hint{padding:8px 0}

/* ---- maturity capability cards ---- */
.capcard{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);margin:10px 0;box-shadow:var(--shadow);overflow:hidden}
.caphead{display:flex;align-items:center;gap:10px;width:100%;text-align:left;background:transparent;border:0;cursor:pointer;padding:15px 16px;font:inherit}
.caphead:hover{background:var(--surface-2)}
.caparrow{color:var(--muted);font-size:12px;width:14px}
.captitle{font-weight:650;flex:1}
.capmeta{display:flex;align-items:center;gap:8px}
.scorechip{background:var(--accent-weak);color:var(--accent-ink);font-weight:700;font-size:12.5px;padding:3px 10px;border-radius:999px}
.gapchip{background:#fff4e6;color:#b5731a;font-weight:700;font-size:11.5px;padding:3px 9px;border-radius:999px}
.capbody{padding:4px 16px 16px;border-top:1px solid var(--line-2)}
.legend{color:var(--muted);font-size:12px;margin:10px 0 4px}

.reorder-hint{font-size:11.5px;color:var(--muted);margin:2px 0 6px}
.qrow{display:flex;gap:10px;align-items:flex-start;padding:12px 0;border-bottom:1px solid var(--line-2);position:relative}
.qrow:last-of-type{border-bottom:0}
.qrow.skipped{opacity:.5}
.qrow.dragging{opacity:.35}
/* sürüklerken nereye düşeceğini gösteren çizgi */
.qrow.drop-above{box-shadow:inset 0 3px 0 -1px var(--accent)}
.qrow.drop-below{box-shadow:inset 0 -3px 0 -1px var(--accent)}
.qctrl{display:flex;flex-direction:column;align-items:center;gap:2px;padding-top:1px}
.moveb{width:22px;height:18px;line-height:1;border:1px solid var(--line);background:var(--surface);
  border-radius:5px;color:var(--muted);font-size:9px;cursor:pointer;padding:0}
.moveb:hover{color:var(--accent-ink);border-color:var(--accent)}
.drag{cursor:grab;color:var(--muted);user-select:none;font-size:13px;letter-spacing:-2px;line-height:1}
.drag:active{cursor:grabbing}
.qmain{flex:1;min-width:0}
.qtext{font-size:14px;margin-bottom:8px}
.rate{display:flex;flex-wrap:wrap;align-items:center;gap:6px}
.ratelbl{font-size:11.5px;font-weight:600;color:var(--muted);margin-right:2px}
.pills{display:inline-flex;gap:4px;margin-right:8px}
.pill{width:28px;height:28px;border:1px solid var(--line);background:var(--surface);border-radius:7px;
  font:inherit;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer}
.pill.sel{background:var(--accent);border-color:var(--accent);color:#fff}
.pill.pill-tgt.sel{background:var(--target);border-color:var(--target);color:#1f2430}
.pill:disabled{opacity:.4;cursor:not-allowed}
.skipbtn{border:1px solid var(--line);background:transparent;color:var(--muted);border-radius:7px;
  padding:5px 10px;font:inherit;font-size:12px;cursor:pointer}
.skipbtn.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.recs{margin-top:14px;background:var(--surface-2);border:1px solid var(--line-2);border-radius:9px;padding:12px 14px}
.recs-h{font-weight:650;font-size:12.5px;margin-bottom:6px}
.recs ul{margin:0;padding-left:18px}
.recs li{font-size:13px;margin:3px 0;color:var(--ink)}

/* ---- modül kartı: aktif (tıklanır) ---- */
.modcard.active{cursor:pointer;border-color:var(--accent);background:var(--surface);font:inherit;text-align:left}
.modcard.active:hover{background:var(--accent-weak)}
.badge.open{background:var(--accent-weak);color:var(--accent-ink)}

/* ---- roadmap: 3 faz kolonu ---- */
.rm-board{display:grid;grid-template-columns:1fr;gap:14px;margin-top:8px}
@media(min-width:820px){.rm-board{grid-template-columns:1fr 1fr 1fr;align-items:start}}
.rm-col{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius);padding:12px}
.rm-colhead{font-weight:650;font-size:13px;margin-bottom:10px;display:flex;justify-content:space-between;align-items:center}
.rm-count{background:var(--accent-weak);color:var(--accent-ink);font-size:11px;font-weight:700;padding:2px 8px;border-radius:999px}
.rm-drop{min-height:60px;display:flex;flex-direction:column;gap:10px;border-radius:10px;transition:background .12s}
.rm-drop.over{background:var(--accent-weak);outline:2px dashed var(--accent)}
.rm-empty{text-align:center;padding:14px 0}
.rm-card{background:var(--surface);border:1px solid var(--line);border-left:4px solid var(--ws);
  border-radius:10px;padding:11px 12px;box-shadow:var(--shadow);cursor:grab}
.rm-card.dragging{opacity:.4}
.rm-card.status-done{opacity:.62}
.rm-top{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:5px}
.rm-ws{font-size:10.5px;font-weight:700;color:var(--ws);text-transform:uppercase;letter-spacing:.03em}
.rm-level{font-size:10px;font-weight:700;padding:2px 7px;border-radius:999px}
.rm-level.initial{background:#eef7e0;color:#4d7c0f}
.rm-level.advanced{background:var(--accent-weak);color:var(--accent-ink)}
.rm-name{font-weight:650;font-size:13.5px;margin-bottom:4px}
.rm-deliv{font-size:11.5px;color:var(--muted);margin-bottom:6px}
.rm-steps{margin-bottom:8px}
.rm-steps summary{cursor:pointer;font-size:11.5px;color:var(--accent-ink)}
.rm-steps ul{margin:6px 0 0;padding-left:16px}
.rm-steps li{font-size:12px;margin:2px 0}
.rm-row{display:flex;gap:6px;align-items:center}
.rm-owner{flex:1;min-width:0;padding:6px 8px;font-size:12px}
.rm-status{padding:6px 6px;font-size:12px;border:1px solid var(--line);border-radius:8px;background:var(--surface)}
.rm-del{width:28px;height:28px;flex:0 0 auto}
/* roadmap v2: kart-içi görevler, banner, sürüm, override */
.rm-fw{font-size:11px;font-weight:600;color:var(--muted)}
.rm-vbadge{background:var(--accent-weak);color:var(--accent-ink);padding:1px 8px;border-radius:999px;font-size:11px}
#rm-ver{font-size:12px;padding:2px 6px;border:1px solid var(--line);border-radius:6px;background:var(--surface)}
.rm-banner{background:#fff7e6;border:1px solid #f3d9a6;border-radius:10px;padding:10px 12px;margin:6px 0 14px;
  display:flex;flex-wrap:wrap;gap:10px;align-items:center;font-size:12.5px;color:#8a5a00}
.rm-banner .btn{margin-left:auto}
.rm-todo{margin:6px 0 2px}
.rm-task{font-size:12.5px;margin:4px 0;color:var(--ink);line-height:1.4}
.rm-task .rm-deliv{display:inline;color:var(--muted);font-size:11.5px;margin-left:6px}
.rm-ovr{background:#fff4e6;color:#b5731a;font-size:10.5px;font-weight:700;padding:1px 7px;border-radius:999px;margin-left:4px}
.rm-lock{background:#eef1f6;color:var(--muted);font-size:10px;font-weight:700;padding:1px 7px;border-radius:999px}
.freeze-card{align-items:center}

/* assessment listesi (panel) */
.asmt-list{margin-top:14px;display:flex;flex-direction:column;gap:10px}
.asmt-row{display:flex;gap:12px;align-items:center;justify-content:space-between;border:1px solid var(--line);border-radius:10px;padding:12px 14px;background:var(--surface-2)}
.asmt-main{min-width:0;flex:1}
.asmt-name{font-weight:650;font-size:14px}
.asmt-date{color:var(--muted);font-weight:500;font-size:12px;margin-left:6px}
.asmt-sum{display:flex;flex-wrap:wrap;gap:6px;margin-top:7px}
.sum-chip{font-size:11px;color:var(--muted);background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:2px 8px}
.sum-chip b{color:var(--accent-ink)}
.asmt-act{display:flex;gap:6px;align-items:center;flex:0 0 auto}

/* roadmap RACI (A/R) + süre */
.rm-actions{display:flex;gap:8px}
.rm-raci{display:flex;gap:6px;margin:8px 0 0}
.rm-raci select{flex:1;min-width:0;font-size:12px;padding:6px;border:1px solid var(--line);border-radius:8px;background:var(--surface);color:var(--ink)}
.rm-monwrap{display:flex;align-items:center;gap:5px;font-size:11.5px;color:var(--muted)}
.rm-mon{width:52px;padding:6px 8px;font-size:12px}

/* roadmap v3: tablar, oklar, hover, pasif, salt-okunur */
.rm-tabs{display:flex;flex-wrap:wrap;gap:6px;margin:4px 0 12px}
.rm-tab{border:1px solid var(--line);background:var(--surface);border-radius:999px;padding:6px 14px;font:inherit;font-size:12.5px;font-weight:600;color:var(--muted);cursor:pointer}
.rm-tab.sel{background:var(--accent);border-color:var(--accent);color:#fff}
.rm-card[draggable]:hover{transform:translateY(-2px);cursor:grab;box-shadow:0 4px 16px rgba(20,30,60,.10)}
.rm-card{transition:transform .1s, box-shadow .1s}
.rm-move{margin-left:auto;display:inline-flex;gap:3px}
.rm-arrow{width:22px;height:22px;border:1px solid var(--line);background:var(--surface);border-radius:6px;color:var(--accent-ink);font-size:10px;cursor:pointer;padding:0}
.rm-arrow:disabled{opacity:.3;cursor:not-allowed}
.rm-arrow:hover:not(:disabled){background:var(--accent-weak)}
.rm-deact{width:28px;height:28px;flex:0 0 auto;color:var(--danger);border-color:#f0c9c4;font-size:15px}
.rm-deact:hover{background:#fdecea;color:var(--danger)}
.rm-off-wrap{margin-top:16px;border-top:1px dashed var(--line);padding-top:10px}
.rm-offcard{display:flex;align-items:center;justify-content:space-between;gap:10px;border-left-color:var(--line)!important;opacity:.75;padding:8px 12px}
.rm-offname{font-size:12.5px;color:var(--muted)}
.rm-raci.ro{display:flex;gap:12px;font-size:12px;color:var(--ink);margin-top:8px}
.rm-row.ro{display:flex;justify-content:space-between;font-size:12px;color:var(--muted);margin-top:8px}
.rm-stat{font-weight:700}
.rm-stat.done{color:var(--ok)}
.rm-banner.ro{background:#eef1f6;color:var(--muted);border-color:var(--line)}
.rm-viewtoggle{display:inline-flex;gap:6px;margin:0 0 12px}
.rm-vt{border:1px solid var(--line);background:var(--surface);border-radius:8px;padding:6px 12px;font:inherit;font-size:12.5px;font-weight:600;color:var(--muted);cursor:pointer}
.rm-vt.sel{background:var(--accent);border-color:var(--accent);color:#fff}
.rm-gantt{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:0;box-shadow:var(--shadow);overflow:hidden}
.gantt-wrap{position:relative}
.gantt-scroll{overflow-x:auto;overflow-y:hidden}
.gantt-scroll>svg{display:block}
.gantt-frozen{position:absolute;left:0;top:0;pointer-events:none}
.gantt-frozen>svg{display:block}
.rm-gantt-hint{font-size:12px;color:var(--muted);background:var(--accent-weak);border-radius:8px;padding:8px 12px;margin:0 0 8px}
.gantt-int .gstart,.gantt-int .gend{cursor:ew-resize}
.gantt-int .glink{cursor:grab}
.gantt-int .ghandle{touch-action:none}
.gantt-int .gdep{cursor:pointer}
.gantt-int .gbar.gdrop{stroke:#F97316;stroke-width:2.5}   /* bağ bırakma hedefi vurgusu */
.rm-when{font-size:11.5px;color:var(--muted);margin:2px 0 6px}.rm-when b{color:var(--ink)}
.rm-filter{display:inline-flex;gap:4px;margin-left:6px}
.rm-fl{border:1px solid var(--line);background:var(--surface);border-radius:20px;padding:4px 11px;font-size:12px;cursor:pointer;color:var(--muted)}
.rm-fl.sel{background:var(--accent);border-color:var(--accent);color:#fff}
.rm-kind{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;border-radius:5px;padding:1px 6px;margin-right:4px}
.rm-kind.enabler{background:var(--surface-2);color:var(--muted);border:1px solid var(--line)}
.rm-kind.project{background:#d6f0ec;color:#0d7d72;border:1px solid #a3e0d6}
.rm-pcount{font-size:11px;font-weight:700;background:rgba(255,255,255,.25);border-radius:20px;padding:1px 7px;margin-left:4px}
.rm-pcount.low{color:#fff}
.rm-pdesc{font-size:12px;color:var(--muted);margin:2px 0 6px;line-height:1.4}
.rm-proj{border-left:3px solid var(--ws,#0D9488)}
.rm-ve{display:flex;gap:12px;margin:6px 0;font-size:11.5px;color:var(--muted)}
.rm-ve label{display:flex;align-items:center;gap:4px}
.rm-ve select{border:1px solid var(--line);border-radius:6px;padding:2px 4px;font:inherit}
.rm-qw{font-size:10px;font-weight:700;color:#b4530a;background:#fdf3e1;border:1px solid #f3d9a6;border-radius:5px;padding:1px 6px;margin-left:auto}
/* ---- Use-Case Explorer ---- */
.xp-ov{position:fixed;inset:0;background:rgba(16,22,38,.5);display:grid;place-items:start center;z-index:250;padding:24px 16px;overflow:auto}
.xp{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);width:100%;max-width:1000px;padding:20px 22px}
.xp-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.xp-head h2{margin:0 0 2px;font-size:18px}
.xp-bar{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin:12px 0;font-size:13px}
.xp-bar select{border:1px solid var(--line);border-radius:8px;padding:5px 8px;font:inherit}
.xp-own{background:var(--surface-2);border:1px solid var(--line);border-radius:10px;padding:12px;margin-bottom:12px;display:flex;flex-direction:column;gap:8px}
.xp-own input,.xp-own textarea{border:1px solid var(--line);border-radius:8px;padding:8px;font:inherit;width:100%}
.xp-own-row{display:flex;gap:8px}.xp-own-row select{flex:1;border:1px solid var(--line);border-radius:8px;padding:6px}
.xp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;max-height:64vh;overflow:auto;padding:2px}
.xp-item{border:1px solid var(--line);border-radius:12px;padding:12px 14px;background:var(--surface);display:flex;flex-direction:column}
.xp-meta{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;color:var(--accent-ink)}
.xp-item h4{margin:4px 0 6px;font-size:14px}
.xp-ch{font-size:12.5px;color:var(--ink);margin:0 0 4px;line-height:1.4}
.xp-ap{font-size:11.5px;color:var(--muted);margin:0 0 8px;line-height:1.4}
.xp-tags{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:10px}
.xp-tag{font-size:10px;border:1px solid var(--line);border-radius:20px;padding:1px 8px;color:var(--muted)}
.xp-tag.bv{background:#e7f3d6;color:#4d7c0f;border-color:#cfe8a3}
.xp-add{margin-top:auto;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.gantt-int .gbar{cursor:pointer}                          /* bar'a tıkla → kart popup */
.gantt-cardpop{min-width:260px}
.gantt-cardpop .rm-card{box-shadow:none;margin:0;cursor:default}
/* taşınan kart vurgu animasyonu */
.rm-moved{animation:rmMoved 1.15s ease}
@keyframes rmMoved{
  0%{box-shadow:0 0 0 3px var(--accent), 0 8px 22px rgba(76,29,149,.28);transform:scale(1.04);background:var(--accent-weak)}
  60%{box-shadow:0 0 0 2px var(--accent);transform:scale(1.0)}
  100%{box-shadow:var(--shadow);transform:none;background:var(--surface)}
}

/* ---- belge üreteci ---- */
.doc-wrap{max-width:1080px}
.doc-gantt{overflow-x:auto;border:1px solid var(--line);border-radius:10px;padding:6px}
.doc{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:30px 34px;box-shadow:var(--shadow);overflow:hidden}
.doc-h1{font-size:22px;margin:0 0 2px}
.doc-sub{color:var(--muted);font-size:13px;margin-bottom:18px}
.doc h3{font-size:15px;margin:22px 0 8px;border-bottom:2px solid var(--accent-weak);padding-bottom:4px}
.doc h4{font-size:13px;margin:12px 0 4px;color:var(--accent-ink)}
.doc-exec{margin:0 0 8px;padding-left:18px}.doc-exec li{margin:4px 0}
.doc-radar{max-width:320px;margin:6px auto}
.doc-table{width:100%;border-collapse:collapse;font-size:13px;margin:8px 0}
.doc-table th,.doc-table td{border:1px solid var(--line);padding:6px 10px;text-align:left}
.doc-table th{background:var(--surface-2)}
.doc-tasks{margin:4px 0 10px;padding-left:18px}.doc-tasks li{margin:6px 0;font-size:13.5px}
.doc-meta{display:block;color:var(--muted);font-size:11.5px;margin-top:2px}
.doc-demobar{background:#fff7e6;border:1px solid #f3d9a6;color:#8a5a00;border-radius:10px;padding:10px 14px;margin:6px 0 14px;font-size:13px}
.doc-wm{position:absolute;inset:0;pointer-events:none;display:flex;align-items:center;justify-content:center;
  font-size:60px;font-weight:800;color:rgba(76,29,149,.07);transform:rotate(-24deg);letter-spacing:4px;z-index:1}
.doc-roadmap{position:relative}
.doc-roadmap.locked{max-height:170px;overflow:hidden}
.doc-roadmap.locked::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent,var(--surface) 88%)}
.doc-lock{position:absolute;inset:0;display:flex;flex-direction:column;gap:10px;align-items:center;justify-content:flex-end;padding-bottom:14px;z-index:2;color:var(--muted);font-weight:600}

/* ---- resmi belge mührü ---- */
.rm-seal{margin-left:auto;border:1px solid var(--accent-weak);background:var(--surface);color:var(--accent-ink);border-radius:20px;padding:4px 12px;font-size:12px;font-weight:600;cursor:pointer}
.rm-seal:hover{background:var(--accent-weak)}
.rm-seal.on{background:#fbf3e0;border-color:#e6c879;color:#8a5a00}
.asmt-official{display:inline-block;margin-left:8px;font-size:11px;font-weight:600;color:#8a5a00;background:#fbf3e0;border:1px solid #e6c879;border-radius:20px;padding:1px 8px;vertical-align:1px}

/* ---- olgunluk raporu bölümleri ---- */
.doc-cover{text-align:center;padding:18px 0 26px;border-bottom:1px solid var(--line);margin-bottom:6px}
.doc-cover-mark{font-size:30px;color:var(--accent);margin-bottom:8px}
.doc-cover-org{font-size:18px;font-weight:700;margin:6px 0 2px;color:var(--ink)}
.doc-section{margin:26px 0;position:relative}
.doc-h2{font-size:17px;margin:0 0 4px;color:var(--accent-ink);border-bottom:2px solid var(--accent-weak);padding-bottom:5px}
.doc-help{color:var(--muted);font-size:12.5px;margin:4px 0 12px}
.doc-overall{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin:10px 0}
.doc-arrow{font-size:24px;color:var(--muted)}
.bignum{display:flex;flex-direction:column;align-items:center;min-width:96px;background:var(--surface-2);border:1px solid var(--line);border-radius:12px;padding:12px 16px}
.bignum b{font-size:30px;line-height:1;color:var(--accent-ink)}
.bignum span{font-size:11px;color:var(--muted);margin-top:6px;text-align:center}
.bignum.cur{background:var(--accent-weak);border-color:#d9cdf5}
.bignum.cur b{color:var(--accent-ink)}
.bignum.tgt{background:#f1f8e2;border-color:#cfe8a3}        /* hedef yeşilinin açığı (radar uyumu) */
.bignum.tgt b{color:#4d7c0f}
.bignum.gap{background:#fdf3e1;border-color:#f3d9a6}        /* fark turuncusunun açığı */
.bignum.gap b{color:#b4530a}
.doc-interp{font-size:14px;line-height:1.55;margin:12px 0;padding:12px 14px;background:var(--accent-weak);border-radius:10px}
.doc-scale{display:flex;flex-wrap:wrap;gap:8px;margin:10px 0}
.doc-scale-i{font-size:11.5px;color:var(--muted);background:var(--surface-2);border:1px solid var(--line);border-radius:20px;padding:3px 10px}
.doc-scale-i b{color:var(--accent-ink);margin-right:3px}
.doc-legend{display:flex;gap:16px;font-size:12px;color:var(--muted);margin:2px 0 8px}
.doc-cap-vis{display:flex;gap:18px;align-items:center;flex-wrap:wrap}
.doc-cap-vis .doc-radar{flex:0 0 300px;max-width:300px;margin:0}
.doc-cap-vis .doc-bars{flex:1 1 360px;min-width:320px}
.doc-act-grp{margin:14px 0}
.doc-act-grp h4{display:flex;justify-content:space-between;align-items:baseline;border-bottom:1px solid var(--line);padding-bottom:3px}
.doc-act-avg{font-size:11px;color:var(--muted);font-weight:500}
.doc-caps{position:relative}
.doc-caps.locked{max-height:340px;overflow:hidden}
.doc-caps.locked::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent,var(--surface) 90%)}
.doc-cap{border:1px solid var(--line);border-radius:12px;padding:14px 16px;margin:12px 0;background:var(--surface)}
.doc-cap-head h3{margin:0;border:0;font-size:15px}
.doc-cap-desc{color:var(--muted);font-size:12.5px;margin:3px 0 10px}
.doc-cap-nums{display:flex;gap:12px;margin:8px 0 12px}
.doc-cap-nums .bignum{min-width:78px;padding:8px 12px}
.doc-cap-nums .bignum b{font-size:22px}
.doc-cap-recs{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.doc-cap-recs h4{margin:2px 0 4px}
.doc-recs{margin:0;padding-left:16px}.doc-recs li{font-size:12.5px;margin:4px 0;line-height:1.4}
@media(max-width:640px){.doc-cap-recs{grid-template-columns:1fr}.doc-cap-vis .doc-radar{flex-basis:100%}}

/* ---- print (olgunluk raporu — landscape A4) ---- */
@media print{
  @page{size:A4 landscape;margin:12mm}
  #topbar,.actions,.iconbtn,.no-print,.doc-demobar,.rm-actions{display:none!important}
  body{background:#fff}
  .doc{box-shadow:none;border:0;padding:0}
  .doc-wrap,.wrap{max-width:none;padding:0}
  .card{box-shadow:none;border-color:#ccc;break-inside:avoid}
  /* bölüm sayfaya sığmazsa sayfa başına taşı; akış bölümlerinde çocukları koru */
  .doc-section{break-inside:avoid}
  .doc-section.flow{break-inside:auto}
  .doc-cap,.doc-act-grp{break-inside:avoid}     /* küçükler aynı sayfaya 2+ sığar */
  .doc-h2,.doc-cap-head{break-after:avoid}
  .doc-cover{break-after:page}
  .doc-gantt{overflow:visible;border:0;padding:0}
  .doc-caps.locked,.doc-roadmap.locked{max-height:none;overflow:visible}
  .doc-caps.locked::after,.doc-roadmap.locked::after{display:none}
}
