:root{--bg: oklch(.97 .012 75);--bg-elev: oklch(.99 .008 80);--bg-sunk: oklch(.94 .014 75);--line: oklch(.86 .018 70);--line-soft: oklch(.91 .014 72);--ink: oklch(.22 .018 50);--ink-2: oklch(.42 .022 50);--ink-3: oklch(.58 .02 55);--accent: oklch(.58 .14 38);--accent-soft: oklch(.92 .05 55);--accent-ink: oklch(.42 .13 38);--warn: oklch(.6 .15 55);--good: oklch(.55 .1 145);--bad: oklch(.55 .18 25);--shadow: 0 1px 0 oklch(0 0 0 / .04), 0 1px 3px oklch(0 0 0 / .04);--shadow-lg: 0 1px 0 oklch(0 0 0 / .04), 0 16px 40px -12px oklch(0 0 0 / .18);--radius: 4px;--radius-lg: 8px;--font-display: "Fraunces", "Iowan Old Style", Georgia, serif;--font-sans: "Geist", "Helvetica Neue", Helvetica, system-ui, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace}[data-theme=dark]{--bg: oklch(.18 .012 55);--bg-elev: oklch(.22 .014 55);--bg-sunk: oklch(.15 .012 55);--line: oklch(.32 .018 55);--line-soft: oklch(.26 .014 55);--ink: oklch(.94 .012 75);--ink-2: oklch(.74 .018 70);--ink-3: oklch(.58 .018 65);--accent: oklch(.72 .14 42);--accent-soft: oklch(.3 .05 40);--accent-ink: oklch(.8 .14 42);--shadow: 0 1px 0 oklch(0 0 0 / .3);--shadow-lg: 0 1px 0 oklch(0 0 0 / .3), 0 20px 40px -12px oklch(0 0 0 / .6)}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--font-sans);font-feature-settings:"ss01","cv11";-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.45;transition:background .2s ease,color .2s ease}button{font:inherit;color:inherit;background:none;border:none;cursor:pointer;padding:0}input,textarea,select{font:inherit;color:inherit}.app{display:grid;grid-template-columns:248px 1fr;height:100vh;overflow:hidden}.sidebar{background:var(--bg-sunk);border-right:1px solid var(--line);display:flex;flex-direction:column;padding:22px 16px 14px;overflow:hidden}.brand{display:flex;align-items:baseline;gap:8px;padding:0 6px 28px}.brand-mark{width:30px;height:30px;border-radius:50%;background:var(--ink);color:var(--bg);display:grid;place-items:center;align-self:center}.brand-mark svg{width:18px;height:18px}.login-mark{color:var(--ink);display:block;margin:0 auto 16px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.brand-name{font-family:var(--font-display);font-size:22px;font-weight:400;letter-spacing:-.01em}.brand-name em{font-style:italic;font-weight:400;color:var(--accent-ink)}.brand-sub{font-family:var(--font-mono);font-size:10px;color:var(--ink-3);margin-left:auto;text-transform:uppercase;letter-spacing:.08em;align-self:center}.nav-label{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-3);padding:14px 8px 6px}.nav-item{display:flex;align-items:center;gap:10px;width:100%;padding:8px 10px;border-radius:var(--radius);color:var(--ink-2);font-size:14px;text-align:left;transition:background .12s,color .12s;position:relative}.nav-item:hover{background:var(--line-soft);color:var(--ink)}.nav-item.active{background:var(--bg-elev);color:var(--ink);box-shadow:var(--shadow)}.nav-item.active:before{content:"";position:absolute;left:-16px;top:8px;bottom:8px;width:2px;background:var(--accent)}.nav-item-icon{width:18px;height:18px;color:var(--ink-3);flex-shrink:0}.nav-item.active .nav-item-icon{color:var(--accent)}.nav-count{margin-left:auto;font-family:var(--font-mono);font-size:11px;color:var(--ink-3)}.sidebar-foot{margin-top:auto;padding-top:14px;border-top:1px solid var(--line-soft);display:flex;flex-direction:column;align-items:stretch;gap:10px}.theme-toggle{display:flex;border:1px solid var(--line);border-radius:999px;padding:2px;background:var(--bg)}.theme-toggle button{padding:5px 9px;border-radius:999px;font-size:11px;color:var(--ink-3);display:flex;align-items:center;gap:4px}.theme-toggle button svg{width:12px;height:12px}.theme-toggle button.on{background:var(--ink);color:var(--bg)}.user-chip{display:flex;align-items:center;gap:10px;width:100%;padding:7px 9px;border-radius:var(--radius);border:1px solid transparent;background:transparent;color:var(--ink-2);text-align:left;transition:background .12s,border-color .12s;overflow:hidden}.user-chip:hover{background:var(--line-soft);color:var(--ink)}.user-chip.active{background:var(--bg-elev);border-color:var(--line);color:var(--ink);box-shadow:var(--shadow)}.user-chip-meta{display:flex;flex-direction:column;min-width:0;line-height:1.25}.user-chip-name{font-size:13px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-chip-hint{font-family:var(--font-mono);font-size:9.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3)}.user-avatar{width:30px;height:30px;flex-shrink:0;border-radius:50%;background:var(--accent-soft);color:var(--accent-ink);display:grid;place-items:center;font-family:var(--font-display);font-size:14px;font-style:italic}.main{display:flex;flex-direction:column;overflow:hidden;position:relative}.topbar{display:flex;align-items:center;gap:14px;padding:16px 32px;border-bottom:1px solid var(--line);background:var(--bg);flex-shrink:0}.page-title{font-family:var(--font-display);font-size:24px;font-weight:400;letter-spacing:-.015em;color:var(--ink);margin:0}.page-title em{font-style:italic;color:var(--accent-ink);font-weight:400}.page-sub{font-family:var(--font-mono);font-size:11px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.08em}.topbar-right{margin-left:auto;display:flex;gap:10px;align-items:center}.btn{padding:7px 14px;border-radius:var(--radius);border:1px solid var(--line);background:var(--bg-elev);color:var(--ink);font-size:13px;display:inline-flex;align-items:center;gap:6px;transition:background .12s,border-color .12s}.btn:hover{background:var(--bg-sunk)}.btn-primary{background:var(--ink);color:var(--bg);border-color:var(--ink)}.btn-primary:hover{background:var(--ink-2);border-color:var(--ink-2)}.btn-ghost{border-color:transparent;background:transparent;color:var(--ink-2)}.btn-ghost:hover{background:var(--bg-sunk);color:var(--ink)}.btn svg{width:14px;height:14px}.toolbar{display:flex;align-items:center;gap:12px;padding:14px 32px;border-bottom:1px solid var(--line);background:var(--bg);flex-shrink:0}.range-pills{display:flex;border:1px solid var(--line);border-radius:var(--radius);padding:2px;background:var(--bg-elev)}.range-pills button{padding:5px 11px;font-size:12px;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3);border-radius:3px}.range-pills button.on{background:var(--ink);color:var(--bg)}.raw-toggle{display:inline-flex;align-items:center;gap:8px;padding:5px 11px 5px 8px;font-size:12px;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3);border:1px solid var(--line);border-radius:var(--radius);background:var(--bg-elev);cursor:pointer}.raw-toggle:hover{color:var(--ink-2)}.raw-toggle.on{color:var(--ink);border-color:color-mix(in oklch,var(--accent) 55%,var(--line))}.raw-toggle .switch{position:relative;width:26px;height:14px;border-radius:999px;background:var(--line);transition:background .15s ease;flex-shrink:0}.raw-toggle.on .switch{background:var(--accent)}.raw-toggle .knob{position:absolute;top:2px;left:2px;width:10px;height:10px;border-radius:50%;background:var(--bg-elev);transition:transform .15s ease}.raw-toggle.on .knob{transform:translate(12px)}.date-range{display:flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:11px;color:var(--ink-3)}.date-range input{background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius);padding:5px 8px;font-family:var(--font-mono);font-size:11px;color:var(--ink);width:130px}.search{margin-left:auto;position:relative;width:320px}.search input{width:100%;background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius);padding:7px 10px 7px 30px;font-size:13px}.search input:focus{outline:2px solid var(--accent-soft);outline-offset:-1px;border-color:var(--accent)}.search svg{position:absolute;left:9px;top:50%;transform:translateY(-50%);width:14px;height:14px;color:var(--ink-3)}.canvas{flex:1;overflow:auto;padding:32px}.timeline-wrap{max-width:760px;margin:0 auto;position:relative;padding-left:40px}.timeline-rail{position:absolute;left:11px;top:6px;bottom:24px;width:1px;background:linear-gradient(to bottom,transparent 0,var(--line) 8%,var(--line) 92%,transparent 100%)}.day-group{margin-bottom:28px}.day-marker{display:flex;align-items:center;gap:12px;position:relative;margin-left:-40px;padding-left:0;margin-bottom:14px}.day-dot{width:22px;height:22px;border-radius:50%;background:var(--bg);border:1px solid var(--line);display:grid;place-items:center;flex-shrink:0;position:relative;z-index:1}.day-dot:after{content:"";width:6px;height:6px;border-radius:50%;background:var(--ink-3)}.day-group.today .day-dot{border-color:var(--accent)}.day-group.today .day-dot:after{background:var(--accent)}.day-label{font-family:var(--font-display);font-style:italic;font-size:18px;color:var(--ink);font-weight:400}.day-label-date{font-family:var(--font-mono);font-size:11px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.08em}.day-rule{flex:1;height:1px;background:var(--line-soft)}.note-card{background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius-lg);padding:18px 20px;margin-bottom:12px;box-shadow:var(--shadow);position:relative;transition:border-color .12s,transform .12s}.note-card:hover{border-color:var(--ink-3);cursor:pointer}.note-card:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.note-prose{font-size:14.5px;line-height:1.65;color:var(--ink);white-space:pre-wrap;margin:12px 0 2px;padding:12px 14px;background:color-mix(in oklch,var(--accent-soft) 35%,var(--bg-sunk));border-left:2px solid var(--accent);border-radius:var(--radius)}.timeline-wrap--wide{max-width:900px}.note-card:before{content:"";position:absolute;left:-29px;top:24px;width:17px;height:1px;background:var(--line)}.note-head{display:flex;align-items:baseline;gap:10px;margin-bottom:10px}.note-animal{font-family:var(--font-display);font-size:20px;font-weight:400;letter-spacing:-.01em}.note-animal em{font-style:italic}.note-meta{font-family:var(--font-mono);font-size:11px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.06em;display:inline-flex;align-items:center;gap:6px;flex-wrap:wrap}.note-meta-item{display:inline-flex;align-items:center;gap:5px}.note-meta-icon{width:12px;height:12px;color:var(--accent-ink);flex-shrink:0;opacity:.85}.note-meta-sep{color:var(--line);font-weight:400}.note-time{margin-left:auto;font-family:var(--font-mono);font-size:11px;color:var(--ink-3)}.note-kind-pill{font-family:var(--font-mono);font-size:9px;text-transform:uppercase;letter-spacing:.1em;padding:2px 6px;border-radius:3px;background:var(--accent-soft);color:var(--accent-ink)}.note-kind-pill.imaging{background:#c8ebf7;color:#00566a;color:oklch(.42 .13 220)}[data-theme=dark] .note-kind-pill.imaging{background:#012e3a;color:#44d7ff;color:oklch(.82 .14 220)}.note-kind-pill.shoeing{background:#ceefd3;color:#005725}[data-theme=dark] .note-kind-pill.shoeing{background:#15301b;color:#7cd591}.note-card--detailed .note-meta{margin:0 0 4px}.note-empty-body{font-size:13px;font-style:italic;color:var(--ink-3);margin:8px 0 2px}.note-body{display:grid;grid-template-columns:max-content 1fr;gap:8px 18px;margin:14px 0 4px;font-size:14px;line-height:1.6}.note-body dt{font-family:var(--font-mono);font-size:10px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.08em;padding-top:9px;align-self:start}.note-body dd{margin:0;color:var(--ink);padding:7px 12px;background:color-mix(in oklch,var(--accent-soft) 22%,var(--bg-sunk));border-left:2px solid color-mix(in oklch,var(--accent) 60%,transparent);border-radius:var(--radius)}.note-body dd em{color:var(--accent-ink);font-style:italic;font-weight:500}.note-raw{margin:12px 0 2px}.note-raw>summary{font-family:var(--font-mono);font-size:10px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.08em;cursor:pointer;list-style:none;display:inline-flex;align-items:center;gap:6px;-webkit-user-select:none;user-select:none}.note-raw>summary::-webkit-details-marker{display:none}.note-raw>summary:before{content:"▸";font-size:9px;transition:transform .15s ease}.note-raw[open]>summary:before{transform:rotate(90deg)}.note-raw>summary:hover{color:var(--ink-2)}.note-raw--static .note-raw-label{font-family:var(--font-mono);font-size:10px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.08em}.note-raw-body{margin-top:8px;font-size:13px;line-height:1.6;color:var(--ink-2);padding:7px 12px;background:var(--bg-sunk);border-left:2px solid var(--line);border-radius:var(--radius);white-space:pre-wrap}.attach-row{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-top:14px;padding-top:14px;border-top:1px dashed var(--line)}.attach-download-all{display:inline-flex;align-items:center;gap:6px;height:30px;padding:0 12px;border-radius:999px;border:1px solid var(--line);background:var(--bg-elev);color:var(--ink-2);font-size:12px;font-family:inherit;cursor:pointer;transition:border-color .12s,color .12s,background .12s}.attach-download-all:hover{border-color:var(--accent);color:var(--ink)}.attach-download-all svg{width:14px;height:14px}.thumb{width:120px;height:90px;border-radius:var(--radius);border:1px solid var(--line);background:var(--bg-sunk);overflow:hidden;position:relative;cursor:pointer;flex-shrink:0;transition:transform .12s,border-color .12s;padding:0}.thumb:hover{transform:translateY(-1px);border-color:var(--accent)}.thumb-fill{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;display:block}img.thumb-fill{object-fit:cover}.thumb--photo .thumb-label{display:none}.thumb-fill.radio{background:radial-gradient(circle at 40% 50%,#43494d,#141618,#030303 70%),#020202}.thumb-fill.ultrasound{background:radial-gradient(ellipse at 50% 100%,#a8c4c5,#657576,#282f30,#141717,#030303 80%)}.thumb-fill.wound{background:radial-gradient(circle at 60% 40%,#b54a46,#cb8d7d 40%,#795b56)}.thumb-fill.chart{background:var(--bg-elev)}.thumb-fill.chart:after{content:"";position:absolute;top:8px;right:8px;bottom:8px;left:8px;background:linear-gradient(to right,oklch(.7 .02 50) 1px,transparent 1px) 0 0 / 8px 100%,linear-gradient(to bottom,oklch(.7 .02 50) 1px,transparent 1px) 0 0 / 100% 8px;opacity:.4}.thumb-fill.field{background:linear-gradient(to bottom,#abd4f2,#89a2b5 40%,#708a56 41%,#506e2c)}.thumb-fill.pdf{background:var(--bg-elev);display:grid;place-items:center}.thumb-fill.pdf:after{content:"PDF";font-family:var(--font-mono);font-size:14px;font-weight:500;color:var(--accent-ink);letter-spacing:.05em}.thumb-label{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,oklch(0 0 0 / .7),transparent);color:#fff;font-family:var(--font-mono);font-size:9px;padding:10px 6px 4px;letter-spacing:.05em;text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.thumb-fill.pdf+.thumb-label,.thumb-fill.chart+.thumb-label{color:var(--ink-2);background:linear-gradient(to top,var(--bg-elev),transparent)}.empty{text-align:center;padding:80px 20px;color:var(--ink-3)}.empty-title{font-family:var(--font-display);font-style:italic;font-size:22px;color:var(--ink-2);margin-bottom:6px}.empty-sub{font-size:13px}.entity-grid{max-width:1100px;margin:0 auto}.entity-head{display:flex;align-items:baseline;margin-bottom:22px;gap:14px}.entity-head h2{font-family:var(--font-display);font-size:28px;font-weight:400;letter-spacing:-.02em;margin:0}.entity-head h2 em{font-style:italic;color:var(--accent-ink)}.entity-count{font-family:var(--font-mono);font-size:12px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.08em}.tbl{width:100%;border-collapse:collapse;background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden}.tbl th{text-align:left;font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-3);padding:12px 16px;border-bottom:1px solid var(--line);background:var(--bg-sunk)}.tbl td{padding:14px 16px;border-bottom:1px solid var(--line-soft);font-size:13.5px}.tbl tr:last-child td{border-bottom:none}.tbl tr:hover td{background:var(--bg-sunk)}.tbl-clickable tbody tr{cursor:pointer;transition:background .12s ease}.tbl-clickable tbody tr:hover td{background:color-mix(in oklch,var(--accent) 7%,var(--bg-sunk))}.reminder-clickable{cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}.reminder-clickable:hover{transform:translateY(-1px);border-color:var(--accent);box-shadow:var(--shadow-lg, var(--shadow))}.tbl .name{font-family:var(--font-display);font-size:16px;font-weight:400}.tbl .mono{font-family:var(--font-mono);font-size:12px;color:var(--ink-2)}.sex-pill{display:inline-flex;align-items:center;gap:4px;font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3)}.sex-pill:before{content:"";width:6px;height:6px;border-radius:50%}.sex-pill.male:before{background:#009cce;background:oklch(.65 .13 230)}.sex-pill.female:before{background:#c16aba}.sex-pill.unknown:before{background:var(--ink-3)}.reminders-list{max-width:780px;margin:0 auto;display:flex;flex-direction:column;gap:10px}.reminder{display:grid;grid-template-columns:80px 1fr auto auto;gap:18px;align-items:center;padding:16px 20px;background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow)}.reminder--done{opacity:.55;background:var(--bg)}.reminder--done .reminder-title{text-decoration:line-through}.reminder-actions{display:flex;gap:6px;align-items:center}.btn-sm{padding:6px 12px;font-size:12px;font-family:var(--font-mono);letter-spacing:.02em;border-radius:var(--radius);cursor:pointer;border:1px solid var(--line);background:var(--bg-elev);color:var(--ink)}.btn-sm:hover{border-color:var(--accent)}.reminder-action-done{background:var(--accent);color:var(--bg);border-color:var(--accent)}.reminder-action-done:hover{filter:brightness(1.05);border-color:var(--accent)}.reminder--done .reminder-actions{opacity:.8}.reminders-section-header{margin-top:12px;padding:10px 4px;font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3);cursor:pointer;-webkit-user-select:none;user-select:none;display:flex;gap:8px;align-items:center;border-top:1px solid var(--line-soft)}.reminders-section-toggle{font-size:12px}.reminder-date{text-align:center;padding-right:18px;border-right:1px solid var(--line-soft)}.reminder-date .day{font-family:var(--font-display);font-size:28px;font-weight:400;line-height:1;display:block}.reminder-date .month{font-family:var(--font-mono);font-size:10px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.1em;margin-top:4px;display:block}.reminder-date .delta{font-family:var(--font-mono);font-size:10px;color:var(--accent-ink);margin-top:2px;display:block}.reminder-title{font-size:14.5px;color:var(--ink)}.reminder-meta{font-family:var(--font-mono);font-size:11px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.06em;margin-top:3px}.priority-flag{display:flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-3)}.priority-flag:before{content:"";width:8px;height:8px;border-radius:2px}.priority-flag.high:before{background:var(--bad)}.priority-flag.medium:before{background:var(--warn)}.priority-flag.low:before{background:var(--good)}.modal-veil{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:grid;place-items:center;padding:24px;z-index:100;animation:veil-in .15s ease}@keyframes veil-in{0%{opacity:0}}.modal{width:100%;max-width:620px;background:var(--bg);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-height:92vh;display:flex;flex-direction:column;overflow:hidden;animation:modal-in .18s ease}@keyframes modal-in{0%{transform:translateY(8px);opacity:0}}.modal-head{display:flex;align-items:center;padding:18px 22px;border-bottom:1px solid var(--line)}.modal-title{font-family:var(--font-display);font-size:22px;font-weight:400;letter-spacing:-.01em}.modal-title em{font-style:italic;color:var(--accent-ink)}.modal-close{margin-left:auto;color:var(--ink-3);padding:6px;border-radius:4px}.modal-close:hover{background:var(--bg-sunk);color:var(--ink)}.modal-close svg{width:16px;height:16px}.lightbox-close svg{width:22px;height:22px}.modal-body{padding:20px 22px;overflow:auto;flex:1}.modal-foot{display:flex;gap:10px;padding:14px 22px;border-top:1px solid var(--line);background:var(--bg-sunk)}.modal-foot .spacer{flex:1}.form-section{margin-bottom:22px}.form-section-label{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-3);margin-bottom:10px;display:flex;align-items:center;gap:8px}.form-section-label:after{content:"";flex:1;height:1px;background:var(--line-soft)}.field{display:flex;flex-direction:column;gap:5px;margin-bottom:12px}.field-row{display:grid;gap:12px}.field-row.cols-2{grid-template-columns:1fr 1fr}.field-row.cols-3{grid-template-columns:2fr 1fr 1fr}.field label{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3)}.field input,.field select,.field textarea{background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius);padding:8px 10px;font-size:13.5px;color:var(--ink);font-family:var(--font-sans)}.field textarea{resize:vertical;min-height:70px;line-height:1.5}.field input:focus,.field select:focus,.field textarea:focus{outline:2px solid var(--accent-soft);outline-offset:-1px;border-color:var(--accent)}.combo{position:relative}.combo-list{position:absolute;top:100%;left:0;right:0;background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius);margin-top:4px;box-shadow:var(--shadow-lg);z-index:10;max-height:200px;overflow:auto}.combo-item{display:block;width:100%;text-align:left;padding:8px 10px;font-size:13px;border-radius:0}.combo-item:hover,.combo-item.hl{background:var(--bg-sunk)}.combo-item em{font-style:italic;color:var(--accent-ink)}.combo-item .meta{font-family:var(--font-mono);font-size:10px;color:var(--ink-3);margin-left:6px}.combo-new{border-top:1px solid var(--line-soft);color:var(--accent-ink)}.upload-zone{border:1px dashed var(--line);border-radius:var(--radius);padding:18px;text-align:center;color:var(--ink-3);font-size:12px;font-family:var(--font-mono);letter-spacing:.05em;background:var(--bg-sunk)}.upload-zone svg{width:18px;height:18px;margin-bottom:6px;opacity:.7}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000eb;z-index:200;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:64px 40px;animation:veil-in .15s}.lightbox-img{width:min(1100px,92vw);height:min(800px,78vh);border-radius:4px;border:1px solid oklch(0 0 0 / .5);background:#000;position:relative;overflow:hidden;flex:0 1 auto}.lightbox-caption{position:static;text-align:center;font-family:var(--font-mono);font-size:11px;color:#bebebe;letter-spacing:.08em;text-transform:uppercase}.lightbox-close{position:absolute;top:24px;right:24px;color:#fff;background:#0006;border:0;border-radius:50%;width:36px;height:36px;display:grid;place-items:center;cursor:pointer;z-index:2}.lightbox-action{position:absolute;top:24px;color:#fff;background:#0006;border:0;border-radius:50%;width:36px;height:36px;display:grid;place-items:center;cursor:pointer;z-index:2;transition:background .12s}.lightbox-action:hover{background:#000000b3}.lightbox-action svg{width:18px;height:18px}.lightbox-action--download{right:72px}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;background:#00000073;color:#fff;border:0;display:grid;place-items:center;cursor:pointer;z-index:2;transition:background .12s,transform .12s}.lightbox-nav:hover{background:#000000b3}.lightbox-nav:active{transform:translateY(-50%) scale(.95)}.lightbox-nav--prev{left:24px}.lightbox-nav--next{right:24px}.lightbox-nav svg{width:26px;height:26px}.lightbox-counter{position:absolute;top:24px;left:50%;transform:translate(-50%);color:#fff;font-family:var(--font-mono);font-size:12px;letter-spacing:.1em;background:#00000073;padding:6px 14px;border-radius:999px;z-index:2}.lightbox-toolbar{display:flex;align-items:center;gap:4px;background:#0000008c;padding:6px 10px;border-radius:999px;color:#fff}.lightbox-toolbar button{width:32px;height:32px;display:grid;place-items:center;color:#fff;background:transparent;border:0;border-radius:50%;cursor:pointer}.lightbox-toolbar button:hover{background:#ffffff26}.lightbox-toolbar svg{width:18px;height:18px}.lightbox-scale{font-family:var(--font-mono);font-size:12px;min-width:52px;text-align:center;letter-spacing:.05em}@media (max-width: 640px){.lightbox{padding:56px 8px}.lightbox-nav--prev{left:8px}.lightbox-nav--next{right:8px}.lightbox-nav{width:40px;height:40px}}.canvas::-webkit-scrollbar,.modal-body::-webkit-scrollbar{width:10px}.canvas::-webkit-scrollbar-thumb,.modal-body::-webkit-scrollbar-thumb{background:var(--line);border-radius:10px;border:3px solid var(--bg)}.mobile-nav-trigger{display:none;position:absolute;top:18px;left:16px;width:36px;height:36px;border-radius:6px;border:1px solid var(--line);background:var(--bg-elev);color:var(--ink);place-items:center;z-index:30}.mobile-nav-trigger svg{width:18px;height:18px}.sidebar-close-mobile{display:none;margin-left:auto;color:var(--ink-3);padding:6px;border-radius:4px;align-self:center}.sidebar-close-mobile svg{width:18px;height:18px}.sidebar-veil{display:none}@media (max-width: 900px){.app{grid-template-columns:1fr}.sidebar{position:fixed;top:0;bottom:0;left:0;width:280px;z-index:50;transform:translate(-100%);transition:transform .22s ease;border-right:1px solid var(--line);box-shadow:var(--shadow-lg)}.sidebar--open{transform:translate(0)}.sidebar-veil{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:40;animation:veil-in .15s ease}.sidebar-close-mobile{display:grid;place-items:center}.mobile-nav-trigger{display:grid}.topbar{padding:14px 16px 14px 64px;gap:10px;flex-wrap:wrap}.topbar-right{margin-left:auto}.toolbar{padding:12px 16px;flex-wrap:wrap;gap:10px}.search{margin-left:0;width:100%;order:99}.canvas{padding-left:16px;padding-right:16px}}@media (max-width: 640px){.page-title{font-size:20px}.topbar{padding:12px 14px 12px 60px}.topbar-right .btn{padding:6px 10px;font-size:12px}.range-pills button{padding:4px 8px;font-size:11px}.date-range{width:100%;flex-wrap:wrap}.date-range input{width:100%;flex:1}.entity-grid{max-width:none}.reminder{grid-template-columns:64px 1fr;gap:12px;padding:14px}.reminder .priority-flag{grid-column:1 / -1;justify-self:flex-start}.reminder-actions{grid-column:1 / -1;justify-content:flex-end}.modal-veil{padding:0;height:100vh;height:100dvh;min-height:100vh;min-height:100dvh;align-items:stretch}.modal{max-width:100vw;width:100vw;max-height:100vh;max-height:100dvh;height:100vh;height:100dvh;border-radius:0;border:none;min-width:0;overflow-x:hidden}.modal-head{padding:14px 16px;padding-top:calc(14px + env(safe-area-inset-top,0px));min-width:0}.modal-title{font-size:18px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.modal-body{padding:16px;overflow-x:hidden}.modal-body *{max-width:100%}.modal-body input,.modal-body select,.modal-body textarea{max-width:100%;box-sizing:border-box}.modal-foot{padding:12px 16px;padding-bottom:calc(12px + env(safe-area-inset-bottom,0px));flex-wrap:wrap}.modal-foot .btn{flex:1 1 auto;min-width:0}.field-row.cols-2,.field-row.cols-3{grid-template-columns:1fr}.timeline-wrap,.timeline-wrap--wide{max-width:100%;padding-left:0;padding-right:0}.note-card{padding:16px}.sidebar{width:86%}}.canvas::-webkit-scrollbar-track{background:transparent}.billing-shell{flex:1;overflow:auto;padding:24px 32px;width:100%;box-sizing:border-box}.billing-shell>*{max-width:1280px;margin-left:auto;margin-right:auto}.billing-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-bottom:16px}.billing-header h1{margin:0;font-size:24px}.billing-tabs{display:flex;gap:4px;border-bottom:1px solid var(--line-soft);flex:1}.billing-tab{background:transparent;border:none;padding:10px 18px;color:var(--ink-3);cursor:pointer;border-bottom:2px solid transparent;font-size:14px}.billing-tab.active{color:var(--ink);border-bottom-color:var(--accent);font-weight:600}.billing-loading,.billing-error,.billing-success,.billing-onboarding{padding:12px 16px;border-radius:8px;margin-bottom:12px}.billing-loading{color:var(--ink-3)}.billing-error{background:#dc46461a;color:var(--bad, #c33);border:1px solid rgba(220,70,70,.3)}.billing-success{background:#46b4641a;color:var(--good);border:1px solid rgba(70,180,100,.3)}.billing-onboarding{background:var(--bg-sunk);display:flex;align-items:center;justify-content:space-between;gap:16px}.billing-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:24px}.billing-card{background:var(--bg-elev);border:1px solid var(--line-soft);border-radius:8px;padding:16px}.billing-card .card-label{color:var(--ink-3);font-size:12px;text-transform:uppercase;letter-spacing:.05em}.billing-card .card-value{font-size:22px;font-weight:600;margin-top:4px}.billing-section{margin-top:24px}.billing-section h2,.billing-section h3{margin:0 0 12px}.billing-list{list-style:none;padding:0;margin:0}.billing-list li{padding:8px 0;border-bottom:1px solid var(--line-soft)}.billing-table{width:100%;border-collapse:collapse;font-size:14px}.billing-table th,.billing-table td{padding:8px 10px;text-align:left;border-bottom:1px solid var(--line-soft);vertical-align:top}.billing-table th{font-size:12px;text-transform:uppercase;color:var(--ink-3);letter-spacing:.04em;font-weight:600}.billing-items th,.billing-items td{padding:4px 6px}.billing-input{width:100%;padding:6px 8px;border:1px solid var(--line);border-radius:4px;background:var(--bg-elev);color:var(--ink);font-size:14px;box-sizing:border-box;font-family:inherit}.billing-input:focus{outline:2px solid var(--accent);outline-offset:-1px}.billing-status{display:inline-block;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;background:var(--bg-sunk);color:var(--ink-2)}.status-draft{background:#e2e2e2;color:#555}.status-sent{background:#e0f0ff;color:#1a6}.status-partial{background:#ffe7c0;color:#a60}.status-paid{background:#d4f4dd;color:#2a8}.status-overdue{background:#fcd8d8;color:#b22}.status-cancelled{background:#e2e2e2;color:#999;text-decoration:line-through}[data-theme=dark] .status-draft{background:#3a3a3a;color:#d0d0d0}[data-theme=dark] .status-sent{background:#1e3a5f;color:#6ec8ff}[data-theme=dark] .status-partial{background:#5a3d0c;color:#ffc878}[data-theme=dark] .status-paid{background:#1c4a2a;color:#7ee5a0}[data-theme=dark] .status-overdue{background:#5a1f1f;color:#ff8e8e}[data-theme=dark] .status-cancelled{background:#2a2a2a;color:#888}[data-theme=dark] .kind-tag{background:#1e3a5f;color:#6ec8ff}.invoice-list-header{display:flex;gap:12px;align-items:center;margin-bottom:16px;flex-wrap:wrap}.invoice-list-header .billing-input{width:auto;min-width:180px}.bulk-toolbar{display:flex;gap:8px;align-items:center;margin-bottom:12px;padding:8px 12px;background:var(--bg-sunk);border-radius:6px;flex-wrap:wrap}.bulk-toolbar__count{font-size:13px;color:var(--ink-2);margin-right:4px}.billing-notice{margin-bottom:12px;padding:8px 12px;background:var(--bg-sunk);border-radius:6px;font-size:13px;color:var(--ink-2)}.billing-table tr.is-selected{background:var(--bg-sunk)}.rt-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}.rt-table{width:var(--rt-w, auto);table-layout:fixed;border-collapse:collapse;font-size:14px;max-width:none}.rt-table th,.rt-table td{padding:8px 10px;border-bottom:1px solid var(--line-soft)}.rt-th{position:relative;text-transform:uppercase;font-size:12px;font-weight:600;color:var(--ink-3);letter-spacing:.04em;-webkit-user-select:none;user-select:none}.rt-th-label{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rt-cell{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-variant-numeric:tabular-nums}.rt-resizer{position:absolute;top:0;bottom:0;right:0;width:14px;cursor:col-resize;touch-action:none;z-index:2}.rt-resizer:after{content:"";position:absolute;top:4px;bottom:4px;right:4px;width:2px;background:var(--line);border-radius:1px}.rt-resizer:hover:after,.rt-resizer:active:after{background:var(--accent, #1a6);width:3px}.rt-table tr.is-selected{background:var(--bg-sunk)}.rt-table td.cell-name{overflow:hidden}.rt-table td.cell-name>div{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tbl{box-shadow:var(--shadow)}.rt-table.tbl .rt-th{font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;font-weight:600;color:var(--ink-3);background:var(--bg-sunk);padding:11px 14px}.rt-table.tbl thead th{border-bottom:1px solid var(--line)}.rt-table.tbl td{padding:12px 14px;font-size:13.5px;color:var(--ink-2);border-bottom:1px solid var(--line-soft)}.rt-table.tbl tbody tr:last-child td{border-bottom:none}.rt-table.tbl td.name{color:var(--ink);font-weight:600;font-size:14px}.rt-table.tbl.tbl-clickable tbody tr:hover td{background:var(--accent-soft)}.count-badge{display:inline-block;min-width:22px;padding:1px 7px;border-radius:999px;background:var(--bg-sunk);color:var(--ink-2);font-size:12px;text-align:center;font-variant-numeric:tabular-nums}.invoice-row-actions{white-space:nowrap;display:flex;gap:4px;align-items:center}.money-toggle[aria-pressed=true]{color:var(--accent, #1a6)}.invoice-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:20px;padding:12px;background:var(--bg-sunk);border-radius:8px}.invoice-totals{display:flex;gap:24px;justify-content:flex-end;margin:12px 0;font-size:14px}.invoice-pay-row{display:flex;gap:8px;align-items:center;margin-top:12px}.invoice-pay-row .billing-input{width:auto;min-width:120px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:100;padding:16px}.modal-panel{background:var(--bg-elev);border-radius:8px;width:100%;max-width:600px;max-height:90vh;overflow:auto;display:flex;flex-direction:column}.modal-panel--wide{max-width:960px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--line-soft)}.modal-header h2{margin:0;font-size:18px}.modal-body{padding:20px;flex:1;overflow:auto}.modal-body h3{margin:20px 0 10px;font-size:14px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-3)}.modal-footer{display:flex;gap:8px;justify-content:flex-end;padding:14px 20px;border-top:1px solid var(--line-soft);flex-wrap:wrap}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.form-field{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.form-field>span{font-size:12px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.03em}.btn-link{background:transparent;border:none;color:var(--accent-ink);cursor:pointer;padding:4px 6px;font-size:14px}.btn-link:hover{text-decoration:underline;color:var(--accent)}.btn-danger{background:var(--bad);color:var(--bg);border:none;padding:8px 14px;border-radius:4px;cursor:pointer}.btn-danger:hover{background:var(--bad);color:var(--bg);filter:brightness(1.08)}.btn-secondary{background:var(--bg-sunk);color:var(--ink);border:1px solid var(--line);padding:8px 14px;border-radius:4px;cursor:pointer}.btn-secondary:hover{background:var(--line-soft)}.btn:disabled,.btn-primary:disabled,.btn-secondary:disabled,.btn-link:disabled{opacity:.5;cursor:not-allowed}.muted{color:var(--ink-3)}.row-warning{background:#dc96000d}.warning-tag{color:var(--warn);font-size:11px;margin-left:4px}.billing-settings{max-width:800px}.billing-settings section{margin-bottom:32px}.billing-settings h2,.billing-settings h3{margin:0 0 12px}.billing-settings-actions{margin-top:24px}.invoiceable-section{margin:16px 0;padding:12px;border:1px dashed var(--line);border-radius:8px;background:var(--bg-sunk)}.invoiceable-section h3{margin:0 0 10px}.invoiceable-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px;max-height:240px;overflow:auto}.invoiceable-row{display:grid;grid-template-columns:1fr auto;gap:8px;padding:8px 10px;background:var(--bg-elev);border:1px solid var(--line-soft);border-radius:6px;align-items:center}.invoiceable-row .invoiceable-meta{font-size:13px}.invoiceable-row .invoiceable-summary{grid-column:1;color:var(--ink-2);font-size:12px}.invoiceable-row.used{opacity:.55}.kind-tag{display:inline-block;background:#e0f0ff;color:#1a6;padding:1px 6px;border-radius:4px;font-size:10px;margin-left:6px;text-transform:uppercase}.external-nfse-block{margin:16px 0;padding:12px;border:1px dashed var(--line);border-radius:8px;background:var(--bg-sunk)}.external-nfse-block h3{margin:0 0 10px}.external-nfse-summary>div{margin-bottom:4px;font-size:13px}.external-nfse-form .form-field{margin-bottom:10px}.wm-preview{position:relative;width:300px;height:424px;background:#fff;border:1px solid var(--line, #ddd);box-shadow:0 2px 8px #00000014;overflow:hidden;font-family:-apple-system,Segoe UI,sans-serif;color:#222}.wm-preview-bg{position:absolute;top:0;right:0;bottom:0;left:0;background-size:cover;background-position:center}.wm-preview-content{position:relative;padding:12px;z-index:1;font-size:7px;line-height:1.3}.wm-header{display:flex;justify-content:space-between;gap:8px}.wm-emit-name{font-size:9px;font-weight:700}.wm-meta{color:#555;font-size:6px;margin-top:1px}.wm-title{text-align:right;min-width:70px}.wm-fatura{font-size:14px;font-weight:700}.wm-meta-right{font-size:6px;color:#555;text-align:right}.wm-sep{border-top:1px solid #ccc;margin:6px 0}.wm-label{font-size:6px;font-weight:700;color:#888;letter-spacing:.05em;margin-top:6px}.wm-customer{font-size:8px;font-weight:700;margin-top:2px}.wm-items-header{display:grid;grid-template-columns:1fr 24px 36px 38px;background:#f5f5f5;padding:3px 4px;font-size:6px;font-weight:700;color:#333;margin-top:10px}.wm-items-header span:not(:first-child){text-align:right}.wm-item{display:grid;grid-template-columns:1fr 24px 36px 38px;padding:3px 4px;font-size:6.5px;border-bottom:1px solid #eee}.wm-item span:not(:first-child){text-align:right}.wm-totals{margin-top:6px;padding:4px}.wm-totals>div{display:flex;justify-content:space-between;padding:1px 0;font-size:7px}.wm-totals .wm-total{font-weight:700;font-size:8px;background:#f5f5f5;padding:3px;margin-top:2px}.wm-footer-box{margin-top:14px;padding:6px;background:#fafafad9;border:1px solid #ddd}.wm-preview-pair{display:flex;gap:16px;align-items:flex-start;flex-wrap:wrap}.billing-reports{display:flex;flex-direction:column;gap:12px}.report-bars{display:flex;flex-direction:column;gap:4px;padding:4px 0}.report-bar-row{display:grid;grid-template-columns:60px 1fr 200px;gap:10px;align-items:center;padding:4px 0;font-size:12px}.report-bar-label{font-family:var(--font-mono, monospace);color:var(--ink-3);font-size:11px}.report-bar-track{position:relative;height:18px;background:var(--bg-sunk, #f5f5f5);border-radius:3px;overflow:hidden}.report-bar{position:absolute;top:0;bottom:0;transition:width .2s ease}.report-bar.fill-invoiced{left:0;background:#4682c88c;height:50%;top:0}.report-bar.fill-received{left:0;background:#3caa5a8c;height:50%;top:50%}.report-bar-amount{font-size:11px;color:var(--ink-2);text-align:right}.report-legend{display:flex;gap:14px;padding:8px 0 0;font-size:11px;color:var(--ink-3)}.report-legend .dot{display:inline-block;width:10px;height:10px;border-radius:2px;margin-right:4px;vertical-align:middle}.invoice-pay-form{margin-top:12px;padding:12px;border:1px dashed var(--line);border-radius:8px;background:var(--bg-sunk)}.invoice-pay-form .form-grid{gap:10px}@media (max-width: 900px){.billing-shell{padding:16px 18px 16px 64px}.billing-header{gap:10px}.billing-tabs{overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch}.billing-tab{white-space:nowrap;padding:8px 14px;font-size:13px;flex-shrink:0}.modal-panel--wide{max-width:100%}}@media (max-width: 640px){.billing-shell{padding:12px 12px 32px 60px}.billing-header h1{font-size:20px}.billing-shell>*{margin-left:0;margin-right:0}.billing-cards{grid-template-columns:repeat(2,1fr);gap:8px}.billing-card{padding:12px}.billing-card .card-value{font-size:18px}.billing-card .card-label{font-size:10px}.billing-table{display:block;overflow-x:auto;white-space:nowrap;font-size:12px;-webkit-overflow-scrolling:touch}.billing-table thead,.billing-table tbody,.billing-table tr{display:table;width:100%;table-layout:auto}.billing-table th,.billing-table td{padding:6px 8px}.billing-items .billing-input{font-size:12px;padding:4px 6px}.rt-table{display:table;white-space:normal}.rt-table thead{display:table-header-group}.rt-table tbody{display:table-row-group}.rt-table tr{display:table-row;width:auto}.modal-panel,.modal-panel--wide{max-width:100vw;width:100vw;height:100vh;height:100dvh;max-height:100vh;max-height:100dvh;border-radius:0;min-width:0;overflow-x:hidden}.modal-backdrop{padding:0;height:100vh;height:100dvh;align-items:stretch}.modal-header{padding:12px 14px;padding-top:calc(12px + env(safe-area-inset-top,0px))}.modal-header h2{font-size:16px;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.modal-body{padding:14px;overflow-x:hidden}.modal-body .billing-table{width:100%;max-width:100%}.modal-footer{padding:12px 14px;padding-bottom:calc(12px + env(safe-area-inset-bottom,0px));gap:6px;flex-wrap:wrap}.modal-footer .btn{font-size:13px;padding:7px 10px;flex:1 1 auto;min-width:0}.modal-panel--small{max-width:100vw!important;height:auto;max-height:90vh}.editor-section{margin-bottom:16px;padding-bottom:12px}.product-editor .seg-toggle{flex-wrap:wrap}.product-editor .seg-toggle button{flex:1 1 50%;min-width:0;padding:8px 6px;font-size:13px}.component-row{grid-template-columns:minmax(0,1fr) 46px 84px 28px;gap:6px;padding:6px 8px}.component-name{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.component-qty,.component-price{width:100%!important;padding:4px!important;font-size:13px}.component-line{display:none}.svc-expansion table input[type=number]{width:60px}.svc-expansion table td{padding:3px 4px;font-size:12px}.form-grid{grid-template-columns:1fr;gap:8px}.invoice-list-header{flex-direction:column;align-items:stretch;gap:8px}.invoice-list-header .billing-input{width:100%;min-width:0}.invoice-summary{grid-template-columns:repeat(2,1fr);gap:8px;padding:10px}.invoice-pay-form{padding:10px}.invoice-pay-form .form-grid{grid-template-columns:1fr}.wm-preview{width:100%;max-width:100%;aspect-ratio:300 / 424;height:auto}.wm-preview-pair{flex-direction:column;gap:12px}.wm-preview-content{padding:8px}.invoiceable-section{padding:10px}.invoiceable-row{grid-template-columns:1fr;gap:4px}.invoiceable-row .btn{width:100%}.report-bar-row{grid-template-columns:56px 1fr;gap:6px}.report-bar-amount{grid-column:2;text-align:left;font-size:10px}.report-bars{font-size:11px}.external-nfse-block{padding:10px}.billing-settings{max-width:100%}.billing-items{display:block;white-space:normal;overflow:visible}.billing-items thead{display:none}.billing-items tbody{display:block;width:100%}.billing-items tr{display:block;width:100%;border:1px solid var(--line);border-radius:8px;padding:8px 10px;margin-bottom:10px;background:var(--bg-elev)}.billing-items td{display:flex;align-items:center;gap:8px;width:100%;padding:4px 0;border:none;white-space:normal}.billing-items td:before{content:attr(data-label);flex:0 0 80px;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-3)}.billing-items td:last-child{justify-content:flex-end;gap:12px}.billing-items td:last-child:before{display:none}.billing-items .billing-input{width:100%;font-size:13px}.billing-items td.item-desc{flex-direction:column;align-items:stretch}.billing-items td.item-desc:before{flex-basis:auto;margin-bottom:2px}}.products-view-tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin-bottom:18px}.view-tab{background:transparent;border:none;border-bottom:2px solid transparent;padding:8px 16px;font-size:14px;color:var(--ink-3);cursor:pointer;margin-bottom:-1px;font-family:inherit}.view-tab:hover{color:var(--ink)}.view-tab.on{color:var(--ink);border-bottom-color:var(--accent);font-weight:600}.seg-toggle{display:inline-flex;border:1px solid var(--line);border-radius:6px;padding:2px;background:var(--bg-sunk);gap:2px}.seg-toggle button{background:transparent;border:none;padding:6px 14px;font-size:13px;color:var(--ink-3);border-radius:4px;cursor:pointer;font-family:inherit}.seg-toggle button:hover{color:var(--ink)}.seg-toggle button.on{background:var(--bg-elev);color:var(--ink);box-shadow:0 1px 2px #0000000f;font-weight:500}.seg-toggle button.on.in{color:var(--ok, #2a8)}.seg-toggle button.on.out{color:var(--bad, #c44)}.catalog-header{display:flex;gap:12px;align-items:center;margin-bottom:16px;flex-wrap:wrap}.catalog-search{position:relative;display:flex;align-items:center;flex:1;min-width:200px;max-width:360px}.catalog-search svg{position:absolute;left:10px;color:var(--ink-3);pointer-events:none}.catalog-search input{padding-left:30px;width:100%}.catalog-empty{padding:32px;text-align:center}.catalog-header-io{display:inline-flex;gap:6px;margin-left:auto;padding-left:14px;border-left:1px solid var(--line-soft)}.btn-sm{padding:6px 10px;font-size:12px}.products-table{width:100%}.products-table .cell-name{font-weight:500}.products-table .cell-desc{font-size:12px;margin-top:2px}.products-table .th-actions,.products-table .td-actions{text-align:right;white-space:nowrap}.kind-tag{display:inline-block;padding:2px 8px;border-radius:10px;font-size:10px;text-transform:uppercase;letter-spacing:.04em;font-weight:600;margin-left:0}.kind-service{background:#3c82dc1f;color:#2b6cb0}.kind-product{background:#8c5ac81f;color:#6b46c1}.stock-pill{display:inline-block;min-width:32px;padding:2px 10px;border-radius:10px;font-size:12px;font-weight:600;text-align:center;font-variant-numeric:tabular-nums}.stock-pill--ok{background:#28a0641f;color:#2a7d52}.stock-pill--low{background:#dc96002e;color:#b67500}.stock-pill--zero{background:#c8323226;color:#b03030}.row-zero{background:#c832320a}.stock-cell{display:inline-flex;align-items:center;gap:6px}.qty-btn{width:24px;height:24px;border:1px solid var(--line);background:var(--bg-elev);border-radius:4px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;color:var(--ink-2);padding:0}.qty-btn:hover:not(:disabled){background:var(--bg-sunk);color:var(--ink)}.qty-btn:disabled{opacity:.35;cursor:not-allowed}.icon-btn{background:transparent;border:none;padding:6px;border-radius:4px;cursor:pointer;color:var(--ink-3);display:inline-flex;align-items:center;justify-content:center}.icon-btn:hover{background:var(--bg-sunk);color:var(--ink)}.icon-btn--danger:hover,.btn-link--danger{color:var(--bad, #c44)}.btn-out{background:var(--bad, #c44)}.product-editor .seg-toggle{width:100%;margin-bottom:18px}.product-editor .seg-toggle button{flex:1}.editor-section{margin-bottom:22px;padding-bottom:18px;border-bottom:1px solid var(--line-soft)}.editor-section:last-child{border-bottom:none;padding-bottom:0}.editor-section-title{margin:0 0 12px!important;font-size:11px!important;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3)!important;font-weight:600}.editor-section--collapsible summary{cursor:pointer;list-style:none;display:flex;align-items:center;gap:6px;-webkit-user-select:none;user-select:none}.editor-section--collapsible summary:before{content:"▸";font-size:10px;color:var(--ink-3);transition:transform .15s}.editor-section--collapsible[open] summary:before{transform:rotate(90deg)}.editor-section--collapsible summary::-webkit-details-marker{display:none}.editor-section--collapsible[open]{padding-top:4px}.editor-section--collapsible[open] .form-grid{margin-top:10px}.form-field--inline{flex-direction:row!important;align-items:center;gap:8px!important}.form-field--inline>span{display:none}.field-error{color:var(--bad, #c44);font-size:12px;margin-top:2px}.req{color:var(--bad, #c44);font-style:normal}.billing-input.has-error{border-color:var(--bad, #c44)}.stock-adjust .stock-status{display:flex;align-items:baseline;justify-content:space-between;padding:14px 18px;background:var(--bg-sunk);border-radius:8px;margin-bottom:18px;border-left:3px solid var(--ok, #2a8)}.stock-adjust .stock-status.low{border-left-color:var(--warn, #d80)}.stock-status-label{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-3);display:block;margin-bottom:4px}.stock-status-value{font-size:28px;font-weight:700;font-variant-numeric:tabular-nums}.stock-status-unit{margin-left:6px;color:var(--ink-3);font-size:14px}.stock-status-min{font-size:13px;color:var(--ink-3)}.stock-mode{width:100%;margin-bottom:14px}.stock-mode button{flex:1;font-size:14px;padding:8px 14px}.stock-preview{padding:10px 14px;background:var(--bg-sunk);border-radius:6px;margin:12px 0;font-size:14px;font-variant-numeric:tabular-nums}.stock-preview.bad{background:#c8323214;color:var(--bad, #c44)}.stock-submit{width:100%;padding:10px;font-size:15px}.stock-moves .delta-in{color:var(--ok, #2a8);font-weight:500}.stock-moves .delta-out{color:var(--bad, #c44);font-weight:500}.quick-stock-pop{position:fixed;z-index:200;background:var(--bg-elev);border:1px solid var(--line);border-radius:8px;box-shadow:0 8px 24px #0000002e;padding:12px;min-width:200px;display:flex;flex-direction:column;gap:8px}.quick-stock-pop--in{border-top:3px solid var(--ok, #2a8)}.quick-stock-pop--out{border-top:3px solid var(--bad, #c44)}.quick-stock-header{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-3);font-weight:600}.quick-stock-row{display:flex;gap:6px;align-items:center}.quick-stock-row input{flex:1;min-width:0}.quick-stock-row .btn{padding:6px 12px;font-size:13px}.quick-stock-preview{font-size:12px;color:var(--ink-3);font-variant-numeric:tabular-nums}.quick-stock-error{font-size:12px;padding:4px 6px}.quick-stock-full{background:transparent;border:none;color:var(--accent-ink);font-size:11px;cursor:pointer;padding:2px;text-align:left}.quick-stock-full:hover{text-decoration:underline}.stock-overview{display:flex;flex-direction:column;gap:20px}.stock-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}.stock-card{background:var(--bg-elev);border:1px solid var(--line-soft);border-radius:8px;padding:14px 16px}.stock-card.warning{border-color:var(--warn, #d80);background:#dc96000a}.stock-card.bad{border-color:var(--bad, #c44);background:#c832320a}.stock-card-label{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-3);margin-bottom:4px}.stock-card-value{font-size:22px;font-weight:700;font-variant-numeric:tabular-nums}.stock-section h3{font-size:13px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-3);margin:0 0 10px}.stock-empty{padding:48px 20px;text-align:center;color:var(--ink-3);display:flex;flex-direction:column;align-items:center;gap:8px}.stock-empty p{margin:4px 0}.modal-panel--small{max-width:420px}@media (max-width: 640px){.catalog-header{flex-direction:column;align-items:stretch}.catalog-search{max-width:100%}.stock-cards{grid-template-columns:repeat(2,1fr)}.stock-card-value{font-size:18px}}.product-import .import-drop{padding:32px 20px;text-align:center;border:2px dashed var(--line);border-radius:8px;background:var(--bg-sunk)}.product-import .import-drop p{margin:6px 0}.product-import .import-drop label{display:inline-block;margin-top:14px;cursor:pointer}.import-file-meta{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--bg-sunk);border-radius:6px;margin-bottom:14px}.import-options{display:flex;gap:18px;flex-wrap:wrap;margin:12px 0;font-size:13px}.import-summary{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}.chip{display:inline-block;padding:2px 10px;border-radius:10px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.chip-ok{background:#28a06426;color:#2a7d52}.chip-warn{background:#dc96002e;color:#b67500}.chip-muted{background:#7878781f;color:var(--ink-3)}.row-skipped{opacity:.5}.import-preview td{vertical-align:middle}.import-progress{padding:24px 12px;text-align:center}.progress-bar{height:8px;background:var(--bg-sunk);border-radius:4px;overflow:hidden;margin-bottom:12px}.progress-fill{height:100%;background:var(--accent, #4a8);transition:width .2s}.import-result h3{margin-top:0}.import-mapping{margin-bottom:18px;padding:14px;background:var(--bg-sunk);border-radius:8px;border:1px solid var(--line-soft)}.import-mapping h3{margin-top:0!important}.mapping-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin-top:10px}.mapping-preview{font-size:11px;font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block;margin-top:2px}.editor-section-hint{font-size:12px;margin:-6px 0 10px}.components-list{list-style:none;padding:0;margin:0 0 10px;display:flex;flex-direction:column;gap:6px}.component-row{display:grid;grid-template-columns:minmax(0,1fr) 56px 96px 76px 32px;align-items:center;gap:8px;padding:6px 10px;background:var(--bg-sunk);border-radius:6px;border:1px solid var(--line-soft)}.component-name{font-size:13px}.component-qty{padding:4px 6px!important;text-align:right}.component-price{padding:4px 6px!important;text-align:right;font-size:13px}.component-line{font-size:12px;text-align:right;white-space:nowrap;color:var(--ink-3)}.picker-list{list-style:none;padding:0;margin:0;max-height:320px;overflow:auto;display:flex;flex-direction:column;gap:2px}.picker-row{display:flex;align-items:center;gap:6px;width:100%;padding:8px 10px;background:transparent;border:1px solid transparent;border-radius:4px;cursor:pointer;font-size:13px;text-align:left;color:inherit}.picker-row:hover{background:var(--bg-sunk);border-color:var(--line-soft)}.picker-price{margin-left:auto;font-variant-numeric:tabular-nums}.svc-expansion{margin:8px 0;padding:10px 12px;border:1px dashed var(--accent, #4a8);border-radius:6px;background:#3c82dc0a}.svc-expansion-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}.svc-expansion-head h4{margin:0;font-size:13px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-3)}.svc-expansion table{width:100%;font-size:13px}.svc-expansion table td{padding:4px 6px}.svc-expansion table input[type=number]{width:70px;padding:3px 6px;text-align:right}.svc-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:8px}.account-wrap{max-width:720px;margin:0 auto;display:flex;flex-direction:column;gap:18px}.account-card{background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius-lg);padding:22px 24px;box-shadow:var(--shadow)}.account-card--danger{border-color:color-mix(in oklch,var(--bad) 45%,var(--line));background:color-mix(in oklch,var(--bad) 5%,var(--bg-elev))}.account-profile{display:flex;align-items:center;gap:18px}.account-avatar{width:64px;height:64px;flex-shrink:0;border-radius:50%;background:var(--accent-soft);color:var(--accent-ink);display:grid;place-items:center;font-family:var(--font-display);font-style:italic;font-size:28px}.account-profile-meta{min-width:0}.account-name{font-family:var(--font-display);font-size:22px;letter-spacing:-.01em;color:var(--ink)}.account-email{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--ink-2);margin-top:2px;word-break:break-all}.account-inline-icon{width:13px;height:13px;flex-shrink:0;color:var(--ink-3)}.account-badges{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.account-badge{display:inline-flex;align-items:center;gap:5px;font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.06em;padding:3px 8px;border-radius:999px;background:var(--bg-sunk);border:1px solid var(--line);color:var(--ink-2)}.account-badge--telegram{color:var(--accent-ink);border-color:var(--accent-soft)}.account-badge--telegram .account-inline-icon{color:var(--accent-ink)}.account-badge--method{color:var(--ink-3)}.form-section-label--danger{color:var(--bad)}.form-section-label--danger svg{width:13px;height:13px}.form-section-label svg{width:13px;height:13px}.account-row{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.account-row-text{min-width:0;flex:1 1 240px}.account-row-title{font-size:14.5px;color:var(--ink);display:flex;align-items:center;gap:8px}.account-row-sub{font-size:12.5px;color:var(--ink-3);margin-top:3px;line-height:1.45}.account-note{font-size:13px;color:var(--ink-2);line-height:1.5;padding:12px 14px;background:var(--bg-sunk);border-radius:var(--radius);border-left:2px solid var(--line)}.account-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}.account-msg-ok{color:var(--good);font-size:12.5px;margin-top:10px}.account-msg-err{color:var(--bad);font-size:12.5px;margin-top:10px}.account-pill-soft{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.06em;padding:2px 7px;border-radius:999px;background:var(--accent-soft);color:var(--accent-ink)}.account-danger-lead{font-size:13.5px;color:var(--ink);line-height:1.5;margin:0 0 10px}.account-danger-list{margin:0 0 16px;padding-left:18px;font-size:13px;color:var(--ink-2);line-height:1.7}.account-danger-list strong{color:var(--ink)}.account-reqs{list-style:none;margin:14px 0 0;padding:10px 12px;background:var(--bg-sunk);border:1px solid var(--line-soft);border-radius:var(--radius);display:flex;flex-direction:column;gap:7px;font-size:12.5px;color:var(--ink-3)}.account-reqs li{display:flex;align-items:center;gap:8px}.account-reqs li.is-done{color:var(--good)}.account-reqs-mark{font-family:var(--font-mono);width:14px;text-align:center;flex-shrink:0}.account-reqs-hint{margin-top:8px;font-size:12px;color:var(--warn)}.account-reqs-hint.is-ready{color:var(--good)}.account-steps-intro{font-size:13px;color:var(--ink-2);margin:4px 0 14px}.step-badge{display:inline-grid;place-items:center;width:17px;height:17px;border-radius:50%;background:var(--accent);color:var(--bg);font-family:var(--font-mono);font-size:10px;margin-right:6px;vertical-align:middle}.field-help{font-size:12px;color:var(--ink-3);line-height:1.45;margin:-2px 0 2px}.field-help code{font-family:var(--font-mono);font-size:11.5px;background:var(--bg-sunk);border:1px solid var(--line-soft);padding:1px 5px;border-radius:3px;color:var(--accent-ink)}.btn-danger.is-locked{background:var(--bg-sunk);color:var(--ink-3);border:1px solid var(--line);opacity:1;cursor:not-allowed;box-shadow:none}.btn-danger.is-locked:hover{background:var(--bg-sunk);filter:none}.btn-danger.is-armed{background:var(--bad);color:var(--bg);border:1px solid var(--bad);opacity:1;box-shadow:0 0 0 3px color-mix(in oklch,var(--bad) 28%,transparent)}.btn-danger.is-armed:hover{filter:brightness(1.08)}.account-danger-list+.field input.input-ok,.field input.input-ok{border-color:var(--good);outline-color:color-mix(in oklch,var(--good) 30%,transparent)}.field input.input-err{border-color:var(--bad)}.modal-body code{font-family:var(--font-mono);font-size:12px;background:var(--bg-sunk);padding:2px 6px;border-radius:3px;border:1px solid var(--line-soft);color:var(--accent-ink);letter-spacing:.04em}@media (max-width: 640px){.account-card{padding:18px 16px}.account-profile{gap:14px}.account-avatar{width:52px;height:52px;font-size:22px}.account-name{font-size:19px}.account-actions .btn{flex:1 1 auto;justify-content:center}}.plan-interval-toggle{display:flex;gap:8px;justify-content:center;margin-bottom:18px}.plan-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.plan-card{display:flex;flex-direction:column;gap:10px}.plan-card-title{font-weight:600;font-size:1.05rem}.plan-card-price{font-size:1.6rem;font-weight:700;color:var(--ink)}.plan-card-suffix{font-size:.85rem;font-weight:400;opacity:.65;margin-left:4px}.plan-feature-list{list-style:none;padding:0;margin:6px 0;display:flex;flex-direction:column;gap:6px;font-size:.9rem}.plan-feature-list li{display:flex;gap:8px;align-items:flex-start}.plan-feature-check{color:var(--good);font-weight:700}.plan-card .btn{margin-top:auto}
