:root{
  --ink:#e8ecf0;--ink-dim:#8a97a6;--ink-faint:#4a5968;
  --abyss:#05101a;--deep:#0a1a2a;--mid:#13293d;--panel:#0b1a2a;--panel-2:#0e2135;
  --line:rgba(232,236,240,.12);--line-strong:rgba(232,236,240,.22);
  --coral:#e8845c;--kelp:#5b9a7c;--red:#d9645c;--glow:#c9d6de;
  --serif:"Cormorant Garamond","Noto Serif TC",serif;
  --sans:"Inter","Noto Sans TC",system-ui,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--abyss);color:var(--ink);font-family:var(--sans);font-weight:400;font-size:14px;-webkit-font-smoothing:antialiased;min-height:100vh}
body{line-height:1.55}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
input,select,textarea{font-family:inherit;color:inherit}
::selection{background:var(--coral);color:var(--abyss)}
.caustic{position:fixed;inset:-5%;pointer-events:none;z-index:0;opacity:.35;mix-blend-mode:screen;
  background:radial-gradient(ellipse 50% 40% at 20% 10%,rgba(139,177,196,.12),transparent 70%),radial-gradient(ellipse 40% 50% at 80% 90%,rgba(80,130,160,.1),transparent 70%);
  filter:blur(30px);animation:drift 22s ease-in-out infinite alternate}
@keyframes drift{to{transform:translate(-3%,2%) scale(1.08)}}

.top{position:sticky;top:0;z-index:50;background:rgba(5,16,26,.85);backdrop-filter:blur(20px);border-bottom:1px solid var(--line);padding:14px 24px;display:flex;align-items:center;gap:16px}
.brand{display:flex;align-items:center;gap:12px;flex:1;min-width:0}
.brand-sigil{width:50px;height:33px;background:url('logo-sigil.png') center/contain no-repeat;flex-shrink:0}
.brand-text{min-width:0}
.brand-name{font-family:var(--serif);font-size:17px;letter-spacing:.24em;text-transform:uppercase;color:var(--ink);line-height:1}
.brand-sub{font-family:var(--mono);font-size:10px;letter-spacing:.22em;color:var(--ink-dim);margin-top:4px;text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.home-link{font-family:var(--mono);font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-dim);padding:8px 12px;border:1px solid var(--line);transition:.3s;flex-shrink:0}
.home-link:hover{color:var(--ink);border-color:var(--line-strong)}

nav.tabs{display:flex;background:var(--deep);border-bottom:1px solid var(--line);position:sticky;top:63px;z-index:40;overflow-x:auto;scrollbar-width:none}
nav.tabs::-webkit-scrollbar{display:none}
.tab{flex:1;min-width:100px;padding:16px 10px;text-align:center;font-family:var(--mono);font-size:10px;font-weight:500;letter-spacing:.26em;text-transform:uppercase;color:var(--ink-dim);cursor:pointer;border-bottom:1px solid transparent;transition:.25s;white-space:nowrap;position:relative}
.tab:hover{color:var(--ink)}
.tab.active{color:var(--ink)}
.tab.active::after{content:"";position:absolute;left:50%;bottom:-1px;transform:translateX(-50%);width:40px;height:1px;background:var(--coral)}
.tab .tn{font-family:var(--serif);font-style:italic;font-size:13px;text-transform:none;letter-spacing:0;font-weight:400;color:var(--coral);margin-right:6px;opacity:.85}

.page{display:none;padding:28px 24px 80px;max-width:780px;margin:0 auto;position:relative;z-index:2}
.page.active{display:block;animation:fadeIn .5s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.page-head{margin-bottom:28px;padding-bottom:20px;border-bottom:1px solid var(--line)}
.page-eyebrow{font-family:var(--mono);font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--coral);margin-bottom:10px;display:flex;align-items:center;gap:10px}
.page-eyebrow::before{content:"";width:22px;height:1px;background:var(--coral)}
.page-title{font-family:var(--serif);font-weight:300;font-size:42px;line-height:1;letter-spacing:-.01em;color:var(--ink)}
.page-title em{font-style:italic;color:var(--glow)}

