:root{
  --bg:#f7f8f4;
  --panel:#ffffff;
  --soft:#eef3ef;
  --soft-2:#f4f7f3;
  --line:#dde5dd;
  --line-strong:#ced9ce;
  --text:#1f2c30;
  --muted:#68767d;
  --brand:#7ecb97;
  --brand-strong:#2f6f55;
  --dark:#102924;
  --shadow-sm:0 10px 24px rgba(16, 41, 36, .05);
  --shadow-md:0 18px 44px rgba(16, 41, 36, .08);
  --shadow-lg:0 30px 84px rgba(16, 41, 36, .12);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Plus Jakarta Sans", ui-sans-serif, system-ui, sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.72;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font:inherit}
main{overflow:hidden}
.container{width:min(1180px,92%);margin:0 auto}
.narrow{width:min(760px,92%);margin:0 auto}

.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(247,248,244,.90);
  backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(206,217,206,.72);
}
.header-shell{
  min-height:76px;
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:28px;
}
.brand{
  display:flex;
  align-items:center;
  gap:12px;
  white-space:nowrap;
}
.brand-mark{
  width:10px;
  height:10px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--brand),#c0ead0);
  box-shadow:0 0 0 8px rgba(126,203,151,.12);
}
.brand-label{
  font-size:1rem;
  font-weight:700;
  letter-spacing:-.03em;
}
.site-nav{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:24px;
  color:var(--muted);
  font-size:.94rem;
  font-weight:600;
}
.site-nav a,
.header-link,
.footer-col a{
  transition:color .18s ease;
}
.site-nav a:hover,
.header-link:hover,
.footer-col a:hover{
  color:var(--text);
}
.header-actions{
  display:flex;
  align-items:center;
  gap:14px;
}
.header-link{
  color:var(--muted);
  font-weight:700;
}

