:root{--green:#1f5d4c;--green-d:#164236;--green-dd:#0e2c24;--teal:#2c7a64;--teal-d:#1f5d4c;--aqua:#4e9d85;--green-soft:#eaf1ed;--green-mist:#f1f6f3;--gold:#a9853f;--gold-d:#876527;--gold-l:#d9bd85;--gold-soft:#f6efe1;--paper:#f6f4ee;--paper-2:#efece4;--cream:#fcfbf7;--cream-2:#faf8f2;--ink:#20211d;--ink-soft:#44473f;--muted:#7a7d72;--line:#e1ded3;--line-2:#d3cfc1;--line-soft:#ece9e0;--field-bg:#fff;--red:#a8392e;--red-d:#8a2c23;--red-soft:#f6ece9;--radius:4px;--radius-sm:3px;--radius-xs:2px;--shadow-sm:0 1px 2px rgba(34,33,28,.04);--shadow:0 1px 3px rgba(34,33,28,.05),0 12px 30px -18px rgba(34,33,28,.22);--shadow-lg:0 24px 60px -22px rgba(20,20,16,.42);--shadow-soft:0 8px 24px -16px rgba(34,33,28,.30);--display:'Playfair Display','Georgia',serif;--sans:'Inter',system-ui,-apple-system,'Segoe UI',sans-serif;--bg:var(--paper);--panel:var(--cream);--serif:var(--display);--green-light:var(--green-mist)}
*{box-sizing:border-box}html,body{margin:0;min-height:100%}
body{font-family:var(--sans);color:var(--ink);font-size:14px;line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;background-color:var(--paper);background-image:radial-gradient(1100px 640px at 100% -8%,rgba(169,133,63,.05),transparent 60%),radial-gradient(1000px 700px at -6% 108%,rgba(31,93,76,.045),transparent 60%);background-attachment:fixed}
::selection{background:rgba(31,93,76,.16);color:var(--green-dd)}
.topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:18px 34px;color:var(--ink);background:rgba(250,248,242,.9);-webkit-backdrop-filter:blur(12px) saturate(118%);backdrop-filter:blur(12px) saturate(118%);border-bottom:1px solid var(--line)}
.topbar::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:1px;background:linear-gradient(90deg,transparent,var(--green) 18%,var(--gold) 58%,transparent 92%);opacity:.5}
.brand{display:flex;align-items:center;gap:16px;min-width:0}
.logo{font-size:22px;width:50px;height:50px;flex:none;display:grid;place-items:center;border-radius:50%;background:var(--cream);border:1px solid var(--line-2);box-shadow:inset 0 0 0 4px var(--cream),0 1px 2px rgba(34,33,28,.06)}
.brand-name{font-family:var(--display);font-weight:700;font-size:23px;letter-spacing:.2px;line-height:1.05;color:var(--green-dd)}
.brand-sub{font-size:10.5px;letter-spacing:.22em;margin-top:4px;color:var(--gold-d);text-transform:uppercase;font-weight:700}
.topbar-actions{display:flex;align-items:center;gap:12px;flex:none}
.conn{font-size:11px;font-weight:700;letter-spacing:.04em;padding:7px 14px;border-radius:999px;white-space:nowrap;display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line-2);background:var(--cream);color:var(--ink-soft);text-transform:uppercase}
.conn.connecting{background:var(--cream);color:var(--muted);border-color:var(--line-2)}
.conn.ok{background:var(--green-soft);color:var(--green-d);border-color:rgba(31,93,76,.26)}
.conn.ok::before,.conn.connecting::before,.conn.err::before{content:"";width:7px;height:7px;border-radius:50%;flex:none}
.conn.ok::before{background:var(--green);box-shadow:0 0 0 3px rgba(31,93,76,.14)}
.conn.connecting::before{background:var(--gold);animation:blink 1.4s ease-in-out infinite}
.conn.err{background:var(--red-soft);color:var(--red-d);border-color:rgba(168,57,46,.3)}
.conn.err::before{background:var(--red);animation:blink 1s ease-in-out infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.layout{position:relative;z-index:1;display:grid;grid-template-columns:1.1fr 1.3fr 0.95fr;gap:30px;padding:40px 34px 60px;max-width:1480px;margin:0 auto;align-items:start}
@media (max-width:1080px){.layout{grid-template-columns:1fr;max-width:680px;gap:22px}.summary{position:static}}
.panel{position:relative;background:var(--cream);border-radius:var(--radius);box-shadow:var(--shadow);padding:34px 32px 36px;border:1px solid var(--line)}
.panel::before{content:"";position:absolute;left:0;right:0;top:0;height:1px;border-radius:var(--radius) var(--radius) 0 0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.9) 40%,rgba(255,255,255,.5) 60%,transparent);pointer-events:none}
.panel-title{position:relative;font-family:var(--display);margin:0 0 26px;font-size:21px;font-weight:700;letter-spacing:.1px;color:var(--green-dd);display:flex;align-items:baseline;gap:14px;padding-bottom:18px;border-bottom:1px solid var(--line)}
.panel-title::after{content:"";position:absolute;left:0;bottom:-1px;width:54px;height:2px;background:linear-gradient(90deg,var(--gold),var(--gold-l))}
.field{margin-bottom:20px}
.field>label{display:block;font-size:10.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.req{color:var(--red);font-weight:800}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
input,select,textarea{width:100%;padding:12px 14px;border:1px solid var(--line-2);border-radius:var(--radius-sm);font:inherit;color:var(--ink);background:var(--field-bg);outline:none;transition:border-color .18s ease,box-shadow .2s ease,background .18s ease}
input::placeholder,textarea::placeholder{color:#a6a89c}
input:hover,select:hover,textarea:hover{border-color:var(--muted)}
input:focus,select:focus,textarea:focus{border-color:var(--green);background:#fff;box-shadow:0 0 0 3px rgba(31,93,76,.12)}
select{appearance:none;-webkit-appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--green) 50%),linear-gradient(135deg,var(--green) 50%,transparent 50%);background-position:calc(100% - 19px) 53%,calc(100% - 14px) 53%;background-size:5px 5px,5px 5px;background-repeat:no-repeat;padding-right:36px;cursor:pointer}
textarea{resize:vertical;min-height:56px;line-height:1.55}
.hint{font-size:12px;color:var(--green-d);margin-top:8px;min-height:14px;font-weight:600}
.hint:not(:empty)::before{content:"— ";color:var(--gold-d);font-weight:800}
.customer-row{display:flex;gap:10px}.customer-row input{flex:1}
.add-line{display:flex;gap:12px;align-items:stretch;margin-bottom:22px;padding:16px;background:var(--green-mist);border:1px solid var(--line);border-radius:var(--radius-sm)}
.add-line .grow{flex:1}.add-line select{background-color:#fff}
.qty{display:flex;align-items:center;border:1px solid var(--line-2);border-radius:var(--radius-sm);overflow:hidden;background:#fff}
.qty.mini{width:128px;flex:none}
.qty button{width:40px;align-self:stretch;border:none;cursor:pointer;font-size:17px;font-weight:600;color:var(--green-d);background:var(--cream);transition:background .15s ease,color .15s ease}
.qty button:hover{background:var(--green);color:#fff}.qty button:active{background:var(--green-d)}
.qty input{width:48px;border:none;text-align:center;padding:10px 0;background:#fff;font-weight:700;color:var(--ink);font-variant-numeric:tabular-nums}
.qty input::-webkit-outer-spin-button,.qty input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.qty input{-moz-appearance:textfield}
.lines{width:100%;border-collapse:separate;border-spacing:0}
.lines th{text-align:left;font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-weight:800;padding:0 10px 11px;border-bottom:1.5px solid var(--ink)}
.lines .r{text-align:right}.lines .c{text-align:center}
.lines td{padding:15px 10px;border-bottom:1px solid var(--line);vertical-align:middle}
.lines .empty td{text-align:center;color:var(--muted);padding:46px 10px;font-style:italic;font-size:13.5px;border-bottom:1px solid var(--line)}
.lines tbody tr:not(.empty){transition:background .15s ease}
.lines tbody tr:not(.empty):hover{background:var(--green-mist)}
.svc-name{font-weight:700;color:var(--ink);letter-spacing:.1px}
.svc-group{font-size:11.5px;color:var(--muted);margin-top:3px;letter-spacing:.02em}
.line-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.meta-field{display:flex;flex-direction:column;gap:3px;flex:1 1 130px;min-width:0;padding:6px 9px;background:var(--green-mist);border:1px solid var(--line);border-radius:var(--radius-sm);transition:border-color .15s ease,background .15s ease}
.meta-field.on{background:var(--gold-soft);border-color:var(--gold-l)}
.meta-lbl{font-size:9.5px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);white-space:nowrap}
.meta-field.on .meta-lbl{color:var(--gold-d)}
.meta-sel{font-size:12px;padding:5px 24px 5px 2px;border:none;border-bottom:1px solid var(--line-2);border-radius:0;color:var(--ink);background-color:transparent;background-position:calc(100% - 6px) 60%,calc(100% - 2px) 60%;background-size:5px 5px,5px 5px;width:100%;cursor:pointer;font-weight:600}
.meta-sel:hover{border-bottom-color:var(--muted)}
.meta-sel:focus{border-bottom-color:var(--green);box-shadow:none;outline:none}
.meta-field.on .meta-sel{border-bottom-color:var(--gold)}
.lines td.r{font-variant-numeric:tabular-nums;color:var(--ink-soft)}
.lines td.r b{font-variant-numeric:tabular-nums;font-weight:800;color:var(--green-dd)}
.lines td.r .gross-strike{display:block;font-size:11.5px;font-weight:600;color:var(--muted);text-decoration:line-through;margin-bottom:1px}
.price-cell{white-space:nowrap}
.price-in{width:98px;padding:7px 8px;border:1px solid var(--line-2);border-radius:var(--radius-sm);background:#fff;font-size:13.5px;font-variant-numeric:tabular-nums;text-align:right;color:var(--ink);font-weight:700}
.price-in:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px var(--green-mist)}
.price-in.edited{border-color:var(--gold);background:#fffdf3}
.price-tag{display:block;font-size:10px;font-weight:700;color:#a07a00;margin-top:2px;letter-spacing:.02em}
.row-del{border:none;background:transparent;color:var(--red);cursor:pointer;font-size:14px;line-height:1;opacity:.55;width:30px;height:30px;border-radius:var(--radius-sm);transition:background .15s ease,opacity .15s ease}
.row-del:hover{opacity:1;background:var(--red-soft)}
.line-qty{display:inline-flex;align-items:center;justify-content:center;gap:6px}
.line-qty button{width:26px;height:26px;border:1px solid var(--line-2);background:#fff;border-radius:var(--radius-sm);cursor:pointer;color:var(--green-d);font-weight:700;line-height:1;transition:border-color .15s ease,background .15s ease,color .15s ease}
.line-qty button:hover{border-color:var(--green);background:var(--green);color:#fff}
.line-qty span{min-width:22px;text-align:center;font-weight:700;font-variant-numeric:tabular-nums}
.summary{position:sticky;top:104px}.summary.panel{background:var(--cream-2)}
.sum-row{display:flex;align-items:center;justify-content:space-between;padding:12px 0;font-size:14px;gap:12px}
.sum-row + .sum-row{border-top:1px solid var(--line-soft)}
.sum-row>span{color:var(--ink-soft);font-weight:500}
.sum-row b{font-variant-numeric:tabular-nums;font-weight:700;color:var(--ink)}
.sum-row.total{margin-top:16px;padding:24px 24px 24px 26px;border-radius:var(--radius-sm);background:var(--green-dd);border:none;position:relative;overflow:hidden;box-shadow:0 14px 34px -22px rgba(14,44,36,.7)}
.sum-row.total::after{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(180deg,var(--gold-l),var(--gold))}
.sum-row.total>span{color:rgba(241,246,243,.85);font-weight:600;letter-spacing:.06em;text-transform:uppercase;font-size:11px}
.sum-row.total b{color:#fff;font-weight:700;font-size:27px;letter-spacing:.2px;font-variant-numeric:tabular-nums;position:relative;z-index:1}
.sum-row.remain{margin-top:6px;padding:15px 18px;border-radius:var(--radius-sm);background:var(--red-soft);border:1px solid rgba(168,57,46,.22)}
.sum-row.remain>span{color:var(--red-d);font-weight:700;text-transform:uppercase;font-size:11px;letter-spacing:.04em}
.sum-row.remain b{color:var(--red-d);font-weight:800;font-size:20px;font-variant-numeric:tabular-nums}
.money-in{width:140px;text-align:right;padding:10px 13px;font-weight:700;font-variant-numeric:tabular-nums}
.money-in.full{width:100%}
.divider{height:1px;margin:22px 0;background:var(--line);position:relative}
.divider::after{content:"";position:absolute;left:50%;top:-2px;transform:translateX(-50%);width:5px;height:5px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 3px var(--cream-2)}
.discount-wrap{display:flex;align-items:center;gap:10px}.discount-wrap .money-in{width:96px}
.seg{display:inline-flex;flex:none;border:1px solid var(--line-2);border-radius:var(--radius-sm);overflow:hidden;background:#fff}
.seg button{width:40px;padding:10px 0;border:none;cursor:pointer;background:transparent;font-weight:800;color:var(--muted);transition:background .15s ease,color .15s ease}
.seg button + button{border-left:1px solid var(--line-2)}
.seg button:hover{background:var(--green-mist);color:var(--green-d)}
.seg button.on{background:var(--green);color:#fff}
.btn{border:1px solid transparent;border-radius:var(--radius-sm);padding:12px 20px;font:inherit;font-weight:600;letter-spacing:.01em;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:7px;transition:transform .06s ease,background .18s ease,box-shadow .2s ease,color .18s ease,border-color .18s ease;-webkit-tap-highlight-color:transparent}
.btn:active{transform:translateY(1px)}
.btn.primary{color:#fff;background:var(--green);border-color:var(--green);box-shadow:var(--shadow-soft)}
.btn.primary:hover{background:var(--green-d);border-color:var(--green-d)}
.btn.soft{background:#fff;color:var(--gold-d);white-space:nowrap;border:1px solid var(--gold-l)}
.btn.soft:hover{background:var(--gold-soft);color:var(--gold-d);border-color:var(--gold)}
.btn.ghost{background:transparent;color:var(--ink-soft);border:1px solid var(--line-2)}
.btn.ghost:hover{background:var(--green-mist);border-color:var(--muted);color:var(--green-dd)}
.summary .btn.ghost,.modal .btn.ghost{background:#fff;color:var(--ink-soft);border:1px solid var(--line-2)}
.summary .btn.ghost:hover,.modal .btn.ghost:hover{background:var(--green-mist);border-color:var(--muted);color:var(--green-dd)}
.btn.confirm{width:100%;margin-top:26px;padding:18px;font-family:var(--sans);font-size:15px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#fff;background:var(--green-dd);border:1px solid var(--green-dd);box-shadow:0 12px 30px -16px rgba(14,44,36,.7);position:relative;overflow:hidden}
.btn.confirm::after{content:"";position:absolute;top:0;left:-60%;width:45%;height:100%;background:linear-gradient(100deg,transparent,rgba(217,189,133,.32),transparent);transform:skewX(-18deg);transition:left .6s ease}
.btn.confirm:hover:not(:disabled)::after{left:130%}
.btn.confirm:hover:not(:disabled){background:var(--green-d);border-color:var(--green-d)}
.btn.confirm:disabled{background:var(--paper-2);color:var(--muted);border-color:var(--line-2);box-shadow:none;cursor:not-allowed}
.btn.danger{background:var(--red);color:#fff;border-color:var(--red);box-shadow:var(--shadow-soft)}
.btn.danger:hover{background:var(--red-d);border-color:var(--red-d)}
.btn.danger:disabled{background:#d9b3ae;border-color:#d9b3ae;box-shadow:none;cursor:not-allowed}
.danger-link{color:var(--red)}
.confirm-note{text-align:center;font-size:11.5px;color:var(--muted);margin-top:12px;font-style:italic}
.modal-bg{position:fixed;inset:0;z-index:50;display:grid;place-items:center;padding:20px;background:rgba(28,30,26,.42);-webkit-backdrop-filter:blur(6px) saturate(110%);backdrop-filter:blur(6px) saturate(110%);animation:bgIn .22s ease both}
@keyframes bgIn{from{opacity:0}to{opacity:1}}
.modal-bg[hidden]{display:none!important}
.modal{position:relative;background:var(--cream);border-radius:var(--radius);width:100%;max-width:410px;padding:34px 32px 30px;box-shadow:var(--shadow-lg);border:1px solid var(--line-2);animation:modalIn .3s cubic-bezier(.16,1,.3,1) both;overflow:hidden}
.modal::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--green-dd) 0%,var(--green) 50%,var(--gold) 100%)}
@keyframes modalIn{from{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}
.modal h3{font-family:var(--display);margin:4px 0 22px;font-size:24px;font-weight:700;color:var(--green-dd);letter-spacing:.1px}
.modal-note{font-size:12px;color:var(--ink-soft);background:var(--green-mist);border:1px solid var(--line);border-left:2px solid var(--gold);border-radius:var(--radius-xs);padding:11px 14px;margin-top:10px;line-height:1.55}
.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:26px}
.modal-actions .btn{padding:12px 22px}
.modal.done{text-align:center;max-width:450px;padding-top:38px}
.done-icon{font-size:30px;width:76px;height:76px;margin:4px auto 14px;display:grid;place-items:center;border-radius:50%;background:var(--green-mist);box-shadow:0 0 0 1px var(--line-2),0 0 0 7px var(--cream),0 0 0 8px rgba(169,133,63,.45),0 14px 30px -16px rgba(14,44,36,.5);border:1px solid var(--line);animation:popIcon .5s cubic-bezier(.2,1.45,.4,1) both}
@keyframes popIcon{from{transform:scale(.4);opacity:0}to{transform:scale(1);opacity:1}}
.modal.done h3{margin-bottom:8px}
.done-code{font-family:var(--display);font-size:26px;font-weight:800;letter-spacing:1.5px;color:var(--green-d);margin:6px 0 24px}
.done-info{text-align:left;background:var(--green-mist);border:1px solid var(--line);border-radius:var(--radius-sm);padding:4px 16px;margin-bottom:14px}
.done-info-row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:9px 0}
.done-info-row+.done-info-row{border-top:1px solid var(--line)}
.done-info-row span{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;font-weight:700}
.done-info-row b{font-size:15px;color:var(--ink);font-weight:800;text-align:right}
.done-products{text-align:left;margin-bottom:14px;border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden}
.done-prod{display:flex;justify-content:space-between;align-items:baseline;gap:10px;padding:9px 14px;font-size:13.5px}
.done-prod:nth-child(even){background:var(--cream-2)}
.dp-name{color:var(--ink);font-weight:600;line-height:1.35}
.dp-qty{color:var(--green-d);font-weight:800;font-variant-numeric:tabular-nums}
.dp-km{color:#a07a00;font-style:normal;font-weight:700;font-size:11px}
.dp-amt{color:var(--ink);font-weight:700;font-variant-numeric:tabular-nums;white-space:nowrap}
.done-lines{text-align:left}
.done-line{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:9px 4px;font-size:14px}
.done-line+.done-line{border-top:1px solid var(--line)}
.done-line span{color:var(--ink-soft)}
.done-line b{font-variant-numeric:tabular-nums;font-weight:700;color:var(--ink)}
.done-line.strong{background:var(--cream-2);border:1px solid var(--line);border-radius:var(--radius-sm);padding:12px 14px;margin:8px 0}
.done-line.strong span{font-weight:800;color:var(--ink);text-transform:uppercase;font-size:11px;letter-spacing:.08em}
.done-line.strong b{font-size:20px;font-weight:800;color:var(--green-d)}
.done-line.strong+.done-line{border-top:none}
.done-line.remain b{color:var(--red-d);font-weight:800}
.modal.done .modal-actions{justify-content:center;margin-top:24px}
.toast{position:fixed;bottom:28px;left:50%;transform:translateX(-50%);z-index:99;background:var(--green-dd);color:#f1f6f3;padding:14px 24px;border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);border:1px solid rgba(255,255,255,.08);border-left:2px solid var(--gold);font-weight:600;max-width:90vw;animation:toastIn .3s cubic-bezier(.16,1,.3,1) both}
@keyframes toastIn{from{opacity:0;transform:translate(-50%,14px)}to{opacity:1;transform:translate(-50%,0)}}
.toast.err{background:var(--red-d);border-left-color:var(--gold-l)}
.toast[hidden]{display:none!important}
.admin-wrap{position:relative;z-index:1;max-width:980px;margin:0 auto;padding:40px 34px 60px}
.admin-wrap .panel{margin-bottom:30px}
.admintok{width:220px;padding:9px 13px;font-size:13px;background:var(--cream);border:1px solid var(--line-2);color:var(--ink);border-radius:var(--radius-sm)}
.admintok::placeholder{color:var(--muted)}
.admintok:focus{background:#fff;color:var(--ink);box-shadow:0 0 0 3px rgba(31,93,76,.12);border-color:var(--green)}
.adv{margin:10px 0 18px}
.adv summary{cursor:pointer;font-size:12.5px;color:var(--green-d);font-weight:700;list-style:none;padding:5px 0}
.adv summary::-webkit-details-marker{display:none}
.adv summary::before{content:"▸ ";color:var(--gold-d);font-weight:800}
.adv[open] summary::before{content:"▾ "}
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
@media (max-width:720px){.grid3,.grid2{grid-template-columns:1fr}}
.map-note{font-size:13px;color:var(--ink-soft);margin:-4px 0 16px;line-height:1.55}
.mode-switch{display:flex;flex-wrap:wrap;align-items:center;gap:8px 16px;padding:15px 18px;margin:4px 0 20px;background:var(--green-mist);border:1px solid var(--line);border-left:2px solid var(--gold);border-radius:var(--radius-sm)}
.mode-switch .mode-lbl{font-weight:800;color:var(--green-dd)}
.mode-switch label{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--ink);cursor:pointer}
.mode-switch input[type=radio]{accent-color:var(--green);width:auto}
.flat-group{font-size:11px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.12em;margin:26px 0 12px;padding-top:10px;border-top:1px solid var(--line)}
.flat-group:first-child{border-top:0;padding-top:0;margin-top:4px}
.sub{font-family:var(--display);font-size:18px;font-weight:700;color:var(--green-dd);margin:26px 0 14px}
.map-table{border:1px solid var(--line);border-radius:var(--radius-sm);padding:16px 18px;margin-bottom:16px;background:var(--cream-2)}
.map-table-head{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.map-tlabel{font-weight:800;color:var(--green-dd);min-width:120px}.map-tbl{flex:1}
.map-fields{display:grid;grid-template-columns:1fr 1fr;gap:10px 18px}
@media (max-width:720px){.map-fields{grid-template-columns:1fr}}
.map-row{display:flex;flex-direction:column;gap:4px}
.map-row label{font-size:12px;color:var(--muted);font-weight:700;display:flex;align-items:center;gap:6px;text-transform:none;letter-spacing:0}
.fld-info{font-size:11px;color:var(--green-d);margin-top:3px;min-height:13px;word-break:break-word}
.badge{font-style:normal;font-size:10px;padding:2px 7px;border-radius:var(--radius-xs);font-weight:800}
.badge.link{background:var(--green-soft);color:var(--green-d)}
.badge.ro{background:var(--gold-soft);color:var(--gold-d)}
.st-table{width:100%;border-collapse:separate;border-spacing:0;font-size:13.5px}
.st-table th{text-align:left;font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-weight:800;padding:0 10px 10px;border-bottom:1.5px solid var(--ink)}
.st-table td{padding:12px 10px;border-bottom:1px solid var(--line);vertical-align:middle}
.st-table .muted{font-size:11.5px;color:var(--muted)}
.st-ok{color:var(--green-d);font-weight:800}.st-err{color:var(--red);font-weight:800}.scanned{margin-top:12px}
@media (max-width:1080px) and (min-width:641px){.summary{position:static}}
@media (max-width:640px){
body{font-size:15px}
.topbar{padding:14px 18px;flex-wrap:wrap;gap:10px}
.brand-sub{display:none}.brand-name{font-size:20px}
.logo{width:44px;height:44px;font-size:20px}
.topbar-actions{gap:8px;width:100%;justify-content:space-between}
.conn{font-size:10.5px}
.layout{padding:20px 15px 36px;gap:18px;max-width:100%}
.panel{padding:26px 20px 26px}
.panel-title{font-size:19px;margin-bottom:20px}
.grid2{grid-template-columns:1fr}
input,select,textarea{padding:14px;font-size:16px}
.btn{padding:14px 18px}
.customer-row{flex-direction:column}.customer-row .btn{width:100%}
.add-line{flex-wrap:wrap;padding:14px}
.add-line .grow{flex:1 1 100%}
.qty.mini{width:auto;flex:1}#btnAddLine{flex:1}
.qty button{width:50px;height:50px;font-size:19px}
.lines th,.lines td{padding:12px 4px;font-size:13.5px}
.lines th:nth-child(2),.lines td:nth-child(2){padding-left:2px;padding-right:2px}
.price-in{width:74px;padding:7px 5px;font-size:12.5px}
.svc-group{font-size:11px}
.money-in{width:120px}.discount-wrap .money-in{width:90px}
.summary{position:static}
.sum-row.total{padding:20px}
.sum-row.total b{font-size:25px}
.btn.confirm{position:sticky;bottom:12px;padding:18px;font-size:15px;box-shadow:var(--shadow-lg)}
.modal{max-width:100%;padding:28px 22px}.modal h3{font-size:22px}
.done-grid{grid-template-columns:1fr 1fr}
.admin-wrap{padding:20px 15px 36px}.admintok{width:100%}}
@media (max-width:380px){.done-grid{grid-template-columns:1fr}.modal-actions{flex-direction:column-reverse}.modal-actions .btn{width:100%}}
@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important}.btn.confirm::after{display:none}}
