/* ═══════════════════════════════════════
   RESET & BOX MODEL
═══════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; }

/* ═══════════════════════════════════════
   VARIABLES
═══════════════════════════════════════ */
:root {
  --brand:        #00C87A;
  --brand-dk:     #00A866;
  --brand-lt:     #34D494;
  --brand-tint:   rgba(0,200,122,.12);
  --brand-glow:   rgba(0,200,122,.25);
  --brand-strong: rgba(0,200,122,.50);

  --bg:         #0D2A1C;
  --bg2:        #09201A;
  --bg3:        #162E22;
  --bg4:        #1C3A2A;

  --text:       #DFF0E8;
  --muted:      #5A8A70;

  --border:     rgba(0,200,122,.16);
  --border-md:  rgba(0,200,122,.30);

  --on-brand:    #082016;
  --warn:        #B45309;
  --warn-bg:     rgba(180,83,9,.10);
  --warn-border: rgba(180,83,9,.25);

  --err:        #F87171;
  --err-bg:     rgba(248,113,113,.1);
  --ok:         #34D494;
  --ok-bg:      rgba(52,212,148,.1);

  --rs:   10px;
  --rm:   14px;
  --rl:   18px;
  --tr:   .2s cubic-bezier(.4,0,.2,1);
  --tr-f: .1s ease;
}

