/* ============================================================
   Ön Büro Takip — rafine "endüstriyel kâğıt" tema
   ============================================================ */
:root{
  --paper:#f3eee4; --paper-2:#ece4d5; --surface:#fffefb; --surface-2:#faf6ee;
  --ink:#221e18; --ink-soft:#766c5d; --ink-faint:#a89e8c;
  --line:#e6decf; --line-2:#d9cdb7;
  --accent:#1c6b66; --accent-d:#134f4a; --accent-soft:#d6e7e5;

  --deliv-bg:#fbedc2; --deliv-line:#cf9f2c; --deliv-ink:#6a4d08;
  --call-bg:#dae7f2;  --call-line:#3f78ab;  --call-ink:#23456a;
  --prob-bg:#f5dacf;  --prob-line:#c0512f;  --prob-ink:#7a2c16;
  --ok-bg:#dcefe1;    --ok-ink:#1f6b41;
  --warn-bg:#f7e6c0;  --warn-ink:#8a5d0c;
  --pay-bg:#e7e2f1;   --pay-ink:#473b6b;

  --r:14px; --r-sm:9px;
  --shadow:0 1px 2px rgba(40,32,20,.05), 0 4px 14px -6px rgba(40,32,20,.12);
  --shadow-lg:0 18px 50px -18px rgba(40,32,20,.4);
  --font-disp:"Bricolage Grotesque","Plus Jakarta Sans",system-ui,sans-serif;
  --font-body:"Plus Jakarta Sans",system-ui,"Segoe UI",sans-serif;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0; color:var(--ink); font-family:var(--font-body); font-size:14px; line-height:1.45;
  background:var(--paper);
  background-image:
    radial-gradient(120% 80% at 100% 0%, rgba(28,107,102,.07), transparent 55%),
    radial-gradient(90% 70% at 0% 100%, rgba(207,159,44,.08), transparent 55%);
  background-attachment:fixed;
  -webkit-font-smoothing:antialiased;
}
/* ince grain dokusu */
body::before{
  content:""; position:fixed; inset:0; pointer-events:none; z-index:0; opacity:.4;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.035'/%3E%3C/svg%3E");
}
#app{position:relative;z-index:1}
/* #login pozisyonunu .login-screen (position:fixed) yönetir; id ile çakışmasın */
.hidden{display:none !important}
.muted{color:var(--ink-soft)}

/* ---- Butonlar & form öğeleri ---- */
button{font-family:inherit;font-size:13.5px;font-weight:600;cursor:pointer;border:none;
  border-radius:var(--r-sm);padding:9px 15px;transition:transform .08s, background .15s, box-shadow .15s;letter-spacing:.01em}
button:active{transform:translateY(1px)}
button.primary{background:var(--accent);color:#fff;box-shadow:0 2px 0 var(--accent-d)}
button.primary:hover{background:var(--accent-d)}
button.ghost{background:var(--surface);border:1px solid var(--line-2);color:var(--ink)}
button.ghost:hover{background:var(--surface-2);border-color:var(--ink-faint)}
button.danger{background:var(--prob-line);color:#fff}
button.danger:hover{background:var(--prob-ink)}
input,select,textarea{font-family:inherit;font-size:14px;padding:10px 12px;border:1px solid var(--line-2);
  border-radius:var(--r-sm);background:var(--surface);width:100%;color:var(--ink);transition:border .15s,box-shadow .15s}
textarea{resize:vertical;line-height:1.45}
input::placeholder,textarea::placeholder{color:var(--ink-faint)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}

/* ============================ Giriş (tek parça kart) ============================ */
.login-screen{position:fixed;inset:0;z-index:5;display:flex;align-items:center;justify-content:center;padding:24px 16px;overflow:auto;
  background:
    radial-gradient(130% 90% at 85% 4%, rgba(28,107,102,.20), transparent 55%),
    radial-gradient(110% 80% at 4% 100%, rgba(207,159,44,.20), transparent 55%),
    var(--paper)}
.login-box{position:relative;width:100%;max-width:404px;background:var(--surface);
  border:1px solid var(--line);border-radius:22px;padding:42px 38px 30px;box-shadow:var(--shadow-lg);overflow:hidden;
  display:flex;flex-direction:column;gap:18px;animation:rise .5s cubic-bezier(.2,.75,.2,1) both}
@media(max-width:430px){ .login-box{padding:34px 24px 26px} .login-head h1{font-size:27px} }
.login-box::before{content:"";position:absolute;left:0;right:0;top:0;height:4px;
  background:linear-gradient(90deg,var(--accent),var(--deliv-line))}
.login-head{margin-bottom:6px}
.login-head h1{margin:0;font-family:var(--font-disp);font-weight:800;font-size:31px;line-height:1;letter-spacing:-.025em;color:var(--ink)}
.login-sub{display:block;margin-top:9px;font-size:11.5px;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--ink-faint)}
.login-field{display:flex;flex-direction:column;gap:8px}
.login-lab{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft)}
.pass-wrap{position:relative;display:flex;align-items:center}
.pass-wrap input{padding:14px 48px 14px 15px;font-size:15px;border-radius:12px;background:var(--surface-2)}
.pass-wrap input:focus{background:var(--surface)}
.pass-toggle{position:absolute;right:7px;top:50%;transform:translateY(-50%);background:transparent;border:0;
  padding:7px;color:var(--ink-faint);border-radius:9px;display:flex;cursor:pointer}
.pass-toggle:hover{color:var(--accent);background:var(--accent-soft)}
.pass-toggle:active{transform:translateY(-50%)}
.pass-toggle.on{color:var(--accent)}
.login-submit{display:flex;align-items:center;justify-content:center;gap:9px;background:var(--accent);color:#fff;
  padding:14px;font-size:15px;border-radius:12px;box-shadow:0 3px 0 var(--accent-d),0 12px 22px -12px var(--accent);margin-top:6px}