.summary-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px;background:var(--line);border:1px solid var(--line);margin-bottom:28px}
.card{background:var(--panel);padding:22px 20px;position:relative}
.card-full{grid-column:1/-1}
.card-label{font-family:var(--mono);font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:12px;display:flex;align-items:center;gap:8px}
.card-label::before{content:"";width:6px;height:6px;background:var(--coral);border-radius:50%;opacity:.8}
.card-value{font-family:var(--serif);font-weight:400;font-size:32px;line-height:1;letter-spacing:-.02em}
.card-value .cur{font-family:var(--mono);font-size:12px;color:var(--ink-dim);font-weight:400;margin-right:4px;letter-spacing:.1em}
.pos{color:var(--kelp)}.neg{color:var(--red)}.neutral{color:var(--glow)}

.period-wrap{margin-bottom:14px;position:relative}
.period-btn{width:100%;padding:14px 16px;border:1px solid var(--line);background:var(--panel);color:var(--ink);text-align:left;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;transition:.25s}
.period-btn:hover{border-color:var(--line-strong)}
.period-btn .arrow{color:var(--coral);font-size:10px}
.period-dropdown{display:none;position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--panel-2);border:1px solid var(--line-strong);z-index:50;max-height:340px;overflow-y:auto;box-shadow:0 20px 40px rgba(0,0,0,.5)}
.period-dropdown.open{display:block}
.pd-all{padding:12px 16px;cursor:pointer;font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--line);color:var(--ink)}
.pd-all:hover,.pd-year:hover,.pd-month:hover{background:rgba(232,132,92,.08)}
.pd-year{padding:10px 16px;cursor:pointer;font-family:var(--mono);font-size:11px;letter-spacing:.2em;color:var(--ink);display:flex;align-items:center;gap:10px;user-select:none;text-transform:uppercase}
.pd-year-arrow{font-size:9px;transition:.2s;color:var(--ink-dim);margin-left:auto}
.pd-year.expanded .pd-year-arrow{transform:rotate(90deg)}
.pd-months{display:none;padding-left:12px}
.pd-year.expanded + .pd-months{display:block}
.pd-month{padding:8px 16px 8px 34px;cursor:pointer;font-family:var(--mono);font-size:10px;letter-spacing:.18em;color:var(--ink-dim);display:flex;align-items:center;gap:10px;text-transform:uppercase}
.pd-month:hover{color:var(--ink)}
.pd-month-only{margin-left:auto;font-family:var(--mono);font-size:9px;letter-spacing:.2em;color:var(--ink-faint);padding:3px 8px;border:1px solid transparent;transition:.15s;text-transform:uppercase}
.pd-month-only:hover{color:var(--coral);border-color:rgba(232,132,92,.4)}
.pd-year .pd-check{cursor:pointer}
.pd-year .pd-check:hover{background:rgba(232,132,92,.15);border-color:var(--coral)}
.pd-check{width:14px;height:14px;border:1px solid var(--line-strong);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:9px;transition:.15s;color:transparent}
.pd-check.checked{background:var(--coral);border-color:var(--coral);color:var(--abyss)}
.pd-check.partial{background:rgba(232,132,92,.25);border-color:var(--coral);color:var(--coral)}

.filter-row{display:flex;gap:10px;margin-bottom:12px;flex-wrap:wrap}
.filter-row select,.filter-row input,.form-input{flex:1;min-width:120px;padding:12px 14px;border:1px solid var(--line);background:var(--panel);color:var(--ink);font-size:13px;font-family:var(--sans);transition:.2s}
.filter-row select:focus,.filter-row input:focus,.form-input:focus{outline:none;border-color:var(--coral);background:var(--panel-2)}
.filter-row select,.form-input[type=date]{cursor:pointer}
select.form-input option{background:var(--panel-2);color:var(--ink)}

.rec-toolbar{display:flex;gap:10px;margin-bottom:14px;align-items:center;font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-dim)}
.rec-count{flex:1}
.rec-count em{color:var(--coral);font-style:normal;font-weight:500}
.export-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;background:transparent;color:var(--ink);border:1px solid var(--line-strong);font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;cursor:pointer;transition:.25s}
.export-btn:hover{background:var(--ink);color:var(--abyss)}