/* ═══════════════════════════════════════
   LIGHT THEME
═══════════════════════════════════════ */
body.light {
  --bg:         #EEF6F1;
  --bg2:        #E0EDE5;
  --bg3:        #FFFFFF;
  --bg4:        #C2DDC9;
  --text:         #0C1C13;
  --muted:        #1E5C38;
  --border:       rgba(0,110,55,.14);
  --border-md:    rgba(0,110,55,.28);
  --brand-lt:     #008A4E;
  --brand-dk:     #006E3C;
  --brand-tint:   rgba(0,160,90,.12);
  --brand-glow:   rgba(0,160,90,.28);
  --brand-strong: rgba(0,160,90,.55);
}
body.light input:-webkit-autofill,
body.light input:-webkit-autofill:hover,
body.light input:-webkit-autofill:focus {
  -webkit-box-shadow:0 0 0 1000px #FFFFFF inset;
  -webkit-text-fill-color:#182E21;
}
body.light select.inp option { background:#FFFFFF; color:#182E21; }
body.light select.inp {
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='7' viewBox='0 0 12 7'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23447A5A' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
}

/* ═══════════════════════════════════════
   BASE
═══════════════════════════════════════ */
html { -webkit-text-size-adjust:100%; text-size-adjust:100%; }

body {
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  font-size: 16px; line-height: 1.6;
  color: var(--text); background: var(--bg);
  -webkit-font-smoothing: antialiased;
  margin:0; padding:0; min-height:100vh; overflow-x:hidden;
}

button { cursor:pointer; font:inherit; border:none; background:none; padding:0; }
input, textarea, select { font:inherit; }
img { display:block; max-width:100%; }

input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button { -webkit-appearance:none; margin:0; }
input[type=number] { -moz-appearance:textfield; }

input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus {
  -webkit-box-shadow:0 0 0 1000px #162E22 inset;
  -webkit-text-fill-color:#DFF0E8;
  transition:background-color 5000s ease 0s;
}

::-webkit-scrollbar { width:4px; height:4px; }
::-webkit-scrollbar-track { background:var(--bg2); }
::-webkit-scrollbar-thumb { background:var(--bg4); border-radius:2px; }
::-webkit-scrollbar-thumb:hover { background:var(--muted); }

/* ═══════════════════════════════════════
   WRAP
═══════════════════════════════════════ */
.wrap { width:100%; background:var(--bg); min-height:100vh; }

/* ═══════════════════════════════════════
   PIN SCREEN
═══════════════════════════════════════ */
.pin-screen {
  position:fixed; inset:0;
  display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  gap:22px; padding:32px 24px;
  background:#082016;
  overflow-y:auto; z-index:50;
}

.pin-screen::before {
  content:''; position:fixed; inset:0;
  background:
    radial-gradient(ellipse 90% 65% at 50% 35%, var(--brand-glow) 0%, transparent 65%),
    radial-gradient(ellipse 60% 50% at 15% 85%, rgba(0,100,60,.18) 0%, transparent 55%);
  pointer-events:none; z-index:-1;
}

.pin-screen::after { display:none; }

.pin-logo {
  width:68px; height:68px;
  background:var(--brand-tint);
  border:1px solid var(--brand-strong);
  border-radius:20px;
  display:flex; align-items:center; justify-content:center;
  color:var(--brand-lt); flex-shrink:0;
  box-shadow:0 0 32px var(--brand-glow);
  transition:border-color var(--tr), box-shadow var(--tr), background var(--tr);
}
@keyframes unlock-bounce {
  0%   { transform:scale(1); }
  25%  { transform:scale(1.18); }
  55%  { transform:scale(0.93); }
  80%  { transform:scale(1.06); }
  100% { transform:scale(1); }
}
.pin-logo.unlocking {
  animation:unlock-bounce .55s cubic-bezier(.36,.07,.19,.97);
  border-color:var(--brand);
  background:var(--brand-tint);
  box-shadow:0 0 48px var(--brand-strong), 0 0 80px var(--brand-glow);
  color:var(--brand-lt);
}

.pin-title {
  font-size:2.8rem; font-weight:800;
  letter-spacing:.08em; text-transform:uppercase;
  background:linear-gradient(135deg, #86EFCA 0%, var(--brand) 50%, var(--brand-dk) 100%);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text; text-align:center;
}

.pin-sub {
  font-size:.88rem; color:rgba(255,255,255,.75);
  text-align:center; letter-spacing:.06em; text-transform:uppercase;
}

.pin-dots { display:flex; gap:14px; }

.pin-dot {
  width:13px; height:13px; border-radius:50%;
  border:2px solid rgba(255,255,255,.4); background:transparent;
  transition:background var(--tr), border-color var(--tr), box-shadow var(--tr), transform var(--tr);
  flex-shrink:0;
}
.pin-dot.filled  { background:var(--brand-lt); border-color:var(--brand-lt); box-shadow:0 0 10px var(--brand-strong); }
.pin-dot.error   { background:#F87171;         border-color:#F87171;         box-shadow:0 0 10px rgba(248,113,113,.5); }
.pin-dot.success { background:var(--brand-lt); border-color:var(--brand-lt); box-shadow:0 0 10px var(--brand-strong); }
.pin-dot.checking {
  background:var(--brand-lt); border-color:var(--brand-lt);
  animation:pulse .7s ease-in-out infinite alternate;
}

@keyframes pulse {
  from { opacity:1;  transform:scale(1);   }
  to   { opacity:.4; transform:scale(.75); }
}
@keyframes shake {
  0%,100% { transform:translateX(0);   }
  20%     { transform:translateX(-7px); }
  40%     { transform:translateX(7px);  }
  60%     { transform:translateX(-4px); }
  80%     { transform:translateX(4px);  }
}
.pin-dots.shake { animation:shake .45s ease; }

.pin-err {
  font-size:.84rem; color:#F87171;
  text-align:center; min-height:1.5em; font-weight:500;
  max-width:280px; padding:6px 14px;
  border-radius:var(--rs); border:1px solid transparent;
  transition:background var(--tr), border-color var(--tr);
}
.pin-err:not(:empty) { background:rgba(248,113,113,.1); border-color:rgba(248,113,113,.2); }

.pin-kbd {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:10px; width:100%; max-width:296px;
}

.pin-key {
  padding:17px; font-size:1.4rem; font-weight:600; text-align:center;
  border:1px solid rgba(255,255,255,.25); border-radius:var(--rm);
  cursor:pointer; color:#fff; background:rgba(255,255,255,.08);
  font-family:inherit; user-select:none;
  transition:background var(--tr), border-color var(--tr), box-shadow var(--tr), transform var(--tr-f);
  -webkit-tap-highlight-color:transparent;
}
.pin-key:active:not(:disabled) {
  background:var(--brand-glow); border-color:var(--brand-strong);
  box-shadow:0 0 18px var(--brand-glow); transform:scale(.95);
}
.pin-key:disabled { opacity:.25; cursor:not-allowed; }
.pin-key.del   { font-size:1.1rem; color:rgba(255,255,255,.75); display:flex; align-items:center; justify-content:center; }
.pin-key.empty { border:none; background:none; cursor:default; box-shadow:none; }

/* ═══════════════════════════════════════
   TOPBAR
═══════════════════════════════════════ */
.topbar {
  background:var(--bg2);
  box-shadow:inset 0 -1px 0 var(--border-md);
  padding: clamp(8px, calc(8px + (100vw - 360px) / 30), 16px);  /* F-12: fluid 8→16px (vw 360→600) */
  display:flex; justify-content:space-between; align-items:center; gap:8px;
}

.topbar-brand {
  font-size: clamp(1.6rem, calc(0.4rem + 5.33vw), 2.4rem);  /* F-12: fluid 1.6→2.4rem (vw 360→600) */
  font-weight:900;
  letter-spacing:.08em; text-transform:uppercase;
  line-height: clamp(28px, calc(19px + 2.5vw), 34px);  /* F-12: fluid 28→34px */
  background:linear-gradient(135deg, #86EFCA 0%, var(--brand) 50%, var(--brand-dk) 100%);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text;
}
.topbar-brand span { -webkit-text-fill-color:transparent; }

.topbar-left  { display:flex; align-items:center; gap:10px; }
.topbar-right { display:flex; flex-direction:column; align-items:flex-end; gap:1px; }

.theme-btn {
  width:  clamp(28px, calc(19px + 2.5vw), 34px);  /* F-12: fluid 28→34px */
  height: clamp(28px, calc(19px + 2.5vw), 34px);
  flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  border:1px solid var(--border-md); border-radius:50%;
  background:var(--text); color:var(--bg); cursor:pointer;
  transition:all var(--tr); -webkit-tap-highlight-color:transparent;
}
.theme-btn:active { background:var(--brand-tint); border-color:var(--brand); transform:scale(.92); }
.t2    { color:var(--brand-lt); font-size: clamp(0.52rem, calc(0.34rem + 0.8vw), 0.64rem); font-weight:600; letter-spacing:.02em; line-height:1.1; }  /* F-12 */
.tdate { color:var(--muted);    font-size: clamp(0.52rem, calc(0.34rem + 0.8vw), 0.64rem); font-weight:500; line-height:1.1; }  /* F-12 */

/* ═══════════════════════════════════════
   TABS
═══════════════════════════════════════ */
.tabs {
  display:flex; border-bottom:1px solid var(--border);
  background:var(--bg2); position:sticky; top:0; z-index:10;
}
.tab {
  flex:1; padding:12px 0;
  font-size:.88rem; font-weight:500; text-align:center;
  cursor:pointer; color:var(--muted);
  border:none; border-bottom:2px solid transparent;
  background:none; font-family:inherit; letter-spacing:.02em;
  transition:color var(--tr), border-color var(--tr);
  -webkit-tap-highlight-color:transparent;
}
.tab.on { color:var(--on-brand); border-bottom-color:var(--brand); font-weight:700; background:var(--brand); }
.tab + .tab { border-left:1px solid var(--border); }
.tab.on, .tab.on + .tab { border-left-color:transparent; }

/* ═══════════════════════════════════════
   PANELS
═══════════════════════════════════════ */
.pnl    { display:none; }
.pnl.on { display:block; }

/* ═══════════════════════════════════════
   FORM
═══════════════════════════════════════ */
.form {
  padding:16px;
  display:flex; flex-direction:column; gap:12px;
  background:var(--bg);
}

#c-own-action, #c-accept-action {
  display:flex; flex-direction:column; gap:16px;
}

#client-block, #materials-block, .works-block {
  display:flex; flex-direction:column; gap:14px;
}
#referral-block { display:flex; flex-direction:column; gap:12px; }

.lbl {
  display:block; font-size:.68rem; font-weight:700;
  color:var(--muted); margin-bottom:6px;
  text-transform:uppercase; letter-spacing:.09em;
}

.lbl-section {
  padding-bottom:6px;
  border-bottom:1px solid var(--muted);
  margin-bottom:2px;
}

.section-lbl {
  font-size:.75rem; font-weight:700;
  color:var(--muted); text-transform:uppercase;
  letter-spacing:.05em; padding:8px 0 2px;
}

/* ═══════════════════════════════════════
   SECTION CARD
═══════════════════════════════════════ */
.section-card {
  background:var(--bg3);
  border:1px solid var(--border-md);
  border-radius:var(--rm);
  padding:14px;
  display:flex; flex-direction:column; gap:14px;
}

/* ═══════════════════════════════════════
   INPUTS — base (select, textarea, div.readonly)
═══════════════════════════════════════ */
.inp {
  width:100%; padding:11px 14px; font-size:1rem;
  border:1px solid var(--border-md); border-radius:var(--rs);
  color:var(--text); background:var(--bg3); outline:none;
  transition:border-color var(--tr), box-shadow var(--tr);
  -webkit-appearance:none; appearance:none; display:block;
}
.inp::placeholder { color:var(--muted); opacity:.85; }
.inp:focus { border-color:var(--brand); box-shadow:0 0 0 3px var(--brand-glow); }
:focus-visible { outline:2px solid var(--brand); outline-offset:2px; }
.inp.readonly { background:var(--bg2); color:var(--muted); cursor:default; }
textarea.inp  { resize:vertical; min-height:76px; }

select.inp {
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='7' viewBox='0 0 12 7'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%235A8A70' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 14px center;
  padding-right:38px; cursor:pointer;
}
select.inp option { background:var(--bg3); color:var(--text); }

/* ═══════════════════════════════════════
   INPUTS — text/number/tel
═══════════════════════════════════════ */
input.inp { caret-color:var(--brand); }

/* ═══════════════════════════════════════
   GRID 2 COLS
═══════════════════════════════════════ */
.g-slim{ display:grid; grid-template-columns:35% 1fr;  gap:12px; }

/* ═══════════════════════════════════════
   DIVIDER / HINT
═══════════════════════════════════════ */
hr { border:none; border-top:1px solid var(--border); margin:2px 0; }

.hint { font-size:.72rem; color:var(--muted); margin-top:5px; line-height:1.45; }
.hint::before { content:'· '; color:var(--brand-lt); font-weight:700; }

/* ═══════════════════════════════════════
   CHIPS
═══════════════════════════════════════ */
.chips { display:flex; flex-wrap:wrap; gap:8px; }

/* ═══════════════════════════════════════
   TEAM BOX
═══════════════════════════════════════ */
.tbox {
  border:1px solid var(--border-md); border-radius:var(--rs);
  padding:10px 12px; min-height:46px;
  display:flex; flex-wrap:wrap; gap:6px; align-items:center;
  background:var(--bg2); width:100%;
}

.tag {
  display:inline-flex; align-items:center; gap:5px;
  background:var(--bg3); border:1px solid var(--border-md);
  border-radius:50px; padding:4px 12px;
  font-size:.82rem; color:var(--brand-lt); font-weight:500;
}
.tag-x {
  cursor:pointer; color:var(--brand-lt); opacity:.55;
  font-size:1.1rem; line-height:1; padding-left:2px;
  -webkit-tap-highlight-color:transparent; transition:opacity var(--tr);
}
.tag-x:hover { opacity:1; }

.add-btn {
  font-size:.82rem; color:var(--brand-lt);
  cursor:pointer; padding:3px 6px; font-weight:600; white-space:nowrap;
  -webkit-tap-highlight-color:transparent; transition:opacity var(--tr);
}
.add-btn:active { opacity:.65; }

/* ═══════════════════════════════════════
   PAY OPTIONS
═══════════════════════════════════════ */
.pgrid  { display:grid; grid-template-columns:1fr 1fr;     gap:8px; }
.pgrid3 { display:grid; grid-template-columns:1fr 1fr 1fr; gap:8px; }

#work-chips { display:flex; flex-wrap:wrap; justify-content:center; gap:8px; }
#work-chips .popt { width:calc((100% - 8px) / 2); }

.popt {
  border:1px solid var(--border-md); border-radius:50px;
  padding:12px 10px;
  display:flex; align-items:center; justify-content:center;
  text-align:center; font-size:.88rem; font-weight:500;
  color:var(--muted); cursor:pointer; background:var(--bg2); user-select:none;
  transition:background var(--tr), border-color var(--tr), color var(--tr), transform var(--tr-f);
  -webkit-tap-highlight-color:transparent;
}
.popt:active { transform:scale(.97); }
.popt.on {
  border-color:transparent; background:var(--brand); color:var(--on-brand); font-weight:700;
}
body.light .popt.on { background:var(--brand); border-color:transparent; color:var(--on-brand); }

/* ═══════════════════════════════════════
   BUTTON
═══════════════════════════════════════ */
.btn {
  width:100%; padding:14px;
  background:var(--brand); color:#fff;
  border:none; border-radius:50px;
  font-size:1rem; font-weight:700;
  cursor:pointer; font-family:inherit; letter-spacing:.03em;
  transition:background var(--tr), opacity var(--tr), transform var(--tr), box-shadow var(--tr);
  -webkit-tap-highlight-color:transparent;
  box-shadow:0 4px 20px var(--brand-strong);
  position:relative; overflow:hidden;
}
.btn::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(255,255,255,.12) 0%, transparent 55%);
  pointer-events:none;
}
.btn:active   { opacity:.88; transform:scale(.99); box-shadow:0 2px 8px var(--brand-glow); }
.btn:disabled { background:var(--bg4); color:var(--muted); cursor:not-allowed; transform:none; opacity:1; box-shadow:none; }

