/* ============================================================
   Vois POS — paylaşılan tasarım sistemi
   chexta app düzeni (gri-50 tuval, beyaz kart, gri-200 kenarlık, koyu sidebar,
   6-8px radius, yoğun/utilitarian) + VOIS kimliği:
   aksan amber #f5ba12, sidebar VOIS grisi #2b2a2a + beyaz metin, font Inter
   (CRM master admin ile aynı), CRM rahat tipografi (negatif letter-spacing yok).
   İkonlar inline SVG line — emoji YOK.
   ============================================================ */
:root{
  --canvas:#f9fafb; --surface:#ffffff; --raise:#f3f4f6;
  --line:#e5e7eb; --line-2:#d1d5db;
  --ink:#1f2937; --ink-2:#4b5563; --ink-3:#6b7280; --ink-4:#9ca3af;
  --dark:#1a1a1a; --dark-2:#111; --dark-line:rgba(255,255,255,.09);
  --accent:#f5ba12; --accent-d:#e0a800; --accent-ink:#1c1500; --accent-soft:#fef6e0; --accent-soft-line:#f3e3ad;
  --ok:#10b981; --ok-soft:#d1fae5; --ok-ink:#047857;
  --danger:#ef4444; --danger-soft:#fee2e2; --danger-ink:#b42318; --danger-soft-2:#fbcfca;
  --info:#3b82f6; --info-soft:#dbeafe; --info-ink:#1d4ed8; --purple:#a855f7; --purple-soft:#f3e8ff; --purple-ink:#7e22ce;
  /* food cost / grafik tonları (recete + raporlar) */
  --fc-ok:#10b981; --fc-warn:#f5ba12; --fc-danger:#ef4444; --warn-soft-2:#fdeec3;
  /* pazaryeri / kanal marka renkleri */
  --ch-trendyol:#f27a1a; --ch-yemeksepeti:#d6004a; --ch-whatsapp:#25d366; --ch-getir:#5d3ebc;
  --r:8px; --r-sm:6px; --r-md:9px; --r-lg:12px; --pill:999px;
  --sh:0 1px 3px rgba(17,24,39,.07),0 1px 2px rgba(17,24,39,.05);
  --sh-md:0 4px 14px rgba(17,24,39,.10); --sh-pop:0 14px 38px rgba(17,24,39,.20);
  --side:236px; --hdr:58px;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;}
/* Pencere-scroll kabuk: sayfa doğal kayar (tekerlek/klavye her yerde çalışır),
   scrollbar sağ kenarda tam boy; sidebar sticky, header sticky. */
html{height:100%;}
body{min-height:100%;font-family:"Inter",ui-sans-serif,system-ui,-apple-system,"Segoe UI",sans-serif;
  background:var(--canvas);color:var(--ink);-webkit-font-smoothing:antialiased;}
.mono{font-feature-settings:"tnum" 1;}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}
a{color:inherit;text-decoration:none;}
.ico{width:18px;height:18px;flex:none;stroke:currentColor;stroke-width:1.7;fill:none;stroke-linecap:round;stroke-linejoin:round;}
.ico.sm{width:15px;height:15px;} .ico.lg{width:22px;height:22px;}
.app{display:flex;min-height:100vh;}

/* ===================== SIDEBAR ===================== */
.side{width:var(--side);background:var(--dark);color:#fff;display:flex;flex-direction:column;flex:none;
  position:sticky;top:0;height:100vh;align-self:flex-start;}