.tx-list{display:flex;flex-direction:column}
.tx-item{background:var(--panel);border:1px solid var(--line);border-top:none;padding:16px 18px;display:flex;align-items:center;gap:14px;transition:.2s}
.tx-item:first-child{border-top:1px solid var(--line)}
.tx-item:hover{background:var(--panel-2);border-color:var(--line-strong)}
.tx-main{flex:1;cursor:pointer;min-width:0}
.tx-date{font-family:var(--mono);font-size:10px;letter-spacing:.2em;color:var(--ink-dim);text-transform:uppercase;margin-bottom:4px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.tx-customer{font-family:var(--serif);font-size:19px;font-weight:400;color:var(--ink);line-height:1.2}
.tx-item-name{font-size:12px;color:var(--ink-dim);margin-top:2px}
.tx-type-badge{font-family:var(--mono);font-size:9px;padding:2px 7px;border:1px solid;letter-spacing:.2em;text-transform:uppercase}
.badge-直客{color:var(--glow);border-color:var(--line-strong)}
.badge-支援{color:var(--kelp);border-color:var(--kelp)}
.badge-固定支出{color:var(--red);border-color:var(--red)}
.tx-right{text-align:right;min-width:100px;cursor:pointer}
.tx-amount{font-family:var(--serif);font-size:22px;font-weight:400;letter-spacing:-.01em}
.tx-amount .cur{font-family:var(--mono);font-size:10px;color:var(--ink-dim);margin-right:3px;letter-spacing:.1em}
.tx-rev{font-family:var(--mono);font-size:10px;color:var(--ink-dim);margin-top:2px;letter-spacing:.15em}
.tx-actions{display:flex;flex-direction:column;gap:4px}
.tx-del,.tx-edit{background:none;border:1px solid transparent;font-size:14px;cursor:pointer;padding:4px 6px;transition:.2s;line-height:1;color:var(--ink-dim)}
.tx-del:hover{color:var(--red);border-color:var(--red)}
.tx-edit:hover{color:var(--coral);border-color:var(--coral)}
.tx-item.pending-cost{border-left:2px solid var(--coral)}
.pending-cost-badge{font-family:var(--mono);font-size:9px;padding:2px 6px;background:rgba(232,132,92,.1);color:var(--coral);letter-spacing:.18em;text-transform:uppercase;border:1px solid rgba(232,132,92,.3)}

.chart-wrap{background:var(--panel);border:1px solid var(--line);padding:22px;margin-bottom:16px}
.chart-title{font-family:var(--mono);font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:18px;display:flex;align-items:center;gap:10px}
.chart-title::before{content:"";width:6px;height:6px;background:var(--coral);border-radius:50%}
.chart-wrap canvas{max-height:280px}

.section-label{font-family:var(--mono);font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:var(--ink-dim);margin:28px 0 14px;display:flex;align-items:center;gap:10px}
.section-label::before,.section-label::after{content:"";flex:1;height:1px;background:var(--line);max-width:40px}

.qc-card{background:var(--panel);border:1px solid var(--line);padding:24px;margin-bottom:22px;position:relative}
.qc-card::before{content:"";position:absolute;top:0;left:0;width:40px;height:1px;background:var(--coral)}
.qc-title{font-family:var(--serif);font-size:24px;font-weight:400;color:var(--ink);margin-bottom:4px}
.qc-title em{font-style:italic;color:var(--glow)}
.qc-subtitle{font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:20px}

.qc-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;flex-wrap:wrap}
.qc-head .qc-subtitle{margin-bottom:0}
.mode-toggle{display:inline-flex;border:1px solid var(--line-strong);background:var(--deep);flex-shrink:0;align-self:flex-start}
.mode-btn{background:transparent;border:none;color:var(--ink-dim);font-family:var(--mono);font-size:10px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;padding:9px 14px;cursor:pointer;transition:.18s}
.mode-btn:hover{color:var(--ink)}
.mode-btn.active{background:var(--coral);color:var(--abyss)}