.login-submit:hover{background:var(--accent-d)}
.login-submit:active{transform:translateY(2px);box-shadow:0 1px 0 var(--accent-d)}
.login-submit svg{transition:transform .18s}
.login-submit:hover svg{transform:translateX(4px)}
.login-foot{margin:2px 0 0;font-size:11.5px;color:var(--ink-faint);text-align:center;line-height:1.5}
.error{color:var(--prob-line);font-size:13px;font-weight:600;text-align:center}

/* ============================ Masthead ============================ */
.masthead{display:flex;align-items:center;flex-wrap:wrap;gap:10px 20px;padding:12px 24px;
  background:rgba(255,254,251,.82);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10}
.brand{display:flex;align-items:center;gap:10px 18px;flex-wrap:wrap}
.brand-text{font-family:var(--font-disp);font-weight:700;font-size:19px;line-height:1;letter-spacing:-.02em;
  display:flex;flex-direction:column;gap:2px;white-space:nowrap}
.brand-text em{font-family:var(--font-body);font-style:normal;font-weight:500;font-size:11px;
  letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint)}
.search-wrap{flex:1 1 200px;min-width:160px;position:relative;display:flex;align-items:center}
.search-ic{position:absolute;left:14px;color:var(--ink-faint);pointer-events:none}
.search-wrap input{padding-left:42px;border-radius:999px;background:var(--surface-2)}
.actions{display:flex;gap:8px;margin-left:auto}
.icon-btn{display:inline-flex;align-items:center;gap:7px}
.icon-btn svg{opacity:.8;margin-left:-1px}

/* ============================ Filtreler ============================ */
.filters{display:flex;gap:9px;padding:12px 26px;flex-wrap:wrap;justify-content:center;
  background:rgba(243,238,228,.7);backdrop-filter:blur(6px);
  border-bottom:1px solid var(--line)}

