/* ==========================================================================
   pricing/css/pricing-page.css
   Mobile-fixed full file
   ========================================================================== */

/* ==========================================================================
   Base / shared
   ========================================================================== */

:root{
  --pricing-bg-1:#f5fbff;
  --pricing-bg-2:#f9fcff;
  --pricing-surface:#ffffff;
  --pricing-surface-soft:#f7fbff;
  --pricing-text:#07111f;
  --pricing-text-soft:#475569;
  --pricing-text-muted:#64748b;
  --pricing-border:rgba(15,23,42,.08);
  --pricing-border-strong:rgba(15,23,42,.12);
  --pricing-shadow-lg:0 24px 70px rgba(2,6,23,.08);
  --pricing-shadow-md:0 18px 40px rgba(15,23,42,.06);
  --pricing-shadow-sm:0 12px 30px rgba(15,23,42,.05);
  --pricing-radius-xl:28px;
  --pricing-radius-lg:24px;
  --pricing-radius-md:20px;
  --pricing-radius-sm:16px;
  --pricing-accent:#119bd2;
  --pricing-accent-2:#33c8c1;
  --pricing-accent-deep:#0b4b8c;
  --pricing-dark:#07111f;
}

html,
body{
  max-width:100%;
  overflow-x:hidden;
}

body.mh-pricing-page,
body.mlh-pricing-page,
body.mh-pricing-page.mlh-pricing-page{
  background:
    radial-gradient(1200px 500px at 10% -10%, rgba(51,200,193,0.10), transparent 60%),
    radial-gradient(900px 420px at 90% 0%, rgba(17,155,210,0.09), transparent 60%),
    linear-gradient(180deg, var(--pricing-bg-1) 0%, var(--pricing-bg-2) 100%);
}

.pricing-page-main{
  position:relative;
  display:block;
  width:100%;
  max-width:100%;
  min-height:60vh;
  padding-top:132px;
  padding-bottom:40px;
  overflow:hidden;
}

.pricing-page-main *,
.pricing-page-main *::before,
.pricing-page-main *::after{
  box-sizing:border-box;
  min-width:0;
}

.pricing-page-main img,
.pricing-page-main svg,
.pricing-page-main video,
.pricing-page-main iframe{
  max-width:100%;
}

.pricing-page-main img{
  height:auto;
}

.pricing-page-main button,
.pricing-page-main input,
.pricing-page-main select,
.pricing-page-main textarea{
  font:inherit;
}

.pricing-page-main a{
  transition:all .2s ease;
}

.pricing-page-main a:focus-visible,
.pricing-page-main button:focus-visible,
.pricing-page-main input:focus-visible,
.pricing-page-main select:focus-visible,
.pricing-page-main [role="button"]:focus-visible{
  outline:2px solid rgba(17,155,210,.55);
  outline-offset:3px;
}

.section-block{
  position:relative;
}

.pricing-page-shell{
  width:min(1240px, calc(100% - 24px));
  max-width:100%;
  margin:0 auto;
  border-radius:var(--pricing-radius-xl);
  background:linear-gradient(180deg, rgba(255,255,255,0.92) 0%, rgba(247,252,255,0.96) 100%);
  border:1px solid rgba(11,75,140,0.08);
  box-shadow:
    var(--pricing-shadow-lg),
    inset 0 1px 0 rgba(255,255,255,0.7);
  backdrop-filter:blur(10px);
  overflow:hidden;
  position:relative;
}

.pricing-page-shell::before{
  content:"";
  position:absolute;
  inset:0 auto auto 0;
  width:100%;
  height:2px;
  background:linear-gradient(90deg, rgba(51,200,193,0), rgba(17,155,210,.45), rgba(51,200,193,0));
  opacity:.9;
  pointer-events:none;
}

.pricing-page-inner{
  position:relative;
  z-index:1;
  padding:20px;
}

.pricing-page-intro{
  padding:18px 18px 8px;
}

.pricing-page-intro-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border-radius:999px;
  font-size:12px;
  font-weight:900;
  letter-spacing:.2px;
  text-transform:uppercase;
  color:var(--pricing-accent-deep);
  background:linear-gradient(90deg, rgba(51,200,193,.18), rgba(17,155,210,.12));
  border:1px solid rgba(17,155,210,.12);
  max-width:100%;
  flex-wrap:wrap;
}

.pricing-page-intro h1{
  margin:14px 0 10px;
  font-size:clamp(2rem, 4vw, 3.35rem);
  line-height:1.05;
  letter-spacing:-0.03em;
  color:var(--pricing-text);
  font-weight:900;
  overflow-wrap:anywhere;
}

.pricing-page-intro p{
  margin:0;
  max-width:880px;
  color:#3a4a5e;
  font-size:1rem;
  line-height:1.75;
}

.pricing-sections-stack{
  display:grid;
  gap:18px;
  padding:18px;
}

.pricing-fallback-section{
  position:relative;
}

.pricing-fallback-card{
  position:relative;
  padding:26px;
  border-radius:22px;
  background:
    radial-gradient(600px 180px at 100% 0%, rgba(17,155,210,.08), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,.96), rgba(247,251,255,.96));
  border:1px solid var(--pricing-border);
  box-shadow:var(--pricing-shadow-sm);
}

.pricing-fallback-eyebrow{
  display:inline-flex;
  align-items:center;
  padding:6px 10px;
  border-radius:999px;
  font-size:11px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.18em;
  color:var(--pricing-accent-deep);
  background:rgba(17,155,210,.08);
  border:1px solid rgba(17,155,210,.12);
  max-width:100%;
  flex-wrap:wrap;
}

.pricing-fallback-card h2{
  margin:14px 0 8px;
  color:#0b1220;
  font-size:clamp(1.35rem, 2.4vw, 2rem);
  line-height:1.18;
  font-weight:900;
  letter-spacing:-0.02em;
  overflow-wrap:anywhere;
}

.pricing-fallback-card p{
  margin:0;
  color:var(--pricing-text-soft);
  line-height:1.72;
  font-size:.98rem;
  max-width:840px;
}

/* ==========================================================================
   Section 1: pricing-scene-banner.php
   ========================================================================== */

.pricing-scene-banner{
  position:relative;
  overflow:hidden;
}

.pricing-scene-banner__shell{
  position:relative;
  padding:28px;
  border-radius:24px;
  background:
    radial-gradient(1000px 420px at 0% 0%, rgba(51,200,193,.13), transparent 55%),
    radial-gradient(800px 420px at 100% 0%, rgba(17,155,210,.13), transparent 55%),
    linear-gradient(180deg, rgba(7,17,31,.98) 0%, rgba(10,20,38,.98) 100%);
  color:#fff;
  border:1px solid rgba(255,255,255,.08);
  box-shadow:
    0 22px 60px rgba(2,6,23,.22),
    inset 0 1px 0 rgba(255,255,255,.05);
}