.side .logo{height:var(--hdr);display:flex;align-items:center;gap:10px;padding:0 18px;border-bottom:1px solid var(--dark-line);}
.side .logo .mk{width:42px;height:38px;object-fit:contain;object-position:left center;flex:none;}
.side .logo .wm{font-weight:700;font-size:15px;white-space:nowrap;}
.side .logo .wm small{display:block;font-weight:500;font-size:9.5px;color:rgba(255,255,255,.45);letter-spacing:.02em;}
.nav{flex:1;overflow-y:auto;padding:12px 10px;scrollbar-width:thin;}
.nav .grp{font-size:10px;font-weight:600;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:.07em;padding:14px 10px 6px;white-space:nowrap;}
.nav a{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:var(--r-sm);color:#fff;font-size:13px;font-weight:500;transition:.14s;white-space:nowrap;margin-bottom:1px;}
.nav a .ico{width:17px;height:17px;color:rgba(255,255,255,.85);}
.nav a:hover{background:rgba(255,255,255,.08);}
.nav a.active{background:var(--accent);color:var(--accent-ink);font-weight:600;}
.nav a.active .ico{color:var(--accent-ink);}
.nav a .pip{margin-left:auto;font-size:10px;background:rgba(255,255,255,.14);color:#fff;border-radius:var(--pill);padding:1px 7px;font-feature-settings:"tnum" 1;}
.nav a.active .pip{background:rgba(0,0,0,.18);color:var(--accent-ink);}
.nav a .flag{margin-left:auto;font-size:8.5px;font-weight:700;letter-spacing:.04em;background:var(--ok);color:#04130c;border-radius:var(--pill);padding:2px 6px;}
.side .me{border-top:1px solid var(--dark-line);padding:12px;display:flex;align-items:center;gap:10px;}
.side .me .av{width:32px;height:32px;border-radius:50%;background:var(--accent-soft);color:var(--accent-d);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;flex:none;}
.side .me .who{line-height:1.2;min-width:0;} .side .me .who b{font-size:12.5px;font-weight:600;display:block;}
.side .me .who span{font-size:10px;color:rgba(255,255,255,.45);}
.side .me .out{margin-left:auto;color:rgba(255,255,255,.5);padding:5px;border-radius:var(--r-sm);}
.side .me .out:hover{color:#fff;background:rgba(255,255,255,.08);}

/* ===================== WORK + HEADER ===================== */
.work{flex:1;display:flex;flex-direction:column;min-width:0;}
.hdr{height:var(--hdr);background:var(--surface);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:14px;padding:0 18px;flex:none;
  position:sticky;top:0;z-index:60;}
.burger{display:none;width:36px;height:36px;border-radius:var(--r-sm);align-items:center;justify-content:center;color:var(--ink-2);border:1px solid var(--line);}
.hdr .ttl{font-size:16px;font-weight:600;}
.hdr .ttl small{display:block;font-size:11px;font-weight:400;color:var(--ink-4);margin-top:1px;}
.hdr .sp{flex:1;}
.branch-sel{display:inline-flex;align-items:center;gap:8px;height:36px;background:var(--surface);border:1px solid var(--line);border-radius:var(--pill);padding:0 12px;cursor:pointer;transition:.14s;}
.branch-sel:hover{border-color:var(--line-2);}
.branch-sel:focus-within{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft);}
.branch-sel .ico{width:15px;height:15px;color:var(--accent-d);flex:none;}
.branch-sel select{appearance:none;-webkit-appearance:none;-moz-appearance:none;border:none;background:transparent;outline:none;font-family:inherit;font-size:13px;font-weight:600;color:var(--ink);cursor:pointer;line-height:1;height:100%;padding:0 20px 0 0;max-width:170px;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239aa0a6' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><path d='M6 9l6 6 6-6'/></svg>");background-repeat:no-repeat;background-position:right center;background-size:12px;}
.branch-sel select:focus{outline:none;}
@media(max-width:760px){.branch-sel select{max-width:120px;}}
.qact{display:flex;gap:7px;}
.qact button{display:flex;align-items:center;gap:6px;padding:8px 12px;border-radius:var(--r-sm);border:1px solid var(--line);background:var(--surface);font-size:12.5px;font-weight:500;color:var(--ink-2);transition:.14s;}
.qact button .ico{width:15px;height:15px;color:var(--ink-3);}
.qact button:hover{border-color:var(--line-2);color:var(--ink);background:var(--raise);}
@media(max-width:1180px){.qact .ql{display:none;} .qact button{padding:8px;}}

/* ===================== İÇERİK (genel sayfa) ===================== */
.content{flex:1;padding:20px 22px 28px;min-width:0;}
.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px;flex-wrap:wrap;}
.page-head h1{font-size:20px;font-weight:700;}
.page-head p{font-size:13px;color:var(--ink-3);margin-top:3px;}
.page-head .acts{display:flex;gap:8px;flex-wrap:wrap;}

/* butonlar */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:9px 15px;border-radius:var(--r-sm);font-size:13px;font-weight:600;transition:.14s;border:1px solid transparent;}
.btn .ico{width:16px;height:16px;}
.btn-primary{background:var(--accent);color:var(--accent-ink);box-shadow:0 4px 12px -5px rgba(245,186,18,.7);}
.btn-primary:hover{background:var(--accent-d);}
.btn-ghost{background:var(--surface);border-color:var(--line-2);color:var(--ink-2);}
.btn-ghost:hover{background:var(--raise);color:var(--ink);}
.btn-dark{background:var(--dark);color:#fff;} .btn-dark:hover{background:var(--dark-2);}
.btn-danger{background:var(--danger-soft);color:var(--danger-ink);} .btn-danger:hover{background:var(--danger-soft-2);}
.btn-sm{padding:6px 10px;font-size:12px;} .btn-icon{padding:8px;width:34px;height:34px;}

/* kartlar */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh);}
.card-head{padding:15px 18px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:12px;}
.card-head h2{font-size:14.5px;font-weight:600;display:flex;align-items:center;gap:9px;}
.card-head h2 .ico{width:17px;height:17px;color:var(--ink-3);}
.card-body{padding:18px;}
.card-pad{padding:18px;}

/* KPI istatistik */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:18px;}
.kpi{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:16px 18px;box-shadow:var(--sh);}
.kpi .top{display:flex;align-items:center;justify-content:space-between;}
.kpi .lbl{font-size:12px;color:var(--ink-3);font-weight:500;}
.kpi .ic{width:34px;height:34px;border-radius:9px;background:var(--accent-soft);color:var(--accent-d);display:flex;align-items:center;justify-content:center;}
.kpi .ic .ico{width:18px;height:18px;}
.kpi .val{font-size:26px;font-weight:700;margin-top:10px;font-feature-settings:"tnum" 1;}
.kpi .sub{font-size:11.5px;color:var(--ink-4);margin-top:3px;}
.kpi .sub.up{color:var(--ok);} .kpi .sub.down{color:var(--danger);}
.kpi.ok .ic{background:var(--ok-soft);color:var(--ok);}
.kpi.info .ic{background:var(--info-soft);color:var(--info);}
.kpi.danger .ic{background:var(--danger-soft);color:var(--danger);}

/* tablo */
.tbl-wrap{overflow-x:auto;}
/* KÖK NEDEN DÜZELTMESİ: view'lardaki sabit tablo min-width'leri (680–1320px)
   kart içi yatay kesilme yaratıyordu; zoom px'leri birlikte ölçeklediğinden
   küçültüp büyütmek oranı değiştirmiyordu. Tablolar her genişlikte karta sığar;
   hücreler gerektiğinde sarar (sayısal .num hücreleri sarmasın). */
.tbl-wrap table,.tbl-card table{min-width:0 !important;width:100%;}
.tbl .num{white-space:nowrap;}
.tbl{width:100%;border-collapse:collapse;font-size:13px;}
.tbl th{text-align:left;font-size:10.5px;font-weight:600;color:var(--ink-4);text-transform:uppercase;letter-spacing:.05em;padding:11px 14px;border-bottom:1px solid var(--line);white-space:nowrap;}
.tbl td{padding:13px 14px;border-bottom:1px solid var(--line);color:var(--ink-2);vertical-align:middle;}
.tbl tr:last-child td{border-bottom:none;}
.tbl tbody tr{transition:.1s;} .tbl tbody tr:hover{background:var(--raise);}
.tbl td b,.tbl td .strong{color:var(--ink);font-weight:600;}
.tbl .num{text-align:right;font-feature-settings:"tnum" 1;}
.rowact{display:flex;gap:6px;justify-content:flex-end;}
.iact{width:30px;height:30px;border-radius:var(--r-sm);border:1px solid var(--line);display:inline-flex;align-items:center;justify-content:center;color:var(--ink-3);transition:.12s;cursor:pointer;flex:none;}
.iact:hover{border-color:var(--line-2);color:var(--ink);background:var(--surface);}
.iact.del:hover{color:var(--danger);border-color:var(--danger-soft);background:var(--danger-soft);}
.icbtn{width:30px;height:30px;border-radius:var(--r-sm);border:1px solid var(--line);background:var(--surface);display:inline-flex;align-items:center;justify-content:center;color:var(--ink-3);cursor:pointer;transition:.12s;}
.icbtn .ico{width:15px;height:15px;}
.icbtn:hover{border-color:var(--line-2);color:var(--ink);background:var(--raise);}
.icbtn.del:hover{color:var(--danger);border-color:var(--danger-soft);background:var(--danger-soft);}
.bar{height:9px;border-radius:var(--pill);background:var(--raise);overflow:hidden;}
.bar>i{display:block;height:100%;border-radius:var(--pill);transition:width .5s cubic-bezier(.16,1,.3,1);}
.tri{display:inline-block;width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;vertical-align:middle;margin-right:2px;}
.tri.up{border-bottom:5px solid currentColor;}
.tri.down{border-top:5px solid currentColor;}

