:root{
  --lbp-bg:#050505;
  --lbp-panel:#101114;
  --lbp-panel-2:#17191d;
  --lbp-card:#ffffff;
  --lbp-ink:#14171c;
  --lbp-muted:#747b86;
  --lbp-line:rgba(255,255,255,.10);
  --lbp-red:#e72e25;
  --lbp-red-dark:#9f1714;
  --lbp-red-soft:#fff1f0;
  --lbp-silver:#f4f5f7;
  --lbp-metal:#c8ccd3;
  --lbp-metal-dark:#69707a;
  --lbp-good:#099250;
  --lbp-warn:#b54708;
  --lbp-bad:#b42318;
  --lbp-shadow:0 30px 80px rgba(0,0,0,.24);
  --lbp-shadow-soft:0 16px 42px rgba(16,24,40,.10);
}

/* Hard reset inside the component so the Joomla template does not create odd gaps. */
.lbp-portal,
.lbp-portal *{box-sizing:border-box}
.lbp-portal{max-width:1220px;width:100%;margin:24px auto 44px!important;padding:18px!important;color:var(--lbp-ink);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Arial,sans-serif;background:linear-gradient(145deg,#050505 0%,#111216 58%,#050505 100%);border:1px solid rgba(255,255,255,.12);border-radius:32px;box-shadow:var(--lbp-shadow);overflow:hidden;isolation:isolate}
.lbp-portal a{text-decoration:none!important}.lbp-portal p,.lbp-portal h1,.lbp-portal h2,.lbp-portal table{margin-top:0}.lbp-theme-towing24{position:relative}.lbp-theme-towing24:before{content:"";position:absolute;inset:0;height:315px;background:radial-gradient(circle at 14% 10%,rgba(231,46,37,.28),transparent 34%),radial-gradient(circle at 86% 5%,rgba(255,255,255,.10),transparent 30%);z-index:-2}.lbp-theme-towing24:after{content:"";position:absolute;left:22px;right:22px;top:132px;height:1px;background:linear-gradient(90deg,transparent,rgba(231,46,37,.90),rgba(255,255,255,.34),transparent);z-index:-1;opacity:.78}

/* Hero */
.lbp-hero{position:relative;overflow:hidden;display:grid;grid-template-columns:minmax(0,1fr) minmax(230px,310px);align-items:stretch;gap:18px;padding:24px!important;border-radius:26px;background:linear-gradient(135deg,#070707 0%,#15171b 58%,#080808 100%);border:1px solid rgba(255,255,255,.12);box-shadow:0 20px 54px rgba(0,0,0,.22);margin:0!important}.lbp-hero:before{content:"";position:absolute;right:-120px;top:-136px;width:350px;height:350px;border-radius:50%;background:radial-gradient(circle,rgba(231,46,37,.40),rgba(231,46,37,.12) 38%,transparent 66%)}.lbp-hero:after{content:"";position:absolute;left:-88px;bottom:-122px;width:310px;height:310px;border-radius:50%;background:radial-gradient(circle,rgba(244,245,247,.13),transparent 64%)}.lbp-hero>*{position:relative;z-index:1}.lbp-logo-wrap{display:flex;align-items:center;justify-content:flex-start;max-width:390px;width:100%;margin:0 0 14px!important}.lbp-logo-wrap img{display:block;max-width:min(390px,100%);height:auto;filter:drop-shadow(0 15px 25px rgba(0,0,0,.45))}.lbp-eyebrow{display:inline-flex;align-items:center;gap:8px;color:#fff;background:linear-gradient(135deg,var(--lbp-red),var(--lbp-red-dark));border:1px solid rgba(255,255,255,.16);border-radius:999px;padding:7px 12px;font-size:12px;font-weight:950;letter-spacing:.1em;text-transform:uppercase;box-shadow:0 14px 30px rgba(231,46,37,.22)}.lbp-eyebrow:before{content:"";width:8px;height:8px;border-radius:50%;background:#fff;box-shadow:0 0 0 4px rgba(255,255,255,.16)}.lbp-hero h1{margin:12px 0 8px!important;color:#fff;font-size:clamp(26px,3.1vw,44px);line-height:1.02;font-weight:1000;letter-spacing:-.055em;text-transform:uppercase;text-shadow:0 2px 0 rgba(255,255,255,.08)}.lbp-hero p{margin:0!important;color:#d5d9df;font-size:16px;font-weight:750;line-height:1.45}.lbp-hero-balance{min-width:0;align-self:stretch;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0;padding:26px 22px!important;border-radius:22px;background:linear-gradient(180deg,rgba(255,255,255,.14),rgba(255,255,255,.06));border:1px solid rgba(255,255,255,.16);box-shadow:inset 0 1px 0 rgba(255,255,255,.16),0 18px 44px rgba(0,0,0,.25);text-align:center;min-height:190px}.lbp-hero-balance span{display:block;width:100%;color:#cbd1da;text-transform:uppercase;letter-spacing:.105em;font-size:12px;font-weight:950;line-height:1.25;margin:0 0 12px!important}.lbp-hero-balance strong{display:block;width:100%;margin:0!important;color:#fff;font-size:clamp(34px,3.5vw,50px);line-height:.98;font-weight:1000;letter-spacing:-.055em;text-align:center}.lbp-hero-balance small{display:block;width:100%;margin:13px 0 0!important;color:#aeb5bf;font-size:12px;font-weight:850;line-height:1.35;text-align:center}

/* v1.0.12 centers and tightens the Available Credit hero panel. */
/* Navigation: literal PHP text nodes were removed in v1.0.10. Font-size:0 is an extra guard against template text gaps. */
.lbp-tabs{display:grid!important;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px!important;width:100%;margin:14px 0!important;padding:0!important;font-size:0;align-items:stretch}.lbp-tab,.lbp-tabs a{display:flex!important;flex-direction:column;justify-content:center;gap:4px;min-width:0;min-height:72px;margin:0!important;padding:14px 16px!important;border-radius:17px;background:linear-gradient(180deg,#fff 0%,#f5f6f8 100%);border:1px solid #e4e7ec;color:#24272d!important;box-shadow:0 14px 32px rgba(16,24,40,.09);transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease,background .16s ease;white-space:normal!important;font-size:16px}.lbp-tab:hover,.lbp-tabs a:hover{transform:translateY(-2px);border-color:rgba(231,46,37,.38);box-shadow:0 18px 42px rgba(16,24,40,.14)}.lbp-tab.active,.lbp-tabs a.active{color:#fff!important;background:linear-gradient(135deg,#1a1c21 0%,#0b0c0f 46%,#e72e25 148%);border-color:rgba(231,46,37,.58);box-shadow:0 20px 46px rgba(231,46,37,.24),inset 0 1px 0 rgba(255,255,255,.14)}.lbp-tab-label{display:block;font-size:16px;font-weight:1000;line-height:1.08;letter-spacing:-.02em}.lbp-tab small{display:block;color:inherit;opacity:.72;font-size:11px;font-weight:800;line-height:1.25}

/* Content */
.lbp-grid{display:grid!important;gap:12px!important;margin:0 0 14px!important}.lbp-grid.four{grid-template-columns:repeat(4,minmax(0,1fr))}.lbp-stat{position:relative;overflow:hidden;min-width:0;background:#fff;border:1px solid #e8ebef;border-radius:20px;padding:18px!important;box-shadow:0 14px 34px rgba(16,24,40,.09);margin:0!important}.lbp-stat:before{content:"";position:absolute;inset:0 0 auto;height:4px;background:linear-gradient(90deg,var(--lbp-red),#ff6b61,#ffffff)}.lbp-stat:after{content:"";position:absolute;right:-46px;top:-54px;width:126px;height:126px;border-radius:50%;background:rgba(231,46,37,.08)}.lbp-stat span{display:block;color:#747b86;font-size:11px;font-weight:950;text-transform:uppercase;letter-spacing:.075em;line-height:1.2}.lbp-stat strong{display:block;margin-top:8px;color:#111318;font-size:clamp(26px,2.8vw,40px);line-height:1;font-weight:1000;letter-spacing:-.05em;overflow-wrap:anywhere}.lbp-card{background:#fff;border:1px solid #e4e7ec;border-radius:22px;padding:20px!important;margin:0 0 14px!important;box-shadow:0 14px 34px rgba(16,24,40,.09);overflow:hidden}.lbp-card:last-child{margin-bottom:0!important}.lbp-card-title{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:0 0 14px!important;padding:0 0 13px!important;border-bottom:1px solid #eceff3}.lbp-card h2{margin:0!important;color:#111318;font-size:21px;line-height:1.15;font-weight:1000;letter-spacing:-.025em}.lbp-empty{text-align:center;padding:30px!important}.lbp-empty p,.lbp-card p{color:#555e69;line-height:1.58;font-weight:560;margin-bottom:12px}.lbp-card p:last-child{margin-bottom:0!important}

/* Tables */
.lbp-table{overflow:auto;border:1px solid #eceff3;border-radius:17px;background:#fff;margin:0!important}.lbp-table table{width:100%;border-collapse:separate;border-spacing:0;min-width:760px;margin:0!important}.lbp-table th,.lbp-table td{padding:13px 14px!important;border-bottom:1px solid #eceff3;text-align:left;vertical-align:middle}.lbp-table tr:last-child td{border-bottom:0}.lbp-table th{background:linear-gradient(180deg,#f7f8fa,#eef1f5);color:#353a42;font-size:11px;font-weight:1000;letter-spacing:.08em;text-transform:uppercase;white-space:nowrap}.lbp-table td{color:#252a31;font-size:14px;line-height:1.42}.lbp-table tbody tr:hover td{background:#fff8f7}.lbp-badge{display:inline-flex;align-items:center;border-radius:999px;padding:5px 11px;background:#eef0f2;color:#30343b;font-size:12px;font-weight:900;text-transform:capitalize;white-space:nowrap}.lbp-badge.good{background:#e8f7ef;color:var(--lbp-good)}.lbp-badge.warn{background:#fff4e5;color:var(--lbp-warn)}.lbp-badge.bad{background:#fff1f0;color:var(--lbp-bad)}

/* Forms and buttons */
.lbp-inline{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin:0!important}.lbp-inline input[type=text],.lbp-card input[type=text]{height:38px;border:1px solid #d0d5dd;border-radius:12px;padding:8px 10px;box-shadow:0 1px 2px rgba(16,24,40,.04);margin:0!important}.lbp-inline input[type=text]:focus,.lbp-card input[type=text]:focus{outline:0;border-color:var(--lbp-red);box-shadow:0 0 0 4px rgba(231,46,37,.12)}.btn,.lbp-card button,.lbp-actions .btn{display:inline-flex;align-items:center;justify-content:center;border:0!important;border-radius:12px;background:linear-gradient(135deg,var(--lbp-red),var(--lbp-red-dark));color:#fff!important;font-weight:950;padding:10px 14px!important;min-height:40px;box-shadow:0 13px 25px rgba(231,46,37,.24);cursor:pointer;text-decoration:none!important;margin:0!important}.btn:hover,.lbp-card button:hover{filter:brightness(.96);transform:translateY(-1px)}.btn.btn-small{font-size:12px;padding:8px 10px!important;min-height:34px;border-radius:10px}.lbp-card em{color:#7a828e}

@media(max-width:1050px){.lbp-grid.four,.lbp-tabs{grid-template-columns:repeat(2,minmax(0,1fr))}.lbp-hero{grid-template-columns:1fr}.lbp-hero-balance{text-align:center;min-height:auto}.lbp-logo-wrap{max-width:340px}}
@media(max-width:640px){.lbp-portal{margin:14px auto 28px!important;padding:12px!important;border-radius:24px}.lbp-theme-towing24:after{top:122px;left:14px;right:14px}.lbp-hero{padding:18px!important;border-radius:22px}.lbp-hero h1{font-size:27px}.lbp-grid.four,.lbp-tabs{grid-template-columns:1fr}.lbp-tab,.lbp-tabs a{min-height:64px;padding:13px 14px!important}.lbp-card{padding:16px!important;border-radius:20px}.lbp-table table{min-width:720px}.lbp-inline input[type=text]{width:100%!important}.btn.btn-small{width:100%}}

/* v1.0.12: shorter title and slightly smaller hero heading for cleaner Response Network branding. */