.pricing-scene-banner__shell::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(90deg, rgba(51,200,193,.05), transparent 20%, transparent 80%, rgba(17,155,210,.05)),
    repeating-linear-gradient(
      90deg,
      rgba(255,255,255,.02) 0,
      rgba(255,255,255,.02) 1px,
      transparent 1px,
      transparent 110px
    );
  opacity:.75;
}

.pricing-scene-banner__grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(0, 1.05fr) minmax(360px, .95fr);
  gap:24px;
  align-items:stretch;
}

.pricing-scene-banner__content{
  display:flex;
  flex-direction:column;
  gap:16px;
  min-width:0;
}

.pricing-scene-banner__intro{
  display:flex;
  flex-direction:column;
  gap:16px;
  min-width:0;
}

.pricing-scene-banner__eyebrow{
  display:inline-flex;
  align-items:center;
  width:max-content;
  max-width:100%;
  gap:8px;
  padding:8px 12px;
  border-radius:999px;
  font-size:12px;
  font-weight:900;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:#d9fbff;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  backdrop-filter:blur(8px);
  flex-wrap:wrap;
}

.pricing-scene-banner__eyebrow-dot{
  width:8px;
  height:8px;
  border-radius:50%;
  background:linear-gradient(180deg,#33c8c1,#119bd2);
  box-shadow:0 0 16px rgba(51,200,193,.8);
  flex:0 0 auto;
}

.pricing-scene-banner__eyebrow-text{
  display:inline-block;
}

.pricing-scene-banner__title{
  margin:0;
  font-size:clamp(2rem, 4vw, 3.5rem);
  line-height:1.03;
  letter-spacing:-0.04em;
  font-weight:950;
  color:#ffffff;
  max-width:900px;
  overflow-wrap:anywhere;
}

.pricing-scene-banner__text{
  margin:0;
  max-width:840px;
  color:rgba(231,239,255,.88);
  line-height:1.8;
  font-size:1rem;
}

.pricing-scene-banner__support-note{
  display:flex;
  align-items:flex-start;
  gap:12px;
  padding:14px 16px;
  border-radius:18px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08);
  color:#ecf8ff;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
}

.pricing-scene-banner__support-icon{
  width:38px;
  height:38px;
  border-radius:12px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(180deg, rgba(51,200,193,.28), rgba(17,155,210,.18));
  border:1px solid rgba(255,255,255,.12);
  flex:0 0 auto;
}

.pricing-scene-banner__support-icon-svg{
  display:block;
}

.pricing-scene-banner__support-copy{
  min-width:0;
}

.pricing-scene-banner__support-title{
  display:block;
  margin-bottom:4px;
  font-size:1rem;
  color:#fff;
}

.pricing-scene-banner__support-text{
  display:block;
  color:rgba(231,239,255,.86);
  line-height:1.7;
  font-size:.96rem;
}

.pricing-scene-banner__benefits{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:14px;
}

.pricing-scene-banner__benefit{
  min-width:0;
  padding:16px;
  border-radius:18px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
  display:flex;
  align-items:flex-start;
  gap:12px;
}

.pricing-scene-banner__benefit-icon{
  width:38px;
  height:38px;
  border-radius:12px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(180deg, rgba(51,200,193,.20), rgba(17,155,210,.16));
  border:1px solid rgba(255,255,255,.10);
  flex:0 0 auto;
}

.pricing-scene-banner__benefit-icon-dot{
  width:10px;
  height:10px;
  border-radius:50%;
  background:linear-gradient(180deg,#33c8c1,#119bd2);
  box-shadow:0 0 14px rgba(51,200,193,.75);
}

.pricing-scene-banner__benefit-content{
  min-width:0;
}

.pricing-scene-banner__benefit-title{
  margin:0 0 8px;
  font-size:1.04rem;
  line-height:1.25;
  color:#fff;
  font-weight:850;
  letter-spacing:-0.02em;
  overflow-wrap:anywhere;
}

.pricing-scene-banner__benefit-text{
  margin:0;
  color:rgba(231,239,255,.84);
  line-height:1.7;
  font-size:.95rem;
}

.pricing-scene-banner__compare{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:16px;
}

.pricing-scene-banner__compare-card{
  min-width:0;
  padding:18px;
  border-radius:20px;
  background:linear-gradient(180deg, rgba(255,255,255,.085), rgba(255,255,255,.05));
  border:1px solid rgba(255,255,255,.1);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.06),
    0 14px 32px rgba(0,0,0,.12);
}

.pricing-scene-banner__compare-header{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
}

.pricing-scene-banner__compare-badge{
  display:inline-flex;
  align-items:center;
  padding:7px 10px;
  border-radius:999px;
  font-size:11px;
  font-weight:900;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:#d7f8ff;
  background:rgba(17,155,210,.18);
  border:1px solid rgba(255,255,255,.1);
  max-width:100%;
  flex-wrap:wrap;
}

.pricing-scene-banner__compare-title{
  margin:14px 0 8px;
  font-size:1.22rem;
  line-height:1.2;
  color:#fff;
  font-weight:900;
  letter-spacing:-0.02em;
  overflow-wrap:anywhere;
}

.pricing-scene-banner__compare-text{
  margin:0 0 14px;
  color:rgba(231,239,255,.84);
  line-height:1.72;
  font-size:.95rem;
}

.pricing-scene-banner__compare-list{
  margin:0;
  padding:0;
  list-style:none;
  display:grid;
  gap:9px;
}

.pricing-scene-banner__compare-item{
  display:flex;
  align-items:flex-start;
  gap:10px;
  color:#f4fbff;
  font-size:.93rem;
  line-height:1.55;
}

.pricing-scene-banner__compare-item-marker{
  width:8px;
  height:8px;
  margin-top:.45rem;
  border-radius:50%;
  background:linear-gradient(180deg,#33c8c1,#119bd2);
  box-shadow:0 0 12px rgba(51,200,193,.6);
  flex:0 0 auto;
}

.pricing-scene-banner__compare-item-text{
  min-width:0;
}

.pricing-scene-banner__visual{
  position:relative;
  min-height:640px;
  border-radius:24px;
  overflow:hidden;
  background:
    radial-gradient(circle at 50% 18%, rgba(51,200,193,.18), transparent 28%),
    radial-gradient(circle at 25% 75%, rgba(17,155,210,.15), transparent 22%),
    linear-gradient(180deg, rgba(6,12,22,.9) 0%, rgba(10,18,34,.96) 100%);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.06),
    0 18px 40px rgba(0,0,0,.2);
}