/* ═══════════════════════════════════════
   OK / ERROR
═══════════════════════════════════════ */
.ok { display:none; text-align:center; padding:12px 0 4px; }
.ok-ico {
  width:48px; height:48px; background:var(--ok-bg); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 10px; font-size:22px;
}
.err-box {
  background:var(--err-bg); border:1px solid rgba(248,113,113,.2);
  border-radius:var(--rs); padding:10px 14px;
  font-size:.85rem; color:var(--err); font-weight:500; display:none;
}
.err-box::before { content:'⚠ '; }

/* ═══════════════════════════════════════
   MODAL
═══════════════════════════════════════ */
.ov {
  display:none; position:fixed; inset:0;
  background:rgba(0,0,0,.6);
  backdrop-filter:blur(4px); -webkit-backdrop-filter:blur(4px);
  align-items:flex-end; justify-content:center; z-index:100;
}
.ov.on { display:flex; }

.mdl {
  background:var(--bg2); border:1px solid var(--border-md);
  border-radius:var(--rl) var(--rl) 0 0;
  width:100%; max-width:480px; max-height:80vh;
  display:flex; flex-direction:column; overflow:hidden;
  box-shadow:0 -4px 40px rgba(0,0,0,.4);
}

.mhd {
  display:flex; justify-content:space-between; align-items:center;
  flex-shrink:0; background:var(--bg2); padding:16px 16px 14px;
  border-bottom:1px solid var(--border);
}

