/*!
 * Stremzi Frontend Styles v1.4
 * -----------------------------------------------------------------------------
 * STRATEGY: We accept that themes like Brisk/UiCore inject aggressive CSS. We
 * defeat them with three tactics used together:
 *
 *   1. `isolation: isolate` on the root creates a new stacking context.
 *   2. `all: revert` on descendants wipes theme styles back to UA defaults
 *      before we re-apply ours.
 *   3. `!important` ONLY on structural properties (display, position, width,
 *      background, colour) where the theme is known to interfere. We avoid
 *      `!important` on font sizes and spacing so users can still override via
 *      custom CSS.
 *
 *   Plus: we stop using custom checkboxes (the invisible-input + fake-box
 *   pattern is fragile with pointer-events). Instead we use a normal checkbox
 *   and skin it with the `accent-color` CSS property (widely supported).
 */

/* =========================================================================
   Root isolation
   ========================================================================= */
#stremzi-root,
.stremzi-wrap {
  all: revert !important;
  isolation: isolate;
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  font-family: inherit !important;
  font-size: inherit !important;
  line-height: 1.5 !important;
  color: inherit !important;
  text-align: left !important;
  background: transparent !important;
  box-sizing: border-box !important;
}

/* Reset every descendant back to sane defaults.
 * NOTE: we DO NOT reset inputs here — that kills their functionality on
 * some browsers. Inputs get explicit rules below. */
.stremzi-wrap *,
.stremzi-wrap *::before,
.stremzi-wrap *::after {
  box-sizing: border-box !important;
}
.stremzi-wrap div,
.stremzi-wrap span,
.stremzi-wrap p,
.stremzi-wrap h1,
.stremzi-wrap h2,
.stremzi-wrap h3,
.stremzi-wrap h4,
.stremzi-wrap a,
.stremzi-wrap label,
.stremzi-wrap button,
.stremzi-wrap form,
.stremzi-wrap small {
  all: revert;
  box-sizing: border-box !important;
  font-family: inherit !important;
  margin: 0;
  padding: 0;
}

/* =========================================================================
   Card
   ========================================================================= */
.stremzi-wrap .stremzi-card {
  display: block !important;
  max-width: 520px !important;
  margin: 32px auto !important;
  padding: 0 !important;
  background: #ffffff !important;
  border: 1px solid rgba(226, 232, 240, 0.6) !important;
  border-radius: 24px !important;
  box-shadow: 0 20px 60px rgba(14, 165, 233, 0.08), 0 2px 8px rgba(15, 23, 42, 0.04) !important;
  overflow: hidden !important;
  color: #0e1a2b !important;
  text-align: left !important;
  position: relative !important;
}

/* =========================================================================
   Hero
   ========================================================================= */