.chips-toggle{font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-dim);margin-top:8px;cursor:pointer;user-select:none;display:inline-flex;align-items:center;gap:4px;transition:.15s;padding:4px 0}
.chips-toggle:hover{color:var(--coral)}
.chips-arrow{color:var(--coral);font-size:10px}
.customer-chips{flex-wrap:wrap;gap:6px;margin-top:8px;align-items:center;max-height:180px;overflow-y:auto;padding:2px}
.customer-chip{padding:5px 10px;border:1px solid var(--line);background:var(--deep);color:var(--ink-dim);font-size:12px;cursor:pointer;transition:.15s;font-family:var(--sans);line-height:1.3;border-radius:2px}
.customer-chip:hover{color:var(--ink);border-color:var(--line-strong);background:var(--panel-2)}
.customer-chip.chip-直客{border-left:2px solid var(--glow)}
.customer-chip.chip-支援{border-left:2px solid var(--kelp)}
.chip-more{font-family:var(--mono);font-size:10px;letter-spacing:.16em;color:var(--ink-faint);padding:5px 4px;text-transform:uppercase}

.form-group{margin-bottom:14px}
.form-label{font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:6px;display:block}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.form-input{width:100%;padding:12px 14px;border:1px solid var(--line);background:var(--deep);color:var(--ink);font-size:14px}
.form-input:focus{outline:none;border-color:var(--coral)}