#mbody { padding:0 16px 48px; overflow-y:auto; flex:1; min-height:0; }
.mttl  { font-size:1rem; font-weight:700; color:var(--text); letter-spacing:-.01em; }

.mcl {
  cursor:pointer; color:var(--muted);
  width:30px; height:30px;
  display:flex; align-items:center; justify-content:center;
  font-size:18px; line-height:1;
  border-radius:var(--rs); background:var(--bg3); border:1px solid var(--border-md);
  margin-left:8px; transition:background var(--tr), color var(--tr);
  -webkit-tap-highlight-color:transparent;
}
.mcl:active { background:var(--brand-tint); color:var(--brand-lt); }

.mrow {
  padding:12px 0; font-size:.95rem; cursor:pointer;
  color:var(--text); border-bottom:1px solid var(--border);
  display:flex; align-items:center; gap:12px;
  -webkit-tap-highlight-color:transparent; transition:background var(--tr);
}
.mrow:last-child { border-bottom:none; }
.mrow:active { background:var(--bg3); margin:0 -16px; padding:12px 16px; }

.mck {
  width:22px; height:22px; border-radius:50%;
  border:1.5px solid var(--border-md);
  display:inline-flex; align-items:center; justify-content:center;
  flex-shrink:0; font-size:11px; color:#fff; transition:all var(--tr);
}
.mck.on { background:var(--brand); border-color:var(--brand); box-shadow:0 0 8px var(--brand-glow); }