.btn,
.plan-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:44px;
  padding:10px 18px;
  border-radius:999px;
  font-weight:700;
  line-height:1;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease;
}
.btn:hover,
.plan-link:hover{
  transform:translateY(-1px);
}
.btn-primary{
  background:linear-gradient(135deg,var(--brand),#93d8ab);
  color:#123122;
  box-shadow:var(--shadow-sm);
}
.btn-secondary{
  background:rgba(255,255,255,.84);
  border:1px solid var(--line-strong);
  color:var(--text);
}
.plan-link{
  border:1px solid var(--line-strong);
  background:#fff;
  color:var(--text);
}

.hero{
  padding:62px 0 54px;
  background:
    radial-gradient(circle at 0% 0%, rgba(126,203,151,.10), transparent 28%),
    linear-gradient(180deg,#fbfcf9 0%, #f7f8f4 100%);
}
.hero-shell{
  display:grid;
  grid-template-columns:minmax(0,.95fr) minmax(0,1.05fr);
  gap:62px;
  align-items:center;
}
.eyebrow{
  display:inline-block;
  margin-bottom:14px;
  color:var(--brand-strong);
  font-size:.78rem;
  font-weight:800;
  letter-spacing:.14em;
  text-transform:uppercase;
}
.eyebrow-small{
  margin-bottom:8px;
  font-size:.7rem;
  letter-spacing:.12em;
}
.hero-title,
.page-title,
.section-title,
.page-hero h1:not(.page-title){
  margin:0 0 14px;
  line-height:1.04;
  letter-spacing:-.06em;
  font-weight:700;
  color:var(--text);
}
.hero-title{
  font-size:clamp(2.25rem,3.5vw,3.85rem);
  max-width:10.6ch;
}
.page-title,
.page-hero h1:not(.page-title){
  font-size:clamp(2rem,3vw,3.05rem);
  max-width:14ch;
}
.section-title{
  font-size:clamp(1.8rem,2.55vw,2.7rem);
  max-width:14ch;
}
h3{
  margin:0 0 10px;
  font-size:1.02rem;
  line-height:1.32;
  font-weight:700;
}
h4{
  margin:0;
  font-size:1rem;
  line-height:1.32;
  font-weight:700;
}
h5{
  margin:0 0 12px;
  color:var(--muted);
  font-size:.9rem;
  text-transform:uppercase;
  letter-spacing:.05em;
}
p{
  margin:0;
  color:var(--muted);
  font-size:1rem;
}
.hero-lead,
.page-copy p,
.intro-side p,
.content-copy p,
.footer-brand p{
  max-width:60ch;
}
.hero-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin:24px 0 18px;
}
.hero-proofs{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.proof-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:38px;
  padding:8px 14px;
  border-radius:999px;
  border:1px solid var(--line-strong);
  background:rgba(255,255,255,.80);
  color:var(--text);
  font-size:.88rem;
  font-weight:700;
}

.hero-stage{
  position:relative;
  min-height:520px;
  display:flex;
  align-items:center;
  justify-content:flex-end;
}
.hero-stage::before{
  content:"";
  position:absolute;
  inset:8% 4% 8% 22%;
  border-radius:34px 34px 180px 34px;
  background:rgba(255,255,255,.68);
  border:1px solid rgba(221,229,221,.92);
}
.hero-image-shell{
  position:relative;
  z-index:1;
  width:min(100%,520px);
  height:520px;
  margin-left:auto;
  border-radius:32px 32px 190px 32px;
  overflow:hidden;
  border:1px solid var(--line);
  box-shadow:var(--shadow-lg);
  background:#e9efe9;
}
.hero-image-shell img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.hero-surface{
  position:absolute;
  left:0;
  bottom:22px;
  z-index:2;
  width:min(340px,82%);
  padding:18px;
  border-radius:24px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.96);
  box-shadow:var(--shadow-md);
}
.surface-top,
.panel-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.surface-top span,
.panel-head span,
.panel-meta,
.legend-list,
.widget-list,
.mini-list,
.footer-bottom,
.analytics-period{
  color:var(--muted);
}
.surface-top span,
.panel-head span,
.analytics-period,
.panel-meta{
  font-size:.84rem;
}
.surface-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
  margin:16px 0;
}
.surface-stat,
.analytics-kpi,
.app-stat,
.dash-stat{
  padding:14px;
  border-radius:18px;
  border:1px solid var(--line);
  background:#fff;
}
.surface-stat span,
.analytics-kpi span,
.app-stat span,
.dash-stat span{
  display:block;
  margin-bottom:5px;
  font-size:.76rem;
  color:var(--muted);
}
.surface-stat strong,
.analytics-kpi strong,
.app-stat strong,
.dash-stat strong{
  font-size:1rem;
  line-height:1.1;
  font-weight:700;
}