.pricing-scene-banner__visual::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(circle at 20% 20%, rgba(51,200,193,.1), transparent 18%),
    radial-gradient(circle at 80% 20%, rgba(17,155,210,.1), transparent 18%),
    linear-gradient(180deg, transparent 0%, rgba(255,255,255,.02) 100%);
}

.pricing-scene-banner__scene-canvas{
  position:absolute;
  inset:0;
  z-index:1;
  width:100%;
  height:100%;
}

.pricing-scene-banner__scene-fallback{
  position:absolute;
  inset:0;
  z-index:0;
  overflow:hidden;
}

.pricing-scene-banner__scene-half{
  position:absolute;
  top:0;
  bottom:0;
  width:50%;
  padding:22px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}

.pricing-scene-banner__scene-half--left{
  left:0;
  border-right:1px solid rgba(255,255,255,.06);
  background:
    linear-gradient(180deg, rgba(51,200,193,.05), transparent 45%),
    linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.01));
}

.pricing-scene-banner__scene-half--right{
  right:0;
  background:
    linear-gradient(180deg, rgba(17,155,210,.06), transparent 45%),
    linear-gradient(180deg, rgba(255,255,255,.01), rgba(255,255,255,.015));
}

.pricing-scene-banner__scene-panel-head{
  display:flex;
  align-items:center;
  justify-content:flex-start;
}

.pricing-scene-banner__scene-panel-head--end{
  justify-content:flex-end;
}

.pricing-scene-banner__scene-title{
  display:inline-flex;
  align-items:center;
  gap:10px;
  width:max-content;
  max-width:100%;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.1);
  color:#effbff;
  font-size:12px;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
  flex-wrap:wrap;
}

.pricing-scene-banner__scene-title-dot{
  width:8px;
  height:8px;
  border-radius:50%;
  background:#33c8c1;
  box-shadow:0 0 16px rgba(51,200,193,.75);
}

.pricing-scene-banner__scene-title-text{
  display:inline-block;
}

.pricing-scene-banner__node-stack{
  display:grid;
  gap:12px;
  max-width:210px;
}

.pricing-scene-banner__node-stack--right{
  margin-left:auto;
}

.pricing-scene-banner__node{
  position:relative;
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px 14px;
  border-radius:16px;
  color:#fff;
  font-size:.92rem;
  font-weight:800;
  letter-spacing:-0.01em;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.1);
  box-shadow:0 10px 24px rgba(0,0,0,.12);
  backdrop-filter:blur(8px);
}

.pricing-scene-banner__node::after{
  content:"";
  position:absolute;
  right:-26px;
  top:50%;
  width:26px;
  height:2px;
  transform:translateY(-50%);
  background:linear-gradient(90deg, rgba(51,200,193,.85), rgba(17,155,210,.15));
}

.pricing-scene-banner__scene-half--right .pricing-scene-banner__node::after{
  left:-26px;
  right:auto;
  background:linear-gradient(90deg, rgba(17,155,210,.15), rgba(51,200,193,.85));
}

.pricing-scene-banner__node-icon{
  width:12px;
  height:12px;
  border-radius:50%;
  background:linear-gradient(180deg,#33c8c1,#119bd2);
  box-shadow:0 0 14px rgba(51,200,193,.75);
  flex:0 0 auto;
}

.pricing-scene-banner__node-label{
  min-width:0;
}

.pricing-scene-banner__center-hub{
  position:absolute;
  top:50%;
  left:50%;
  width:170px;
  height:170px;
  transform:translate(-50%, -50%);
  z-index:0;
  border-radius:50%;
  background:
    radial-gradient(circle at 50% 50%, rgba(51,200,193,.24), rgba(17,155,210,.08) 45%, transparent 70%);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:
    0 0 90px rgba(17,155,210,.2),
    inset 0 0 30px rgba(255,255,255,.04);
}

.pricing-scene-banner__center-hub::before,
.pricing-scene-banner__center-hub::after{
  content:"";
  position:absolute;
  inset:20px;
  border-radius:50%;
  border:1px dashed rgba(255,255,255,.12);
}

.pricing-scene-banner__center-hub::after{
  inset:42px;
  border-style:solid;
  border-color:rgba(51,200,193,.18);
}

.pricing-scene-banner__center-label{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  color:#e7f8ff;
  font-weight:900;
  font-size:1rem;
  line-height:1.25;
  letter-spacing:-0.02em;
  padding:28px;
}

.pricing-scene-banner__signal{
  position:absolute;
  top:50%;
  left:50%;
  width:46%;
  height:2px;
  transform-origin:left center;
  background:linear-gradient(90deg, rgba(51,200,193,.8), rgba(17,155,210,.2));
  opacity:.65;
  filter:drop-shadow(0 0 12px rgba(51,200,193,.35));
}

.pricing-scene-banner__signal--one{
  transform:translate(-50%, -50%) rotate(-24deg);
}

.pricing-scene-banner__signal--two{
  transform:translate(-50%, -50%) rotate(24deg);
}

.pricing-scene-banner__signal--three{
  transform:translate(-50%, -50%) rotate(180deg);
}

.pricing-scene-banner__signal--four{
  transform:translate(-50%, -50%) rotate(156deg);
}

.pricing-scene-banner__legend{
  position:absolute;
  left:18px;
  right:18px;
  bottom:18px;
  z-index:2;
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:12px;
}

.pricing-scene-banner__legend-card{
  padding:14px;
  border-radius:16px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.08);
  backdrop-filter:blur(8px);
  box-shadow:0 10px 24px rgba(0,0,0,.12);
}

.pricing-scene-banner__legend-title{
  display:block;
  margin:0 0 6px;
  color:#fff;
  font-size:.95rem;
  line-height:1.3;
  font-weight:850;
}

.pricing-scene-banner__legend-text{
  display:block;
  color:rgba(231,239,255,.82);
  font-size:.88rem;
  line-height:1.55;
}

.pricing-scene-banner__visual-overlay{
  position:absolute;
  inset:0;
  z-index:3;
  pointer-events:none;
  background:
    radial-gradient(circle at 50% 50%, transparent 0%, transparent 52%, rgba(255,255,255,.02) 100%);
}

/* ==========================================================================
   Section 2: pricing-calculator.php
   ========================================================================== */

.pricing-calculator-section{
  position:relative;
}