.msub { font-size:.78rem; color:var(--muted); margin-top:2px; }

.bk {
  font-size:.84rem; color:var(--brand-lt);
  cursor:pointer; margin-bottom:8px; margin-top:4px;
  display:inline-flex; align-items:center; gap:4px; font-weight:600;
  -webkit-tap-highlight-color:transparent; transition:opacity var(--tr);
}
.bk:active { opacity:.65; }

/* ═══════════════════════════════════════
   CONFIRMATION MODAL
═══════════════════════════════════════ */
.conf-ov {
  display:none; position:fixed; inset:0;
  background:rgba(0,0,0,.65);
  backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px);
  align-items:center; justify-content:center; z-index:200;
}
.conf-ov.on { display:flex; }

.conf-mdl {
  background:var(--bg2); border:1px solid var(--border-md);
  border-radius:var(--rl); padding:36px 28px 28px;
  width:calc(100% - 48px); max-width:300px; text-align:center;
  box-shadow:0 8px 48px rgba(0,0,0,.5);
}

.conf-spinner {
  width:48px; height:48px;
  border:3px solid var(--brand-tint); border-top-color:var(--brand);
  border-radius:50%; animation:spin .7s linear infinite;
  display:inline-block;
}
.conf-mdl .conf-spinner { margin:0 auto 16px; }   /* зберігаємо layout у success-модалці */
.conf-spinner.sm { width:20px; height:20px; border-width:2px; }
@keyframes spin { to { transform:rotate(360deg); } }

.conf-ico {
  width:60px; height:60px; background:var(--ok-bg);
  border:1px solid rgba(52,212,148,.2); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:28px; color:var(--ok); margin:0 auto 16px;
}

.conf-lbl { font-size:1rem; font-weight:600; color:var(--text); margin-bottom:20px; line-height:1.45; }
#conf-loading .conf-lbl { color:var(--muted); font-weight:500; font-size:.92rem; margin-bottom:0; }

