:root {
  --t24-red: #e30613;
  --t24-red-bright: #ff202d;
  --t24-dark: #070b10;
  --t24-ink: #0b1119;
  --t24-panel: #111821;
  --t24-silver: #f4f6f8;
  --t24-muted: rgba(255,255,255,.68);
  --t24-line: rgba(255,255,255,.11);
  --t24-radius: 24px;
  --t24-shadow: 0 24px 90px rgba(0,0,0,.38);
  --t24-font: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body.t24 { margin:0; min-height:100vh; font-family:var(--t24-font); background:var(--t24-dark); color:var(--t24-silver); line-height:1.55; overflow-x:hidden; }
body.t24::before { content:""; position:fixed; inset:0; pointer-events:none; z-index:-2; background: radial-gradient(circle at 16% -8%, color-mix(in srgb, var(--t24-red) 26%, transparent), transparent 30rem), radial-gradient(circle at 100% 12%, rgba(255,255,255,.085), transparent 32rem), linear-gradient(180deg, #070b10 0%, #080d14 46%, #030508 100%); }
body.t24::after { content:""; position:fixed; inset:0; pointer-events:none; z-index:-1; opacity:.22; background-image:linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px); background-size:42px 42px; mask-image:linear-gradient(to bottom, black, transparent 78%); }
a { color:inherit; text-decoration:none; }
img { max-width:100%; height:auto; display:block; }
.container { width:min(100% - 40px, 1220px); margin-inline:auto; }
.skip-link { position:absolute; left:-999px; top:10px; z-index:9999; background:#fff; color:#000; padding:.75rem 1rem; border-radius:.7rem; }
.skip-link:focus { left:10px; }

.emergency-bar { position:relative; z-index:80; background:linear-gradient(90deg,#a9040b,var(--t24-red),#fc2430); color:#fff; border-bottom:1px solid rgba(255,255,255,.2); box-shadow:0 10px 34px rgba(0,0,0,.32); }
.emergency-bar__inner { min-height:42px; display:flex; align-items:center; justify-content:center; gap:.75rem; font-size:.92rem; text-transform:uppercase; letter-spacing:.08em; text-align:center; }
.emergency-bar__inner a { font-weight:950; padding:.28rem .7rem; border:1px solid rgba(255,255,255,.44); border-radius:999px; background:rgba(0,0,0,.18); }
.pulse-dot { width:10px; height:10px; border-radius:50%; background:#fff; box-shadow:0 0 0 0 rgba(255,255,255,.7); animation:t24-pulse 1.5s infinite; flex:0 0 auto; }
@keyframes t24-pulse { 70% { box-shadow:0 0 0 11px rgba(255,255,255,0); } 100% { box-shadow:0 0 0 0 rgba(255,255,255,0); } }
.topbar { background:rgba(0,0,0,.28); border-bottom:1px solid var(--t24-line); }
.topbar__inner { min-height:36px; display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.72); font-size:.9rem; }

.site-header { position:sticky; top:0; z-index:70; background:rgba(5,8,12,.86); backdrop-filter:blur(18px); border-bottom:1px solid rgba(255,255,255,.08); transition:box-shadow .18s ease, background .18s ease; }
.site-header.is-scrolled { box-shadow:0 18px 48px rgba(0,0,0,.28); background:rgba(4,7,11,.94); }
.header-grid { min-height:88px; display:grid; grid-template-columns:minmax(260px, 360px) 1fr auto; align-items:center; gap:22px; }
.brand-wrap { min-width:0; }
.brand--image { display:flex; align-items:center; min-width:0; width:max-content; max-width:100%; }
.brand--image img { width:315px; max-width:min(315px, 32vw); max-height:76px; object-fit:contain; filter:drop-shadow(0 11px 20px rgba(0,0,0,.46)); }
.site-nav { justify-self:center; }
.site-nav ul, .fallback-menu, .mod-menu { list-style:none; padding:0; margin:0; display:flex; align-items:center; gap:.35rem; }
.site-nav a { display:flex; align-items:center; min-height:42px; padding:.65rem .9rem; border-radius:999px; color:rgba(255,255,255,.76); font-weight:850; font-size:.92rem; letter-spacing:.01em; transition:background .18s ease, color .18s ease, transform .18s ease; }
.site-nav a:hover, .site-nav .current > a, .site-nav .active > a { color:#fff; background:rgba(255,255,255,.075); transform:translateY(-1px); }
.header-actions { justify-self:end; }
.call-pill { display:flex; flex-direction:column; align-items:flex-start; justify-content:center; min-height:58px; padding:.72rem 1.05rem; border-radius:18px; color:#fff; background:linear-gradient(135deg,#ff2d38,var(--t24-red) 56%,#9e050b); box-shadow:0 14px 34px color-mix(in srgb, var(--t24-red) 24%, transparent), inset 0 1px 0 rgba(255,255,255,.26); font-weight:900; line-height:1.05; }
.call-pill span { font-size:.7rem; text-transform:uppercase; letter-spacing:.12em; opacity:.92; }
.call-pill strong { font-size:1.05rem; white-space:nowrap; }
.nav-toggle { display:none; }

.hero-shell { position:relative; padding:clamp(42px,6vw,86px) 0 38px; overflow:hidden; }
.hero-shell::before { content:""; position:absolute; inset:0; z-index:-1; background:linear-gradient(120deg, rgba(0,0,0,.44), transparent 58%); }
.hero-grid { display:grid; grid-template-columns:1.01fr .99fr; gap:clamp(30px,5vw,70px); align-items:center; }
.eyebrow { display:flex; align-items:center; gap:.7rem; margin:0 0 1rem; color:#fff; text-transform:uppercase; letter-spacing:.16em; font-size:.77rem; font-weight:900; }
.eyebrow span { width:46px; height:3px; border-radius:99px; background:var(--t24-red); box-shadow:0 0 22px color-mix(in srgb, var(--t24-red) 70%, transparent); }
.hero-copy h1 { margin:0; font-size:clamp(3rem,7vw,6.9rem); line-height:.91; letter-spacing:-.075em; max-width:820px; color:#fff; text-shadow:0 22px 56px rgba(0,0,0,.4); }
.hero-lede { max-width:690px; margin:1.15rem 0 0; color:rgba(255,255,255,.78); font-size:clamp(1.05rem,1.65vw,1.34rem); }
.hero-actions { display:flex; flex-wrap:wrap; gap:14px; margin:2rem 0 0; }
.btn { display:inline-flex; align-items:center; justify-content:center; gap:.65rem; min-height:56px; padding:.92rem 1.35rem; border-radius:16px; font-weight:950; letter-spacing:.01em; border:1px solid rgba(255,255,255,.12); transition:transform .16s ease, box-shadow .16s ease, background .16s ease; }
.btn:hover { transform:translateY(-2px); }
.btn-primary { background:linear-gradient(135deg,#ff2d38,var(--t24-red) 56%,#97050a); color:#fff; box-shadow:0 18px 46px color-mix(in srgb, var(--t24-red) 28%, transparent), inset 0 1px 0 rgba(255,255,255,.24); }
.btn-primary:hover { box-shadow:0 22px 60px color-mix(in srgb, var(--t24-red) 38%, transparent), inset 0 1px 0 rgba(255,255,255,.24); }
.btn-ghost { background:rgba(255,255,255,.065); color:#fff; }
.btn-call { font-size:1.08rem; }
.hero-proof { display:flex; flex-wrap:wrap; gap:10px; margin-top:1.45rem; }
.hero-proof span { padding:.55rem .78rem; border:1px solid rgba(255,255,255,.12); border-radius:999px; background:rgba(255,255,255,.052); color:rgba(255,255,255,.78); font-size:.86rem; font-weight:800; }
.hero-panel { display:grid; gap:18px; }
.hero-logo-card { min-height:310px; display:grid; place-items:center; padding:28px; border-radius:34px; background:radial-gradient(circle at 42% 28%, rgba(255,255,255,.14), transparent 22rem), linear-gradient(145deg, rgba(255,255,255,.12), rgba(255,255,255,.036)); border:1px solid rgba(255,255,255,.13); box-shadow:var(--t24-shadow); }
.hero-logo-card img { width:min(650px,100%); filter:drop-shadow(0 20px 32px rgba(0,0,0,.54)); }
.help-console { display:grid; gap:10px; padding:18px 20px; border-radius:22px; border:1px solid rgba(255,255,255,.11); background:rgba(0,0,0,.27); box-shadow:0 16px 48px rgba(0,0,0,.26); }
.console-head { display:flex; align-items:center; gap:.62rem; }
.console-head strong { color:#fff; margin-right:auto; }
.console-head small { color:rgba(255,255,255,.62); text-transform:uppercase; font-size:.76rem; letter-spacing:.14em; font-weight:900; }
.route-row { display:flex; justify-content:space-between; gap:14px; padding:12px 0; border-top:1px solid rgba(255,255,255,.08); }
.route-row span { color:rgba(255,255,255,.62); }
.route-row strong { color:#fff; text-align:right; }
.live-dot { width:12px; height:12px; border-radius:50%; background:var(--t24-red); box-shadow:0 0 0 7px color-mix(in srgb, var(--t24-red) 14%, transparent), 0 0 22px color-mix(in srgb, var(--t24-red) 78%, transparent); }

.trust-band { border-block:1px solid rgba(255,255,255,.08); background:linear-gradient(90deg, rgba(255,255,255,.04), rgba(255,255,255,.02)); }
.trust-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:1px; }
.trust-grid > * { display:flex; flex-direction:column; justify-content:center; min-height:98px; padding:18px; border-inline:1px solid rgba(255,255,255,.055); }
.trust-grid strong { color:#fff; font-size:1.25rem; text-transform:uppercase; letter-spacing:-.025em; }
.trust-grid span { color:rgba(255,255,255,.64); font-size:.9rem; }
.section { padding:64px 0; }
.section-head { margin-bottom:26px; max-width:760px; }
.section-head--center { margin-inline:auto; text-align:center; }
.section-head--center .eyebrow { justify-content:center; }
.section-head h2, .split-section h2, .partner-card h2, .faq-intro h2 { margin:0; font-size:clamp(2.05rem,4.8vw,4.8rem); line-height:.96; letter-spacing:-.06em; color:#fff; }
.section-head p, .split-section p, .partner-card p, .faq-intro p { color:rgba(255,255,255,.68); font-size:1.04rem; }
.service-finder { background:linear-gradient(180deg, rgba(255,255,255,.025), rgba(255,255,255,.045)); }

/* Center the built-in service finder intro copy. */
.service-finder .section-head { margin-left:auto; margin-right:auto; text-align:center; max-width:900px; }
.service-finder .section-head .eyebrow { justify-content:center; }
.service-finder .section-head h2 { max-width:860px; margin-left:auto; margin-right:auto; }
.service-finder .section-head p:not(.eyebrow) { max-width:760px; margin-left:auto; margin-right:auto; }

/* Joomla login/forms: make core buttons match the template CTA style. */
.t24 .mod-login, .t24 .login, .t24 .logout, .t24 .com-users-login, .t24 .com-users-registration, .t24 #member-registration, .t24 .remind, .t24 .reset { color:rgba(255,255,255,.78); }
.t24 .mod-login input[type="text"], .t24 .mod-login input[type="password"], .t24 .mod-login input[type="email"], .t24 .login input[type="text"], .t24 .login input[type="password"], .t24 .login input[type="email"], .t24 .com-users-login input[type="text"], .t24 .com-users-login input[type="password"], .t24 .com-users-login input[type="email"], .t24 .com-users-registration input, .t24 #member-registration input, .t24 textarea, .t24 select { width:100%; min-height:48px; border-radius:14px; border:1px solid rgba(255,255,255,.14); background:rgba(255,255,255,.07); color:#fff; padding:.76rem .9rem; box-shadow:inset 0 1px 0 rgba(255,255,255,.05); }
.t24 .mod-login input:focus, .t24 .login input:focus, .t24 .com-users-login input:focus, .t24 .com-users-registration input:focus, .t24 #member-registration input:focus, .t24 textarea:focus, .t24 select:focus { outline:2px solid color-mix(in srgb, var(--t24-red) 68%, transparent); outline-offset:2px; border-color:color-mix(in srgb, var(--t24-red) 62%, transparent); }
.t24 .mod-login label, .t24 .login label, .t24 .com-users-login label, .t24 .com-users-registration label, .t24 #member-registration label { color:rgba(255,255,255,.78); font-weight:800; }
.t24 .mod-login .btn, .t24 .mod-login button, .t24 .login .btn, .t24 .login button, .t24 .logout .btn, .t24 .logout button, .t24 .com-users-login .btn, .t24 .com-users-login button, .t24 .com-users-registration .btn, .t24 .com-users-registration button, .t24 #member-registration .btn, .t24 #member-registration button, .t24 input[type="submit"].btn, .t24 button.btn-primary, .t24 a.btn-primary { display:inline-flex; align-items:center; justify-content:center; gap:.55rem; min-height:50px; padding:.82rem 1.18rem; border-radius:16px; border:1px solid rgba(255,255,255,.16); background:linear-gradient(135deg,#ff2d38,var(--t24-red) 56%,#97050a); color:#fff !important; font-weight:950; letter-spacing:.01em; box-shadow:0 15px 36px color-mix(in srgb, var(--t24-red) 25%, transparent), inset 0 1px 0 rgba(255,255,255,.24); text-shadow:none; }
.t24 .mod-login .btn:hover, .t24 .mod-login button:hover, .t24 .login .btn:hover, .t24 .login button:hover, .t24 .logout .btn:hover, .t24 .logout button:hover, .t24 .com-users-login .btn:hover, .t24 .com-users-login button:hover, .t24 .com-users-registration .btn:hover, .t24 .com-users-registration button:hover, .t24 #member-registration .btn:hover, .t24 #member-registration button:hover { transform:translateY(-1px); box-shadow:0 18px 44px color-mix(in srgb, var(--t24-red) 34%, transparent), inset 0 1px 0 rgba(255,255,255,.24); }
.t24 .mod-login ul, .t24 .login ul, .t24 .com-users-login ul { list-style:none; padding-left:0; }
.t24 .mod-login a, .t24 .login a, .t24 .com-users-login a { color:rgba(255,255,255,.76); }
.t24 .mod-login a:hover, .t24 .login a:hover, .t24 .com-users-login a:hover { color:#fff; }
.service-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.service-card, .moduletable, .card, .premium-module { border:1px solid rgba(255,255,255,.1); border-radius:var(--t24-radius); background:linear-gradient(180deg, rgba(255,255,255,.078), rgba(255,255,255,.035)); box-shadow:0 18px 54px rgba(0,0,0,.25); }
.service-card { padding:22px; position:relative; overflow:hidden; min-height:248px; display:flex; flex-direction:column; }
.service-card::after { content:""; position:absolute; inset:auto -44px -68px auto; width:150px; height:150px; border-radius:50%; background:color-mix(in srgb, var(--t24-red) 13%, transparent); }
.service-icon { width:58px; height:58px; display:grid; place-items:center; margin-bottom:1rem; border-radius:17px; background:linear-gradient(135deg,#ff2632,var(--t24-red) 62%,#94060c); color:#fff; font-weight:950; font-size:.82rem; letter-spacing:-.03em; box-shadow:0 18px 34px color-mix(in srgb, var(--t24-red) 25%, transparent); }
.service-card h3 { margin:0 0 .65rem; font-size:1.26rem; line-height:1.07; letter-spacing:-.035em; color:#fff; }
.service-card p { margin:0 0 1.2rem; color:rgba(255,255,255,.68); font-size:.94rem; }
.mini-call { margin-top:auto; position:relative; z-index:1; display:inline-flex; align-self:flex-start; padding:.62rem .88rem; border-radius:999px; background:rgba(227,6,19,.16); color:#fff; border:1px solid color-mix(in srgb, var(--t24-red) 55%, rgba(255,255,255,.08)); font-weight:950; }
.mini-call::before { content:"☎"; margin-right:.42rem; }
.module-row { padding:28px 0; }
.module-row > * + * { margin-top:18px; }
.moduletable, .premium-module { padding:22px; }
.module-title { margin:0 0 .8rem; color:#fff; letter-spacing:-.025em; }
.breadcrumbs { padding:18px 0 0; color:var(--t24-muted); }

.main-layout { display:grid; gap:26px; padding:42px 0 64px; }
.main-layout.no-sidebar { grid-template-columns:1fr; }
.main-layout.has-left-sidebar { grid-template-columns:290px 1fr; }
.main-layout.has-right-sidebar { grid-template-columns:1fr 290px; }
.main-layout.has-two-sidebars { grid-template-columns:250px 1fr 250px; }
.content-area { min-width:0; padding:30px; border-radius:28px; background:rgba(255,255,255,.045); border:1px solid rgba(255,255,255,.08); }
body.is-home .content-area:empty { display:none; }
.content-area h1, .content-area h2, .content-area h3 { letter-spacing:-.035em; line-height:1.05; color:#fff; }
.content-area a { color:#fff; border-bottom:1px solid color-mix(in srgb, var(--t24-red) 70%, transparent); }
.content-area .btn { border-bottom:0; }
.sidebar { min-width:0; }

.how-it-works { background:linear-gradient(180deg, rgba(0,0,0,.05), rgba(255,255,255,.025)); }
.steps-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.step-card { padding:26px; border-radius:26px; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1); box-shadow:0 20px 58px rgba(0,0,0,.22); }
.step-card strong { width:48px; height:48px; display:grid; place-items:center; margin-bottom:1rem; border-radius:50%; background:var(--t24-red); color:#fff; font-size:1.25rem; box-shadow:0 12px 30px color-mix(in srgb, var(--t24-red) 25%, transparent); }
.step-card h3 { margin:0 0 .5rem; color:#fff; font-size:1.4rem; letter-spacing:-.035em; }
.step-card p { margin:0; color:rgba(255,255,255,.68); }

.cities-section { padding:76px 0; background:radial-gradient(circle at 18% 20%, color-mix(in srgb, var(--t24-red) 18%, transparent), transparent 28rem), linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.02)); border-block:1px solid rgba(255,255,255,.08); }
.split-section { display:grid; grid-template-columns:.95fr 1.05fr; gap:42px; align-items:center; }
.inline-call { margin-top:1.2rem; }
.city-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:12px; }
.city-grid a { display:block; }
.city-grid span { display:block; padding:16px 18px; border:1px solid rgba(255,255,255,.1); border-radius:18px; background:rgba(0,0,0,.24); color:#fff; font-weight:850; transition:transform .18s ease, border-color .18s ease; }
.city-grid a:hover span { transform:translateY(-2px); border-color:color-mix(in srgb, var(--t24-red) 65%, rgba(255,255,255,.1)); }
.city-grid span::before { content:""; display:inline-block; width:9px; height:9px; border-radius:50%; margin-right:10px; background:var(--t24-red); box-shadow:0 0 18px color-mix(in srgb, var(--t24-red) 72%, transparent); }

.faq-section { background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(0,0,0,.08)); }
.faq-grid { display:grid; grid-template-columns:.82fr 1.18fr; gap:28px; align-items:start; }
.faq-intro { position:sticky; top:120px; padding:28px; border-radius:28px; background:linear-gradient(145deg, rgba(227,6,19,.16), rgba(255,255,255,.055)); border:1px solid rgba(255,255,255,.1); }
.faq-list { display:grid; gap:12px; }
details { border:1px solid rgba(255,255,255,.1); border-radius:20px; background:rgba(255,255,255,.055); overflow:hidden; }
summary { cursor:pointer; padding:18px 20px; color:#fff; font-weight:950; list-style:none; }
summary::-webkit-details-marker { display:none; }
summary::after { content:"+"; float:right; color:var(--t24-red); }
details[open] summary::after { content:"–"; }
details p { padding:0 20px 20px; margin:0; color:rgba(255,255,255,.68); }
.partner-section { padding:64px 0; }
.partner-card { display:grid; grid-template-columns:1fr auto; align-items:center; gap:26px; padding:34px; border-radius:32px; background:linear-gradient(135deg, rgba(227,6,19,.22), rgba(255,255,255,.055)); border:1px solid rgba(255,255,255,.12); box-shadow:var(--t24-shadow); }

.site-footer { padding:48px 0 28px; background:#040609; border-top:1px solid rgba(255,255,255,.1); }
.footer-grid { display:grid; grid-template-columns:1.25fr repeat(3,1fr); gap:28px; }
.footer-brand img { width:280px; max-height:100px; object-fit:contain; margin-bottom:16px; }
.footer-brand p { color:rgba(255,255,255,.58); margin:0; font-size:.9rem; }
.footer-call { display:inline-flex; margin-top:16px; padding:.78rem 1rem; border-radius:999px; background:rgba(227,6,19,.15); border:1px solid color-mix(in srgb, var(--t24-red) 55%, transparent); color:#fff; font-weight:950; }
.site-footer h3, .site-footer h4 { color:#fff; margin-top:0; }
.site-footer ul { list-style:none; padding:0; margin:0; }
.site-footer li + li { margin-top:.5rem; }
.site-footer a { color:rgba(255,255,255,.7); }
.site-footer a:hover { color:#fff; }
.footer-bottom { display:flex; gap:20px; justify-content:space-between; align-items:center; border-top:1px solid rgba(255,255,255,.08); margin-top:34px; padding-top:22px; color:rgba(255,255,255,.52); font-size:.88rem; }
.footer-menu ul { display:flex; flex-wrap:wrap; gap:12px; list-style:none; padding:0; margin:0; }

.sticky-call { position:fixed; left:16px; right:16px; bottom:14px; z-index:120; display:none; align-items:center; justify-content:center; gap:.7rem; min-height:58px; padding:.78rem .86rem; border-radius:18px; background:linear-gradient(135deg,#ff2b36,var(--t24-red) 56%,#9c050b); color:#fff; box-shadow:0 18px 60px rgba(0,0,0,.58),0 12px 38px color-mix(in srgb, var(--t24-red) 30%, transparent); font-weight:950; text-align:center; overflow:hidden; }
.sticky-call span { text-transform:uppercase; letter-spacing:.06em; font-size:clamp(.66rem, 2.7vw, .76rem); opacity:.95; white-space:nowrap; }
.sticky-call strong { font-size:clamp(.86rem, 3.5vw, 1rem); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; min-width:0; }
.sticky-call-desktop { position:fixed; right:22px; bottom:22px; z-index:110; display:inline-flex; align-items:center; gap:.8rem; max-width:min(360px, calc(100vw - 44px)); min-height:64px; padding:.78rem .95rem; border-radius:18px; color:#fff; background:rgba(4,7,11,.94); border:1px solid rgba(255,255,255,.15); box-shadow:0 18px 54px rgba(0,0,0,.46); backdrop-filter:blur(16px); overflow:hidden; }
.sticky-call-desktop__badge { flex:0 0 44px; display:grid; place-items:center; width:44px; height:44px; border-radius:50%; background:linear-gradient(135deg,#ff2d38,var(--t24-red) 58%,#9b050b); font-size:.76rem; font-style:normal; font-weight:950; line-height:1; letter-spacing:-.02em; text-transform:uppercase; box-shadow:inset 0 1px 0 rgba(255,255,255,.24); }
.sticky-call-desktop__copy { min-width:0; display:flex; flex-direction:column; line-height:1.12; }
.sticky-call-desktop__copy strong { font-size:.95rem; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.sticky-call-desktop__copy em { margin-top:.18rem; color:rgba(255,255,255,.7); font-size:.86rem; font-style:normal; font-weight:900; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }

.component-view { background:#fff; color:#1b1f26; }
.component-container { padding:40px 0; }
.error-view { display:grid; place-items:center; min-height:100vh; }
.error-shell { width:min(640px, calc(100% - 40px)); padding:42px; text-align:center; border-radius:32px; background:rgba(255,255,255,.065); border:1px solid rgba(255,255,255,.12); box-shadow:var(--t24-shadow); }
.error-shell img { width:170px; margin:0 auto 20px; }
.error-shell h1 { font-size:clamp(4rem,14vw,8rem); line-height:1; margin:0; }
.error-shell p { color:rgba(255,255,255,.72); }

/* Article helper classes: add these to Joomla articles/modules for premium landing pages. */
.t24-landing-hero { padding: clamp(34px, 5vw, 70px); border-radius: 34px; background: radial-gradient(circle at 80% 20%, color-mix(in srgb, var(--t24-red) 22%, transparent), transparent 20rem), linear-gradient(145deg, rgba(255,255,255,.1), rgba(255,255,255,.035)); border:1px solid rgba(255,255,255,.12); }
.t24-price-card, .t24-step-card { padding:24px; border-radius:24px; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1); }
.t24-grid-2 { display:grid; grid-template-columns:repeat(2,1fr); gap:18px; }
.t24-grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }

@media (max-width: 1160px) {
  .service-grid { grid-template-columns:repeat(2,1fr); }
  .header-grid { grid-template-columns:minmax(220px,300px) 1fr auto; gap:14px; }
  .brand--image img { width:280px; }
  .site-nav a { padding:.6rem .66rem; font-size:.86rem; }
}
@media (max-width: 1080px) {
  .header-grid { grid-template-columns:auto auto; min-height:78px; }
  .brand--image img { width:min(300px,60vw); max-width:min(300px,60vw); max-height:70px; }
  .nav-toggle { display:inline-flex; justify-self:end; width:46px; height:46px; border:1px solid rgba(255,255,255,.12); border-radius:14px; background:rgba(255,255,255,.06); flex-direction:column; justify-content:center; gap:5px; padding:0 12px; }
  .nav-toggle span { display:block; height:2px; border-radius:9px; background:#fff; }
  .site-nav { display:none; grid-column:1 / -1; justify-self:stretch; padding-bottom:16px; }
  .site-nav.is-open { display:block; }
  .site-nav ul, .fallback-menu, .mod-menu { flex-direction:column; align-items:stretch; }
  .site-nav a { width:100%; background:rgba(255,255,255,.05); }
  .header-actions { display:none; }
  .hero-grid, .split-section, .faq-grid { grid-template-columns:1fr; }
  .hero-panel { order:-1; }
  .hero-logo-card { min-height:240px; }
  .footer-grid, .trust-grid { grid-template-columns:1fr; }
  .main-layout, .main-layout.has-left-sidebar, .main-layout.has-right-sidebar, .main-layout.has-two-sidebars { grid-template-columns:1fr; }
  .partner-card { grid-template-columns:1fr; }
  .steps-grid { grid-template-columns:1fr; }
  .faq-intro { position:relative; top:auto; }
}
@media (max-width: 720px) {
  body.t24 { padding-bottom: 78px; }
  .container { width:min(100% - 26px,1180px); }
  .emergency-bar__inner { font-size:.76rem; min-height:48px; gap:.45rem; letter-spacing:.04em; }
  .emergency-bar__inner strong { display:none; }
  .brand--image img { width:235px; max-width:60vw; max-height:62px; }
  .hero-shell { padding-top:34px; }
  .hero-copy h1 { font-size:clamp(2.45rem,13vw,4.1rem); }
  .hero-actions { flex-direction:column; }
  .btn { width:100%; }
  .service-grid, .city-grid { grid-template-columns:1fr; }
  .content-area { padding:22px; }
  .footer-bottom { flex-direction:column; align-items:flex-start; }
  .sticky-call { display:flex; }
  .sticky-call-desktop { display:none; }
  .t24-grid-2, .t24-grid-3 { grid-template-columns:1fr; }
}

/* v1.6 UI fixes marker */

/* v1.6 UI fixes: cleaner Joomla login module. */
.t24 .moduletable:has(.mod-login),
.t24 .card:has(.mod-login),
.t24 .premium-module:has(.mod-login) {
  padding: 24px;
  border-radius: 26px;
  background: linear-gradient(180deg, rgba(255,255,255,.09), rgba(255,255,255,.04));
  border: 1px solid rgba(255,255,255,.12);
}
.t24 .mod-login,
.t24 .login,
.t24 .com-users-login,
.t24 .logout,
.t24 .remind,
.t24 .reset { width:100%; max-width:520px; }
.t24 .mod-login .control-group,
.t24 .login .control-group,
.t24 .com-users-login .control-group,
.t24 #member-registration .control-group,
.t24 .remind .control-group,
.t24 .reset .control-group,
.t24 .mod-login .mb-3,
.t24 .login .mb-3,
.t24 .com-users-login .mb-3 { margin:0 0 16px; }
.t24 .mod-login .control-label,
.t24 .login .control-label,
.t24 .com-users-login .control-label,
.t24 #member-registration .control-label,
.t24 .remind .control-label,
.t24 .reset .control-label { margin:0 0 7px; }
.t24 .mod-login label,
.t24 .login label,
.t24 .com-users-login label,
.t24 #member-registration label,
.t24 .remind label,
.t24 .reset label {
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  margin:0 0 7px;
  color:rgba(255,255,255,.82);
  font-size:.9rem;
  font-weight:850;
  line-height:1.25;
}
.t24 .mod-login .controls,
.t24 .login .controls,
.t24 .com-users-login .controls,
.t24 #member-registration .controls,
.t24 .remind .controls,
.t24 .reset .controls { width:100%; }
.t24 .mod-login .input-group,
.t24 .login .input-group,
.t24 .com-users-login .input-group {
  display:flex;
  align-items:stretch;
  width:100%;
  border-radius:16px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(0,0,0,.22);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05);
}
.t24 .mod-login .input-group-text,
.t24 .login .input-group-text,
.t24 .com-users-login .input-group-text {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:46px;
  padding:0 .85rem;
  border:0;
  border-right:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.06);
  color:rgba(255,255,255,.72);
}
.t24 .mod-login input[type="text"],
.t24 .mod-login input[type="password"],
.t24 .mod-login input[type="email"],
.t24 .login input[type="text"],
.t24 .login input[type="password"],
.t24 .login input[type="email"],
.t24 .com-users-login input[type="text"],
.t24 .com-users-login input[type="password"],
.t24 .com-users-login input[type="email"],
.t24 .com-users-registration input,
.t24 #member-registration input,
.t24 .remind input,
.t24 .reset input {
  width:100%;
  min-height:50px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(0,0,0,.22);
  color:#fff;
  padding:.8rem .95rem;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05);
  appearance:none;
}
.t24 .mod-login .input-group input,
.t24 .login .input-group input,
.t24 .com-users-login .input-group input { border:0; border-radius:0; background:transparent; box-shadow:none; }
.t24 .mod-login input::placeholder,
.t24 .login input::placeholder,
.t24 .com-users-login input::placeholder,
.t24 #member-registration input::placeholder { color:rgba(255,255,255,.45); }

.t24 .mod-login input[type="checkbox"],
.t24 .login input[type="checkbox"],
.t24 .com-users-login input[type="checkbox"] {
  width:18px;
  height:18px;
  min-height:18px;
  flex:0 0 18px;
  margin:0;
  padding:0;
  border-radius:5px;
  accent-color:var(--t24-red);
  appearance:auto;
}
.t24 .mod-login .form-check,
.t24 .login .form-check,
.t24 .com-users-login .form-check,
.t24 .mod-login .remember,
.t24 .login .remember {
  display:flex;
  align-items:center;
  gap:.55rem;
  margin:4px 0 16px;
  padding:0;
}
.t24 .mod-login .form-check label,
.t24 .login .form-check label,
.t24 .com-users-login .form-check label,
.t24 .mod-login .remember label,
.t24 .login .remember label { margin:0; font-weight:750; color:rgba(255,255,255,.74); }
.t24 .mod-login .btn,
.t24 .mod-login button,
.t24 .login .btn,
.t24 .login button,
.t24 .logout .btn,
.t24 .logout button,
.t24 .com-users-login .btn,
.t24 .com-users-login button,
.t24 .com-users-registration .btn,
.t24 .com-users-registration button,
.t24 #member-registration .btn,
.t24 #member-registration button,
.t24 .remind .btn,
.t24 .remind button,
.t24 .reset .btn,
.t24 .reset button,
.t24 input[type="submit"],
.t24 button[type="submit"] {
  width:auto;
  max-width:100%;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.55rem;
  min-height:50px;
  padding:.82rem 1.2rem;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.16);
  background:linear-gradient(135deg,#ff2d38,var(--t24-red) 56%,#97050a);
  color:#fff !important;
  font-weight:950;
  line-height:1.1;
  letter-spacing:.01em;
  box-shadow:0 15px 36px color-mix(in srgb, var(--t24-red) 25%, transparent), inset 0 1px 0 rgba(255,255,255,.24);
  text-shadow:none;
  cursor:pointer;
}
.t24 .mod-login .btn-primary,
.t24 .login .btn-primary,
.t24 .com-users-login .btn-primary,
.t24 .com-users-registration .btn-primary,
.t24 #member-registration .btn-primary { width:100%; }
.t24 .mod-login .btn-secondary,
.t24 .login .btn-secondary,
.t24 .com-users-login .btn-secondary,
.t24 .logout .btn-secondary { background:rgba(255,255,255,.08); color:#fff !important; box-shadow:none; }
.t24 .mod-login ul,
.t24 .login ul,
.t24 .com-users-login ul {
  margin:16px 0 0;
  padding:14px 0 0;
  border-top:1px solid rgba(255,255,255,.08);
  list-style:none;
}
.t24 .mod-login li + li,
.t24 .login li + li,
.t24 .com-users-login li + li { margin-top:8px; }
.t24 .mod-login a,
.t24 .login a,
.t24 .com-users-login a { color:rgba(255,255,255,.72); border-bottom:0; font-weight:800; }
.t24 .mod-login a:hover,
.t24 .login a:hover,
.t24 .com-users-login a:hover { color:#fff; }

/* Bulletproof bottom-right desktop call button. */
.sticky-call-desktop {
  position:fixed;
  right:22px;
  bottom:22px;
  z-index:110;
  display:grid;
  grid-template-columns:46px minmax(0, 1fr);
  align-items:center;
  gap:12px;
  width:286px;
  max-width:calc(100vw - 44px);
  min-height:66px;
  padding:10px 13px;
  border-radius:999px;
  color:#fff;
  background:linear-gradient(135deg, rgba(255,45,56,.98), var(--t24-red) 56%, #97050a);
  border:1px solid rgba(255,255,255,.18);
  box-shadow:0 18px 54px rgba(0,0,0,.52), 0 10px 34px color-mix(in srgb, var(--t24-red) 30%, transparent), inset 0 1px 0 rgba(255,255,255,.24);
  backdrop-filter:blur(16px);
  overflow:hidden;
}
.sticky-call-desktop::after {
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:linear-gradient(90deg, rgba(255,255,255,.18), transparent 34%, rgba(0,0,0,.12));
}
.sticky-call-desktop__badge {
  position:relative;
  z-index:1;
  flex:none;
  display:grid;
  place-items:center;
  width:46px;
  height:46px;
  min-width:46px;
  border-radius:50%;
  background:rgba(0,0,0,.32);
  border:1px solid rgba(255,255,255,.22);
  color:#fff;
  font-size:1.12rem;
  font-style:normal;
  font-weight:950;
  line-height:1;
  letter-spacing:0;
  text-transform:none;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.18);
}
.sticky-call-desktop__copy {
  position:relative;
  z-index:1;
  min-width:0;
  max-width:100%;
  display:flex;
  flex-direction:column;
  justify-content:center;
  line-height:1.05;
  overflow:hidden;
}
.sticky-call-desktop__copy strong,
.sticky-call-desktop__copy em {
  display:block;
  max-width:100%;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.sticky-call-desktop__copy strong { font-size:1rem; text-transform:uppercase; letter-spacing:.06em; }
.sticky-call-desktop__copy em { margin-top:.25rem; color:rgba(255,255,255,.88); font-size:.92rem; font-style:normal; font-weight:950; letter-spacing:.01em; }
@media (max-width:720px) {
  .sticky-call-desktop { display:none; }
  .sticky-call {
    left:12px;
    right:12px;
    bottom:12px;
    min-height:62px;
    display:flex;
    flex-wrap:nowrap;
    justify-content:center;
    padding:10px 12px;
    border-radius:18px;
  }
  .sticky-call span,
  .sticky-call strong { min-width:0; max-width:50%; }
  .sticky-call span { font-size:.72rem; }
  .sticky-call strong { font-size:.93rem; }
}