/* Renk açıklaması (navbar içinde, brand'in yanında) */
.legend{display:flex;flex-wrap:wrap;align-items:center;gap:5px 13px;font-size:11.5px;color:var(--ink-soft);font-weight:600}
.legend .lg{display:inline-flex;align-items:center;gap:5px;white-space:nowrap}
.legend .dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;display:inline-block}
.legend .d-arr{background:var(--ok-ink)}
.legend .d-call{background:var(--call-line)}
.legend .d-deliv{background:var(--deliv-line)}
.legend .d-prob{background:var(--prob-line)}
.legend .d-cikis{background:#7c5cbf}
.chip{background:var(--surface);border:1px solid var(--line-2);color:var(--ink-soft);border-radius:999px;
  padding:7px 8px 7px 14px;display:flex;align-items:center;gap:9px;font-weight:600;font-size:13px}
.chip:hover{border-color:var(--ink-faint);color:var(--ink)}
.chip .cnt{background:var(--paper-2);color:var(--ink-soft);border-radius:999px;padding:1px 9px;font-size:12px;
  font-weight:700;font-variant-numeric:tabular-nums;min-width:24px;text-align:center}
.chip.act .cnt{background:var(--warn-bg);color:var(--warn-ink)}
.chip.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.chip.active .cnt{background:rgba(255,255,255,.22);color:#fff}
/* Depo Çıkış: farklı kategori — mor aksanla ayrılır (depo görünümü) */
.chip[data-filter="cikis"]{margin-left:14px;border-color:#cdbdef;color:#6c4fae}
.chip[data-filter="cikis"]:hover{border-color:#b59ee6;color:#5a3f9c}
.chip[data-filter="cikis"] .cnt{background:#efe9fb;color:#6c4fae}
.chip[data-filter="cikis"].active{background:#7c5cbf;border-color:#7c5cbf;color:#fff}
.chip[data-filter="cikis"].active .cnt{background:rgba(255,255,255,.24);color:#fff}

/* ============================ Liste ============================ */
.list{padding:22px 24px 80px;max-width:1290px;margin:0 auto}
.list-summary{display:flex;align-items:center;gap:10px;margin:0 2px 18px;flex-wrap:wrap}
.list-summary strong{font-family:var(--font-disp);font-weight:700;font-size:19px;letter-spacing:-.01em;color:var(--ink)}
.list-summary span{font-size:12.5px;font-weight:600;color:var(--ink-soft);background:var(--surface);
  border:1px solid var(--line);padding:3px 11px;border-radius:999px;font-variant-numeric:tabular-nums}
.list-summary .q{color:var(--accent);background:var(--accent-soft);border-color:transparent}
.day-group{margin-bottom:26px}
.day-head{display:flex;align-items:center;gap:14px;margin:0 0 12px}
.day-head .d{font-family:var(--font-disp);font-weight:700;font-size:15px;letter-spacing:-.01em;color:var(--ink)}
.day-head .c{font-size:12px;color:var(--ink-faint);font-weight:600;white-space:nowrap}
.day-head .rule{flex:1;height:1px;background:linear-gradient(90deg,var(--line-2),transparent)}

/* ---- Tablo görünümü ---- */
.table{--cols:minmax(0,1.15fr) minmax(0,1.3fr) minmax(0,1fr) 74px 176px 132px 195px;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow)}
.thead{display:grid;grid-template-columns:var(--cols);gap:12px;padding:11px 16px 11px 20px;
  font-size:10.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-faint);
  background:var(--surface-2);border-bottom:1px solid var(--line-2);text-align:center}
.tdate{display:flex;align-items:center;gap:12px;padding:9px 18px;background:var(--paper);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.tdate:first-of-type{border-top:0}
.tdate .d{font-family:var(--font-disp);font-weight:700;font-size:13.5px;letter-spacing:-.01em}
.tdate .c{font-size:11.5px;color:var(--ink-faint);font-weight:600}

/* bir müşteri = bir blok; ad yalnız ilk satırda, devam satırlarında boş */
.c-cust .ph svg{color:var(--accent)}
.trow.sub{padding-top:7px;padding-bottom:7px}
/* ayraç çizgisi YALNIZ farklı müşteriler arasında; aynı müşterinin malzemeleri çizgisiz akar */
.cust-block + .cust-block{border-top:1px solid var(--line-2)}

.trow{position:relative;display:grid;grid-template-columns:var(--cols);gap:12px;align-items:center;
  padding:11px 16px 11px 20px;animation:rise .35s ease both}
.trow::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:transparent}
.trow:hover{background:var(--surface-2)}
/* öncelik (sonraki kazanır): sorun > teslim > arandı > geldi */
.trow.arrived{background:linear-gradient(90deg,var(--ok-bg),transparent 62%)}
.trow.arrived::before{background:var(--ok-ink)}
.trow.called{background:linear-gradient(90deg,var(--call-bg),transparent 62%)}
.trow.called::before{background:var(--call-line)}
.trow.delivered{background:linear-gradient(90deg,var(--deliv-bg),transparent 62%)}
.trow.delivered::before{background:var(--deliv-line)}
.trow.problem{background:linear-gradient(90deg,var(--prob-bg),transparent 62%)}
.trow.problem::before{background:var(--prob-line)}
.trow.cikis{background:linear-gradient(90deg,#f1ebf9,transparent 62%)}
.trow.cikis::before{background:#7c5cbf}

.c-cust{min-width:0;display:flex;flex-direction:column;align-items:center;gap:2px;text-align:center}
.c-cust .nm{font-family:var(--font-disp);font-weight:700;font-size:14.5px;letter-spacing:-.01em;
  max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.c-cust .nm .nameless{color:var(--ink-faint);font-style:italic;font-weight:500}
.c-cust .ph{display:inline-flex;align-items:center;gap:5px;font-size:12px;color:var(--ink-soft);
  font-variant-numeric:tabular-nums;font-weight:600}
.ic-phone{color:var(--accent);flex-shrink:0}
/* gruplu defter: aynı müşterinin alt satırlarında ad gizli (masaüstü); mobilde geri açılır */
.trow.sub .c-cust > *{display:none}
/* tıkla-kopyala (telefon, stok no) */
.copyable{cursor:pointer;border-radius:6px;transition:background .12s}
.copyable:hover{background:var(--accent-soft)}
.c-mat{min-width:0;display:flex;flex-direction:column;align-items:center;gap:2px;text-align:center}
.c-mat .mn{max-width:100%;font-size:13px;font-weight:600;color:var(--ink);font-variant-numeric:tabular-nums;
  letter-spacing:.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.c-mat .desc{max-width:100%;font-size:10.5px;color:var(--ink-faint);font-weight:600;letter-spacing:.02em;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.c-note{min-width:0;font-size:12px;color:var(--ink-soft);font-weight:500;line-height:1.35;text-align:center;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.c-price{font-family:var(--font-disp);font-weight:700;font-size:15px;text-align:center;
  font-variant-numeric:tabular-nums;white-space:nowrap;color:var(--ink)}
.c-price small{font-size:11px;color:var(--ink-faint);font-weight:600}
.c-price.raw{font-size:11.5px;font-weight:600;color:var(--ink-soft);font-family:var(--font-body);
  overflow:hidden;text-overflow:ellipsis}
.c-pay{min-width:0;display:flex;justify-content:center;align-items:center}
.c-durum{min-width:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;text-align:center}
.c-durum:empty::after{content:"–";color:var(--ink-faint);opacity:.5}
.paysel{display:inline-flex;border:1px solid var(--line-2);border-radius:9px;overflow:hidden;
  background:var(--surface);flex-shrink:0}
.paysel .pm{border:0;border-left:1px solid var(--line);border-radius:0;padding:6px 11px;
  font-size:11.5px;font-weight:600;background:transparent;color:var(--ink-soft)}
.paysel .pm:first-child{border-left:0}
.paysel .pm:hover{background:var(--surface-2);color:var(--ink)}
.paysel .pm:active{transform:none}
.paysel .pm.on{background:var(--accent);color:#fff}
.paytags{display:flex;gap:5px;flex-wrap:wrap;justify-content:center}
.c-act{display:flex;justify-content:center}

.badge{font-size:11px;padding:3px 8px;border-radius:6px;font-weight:700;white-space:nowrap;letter-spacing:.01em}
.b-pay{background:var(--pay-bg);color:var(--pay-ink)}
.b-arr{background:var(--ok-bg);color:var(--ok-ink)}
.b-iptal{background:var(--prob-bg);color:var(--prob-ink)}
.b-iade{background:var(--prob-bg);color:var(--prob-ink);border:1px solid var(--prob-line)}
.b-unpaid{background:var(--warn-bg);color:var(--warn-ink)}
.b-prepaid{background:var(--ok-bg);color:var(--ok-ink)}
.b-fis{background:#efe2f5;color:#6b21a8}
.b-deliv{background:var(--deliv-line);color:#fff}
.b-called{background:var(--call-line);color:#fff}
.b-teslim{background:var(--deliv-bg);color:var(--deliv-ink);border:1px solid var(--deliv-line);
  display:inline-flex;align-items:center;gap:4px}
.b-cikti{background:#ede4f7;color:#5b3a8a;border:1px solid #c4a9e6}
.b-cikis{background:#7c5cbf;color:#fff}
.b-haber{background:var(--call-bg);color:var(--call-ink);border:1px solid #b3cbe0}
.b-bekle{background:var(--warn-bg);color:var(--warn-ink)}
.b-gec{background:var(--prob-bg);color:var(--prob-ink);border:1px solid var(--prob-line)}

.tacts{display:inline-flex;border:1px solid var(--line-2);border-radius:9px;overflow:hidden;
  background:var(--surface);flex-shrink:0}
.tacts button{border:0;border-left:1px solid var(--line);border-radius:0;padding:6px 10px;
  font-size:11.5px;font-weight:600;background:transparent;color:var(--ink-soft)}
.tacts button:first-child{border-left:0}
.tacts button:active{transform:none}
.tacts button:hover{background:var(--surface-2);color:var(--ink)}
.tacts button.on{color:#fff}
.tacts .act-geldi.on{background:var(--ok-ink)}
.tacts .act-teslim.on{background:var(--deliv-line);color:#3a2a05}
.tacts .act-arandi.on{background:var(--call-line)}
.tacts .act-cikti.on{background:#7c5cbf;color:#fff}
.tacts .act-iade.on{background:var(--prob-line)}
.tacts .act-edit{color:var(--ink-faint);font-size:13px;padding:6px 9px}
.tacts .act-edit:hover{color:var(--accent);background:var(--accent-soft)}

.empty{text-align:center;color:var(--ink-faint);padding:70px 20px}
.empty-mark{font-size:46px;font-family:var(--font-disp);opacity:.5}
.empty p{font-size:15px;font-weight:600}

/* ============================ Modal ============================ */
.modal-bg{position:fixed;inset:0;background:rgba(34,30,24,.45);backdrop-filter:blur(3px);
  display:flex;align-items:flex-start;justify-content:center;padding:36px 16px;z-index:50;overflow:auto;
  animation:fade .2s ease both}
.modal{background:var(--surface);border-radius:20px;width:600px;max-width:100%;padding:26px;
  box-shadow:var(--shadow-lg);border:1px solid var(--line);animation:rise .28s ease both}
.modal h2{margin:0 0 20px;font-family:var(--font-disp);font-weight:700;font-size:22px;letter-spacing:-.02em}
.grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.grid label{display:flex;flex-direction:column;gap:5px;font-size:11.5px;color:var(--ink-soft);font-weight:700;
  text-transform:uppercase;letter-spacing:.06em}
.grid .col2{grid-column:1 / -1}
.seg{display:flex;border:1px solid var(--line-2);border-radius:9px;overflow:hidden;background:var(--surface);width:fit-content;max-width:100%}
.seg button{border:0;border-left:1px solid var(--line);border-radius:0;padding:10px 18px;font-size:13px;font-weight:600;
  background:transparent;color:var(--ink-soft);text-transform:none;letter-spacing:0}
.seg button:first-child{border-left:0}
.seg button:hover{background:var(--surface-2);color:var(--ink)}
.seg button:active{transform:none}
.seg button.active{background:var(--accent);color:#fff}
.modal-actions{display:flex;align-items:center;gap:9px;margin-top:24px}
.modal-actions .spacer{flex:1}
.req-mark{color:var(--prob-line);font-weight:800}
.grid label .lab{display:inline-flex;align-items:center;gap:4px}

/* ---- Fatura bilgisi (havale) ---- */
.billing-wrap{border:1px solid var(--line-2);border-radius:var(--r);padding:16px;background:var(--surface-2);
  animation:rise .25s ease both}
.billing-head{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.billing-title{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--accent-d)}
.cari-seg{background:var(--surface)}
.billing-fields{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.billing-fields .col2{grid-column:1 / -1}
/* .grid label / .cikis-modal label (0,1,1) display:flex'ini ezmek için .billing-fields ile özgüllük yükseltildi (0,2,0) */
.billing-fields .bf{flex-direction:column;gap:5px;font-size:11.5px;color:var(--ink-soft);font-weight:700;
  text-transform:uppercase;letter-spacing:.06em;display:none}            /* tip seçilene kadar gizli */
.billing-fields.is-bireysel .bf-bireysel,
.billing-fields.is-bireysel .bf-addr,
.billing-fields.is-kurumsal .bf-kurumsal,
.billing-fields.is-kurumsal .bf-addr{display:flex}
.billing-fields.is-none::before{content:"Fatura tipini seçin (Bireysel / Kurumsal)";font-size:12.5px;
  color:var(--ink-faint);font-weight:600;text-transform:none;letter-spacing:0;grid-column:1 / -1}
.billing-hint{display:block;margin-top:11px;font-size:11px;color:var(--ink-faint);font-weight:500;
  text-transform:none;letter-spacing:0;line-height:1.4}

/* ---- Çoklu malzeme (yeni kayıt): sadece ek "kod-ad" alanları; fiyat/ödeme/not ortak ---- */
.extra-wrap{display:flex;flex-direction:column;gap:8px;margin-top:-3px}
#extraMats{display:flex;flex-direction:column;gap:8px}
.xmat{display:flex;gap:8px;align-items:center}
.xmat .xm-mat{flex:1}
.xmat-del{flex:0 0 auto;width:42px;height:42px;padding:0;border:1px solid var(--line-2);background:var(--surface);
  color:var(--prob-line);font-size:20px;line-height:1;border-radius:var(--r-sm);cursor:pointer;font-weight:700}
.xmat-del:hover{background:var(--prob-bg);border-color:var(--prob-line)}
.add-mat{align-self:flex-start;border:1px dashed var(--line-2);background:var(--surface-2);color:var(--accent-d);
  font-weight:700;font-size:12.5px;padding:9px 14px;border-radius:var(--r-sm);cursor:pointer;transition:.15s}
.add-mat:hover{background:var(--accent-soft);border-color:var(--accent)}
.extra-hint{font-size:11px;color:var(--ink-faint);font-weight:500;text-transform:none;letter-spacing:0;line-height:1.4}

/* ---- Depo Çıkış modalı ---- */
.cikis-modal{width:460px}
.cikis-hint{font-size:12.5px;color:var(--ink-soft);margin:-8px 0 16px;line-height:1.5}
.cikis-row{display:flex;gap:9px;align-items:stretch}
.cikis-row #c_barkod{flex:1}
.cikis-row #c_qty{flex:0 0 78px;text-align:center}
/* Çıkış düzenleme formu (etiketli alanlar) */
.cikis-modal label{display:flex;flex-direction:column;gap:5px;font-size:11.5px;color:var(--ink-soft);
  font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:14px}
.cikis-modal label .muted{text-transform:none;letter-spacing:0;font-weight:600}
.cikis-recent{display:flex;flex-direction:column;gap:6px;margin-top:14px;max-height:240px;overflow:auto}
.crec{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:var(--surface-2);
  border:1px solid var(--line);border-radius:9px;font-size:13px;animation:rise .25s ease both}
.crec .cb{font-weight:600;font-variant-numeric:tabular-nums;color:var(--ink)}
.crec .cq{font-weight:800;color:#7c5cbf}

/* ---- Onay penceresi ---- */
.confirm-box{background:var(--surface);border-radius:18px;width:430px;max-width:100%;padding:26px 26px 22px;
  box-shadow:var(--shadow-lg);border:1px solid var(--line);animation:rise .25s ease both;margin-top:12vh}
.confirm-msg{font-size:15.5px;line-height:1.55;color:var(--ink)}
.confirm-msg b{font-weight:800}
.confirm-msg .c-from{color:var(--ink-soft)}
.confirm-msg .c-to{color:var(--accent)}
.confirm-msg .c-del{color:var(--prob-line)}
.confirm-msg .wa-prev{display:block;margin-top:13px;padding:11px 13px;background:var(--surface-2);
  border:1px solid var(--line);border-radius:10px;font-size:13.5px;color:var(--ink-soft);font-weight:500;line-height:1.5}
.confirm-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:22px}

/* ============================ Toast ============================ */
.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%);background:var(--ink);color:#fff;
  padding:12px 20px;border-radius:11px;box-shadow:var(--shadow-lg);z-index:100;font-size:13.5px;font-weight:600;
  animation:toastIn .25s ease both}

/* ============================ Animasyon ============================ */
@keyframes rise{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes toastIn{from{opacity:0;transform:translate(-50%,12px)}to{opacity:1;transform:translate(-50%,0)}}
@media(prefers-reduced-motion:reduce){*{animation:none !important}}

/* ============================ Zimmet (teknisyen) ============================ */
/* Zimmet görünümünde üstteki arama/yeni-kayıt/çıkış/legend gizli (zimmet kendi araç çubuğunu kullanır) */
.view-zimmet .search-wrap,
.view-zimmet #btnNew,
.view-zimmet #btnCikis,
.view-zimmet #btnExport,
.view-zimmet .legend{display:none}

.zimmet-view{padding:18px 24px 80px;max-width:1290px;margin:0 auto}
.z-bar{display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:space-between;margin-bottom:6px}
.z-techs{display:flex;flex-wrap:wrap;gap:8px}
.z-tech{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border:1px solid var(--line-2);
  background:var(--surface);border-radius:999px;font-weight:700;font-size:14px;color:var(--ink-soft);cursor:pointer}
.z-tech:hover{border-color:var(--ink-faint);color:var(--ink)}
.z-tech.on{background:var(--ink);border-color:var(--ink);color:#fff}
.z-tech .z-tcnt{background:var(--paper-2);color:var(--ink-soft);border-radius:999px;padding:1px 8px;font-size:12px;
  font-weight:700;font-variant-numeric:tabular-nums}
.z-tech.on .z-tcnt{background:rgba(255,255,255,.22);color:#fff}
.z-notech{color:var(--ink-soft);font-size:14px}
.z-techsel{font-family:inherit;font-size:15px;font-weight:700;padding:9px 14px;border:1px solid var(--line-2);
  border-radius:10px;background:var(--surface);color:var(--ink);cursor:pointer;min-width:240px;max-width:100%}
.z-techsel:hover{border-color:var(--ink-faint)}
.z-tools{display:flex;gap:9px;align-items:center;flex-wrap:wrap}
.z-search{position:relative;display:flex;align-items:center}
.z-search .search-ic{position:absolute;left:11px;color:var(--ink-faint);pointer-events:none}
.z-search input{padding-left:34px;min-width:210px}

.z-summary{display:flex;align-items:center;gap:10px;margin:14px 2px 16px;flex-wrap:wrap}
.z-summary strong{font-family:var(--font-disp);font-weight:700;font-size:19px;letter-spacing:-.01em;color:var(--ink)}
.z-summary span{color:var(--ink-soft);font-size:13px}
.z-summary .q{color:var(--accent-d)}

/* ============ Net tablo: her teknisyen bir bölüm ============ */
.z-sec{margin-bottom:30px}
.z-sec-head{display:flex;align-items:baseline;gap:10px;margin:0 2px 11px;padding-bottom:9px;border-bottom:2px solid var(--line-2)}
.z-sec-name{margin:0;font-family:var(--font-disp);font-weight:700;font-size:19px;letter-spacing:-.01em;color:var(--ink)}
.z-sec-cnt{font-size:12.5px;color:var(--ink-soft);font-weight:600}

.z-tbl{background:var(--surface);border:1px solid var(--line);border-radius:12px;overflow:hidden;box-shadow:var(--shadow)}
.z-row{display:grid;grid-template-columns:130px minmax(0,1fr) 50px 124px 92px 150px;gap:12px;align-items:center;padding:9px 16px}
.z-tbl-head{background:var(--paper-2);font-size:10.5px;text-transform:uppercase;letter-spacing:.06em;
  color:var(--ink-faint);font-weight:700;border-bottom:1px solid var(--line)}
.z-tbl-head .zc-qty,.z-tbl-head span:nth-child(3){text-align:center}
.z-item{border-top:1px solid var(--line);font-size:13.5px;animation:zin .2s ease both}
.z-item:first-of-type{border-top:0}
.z-item:hover{background:var(--surface-2)}
.z-tbl-date{display:flex;justify-content:space-between;align-items:center;padding:7px 16px;background:var(--accent-soft);
  border-top:1px solid var(--line);font-size:11.5px;font-weight:700;color:var(--accent-d)}
.z-tbl-date:first-child{border-top:0}
.z-tbl-date-c{color:var(--accent-d);opacity:.75;font-weight:600;font-variant-numeric:tabular-nums}
.zc-stok{font-variant-numeric:tabular-nums;font-weight:700;color:var(--ink);cursor:pointer;border-radius:6px;
  padding:2px 5px;margin-left:-5px;justify-self:start;white-space:nowrap}
.zc-stok:hover{background:var(--accent-soft)}
.zc-mal{color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.zc-mal .nameless{color:var(--ink-faint)}
.zc-note{color:var(--ink-faint);font-size:11px;margin-left:6px}
.zc-qty{font-weight:800;color:var(--ink);font-variant-numeric:tabular-nums;text-align:center}
.zc-dur .z-dursel,.z-dursel{width:100%;font-family:inherit;font-size:11.5px;font-weight:700;padding:4px 6px;
  border:1px solid var(--line-2);border-radius:7px;cursor:pointer}
.z-dursel.zb-oth{background:var(--surface);color:var(--ink-soft)}
.zc-fis{color:var(--ink-soft);font-size:12px;font-variant-numeric:tabular-nums;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.zc-act{display:flex;gap:6px;justify-content:flex-end}
.zc-act button{padding:5px 12px;border:1px solid var(--line-2);background:var(--surface);border-radius:7px;
  cursor:pointer;font-size:12px;font-weight:600;color:var(--ink-soft);white-space:nowrap}
.zc-act .z-edit:hover{background:var(--accent-soft);border-color:var(--accent);color:var(--accent-d)}
.zc-act .z-del:hover{background:var(--prob-bg);border-color:var(--prob-line);color:var(--prob-line)}
@keyframes zin{from{opacity:0;transform:translateY(2px)}to{opacity:1;transform:none}}

/* durum rozetleri */
.zb-hurda{background:#f4d9d9;color:#9c3838}
.zb-ucret{background:#fde9c8;color:#9a6206}
.zb-iade{background:#f7dede;color:#b3402f}
.zb-dolap{background:#dbe7f5;color:#2f5b8c}
.zb-teslim{background:#d9efdb;color:#2e6b3a}
.zb-takildi{background:#d9efdb;color:#2e6b3a}
.zb-takilmadi{background:#ede6d4;color:#7a6a3a}
.zb-yarin{background:#e9e2f7;color:#5a3f9c}
.zb-must{background:#e0e7ef;color:#46586b}
.zb-oth{background:var(--paper-2);color:var(--ink-soft)}
/* satır içi durum combobox — kapalı select durum rengini taşır */
.z-dursel{font-family:inherit;font-size:12px;font-weight:700;padding:4px 7px;border:1px solid var(--line-2);
  border-radius:8px;cursor:pointer;max-width:100%}
.z-dursel:hover{filter:brightness(.97)}
.z-dursel.zb-oth{background:var(--surface);color:var(--ink-soft)}
/* Tümü görünümünde teknisyen etiketi */
.zc-tech{align-self:flex-start;font-size:10.5px;font-weight:800;letter-spacing:.02em;color:var(--accent-d);
  background:var(--accent-soft);padding:1px 8px;border-radius:999px;margin-bottom:3px;text-transform:none}

/* durum seçici (modal) — sarılabilir çipler */
.seg-wrap{display:flex;flex-wrap:wrap;border:0;background:transparent;gap:6px;width:100%;max-width:100%}
.seg-wrap button{border:1px solid var(--line-2);border-left:1px solid var(--line-2);border-radius:999px;padding:7px 13px;
  background:var(--surface);color:var(--ink-soft);text-transform:none;letter-spacing:0;font-size:13px;font-weight:600}
.seg-wrap button:first-child{border-left:1px solid var(--line-2)}
.seg-wrap button.active{background:var(--accent);color:#fff;border-color:var(--accent)}

/* Arçelik import önizleme */
.im-preview{margin-top:4px}
.im-ok{font-size:13px;color:var(--ink);margin-bottom:8px}
.im-warn{font-size:13px;color:#9c3838;background:#f4d9d9;padding:10px 12px;border-radius:var(--r-sm)}
.im-line{display:grid;grid-template-columns:108px 1fr 42px;gap:8px;font-size:12.5px;color:var(--ink-soft);padding:5px 0;border-top:1px solid var(--line)}
.im-line span:first-child{font-variant-numeric:tabular-nums;font-weight:600;color:var(--ink)}

/* ============================ Muhasebe (havale / fatura) ============================ */
/* Muhasebe rolünde ön büro araçları gizli; sayfanın kendi araç çubuğu var */
.role-muhasebe .search-wrap,
.role-muhasebe #btnExport,
.role-muhasebe .legend,
.role-muhasebe .filters,
.role-muhasebe #list,
.role-muhasebe #empty{display:none}

.muhasebe-view{padding:18px 24px 80px;max-width:1320px;margin:0 auto}
.m-bar{display:flex;flex-wrap:wrap;gap:12px 16px;align-items:center}
.m-filters{display:flex;gap:9px;flex-wrap:wrap}
.m-filters .chip{cursor:pointer}
.m-chip-warn{border-color:#e3b9ac;color:var(--prob-ink)}
.m-chip-warn .cnt{background:var(--prob-bg);color:var(--prob-ink)}
.m-chip-warn.active{background:var(--prob-line);border-color:var(--prob-line);color:#fff}
.m-chip-warn.active .cnt{background:rgba(255,255,255,.24);color:#fff}
.m-tools{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-left:auto}
/* Arama ana sayfadaki gibi: ortada, geniş, belirgin pill */
.m-search{position:relative;display:flex;align-items:center;flex:1 1 280px;min-width:200px}
.m-search .search-ic{position:absolute;left:14px;color:var(--ink-faint);pointer-events:none}
.m-search input{width:100%;padding-left:42px;border-radius:999px;background:var(--surface-2)}

/* Araç çubuğundaki toplam (ayrı özet satırı kaldırıldı; sayı yalnız çiplerde) */
.m-bar-total{display:inline-flex;align-items:baseline;gap:7px;margin-right:4px;white-space:nowrap}
.m-tlabel,.m-tnum{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-faint)}
.m-tsum{font-family:var(--font-disp);font-weight:800;font-size:16px;color:var(--accent-d);font-variant-numeric:tabular-nums}
.m-list{display:block;margin-top:14px}

.m-table{--mcols:minmax(0,1.5fr) minmax(0,1.2fr) 110px 296px;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow)}
.m-row{display:grid;grid-template-columns:var(--mcols);gap:14px;align-items:center;padding:12px 18px}
.m-thead{font-size:10.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-faint);
  background:var(--surface-2);border-bottom:1px solid var(--line-2)}
.m-date{display:flex;justify-content:space-between;align-items:center;padding:8px 18px;background:var(--paper);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);font-family:var(--font-disp);font-weight:700;font-size:13.5px}
.m-date:first-of-type{border-top:0}
.m-date-c{font-family:var(--font-body);font-size:11.5px;color:var(--ink-faint);font-weight:600}
.m-item{border-top:1px solid var(--line);animation:rise .3s ease both}
.m-item:first-of-type{border-top:0}
.m-item:hover{background:var(--surface-2)}
.m-item.missing{background:linear-gradient(90deg,var(--prob-bg),transparent 72%)}
.m-item.invoiced{background:linear-gradient(90deg,var(--ok-bg),transparent 72%)}

/* Müşteri sütunu: ad + tip + telefon + (doluysa) fatura kimliği + not.
   align-items:flex-start → her öğe içerik genişliğinde, hover vurgusu metni sarar (boş alanı değil) */
.m-cust{display:flex;flex-direction:column;align-items:flex-start;gap:3px;min-width:0;max-width:100%}
.m-cust .nm{font-family:var(--font-disp);font-weight:700;font-size:14.5px;color:var(--ink);max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.m-cust .nameless{color:var(--ink-faint);font-style:italic;font-weight:500}
.m-cust .ph{font-size:12px;color:var(--ink-soft);font-weight:600;font-variant-numeric:tabular-nums;cursor:pointer;border-radius:6px;padding:1px 5px;margin-left:-5px;max-width:100%}
.m-cust .ph:hover{background:var(--accent-soft)}
.m-type{font-size:10px;font-weight:800;letter-spacing:.03em;padding:1px 8px;border-radius:999px;text-transform:uppercase}
.m-type.t-bir{background:var(--call-bg);color:var(--call-ink)}
.m-type.t-kur{background:var(--pay-bg);color:var(--pay-ink)}
.m-ident{font-size:11.5px;font-weight:700;color:var(--ink-soft);font-variant-numeric:tabular-nums;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.m-mat{display:flex;flex-direction:column;align-items:flex-start;gap:2px;min-width:0;max-width:100%}
.m-mat .mn{font-size:13px;font-weight:600;color:var(--ink);font-variant-numeric:tabular-nums;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;border-radius:6px;padding:1px 5px;margin-left:-5px;max-width:100%}
.m-mat .mn:hover{background:var(--accent-soft)}
.m-mat .desc{font-size:10.5px;color:var(--ink-faint);font-weight:600;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.m-price{font-family:var(--font-disp);font-weight:700;font-size:15px;font-variant-numeric:tabular-nums;white-space:nowrap;color:var(--ink)}
.m-price small{font-size:11px;color:var(--ink-faint);font-weight:600}
.m-note{margin-top:3px;font-size:11px;font-weight:600;color:var(--warn-ink);background:var(--warn-bg);
  border-radius:6px;padding:3px 8px;line-height:1.3;max-width:100%;white-space:normal;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
/* Aksiyon sütunu: Bilgi gir/Düzenle + Faturalandı YAN YANA, aynı yükseklik (30px) */
.m-durum{display:flex;justify-content:flex-end;align-items:center;gap:8px;flex-wrap:wrap}
.m-fill,.m-edit-bill,.m-inv{height:30px;display:inline-flex;align-items:center;gap:6px;
  border:1px solid;border-radius:8px;font-weight:700;line-height:1;white-space:nowrap;cursor:pointer}
.m-fill{padding:0 13px;font-size:12px;color:#fff;background:var(--accent);border-color:var(--accent)}
.m-fill:hover{background:var(--accent-d);border-color:var(--accent-d)}
.m-edit-bill{padding:0 12px;font-size:11.5px;color:var(--accent-d);background:var(--surface);border-color:var(--line-2)}
.m-edit-bill:hover{background:var(--accent-soft);border-color:var(--accent)}
.m-inv{padding:0 14px;font-size:12px;color:var(--ink-soft);background:var(--surface);border-color:var(--line-2)}
.m-inv:hover{border-color:var(--ok-ink);color:var(--ok-ink);background:var(--ok-bg)}
.m-inv.on{background:var(--ok-ink);border-color:var(--ok-ink);color:#fff}

/* ============================ Responsive ============================ */
@media(max-width:760px){
  .masthead{display:flex;flex-wrap:wrap;align-items:center;gap:10px 12px;padding:12px 16px}
  .brand{margin-right:auto}
  .search-wrap{order:3;flex:1 1 100%;width:auto}
  .filters{top:auto;position:static;padding:12px 14px;overflow-x:auto;flex-wrap:nowrap;justify-content:flex-start}
  .chip{flex-shrink:0}
  .legend{gap:4px 11px;font-size:11px;width:100%}
  .grid{grid-template-columns:1fr}

  /* Liste → kart görünümü; AYNI MÜŞTERİ TEK KARTTA gruplanır */
  .list{padding:14px 12px 84px}
  .table{background:transparent;border:0;box-shadow:none;border-radius:0;overflow:visible}
  .thead{display:none}
  .tdate{background:transparent;border:0;padding:15px 4px 3px;margin-top:4px}
  /* müşteri bloğu = kart */
  .cust-block{background:var(--surface);border:1px solid var(--line);border-radius:13px;
    box-shadow:var(--shadow);overflow:hidden;margin-bottom:10px}
  .cust-block + .cust-block{border-top:0}
  /* kart içindeki her satır (malzeme) — kendi kart çerçevesi yok */
  .trow{display:flex;flex-direction:column;align-items:stretch;gap:9px;
    padding:12px 14px;margin:0;background:transparent;border:0;border-radius:0;box-shadow:none;animation:none}
  .trow.sub{border-top:1px solid var(--line)}   /* aynı müşterinin malzemeleri arası ayraç */
  .trow.sub .c-cust{display:none}               /* alt malzemelerde müşteri adı tekrar etmesin */
  .trow::before{width:5px}
  .c-cust{flex-direction:row;flex-wrap:wrap;justify-content:space-between;align-items:baseline;
    gap:5px 10px;text-align:left}
  .c-cust .nm{font-size:15.5px;white-space:normal}
  .c-mat{align-items:flex-start;text-align:left;gap:1px}
  .c-mat .mn,.c-mat .desc{white-space:normal}
  .c-note{text-align:left}
  .c-note:empty{display:none}
  .c-price{text-align:left}
  .c-price:empty{display:none}
  .c-pay{justify-content:flex-start}
  .c-durum{flex-direction:row;flex-wrap:wrap;justify-content:flex-start;align-items:center;gap:6px;text-align:left}
  .c-durum:empty{display:none}
  .c-act{justify-content:flex-start}
  .tacts,.paysel{width:100%}
  .tacts button,.paysel .pm{flex:1;padding:12px 8px;font-size:13px}

  /* Zimmet → kartlar tek sütun */
  .zimmet-view{padding:14px 12px 84px}
  .z-bar{align-items:stretch}
  .z-tools{flex-wrap:wrap}
  .z-search{flex:1 1 100%}
  .z-search input{min-width:0;width:100%}
  .z-sec{margin-bottom:20px}
  .z-sec-name{font-size:17px}
  .z-tbl-head{display:none}
  .z-row{display:flex;flex-direction:column;align-items:stretch;gap:6px;padding:12px 14px}
  .zc-stok{align-self:flex-start;font-size:14px}
  .zc-mal{white-space:normal}
  .zc-qty{align-self:flex-start;text-align:left}
  .zc-qty::before{content:"Adet: ";color:var(--ink-faint);font-weight:600}
  .zc-dur .z-dursel,.z-dursel{width:auto;max-width:180px}
  .zc-fis:empty{display:none}
  .zc-fis::before{content:"Fiş: ";color:var(--ink-faint)}
  .zc-act{justify-content:stretch;gap:8px;margin-top:4px}
  .zc-act button{flex:1;padding:10px}
  .zc-act button{width:34px;height:34px}

  /* Muhasebe → kartlar tek sütun */
  .muhasebe-view{padding:14px 12px 84px}
  .m-bar{align-items:stretch}
  .m-filters{overflow-x:auto;flex-wrap:nowrap}
  .m-filters .chip{flex-shrink:0}
  .m-tools{flex-wrap:wrap}
  .m-search{flex:1 1 100%}
  .m-search input{min-width:0;width:100%}
  .m-table{background:transparent;border:0;box-shadow:none;border-radius:0;overflow:visible}
  .m-thead{display:none}
  .m-date{background:transparent;border:0;padding:14px 4px 4px}
  .m-item{display:flex;flex-direction:column;align-items:stretch;gap:8px;background:var(--surface);
    border:1px solid var(--line);border-radius:13px;box-shadow:var(--shadow);padding:14px;margin-bottom:10px;animation:none}
  .m-item.missing{border-color:var(--prob-line)}
  .m-item.invoiced{border-color:var(--ok-ink)}
  .m-cust{flex-direction:row;flex-wrap:wrap;align-items:center;gap:6px 10px}
  .m-cust .nm{white-space:normal}
  .m-ident{white-space:normal}
  .m-mat{align-items:flex-start}
  .m-mat .mn,.m-mat .desc{white-space:normal}
  .m-durum{justify-content:flex-start;gap:8px}
  .m-fill,.m-edit-bill,.m-inv{flex:1;justify-content:center;min-width:120px}

  /* Fatura alanları tek sütun */
  .billing-fields{grid-template-columns:1fr}
}
