/* Hugin S1 · Cloud Filo — "mali cihaz" estetiği: termal fiş kâğıdı + mali mühür altını + LED durum */
:root{
  --paper:#F5F4EF;
  --paper-2:#EFEEE7;
  --card:#FFFFFF;
  --ink:#15202E;
  --ink-2:#1B2938;
  --ink-soft:#243244;
  --muted:#63717F;
  --muted-2:#8A97A3;
  --line:#E6E5DD;
  --line-strong:#D2D1C7;
  --signal:#1C7A54;      /* onay / çevrimiçi */
  --signal-dark:#12583C;
  --alert:#B23A28;       /* iptal / hata / çevrimdışı */
  --alert-dark:#8C2C1E;
  --sky:#1F5FA8;         /* cloud modu */
  --amber:#B9770F;       /* bekleme / bilinmiyor */
  --gold:#B8912E;        /* mali mühür imzası */
  --gold-soft:#E7D08A;
  --radius:12px;
  --mono:"SF Mono",ui-monospace,"JetBrains Mono","Cascadia Code",Menlo,Consolas,monospace;
  --sans:system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
  --shadow:0 1px 2px rgba(20,32,46,.04),0 10px 26px -14px rgba(20,32,46,.16);
  --shadow-sm:0 1px 2px rgba(20,32,46,.05);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{background:var(--paper);color:var(--ink);font-family:var(--sans);font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased}
.num{font-family:var(--mono);font-variant-numeric:tabular-nums;letter-spacing:-.01em}
h2{letter-spacing:-.01em}

/* ================= Üst blok (yapışkan) ================= */
.appbar{position:sticky;top:0;z-index:30;box-shadow:var(--shadow-sm)}

header.topbar{background:linear-gradient(180deg,var(--ink-2),var(--ink));color:#EEF1F0;border-bottom:2px solid var(--gold)}
.topbar-inner{max-width:1200px;margin:0 auto;padding:12px 22px;display:flex;align-items:center;gap:14px 18px;flex-wrap:wrap}

.brand{display:flex;align-items:center;gap:11px;min-width:0;text-decoration:none;color:inherit}
.brand .seal{flex:none;width:34px;height:34px;border-radius:8px;display:grid;place-items:center;
  background:radial-gradient(120% 120% at 30% 25%,#E7CE86,var(--gold) 55%,#8E6E1E);
  color:#3A2E08;font-family:var(--mono);font-weight:800;font-size:18px;
  box-shadow:inset 0 1px 1px rgba(255,255,255,.5),0 2px 6px rgba(0,0,0,.3)}
.brand-txt{display:flex;flex-direction:column;line-height:1.05}
.brand .mark{font-family:var(--mono);font-size:15px;font-weight:800;letter-spacing:.06em}
.brand .sub{font-size:11px;color:#9FB0AE;letter-spacing:.14em;text-transform:uppercase;margin-top:2px}

/* depolama rozeti */
.store-badge{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:600;
  padding:6px 11px;border-radius:20px;border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.06);color:#D7DEDC;white-space:nowrap}
.store-badge .sb-dot{width:8px;height:8px;border-radius:50%;background:var(--muted-2);flex:none}
.store-badge.mysql .sb-dot{background:#57D98A;box-shadow:0 0 0 3px rgba(87,217,138,.18)}
.store-badge.file  .sb-dot{background:var(--gold-soft)}
.store-badge.warn  .sb-dot{background:#E88C7D}

/* filo readout (cihaz paneli görünümü) */
.fleet{margin-left:auto;display:flex;align-items:center;gap:14px}
.readout{display:flex;align-items:stretch;border:1px solid rgba(255,255,255,.16);border-radius:10px;overflow:hidden;background:rgba(0,0,0,.18)}
.readout .stat{display:flex;flex-direction:column;align-items:center;justify-content:center;line-height:1;padding:7px 14px;min-width:64px}
.readout .stat + .stat{border-left:1px solid rgba(255,255,255,.12)}
.readout .stat .n{font-family:var(--mono);font-size:19px;font-weight:700}
.readout .stat .l{font-size:9.5px;color:#8FA09E;letter-spacing:.12em;text-transform:uppercase;margin-top:3px}
.readout .stat.on .n{color:#57D98A}
.readout .stat.off .n{color:#E88C7D}

.btn-refresh{appearance:none;border:1px solid rgba(255,255,255,.26);background:rgba(255,255,255,.07);color:#EEF1F0;font-family:var(--sans);font-weight:700;font-size:13px;padding:10px 15px;border-radius:10px;cursor:pointer;display:inline-flex;align-items:center;gap:8px}
.btn-refresh:hover{background:rgba(255,255,255,.14)}
.btn-refresh svg{width:15px;height:15px}
.btn-refresh.spin svg{animation:spin .8s linear infinite}

/* ================= Sekmeler (açık zemin, kırpılmaz) ================= */
nav.tabs{background:var(--card);border-bottom:1px solid var(--line)}
.tabs-inner{max-width:1200px;margin:0 auto;padding:0 22px;display:flex;gap:2px;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}
.tabs-inner::-webkit-scrollbar{display:none}
.tabs-inner .tab{appearance:none;border:0;background:transparent;color:var(--muted);font-family:var(--sans);font-size:15px;font-weight:600;text-decoration:none;padding:15px 16px 13px;cursor:pointer;white-space:nowrap;border-bottom:3px solid transparent;display:inline-flex;align-items:center;gap:8px;transition:color .15s,border-color .15s}
.tabs-inner .tab:hover{color:var(--ink-soft)}
.tabs-inner .tab[aria-current="page"]{color:var(--ink);border-bottom-color:var(--gold)}
.tabs-inner .count{font-family:var(--mono);font-size:11px;background:var(--paper-2);color:var(--muted);border:1px solid var(--line-strong);border-radius:20px;padding:1px 8px;min-width:22px;text-align:center}
.tabs-inner .tab[aria-current="page"] .count{background:#EAF3EE;color:var(--signal-dark);border-color:#BFE0CE}

main{max-width:1200px;margin:0 auto;padding:24px 22px 96px}
.panel{display:none}
.panel.active{display:block;animation:rise .22s ease}
@keyframes rise{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* ================= Kart / form ================= */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:22px;margin-bottom:18px;box-shadow:var(--shadow)}
.card h2{margin:0 0 5px;font-size:18px}
.card .hint{margin:0 0 16px;color:var(--muted);font-size:13px;line-height:1.55}
.section-head{display:flex;align-items:flex-start;gap:14px;margin-bottom:18px}
.section-head h2{margin:0;font-size:22px}
.section-head .lead{margin:6px 0 0;color:var(--muted);font-size:14px;max-width:56ch}
.section-head .spacer{flex:1}
.grid{display:grid;gap:14px}
.grid.two{grid-template-columns:1fr 1fr}
.grid.three{grid-template-columns:1fr 1fr 1fr}
@media(max-width:720px){.grid.two,.grid.three{grid-template-columns:1fr}}
label.f{display:flex;flex-direction:column;gap:6px;font-size:13px;font-weight:600;color:var(--ink)}
label.f.end{justify-content:flex-end}
label.f .req{color:var(--alert)}
label.f small{font-weight:500;color:var(--muted)}
input,select,textarea{font-family:var(--sans);font-size:15px;color:var(--ink);padding:11px 12px;border:1px solid var(--line-strong);border-radius:9px;background:#FCFCFA;min-height:44px;width:100%}
textarea{min-height:auto;line-height:1.5}
input.num,input[inputmode="decimal"]{font-family:var(--mono)}
input:focus,select:focus,textarea:focus{outline:2px solid var(--signal);outline-offset:1px;border-color:var(--signal)}
.seg{display:flex;border:1px solid var(--line-strong);border-radius:9px;overflow:hidden;width:max-content;max-width:100%}
.seg button{appearance:none;border:0;background:#FCFCFA;color:var(--muted);padding:11px 16px;font-weight:600;cursor:pointer;min-height:44px}
.seg button[aria-pressed="true"]{background:var(--ink);color:#fff}

/* ================= Butonlar ================= */
.btn{appearance:none;border:1px solid var(--line-strong);background:#fff;color:var(--ink);font-family:var(--sans);font-weight:700;font-size:15px;padding:12px 18px;border-radius:10px;cursor:pointer;min-height:46px;transition:transform .05s,background .15s,box-shadow .15s}
.btn:hover{box-shadow:var(--shadow-sm)}
.btn:active{transform:translateY(1px)}
.btn.primary{background:var(--signal);border-color:var(--signal-dark);color:#fff}
.btn.primary:hover{background:var(--signal-dark)}
.btn.danger{background:var(--alert);border-color:var(--alert-dark);color:#fff}
.btn.danger:hover{background:var(--alert-dark)}
.btn.ghost{background:transparent}
.btn.ghost:hover{background:var(--paper-2)}
.btn.sm{font-size:13px;padding:8px 12px;min-height:38px}
.btn.lg{font-size:17px;padding:16px 22px;min-height:56px;width:100%}
.btn:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}
.row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}

/* ================= Cihaz filosu ================= */
.devgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:16px}
.devcard{position:relative;background:var(--card);border:1px solid var(--line);border-left:4px solid var(--line-strong);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);transition:border-color .15s,box-shadow .15s,transform .1s}
.devcard:hover{box-shadow:0 2px 4px rgba(20,32,46,.05),0 14px 30px -16px rgba(20,32,46,.22)}
.devcard.online{border-left-color:var(--signal)}
.devcard.offline{border-left-color:var(--alert)}
.devcard.unknown{border-left-color:var(--amber)}
.devcard.active{border-color:var(--signal);box-shadow:0 0 0 2px rgba(28,122,84,.25),var(--shadow)}
.devcard .dc-top{display:flex;align-items:flex-start;gap:10px;margin-bottom:12px}
.devcard .dc-name{font-size:17px;font-weight:700;line-height:1.2;padding-right:56px}
.devcard .dc-serial{font-family:var(--mono);font-size:12px;color:var(--muted);margin-top:3px}
.devcard .dc-state{margin-left:auto;display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--muted);white-space:nowrap}
.badge-mode{display:inline-block;font-size:10.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:2px 8px;border-radius:20px;border:1px solid;margin-top:8px}
.badge-mode.cloud{color:var(--sky);border-color:#BBD3EC;background:#EEF4FB}
.badge-mode.lan{color:var(--ink-soft);border-color:var(--line-strong);background:#F2F2ED}
.dc-chips{display:flex;flex-wrap:wrap;gap:6px;margin:12px 0 14px}
.chip{font-size:11.5px;padding:3px 9px;border-radius:20px;border:1px solid var(--line-strong);background:#fff;color:var(--muted);display:inline-flex;align-items:center;gap:5px}
.chip.good{color:var(--signal-dark);border-color:#BFE0CE;background:#EFF7F2}
.chip.bad{color:var(--alert-dark);border-color:#EBC6BF;background:#FBF1EF}
.chip.warn{color:var(--amber);border-color:#EAD6AE;background:#FBF4E6}
.dc-actions{display:flex;flex-wrap:wrap;gap:8px}
.dc-actions .btn{flex:1 1 auto}
.link-x{border:0;background:transparent;color:var(--alert);font-weight:700;cursor:pointer;font-size:13px;padding:8px 6px;border-radius:8px}
.link-x:hover{background:#FBF1EF}
.pick-active{position:absolute;top:16px;right:16px}

.dot{width:9px;height:9px;border-radius:50%;background:#5A6B72;display:inline-block;flex:none}
.dot.on{background:#38C172;animation:ping 2s infinite}
.dot.off{background:var(--alert)}
.dot.unknown{background:var(--amber)}
@keyframes ping{0%{box-shadow:0 0 0 0 rgba(56,193,114,.55)}70%{box-shadow:0 0 0 7px rgba(56,193,114,0)}100%{box-shadow:0 0 0 0 rgba(56,193,114,0)}}

/* boş durum */
.empty-state{text-align:center;padding:52px 24px;color:var(--muted);border:1.5px dashed var(--line-strong);border-radius:var(--radius);background:#FCFCFA}
.empty-state .es-seal{width:52px;height:52px;margin:0 auto 14px;border-radius:12px;display:grid;place-items:center;
  background:radial-gradient(120% 120% at 30% 25%,#F0E2B4,var(--gold-soft) 60%,#CBB055);
  color:#5C4A12;font-family:var(--mono);font-weight:800;font-size:24px}
.empty-state h3{margin:0 0 8px;color:var(--ink);font-size:19px}
.empty-state p{margin:0 auto 20px;max-width:46ch;line-height:1.6}

/* aktif cihaz bandı */
.active-banner{display:flex;align-items:center;gap:12px;background:linear-gradient(180deg,var(--ink-2),var(--ink));color:#EEF1F0;border-radius:var(--radius);padding:13px 18px;margin-bottom:18px;flex-wrap:wrap;border-left:4px solid var(--gold)}
.active-banner .lbl{font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:#8FA09E}
.active-banner .name{font-weight:700;font-size:16px}
.active-banner .ser{font-family:var(--mono);font-size:13px;color:#AFC0BE}
.active-banner select{max-width:260px;min-height:40px;background:#243244;color:#fff;border-color:#33465C}
.active-banner .spacer{flex:1}
.no-active{border:1.5px dashed var(--line-strong);border-radius:var(--radius);padding:22px;text-align:center;color:var(--muted);background:#FCFCFA;margin-bottom:18px}

/* depolama kartı (Genel Ayarlar) */
.storage-card{display:flex;gap:16px;align-items:flex-start}
.storage-card .sc-icon{flex:none;width:46px;height:46px;border-radius:11px;display:grid;place-items:center;font-family:var(--mono);font-weight:800;font-size:14px;letter-spacing:.02em;color:#fff;background:var(--muted)}
.storage-card.ok  .sc-icon{background:var(--signal)}
.storage-card.file .sc-icon{background:var(--amber)}
.storage-card.warn .sc-icon{background:var(--alert)}
.storage-card .sc-body{min-width:0}
.storage-card h2{margin:0 0 4px}
.storage-card .sc-detail{margin:0 0 6px;font-family:var(--mono);font-size:13px;color:var(--ink-soft)}
.storage-card .hint{margin:0}

/* ================= Sepet ================= */
.cart{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.cart .head,.cart .line{display:grid;grid-template-columns:1fr 70px 110px 60px 40px;gap:8px;align-items:center;padding:11px 14px}
.cart .head{background:var(--paper-2);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:700}
.cart .line{border-top:1px solid var(--line)}
.cart .line .r{text-align:right}
.cart .line button.x{border:0;background:transparent;color:var(--alert);font-size:20px;cursor:pointer;line-height:1}
.cart .empty{padding:28px;text-align:center;color:var(--muted)}
.totals{display:flex;justify-content:flex-end;align-items:baseline;gap:22px;padding:14px 16px;border-top:2px solid var(--ink);background:#FBFBF8}
.totals .k{color:var(--muted);font-size:13px;letter-spacing:.06em;text-transform:uppercase}
.totals .grand{font-family:var(--mono);font-size:26px;font-weight:700}

/* ================= Sonuç / bildirim ================= */
.result{border-radius:var(--radius);padding:16px 18px;margin-top:16px;border:1px solid var(--line);display:none}
.result.show{display:block}
.result.ok{border-color:var(--signal);background:#F0F8F4}
.result.err{border-color:var(--alert);background:#FBF1EF}
.result h3{margin:0 0 6px;font-size:15px}
.result pre{margin:8px 0 0;font-family:var(--mono);font-size:12px;white-space:pre-wrap;word-break:break-word;color:#31404C;max-height:280px;overflow:auto}
.badge{display:inline-block;font-family:var(--mono);font-size:12px;padding:3px 8px;border-radius:6px;background:var(--paper-2);color:var(--ink)}
.badge.ok{background:#DCF0E6;color:var(--signal-dark)}
.badge.err{background:#F6DDD8;color:var(--alert-dark)}

.kv{display:grid;grid-template-columns:180px 1fr;gap:7px 16px;font-size:14px;margin-top:10px}
.kv .k{color:var(--muted)}
.kv .v{font-family:var(--mono)}
.dept-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.dept-chip{border:1px solid var(--line-strong);border-radius:20px;padding:6px 12px;font-size:13px;background:#fff}
.dept-chip b{font-family:var(--mono)}

/* ================= Modal ================= */
.modal-back{position:fixed;inset:0;background:rgba(15,24,38,.55);backdrop-filter:blur(2px);display:none;align-items:flex-start;justify-content:center;z-index:60;padding:40px 16px;overflow:auto}
.modal-back.show{display:flex}
.modal{background:var(--card);border-radius:16px;max-width:640px;width:100%;box-shadow:0 24px 60px -20px rgba(0,0,0,.45);animation:rise .2s ease}
.modal .m-head{display:flex;align-items:center;gap:12px;padding:18px 22px;border-bottom:1px solid var(--line)}
.modal .m-head h2{margin:0;font-size:19px}
.modal .m-head .x{margin-left:auto;border:0;background:transparent;font-size:26px;color:var(--muted);cursor:pointer;line-height:1;padding:0 4px;border-radius:8px}
.modal .m-head .x:hover{color:var(--ink)}
.modal .m-body{padding:22px}
.modal .m-foot{display:flex;gap:10px;justify-content:flex-end;padding:16px 22px;border-top:1px solid var(--line);background:#FBFBF8;border-radius:0 0 16px 16px}
.inherit-note{font-size:12px;color:var(--muted);background:var(--paper-2);border:1px solid var(--line);border-radius:8px;padding:9px 12px;margin-top:4px;line-height:1.55}
details.adv{margin-top:14px}
details.adv summary{cursor:pointer;font-weight:600;font-size:14px;color:var(--ink-soft);padding:8px 0}

.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--ink);color:#fff;padding:12px 20px;border-radius:10px;font-weight:600;opacity:0;pointer-events:none;transition:.25s;z-index:70;box-shadow:0 12px 30px -10px rgba(0,0,0,.5)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.err{background:var(--alert)}

.spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;vertical-align:-3px;margin-right:8px}
@keyframes spin{to{transform:rotate(360deg)}}

@media(max-width:640px){
  .readout .stat{min-width:52px;padding:6px 10px}
  .readout .stat .n{font-size:17px}
  .btn-refresh span{display:none}
  .section-head{flex-wrap:wrap}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

/* ================= Çok sayfalı bileşenler ================= */
/* flash / bildirim bandı (PRG sonrası) */
.flash{max-width:1200px;margin:16px auto -4px;padding:12px 16px;border-radius:10px;display:flex;align-items:center;gap:10px;font-weight:600;font-size:14px;border:1px solid}
.flash.ok{background:#F0F8F4;border-color:#BFE0CE;color:var(--signal-dark)}
.flash.err{background:#FBF1EF;border-color:#EBC6BF;color:var(--alert-dark)}
.flash .flash-ic{width:22px;height:22px;border-radius:50%;display:grid;place-items:center;font-weight:800;color:#fff;flex:none}
.flash.ok .flash-ic{background:var(--signal)}
.flash.err .flash-ic{background:var(--alert)}

/* uyarı kutusu (ör. genel ayar eksik) */
.callout{display:flex;align-items:center;gap:12px;flex-wrap:wrap;border:1px solid var(--line);border-radius:var(--radius);padding:14px 18px;margin-bottom:18px;background:#fff;box-shadow:var(--shadow-sm)}
.callout.warn{background:#FBF7EC;border-color:#EAD6AE}
.callout .btn{margin-left:auto}

/* ekle/düzenle form kartı */
.form-card{border-left:4px solid var(--gold)}
fieldset.subgroup{border:1px solid var(--line);border-radius:10px;padding:14px 16px 4px;margin:16px 0 0}
fieldset.subgroup legend{font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;padding:0 6px}

/* alt bilgi */
.site-foot{max-width:1200px;margin:8px auto 0;padding:26px 22px 40px;color:var(--muted-2);font-size:12px;text-align:center;border-top:1px solid var(--line)}

/* ================= Cloud Link POS ================= */
.muted-tag{font-size:13px;font-weight:600;color:var(--muted);letter-spacing:.02em}

/* Masa ızgarası */
.tablegrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px}
.masa{display:flex;flex-direction:column;gap:8px;text-decoration:none;color:var(--ink);background:var(--card);border:1px solid var(--line);border-left:5px solid var(--line-strong);border-radius:var(--radius);padding:16px 16px 14px;box-shadow:var(--shadow);transition:transform .08s,box-shadow .15s,border-color .15s;min-height:112px}
.masa:hover{box-shadow:0 2px 4px rgba(20,32,46,.05),0 14px 30px -16px rgba(20,32,46,.22);transform:translateY(-1px)}
.masa.free{border-left-color:var(--line-strong)}
.masa.draft{border-left-color:var(--amber)}
.masa.sent{border-left-color:var(--signal)}
.masa-top{display:flex;align-items:baseline;justify-content:space-between;gap:8px}
.masa-name{font-size:17px;font-weight:800}
.masa-region{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.masa-status{display:flex;align-items:center;gap:7px;font-size:12.5px;font-weight:600;color:var(--muted);margin-top:auto}
.masa.free .masa-status{color:var(--muted-2)}
.masa-amount{font-family:var(--mono);font-size:20px;font-weight:700}
.masa.free .masa-amount{color:var(--muted-2);font-size:16px;font-weight:600}

/* Adisyon ekranı */
.adisyon-layout{display:grid;grid-template-columns:1.15fr .85fr;gap:18px;align-items:start}
@media(max-width:900px){.adisyon-layout{grid-template-columns:1fr}}
.menu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px}
.menu-item{display:flex;flex-direction:column;gap:3px;text-align:left;background:#FCFCFA;border:1px solid var(--line-strong);border-radius:10px;padding:12px 13px;cursor:pointer;min-height:74px;transition:transform .06s,border-color .15s,box-shadow .15s;font-family:var(--sans)}
.menu-item:hover{border-color:var(--signal);box-shadow:var(--shadow-sm)}
.menu-item:active{transform:translateY(1px)}
.mi-name{font-size:14px;font-weight:700;color:var(--ink);line-height:1.2}
.mi-price{font-family:var(--mono);font-size:15px;font-weight:700;color:var(--signal-dark)}
.mi-meta{font-size:10.5px;color:var(--muted);font-family:var(--mono)}
.order-card{position:sticky;top:118px}
@media(max-width:900px){.order-card{position:static}}
.qtybox{margin:0}
.qty-in{width:58px;padding:6px 8px;min-height:34px;text-align:center}

/* Tablolar */
.table-wrap{overflow-x:auto;margin:0 -4px}
.grid-table{width:100%;border-collapse:collapse;font-size:14px}
.grid-table th{text-align:left;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);font-weight:700;padding:8px 10px;border-bottom:2px solid var(--line)}
.grid-table td{padding:10px;border-bottom:1px solid var(--line);vertical-align:middle}
.grid-table tr:hover td{background:#FBFBF8}
.grid-table .r{text-align:right}
.grid-table .nowrap{white-space:nowrap}
.grid-table .row-off td{opacity:.55}
.cart .head,.cart .line{grid-template-columns:1fr 74px 100px 36px}
