/* =====================================================================
   LOGDEF Teklif Paneli — Stil
   Palet: lacivert + altın + krem | Tip: Fraunces (display) + Inter (UI)
   ===================================================================== */
:root{
  --navy:#0a1430; --navy-2:#111a3a; --navy-3:#1b2654;
  --gold:#c9a961; --gold-2:#b58f3c; --gold-soft:#e8d6a8;
  --cream:#f5f2e9; --paper:#ffffff; --ink:#1b2238; --muted:#6f7689;
  --line:#e7e3d6; --line-2:#eef0f5;
  --ok:#1f9d6b; --ok-soft:#e4f4ec; --bad:#d24a45; --bad-soft:#fbe9e8;
  --display:'Fraunces',Georgia,'Times New Roman',serif;
  --ui:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --r:14px; --r-sm:9px; --shadow:0 1px 2px rgba(10,20,48,.06),0 10px 30px rgba(10,20,48,.08);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:var(--ui);color:var(--ink);background:var(--cream);
  -webkit-font-smoothing:antialiased;font-size:14px;line-height:1.45}
h1,h2,h3{margin:0;font-family:var(--display);font-weight:600;letter-spacing:-.01em}
input,select,textarea,button{font-family:inherit;font-size:14px;color:inherit}
button{cursor:pointer}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;
  border:1px solid transparent;border-radius:var(--r-sm);padding:.55rem .9rem;
  font-weight:600;background:transparent;transition:.16s ease;white-space:nowrap}
