*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:#f0f2f5;color:#1a1a2e;min-height:100vh}.spinner-container{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:64px 0}.spinner-text{font-size:14px;color:#888}.spinner{width:36px;height:36px;border:3px solid #e0e0e0;border-top-color:var(--color-primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.header{display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:60px;background:linear-gradient(135deg,var(--color-header-start),var(--color-header-end));color:#fff;box-shadow:0 2px 8px #00000026}.header-left{display:flex;align-items:center;gap:12px;cursor:pointer}.header-logo{width:36px;height:36px;background:#fff;color:var(--color-primary);border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:20px}.header-title{font-size:18px;font-weight:600}.header-right{display:flex;align-items:center;gap:16px}.header-user{font-size:14px;opacity:.85}.btn-link{background:none;border:none;color:#fff;cursor:pointer;font-size:14px;text-decoration:underline;opacity:.85}.btn-link:hover{opacity:1}.lang-select{background:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:4px;padding:4px 8px;font-size:13px;cursor:pointer;outline:none}.lang-select option{color:#1a1a2e;background:#fff}.login-page{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 60px);padding:24px}.login-card{background:#fff;border-radius:12px;padding:48px 40px;width:100%;max-width:400px;box-shadow:0 4px 24px #00000014;text-align:center}.login-logo{width:64px;height:64px;background:linear-gradient(135deg,var(--color-header-start),var(--color-header-end));color:#fff;border-radius:16px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:32px;margin:0 auto 16px}.login-card h1{font-size:24px;color:#1a1a2e;margin-bottom:4px}.login-subtitle{color:#666;margin-bottom:32px;font-size:14px}.form-group{margin-bottom:16px;text-align:left}.form-group label{display:block;font-size:13px;font-weight:600;color:#444;margin-bottom:6px}.form-group input{width:100%;padding:12px 14px;border:1px solid #ddd;border-radius:8px;font-size:15px;transition:border-color .2s;background:#fafafa}.form-group input:focus{outline:none;border-color:var(--color-primary);background:#fff}.form-row{display:flex;gap:12px}.form-row .form-group{flex:1}.btn-primary{width:100%;padding:14px;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-end));color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;margin-top:8px;transition:opacity .2s}.btn-primary:hover{opacity:.9}.invoices-page{max-width:720px;margin:0 auto;padding:32px 24px}.page-header{margin-bottom:24px}.page-header h2{font-size:22px;margin-bottom:4px}.page-header p{color:#666;font-size:14px}.invoices-list{display:flex;flex-direction:column;gap:12px}.search-bar{margin-bottom:20px}.search-bar input{width:100%;padding:14px 16px;border:1px solid #ddd;border-radius:10px;font-size:16px;background:#fff;box-shadow:0 2px 8px #0000000a;transition:border-color .2s}.search-bar input:focus{outline:none;border-color:var(--color-primary)}.client-list{display:flex;flex-direction:column;gap:10px}.client-card{display:flex;justify-content:space-between;align-items:center;background:#fff;border-radius:10px;padding:18px 24px;box-shadow:0 2px 8px #0000000f;cursor:pointer;transition:box-shadow .2s,transform .15s;border:1px solid #eee}.client-card:hover{box-shadow:0 4px 16px color-mix(in srgb,var(--color-primary) 12%,transparent);transform:translateY(-1px)}.client-card-info{display:flex;flex-direction:column;gap:4px}.client-name{font-size:16px;font-weight:600;color:#1a1a2e}.client-contact{font-size:13px;color:#888}.client-card-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.client-invoice-count{font-size:13px;font-weight:600;color:#c0392b;background:#fdecea;padding:3px 10px;border-radius:12px}.no-results{text-align:center;color:#888;padding:32px 0}.invoice-card{background:#fff;border-radius:10px;padding:20px 24px;box-shadow:0 2px 8px #0000000f;cursor:pointer;transition:box-shadow .2s,transform .15s;border:1px solid #eee}.invoice-card:hover{box-shadow:0 4px 16px color-mix(in srgb,var(--color-primary) 12%,transparent);transform:translateY(-1px)}.invoice-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.invoice-number{font-weight:700;color:var(--color-primary);font-size:14px}.invoice-status{font-size:12px;font-weight:600;color:#c0392b;background:#fdecea;padding:3px 10px;border-radius:12px}.invoice-card-body{margin-bottom:12px}.invoice-description{font-size:15px;font-weight:500;margin-bottom:4px}.invoice-date{font-size:13px;color:#888}.invoice-card-footer{display:flex;justify-content:space-between;align-items:center}.invoice-amount{font-size:20px;font-weight:700;color:#1a1a2e}.invoice-pay-link{font-size:14px;color:var(--color-primary);font-weight:600}.payment-page{display:flex;justify-content:center;padding:32px 24px}.payment-card{background:#fff;border-radius:12px;padding:32px;width:100%;max-width:480px;box-shadow:0 4px 24px #00000014}.btn-back{background:none;border:none;color:var(--color-primary);cursor:pointer;font-size:14px;font-weight:600;padding:0;margin-bottom:20px}.btn-back:hover{text-decoration:underline}.payment-summary{margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid #eee}.payment-summary h2{font-size:20px;margin-bottom:6px}.payment-description{color:#666;font-size:14px;margin-bottom:16px}.payment-amount-display{display:flex;justify-content:space-between;align-items:center;background:color-mix(in srgb,var(--color-primary) 6%,white);padding:14px 18px;border-radius:8px}.payment-amount-display span:first-child{font-size:14px;color:#666}.amount-value{font-size:24px;font-weight:700;color:var(--color-primary)}.payment-amount-section{display:flex;flex-direction:column;gap:12px}.pay-amount-input label{display:block;font-size:13px;font-weight:600;color:#444;margin-bottom:4px}.amount-input-wrapper{display:flex;align-items:center;border:1px solid #ddd;border-radius:8px;background:#fafafa;overflow:hidden;transition:border-color .2s}.amount-input-wrapper:focus-within{border-color:var(--color-primary);background:#fff}.amount-prefix{padding:10px 0 10px 14px;font-size:18px;font-weight:700;color:#333}.amount-input-wrapper input{flex:1;padding:10px 14px 10px 4px;border:none;background:transparent;font-size:18px;font-weight:700;color:#1a1a2e;outline:none}.amount-input-wrapper input::-webkit-inner-spin-button,.amount-input-wrapper input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.amount-input-wrapper input[type=number]{-moz-appearance:textfield}.amount-error{display:inline-block;margin-top:6px;font-size:13px;font-weight:600;color:#c0392b}.partial-badge{display:inline-block;margin-top:6px;font-size:13px;font-weight:600;color:#e67e22;background:#fef5e7;padding:4px 10px;border-radius:8px}.error-banner{background:#fdecea;color:#c0392b;padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:14px}.cc-form h3{font-size:16px;margin-bottom:16px;color:#333}.btn-pay{width:100%;padding:14px;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-end));color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;margin-top:8px;transition:opacity .2s}.btn-pay:hover:not(:disabled){opacity:.9}.btn-pay:disabled{opacity:.6;cursor:not-allowed}.terminal-divider{display:flex;align-items:center;gap:12px;margin:20px 0;color:#999;font-size:13px}.terminal-divider:before,.terminal-divider:after{content:"";flex:1;height:1px;background:#ddd}.terminal-section{margin-top:4px}.btn-terminal{width:100%;display:flex;align-items:center;gap:14px;padding:16px 20px;background:#1a1d21;color:#e0e0e0;border:1px solid #333;border-radius:10px;font-size:15px;font-weight:500;cursor:pointer;transition:border-color .2s,box-shadow .2s;font-family:SF Mono,Fira Code,Consolas,monospace}.btn-terminal:hover:not(:disabled){border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary),0 4px 12px #0003}.btn-terminal:disabled{opacity:.5;cursor:not-allowed}.terminal-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:#2a2d31;border-radius:8px;font-size:20px;color:var(--color-primary);border:1px solid #3a3d41}.terminal-label{flex:1;text-align:left}.terminal-status{font-size:12px;color:var(--color-primary);background:#00d0841a;padding:3px 10px;border-radius:10px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.remote-pay-options{display:flex;flex-direction:column;gap:12px}.remote-pay-row{display:flex;gap:10px;align-items:flex-end}.remote-pay-input{flex:1}.remote-pay-input label{display:block;font-size:13px;font-weight:600;color:#444;margin-bottom:4px}.remote-pay-input input{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:8px;font-size:15px;background:#fafafa;transition:border-color .2s}.remote-pay-input input:focus{outline:none;border-color:var(--color-primary);background:#fff}.btn-text-to-pay,.btn-email-to-pay{padding:10px 16px;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;white-space:nowrap;transition:opacity .2s}.btn-text-to-pay{background:var(--color-primary)}.btn-email-to-pay{background:var(--color-header-start)}.btn-text-to-pay:hover:not(:disabled),.btn-email-to-pay:hover:not(:disabled){opacity:.9}.btn-text-to-pay:disabled,.btn-email-to-pay:disabled{opacity:.6;cursor:not-allowed}.success-card{text-align:center}.success-icon{width:64px;height:64px;background:#27ae60;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:32px;margin:0 auto 16px}.success-card h2{color:#27ae60;margin-bottom:8px}.success-card p{color:#444;margin-bottom:4px}.success-detail{color:#888!important;font-size:14px;margin-bottom:24px!important}.success-card .btn-primary{margin-top:16px}.admin-page{max-width:720px;margin:0 auto;padding:32px 24px}.admin-tabs{display:flex;gap:0;margin-bottom:24px;border-bottom:2px solid #eee}.admin-tab{padding:10px 20px;background:none;border:none;font-size:14px;font-weight:600;color:#888;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .2s,border-color .2s}.admin-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.admin-tab:hover{color:#444}.admin-form{background:#fff;border-radius:10px;padding:24px;margin-bottom:20px;box-shadow:0 2px 8px #0000000f;border:1px solid #eee}.admin-form h3{font-size:16px;margin-bottom:16px;color:#333}.admin-section{margin-bottom:24px}.admin-section h2{font-size:22px;margin-bottom:4px}.admin-section h3{font-size:16px;margin-bottom:12px;color:#333}.admin-subtitle{color:#888;font-size:13px;font-family:monospace}.admin-list{display:flex;flex-direction:column;gap:10px}.admin-list-item{display:flex;justify-content:space-between;align-items:center;background:#fff;border-radius:10px;padding:16px 20px;box-shadow:0 2px 8px #0000000f;border:1px solid #eee}.admin-list-item.clickable{cursor:pointer;transition:box-shadow .2s,transform .15s}.admin-list-item.clickable:hover{box-shadow:0 4px 16px color-mix(in srgb,var(--color-primary) 12%,transparent);transform:translateY(-1px)}.admin-list-info{display:flex;flex-direction:column;gap:2px}.admin-list-name{font-size:15px;font-weight:600;color:#1a1a2e;display:flex;align-items:center;gap:8px}.admin-list-detail{font-size:13px;color:#888}.super-badge{font-size:11px;font-weight:600;color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 10%,white);padding:2px 8px;border-radius:10px}.admin-inline-form{display:flex;gap:10px;align-items:center}.admin-select{flex:1;padding:10px 12px;border:1px solid #ddd;border-radius:8px;font-size:14px;background:#fff}.admin-select:focus{outline:none;border-color:var(--color-primary)}.btn-primary-sm{padding:10px 18px;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-end));color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;white-space:nowrap}.btn-primary-sm:hover:not(:disabled){opacity:.9}.btn-primary-sm:disabled{opacity:.6;cursor:not-allowed}.btn-danger-sm{padding:6px 14px;background:#fdecea;color:#c0392b;border:1px solid #f5c6cb;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:background .2s}.btn-danger-sm:hover{background:#f8d7da}.admin-badge{font-size:11px;font-weight:600;color:#e67e22;background:#fef5e7;padding:2px 8px;border-radius:10px}.role-select{width:120px;flex:none}.suggest-input{position:relative;flex:1}.suggest-input input{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:8px;font-size:15px;background:#fafafa;transition:border-color .2s}.suggest-input input:focus{outline:none;border-color:var(--color-primary);background:#fff}.suggest-dropdown{position:absolute;top:100%;left:0;right:0;margin-top:4px;background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 4px 16px #0000001a;z-index:10;overflow:hidden}.suggest-option{width:100%;display:flex;justify-content:space-between;align-items:center;padding:10px 14px;border:none;background:none;cursor:pointer;font-size:14px;text-align:left;transition:background .15s}.suggest-option:hover{background:#f5f5f5}.suggest-value{color:#1a1a2e}.suggest-label{font-size:12px;color:#888;text-transform:capitalize}.suggest-empty{padding:10px 14px;font-size:13px;color:#aaa;text-align:center}