/* ═══════════════════════════════════════
   TOGGLE BUTTON
═══════════════════════════════════════ */
.btn-toggle {
  display:flex; align-items:center; justify-content:center;
  width:100%; padding:11px 14px;
  font-size:.92rem; font-weight:600; color:var(--brand-lt);
  border:1px solid var(--border-md); border-radius:50px;
  background:var(--brand-tint); cursor:pointer; font-family:inherit;
  transition:all var(--tr); -webkit-tap-highlight-color:transparent; user-select:none;
}
.btn-toggle:active { opacity:.75; transform:scale(.99); }
.btn-toggle.on { background:var(--brand-lt); color:#fff; border-color:var(--brand-lt); }

#c-search-results > div:last-child { border-bottom:none; }

#pay-section { display:flex; flex-direction:column; gap:14px; }

/* ═══════════════════════════════════════
   GPS WRAP
═══════════════════════════════════════ */
.gps-wrap { display:flex; gap:8px; align-items:stretch; }
.gps-wrap .inp { flex:1; }

.gps-icon-btn {
  flex-shrink:0; width:46px;
  border:1px solid var(--border-md); border-radius:var(--rs);
  background:var(--bg3); cursor:pointer; color:var(--brand-lt);
  display:flex; align-items:center; justify-content:center;
  -webkit-tap-highlight-color:transparent;
  transition:border-color var(--tr), background var(--tr), box-shadow var(--tr);
}
.gps-icon-btn:hover  { border-color:var(--brand); background:var(--brand-tint); box-shadow:0 0 10px var(--brand-glow); }
.gps-icon-btn:disabled { opacity:.35; cursor:wait; animation:none; }

@keyframes gps-pulse {
  0%   { box-shadow: 0 0 0 0 var(--brand-strong); border-color:var(--brand); }
  70%  { box-shadow: 0 0 0 10px rgba(0,200,122,0); border-color:var(--brand); }
  100% { box-shadow: 0 0 0 0 rgba(0,200,122,0); border-color:var(--border-md); }
}
.gps-icon-btn.pulse {
  animation: gps-pulse 1.6s cubic-bezier(.4,0,.2,1) infinite;
}

/* ═══════════════════════════════════════
   FIX BUTTON (Зафіксувати матеріали)
   GPS-like colors, pill shape, no hover/active/disabled color changes.
   Reuses gps-pulse animation in active (dirty) state.
═══════════════════════════════════════ */
.fix-btn {
  width:100%; padding:12px 10px;
  margin-top:8px;
  background:var(--bg3); color:var(--brand-lt);
  border:1px solid var(--border-md); border-radius:50px;
  font:inherit; font-size:.88rem; font-weight:700; letter-spacing:.03em;
  cursor:pointer;
  -webkit-tap-highlight-color:transparent;
  transition:border-color var(--tr), box-shadow var(--tr);
}
.fix-btn:disabled { cursor:default; animation:none; }
.fix-btn.pulse {
  animation: gps-pulse 1.6s cubic-bezier(.4,0,.2,1) infinite;
}

/* ═══════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════ */
@media (min-width:600px) {
  body {
    display:flex; justify-content:center; align-items:flex-start;
    padding:32px 16px;
    background: radial-gradient(ellipse 80% 50% at 50% 0%, rgba(0,200,122,.07) 0%, transparent 65%), #09201A;
  }
  body.light {
    background: radial-gradient(ellipse 80% 50% at 50% 0%, rgba(0,200,122,.08) 0%, transparent 65%), #D8EDDF;
  }
  .wrap {
    max-width:480px;
    border-radius:var(--rl);
    border:1px solid var(--border-md);
    box-shadow:0 4px 40px rgba(0,0,0,.4), 0 0 60px rgba(0,200,122,.04);
    min-height:auto; overflow:hidden;
  }
  body.light .wrap { box-shadow:0 4px 40px rgba(0,0,0,.12), 0 0 60px rgba(0,200,122,.06); }
  .form    { padding:20px 24px; gap:12px; }
  #c-own-action, #c-accept-action { gap:20px; }
  #mbody   { padding:0 24px 48px; }
  .mhd     { padding:16px 24px 14px; }
  .mrow:active { margin:0 -24px; padding:12px 24px; }
  .pin-kbd { max-width:316px; gap:12px; }
  .pin-key { padding:18px; font-size:1.5rem; }
}

@media (max-width:424px) {
  .form         { padding:12px; gap:12px; }
  #c-own-action, #c-accept-action { gap:12px; }
  .inp          { font-size:.95rem; padding:10px 12px; }
  .btn          { padding:13px; font-size:.95rem; }
  .tab          { font-size:.82rem; padding:10px 0; }
  .lbl          { font-size:.65rem; }
  .popt         { font-size:.82rem; padding:10px 8px; }
  .fix-btn      { font-size:.82rem; padding:10px 8px; }
  .g-slim       { grid-template-columns:1fr; }
  .pin-kbd      { max-width:268px; gap:8px; }
  .pin-key      { padding:14px; font-size:1.2rem; }
  .pin-dot      { width:11px; height:11px; }
  .pin-title    { font-size:2.2rem; }
  .pin-screen   { gap:18px; padding:24px 16px; }
}

@media (max-width:360px) {
  .popt         { font-size:.78rem; padding:9px 6px; }
  .tab          { font-size:.78rem; padding:9px 0; }
  .fix-btn      { font-size:.78rem; padding:9px 6px; }
  .pin-title    { font-size:1.9rem; }
  .pin-kbd      { max-width:248px; }
  .pin-key      { padding:12px; font-size:1.1rem; }
}

/* ═══════════════════════════════════════
   LOADING BLOCK (Cash Власна / Cash Прийом / Бонуси)
   Spinner (.conf-spinner) + "Дані завантажуються" text.
═══════════════════════════════════════ */
.loading-block {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:12px; padding:32px 16px; color:var(--muted);
  border:1px solid var(--border-md); border-radius:var(--rs); background:var(--bg2);
}
.loading-text {
  font-size:.85rem; letter-spacing:.03em;
}

/* ============================================================
   F-2 / sub-batch 2A — extracted from index.html inline styles (2026-05-11)
   ============================================================ */

/* Form body — vertical column with 12px gap when visible */
#form-body { display:flex; flex-direction:column; gap:12px; }

/* Client block (under «Дані по клієнту») — vertical column with 14px gap when visible */
#client-block { display:flex; flex-direction:column; gap:14px; }

/* Referral block frame — tinted bordered padded box */
#referral-block {
  background:var(--bg2);
  border:1px solid var(--border-md);
  border-radius:var(--rs);
  padding:12px;
}

