@font-face{
  font-family:"SiteHeadings";
  src:url("/fonts/heading-font.ttf") format("truetype");
  font-style:normal;
  font-weight:100 900;
  font-display:swap;
}
@font-face{
  font-family:"SiteHeadings";
  src:url("/fonts/heading-font-italic.ttf") format("truetype");
  font-style:italic;
  font-weight:100 900;
  font-display:swap;
}
@font-face{
  font-family:"SiteText";
  src:url("/fonts/body-font.ttf") format("truetype");
  font-style:normal;
  font-weight:300 800;
  font-stretch:75% 100%;
  font-display:swap;
}
@font-face{
  font-family:"SiteText";
  src:url("/fonts/body-font-italic.ttf") format("truetype");
  font-style:italic;
  font-weight:300 800;
  font-stretch:75% 100%;
  font-display:swap;
}

:root{
  --font-heading:"SiteHeadings", "Montserrat", "Segoe UI", Arial, sans-serif;
  --font-body:"SiteText", "Open Sans", "Segoe UI", Arial, sans-serif;

  
  --bg:#F8FAFC;
  --text:#0B1220;
  --muted:#475569;

  
  --card:#ffffff;
  --surface: rgba(255,255,255,.78);
  --surface2:#E0F2FE;
  --line:#E2E8F0;

  
  --blue:#0284C7;
  --blue2:#0B1220;
  --blue-rgb: 2, 132, 199;
  --blue2-rgb: 11, 18, 32;

  
  --tile1:#E0F2FE;
  --tile2:#ECFEFF;
  --tile3:#F1F5F9;

  
  --shadow: 0 18px 48px rgba(2,6,23,.10);
  --shadow-sm: 0 10px 28px rgba(2,6,23,.08);

  
  --radius: 16px;
  --radius-sm: 12px;
}


.icon{
  display:inline-block;
  width:1em;
  height:1em;
  stroke:currentColor;
  fill:none;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
}



*{box-sizing:border-box}
html,


body{margin:0;padding:0}
html{scroll-behavior:smooth;font-size:clamp(15px, 0.35vw + 14px, 17px)}
body{
  font-family: var(--font-body);
  color:var(--text);
  background:var(--bg);
  font-size:1rem;
  line-height:1.55;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}


h1,h2,h3{
  font-family:var(--font-heading);
  letter-spacing: -.01em;
}
h1{font-weight:800}
h2{font-weight:750}
h3{font-weight:700}


h1{font-size:1.45rem; line-height:1.18}
h2{font-size:1.18rem; line-height:1.25}
h3{font-size:1.04rem; line-height:1.30}
a:focus-visible, button:focus-visible{outline:3px solid rgba(var(--blue-rgb), .35); outline-offset:2px}


html.nav-open{overflow:hidden}


html.nav-open 

.nav{
  background:#fff;
  backdrop-filter:none;
  -webkit-backdrop-filter:none;
}




@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *{transition:none !important; animation:none !important}
}


.progress{
  position:fixed;left:0;top:0;right:0;height:3px;
  background:transparent;z-index:100;
}
.progress__bar{
  height:100%;width:0%;
  background:linear-gradient(90deg, var(--blue), var(--blue2));
}


a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline; text-decoration-thickness:.08em; text-underline-offset:.18em}


.quickcard:hover,
.quickcard:focus-visible,
.callbar a:hover,
.callbar a:focus-visible,
.brand:hover,
.brand:focus-visible{
  text-decoration:none;
}


.wrap{max-width:1160px;margin:0 auto;padding:0 clamp(14px, 4vw, 20px)}
.section{padding:clamp(28px, 6vw, 46px) 0}

.section + .section{padding-top:clamp(28px, 6vw, 46px)}



.skip{
  position:absolute;left:-999px;top:auto;width:1px;height:1px;overflow:hidden
}
.skip:focus{left:18px;top:18px;width:auto;height:auto;background:#fff;border:1px solid var(--line);padding:10px;border-radius:10px;z-index:9999}


.breadcrumbs{
  margin:-6px 0 12px;
  font-size:0.72rem;
  color:var(--muted);
}
.breadcrumbs ol{
  list-style:none;
  padding:0;
  margin:0;
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  align-items:center;
}
.breadcrumbs li{display:flex;align-items:center;gap:6px}
.breadcrumbs li + li::before{content:"/";color:var(--muted);opacity:.7}
.breadcrumbs a{color:var(--muted);text-decoration:none}
.breadcrumbs a:hover{text-decoration:underline;color:var(--text)}
.breadcrumbs span[aria-current="page"]{color:var(--text);font-weight:750}

@media (max-width: 520px){
  .breadcrumbs{display:none}
}


.compare{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:12px}
.compare__card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:18px;
  box-shadow:none;
  padding:16px;
}
.compare__card h3{margin:0 0 6px;font-size:1rem}
.compare__card .muted{margin:0 0 10px}
.compare__card ul{margin:0;padding-left:18px;color:var(--muted)}
.compare__card li{margin:6px 0}

.compare__summary{
  list-style:none;
  cursor:pointer;
  padding:14px 16px;
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:10px;
  font-weight:800;
}
.compare__summary::-webkit-details-marker{display:none}
.compare__hint{font-weight:650;font-size:0.76rem;color:var(--muted)}
.compare__body{padding:0 16px 14px}
.compare__body p{margin:6px 0 0;color:var(--muted)}
.compare__body ul{margin:10px 0 0;padding-left:18px;color:var(--muted)}
.compare__body li{margin:6px 0}
.compare__card[open]{border-color:rgba(46,125,246,.35)}
.compare__card[open] .compare__summary{background:linear-gradient(180deg, rgba(46,125,246,.10), rgba(46,125,246,0))}
@media (max-width:980px){
  .compare{grid-template-columns:1fr}
}