/* rozet / durum */
.badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:3px 9px;border-radius:var(--pill);}
.badge .dot{width:7px;height:7px;border-radius:50%;background:currentColor;}
.badge.ok{background:var(--ok-soft);color:var(--ok-ink);} .badge.warn{background:var(--accent-soft);color:var(--accent-d);}
.badge.info{background:var(--info-soft);color:var(--info-ink);} .badge.danger{background:var(--danger-soft);color:var(--danger-ink);}
.badge.purple{background:var(--purple-soft);color:var(--purple-ink);} .badge.muted{background:var(--raise);color:var(--ink-3);}

/* sekmeler */
.tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin-bottom:18px;overflow-x:auto;scrollbar-width:none;}
.tabs::-webkit-scrollbar{display:none;}
.tab{padding:10px 15px;font-size:13px;font-weight:500;color:var(--ink-3);border-bottom:2px solid transparent;white-space:nowrap;transition:.12s;display:flex;align-items:center;gap:7px;}
.tab .ico{width:16px;height:16px;}
.tab:hover{color:var(--ink);} .tab.active{color:var(--ink);border-bottom-color:var(--accent);font-weight:600;}
/* pill seçici */
.seg{display:inline-flex;gap:2px;background:var(--raise);border:1px solid var(--line);border-radius:var(--pill);padding:3px;}
.seg button{padding:7px 14px;border-radius:var(--pill);font-size:12.5px;font-weight:500;color:var(--ink-3);transition:.14s;}
.seg button.active{background:var(--surface);color:var(--ink);box-shadow:var(--sh);font-weight:600;}

/* form */
.field{margin-bottom:15px;} .field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.field label{display:block;font-size:11.5px;font-weight:600;color:var(--ink-2);margin-bottom:6px;}
/* GLOBAL form teması — inline formlar (ödeme kaydet, yanıt yaz, durum seç...) dahil
   her .field suite diline oturur; form sayfalarındaki yerel kopyalar aynı değerlerdir. */
.field input,.field select,.field textarea{width:100%;font-family:inherit;font-size:13px;padding:9px 11px;border:1px solid var(--line-2);border-radius:var(--r-md);background:var(--surface);color:var(--ink);outline:none;transition:border-color .15s,box-shadow .15s;}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft);}
.field textarea{resize:vertical;min-height:72px;}
.field .err{display:block;font-size:11.5px;color:var(--danger);margin-top:2px;}
.field input[type=checkbox],.field input[type=radio]{width:15px;height:15px;accent-color:var(--accent);}
.field select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239aa0a6' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><path d='M6 9l6 6 6-6'/></svg>");background-repeat:no-repeat;background-position:right 10px center;background-size:12px;padding-right:30px;}
.input,.select,textarea.input{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:var(--r-sm);font-size:13.5px;font-family:inherit;color:var(--ink);background:var(--surface);outline:none;transition:.14s;}
.input:focus,.select:focus,textarea.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(245,186,18,.15);}
.select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:34px;}
.hint{font-size:11px;color:var(--ink-4);margin-top:5px;}
.switch{position:relative;width:40px;height:23px;border-radius:var(--pill);background:var(--line-2);transition:.16s;flex:none;cursor:pointer;}
.switch.on{background:var(--accent);}
.switch::after{content:"";position:absolute;top:2px;left:2px;width:19px;height:19px;border-radius:50%;background:#fff;transition:.16s;box-shadow:var(--sh);}
.switch.on::after{transform:translateX(17px);}

/* boş durum */
.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:13px;color:var(--ink-4);padding:48px 20px;text-align:center;}
.empty .ring{width:62px;height:62px;border-radius:50%;background:var(--raise);display:flex;align-items:center;justify-content:center;}
.empty .ring .ico{width:28px;height:28px;color:var(--ink-4);stroke-width:1.4;}
.empty p{font-size:13px;font-weight:500;line-height:1.6;}

/* grid yardımcıları */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px;} .grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.row{display:flex;gap:10px;align-items:center;} .wrap{flex-wrap:wrap;} .gap-sm{gap:6px;}
.toolbar{display:flex;align-items:center;gap:10px;margin-bottom:16px;flex-wrap:wrap;}
.search{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-sm);padding:8px 12px;min-width:220px;flex:1;max-width:340px;}
.search input{border:none;outline:none;font-family:inherit;font-size:13px;flex:1;background:transparent;color:var(--ink);}
.search .ico{color:var(--ink-4);width:16px;height:16px;}

/* ===================== MODAL ===================== */
.ov{position:fixed;inset:0;background:rgba(17,24,39,.45);backdrop-filter:blur(2px);z-index:90;display:none;align-items:flex-end;justify-content:center;}
.ov.show{display:flex;} @media(min-width:560px){.ov{align-items:center;padding:20px;}}
.modal{background:var(--surface);width:100%;max-width:480px;border-radius:var(--r-lg) var(--r-lg) 0 0;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--sh-pop);animation:up .3s cubic-bezier(.16,1,.3,1);}
@media(min-width:560px){.modal{border-radius:var(--r-lg);}}
@keyframes up{from{transform:translateY(22px);opacity:0;}to{transform:none;opacity:1;}}
.m-head{padding:16px 18px;border-bottom:1px solid var(--line);display:flex;align-items:flex-start;justify-content:space-between;}
.m-head h3{font-size:16px;font-weight:600;} .m-head .sub{font-size:12px;color:var(--ink-4);margin-top:2px;}
.m-head .x{color:var(--ink-4);padding:3px;} .m-head .x:hover{color:var(--ink);}
.m-body{padding:16px 18px;overflow-y:auto;}
.m-foot{padding:14px 18px;border-top:1px solid var(--line);display:flex;gap:9px;justify-content:flex-end;}

/* toast */
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);background:var(--dark-2);color:#fff;padding:12px 18px;border-radius:var(--r);font-size:13px;font-weight:500;z-index:200;box-shadow:var(--sh-pop);display:flex;align-items:center;gap:8px;}
.toast .ico{color:var(--accent);width:16px;height:16px;}

/* ===================== RESPONSIVE (shell) ===================== */
@media(max-width:860px){
  .side{position:fixed;inset:0 auto 0 0;z-index:100;transform:translateX(-100%);transition:transform .25s;box-shadow:var(--sh-pop);}
  body.nav-open .side{transform:none;} .burger{display:flex;}
  body.nav-open::after{content:"";position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:99;}
  .field-row,.grid-2,.grid-3{grid-template-columns:1fr;}
  .content{padding:16px;}
}

