/* M3 Frontend — shared page styles */

/* ---- Markantes Logo (zentriert, scrollt weg; kompaktes Logo in der App Bar) ---- */
.fe-brand-header {
  display: flex;
  justify-content: center;
  padding: 12px 16px 20px;
  border-bottom: 1px solid var(--md-sys-color-outline-variant);
  background: linear-gradient(
    180deg,
    var(--md-sys-color-surface-container-low) 0%,
    var(--md-sys-color-surface) 100%
  );
}
.fe-brand-header__link {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: inherit;
  -webkit-tap-highlight-color: transparent;
}
.fe-brand-header__logo {
  width: 80px;
  height: 80px;
  border-radius: 14px;
  object-fit: contain;
  box-shadow: var(--md-sys-elevation-level1);
}
.fe-brand-header__name {
  font: 700 15px/1.25 var(--md-ref-typeface-brand);
  letter-spacing: -0.01em;
  text-align: center;
  color: var(--md-sys-color-on-surface);
  max-width: min(280px, 90vw);
}
.m3-top-app-bar--fe {
  position: sticky;
  top: 0;
  z-index: 30;
}
.m3-top-app-bar--fe .m3-top-app-bar__title {
  transition: opacity var(--md-sys-motion-duration-short4) var(--md-sys-motion-easing-standard);
}
.m3-top-app-bar--fe .m3-top-app-bar__center-logo {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition:
    opacity var(--md-sys-motion-duration-short4) var(--md-sys-motion-easing-standard),
    visibility 0s var(--md-sys-motion-duration-short4);
}
.m3-top-app-bar--fe .m3-top-app-bar__center-logo img {
  display: block;
  width: 36px;
  height: 36px;
  border-radius: 8px;
  object-fit: contain;
}
.m3-top-app-bar--fe.is-brand-compact .m3-top-app-bar__center-logo {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transition-delay: 0s;
}
.m3-top-app-bar--fe.is-brand-compact .m3-top-app-bar__title {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

/* ---- Start / sections ---- */
.hero { background: var(--md-sys-color-primary); color: var(--md-sys-color-on-primary); padding: 24px 16px 32px; position: relative; overflow: hidden;
  border-bottom-left-radius: var(--md-sys-shape-corner-extra-large); border-bottom-right-radius: var(--md-sys-shape-corner-extra-large); }
.hero::before, .hero::after { content: ""; position: absolute; border-radius: 50%; pointer-events: none; }
.hero::before { width: 320px; height: 320px; top: -120px; right: -120px; background: radial-gradient(circle, rgba(255,255,255,.10), transparent 70%); }
.hero::after  { width: 240px; height: 240px; bottom: -80px; left: -80px; background: radial-gradient(circle, rgba(182,255,58,.18), transparent 70%); }
.hero__eyebrow { display: inline-flex; align-items: center; gap: 8px; height: 32px; padding: 0 12px; border-radius: var(--md-sys-shape-corner-small); background: rgba(255,255,255,.12); color: var(--md-sys-color-tertiary-container); font: 500 12px/1 var(--md-ref-typeface-plain); letter-spacing: 0.08em; text-transform: uppercase; }
.hero__eyebrow .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--md-sys-color-tertiary-container); animation: fe-pulse 2s ease-in-out infinite; }
@keyframes fe-pulse { 0%,100% { box-shadow: 0 0 0 4px rgba(209,238,146,.18); } 50% { box-shadow: 0 0 0 8px rgba(209,238,146,.08); } }
.hero h1 { font: 700 clamp(2.4rem, 10vw, 3rem)/1 var(--md-ref-typeface-brand); letter-spacing: -0.02em; margin: 20px 0 16px; }
.hero h1 em { font-style: normal; background: linear-gradient(180deg, transparent 60%, rgba(209,238,146,.35) 60%); padding: 0 2px; }
.hero__lead { font: 400 16px/24px var(--md-ref-typeface-plain); letter-spacing: 0.5px; color: rgba(255,255,255,.78); margin: 0 0 24px; }
.hero__actions { display: flex; gap: 8px; flex-wrap: wrap; }
.hero__sig { display: flex; align-items: center; gap: 12px; margin-top: 28px; padding-top: 20px; border-top: 1px solid rgba(255,255,255,.14); font-size: 13px; color: rgba(255,255,255,.7); }
.hero__sig__avatar { width: 40px; height: 40px; border-radius: 50%; background: var(--md-sys-color-tertiary-container); color: var(--md-sys-color-on-tertiary-container); display: grid; place-items: center; font: 700 16px/1 var(--md-ref-typeface-brand); }
.hero__sig strong { color: #fff; font-weight: 600; }

.live-strip { display: flex; gap: 12px; overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: none; padding: 16px 16px 4px; margin: -20px 0 0; position: relative; z-index: 2; scroll-snap-type: x mandatory; }
.live-strip::-webkit-scrollbar { display: none; }
.live-card { flex: 0 0 144px; background: var(--md-sys-color-surface-container-low); color: var(--md-sys-color-on-surface); border-radius: var(--md-sys-shape-corner-medium); padding: 14px; box-shadow: var(--md-sys-elevation-level1); scroll-snap-align: start; display: flex; flex-direction: column; gap: 4px; }
.live-card--accent { background: var(--md-sys-color-tertiary-container); color: var(--md-sys-color-on-tertiary-container); }
.live-card__label { font: 500 11px/1 var(--md-ref-typeface-plain); letter-spacing: 0.5px; text-transform: uppercase; opacity: .7; }
.live-card__value { font: 700 28px/1 var(--md-ref-typeface-brand); letter-spacing: -0.02em; margin-top: 6px; }
.live-card__sub { font: 400 12px/16px var(--md-ref-typeface-mono); opacity: .7; }
.live-card__unit { font-size: 14px; opacity: .6; }
.live-card--link { text-decoration: none; color: inherit; transition: transform .15s ease; }
.live-card--link:active { transform: scale(.98); }
.fe-hero-outline-btn { color: #fff !important; border-color: rgba(255,255,255,.4) !important; }
.fe-section-head-row { display: flex; align-items: end; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
.fe-pkg-eyebrow { color: var(--md-sys-color-on-primary-container); opacity: .7; }
.fe-pkg-btn { background: var(--md-sys-color-primary); }
.blog-card__hero img, .blog-card__hero-img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* ---- Weather widget ---- */
.fe-widget-section { padding-top: 8px; }
.fe-widget-host { padding: 0 16px; }
.fe-widget { background: var(--md-sys-color-surface-container-low); border-radius: var(--md-sys-shape-corner-extra-large); padding: 20px; box-shadow: var(--md-sys-elevation-level1); }
.fe-widget--loading { text-align: center; color: var(--md-sys-color-on-surface-variant); padding: 32px 16px; }
.fe-widget__head { margin-bottom: 16px; }
.fe-widget__head h2 { font: 700 22px/1.2 var(--md-ref-typeface-brand); margin: 0 0 4px; }
.fe-widget__head p { margin: 0; font-size: 13px; color: var(--md-sys-color-on-surface-variant); }
.fe-widget__body { display: grid; gap: 16px; }
.fe-widget__main { display: grid; grid-template-columns: minmax(100px, 140px) 1fr; gap: 16px; align-items: center; }
.fe-widget__icon { width: 100%; max-width: 140px; height: auto; }
.fe-widget__summary h3 { font: 700 18px/1.2 var(--md-ref-typeface-brand); margin: 0 0 8px; }
.fe-widget__temp { font: 700 40px/1 var(--md-ref-typeface-brand); margin: 0 0 4px; color: var(--md-sys-color-primary); }
.fe-widget__cond { margin: 0; font-size: 14px; color: var(--md-sys-color-on-surface-variant); }
.fe-widget__metrics { display: grid; gap: 10px; grid-template-columns: 1fr; }
.fe-widget__metric { display: flex; justify-content: space-between; align-items: center; padding: 12px 14px; background: var(--md-sys-color-surface); border-radius: var(--md-sys-shape-corner-medium); font-size: 14px; }
.fe-widget__metric-label { color: var(--md-sys-color-on-surface-variant); }
.fe-widget__metric-value { font-weight: 700; font-family: var(--md-ref-typeface-brand); }

/* ---- Welcome ---- */
.fe-welcome { display: grid; gap: 20px; padding: 0 16px; align-items: start; }
.fe-welcome__photo { width: 100%; height: auto; object-fit: cover; border-radius: var(--md-sys-shape-corner-large); aspect-ratio: 4/3; }
.fe-welcome__text h2 { font: 700 24px/1.2 var(--md-ref-typeface-brand); margin: 0 0 12px; }
.fe-welcome__text p { margin: 0; font: 400 15px/1.55 var(--md-ref-typeface-plain); color: var(--md-sys-color-on-surface-variant); }

/* ---- Info card ---- */
.fe-info-card { margin: 0 16px; padding: 24px 20px; background: var(--md-sys-color-surface-container-low); border-radius: var(--md-sys-shape-corner-extra-large); box-shadow: var(--md-sys-elevation-level1); }
.fe-info-card h2 { font: 700 22px/1.25 var(--md-ref-typeface-brand); margin: 0 0 16px; }
.fe-info-list { margin: 0 0 16px; padding-left: 1.2em; font: 400 15px/1.55 var(--md-ref-typeface-plain); color: var(--md-sys-color-on-surface); }
.fe-info-list li { margin: 6px 0; }
.fe-info-foot { margin: 0; font-size: 14px; color: var(--md-sys-color-on-surface-variant); line-height: 1.5; }

/* ---- Webcams ---- */
.fe-webcam-grid { display: grid; gap: 12px; padding: 0 16px; grid-template-columns: 1fr; }
.fe-webcam-card { background: var(--md-sys-color-surface-container-low); border-radius: var(--md-sys-shape-corner-large); overflow: hidden; box-shadow: var(--md-sys-elevation-level1); }
.fe-webcam-card__head { padding: 14px 16px 8px; }
.fe-webcam-card__head h3 { font: 700 16px/1.3 var(--md-ref-typeface-brand); margin: 0 0 4px; }
.fe-webcam-card__head p { margin: 0; font-size: 13px; color: var(--md-sys-color-on-surface-variant); }
.fe-webcam-thumb { width: 100%; display: block; aspect-ratio: 16/10; object-fit: cover; cursor: zoom-in; transition: transform .2s ease; }
.fe-webcam-thumb:hover { transform: scale(1.01); }
.fe-webcam-overlay { position: fixed; inset: 0; z-index: 3000; background: rgba(0,0,0,.88); display: grid; place-items: center; padding: 16px; }
.fe-webcam-overlay[hidden] { display: none !important; }
.fe-webcam-full { max-width: min(92vw, 1200px); max-height: 85vh; border-radius: var(--md-sys-shape-corner-medium); box-shadow: var(--md-sys-elevation-level3); cursor: zoom-out; }

.section { padding: 32px 0; }
.section__head { padding: 0 16px; margin-bottom: 16px; }
.section__eyebrow { font: 500 11px/1 var(--md-ref-typeface-plain); letter-spacing: 0.1em; text-transform: uppercase; color: var(--md-sys-color-primary); margin-bottom: 8px; }
.section h2 { font: 700 28px/36px var(--md-ref-typeface-brand); letter-spacing: -0.01em; color: var(--md-sys-color-on-surface); margin: 0; }
.section__sub { margin-top: 8px; color: var(--md-sys-color-on-surface-variant); }

.why-grid { display: grid; grid-template-columns: 1fr; gap: 12px; padding: 0 16px; }
.why-card { background: var(--md-sys-color-surface-container-low); border-radius: var(--md-sys-shape-corner-large); padding: 20px; }
.why-card--tertiary { background: var(--md-sys-color-tertiary-container); color: var(--md-sys-color-on-tertiary-container); }
.why-card--secondary { background: var(--md-sys-color-secondary-container); color: var(--md-sys-color-on-secondary-container); }
.why-card__icon { width: 56px; height: 56px; border-radius: var(--md-sys-shape-corner-large); background: var(--md-sys-color-primary); color: var(--md-sys-color-on-primary); display: grid; place-items: center; margin-bottom: 16px; }
.why-card--tertiary .why-card__icon { background: var(--md-sys-color-tertiary); color: var(--md-sys-color-on-tertiary); }
.why-card--secondary .why-card__icon { background: var(--md-sys-color-secondary); color: var(--md-sys-color-on-secondary); }
.why-card__icon .material-symbols-outlined { font-size: 28px; font-variation-settings: 'FILL' 1, 'wght' 500, 'GRAD' 0, 'opsz' 28; }
.why-card h3 { font: 700 22px/28px var(--md-ref-typeface-brand); letter-spacing: -0.01em; margin: 0 0 8px; }
.why-card p { font: 400 14px/20px var(--md-ref-typeface-plain); letter-spacing: 0.25px; margin: 0; opacity: .88; }

.blog-list { display: flex; flex-direction: column; gap: 12px; padding: 0 16px; }
.blog-card { background: var(--md-sys-color-surface-container-low); border-radius: var(--md-sys-shape-corner-large); overflow: hidden; display: block; color: inherit; text-decoration: none; }
.blog-card__hero { aspect-ratio: 16/9; background: radial-gradient(circle at 30% 30%, rgba(255,201,58,.4), transparent 50%), radial-gradient(circle at 70% 70%, rgba(186,26,26,.35), transparent 50%), linear-gradient(135deg, #1A3A5E, #0A1626); }
.blog-card__hero img { width: 100%; height: 100%; object-fit: cover; display: block; }
.blog-card__date { font: 500 12px/1 var(--md-ref-typeface-mono); color: var(--md-sys-color-on-surface-variant); margin-bottom: 8px; }
.blog-card__body { padding: 16px 20px 20px; }
.blog-card__body h3 { font: 700 20px/24px var(--md-ref-typeface-brand); letter-spacing: -0.01em; margin: 0 0 8px; }
.blog-card__body p { font: 400 14px/20px var(--md-ref-typeface-plain); color: var(--md-sys-color-on-surface-variant); margin: 0; }
.blog-card--featured { background: var(--md-sys-color-primary); color: var(--md-sys-color-on-primary); }
.blog-card--featured .blog-card__date { color: var(--md-sys-color-tertiary-container); }
.blog-card--featured .blog-card__body p { color: rgba(255,255,255,.78); }

.pkg-cta { margin: 0 16px; background: var(--md-sys-color-primary-container); color: var(--md-sys-color-on-primary-container); border-radius: var(--md-sys-shape-corner-extra-large); padding: 32px 24px; text-align: center; }
.pkg-cta h2 { font: 700 28px/32px var(--md-ref-typeface-brand); letter-spacing: -0.01em; margin: 8px 0 12px; }
.pkg-cta p { font: 400 14px/20px var(--md-ref-typeface-plain); opacity: .8; margin: 0 0 20px; }
.pkg-tiers { display: flex; gap: 8px; flex-direction: column; margin-bottom: 24px; }
.pkg-pill { display: flex; align-items: center; justify-content: space-between; padding: 12px 16px; background: rgba(0,0,0,.06); border-radius: var(--md-sys-shape-corner-full); font: 500 14px/1 var(--md-ref-typeface-plain); }
.pkg-pill strong { font-family: var(--md-ref-typeface-brand); }

/* ---- Inner page header ---- */
.fe-page-header { padding: 24px 16px 8px; }
.fe-page-header h1 { font: 700 28px/1.1 var(--md-ref-typeface-brand); letter-spacing: -0.02em; margin: 0 0 8px; color: var(--md-sys-color-on-surface); }
.fe-page-header p { margin: 0; color: var(--md-sys-color-on-surface-variant); font: 400 15px/22px var(--md-ref-typeface-plain); }

/* ---- Auth ---- */
.fe-auth { display: flex; justify-content: center; padding: 16px 16px 32px; min-height: 60vh; }
.fe-auth__card { width: 100%; max-width: 420px; background: var(--md-sys-color-surface-container-low); border-radius: var(--md-sys-shape-corner-extra-large); padding: 24px; box-shadow: var(--md-sys-elevation-level1); }
.fe-auth__card--wide { max-width: 520px; }
.fe-auth__title { font: 700 24px/1.2 var(--md-ref-typeface-brand); text-align: center; margin: 0 0 8px; }
.fe-auth__sub { text-align: center; color: var(--md-sys-color-on-surface-variant); font-size: 14px; margin: 0 0 20px; line-height: 1.45; }
.fe-auth__form { display: grid; gap: 16px; }
.fe-auth__field label { display: block; font: 500 14px/1.3 var(--md-ref-typeface-plain); margin-bottom: 6px; color: var(--md-sys-color-on-surface); }
.fe-auth__field input[type="email"],
.fe-auth__field input[type="password"],
.fe-auth__field input[type="text"],
.fe-auth__field select { width: 100%; box-sizing: border-box; padding: 12px 14px; border-radius: var(--md-sys-shape-corner-small); border: 1px solid var(--md-sys-color-outline); background: var(--md-sys-color-surface); color: var(--md-sys-color-on-surface); font: 400 16px/1.3 var(--md-ref-typeface-plain); }
.fe-auth__field input:focus { outline: none; border-color: var(--md-sys-color-primary); box-shadow: 0 0 0 2px color-mix(in srgb, var(--md-sys-color-primary) 25%, transparent); }
.fe-auth__field input.is-invalid { border-color: var(--md-sys-color-error); }
.fe-auth__remember { display: flex; align-items: center; gap: 8px; font-size: 14px; }
.fe-auth__footer { margin-top: 20px; padding-top: 16px; border-top: 1px solid var(--md-sys-color-outline-variant); text-align: center; font-size: 14px; color: var(--md-sys-color-on-surface-variant); }
.fe-auth__footer a { color: var(--md-sys-color-primary); text-decoration: none; font-weight: 500; }
.fe-auth__footer p { margin: 8px 0 0; }
.fe-alert { padding: 12px 14px; border-radius: var(--md-sys-shape-corner-medium); font-size: 14px; margin-bottom: 4px; }
.fe-alert--error { background: color-mix(in srgb, var(--md-sys-color-error) 12%, transparent); border: 1px solid var(--md-sys-color-error); color: var(--md-sys-color-on-error-container); }
.fe-alert--success { background: color-mix(in srgb, var(--md-sys-color-tertiary) 15%, transparent); border: 1px solid var(--md-sys-color-tertiary); }
.fe-alert--info { background: var(--md-sys-color-primary-container); color: var(--md-sys-color-on-primary-container); border-radius: var(--md-sys-shape-corner-medium); padding: 14px 16px; margin-bottom: 16px; font-size: 14px; }
.fe-field-error { display: none; color: var(--md-sys-color-error); font-size: 13px; margin-top: 4px; }
.fe-auth__field input.is-invalid ~ .fe-field-error { display: block; }
.fe-password-wrap { position: relative; }
.fe-password-toggle { position: absolute; right: 8px; top: 50%; transform: translateY(-50%); border: 0; background: transparent; padding: 6px; cursor: pointer; color: var(--md-sys-color-on-surface-variant); border-radius: 50%; }

/* ---- Blog (Index + Artikel) ---- */
.fe-blog-page {
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 16px 56px;
}

.fe-blog-layout {
  display: grid;
  gap: 32px;
  align-items: start;
}

.fe-blog-layout__main {
  min-width: 0;
}

.fe-blog-sidebar {
  display: grid;
  gap: 20px;
}

.fe-blog-sidebar__panel {
  background: var(--md-sys-color-surface);
  border: 1px solid var(--md-sys-color-outline-variant);
  border-radius: var(--md-sys-shape-corner-extra-large);
  padding: 20px;
  box-shadow: var(--md-sys-elevation-level1);
}

.fe-blog-sidebar__panel--banner {
  padding: 16px;
}

.fe-blog-sidebar__title {
  font: 700 13px/1 var(--md-ref-typeface-plain);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--md-sys-color-on-surface-variant);
  margin: 0 0 14px;
}

.fe-blog-sidebar__cats {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 4px;
}

.fe-blog-sidebar__cat {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
  border-radius: var(--md-sys-shape-corner-medium);
  text-decoration: none;
  color: var(--md-sys-color-on-surface);
  font: 500 14px/1.35 var(--md-ref-typeface-plain);
  transition: background 0.15s ease, color 0.15s ease;
}

.fe-blog-sidebar__cat:hover {
  background: var(--md-sys-color-surface-container-high);
}

.fe-blog-sidebar__cat.is-active {
  background: var(--md-sys-color-primary-container);
  color: var(--md-sys-color-on-primary-container);
}

.fe-blog-sidebar__count {
  font: 600 12px/1 var(--md-ref-typeface-mono);
  color: var(--md-sys-color-on-surface-variant);
  background: var(--md-sys-color-surface-container-highest);
  border-radius: var(--md-sys-shape-corner-full);
  padding: 4px 8px;
  flex-shrink: 0;
}

.fe-blog-sidebar__cat.is-active .fe-blog-sidebar__count {
  background: color-mix(in srgb, var(--md-sys-color-primary) 18%, transparent);
  color: var(--md-sys-color-on-primary-container);
}

.fe-paid-banner--sidebar {
  display: block;
  margin: 0;
  overflow: hidden;
}

.fe-paid-banner--sidebar a {
  display: block;
}

.fe-paid-banner--sidebar .fe-paid-banner__img {
  width: 100%;
  max-width: 100%;
  max-height: none;
  height: auto;
  object-fit: contain;
  border-radius: var(--md-sys-shape-corner-medium);
}

.fe-blog-card__category {
  display: inline-block;
  width: fit-content;
  font: 600 11px/1 var(--md-ref-typeface-plain);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--md-sys-color-primary);
  background: color-mix(in srgb, var(--md-sys-color-primary) 10%, transparent);
  border-radius: var(--md-sys-shape-corner-full);
  padding: 5px 10px;
}

.fe-blog-related {
  margin-top: 40px;
  padding-top: 32px;
  border-top: 1px solid var(--md-sys-color-outline-variant);
}

.fe-blog-related__title {
  font: 700 22px/1.2 var(--md-ref-typeface-brand);
  letter-spacing: -0.01em;
  margin: 0 0 16px;
}

.fe-blog-related__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 12px;
}

.fe-blog-related__item {
  display: grid;
  grid-template-columns: 96px minmax(0, 1fr);
  gap: 14px;
  align-items: center;
  padding: 12px;
  border-radius: var(--md-sys-shape-corner-large);
  border: 1px solid var(--md-sys-color-outline-variant);
  background: var(--md-sys-color-surface);
  text-decoration: none;
  color: inherit;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.fe-blog-related__item:hover {
  border-color: color-mix(in srgb, var(--md-sys-color-primary) 35%, var(--md-sys-color-outline-variant));
  box-shadow: var(--md-sys-elevation-level1);
}

.fe-blog-related__item:not(:has(.fe-blog-related__thumb)) {
  grid-template-columns: 1fr;
}

.fe-blog-related__thumb {
  display: block;
  width: 96px;
  height: 72px;
  border-radius: var(--md-sys-shape-corner-medium);
  overflow: hidden;
  background: var(--md-sys-color-surface-container-high);
}

.fe-blog-related__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.fe-blog-related__body {
  display: grid;
  gap: 6px;
  min-width: 0;
}

.fe-blog-related__date {
  font: 500 11px/1 var(--md-ref-typeface-mono);
  color: var(--md-sys-color-on-surface-variant);
}

.fe-blog-related__headline {
  font: 600 15px/1.35 var(--md-ref-typeface-brand);
  color: var(--md-sys-color-on-surface);
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}

.fe-blog-article__category {
  display: inline-block;
  margin-bottom: 10px;
  font: 600 11px/1 var(--md-ref-typeface-plain);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--md-sys-color-primary);
  text-decoration: none;
}

.fe-blog-article__category:hover {
  text-decoration: underline;
}

.fe-blog-article__crumb {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
}

.fe-blog-article__crumb-sep {
  color: var(--md-sys-color-on-surface-variant);
}

.fe-blog-article__crumb-link {
  font: 500 14px/1.3 var(--md-ref-typeface-plain);
  color: var(--md-sys-color-primary);
  text-decoration: none;
}

.fe-blog-article__crumb-link:hover {
  text-decoration: underline;
}

.fe-blog-page__hero {
  padding: 28px 0 24px;
  text-align: center;
}

.fe-blog-page__hero h1 {
  font: 700 clamp(1.75rem, 4vw, 2.75rem)/1.1 var(--md-ref-typeface-brand);
  letter-spacing: -0.02em;
  margin: 0 0 12px;
  color: var(--md-sys-color-on-surface);
}

.fe-blog-page__lead {
  margin: 0 auto;
  max-width: 42rem;
  font: 400 16px/1.55 var(--md-ref-typeface-plain);
  color: var(--md-sys-color-on-surface-variant);
}

.fe-blog-page__grid {
  display: grid;
  gap: 20px;
}

.fe-blog-card {
  display: grid;
  grid-template-columns: 1fr;
  background: var(--md-sys-color-surface);
  border: 1px solid var(--md-sys-color-outline-variant);
  border-radius: var(--md-sys-shape-corner-extra-large);
  overflow: hidden;
  box-shadow: var(--md-sys-elevation-level1);
  color: inherit;
  text-decoration: none;
  transition: box-shadow 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
}

.fe-blog-card:hover {
  box-shadow: var(--md-sys-elevation-level2);
  border-color: color-mix(in srgb, var(--md-sys-color-primary) 35%, var(--md-sys-color-outline-variant));
}

.fe-blog-card__media {
  aspect-ratio: 16 / 9;
  background: var(--md-sys-color-surface-container-high);
  overflow: hidden;
}

.fe-blog-card__media img,
.fe-blog-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.35s ease;
}

.fe-blog-card:hover .fe-blog-card__media img {
  transform: scale(1.03);
}

.fe-blog-card__placeholder {
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center;
  background:
    radial-gradient(circle at 30% 30%, rgba(255, 201, 58, 0.35), transparent 55%),
    radial-gradient(circle at 70% 70%, rgba(186, 26, 26, 0.3), transparent 55%),
    linear-gradient(135deg, #1a3a5e, #0a1626);
  color: rgba(255, 255, 255, 0.85);
}

.fe-blog-card__placeholder .material-symbols-outlined {
  font-size: 48px;
  font-variation-settings: 'FILL' 1, 'wght' 400, 'GRAD' 0, 'opsz' 48;
}

.fe-blog-card__body {
  min-width: 0;
  padding: 18px 20px 22px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.fe-blog-card__date {
  font: 500 12px/1 var(--md-ref-typeface-mono);
  color: var(--md-sys-color-on-surface-variant);
}

.fe-blog-card__title {
  font: 700 clamp(1.125rem, 2.5vw, 1.375rem)/1.3 var(--md-ref-typeface-brand);
  margin: 0;
  letter-spacing: -0.01em;
  color: var(--md-sys-color-on-surface);
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
}

.fe-blog-card__excerpt {
  margin: 2px 0 0;
  font: 400 15px/1.55 var(--md-ref-typeface-plain);
  color: var(--md-sys-color-on-surface-variant);
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
}

.fe-blog-card__more {
  margin-top: auto;
  padding-top: 12px;
  font: 600 14px/1 var(--md-ref-typeface-plain);
  color: var(--md-sys-color-primary);
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.fe-blog-card__more .material-symbols-outlined {
  font-size: 18px;
}

.fe-blog-page__empty {
  padding: 48px 0;
}

.fe-blog-pager {
  margin-top: 40px;
  padding-top: 24px;
  border-top: 1px solid var(--md-sys-color-outline-variant);
}

.fe-blog-pager__list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
  list-style: none;
  margin: 0;
  padding: 0;
}

.fe-blog-pager__dots {
  display: flex;
  align-items: center;
  padding: 0 4px;
  color: var(--md-sys-color-on-surface-variant);
}

.fe-blog-pager__disabled {
  opacity: 0.45;
  pointer-events: none;
}

.fe-blog-article-wrap {
  padding: 0 16px 56px;
}

.fe-blog-article-wrap .fe-blog-layout {
  max-width: 1180px;
  margin: 0 auto;
}

.fe-blog-article {
  max-width: none;
  margin: 0;
}

.fe-blog-article__crumb {
  padding: 16px 0 8px;
}

.fe-blog-article__header {
  padding: 8px 0 24px;
}

.fe-blog-article__date {
  display: block;
  font: 500 12px/1 var(--md-ref-typeface-mono);
  color: var(--md-sys-color-on-surface-variant);
  margin-bottom: 12px;
}

.fe-blog-article__title {
  font: 700 clamp(1.75rem, 5vw, 2.5rem)/1.12 var(--md-ref-typeface-brand);
  letter-spacing: -0.02em;
  margin: 0 0 16px;
  color: var(--md-sys-color-on-surface);
}

.fe-blog-article__deck {
  margin: 0;
  font: 400 18px/1.55 var(--md-ref-typeface-plain);
  color: var(--md-sys-color-on-surface-variant);
}

.fe-blog-article__hero {
  margin: 0 0 32px;
  border-radius: var(--md-sys-shape-corner-extra-large);
  overflow: hidden;
  background: var(--md-sys-color-surface-container-high);
  box-shadow: var(--md-sys-elevation-level1);
}

.fe-blog-article__hero-img {
  width: 100%;
  height: auto;
  display: block;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}

.fe-blog-article__content {
  font: 400 17px/1.65 var(--md-ref-typeface-plain);
  color: var(--md-sys-color-on-surface);
}

.fe-blog-article__content > *:first-child {
  margin-top: 0;
}

.fe-blog-article__content h2 {
  font: 700 1.5rem/1.25 var(--md-ref-typeface-brand);
  margin: 2em 0 0.75em;
  letter-spacing: -0.01em;
}

.fe-blog-article__content h3 {
  font: 700 1.2rem/1.3 var(--md-ref-typeface-brand);
  margin: 1.75em 0 0.6em;
}

.fe-blog-article__content p {
  margin: 0 0 1.15em;
}

.fe-blog-article__content ul,
.fe-blog-article__content ol {
  margin: 0 0 1.15em;
  padding-left: 1.35em;
}

.fe-blog-article__content li {
  margin-bottom: 0.45em;
}

.fe-blog-article__content a {
  color: var(--md-sys-color-primary);
  text-decoration-thickness: 1px;
  text-underline-offset: 2px;
}

.fe-blog-article__content img {
  max-width: 100%;
  height: auto;
  border-radius: var(--md-sys-shape-corner-medium);
  margin: 1.5em 0;
}

.fe-blog-article__content blockquote {
  margin: 1.5em 0;
  padding: 16px 20px;
  border-left: 4px solid var(--md-sys-color-primary);
  background: var(--md-sys-color-surface-container-low);
  border-radius: 0 var(--md-sys-shape-corner-medium) var(--md-sys-shape-corner-medium) 0;
  color: var(--md-sys-color-on-surface-variant);
}

.fe-blog-cta {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  margin: 40px 0 24px;
  padding: 24px;
  border-radius: var(--md-sys-shape-corner-extra-large);
  background: var(--md-sys-color-primary-container);
  border: 1px solid color-mix(in srgb, var(--md-sys-color-primary) 25%, transparent);
}

.fe-blog-cta__icon {
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  border-radius: var(--md-sys-shape-corner-medium);
  background: var(--md-sys-color-primary);
  color: var(--md-sys-color-on-primary);
  display: grid;
  place-items: center;
}

.fe-blog-cta__icon .material-symbols-outlined {
  font-size: 26px;
  font-variation-settings: 'FILL' 1, 'wght' 500, 'GRAD' 0, 'opsz' 24;
}

.fe-blog-cta__body {
  min-width: 0;
  display: grid;
  gap: 8px;
}

.fe-blog-cta__body strong {
  font: 700 17px/1.35 var(--md-ref-typeface-brand);
  color: var(--md-sys-color-on-primary-container);
}

.fe-blog-cta__body p {
  margin: 0;
  font: 400 15px/1.5 var(--md-ref-typeface-plain);
  color: color-mix(in srgb, var(--md-sys-color-on-primary-container) 85%, transparent);
}

.fe-blog-article__footer {
  margin-top: 32px;
  padding-top: 20px;
  border-top: 1px solid var(--md-sys-color-outline-variant);
}

.fe-empty { padding: 32px 16px; text-align: center; color: var(--md-sys-color-on-surface-variant); }

/* Legacy article helpers (TinyMCE embeds) */
.fe-article__content .blog-video-embed,
.fe-article__content div[style*="text-align:center"] {
  display: block;
  position: relative;
  width: 100%;
  max-width: 720px;
  margin: 24px auto;
  aspect-ratio: 16 / 9;
  border-radius: var(--md-sys-shape-corner-medium);
  overflow: hidden;
  background: var(--md-sys-color-surface-container-high);
}
.fe-article__content .blog-video-embed iframe,
.fe-article__content div[style*="text-align:center"] iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

.fe-pager { padding: 8px 16px 32px; }
.fe-pager__list { display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; list-style: none; margin: 0; padding: 0; }
.fe-pager__dots { display: flex; align-items: center; padding: 0 4px; color: var(--md-sys-color-on-surface-variant); }

/* ---- Legal ---- */
.fe-legal { padding: 16px 16px 32px; max-width: 800px; margin: 0 auto; }
.fe-legal__card { padding: 24px 20px; border-radius: var(--md-sys-shape-corner-large); background: var(--md-sys-color-surface-container-low); box-shadow: var(--md-sys-elevation-level1); }
.fe-legal__card h2 { font: 700 22px/1.2 var(--md-ref-typeface-brand); margin: 0 0 16px; }
.fe-legal__card h3 { font: 700 18px/1.3 var(--md-ref-typeface-brand); margin: 24px 0 8px; }
.fe-legal__card p, .fe-legal__card li { font: 400 15px/1.55 var(--md-ref-typeface-plain); color: var(--md-sys-color-on-surface); }
.fe-legal__card a { color: var(--md-sys-color-primary); }
.fe-legal__card ul { padding-left: 1.2em; }

.fe-auth__form ul { list-style: none; padding: 0; margin: 4px 0 0; color: var(--md-sys-color-error); font-size: 13px; }
.fe-alert--info a { color: var(--md-sys-color-primary); font-weight: 500; }
.fe-pricing .fe-page-header { padding-left: 0; padding-right: 0; }
.fe-pricing .fe-alert--info { margin-bottom: 16px; }
.fe-pricing hr { border: none; border-top: 1px solid var(--border); margin: 12px 0; }
.fe-pricing .addon-duration { margin-left: 6px; display: inline-block; font-size: 0.9rem; }
.fe-pricing .included-locations-badge { text-align: center; margin: 8px 0 0; }
.fe-pricing .add-to-cart[data-type="addon"].active { filter: brightness(.92); }
.fe-pricing .pricing-cart h4 { font: 700 18px/1.2 var(--md-ref-typeface-brand); margin: 0 0 12px; }

.fe-pricing--info { padding: 0 16px 32px; }
.fe-pricing__toolbar { margin-bottom: 20px; }
.fe-pricing__toggle {
  display: inline-flex; align-items: center; gap: 10px; font-size: 14px; cursor: pointer;
}
.fe-pricing__switch {
  position: relative; width: 48px; height: 26px; border-radius: 999px;
  background: var(--md-sys-color-outline-variant);
}
.fe-pricing__switch::after {
  content: ""; position: absolute; width: 20px; height: 20px; top: 3px; left: 3px;
  border-radius: 50%; background: #fff; transition: transform .2s;
}
.fe-pricing__toggle input { position: absolute; opacity: 0; width: 0; height: 0; }
.fe-pricing__toggle input:checked + .fe-pricing__switch { background: var(--md-sys-color-primary); }
.fe-pricing__toggle input:checked + .fe-pricing__switch::after { transform: translateX(22px); }
.fe-pricing__grid {
  display: grid; gap: 16px;
  grid-template-columns: 1fr;
}
@media (min-width: 768px) {
  .fe-pricing__grid { grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); }
}
.fe-pricing__card {
  display: flex; flex-direction: column;
  background: var(--md-sys-color-surface-container-low);
  border: 1px solid var(--md-sys-color-outline-variant);
  border-radius: var(--md-sys-shape-corner-large);
  padding: 20px; box-shadow: var(--md-sys-elevation-level1);
}
.fe-pricing__title { font: 700 22px/1.2 var(--md-ref-typeface-brand); text-align: center; margin: 0 0 8px; }
.fe-pricing__price { font: 700 24px/1 var(--md-ref-typeface-brand); text-align: center; margin: 0; }
.fe-pricing__per { font-weight: 500; font-size: 14px; color: var(--md-sys-color-on-surface-variant); }
.fe-pricing__badge { text-align: center; margin: 10px 0 0; }
.fe-pricing__chip {
  display: inline-block; padding: 4px 12px; border-radius: 999px;
  background: color-mix(in srgb, var(--md-sys-color-tertiary) 20%, transparent);
  color: var(--md-sys-color-tertiary); font-size: 12px; font-weight: 700;
}
.fe-pricing__subtitle { text-align: center; color: var(--md-sys-color-on-surface-variant); font-size: 14px; margin: 8px 0; }
.fe-pricing__features ul { list-style: none; padding: 0; margin: 0 0 12px; font-size: 14px; }
.fe-pricing__features li { padding-left: 18px; position: relative; margin: 6px 0; }
.fe-pricing__features li::before { content: "•"; position: absolute; left: 0; color: var(--md-sys-color-primary); }
.fe-pricing__spacer { flex-grow: 1; min-height: 12px; }

/* Info-Banner — gleiche Kartenoptik wie Pakete/Extras (Cream-Surface) */
.fe-info-banner {
  display: flex; gap: 14px; align-items: flex-start;
  padding: 16px 18px; margin-bottom: 24px;
  background: var(--md-sys-color-surface-container-low);
  border: 1px solid var(--md-sys-color-outline-variant);
  border-radius: var(--md-sys-shape-corner-large);
  box-shadow: var(--md-sys-elevation-level1);
}
.fe-info-banner__icon {
  font-size: 28px; flex-shrink: 0; margin-top: 2px;
  color: var(--md-sys-color-primary);
  font-variation-settings: 'FILL' 1;
}
.fe-info-banner__body { flex: 1; min-width: 0; }
.fe-info-banner__body strong {
  display: block; font: 700 16px/1.3 var(--md-ref-typeface-brand); margin-bottom: 6px;
  color: var(--md-sys-color-on-surface);
}
.fe-info-banner__body p {
  margin: 0; font-size: 14px; line-height: 1.5;
  color: var(--md-sys-color-on-surface-variant);
}
.fe-info-banner__body p a {
  color: var(--md-sys-color-primary); font-weight: 700; text-decoration: underline;
}
.fe-info-banner__actions {
  display: flex; flex-wrap: wrap; gap: 8px; margin-top: 14px;
}
.fe-info-banner__actions .m3-btn--filled {
  background: var(--md-sys-color-primary);
  color: var(--md-sys-color-on-primary);
}
.fe-info-banner__actions .m3-btn--outlined {
  color: var(--md-sys-color-primary);
  border-color: var(--md-sys-color-outline);
}

/* Extras & Add-ons (Info) */
.fe-extras-section { margin-top: 36px; }
.fe-extras-section__title {
  font: 700 22px/1.2 var(--md-ref-typeface-brand); margin: 0 0 8px;
}
.fe-extras-section__lead {
  margin: 0 0 16px; font-size: 14px; color: var(--md-sys-color-on-surface-variant);
}
.fe-extras-card {
  display: flex; gap: 16px; align-items: flex-start;
  padding: 18px 20px;
  background: var(--md-sys-color-surface-container-low);
  border: 1px solid var(--md-sys-color-outline-variant);
  border-radius: var(--md-sys-shape-corner-large);
  box-shadow: var(--md-sys-elevation-level1);
}
.fe-extras-card__icon {
  font-size: 32px; color: var(--md-sys-color-primary); flex-shrink: 0;
  font-variation-settings: 'FILL' 1;
}
.fe-extras-card h3 { font: 700 18px/1.2 var(--md-ref-typeface-brand); margin: 0 0 6px; }
.fe-extras-card__price {
  font: 600 15px/1.3 var(--md-ref-typeface-brand); margin: 0 0 8px;
  color: var(--md-sys-color-primary);
}
.fe-extras-card__desc {
  margin: 0 0 6px; font-size: 14px; line-height: 1.5;
  color: var(--md-sys-color-on-surface-variant);
}
.fe-addon-list {
  list-style: none; padding: 0; margin: 0;
  display: grid; gap: 12px;
}
@media (min-width: 640px) {
  .fe-addon-list { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }
}
.fe-addon-card {
  padding: 16px 18px;
  background: var(--md-sys-color-surface-container-low);
  border: 1px solid var(--md-sys-color-outline-variant);
  border-radius: var(--md-sys-shape-corner-medium);
}
.fe-addon-card__head {
  display: flex; justify-content: space-between; align-items: flex-start; gap: 8px; margin-bottom: 6px;
}
.fe-addon-card__head h3 { font: 700 16px/1.3 var(--md-ref-typeface-brand); margin: 0; }
.fe-addon-card__price { font-size: 14px; font-weight: 600; margin: 0 0 6px; color: var(--md-sys-color-primary); }
.fe-addon-card__desc { font-size: 13px; margin: 0 0 6px; color: var(--md-sys-color-on-surface-variant); line-height: 1.45; }
.fe-addon-card__meta { font-size: 12px; margin: 0; color: var(--md-sys-color-on-surface-variant); }

.fe-pricing__footer-note {
  margin-top: 36px; padding-top: 24px;
  border-top: 1px solid var(--md-sys-color-outline-variant);
  text-align: center;
}

/* fe-dialog → m3-components.css */

/* Legacy pricing (cart) — kept for reference, unused on info page */
.fe-pricing .pricing-grid-wrapper { display: grid; grid-template-columns: 1fr; gap: 24px; align-items: start; }
.fe-pricing .pricing-grid { display: grid; grid-template-columns: 1fr; gap: 16px; }
.fe-pricing .pricing-card { display: flex; flex-direction: column; background: var(--surface); border: 1px solid var(--border); border-radius: var(--md-sys-shape-corner-large); padding: 20px; box-shadow: var(--md-sys-elevation-level1); }
.fe-pricing .pricing-head .title { font: 700 22px/1.2 var(--md-ref-typeface-brand); text-align: center; margin-bottom: 8px; }
.fe-pricing .price { font: 700 24px/1 var(--md-ref-typeface-brand); text-align: center; }
.fe-pricing .per { font-weight: 500; font-size: 14px; color: var(--muted); }
.fe-pricing .subtitle { text-align: center; color: var(--muted); font-size: 14px; margin: 4px 0 12px; }
.fe-pricing .features ul { list-style: none; padding: 0; margin: 0 0 12px; font-size: 14px; }
.fe-pricing .features li { padding-left: 18px; position: relative; margin: 6px 0; }
.fe-pricing .features li::before { content: "•"; position: absolute; left: 0; color: var(--accent); }
.fe-pricing .spacer { flex-grow: 1; }
.fe-pricing .btn-primary, .fe-pricing .add-to-cart[data-type="package"] { display: block; width: 100%; text-align: center; padding: 12px; font-weight: 700; border: none; border-radius: var(--md-sys-shape-corner-full); background: var(--accent); color: var(--on-accent); cursor: pointer; font-size: 15px; }
.fe-pricing .btn-primary:hover, .fe-pricing .add-to-cart:hover { filter: brightness(.95); }
.fe-pricing .btn-primary.disabled, .fe-pricing .btn-primary:disabled { opacity: .5; pointer-events: none; }
.fe-pricing .pricing-cart { background: var(--surface); border: 1px solid var(--border); border-radius: var(--md-sys-shape-corner-large); padding: 18px; box-shadow: var(--md-sys-elevation-level1); position: sticky; top: 80px; }
.fe-pricing .toggle-topright { display: flex; gap: 12px; align-items: center; margin-bottom: 16px; font-size: 14px; }
.fe-pricing .switch { position: relative; display: inline-block; width: 54px; height: 28px; flex-shrink: 0; }
.fe-pricing .switch input { opacity: 0; width: 0; height: 0; }
.fe-pricing .slider { position: absolute; cursor: pointer; inset: 0; background: var(--border); transition: .2s; border-radius: 28px; }
.fe-pricing .slider:before { position: absolute; content: ""; height: 22px; width: 22px; left: 3px; top: 3px; background: white; border-radius: 50%; transition: .2s; }
.fe-pricing .switch input:checked + .slider { background: var(--accent); }
.fe-pricing .switch input:checked + .slider:before { transform: translateX(26px); }
.fe-pricing .cart-items { list-style: none; padding: 0; margin: 0 0 12px; font-size: 14px; }
.fe-pricing .cart-summary { display: flex; justify-content: space-between; font-weight: 700; }
.fe-pricing .addons h4, .fe-pricing .additional-locations h4 { font: 700 18px/1 var(--md-ref-typeface-brand); margin: 0 0 12px; }
.fe-pricing .addon-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 8px; }
.fe-pricing .addon-item { background: var(--surface); border: 1px solid var(--border); border-radius: var(--md-sys-shape-corner-medium); padding: 12px; font-size: 14px; }
.fe-pricing .add-to-cart[data-type="addon"] { display: inline-block; width: auto; padding: 6px 12px; font-size: 13px; border-radius: var(--md-sys-shape-corner-full); }
.fe-pricing .additional-locations { background: var(--surface); border: 1px solid var(--border); border-radius: var(--md-sys-shape-corner-medium); padding: 16px; margin-top: 16px; }
.fe-pricing .location-counter { display: flex; flex-wrap: wrap; align-items: center; gap: 12px; margin-top: 12px; }
.fe-pricing .counter-controls { display: flex; align-items: center; gap: 8px; }
.fe-pricing .counter-controls input { width: 48px; text-align: center; border: 1px solid var(--border); border-radius: 8px; padding: 6px; background: var(--md-sys-color-surface); color: var(--text); }
.fe-pricing .btn-outline-secondary { padding: 8px 14px; border-radius: var(--md-sys-shape-corner-full); border: 1px solid var(--border); background: transparent; cursor: pointer; font-size: 18px; line-height: 1; }
.fe-pricing .badge-success { display: inline-block; padding: 4px 10px; border-radius: 999px; background: color-mix(in srgb, var(--md-sys-color-tertiary) 20%, transparent); color: var(--md-sys-color-tertiary); font-size: 12px; font-weight: 700; }
.fe-pricing .selected-package { border: 2px solid var(--accent) !important; }
.fe-pricing .package-disabled { opacity: .65; filter: grayscale(40%); }
.fe-pricing .addon-active { opacity: .6; pointer-events: none; }
.fe-pricing .addon-active strong::after { content: " (aktiv)"; color: var(--md-sys-color-tertiary); font-weight: normal; }
.fe-pricing .btn-success { background: var(--md-sys-color-tertiary) !important; color: var(--md-sys-color-on-tertiary) !important; }
.fe-pricing .text-muted { color: var(--muted); }
.fe-pricing .w-100 { width: 100%; }
.fe-pricing .mt-3 { margin-top: 12px; }
.fe-pricing .mt-4 { margin-top: 16px; }
.fe-pricing .mb-3 { margin-bottom: 12px; }
.fe-pricing .mb-4 { margin-bottom: 16px; }
.fe-pricing .ms-2 { margin-left: 8px; }
.fe-pricing .form-select,
.fe-pricing select {
  padding: 8px 12px;
  border-radius: var(--md-sys-shape-corner-small);
  border: 1px solid var(--md-sys-color-outline);
  background-color: var(--md-sys-color-surface-container-highest);
  color: var(--md-sys-color-on-surface);
  font: 500 14px/1.3 var(--md-ref-typeface-plain);
  color-scheme: light dark;
}
.fe-pricing .form-select option,
.fe-pricing select option {
  background-color: var(--md-sys-color-surface-container-high);
  color: var(--md-sys-color-on-surface);
}

@media (min-width: 600px) {
  .hero { padding: 32px 24px 48px; }
  .why-grid { grid-template-columns: 1fr 1fr; padding: 0 24px; gap: 16px; }
  .fe-legal, .fe-pricing, .fe-widget-host, .fe-welcome, .fe-info-card, .fe-webcam-grid { padding-left: 24px; padding-right: 24px; }
  .fe-blog-page { padding-left: 24px; padding-right: 24px; }
  .fe-blog-article-wrap { padding-left: 24px; padding-right: 24px; }
  .fe-info-card { margin: 0 24px; }
  .pkg-cta { margin: 0 24px; }
  .fe-welcome { grid-template-columns: minmax(240px, 38%) 1fr; }
  .fe-webcam-grid { grid-template-columns: 1fr 1fr; }
  .fe-widget__metrics { grid-template-columns: repeat(2, 1fr); }
  .fe-widget__main { grid-template-columns: 160px 1fr; }
}

@media (min-width: 768px) {
  .fe-pricing .pricing-grid-wrapper { grid-template-columns: 2fr 1fr; gap: 32px; }
  .fe-pricing .pricing-grid { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }
}

@media (min-width: 905px) {
  .hero { padding: 48px 32px 56px; margin: 16px; border-radius: var(--md-sys-shape-corner-extra-large); }
  .hero h1 { font-size: 3.6rem; }
  .why-grid { grid-template-columns: repeat(3, 1fr); padding: 0 32px; }
  .blog-list { display: grid; grid-template-columns: 2fr 1fr; gap: 16px; padding: 0 32px; }
  .blog-card--featured { grid-row: span 2; }
  .pkg-tiers { flex-direction: row; justify-content: center; flex-wrap: wrap; }
  .pkg-cta { margin: 0 32px; padding: 56px 40px; }
  .fe-widget-host, .fe-welcome, .fe-webcam-grid { padding-left: 32px; padding-right: 32px; }
  .fe-blog-page { padding-left: 32px; padding-right: 32px; padding-bottom: 72px; }
  .fe-blog-article-wrap { padding-left: 32px; padding-right: 32px; padding-bottom: 72px; }
  .fe-blog-layout {
    grid-template-columns: minmax(0, 1fr) 320px;
    gap: 40px;
  }
  .fe-blog-sidebar {
    position: sticky;
    top: 88px;
  }
  .fe-blog-page__hero { text-align: left; padding: 40px 0 32px; }
  .fe-blog-page__lead { margin-left: 0; max-width: 36rem; }
  .fe-blog-page__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 24px;
  }
  .fe-blog-card--featured {
    grid-column: 1 / -1;
    grid-template-columns: minmax(280px, 44%) minmax(0, 1fr);
    align-items: stretch;
  }
  .fe-blog-card--featured .fe-blog-card__media {
    aspect-ratio: unset;
    align-self: stretch;
    display: grid;
    min-height: 100%;
  }
  .fe-blog-card--featured .fe-blog-card__media img,
  .fe-blog-card--featured .fe-blog-card__media .fe-blog-card__img,
  .fe-blog-card--featured .fe-blog-card__media .fe-blog-card__placeholder {
    width: 100%;
    height: 100%;
    min-height: 100%;
    object-fit: cover;
  }
  .fe-blog-card--featured .fe-blog-card__title {
    font-size: clamp(1.35rem, 2.2vw, 1.85rem);
    -webkit-line-clamp: 2;
  }
  .fe-blog-card--featured .fe-blog-card__excerpt {
    -webkit-line-clamp: 4;
    font-size: 16px;
  }
  .fe-info-card { margin: 0 32px; }
  .fe-webcam-grid { grid-template-columns: repeat(3, 1fr); }
  .fe-widget__metrics { grid-template-columns: repeat(3, 1fr); }
  body.has-bottom-nav { padding-bottom: 0; }
  .m3-bottom-nav { display: none; }
}