.qc-add-row{display:flex;gap:10px;align-items:flex-end;margin-top:4px}
.qc-add-row .form-group{margin-bottom:0}
.qc-add-btn{padding:12px 16px;background:var(--coral);color:var(--abyss);border:none;font-family:var(--mono);font-size:12px;font-weight:500;letter-spacing:.1em;cursor:pointer;height:42px;flex-shrink:0;transition:.2s}
.qc-add-btn:hover{background:#f19875}

.qc-item-list{margin:14px 0 6px;max-height:220px;overflow-y:auto}
.qc-item-row{display:flex;align-items:center;padding:12px 14px;background:var(--deep);border:1px solid var(--line);margin-bottom:6px;gap:10px;font-size:13px}
.qc-item-name{flex:1;font-family:var(--serif);font-size:17px;font-weight:400}
.qc-item-price{font-family:var(--mono);font-weight:500;color:var(--coral);min-width:90px;text-align:right;letter-spacing:.05em}
.qc-item-del{background:none;border:none;color:var(--ink-faint);font-size:16px;cursor:pointer;padding:2px 6px;line-height:1}
.qc-item-del:hover{color:var(--red)}

.qc-total-bar{display:flex;justify-content:space-between;align-items:baseline;padding:18px 16px;background:var(--deep);border:1px solid var(--line-strong);margin:12px 0}
.qc-total-label{font-family:var(--mono);font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:var(--ink-dim)}
.qc-total-val{font-family:var(--serif);font-size:36px;font-weight:400;color:var(--ink);letter-spacing:-.02em}
.qc-total-val .cur{font-family:var(--mono);font-size:13px;color:var(--ink-dim);margin-right:4px;letter-spacing:.1em}

.qc-actions{display:flex;gap:10px;margin-top:10px}
.btn-primary,.qc-btn-save{flex:2;padding:16px;background:var(--coral);color:var(--abyss);border:none;font-family:var(--mono);font-size:11px;font-weight:600;letter-spacing:.24em;text-transform:uppercase;cursor:pointer;transition:.2s}
.btn-primary:hover,.qc-btn-save:hover{background:#f19875}
.btn-ghost,.qc-btn-clear{flex:1;padding:16px;background:transparent;color:var(--ink-dim);border:1px solid var(--line);font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;cursor:pointer;transition:.2s}
.btn-ghost:hover,.qc-btn-clear:hover{color:var(--ink);border-color:var(--line-strong)}
.qc-success{text-align:center;padding:14px;background:rgba(91,154,124,.1);border:1px solid var(--kelp);color:var(--kelp);font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;margin:10px 0}

.date-range{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.cust-actions{display:flex;gap:6px;margin-bottom:10px;flex-wrap:wrap}
.cust-act-btn{flex:1;min-width:70px;padding:9px 8px;border:1px solid var(--line);background:transparent;color:var(--ink-dim);font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;cursor:pointer;transition:.2s}
.cust-act-btn:hover{color:var(--ink);border-color:var(--line-strong)}
.cust-search-wrap{position:relative;margin-bottom:8px}
.cust-search{width:100%;padding:11px 14px 11px 34px;border:1px solid var(--line);background:var(--deep);color:var(--ink);font-size:13px}
.cust-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--ink-dim);font-size:12px;pointer-events:none;font-family:var(--mono)}
.cust-select-box{background:var(--deep);border:1px solid var(--line);max-height:200px;overflow-y:auto}
.cust-option{display:flex;align-items:center;gap:12px;padding:10px 14px;cursor:pointer;font-size:13px;color:var(--ink);border-bottom:1px solid var(--line)}
.cust-option:last-child{border-bottom:none}
.cust-option:hover{background:var(--panel-2)}
.cust-option input[type=checkbox]{width:14px;height:14px;accent-color:var(--coral);cursor:pointer;flex-shrink:0}

.settle-summary-bar{background:var(--panel);border:1px solid var(--line);padding:20px;margin-bottom:16px;display:grid;grid-template-columns:1fr 1fr;gap:20px}
.settle-sum-label{font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:6px}
.settle-sum-val{font-family:var(--serif);font-size:24px;font-weight:400;color:var(--ink)}
.settle-sum-range{grid-column:1/-1;font-family:var(--mono);font-size:10px;letter-spacing:.2em;color:var(--ink-dim);padding-bottom:10px;border-bottom:1px solid var(--line);margin-bottom:4px;text-transform:uppercase}
.settle-customer-block{background:var(--panel);border:1px solid var(--line);margin-bottom:12px}
.settle-cust-header{padding:14px 18px;background:var(--panel-2);display:flex;justify-content:space-between;align-items:center;cursor:pointer;user-select:none;border-bottom:1px solid var(--line)}
.settle-cust-name{font-family:var(--serif);font-size:18px;color:var(--ink);display:flex;align-items:center;gap:8px}
.settle-cust-total{font-family:var(--serif);font-size:20px;color:var(--coral)}
.settle-cust-body{padding:6px 18px 14px}
.settle-item-row{display:flex;padding:10px 0;border-bottom:1px solid var(--line);font-size:12px;gap:12px;align-items:center}
.settle-item-row:last-child{border-bottom:none}
.settle-item-date{font-family:var(--mono);color:var(--ink-dim);min-width:90px;flex-shrink:0;letter-spacing:.1em;font-size:10px}
.settle-item-name{color:var(--ink);flex:1;font-size:13px}
.settle-item-rev{font-family:var(--mono);color:var(--coral);text-align:right;min-width:80px;font-weight:500}
.settle-empty{text-align:center;padding:60px 20px;color:var(--ink-dim);font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase}
.settle-empty .icon{font-family:var(--serif);font-size:44px;font-style:italic;color:var(--coral);margin-bottom:14px}

.gs-bar{background:var(--panel-2);border:1px solid var(--line);padding:10px 14px;font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;display:flex;align-items:center;gap:10px;margin-bottom:14px;color:var(--ink-dim)}
.gs-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.gs-dot.ok{background:var(--kelp)}.gs-dot.err{background:var(--red)}.gs-dot.local{background:var(--coral)}.gs-dot.syncing{background:var(--glow);animation:pulse 1s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

.modal-bg{display:none;position:fixed;inset:0;background:rgba(5,16,26,.75);backdrop-filter:blur(8px);z-index:300;justify-content:center;align-items:flex-end}
.modal-bg.open{display:flex;animation:fadeIn .2s}
.modal{background:var(--panel);border:1px solid var(--line-strong);border-bottom:none;width:100%;max-width:640px;max-height:80vh;overflow-y:auto;padding:28px;position:relative;animation:slideUp .3s ease}
@keyframes slideUp{from{transform:translateY(30px);opacity:0}to{transform:none;opacity:1}}
.modal h3{font-family:var(--serif);font-size:26px;font-weight:400;color:var(--ink);margin-bottom:18px}
.modal-row{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--line);font-size:13px;gap:14px}
.modal-row:last-child{border-bottom:none}
.modal-row span:first-child{font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-dim);flex-shrink:0}
.modal-row span:last-child{font-family:var(--serif);font-size:16px;color:var(--ink);text-align:right}
.modal-close{position:absolute;top:18px;right:18px;background:none;border:1px solid var(--line);color:var(--ink-dim);font-size:16px;cursor:pointer;width:34px;height:34px;display:flex;align-items:center;justify-content:center;transition:.2s}
.modal-close:hover{color:var(--ink);border-color:var(--line-strong)}