.pricing-calculator-shell{
  position:relative;
  padding:28px;
  border-radius:24px;
  background:
    radial-gradient(1000px 260px at 100% 0%, rgba(17,155,210,.08), transparent 50%),
    radial-gradient(800px 220px at 0% 0%, rgba(51,200,193,.08), transparent 50%),
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(247,251,255,.98));
  border:1px solid var(--pricing-border);
  box-shadow:
    var(--pricing-shadow-md),
    inset 0 1px 0 rgba(255,255,255,.9);
  overflow:hidden;
}

.pricing-calculator-shell::before{
  content:"";
  position:absolute;
  inset:0 auto auto 0;
  width:100%;
  height:2px;
  background:linear-gradient(90deg, rgba(51,200,193,.08), rgba(17,155,210,.45), rgba(51,200,193,.08));
  pointer-events:none;
}

.pricing-calculator-section-intro{
  position:relative;
  z-index:1;
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-bottom:22px;
  padding:0 0 8px;
}

.pricing-calculator-section-intro__eyebrow{
  display:inline-flex;
  align-items:center;
  width:max-content;
  max-width:100%;
  padding:8px 12px;
  border-radius:999px;
  background:linear-gradient(90deg, rgba(51,200,193,.12), rgba(17,155,210,.10));
  border:1px solid rgba(17,155,210,.10);
  color:var(--pricing-accent-deep);
  font-size:12px;
  font-weight:900;
  letter-spacing:.14em;
  text-transform:uppercase;
  flex-wrap:wrap;
}

.pricing-calculator-section-intro__heading{
  margin:0;
  color:var(--pricing-text);
  font-size:clamp(1.85rem, 3vw, 2.9rem);
  line-height:1.08;
  letter-spacing:-0.03em;
  font-weight:950;
  overflow-wrap:anywhere;
}

.pricing-calculator-section-intro__text{
  margin:0;
  max-width:840px;
  color:var(--pricing-text-soft);
  line-height:1.75;
  font-size:1rem;
}

.pricing-calculator-header{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:18px;
  margin-bottom:20px;
}

.pricing-calculator-header__left{
  min-width:0;
}

.pricing-calculator-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border-radius:999px;
  background:linear-gradient(90deg, rgba(51,200,193,.12), rgba(17,155,210,.10));
  border:1px solid rgba(17,155,210,.10);
  color:var(--pricing-accent-deep);
  font-size:12px;
  font-weight:900;
  letter-spacing:.14em;
  text-transform:uppercase;
  max-width:100%;
  flex-wrap:wrap;
}

.pricing-calculator-badge__dot{
  width:8px;
  height:8px;
  border-radius:50%;
  background:linear-gradient(180deg,#33c8c1,#119bd2);
  box-shadow:0 0 10px rgba(17,155,210,.35);
  flex:0 0 auto;
}

.pricing-calculator-badge__text{
  display:inline-block;
}

.pricing-calculator-title{
  margin:14px 0 8px;
  color:var(--pricing-text);
  font-size:clamp(1.4rem, 2.6vw, 2.2rem);
  line-height:1.08;
  letter-spacing:-0.03em;
  font-weight:950;
  overflow-wrap:anywhere;
}

.pricing-calculator-subtitle{
  margin:0;
  color:var(--pricing-text-soft);
  line-height:1.75;
  max-width:760px;
  font-size:1rem;
}

.pricing-calculator-free-note{
  flex:0 0 auto;
  min-width:220px;
  max-width:320px;
  padding:16px;
  border-radius:18px;
  background:linear-gradient(180deg, rgba(11,75,140,.04), rgba(17,155,210,.06));
  border:1px solid rgba(17,155,210,.12);
  box-shadow:0 10px 22px rgba(15,23,42,.04);
}

.pricing-calculator-free-note__title{
  display:block;
  margin-bottom:6px;
  color:var(--pricing-text);
  font-size:1rem;
  font-weight:900;
}

.pricing-calculator-free-note__text{
  display:block;
  color:#526277;
  line-height:1.65;
  font-size:.93rem;
}

.pricing-calculator-layout{
  display:grid;
  grid-template-columns:minmax(0, 1.2fr) minmax(320px, .8fr);
  gap:18px;
  align-items:start;
}

.pricing-calculator-form-card,
.pricing-calculator-summary-card{
  border-radius:22px;
  background:#fff;
  border:1px solid var(--pricing-border);
  box-shadow:0 14px 34px rgba(15,23,42,.05);
  min-width:0;
}

.pricing-calculator-form-card{
  padding:20px;
}

.pricing-calculator-summary-card{
  padding:18px;
  position:sticky;
  top:116px;
}

.pricing-calculator-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:14px;
}

.pricing-calculator-field{
  display:flex;
  flex-direction:column;
  gap:8px;
  min-width:0;
}

.pricing-calculator-field--full{
  grid-column:1 / -1;
}

.pricing-calculator-label{
  color:var(--pricing-text);
  font-size:.95rem;
  font-weight:850;
  letter-spacing:-0.01em;
}

.pricing-calculator-input,
.pricing-calculator-select{
  width:100%;
  min-height:52px;
  padding:14px 15px;
  border-radius:15px;
  border:1px solid rgba(15,23,42,.12);
  background:#fff;
  color:#0f172a;
  font-size:.97rem;
  line-height:1.4;
  transition:border-color .2s ease, box-shadow .2s ease, transform .2s ease, background-color .2s ease;
  outline:none;
  appearance:none;
}

.pricing-calculator-input::placeholder{
  color:#94a3b8;
}

.pricing-calculator-input:focus,
.pricing-calculator-select:focus{
  border-color:rgba(17,155,210,.45);
  box-shadow:0 0 0 4px rgba(17,155,210,.10);
}

.pricing-calculator-helper{
  margin:0;
  color:#526277;
  font-size:.9rem;
  line-height:1.65;
}

.pricing-calculator-radio-row{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:10px;
}

.pricing-calculator-radio{
  position:relative;
}

.pricing-calculator-radio input{
  position:absolute;
  opacity:0;
  pointer-events:none;
}

