:root{--background:#f4f6fb;--surface:#fff;--text:#111827;--muted:#6b7280;--border:#e5e7eb;--primary:#2563eb;--primary-hover:#1d4ed8;--danger:#dc2626;--success:#16a34a;--shadow:0 10px 25px rgba(17,24,39,.08);--radius:14px}*,:after,:before{box-sizing:border-box}body,html{padding:0;margin:0;min-height:100%}body{font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,Apple Color Emoji,Segoe UI Emoji;color:var(--text);background:radial-gradient(circle at top,#eef3ff 0,var(--background) 40%,#f8fafc 100%);line-height:1.5}a{color:inherit;text-decoration:none}main{width:100%}.page-shell{width:min(980px,100% - 2rem);margin:2rem auto}.home-shell{width:min(760px,100% - 2rem);margin:2.5rem auto}.home-header{margin-bottom:1.2rem}.home-badge{display:inline-block;border-radius:999px;background:#dbeafe;color:#1d4ed8;font-size:.78rem;font-weight:700;padding:.25rem .6rem;margin-bottom:.65rem}.home-title{margin:0;font-size:clamp(1.6rem,3.1vw,2.2rem);line-height:1.2;letter-spacing:-.01em}.home-description{margin:.5rem 0 0;color:var(--muted);max-width:62ch}.home-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.1rem 1rem}.home-card-title{margin:0;font-size:1.03rem;font-weight:700}.home-card-text{margin:.4rem 0 0;color:var(--muted);font-size:.93rem}.home-page{width:100%;min-height:100vh}.home-container{width:min(760px,100% - 2rem);margin:2.5rem auto}.home-card-description{margin:.4rem 0 0;color:var(--muted);font-size:.93rem}.home-code-inline{display:inline-block;padding:.08rem .35rem;border-radius:6px;border:1px solid var(--border);background:#f8fafc;color:#0f172a;font-size:.82rem}.home-code-block,.home-code-inline{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.home-code-block{margin-top:.8rem;border-radius:10px;background:#0f172a;color:#f8fafc;font-size:.86rem;padding:.65rem .8rem;overflow-x:auto}.home-button{display:inline-flex;align-items:center;justify-content:center;height:40px;padding:0 .95rem;border-radius:10px;border:1px solid transparent;background:var(--primary);color:#fff;font-size:.92rem;font-weight:600;transition:all .2s ease}.home-button:hover{background:var(--primary-hover)}.home-code{margin-top:.8rem;border-radius:10px;background:#0f172a;color:#f8fafc;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.86rem;padding:.65rem .8rem;overflow-x:auto}.home-actions{margin-top:.9rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.invoice-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border)}.invoice-title{margin:0;font-size:clamp(1.2rem,2vw,1.6rem);font-weight:700;letter-spacing:-.01em}.invoice-subtitle{margin:.35rem 0 0;color:var(--muted);font-size:.95rem}.invoice-meta{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.8rem 1rem;padding:1rem 1.5rem 1.25rem;border-bottom:1px solid var(--border)}.meta-item{background:#f9fafb;border:1px solid var(--border);border-radius:10px;padding:.7rem .8rem}.meta-label{margin:0;color:var(--muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.05em}.meta-value{margin:.25rem 0 0;font-size:.95rem;font-weight:600;word-break:break-word}.invoice-actions{display:flex;flex-wrap:wrap;gap:.75rem;padding:1.1rem 1.5rem;border-bottom:1px solid var(--border)}.button,.invoice-actions--single{justify-content:center}.button{display:inline-flex;align-items:center;gap:.45rem;height:40px;padding:0 .95rem;border-radius:10px;border:1px solid transparent;font-size:.92rem;font-weight:600;cursor:pointer;transition:all .2s ease;user-select:none;white-space:nowrap}.button-full{width:100%;min-height:46px;font-size:.96rem;border-radius:12px}.button:disabled{opacity:.6;cursor:not-allowed}.button-primary{background:var(--primary);color:#fff}.button-primary:hover:not(:disabled){background:var(--primary-hover)}.button-outline{background:#fff;color:var(--text);border-color:var(--border)}.button-outline:hover:not(:disabled){background:#f9fafb}.button-danger{background:#fff5f5;border-color:#fecaca;color:var(--danger)}.button-danger:hover:not(:disabled){background:#ffe4e6}.viewer-wrap{padding:.75rem}.viewer-frame{width:100%;min-height:78vh;border:none;border-radius:14px;background:#fff;box-shadow:0 14px 36px rgba(15,23,42,.12)}.status-pill{display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .55rem;border-radius:999px;font-size:.78rem;font-weight:700;text-transform:capitalize}.status-pill--default,.status-pill--received{color:#1d4ed8;background:#dbeafe}.status-pill--paid{color:#166534;background:#dcfce7}.status-pill--cancelled,.status-pill--failed{color:#991b1b;background:#fee2e2}.alert{margin:.9rem 1.5rem 1.25rem;padding:.8rem .9rem;border-radius:10px;border:1px solid transparent;font-size:.9rem}.alert-error{color:#991b1b;background:#fef2f2;border-color:#fecaca}.alert-success{color:#166534;background:#f0fdf4;border-color:#bbf7d0}.invoice-logo-wrap{display:flex;justify-content:center;align-items:center;margin-bottom:.85rem}.invoice-logo{width:140px;max-width:100%;height:auto;object-fit:contain}.invoice-subtitle-row{margin-top:.35rem;display:flex;flex-direction:column;align-items:stretch;gap:.75rem}.invoice-subtitle-row .invoice-subtitle{margin:0}.google-review-button{width:100%;min-height:46px;border:1px solid #dfe1e5;border-radius:12px;background:linear-gradient(135deg,#fff,#f8fbff);color:#1f2937;display:inline-flex;align-items:center;justify-content:center;gap:.65rem;font-size:.95rem;font-weight:700;letter-spacing:.01em;cursor:pointer;box-shadow:0 6px 16px rgba(17,24,39,.08);transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease;padding:.65rem 1rem}.google-review-button:hover{transform:translateY(-1px);border-color:#c7d2fe;box-shadow:0 10px 22px rgba(37,99,235,.18)}.google-review-button:active{transform:translateY(0)}.google-review-g{font-size:1.15rem;font-weight:800;line-height:1}.google-review-g .g-blue{color:#4285f4}.google-review-g .g-red{color:#ea4335}.google-review-g .g-yellow{color:#fbbc05}.google-review-g .g-green{color:#34a853}.google-review-text{color:#111827}.review-modal-overlay{position:fixed;inset:0;z-index:1000;display:grid;place-items:center;background:rgba(15,23,42,.62);padding:1rem}.review-modal-card{width:min(560px,100%);background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:0 20px 45px rgba(15,23,42,.28);overflow:hidden}.review-modal-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:1rem 1.1rem;border-bottom:1px solid var(--border)}.review-modal-title{margin:0;font-size:1.05rem;font-weight:700;letter-spacing:-.01em}.review-modal-close{border:none;background:transparent;color:#6b7280;font-size:1.35rem;cursor:pointer;line-height:1;padding:.1rem .2rem}.review-modal-close:hover{color:#111827}.review-modal-subtitle{margin:.8rem 1.1rem 0;color:var(--muted);font-size:.9rem}.review-stars{display:flex;align-items:center;gap:.45rem;padding:.75rem 1.1rem 0}.review-star{appearance:none;border:none;background:transparent;cursor:pointer;font-size:1.75rem;line-height:1;color:#d1d5db;padding:0;transition:transform .12s ease,color .12s ease}.review-star:hover{transform:translateY(-1px)}.review-star--active{color:#f59e0b}.review-low-rating-wrap{padding:.9rem 1.1rem 1.1rem}.review-text-label{display:block;margin:0 0 .35rem;color:#374151;font-size:.88rem;font-weight:600}.review-textarea{width:100%;min-height:110px;resize:vertical;border:1px solid var(--border);border-radius:10px;padding:.6rem .7rem;font:inherit;color:var(--text);background:#fff}.review-textarea:focus{outline:2px solid #bfdbfe;border-color:#93c5fd}.empty-state,.loading-state{padding:2.2rem 1.5rem;text-align:center;color:var(--muted)}@media (max-width:720px){.page-shell{width:min(980px,100% - 1rem);margin:1rem auto}.home-container,.home-shell{width:min(760px,100% - 1rem);margin:1rem auto}.home-card{padding:1rem .85rem}.invoice-actions,.invoice-header,.invoice-meta{padding-left:1rem;padding-right:1rem}.invoice-subtitle-row{align-items:stretch;flex-direction:column}.google-review-button{width:100%}.review-modal-card{width:min(560px,100%)}.invoice-meta{grid-template-columns:1fr}.viewer-wrap{padding:.55rem}.viewer-frame{min-height:82vh;border-radius:12px}.button-full{width:100%}}