:root{--tg-font: "Noto Sans Thai", system-ui, sans-serif;--tg-safe-b: env(safe-area-inset-bottom, 0px);--tg-safe-t: env(safe-area-inset-top, 0px);--tg-topbar-h: calc(52px + var(--tg-safe-t));--bg: #111827;--bg2: #1f2937;--bg3: #374151;--surface: #1f2937;--surface-elevated: #374151;--border: rgba(255, 255, 255, .08);--border2: rgba(255, 255, 255, .12);--text: #f9fafb;--text2: #d1d5db;--text3: #9ca3af;--muted: #9ca3af;--accent: #0070f3;--accent2: #3b9fff;--accent-bg: rgba(0, 112, 243, .14);--accent-soft: rgba(0, 112, 243, .12);--green: #059669;--red: #dc2626;--amber: #d97706;--overlay-scrim: rgba(0, 0, 0, .55);--toast-bg: rgba(31, 41, 55, .97);--toast-border: rgba(255, 255, 255, .1);--toast-shadow: 0 10px 36px rgba(0, 0, 0, .45);--toast-inset: rgba(255, 255, 255, .04);--toast-detail: rgba(255, 255, 255, .68);--toast-title: #f9fafb;--ghost-btn-bg: rgba(255, 255, 255, .06);--ghost-btn-border: rgba(255, 255, 255, .1);--r: 8px;--r2: 12px;--r3: 16px;--space-2: 8px;--space-3: 12px}[data-theme=light]{--bg: #f4f5f7;--bg2: #ffffff;--bg3: #ececee;--surface: #ffffff;--surface-elevated: #f4f5f7;--border: #e5e7eb;--border2: #d1d5db;--text: #111827;--text2: #4b5563;--text3: #6b7280;--muted: #6b7280;--overlay-scrim: rgba(0, 0, 0, .35);--toast-bg: rgba(255, 255, 255, .97);--toast-border: rgba(0, 0, 0, .1);--toast-shadow: 0 10px 36px rgba(0, 0, 0, .12);--toast-inset: rgba(0, 0, 0, .03);--toast-detail: rgba(17, 24, 39, .68);--toast-title: var(--text);--ghost-btn-bg: rgba(0, 0, 0, .05);--ghost-btn-border: rgba(0, 0, 0, .1)}.btn-ghost{background:var(--ghost-btn-bg);border-color:var(--ghost-btn-border);color:var(--text2)}.btn-ghost:active{opacity:.85}.btn-icon{min-width:40px;width:40px;padding:0;display:inline-flex;align-items:center;justify-content:center}.btn-icon svg{display:block}.btn-secondary{background:var(--bg3);border-color:var(--border2);color:var(--text)}.btn-danger{background:var(--red);border-color:var(--red);color:#fff}.topbar-actions{display:flex;align-items:center;gap:6px;flex-shrink:0;margin-left:auto}@keyframes tgToastIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.toast-container{position:fixed;top:calc(var(--tg-topbar-h) + 4px);left:max(12px,env(safe-area-inset-left,0px));right:max(12px,env(safe-area-inset-right,0px));z-index:9999;display:flex;flex-direction:column;gap:6px;pointer-events:none;max-width:480px;margin:0 auto}.toast{display:flex;align-items:flex-start;gap:10px;padding:11px 14px;border-radius:var(--r2);font-size:13px;line-height:1.35;color:var(--text);animation:tgToastIn .22s cubic-bezier(.22,1,.36,1);pointer-events:none;max-height:72px;overflow:hidden;background:var(--toast-bg);border:1px solid var(--toast-border);box-shadow:var(--toast-shadow),0 1px 0 var(--toast-inset) inset;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.toast-icon{flex-shrink:0;width:16px;height:16px;margin-top:1px;display:inline-flex;align-items:center;justify-content:center}.toast-copy{min-width:0;flex:1}.toast-title{display:block;color:var(--toast-title);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.toast-detail{display:block;color:var(--toast-detail);font-size:12px;margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.toast-success{border-color:#05966959;box-shadow:var(--toast-shadow),inset 3px 0 0 var(--green)}.toast-success .toast-icon{color:var(--green)}.toast-error{border-color:#dc262659;box-shadow:var(--toast-shadow),inset 3px 0 0 var(--red)}.toast-error .toast-icon{color:var(--red)}.toast-warn{border-color:#d9770659;box-shadow:var(--toast-shadow),inset 3px 0 0 var(--amber)}.toast-warn .toast-icon{color:var(--amber)}.toast-info{border-color:#0070f359;box-shadow:var(--toast-shadow),inset 3px 0 0 var(--accent)}.toast-info .toast-icon{color:var(--accent)}.toast--has-action{pointer-events:auto;max-height:none;align-items:center}.toast-action{flex-shrink:0;margin-left:4px;padding:5px 10px;border-radius:var(--r);border:1px solid rgba(0,112,243,.4);background:var(--accent-bg);color:var(--accent2);font-size:12px;font-weight:600;cursor:pointer;font-family:var(--tg-font)}#modal-container{position:relative;z-index:7000}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay-scrim);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:7000;display:flex;align-items:flex-end;justify-content:center}.modal-overlay:not(.modal-overlay--center){opacity:0;pointer-events:none;transition:opacity .3s ease}.modal-overlay:not(.modal-overlay--center).is-open{opacity:1;pointer-events:auto}.modal-overlay:not(.modal-overlay--center) .modal-bottom-wrap{transform:translateY(100%);transition:transform .35s cubic-bezier(.32,.72,0,1);border-radius:24px 24px 0 0}.modal-overlay:not(.modal-overlay--center).is-open .modal-bottom-wrap{transform:translateY(0)}.modal-overlay--center{align-items:center;justify-content:center;padding:max(16px,var(--tg-safe-t)) 16px max(16px,var(--tg-safe-b));opacity:1;pointer-events:auto}.modal-overlay--center>.modal-sheet-wrap{width:100%;max-width:340px;margin:0 auto}.modal{background:var(--bg2);border:1px solid var(--border2);border-radius:var(--r3) var(--r3) 0 0;width:100%;max-width:640px;max-height:92vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 12px 32px #00000059;padding-bottom:var(--tg-safe-b)}.modal.modal--center{border-radius:var(--r3);max-width:340px;padding-bottom:0}.modal-handle{width:36px;height:4px;border-radius:2px;background:var(--border2);margin:12px auto 4px;flex-shrink:0}.modal-header{padding:8px 20px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px}.modal-title{font-size:17px;font-weight:600;color:var(--text)}.modal-body{padding:20px;flex:1;min-height:0;overflow-y:auto;color:var(--text2)}.modal-footer{padding:14px 20px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px;flex-shrink:0}.modal-footer .btn{flex:1 1 0;min-width:72px}.btn-close-round{width:36px;height:36px;min-width:36px;padding:0;border-radius:50%;border:1px solid var(--border2);background:var(--bg3);color:var(--text3);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;font-family:var(--tg-font)}.btn-close-round:active{opacity:.85}.filter-bar-compact.dash-panel{padding:var(--space-3);background:var(--surface);border:1px solid var(--border);border-radius:var(--r2);margin-bottom:12px}.dash-seg{display:flex;gap:4px;padding:4px;background:var(--bg3);border-radius:12px;margin-bottom:var(--space-2)}.dash-seg:last-child{margin-bottom:0}.dash-seg-btn{flex:1;padding:8px 10px;border:none;border-radius:9px;font-size:12px;font-weight:500;font-family:var(--tg-font);color:var(--text3);background:transparent;cursor:pointer;transition:background .18s,color .18s}.dash-seg-btn.active{background:var(--accent-bg);color:var(--accent2);font-weight:600;box-shadow:inset 0 0 0 1px #0070f359}.dash-seg--2 .dash-seg-btn{font-size:12px}.dash-seg--3 .dash-seg-btn{font-size:11px;padding:8px 6px}.dash-seg--4 .dash-seg-btn{font-size:10px;padding:8px 4px}.dash-seg--5 .dash-seg-btn{font-size:9px;padding:7px 3px}.dash-seg--status .dash-seg-btn{font-size:10px;padding:7px 5px}.filter-date-row{display:flex;align-items:center;gap:6px;margin-bottom:var(--space-2)}.filter-date-row .dash-seg{flex:1;margin-bottom:0}.filter-custom-dates{display:flex;align-items:center;gap:8px;margin-bottom:var(--space-2);font-size:12px}.filter-custom-label{color:var(--muted);font-weight:600}.filter-date-in{flex:1;min-width:0;padding:8px;font-size:13px}.btn-icon-plain{min-height:36px;min-width:36px;padding:6px;border:none!important;background:transparent!important;color:var(--text2);box-shadow:none!important}.btn-icon-plain:active{opacity:.7}.btn-cal-range{flex-shrink:0}.filter-bar-row{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-2)}.search-wrap{position:relative;flex:1;min-width:0}.search-wrap svg{position:absolute;left:13px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--text3);pointer-events:none}.search-input,.field-input{width:100%;padding:10px 12px 10px 40px;border:1px solid var(--border);border-radius:var(--r);font-family:var(--tg-font);font-size:15px;background:var(--bg2);color:var(--text);min-height:40px;box-sizing:border-box}.search-input:focus,.field-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.link-box-label{display:flex;align-items:center;gap:6px}.link-box-label .sec-icon{display:inline-flex;color:var(--accent)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--tg-font, "Noto Sans Thai", sans-serif);background:var(--bg);color:var(--text);line-height:1.5;padding-bottom:env(safe-area-inset-bottom)}.app-shell{max-width:480px;margin:0 auto;min-height:100vh;padding-bottom:calc(64px + env(safe-area-inset-bottom))}.topbar{position:sticky;top:0;z-index:10;background:var(--surface);border-bottom:1px solid var(--border);padding:12px 16px;display:flex;align-items:center;gap:10px}.topbar h1{font-size:16px;color:var(--text)}.topbar-text{flex:1;min-width:0}.topbar .sub{font-size:11px;color:var(--muted)}.brand-logo-wrap{flex-shrink:0;display:flex;align-items:center;width:var(--tg-logo-size, 40px);height:var(--tg-logo-size, 40px)}.brand-logo-wrap .tg-logo{padding:0;width:100%;height:100%}.brand-logo-wrap .tg-logo--inline>img{display:block;width:100%;height:100%;object-fit:contain}.login-box{max-width:400px;margin:0 auto;padding:32px 16px 24px}.login-box .brand-logo-wrap{display:flex;justify-content:center;margin-bottom:12px;width:auto;height:auto;--tg-logo-size: 72px}.banner{background:#fef3c7;color:#92400e;padding:10px 16px;font-size:13px;border-bottom:1px solid #fde68a}.content{padding:12px 16px 24px}.btn{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:10px 16px;border-radius:10px;border:1px solid var(--border);background:var(--surface);font-family:inherit;font-size:14px;font-weight:600;cursor:pointer;text-decoration:none;color:var(--text);gap:6px}.btn-inner{display:inline-flex;align-items:center;gap:6px}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-block{width:100%}.btn-sm{min-height:36px;padding:6px 12px;font-size:13px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius, 12px);padding:14px;margin-bottom:10px}.card h3{font-size:15px;margin-bottom:4px;color:var(--text)}.card .meta{font-size:12px;color:var(--muted)}.status{display:inline-block;font-size:11px;font-weight:700;padding:3px 8px;border-radius:6px;background:var(--accent-soft, var(--accent-bg));color:var(--accent)}.status.published{background:#05966924;color:var(--green, #059669)}.field{margin-bottom:12px}.field label{display:block;font-size:12px;font-weight:600;color:var(--muted);margin-bottom:4px}.field-hint{font-size:11px;color:var(--muted);margin:0 0 6px;line-height:1.4}.field input,.field textarea,.field select{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;font-family:inherit;font-size:15px;background:var(--bg2);color:var(--text)}.field textarea{min-height:100px;resize:vertical}.day-block{border:1px solid var(--border);border-radius:var(--radius, 12px);margin-bottom:10px;overflow:hidden}.day-head{padding:12px 14px;background:var(--bg3);font-weight:600;font-size:14px}.item-edit{padding:12px 14px;border-top:1px solid var(--border)}.tabs{display:flex;gap:6px;margin-bottom:12px;flex-wrap:wrap}.tabs .btn{flex:1;min-width:72px}.revision-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius, 12px);padding:12px;margin-bottom:8px}.revision-meta{display:flex;justify-content:space-between;align-items:center;font-size:13px;gap:8px}.revision-meta span{color:var(--muted);font-size:12px}.revision-actions{display:flex;gap:6px;margin-top:8px}.revision-actions .btn{flex:1}.revision-banner{font-size:12px;color:var(--muted);margin-bottom:8px;display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}.build-stamp{text-align:center;font-size:10px;color:var(--muted);padding:10px 16px 16px;font-family:ui-monospace,monospace}.preview-wrap{border:1px solid var(--border);border-radius:var(--radius, 12px);max-height:70vh;overflow:auto;background:var(--bg2)}.checklist label{display:flex;gap:8px;padding:6px 0;font-size:13px}.link-box{background:var(--accent-soft, var(--accent-bg));padding:12px;border-radius:8px;font-size:13px;margin-bottom:12px;border:1px solid rgba(0,112,243,.15)}.link-box--compact{margin-bottom:0;padding:10px}.link-box-label{font-weight:700;font-size:13px;margin-bottom:6px}.link-url{font-size:12px;word-break:break-all;color:var(--accent2, var(--accent));font-family:ui-monospace,monospace;line-height:1.4}.link-hint{font-size:11px;color:var(--muted);margin:0 0 8px;line-height:1.4}.link-actions{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}.link-actions .btn{flex:1;min-width:120px}.card-links{display:flex;align-items:center;gap:8px;margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}.card-link-url{flex:1;font-size:11px;color:var(--accent2, var(--accent));word-break:break-all;font-family:ui-monospace,monospace;line-height:1.3}.card-links .btn{flex-shrink:0}.empty-list{text-align:center;color:var(--muted);margin-top:24px;font-size:14px}#btn-new{margin-bottom:0}.list-toolbar{display:flex;gap:8px;margin-bottom:12px}.list-toolbar .btn-primary{flex:1}.order-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius, 12px);padding:12px 14px;margin-bottom:10px;cursor:pointer;border-left:4px solid var(--muted)}.order-card--published{border-left-color:var(--green, #059669)}.order-card--draft{border-left-color:var(--accent)}.order-card--review{border-left-color:var(--amber, #d97706)}.order-card--archived{border-left-color:var(--muted)}.order-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.order-card-top h3{font-size:15px;flex:1;min-width:0}.order-card-actions{display:flex;gap:4px;flex-shrink:0}.order-card-meta{font-size:12px;color:var(--muted);margin-top:4px}.order-card-badges{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px;align-items:center}.pay-chip{font-size:10px;font-weight:700;padding:3px 8px;border-radius:6px}.pay-chip--unpaid{background:#dc26261f;color:var(--red, #dc2626)}.pay-chip--awaiting_slip{background:#d9770624;color:var(--amber, #d97706)}.pay-chip--paid{background:#05966924;color:var(--green, #059669)}.pay-chip--refunded{background:var(--bg3);color:var(--muted)}.price-badge{font-size:11px;font-weight:700;color:var(--text2)}.view-badge{font-size:11px;color:var(--muted);display:inline-flex;align-items:center;gap:3px}.list-more-hint{text-align:center;font-size:12px;color:var(--muted);padding:12px 0}.banner--warn{background:#fef3c7;color:#92400e}.admin-bnav{position:fixed;left:50%;transform:translate(-50%);bottom:0;width:100%;max-width:480px;display:flex;background:var(--surface);border-top:1px solid var(--border);padding-bottom:env(safe-area-inset-bottom);z-index:20}.admin-bnav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:8px 4px;font-size:10px;color:var(--muted);text-decoration:none}.admin-bnav-item.active{color:var(--accent);font-weight:700}.kpi-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px}.kpi-grid--pl{grid-template-columns:1fr}.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px}.kpi-label{font-size:11px;color:var(--muted);margin-bottom:4px}.kpi-value{font-size:18px;font-weight:700}.kpi-card--green .kpi-value{color:var(--green, #059669)}.kpi-card--red .kpi-value{color:var(--red, #dc2626)}.kpi-card--amber .kpi-value{color:var(--amber, #d97706)}.section-title{font-size:14px;font-weight:700;margin:16px 0 10px}.alert-strip{padding:10px 12px;border-radius:8px;font-size:13px;margin-bottom:12px;background:#d977061f;color:var(--amber, #d97706)}.btn-link{background:none;border:none;color:var(--accent);font-weight:700;cursor:pointer;text-decoration:underline;padding:0}.chart-bars{display:flex;align-items:flex-end;gap:6px;height:140px;margin-bottom:8px}.chart-bar-col{flex:1;display:flex;flex-direction:column;align-items:center;min-width:0;height:100%}.chart-bar{width:100%;max-width:36px;background:var(--accent);border-radius:4px 4px 0 0;margin-top:auto;min-height:4px}.chart-bar-label{font-size:9px;color:var(--muted);margin-top:4px;text-align:center;white-space:pre-line}.chart-bar-sub{font-size:9px;color:var(--text2)}.month-picker-row{display:flex;align-items:center;gap:8px;margin-bottom:12px;flex-wrap:wrap}.month-picker-label{font-size:13px;font-weight:600}.row-2{display:grid;grid-template-columns:1fr 1fr;gap:8px}.exp-form{margin-bottom:16px}.exp-row{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:10px 12px;margin-bottom:8px}.exp-row-main{display:flex;justify-content:space-between;font-size:14px}.exp-amount{font-weight:700}.exp-row-meta{font-size:12px;color:var(--muted);margin:4px 0 8px}.audit-row{display:flex;justify-content:space-between;gap:8px;font-size:12px;padding:8px 0;border-bottom:1px solid var(--border)}.audit-row span{color:var(--muted);flex-shrink:0}.finance-block{margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--border)}:root{--tg-brand-teal: #00c9b7;--tg-brand-blue: #0070f3;--tg-brand-blue-deep: #0052cc;--tg-brand-ink: #111827;--tg-brand-surface: #f4f5f7;--tg-logo-clear-space: .25}.tg-logo{display:inline-block;box-sizing:content-box;padding:calc(var(--tg-logo-size, 48px) * var(--tg-logo-clear-space));line-height:0}.tg-logo>img,.tg-logo>svg{display:block;width:var(--tg-logo-size, 48px);height:var(--tg-logo-size, 48px);object-fit:contain;object-position:center;flex-shrink:0}.tg-logo--icon{--tg-logo-size: 48px;padding:0}.tg-logo--inline{padding:0;width:var(--tg-logo-size, 48px);height:var(--tg-logo-size, 48px);flex-shrink:0}.tg-logo--inline>img,.tg-logo--inline>svg{width:100%;height:100%;max-width:100%;max-height:100%}.tg-logo--icon>img,.tg-logo--icon>svg{width:var(--tg-logo-size, 48px);height:var(--tg-logo-size, 48px)}
