/* --- ABLP Portal Skin --- */
:root { --ablp-blue: #0052cc; --ablp-dark-blue: #071A3B; --ablp-light-gray: #f4f7fa; --ablp-text-color: #333; --ablp-border-color: #e0e0e0; }
body { margin: 0; }
.ablp-portal-wrapper *, .ablp-portal-forms-wrapper * { box-sizing: border-box; }
.ablp-portal-wrapper, .ablp-portal-forms-wrapper { font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif; min-height: 100vh; background-color: var(--ablp-light-gray); }
.ablp-portal-wrapper { display: flex; }

/* Sidebar */
.ablp-sidebar { width: 240px; background-color: var(--ablp-dark-blue); color: white; display: flex; flex-direction: column; position: fixed; height: 100%; flex-shrink: 0; }
.ablp-sidebar-header { padding: 20px; text-align: center; border-bottom: 1px solid #1a2c4d; }
.ablp-sidebar-header img { max-width: 80%; height: auto; }
.ablp-sidebar-nav { list-style: none; padding: 0; margin: 20px 0; flex-grow: 1; }
.ablp-sidebar-nav .nav-item a { display: flex; align-items: center; padding: 15px 20px; color: #cbd5e0; text-decoration: none; transition: background-color 0.2s, color 0.2s; }
.ablp-sidebar-nav .nav-item a:hover { background-color: #1a2c4d; color: white; }
.ablp-sidebar-nav .nav-item.active a { background-color: var(--ablp-blue); color: white; font-weight: 600; }
.ablp-sidebar-nav .nav-item a span { margin-right: 15px; font-size: 20px; }
.ablp-sidebar-footer { padding: 20px; border-top: 1px solid #1a2c4d; }
.ablp-sidebar-footer .logout-link { display: flex; align-items: center; color: #cbd5e0; text-decoration: none; }
.ablp-sidebar-footer .logout-link:hover { color: white; }
.ablp-sidebar-footer .logout-link span { margin-right: 15px; font-size: 20px; transform: scaleX(-1); display: inline-block; }

/* Main Content */
.ablp-main-content { flex-grow: 1; padding: 30px; margin-left: 240px; }
.ablp-content-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 30px; }
.ablp-content-header h2 { margin: 0; font-size: 28px; color: var(--ablp-text-color); }
.user-info { font-weight: 500; }

/* Card Component */
.ablp-card { background-color: white; border-radius: 8px; box-shadow: 0 2px 4px rgba(0,0,0,0.05); margin-bottom: 30px; }
.ablp-card-header { padding: 20px; border-bottom: 1px solid var(--ablp-border-color); }
.ablp-card-header h3 { margin: 0; font-size: 18px; }
.ablp-card-body { padding: 20px; }

/* Form Styles */
.form-section { margin-bottom: 25px; }
.form-section h4 { margin-top: 0; margin-bottom: 15px; font-size: 16px; border-bottom: 1px solid var(--ablp-border-color); padding-bottom: 10px; }
.form-grid { display: grid; gap: 20px; }
.two-cols { grid-template-columns: repeat(2, 1fr); }
.four-cols { grid-template-columns: repeat(4, 1fr); }
.form-group { margin-bottom: 10px; }
.form-group label { display: block; margin-bottom: 5px; font-weight: 600; font-size: 14px; }
.form-group .ablp-input { display: block; width: 100%; padding: 10px; margin-bottom: 10px; border: 1px solid #ccc; border-radius: 4px; transition: border-color 0.2s; }
.form-group .ablp-input:focus { border-color: var(--ablp-blue); outline: none; box-shadow: 0 0 0 2px rgba(0, 82, 204, 0.2); }
.form-actions { margin-top: 20px; }
.button-primary, .button.button-primary { background-color: var(--ablp-blue); color: white; border: none; padding: 8px 12px; font-size: 14px; font-weight: 600; border-radius: 5px; cursor: pointer; transition: background-color 0.2s; text-decoration: none; display: inline-block; vertical-align: middle; }
.button-primary:hover, .button.button-primary:hover { background-color: #003e99; }
.button-secondary { background-color: #eef2f5; color: #4d5d6a; border: 1px solid #d1d9e0; padding: 8px 12px; font-size: 14px; font-weight: 600; border-radius: 5px; cursor: pointer; transition: background-color 0.2s; display: inline-block; vertical-align: middle; }
.button-secondary:hover { background-color: #d1d9e0; }
.reprint-btn { margin-left: 10px; }

/* Spinner & Table */
.spinner { float: none; vertical-align: middle; margin-left: 10px; visibility: hidden; }
.spinner.is-active { visibility: visible; }
.ablp-table { width: 100%; border-collapse: collapse; }
.ablp-table th, .ablp-table td { padding: 15px; text-align: left; border-bottom: 1px solid var(--ablp-border-color); }
.ablp-table thead th { font-size: 14px; text-transform: uppercase; color: #666; background-color: var(--ablp-light-gray); }
.ablp-table tbody tr:last-child td { border-bottom: none; }
.ablp-table .select-rate-btn { background-color: #e6f0ff; color: var(--ablp-blue); border: 1px solid var(--ablp-blue); padding: 8px 12px; border-radius: 5px; font-weight: 600; cursor: pointer; }

/* Modal Styles */
.ablp-modal-overlay { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0,0,0,0.6); z-index: 1000; display: flex; align-items: center; justify-content: center; }
.ablp-modal-content { background: white; border-radius: 8px; width: 90%; max-width: 800px; box-shadow: 0 5px 15px rgba(0,0,0,0.3); animation: slide-down 0.3s ease-out; }
.ablp-modal-header { display: flex; justify-content: space-between; align-items: center; padding: 20px; border-bottom: 1px solid var(--ablp-border-color); }
.ablp-modal-header h2 { margin: 0; font-size: 18px; }
.ablp-modal-close { background: none; border: none; font-size: 28px; cursor: pointer; }
.ablp-modal-body { padding: 20px; max-height: 70vh; overflow-y: auto; }
.order-summary { background: var(--ablp-light-gray); padding: 15px; border-radius: 5px; margin-bottom: 20px; }
.payment-section { margin-top: 20px; }
#card-element { border: 1px solid #ccc; padding: 10px; border-radius: 4px; margin: 10px 0; }
#card-errors { color: #fa755a; }
#purchase-spinner.is-active { visibility: visible; }
@keyframes slide-down { from { transform: translateY(-30px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }

/* Login/Register Page Styles */
.ablp-portal-forms-wrapper { display: flex; align-items: center; justify-content: center; min-height: 80vh; }
.ablp-portal-forms { display: flex; gap: 40px; padding: 20px; max-width: 800px; width: 100%; }
.ablp-login-form, .ablp-register-form { flex: 1; background: white; padding: 30px; border-radius: 8px; box-shadow: 0 2px 4px rgba(0,0,0,0.05); }
.ablp-login-form h2, .ablp-register-form h2 { margin-top: 0; }
.ablp-login-form p, .ablp-register-form p { margin-bottom: 15px; }
.ablp-login-form label, .ablp-register-form label { display: block; margin-bottom: 5px; font-weight: 600; }
.ablp-login-form .input, .ablp-register-form .input { width: 100%; padding: 10px; border: 1px solid #ccc; border-radius: 4px; }
.ablp-notice.error { background-color: #fbeaea; color: #912d2b; border: 1px solid #e0b4b4; padding: 15px; border-radius: 5px; margin: 0 auto 20px auto; max-width: 800px; width: 100%; }

/* Responsive */
@media (max-width: 992px) { .four-cols { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 768px) { .ablp-portal-wrapper { flex-direction: column; } .ablp-sidebar { position: static; width: 100%; height: auto; } .ablp-main-content { margin-left: 0; } .two-cols, .four-cols { grid-template-columns: 1fr; } .ablp-portal-forms { flex-direction: column; } }

/* Express Widget Styles */
#ablp-express-widget-wrapper { max-width: 450px; margin: 40px auto; font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif; }
.ablp-widget-card { background: #fff; border-radius: 8px; box-shadow: 0 4px 15px rgba(0,0,0,0.1); overflow: hidden; }
.ablp-widget-header { background-color: var(--ablp-dark-blue); color: white; padding: 20px; }
.ablp-widget-header h3 { margin: 0 0 5px 0; font-size: 20px; }
.ablp-widget-header p { margin: 0; opacity: 0.8; }
.ablp-widget-body { padding: 20px; }
.ablp-widget-row { display: flex; gap: 15px; margin-bottom: 15px; }
.ablp-widget-group { flex: 1; }
.ablp-widget-group label { display: block; font-size: 14px; font-weight: 600; margin-bottom: 5px; }
.ablp-widget-group input { width: 100%; padding: 10px; border: 1px solid #ccc; border-radius: 4px; }
.ablp-widget-row.package-details .ablp-widget-group { flex-basis: 25%; }
.ablp-widget-actions { margin-top: 20px; }
.ablp-widget-actions .button-primary { width: 100%; padding: 15px; font-size: 18px; }
#ablp-widget-results { padding: 20px; border-top: 1px solid var(--ablp-border-color); }
#ablp-widget-results .spinner-wrapper { text-align: center; }
#ablp-widget-results-list { list-style: none; padding: 0; margin: 0; }
#ablp-widget-results-list li { display: flex; justify-content: space-between; align-items: center; padding: 15px 0; border-bottom: 1px solid #f0f0f0; }
#ablp-widget-results-list li:last-child { border-bottom: none; }
#ablp-widget-results-list .carrier-name { font-weight: 600; }
#ablp-widget-results-list .rate-cost { font-size: 18px; font-weight: 700; color: var(--ablp-blue); }
.ablp-widget-footer { text-align: center; margin-top: 20px; padding-top: 20px; border-top: 2px solid var(--ablp-blue); }
.ablp-widget-footer a { font-weight: 600; color: var(--ablp-blue); text-decoration: none; }
#ablp-widget-error.ablp-notice.error { margin-bottom: 0; }

/* Tracking Modal Timeline Styles */
#ablp-tracking-results-list { list-style: none; padding: 0; }
#ablp-tracking-results-list li { padding: 10px 10px 25px 30px; border-left: 2px solid #e0e0e0; position: relative; }
#ablp-tracking-results-list li:last-child { border-left: 2px solid transparent; }
#ablp-tracking-results-list li::before { content: ''; width: 12px; height: 12px; background-color: #ccc; border-radius: 50%; position: absolute; left: -7px; top: 12px; }
#ablp-tracking-results-list li.is-latest::before { background-color: var(--ablp-blue); }
#ablp-tracking-results-list .tracking-status { display: block; font-weight: 600; font-size: 16px; margin-bottom: 4px; }
#ablp-tracking-results-list .tracking-location { display: block; color: #555; margin-bottom: 4px; }
#ablp-tracking-results-list .tracking-date { display: block; color: #888; font-size: 12px; }