.stremzi-wrap .stremzi-hero {
  display: block !important;
  background: linear-gradient(135deg, #e0f2fe 0%, #bae6fd 100%) !important;
  padding: 36px 32px 28px !important;
  text-align: center !important;
}
.stremzi-wrap .stremzi-logo {
  display: inline-flex !important;
  align-items: center !important;
  gap: 12px !important;
  margin: 0 0 22px !important;
  padding: 0 !important;
  font-size: 0;
}
.stremzi-wrap .stremzi-logo-dot {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 44px !important;
  height: 44px !important;
  border-radius: 50% !important;
  background: linear-gradient(135deg, #38bdf8, #0ea5e9) !important;
  color: #fff !important;
  box-shadow: 0 4px 12px rgba(14, 165, 233, 0.3) !important;
}
.stremzi-wrap .stremzi-logo-dot svg {
  display: block !important;
  width: 20px !important;
  height: 20px !important;
  fill: #fff !important;
}
.stremzi-wrap .stremzi-logo-text {
  display: inline-block !important;
  font-size: 24px !important;
  font-weight: 800 !important;
  color: #0e1a2b !important;
  letter-spacing: -0.3px !important;
  line-height: 1 !important;
}

.stremzi-wrap .stremzi-title {
  display: block !important;
  margin: 0 0 10px !important;
  padding: 0 !important;
  font-size: 28px !important;
  font-weight: 800 !important;
  color: #0e1a2b !important;
  letter-spacing: -0.5px !important;
  line-height: 1.2 !important;
  text-align: center !important;
  visibility: visible !important;
  opacity: 1 !important;
}
.stremzi-wrap .stremzi-subtitle {
  display: block !important;
  color: #64748b !important;
  margin: 0 !important;
  padding: 0 !important;
  font-size: 15px !important;
  line-height: 1.5 !important;
  text-align: center !important;
  font-weight: 400 !important;
  visibility: visible !important;
  opacity: 1 !important;
}

/* =========================================================================
   Body
   ========================================================================= */
.stremzi-wrap .stremzi-body {
  display: block !important;
  padding: 28px 32px 32px !important;
  background: #ffffff !important;
}

/* =========================================================================
   Trial perks
   ========================================================================= */
.stremzi-wrap .stremzi-perks {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 10px 16px !important;
  margin: 0 0 24px !important;
  padding: 14px 16px !important;
  background: linear-gradient(135deg, #f0f9ff 0%, #f8fbff 100%) !important;
  border: 1px solid #e0f2fe !important;
  border-radius: 16px !important;
}
.stremzi-wrap .stremzi-perk {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  font-size: 13px !important;
  color: #334155 !important;
  font-weight: 500 !important;
  line-height: 1.3 !important;
}
.stremzi-wrap .stremzi-perk-ic {
  display: inline-block !important;
  font-size: 14px !important;
  flex-shrink: 0 !important;
  line-height: 1 !important;
}

/* =========================================================================
   Form fields
   ========================================================================= */
.stremzi-wrap .stremzi-form {
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
}
.stremzi-wrap .stremzi-field {
  display: block !important;
  margin: 0 0 18px !important;
  padding: 0 !important;
  position: relative !important;
}
.stremzi-wrap .stremzi-lbl {
  display: block !important;
  margin: 0 0 8px !important;
  padding: 0 !important;
  color: #334155 !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  line-height: 1.3 !important;
  text-align: left !important;
  text-transform: none !important;
  letter-spacing: normal !important;
  float: none !important;
  width: auto !important;
}

.stremzi-wrap .stremzi-input-wrap {
  display: block !important;
  position: relative !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}
.stremzi-wrap .stremzi-ic {
  display: flex !important;
  position: absolute !important;
  left: 16px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 20px !important;
  height: 20px !important;
  align-items: center !important;
  justify-content: center !important;
  color: #94a3b8 !important;
  pointer-events: none !important;
  z-index: 2 !important;
  background: transparent !important;
}
.stremzi-wrap .stremzi-ic svg {
  display: block !important;
  width: 18px !important;
  height: 18px !important;
  color: #94a3b8 !important;
  stroke: #94a3b8 !important;
  fill: none !important;
}

/* =========================================================================
   Inputs — these must be protected aggressively from themes.
   Trick: `background: linear-gradient(#fff,#fff)` beats `background-color`
   from any theme because `background` shorthand resets the color layer.
   ========================================================================= */
.stremzi-wrap .stremzi-card input[type="email"],
.stremzi-wrap .stremzi-card input[type="tel"],
.stremzi-wrap .stremzi-card input[type="password"],
.stremzi-wrap .stremzi-card input[type="text"],
.stremzi-wrap .stremzi-card input[type="number"],
.stremzi-wrap .stremzi-form input[type="email"],
.stremzi-wrap .stremzi-form input[type="tel"],
.stremzi-wrap .stremzi-form input[type="password"],
.stremzi-wrap .stremzi-form input[type="text"] {
  display: block !important;
  width: 100% !important;
  height: 52px !important;
  min-height: 52px !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 12px 44px 12px 44px !important;
  border: 1.5px solid #e2e8f0 !important;
  border-radius: 999px !important;
  font-size: 15px !important;
  font-family: inherit !important;
  font-weight: 400 !important;
  color: #0e1a2b !important;
  background: linear-gradient(#ffffff, #ffffff) !important;
  background-color: #ffffff !important;
  background-image: linear-gradient(#ffffff, #ffffff) !important;
  line-height: 1.4 !important;
  transition: border-color .15s, box-shadow .15s !important;
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  appearance: none !important;
  box-shadow: none !important;
  outline: none !important;
  letter-spacing: normal !important;
  text-transform: none !important;
  text-align: left !important;
  float: none !important;
  position: relative !important;
  z-index: 1 !important;
  filter: none !important;
  -webkit-text-fill-color: #0e1a2b !important;
}
.stremzi-wrap .stremzi-card input:focus,
.stremzi-wrap .stremzi-form input:focus {
  border-color: #0ea5e9 !important;
  box-shadow: 0 0 0 4px rgba(14, 165, 233, 0.15) !important;
  outline: none !important;
  background: linear-gradient(#ffffff, #ffffff) !important;
  background-color: #ffffff !important;
}
/* Autofill (yellow on Chrome, blue on Firefox) — neutralise */
.stremzi-wrap .stremzi-card input:-webkit-autofill,
.stremzi-wrap .stremzi-card input:-webkit-autofill:hover,
.stremzi-wrap .stremzi-card input:-webkit-autofill:focus {
  -webkit-box-shadow: 0 0 0 1000px #ffffff inset !important;
  box-shadow: 0 0 0 1000px #ffffff inset !important;
  -webkit-text-fill-color: #0e1a2b !important;
  caret-color: #0e1a2b !important;
  transition: background-color 600000s 0s, color 600000s 0s !important;
}
.stremzi-wrap .stremzi-card input::placeholder {
  color: #cbd5e1 !important;
  opacity: 1 !important;
  font-weight: 400 !important;
  -webkit-text-fill-color: #cbd5e1 !important;
}
.stremzi-wrap .stremzi-card input::-webkit-input-placeholder { color: #cbd5e1 !important; }
.stremzi-wrap .stremzi-card input::-moz-placeholder { color: #cbd5e1 !important; opacity: 1 !important; }

/* Password eye toggle */
.stremzi-wrap .stremzi-pwd-toggle {
  display: flex !important;
  position: absolute !important;
  right: 12px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 32px !important;
  height: 32px !important;
  padding: 0 !important;
  margin: 0 !important;
  border: none !important;
  background: transparent !important;
  color: #94a3b8 !important;
  cursor: pointer !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 6px !important;
  z-index: 3 !important;
}
.stremzi-wrap .stremzi-pwd-toggle:hover { color: #0ea5e9 !important; }
.stremzi-wrap .stremzi-pwd-toggle svg {
  display: block !important;
  width: 18px !important;
  height: 18px !important;
  pointer-events: none !important;
}

/* Password hint pills */
.stremzi-wrap .stremzi-pwd-hints {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 14px !important;
  margin: 10px 0 0 !important;
  padding: 0 !important;
  font-size: 12px !important;
  color: #64748b !important;
}
.stremzi-wrap .stremzi-pwd-hints span {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  line-height: 1.2 !important;
  margin: 0 !important;
  padding: 0 !important;
  color: #64748b !important;
}
.stremzi-wrap .stremzi-pwd-hints span::before {
  content: "" !important;
  display: inline-block !important;
  width: 8px !important;
  height: 8px !important;
  border-radius: 50% !important;
  background: #e2e8f0 !important;
  flex-shrink: 0 !important;
  transition: background-color .15s !important;
}
.stremzi-wrap .stremzi-pwd-hints span.ok { color: #16a34a !important; }
.stremzi-wrap .stremzi-pwd-hints span.ok::before { background: #22c55e !important; }

/* =========================================================================
   Terms of Service — native checkbox styled with custom SVG for reliable
   cross-theme appearance. `accent-color` isn't enough when the theme forces
   `filter: grayscale()` or similar.
   ========================================================================= */
.stremzi-wrap .stremzi-tos {
  display: flex !important;
  align-items: flex-start !important;
  gap: 12px !important;
  margin: 22px 0 18px !important;
  padding: 0 !important;
  cursor: pointer !important;
}
.stremzi-wrap .stremzi-tos input[type="checkbox"] {
  display: inline-block !important;
  width: 20px !important;
  height: 20px !important;
  min-width: 20px !important;
  margin: 1px 0 0 !important;
  padding: 0 !important;
  cursor: pointer !important;
  flex-shrink: 0 !important;
  position: relative !important;
  appearance: none !important;
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  vertical-align: top !important;
  background: #ffffff !important;
  background-color: #ffffff !important;
  background-image: none !important;
  border: 1.5px solid #cbd5e1 !important;
  border-radius: 5px !important;
  box-shadow: none !important;
  outline: none !important;
  transition: background-color .15s, border-color .15s !important;
  filter: none !important;
}
.stremzi-wrap .stremzi-tos input[type="checkbox"]:checked {
  background: #0ea5e9 !important;
  background-color: #0ea5e9 !important;
  border-color: #0ea5e9 !important;
  /* Inline SVG checkmark — survives any theme manipulation */
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='none' stroke='%23ffffff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='4 10 8 14 16 6'/></svg>") !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  background-size: 14px 14px !important;
}
.stremzi-wrap .stremzi-tos input[type="checkbox"]:focus-visible {
  box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.25) !important;
  border-color: #0ea5e9 !important;
}
.stremzi-wrap .stremzi-tos-text {
  display: block !important;
  color: #334155 !important;
  font-size: 14px !important;
  line-height: 1.5 !important;
  cursor: pointer !important;
  user-select: none;
  flex: 1;
}
.stremzi-wrap .stremzi-tos-text a {
  color: #0ea5e9 !important;
  text-decoration: none !important;
  font-weight: 500 !important;
}
.stremzi-wrap .stremzi-tos-text a:hover { text-decoration: underline !important; }

/* v1.5.22: implicit consent text (replaces .stremzi-tos checkbox variant) */
.stremzi-wrap .stremzi-consent {
  display: block !important;
  margin: 14px 0 10px !important;
  padding: 0 !important;
  color: #64748b !important;
  font-size: 13px !important;
  line-height: 1.5 !important;
  text-align: center !important;
  font-weight: 400 !important;
}
.stremzi-wrap .stremzi-consent a {
  color: #0ea5e9 !important;
  text-decoration: none !important;
  font-weight: 500 !important;
}
.stremzi-wrap .stremzi-consent a:hover { text-decoration: underline !important; }

/* v1.5.23: Turnstile wrapper — centers widget in the card, gives consistent
   spacing, and the inner widget is forced to light theme via data attrs. */
.stremzi-wrap .stremzi-turnstile-wrap {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  margin: 12px 0 !important;
  padding: 0 !important;
  min-height: 65px !important;
}
.stremzi-wrap .stremzi-turnstile {
  display: inline-block !important;
  max-width: 100% !important;
}
.stremzi-wrap .stremzi-turnstile iframe {
  border-radius: 10px !important;
  overflow: hidden !important;
  max-width: 100% !important;
}

/* =========================================================================
   Button
   ========================================================================= */
.stremzi-wrap .stremzi-card .stremzi-btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 10px !important;
  width: 100% !important;
  padding: 16px 22px !important;
  background: linear-gradient(135deg, #7dd3fc 0%, #0ea5e9 100%) !important;
  color: #ffffff !important;
  border: none !important;
  border-radius: 999px !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  cursor: pointer !important;
  margin: 8px 0 0 !important;
  transition: transform .1s, box-shadow .2s, opacity .2s !important;
  box-shadow: 0 6px 20px rgba(14, 165, 233, 0.3) !important;
  font-family: inherit !important;
  letter-spacing: 0.2px !important;
  line-height: 1 !important;
  text-transform: none !important;
  text-decoration: none !important;
  height: auto !important;
  min-height: 52px !important;
  -webkit-appearance: none !important;
  appearance: none !important;
}
.stremzi-wrap .stremzi-card .stremzi-btn:hover:not(:disabled) {
  transform: translateY(-1px) !important;
  box-shadow: 0 10px 28px rgba(14, 165, 233, 0.4) !important;
  color: #fff !important;
}
.stremzi-wrap .stremzi-card .stremzi-btn:active:not(:disabled) { transform: translateY(0) !important; }
.stremzi-wrap .stremzi-card .stremzi-btn:disabled {
  opacity: .6 !important;
  cursor: not-allowed !important;
  transform: none !important;
}
.stremzi-wrap .stremzi-card .stremzi-btn svg {
  display: inline-block !important;
  width: 16px !important;
  height: 16px !important;
  stroke: currentColor !important;
  fill: none !important;
}

.stremzi-wrap .stremzi-footer-link {
  display: block !important;
  text-align: center !important;
  margin: 22px 0 0 !important;
  color: #64748b !important;
  font-size: 14px !important;
  line-height: 1.5 !important;
}
.stremzi-wrap .stremzi-footer-link a {
  color: #0ea5e9 !important;
  font-weight: 600 !important;
  text-decoration: none !important;
  margin-left: 4px !important;
}
.stremzi-wrap .stremzi-footer-link a:hover { text-decoration: underline !important; }

/* =========================================================================
   Feedback
   ========================================================================= */
.stremzi-wrap .stremzi-error {
  display: block !important;
  background: #fef2f2 !important;
  color: #b91c1c !important;
  padding: 12px 16px !important;
  border-radius: 12px !important;
  margin: 0 0 18px !important;
  font-size: 14px !important;
  border: 1px solid #fecaca !important;
  line-height: 1.4 !important;
}
.stremzi-wrap .stremzi-success {
  display: block !important;
  background: #f0fdf4 !important;
  color: #166534 !important;
  padding: 12px 16px !important;
  border-radius: 12px !important;
  margin: 0 0 18px !important;
  font-size: 14px !important;
  border: 1px solid #bbf7d0 !important;
  line-height: 1.4 !important;
}

/* =========================================================================
   OTP digit boxes
   ========================================================================= */
.stremzi-wrap .stremzi-otp {
  display: flex !important;
  gap: 10px !important;
  justify-content: center !important;
  align-items: center !important;
  margin: 24px 0 !important;
  padding: 0 !important;
  flex-wrap: nowrap !important;
}
.stremzi-wrap .stremzi-card .stremzi-otp input {
  width: 52px !important;
  height: 60px !important;
  min-height: 60px !important;
  text-align: center !important;
  font-size: 26px !important;
  font-weight: 700 !important;
  padding: 0 !important;
  border-radius: 14px !important;
  border: 1.5px solid #e2e8f0 !important;
  color: #0e1a2b !important;
  background: #f8fbff !important;
  line-height: 1 !important;
  max-width: 52px !important;
}
.stremzi-wrap .stremzi-card .stremzi-otp input:focus {
  border-color: #0ea5e9 !important;
  background: #fff !important;
  box-shadow: 0 0 0 4px rgba(14, 165, 233, 0.15) !important;
}
.stremzi-wrap .stremzi-otp-sep {
  display: inline-block !important;
  color: #cbd5e1 !important;
  font-size: 22px !important;
  font-weight: 300 !important;
  line-height: 1 !important;
  user-select: none !important;
}

/* =========================================================================
   Dashboard
   ========================================================================= */
.stremzi-wrap .stremzi-grid {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 12px !important;
  margin: 16px 0 0 !important;
}
.stremzi-wrap .stremzi-grid > div {
  display: block !important;
  background: #f8fbff !important;
  padding: 14px 16px !important;
  border-radius: 14px !important;
  border: 1px solid #e2e8f0 !important;
  min-width: 0 !important;
}
.stremzi-wrap .stremzi-grid small {
  display: block !important;
  color: #94a3b8 !important;
  font-size: 11px !important;
  text-transform: uppercase !important;
  font-weight: 600 !important;
  letter-spacing: 0.5px !important;
  margin: 0 0 4px !important;
}
.stremzi-wrap .stremzi-grid code {
  display: block !important;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace !important;
  font-size: 13px !important;
  color: #0e1a2b !important;
  background: transparent !important;
  padding: 0 !important;
  margin: 0 !important;
  word-break: break-all !important;
}

/* =========================================================================
   Responsive
   ========================================================================= */
@media (max-width: 560px) {
  .stremzi-wrap .stremzi-card { margin: 16px !important; border-radius: 20px !important; }
  .stremzi-wrap .stremzi-hero { padding: 28px 20px 22px !important; }
  .stremzi-wrap .stremzi-body { padding: 22px 20px 26px !important; }
  .stremzi-wrap .stremzi-title { font-size: 24px !important; }
  .stremzi-wrap .stremzi-perks { grid-template-columns: 1fr !important; }
  .stremzi-wrap .stremzi-card .stremzi-otp input { width: 44px !important; height: 52px !important; min-height: 52px !important; font-size: 22px !important; max-width: 44px !important; }
  .stremzi-wrap .stremzi-grid { grid-template-columns: 1fr !important; }
}

/* =========================================================================
   v1.5.0 — DASHBOARD additions
   ========================================================================= */

/* Tier badges (used across signup, dashboard, pricing) */
.stremzi-wrap .stremzi-tier-badge {
  display: inline-block !important;
  padding: 4px 10px !important;
  border-radius: 999px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  line-height: 1 !important;
  vertical-align: middle !important;
}
.stremzi-wrap .stremzi-tier-badge-premium {
  background: linear-gradient(135deg, #fbbf24 0%, #f59e0b 100%) !important;
  color: #422006 !important;
}
.stremzi-wrap .stremzi-tier-badge-standard {
  background: linear-gradient(135deg, #38bdf8 0%, #0ea5e9 100%) !important;
  color: #082f49 !important;
}
.stremzi-wrap .stremzi-tier-badge-custom,
.stremzi-wrap .stremzi-tier-badge-trial {
  background: #e2e8f0 !important;
  color: #334155 !important;
}

/* Signup tier switcher */
.stremzi-wrap .stremzi-tier-switch {
  text-align: center !important;
  font-size: 13px !important;
  color: #64748b !important;
  margin: 12px 0 0 !important;
  padding: 10px 0 !important;
  border-top: 1px dashed #e2e8f0 !important;
}
.stremzi-wrap .stremzi-tier-switch a {
  color: #0ea5e9 !important;
  text-decoration: none !important;
  font-weight: 600 !important;
}
.stremzi-wrap .stremzi-tier-switch a:hover { text-decoration: underline !important; }

/* =========================================================================
   Dashboard layout
   ========================================================================= */
.stremzi-wrap .stremzi-dash {
  max-width: 960px !important;
  margin: 20px auto !important;
  padding: 0 16px !important;
}

/* Header */
.stremzi-wrap .stremzi-dash-header {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 16px !important;
  margin-bottom: 24px !important;
  flex-wrap: wrap !important;
}
.stremzi-wrap .stremzi-dash-title {
  margin: 0 !important;
  font-size: 28px !important;
  font-weight: 800 !important;
  color: #0e1a2b !important;
  letter-spacing: -0.5px !important;
}
.stremzi-wrap .stremzi-dash-subtitle {
  margin: 4px 0 0 !important;
  font-size: 14px !important;
  color: #64748b !important;
}
.stremzi-wrap .stremzi-dash-header-actions {
  display: flex !important;
  gap: 10px !important;
  align-items: center !important;
}

/* v1.5.82: dashboard header buttons — primary pill + ghost, both with
   text-decoration hard-killed against Brisk/UiCore themes that underline
   every <a> in "reading content". */
.stremzi-wrap .stremzi-dash-header-actions .stremzi-btn,
.stremzi-wrap .stremzi-dash-header-actions a.stremzi-btn,
.stremzi-wrap .stremzi-dash-header-actions a.stremzi-btn:hover,
.stremzi-wrap .stremzi-dash-header-actions a.stremzi-btn:focus,
.stremzi-wrap .stremzi-dash-header-actions a.stremzi-btn:active,
.stremzi-wrap .stremzi-dash-header-actions a.stremzi-btn:visited {
  text-decoration: none !important;
  box-shadow: none !important;
  background-image: none !important;
}
.stremzi-wrap .stremzi-dash-header-actions a.stremzi-btn-primary,
.stremzi-wrap .stremzi-dash-header-actions a.stremzi-btn-primary:hover,
.stremzi-wrap .stremzi-dash-header-actions a.stremzi-btn-primary:focus,
.stremzi-wrap .stremzi-dash-header-actions a.stremzi-btn-primary:visited {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 6px !important;
  padding: 9px 16px !important;
  min-height: 38px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  line-height: 1 !important;
  color: #ffffff !important;
  background: var(--stremzi-brand-primary, #0ea5e9) !important;
  border: 0 !important;
  border-radius: 999px !important;
  box-shadow: 0 1px 2px rgba(14, 165, 233, 0.25) !important;
  transition: background 0.15s ease, transform 0.1s ease, box-shadow 0.15s ease !important;
  white-space: nowrap !important;
  text-decoration: none !important;
  letter-spacing: 0 !important;
}
.stremzi-wrap .stremzi-dash-header-actions a.stremzi-btn-primary:hover {
  background: var(--stremzi-brand-primary-hover, #0284c7) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 4px 10px rgba(14, 165, 233, 0.3) !important;
  color: #ffffff !important;
}
.stremzi-wrap .stremzi-dash-header-actions a.stremzi-btn-primary:active {
  transform: translateY(0) !important;
}
.stremzi-wrap .stremzi-dash-header-actions a.stremzi-btn-primary svg {
  width: 14px !important;
  height: 14px !important;
  stroke: currentColor !important;
  flex-shrink: 0 !important;
}
.stremzi-wrap .stremzi-dash-header-actions #stremzi-logout {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 9px 16px !important;
  min-height: 38px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  line-height: 1 !important;
  color: #334155 !important;
  background: #ffffff !important;
  border: 1px solid #e2e8f0 !important;
  border-radius: 999px !important;
  cursor: pointer !important;
  transition: background 0.15s ease, border-color 0.15s ease !important;
  white-space: nowrap !important;
}
.stremzi-wrap .stremzi-dash-header-actions #stremzi-logout:hover {
  background: #f8fafc !important;
  border-color: #cbd5e1 !important;
}

/* Buttons */
.stremzi-wrap .stremzi-btn-sm {
  padding: 8px 14px !important;
  font-size: 13px !important;
  min-height: 36px !important;
  border-radius: 10px !important;
  gap: 6px !important;
}
.stremzi-wrap .stremzi-btn-xs {
  padding: 6px 10px !important;
  font-size: 12px !important;
  min-height: 30px !important;
  border-radius: 8px !important;
}
.stremzi-wrap .stremzi-btn-primary {
  background: #0ea5e9 !important;
  color: #fff !important;
  border: 1px solid #0284c7 !important;
  box-shadow: 0 1px 2px rgba(14,165,233,0.15) !important;
}
.stremzi-wrap .stremzi-btn-primary:hover { background: #0284c7 !important; }
.stremzi-wrap .stremzi-btn-ghost {
  background: #fff !important;
  color: #334155 !important;
  border: 1px solid #e2e8f0 !important;
}
.stremzi-wrap .stremzi-btn-ghost:hover { background: #f8fafc !important; border-color: #cbd5e1 !important; }
.stremzi-wrap .stremzi-btn-block { display: flex !important; width: 100% !important; justify-content: center !important; }
.stremzi-wrap .stremzi-btn-ic { margin-right: 4px !important; }

/* Loading skeleton */
.stremzi-wrap .stremzi-dash-loading {
  display: flex !important;
  flex-direction: column !important;
  gap: 16px !important;
}
.stremzi-wrap .stremzi-skeleton-card {
  height: 200px !important;
  border-radius: 16px !important;
  background: linear-gradient(90deg, #f1f5f9 0%, #e2e8f0 50%, #f1f5f9 100%) !important;
  background-size: 200% 100% !important;
  animation: stremzi-skeleton 1.5s ease-in-out infinite !important;
}
@keyframes stremzi-skeleton {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* Empty states */
.stremzi-wrap .stremzi-empty {
  text-align: center !important;
  padding: 60px 24px !important;
  background: #fff !important;
  border-radius: 20px !important;
  border: 1px solid #e2e8f0 !important;
}
.stremzi-wrap .stremzi-empty-ic {
  font-size: 48px !important;
  margin-bottom: 12px !important;
}
.stremzi-wrap .stremzi-empty h3 {
  margin: 0 0 8px !important;
  font-size: 22px !important;
  font-weight: 700 !important;
  color: #0e1a2b !important;
}
.stremzi-wrap .stremzi-empty p {
  color: #64748b !important;
  margin: 0 0 20px !important;
}
.stremzi-wrap .stremzi-empty-actions {
  display: flex !important;
  gap: 10px !important;
  justify-content: center !important;
  flex-wrap: wrap !important;
}
.stremzi-wrap .stremzi-empty-inline {
  padding: 20px !important;
  text-align: center !important;
  color: #94a3b8 !important;
  font-size: 14px !important;
}

/* =========================================================================
   Subscription cards
   ========================================================================= */
.stremzi-wrap .stremzi-subs-list {
  display: flex !important;
  flex-direction: column !important;
  gap: 16px !important;
  margin-bottom: 32px !important;
}
.stremzi-wrap .stremzi-sub-card {
  background: #fff !important;
  border-radius: 16px !important;
  border: 1px solid #e2e8f0 !important;
  overflow: hidden !important;
  box-shadow: 0 2px 8px rgba(15,23,42,0.04) !important;
}
.stremzi-wrap .stremzi-sub-active {
  border-left: 4px solid #22c55e !important;
}
.stremzi-wrap .stremzi-sub-ghost {
  border-left: 4px solid #f59e0b !important;
  background: #fffbeb !important;
}
.stremzi-wrap .stremzi-sub-expired {
  border-left: 4px solid #94a3b8 !important;
  opacity: 0.85 !important;
}

.stremzi-wrap .stremzi-sub-header {
  display: flex !important;
  justify-content: space-between !important;
  align-items: flex-start !important;
  gap: 16px !important;
  padding: 16px 20px !important;
  border-bottom: 1px solid #f1f5f9 !important;
  flex-wrap: wrap !important;
}
.stremzi-wrap .stremzi-sub-header-left h3 {
  margin: 0 0 6px !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  color: #0e1a2b !important;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace !important;
}
.stremzi-wrap .stremzi-sub-meta {
  display: flex !important;
  gap: 8px !important;
  align-items: center !important;
  flex-wrap: wrap !important;
}
/* v1.5.79: header-right column — Extend pill on top, countdown below */
.stremzi-wrap .stremzi-sub-header-right {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-end !important;
  gap: 10px !important;
  min-width: 140px !important;
}

/* v1.5.79: Extend button — primary pill, compact, not ghost */
.stremzi-wrap .stremzi-btn.stremzi-btn-extend {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 6px !important;
  padding: 8px 16px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  line-height: 1 !important;
  color: #ffffff !important;
  background: var(--stremzi-brand-primary, #0ea5e9) !important;
  border: 0 !important;
  border-radius: 999px !important;
  cursor: pointer !important;
  box-shadow: 0 1px 2px rgba(14, 165, 233, 0.25) !important;
  transition: background 0.15s ease, transform 0.1s ease !important;
  white-space: nowrap !important;
}
.stremzi-wrap .stremzi-btn.stremzi-btn-extend:hover {
  background: var(--stremzi-brand-primary-hover, #0284c7) !important;
  transform: translateY(-1px) !important;
}
.stremzi-wrap .stremzi-btn.stremzi-btn-extend:active {
  transform: translateY(0) !important;
}
.stremzi-wrap .stremzi-btn.stremzi-btn-extend .stremzi-btn-ic {
  font-size: 14px !important;
  line-height: 1 !important;
}

.stremzi-wrap .stremzi-status {
  display: inline-block !important;
  padding: 3px 10px !important;
  border-radius: 999px !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
}
.stremzi-wrap .stremzi-status-active { background: #dcfce7 !important; color: #166534 !important; }
.stremzi-wrap .stremzi-status-ghost  { background: #fef3c7 !important; color: #92400e !important; }
.stremzi-wrap .stremzi-status-expired { background: #f1f5f9 !important; color: #64748b !important; }

/* Countdown — v1.5.79 redesigned: tight mono block, single subtle label */
.stremzi-wrap .stremzi-countdown {
  text-align: right !important;
  min-width: 0 !important;
}
.stremzi-wrap .stremzi-countdown-label {
  font-size: 10px !important;
  color: #94a3b8 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.8px !important;
  font-weight: 600 !important;
  margin-bottom: 3px !important;
  line-height: 1 !important;
}
.stremzi-wrap .stremzi-countdown-value {
  font-size: 18px !important;
  font-weight: 700 !important;
  color: #0e1a2b !important;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace !important;
  line-height: 1.1 !important;
  font-variant-numeric: tabular-nums !important;
  white-space: nowrap !important;
}
.stremzi-wrap .stremzi-countdown-unit {
  font-size: 11px !important;
  font-weight: 600 !important;
  color: #64748b !important;
  margin-left: 1px !important;
  margin-right: 3px !important;
}
/* Legacy support - in case old markup is still rendered somewhere */
.stremzi-wrap .stremzi-countdown-values {
  display: flex !important;
  gap: 8px !important;
  justify-content: flex-end !important;
  font-size: 13px !important;
  color: #475569 !important;
}
.stremzi-wrap .stremzi-countdown-values b {
  font-size: 18px !important;
  color: #0e1a2b !important;
  font-weight: 800 !important;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace !important;
}
.stremzi-wrap .stremzi-countdown-expired {
  color: #ef4444 !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  font-size: 13px !important;
}

/* Sub body */
.stremzi-wrap .stremzi-sub-body { padding: 20px !important; }

.stremzi-wrap .stremzi-creds-grid {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 12px !important;
  margin-bottom: 16px !important;
}
.stremzi-wrap .stremzi-cred-field {
  background: #f8fafc !important;
  border: 1px solid #e2e8f0 !important;
  padding: 10px 14px !important;
  border-radius: 10px !important;
  min-width: 0 !important;
}
.stremzi-wrap .stremzi-cred-label {
  font-size: 10px !important;
  color: #94a3b8 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.8px !important;
  font-weight: 600 !important;
  margin-bottom: 4px !important;
}
.stremzi-wrap .stremzi-cred-value-row {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
}
.stremzi-wrap .stremzi-cred-value {
  flex: 1 !important;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace !important;
  font-size: 13px !important;
  color: #0e1a2b !important;
  background: transparent !important;
  padding: 0 !important;
  word-break: break-all !important;
  overflow-wrap: break-word !important;
  min-width: 0 !important;
}
.stremzi-wrap .stremzi-icon-btn {
  padding: 4px 6px !important;
  background: transparent !important;
  border: 1px solid transparent !important;
  color: #64748b !important;
  border-radius: 6px !important;
  cursor: pointer !important;
  min-height: auto !important;
  font-size: 12px !important;
  line-height: 1 !important;
  flex-shrink: 0 !important;
}
.stremzi-wrap .stremzi-icon-btn:hover {
  background: #e2e8f0 !important;
  color: #0e1a2b !important;
  border-color: #cbd5e1 !important;
}

.stremzi-wrap .stremzi-m3u-row { margin-bottom: 16px !important; }
.stremzi-wrap .stremzi-m3u-row .stremzi-cred-field { max-width: 100% !important; }

.stremzi-wrap .stremzi-sub-actions {
  display: flex !important;
  gap: 8px !important;
  flex-wrap: wrap !important;
  padding-top: 12px !important;
  border-top: 1px dashed #e2e8f0 !important;
}

/* v1.5.26: Ghost (pending provisioning) — compact friendly card
   ────────────────────────────────────────────────────────────────
   Replaces the previous amber "recovery" warning. The earlier UI
   showed raw error reasons and intimidated customers. The new one
   is a small horizontal strip: icon, two short lines, prominent
   Retry button. No scary wording, no technical details exposed. */
.stremzi-wrap .stremzi-ghost {
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  padding: 14px 16px !important;
  background: #f8fafc !important;
  border: 1px solid #e2e8f0 !important;
  border-radius: 12px !important;
}
.stremzi-wrap .stremzi-ghost-ic {
  flex-shrink: 0 !important;
  width: 40px !important;
  height: 40px !important;
  border-radius: 10px !important;
  background: #eef2ff !important;
  color: #6366f1 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}
.stremzi-wrap .stremzi-ghost-ic svg {
  width: 20px !important;
  height: 20px !important;
  animation: stremzi-spin 2s linear infinite !important;
}
@keyframes stremzi-spin {
  0%   { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}
.stremzi-wrap .stremzi-ghost-body {
  flex: 1 !important;
  min-width: 0 !important;
}
.stremzi-wrap .stremzi-ghost-title {
  margin: 0 0 2px !important;
  color: #0f172a !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  line-height: 1.3 !important;
}
.stremzi-wrap .stremzi-ghost-sub {
  margin: 0 !important;
  color: #64748b !important;
  font-size: 13px !important;
  line-height: 1.4 !important;
}
.stremzi-wrap .stremzi-ghost-retry {
  flex-shrink: 0 !important;
  padding: 10px 18px !important;
  font-size: 13px !important;
  white-space: nowrap !important;
}
@media (max-width: 520px) {
  .stremzi-wrap .stremzi-ghost {
    flex-wrap: wrap !important;
  }
  .stremzi-wrap .stremzi-ghost-retry {
    width: 100% !important;
    justify-content: center !important;
    margin-top: 4px !important;
  }
}

/* Legacy class kept for any lingering references (won't render in new UI) */
.stremzi-wrap .stremzi-ghost-notice,
.stremzi-wrap .stremzi-ghost-reason { display: none !important; }

.stremzi-wrap .stremzi-muted { color: #94a3b8 !important; font-style: italic !important; margin: 0 !important; }

/* =========================================================================
   Invoices
   ========================================================================= */
.stremzi-wrap .stremzi-invoices-section {
  background: #fff !important;
  border-radius: 16px !important;
  border: 1px solid #e2e8f0 !important;
  padding: 20px !important;
  margin-top: 24px !important;
}
.stremzi-wrap .stremzi-section-header {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  margin-bottom: 16px !important;
}
.stremzi-wrap .stremzi-section-header h2 {
  margin: 0 !important;
  font-size: 18px !important;
  font-weight: 700 !important;
  color: #0e1a2b !important;
}
.stremzi-wrap .stremzi-invoices-list {
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
}
.stremzi-wrap .stremzi-invoice-row {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  padding: 12px 14px !important;
  background: #f8fafc !important;
  border-radius: 10px !important;
  flex-wrap: wrap !important;
}
.stremzi-wrap .stremzi-invoice-main { flex: 1 !important; min-width: 180px !important; }
.stremzi-wrap .stremzi-invoice-num {
  font-weight: 700 !important;
  color: #0e1a2b !important;
  font-size: 14px !important;
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
}
.stremzi-wrap .stremzi-invoice-meta {
  font-size: 12px !important;
  color: #64748b !important;
  margin-top: 2px !important;
}
.stremzi-wrap .stremzi-invoice-badge {
  display: inline-block !important;
  padding: 2px 8px !important;
  border-radius: 6px !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
}
.stremzi-wrap .stremzi-invoice-badge-trial { background: #e0f2fe !important; color: #075985 !important; }
.stremzi-wrap .stremzi-invoice-badge-paid  { background: #dcfce7 !important; color: #166534 !important; }
.stremzi-wrap .stremzi-invoice-total {
  font-weight: 700 !important;
  font-size: 14px !important;
  color: #0e1a2b !important;
  min-width: 80px !important;
  text-align: right !important;
}
.stremzi-wrap .stremzi-invoice-status {
  font-size: 11px !important;
  padding: 2px 8px !important;
  border-radius: 6px !important;
  text-transform: capitalize !important;
  background: #f1f5f9 !important;
  color: #64748b !important;
}
.stremzi-wrap .stremzi-invoice-status.stremzi-status-completed { background: #dcfce7 !important; color: #166534 !important; }
.stremzi-wrap .stremzi-invoice-status.stremzi-status-on-hold   { background: #fef3c7 !important; color: #92400e !important; }
.stremzi-wrap .stremzi-invoice-status.stremzi-status-pending   { background: #e0f2fe !important; color: #075985 !important; }
.stremzi-wrap .stremzi-invoices-loading {
  text-align: center !important;
  padding: 20px !important;
  color: #94a3b8 !important;
  font-size: 13px !important;
}

/* =========================================================================
   Modals
   ========================================================================= */
.stremzi-wrap .stremzi-modal,
.stremzi-modal {
  position: fixed !important;
  inset: 0 !important;
  z-index: 999999 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 20px !important;
}
.stremzi-modal[hidden] { display: none !important; }
.stremzi-modal-backdrop {
  position: absolute !important;
  inset: 0 !important;
  background: rgba(15, 23, 42, 0.55) !important;
  backdrop-filter: blur(2px) !important;
}
.stremzi-modal-box {
  position: relative !important;
  background: #fff !important;
  border-radius: 20px !important;
  width: 100% !important;
  max-width: 520px !important;
  max-height: 90vh !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
  box-shadow: 0 20px 50px rgba(15,23,42,0.3) !important;
  font-family: inherit !important;
  color: #0e1a2b !important;
}
.stremzi-modal-box-sm { max-width: 360px !important; }
.stremzi-modal-header {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  padding: 18px 22px !important;
  border-bottom: 1px solid #e2e8f0 !important;
}
.stremzi-modal-header h3 {
  margin: 0 !important;
  font-size: 18px !important;
  font-weight: 700 !important;
  color: #0e1a2b !important;
}
.stremzi-modal-close {
  background: transparent !important;
  border: none !important;
  color: #64748b !important;
  font-size: 28px !important;
  line-height: 1 !important;
  cursor: pointer !important;
  padding: 0 8px !important;
  min-height: auto !important;
}
.stremzi-modal-close:hover { color: #0e1a2b !important; }
.stremzi-modal-body {
  padding: 20px 22px !important;
  overflow-y: auto !important;
  flex: 1 !important;
}
.stremzi-modal-intro {
  color: #64748b !important;
  font-size: 14px !important;
  margin: 0 0 16px !important;
  line-height: 1.5 !important;
}

/* Extend packages */
.stremzi-wrap .stremzi-extend-packages,
.stremzi-extend-packages {
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
}

/* v1.5.96: outer tier tabs (Premium / Standard) above device tabs.
   Larger, bolder than inner device tabs so the hierarchy is clear. */
.stremzi-wrap .stremzi-extend-tier-tabs {
  display: flex !important;
  gap: 0 !important;
  margin-bottom: 14px !important;
  border-bottom: 2px solid #e2e8f0 !important;
  flex-wrap: wrap !important;
  justify-content: center !important;
}
.stremzi-wrap .stremzi-extend-tier-tab {
  padding: 10px 20px !important;
  background: transparent !important;
  border: 0 !important;
  border-bottom: 2px solid transparent !important;
  margin-bottom: -2px !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  color: #64748b !important;
  cursor: pointer !important;
  transition: color 0.15s ease, border-color 0.15s ease !important;
  white-space: nowrap !important;
  text-decoration: none !important;
}
.stremzi-wrap .stremzi-extend-tier-tab:hover { color: #0e1a2b !important; }
.stremzi-wrap .stremzi-extend-tier-tab.is-active {
  color: var(--stremzi-brand-primary, #0ea5e9) !important;
  border-bottom-color: var(--stremzi-brand-primary, #0ea5e9) !important;
}

/* Tier groups — only the active one renders. Each group contains its
   own device tabs + panes so device selection is scoped per tier. */
.stremzi-wrap .stremzi-extend-tier-group { display: none !important; }
.stremzi-wrap .stremzi-extend-tier-group.is-active { display: block !important; }

/* v1.5.89: device-count tabs for the extend modal (1 device, 2 devices, ...) */
.stremzi-wrap .stremzi-extend-tabs {
  display: flex !important;
  gap: 4px !important;
  padding: 4px !important;
  background: #f1f5f9 !important;
  border-radius: 10px !important;
  margin: 0 auto 14px !important;
  flex-wrap: wrap !important;
  justify-content: center !important;
  width: fit-content !important;
  max-width: 100% !important;
}
.stremzi-wrap .stremzi-extend-tab {
  flex: 1 1 auto !important;
  padding: 8px 14px !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 8px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  color: #64748b !important;
  cursor: pointer !important;
  transition: background 0.15s ease, color 0.15s ease !important;
  white-space: nowrap !important;
  text-decoration: none !important;
  min-width: 0 !important;
}
.stremzi-wrap .stremzi-extend-tab:hover { color: #0e1a2b !important; }
.stremzi-wrap .stremzi-extend-tab.is-active {
  background: #fff !important;
  color: #0e1a2b !important;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.08) !important;
}

/* v1.5.89: tab panes — only the active one is visible */
.stremzi-wrap .stremzi-extend-panes { display: flex !important; flex-direction: column !important; }
.stremzi-wrap .stremzi-extend-pane { display: none !important; flex-direction: column !important; gap: 8px !important; }
.stremzi-wrap .stremzi-extend-pane.is-active { display: flex !important; }

.stremzi-extend-pack {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  padding: 12px 14px !important;
  background: #f8fafc !important;
  border: 1px solid #e2e8f0 !important;
  border-radius: 10px !important;
}
.stremzi-extend-pack-info { flex: 1 !important; min-width: 0 !important; }
.stremzi-extend-pack-info h4 { margin: 0 0 2px !important; font-size: 14px !important; font-weight: 700 !important; color: #0e1a2b !important; }
.stremzi-extend-pack-meta { font-size: 12px !important; color: #64748b !important; }
.stremzi-extend-pack-price {
  font-weight: 700 !important;
  color: #0e1a2b !important;
  font-size: 15px !important;
  min-width: 70px !important;
  text-align: right !important;
}

/* v1.5.89: Buy & extend button — matches dashboard Extend pill shape.
   Hard override for text-decoration since it's an <a> inside theme content. */
.stremzi-wrap .stremzi-extend-pack a.stremzi-extend-buy-btn,
.stremzi-wrap .stremzi-extend-pack a.stremzi-extend-buy-btn:hover,
.stremzi-wrap .stremzi-extend-pack a.stremzi-extend-buy-btn:focus,
.stremzi-wrap .stremzi-extend-pack a.stremzi-extend-buy-btn:active,
.stremzi-wrap .stremzi-extend-pack a.stremzi-extend-buy-btn:visited {
  text-decoration: none !important;
  background-image: none !important;
}
.stremzi-wrap .stremzi-extend-pack a.stremzi-extend-buy-btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 8px 16px !important;
  min-height: 36px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  line-height: 1 !important;
  color: #ffffff !important;
  background: var(--stremzi-brand-primary, #0ea5e9) !important;
  border: 0 !important;
  border-radius: 999px !important;
  box-shadow: 0 1px 2px rgba(14, 165, 233, 0.25) !important;
  transition: background 0.15s ease, transform 0.1s ease, box-shadow 0.15s ease !important;
  white-space: nowrap !important;
  flex-shrink: 0 !important;
}
.stremzi-wrap .stremzi-extend-pack a.stremzi-extend-buy-btn:hover {
  background: var(--stremzi-brand-primary-hover, #0284c7) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 4px 10px rgba(14, 165, 233, 0.3) !important;
}
.stremzi-wrap .stremzi-extend-pack a.stremzi-extend-buy-btn:active { transform: translateY(0) !important; }

/* Bouquet list */
.stremzi-bouquet-list {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
}
.stremzi-bouquet-list li {
  padding: 10px 14px !important;
  background: #f8fafc !important;
  border-radius: 8px !important;
  font-size: 14px !important;
  color: #334155 !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
}
.stremzi-bouquet-dot {
  width: 8px !important;
  height: 8px !important;
  background: #0ea5e9 !important;
  border-radius: 50% !important;
  display: inline-block !important;
}

/* QR + deeplinks */
.stremzi-qr-container {
  display: flex !important;
  justify-content: center !important;
  margin: 10px 0 18px !important;
  padding: 14px !important;
  background: #fff !important;
  border: 1px solid #e2e8f0 !important;
  border-radius: 12px !important;
}
.stremzi-qr-container svg,
.stremzi-qr-container img {
  display: block !important;
  width: 240px !important;
  height: 240px !important;
  max-width: 100% !important;
}
.stremzi-qr-help { text-align: center !important; color: #64748b !important; font-size: 13px !important; margin: 0 0 18px !important; }
.stremzi-deeplinks { border-top: 1px solid #e2e8f0 !important; padding-top: 14px !important; }
.stremzi-deeplinks-header {
  margin: 0 0 10px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  color: #475569 !important;
  text-align: center !important;
}
.stremzi-deeplinks-grid {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 8px !important;
}
.stremzi-deeplink {
  padding: 10px !important;
  text-align: center !important;
  background: #f8fafc !important;
  border: 1px solid #e2e8f0 !important;
  border-radius: 10px !important;
  color: #0e1a2b !important;
  text-decoration: none !important;
  font-size: 13px !important;
  font-weight: 600 !important;
}
.stremzi-deeplink:hover { background: #e2e8f0 !important; }

/* =========================================================================
   Toast
   ========================================================================= */
.stremzi-toast {
  position: fixed !important;
  bottom: 20px !important;
  left: 50% !important;
  transform: translateX(-50%) translateY(20px) !important;
  z-index: 9999999 !important;
  padding: 12px 20px !important;
  border-radius: 12px !important;
  background: #0e1a2b !important;
  color: #fff !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  box-shadow: 0 10px 30px rgba(0,0,0,0.3) !important;
  opacity: 0 !important;
  transition: all 0.3s ease !important;
  font-family: inherit !important;
  pointer-events: none !important;
}
.stremzi-toast-in { opacity: 1 !important; transform: translateX(-50%) translateY(0) !important; }
.stremzi-toast-success { background: #16a34a !important; }
.stremzi-toast-error   { background: #dc2626 !important; }

/* =========================================================================
   Pricing page
   ========================================================================= */
.stremzi-wrap .stremzi-pricing {
  max-width: 1100px !important;
  margin: 20px auto !important;
  padding: 0 16px !important;
}
.stremzi-wrap .stremzi-pricing-header {
  text-align: center !important;
  margin-bottom: 40px !important;
}
.stremzi-wrap .stremzi-pricing-header h1 {
  margin: 0 0 10px !important;
  font-size: 36px !important;
  font-weight: 800 !important;
  color: #0e1a2b !important;
  letter-spacing: -1px !important;
}
.stremzi-wrap .stremzi-pricing-header p {
  margin: 0 !important;
  font-size: 16px !important;
  color: #64748b !important;
}
.stremzi-wrap .stremzi-pricing-group { margin-bottom: 40px !important; }
.stremzi-wrap .stremzi-pricing-group-title {
  display: inline-block !important;
  margin: 0 0 20px !important;
  padding: 6px 16px !important;
  font-size: 14px !important;
}
.stremzi-wrap .stremzi-pricing-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)) !important;
  gap: 20px !important;
}
.stremzi-wrap .stremzi-price-card {
  background: #fff !important;
  border-radius: 20px !important;
  border: 1px solid #e2e8f0 !important;
  overflow: hidden !important;
  box-shadow: 0 2px 10px rgba(15,23,42,0.04) !important;
  transition: transform 0.2s ease, box-shadow 0.2s ease !important;
}
.stremzi-wrap .stremzi-price-card:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 12px 30px rgba(15,23,42,0.1) !important;
}
.stremzi-wrap .stremzi-price-card.stremzi-tier-premium {
  border: 2px solid #f59e0b !important;
  position: relative !important;
}
.stremzi-wrap .stremzi-price-card-header {
  padding: 20px 24px !important;
  background: linear-gradient(135deg, #f8fafc 0%, #f1f5f9 100%) !important;
  border-bottom: 1px solid #e2e8f0 !important;
}
.stremzi-wrap .stremzi-tier-premium .stremzi-price-card-header {
  background: linear-gradient(135deg, #fef3c7 0%, #fde68a 100%) !important;
}
.stremzi-wrap .stremzi-price-card-header h3 {
  margin: 0 0 4px !important;
  font-size: 18px !important;
  font-weight: 700 !important;
  color: #0e1a2b !important;
}
.stremzi-wrap .stremzi-price-duration {
  font-size: 13px !important;
  color: #64748b !important;
}
.stremzi-wrap .stremzi-price-card-body { padding: 24px !important; }
.stremzi-wrap .stremzi-price-amount {
  font-size: 32px !important;
  font-weight: 800 !important;
  color: #0e1a2b !important;
  margin-bottom: 20px !important;
  text-align: center !important;
}
.stremzi-wrap .stremzi-price-amount .woocommerce-Price-amount { color: #0e1a2b !important; font-weight: 800 !important; }
.stremzi-wrap .stremzi-price-free { font-size: 16px !important; color: #64748b !important; font-weight: 600 !important; }
.stremzi-wrap .stremzi-price-features {
  list-style: none !important;
  margin: 0 0 24px !important;
  padding: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
}
.stremzi-wrap .stremzi-price-features li {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  font-size: 14px !important;
  color: #334155 !important;
}
.stremzi-wrap .stremzi-price-features li::before {
  content: '✓' !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 18px !important;
  height: 18px !important;
  background: #dcfce7 !important;
  color: #166534 !important;
  border-radius: 50% !important;
  font-weight: 700 !important;
  font-size: 11px !important;
  flex-shrink: 0 !important;
}

/* =========================================================================
   Mobile
   ========================================================================= */
@media (max-width: 640px) {
  .stremzi-wrap .stremzi-dash-title { font-size: 22px !important; }
  .stremzi-wrap .stremzi-creds-grid { grid-template-columns: 1fr !important; }
  .stremzi-wrap .stremzi-sub-header { flex-direction: column !important; gap: 8px !important; align-items: flex-start !important; }
  .stremzi-wrap .stremzi-countdown { text-align: left !important; }
  .stremzi-wrap .stremzi-countdown-values { justify-content: flex-start !important; }
  .stremzi-wrap .stremzi-sub-actions { flex-direction: column !important; }
  .stremzi-wrap .stremzi-sub-actions .stremzi-btn { width: 100% !important; }
  .stremzi-wrap .stremzi-pricing-header h1 { font-size: 28px !important; }
  .stremzi-wrap .stremzi-invoice-row { flex-direction: column !important; align-items: flex-start !important; }
  .stremzi-wrap .stremzi-invoice-total { align-self: flex-end !important; }
}

/* =========================================================================
   v1.5.1 — GLOBAL [hidden] FIX
   Themes (Brisk, UiCore, etc.) often override HTML5 `hidden`'s default
   display:none with `display:block` on generic selectors like `div`.
   We force it back inside our namespaces.
   ========================================================================= */
.stremzi-wrap [hidden],
.stremzi-dash [hidden],
.stremzi-modal[hidden] {
  display: none !important;
}

/* =========================================================================
   v1.5.1 — Device type selector (signup) — short & clean
   ========================================================================= */
.stremzi-wrap .stremzi-device-toggle {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 10px !important;
  margin: 0 0 16px !important;
}
.stremzi-wrap .stremzi-device-opt {
  position: relative !important;
  display: block !important;
  padding: 0 !important;
  border: 2px solid #e2e8f0 !important;
  border-radius: 14px !important;
  cursor: pointer !important;
  background: #fff !important;
  transition: all 0.15s ease !important;
  overflow: hidden !important;
}
.stremzi-wrap .stremzi-device-opt input[type="radio"] {
  position: absolute !important;
  opacity: 0 !important;
  pointer-events: none !important;
}
.stremzi-wrap .stremzi-device-opt:hover {
  border-color: #cbd5e1 !important;
  background: #f8fafc !important;
}
.stremzi-wrap .stremzi-device-opt:has(input:checked) {
  border-color: var(--stremzi-accent, #0ea5e9) !important;
  background: #f0f9ff !important;
  box-shadow: 0 0 0 3px rgba(14,165,233,0.12) !important;
}
.stremzi-wrap .stremzi-device-card {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 6px !important;
  padding: 18px 12px !important;
  text-align: center !important;
}
.stremzi-wrap .stremzi-device-ic {
  font-size: 26px !important;
  line-height: 1 !important;
}
.stremzi-wrap .stremzi-device-title {
  font-weight: 700 !important;
  font-size: 14px !important;
  color: #0e1a2b !important;
  letter-spacing: 0.2px !important;
}

/* MAC field — hidden by default, shown when MAG selected.
   The HTML `hidden` attr handles default; JS adds `.stremzi-device-mag-selected`
   to the parent `.stremzi-card` to reveal it. */
.stremzi-wrap .stremzi-card.stremzi-device-mag-selected .stremzi-mac-field[hidden] {
  display: block !important;
}

/* =========================================================================
   v1.5.1 — MAG subscription card (portal + MAC, no username/pass/m3u)
   ========================================================================= */
.stremzi-wrap .stremzi-device-badge {
  display: inline-flex !important;
  align-items: center !important;
  gap: 4px !important;
  padding: 2px 8px !important;
  border-radius: 6px !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  background: #e0f2fe !important;
  color: #075985 !important;
}
.stremzi-wrap .stremzi-device-badge-mag {
  background: #fef3c7 !important;
  color: #78350f !important;
}

/* =========================================================================
   v1.5.1 — Real channel browser
   ========================================================================= */
.stremzi-channel-browser {
  display: grid !important;
  grid-template-columns: 200px 1fr !important;
  gap: 14px !important;
  min-height: 400px !important;
  max-height: 70vh !important;
}
.stremzi-cat-list {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow-y: auto !important;
  border-right: 1px solid #e2e8f0 !important;
  padding-right: 8px !important;
}
.stremzi-cat-list li {
  padding: 8px 10px !important;
  font-size: 13px !important;
  color: #334155 !important;
  cursor: pointer !important;
  border-radius: 6px !important;
  margin-bottom: 2px !important;
}
.stremzi-cat-list li:hover { background: #f1f5f9 !important; }
.stremzi-cat-list li.active {
  background: #0ea5e9 !important;
  color: #fff !important;
  font-weight: 600 !important;
}
.stremzi-cat-count {
  float: right !important;
  font-size: 11px !important;
  opacity: 0.7 !important;
}
.stremzi-streams {
  overflow-y: auto !important;
  padding-right: 4px !important;
}
.stremzi-stream {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 8px 10px !important;
  border-bottom: 1px solid #f1f5f9 !important;
  font-size: 13px !important;
}
.stremzi-stream-icon {
  width: 32px !important;
  height: 32px !important;
  border-radius: 6px !important;
  object-fit: contain !important;
  background: #f1f5f9 !important;
  flex-shrink: 0 !important;
}
.stremzi-stream-name {
  flex: 1 !important;
  color: #0e1a2b !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}
.stremzi-stream-num {
  color: #94a3b8 !important;
  font-size: 11px !important;
  font-family: ui-monospace, monospace !important;
  min-width: 30px !important;
}
.stremzi-channel-search {
  width: 100% !important;
  padding: 8px 10px !important;
  border: 1px solid #e2e8f0 !important;
  border-radius: 8px !important;
  margin-bottom: 10px !important;
  font-size: 13px !important;
}
@media (max-width: 640px) {
  .stremzi-channel-browser {
    grid-template-columns: 1fr !important;
    max-height: unset !important;
  }
  .stremzi-cat-list {
    border-right: none !important;
    border-bottom: 1px solid #e2e8f0 !important;
    padding: 0 0 8px !important;
    max-height: 200px !important;
  }
}

/* =========================================================================
   v1.5.1 — Category checkbox browser (like the Kenya panel screenshot)
   ========================================================================= */
.stremzi-chan-toolbar {
  display: flex !important;
  gap: 10px !important;
  margin-bottom: 12px !important;
  align-items: center !important;
}
.stremzi-chan-toolbar .stremzi-channel-search {
  flex: 1 !important;
  margin-bottom: 0 !important;
}
.stremzi-chan-actions {
  display: flex !important;
  gap: 6px !important;
}
.stremzi-chan-warning {
  padding: 12px 14px !important;
  border-radius: 10px !important;
  background: #fef3c7 !important;
  border: 1px solid #fde68a !important;
  color: #78350f !important;
  font-size: 13px !important;
  line-height: 1.5 !important;
  margin-bottom: 12px !important;
}
.stremzi-chan-count {
  font-size: 13px !important;
  color: #475569 !important;
  margin-bottom: 10px !important;
  font-weight: 600 !important;
}
.stremzi-cat-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)) !important;
  gap: 6px !important;
  max-height: 50vh !important;
  overflow-y: auto !important;
  padding: 4px !important;
  border: 1px solid #e2e8f0 !important;
  border-radius: 10px !important;
  background: #fafbfc !important;
}
.stremzi-cat-chk {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 8px 10px !important;
  border: 1px solid #e2e8f0 !important;
  border-radius: 8px !important;
  background: #fff !important;
  cursor: pointer !important;
  font-size: 13px !important;
  color: #334155 !important;
  transition: all 0.12s ease !important;
  user-select: none !important;
}
.stremzi-cat-chk:hover {
  border-color: #cbd5e1 !important;
  background: #f8fafc !important;
}
.stremzi-cat-chk.checked {
  border-color: #0ea5e9 !important;
  background: #f0f9ff !important;
  color: #0c4a6e !important;
}
.stremzi-cat-chk input[type="checkbox"] {
  margin: 0 !important;
  width: 16px !important;
  height: 16px !important;
  accent-color: #0ea5e9 !important;
  flex-shrink: 0 !important;
}
.stremzi-cat-chk-name {
  flex: 1 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  font-weight: 500 !important;
}
.stremzi-chan-footer {
  display: flex !important;
  justify-content: space-between !important;
  gap: 10px !important;
  margin-top: 14px !important;
  padding-top: 14px !important;
  border-top: 1px solid #e2e8f0 !important;
}

.stremzi-error-box {
  padding: 16px !important;
  background: #fef2f2 !important;
  border: 1px solid #fecaca !important;
  border-radius: 12px !important;
  color: #7f1d1d !important;
}
.stremzi-error-box h4 { color: #991b1b !important; }
.stremzi-error-box code {
  background: #fff !important;
  padding: 2px 6px !important;
  border-radius: 4px !important;
  font-size: 11px !important;
}

.stremzi-streams-preview { max-height: 60vh; overflow-y: auto; margin-top: 10px; }
.stremzi-preview-cat { margin-bottom: 16px; }
.stremzi-preview-cat h4 {
  margin: 8px 0 !important;
  padding: 6px 10px !important;
  background: #f1f5f9 !important;
  border-radius: 6px !important;
  font-size: 13px !important;
  color: #334155 !important;
}

@media (max-width: 640px) {
  .stremzi-chan-toolbar { flex-wrap: wrap; }
  .stremzi-cat-grid { grid-template-columns: 1fr 1fr; }
}

/* ============================================================
   v1.5.3 — LOGIN PAGE
   ============================================================ */

.stremzi-wrap .stremzi-pwd-wrap {
  position: relative !important;
}
.stremzi-wrap .stremzi-pwd-wrap input[type="password"],
.stremzi-wrap .stremzi-pwd-wrap input[type="text"] {
  padding-right: 44px !important;
  width: 100% !important;
}
.stremzi-wrap .stremzi-pwd-wrap .stremzi-pwd-toggle {
  position: absolute !important;
  right: 10px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  background: transparent !important;
  border: 0 !important;
  padding: 6px !important;
  cursor: pointer !important;
  color: #64748b !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}
.stremzi-wrap .stremzi-pwd-wrap .stremzi-pwd-toggle:hover {
  color: #0ea5e9 !important;
}

.stremzi-wrap .stremzi-login-row {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
  margin: 6px 0 18px !important;
  font-size: 14px !important;
}

.stremzi-wrap .stremzi-check-row {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  color: #334155 !important;
  cursor: pointer !important;
  user-select: none !important;
  margin: 0 !important;
}
.stremzi-wrap .stremzi-check-row input[type="checkbox"] {
  width: 16px !important;
  height: 16px !important;
  margin: 0 !important;
  accent-color: #0ea5e9 !important;
}

.stremzi-wrap .stremzi-link-muted {
  color: #64748b !important;
  text-decoration: none !important;
  transition: color .15s ease !important;
}
.stremzi-wrap .stremzi-link-muted:hover {
  color: #0ea5e9 !important;
  text-decoration: underline !important;
}

#stremzi-login .stremzi-body { padding: 24px !important; }
#stremzi-login .stremzi-hero  { padding-bottom: 20px !important; }
#stremzi-login .stremzi-field { margin-bottom: 14px !important; }

/* Small-screen adjustments for the login row */
@media (max-width: 420px) {
  .stremzi-wrap .stremzi-login-row {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 10px !important;
  }
}

/* ============================================================
   v1.5.6 — CUSTOMIZE CHANNELS (country picker)
   ============================================================ */

.stremzi-wrap .stremzi-countries-wrap {
  background: #ffffff !important;
  border: 1px solid #e2e8f0 !important;
  border-radius: 16px !important;
  margin: 20px 0 !important;
  overflow: hidden !important;
  max-width: 100% !important;
}

.stremzi-wrap .stremzi-countries-header {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 16px 20px !important;
  border-bottom: 1px solid #e2e8f0 !important;
  background: #f8fafc !important;
}
.stremzi-wrap .stremzi-countries-title {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  margin: 0 !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  letter-spacing: 0.08em !important;
  color: #0f172a !important;
  text-transform: uppercase !important;
}
.stremzi-wrap .stremzi-countries-collapse {
  background: transparent !important;
  border: 0 !important;
  color: #475569 !important;
  cursor: pointer !important;
  padding: 6px !important;
  border-radius: 8px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: background .15s ease !important;
}
.stremzi-wrap .stremzi-countries-collapse:hover { background: #e2e8f0 !important; }
.stremzi-wrap .stremzi-countries-collapse svg { transition: transform .2s ease !important; }

.stremzi-wrap .stremzi-countries-body { padding: 20px !important; }

.stremzi-wrap .stremzi-countries-search {
  display: block !important;
  margin-bottom: 16px !important;
}
.stremzi-wrap .stremzi-countries-search input {
  width: 100% !important;
  padding: 12px 16px !important;
  border: 1px solid #e2e8f0 !important;
  border-radius: 10px !important;
  font-size: 14px !important;
  background: #ffffff !important;
  color: #0f172a !important;
  transition: border-color .15s ease, box-shadow .15s ease !important;
  box-sizing: border-box !important;
}
.stremzi-wrap .stremzi-countries-search input:focus {
  outline: none !important;
  border-color: #0ea5e9 !important;
  box-shadow: 0 0 0 3px rgba(14, 165, 233, .12) !important;
}

.stremzi-wrap .stremzi-countries-tabs {
  display: flex !important;
  gap: 8px !important;
  margin-bottom: 16px !important;
  flex-wrap: wrap !important;
}
.stremzi-wrap .stremzi-countries-tab {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 10px 18px !important;
  border: 1.5px solid #0f172a !important;
  border-radius: 10px !important;
  background: #ffffff !important;
  color: #0f172a !important;
  cursor: pointer !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  transition: all .15s ease !important;
}
.stremzi-wrap .stremzi-countries-tab:hover { background: #f1f5f9 !important; }
.stremzi-wrap .stremzi-countries-tab.is-active {
  background: #0f172a !important;
  color: #ffffff !important;
}

.stremzi-wrap .stremzi-countries-status {
  color: #64748b !important;
  font-size: 13px !important;
  min-height: 18px !important;
  margin-bottom: 8px !important;
}

.stremzi-wrap .stremzi-countries-grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 10px !important;
}
@media (max-width: 900px) {
  .stremzi-wrap .stremzi-countries-grid { grid-template-columns: repeat(2, 1fr) !important; }
}
@media (max-width: 540px) {
  .stremzi-wrap .stremzi-countries-grid { grid-template-columns: 1fr !important; }
}

.stremzi-wrap .stremzi-cc-item {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 12px 14px !important;
  border: 1px solid #e2e8f0 !important;
  border-radius: 12px !important;
  background: #ffffff !important;
  cursor: pointer !important;
  transition: border-color .12s ease, background .12s ease !important;
  font-size: 14px !important;
  color: #0f172a !important;
  line-height: 1.3 !important;
}
.stremzi-wrap .stremzi-cc-item:hover {
  border-color: #cbd5e1 !important;
  background: #f8fafc !important;
}
.stremzi-wrap .stremzi-cc-item.is-checked {
  border-color: #0ea5e9 !important;
  background: #f0f9ff !important;
}
.stremzi-wrap .stremzi-cc-item input[type="checkbox"] {
  width: 18px !important;
  height: 18px !important;
  margin: 0 !important;
  accent-color: #0ea5e9 !important;
  cursor: pointer !important;
  flex-shrink: 0 !important;
}
.stremzi-wrap .stremzi-cc-flag {
  font-size: 18px !important;
  line-height: 1 !important;
  flex-shrink: 0 !important;
}
.stremzi-wrap .stremzi-cc-name {
  flex: 1 !important;
  display: inline-flex !important;
  gap: 4px !important;
  align-items: baseline !important;
  flex-wrap: wrap !important;
}
.stremzi-wrap .stremzi-cc-name em {
  color: #64748b !important;
  font-style: normal !important;
  font-size: 13px !important;
  font-weight: 400 !important;
}
.stremzi-wrap .stremzi-cc-all {
  background: #f1f5f9 !important;
  border-style: dashed !important;
}
.stremzi-wrap .stremzi-cc-all.is-checked {
  background: #0f172a !important;
  border-color: #0f172a !important;
  color: #ffffff !important;
}
.stremzi-wrap .stremzi-cc-all.is-checked .stremzi-cc-flag { color: #ffffff !important; }

.stremzi-wrap .stremzi-cc-empty {
  grid-column: 1 / -1 !important;
  text-align: center !important;
  color: #64748b !important;
  font-size: 14px !important;
  padding: 32px 12px !important;
}

.stremzi-wrap .stremzi-countries-footer {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
  margin-top: 20px !important;
  padding-top: 16px !important;
  border-top: 1px solid #e2e8f0 !important;
  flex-wrap: wrap !important;
}
.stremzi-wrap .stremzi-countries-stats {
  color: #475569 !important;
  font-size: 14px !important;
}
.stremzi-wrap .stremzi-chip-count {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 26px !important;
  height: 26px !important;
  padding: 0 8px !important;
  border-radius: 999px !important;
  background: #0ea5e9 !important;
  color: #ffffff !important;
  font-weight: 700 !important;
  font-size: 13px !important;
  margin-right: 4px !important;
}
.stremzi-wrap .stremzi-countries-actions {
  display: inline-flex !important;
  gap: 8px !important;
  flex-wrap: wrap !important;
}

/* ============================================================
   v1.5.10 — COUNTRIES UI REFINEMENTS
   ============================================================ */

/* Inside the Customize modal the available width is narrower (~420-600px) —
   switch to 2 columns and keep labels from being truncated. */
.stremzi-modal .stremzi-countries-wrap,
.stremzi-signup-country-wrap .stremzi-countries-wrap {
  border-radius: 12px !important;
  margin: 0 !important;
  box-shadow: none !important;
}
.stremzi-modal .stremzi-countries-header,
.stremzi-signup-country-wrap .stremzi-countries-header {
  padding: 12px 16px !important;
}
.stremzi-modal .stremzi-countries-body,
.stremzi-signup-country-wrap .stremzi-countries-body {
  padding: 14px !important;
}

/* 2-column grid inside modals and the signup embed (was 3 — too narrow). */
.stremzi-modal .stremzi-countries-grid,
.stremzi-signup-country-wrap .stremzi-countries-grid {
  grid-template-columns: 1fr 1fr !important;
  gap: 8px !important;
}
@media (max-width: 480px) {
  .stremzi-modal .stremzi-countries-grid,
  .stremzi-signup-country-wrap .stremzi-countries-grid {
    grid-template-columns: 1fr !important;
  }
}

/* Keep country name + count on a single line; if it won't fit, ellipsize the
   whole line rather than wrapping the count onto a second line. */
.stremzi-wrap .stremzi-cc-name {
  min-width: 0 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}
.stremzi-wrap .stremzi-cc-name em {
  white-space: nowrap !important;
  font-size: 12px !important;
  color: #94a3b8 !important;
  font-weight: 400 !important;
  margin-left: 4px !important;
}

/* Tighter item padding so 2 per row actually fit on narrow modals. */
.stremzi-modal .stremzi-cc-item,
.stremzi-signup-country-wrap .stremzi-cc-item {
  padding: 9px 12px !important;
  font-size: 13px !important;
  gap: 8px !important;
}
.stremzi-modal .stremzi-cc-flag,
.stremzi-signup-country-wrap .stremzi-cc-flag {
  font-size: 16px !important;
}

/* "Select all" tile should stand out a bit */
.stremzi-wrap .stremzi-cc-all .stremzi-cc-name em { display: none !important; }
.stremzi-wrap .stremzi-cc-all .stremzi-cc-name { font-weight: 600 !important; }


/* ============================================================
   v1.5.18 — BOUQUETS PICKER (redesigned)
   ============================================================ */

/* Root container — collapsed by default, low visual weight */
.stremzi-bp {
  margin: 10px 0 18px;
  border: 1px solid #e5e7eb;
  border-radius: 14px;
  background: #ffffff;
  overflow: hidden;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.03);
}
.stremzi-bp[open] {
  box-shadow: 0 4px 16px -4px rgba(15, 23, 42, 0.08);
}

/* Summary (clickable header) */
.stremzi-bp > summary {
  list-style: none;
  cursor: pointer;
  padding: 14px 16px;
  display: flex;
  align-items: center;
  gap: 12px;
  user-select: none;
  transition: background-color 0.12s;
}
.stremzi-bp > summary::-webkit-details-marker { display: none; }
.stremzi-bp > summary:hover { background-color: #f9fafb; }
.stremzi-bp[open] > summary { border-bottom: 1px solid #e5e7eb; }

.stremzi-bp-summary-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 10px;
  background: linear-gradient(135deg, #e0e7ff, #f3e8ff);
  color: #6366f1;
  flex-shrink: 0;
}
.stremzi-bp-summary-text { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.stremzi-bp-summary-title {
  font-size: 14px;
  font-weight: 600;
  color: #0f172a;
  line-height: 1.2;
}
.stremzi-bp-summary-sub {
  font-size: 12px;
  color: #94a3b8;
  line-height: 1.2;
}
.stremzi-bp-summary-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 5px 10px;
  border-radius: 999px;
  background: #0f172a;
  color: #fff;
  font-size: 11px;
  font-weight: 600;
  white-space: nowrap;
  flex-shrink: 0;
}
.stremzi-bp-summary-badge [data-count] { font-variant-numeric: tabular-nums; }
.stremzi-bp-summary-chevron {
  color: #94a3b8;
  transition: transform 0.18s ease;
  flex-shrink: 0;
}
.stremzi-bp[open] .stremzi-bp-summary-chevron { transform: rotate(180deg); }

/* Panel (expanded content) */
.stremzi-bp-panel {
  padding: 14px;
  background: #fafbfc;
  /* v1.5.19: cap height so the picker doesn't push the Create account
     button below the fold. Users scroll inside the panel, which is the
     expected mental model for a nested collection picker. */
  max-height: 520px;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
.stremzi-bp-panel::-webkit-scrollbar { width: 8px; }
.stremzi-bp-panel::-webkit-scrollbar-thumb { background: #cbd5e1; border-radius: 4px; }
.stremzi-bp-panel::-webkit-scrollbar-thumb:hover { background: #94a3b8; }

/* Tabs */
.stremzi-bp-tabs {
  display: flex;
  gap: 4px;
  padding: 4px;
  background: #ffffff;
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  margin-bottom: 12px;
}
.stremzi-bp-tab {
  flex: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 9px 12px;
  background: transparent;
  border: 0;
  border-radius: 7px;
  font-size: 13px;
  font-weight: 600;
  color: #64748b;
  cursor: pointer;
  transition: all 0.12s;
  white-space: nowrap;
}
.stremzi-bp-tab:hover { background: #f1f5f9; color: #334155; }
.stremzi-bp-tab.is-active {
  background: #0f172a;
  color: #ffffff;
}
.stremzi-bp-tab.is-active .stremzi-bp-tab-count {
  background: rgba(255, 255, 255, 0.2);
  color: #ffffff;
}
.stremzi-bp-tab-count {
  font-size: 10px;
  font-weight: 700;
  padding: 2px 6px;
  border-radius: 5px;
  background: #e2e8f0;
  color: #64748b;
  font-variant-numeric: tabular-nums;
}

/* Search */
.stremzi-bp-search {
  position: relative;
  margin-bottom: 10px;
}
.stremzi-bp-search > svg:first-child {
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  color: #94a3b8;
  pointer-events: none;
}
.stremzi-bp-search input {
  width: 100%;
  padding: 10px 36px 10px 38px;
  background: #ffffff;
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  font-size: 13px;
  color: #0f172a;
  transition: border-color 0.12s, box-shadow 0.12s;
}
.stremzi-bp-search input::placeholder { color: #94a3b8; }
.stremzi-bp-search input:focus {
  outline: none;
  border-color: #6366f1;
  box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.12);
}
.stremzi-bp-search-clear {
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  width: 24px;
  height: 24px;
  padding: 0;
  border: 0;
  border-radius: 50%;
  background: #e5e7eb;
  color: #64748b;
  font-size: 16px;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.stremzi-bp-search-clear:hover { background: #cbd5e1; color: #0f172a; }

/* Toolbar */
.stremzi-bp-toolbar {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 12px;
  padding: 0 2px;
}
.stremzi-bp-toolbtn {
  padding: 6px 10px;
  background: transparent;
  border: 1px solid #e5e7eb;
  border-radius: 7px;
  font-size: 12px;
  font-weight: 500;
  color: #475569;
  cursor: pointer;
  transition: all 0.12s;
}
.stremzi-bp-toolbtn:hover {
  background: #f1f5f9;
  border-color: #cbd5e1;
  color: #0f172a;
}
.stremzi-bp-toolbar-count {
  margin-left: auto;
  font-size: 11px;
  color: #94a3b8;
  font-variant-numeric: tabular-nums;
}

/* Region group */
.stremzi-bp-region {
  margin-bottom: 8px;
  background: #ffffff;
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  overflow: hidden;
}
.stremzi-bp-region > summary {
  list-style: none;
  cursor: pointer;
  padding: 10px 12px;
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 600;
  color: #0f172a;
  user-select: none;
  transition: background-color 0.12s;
}
.stremzi-bp-region > summary::-webkit-details-marker { display: none; }
.stremzi-bp-region > summary:hover { background: #f9fafb; }
.stremzi-bp-region-icon { font-size: 16px; }
.stremzi-bp-region-name { flex: 1; }
.stremzi-bp-region-count {
  font-size: 10px;
  font-weight: 700;
  padding: 3px 7px;
  border-radius: 5px;
  background: #f1f5f9;
  color: #64748b;
  font-variant-numeric: tabular-nums;
}
.stremzi-bp-region-count.has-selection {
  background: #dcfce7;
  color: #166534;
}
.stremzi-bp-chevron {
  color: #94a3b8;
  transition: transform 0.18s ease;
}
.stremzi-bp-region[open] .stremzi-bp-chevron { transform: rotate(180deg); }

/* Item list */
.stremzi-bp-list {
  list-style: none;
  margin: 0;
  padding: 4px;
  border-top: 1px solid #f1f5f9;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 2px;
}
.stremzi-bp-row {
  margin: 0;
  padding: 0;
}
.stremzi-bp-row label {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  border-radius: 7px;
  cursor: pointer;
  transition: background-color 0.1s;
  position: relative;
}
.stremzi-bp-row label:hover {
  background: #f1f5f9;
}
/* v1.5.27: support radio inputs (single-select) alongside legacy
   checkbox selectors. We keep :has() AND .is-checked class fallbacks
   so older browsers still render the selected state. The visual
   affordance is a ROUND check (indicates radio — one at a time)
   instead of the v1.5.26 square (multi-select). */
.stremzi-bp-row input[type="checkbox"],
.stremzi-bp-row input[type="radio"] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
  pointer-events: none;
}
.stremzi-bp-flag {
  font-size: 18px;
  line-height: 1;
  flex-shrink: 0;
}
.stremzi-bp-name {
  flex: 1;
  font-size: 13px;
  color: #334155;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.3;
}
.stremzi-bp-check {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 50%; /* circular = radio look */
  border: 1.5px solid #cbd5e1;
  background: #ffffff;
  color: transparent;
  transition: all 0.15s;
  flex-shrink: 0;
}
.stremzi-bp-row input:checked ~ .stremzi-bp-check,
.stremzi-bp-row label:has(input:checked) .stremzi-bp-check,
.stremzi-bp-row.is-checked .stremzi-bp-check {
  background: #6366f1;
  border-color: #6366f1;
  color: #ffffff;
}
.stremzi-bp-row label:has(input:checked),
.stremzi-bp-row.is-checked label {
  background: #eef2ff;
}
.stremzi-bp-row label:has(input:checked) .stremzi-bp-name,
.stremzi-bp-row.is-checked .stremzi-bp-name {
  color: #0f172a;
  font-weight: 600;
}

/* Focus ring for keyboard users */
.stremzi-bp-row input:focus-visible ~ .stremzi-bp-check {
  box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.25);
}

/* Hidden rows (search filter / tab switch) */
.stremzi-bp-row[hidden] { display: none !important; }
.stremzi-bp-region[hidden] { display: none !important; }
.stremzi-bp-tabpanel[hidden] { display: none !important; }

.stremzi-bp-empty {
  text-align: center;
  color: #94a3b8;
  font-size: 13px;
  padding: 28px 14px;
  margin: 0;
}

/* ═══════════════════════════════════════════════════════════════════
   v1.5.28: Smart group sections in the picker
   ─────────────────────────────────────────────────────────────────── */
.stremzi-wrap .stremzi-bp-groups {
  display: flex !important;
  flex-direction: column !important;
  gap: 18px !important;
  margin-top: 10px !important;
}
.stremzi-wrap .stremzi-bp-group {
  display: block !important;
  padding: 0 !important;
}
.stremzi-wrap .stremzi-bp-group-header {
  display: block !important;
  margin: 0 0 10px !important;
  padding: 0 4px !important;
}
.stremzi-wrap .stremzi-bp-group-label {
  margin: 0 0 2px !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  color: #0f172a !important;
  line-height: 1.3 !important;
}
.stremzi-wrap .stremzi-bp-group-sub {
  margin: 0 !important;
  font-size: 12px !important;
  color: #64748b !important;
  line-height: 1.4 !important;
}

/* "🔥 Popular" badge on the killer combo */
.stremzi-wrap .stremzi-bp-row.is-hot label {
  background: linear-gradient(90deg, rgba(251, 146, 60, 0.08) 0%, rgba(239, 68, 68, 0.08) 100%) !important;
  border: 1px solid rgba(251, 146, 60, 0.3) !important;
  border-radius: 8px !important;
}
.stremzi-wrap .stremzi-bp-row.is-hot label:hover {
  background: linear-gradient(90deg, rgba(251, 146, 60, 0.12) 0%, rgba(239, 68, 68, 0.12) 100%) !important;
}
.stremzi-wrap .stremzi-bp-hot-badge {
  display: inline-flex !important;
  align-items: center !important;
  gap: 2px !important;
  padding: 2px 8px !important;
  margin-right: 6px !important;
  background: linear-gradient(90deg, #fb923c, #ef4444) !important;
  color: #ffffff !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  border-radius: 4px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  flex-shrink: 0 !important;
}

/* Bottom Clear button */
.stremzi-wrap .stremzi-bp-footer {
  margin-top: 16px !important;
  padding-top: 14px !important;
  border-top: 1px solid #e2e8f0 !important;
  text-align: center !important;
}
.stremzi-wrap .stremzi-bp-clear-btn {
  padding: 8px 16px !important;
  background: transparent !important;
  border: 1px solid #cbd5e1 !important;
  border-radius: 8px !important;
  color: #64748b !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  cursor: pointer !important;
  transition: all 0.15s !important;
}
.stremzi-wrap .stremzi-bp-clear-btn:hover {
  background: #f1f5f9 !important;
  color: #0f172a !important;
  border-color: #94a3b8 !important;
}

/* Mobile */
@media (max-width: 540px) {
  .stremzi-wrap .stremzi-bp-list { grid-template-columns: 1fr !important; }
  .stremzi-wrap .stremzi-bp-summary-sub { display: none !important; }
  .stremzi-wrap .stremzi-bp > summary { padding: 12px 14px !important; gap: 10px !important; }
  .stremzi-wrap .stremzi-bp-summary-icon { width: 32px !important; height: 32px !important; }
  .stremzi-wrap .stremzi-bp-panel { padding: 10px !important; }
  .stremzi-wrap .stremzi-bp-group-label { font-size: 13px !important; }
  .stremzi-wrap .stremzi-bp-hot-badge { font-size: 9px !important; padding: 2px 6px !important; }
  .stremzi-wrap .stremzi-bp-summary-preview { font-size: 11px !important; padding: 3px 8px !important; }
  .stremzi-wrap .stremzi-bp-warning { flex-direction: row !important; padding: 10px 12px !important; }
  .stremzi-wrap .stremzi-bp-warning-icon { font-size: 20px !important; }
  .stremzi-wrap .stremzi-bp-warning-body strong { font-size: 13px !important; }
  .stremzi-wrap .stremzi-bp-warning-body span { font-size: 12px !important; }
}

/* ═══════════════════════════════════════════════════════════════════
   v1.5.29: Closed-dropdown summary preview pill
   When the picker is collapsed, show which pack the customer ended up
   with (flag + name) as a compact pill in the summary line. The pill
   only appears after a selection exists (hidden by default).
   ─────────────────────────────────────────────────────────────────── */
.stremzi-wrap .stremzi-bp-summary-preview {
  display: inline-flex !important;
  align-items: center !important;
  gap: 4px !important;
  padding: 3px 10px !important;
  margin-top: 4px !important;
  background: rgba(99, 102, 241, 0.12) !important;
  color: #4338ca !important;
  border: 1px solid rgba(99, 102, 241, 0.25) !important;
  border-radius: 999px !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  line-height: 1.3 !important;
  width: fit-content !important;
  max-width: 100% !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}
.stremzi-wrap .stremzi-bp-summary-preview[hidden] {
  display: none !important;
}

/* ═══════════════════════════════════════════════════════════════════
   v1.5.29: Heavy-M3U warning banner
   Shown only when the customer picks a "Worldwide Premium" / all-in-one
   pack. Amber-colored alert with icon + title + explanation.
   ─────────────────────────────────────────────────────────────────── */
.stremzi-wrap .stremzi-bp-warning {
  display: flex !important;
  gap: 12px !important;
  align-items: flex-start !important;
  padding: 14px 16px !important;
  margin: 0 0 14px !important;
  background: linear-gradient(135deg, rgba(251, 191, 36, 0.1) 0%, rgba(245, 158, 11, 0.08) 100%) !important;
  border: 1px solid rgba(245, 158, 11, 0.35) !important;
  border-left: 4px solid #f59e0b !important;
  border-radius: 10px !important;
  animation: stremzi-bp-warning-fade-in 0.25s ease !important;
}
.stremzi-wrap .stremzi-bp-warning[hidden] {
  display: none !important;
}
.stremzi-wrap .stremzi-bp-warning-icon {
  font-size: 24px !important;
  line-height: 1.2 !important;
  flex-shrink: 0 !important;
  user-select: none !important;
}
.stremzi-wrap .stremzi-bp-warning-body {
  display: flex !important;
  flex-direction: column !important;
  gap: 4px !important;
  color: #78350f !important;
  min-width: 0 !important;
}
.stremzi-wrap .stremzi-bp-warning-body strong {
  font-size: 14px !important;
  font-weight: 700 !important;
  color: #92400e !important;
  line-height: 1.35 !important;
}
.stremzi-wrap .stremzi-bp-warning-body span {
  font-size: 13px !important;
  line-height: 1.5 !important;
  color: #78350f !important;
}

@keyframes stremzi-bp-warning-fade-in {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ════════════════════════════════════════════════════════════════════
   v1.5.30 — UX polish layer
   ════════════════════════════════════════════════════════════════════ */

/* ───────── Sticky selection header (inside open panel) ───────── */
.stremzi-wrap .stremzi-bp-sticky {
  position: sticky !important;
  top: 0 !important;
  z-index: 10 !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 10px 14px !important;
  margin: -10px -14px 14px !important;
  background: linear-gradient(135deg, #4f46e5 0%, #6366f1 100%) !important;
  color: #ffffff !important;
  border-radius: 0 0 10px 10px !important;
  box-shadow: 0 4px 12px rgba(79, 70, 229, 0.25) !important;
  font-size: 13px !important;
}
.stremzi-wrap .stremzi-bp-sticky[hidden] { display: none !important; }
.stremzi-wrap .stremzi-bp-sticky-label {
  font-weight: 500 !important;
  opacity: 0.85 !important;
  font-size: 12px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  flex-shrink: 0 !important;
}
.stremzi-wrap .stremzi-bp-sticky-pick {
  flex: 1 !important;
  font-weight: 700 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  min-width: 0 !important;
}
.stremzi-wrap .stremzi-bp-sticky-reset {
  padding: 5px 12px !important;
  background: rgba(255, 255, 255, 0.2) !important;
  color: #ffffff !important;
  border: 1px solid rgba(255, 255, 255, 0.35) !important;
  border-radius: 6px !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  transition: background 0.15s !important;
  flex-shrink: 0 !important;
}
.stremzi-wrap .stremzi-bp-sticky-reset:hover {
  background: rgba(255, 255, 255, 0.3) !important;
}

/* ───────── Tiered group hierarchy ───────── */
/* Tier 1 (single + special): bright, prominent, biggest */
.stremzi-wrap .stremzi-bp-group.is-tier-1 .stremzi-bp-group-label {
  font-size: 16px !important;
  color: #0f172a !important;
  font-weight: 800 !important;
}
/* Tier 2 (combo): standard */
.stremzi-wrap .stremzi-bp-group.is-tier-2 .stremzi-bp-group-label {
  font-size: 14px !important;
  color: #1e293b !important;
  font-weight: 700 !important;
}
/* Tier 3 (all_in_one advanced): small + dimmed — discourages picking */
.stremzi-wrap .stremzi-bp-group.is-tier-3 .stremzi-bp-group-label {
  font-size: 13px !important;
  color: #64748b !important;
  font-weight: 600 !important;
}
.stremzi-wrap .stremzi-bp-group.is-tier-3 .stremzi-bp-group-sub {
  color: #94a3b8 !important;
  font-style: italic !important;
}
.stremzi-wrap .stremzi-bp-group.is-tier-3 {
  opacity: 0.92 !important;
  padding-top: 6px !important;
  border-top: 1px dashed #e2e8f0 !important;
}

/* Count bubble next to group label */
.stremzi-wrap .stremzi-bp-group-count {
  display: inline-block !important;
  padding: 1px 8px !important;
  margin-left: 6px !important;
  background: #e0e7ff !important;
  color: #4338ca !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  border-radius: 999px !important;
  vertical-align: middle !important;
}
.stremzi-wrap .stremzi-bp-group.is-tier-3 .stremzi-bp-group-count {
  background: #f1f5f9 !important;
  color: #94a3b8 !important;
}

/* ───────── Badges row on each pack ───────── */
.stremzi-wrap .stremzi-bp-badges {
  display: inline-flex !important;
  align-items: center !important;
  gap: 4px !important;
  margin-left: auto !important;
  margin-right: 6px !important;
  flex-shrink: 0 !important;
}
.stremzi-wrap .stremzi-bp-default-badge {
  display: inline-flex !important;
  align-items: center !important;
  gap: 3px !important;
  padding: 2px 8px !important;
  background: linear-gradient(90deg, #10b981, #059669) !important;
  color: #ffffff !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  border-radius: 4px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  box-shadow: 0 1px 3px rgba(16, 185, 129, 0.3) !important;
}
.stremzi-wrap .stremzi-bp-heavy-badge {
  display: inline-flex !important;
  align-items: center !important;
  gap: 3px !important;
  padding: 2px 8px !important;
  background: rgba(245, 158, 11, 0.15) !important;
  color: #b45309 !important;
  border: 1px solid rgba(245, 158, 11, 0.4) !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  border-radius: 4px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
}

/* ───────── Default row subtle highlight ───────── */
.stremzi-wrap .stremzi-bp-row.is-default label {
  background: linear-gradient(90deg, rgba(16, 185, 129, 0.05) 0%, rgba(16, 185, 129, 0.02) 100%) !important;
  border: 1px solid rgba(16, 185, 129, 0.2) !important;
  border-radius: 10px !important;
}
.stremzi-wrap .stremzi-bp-row.is-default.is-checked label {
  background: linear-gradient(90deg, rgba(16, 185, 129, 0.15) 0%, rgba(16, 185, 129, 0.08) 100%) !important;
  border-color: #10b981 !important;
  box-shadow: 0 0 0 2px rgba(16, 185, 129, 0.2) !important;
}

/* ───────── Heavy row: visual hint ───────── */
.stremzi-wrap .stremzi-bp-row.is-heavy label {
  border: 1px solid rgba(245, 158, 11, 0.25) !important;
  border-radius: 10px !important;
}
.stremzi-wrap .stremzi-bp-row.is-heavy.is-checked label {
  border-color: #f59e0b !important;
  box-shadow: 0 0 0 2px rgba(245, 158, 11, 0.15) !important;
}

/* ───────── Selection bounce animation ───────── */
.stremzi-wrap .stremzi-bp-row.is-checked label {
  animation: stremzi-bp-pop 0.25s ease !important;
}
@keyframes stremzi-bp-pop {
  0%   { transform: scale(1); }
  50%  { transform: scale(1.015); }
  100% { transform: scale(1); }
}
.stremzi-wrap .stremzi-bp-row.is-checked .stremzi-bp-check svg {
  animation: stremzi-bp-check-in 0.3s cubic-bezier(0.34, 1.56, 0.64, 1) !important;
}
@keyframes stremzi-bp-check-in {
  0%   { opacity: 0; transform: scale(0) rotate(-45deg); }
  100% { opacity: 1; transform: scale(1) rotate(0); }
}

/* ───────── Inline warning under heavy row ───────── */
.stremzi-wrap .stremzi-bp-inline-warning {
  display: none !important;
  gap: 10px !important;
  margin: 8px 0 4px !important;
  padding: 12px 14px !important;
  background: linear-gradient(135deg, rgba(251, 191, 36, 0.12) 0%, rgba(245, 158, 11, 0.08) 100%) !important;
  border: 1px solid rgba(245, 158, 11, 0.4) !important;
  border-left: 4px solid #f59e0b !important;
  border-radius: 10px !important;
}
.stremzi-wrap .stremzi-bp-row.is-showing-warning .stremzi-bp-inline-warning {
  display: flex !important;
  animation: stremzi-bp-warning-slide 0.25s ease !important;
}
@keyframes stremzi-bp-warning-slide {
  from { opacity: 0; max-height: 0; transform: translateY(-4px); }
  to   { opacity: 1; max-height: 200px; transform: translateY(0); }
}
.stremzi-wrap .stremzi-bp-inline-warning-icon {
  font-size: 22px !important;
  line-height: 1.2 !important;
  flex-shrink: 0 !important;
}
.stremzi-wrap .stremzi-bp-inline-warning-body {
  display: flex !important;
  flex-direction: column !important;
  gap: 3px !important;
  min-width: 0 !important;
}
.stremzi-wrap .stremzi-bp-inline-warning-body strong {
  font-size: 13px !important;
  font-weight: 700 !important;
  color: #92400e !important;
}
.stremzi-wrap .stremzi-bp-inline-warning-body span {
  font-size: 12.5px !important;
  line-height: 1.5 !important;
  color: #78350f !important;
}

/* ───────── Improved closed-dropdown summary pill ───────── */
.stremzi-wrap .stremzi-bp-summary-preview {
  margin-top: 4px !important;
  font-size: 13px !important;
  padding: 4px 12px !important;
  font-weight: 700 !important;
  background: linear-gradient(90deg, #4f46e5, #6366f1) !important;
  color: #ffffff !important;
  border: 0 !important;
  box-shadow: 0 2px 6px rgba(79, 70, 229, 0.25) !important;
}

/* Reset-to-default button (footer) — clearer intent */
.stremzi-wrap .stremzi-bp-clear-btn {
  padding: 10px 18px !important;
  background: #f1f5f9 !important;
  border: 1px solid #cbd5e1 !important;
  color: #475569 !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  border-radius: 8px !important;
}
.stremzi-wrap .stremzi-bp-clear-btn:hover {
  background: #e0e7ff !important;
  color: #4338ca !important;
  border-color: #6366f1 !important;
}

/* Mobile fine-tune */
@media (max-width: 540px) {
  .stremzi-wrap .stremzi-bp-sticky {
    flex-wrap: wrap !important;
    padding: 10px 12px !important;
  }
  .stremzi-wrap .stremzi-bp-sticky-label { font-size: 11px !important; }
  .stremzi-wrap .stremzi-bp-sticky-pick { font-size: 13px !important; flex: 1 1 100% !important; order: 2 !important; }
  .stremzi-wrap .stremzi-bp-sticky-reset { font-size: 11px !important; padding: 4px 10px !important; }
  .stremzi-wrap .stremzi-bp-group.is-tier-1 .stremzi-bp-group-label { font-size: 15px !important; }
  .stremzi-wrap .stremzi-bp-badges { margin-right: 4px !important; }
  .stremzi-wrap .stremzi-bp-inline-warning { padding: 10px 12px !important; }
  .stremzi-wrap .stremzi-bp-inline-warning-icon { font-size: 20px !important; }
  .stremzi-wrap .stremzi-bp-inline-warning-body strong { font-size: 12.5px !important; }
  .stremzi-wrap .stremzi-bp-inline-warning-body span { font-size: 12px !important; }
}

/* ════════════════════════════════════════════════════════════════════
   v1.5.35 — Lightweight picker with flag-icons library
   ──────────────────────────────────────────────────────────────────
   - Uses `flag-icons` (lipis/flag-icons, MIT) for real country flags
   - No custom picker tab (removed in this version)
   - Dropdown collapsed by default via <details>
   - flag-icons CSS is enqueued as a dependency of stremzi-css
   ════════════════════════════════════════════════════════════════════ */

.stremzi-wrap details.stremzi-bp-v2 {
  display: block !important;
  background: #ffffff !important;
  border: 1px solid #e2e8f0 !important;
  border-radius: 12px !important;
  font-family: inherit !important;
  overflow: hidden !important;
}
.stremzi-wrap details.stremzi-bp-v2[open] {
  border-color: #cbd5e1 !important;
}
.stremzi-wrap details.stremzi-bp-v2 > summary::-webkit-details-marker { display: none !important; }
.stremzi-wrap details.stremzi-bp-v2 > summary { list-style: none !important; }

/* ─── Summary ─── */
.stremzi-wrap .stremzi-bp-v2-summary {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
  padding: 14px 16px !important;
  cursor: pointer !important;
  user-select: none !important;
  transition: background 0.12s !important;
}
.stremzi-wrap .stremzi-bp-v2-summary:hover { background: #f8fafc !important; }
.stremzi-wrap .stremzi-bp-v2-summary-left {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  flex: 1 !important;
  min-width: 0 !important;
}
.stremzi-wrap .stremzi-bp-v2-summary-icon {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
  width: 36px !important;
  height: 36px !important;
  background: #eef2ff !important;
  color: #6366f1 !important;
  border-radius: 8px !important;
}
.stremzi-wrap .stremzi-bp-v2-summary-text {
  display: flex !important;
  flex-direction: column !important;
  gap: 2px !important;
  flex: 1 !important;
  min-width: 0 !important;
}
.stremzi-wrap .stremzi-bp-v2-summary-title {
  font-size: 14px !important;
  font-weight: 600 !important;
  color: #0f172a !important;
  line-height: 1.3 !important;
}
.stremzi-wrap .stremzi-bp-v2-summary-sub {
  font-size: 12px !important;
  color: #64748b !important;
  line-height: 1.4 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}
.stremzi-wrap .stremzi-bp-v2-summary-right {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  flex-shrink: 0 !important;
}
.stremzi-wrap .stremzi-bp-v2-summary-cta {
  font-size: 12px !important;
  font-weight: 600 !important;
  color: #6366f1 !important;
}
.stremzi-wrap .stremzi-bp-v2-summary-chevron {
  color: #94a3b8 !important;
  transition: transform 0.2s !important;
}
.stremzi-wrap details.stremzi-bp-v2[open] .stremzi-bp-v2-summary-chevron {
  transform: rotate(180deg) !important;
}

/* ─── Body ─── */
.stremzi-wrap .stremzi-bp-v2-body {
  display: flex !important;
  flex-direction: column !important;
  gap: 18px !important;
  padding: 16px !important;
  border-top: 1px solid #e2e8f0 !important;
}

/* ─── Section headers ─── */
.stremzi-wrap .stremzi-bp-v2-section {
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
}
.stremzi-wrap .stremzi-bp-v2-section-head {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
  flex-wrap: wrap !important;
}
.stremzi-wrap .stremzi-bp-v2-section-title {
  margin: 0 !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  color: #475569 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.6px !important;
}
.stremzi-wrap .stremzi-bp-v2-section-hint {
  font-size: 12px !important;
  color: #94a3b8 !important;
}
.stremzi-wrap .stremzi-bp-v2-section-actions {
  display: flex !important;
  gap: 4px !important;
}
.stremzi-wrap .stremzi-bp-v2-linkbtn {
  display: inline-flex !important;
  align-items: center !important;
  gap: 5px !important;
  padding: 5px 9px !important;
  background: transparent !important;
  border: 1px solid transparent !important;
  border-radius: 6px !important;
  color: #6366f1 !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  transition: all 0.12s !important;
}
.stremzi-wrap .stremzi-bp-v2-linkbtn:hover {
  background: #eef2ff !important;
  border-color: #e0e7ff !important;
}

/* ─── Region cards (flag-icons inside) ─── */
.stremzi-wrap .stremzi-bp-v2-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)) !important;
  gap: 8px !important;
}
.stremzi-wrap .stremzi-bp-v2-card {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 10px 12px !important;
  background: #ffffff !important;
  border: 1px solid #e2e8f0 !important;
  border-radius: 10px !important;
  cursor: pointer !important;
  transition: all 0.12s !important;
  min-height: 56px !important;
  position: relative !important;
}
.stremzi-wrap .stremzi-bp-v2-card:hover {
  border-color: #cbd5e1 !important;
  background: #f8fafc !important;
}
.stremzi-wrap .stremzi-bp-v2-card.is-checked {
  border-color: #6366f1 !important;
  background: #eef2ff !important;
  box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.1) !important;
}
.stremzi-wrap .stremzi-bp-v2-card input[type="checkbox"] {
  position: absolute !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

/* Flag wrapper — sized 32x24 (4:3 aspect) for flag images */
.stremzi-wrap .stremzi-bp-v2-card-flag {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
  width: 32px !important;
  height: 24px !important;
  border-radius: 4px !important;
  overflow: hidden !important;
  border: 1px solid rgba(0, 0, 0, 0.08) !important;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05) !important;
  background: #f1f5f9 !important;
}
.stremzi-wrap .stremzi-bp-v2-card-flag-img {
  width: 100% !important;
  height: 100% !important;
  display: block !important;
  object-fit: cover !important;
}

.stremzi-wrap .stremzi-bp-v2-card-body {
  display: flex !important;
  flex-direction: column !important;
  gap: 1px !important;
  flex: 1 !important;
  min-width: 0 !important;
}
.stremzi-wrap .stremzi-bp-v2-card-label {
  font-size: 13.5px !important;
  font-weight: 600 !important;
  color: #0f172a !important;
  line-height: 1.3 !important;
}
.stremzi-wrap .stremzi-bp-v2-card-sub {
  font-size: 11.5px !important;
  color: #64748b !important;
  line-height: 1.3 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}
.stremzi-wrap .stremzi-bp-v2-card-check {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
  width: 22px !important;
  height: 22px !important;
  background: transparent !important;
  border: 1.5px solid #cbd5e1 !important;
  border-radius: 6px !important;
  color: transparent !important;
  transition: all 0.12s !important;
}
.stremzi-wrap .stremzi-bp-v2-card.is-checked .stremzi-bp-v2-card-check {
  background: #6366f1 !important;
  border-color: #6366f1 !important;
  color: #ffffff !important;
}

/* ─── Specialty chips ─── */
.stremzi-wrap .stremzi-bp-v2-chips {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)) !important;
  gap: 8px !important;
}
.stremzi-wrap .stremzi-bp-v2-chip {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 10px 12px !important;
  background: #ffffff !important;
  border: 1px solid #e2e8f0 !important;
  border-radius: 10px !important;
  cursor: pointer !important;
  transition: all 0.12s !important;
  position: relative !important;
  min-height: 50px !important;
}
.stremzi-wrap .stremzi-bp-v2-chip:hover {
  border-color: #cbd5e1 !important;
  background: #f8fafc !important;
}
.stremzi-wrap .stremzi-bp-v2-chip.is-checked {
  border-color: #6366f1 !important;
  background: #eef2ff !important;
}
.stremzi-wrap .stremzi-bp-v2-chip input[type="checkbox"] {
  position: absolute !important;
  opacity: 0 !important;
  pointer-events: none !important;
}
.stremzi-wrap .stremzi-bp-v2-chip-flag {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
  width: 28px !important;
  height: 28px !important;
  background: #f1f5f9 !important;
  color: #64748b !important;
  border-radius: 6px !important;
}
.stremzi-wrap .stremzi-bp-v2-chip.is-checked .stremzi-bp-v2-chip-flag {
  background: #6366f1 !important;
  color: #ffffff !important;
}
.stremzi-wrap .stremzi-bp-v2-chip-body {
  display: flex !important;
  flex-direction: column !important;
  gap: 1px !important;
  flex: 1 !important;
  min-width: 0 !important;
}
.stremzi-wrap .stremzi-bp-v2-chip-label {
  font-size: 13.5px !important;
  font-weight: 600 !important;
  color: #0f172a !important;
}
.stremzi-wrap .stremzi-bp-v2-chip-sub {
  font-size: 11.5px !important;
  color: #64748b !important;
}
.stremzi-wrap .stremzi-bp-v2-chip-check {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
  width: 22px !important;
  height: 22px !important;
  background: transparent !important;
  border: 1.5px solid #cbd5e1 !important;
  border-radius: 6px !important;
  color: transparent !important;
  transition: all 0.12s !important;
}
.stremzi-wrap .stremzi-bp-v2-chip.is-checked .stremzi-bp-v2-chip-check {
  background: #6366f1 !important;
  border-color: #6366f1 !important;
  color: #ffffff !important;
}

/* ─── Result card ─── */
.stremzi-wrap .stremzi-bp-v2-result {
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
  padding: 14px 16px !important;
  background: #f8fafc !important;
  border: 1px solid #e2e8f0 !important;
  border-radius: 10px !important;
}
.stremzi-wrap .stremzi-bp-v2-result-head {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 10px !important;
  flex-wrap: wrap !important;
}
.stremzi-wrap .stremzi-bp-v2-result-label {
  font-size: 11px !important;
  font-weight: 700 !important;
  color: #64748b !important;
  text-transform: uppercase !important;
  letter-spacing: 0.8px !important;
}
.stremzi-wrap .stremzi-bp-v2-result-status {
  display: inline-flex !important;
  align-items: center !important;
  padding: 3px 10px !important;
  border-radius: 12px !important;
  font-size: 11px !important;
  font-weight: 600 !important;
}
.stremzi-wrap .stremzi-bp-v2-result-status[data-status="exact"]    { background:#dcfce7 !important; color:#15803d !important; }
.stremzi-wrap .stremzi-bp-v2-result-status[data-status="superset"] { background:#fef3c7 !important; color:#a16207 !important; }
.stremzi-wrap .stremzi-bp-v2-result-status[data-status="fallback"] { background:#fee2e2 !important; color:#b91c1c !important; }
.stremzi-wrap .stremzi-bp-v2-result-status[data-status="extra"]    { background:#e0e7ff !important; color:#4338ca !important; }
.stremzi-wrap .stremzi-bp-v2-result-status[hidden] { display:none !important; }
.stremzi-wrap .stremzi-bp-v2-result-name {
  font-size: 17px !important;
  font-weight: 700 !important;
  color: #0f172a !important;
  line-height: 1.3 !important;
}
.stremzi-wrap .stremzi-bp-v2-result-note {
  font-size: 12.5px !important;
  color: #64748b !important;
  line-height: 1.5 !important;
}
.stremzi-wrap .stremzi-bp-v2-result-note[hidden] { display:none !important; }

/* ─── Warning ─── */
.stremzi-wrap .stremzi-bp-v2-warning {
  display: flex !important;
  align-items: flex-start !important;
  gap: 12px !important;
  padding: 13px 14px !important;
  background: #fef3c7 !important;
  border: 1px solid #fde68a !important;
  border-radius: 10px !important;
}
.stremzi-wrap .stremzi-bp-v2-warning[hidden] { display:none !important; }
.stremzi-wrap .stremzi-bp-v2-warning-icon {
  display: flex !important;
  flex-shrink: 0 !important;
  color: #a16207 !important;
  margin-top: 1px !important;
}
.stremzi-wrap .stremzi-bp-v2-warning-body {
  display: flex !important;
  flex-direction: column !important;
  gap: 3px !important;
}
.stremzi-wrap .stremzi-bp-v2-warning-body strong {
  font-size: 13px !important;
  font-weight: 700 !important;
  color: #78350f !important;
}
.stremzi-wrap .stremzi-bp-v2-warning-body span {
  font-size: 12.5px !important;
  color: #78350f !important;
  line-height: 1.5 !important;
}

/* ─── Contact CTA banner (v1.5.36) ─── */
.stremzi-wrap .stremzi-bp-v2-contact {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  padding: 12px 14px !important;
  background: #f0f9ff !important;
  border: 1px solid #bae6fd !important;
  border-radius: 10px !important;
  flex-wrap: wrap !important;
}
.stremzi-wrap .stremzi-bp-v2-contact-icon {
  display: flex !important;
  flex-shrink: 0 !important;
  align-items: center !important;
  justify-content: center !important;
  width: 36px !important;
  height: 36px !important;
  background: #0ea5e9 !important;
  color: #ffffff !important;
  border-radius: 8px !important;
}
.stremzi-wrap .stremzi-bp-v2-contact-body {
  display: flex !important;
  flex-direction: column !important;
  gap: 2px !important;
  flex: 1 !important;
  min-width: 180px !important;
}
.stremzi-wrap .stremzi-bp-v2-contact-body strong {
  font-size: 13px !important;
  font-weight: 700 !important;
  color: #0c4a6e !important;
  line-height: 1.3 !important;
}
.stremzi-wrap .stremzi-bp-v2-contact-body span {
  font-size: 12px !important;
  color: #075985 !important;
  line-height: 1.5 !important;
}
.stremzi-wrap .stremzi-bp-v2-contact-cta {
  display: inline-flex !important;
  align-items: center !important;
  gap: 5px !important;
  padding: 7px 12px !important;
  background: #0ea5e9 !important;
  color: #ffffff !important;
  border-radius: 8px !important;
  font-size: 12.5px !important;
  font-weight: 600 !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  transition: all 0.12s !important;
  flex-shrink: 0 !important;
}
.stremzi-wrap .stremzi-bp-v2-contact-cta:hover {
  background: #0284c7 !important;
  color: #ffffff !important;
  text-decoration: none !important;
  transform: translateX(2px) !important;
}

/* ─── Footer ─── */
.stremzi-wrap .stremzi-bp-v2-footer {
  display: flex !important;
  justify-content: center !important;
  padding-top: 6px !important;
  border-top: 1px solid #e2e8f0 !important;
}
.stremzi-wrap .stremzi-bp-v2-reset {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  padding: 7px 14px !important;
  background: transparent !important;
  border: 1px solid #cbd5e1 !important;
  color: #475569 !important;
  border-radius: 8px !important;
  font-size: 12.5px !important;
  font-weight: 500 !important;
  cursor: pointer !important;
  transition: all 0.12s !important;
}
.stremzi-wrap .stremzi-bp-v2-reset:hover {
  background: #f1f5f9 !important;
  color: #0f172a !important;
}

/* ─── Mobile ─── */
@media (max-width: 540px) {
  .stremzi-wrap .stremzi-bp-v2-summary { padding: 12px 14px !important; }
  .stremzi-wrap .stremzi-bp-v2-summary-icon { width: 32px !important; height: 32px !important; }
  .stremzi-wrap .stremzi-bp-v2-summary-cta { display: none !important; }
  .stremzi-wrap .stremzi-bp-v2-body { padding: 14px !important; gap: 14px !important; }
  .stremzi-wrap .stremzi-bp-v2-grid { grid-template-columns: 1fr !important; }
  .stremzi-wrap .stremzi-bp-v2-chips { grid-template-columns: 1fr !important; }
  .stremzi-wrap .stremzi-bp-v2-card-sub { white-space: normal !important; }
  .stremzi-wrap .stremzi-bp-v2-result-name { font-size: 15px !important; }
  .stremzi-wrap .stremzi-bp-v2-contact { padding: 11px 12px !important; }
  .stremzi-wrap .stremzi-bp-v2-contact-cta { width: 100% !important; justify-content: center !important; }
}

/* ============================================================
   v1.5.98: Host card styling. The host picker used to rely on
   browser defaults which rendered the domain + URL rows in a
   jumbled way. Clean card layout now: bold HOST label, two
   labelled URL rows with copy buttons.
   ============================================================ */
.stremzi-wrap .stremzi-host-card {
  background: #f8fafc !important;
  border: 1px solid #e2e8f0 !important;
  border-radius: 10px !important;
  padding: 12px 14px !important;
  margin-bottom: 8px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
}
.stremzi-wrap .stremzi-host-card-head {
  display: flex !important;
  align-items: center !important;
}
.stremzi-wrap .stremzi-host-card-number {
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.8px !important;
  color: var(--stremzi-brand-primary, #0ea5e9) !important;
  text-transform: uppercase !important;
}
.stremzi-wrap .stremzi-host-card-body {
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
}
.stremzi-wrap .stremzi-host-url-row {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  min-width: 0 !important;
}
.stremzi-wrap .stremzi-host-url-label {
  font-size: 11px !important;
  font-weight: 600 !important;
  color: #64748b !important;
  min-width: 52px !important;
  flex-shrink: 0 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.4px !important;
}
.stremzi-wrap .stremzi-host-url {
  flex: 1 !important;
  min-width: 0 !important;
  padding: 6px 10px !important;
  background: #ffffff !important;
  border: 1px solid #e2e8f0 !important;
  border-radius: 6px !important;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace !important;
  font-size: 11px !important;
  color: #0e1a2b !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  display: block !important;
}
.stremzi-wrap .stremzi-host-url-copy {
  flex-shrink: 0 !important;
  padding: 6px !important;
  background: #ffffff !important;
  border: 1px solid #e2e8f0 !important;
  border-radius: 6px !important;
  cursor: pointer !important;
  color: #64748b !important;
  transition: background 0.15s ease, color 0.15s ease !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}
.stremzi-wrap .stremzi-host-url-copy:hover {
  background: var(--stremzi-brand-primary, #0ea5e9) !important;
  color: #ffffff !important;
  border-color: var(--stremzi-brand-primary, #0ea5e9) !important;
}

/* ============================================================
   v1.5.98: Pricing page v2 — matches extend-modal UX.
   ============================================================ */
.stremzi-wrap .stremzi-pricing-v2 {
  max-width: 720px !important;
  margin: 0 auto !important;
  padding: 24px 16px !important;
}
.stremzi-wrap .stremzi-pricing-v2-header {
  text-align: center !important;
  margin-bottom: 24px !important;
}
.stremzi-wrap .stremzi-pricing-v2-header h1 {
  margin: 0 0 6px !important;
  font-size: 26px !important;
  font-weight: 700 !important;
  color: #0e1a2b !important;
}
.stremzi-wrap .stremzi-pricing-v2-header p {
  margin: 0 !important;
  color: #64748b !important;
  font-size: 14px !important;
}

/* Tier tabs — underlined, centered */
.stremzi-wrap .stremzi-pricing-v2-tier-tabs {
  display: flex !important;
  justify-content: center !important;
  gap: 0 !important;
  margin-bottom: 18px !important;
  border-bottom: 2px solid #e2e8f0 !important;
  flex-wrap: wrap !important;
}
.stremzi-wrap .stremzi-pricing-v2-tier-tab {
  padding: 12px 28px !important;
  background: transparent !important;
  border: 0 !important;
  border-bottom: 2px solid transparent !important;
  margin-bottom: -2px !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  color: #64748b !important;
  cursor: pointer !important;
  transition: color 0.15s ease, border-color 0.15s ease !important;
  white-space: nowrap !important;
  text-decoration: none !important;
}
.stremzi-wrap .stremzi-pricing-v2-tier-tab:hover { color: #0e1a2b !important; }
.stremzi-wrap .stremzi-pricing-v2-tier-tab.is-active {
  color: var(--stremzi-brand-primary, #0ea5e9) !important;
  border-bottom-color: var(--stremzi-brand-primary, #0ea5e9) !important;
}

/* Tier groups: only active renders */
.stremzi-wrap .stremzi-pricing-v2-tier-group { display: none !important; }
.stremzi-wrap .stremzi-pricing-v2-tier-group.is-active { display: block !important; }

/* Device tabs — pill bar, centered */
.stremzi-wrap .stremzi-pricing-v2-dev-tabs {
  display: flex !important;
  justify-content: center !important;
  gap: 4px !important;
  padding: 4px !important;
  background: #f1f5f9 !important;
  border-radius: 10px !important;
  margin: 0 auto 18px !important;
  width: fit-content !important;
  max-width: 100% !important;
  flex-wrap: wrap !important;
}
.stremzi-wrap .stremzi-pricing-v2-dev-tab {
  padding: 8px 16px !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 8px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  color: #64748b !important;
  cursor: pointer !important;
  transition: background 0.15s ease, color 0.15s ease !important;
  white-space: nowrap !important;
  text-decoration: none !important;
}
.stremzi-wrap .stremzi-pricing-v2-dev-tab:hover { color: #0e1a2b !important; }
.stremzi-wrap .stremzi-pricing-v2-dev-tab.is-active {
  background: #ffffff !important;
  color: #0e1a2b !important;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.08) !important;
}

/* Panes */
.stremzi-wrap .stremzi-pricing-v2-panes { display: flex !important; flex-direction: column !important; }
.stremzi-wrap .stremzi-pricing-v2-pane {
  display: none !important;
  flex-direction: column !important;
  gap: 10px !important;
}
.stremzi-wrap .stremzi-pricing-v2-pane.is-active { display: flex !important; }

/* Package rows */
.stremzi-wrap .stremzi-pricing-v2-pack {
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  padding: 14px 16px !important;
  background: #f8fafc !important;
  border: 1px solid #e2e8f0 !important;
  border-radius: 12px !important;
  transition: border-color 0.15s ease, box-shadow 0.15s ease !important;
}
.stremzi-wrap .stremzi-pricing-v2-pack:hover {
  border-color: var(--stremzi-brand-primary, #0ea5e9) !important;
  box-shadow: 0 2px 8px rgba(14, 165, 233, 0.08) !important;
}
.stremzi-wrap .stremzi-pricing-v2-pack-info { flex: 1 !important; min-width: 0 !important; }
.stremzi-wrap .stremzi-pricing-v2-pack-info h4 {
  margin: 0 0 3px !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  color: #0e1a2b !important;
}
.stremzi-wrap .stremzi-pricing-v2-pack-meta {
  font-size: 12px !important;
  color: #64748b !important;
}
.stremzi-wrap .stremzi-pricing-v2-pack-price {
  font-weight: 700 !important;
  color: #0e1a2b !important;
  font-size: 16px !important;
  min-width: 80px !important;
  text-align: right !important;
  white-space: nowrap !important;
}
.stremzi-wrap .stremzi-pricing-v2-pack-price .woocommerce-Price-amount { font-size: 16px !important; }
.stremzi-wrap .stremzi-pricing-v2-pack a.stremzi-pricing-v2-buy-btn,
.stremzi-wrap .stremzi-pricing-v2-pack a.stremzi-pricing-v2-buy-btn:hover,
.stremzi-wrap .stremzi-pricing-v2-pack a.stremzi-pricing-v2-buy-btn:focus,
.stremzi-wrap .stremzi-pricing-v2-pack a.stremzi-pricing-v2-buy-btn:active,
.stremzi-wrap .stremzi-pricing-v2-pack a.stremzi-pricing-v2-buy-btn:visited {
  text-decoration: none !important;
  background-image: none !important;
}
.stremzi-wrap .stremzi-pricing-v2-pack a.stremzi-pricing-v2-buy-btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 9px 20px !important;
  min-height: 38px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  line-height: 1 !important;
  color: #ffffff !important;
  background: var(--stremzi-brand-primary, #0ea5e9) !important;
  border: 0 !important;
  border-radius: 999px !important;
  box-shadow: 0 1px 2px rgba(14, 165, 233, 0.25) !important;
  transition: background 0.15s ease, transform 0.1s ease, box-shadow 0.15s ease !important;
  white-space: nowrap !important;
  flex-shrink: 0 !important;
}
.stremzi-wrap .stremzi-pricing-v2-pack a.stremzi-pricing-v2-buy-btn:hover {
  background: var(--stremzi-brand-primary-hover, #0284c7) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 4px 10px rgba(14, 165, 233, 0.3) !important;
}
.stremzi-wrap .stremzi-pricing-v2-pack a.stremzi-pricing-v2-buy-btn:active { transform: translateY(0) !important; }

.stremzi-wrap .stremzi-pricing-v2-unavailable {
  color: #94a3b8 !important;
  font-size: 13px !important;
  font-style: italic !important;
}

/* Mobile: stack pack info/price/button */
@media (max-width: 540px) {
  .stremzi-wrap .stremzi-pricing-v2-pack {
    flex-wrap: wrap !important;
  }
  .stremzi-wrap .stremzi-pricing-v2-pack-info { flex: 1 1 100% !important; }
  .stremzi-wrap .stremzi-pricing-v2-pack-price { flex: 0 0 auto !important; text-align: left !important; min-width: 0 !important; }
  .stremzi-wrap .stremzi-pricing-v2-pack a.stremzi-pricing-v2-buy-btn { margin-left: auto !important; }
}

/* ============================================================
   v1.5.99: Pricing popup wrapper — trigger button + modal that
   overlays the whole screen. The modal content re-uses every
   .stremzi-pricing-v2-* rule from v1.5.98 so the inside looks
   identical to the dashboard extend modal.
   ============================================================ */
.stremzi-wrap .stremzi-pricing-trigger-btn,
.stremzi-wrap .stremzi-pricing-trigger-btn:hover,
.stremzi-wrap .stremzi-pricing-trigger-btn:focus,
.stremzi-wrap .stremzi-pricing-trigger-btn:active,
.stremzi-wrap .stremzi-pricing-trigger-btn:visited {
  text-decoration: none !important;
  background-image: none !important;
}
.stremzi-wrap .stremzi-pricing-trigger-btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 14px 32px !important;
  min-height: 48px !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  line-height: 1 !important;
  color: #ffffff !important;
  background: var(--stremzi-brand-primary, #0ea5e9) !important;
  border: 0 !important;
  border-radius: 999px !important;
  box-shadow: 0 2px 6px rgba(14, 165, 233, 0.25) !important;
  transition: background 0.15s ease, transform 0.1s ease, box-shadow 0.15s ease !important;
  cursor: pointer !important;
  white-space: nowrap !important;
}
.stremzi-wrap .stremzi-pricing-trigger-btn:hover {
  background: var(--stremzi-brand-primary-hover, #0284c7) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 6px 14px rgba(14, 165, 233, 0.3) !important;
}
.stremzi-wrap .stremzi-pricing-trigger-btn:active { transform: translateY(0) !important; }

/* The modal itself — hidden by default. */
.stremzi-pricing-modal {
  position: fixed !important;
  inset: 0 !important;
  z-index: 999999 !important;
  display: none !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 16px !important;
}
.stremzi-pricing-modal.is-open { display: flex !important; }
.stremzi-pricing-modal-backdrop {
  position: absolute !important;
  inset: 0 !important;
  background: rgba(15, 23, 42, 0.55) !important;
  backdrop-filter: blur(2px) !important;
  -webkit-backdrop-filter: blur(2px) !important;
}
.stremzi-pricing-modal-dialog {
  position: relative !important;
  width: 100% !important;
  max-width: 640px !important;
  max-height: calc(100vh - 32px) !important;
  background: #ffffff !important;
  border-radius: 16px !important;
  box-shadow: 0 20px 60px rgba(15, 23, 42, 0.25) !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
}
.stremzi-pricing-modal-head {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 18px 22px !important;
  border-bottom: 1px solid #e2e8f0 !important;
}
.stremzi-pricing-modal-title {
  margin: 0 !important;
  font-size: 17px !important;
  font-weight: 700 !important;
  color: #0e1a2b !important;
}
.stremzi-pricing-modal-close {
  background: transparent !important;
  border: 0 !important;
  padding: 6px !important;
  border-radius: 8px !important;
  color: #64748b !important;
  cursor: pointer !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: background 0.15s ease, color 0.15s ease !important;
}
.stremzi-pricing-modal-close:hover {
  background: #f1f5f9 !important;
  color: #0e1a2b !important;
}
.stremzi-pricing-modal-body {
  padding: 20px 22px !important;
  overflow-y: auto !important;
  flex: 1 !important;
}

/* Tighten header margin when rendered inside the modal (no hero needed). */
.stremzi-pricing-modal-body .stremzi-pricing-v2-header { display: none !important; }
/* Also hide the now-unused outer pricing container styles inside the modal. */
.stremzi-pricing-modal-body .stremzi-pricing-v2 { padding: 0 !important; max-width: 100% !important; }

/* Mobile tweaks — fill more of the viewport. */
@media (max-width: 540px) {
  .stremzi-pricing-modal { padding: 0 !important; }
  .stremzi-pricing-modal-dialog {
    max-width: 100% !important;
    max-height: 100vh !important;
    height: 100vh !important;
    border-radius: 0 !important;
  }
}

/* v1.5.119: geo currency hint shown alongside primary price */
.stremzi-pack-geo {
    display: block;
    font-size: 11px;
    font-weight: 500;
    color: #94a3b8;
    letter-spacing: 0.3px;
    margin-top: 2px;
    font-variant-numeric: tabular-nums;
}
.stremzi-pricing-card .stremzi-pack-geo,
.stremzi-extend-pack-price .stremzi-pack-geo {
    color: #94a3b8;
    font-weight: 500;
}