.confirm-bg{display:none;position:fixed;inset:0;background:rgba(5,16,26,.8);backdrop-filter:blur(10px);z-index:400;justify-content:center;align-items:center;padding:24px}
.confirm-bg.open{display:flex}
.confirm-box{background:var(--panel);border:1px solid var(--line-strong);padding:32px;width:100%;max-width:360px;text-align:center}
.confirm-box h3{font-family:var(--serif);font-size:26px;font-weight:400;color:var(--ink);margin-bottom:8px}
.confirm-box h3 em{font-style:italic;color:var(--coral)}
.confirm-box p{font-family:var(--sans);font-size:13px;color:var(--ink-dim);margin-bottom:22px;line-height:1.6}
.confirm-btns{display:flex;gap:10px}
.confirm-btns button{flex:1;padding:13px;border:none;font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;cursor:pointer;transition:.2s}
.btn-cancel{background:transparent;color:var(--ink-dim);border:1px solid var(--line)!important}
.btn-cancel:hover{color:var(--ink)}
.btn-del{background:var(--red);color:#fff}
.btn-del:hover{background:#e87469}

#loading-overlay{display:none;position:fixed;inset:0;background:rgba(5,16,26,.96);z-index:999;justify-content:center;align-items:center;flex-direction:column;gap:20px}
.loader{width:36px;height:36px;border:1px solid rgba(232,236,240,.2);border-top-color:var(--coral);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
#loading-msg{font-family:var(--mono);font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--ink)}

#setup-overlay{display:none;position:fixed;inset:0;background:var(--abyss);z-index:998;justify-content:center;align-items:center;padding:24px}
.setup-card{background:var(--panel);border:1px solid var(--line-strong);padding:36px;width:100%;max-width:420px;position:relative}
.setup-card::before{content:"";position:absolute;top:0;left:0;width:40px;height:1px;background:var(--coral)}
.setup-sigil{width:54px;height:54px;border-radius:50%;border:1px solid var(--line-strong);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-style:italic;font-size:26px;color:var(--glow);margin:0 auto 16px}
.setup-card h2{font-family:var(--serif);font-size:26px;font-weight:400;text-align:center;margin-bottom:6px}
.setup-card h2 em{font-style:italic;color:var(--coral)}
.setup-card p{font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-dim);text-align:center;margin-bottom:22px}

.scroll-top{position:fixed;bottom:24px;right:24px;background:var(--coral);color:var(--abyss);border:none;width:44px;height:44px;font-size:18px;cursor:pointer;box-shadow:0 6px 20px rgba(0,0,0,.4);display:none;z-index:200;align-items:center;justify-content:center;font-family:var(--mono);font-weight:600}
.scroll-top.show{display:flex}

.empty{text-align:center;padding:60px 20px;color:var(--ink-dim);font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase}
.empty .icon{font-family:var(--serif);font-size:44px;font-style:italic;color:var(--coral);margin-bottom:14px}

@media(max-width:600px){
  .page{padding:20px 16px 60px}
  .page-title{font-size:34px}
  nav.tabs{top:63px}
  .tab{padding:14px 6px;font-size:9px;letter-spacing:.2em;min-width:82px}
  .tab .tn{display:none}
  .card-value{font-size:26px}
  .qc-add-row{flex-wrap:wrap}
  .qc-add-row .form-group{flex:1 1 100%!important}
  .qc-add-btn{flex:1 1 100%}
}