/* Order comment textarea — shorter min-height than default textarea.inp (76px) */
#works-comment { min-height:64px; }

/* Cash mode chips row — flex with small gap */
#c-mode-chips { display:flex; gap:8px; }

/* Total cost row — section-card-like frame with split alignment */
.total-row {
  background:var(--bg2);
  border:1px solid var(--border-md);
  border-radius:var(--rs);
  padding:12px 14px;
  display:flex;
  justify-content:space-between;
  align-items:center;
}
.total-row-lbl {
  font-size:.85rem;
  font-weight:600;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.05em;
}

/* Total cost amount (#f-total) — large brand-color number */
#f-total { font-size:1.1rem; font-weight:700; color:var(--brand); }

/* ============================================================
   F-2 / sub-batch 2B — extracted from app.js style.cssText (2026-05-11)
   ============================================================ */

/* Top warning banner (network/data load failure — top of #main) */
.top-warn-banner {
  background:var(--warn-bg); color:var(--warn);
  padding:8px 14px; font-size:.8rem;
  border-bottom:1px solid var(--warn-border); text-align:center;
}

/* Modal search input wrapper */
.modal-search-wrap {
  padding:12px 14px 8px;
  border-bottom:1px solid var(--border);
}

/* Modal empty/loading message (centered, larger padding) */
.modal-empty-msg {
  padding:20px; text-align:center;
  color:var(--muted); font-size:.9rem;
}

/* Materials block top header (with border-bottom divider above materials list) */
.materials-hdr-title {
  width:100%; font-size:.68rem; font-weight:700; color:var(--muted);
  text-transform:uppercase; letter-spacing:.09em;
  padding-bottom:6px; border-bottom:1px solid var(--border);
  margin-bottom:2px;
}

/* Group header (Equipment type / Materials type — uppercase muted label) */
.group-hdr-row {
  font-size:.75rem; font-weight:700; color:var(--muted);
  text-transform:uppercase; letter-spacing:.05em;
  padding:4px 0 2px; width:100%;
}

/* Tag row (material/equipment item — flex row with quantity input on the right) */
.tag-row {
  display:flex; align-items:center; gap:6px;
  width:100%; box-sizing:border-box;
}
.tag-label {
  flex:1; white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}

/* Quantity input (works-qty-inp and eq-qty-inp share this) */
.qty-inp {
  width:68px; padding:2px 5px;
  border:1px solid var(--border); border-radius:4px;
  font:inherit; font-size:.82rem; text-align:center;
  color:var(--text); background:var(--bg);
}

/* Section empty message (compact, inline in cash/bonus blocks — no padding) */
.section-empty-msg {
  color:var(--muted); font-size:.9rem; text-align:center;
  padding:8px 0;
}

/* Vertical flex column with 4px gap — cash/bonus month list wrapper */
.col-gap-4 { display:flex; flex-direction:column; gap:4px; }

/* Cash total-summary row («До прийому» / «До закриття») */
.cash-total-row {
  display:flex; justify-content:space-between; align-items:center;
  padding:10px 12px;
  background:var(--brand-tint);
  border-radius:var(--rs);
  border:1px solid var(--border-md);
}

/* Month card (cash/bonus month card with header + collapsible detail) */
.month-card {
  border:1px solid var(--border-md);
  border-radius:var(--rs);
  overflow:hidden;
}
.month-card.is-all { margin-top:4px; }

/* Month row (header inside month card — clickable by default; .is-all = grand-total style, non-clickable) */
.month-row {
  display:flex; justify-content:space-between; align-items:center;
  padding:10px 12px;
  background:var(--bg2); cursor:pointer;
}
.month-row.is-all {
  background:var(--brand-tint);
  cursor:default;
}

/* Detail container (expandable — display toggled via JS .style.display) */
.detail-col {
  flex-direction:column;
}

/* Detail line (row inside expanded detail — fixed line items) */
.detail-line {
  display:flex; justify-content:space-between; align-items:center;
  padding:10px 12px;
  border-top:1px solid var(--border);
}