.pricing-calculator-radio label{
  display:flex;
  flex-direction:column;
  gap:6px;
  min-height:100%;
  padding:14px;
  border-radius:16px;
  border:1px solid rgba(15,23,42,.10);
  background:linear-gradient(180deg,#fff,#f8fbff);
  cursor:pointer;
  transition:border-color .2s ease, transform .2s ease, box-shadow .2s ease, background .2s ease;
}

.pricing-calculator-radio label strong{
  color:var(--pricing-text);
  font-size:.95rem;
  font-weight:900;
}

.pricing-calculator-radio label span{
  color:#5b6b7f;
  font-size:.86rem;
  line-height:1.5;
}

.pricing-calculator-radio input:checked + label{
  border-color:rgba(17,155,210,.42);
  box-shadow:0 10px 24px rgba(17,155,210,.12);
  background:linear-gradient(180deg, rgba(17,155,210,.08), rgba(51,200,193,.06));
  transform:translateY(-1px);
}

.pricing-calculator-preset-row{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.pricing-calculator-preset{
  appearance:none;
  border:1px solid rgba(15,23,42,.10);
  background:#fff;
  color:#0b1220;
  border-radius:999px;
  padding:10px 14px;
  font-size:.88rem;
  font-weight:850;
  line-height:1.2;
  cursor:pointer;
  transition:all .2s ease;
  max-width:100%;
}

.pricing-calculator-preset:hover{
  border-color:rgba(17,155,210,.30);
  transform:translateY(-1px);
}

.pricing-calculator-preset.is-active{
  color:#fff;
  border-color:transparent;
  background:linear-gradient(90deg,#33c8c1,#119bd2);
  box-shadow:0 10px 20px rgba(17,155,210,.18);
}

.pricing-calculator-group{
  margin-top:18px;
  padding-top:18px;
  border-top:1px solid rgba(15,23,42,.08);
}

.pricing-calculator-group:first-of-type{
  margin-top:18px;
}

.pricing-calculator-group-head{
  margin-bottom:12px;
}

.pricing-calculator-group-title{
  margin:0 0 6px;
  color:var(--pricing-text);
  font-size:1.1rem;
  line-height:1.2;
  font-weight:900;
  letter-spacing:-0.02em;
  overflow-wrap:anywhere;
}

.pricing-calculator-group-description{
  margin:0;
  color:#5b6b7f;
  line-height:1.65;
  font-size:.92rem;
}

.pricing-calculator-products{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:12px;
}

.pricing-calculator-product{
  position:relative;
}

.pricing-calculator-product input{
  position:absolute;
  opacity:0;
  pointer-events:none;
}

.pricing-calculator-product label{
  display:flex;
  flex-direction:column;
  gap:10px;
  min-height:100%;
  padding:16px;
  border-radius:18px;
  border:1px solid rgba(15,23,42,.10);
  background:linear-gradient(180deg,#fff,#fbfdff);
  cursor:pointer;
  transition:border-color .2s ease, transform .2s ease, box-shadow .2s ease, background .2s ease;
  box-shadow:0 6px 18px rgba(15,23,42,.03);
}

.pricing-calculator-product label:hover{
  transform:translateY(-1px);
  border-color:rgba(17,155,210,.24);
}

.pricing-calculator-product input:checked + label{
  border-color:rgba(17,155,210,.42);
  background:linear-gradient(180deg, rgba(17,155,210,.08), rgba(51,200,193,.06));
  box-shadow:0 14px 28px rgba(17,155,210,.10);
  transform:translateY(-1px);
}

.pricing-calculator-product-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}

.pricing-calculator-product-title{
  margin:0;
  color:var(--pricing-text);
  font-size:1rem;
  line-height:1.25;
  font-weight:900;
  letter-spacing:-0.02em;
  overflow-wrap:anywhere;
}

.pricing-calculator-product-price{
  flex:0 0 auto;
  padding:7px 10px;
  border-radius:999px;
  color:var(--pricing-accent-deep);
  background:rgba(17,155,210,.08);
  border:1px solid rgba(17,155,210,.12);
  font-size:.85rem;
  font-weight:900;
  white-space:nowrap;
  max-width:100%;
}

.pricing-calculator-product-desc{
  margin:0;
  color:#5b6b7f;
  line-height:1.62;
  font-size:.91rem;
}

.pricing-calculator-product-tags{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.pricing-calculator-tag{
  display:inline-flex;
  align-items:center;
  padding:6px 9px;
  border-radius:999px;
  background:rgba(15,23,42,.05);
  color:#415065;
  font-size:.78rem;
  font-weight:800;
  line-height:1.1;
  max-width:100%;
}

.pricing-calculator-inline-note{
  margin-top:16px;
  padding:14px 16px;
  border-radius:18px;
  background:linear-gradient(180deg, rgba(51,200,193,.06), rgba(17,155,210,.05));
  border:1px solid rgba(17,155,210,.10);
  color:#44566c;
  line-height:1.7;
  font-size:.93rem;
}

.pricing-calculator-inline-note__title{
  display:block;
  color:var(--pricing-text);
  font-weight:900;
  margin-bottom:6px;
}

.pricing-calculator-inline-note__text{
  display:block;
}

.pricing-calculator-summary-head{
  display:block;
}

.pricing-calculator-summary-title{
  margin:0 0 4px;
  color:var(--pricing-text);
  font-size:1.25rem;
  line-height:1.2;
  font-weight:950;
  letter-spacing:-0.03em;
  overflow-wrap:anywhere;
}

.pricing-calculator-summary-text{
  margin:0;
  color:#5b6b7f;
  line-height:1.65;
  font-size:.92rem;
}

.pricing-calculator-results{
  display:grid;
  gap:12px;
  margin-top:16px;
}

.pricing-calculator-result-card{
  padding:16px;
  border-radius:18px;
  background:linear-gradient(180deg,#fff,#f8fbff);
  border:1px solid rgba(15,23,42,.08);
  box-shadow:0 10px 22px rgba(15,23,42,.04);
}

.pricing-calculator-result-card small{
  display:block;
  margin-bottom:8px;
  color:#526277;
  font-size:.82rem;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.12em;
}

.pricing-calculator-result-value{
  color:var(--pricing-text);
  font-size:1.75rem;
  line-height:1.05;
  font-weight:950;
  letter-spacing:-0.04em;
  overflow-wrap:anywhere;
}

.pricing-calculator-result-note{
  margin-top:8px;
  color:#5b6b7f;
  line-height:1.6;
  font-size:.88rem;
}

.pricing-calculator-summary-list{
  margin-top:14px;
  display:grid;
  gap:10px;
}

.pricing-calculator-summary-row{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
  padding:12px 14px;
  border-radius:15px;
  background:rgba(15,23,42,.03);
  border:1px solid rgba(15,23,42,.05);
}

.pricing-calculator-summary-row strong{
  color:var(--pricing-text);
  font-size:.9rem;
  font-weight:850;
}

.pricing-calculator-summary-row span{
  color:#526277;
  font-size:.9rem;
  text-align:right;
  line-height:1.5;
  overflow-wrap:anywhere;
}

.pricing-calculator-formula-wrap{
  margin-top:16px;
  padding:16px;
  border-radius:18px;
  background:linear-gradient(180deg, rgba(11,75,140,.03), rgba(17,155,210,.05));
  border:1px solid rgba(17,155,210,.10);
}

.pricing-calculator-formula-title{
  margin:0 0 10px;
  color:var(--pricing-text);
  font-size:1rem;
  line-height:1.2;
  font-weight:900;
}

.pricing-calculator-formula-list{
  display:grid;
  gap:10px;
}

.pricing-calculator-formula{
  padding:12px 14px;
  border-radius:14px;
  background:#fff;
  border:1px solid rgba(15,23,42,.07);
  color:#334155;
  font-size:.92rem;
  line-height:1.65;
  overflow:auto hidden;
}

.pricing-calculator-formula-label{
  display:block;
  margin-bottom:6px;
  color:var(--pricing-text);
  font-weight:900;
}

.pricing-calculator-support-note{
  margin-top:14px;
  padding:14px 15px;
  border-radius:16px;
  background:linear-gradient(180deg, rgba(51,200,193,.05), rgba(17,155,210,.04));
  border:1px solid rgba(17,155,210,.09);
  color:#44566c;
  line-height:1.7;
  font-size:.92rem;
}

.pricing-calculator-cta-wrap{
  margin-top:16px;
  display:grid;
  gap:10px;
}

.pricing-calculator-whatsapp{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  width:100%;
  min-height:52px;
  padding:12px 16px;
  border-radius:16px;
  background:linear-gradient(90deg,#33c8c1,#119bd2);
  color:#fff !important;
  font-size:.96rem;
  font-weight:950;
  text-decoration:none;
  box-shadow:0 12px 24px rgba(17,155,210,.18);
  transition:transform .2s ease, filter .2s ease, box-shadow .2s ease;
  text-align:center;
}

.pricing-calculator-whatsapp:hover{
  color:#fff !important;
  transform:translateY(-1px);
  filter:brightness(.98);
}

.pricing-calculator-whatsapp__icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex:0 0 auto;
}

.pricing-calculator-whatsapp__text{
  display:inline-block;
}

.pricing-calculator-reset{
  appearance:none;
  width:100%;
  min-height:48px;
  padding:12px 16px;
  border-radius:16px;
  border:1px solid rgba(15,23,42,.12);
  background:#fff;
  color:#0f172a;
  font-size:.94rem;
  font-weight:850;
  cursor:pointer;
  transition:all .2s ease;
}

.pricing-calculator-reset:hover{
  border-color:rgba(17,155,210,.28);
  transform:translateY(-1px);
}

.pricing-calculator-footer-note{
  margin-top:14px;
  color:#64748b;
  line-height:1.7;
  font-size:.88rem;
}

.pricing-calculator-selected-products{
  color:#526277;
  font-size:.9rem;
  line-height:1.6;
  word-break:break-word;
}

.pricing-calculator-selected-products.is-empty{
  color:#94a3b8;
}

/* ==========================================================================
   Section 3: pricing-demo.php
   ========================================================================== */

.pricing-demo-section{
  position:relative;
}

.pricing-demo-shell{
  position:relative;
  padding:28px;
  border-radius:24px;
  background:
    radial-gradient(900px 260px at 0% 0%, rgba(51,200,193,.08), transparent 50%),
    radial-gradient(900px 260px at 100% 0%, rgba(17,155,210,.08), transparent 50%),
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(247,251,255,.98));
  border:1px solid rgba(15,23,42,.08);
  box-shadow:
    0 18px 40px rgba(15,23,42,.06),
    inset 0 1px 0 rgba(255,255,255,.88);
  overflow:hidden;
}

.pricing-demo-shell::before{
  content:"";
  position:absolute;
  inset:0 auto auto 0;
  width:100%;
  height:2px;
  background:linear-gradient(90deg, rgba(51,200,193,.08), rgba(17,155,210,.45), rgba(51,200,193,.08));
  pointer-events:none;
}

.pricing-demo-section-intro{
  position:relative;
  z-index:1;
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-bottom:18px;
}

.pricing-demo-section-intro__eyebrow{
  display:inline-flex;
  align-items:center;
  width:max-content;
  max-width:100%;
  padding:8px 12px;
  border-radius:999px;
  background:linear-gradient(90deg, rgba(51,200,193,.12), rgba(17,155,210,.10));
  border:1px solid rgba(17,155,210,.10);
  color:var(--pricing-accent-deep);
  font-size:12px;
  font-weight:900;
  letter-spacing:.14em;
  text-transform:uppercase;
  flex-wrap:wrap;
}

.pricing-demo-section-intro__heading{
  margin:0;
  color:var(--pricing-text);
  font-size:clamp(1.7rem, 3vw, 2.45rem);
  line-height:1.08;
  letter-spacing:-0.03em;
  font-weight:950;
  overflow-wrap:anywhere;
}

.pricing-demo-section-intro__text{
  margin:0;
  max-width:860px;
  color:var(--pricing-text-soft);
  line-height:1.75;
  font-size:1rem;
}

.pricing-demo-stage{
  position:relative;
  display:block;
  width:100%;
  padding:0;
  border-radius:24px;
  overflow:hidden;
  background:
    radial-gradient(circle at 50% 20%, rgba(51,200,193,.16), transparent 32%),
    linear-gradient(180deg, #07111f 0%, #0d1d34 100%);
  border:1px solid rgba(15,23,42,.08);
  box-shadow:0 20px 42px rgba(15,23,42,.10);
  cursor:pointer;
  text-align:left;
  appearance:none;
  -webkit-appearance:none;
}

.pricing-demo-stage::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, rgba(7,17,31,.08), rgba(7,17,31,.24)),
    radial-gradient(circle at center, rgba(255,255,255,.04), transparent 40%);
  pointer-events:none;
}

.pricing-demo-stage__media{
  position:relative;
  width:100%;
  aspect-ratio:16 / 9;
  overflow:hidden;
}

.pricing-demo-stage__media img,
.pricing-demo-stage__media video,
.pricing-demo-stage__media iframe{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:transform .45s ease;
}

.pricing-demo-stage:hover .pricing-demo-stage__media img{
  transform:scale(1.03);
}

.pricing-demo-stage__empty{
  width:100%;
  height:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#dbeafe;
  font-size:1rem;
  font-weight:800;
  letter-spacing:-0.01em;
  text-align:center;
  padding:20px;
}

.pricing-demo-stage__overlay{
  position:absolute;
  inset:0;
  z-index:2;
  display:flex;
  align-items:center;
  justify-content:center;
  pointer-events:none;
}

.pricing-demo-stage__play{
  width:92px;
  height:92px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(180deg, rgba(255,255,255,.92), rgba(245,250,255,.92));
  border:1px solid rgba(255,255,255,.55);
  box-shadow:
    0 18px 40px rgba(2,6,23,.24),
    0 0 0 14px rgba(255,255,255,.08);
  transition:transform .25s ease, box-shadow .25s ease;
}

.pricing-demo-stage:hover .pricing-demo-stage__play{
  transform:scale(1.05);
  box-shadow:
    0 20px 44px rgba(2,6,23,.28),
    0 0 0 16px rgba(255,255,255,.10);
}

.pricing-demo-stage__play svg{
  margin-left:5px;
  color:var(--pricing-accent-deep);
}

.pricing-demo-stage__content{
  position:relative;
  z-index:2;
  padding:18px 20px 20px;
  background:linear-gradient(180deg, rgba(7,17,31,.12), rgba(7,17,31,.32));
  border-top:1px solid rgba(255,255,255,.08);
}

.pricing-demo-stage__title{
  margin:0 0 6px;
  color:#fff;
  font-size:1.15rem;
  line-height:1.25;
  font-weight:900;
  letter-spacing:-0.02em;
  overflow-wrap:anywhere;
}

.pricing-demo-stage__text{
  margin:0;
  color:rgba(231,239,255,.84);
  line-height:1.7;
  font-size:.95rem;
}

.pricing-demo-modal{
  position:fixed;
  inset:0;
  z-index:30050;
  display:none;
  align-items:center;
  justify-content:center;
  padding:18px;
}

.pricing-demo-modal.is-open{
  display:flex;
}

.pricing-demo-modal__backdrop{
  position:absolute;
  inset:0;
  background:rgba(2,6,23,.78);
  backdrop-filter:blur(6px);
}

.pricing-demo-modal__dialog{
  position:relative;
  z-index:1;
  width:min(1280px, 100%);
  max-width:1280px;
  max-height:min(94vh, 1000px);
  display:flex;
  flex-direction:column;
  border-radius:24px;
  overflow:hidden;
  background:#07111f;
  border:1px solid rgba(255,255,255,.10);
  box-shadow:0 30px 80px rgba(0,0,0,.34);
}

.pricing-demo-modal__top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:14px 16px;
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border-bottom:1px solid rgba(255,255,255,.08);
}

.pricing-demo-modal__title{
  color:#ffffff;
  font-size:1rem;
  line-height:1.35;
  font-weight:900;
  letter-spacing:-0.01em;
  overflow-wrap:anywhere;
}

.pricing-demo-modal__close{
  appearance:none;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.06);
  color:#fff;
  min-width:110px;
  height:44px;
  border-radius:14px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  cursor:pointer;
  flex:0 0 auto;
  transition:background .2s ease, transform .2s ease;
  font-weight:900;
  font-size:.92rem;
}

.pricing-demo-modal__close:hover{
  background:rgba(255,255,255,.10);
  transform:translateY(-1px);
}

.pricing-demo-modal__body{
  position:relative;
  width:100%;
  background:#000;
  aspect-ratio:16 / 9;
  min-height:280px;
  max-height:calc(94vh - 76px);
  overflow:hidden;
}

.pricing-demo-modal__frame,
.pricing-demo-modal__body iframe,
.pricing-demo-modal__body video{
  width:100%;
  height:100%;
  display:block;
  border:0;
  background:#000;
  object-fit:cover;
}

.pricing-demo-modal__placeholder{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:22px;
  text-align:center;
  color:#dbeafe;
  line-height:1.7;
  background:
    radial-gradient(circle at 50% 20%, rgba(51,200,193,.14), transparent 35%),
    linear-gradient(180deg, #07111f 0%, #030712 100%);
}

.pricing-demo-modal__placeholder-inner{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:12px;
  max-width:520px;
}

.pricing-demo-modal__placeholder-text{
  margin:0;
  color:#dbeafe;
  line-height:1.7;
}

.pricing-demo-modal__placeholder-title{
  margin:0;
  color:#fff;
  font-size:1.1rem;
  font-weight:900;
}

.pricing-demo-modal__placeholder-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:46px;
  padding:10px 16px;
  border-radius:14px;
  background:linear-gradient(90deg,#33c8c1,#119bd2);
  color:#fff;
  text-decoration:none;
  font-weight:900;
  box-shadow:0 12px 24px rgba(17,155,210,.18);
  max-width:100%;
}

.pricing-demo-modal__placeholder-link:hover{
  color:#fff;
  transform:translateY(-1px);
}

/* ==========================================================================
   Common utility enhancements
   ========================================================================== */

.is-visually-hidden{
  position:absolute !important;
  width:1px !important;
  height:1px !important;
  padding:0 !important;
  margin:-1px !important;
  overflow:hidden !important;
  clip:rect(0,0,0,0) !important;
  white-space:nowrap !important;
  border:0 !important;
}

/* ==========================================================================
   Responsive
   ========================================================================== */

@media (max-width: 1199px){
  .pricing-scene-banner__grid{
    grid-template-columns:1fr;
  }

  .pricing-scene-banner__visual{
    min-height:560px;
  }

  .pricing-calculator-layout{
    grid-template-columns:1fr;
  }

  .pricing-calculator-summary-card{
    position:relative;
    top:auto;
  }

  .pricing-demo-modal__dialog{
    width:min(100%, 1100px);
  }
}

@media (max-width: 991px){
  .pricing-page-main{
    padding-top:116px;
  }

  .pricing-page-shell{
    width:min(100%, calc(100% - 16px));
    border-radius:22px;
  }

  .pricing-page-inner{
    padding:14px;
  }

  .pricing-page-intro{
    padding:14px 14px 6px;
  }

  .pricing-sections-stack{
    gap:14px;
    padding:14px;
  }

  .pricing-fallback-card{
    padding:20px;
    border-radius:18px;
  }

  .pricing-scene-banner__shell,
  .pricing-calculator-shell,
  .pricing-demo-shell{
    padding:20px;
    border-radius:20px;
  }

  .pricing-scene-banner__benefits,
  .pricing-scene-banner__compare{
    grid-template-columns:1fr;
  }

  .pricing-scene-banner__visual{
    min-height:620px;
    border-radius:20px;
  }

  .pricing-scene-banner__legend{
    grid-template-columns:1fr;
  }

  .pricing-calculator-header{
    flex-direction:column;
  }

  .pricing-calculator-free-note{
    width:100%;
    max-width:none;
    min-width:0;
  }

  .pricing-calculator-grid,
  .pricing-calculator-products{
    grid-template-columns:1fr;
  }

  .pricing-demo-modal{
    padding:14px;
  }

  .pricing-demo-modal__dialog{
    width:100%;
    max-width:100%;
  }

  .pricing-demo-modal__body{
    min-height:240px;
    max-height:65vh;
  }
}

@media (max-width: 767px){
  .pricing-page-main{
    padding-top:108px;
    padding-bottom:28px;
  }

  .pricing-page-shell{
    width:calc(100% - 14px);
    border-radius:18px;
  }

  .pricing-page-inner{
    padding:12px;
  }

  .pricing-page-intro{
    padding:12px 12px 4px;
  }

  .pricing-sections-stack{
    gap:12px;
    padding:12px;
  }

  .pricing-scene-banner__shell,
  .pricing-calculator-shell,
  .pricing-demo-shell{
    padding:16px;
    border-radius:18px;
  }

  .pricing-page-intro h1,
  .pricing-scene-banner__title,
  .pricing-calculator-section-intro__heading,
  .pricing-demo-section-intro__heading{
    line-height:1.12;
  }

  .pricing-scene-banner__text,
  .pricing-calculator-section-intro__text,
  .pricing-demo-section-intro__text{
    font-size:.95rem;
    line-height:1.68;
  }

  .pricing-scene-banner__visual{
    min-height:720px;
  }

  .pricing-scene-banner__scene-half{
    width:100%;
    height:50%;
  }

  .pricing-scene-banner__scene-half--left{
    left:0;
    right:0;
    top:0;
    bottom:auto;
    border-right:0;
    border-bottom:1px solid rgba(255,255,255,.06);
  }

  .pricing-scene-banner__scene-half--right{
    left:0;
    right:0;
    top:auto;
    bottom:0;
  }

  .pricing-scene-banner__center-hub{
    width:138px;
    height:138px;
  }

  .pricing-scene-banner__center-label{
    font-size:.88rem;
    padding:18px;
  }

  .pricing-scene-banner__node-stack{
    max-width:180px;
  }

  .pricing-scene-banner__scene-half--left .pricing-scene-banner__node::after,
  .pricing-scene-banner__scene-half--right .pricing-scene-banner__node::after{
    display:none;
  }

  .pricing-calculator-form-card,
  .pricing-calculator-summary-card{
    padding:15px;
    border-radius:18px;
  }

  .pricing-calculator-radio-row{
    grid-template-columns:1fr;
  }

  .pricing-calculator-product-top{
    flex-direction:column;
    align-items:flex-start;
  }

  .pricing-demo-stage{
    border-radius:18px;
  }

  .pricing-demo-stage__play{
    width:74px;
    height:74px;
  }

  .pricing-demo-stage__content{
    padding:14px 16px 16px;
  }

  .pricing-demo-modal{
    padding:8px;
    align-items:center;
    justify-content:center;
  }

  .pricing-demo-modal__dialog{
    width:calc(100vw - 16px);
    max-width:calc(100vw - 16px);
    max-height:calc(100vh - 16px);
    border-radius:16px;
  }

  .pricing-demo-modal__top{
    padding:12px;
    gap:10px;
  }

  .pricing-demo-modal__title{
    font-size:.94rem;
    line-height:1.35;
  }

  .pricing-demo-modal__close{
    min-width:auto;
    height:40px;
    padding:0 12px;
    border-radius:12px;
    font-size:.86rem;
  }

  .pricing-demo-modal__body{
    width:100%;
    aspect-ratio:16 / 9;
    min-height:180px;
    max-height:56vh;
  }
}

@media (max-width: 575px){
  .pricing-page-main{
    padding-top:100px;
    padding-bottom:22px;
  }

  .pricing-page-shell{
    width:calc(100% - 10px);
    border-radius:16px;
  }

  .pricing-page-inner{
    padding:8px;
  }

  .pricing-page-intro{
    padding:10px 10px 4px;
  }

  .pricing-sections-stack{
    padding:8px;
    gap:10px;
  }

  .pricing-fallback-card{
    padding:16px;
    border-radius:16px;
  }

  .pricing-page-intro p,
  .pricing-fallback-card p{
    line-height:1.62;
  }

  .pricing-scene-banner__support-note{
    padding:12px;
    flex-direction:column;
  }

  .pricing-scene-banner__benefit{
    padding:14px;
  }

  .pricing-scene-banner__compare-card{
    padding:15px;
    border-radius:16px;
  }

  .pricing-scene-banner__visual{
    min-height:760px;
    border-radius:18px;
  }

  .pricing-scene-banner__scene-half{
    padding:16px;
  }

  .pricing-scene-banner__legend{
    left:12px;
    right:12px;
    bottom:12px;
    gap:10px;
  }

  .pricing-scene-banner__legend-card{
    padding:12px;
    border-radius:14px;
  }

  .pricing-calculator-summary-row{
    flex-direction:column;
    align-items:flex-start;
  }

  .pricing-calculator-summary-row span{
    text-align:left;
  }

  .pricing-calculator-preset-row{
    gap:8px;
  }

  .pricing-calculator-preset{
    width:100%;
    justify-content:center;
    text-align:center;
  }

  .pricing-demo-stage__play{
    width:62px;
    height:62px;
  }

  .pricing-demo-stage__title{
    font-size:1rem;
  }

  .pricing-demo-stage__text{
    font-size:.9rem;
    line-height:1.6;
  }

  .pricing-demo-modal__top{
    flex-direction:column;
    align-items:stretch;
  }

  .pricing-demo-modal__close{
    width:100%;
  }

  .pricing-demo-modal__body{
    min-height:170px;
    max-height:50vh;
  }

  .pricing-demo-modal__placeholder{
    padding:16px;
  }
}

@media (max-width: 420px){
  .pricing-page-shell{
    width:calc(100% - 8px);
  }

  .pricing-page-intro h1{
    font-size:1.7rem;
  }

  .pricing-scene-banner__title{
    font-size:1.75rem;
  }

  .pricing-calculator-title,
  .pricing-demo-section-intro__heading,
  .pricing-calculator-section-intro__heading{
    font-size:1.45rem;
  }

  .pricing-scene-banner__visual{
    min-height:700px;
  }

  .pricing-demo-modal__dialog{
    width:calc(100vw - 12px);
    max-width:calc(100vw - 12px);
    max-height:calc(100vh - 12px);
    border-radius:14px;
  }

  .pricing-demo-modal{
    padding:6px;
  }

  .pricing-demo-modal__body{
    min-height:160px;
    max-height:46vh;
  }
}

@media (prefers-reduced-motion: reduce){
  .pricing-page-main *,
  .pricing-page-main *::before,
  .pricing-page-main *::after{
    animation:none !important;
    transition:none !important;
    scroll-behavior:auto !important;
  }
}