.surface-chart,
.line-chart,
.graph-surface,
.chart-surface{
  position:relative;
  border-radius:20px;
  border:1px solid var(--line);
  background:linear-gradient(180deg,#fbfcfa 0%, #f2f6f2 100%);
  overflow:hidden;
}
.surface-chart{
  height:96px;
}
.line-chart{
  height:210px;
}
.line-chart-tall{
  height:250px;
}
.graph-surface,
.chart-surface{
  height:180px;
}
.surface-chart::before,
.line-chart::before,
.graph-surface::before,
.chart-surface::before{
  content:"";
  position:absolute;
  left:8%;
  right:8%;
  top:54%;
  height:3px;
  border-radius:999px;
  background:linear-gradient(90deg, rgba(126,203,151,.18), rgba(126,203,151,.60));
  transform:skewY(-9deg);
  transform-origin:left center;
}
.surface-chart span,
.line-chart span,
.graph-surface span,
.chart-surface span{
  position:absolute;
  width:12px;
  height:12px;
  border-radius:50%;
  background:var(--brand);
  box-shadow:0 0 0 6px rgba(126,203,151,.16);
}

.section{
  padding:82px 0;
}
.section-soft{
  background:var(--soft);
}
.page-hero{
  padding:58px 0 24px;
  background:
    radial-gradient(circle at 0% 0%, rgba(126,203,151,.08), transparent 25%),
    linear-gradient(180deg,#fbfcf9 0%, #f7f8f4 100%);
}
.page-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,.92fr);
  gap:34px;
  align-items:center;
}
.ai-grid{
  align-items:center;
}
.intro-split{
  display:grid;
  grid-template-columns:minmax(0,.95fr) minmax(0,1.05fr);
  gap:34px;
  align-items:end;
  margin-bottom:28px;
}
.intro-block .section-title,
.intro-block .page-title{
  max-width:11.8ch;
}
.intro-side{
  max-width:540px;
}
.page-visual,
.feature-card,
.plan-card,
.bullet-item,
.content-media,
.pricing-summary-card,
.soft-card,
.calculator-card,
.dashboard-shell,
.analytics-board,
.analytics-card,
.ai-card{
  border:1px solid var(--line);
  background:rgba(255,255,255,.88);
}
.page-visual,
.content-media{
  overflow:hidden;
  border-radius:28px;
  box-shadow:var(--shadow-sm);
}
.page-visual img,
.content-media img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.page-visual-note{
  padding:18px 20px 20px;
  background:#fff;
  border-top:1px solid var(--line);
}
.page-visual-note strong{
  display:block;
  margin-bottom:6px;
  font-size:1rem;
}

.feature-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
}
.feature-grid-3{
  grid-template-columns:repeat(3,minmax(0,1fr));
}
.feature-card{
  padding:22px;
  border-radius:22px;
  box-shadow:none;
}
.feature-card p{
  font-size:.96rem;
}

.preview-split,
.product-layout,
.content-grid{
  display:grid;
  grid-template-columns:minmax(0,1.04fr) minmax(0,.96fr);
  gap:42px;
  align-items:center;
}
.content-copy{
  min-width:0;
}
.bullet-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
  margin-top:22px;
}
.bullet-item{
  padding:16px 18px;
  border-radius:18px;
}
.bullet-item strong{
  display:block;
  margin-bottom:4px;
  font-size:.96rem;
}
.bullet-item span{
  display:block;
  color:var(--muted);
  font-size:.9rem;
}