/* Month footer (final row inside expanded detail — «Каса» / «Непокрита витрата» / «Загально»; default brand-tint bg, .pickable = clickable) */
.month-footer {
  display:flex; justify-content:space-between; align-items:center;
  padding:10px 12px;
  border-top:1px solid var(--border-md);
  background:var(--brand-tint);
}
.month-footer.pickable { cursor:pointer; }

/* ============================================================
   F-2 / F-5 / sub-batch 2C-1 — extracted from app.js innerHTML templates (2026-05-11)
   ============================================================ */

/* Modal row info column (flex:1 grow — wraps title + subtitle) */
.modal-row-info { flex:1; }

/* Modal row title (network name / equipment type — bold) */
.modal-row-title { font-weight:600; }

/* Modal row subtitle (person name / equipment item — semi-bold) */
.modal-row-subtitle { font-weight:500; }

/* Counter inline "· N обрано" — brand color */
.modal-row-count { color:var(--brand); }

/* Chevron › on modal rows */
.modal-row-chev { font-size:1.2rem; color:var(--muted); }

/* "я" self badge — small pill marking current user inside person rows / tags */
.self-badge {
  font-size:.7rem;
  background:var(--brand-lt); color:#fff;
  border-radius:10px;
  padding:1px 7px;
  vertical-align:middle;
  margin-left:2px;
}

/* Retry link inside "Не вдалось завантажити" message */
.retry-link {
  color:var(--brand);
  cursor:pointer;
  font-weight:600;
}

/* Equipment-picker inline qty input wrapper (inside modal row when item is selected) */
.eq-pick-qty-wrap { margin-top:6px; }
.eq-pick-qty-inp {
  width:100px; padding:4px 8px;
  border:1.5px solid var(--border); border-radius:var(--rs);
  font:inherit;
}

/* ============================================================
   F-2 / F-5 / sub-batch 2C-2 — extracted from cash + bonus rendering (2026-05-11)
   ============================================================ */

/* Cash total-row content («До закриття» / «До прийому» — inside .cash-total-row) */
.cash-total-row-lbl {
  font-size:.85rem; font-weight:700; color:var(--brand);
  text-transform:uppercase; letter-spacing:.05em;
}
.cash-total-row-amt {
  font-size:1.1rem; font-weight:700; color:var(--brand);
}

/* Month row label — name of month (inside .month-row) */
.month-row-lbl {
  font-weight:500; font-size:.9rem; color:var(--text);
}
.month-row-lbl.is-all { font-weight:700; }

/* Month row right side container (amount + chevron) */
.month-row-right {
  display:flex; align-items:center; gap:8px;
}

/* Month row amount (hidden when expanded) — default text, .warn for uncovered */
.month-row-amt {
  font-weight:700; color:var(--text);
}
.month-row-amt.warn { color:var(--warn); }

/* Month row grand-total amount (isAll branch — fixed brand color) */
.month-row-amt-grand {
  font-weight:700; color:var(--brand);
}

/* Month row chevron ▸/▾ */
.month-row-chev {
  font-size:.8rem; color:var(--muted);
}

/* Detail line content (inside .detail-line) — label + value */
.detail-line-lbl {
  font-size:.85rem; color:var(--muted);
}
.detail-line-val {
  font-size:.9rem; font-weight:600; color:var(--text);
}
.detail-line-val.warn { color:var(--warn); }

/* Month footer content («Каса» / «Непокрита витрата» / «Загально» — inside .month-footer) */
.month-footer-lbl, .month-footer-amt {
  font-weight:700; color:var(--brand);
}
.month-footer-lbl {
  font-size:.85rem;
  text-transform:uppercase; letter-spacing:.05em;
}
.month-footer-amt { font-size:.95rem; }
.month-footer-amt.sm { font-size:.9rem; }  /* bonus footer slightly smaller than cash */

/* Modifier states for cash footer content (mutually exclusive: uncovered XOR selected) */
.month-footer-lbl.warn, .month-footer-amt.warn { color:var(--warn); }
.month-footer-lbl.on-brand, .month-footer-amt.on-brand { color:var(--on-brand); }

/* ═══════════════════════════════════════
   BILLING PASTE (Швидке заповнення з тексту білінгу)
   - One-line textarea looking like .inp, but preserves \n in pasted text
   - Hint message: success (ok) / error (warn)
═══════════════════════════════════════ */
textarea.inp.inp-oneline {
  resize:none;
  min-height:0;
  overflow:hidden;
  white-space:nowrap;
}
.billing-hint {
  margin-top:8px;
  padding:8px 10px;
  border-radius:var(--rs);
  font-size:.82rem;
  text-align:center;
}
.billing-hint.ok {
  background:var(--ok-bg);
  color:var(--ok);
  border:1px solid var(--ok);
}
.billing-hint.warn {
  background:var(--warn-bg);
  color:var(--warn);
  border:1px solid var(--warn-border);
}