.btn-primary{background:var(--gold);color:#241a05;border-color:var(--gold-2)}
.btn-primary:hover{background:var(--gold-2);color:#fff}
.btn-soft{background:#fff;border-color:var(--line);color:var(--ink)}
.btn-soft:hover{border-color:var(--gold);color:var(--gold-2)}
.btn-ghost{color:#cfd6ea;padding:.5rem .7rem}
.btn-ghost:hover{background:rgba(255,255,255,.08);color:#fff}
.btn-link{background:none;border:none;color:var(--gold-2);font-weight:600;padding:.3rem .2rem;text-decoration:underline;text-underline-offset:3px}
.btn-block{width:100%}
.btn-logout{color:#9aa3bd}
.btn-install{background:var(--gold);color:#241a05;border-color:var(--gold-2);font-size:13px;padding:.5rem .8rem}
.btn-install:hover{background:var(--gold-2);color:#fff}
.btn[disabled]{opacity:.5;pointer-events:none}

/* ---------- Login ---------- */
.login-wrap{min-height:100vh;display:grid;place-items:center;
  background:radial-gradient(120% 120% at 50% 0%, #142046 0%, var(--navy) 55%, #060c1f 100%);padding:24px}
.login-card{width:min(380px,92vw);background:var(--paper);border-radius:18px;padding:34px 30px;
  box-shadow:0 30px 80px rgba(0,0,0,.45);text-align:center}
.login-brand{display:flex;flex-direction:column;gap:2px;margin-bottom:6px}
.brand-mark{font-family:var(--display);font-weight:700;letter-spacing:.04em;color:var(--navy)}
.login-brand .brand-mark{font-size:30px}
.brand-sub{color:var(--gold-2);font-weight:600;letter-spacing:.18em;text-transform:uppercase;font-size:11px}
.login-hint{color:var(--muted);margin:.4rem 0 1.2rem}
.login-card input{width:100%;padding:.8rem .9rem;border:1px solid var(--line);border-radius:10px;margin-bottom:.9rem}
.login-card input:focus{outline:none;border-color:var(--gold)}
.login-error{color:var(--bad);font-weight:600;min-height:1.2em;margin-top:.6rem}

/* ---------- Topbar ---------- */
.topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:18px;
  background:linear-gradient(180deg,#0c1838,#0a1430);color:#eef1f9;
  padding:.7rem 1.1rem;border-bottom:1px solid rgba(201,169,97,.25)}
.topbar-left{display:flex;align-items:center;gap:12px}
.topbar .brand-mark{color:#fff;font-size:20px}
.topbar-divider{width:1px;height:22px;background:rgba(255,255,255,.18)}
.topbar-title{color:var(--gold-soft);font-weight:600;letter-spacing:.02em}
.ver-tag{color:#7c89ad;font-size:11px;font-weight:600;margin-left:2px}
.topbar-meta{display:flex;align-items:center;gap:10px;margin-left:auto}
.chip{background:rgba(201,169,97,.16);color:var(--gold-soft);border:1px solid rgba(201,169,97,.35);
  padding:.25rem .7rem;border-radius:999px;font-weight:600;font-size:12.5px;letter-spacing:.02em}
.save-state{font-size:12px;color:#9fb0d6;min-width:70px}
.save-state.dirty{color:var(--gold-soft)}
.save-state.saved{color:#7fd6a8}
.topbar-actions{display:flex;align-items:center;gap:4px}

/* ---------- Workspace ---------- */
.workspace{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:20px;
  max-width:1320px;margin:0 auto;padding:22px}
.editor{display:flex;flex-direction:column;gap:18px;min-width:0}

/* ---------- Cards & fields ---------- */
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);
  box-shadow:var(--shadow);padding:18px 18px 20px}
.card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}
.card-head h2{font-size:17px;color:var(--navy)}
.card-head h2::before{content:"";display:inline-block;width:8px;height:8px;border-radius:2px;
  background:var(--gold);margin-right:9px;transform:translateY(-2px)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.field{display:flex;flex-direction:column;gap:5px;min-width:0}
.field>span{font-size:11.5px;font-weight:600;color:var(--muted);letter-spacing:.02em;text-transform:uppercase}
.field input,.field select,.field textarea{width:100%;padding:.55rem .65rem;border:1px solid var(--line);
  border-radius:8px;background:#fff;transition:.14s}
.field textarea{resize:vertical;line-height:1.5}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(201,169,97,.15)}
.field-wide{grid-column:1/-1}
.inline{display:flex;gap:6px}
.inline input{flex:1}.inline select{width:84px}
.mt{margin-top:12px}
.toggle{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--muted);font-weight:600;cursor:pointer}
.toggle input{accent-color:var(--gold-2)}

/* ---------- Items table ---------- */
.table-scroll{overflow-x:auto;margin:0 -4px}
table.items{width:100%;border-collapse:collapse;min-width:760px}
.items th{font-size:11px;text-transform:uppercase;letter-spacing:.03em;color:var(--muted);
  text-align:left;font-weight:700;padding:6px 8px;border-bottom:2px solid var(--line)}
.items td{padding:4px 6px;border-bottom:1px solid var(--line-2);vertical-align:middle}
.items tbody tr:hover{background:#fcfbf7}
.items input,.items textarea{width:100%;border:1px solid transparent;background:transparent;
  padding:.45rem .5rem;border-radius:7px}
.items input:focus,.items textarea:focus{outline:none;border-color:var(--gold);background:#fff;
  box-shadow:0 0 0 3px rgba(201,169,97,.12)}
.items textarea{resize:vertical;min-height:34px;line-height:1.4;font-size:13px}
.items .num input{text-align:right;font-variant-numeric:tabular-nums}
.c-no{width:30px;color:var(--muted);text-align:center;font-variant-numeric:tabular-nums}
.c-urun{width:150px}.c-adet{width:70px}.c-birim{width:84px}
.c-maliyet,.c-fiyat{width:104px}.c-karoran{width:74px}.c-tutar{width:118px}.c-kar{width:104px}.c-sil{width:34px}
.cell-tutar{text-align:right;font-weight:600;font-variant-numeric:tabular-nums;white-space:nowrap}
.cell-kar{text-align:right;font-weight:600;font-variant-numeric:tabular-nums;white-space:nowrap}
.cell-kar.pos{color:var(--ok)}.cell-kar.neg{color:var(--bad)}
.row-del{border:none;background:none;color:#c7ccd8;font-size:16px;line-height:1;padding:4px}
.row-del:hover{color:var(--bad)}
#btnAddRow{margin-top:12px}
/* toplu kâr oranı çubuğu */
.items-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  background:linear-gradient(180deg,#fbf9f2,#f7f3e8);border:1px solid var(--line);
  border-radius:10px;padding:9px 12px;margin-bottom:12px}
.items-toolbar .tb-label{font-weight:700;color:var(--navy);font-size:13px}
.items-toolbar .tb-input{position:relative}
.items-toolbar .tb-input input{width:84px;padding:.45rem 1.5rem .45rem .6rem;border:1px solid var(--line);
  border-radius:8px;background:#fff;font-variant-numeric:tabular-nums}
.items-toolbar .tb-input input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,169,97,.15)}
.items-toolbar .tb-input i{position:absolute;right:9px;top:50%;transform:translateY(-50%);color:var(--muted);font-style:normal;font-weight:600}
.items-toolbar .tb-hint{color:var(--muted);font-size:11.5px;flex:1;min-width:160px}
.btn-sm{padding:.45rem .75rem;font-size:13px}
/* maliyet gizliyse sütunları gizle */
body.hide-cost .cost-col{display:none}

/* ---------- Rail (özet + kâr) ---------- */
.rail{position:sticky;top:74px;align-self:start;display:flex;flex-direction:column;gap:16px}
.summary{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);
  box-shadow:var(--shadow);padding:16px 18px}
.sum-row{display:flex;justify-content:space-between;align-items:baseline;padding:7px 0;font-size:14px}
.sum-row b{font-variant-numeric:tabular-nums;font-weight:600}
.sum-muted{color:var(--muted)}
.sum-total{border-top:2px solid var(--line);margin-top:6px;padding-top:12px}
.sum-total span{font-weight:600;color:var(--navy)}
.sum-total b{font-family:var(--display);font-size:23px;color:var(--navy)}

/* Signature: kâr/zarar panosu (koyu, altın) */
.profit{background:linear-gradient(165deg,#101c40,#0a1430);color:#e9edf8;border-radius:var(--r);
  padding:16px 18px 18px;box-shadow:0 14px 34px rgba(10,20,48,.28);border:1px solid rgba(201,169,97,.22)}
.profit-head{display:flex;align-items:center;justify-content:space-between;
  font-weight:600;color:var(--gold-soft);letter-spacing:.02em;margin-bottom:12px}
.profit-badge{font-size:12px;font-weight:700;padding:.2rem .55rem;border-radius:999px;
  background:rgba(255,255,255,.1);color:#cdd6ee}
.profit-badge.pos{background:rgba(31,157,107,.22);color:#7fe3b4}
.profit-badge.neg{background:rgba(210,74,69,.22);color:#ff9a96}
.profit-rows{display:flex;flex-direction:column;gap:2px}
.p-row{display:flex;justify-content:space-between;padding:6px 0;color:#c2cbe4;font-size:13.5px}
.p-row b{color:#fff;font-variant-numeric:tabular-nums;font-weight:600}
.p-strong{border-top:1px solid rgba(255,255,255,.12);margin-top:4px;padding-top:10px}
.p-strong span{color:var(--gold-soft);font-weight:600}
.p-strong b{font-family:var(--display);font-size:20px;color:var(--gold-soft)}
.margin-meter{margin-top:14px}
.margin-bar{height:9px;border-radius:999px;background:rgba(255,255,255,.12);overflow:hidden}
.margin-bar i{display:block;height:100%;width:0;border-radius:999px;
  background:linear-gradient(90deg,var(--gold),var(--gold-soft));transition:width .35s ease}
.margin-bar.neg i{background:linear-gradient(90deg,#d24a45,#ff8b86)}
.margin-label{display:flex;justify-content:space-between;align-items:baseline;margin-top:7px}
.margin-label span{color:#aab4d2;font-size:12.5px}
.margin-label b{font-family:var(--display);font-size:18px;color:#fff}
.profit-note{color:#8b95b4;font-size:11px;margin:12px 0 0;line-height:1.4}

/* ---------- Export ---------- */
.export{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);
  box-shadow:var(--shadow);padding:16px}
.export-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:10px}

/* ---------- Modal ---------- */
.modal{position:fixed;inset:0;z-index:60;display:grid;place-items:center;padding:20px;
  background:rgba(8,14,32,.55);backdrop-filter:blur(3px)}
.modal[hidden]{display:none}
.modal-card{width:min(560px,96vw);max-height:88vh;display:flex;flex-direction:column;
  background:var(--paper);border-radius:16px;box-shadow:0 30px 90px rgba(0,0,0,.4);overflow:hidden}
.modal-lg{width:min(820px,96vw)}
.modal-head{display:flex;align-items:center;justify-content:space-between;
  padding:16px 20px;border-bottom:1px solid var(--line);background:var(--cream)}
.modal-head h3{color:var(--navy);font-size:18px}
.modal-x{border:none;background:none;font-size:18px;color:var(--muted);padding:4px 8px}
.modal-x:hover{color:var(--bad)}
.modal-body{padding:20px;overflow:auto}
.modal-foot{display:flex;align-items:center;gap:12px;margin-top:18px;
  padding-top:16px;border-top:1px solid var(--line)}
.search{width:100%;padding:.7rem .9rem;border:1px solid var(--line);border-radius:10px;margin-bottom:14px}
.search:focus{outline:none;border-color:var(--gold)}

/* quote list */
.quote-list{display:flex;flex-direction:column;gap:8px}
.q-item{display:flex;align-items:center;gap:12px;padding:11px 13px;border:1px solid var(--line);
  border-radius:11px;background:#fff;cursor:pointer;transition:.14s}
.q-item:hover{border-color:var(--gold);box-shadow:0 4px 14px rgba(201,169,97,.14)}
.q-main{flex:1;min-width:0}
.q-title{font-weight:600;color:var(--navy);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.q-sub{font-size:12px;color:var(--muted);margin-top:2px}
.q-amt{font-weight:700;font-variant-numeric:tabular-nums;color:var(--navy);white-space:nowrap}
.q-status{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;
  padding:.15rem .5rem;border-radius:6px;background:#eef0f5;color:var(--muted)}
.q-status.gonderildi{background:#fff4dc;color:#9a6b00}
.q-status.kabul{background:var(--ok-soft);color:#157a51}
.q-status.red{background:var(--bad-soft);color:#b23a35}
.q-actions{display:flex;gap:4px}
.q-mini{border:1px solid var(--line);background:#fff;border-radius:7px;padding:5px 8px;font-size:12px;color:var(--muted)}
.q-mini:hover{border-color:var(--gold);color:var(--gold-2)}
.q-empty{text-align:center;color:var(--muted);padding:30px 0}

/* settings logo */
.logo-area{display:flex;gap:18px;align-items:center}
.logo-preview{width:160px;height:90px;border:1px dashed var(--line);border-radius:10px;
  display:grid;place-items:center;background:var(--cream);overflow:hidden}
.logo-preview img{max-width:100%;max-height:100%;object-fit:contain}
.logo-preview span{color:var(--muted);font-size:12px}
.logo-actions{display:flex;flex-direction:column;gap:8px;align-items:flex-start}
.muted{color:var(--muted);font-size:12px}

/* toast */
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(20px);
  background:var(--navy);color:#fff;padding:.7rem 1.2rem;border-radius:10px;font-weight:600;
  box-shadow:0 12px 30px rgba(0,0,0,.3);opacity:0;transition:.25s;z-index:90}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast[hidden]{display:none}
.toast.bad{background:var(--bad)}.toast.ok{background:var(--ok)}

/* =====================================================================
   BELGE (ekranda gizli, yazdırma/PDF hedefi)
   ===================================================================== */
#belgeWrap{position:absolute;left:-99999px;top:0}
#belge{width:794px;background:#fff;color:#111;font-family:var(--ui);font-size:12px;line-height:1.45}
.doc{padding:34px 38px 28px;--acc:#0a1430;--acc2:#c9a961}
.doc-top{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;
  border-bottom:3px solid var(--acc);padding-bottom:14px}
.doc-logo{max-height:74px;max-width:230px;object-fit:contain}
.doc-logo-text{font-family:var(--display);font-weight:700;font-size:26px;color:var(--acc);letter-spacing:.02em}
.doc-co{text-align:right;max-width:330px}
.doc-co .co-name{font-weight:700;font-size:13.5px;color:var(--acc)}
.doc-co .co-line{color:#444;font-size:11px;margin-top:2px}
.doc-title{text-align:center;font-family:var(--display);font-weight:600;font-size:18px;
  color:var(--acc);margin:14px 0 12px;letter-spacing:.01em}
.doc-info{display:grid;grid-template-columns:1fr 1fr;gap:2px 26px;
  border:1px solid #e3e3e3;border-radius:8px;padding:10px 14px;margin-bottom:14px;background:#fafafa}
.doc-info .row{display:flex;gap:8px;font-size:11.5px;padding:2px 0}
.doc-info .lbl{color:#777;min-width:118px;font-weight:600}
.doc-info .val{color:#111;font-weight:600}
.doc-note{font-size:11.5px;color:#333;margin:0 0 12px;line-height:1.5}

table.doc-items{width:100%;border-collapse:collapse;font-size:11px;table-layout:fixed}
.doc-items th,.doc-items td{word-wrap:break-word;overflow-wrap:anywhere}
.doc-items th{background:var(--acc);color:#fff;text-align:left;padding:7px 8px;font-weight:600;
  border:1px solid var(--acc);white-space:nowrap}
.doc-items th.r,.doc-items td.r{text-align:right}
.doc-items th.c,.doc-items td.c{text-align:center}
.doc-items td{border:1px solid #ddd;padding:6px 8px;vertical-align:top}
.doc-items tbody tr:nth-child(even){background:#f7f7f4}
.doc-items .pname{font-weight:600;color:#111}
.doc-items .pdesc{color:#555;font-size:10.5px}
.doc-tot{margin-top:12px;display:flex;justify-content:flex-end}
.doc-tot table{border-collapse:collapse;min-width:280px;font-size:12px}
.doc-tot td{padding:6px 12px}
.doc-tot tr.t-sub td{border-top:1px solid #ddd}
.doc-tot tr.t-grand td{background:var(--acc);color:#fff;font-weight:700;font-size:13.5px}
.doc-tot td.r{text-align:right;font-variant-numeric:tabular-nums}
.doc-foot{margin-top:18px;border-top:1px solid #e3e3e3;padding-top:12px;
  display:flex;justify-content:space-between;gap:20px;font-size:10.5px;color:#444}
.doc-foot .fcol{max-width:48%}
.doc-foot .fcol b{color:var(--acc)}
.doc-terms{margin-top:16px;font-size:9.6px;color:#444;line-height:1.5;white-space:pre-wrap;
  border-top:2px solid var(--acc2);padding-top:10px}
.doc-bankline{margin-top:8px;font-size:10.5px;color:#333}

/* =====================================================================
   PRINT
   ===================================================================== */
@media print{
  body{background:#fff}
  .topbar,.workspace,.modal,.toast{display:none !important}
  #belgeWrap{position:static;left:0;width:auto;height:auto;overflow:visible}
  #belge{width:auto}
  .doc{padding:0}
  @page{size:A4;margin:14mm 12mm}
  .doc-terms,.doc-foot{page-break-inside:avoid}
  .doc-items tr{page-break-inside:avoid}
}

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media (max-width:1000px){
  .workspace{grid-template-columns:1fr}
  .rail{position:static;flex-direction:column}
  .grid-4{grid-template-columns:1fr 1fr}
}
@media (max-width:560px){
  .workspace{padding:14px;gap:14px}
  .grid-2,.grid-4{grid-template-columns:1fr}
  .topbar{flex-wrap:wrap;gap:8px}
  .topbar-meta{order:3;width:100%;margin-left:0}
  .topbar-actions .btn span{display:inline}
  .export-grid{grid-template-columns:1fr 1fr}
  .logo-area{flex-direction:column;align-items:flex-start}
}
