:root{--color-bg: #f7f7f5;--color-surface: #ffffff;--color-border: #e2e0de;--color-text: #1a1a1a;--color-text-muted: #777;--color-primary: #f7931a;--color-primary-hover: #e07d0e;--color-danger: #e53935;--color-success: #43a047;--color-hover: #efeeec;--radius: 8px;--font: "Outfit", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font);background:var(--color-bg);color:var(--color-text);line-height:1.6}.portal-layout{min-height:100vh;display:flex;flex-direction:column}.portal-header{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.25rem;background:var(--color-surface);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:100;box-shadow:0 1px 3px #0000000a}.brand{font-weight:700;letter-spacing:.05em;color:var(--color-primary);font-size:1rem}.header-right{display:flex;align-items:center;gap:.5rem;margin-left:auto}.hamburger-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:transparent;border:none;border-radius:var(--radius);cursor:pointer;transition:background .15s;flex-shrink:0}.hamburger-btn:hover{background:var(--color-hover)}.hamburger-icon{display:flex;flex-direction:column;justify-content:center;align-items:center;width:20px;height:20px;position:relative}.hamburger-icon span{display:block;width:18px;height:2px;background:var(--color-text);border-radius:1px;transition:transform .25s ease,opacity .2s ease;position:absolute}.hamburger-icon span:nth-child(1){transform:translateY(-6px)}.hamburger-icon span:nth-child(2){transform:translateY(0)}.hamburger-icon span:nth-child(3){transform:translateY(6px)}.hamburger-icon.open span:nth-child(1){transform:rotate(45deg)}.hamburger-icon.open span:nth-child(2){opacity:0}.hamburger-icon.open span:nth-child(3){transform:rotate(-45deg)}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;z-index:200;animation:fadeIn .2s ease}.drawer{position:fixed;top:0;left:0;bottom:0;width:280px;max-width:80vw;background:var(--color-surface);z-index:300;transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:2px 0 12px #00000014;display:flex;flex-direction:column;overflow-y:auto}.drawer--open{transform:translate(0)}.drawer-nav{display:flex;flex-direction:column;padding:1.25rem 0;margin-top:3.5rem}.drawer-link{display:block;padding:.75rem 1.5rem;color:var(--color-text-muted);text-decoration:none;font-size:.95rem;font-weight:500;transition:color .15s,background .15s,border-color .15s;border-left:3px solid transparent}.drawer-link:hover{color:var(--color-text);background:var(--color-hover)}.drawer-link.active{color:var(--color-primary);background:#f7931a0f;border-left-color:var(--color-primary);font-weight:600}.drawer-link--sub{padding-left:2.5rem;font-size:.9rem}.drawer-divider{height:1px;background:var(--color-border);margin:.5rem 1.5rem}.drawer-link--danger{color:var(--color-danger);font-family:var(--font);font-size:1rem;text-align:left;width:100%;border:none;background:transparent;cursor:pointer}.drawer-link--danger:hover{background:#e5393514;color:var(--color-danger)}.drawer-group{display:flex;flex-direction:column}.drawer-group-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.75rem 1.5rem;background:transparent;border:none;border-left:3px solid transparent;color:var(--color-text-muted);font-size:.95rem;font-weight:500;cursor:pointer;text-align:left;transition:color .15s,background .15s}.drawer-group-toggle:hover{color:var(--color-text);background:var(--color-hover)}.drawer-chevron{display:inline-block;width:8px;height:8px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg);transition:transform .2s ease}.drawer-group-toggle.open .drawer-chevron{transform:rotate(-135deg)}.drawer-submenu{display:flex;flex-direction:column}.portal-nav{display:flex;gap:1.5rem;margin-left:auto}.portal-nav a{color:var(--color-text-muted);text-decoration:none;padding:.5rem 0;border-bottom:2px solid transparent;transition:all .2s}.portal-nav a.active,.portal-nav a:hover{color:var(--color-text);border-bottom-color:var(--color-primary)}.lock-indicator{display:flex;align-items:center;padding:.375rem;border:1px solid transparent;border-radius:var(--radius);background:transparent;color:var(--color-text-muted);cursor:default;transition:background .15s,border-color .15s,color .15s}.lock-indicator--locked{cursor:pointer;color:var(--color-warning, #d97706)}.lock-indicator--locked:hover{background:var(--color-hover);border-color:var(--color-border)}.lock-icon{flex-shrink:0}.shutdown-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;display:flex;align-items:center;justify-content:center;background:#0009;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.shutdown-card{background:var(--color-bg, #fff);border-radius:12px;padding:2.5rem 2rem;width:100%;max-width:360px;text-align:center;box-shadow:0 8px 32px #0000004d}.shutdown-title{font-size:1.25rem;font-weight:600;margin:1rem 0 .5rem}.shutdown-desc{font-size:.875rem;color:var(--color-text-muted, #666);margin:0 0 1.25rem;line-height:1.5}.shutdown-input{width:100%;padding:.625rem .75rem;border:1px solid var(--color-border, #ddd);border-radius:var(--radius, 6px);font-size:.9rem;box-sizing:border-box;margin-bottom:.75rem}.shutdown-input:focus{outline:none;border-color:var(--color-primary, #2563eb);box-shadow:0 0 0 2px #2563eb26}.shutdown-error{color:var(--color-error, #dc2626);font-size:.8rem;margin:-.25rem 0 .75rem}.shutdown-btn{width:100%;padding:.625rem;border:none;border-radius:var(--radius, 6px);font-size:.9rem;cursor:pointer;transition:opacity .15s}.shutdown-btn:disabled{opacity:.5;cursor:not-allowed}.shutdown-btn--primary{background:var(--color-primary, #2563eb);color:#fff;margin-bottom:.5rem}.shutdown-btn--primary:hover:not(:disabled){opacity:.9}.shutdown-btn--secondary{background:transparent;color:var(--color-text-muted, #666);border:1px solid var(--color-border, #ddd)}.shutdown-btn--secondary:hover:not(:disabled){background:var(--color-hover, #f5f5f5)}.portal-content{flex:1;padding:2rem;max-width:1200px;margin:0 auto;width:100%}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.5rem;text-align:center;box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a;transition:box-shadow .2s}.stat-card:hover{box-shadow:0 2px 8px #00000014,0 1px 3px #0000000f}.stat-value{font-size:2rem;font-weight:700;color:var(--color-primary)}.stat-label{color:var(--color-text-muted);margin-top:.25rem}.panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.5rem;margin-bottom:1rem;box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a}.panel.alert{border-color:var(--color-primary)}.panel h2{margin-bottom:1rem;font-size:1.1rem}.login-page,.onboarding-page,.settings-page,.vouchers-page{padding:2rem;max-width:800px;margin:0 auto}.dashboard-page{padding:2rem;max-width:1000px;margin:0 auto}.login-page{max-width:480px;margin-top:10vh}.login-form{background:var(--color-surface);border-radius:var(--radius);padding:2rem;box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a;border:1px solid var(--color-border)}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;color:var(--color-text-muted)}.form-group input{width:100%;padding:.75rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);font-size:1rem;transition:border-color .15s,box-shadow .15s}.form-group input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #f7931a1f}button,.btn-primary{padding:.75rem 1.5rem;background:var(--color-primary);color:#000;border:none;border-radius:var(--radius);font-weight:600;cursor:pointer;font-family:var(--font);font-size:.9rem;transition:background .2s,box-shadow .2s,transform .1s}button:hover{background:var(--color-primary-hover);box-shadow:0 2px 6px #f7931a40}button:active{transform:translateY(.5px)}button:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover{background:#c62828}.security-note{margin-top:1rem;font-size:.85rem;color:var(--color-text-muted)}.loading,.error{padding:2rem;text-align:center;color:var(--color-text-muted)}.onboarding-layout{display:grid;grid-template-columns:200px 1fr;gap:2rem;margin-top:2rem}.onboarding-header-row{display:flex;align-items:center;justify-content:space-between;gap:1rem}.step-nav{display:flex;flex-direction:column;gap:.5rem}.step{padding:.5rem 1rem;border-radius:var(--radius);color:var(--color-text-muted)}.step.completed{color:var(--color-success)}.step.current{background:var(--color-hover);color:var(--color-text);font-weight:600}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}@media (max-width: 768px){.portal-header{padding:.75rem 1rem}.portal-content{padding:1rem}.stats-grid{grid-template-columns:repeat(2,1fr)}.onboarding-layout,.settings-layout{grid-template-columns:1fr}.onboarding-header-row{flex-direction:column;align-items:flex-start}}.step-form{max-width:600px}.step-description{color:var(--color-text-muted);margin-bottom:1.5rem}.step-actions{display:flex;gap:1rem;margin-top:2rem;justify-content:flex-end}.btn-secondary{padding:.75rem 1.5rem;background:transparent;color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius);cursor:pointer}.btn-secondary:hover{border-color:var(--color-text-muted)}textarea{width:100%;padding:.75rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);font-family:var(--font);font-size:1rem;resize:vertical}select{width:100%;padding:.75rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);font-size:1rem}.chip-group{display:flex;flex-wrap:wrap;gap:.5rem}.chip{padding:.5rem 1rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:20px;color:var(--color-text-muted);cursor:pointer;font-size:.9rem}.chip.active{background:var(--color-primary);color:#000;border-color:var(--color-primary)}.chip.required{opacity:.7;cursor:default}.help-text{font-size:.85rem;color:var(--color-text-muted);margin-top:.25rem}.review-summary{display:flex;flex-direction:column;gap:1rem}.review-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1rem;box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a}.review-section h3{font-size:.9rem;color:var(--color-text-muted);margin-bottom:.5rem}.voucher-table{width:100%;border-collapse:collapse}.voucher-table th{text-align:left;padding:.75rem;border-bottom:2px solid var(--color-border);color:var(--color-text-muted);font-size:.85rem;text-transform:uppercase;letter-spacing:.05em}.voucher-table td{padding:.75rem;border-bottom:1px solid var(--color-border)}.voucher-table tr.clickable{cursor:pointer}.voucher-table tr.clickable:hover{background:var(--color-hover)}.voucher-id{font-family:monospace;color:var(--color-text-muted)}.btn-small{padding:.3rem .75rem;font-size:.85rem}.voucher-filters{display:flex;gap:1rem;margin-bottom:1.5rem;align-items:center}.filter-group select,.filter-group input{min-width:180px}.empty-state{text-align:center;padding:3rem;color:var(--color-text-muted)}@media (max-width: 768px){.voucher-table{display:none}.voucher-filters{flex-direction:column}}.create-voucher-page{max-width:600px;padding:2rem;margin:0 auto}.form-row{display:flex;gap:1rem}.error-banner{background:#e539351a;border:1px solid var(--color-danger);border-radius:var(--radius);padding:.75rem;color:var(--color-danger);margin-bottom:1rem}.voucher-detail-page{padding:2rem;max-width:800px;margin:0 auto}.back-btn{margin-bottom:1.5rem}.voucher-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:2rem}.detail-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1rem;box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a}.detail-card.full-width{grid-column:1 / -1}.detail-card h3{font-size:.8rem;color:var(--color-text-muted);text-transform:uppercase;margin-bottom:.5rem}.detail-value{font-size:1.1rem}.voucher-actions{margin-top:2rem}.activity-chart{padding:1rem 0}.chart-legend{display:flex;gap:1.5rem;margin-bottom:1rem;font-size:.85rem;color:var(--color-text-muted)}.legend-item{display:flex;align-items:center;gap:.4rem}.dot{width:10px;height:10px;border-radius:50%}.dot.issued{background:var(--color-primary)}.dot.redeemed{background:var(--color-success)}.chart-bars{display:flex;gap:4px;align-items:flex-end;height:150px}.chart-day{display:flex;flex-direction:column;align-items:center;flex:1;min-width:0}.bar-group{display:flex;gap:2px;align-items:flex-end;height:120px;width:100%}.bar{flex:1;border-radius:2px 2px 0 0;min-height:2px;transition:height .3s}.bar.issued{background:var(--color-primary)}.bar.redeemed{background:var(--color-success)}.chart-label{font-size:.7rem;color:var(--color-text-muted);margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.dashboard-panels{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem;margin-bottom:2rem}.sync-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:2rem}.sync-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:2.5rem;max-width:480px;width:100%;box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a}.sync-header{text-align:center;margin-bottom:2rem}.sync-subtitle{color:var(--color-text-muted);margin-top:.5rem}.sync-spinner{width:48px;height:48px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;margin:0 auto 1rem;animation:spin 1s linear infinite}.sync-spinner.done{border-color:var(--color-success);animation:none}.sync-spinner.error{border-color:var(--color-primary);border-top-color:var(--color-danger)}.sync-steps{display:flex;flex-direction:column;gap:.75rem}.sync-step{display:flex;align-items:center;gap:.75rem;padding:.5rem 0}.sync-step-indicator{width:12px;height:12px;border-radius:50%;background:var(--color-border);flex-shrink:0}.sync-step-indicator.active{background:var(--color-primary);animation:pulse 1.5s infinite}.sync-step-indicator.complete{background:var(--color-success)}.sync-step-indicator.error{background:var(--color-danger)}.sync-step-indicator.skipped{background:var(--color-text-muted);opacity:.5}.sync-step.skipped .sync-step-label{color:var(--color-text-muted)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.sync-step-label{font-weight:500}.sync-step-detail{font-size:.85rem;color:var(--color-text-muted)}.sync-warning{background:#f7931a1a;border:1px solid var(--color-primary);border-radius:var(--radius);padding:.75rem;margin-top:1.5rem;text-align:center;font-size:.9rem}.login-choices{display:flex;flex-direction:column;gap:1rem;margin:1.5rem 0}.choice-btn{display:flex;flex-direction:column;align-items:flex-start;padding:1.25rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);cursor:pointer;text-align:left;width:100%;transition:border-color .2s}.choice-btn:hover{border-color:var(--color-primary)}.choice-icon{font-size:1.5rem;margin-bottom:.5rem}.choice-label{font-weight:600;font-size:1.05rem;color:var(--color-text)}.choice-detail{font-size:.85rem;color:var(--color-text-muted);margin-top:.25rem}.readonly-field{background:var(--color-bg)!important;border-color:var(--color-border)!important;cursor:text;font-family:monospace;font-size:.85rem}.nsec-field{color:var(--color-primary)}.nsec-reveal-group{display:flex;gap:.5rem;align-items:center}.nsec-reveal-group input{flex:1}.btn-small{padding:.4rem .75rem;font-size:.8rem;white-space:nowrap}.warning{color:var(--color-primary)!important}.required{color:var(--color-primary);font-weight:600}.username-input-group{display:flex;align-items:center;gap:0}.username-input-group input{flex:1;border-top-right-radius:0;border-bottom-right-radius:0;border-right:none}.username-suffix{padding:.65rem .75rem;background:var(--color-surface);border:1px solid var(--color-border);border-left:none;border-radius:0 8px 8px 0;color:var(--color-text-muted);font-size:.9rem;white-space:nowrap}.username-status{font-size:.8rem;margin-top:.25rem}.status-available,.status-available.username-status{color:#22c55e}.status-error,.status-error.username-status{color:#ef4444}.status-checking,.status-checking.username-status{color:var(--color-text-muted)}input.status-available{border-color:#22c55e}input.status-error{border-color:#ef4444}.segmented-control{display:flex;gap:0;border:1px solid var(--color-border);border-radius:8px;overflow:hidden}.segmented-control .segment{flex:1;padding:.6rem 1rem;border:none;border-right:1px solid var(--color-border);background:var(--color-bg);color:var(--color-text);cursor:pointer;font-size:.9rem;transition:background .15s,color .15s}.segmented-control .segment:last-child{border-right:none}.segmented-control .segment.active{background:var(--color-primary);color:#fff;font-weight:600}.segmented-control .segment:hover:not(.active){background:var(--color-hover)}.hosted-preview{padding:.75rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px}.hosted-preview .mono{font-family:monospace;font-size:.95rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;color:var(--color-text)}.checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-primary)}.settings-page h1{margin-bottom:1.5rem}.settings-layout{display:grid;grid-template-columns:220px 1fr;gap:2rem;min-height:400px}.settings-nav{display:flex;flex-direction:column;gap:.25rem;position:sticky;top:2rem;align-self:start}.settings-nav-item{display:block;width:100%;padding:.6rem 1rem;background:none;border:none;border-radius:var(--radius);color:var(--color-text-muted);text-align:left;cursor:pointer;font-size:.95rem;transition:all .15s}.settings-nav-item:hover{color:var(--color-text);background:var(--color-hover)}.settings-nav-item.active{color:var(--color-text);background:var(--color-hover);border-left:3px solid var(--color-primary);font-weight:500}.settings-nav-item.danger{color:var(--color-danger)}.settings-nav-item.danger:hover{background:#e539351a}.settings-nav-divider{height:1px;background:var(--color-border);margin:.75rem 0}.settings-divider{border:none;border-top:1px solid var(--color-border);margin:2rem 0 1.5rem}.settings-content{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:2rem;box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a}.settings-section h2{font-size:1.25rem;margin-bottom:1rem}.section-placeholder{color:var(--color-text-muted);margin-bottom:1.5rem}.info-block{display:flex;flex-direction:column;gap:.75rem}.info-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--color-border)}.info-label{color:var(--color-text-muted);font-size:.9rem}.status-pill{padding:.2rem .75rem;border-radius:12px;font-size:.8rem;font-weight:500;text-transform:uppercase;letter-spacing:.03em}.status-pill.active{background:#43a04726;color:var(--color-success)}.status-pill.muted{background:#88888826;color:var(--color-text-muted)}@media (max-width: 768px){.settings-layout{grid-template-columns:1fr}.settings-nav{flex-direction:row;overflow-x:auto;position:static;gap:.5rem;padding-bottom:.5rem;border-bottom:1px solid var(--color-border)}.settings-nav-item{white-space:nowrap;border-left:none!important}.settings-nav-item.active{border-bottom:2px solid var(--color-primary)}.settings-nav-divider{display:none}}.toast{position:fixed;top:1rem;right:1rem;background:var(--color-success);color:#fff;padding:.75rem 1.25rem;border-radius:var(--radius);font-weight:500;z-index:1000;animation:fadeIn .2s}.toast.error{background:var(--color-danger)}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:none}}.mono{font-family:monospace;font-size:.85rem}.clickable{cursor:pointer}.clickable:hover{color:var(--color-primary)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:var(--color-surface);border-radius:12px;padding:2rem;max-width:400px;width:90%;box-shadow:0 8px 32px #0000001f}.modal-content h3{margin:0 0 .5rem}.modal-description{color:var(--color-text-muted);margin-bottom:1.25rem;font-size:.9rem}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1rem}.relay-list{display:flex;flex-direction:column;gap:.5rem}.relay-item{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px}.relay-add-group{display:flex;gap:.5rem;align-items:center}.relay-add-group input{flex:1}.relay-add-group select{width:auto;min-width:120px}@keyframes skeleton-pulse{0%{opacity:.15}50%{opacity:.3}to{opacity:.15}}.skeleton{background:var(--color-border);border-radius:var(--radius);animation:skeleton-pulse 1.2s ease-in-out infinite}.skeleton-value{height:2rem;width:60%;margin:0 auto .5rem}.skeleton-label{height:.875rem;width:40%;margin:0 auto}.skeleton-block{height:6rem;width:100%;margin-bottom:1rem}.skeleton-block-short{height:3rem;width:70%;margin-bottom:1rem}.skeleton-nav{height:2.5rem;width:100%;margin-bottom:1.5rem}.settings-skeleton{display:flex;flex-direction:column;gap:.75rem;margin-top:1.5rem}.range-toggle{display:inline-flex;border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden;margin-bottom:1.5rem}.range-btn{padding:.5rem 1.25rem;border:none;border-right:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-muted);cursor:pointer;font-size:.9rem;transition:background .15s,color .15s}.range-btn:last-child{border-right:none}.range-btn.active{background:var(--color-primary);color:#000;font-weight:600}.range-btn:hover:not(.active){background:var(--color-hover)}.range-btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:-2px}.metrics-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}.metric-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.25rem;box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a;transition:box-shadow .2s}.metric-card:hover{box-shadow:0 2px 8px #00000014,0 1px 3px #0000000f}.metric-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.metric-label{color:var(--color-text-muted);font-size:.85rem}.metric-info-btn{width:22px;height:22px;border-radius:50%;border:1px solid var(--color-border);background:transparent;color:var(--color-text-muted);font-size:.75rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:border-color .15s,color .15s}.metric-info-btn:hover{border-color:var(--color-text);color:var(--color-text)}.metric-info-btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.metric-value{font-size:1.75rem;font-weight:700;color:var(--color-text)}.metric-trend{font-size:.85rem;margin-top:.25rem}.metric-trend.up{color:var(--color-success)}.metric-trend.down{color:var(--color-danger)}.metric-trend.flat{color:var(--color-text-muted)}.trend-flat-label{font-size:.8rem}.info-popup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;display:flex;align-items:center;justify-content:center;z-index:1000}.info-popup{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:2rem;max-width:400px;width:90%}.info-popup h3{margin-bottom:.75rem}.info-popup p{color:var(--color-text-muted);margin-bottom:1.25rem;line-height:1.5}.status-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1rem}.status-item{text-align:center}.status-count{font-size:1.5rem;font-weight:700;display:block}.status-count.active{color:var(--color-success)}.status-count.redeemed{color:var(--color-primary)}.status-count.expired{color:#ffa726}.status-count.revoked{color:var(--color-danger)}.status-label{color:var(--color-text-muted);font-size:.85rem}.liability-row{display:flex;justify-content:space-between;align-items:center;padding-top:1rem;border-top:1px solid var(--color-border)}.liability-label{color:var(--color-text-muted);font-size:.9rem}.liability-value{font-weight:600}.liability-count{color:var(--color-text-muted);font-size:.85rem;font-weight:400}.activity-chart-panel{min-height:200px}.live-feed-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.feed-filters{display:flex;gap:.5rem}.feed-chip{padding:.35rem .85rem;border-radius:16px;border:1px solid var(--color-border);background:transparent;color:var(--color-text-muted);cursor:pointer;font-size:.8rem;transition:all .15s}.feed-chip.active{background:var(--color-primary);color:#000;border-color:var(--color-primary)}.feed-chip:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.feed-list{display:flex;flex-direction:column;gap:.5rem}.feed-item{display:flex;align-items:center;gap:.75rem;padding:.6rem 0;border-bottom:1px solid var(--color-border);cursor:pointer;transition:background .1s}.feed-item:hover{background:var(--color-hover)}.feed-icon{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;flex-shrink:0}.feed-icon.issued{background:#43a04726;color:var(--color-success)}.feed-icon.redeemed{background:#f7931a26;color:var(--color-primary)}.feed-icon.revoked{background:#e5393526;color:var(--color-danger)}.feed-text{flex:1;font-size:.9rem}.feed-time{color:var(--color-text-muted);font-size:.8rem;white-space:nowrap}.expiring-list{display:flex;flex-direction:column;gap:.5rem}.expiring-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--color-border)}.expiring-id{font-family:monospace;color:var(--color-text-muted);font-size:.85rem}.expiring-days{color:#ffa726;font-weight:600;font-size:.85rem}.expiring-view-all{margin-top:.75rem}.expiring-view-all a{color:var(--color-primary);text-decoration:none;font-size:.9rem}.expiring-view-all a:hover{text-decoration:underline}.sync-banner{background:#f7931a1a;border:1px solid var(--color-primary);border-radius:var(--radius);padding:.75rem 1rem;margin-bottom:1.5rem;display:flex;align-items:center;gap:1rem}.sync-banner-text{font-size:.9rem;white-space:nowrap}.sync-banner-bar{flex:1;height:6px;background:var(--color-border);border-radius:3px;overflow:hidden}.sync-banner-fill{height:100%;background:var(--color-primary);border-radius:3px;transition:width .3s}.header-avatar-link{display:flex;align-items:center;text-decoration:none;border-radius:50%;transition:box-shadow .15s;margin-right:.5rem}.header-avatar-link:hover{box-shadow:0 0 0 3px #f7931a4d}.header-avatar-link:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.header-avatar{width:36px;height:36px;border-radius:50%;border:2px solid var(--color-border);overflow:hidden;display:flex;align-items:center;justify-content:center;background:var(--color-hover);flex-shrink:0}.header-avatar img{width:100%;height:100%;object-fit:cover}.header-avatar-initials{font-size:.8rem;font-weight:600;color:var(--color-primary);line-height:1;-webkit-user-select:none;user-select:none}.dashboard-loading-overlay{opacity:.5;transition:opacity .2s;position:relative}.text-muted{color:var(--color-text-muted)}.profile-page{max-width:640px;margin:0 auto;padding:2rem 1rem}.profile-banner{position:relative;height:180px;width:100%;border-radius:var(--radius) var(--radius) 0 0;background:linear-gradient(135deg,var(--color-primary) 0%,#c76b00 100%);background-size:cover;background-position:center;overflow:hidden;transition:opacity .3s ease}.profile-banner-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle,rgba(255,255,255,.12) 1px,transparent 1px);background-size:16px 16px;pointer-events:none}.profile-hero{display:flex;flex-direction:column;align-items:flex-start;margin-top:-48px;padding:0 2rem 1.5rem;position:relative;z-index:1}.profile-avatar-large{width:96px;height:96px;border-radius:50%;border:4px solid #fff;box-shadow:0 2px 8px #00000026;overflow:hidden;background:var(--color-hover);display:flex;align-items:center;justify-content:center;flex-shrink:0}.profile-avatar-large img{width:100%;height:100%;object-fit:cover;transition:opacity .3s ease}.profile-avatar-wrapper{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.profile-avatar-wrapper img{width:100%;height:100%;object-fit:cover;transition:opacity .3s ease}.profile-avatar-initials{display:flex;align-items:center;justify-content:center;width:100%;height:100%;background:var(--color-hover);color:var(--color-primary);font-weight:700;line-height:1;-webkit-user-select:none;user-select:none;border-radius:50%}.profile-avatar-fallback{display:flex;align-items:center;justify-content:center;width:100%;height:100%;background:var(--color-hover);color:var(--color-text-muted);border-radius:50%}.profile-name{font-size:1.5rem;font-weight:700;margin-top:12px;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-username{font-size:.875rem;margin-top:2px}.npub-pill{display:inline-flex;align-items:center;gap:.35rem;margin-top:.75rem;padding:.3rem .5rem .3rem .75rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:20px;font-family:monospace;font-size:.8rem;color:var(--color-text-muted)}.npub-text{-webkit-user-select:all;user-select:all}.npub-copy-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;border-radius:50%;background:transparent;color:var(--color-text-muted);cursor:pointer;transition:background .15s,color .15s}.npub-copy-btn:hover{background:var(--color-hover);color:var(--color-text)}.npub-copy-btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.profile-edit-btn{margin-top:1rem;padding:.5rem 1.25rem;background:transparent;color:var(--color-primary);border:1.5px solid var(--color-primary);border-radius:var(--radius);font-weight:600;font-size:.9rem;cursor:pointer;transition:background .15s,color .15s}.profile-edit-btn:hover{background:var(--color-primary);color:#000}.profile-edit-btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.profile-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.5rem;margin-bottom:1rem;box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a}.profile-card h2{font-size:1.1rem;margin-bottom:1rem}.profile-field-list{display:flex;flex-direction:column;gap:.75rem}.profile-field-row{display:flex;align-items:flex-start;gap:.6rem}.profile-field-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:20px;height:20px;color:var(--color-text-muted);margin-top:1px}.profile-field-label{flex-shrink:0;font-size:.85rem;min-width:110px}.profile-field-value{font-size:.95rem;word-break:break-word}.profile-field-value a{color:var(--color-primary);text-decoration:none}.profile-field-value a:hover{text-decoration:underline}.profile-tags{display:flex;flex-wrap:wrap;gap:.4rem;list-style:none;padding:0;margin:0}.profile-tag{display:inline-block;padding:.2rem .65rem;border-radius:12px;font-size:.75rem;font-weight:500;line-height:1.4}.profile-tag--primary{background:#f7931a1a;color:var(--color-primary)}.profile-tag--neutral{background:var(--color-hover);color:var(--color-text)}.profile-tag--success{background:#43a0471a;color:var(--color-success)}.profile-empty-state{font-size:.9rem;padding:.5rem 0}.profile-skeleton{background:var(--color-border);border-radius:var(--radius);animation:skeleton-pulse 1.2s ease-in-out infinite;height:5rem;width:100%}@media (max-width: 639px){.metrics-grid,.status-grid{grid-template-columns:repeat(2,1fr)}.liability-row{flex-direction:column;gap:.25rem;text-align:center}}@media (max-width: 640px){.profile-banner{height:120px}.profile-hero{margin-top:-36px;padding:0 1rem 1rem}.profile-avatar-large{width:72px;height:72px;border-width:3px}.profile-name{font-size:1.25rem}.profile-field-row{flex-wrap:wrap}.profile-field-label{min-width:auto}}.receive-page{max-width:520px;margin:0 auto;padding:2rem 1rem}.receive-page h2{margin-bottom:1.5rem;font-size:1.35rem}.receive-form{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.75rem;box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a;display:flex;flex-direction:column;gap:1.25rem}.receive-form-field{display:flex;flex-direction:column;gap:.4rem}.receive-form-field label{font-size:.85rem;font-weight:500;color:var(--color-text-muted)}.receive-form-field input,.receive-form-field textarea{width:100%;padding:.75rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);font-family:var(--font);font-size:1rem;transition:border-color .15s,box-shadow .15s}.receive-form-field input:focus,.receive-form-field textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #f7931a1f}.receive-form-generate{margin-top:.5rem;padding:.85rem 1.5rem;font-size:1rem}.payment-request-display{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:2rem;box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1.25rem}.payment-request-status{display:inline-block;padding:.3rem 1rem;border-radius:20px;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.payment-request-status.status-pending{background:#f7931a1f;color:var(--color-primary)}.payment-request-status.status-fulfilled{background:#43a0471f;color:var(--color-success)}.payment-request-status.status-expired{background:#e539351f;color:var(--color-danger)}.payment-request-qr{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 12px #00000014;display:inline-flex}.payment-request-details{display:flex;flex-direction:column;gap:.35rem}.payment-request-amount{font-size:1.5rem;font-weight:700;color:var(--color-text)}.payment-request-received{font-size:.9rem;color:var(--color-success)}.payment-request-memo{color:var(--color-text-muted);font-size:.9rem}.payment-request-expiry{font-size:.8rem;color:var(--color-text-muted)}.payment-request-vreq{font-family:monospace;font-size:.8rem;color:var(--color-text-muted);word-break:break-all}.payment-request-actions{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:center}.payment-request-actions button{padding:.6rem 1.25rem;font-size:.9rem}.payment-request-copy,.payment-request-share,.payment-request-check{background:var(--color-primary);color:#000}.payment-request-reset{background:transparent;color:var(--color-text);border:1px solid var(--color-border)}.payment-request-reset:hover{background:var(--color-hover);box-shadow:none}.transactions-page{max-width:800px;margin:0 auto;padding:2rem 1rem}.transactions-page h2{margin-bottom:1.25rem;font-size:1.35rem}.transaction-filters{display:flex;gap:.5rem;margin-bottom:1.25rem;flex-wrap:wrap}.transaction-filter-btn{padding:.35rem .95rem;border-radius:20px;border:1px solid var(--color-border);background:transparent;color:var(--color-text-muted);cursor:pointer;font-size:.8rem;font-weight:500;transition:all .15s}.transaction-filter-btn:hover{color:var(--color-text);background:var(--color-hover);box-shadow:none}.transaction-filter-btn.active{background:var(--color-primary);color:#000;border-color:var(--color-primary);font-weight:600}.transaction-list{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a;overflow:hidden}.transaction-row{display:flex;align-items:center;gap:1rem;padding:.85rem 1.25rem;border-bottom:1px solid var(--color-border);cursor:pointer;transition:background .12s}.transaction-row:last-child{border-bottom:none}.transaction-row:hover{background:var(--color-hover)}.transaction-row:focus-visible{outline:2px solid var(--color-primary);outline-offset:-2px}.transaction-amount{font-weight:600;font-size:1rem;min-width:100px}.transaction-status{display:inline-block;padding:.2rem .7rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:capitalize;letter-spacing:.02em}.transaction-status.status-pending{background:#f7931a1f;color:var(--color-primary)}.transaction-status.status-fulfilled{background:#43a0471f;color:var(--color-success)}.transaction-status.status-expired{background:#e539351f;color:var(--color-danger)}.transaction-date{margin-left:auto;color:var(--color-text-muted);font-size:.8rem;white-space:nowrap}.transaction-list-empty{text-align:center;padding:3rem;color:var(--color-text-muted);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a}.transaction-detail-page{max-width:600px;margin:0 auto;padding:2rem 1rem}.transaction-back-btn{background:transparent;color:var(--color-text-muted);border:1px solid var(--color-border);padding:.5rem 1rem;font-size:.85rem;margin-bottom:1.5rem}.transaction-back-btn:hover{color:var(--color-text);background:var(--color-hover);box-shadow:none}.transaction-detail{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.75rem;box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a;display:flex;flex-direction:column;gap:1rem}.transaction-detail-field{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--color-border)}.transaction-detail-field:last-child{border-bottom:none}.transaction-detail-label{color:var(--color-text-muted);font-size:.85rem;font-weight:500}.transaction-detail-value{font-size:.95rem;text-align:right;word-break:break-all}.status-badge{font-size:1rem;font-weight:600;text-transform:uppercase}.status-badge.status-active,.status-badge.status-fulfilled{color:var(--color-success)}.status-badge.status-pending{color:var(--color-primary)}.status-badge.status-expired,.status-badge.status-revoked{color:var(--color-danger)}@media (max-width: 480px){.transaction-row{flex-wrap:wrap;gap:.5rem}.transaction-date{margin-left:0}.transaction-detail-field{flex-direction:column;align-items:flex-start;gap:.25rem}.transaction-detail-value{text-align:left}}.vouchers-page{max-width:800px;margin:0 auto;padding:0}.vouchers-page h2{font-size:1.4rem;font-weight:700;margin-bottom:1.25rem}.voucher-filters-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a;padding:1.25rem;margin-bottom:1.25rem}.voucher-status-pills{display:flex;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}.voucher-filter-pill{padding:.4rem 1rem;border-radius:20px;border:1px solid var(--color-border);background:transparent;color:var(--color-text-muted);cursor:pointer;font-size:.85rem;font-family:var(--font);transition:all .15s}.voucher-filter-pill:hover{background:var(--color-hover);color:var(--color-text)}.voucher-filter-pill.active{background:var(--color-primary);color:#000;border-color:var(--color-primary);font-weight:600}.voucher-filter-row{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.voucher-search-input{flex:1;min-width:160px;padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);color:var(--color-text);font-size:.9rem;font-family:var(--font)}.voucher-search-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #f7931a26}.voucher-delivery-select{padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);color:var(--color-text);font-size:.9rem;font-family:var(--font);min-width:130px}.voucher-date-input{padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);color:var(--color-text);font-size:.9rem;font-family:var(--font)}.voucher-export-btn{padding:.5rem 1rem;background:transparent;color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius);font-size:.85rem;font-family:var(--font);cursor:pointer;white-space:nowrap;transition:all .15s}.voucher-export-btn:hover{border-color:var(--color-text-muted);background:var(--color-hover)}.voucher-list-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a;overflow:hidden}.voucher-list-row{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--color-border);cursor:pointer;transition:background .1s}.voucher-list-row:last-child{border-bottom:none}.voucher-list-row:hover{background:var(--color-hover)}.voucher-row-left{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.voucher-row-id{font-family:monospace;font-size:.85rem;color:var(--color-text-muted)}.voucher-row-status{display:inline-block;padding:.15rem .6rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.voucher-status--active{background:#43a0471f;color:var(--color-success)}.voucher-status--redeemed{background:#f7931a1f;color:var(--color-primary)}.voucher-status--expired{background:#8888881f;color:var(--color-text-muted)}.voucher-status--revoked{background:#e539351f;color:var(--color-danger)}.voucher-row-delivery{font-size:.8rem;color:var(--color-text-muted)}.voucher-row-right{display:flex;align-items:center;gap:1rem;flex-shrink:0}.voucher-row-value{font-weight:600;font-size:.95rem;white-space:nowrap}.voucher-row-date{font-size:.8rem;color:var(--color-text-muted);white-space:nowrap}.voucher-revoke-btn{padding:.3rem .75rem;background:transparent;color:var(--color-danger);border:1px solid var(--color-danger);border-radius:var(--radius);font-size:.75rem;font-family:var(--font);cursor:pointer;transition:all .15s}.voucher-revoke-btn:hover{background:#e5393514}.voucher-list-empty{text-align:center;padding:3rem;color:var(--color-text-muted);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a}@media (max-width: 640px){.voucher-list-row{flex-direction:column;align-items:flex-start;gap:.5rem}.voucher-row-right{width:100%;justify-content:space-between}.voucher-filter-row{flex-direction:column}.voucher-search-input{min-width:auto;width:100%}}.offline-page{max-width:520px;margin:0 auto;padding:2rem 1rem}.offline-page h2{margin-bottom:1.5rem;font-size:1.35rem}.offline-steps{display:flex;align-items:center;justify-content:center;margin-bottom:2rem;gap:0}.offline-step{display:flex;align-items:center;gap:.35rem}.offline-step-dot{width:28px;height:28px;border-radius:50%;border:2px solid var(--color-border);display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;color:var(--color-text-muted);background:var(--color-surface);transition:all .3s ease;flex-shrink:0}.offline-step.current .offline-step-dot{border-color:var(--color-primary);background:#f7931a1a;color:var(--color-primary);box-shadow:0 0 0 3px #f7931a1f}.offline-step.completed .offline-step-dot{border-color:var(--color-success);background:var(--color-success);color:#fff}.offline-step-label{font-size:.72rem;font-weight:500;color:var(--color-text-muted);white-space:nowrap}.offline-step.current .offline-step-label{color:var(--color-text);font-weight:600}.offline-step.completed .offline-step-label{color:var(--color-success)}.offline-step-line{width:28px;height:2px;background:var(--color-border);margin:0 .2rem;transition:background .3s ease}.offline-step-line.completed{background:var(--color-success)}.offline-method-badge{display:inline-block;padding:.25rem .85rem;border-radius:20px;font-size:.78rem;font-weight:600;background:#f7931a1a;color:var(--color-primary);margin-bottom:1.25rem;letter-spacing:.01em}.offline-method-selector{display:flex;flex-direction:column;gap:1rem}.offline-section-hint{font-size:.9rem;color:var(--color-text-muted)}.offline-method-grid{display:grid;grid-template-columns:1fr;gap:.75rem}.method-card{display:flex;align-items:center;gap:1rem;padding:1.1rem 1.25rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a;cursor:pointer;transition:border-color .15s,box-shadow .2s,transform .1s;text-align:left;color:var(--color-text)}.method-card:hover{border-color:var(--color-primary);box-shadow:0 2px 8px #f7931a1f,0 1px 3px #0000000f;background:var(--color-surface)}.method-card:active{transform:translateY(.5px)}.method-card-icon{flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--color-bg);border-radius:var(--radius);color:var(--color-primary);transition:color .15s}.method-card:hover .method-card-icon{color:var(--color-primary-hover)}.method-card-label{font-weight:600;font-size:.95rem}.method-card-desc{font-size:.8rem;color:var(--color-text-muted);margin-left:auto}.offline-invoice-form{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.75rem;box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a;display:flex;flex-direction:column;gap:1.25rem}.offline-form-field{display:flex;flex-direction:column;gap:.4rem}.offline-form-field label{font-size:.85rem;font-weight:500;color:var(--color-text-muted)}.offline-form-field input,.offline-form-field textarea{width:100%;padding:.75rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);font-family:var(--font);font-size:1rem;transition:border-color .15s,box-shadow .15s}.offline-form-field input:focus,.offline-form-field textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #f7931a1f}.offline-presets{display:flex;gap:.5rem;flex-wrap:wrap}.preset-btn{padding:.4rem .95rem;border-radius:20px;border:1px solid var(--color-border);background:transparent;color:var(--color-text-muted);font-size:.8rem;font-weight:500;cursor:pointer;transition:all .15s}.preset-btn:hover{color:var(--color-text);border-color:var(--color-primary);background:#f7931a0f;box-shadow:none}.offline-form-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:.5rem}.offline-invoice-display{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:2rem;box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a;display:flex;flex-direction:column;align-items:center;gap:1.5rem;text-align:center}.offline-qr-wrapper{background:#fff;border-radius:12px;padding:1.25rem;box-shadow:0 2px 12px #00000014;display:inline-flex}.offline-invoice-details{width:100%;display:flex;flex-direction:column;gap:.65rem}.offline-detail-row{display:flex;justify-content:space-between;align-items:baseline;padding:0 .25rem}.offline-detail-label{font-size:.8rem;color:var(--color-text-muted)}.offline-detail-value{font-weight:500;font-size:.9rem}.offline-amount-lg{font-size:1.15rem;font-weight:700}.offline-proof-code{font-family:Courier New,monospace;font-size:1.1rem;font-weight:700;letter-spacing:.15em;color:var(--color-primary)}.offline-monospace{font-family:monospace;font-size:.85rem;color:var(--color-text-muted)}.offline-countdown{font-size:1.5rem;font-weight:700;font-variant-numeric:tabular-nums;color:var(--color-text);padding:.35rem 1rem;border-radius:var(--radius);background:var(--color-bg)}.offline-countdown.warning{color:var(--color-primary)}.offline-countdown.danger{color:var(--color-danger);animation:countdown-flash 1s infinite}@keyframes countdown-flash{0%,to{opacity:1}50%{opacity:.5}}.offline-waiting-indicator{display:flex;align-items:center;gap:.75rem;color:var(--color-text-muted);font-size:.85rem}.offline-pulse{width:10px;height:10px;border-radius:50%;background:var(--color-primary);animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.85)}}.btn-danger-outline{background:transparent;color:var(--color-danger);border:1px solid var(--color-border)}.btn-danger-outline:hover{border-color:var(--color-danger);background:#e539350f;box-shadow:none}.offline-invoice-confirm{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:2rem;box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a;display:flex;flex-direction:column;align-items:center;gap:1.5rem;text-align:center}.offline-confirm-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem 1rem;border-radius:20px;font-size:.82rem;font-weight:600;background:#f7931a1f;color:var(--color-primary)}.offline-confirm-pulse{width:8px;height:8px;border-radius:50%;background:var(--color-primary);animation:pulse 1.5s ease-in-out infinite}.offline-processing{display:flex;flex-direction:column;align-items:center;gap:.75rem;color:var(--color-text-muted);font-size:.9rem}.offline-spinner{width:32px;height:32px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.offline-terminal{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:2.5rem 2rem;box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a;display:flex;flex-direction:column;align-items:center;gap:1.25rem;text-align:center}.offline-terminal-icon{color:var(--color-text-muted)}.offline-terminal-icon.success{color:var(--color-success)}.offline-terminal-icon.error{color:var(--color-danger)}.offline-terminal-icon.warning{color:var(--color-primary)}.offline-terminal-message{color:var(--color-text-muted);font-size:.9rem;line-height:1.6;max-width:380px}.offline-terminal-message strong{font-family:monospace;color:var(--color-text)}.transaction-method-badge{display:inline-block;padding:.15rem .6rem;border-radius:12px;font-size:.7rem;font-weight:600;background:#f7931a1a;color:var(--color-primary);white-space:nowrap}@media (max-width: 480px){.offline-steps{gap:0}.offline-step-label{display:none}.offline-step-line{width:20px}.offline-method-grid{grid-template-columns:1fr}.method-card-desc{display:none}.offline-form-actions{flex-direction:column}.offline-form-actions button{width:100%}}