/* ===================== KONSOL (index.html'e özel) ===================== */
.stage{flex:1;display:grid;grid-template-columns:1fr 384px;min-height:0;}
.menu-pane{overflow-y:auto;padding:16px 18px 24px;}
.ticket-pane{background:var(--surface);border-left:1px solid var(--line);display:flex;flex-direction:column;overflow:hidden;}
.mtabs{display:none;}
.chans{display:flex;gap:8px;overflow-x:auto;padding-bottom:14px;scrollbar-width:none;}
.chans::-webkit-scrollbar{display:none;}
.chan{display:flex;align-items:center;gap:8px;white-space:nowrap;padding:9px 14px;border-radius:var(--r);background:var(--surface);border:1px solid var(--line);font-size:13px;font-weight:500;color:var(--ink-2);transition:.14s;}
.chan .ico{width:16px;height:16px;color:var(--ink-3);}
.chan:hover{border-color:var(--line-2);color:var(--ink);}
.chan.active{background:var(--dark);color:#fff;border-color:var(--dark);font-weight:600;}
.chan.active .ico{color:var(--accent);}
.chan .dot{width:8px;height:8px;border-radius:50%;}
.chan .ct{font-size:10.5px;background:var(--accent);color:var(--accent-ink);border-radius:var(--pill);padding:0 6px;font-weight:600;font-feature-settings:"tnum" 1;}
.section-h{font-size:11px;font-weight:600;color:var(--ink-4);text-transform:uppercase;letter-spacing:.07em;margin:4px 2px 11px;}
.cats{display:flex;gap:7px;overflow-x:auto;padding-bottom:14px;scrollbar-width:none;}
.cats::-webkit-scrollbar{display:none;}
.cat{display:flex;align-items:center;gap:7px;white-space:nowrap;padding:8px 14px;border-radius:var(--pill);background:var(--surface);border:1px solid var(--line);font-size:12.5px;font-weight:500;color:var(--ink-2);transition:.14s;}
.cat .ico{width:15px;height:15px;color:var(--ink-4);}
.cat:hover{border-color:var(--line-2);} .cat.active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent-d);font-weight:600;}
.cat.active .ico{color:var(--accent-d);}
.items{display:grid;grid-template-columns:repeat(auto-fill,minmax(166px,1fr));gap:12px;}
.item{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:13px;text-align:left;display:flex;flex-direction:column;gap:9px;min-height:124px;position:relative;transition:transform .1s,box-shadow .16s,border-color .16s;animation:rise .36s cubic-bezier(.22,1,.36,1) both;}
@keyframes rise{from{opacity:0;transform:translateY(7px);}to{opacity:1;transform:none;}}
.item:hover{box-shadow:var(--sh-md);border-color:var(--line-2);transform:translateY(-2px);}
.item:active{transform:scale(.98);}
.item .ic{width:38px;height:38px;border-radius:9px;background:var(--accent-soft);color:var(--accent-d);display:flex;align-items:center;justify-content:center;}
.item .ic .ico{width:20px;height:20px;}
.item .nm{font-size:13.5px;font-weight:600;line-height:1.25;color:var(--ink);}
.item .foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;}
.item .pr{font-size:14.5px;font-weight:600;}
.item .add{width:28px;height:28px;border-radius:7px;background:var(--dark);color:#fff;display:flex;align-items:center;justify-content:center;transition:.14s;}
.item:hover .add{background:var(--accent);color:var(--accent-ink);}
.item .flag{position:absolute;top:11px;right:11px;font-size:9px;font-weight:600;letter-spacing:.03em;color:var(--ink-4);border:1px solid var(--line);border-radius:var(--pill);padding:2px 7px;text-transform:uppercase;}
.item .low{position:absolute;top:11px;left:11px;font-size:9px;font-weight:600;color:var(--danger);background:var(--danger-soft);border-radius:var(--pill);padding:2px 7px;}
.item.out{opacity:.5;pointer-events:none;}
.tk-head{padding:15px 18px 13px;border-bottom:1px solid var(--line);}
.tk-head .top{display:flex;align-items:center;justify-content:space-between;}
.tk-head h2{font-size:15px;font-weight:600;}
.tk-head .no{font-size:11px;color:var(--ink-4);background:var(--raise);border-radius:var(--r-sm);padding:2px 8px;font-feature-settings:"tnum" 1;}
.cust{margin-top:12px;display:flex;gap:11px;align-items:flex-start;padding:11px;border:1px solid var(--line);border-radius:var(--r);background:var(--canvas);width:100%;text-align:left;transition:.14s;}
.cust:hover{border-color:var(--line-2);}
.cust .cav{width:34px;height:34px;border-radius:8px;background:var(--surface);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--ink-3);flex:none;}
.cust .cn{font-size:13px;font-weight:600;} .cust .cd{font-size:11.5px;color:var(--ink-3);margin-top:3px;line-height:1.5;display:flex;flex-direction:column;gap:2px;}
.cust .cd span{display:flex;align-items:center;gap:5px;} .cust .cd .ico{width:13px;height:13px;color:var(--ink-4);}
.cust.empty2{justify-content:center;color:var(--ink-4);font-size:12.5px;font-weight:500;padding:14px;}
.lines{flex:1;overflow-y:auto;padding:4px 18px;}
.ln{display:flex;gap:11px;align-items:flex-start;padding:12px 0;border-bottom:1px solid var(--line);}
.qty{display:flex;align-items:center;border:1px solid var(--line);border-radius:var(--r-sm);overflow:hidden;flex:none;}
.qty button{width:26px;height:26px;display:flex;align-items:center;justify-content:center;color:var(--ink-3);transition:.12s;}
.qty button:hover{background:var(--raise);color:var(--ink);}
.qty .v{min-width:24px;text-align:center;font-size:13px;font-weight:600;font-feature-settings:"tnum" 1;}
.ln .body{flex:1;min-width:0;} .ln .lnm{font-size:13px;font-weight:600;line-height:1.3;}
.ln .lop{font-size:11px;color:var(--ink-4);margin-top:2px;line-height:1.4;}
.ln .lpr{font-size:13px;font-weight:600;white-space:nowrap;font-feature-settings:"tnum" 1;}
.ln .del{color:var(--ink-4);padding:2px;transition:.12s;} .ln .del:hover{color:var(--danger);}
.empty-tk{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:13px;color:var(--ink-4);padding:36px;}
.empty-tk .ring{width:60px;height:60px;border-radius:50%;background:var(--canvas);display:flex;align-items:center;justify-content:center;}
.empty-tk .ring .ico{width:26px;height:26px;color:var(--ink-4);stroke-width:1.4;}
.empty-tk p{font-size:12.5px;font-weight:500;text-align:center;line-height:1.6;}
.totals{border-top:1px solid var(--line);padding:13px 18px 2px;}
.tr{display:flex;justify-content:space-between;align-items:center;padding:3px 0;font-size:13px;color:var(--ink-3);}
.tr .mono{font-size:13px;color:var(--ink-2);}
.tr .disc{color:var(--accent-d);font-weight:500;font-size:11.5px;display:flex;align-items:center;gap:4px;}
.tr.grand{border-top:1px solid var(--line);margin-top:5px;padding-top:11px;}
.tr.grand b{font-size:14px;font-weight:600;color:var(--ink);} .tr.grand .mono{font-size:20px;font-weight:600;color:var(--ink);}
.tk-actions{padding:13px 18px 16px;display:grid;grid-template-columns:1fr 1fr;gap:8px;}
.tk-actions .btn{min-height:46px;}
.tk-actions .btn.pay{grid-column:1/-1;background:var(--accent);color:var(--accent-ink);font-size:14.5px;box-shadow:0 6px 16px -6px rgba(245,186,18,.7);}
.tk-actions .btn.pay:hover{background:var(--accent-d);}
.tk-actions .btn.pay:disabled{background:var(--raise);color:var(--ink-4);box-shadow:none;cursor:not-allowed;}
.callpop{position:fixed;top:-280px;right:18px;width:min(420px,calc(100vw - 36px));background:var(--surface);border-radius:var(--r-lg);box-shadow:var(--sh-pop);z-index:120;overflow:hidden;transition:top .5s cubic-bezier(.16,1,.3,1);border:1px solid var(--line);border-top:3px solid var(--accent);}
.callpop.show{top:16px;}
.cp-top{padding:14px 16px;display:flex;align-items:center;gap:12px;}
.cp-ring{width:42px;height:42px;border-radius:50%;background:var(--ok-soft);color:var(--ok);display:flex;align-items:center;justify-content:center;flex:none;animation:pulse 1.4s infinite;}
.cp-ring .ico{width:20px;height:20px;}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(16,185,129,.35);}70%{box-shadow:0 0 0 12px rgba(16,185,129,0);}100%{box-shadow:0 0 0 0 rgba(16,185,129,0);}}
.cp-top .num{font-size:16px;font-weight:600;font-feature-settings:"tnum" 1;}
.cp-top .lbl{font-size:10.5px;color:var(--ink-4);display:flex;align-items:center;gap:5px;margin-top:2px;}
.cp-x{margin-left:auto;align-self:flex-start;color:var(--ink-4);padding:3px;} .cp-x:hover{color:var(--ink);}
.cp-body{padding:0 16px 14px;}
.cp-name{font-size:16px;font-weight:700;display:flex;align-items:center;gap:8px;}
.cp-name .tag{font-size:9.5px;font-weight:600;color:var(--ok);background:var(--ok-soft);border-radius:var(--pill);padding:2px 8px;}
.cp-name.unknown{color:var(--ink-4);font-weight:600;}
.cp-addrs{margin-top:11px;display:flex;flex-direction:column;gap:6px;}
.cp-addr{display:flex;gap:8px;align-items:flex-start;font-size:12px;background:var(--canvas);border:1px solid var(--line);border-radius:var(--r-sm);padding:8px 10px;}
.cp-addr .ico{width:14px;height:14px;color:var(--accent-d);margin-top:1px;flex:none;}
.cp-addr b{font-weight:600;} .cp-addr span{color:var(--ink-3);}
.cp-recent{margin-top:10px;font-size:11px;color:var(--ink-4);display:flex;align-items:center;gap:6px;}
.cp-foot{padding:13px 16px;border-top:1px solid var(--line);display:flex;gap:8px;background:var(--canvas);}
.cp-foot .btn{flex:1;min-height:44px;}
.optg{padding:13px 0;border-bottom:1px solid var(--line);}
.optg .gh{display:flex;align-items:center;justify-content:space-between;margin-bottom:9px;}
.optg .gh b{font-size:13px;font-weight:600;} .optg .gh .req{font-size:9.5px;font-weight:600;color:var(--accent-d);background:var(--accent-soft);border-radius:var(--pill);padding:2px 8px;}
.opt{display:flex;align-items:center;gap:11px;padding:10px 12px;border:1px solid var(--line);border-radius:var(--r);margin-bottom:7px;width:100%;text-align:left;transition:.12s;}
.opt:hover{border-color:var(--line-2);} .opt.sel{border-color:var(--accent);background:var(--accent-soft);}
.opt .box{width:20px;height:20px;border-radius:6px;border:1.6px solid var(--line-2);display:flex;align-items:center;justify-content:center;flex:none;transition:.12s;}
.opt.sel .box{background:var(--accent);border-color:var(--accent);color:var(--accent-ink);}
.opt .box .ico{width:13px;height:13px;opacity:0;stroke-width:2.6;} .opt.sel .box .ico{opacity:1;}
.opt .on{flex:1;font-size:13px;font-weight:500;} .opt .od{font-size:12.5px;color:var(--ink-3);font-feature-settings:"tnum" 1;}
.pay-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(96px,1fr));gap:8px;padding:12px 0;}
@media(max-width:420px){.pay-grid{grid-template-columns:repeat(2,1fr);}}
.pm{display:flex;flex-direction:column;align-items:center;gap:7px;padding:16px 12px;border:1px solid var(--line);border-radius:var(--r);transition:.12s;}
.pm:hover{border-color:var(--line-2);} .pm.sel{border-color:var(--accent);background:var(--accent-soft);}
.pm .ico{width:23px;height:23px;color:var(--ink-3);} .pm.sel .ico{color:var(--accent-d);} .pm span{font-size:12.5px;font-weight:600;}
/* ödeme detayı: nakit / parçalı / not */
.pay-cash,.split-box{margin-top:6px;}
.quick-cash{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:12px;}
.quick-cash button{flex:1;min-width:70px;padding:9px 8px;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--surface);font-size:12.5px;font-weight:600;color:var(--ink-2);font-feature-settings:"tnum" 1;transition:.12s;}
.quick-cash button:hover{border-color:var(--accent);color:var(--accent-d);background:var(--accent-soft);}
.change-row{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-radius:var(--r-sm);background:var(--canvas);border:1px solid var(--line);font-size:13px;font-weight:600;color:var(--ink-2);margin-top:4px;}
.change-row .mono{font-size:15px;font-weight:700;}
.split-h{display:flex;align-items:center;gap:7px;font-size:12px;font-weight:600;color:var(--ink-3);margin-bottom:10px;} .split-h .ico{color:var(--accent-d);}
.pay-note{display:flex;align-items:center;gap:8px;margin-top:10px;padding:11px 13px;border-radius:var(--r-sm);background:var(--ok-soft);color:var(--ok-ink);font-size:12.5px;font-weight:500;} .pay-note .ico{flex:none;}
/* fiş / adisyon önizleme */
.receipt{background:#fff;border:1px dashed var(--line-2);border-radius:var(--r);padding:18px 20px;max-width:300px;margin:0 auto;font-feature-settings:"tnum" 1;}
.rc-top{text-align:center;border-bottom:1px dashed var(--line-2);padding-bottom:12px;margin-bottom:12px;}
.rc-store{font-size:15px;font-weight:700;color:var(--ink);} .rc-sub{font-size:11px;color:var(--ink-3);margin-top:2px;}
.rc-meta{font-size:11px;color:var(--ink-4);margin-top:3px;}
.rc-ln{display:flex;gap:8px;align-items:flex-start;padding:5px 0;font-size:12.5px;}
.rc-ln .rc-q{flex:none;color:var(--ink-3);min-width:26px;} .rc-ln .rc-n{flex:1;color:var(--ink-2);font-weight:500;}
.rc-ln .rc-opt{font-size:10.5px;color:var(--ink-4);margin-top:1px;} .rc-ln .rc-p{flex:none;font-weight:600;color:var(--ink);}
.rc-tot{border-top:1px dashed var(--line-2);margin-top:10px;padding-top:10px;}
.rc-tr{display:flex;justify-content:space-between;padding:3px 0;font-size:12.5px;color:var(--ink-3);}
.rc-tr .mono{color:var(--ink-2);font-weight:600;}
.rc-tr.grand{border-top:1px solid var(--line);margin-top:6px;padding-top:9px;} .rc-tr.grand b{font-size:13.5px;color:var(--ink);} .rc-tr.grand .mono{font-size:16px;color:var(--ink);font-weight:700;}
.rc-tr.pay{margin-top:6px;color:var(--ink-2);font-weight:600;}
.rc-foot{text-align:center;font-size:10.5px;color:var(--ink-4);border-top:1px dashed var(--line-2);margin-top:12px;padding-top:11px;}
.rc-ded{margin-top:14px;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--canvas);padding:11px 13px;}
.rc-ded-h{display:flex;align-items:center;gap:7px;font-size:11.5px;font-weight:600;color:var(--ink-3);margin-bottom:8px;} .rc-ded-h .ico{color:var(--accent-d);}
.rc-ded-ln{display:flex;justify-content:space-between;gap:10px;font-size:11.5px;color:var(--ink-3);padding:3px 0;}
.rc-ded-ln .mono{color:var(--danger-ink);font-weight:600;font-feature-settings:"tnum" 1;}
.board{flex:1;overflow-x:auto;padding:16px 18px;display:none;gap:13px;}
.board.show{display:flex;}
.col{min-width:256px;width:256px;flex:none;display:flex;flex-direction:column;gap:10px;}
.col-h{display:flex;align-items:center;justify-content:space-between;padding:0 3px;}
.col-h .t{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;} .col-h .dt{width:8px;height:8px;border-radius:50%;}
.col-h .ct{font-size:11px;color:var(--ink-4);background:var(--surface);border:1px solid var(--line);border-radius:var(--pill);padding:1px 8px;font-feature-settings:"tnum" 1;}
.oc{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:12px;box-shadow:var(--sh);transition:.14s;}
.oc:hover{box-shadow:var(--sh-md);transform:translateY(-2px);}
.oc .oh{display:flex;align-items:center;justify-content:space-between;}
.oc .ono{font-size:12px;font-weight:600;font-feature-settings:"tnum" 1;}
.oc .ch2{font-size:10px;font-weight:500;color:var(--ink-2);border:1px solid var(--line);border-radius:var(--pill);padding:2px 8px;display:flex;align-items:center;gap:4px;} .oc .ch2 .ico{width:12px;height:12px;}
.oc .ocu{font-size:13px;font-weight:600;margin-top:8px;} .oc .oit{font-size:11px;color:var(--ink-4);margin-top:3px;line-height:1.4;}
.oc .of{display:flex;align-items:center;justify-content:space-between;margin-top:10px;padding-top:10px;border-top:1px solid var(--line);}
.oc .ot{font-size:13.5px;font-weight:600;font-feature-settings:"tnum" 1;}
.oc .nx{display:flex;align-items:center;gap:4px;font-size:11px;font-weight:600;color:var(--accent-d);} .oc .nx .ico{width:14px;height:14px;}
.sim{position:fixed;left:18px;bottom:18px;z-index:60;display:flex;align-items:center;gap:8px;background:var(--dark-2);color:#fff;border-radius:var(--pill);padding:12px 16px;font-size:13px;font-weight:600;box-shadow:var(--sh-pop);transition:.14s;}
.sim:hover{transform:translateY(-2px);} .sim .ico{color:var(--accent);width:16px;height:16px;}
@media(max-width:1100px){.stage{grid-template-columns:1fr 340px;}}
@media(max-width:860px){
  .stage{grid-template-columns:1fr;}
  .ticket-pane{position:fixed;inset:var(--hdr) 0 62px 0;z-index:30;transform:translateX(100%);transition:transform .28s cubic-bezier(.16,1,.3,1);}
  body.view-ticket .ticket-pane{transform:none;}
  body.view-board .menu-pane{display:none;} body.view-board .board{display:flex;}
  .mtabs{display:flex;position:fixed;bottom:0;left:0;right:0;height:62px;background:var(--surface);border-top:1px solid var(--line);z-index:50;padding:6px;}
  .mtabs button{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;border-radius:var(--r-sm);color:var(--ink-4);font-size:10px;font-weight:600;position:relative;}
  .mtabs button .ico{width:20px;height:20px;} .mtabs button.active{color:var(--ink);} .mtabs button.active .ico{color:var(--accent-d);}
  .menu-pane,.board{padding-bottom:74px;} .callpop.show{top:12px;} .sim{bottom:72px;}
}

/* ===================== DOKUNMA HEDEFLERİ (tablet/dokunmatik) =====================
   parmakla kullanılan kasalarda küçük ikon-butonları büyüt (fare/masaüstü değişmez) */
@media(pointer:coarse){
  .qty button{width:40px;height:40px;}
  .qty .v{min-width:32px;font-size:14px;}
  .item .add{width:40px;height:40px;border-radius:9px;}
  .item .add .ico{width:18px;height:18px;}
  .iact,.icbtn{width:38px;height:38px;}
  .iact .ico,.icbtn .ico{width:17px;height:17px;}
}

/* ===================== GRAFİK BİLEŞEN KÜTÜPHANESİ (token renkli, sprite/inline) =====================
   Vanilla — hiçbir grafik kütüphanesi yok; conic-gradient donut + flex/grid bar/sparkline.
   Kullanım: aşağıdaki sınıflar tüm rapor/özet/stok sayfalarında paylaşılır. */
:root{
  --chart-h:160px; --donut-sz:140px; --donut-hole:60%;
  --c1:var(--accent); --c2:var(--info); --c3:var(--ok); --c4:var(--purple); --c5:var(--ink-3); --c6:var(--ch-trendyol);
}
/* --- donut (conic-gradient) + orta etiket + lejant --- */
.chart-donut-wrap{display:flex;align-items:center;gap:18px;flex-wrap:wrap;}
.donut{position:relative;width:var(--donut-sz);height:var(--donut-sz);border-radius:50%;flex:none;
  background:conic-gradient(var(--raise) 0 100%);transition:background .5s cubic-bezier(.16,1,.3,1);}
.donut::after{content:"";position:absolute;inset:var(--donut-hole);background:var(--surface);border-radius:50%;
  box-shadow:inset 0 1px 2px rgba(17,24,39,.06);}
.donut .dc{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1;text-align:center;}
.donut .dc b{font-size:18px;font-weight:700;font-feature-settings:"tnum" 1;color:var(--ink);line-height:1;}
.donut .dc span{font-size:10.5px;color:var(--ink-4);margin-top:3px;}
.donut.sm{--donut-sz:104px;} .donut.sm .dc b{font-size:14px;}
.chart-legend{flex:1;min-width:140px;display:flex;flex-direction:column;gap:9px;}
.chart-legend .lg{display:flex;align-items:center;gap:9px;font-size:12.5px;}
.chart-legend .lg .sw{width:11px;height:11px;border-radius:3px;flex:none;}
.chart-legend .lg .lt{flex:1;color:var(--ink-2);font-weight:500;}
.chart-legend .lg .lv{font-weight:600;color:var(--ink);font-feature-settings:"tnum" 1;}
.chart-legend .lg .lv small{color:var(--ink-4);font-weight:500;margin-left:4px;}

/* --- dikey çubuk/sütun grafiği (trend) --- */
.chart-bars{display:flex;align-items:flex-end;gap:6px;height:var(--chart-h);padding-top:6px;}
.chart-bars .cb{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;gap:6px;height:100%;justify-content:flex-end;}
.chart-bars .cb .bv{width:100%;max-width:34px;border-radius:5px 5px 0 0;background:var(--c1);
  transition:height .55s cubic-bezier(.16,1,.3,1);min-height:3px;position:relative;}
.chart-bars .cb .bv:hover{filter:brightness(1.08);}
.chart-bars .cb .bl{font-size:10px;color:var(--ink-4);font-weight:500;white-space:nowrap;}
.chart-bars .cb .bt{font-size:10px;color:var(--ink-3);font-weight:600;font-feature-settings:"tnum" 1;}

/* --- yatay çubuk (top-N) --- */
.chart-hbars{display:flex;flex-direction:column;gap:11px;}
.chart-hbars .hb{display:flex;flex-direction:column;gap:5px;}
.chart-hbars .hb .hh{display:flex;align-items:center;justify-content:space-between;gap:10px;}
.chart-hbars .hb .hn{font-size:12.5px;font-weight:600;color:var(--ink);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.chart-hbars .hb .hv{font-size:12.5px;font-weight:600;color:var(--ink);font-feature-settings:"tnum" 1;white-space:nowrap;}
.chart-hbars .hb .htrack{height:9px;border-radius:var(--pill);background:var(--raise);overflow:hidden;}
.chart-hbars .hb .htrack > i{display:block;height:100%;border-radius:var(--pill);background:var(--c1);transition:width .55s cubic-bezier(.16,1,.3,1);}

/* --- sparkline (çizgi/alan, inline SVG) --- */
.spark{display:block;width:100%;height:46px;}
.spark .sl{fill:none;stroke:var(--accent);stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round;}
.spark .sa{fill:var(--accent-soft);opacity:.7;stroke:none;}
.spark.ok .sl{stroke:var(--ok);} .spark.ok .sa{fill:var(--ok-soft);}
.spark.info .sl{stroke:var(--info);} .spark.info .sa{fill:var(--info-soft);}

/* --- histogram (food-cost dağılımı) --- */
.chart-hist{display:flex;align-items:flex-end;gap:8px;height:138px;}
.chart-hist .hbar{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;height:100%;justify-content:flex-end;}
.chart-hist .hbar .hv{width:100%;border-radius:5px 5px 0 0;min-height:3px;transition:height .55s cubic-bezier(.16,1,.3,1);background:var(--ink-3);}
.chart-hist .hbar.ok .hv{background:var(--fc-ok);} .chart-hist .hbar.warn .hv{background:var(--fc-warn);} .chart-hist .hbar.danger .hv{background:var(--fc-danger);}
.chart-hist .hbar .hc{font-size:11px;font-weight:700;color:var(--ink);font-feature-settings:"tnum" 1;}
.chart-hist .hbar .hl{font-size:10px;color:var(--ink-4);font-weight:500;text-align:center;line-height:1.2;}

/* --- stok seviye çubuğu (stok/eşik, renk=durum) --- */
.lvl-track{height:8px;border-radius:var(--pill);background:var(--raise);overflow:hidden;}
.lvl-track > i{display:block;height:100%;border-radius:var(--pill);transition:width .5s cubic-bezier(.16,1,.3,1);background:var(--ok);}
.lvl-track.ok > i{background:var(--ok);} .lvl-track.warn > i{background:var(--accent);} .lvl-track.danger > i{background:var(--danger);}

/* --- sadakat piramidi (kademe) --- */
.pyramid{display:flex;flex-direction:column;align-items:center;gap:5px;}
.pyramid .pr{height:30px;border-radius:6px;display:flex;align-items:center;justify-content:center;gap:8px;color:#fff;font-size:12px;font-weight:600;min-width:90px;transition:width .5s cubic-bezier(.16,1,.3,1);}
.pyramid .pr .pc{font-feature-settings:"tnum" 1;opacity:.92;}

@media(max-width:520px){.chart-donut-wrap{justify-content:center;} .chart-legend{min-width:100%;}}

/* ============================================================
   CRM ORTAK BİLEŞENLER — tüm liste ekranları için paylaşılan CSS
   ============================================================ */

/* --- durum badge'leri (fatura/proje/sözleşme/görev) --- */
.badge-ok{display:inline-flex;align-items:center;font-size:11px;font-weight:600;padding:2px 8px;border-radius:var(--pill);background:var(--ok-soft);color:var(--ok-ink);}
.badge-warn{display:inline-flex;align-items:center;font-size:11px;font-weight:600;padding:2px 8px;border-radius:var(--pill);background:#fff7e6;color:#b45309;}
.badge-danger{display:inline-flex;align-items:center;font-size:11px;font-weight:600;padding:2px 8px;border-radius:var(--pill);background:#fff1f0;color:#c0392b;}
.badge-passive{display:inline-flex;align-items:center;font-size:11px;font-weight:600;padding:2px 8px;border-radius:var(--pill);background:var(--line);color:var(--ink-3);}
.badge-draft{display:inline-flex;align-items:center;font-size:11px;font-weight:600;padding:2px 8px;border-radius:var(--pill);background:#f0f0f0;color:var(--ink-3);}
.badge-default{display:inline-flex;align-items:center;font-size:11px;font-weight:600;padding:2px 8px;border-radius:var(--pill);background:#fef3c7;color:#92400e;}
.badge-info{display:inline-flex;align-items:center;font-size:11px;font-weight:600;padding:2px 8px;border-radius:var(--pill);background:var(--info-soft);color:var(--info-ink);}
.badge-count{display:inline-flex;align-items:center;font-size:11px;font-weight:600;padding:2px 8px;border-radius:var(--pill);background:var(--raise);color:var(--ink-3);border:1px solid var(--line);}

/* --- filtre segmenti (link tabanlı) --- */
.seg-btn{padding:6px 13px;border:1px solid transparent;background:transparent;border-radius:var(--pill);cursor:pointer;font-family:inherit;font-size:12px;font-weight:500;color:var(--ink-3);text-decoration:none;display:inline-flex;align-items:center;transition:.14s;}
.seg-btn:hover{color:var(--ink);}
.seg-btn.active{background:var(--surface);border-color:transparent;color:var(--ink);box-shadow:var(--sh);font-weight:600;}

/* --- arama kutusu sarmalayıcı (form içinde) --- */
.search-wrap{position:relative;min-width:220px;flex:1;max-width:340px;}
.search-wrap input{width:100%;padding:7px 12px 7px 34px;border:1px solid var(--line);border-radius:var(--r-md);font-size:13px;background:var(--surface);color:var(--ink);}
.search-wrap input:focus{outline:none;border-color:var(--accent);}
.search-wrap svg{position:absolute;left:9px;top:50%;transform:translateY(-50%);width:15px;height:15px;color:var(--ink-4);}

/* --- tbl-card: liste kartı (tenant ekranlarında pos-app .card yerine bu kullanılıyor) --- */
.tbl-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh);}
.tbl-card .card-head{display:flex;align-items:center;gap:10px;padding:14px 18px;border-bottom:1px solid var(--line);}
.tbl-card .card-head h2{flex:1;font-size:13.5px;font-weight:700;color:var(--ink);margin:0;display:flex;align-items:center;gap:7px;}
.tbl-card .card-head h2 svg{width:16px;height:16px;color:var(--ink-4);}
.tbl-card table{width:100%;border-collapse:collapse;}
.tbl-card th{font-size:11.5px;font-weight:600;color:var(--ink-3);text-transform:uppercase;letter-spacing:.04em;padding:10px 14px;border-bottom:1px solid var(--line);text-align:left;white-space:nowrap;}
.tbl-card td{font-size:13px;color:var(--ink);padding:10px 14px;border-bottom:1px solid var(--line-2);vertical-align:middle;}
.tbl-card tr:last-child td{border-bottom:none;}
.tbl-card tr:hover td{background:var(--raise);}
.tbl-card a.row-link{color:var(--ink);text-decoration:none;font-weight:600;}
.tbl-card a.row-link:hover{color:var(--accent-d);}

/* --- toolbar satırları (tbl-card içi) --- */
.tbl-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:12px 18px;border-bottom:1px solid var(--line);}
.tbl-seg{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:10px 18px;border-bottom:1px solid var(--line);}

/* --- ilerleme çubuğu --- */
.progress-bar{background:var(--line-2,#e2e8f0);border-radius:var(--pill);height:6px;min-width:60px;}
.progress-fill{background:var(--accent,#f59e0b);border-radius:var(--pill);height:6px;}

/* --- sayfalama satırı --- */
.pagination-row{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-top:1px solid var(--line-2);gap:10px;flex-wrap:wrap;}
.pagination-row .pag-info{font-size:12px;color:var(--ink-3);}
.pagination-row .pag-links{display:flex;gap:4px;}
.pagination-row .pag-links a,.pagination-row .pag-links span{display:inline-flex;align-items:center;justify-content:center;min-width:30px;height:30px;padding:0 6px;border-radius:var(--r-sm);font-size:12.5px;text-decoration:none;border:1px solid var(--line);color:var(--ink);background:var(--surface);}
.pagination-row .pag-links span.active{background:var(--accent);color:#fff;border-color:var(--accent);}
.pagination-row .pag-links a:hover{background:var(--raise);}

/* --- boş durum (liste ekranları) --- */
.empty-state{text-align:center;padding:48px 20px;color:var(--ink-4);}
.empty-state svg{width:36px;height:36px;opacity:.4;margin-bottom:10px;}
.empty-state p{font-size:13px;margin:0;}

/* --- görev öncelik renkleri --- */
.pri-1{color:var(--ink-4);font-size:12px;}
.pri-2{color:#3b82f6;font-size:12px;font-weight:600;}
.pri-3{color:var(--accent-d,#b45309);font-size:12px;font-weight:600;}
.pri-4{color:var(--danger,#dc2626);font-size:12px;font-weight:700;}

/* --- para hücresi --- */
.amount-cell{font-variant-numeric:tabular-nums;text-align:right;font-size:13px;}

/* --- ergonomi ekleri (additive): satıra tıkla → detay + boş durum CTA --- */
tbody tr.row-click{cursor:pointer;}
.empty-state .btn{margin-top:14px;}

/* Marka tema: amber aksan + #2b2a2a koyu gri sidebar — temel :root'tan gelir.
   (Eski "yeşil + slate" önizleme bloğu kaldırıldı; sidebar Akıllı Ev ile aynı koyu gri.) */

/* === FORM KONTROL KATMANI (global) === */
/* select.input için chevron (.select sınıfı zaten chevron içeriyor; bare select.input yakalar) */
select.input{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:34px;cursor:pointer;}
/* tarih/saat input stilleri — düşük spesifiklik, view-local kurallar ezebilir */
input[type="datetime-local"],input[type="date"],input[type="time"]{font-family:inherit;color-scheme:light;}
input[type="datetime-local"]::-webkit-calendar-picker-indicator,input[type="date"]::-webkit-calendar-picker-indicator{opacity:.5;cursor:pointer;}
input[type="datetime-local"]:hover::-webkit-calendar-picker-indicator,input[type="date"]:hover::-webkit-calendar-picker-indicator{opacity:.85;}
/* checkbox/radio global accent */
input[type="checkbox"],input[type="radio"]{accent-color:var(--accent);}
/* file input global stili */
input[type="file"]{font-family:inherit;font-size:12.5px;color:var(--ink-3);}
input[type="file"]::file-selector-button{font-family:inherit;font-size:12px;font-weight:600;padding:6px 12px;margin-right:10px;border:1px solid var(--line-2);border-radius:var(--r-sm,6px);background:var(--surface);color:var(--ink-2);cursor:pointer;transition:.14s;}
input[type="file"]::file-selector-button:hover{background:var(--raise);color:var(--ink);}
/* zorunlu alan yıldızı */
.req{color:var(--danger,#ef4444);}
/* === FORM KONTROL KATMANI SONU === */