.analytics-board{
  padding:22px;
  border-radius:28px;
  box-shadow:var(--shadow-sm);
}
.analytics-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:16px;
  margin-bottom:18px;
}
.analytics-kpis{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:10px;
  margin-bottom:14px;
}
.analytics-panels{
  display:grid;
  grid-template-columns:1.2fr .8fr .8fr;
  gap:12px;
}
.analytics-card{
  padding:16px;
  border-radius:22px;
}
.analytics-card-large{
  grid-column:span 2;
}
.bar-chart{
  height:180px;
  display:flex;
  align-items:flex-end;
  gap:12px;
  padding:18px 10px 10px;
  border-radius:18px;
  border:1px solid var(--line);
  background:linear-gradient(180deg,#fbfcfa 0%, #f2f6f2 100%);
}
.bar{
  flex:1;
  height:var(--h);
  border-radius:12px 12px 6px 6px;
  background:linear-gradient(180deg,#bfe6cc 0%, #78c792 100%);
}
.mini-ring{
  --value:72;
  width:124px;
  height:124px;
  margin:18px auto 14px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:
    radial-gradient(closest-side, #fff 68%, transparent 69% 100%),
    conic-gradient(var(--brand) calc(var(--value) * 1%), #e8efea 0);
}
.mini-ring strong{
  font-size:1.45rem;
  letter-spacing:-.04em;
}
.mini-note{
  text-align:center;
  font-size:.9rem;
  color:var(--muted);
}

.ai-visual{
  position:relative;
  min-height:430px;
}
.ai-image{
  height:420px;
  border-radius:30px 30px 160px 30px;
  overflow:hidden;
  border:1px solid var(--line);
  box-shadow:var(--shadow-md);
}
.ai-image img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.ai-card{
  position:absolute;
  left:0;
  bottom:20px;
  width:min(360px,86%);
  padding:18px;
  border-radius:24px;
  box-shadow:var(--shadow-md);
}

.app-frame{
  border-radius:28px;
  overflow:hidden;
  box-shadow:var(--shadow-md);
  border:1px solid var(--line);
  background:#fff;
}
.app-topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:14px 16px;
  border-bottom:1px solid var(--line);
  background:#fbfcfa;
}
.app-dots{
  display:flex;
  gap:6px;
}
.app-dots span{
  width:8px;
  height:8px;
  border-radius:50%;
  background:#d6dfd6;
  box-shadow:none;
  position:static;
}
.app-top-actions{
  display:flex;
  gap:8px;
}
.app-top-actions button{
  padding:8px 12px;
  border-radius:999px;
  border:1px solid var(--line-strong);
  background:#fff;
  color:var(--muted);
  font-size:.8rem;
  font-weight:700;
}
.app-btn-active{
  background:rgba(126,203,151,.10) !important;
  color:var(--brand-strong) !important;
  border-color:rgba(47,111,85,.20) !important;
}
.app-layout{
  display:grid;
  grid-template-columns:150px 1fr;
  min-height:470px;
}
.app-sidebar,
.dashboard-sidebar{
  padding:20px 16px;
  background:linear-gradient(180deg,#102924 0%, #1c5d48 100%);
}
.app-logo,
.dash-logo{
  margin-bottom:18px;
  color:#fff;
  font-size:.95rem;
  font-weight:700;
}
.app-link,
.dash-link{
  display:block;
  padding:10px 12px;
  margin-bottom:8px;
  border-radius:12px;
  color:rgba(255,255,255,.82);
  font-size:.88rem;
  font-weight:600;
}
.app-link.active,
.dash-link.active{
  background:rgba(126,203,151,.18);
  color:#fff;
}
.app-main{
  padding:18px;
  background:#fafcf9;
}
.app-stats{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:10px;
  margin-bottom:14px;
}
.app-panels{
  display:grid;
  grid-template-columns:1.16fr .84fr;
  gap:12px;
}
.app-panel,
.dash-card{
  padding:16px;
  border-radius:22px;
  border:1px solid var(--line);
  background:#fff;
}
.app-panel-large{
  grid-row:span 2;
}
.mini-list,
.widget-list,
.plan-list,
.legend-list{
  list-style:none;
  padding:0;
  margin:16px 0 0;
}
.mini-list li,
.widget-list li,
.plan-list li,
.legend-list li{
  position:relative;
  padding-left:16px;
  margin-bottom:10px;
  font-size:.92rem;
}
.mini-list li::before,
.widget-list li::before,
.plan-list li::before{
  content:"";
  position:absolute;
  left:0;
  top:.68em;
  width:6px;
  height:6px;
  border-radius:50%;
  background:var(--brand);
}
.legend-list{
  margin-top:14px;
}
.legend-list li{
  padding-left:18px;
}
.legend-dot{
  position:absolute;
  left:0;
  top:.48em;
  width:8px;
  height:8px;
  border-radius:50%;
}
.legend-dot.ok{background:var(--brand)}
.legend-dot.warn{background:#d7ded7}
.panel-meta{
  margin-top:14px;
  padding-top:12px;
  border-top:1px solid var(--line);
}

.plan-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
}
.plan-card{
  padding:24px;
  border-radius:24px;
  box-shadow:none;
}
.plan-card.featured{
  background:linear-gradient(180deg,#ffffff 0%, #f6fbf7 100%);
  border-color:rgba(47,111,85,.22);
}
.plan-tag{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:30px;
  padding:6px 12px;
  border-radius:999px;
  background:rgba(126,203,151,.12);
  color:var(--brand-strong);
  font-size:.78rem;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.plan-price{
  margin:16px 0 10px;
  font-size:2rem;
  font-weight:700;
  letter-spacing:-.04em;
}
.plan-price small{
  font-size:1rem;
  color:var(--muted);
  font-weight:600;
}

.pricing-summary{
  display:grid;
  gap:12px;
}
.pricing-summary-card{
  padding:20px 22px;
  border-radius:22px;
}
.pricing-summary-card strong{
  display:block;
  margin-bottom:6px;
  font-size:1rem;
}
.calculator-layout{
  display:grid;
  grid-template-columns:320px minmax(0,1fr);
  gap:18px;
  align-items:start;
}
.calculator-side{
  display:grid;
  gap:14px;
}
.soft-card,
.calculator-card{
  padding:22px;
  border-radius:24px;
}
.soft-card h4{
  margin-bottom:10px;
}
.plan-toggle{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
  margin-bottom:18px;
}
.plan-switch,
.tool-btn{
  padding:13px 16px;
  border-radius:18px;
  border:1px solid var(--line);
  background:#fff;
  color:var(--text);
  font-weight:700;
  transition:background .18s ease, border-color .18s ease, transform .18s ease;
}
.plan-switch{
  text-align:left;
  cursor:pointer;
}
.plan-switch:hover,
.tool-btn:hover{
  transform:translateY(-1px);
}
.plan-switch span{
  display:block;
  margin-bottom:2px;
}
.plan-switch small{
  display:block;
  color:var(--muted);
  font-weight:600;
}
.plan-switch.active,
.tool-btn.active{
  background:rgba(126,203,151,.08);
  border-color:rgba(47,111,85,.22);
}
.tool-btn-primary{
  background:linear-gradient(135deg,var(--brand),#93d8ab);
  border-color:transparent;
  color:#123122;
}
.plan-selected-note{
  margin-bottom:16px;
}
.plan-selected-note strong{
  display:block;
  margin-bottom:6px;
}
.calculator-card label{
  display:block;
  margin-bottom:14px;
  color:var(--text);
  font-size:.95rem;
  font-weight:600;
}
input[type="range"]{
  width:100%;
  margin-top:10px;
  accent-color:var(--brand-strong);
}
input[type="checkbox"]{
  margin-right:8px;
  accent-color:var(--brand-strong);
}
.range-note{
  margin:-4px 0 16px;
  color:var(--muted);
  font-size:.92rem;
}
.price-box{
  margin-top:20px;
  padding-top:16px;
  border-top:1px solid var(--line);
}
.price-box span{
  display:block;
  margin-bottom:6px;
  color:var(--muted);
  font-size:.88rem;
}
.price-box strong{
  font-size:2rem;
  line-height:1;
  letter-spacing:-.04em;
}

.dashboard-shell{
  display:grid;
  grid-template-columns:210px 1fr;
  border-radius:30px;
  overflow:hidden;
  box-shadow:var(--shadow-md);
}
.dashboard-shell-premium{
  background:#fff;
}
.dashboard-main{
  padding:20px;
  background:#fbfcfa;
}
.dashboard-toolbar{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-bottom:14px;
}
.dashboard-toolbar-wide{
  justify-content:space-between;
  align-items:center;
}
.toolbar-tabs,
.toolbar-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.dashboard-top{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
  margin-bottom:14px;
}
.dashboard-grid-premium{
  display:grid;
  grid-template-columns:1.15fr .85fr .85fr;
  gap:14px;
}
.dash-card-large{
  grid-column:span 2;
}
.donut-wrap{
  display:grid;
  justify-items:center;
  gap:8px;
  margin-top:10px;
}
.donut{
  --value:72;
  width:132px;
  height:132px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:
    radial-gradient(closest-side, #fff 68%, transparent 69% 100%),
    conic-gradient(var(--brand) calc(var(--value) * 1%), #e8efea 0);
}
.donut strong{
  font-size:1.5rem;
  letter-spacing:-.04em;
}

.site-footer{
  border-top:1px solid rgba(206,217,206,.78);
  background:#f7f8f4;
}
.footer-grid{
  display:grid;
  grid-template-columns:1.45fr repeat(3,1fr);
  gap:28px;
  padding:32px 0 18px;
}
.footer-brand h4{
  margin-bottom:12px;
}
.footer-col{
  display:flex;
  flex-direction:column;
  gap:10px;
}
.footer-col a,
.footer-col span{
  color:var(--muted);
  font-size:.95rem;
}
.footer-bottom{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:18px 0 28px;
  border-top:1px solid rgba(206,217,206,.78);
  font-size:.9rem;
}

@media (max-width:1120px){
  .hero-shell,
  .preview-split,
  .product-layout,
  .content-grid,
  .page-grid,
  .intro-split,
  .calculator-layout{
    grid-template-columns:1fr;
  }
  .hero-stage{
    min-height:auto;
  }
  .hero-image-shell{
    width:min(100%,640px);
    height:440px;
  }
  .hero-stage::before{
    inset:8% 4% 10% 26%;
  }
  .feature-grid,
  .feature-grid-3,
  .plan-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .analytics-kpis,
  .app-stats,
  .dashboard-top{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .analytics-panels,
  .dashboard-grid-premium{
    grid-template-columns:1fr 1fr;
  }
  .analytics-card-large,
  .dash-card-large{
    grid-column:span 2;
  }
  .footer-grid{
    grid-template-columns:1fr 1fr;
  }
}

@media (max-width:920px){
  .header-shell{
    grid-template-columns:1fr auto;
    row-gap:12px;
    padding:14px 0;
  }
  .site-nav{
    grid-column:1 / -1;
    justify-content:flex-start;
    overflow:auto;
    padding-bottom:4px;
  }
  .hero{
    padding-top:44px;
  }
  .hero-surface,
  .ai-card{
    position:relative;
    left:auto;
    bottom:auto;
    margin-top:-48px;
  }
  .feature-grid,
  .feature-grid-3,
  .plan-grid,
  .bullet-grid,
  .surface-grid,
  .analytics-kpis,
  .analytics-panels,
  .app-panels,
  .dashboard-grid-premium{
    grid-template-columns:1fr;
  }
  .analytics-card-large,
  .dash-card-large{
    grid-column:auto;
  }
  .footer-grid{
    grid-template-columns:1fr;
  }
}

@media (max-width:680px){
  .container{width:min(1180px,94%)}
  .btn,
  .plan-link{
    min-height:42px;
    padding:10px 16px;
  }
  .hero-title{
    font-size:clamp(2rem,8vw,2.8rem);
    max-width:11ch;
  }
  .page-title,
  .page-hero h1:not(.page-title){
    font-size:clamp(1.8rem,7vw,2.3rem);
  }
  .section-title{
    font-size:clamp(1.6rem,6.5vw,2.1rem);
  }
  .hero-image-shell,
  .ai-image{
    height:360px;
    border-radius:28px 28px 140px 28px;
  }
  .hero-stage::before{
    inset:8% 2% 12% 18%;
    border-radius:28px 28px 120px 28px;
  }
  .hero-surface,
  .ai-card{
    width:100%;
    margin-top:-34px;
  }
  .app-layout,
  .dashboard-shell{
    grid-template-columns:1fr;
  }
  .app-sidebar,
  .dashboard-sidebar{
    padding-bottom:12px;
  }
  .footer-bottom{
    flex-direction:column;
    align-items:flex-start;
  }
}

/* ===== dashboard preview hero refinement ===== */
.dashboard-hero{
  padding:52px 0 26px;
}
.dashboard-hero-grid{
  display:grid;
  grid-template-columns:minmax(0,.92fr) minmax(0,1.08fr);
  gap:34px;
  align-items:center;
}
.dashboard-hero-copy{
  max-width:560px;
}
.dashboard-hero-copy .page-title{
  max-width:11.5ch;
  margin-bottom:16px;
}
.dashboard-hero-copy p{
  max-width:56ch;
}
.dashboard-hero-points{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  margin-top:22px;
}
.hero-point-card{
  padding:16px 18px;
  border:1px solid var(--line);
  border-radius:18px;
  background:rgba(255,255,255,.82);
}
.hero-point-card strong{
  display:block;
  margin-bottom:4px;
  font-size:.96rem;
}
.hero-point-card span{
  display:block;
  color:var(--muted);
  font-size:.9rem;
}
.dashboard-hero-side{
  min-width:0;
}
.analytics-board-hero{
  padding:18px;
  border-radius:26px;
  box-shadow:var(--shadow-sm);
}
.analytics-head-hero{
  margin-bottom:14px;
}
.analytics-kpis-hero{
  grid-template-columns:repeat(4,minmax(0,1fr));
  margin-bottom:12px;
}
.analytics-panels-hero{
  grid-template-columns:1.2fr .8fr;
}
.dashboard-hero .line-chart{
  height:190px;
}
.dashboard-hero .mini-ring{
  width:118px;
  height:118px;
}
.dashboard-hero .mini-ring strong{
  font-size:1.35rem;
}

@media (max-width:1120px){
  .dashboard-hero-grid{
    grid-template-columns:1fr;
    gap:22px;
  }
  .dashboard-hero-copy{
    max-width:none;
  }
}

@media (max-width:920px){
  .dashboard-hero{
    padding-top:42px;
  }
  .dashboard-hero-points,
  .analytics-kpis-hero,
  .analytics-panels-hero{
    grid-template-columns:1fr;
  }
}
/* ===== end dashboard preview hero refinement ===== */

/* ===== ai addon refinement ===== */
.ai-page-hero{
  padding-bottom:44px;
}

.ai-band-section{
  background:#ffffff;
}

.ai-band-shell{
  display:grid;
  grid-template-columns:minmax(0,.98fr) minmax(0,1.02fr);
  gap:44px;
  align-items:center;
}

.ai-band-content{
  min-width:0;
  max-width:560px;
}

.ai-band-content .section-title{
  max-width:11.5ch;
  margin-bottom:14px;
}

.ai-band-content > p{
  max-width:58ch;
}

.ai-band-media{
  position:relative;
  min-width:0;
}

.ai-band-image{
  min-height:460px;
  border-radius:30px;
  overflow:hidden;
  box-shadow:var(--shadow-md);
}

.ai-band-image img{
  width:100%;
  height:460px;
  object-fit:cover;
}

.ai-band-float{
  position:absolute;
  left:22px;
  bottom:22px;
  width:min(320px,82%);
  padding:18px 20px;
  border-radius:22px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.94);
  box-shadow:var(--shadow-sm);
}

.ai-band-float strong{
  display:block;
  margin-bottom:6px;
  font-size:1rem;
}

.ai-band-float span{
  display:block;
  color:var(--muted);
  font-size:.92rem;
}

.ai-feature-stack{
  display:grid;
  gap:14px;
  margin-top:24px;
}

.ai-feature-row{
  display:grid;
  grid-template-columns:18px 1fr;
  gap:14px;
  align-items:start;
  padding:18px 20px;
  border:1px solid var(--line);
  border-radius:20px;
  background:rgba(255,255,255,.86);
}

.ai-feature-icon{
  width:12px;
  height:12px;
  margin-top:6px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--brand),#bfe6cc);
  box-shadow:0 0 0 8px rgba(126,203,151,.14);
}

.ai-feature-row h3{
  margin-bottom:6px;
}

.ai-feature-row p{
  font-size:.95rem;
}

@media (max-width:1120px){
  .ai-band-shell{
    grid-template-columns:1fr;
    gap:24px;
  }

  .ai-band-content{
    max-width:none;
  }

  .ai-band-image,
  .ai-band-image img{
    min-height:380px;
    height:380px;
  }
}

@media (max-width:920px){
  .ai-band-float{
    position:relative;
    left:auto;
    bottom:auto;
    width:100%;
    margin-top:-34px;
  }
}
/* ===== end ai addon refinement ===== */