.topbar{
  background: #0b1220;
  color:#e6edf7;
  font-size:0.82rem;
}
.topbar__inner{display:flex;gap:10px;align-items:center;justify-content:space-between;padding:10px 0;flex-wrap:wrap}
.topbar__left{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.topbar__right{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.pill{
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
  padding:4px 10px;border-radius:999px;
}
.toplink{color:#e6edf7;opacity:.95}
.toplink:hover{opacity:1;text-decoration:none}
.topbar__right{display:flex;gap:14px;align-items:center}

@media (min-width: 981px){
  .topbar__left{display:none}
}

@media (min-width: 981px){
  .topbar__left{display:none}
}

.nav{
  position:sticky;
  top:0;
  background: rgba(246,247,249,.85);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom:1px solid var(--line);
  
  z-index:1000;
}
.nav__inner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 0}
.brand{display:flex;align-items:center;gap:12px;color:inherit;text-decoration:none}
.brand__logo{height:40px;width:auto;max-width:190px;object-fit:contain}
.brand__text strong{display:block;font-size:1rem}
.brand__text span{display:block;font-size:0.82rem;color:var(--muted)}
.nav__links{display:flex;gap:18px;align-items:center}
.nav__links a{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 10px;
  border-radius:12px;
  color:var(--text);
  white-space:nowrap;
  word-break:keep-all;
  hyphens:none;
  transition: background .15s ease;
}
.nav__icon{display:none;width:18px;height:18px;color:var(--muted)}
.nav__links a:hover{background: rgba(2,6,23,.04); text-decoration:none}
.nav__links a.is-active{background: transparent}
.nav__toggle{display:none;background:transparent;border:0;cursor:pointer;padding:10px;border-radius:12px}
.nav__toggle span{display:block;width:24px;height:2px;background:var(--text);margin:5px 0;border-radius:2px}

.hero-wrap{
  background: rgba(255,255,255,.86);
  border:1px solid var(--line);
  border-radius: calc(var(--radius) + 6px);
  padding: clamp(16px, 4vw, 22px);
  box-shadow: var(--shadow-sm);
}


.hero{
  display:grid;
  grid-template-columns: 1.35fr .65fr;
  gap:18px;
  align-items:stretch;
  margin:0;
}
.hero__text h1{font-size:clamp(19px, 2.2vw + 12px, 28px);line-height:1.12;margin:0 0 10px}
.lead{font-size:1rem;color:var(--muted);margin:0 0 16px}
.hero__bullets{margin:0 0 16px;color:var(--muted);font-size:0.92rem}
.hero__bullets li{margin:6px 0}
.hero__cta{display:flex;gap:10px;flex-wrap:wrap}
.hero__media{
  margin-top:18px;
  border:1px solid var(--line);
  border-radius:18px;
  overflow:hidden;
  background: linear-gradient(180deg, rgba(255,255,255,.95), rgba(236,245,252,.92));
  box-shadow: var(--shadow-sm);
}
.hero__media img{
  display:block;
  width:100%;
  aspect-ratio:16 / 7;
  object-fit:cover;
  object-position:center;
}
.hero__media--panorama img{
  aspect-ratio:16 / 5;
}
.hero__card 

.card{height:100%}
.hero__card--desktop{display:block}

.hero + .content{margin-top:18px}
.hero-wrap + .content{margin-top:18px}

@media (max-width:1100px){
  .hero__card--desktop{display:none}
}

@media (max-width:920px){
  .hero-wrap{padding:18px}
}

.card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:clamp(16px, 3.4vw, 20px);
  box-shadow: var(--shadow-sm);
}

.card--soft{
  background: var(--surface);
  box-shadow: none;
}


.card--pc-check{
  background: linear-gradient(135deg, var(--blue2), rgba(var(--blue2-rgb), .92));
  border:1px solid rgba(255,255,255,.14);
  color:#fff;
}
.card--pc-check h2, .card--pc-check h3{color:#fff}
.card--pc-check .muted{color: rgba(255,255,255,.78)}
.card--pc-check a{color:#fff}
.card--pc-check .btn--ghost{
  background: rgba(255,255,255,.12);
  color:#fff;
  border-color: rgba(255,255,255,.34);
}
.card--pc-check .btn--ghost:hover{background: rgba(255,255,255,.16)}
.pc-check-teaser__cta{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.pc-check-teaser__seasons{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.pc-check-links{margin-top:18px}
.pc-check-links a{display:block;line-height:1.55}
.pc-check-links a[aria-current="page"]{font-weight:900;color:var(--blue2)}
.pc-check-band{
  background: var(--blue2);
  color:#fff;
  border-radius: var(--radius);
  padding:18px;
  display:flex;
  gap:14px;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
  margin:18px 0 10px;
  border:1px solid rgba(255,255,255,.12);
}
.pc-check-band__title{margin:0;font-size:1.05rem}
.pc-check-band__text{margin:0;opacity:.9}
.pc-check-band .btn--ghost{
  background: rgba(255,255,255,.12);
  color:#fff;
  border-color: rgba(255,255,255,.34);
}
.pc-check-band .btn--ghost:hover{background: rgba(255,255,255,.16)}

.daily-note{
  margin: 0 0 14px;
  border-left: 4px solid var(--blue);
  
  min-height: 112px;
  max-height: 112px;
}
.daily-note__meta{
  font-size: 0.76rem;
  color: var(--muted);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .04em;
  margin-bottom: 6px;
  line-height: 1.25;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.daily-note__text{
  margin: 0;
  font-size: 1rem;
  font-weight: 650;
  line-height: 1.25;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  max-height: calc(1.25em * 2);
}


@media (max-width:560px){
  .daily-note{min-height: 140px; max-height: 140px;}
  .daily-note__text{-webkit-line-clamp: 3; max-height: calc(1.25em * 3);}
}
.stack{display:grid;gap:14px;margin:12px 0}
.stack 

.btn{width:100%;justify-content:center;text-align:center;white-space:normal;line-height:1.25}
.small{font-size:0.82rem}
.hours__emergency{font-weight:700;text-decoration:none;white-space:nowrap}
.hours__emergency:hover,.hours__emergency:focus-visible{text-decoration:underline}
.muted{color:var(--muted)}

.btn{
  display:inline-flex;align-items:center;justify-content:center;
  gap:7px;
  padding:10px 16px;
  border-radius:9999px;
  background: var(--blue);
  color:#fff;
  border:1px solid rgba(var(--blue-rgb), .26);
  font-weight:800;
  font-size:0.84rem;
  line-height:1.15;
  text-decoration:none;
  box-shadow: 0 12px 30px rgba(var(--blue2-rgb), .10);
  transition-property: transform, box-shadow, background, border-color, color;
  transition-duration: .5s;
  transition-timing-function: ease;
  will-change: transform;
}
.btn:hover,
.btn:focus-visible{
  transform:scale(1.07);
  transition-timing-function:cubic-bezier(0.47,2.02,.31,-.36);
  text-decoration:none;
  box-shadow: 0 18px 40px rgba(var(--blue2-rgb), .14);
}
.btn:active{
  transform:scale(1.04);
  box-shadow: 0 10px 26px rgba(var(--blue2-rgb), .12);
}
.btn--ghost{
  background:#fff;
  color:var(--blue2);
  border:1px solid rgba(var(--blue-rgb), .35);
  box-shadow:none;
}
.btn--ghost:hover,
.btn--ghost:focus-visible{background:rgba(255,255,255,.86)}

.btn--small{padding:7px 12px;border-radius:9999px;font-size:0.82rem}
.btn--small:hover,
.btn--small:focus-visible{transform:scale(1.06)}
.btn--small:active{transform:scale(1.03)}

.btn--inline{margin-left:8px;vertical-align:middle}


.form{display:grid;gap:12px;margin-top:12px}
.form__row{display:grid;gap:6px}
.form__label{font-size:0.82rem;color:var(--muted);font-weight:700}
.form__input{
  width:100%;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid var(--line);
  background:#fff;
  color:var(--text);
  font-size:1rem;
}
.form__input:focus{outline:3px solid rgba(var(--blue-rgb), .22);border-color: rgba(var(--blue-rgb), .60)}
.form__hint{margin:6px 0 0}



.grid{
  display:grid;gap:14px;
  grid-template-columns: repeat(12, 1fr);
}
.col-4{grid-column: span 4}
.col-3{grid-column: span 3}
.col-5{grid-column: span 5}
.col-6{grid-column: span 6}
.col-7{grid-column: span 7}
.col-12{grid-column: span 12}
.kpi{
  padding:16px;border-radius:var(--radius);border:1px solid var(--line);background:#fff;
}
.kpi h3{margin:0 0 6px;font-size:1rem}
.kpi p{margin:0;color:var(--muted)}


.kpi__title,
.card__title{
  display:flex;
  align-items:center;
  gap:8px;
  margin:0 0 6px;
}
.kpi__title h3{margin:0}
.kpi__title .icon,
.card__title .icon{color:var(--blue)}

.list{
  margin:0;padding-left:18px
}
.list li{margin:6px 0}

.notice{
  background: var(--surface);
  border-bottom: 1px solid var(--line);
  padding: 10px 0;
  font-size: 0.88rem;
}
.notice__inner{display:flex;gap:8px;align-items:flex-start;flex-wrap:wrap}
.notice strong{font-weight:800}

.footer{
  margin-top:30px;
  background:#0b1220; 
  color:#ffffff;
  padding:28px 0 18px;
  font-size:0.84rem;
}
.footer strong{
  display:block;
  font-size:0.72rem;
  font-weight:800;
  letter-spacing:.01em;
  margin:0 0 8px;
}


.footer__title{
  display:flex;
  align-items:center;
  gap:8px;
}
.footer__title .icon{width:15px;height:15px;opacity:.95}
.footer__line{
  display:flex;
  align-items:flex-start;
  gap:8px;
  margin:6px 0;
}
.footer__line .icon{width:14px;height:14px;margin-top:2px;opacity:.9}
.footer__line a{display:inline-block}
.footer a{color:#ffffff; text-decoration:none; font-weight:600}
.footer a:hover{text-decoration:underline}
.footer .muted{color:rgba(255,255,255,.90)}
.footer .small{color:rgba(255,255,255,.88)}
.footer__grid{
  display:grid;gap:18px;
  grid-template-columns: repeat(12, 1fr);
}
.footer__grid > div:nth-child(1){grid-column: span 3}
.footer__grid > div:nth-child(2){grid-column: span 3}
.footer__grid > div:nth-child(3){grid-column: span 2}
.footer__grid > div:nth-child(4){grid-column: span 3}
.footer__grid > div:nth-child(5){grid-column: span 1}
.footer__bottom{padding-top:14px;border-top:1px solid rgba(255,255,255,.12);margin-top:18px}
.footer__hours{
  margin:0;
  font-size:.82rem;
  line-height:1.45;
  color:rgba(255,255,255,.90);
}
.footer__hours-note{
  color:rgba(255,255,255,.82);
}

.footer__regionlist{
  list-style:none;
  padding:0;
  margin:10px 0 0;
  display:grid;
  grid-template-columns: 1fr;
  gap:8px;
}
.footer__regionlist li{margin:0}
.footer__regionlist a{
  display:block;
  color:rgba(255,255,255,.92);
  font-size:12px;
  font-weight:650;
  text-decoration:none;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.footer__regionlist a:hover{text-decoration:underline}

@media (max-width: 560px){
  .footer__regionlist{grid-template-columns:1fr}
  

.quickgrid{grid-template-columns:1fr}
}

.hide-on-mobile{}



.callbar{
  transition: transform .22s ease, opacity .22s ease;
  transform: translateY(0);
  opacity: 1;
}
.callbar.is-hidden{
  transform: translateY(110%);
  opacity: 0;
  pointer-events: none;
}
.callbar.is-delayed{
  transform: translateY(110%);
  opacity: 0;
  pointer-events: none;
}
.callbar.is-compact a:nth-child(4){
  display:none;
}

.callbar{
  position:fixed;
  left:0;right:0;bottom:0;
  display:none;
  background:#fff;
  border-top:1px solid var(--line);
  box-shadow: 0 -10px 22px rgba(2,6,23,.08);
  z-index:60;
}
.callbar a{
  flex:1;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:7px;
  padding:11px 6px;
  color:var(--text);
  font-weight:700;
  font-size:13px;
  line-height:1.1;
}
.callbar a .icon{width:16px;height:16px}
.callbar a + a{border-left:1px solid var(--line)}

.content h2{margin-top:22px}
.content p{margin:0 0 10px}
.content .card{box-shadow:none}

.tablewrap{overflow:auto;-webkit-overflow-scrolling:touch}
.table{width:100%;border-collapse:collapse;margin-top:10px;font-size:0.94rem}
.table th,.table td{padding:10px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}
.table th{font-weight:800;background:var(--card)}
.table tr:last-child td{border-bottom:0}

.subhead{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;flex-wrap:wrap}
.subhead p{margin:4px 0 0;color:var(--muted);max-width:78ch}


.subhead .btn{white-space:nowrap}

@media (max-width:520px){
  .subhead .btn{width:100%;justify-content:center}
}



ul.quickgrid, ul.truststrip, ul.tiles, ul.grid{list-style:none;padding:0;margin:0}

.quickgrid{display:grid;grid-template-columns:repeat(auto-fit, minmax(200px, 1fr));gap:14px;margin-top:12px}
.quickgrid > li{margin:0;}
.quickcard{
  display:block;
  height:100%;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:16px;
  box-shadow:var(--shadow-sm);
  text-decoration:none;
  color:var(--text);
  position:relative;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
}
.quickcard:hover,
.quickcard:focus-visible{
  transform:translateY(-2px);
  box-shadow:var(--shadow);
  border-color: rgba(var(--blue-rgb), .28);
  background: linear-gradient(180deg, rgba(var(--blue-rgb), 0.06), #fff);
}
.quickcard__top{display:flex;align-items:center;gap:12px;margin:0 0 8px}
.quickcard__icon{width:22px;height:22px;flex:0 0 22px;color:var(--blue);transition: transform .18s ease, color .18s ease}
.quickcard:hover .quickcard__icon,
.quickcard:focus-visible .quickcard__icon{
  color: var(--blue2);
  transform: translateY(-1px);
}
.quickcard__top h3{margin:0;font-size:1rem;line-height:1.25;letter-spacing:-.01em}
.quickcard p{margin:0;font-size:0.86rem;line-height:1.45}

.truststrip{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:10px;
  margin-top:14px;
}
.truststrip__item{
  background:#fff;
  border:1px solid var(--line);
  border-radius:999px;
  padding:10px 12px;
  font-weight:800;
  font-size:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  box-shadow: 0 10px 22px rgba(2,6,23,.06);
}
.truststrip__item svg{width:18px;height:18px;color:var(--blue)}

.signal-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;margin:18px 0 0}
.signal-card{position:relative;display:flex;align-items:center;gap:18px;padding:18px;border:1px solid var(--line);border-radius:var(--radius);background:linear-gradient(180deg,#fff,rgba(224,242,254,.42));box-shadow:var(--shadow-sm);overflow:hidden}
.signal-card__visual{position:relative;flex:0 0 88px;width:88px;height:88px;display:grid;place-items:center}
.signal-card__text h3{margin:0 0 6px}
.signal-card__text p{margin:0;color:var(--muted)}
.signal-pulse-ring{position:absolute;inset:10px;border-radius:999px;border:2px solid rgba(var(--blue-rgb),.28);animation:signalPulse 2.8s ease-out infinite}
.signal-icon{width:64px;height:64px;stroke:var(--blue2);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.signal-icon--clock{animation:signalFloat 3.4s ease-in-out infinite}
.signal-icon--progress{transform:rotate(-90deg)}
.signal-track{stroke:rgba(var(--blue2-rgb),.12)}
.signal-progress{stroke:var(--blue);stroke-dasharray:138.2;stroke-dashoffset:138.2;animation:signalProgress 3.6s ease-in-out infinite}
.signal-percent{position:absolute;font-weight:800;font-size:1rem;color:var(--blue2);animation:signalGlow 3.6s ease-in-out infinite}
@keyframes signalPulse{0%{transform:scale(.9);opacity:.85}70%{transform:scale(1.16);opacity:0}100%{transform:scale(1.16);opacity:0}}
@keyframes signalProgress{0%,12%{stroke-dashoffset:138.2}48%,100%{stroke-dashoffset:0}}
@keyframes signalGlow{0%,12%{transform:scale(.92);opacity:.72}48%,100%{transform:scale(1);opacity:1}}
@keyframes signalFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-2px)}}

.helper{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow: var(--shadow);
  padding:18px;
}
.helper__grid{list-style:none;padding:0;margin:12px 0 0;display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.helper__item{margin:0}
.helper__btn{
  width:100%;
  text-align:left;
  border:1px solid var(--line);
  background:var(--card);
  border-radius:var(--radius);
  padding:14px;
  cursor:pointer;
  font-weight:800;
}
.helper__btn small{display:block;color:var(--muted);font-weight:600;margin-top:4px}
.helper__btn.is-selected{border-color: rgba(var(--blue-rgb), .45); box-shadow: 0 14px 34px rgba(var(--blue-rgb), .12)}
.helper__result{margin-top:14px;border-top:1px solid var(--line);padding-top:14px}
.helper__result h3{margin:0 0 6px;font-size:1rem}
.helper__result p{margin:0 0 10px;color:var(--muted)}



.bars{display:grid;gap:10px;margin-top:12px}
.bars + p{margin-top:16px}
.barrow{display:grid;gap:6px}
.barrow__top{display:flex;justify-content:space-between;gap:10px;font-weight:800}
.bartrack{height:12px;background: #e9eef6;border:1px solid #64748b;border-radius:999px;overflow:hidden}
.barfill{height:100%;background:linear-gradient(90deg, var(--blue), var(--blue2));width:0%}

.scrolltop{
  position:fixed;
  right:16px;
  bottom:140px;
  z-index:65;
  border:1px solid var(--line);
  background:#fff;
  color:var(--text);
  border-radius:999px;
  padding:10px 12px;
  font-weight:900;
  box-shadow: 0 16px 38px rgba(2,6,23,.14);
  cursor:pointer;
}
.scrolltop:hover{filter:brightness(.98)}


.tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:14px}

.training-teaser{margin-top:16px;padding:16px}
.training-teaser h3{margin:0 0 6px;font-size:1rem;line-height:1.25}
.training-teaser p{margin:0 0 10px}
.training-teaser .list{margin:10px 0}
.training-teaser .btn{margin-top:4px}
.tile{border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-sm);background:#fff}
.tile{transition:transform .18s ease, box-shadow .18s ease}
.tile:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.tile__top{min-height:150px;padding:18px;position:relative;display:flex;align-items:flex-end}
.tile__top h3{margin:0;font-size:1.06rem;line-height:1.2;letter-spacing:-.01em;max-width:22ch}
.tile__icon{position:absolute;right:16px;top:16px;width:42px;height:42px;color:rgba(255,255,255,.92)}
.tile__icon--muted{color:rgba(var(--blue-rgb), .24)}
.tile__body{padding:14px 18px 18px;background:#fff}
.tile__body p{margin:0;color:#111827}
.tile--1 .tile__top{background:var(--tile1)}
.tile--2 .tile__top{background:var(--tile2)}
.tile--3 .tile__top{background:var(--tile3)}


.calc-tiles{margin-top:12px}
.calc-tile{appearance:none;-webkit-appearance:none;text-align:left;width:100%;padding:0;background:transparent;cursor:pointer}
.calc-tile:focus{outline:2px solid rgba(var(--blue-rgb), .35);outline-offset:2px}
.calc-tile[aria-pressed="true"]{box-shadow:0 0 0 3px rgba(var(--blue-rgb), .18), var(--shadow)}
.calc-step{margin-top:16px}
.calc-panel{margin-top:8px}
.calc-result{border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;background:#fff}
.calc-sum{font-size:1.35rem;font-weight:800;letter-spacing:-.01em}
.calc-lines{margin-top:8px}
.calc-lines .line{display:flex;justify-content:space-between;gap:12px;padding:6px 0;border-bottom:1px dashed rgba(17,24,39,.12)}
.calc-lines .line:last-child{border-bottom:none}
.calc-hints{margin-top:10px}
.calc-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}
.calc-suggest{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}
.calc-suggest .btn{margin:0}



.reveal{
  opacity:0;
  transform: translate3d(0, 16px, 0) scale(.985);
  transition-property: opacity, transform;
  transition-duration: .62s;
  transition-timing-function: cubic-bezier(.2,.8,.2,1);
  transition-delay: var(--reveal-delay, 0ms);
  will-change: transform, opacity;
}

.reveal--up{transform: translate3d(0, 18px, 0) scale(.985)}
.reveal--left{transform: translate3d(-18px, 0, 0) scale(.985)}
.reveal--right{transform: translate3d(18px, 0, 0) scale(.985)}
.reveal--zoom{transform: translate3d(0, 12px, 0) scale(.96)}

.reveal.is-visible{
  opacity:1;
  transform: translate3d(0, 0, 0) scale(1);
}


.faq{display:grid;grid-template-columns:1fr;gap:14px;margin-top:12px}
.faq--single{grid-template-columns:1fr !important}
.faq details{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:14px;box-shadow: var(--shadow)}
.faq summary{cursor:pointer;font-weight:500;font-size:0.78rem;line-height:1.35;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq details p{margin:10px 0 0;color:var(--muted);font-size:0.9rem;line-height:1.55}

.float-contact{position:fixed;right:16px;bottom:86px;z-index:55;background:#e11d48;color:#fff;border-radius:999px;padding:12px 14px;font-weight:800;box-shadow:0 16px 38px rgba(2,6,23,.18);text-decoration:none;display:none;align-items:center;gap:8px;min-width:172px;justify-content:center;white-space:nowrap}
.float-contact .icon{width:16px;height:16px}
.float-contact:hover{filter:brightness(.95);text-decoration:none}

.float-contact--remote{bottom:36px;background:var(--blue)}
.float-contact--remote:hover{filter:brightness(.95);text-decoration:none}

.toast{
  position:fixed;left:50%;bottom:76px;transform:translateX(-50%);
  background:#111827;color:#fff;
  padding:10px 14px;border-radius:999px;
  box-shadow:0 18px 44px rgba(2,6,23,.22);
  font-weight:700;font-size:14px;
  z-index:80;
}

@media (min-width: 821px){
  .toast{bottom:24px}
}

@media (max-width: 920px){
  .hero{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:1fr}
  .footer__grid > div{grid-column: auto}
}

@media (max-width: 980px){
  .quickgrid{grid-template-columns:1fr 1fr}
  .tiles{grid-template-columns:1fr}
  .faq{grid-template-columns:1fr}
  .truststrip{grid-template-columns:1fr 1fr}
  .signal-grid{grid-template-columns:1fr}
  .helper__grid{grid-template-columns:1fr}
}

@media (min-width: 981px){
  .float-contact{display:inline-flex}
}

@media (max-width: 980px){
  
  .topbar{
    display:block;
    background:#fff;
    color:var(--text);
    border-bottom:1px solid var(--line);
  }
  .topbar__inner{padding:8px 0}
  .topbar__left{display:none}
  .topbar__right{width:100%;justify-content:space-between;gap:8px}
  .toplink--wa{display:none}
  .toplink{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:8px;
    padding:8px 10px;
    border-radius:999px;
    border:1px solid var(--line);
    background: rgba(2,6,23,.04);
    color:var(--text);
    text-decoration:none;
    flex:1;
  }
  .toplink--wa{display:none}
  .col-3,.col-4,.col-5,.col-6,.col-7{grid-column: span 12}
  .hero__cta{flex-direction:column}
  .hero__cta .btn{width:100%;justify-content:center}
  .hero__media{margin-top:14px;border-radius:16px}
  .hero__media img{aspect-ratio:16 / 9}
  .hero__media--panorama img{aspect-ratio:16 / 7}
  
  .hero__card--desktop{display:none}
  
  .hero__cta .btn--ghost{display:none}

  .nav__toggle{display:inline-block}
  .nav__links{
    position:fixed;left:0;right:0;top:var(--nav-offset, 64px);bottom:0;
    background:#fff;
    border-top:1px solid var(--line);
    display:none;flex-direction:column;align-items:stretch;
    padding:14px 18px;
    overflow:auto;
    
    z-index:1200;
    pointer-events:auto;
  }
  .nav__links.is-open{display:flex}
  .nav__links a, .nav__links button{width:100%}
  .nav__icon{display:inline-block}
  .nav__links a{gap:10px;padding:10px 12px;}
  .nav__links a:hover .nav__icon{color:var(--blue)}

  
  html.nav-open .callbar{display:none !important;}
  .callbar{display:flex}
  body{padding-bottom:calc(52px + env(safe-area-inset-bottom))}

  .hide-on-mobile{display:none !important;}
}

@media (max-width: 820px){
  .topbar__right{gap:6px}
  .toplink{font-size:0.82rem}
}

@media (max-width: 480px){
  .wrap{padding:0 14px}
  .lead{font-size:0.94rem}
  .pill{display:inline-flex;max-width:100%}
  .topbar{font-size:0.82rem}
  .btn{width:100%;justify-content:center}
  .float-contact{display:none}
}


.wa-dialog{
  border:0;
  padding:0;
  border-radius: var(--radius);
  width:min(560px, calc(100% - 28px));
  box-shadow: var(--shadow);
}
.wa-dialog::backdrop{
  background: rgba(2,6,23,.55);
}
.wa-dialog__card{
  margin:0;
  padding:18px;
  background:#fff;
  border-radius: var(--radius);
  border:1px solid var(--line);
}
.wa-dialog__card h2{
  margin:0 0 10px;
  font-size:1rem;
}
.wa-dialog__actions{
  display:flex;
  gap:10px;
  justify-content:flex-end;
  flex-wrap:wrap;
  margin-top:12px;
}
.wa-dialog__check{
  display:flex;
  gap:10px;
  align-items:center;
  margin-top:10px;
}
.wa-dialog__check input{transform: translateY(1px)}

@media (min-width:981px){
  .topbar__left{display:none}
}




.contact-profile{
  display:flex;
  align-items:center;
  gap:14px;
  margin: 0 0 14px;
}
.contact-profile .avatar{
  width:140px;
  height:140px;
  border-radius:9999px;
  object-fit:cover;
  border:1px solid var(--line);
  box-shadow: var(--shadow-sm);
}


.contact-profile--address{
  flex-direction:column;
  align-items:flex-start;
  gap:8px;
}
.contact-profile--address .avatar{
  width:96px;
  height:96px;
}
.contact-profile figcaption{
  margin:0;
}
@media (max-width: 640px){
  .contact-profile{
    justify-content:center;
    text-align:center;
    flex-direction:column;
  }
}



:root{
  
  --tap: 44px;
}


*[id]{scroll-margin-top: 92px;}


@media (pointer: coarse){
  .btn,
  .toplink,
  .nav__links a,
  .callbar a{
    min-height: var(--tap);
    touch-action: manipulation;
  }

  
  .btn:active,
  .toplink:active,
  .nav__links a:active,
  .callbar a:active{
    transform: translateY(1px);
  }
}


.callbar{
  padding-bottom: env(safe-area-inset-bottom);
}


/* Startseite: ruhiger, aufgeräumter, stärkere Signal-Karten */
.home-page .content{
  display:grid;
  gap:18px;
}
.home-page .content > .section{margin:4px 0 0}
.home-page .subhead,
.home-page .card,
.home-page .helper,
.home-page .kpi,
.home-page .quickcard,
.home-page .tile,
.home-page .truststrip__item{
  box-shadow:0 10px 24px rgba(15,23,42,.05);
}
.home-page .subhead{
  align-items:center;
  padding:4px 2px 0;
}
.home-page .quickgrid{
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
  align-items:stretch;
}
.home-page .quickcard,
.home-page .tile,
.home-page .helper,
.home-page .card,
.home-page .kpi{
  background:#fff;
}
.home-page .card--pc-check{
  background: linear-gradient(135deg, var(--blue2), rgba(var(--blue2-rgb), .92));
}
.home-page .quickcard:hover,
.home-page .quickcard:focus-visible{
  transform:none;
  box-shadow:0 10px 24px rgba(15,23,42,.07);
  border-color:rgba(var(--blue-rgb), .18);
  background:#fff;
}
.home-page .truststrip{margin-top:4px}
.home-page .truststrip__item{
  background:linear-gradient(180deg,#fff,rgba(248,250,252,.96));
}
.signal-grid--hero{
  margin:4px 0 0;
}
.signal-grid--hero .signal-card{
  min-height:156px;
  padding:24px 26px;
  gap:22px;
  background:linear-gradient(180deg,#fff,rgba(241,245,249,.9));
  box-shadow:0 16px 34px rgba(15,23,42,.07);
}
.signal-grid--hero .signal-card__visual{
  flex:0 0 108px;
  width:108px;
  height:108px;
}
.signal-grid--hero .signal-icon{width:76px;height:76px}
.signal-grid--hero .signal-card__text h2{
  margin:0 0 8px;
  font-size:clamp(1.22rem, 1vw + 1rem, 1.55rem);
  line-height:1.15;
}
.signal-grid--hero .signal-card__text p{
  font-size:1.02rem;
  line-height:1.6;
}
.signal-grid--hero .signal-percent{font-size:1.18rem}
.home-inline-card{
  display:flex;
  justify-content:center;
}
.home-inline-card .card{
  margin:0;
  width:min(100%, 840px);
}
@media (max-width:1100px){
  .home-page .quickgrid{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media (max-width:900px){
  .signal-grid--hero .signal-card{
    min-height:unset;
    padding:22px;
  }
}
@media (max-width:720px){
  .home-page .content{gap:16px}
  .home-page .quickgrid{grid-template-columns:1fr;}
  .signal-grid--hero{
    grid-template-columns:1fr;
  }
  .signal-grid--hero .signal-card__visual{
    flex:0 0 92px;
    width:92px;
    height:92px;
  }
  .signal-grid--hero .signal-icon{width:68px;height:68px}
}

.svg-sprite{position:absolute;width:0;height:0;overflow:hidden}
.u-mt-8{margin-top:8px}
.u-mt-10{margin-top:10px}
.u-mt-12{margin-top:12px}
.u-mt-14{margin-top:14px}
.u-mt-28{margin-top:28px}
.u-mb-12{margin-bottom:12px}
.u-m-0{margin:0}
.u-m-y-12-14{margin:12px 0 14px}
.u-stack-075{margin-top:.75rem;gap:.75rem}
.u-stack-075 > * + *{margin-top:0}
.u-stack-075-plain{margin-top:.75rem}
.u-mt-06{margin-top:.6rem}
.u-small-top{margin:.35rem 0 0 0}
.u-text-right{text-align:right}
.u-font-800{font-weight:800}
.u-word-break{word-break:break-word}
.u-score{font-size:1.7rem;font-weight:900;line-height:1}
.u-no-pointer{pointer-events:none}
.seo-check--danger{border-color:#fecaca;background:#fff5f5}
.seo-check--warn{border-color:#fde68a;background:#fffbeb}
.seo-check-grid-top{align-items:start}

.sep{margin:18px 0;border:0;border-top:1px solid var(--line)}

/* Trainingsportal */
body.portal-page .portal-wrap{
  padding-top: 26px;
  padding-bottom: 34px;
}
body.portal-page #content{
  background: linear-gradient(180deg, rgba(248,250,252,.96), rgba(255,255,255,.98));
}
body.portal-page .hero{
  margin-bottom: 18px;
}
body.portal-page .h-title{
  margin:0 0 10px;
  font-size: clamp(1.9rem, 3.4vw, 2.8rem);
  line-height:1.08;
  letter-spacing:-0.02em;
  color:var(--blue2);
}
body.portal-page .h-sub{
  max-width: 74ch;
  color:var(--muted);
  margin:0 0 16px;
}
body.portal-page .badges{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
body.portal-page .badge{
  display:inline-flex;
  align-items:center;
  padding:8px 12px;
  border:1px solid var(--line);
  border-radius:999px;
  background:#fff;
  color:var(--blue2);
  font-size:.85rem;
  font-weight:700;
}
body.portal-page .grid{
  display:grid;
  gap:14px;
  grid-template-columns: repeat(12, 1fr);
  margin: 18px 0 28px;
}
body.portal-page .card{
  grid-column: span 12;
  padding:18px;
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:#fff;
  box-shadow: var(--shadow-sm);
}
@media (min-width: 860px){
  body.portal-page .card--4{grid-column: span 4;}
  body.portal-page .card--6{grid-column: span 6;}
}
body.portal-page .card__title{
  margin:0 0 8px;
  color:var(--blue2);
}
body.portal-page .card__text{
  margin:0 0 12px;
  color:var(--muted);
}
body.portal-page .card__actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:flex-start;
}
body.portal-page form.card__actions{
  display:grid;
  gap:14px;
}
body.portal-page .card__actions .btn,
body.portal-page .card__actions > a.btn,
body.portal-page .card__actions > button.btn{
  width:auto;
  min-width:unset;
  flex:0 0 auto;
}
body.portal-page .btn svg,
body.portal-page button svg,
body.portal-page a.btn svg{
  width:18px;
  height:18px;
  flex:0 0 18px;
  display:block;
}
body.portal-page .icon-inline{
  width:18px;
  height:18px;
  vertical-align:-3px;
  margin-right:8px;
}
body.portal-page .small{
  color:var(--muted);
}
body.portal-page .notice{
  margin: 12px 0;
  padding: 12px 14px;
  border-radius: 14px;
  border-left:4px solid var(--blue);
  background: rgba(var(--blue-rgb), .08);
}
body.portal-page .notice.good{
  border-left-color:#16a34a;
  background: rgba(22,163,74,.10);
}
body.portal-page .notice.bad{
  border-left-color:#e11d48;
  background: rgba(225,29,72,.08);
}
body.portal-page .infobox{
  border:1px solid var(--line);
  border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(224,242,254,.28), #fff);
  padding:14px 16px;
}
body.portal-page .infobox__title{
  display:flex;
  align-items:center;
  gap:10px;
  margin:0 0 6px;
  font-weight:800;
  color:var(--blue2);
}
body.portal-page .infobox__icon{
  width:18px;
  height:18px;
  flex:0 0 18px;
}
body.portal-page .infobox__text{
  margin:0;
  color:var(--muted);
}
body.portal-page .kpi{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  color:var(--muted);
  font-size:.92rem;
}
body.portal-page .kpi b{color:var(--blue2);}
body.portal-page .progress{
  height:10px;
  overflow:hidden;
}
body.portal-page .progress > div,
body.portal-page .barfill{
  background: linear-gradient(90deg, var(--blue), var(--blue2));
}
body.portal-page .q-title{
  margin:0 0 12px;
  font-size:1.4rem;
  color:var(--blue2);
}
body.portal-page .choice{
  display:flex;
  gap:10px;
  align-items:flex-start;
  padding:12px 14px;
  border:1px solid var(--line);
  border-radius:14px;
  background:#fff;
  margin:10px 0;
}
body.portal-page input[type="text"],
body.portal-page input[type="search"],
body.portal-page input[type="email"],
body.portal-page input[type="url"],
body.portal-page input[type="number"],
body.portal-page textarea,
body.portal-page select,
body.portal-page input:not([type]){
  width:100%;
  max-width:420px;
  padding:11px 12px;
  border-radius:14px;
  border:1px solid var(--line);
  background:#fff;
  color:var(--text);
}
body.portal-page label.small{
  display:flex;
  gap:10px;
  align-items:flex-start;
}
body.portal-page .hero + .card,
body.portal-page .grid + .card{
  margin-top: 4px;
}
@media (max-width: 700px){
  body.portal-page .portal-wrap{padding-top:18px;}
  body.portal-page .card{padding:16px;}
  body.portal-page form.card__actions > div:last-child{
    display:grid !important;
    width:100%;
  }
  body.portal-page form.card__actions > div:last-child .btn,
  body.portal-page .card__actions .btn{
    width:100%;
    justify-content:center;
  }
}


/* Update: geringerer Abstand am Desktop, keine schwebenden Buttons auf Mobilgeräten */
.float-contact{right:16px}
.float-contact--remote{bottom:26px}
@media (min-width:981px){.float-contact{bottom:88px}.float-contact--remote{bottom:26px}}
@media (max-width:980px){.float-contact{display:inline-flex;bottom:96px}.float-contact--remote{bottom:34px}}
@media (max-width:768px){.float-contact,.float-contact--remote{display:none}}
