/* ============================================================
   LAVIO DIGITAL — Design System v1.0
   Editorial-Technical aesthetic for B2B SaaS (TR)
   ============================================================ */

/* ---------- 1. Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;tab-size:4;scroll-behavior:smooth}
body{min-height:100dvh;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}
img,svg,video,canvas{display:block;max-width:100%;height:auto}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
input,textarea,select,button{font:inherit;color:inherit}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:6px}

/* ---------- 2. Design Tokens ---------- */
:root{
  /* Palette — Cloud Dancer & Sapphire */
  --bg:            #FAFAF7;   /* page base, warm white */
  --bg-soft:       #F4F1EA;   /* alternating section, oatmeal */
  --bg-elev:       #FFFFFF;   /* card surface */
  --bg-glass:      rgba(255,255,255,.62);
  --bg-tint:       #EEF2FF;   /* subtle blue tint */

  --ink:           #0B1220;   /* primary text, near-black navy */
  --ink-2:         #1E293B;   /* secondary heading */
  --ink-3:         #475569;   /* body */
  --ink-4:         #64748B;   /* muted */
  --ink-5:         #94A3B8;   /* very muted */

  --line:          #E7E5DF;   /* default border, warm gray */
  --line-2:        #E2E8F0;   /* cool gray border */
  --line-3:        #CBD5E1;   /* stronger border */

  --accent:        #1E40AF;   /* sapphire, primary brand */
  --accent-2:      #2563EB;   /* electric, CTA */
  --accent-soft:   #DBEAFE;   /* tinted background */
  --accent-ink:    #1E3A8A;   /* dark sapphire for text */

  --success:       #059669;
  --success-soft:  #D1FAE5;
  --warn:          #D97706;
  --warn-soft:     #FEF3C7;
  --danger:        #DC2626;
  --danger-soft:   #FEE2E2;

  /* Typography */
  --font-display: "Bricolage Grotesque", "Geist", ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;
  --font-body:    "Geist", ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;
  --font-mono:    "Geist Mono", ui-monospace, "SF Mono", Menlo, monospace;

  /* Scale (clamp-based fluid) */
  --fs-xs:   0.78rem;
  --fs-sm:   0.875rem;
  --fs-md:   1rem;
  --fs-lg:   1.125rem;
  --fs-xl:   1.25rem;
  --fs-2xl:  clamp(1.4rem, 1.2rem + .8vw, 1.65rem);
  --fs-3xl:  clamp(1.7rem, 1.3rem + 1.5vw, 2.15rem);
  --fs-4xl:  clamp(2.1rem, 1.5rem + 2.4vw, 3rem);
  --fs-5xl:  clamp(2.6rem, 1.6rem + 3.6vw, 4rem);
  --fs-6xl:  clamp(3rem, 1.8rem + 4.8vw, 5rem);

  /* Spacing */
  --sp-1: .25rem;  --sp-2: .5rem;   --sp-3: .75rem;
  --sp-4: 1rem;    --sp-5: 1.25rem; --sp-6: 1.5rem;
  --sp-8: 2rem;    --sp-10: 2.5rem; --sp-12: 3rem;
  --sp-16: 4rem;   --sp-20: 5rem;   --sp-24: 6rem;

  /* Radii */
  --r-xs: 6px;  --r-sm: 10px; --r-md: 14px;
  --r-lg: 18px; --r-xl: 24px; --r-2xl: 32px; --r-full: 999px;

  /* Shadows — premium soft */
  --sh-xs: 0 1px 2px rgba(15,23,42,.04);
  --sh-sm: 0 2px 4px rgba(15,23,42,.04), 0 1px 2px rgba(15,23,42,.03);
  --sh-md: 0 4px 12px rgba(15,23,42,.06), 0 2px 4px rgba(15,23,42,.04);
  --sh-lg: 0 12px 28px rgba(15,23,42,.08), 0 4px 8px rgba(15,23,42,.04);
  --sh-xl: 0 24px 48px rgba(15,23,42,.10), 0 8px 16px rgba(15,23,42,.05);
  --sh-glow: 0 0 0 6px rgba(37,99,235,.08), 0 12px 28px rgba(37,99,235,.18);

  /* Layout */
  --container: 1200px;
  --container-narrow: 920px;

  /* Motion */
  --ease: cubic-bezier(.2,.7,.2,1);
  --ease-spring: cubic-bezier(.34,1.56,.64,1);
  --t-fast: 140ms;
  --t-base: 240ms;
  --t-slow: 420ms;
}

/* ---------- 3. Base typography ---------- */
body{
  font-family: var(--font-body);
  font-size: var(--fs-md);
  color: var(--ink-3);
  background: var(--bg);
  background-image:
    radial-gradient(1200px 600px at 80% -10%, rgba(37,99,235,.06), transparent 60%),
    radial-gradient(900px 500px at -10% 30%, rgba(56,189,248,.06), transparent 60%);
  font-feature-settings: "ss01","cv11";
}

h1,h2,h3,h4,h5,h6{
  font-family: var(--font-display);
  color: var(--ink);
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.1;
}
h1{font-size: var(--fs-6xl); font-weight: 600; letter-spacing: -0.035em;}
h2{font-size: var(--fs-5xl); letter-spacing: -0.03em;}
h3{font-size: var(--fs-3xl); letter-spacing: -0.025em;}
h4{font-size: var(--fs-xl); font-weight: 600;}
h5{font-size: var(--fs-lg); font-weight: 600;}

p{color: var(--ink-3); max-width: 70ch}
.lead{font-size: var(--fs-xl); color: var(--ink-2); line-height: 1.55}

::selection{background: var(--accent-2); color:#fff}

/* ---------- 4. Layout primitives ---------- */
.container{
  width: 100%;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: clamp(1rem, 3vw, 1.5rem);
}
.container-narrow{max-width: var(--container-narrow); margin-inline:auto; padding-inline: clamp(1rem,3vw,1.5rem)}
.section{padding-block: clamp(3rem, 7vw, 6rem);}
.section-tight{padding-block: clamp(2rem, 4vw, 3rem);}
.section-soft{background: var(--bg-soft);}
.section-dark{background: var(--ink); color: rgba(255,255,255,.86)}
.section-dark h1,.section-dark h2,.section-dark h3{color: #fff}
.section-dark p{color: rgba(255,255,255,.7)}

.stack > * + *{margin-top: var(--stack, 1rem)}
.cluster{display:flex; flex-wrap:wrap; gap: var(--gap,1rem); align-items:center}
.grid{display:grid; gap: var(--gap, 1.5rem)}
.grid-2{grid-template-columns: repeat(auto-fit, minmax(280px,1fr))}
.grid-3{grid-template-columns: repeat(auto-fit, minmax(260px,1fr))}
.grid-4{grid-template-columns: repeat(auto-fit, minmax(220px,1fr))}

.eyebrow{
  display:inline-flex; align-items:center; gap:.45rem;
  padding:.4rem .75rem;
  background: var(--bg-elev);
  border:1px solid var(--line);
  border-radius: var(--r-full);
  font-size: var(--fs-xs);
  font-weight: 500;
  color: var(--ink-2);
  letter-spacing: .02em;
  box-shadow: var(--sh-xs);
}
.eyebrow .dot{width:6px;height:6px;background: var(--accent-2); border-radius: 50%; box-shadow: 0 0 0 4px rgba(37,99,235,.12)}

.section-head{
  display: flex; flex-direction: column; gap: var(--sp-4);
  margin-bottom: clamp(2rem,4vw,3rem);
  max-width: 760px;
}
.section-head h2{margin-top:.25rem}
.section-head p{font-size: var(--fs-lg); color: var(--ink-3)}

.muted{color: var(--ink-4)}
.serif{font-family: var(--font-display); font-style: italic; font-weight: 500}

/* ---------- 5. Buttons ---------- */
.btn{
  --bg-btn: var(--ink);
  --fg-btn: #fff;
  display: inline-flex; align-items: center; gap: .55rem;
  padding: .85rem 1.25rem;
  background: var(--bg-btn);
  color: var(--fg-btn);
  border-radius: var(--r-full);
  font-weight: 500;
  font-size: var(--fs-md);
  letter-spacing: -.005em;
  transition: transform var(--t-fast) var(--ease), box-shadow var(--t-base) var(--ease), background var(--t-base) var(--ease);
  white-space: nowrap;
  border: 1px solid transparent;
  position: relative;
}
.btn:hover{transform: translateY(-1px); box-shadow: var(--sh-md)}
.btn:active{transform: translateY(0)}
.btn .arr{transition: transform var(--t-base) var(--ease-spring)}
.btn:hover .arr{transform: translateX(3px)}

.btn-primary{
  --bg-btn: var(--accent-2);
  --fg-btn: #fff;
  box-shadow: var(--sh-sm), inset 0 1px 0 rgba(255,255,255,.15);
}
.btn-primary:hover{--bg-btn: var(--accent); box-shadow: var(--sh-glow)}

.btn-dark{--bg-btn: var(--ink); --fg-btn: #fff;}
.btn-dark:hover{--bg-btn: #000}

.btn-soft{
  --bg-btn: var(--bg-elev);
  --fg-btn: var(--ink);
  border-color: var(--line);
}
.btn-soft:hover{--bg-btn: #fff; border-color: var(--line-3)}

.btn-ghost{
  --bg-btn: transparent;
  --fg-btn: var(--ink-2);
  border-color: var(--line-2);
}
.btn-ghost:hover{--bg-btn: var(--bg-elev)}

.btn-sm{padding: .55rem .9rem; font-size: var(--fs-sm)}
.btn-lg{padding: 1rem 1.5rem; font-size: var(--fs-lg)}

/* ---------- 6. Header / Nav ---------- */
.site-header{
  position: sticky; top: 0; z-index: 50;
  background: var(--bg-glass);
  backdrop-filter: saturate(140%) blur(14px);
  -webkit-backdrop-filter: saturate(140%) blur(14px);
  border-bottom: 1px solid var(--line);
}
.nav{
  display: flex; align-items: center; justify-content: space-between; gap: 1rem;
  height: 68px;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: clamp(1rem, 3vw, 1.5rem);
}
.nav:not(.nav-center){
  display:grid;
  grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);
  column-gap:clamp(1.25rem, 3vw, 2.5rem);
}
.nav:not(.nav-center) .brand{grid-column:2; justify-self:center}
.nav:not(.nav-center) .nav-links{grid-column:1; grid-row:1; justify-self:end}
.nav:not(.nav-center) .nav-cta{grid-column:3; grid-row:1; justify-self:start}
.brand{display:flex; align-items:center; gap:.6rem; font-weight: 600; color: var(--ink); letter-spacing: -.01em; font-family: var(--font-display); font-size: 1.1rem}
.brand .logo-mark{
  width: 32px; height: 32px; border-radius: 9px;
  background:
    linear-gradient(135deg, var(--accent-2), var(--accent));
  display:grid; place-items:center;
  color:#fff; font-weight:700; font-family: var(--font-display);
  box-shadow: var(--sh-sm);
  position: relative;
  overflow: hidden;
}
.brand .logo-mark::after{
  content:""; position:absolute; inset:0;
  background: radial-gradient(circle at 30% 20%, rgba(255,255,255,.4), transparent 60%);
}
.brand .logo-mark span{position:relative; z-index:1; font-size: 16px}

.nav-links{display:flex; align-items:center; gap: 1.5rem; font-size: var(--fs-sm)}
.nav-links a, .nav-links button{
  color: var(--ink-2);
  font-weight: 500;
  padding: .4rem 0;
  position: relative;
  transition: color var(--t-fast) var(--ease);
}
.nav-links a:hover, .nav-links button:hover{color: var(--ink)}
.nav-links .has-mega{display:flex; align-items:center; gap:.3rem}
.nav-links .chev{font-size:.7rem; transition: transform var(--t-fast) var(--ease); opacity:.6}
.nav-item{position:relative}
.nav-item:hover .mega{opacity:1; visibility:visible; transform: translateY(0)}
.nav-item:hover .chev{transform: rotate(180deg)}

.mega{
  position: absolute;
  top: calc(100% + 8px); left: 50%;
  transform: translateX(-50%) translateY(8px);
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 1.25rem;
  box-shadow: var(--sh-lg);
  min-width: 520px;
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.25rem;
  opacity: 0; visibility: hidden;
  transition: opacity var(--t-base) var(--ease), transform var(--t-base) var(--ease), visibility 0s var(--t-base);
  z-index: 10;
}
.nav-item:hover .mega{transition: opacity var(--t-base) var(--ease), transform var(--t-base) var(--ease), visibility 0s}
.mega.single{min-width: 280px; grid-template-columns: 1fr}
.mega.mega-wide{min-width:min(760px, calc(100vw - 32px)); grid-template-columns: repeat(3, minmax(0, 1fr))}
.mega.mega-sectors{min-width:300px; grid-template-columns:1fr; left:0; transform:translateY(8px)}
.nav-item:hover .mega.mega-sectors{transform:translateY(0)}
.mega h5{font-size: var(--fs-xs); font-weight: 500; color: var(--ink-4); text-transform: uppercase; letter-spacing: .08em; margin-bottom: .65rem; font-family: var(--font-body)}
.mega-list{display:flex; flex-direction: column; gap: .15rem}
.mega-a{
  display:flex; align-items:center; gap:.65rem;
  padding: .55rem .65rem;
  border-radius: 8px;
  color: var(--ink-2) !important;
  font-weight: 500;
  font-size: var(--fs-sm);
  transition: background var(--t-fast) var(--ease);
}
.mega-a:hover{background: var(--bg-soft)}
.mega-a .mi{
  width: 28px; height: 28px;
  background: var(--bg-soft);
  border-radius: 7px;
  display:grid; place-items: center;
  flex-shrink: 0;
}
.mega-a .mi svg{width:14px; height:14px; color: var(--accent)}

.nav-cta{display:flex; align-items:center; gap: .65rem}
.menu-toggle{display:none; width: 40px; height: 40px; border-radius: 10px; border:1px solid var(--line); align-items:center; justify-content:center}
.menu-toggle span{display:block; width:18px; height:1.5px; background: var(--ink); position: relative; transition: var(--t-fast)}
.menu-toggle span::before,.menu-toggle span::after{content:""; position:absolute; left:0; width:18px; height:1.5px; background: var(--ink); transition: var(--t-fast)}
.menu-toggle span::before{top:-6px} .menu-toggle span::after{top:6px}
body.menu-open .menu-toggle span{background:transparent}
body.menu-open .menu-toggle span::before{top:0; transform: rotate(45deg)}
body.menu-open .menu-toggle span::after{top:0; transform: rotate(-45deg)}

.mobile-menu{
  position: fixed; inset: 68px 0 0 0;
  background: var(--bg);
  z-index: 40;
  padding: 1.5rem;
  display: none;
  flex-direction: column;
  gap: .25rem;
  overflow-y: auto;
}
.mobile-menu a{
  display: block;
  padding: 1rem .25rem;
  border-bottom: 1px solid var(--line);
  font-size: var(--fs-lg);
  font-weight: 500;
  color: var(--ink);
}
.mobile-menu .btn{margin-top: 1rem; justify-content: center}
body.menu-open .mobile-menu{display:flex}
body.menu-open{overflow:hidden}

/* ---------- 7. Hero ---------- */
.hero{
  padding-block: clamp(3rem, 7vw, 6rem) clamp(2rem, 5vw, 4rem);
  position: relative;
  overflow: hidden;
}
.hero-inner{
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: clamp(2rem, 5vw, 4rem);
  align-items: center;
}
.hero h1{
  margin-block: .75rem 1.25rem;
  font-weight: 600;
}
.hero h1 .grad{
  background: linear-gradient(120deg, var(--accent) 0%, var(--accent-2) 50%, var(--accent) 100%);
  background-size: 200% 100%;
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  font-style: italic;
  font-weight: 500;
  animation: gradShift 8s linear infinite;
  padding-right: 0.2em;
}
@keyframes gradShift{to{background-position: 200% 0}}
.hero p.lead{margin-bottom: 1.75rem; max-width: 52ch}
.hero-actions{display:flex; flex-wrap:wrap; gap: .75rem; align-items: center}
.hero-trust{margin-top: 2rem; display: flex; flex-wrap: wrap; gap: 1.25rem 2rem; align-items: center}
.hero-trust .item{display:flex; align-items: center; gap:.55rem; font-size: var(--fs-sm); color: var(--ink-3)}
.hero-trust .item strong{color: var(--ink); font-family: var(--font-display); font-size: var(--fs-xl); font-weight: 600}
.hero-trust .v{width:1px; height:24px; background: var(--line)}

/* ---------- 8. Lavio OS — Hero panel mockup ---------- */
.lavio-os{
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  box-shadow: var(--sh-xl);
  overflow: hidden;
  position: relative;
  isolation: isolate;
}
.lavio-os::before{
  content: ""; position: absolute; inset: -1px;
  background: linear-gradient(135deg, rgba(37,99,235,.16), transparent 30%, transparent 70%, rgba(37,99,235,.10));
  border-radius: inherit;
  z-index: -1;
  pointer-events: none;
}
.os-bar{
  display:flex; align-items:center; gap:.75rem;
  padding: .65rem .9rem;
  border-bottom: 1px solid var(--line);
  background: linear-gradient(to bottom, #FCFBF8, var(--bg-elev));
}
.os-dots{display:flex; gap:.32rem}
.os-dots span{width:10px;height:10px;border-radius:50%; background:#E5E1D8}
.os-dots span:nth-child(1){background:#FB7185}
.os-dots span:nth-child(2){background:#FBBF24}
.os-dots span:nth-child(3){background:#34D399}
.os-title{font-size: var(--fs-xs); color: var(--ink-4); font-family: var(--font-mono); flex: 1; text-align: center; letter-spacing: .02em}
.os-pill{font-size:11px; color: var(--success); background: var(--success-soft); padding:.2rem .55rem; border-radius: var(--r-full); display:flex; align-items:center; gap:.3rem; font-weight: 500}
.os-pill::before{content:""; width:6px;height:6px;background: var(--success); border-radius:50%; animation: pulse 1.8s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1; transform:scale(1)} 50%{opacity:.4; transform:scale(.85)}}

.os-body{
  display: grid;
  grid-template-columns: 180px 1fr;
  min-height: 460px;
}
.os-side{
  background: #FCFBF8;
  border-right: 1px solid var(--line);
  padding: .9rem .55rem;
}
.os-side .group-label{font-size: 10px; color: var(--ink-5); text-transform: uppercase; letter-spacing: .1em; padding: .6rem .7rem .35rem; font-family: var(--font-body); font-weight: 500}
.os-side a{
  display: flex; align-items: center; gap: .55rem;
  padding: .5rem .65rem;
  border-radius: 8px;
  font-size: 13px;
  color: var(--ink-3);
  font-weight: 500;
  cursor: pointer;
}
.os-side a:hover{background: var(--bg-soft); color: var(--ink)}
.os-side a.active{background: var(--accent-soft); color: var(--accent-ink)}
.os-side a .num{margin-left: auto; font-size: 11px; background: var(--ink); color: #fff; padding: .1rem .4rem; border-radius: 6px; font-family: var(--font-mono)}
.os-side a.active .num{background: var(--accent)}
.os-side a svg{width:14px;height:14px;opacity:.7}

.os-main{padding: 1rem 1.1rem; overflow: hidden}
.os-row{
  display: flex; align-items: flex-start; gap: .65rem;
  padding: .65rem .25rem;
  border-bottom: 1px dashed var(--line);
  opacity: 0;
  animation: slideIn .5s var(--ease) forwards;
}
.os-row:nth-child(1){animation-delay: .2s}
.os-row:nth-child(2){animation-delay: .8s}
.os-row:nth-child(3){animation-delay: 1.4s}
.os-row:nth-child(4){animation-delay: 2.0s}
.os-row:nth-child(5){animation-delay: 2.6s}
@keyframes slideIn{from{opacity:0; transform: translateY(8px)}to{opacity:1; transform:none}}

.os-avatar{
  width: 32px; height: 32px;
  border-radius: 50%;
  flex-shrink: 0;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 12px;
  color: #fff;
  display: grid; place-items: center;
  letter-spacing: -.02em;
}
.os-avatar.a1{background: linear-gradient(135deg, #F472B6, #BE185D)}
.os-avatar.a2{background: linear-gradient(135deg, #60A5FA, #1E40AF)}
.os-avatar.a3{background: linear-gradient(135deg, #34D399, #047857)}
.os-avatar.a4{background: linear-gradient(135deg, #FBBF24, #B45309)}
.os-avatar.a5{background: linear-gradient(135deg, #A78BFA, #6D28D9)}

.os-cell{flex:1; min-width: 0}
.os-top{display:flex; align-items:center; gap:.4rem; margin-bottom:.15rem}
.os-name{font-size: 13px; color: var(--ink); font-weight: 600}
.os-channel{display:inline-flex; align-items:center; gap:.25rem; font-size: 10px; padding: .1rem .4rem; border-radius: 5px; font-weight: 500}
.os-channel.wa{background: #D1FAE5; color: #065F46}
.os-channel.ig{background: #FCE7F3; color: #9F1239}
.os-channel.web{background: #DBEAFE; color: #1E40AF}
.os-channel.dot{width:6px;height:6px;border-radius:50%}
.os-time{font-size: 10px; color: var(--ink-5); margin-left:auto; font-family: var(--font-mono)}
.os-snippet{font-size: 13px; color: var(--ink-3); white-space: nowrap; overflow: hidden; text-overflow: ellipsis}
.os-snippet b{color: var(--ink-2); font-weight: 500}
.os-tag{display:inline-block; font-size: 10px; padding: .12rem .42rem; border-radius:5px; margin-top:.25rem; font-weight: 500}
.os-tag.lead{background: var(--accent-soft); color: var(--accent-ink)}
.os-tag.booked{background: var(--success-soft); color: #065F46}
.os-tag.ai{background: #F3E8FF; color: #6D28D9}

.os-typing{display:inline-flex; gap:3px; align-items:center; padding-left:2px}
.os-typing span{width:5px;height:5px;background: var(--ink-5); border-radius:50%; animation: typing 1.2s infinite var(--ease)}
.os-typing span:nth-child(2){animation-delay: .15s}
.os-typing span:nth-child(3){animation-delay: .3s}
@keyframes typing{0%,80%,100%{transform: scale(.6); opacity:.4} 40%{transform: scale(1); opacity:1}}

.os-footer{
  display: flex; justify-content: space-between; align-items: center;
  padding: .65rem 1rem;
  border-top: 1px solid var(--line);
  background: #FCFBF8;
  font-size: 11px;
  color: var(--ink-4);
  font-family: var(--font-mono);
}
.os-footer .live{color: var(--success); display:flex; align-items:center; gap:.3rem}
.os-footer .live::before{content:""; width:6px;height:6px; background:var(--success); border-radius:50%; animation: pulse 1.8s infinite}

/* Float accent badges around OS */
.os-wrap{position: relative}
.os-float{
  position: absolute;
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: .65rem .9rem;
  box-shadow: var(--sh-lg);
  display: flex; align-items: center; gap: .55rem;
  font-size: var(--fs-sm);
  font-weight: 500;
  animation: floatY 4s ease-in-out infinite;
}
.os-float .ico{width: 32px; height: 32px; border-radius: 8px; display:grid; place-items:center; flex-shrink:0}
.os-float strong{color: var(--ink); font-family: var(--font-display)}
.os-float small{color: var(--ink-4); display:block; font-size: 11px; font-weight: 400}
.os-float.f1{top: -16px; right: -20px; animation-delay: 0s}
.os-float.f1 .ico{background: var(--success-soft); color: var(--success)}
.os-float.f2{bottom: 32px; left: -28px; animation-delay: 1.5s}
.os-float.f2 .ico{background: var(--accent-soft); color: var(--accent)}
@keyframes floatY{0%,100%{transform: translateY(0)} 50%{transform: translateY(-6px)}}

/* ---------- 9. Bento grid (capability blocks) ---------- */
.bento{
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 1rem;
}
.bento .b{
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 1.5rem;
  position: relative;
  overflow: hidden;
  transition: transform var(--t-base) var(--ease), box-shadow var(--t-base) var(--ease), border-color var(--t-base) var(--ease);
  display: flex; flex-direction: column;
}
.bento .b:hover{transform: translateY(-3px); box-shadow: var(--sh-md); border-color: var(--line-3)}
.bento .b h4{font-size: var(--fs-xl); margin-bottom: .5rem; font-weight: 600}
.bento .b p{font-size: var(--fs-sm); color: var(--ink-3); margin-bottom: 1rem}
.bento .b .ico{
  width: 44px; height: 44px;
  border-radius: 12px;
  background: var(--accent-soft);
  color: var(--accent);
  display: grid; place-items: center;
  margin-bottom: 1rem;
}
.bento .b .ico svg{width: 22px; height: 22px}
.bento .b .visual{
  margin-top: auto;
  border-top: 1px solid var(--line);
  padding-top: 1rem;
}

/* Bento sizes */
.b-lg{grid-column: span 4}
.b-md{grid-column: span 3}
.b-sm{grid-column: span 2}
.b-w{grid-column: span 6}

/* Bento visual: inbox preview */
.viz-inbox{display:flex; flex-direction: column; gap: .5rem; font-size: var(--fs-sm)}
.viz-inbox .row{
  display: flex; align-items: center; gap: .55rem;
  padding: .5rem .65rem;
  background: var(--bg-soft);
  border-radius: 8px;
}
.viz-inbox .row .ch{width:22px;height:22px;border-radius:6px;display:grid;place-items:center;flex-shrink:0}
.viz-inbox .row .ch svg{width:12px;height:12px;color:#fff}
.viz-inbox .row .ch.wa{background:#25D366}
.viz-inbox .row .ch.ig{background:linear-gradient(135deg,#F58529,#DD2A7B)}
.viz-inbox .row .ch.web{background: var(--accent-2)}
.viz-inbox .row .lbl{font-size: 12px; color: var(--ink-2); font-weight: 500; flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis}
.viz-inbox .row .n{font-size: 11px; background: var(--ink); color: #fff; padding: .1rem .4rem; border-radius: 5px; font-family: var(--font-mono); flex-shrink:0}

/* Bento visual: calendar mini */
.viz-cal{display: grid; grid-template-columns: repeat(7,1fr); gap: 3px; font-size: 10px; text-align: center}
.viz-cal .c{aspect-ratio: 1; background: var(--bg-soft); border-radius: 4px; display: grid; place-items: center; color: var(--ink-4); font-weight: 500; font-family: var(--font-mono)}
.viz-cal .c.has{background: var(--accent-soft); color: var(--accent-ink)}
.viz-cal .c.now{background: var(--accent); color: #fff}
.viz-cal .c.head{background: transparent; color: var(--ink-5); font-size: 9px; aspect-ratio: auto}

/* Bento visual: bar chart */
.viz-bars{display: flex; align-items: flex-end; gap: 4px; height: 72px; padding: .25rem 0}
.viz-bars .bar{flex:1; background: linear-gradient(to top, var(--accent), var(--accent-2)); border-radius: 3px 3px 0 0; min-height: 8px; opacity: .85}
.viz-bars .bar:hover{opacity: 1}

/* Bento visual: flow */
.viz-flow{display:flex; align-items: center; gap: .35rem; font-size: 11px; color: var(--ink-3); font-family: var(--font-mono); flex-wrap: wrap}
.viz-flow .node{padding: .3rem .55rem; background: var(--bg-soft); border-radius: 6px; border: 1px solid var(--line); color: var(--ink-2); font-weight: 500}
.viz-flow .node.hl{background: var(--accent-soft); color: var(--accent-ink); border-color: var(--accent-soft)}
.viz-flow .arr{color: var(--ink-5)}

/* Bento visual: API badges */
.viz-api{display: flex; flex-wrap: wrap; gap: .4rem}
.viz-api .badge{
  display: inline-flex; align-items: center; gap: .35rem;
  padding: .35rem .65rem;
  background: var(--bg-soft);
  border: 1px solid var(--line);
  border-radius: var(--r-full);
  font-size: 12px;
  color: var(--ink-2);
  font-weight: 500;
}
.viz-api .badge .d{width:7px;height:7px;border-radius:50%;background: var(--success)}

/* ---------- 10. Comparison matrix ---------- */
.compare{
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  overflow: hidden;
  box-shadow: var(--sh-md);
}
.compare-row{
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1.1fr;
  align-items: center;
}
.compare-row > div{padding: 1rem 1.25rem; border-bottom: 1px solid var(--line)}
.compare-row:last-child > div{border-bottom: 0}
.compare-row.head > div{
  background: var(--ink);
  color: rgba(255,255,255,.85);
  border-bottom: 1px solid var(--ink-2);
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-sm);
  letter-spacing: .01em;
}
.compare-row.head > div.lavio{background: var(--accent); color: #fff; position: relative}
.compare-row.head > div.lavio::after{
  content: "Önerilen";
  position: absolute; top: 6px; right: 10px;
  font-size: 10px; padding: .15rem .45rem;
  background: rgba(255,255,255,.2); border-radius: var(--r-full);
  font-weight: 500;
}
.compare-row > div.lavio{background: rgba(37,99,235,.05)}
.compare-row > div.feature{font-weight: 500; color: var(--ink-2); font-size: var(--fs-sm)}
.compare-cell{display:flex; align-items: center; gap: .5rem; font-size: var(--fs-sm)}
.compare-cell.no{color: var(--ink-4)}
.compare-cell.yes{color: var(--ink); font-weight: 500}
.compare-cell .ic{width:18px;height:18px;border-radius:50%;display:grid;place-items:center;flex-shrink:0}
.compare-cell.no .ic{background: var(--bg-soft); color: var(--ink-5)}
.compare-cell.yes .ic{background: var(--success-soft); color: var(--success)}
.compare-cell .ic svg{width:11px;height:11px}

/* ---------- 11. Pricing ---------- */
.pricing{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
  align-items: stretch;
}
.price-card{
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  padding: 2rem 1.75rem 1.75rem;
  position: relative;
  display: flex; flex-direction: column;
  transition: transform var(--t-base) var(--ease), box-shadow var(--t-base) var(--ease);
}
.price-card:hover{transform: translateY(-3px); box-shadow: var(--sh-lg)}
.price-card.featured{
  background: var(--ink);
  color: #fff;
  border-color: transparent;
  transform: scale(1.02);
  box-shadow: var(--sh-xl);
}
.price-card.featured::before{
  content: "";
  position: absolute; inset: -1px; z-index: -1;
  background: linear-gradient(135deg, var(--accent-2), var(--accent));
  border-radius: inherit;
}
.price-card.featured h3{color:#fff}
.price-card.featured p, .price-card.featured .price-feature{color: rgba(255,255,255,.8)}
.price-card.featured .price-meta{color: rgba(255,255,255,.55)}
.price-card .badge-hot{
  position: absolute; top: -12px; right: 1.5rem;
  background: var(--accent-2); color: #fff;
  font-size: 11px; font-weight: 500; padding: .35rem .75rem;
  border-radius: var(--r-full);
  letter-spacing: .02em;
  box-shadow: var(--sh-md);
}
.price-card h3{font-size: var(--fs-xl); margin-bottom: .35rem}
.price-card .tagline{font-size: var(--fs-sm); color: var(--ink-4); margin-bottom: 1.5rem; min-height: 2.5em}
.price-card.featured .tagline{color: rgba(255,255,255,.65)}
.price-amount{
  font-family: var(--font-display);
  font-size: 2.6rem;
  font-weight: 600;
  letter-spacing: -.03em;
  line-height: 1;
  display: flex; align-items: baseline; gap: .35rem;
}
.price-amount .cur{font-size: 1.2rem; color: var(--ink-3); font-weight: 500}
.price-card.featured .price-amount .cur{color: rgba(255,255,255,.7)}
.price-amount .per{font-size: var(--fs-sm); color: var(--ink-4); font-family: var(--font-body); font-weight: 400; align-self: center; margin-left: .25rem}
.price-card.featured .price-amount .per{color: rgba(255,255,255,.6)}
.price-meta{font-size: var(--fs-xs); color: var(--ink-5); margin-top: .35rem; margin-bottom: 1.5rem}
.price-features{display: flex; flex-direction: column; gap: .7rem; margin-bottom: 1.75rem; flex: 1}
.price-feature{display:flex; align-items: flex-start; gap: .55rem; font-size: var(--fs-sm); color: var(--ink-2)}
.price-feature .ic{
  width: 18px; height: 18px;
  background: var(--success-soft); color: var(--success);
  border-radius: 50%;
  display: grid; place-items: center; flex-shrink: 0;
  margin-top: 1px;
}
.price-feature .ic svg{width:10px; height: 10px}
.price-card.featured .price-feature .ic{background: rgba(37,99,235,.25); color: #93C5FD}
.price-card .btn{justify-content: center; width: 100%}

.lv-pricing-builder{
  position: relative;
  background:
    radial-gradient(760px 360px at 12% 12%, rgba(14,165,233,.10), transparent 60%),
    radial-gradient(720px 420px at 92% 30%, rgba(37,99,235,.12), transparent 62%),
    linear-gradient(180deg, rgba(255,255,255,0), rgba(239,246,255,.72) 42%, rgba(255,255,255,.88));
  overflow: hidden;
}
.lv-price-tabs{
  display: grid;
  grid-template-columns: repeat(7, minmax(142px, 1fr));
  gap: .85rem;
  margin-bottom: 1.25rem;
  padding: .2rem;
}
.lv-price-tab{
  appearance: none;
  background:
    linear-gradient(180deg, rgba(255,255,255,.94), rgba(248,251,255,.86));
  border: 1px solid rgba(148,163,184,.22);
  border-radius: var(--r-lg);
  padding: 1rem;
  min-height: 128px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: .55rem;
  cursor: pointer;
  text-align: left;
  box-shadow: 0 12px 34px rgba(15,23,42,.055), inset 0 1px 0 rgba(255,255,255,.92);
  transition: transform var(--t-base) var(--ease), border-color var(--t-base) var(--ease), box-shadow var(--t-base) var(--ease), background var(--t-base) var(--ease);
}
.lv-price-tab:hover{
  transform: translateY(-2px);
  border-color: rgba(37,99,235,.38);
  box-shadow: 0 18px 44px rgba(37,99,235,.10), inset 0 1px 0 rgba(255,255,255,.95);
}
.lv-price-tab[aria-selected="true"]{
  background:
    radial-gradient(circle at 18% 12%, rgba(37,99,235,.13), transparent 44%),
    linear-gradient(180deg, #fff, rgba(239,246,255,.98));
  border-color: rgba(37,99,235,.62);
  box-shadow: 0 20px 52px rgba(37,99,235,.16), inset 0 1px 0 rgba(255,255,255,.98);
}
.lv-price-tab .mi{
  width: 34px;
  height: 34px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  background: var(--accent-soft);
  color: var(--accent);
}
.lv-price-tab[aria-selected="true"] .mi{
  background: var(--accent);
  color: #fff;
}
.lv-price-tab .mi img{
  width: 18px;
  height: 18px;
  object-fit: contain;
}
.lv-price-tab strong{
  color: var(--ink);
  font-size: var(--fs-sm);
  font-weight: 600;
  line-height: 1.2;
}
.lv-price-tab span:last-child{
  color: var(--ink-4);
  font-size: var(--fs-xs);
  line-height: 1.35;
}
.lv-price-panel{
  background:
    radial-gradient(circle at top right, rgba(37,99,235,.14), transparent 38%),
    linear-gradient(180deg, rgba(255,255,255,.88), rgba(248,251,255,.76));
  border: 1px solid rgba(148,163,184,.22);
  border-radius: var(--r-2xl);
  padding: clamp(1.1rem, 3vw, 1.75rem);
  box-shadow: 0 24px 80px rgba(15,23,42,.075), inset 0 1px 0 rgba(255,255,255,.9);
  backdrop-filter: blur(14px);
}
.lv-price-panel-head{
  display: grid;
  grid-template-columns: minmax(0, .8fr) minmax(280px, 1fr);
  gap: 1rem 2rem;
  align-items: end;
  margin-bottom: 1.25rem;
}
.lv-price-panel-head .eyebrow{
  grid-column: 1 / -1;
  margin: 0;
}
.lv-price-panel-head h2{
  font-size: var(--fs-3xl);
  max-width: none;
}
.lv-price-panel-head p{
  color: var(--ink-3);
  max-width: 70ch;
  margin: 0;
}
.lv-price-grid{
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
  align-items: stretch;
}
.lv-package-card{
  position: relative;
  display: flex;
  flex-direction: column;
  min-height: 100%;
  background:
    linear-gradient(180deg, rgba(255,255,255,.97), rgba(250,253,255,.92));
  border: 1px solid rgba(148,163,184,.22);
  border-radius: var(--r-xl);
  padding: 1.35rem;
  box-shadow: 0 16px 46px rgba(15,23,42,.06), inset 0 1px 0 rgba(255,255,255,.96);
  transition: transform var(--t-base) var(--ease), box-shadow var(--t-base) var(--ease), border-color var(--t-base) var(--ease);
}
.lv-package-card:hover{
  transform: translateY(-5px);
  border-color: rgba(37,99,235,.34);
  box-shadow: 0 24px 70px rgba(37,99,235,.13), inset 0 1px 0 rgba(255,255,255,.98);
}
.lv-package-card.is-recommended{
  background:
    radial-gradient(circle at 20% 0%, rgba(37,99,235,.34), transparent 38%),
    linear-gradient(180deg, #07142B, #0B1220);
  border-color: rgba(96,165,250,.32);
  color: #fff;
  box-shadow: 0 28px 82px rgba(7,20,43,.28), 0 0 0 1px rgba(37,99,235,.08), 0 0 52px rgba(37,99,235,.16);
}
.lv-package-card .badge-hot{
  align-self: flex-start;
  margin-bottom: .75rem;
  background: var(--accent);
  color: #fff;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .02em;
  border-radius: var(--r-full);
  padding: .32rem .62rem;
}
.lv-package-card h3{
  font-size: var(--fs-xl);
  margin-bottom: .55rem;
}
.lv-package-card.is-recommended h3{color: #fff}
.lv-package-price{
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 2.35vw, 2.35rem);
  font-weight: 700;
  letter-spacing: -.02em;
  color: var(--ink);
  line-height: 1.1;
  margin-bottom: .45rem;
  display: flex;
  flex-direction: column;
  gap: .1rem;
  min-width: 0;
}
.lv-package-price span{display: block; overflow-wrap: anywhere}
.lv-package-price small{
  display: block;
  color: var(--ink-4);
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  font-weight: 600;
  letter-spacing: 0;
}
.lv-package-price.is-quote{font-size: clamp(1.65rem, 2.1vw, 2.1rem)}
.lv-package-card.is-recommended .lv-package-price{color: #fff}
.lv-package-card.is-recommended .lv-package-price small{color: rgba(255,255,255,.68)}
.lv-package-trust{
  color: var(--ink-4);
  font-size: var(--fs-xs);
  margin-bottom: 1rem;
}
.lv-package-card.is-recommended .lv-package-trust{color: rgba(255,255,255,.62)}
.lv-package-features{
  display: flex;
  flex-direction: column;
  gap: .62rem;
  margin: .2rem 0 1.25rem;
  flex: 1;
}
.lv-package-features li{
  display: flex;
  gap: .52rem;
  align-items: flex-start;
  color: var(--ink-2);
  font-size: var(--fs-sm);
  line-height: 1.45;
}
.lv-package-card.is-recommended .lv-package-features li{color: rgba(255,255,255,.78)}
.lv-package-features li::before{
  content: "";
  width: 17px;
  height: 17px;
  margin-top: 2px;
  flex: 0 0 17px;
  border-radius: 50%;
  background: var(--success-soft);
  color: var(--success);
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='%2316A34A' stroke-width='3' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-size: 11px;
  background-repeat: no-repeat;
  background-position: center;
}
.lv-package-card.is-recommended .lv-package-features li::before{
  background-color: rgba(37,99,235,.22);
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='%2393C5FD' stroke-width='3' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
}
.lv-package-card .btn{
  width: 100%;
  justify-content: center;
  margin-top: auto;
  min-height: 46px;
  box-shadow: 0 12px 28px rgba(15,23,42,.055);
}
.lv-package-card.is-recommended .btn{
  background: var(--accent);
  color: #fff;
  border-color: transparent;
  box-shadow: 0 16px 36px rgba(37,99,235,.28);
}
.lv-price-note{
  display: flex;
  gap: .7rem;
  align-items: flex-start;
  margin-top: 1.1rem;
  padding: 1rem 1.15rem;
  border: 1px solid rgba(37,99,235,.18);
  border-radius: var(--r-lg);
  background: linear-gradient(180deg, rgba(255,255,255,.82), rgba(239,246,255,.78));
  color: var(--ink-3);
  font-size: var(--fs-sm);
  line-height: 1.55;
  box-shadow: 0 14px 40px rgba(15,23,42,.05);
}
.lv-price-note strong{
  color: var(--ink);
  white-space: nowrap;
}
.lv-pricing-cta{
  background: linear-gradient(135deg, var(--ink), #172554);
  color: #fff;
  padding: clamp(2rem, 5vw, 3.5rem);
  border-radius: var(--r-2xl);
  position: relative;
  overflow: hidden;
}
.lv-pricing-cta::before{
  content: "";
  position: absolute;
  inset: -50%;
  background: radial-gradient(circle, rgba(37,99,235,.34), transparent 50%);
  pointer-events: none;
}
.lv-pricing-cta > div{position: relative}
.lv-pricing-cta h2{
  color: #fff;
  font-size: var(--fs-4xl);
  margin-bottom: 1rem;
}
.lv-pricing-cta p{
  color: rgba(255,255,255,.75);
  font-size: var(--fs-lg);
  max-width: 54ch;
  margin: 0 auto 1.75rem;
}
.lv-pricing-cta div div{
  display: flex;
  gap: .75rem;
  justify-content: center;
  flex-wrap: wrap;
}
.lv-pricing-cta .btn-ghost{
  color: #fff;
  border-color: rgba(255,255,255,.24);
}

/* ---------- 12. Case study card ---------- */
.case-grid{display: grid; grid-template-columns: repeat(auto-fit,minmax(320px,1fr)); gap: 1.25rem}
.case-card{
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  padding: 1.75rem;
  display: flex; flex-direction: column; gap: 1rem;
  transition: transform var(--t-base) var(--ease), box-shadow var(--t-base) var(--ease);
  position: relative;
  overflow: hidden;
}
.case-card:hover{transform: translateY(-3px); box-shadow: var(--sh-lg)}
.case-tags{display:flex; gap: .35rem; flex-wrap: wrap}
.case-tag{font-size: 11px; padding: .25rem .55rem; background: var(--bg-soft); border-radius: var(--r-full); color: var(--ink-3); font-weight: 500}
.case-card h3{font-size: var(--fs-xl); font-weight: 600}
.case-block{display: grid; grid-template-columns: 1fr; gap: .65rem; margin-top: .5rem; font-size: var(--fs-sm)}
.case-block .label{font-size: 11px; text-transform: uppercase; letter-spacing: .08em; color: var(--ink-5); font-weight: 500; margin-bottom: .15rem}
.case-block .value{color: var(--ink-2); line-height: 1.55}
.case-block .value.metric{font-family: var(--font-display); font-size: var(--fs-2xl); font-weight: 600; color: var(--ink)}
.case-result{
  padding: 1rem; margin-top: auto;
  background: linear-gradient(135deg, var(--accent-soft), rgba(37,99,235,.05));
  border-radius: var(--r-md);
  font-size: var(--fs-sm);
  display: flex; align-items: center; gap: .65rem;
}
.case-result .num{font-family: var(--font-display); font-size: var(--fs-2xl); font-weight: 600; color: var(--accent-ink); letter-spacing: -.02em; line-height: 1}
.case-result .lbl{color: var(--ink-2); font-weight: 500; line-height: 1.3}
.case-result .lbl small{display: block; color: var(--ink-4); font-weight: 400; font-size: 11px; margin-top: 2px}

/* ---------- 13. FAQ ---------- */
.faq{display: flex; flex-direction: column; gap: .65rem}
.faq details{
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  overflow: hidden;
  transition: border-color var(--t-base) var(--ease);
}
.faq details[open]{border-color: var(--line-3); box-shadow: var(--sh-sm)}
.faq summary{
  display: flex; align-items: center; justify-content: space-between; gap: 1rem;
  padding: 1rem 1.25rem;
  cursor: pointer;
  font-weight: 500;
  color: var(--ink);
  font-family: var(--font-display);
  font-size: var(--fs-lg);
  list-style: none;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content: "+";
  font-size: 1.5rem;
  color: var(--ink-4);
  font-weight: 400;
  transition: transform var(--t-base) var(--ease);
}
.faq details[open] summary::after{transform: rotate(45deg); color: var(--accent)}
.faq .answer{padding: 0 1.25rem 1.25rem; color: var(--ink-3); line-height: 1.65}

/* ---------- 14. Form ---------- */
.form{display: flex; flex-direction: column; gap: 1rem}
.form-row{display:grid; grid-template-columns: 1fr 1fr; gap: 1rem}
.field{display: flex; flex-direction: column; gap: .4rem}
.field label{font-size: var(--fs-sm); font-weight: 500; color: var(--ink-2)}
.field input, .field textarea, .field select{
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: .85rem 1rem;
  font-size: var(--fs-md);
  color: var(--ink);
  transition: border-color var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);
  width: 100%;
}
.field input:focus, .field textarea:focus, .field select:focus{
  outline: none; border-color: var(--accent-2);
  box-shadow: 0 0 0 4px rgba(37,99,235,.12);
}
.field textarea{resize: vertical; min-height: 110px}
.field-hint{font-size: var(--fs-xs); color: var(--ink-4)}

.form-bullets{
  background: var(--bg-soft);
  border-radius: var(--r-md);
  padding: 1rem 1.25rem;
  display: flex; flex-direction: column; gap: .55rem;
  margin-bottom: .5rem;
}
.form-bullets .b{display:flex; align-items: flex-start; gap: .55rem; font-size: var(--fs-sm); color: var(--ink-2)}
.form-bullets .b .n{
  font-family: var(--font-mono);
  font-size: 11px;
  background: var(--ink); color: #fff;
  width: 18px; height: 18px;
  border-radius: 50%;
  display: grid; place-items: center;
  flex-shrink: 0; margin-top: 1px;
  font-weight: 500;
}

/* ---------- Zero effort + audience proof ---------- */
.zero-effort{
  background:
    radial-gradient(720px 420px at 78% 20%, rgba(37,99,235,.10), transparent 68%),
    linear-gradient(180deg, #fff 0%, #f8fbff 100%);
}
.zero-card{
  border:1px solid rgba(219,234,254,.95);
  border-radius: var(--r-2xl);
  background: rgba(255,255,255,.78);
  box-shadow: 0 24px 80px rgba(15,23,42,.08);
  backdrop-filter: blur(18px);
  padding: clamp(1.5rem, 4vw, 2.5rem);
  display:grid;
  grid-template-columns: .9fr 1.35fr;
  gap: clamp(1.5rem, 4vw, 3rem);
  align-items:center;
}
.zero-copy h2{margin-block:.9rem .75rem}
.zero-copy p{font-size:var(--fs-lg); line-height:1.65}
.zero-steps{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:1rem;
}
.zero-steps article,
.audience-grid article,
.about-trust{
  border:1px solid rgba(219,234,254,.95);
  background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,251,255,.94));
  box-shadow:0 16px 46px rgba(15,23,42,.055);
}
.zero-steps article{
  border-radius: var(--r-lg);
  padding: 1.15rem;
}
.zero-steps span{
  width:34px;
  height:34px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:var(--accent-2);
  color:#fff;
  font-family:var(--font-mono);
  font-size:13px;
  margin-bottom:.85rem;
}
.zero-steps h3{font-size:var(--fs-xl); margin-bottom:.5rem}
.zero-steps p{font-size:var(--fs-sm); line-height:1.55}
.audience-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:1rem;
  margin-bottom:clamp(2rem,4vw,3rem);
}
.audience-grid article{
  border-radius:var(--r-xl);
  padding:1.25rem;
}
.audience-grid article span{
  display:inline-flex;
  padding:.35rem .62rem;
  border-radius:999px;
  background:var(--accent-soft);
  color:var(--accent-ink);
  font-size:var(--fs-xs);
  font-weight:600;
  margin-bottom:.85rem;
}
.audience-grid h3{font-size:var(--fs-xl); margin-bottom:.75rem}
.audience-grid p{font-size:var(--fs-sm); line-height:1.55; margin-top:.55rem}
.about-trust{
  border-radius:var(--r-2xl);
  padding:clamp(1.5rem,4vw,2.5rem);
  display:grid;
  grid-template-columns: .9fr 1.1fr;
  gap:clamp(1.5rem,4vw,3rem);
  align-items:center;
}
.about-trust h2{margin-top:.85rem}
.about-trust p{font-size:var(--fs-lg); line-height:1.7; margin-bottom:1.25rem}

/* ---------- 15. ROI calculator ---------- */
.roi{
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  padding: 2rem;
  display: grid; grid-template-columns: 1fr 1fr; gap: 2rem;
  align-items: center;
	  box-shadow: var(--sh-md);
	}
.roi-inputs{min-width:0}
.roi-inputs{display: flex; flex-direction: column; gap: 1.25rem}
.roi-field label{font-size: var(--fs-sm); color: var(--ink-2); font-weight: 500; margin-bottom: .35rem; display: block}
.roi-help{font-size:var(--fs-xs); color:var(--ink-4); margin:-.15rem 0 .55rem; line-height:1.45}
.roi-field input[type=range]{
  -webkit-appearance: none; appearance: none;
  width: 100%; height: 6px;
  background: var(--bg-soft);
  border-radius: 3px;
	  outline: none;
	  accent-color: var(--accent-2);
	}
.roi-field input[type=range]::-webkit-slider-thumb{
  -webkit-appearance: none; appearance: none;
  width: 22px; height: 22px;
  border-radius: 50%;
  background: var(--accent-2);
  cursor: pointer;
  border: 3px solid #fff;
  box-shadow: var(--sh-md);
  transition: transform var(--t-fast) var(--ease);
}
.roi-field input[type=range]::-webkit-slider-thumb:hover{transform: scale(1.1)}
.roi-field input[type=range]::-moz-range-thumb{
  width: 22px; height: 22px;
  border-radius: 50%;
  background: var(--accent-2);
  cursor: pointer;
  border: 3px solid #fff;
}
.roi-value{display:flex; justify-content: space-between; align-items: center; margin-top: .25rem}
.roi-value .v{font-family: var(--font-display); font-size: var(--fs-xl); font-weight: 600; color: var(--ink)}
.roi-value .u{font-size: var(--fs-xs); color: var(--ink-4); font-family: var(--font-mono)}

.roi-output{
  background: linear-gradient(135deg, var(--ink), #1E293B);
  color: #fff;
  border-radius: var(--r-lg);
  padding: 1.75rem;
  display: flex; flex-direction: column; gap: 1.25rem;
  position: relative;
	  overflow: hidden;
	}
.roi-output .btn{white-space:normal; text-align:center}
.roi-output::before{
  content:""; position: absolute; inset: -50%;
  background: radial-gradient(circle, rgba(37,99,235,.25), transparent 50%);
  pointer-events: none;
}
.roi-output > *{position: relative; z-index: 1}
.roi-out-label{font-size: var(--fs-sm); color: rgba(255,255,255,.7); font-weight: 500}
.roi-out-value{font-family: var(--font-display); font-size: 2.4rem; font-weight: 600; line-height: 1; letter-spacing: -.03em}
.roi-out-value .cur{font-size: 1.2rem; color: rgba(255,255,255,.7); font-weight: 500}
.roi-out-line{height:1px; background: rgba(255,255,255,.12)}

/* ---------- 16. Sector picker ---------- */
.sector-tabs{
  display: flex; gap: .35rem;
  background: var(--bg-soft);
  padding: .35rem;
  border-radius: var(--r-full);
  width: fit-content;
  flex-wrap: wrap;
}
.sector-tab{
  padding: .55rem 1.1rem;
  border-radius: var(--r-full);
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--ink-3);
  transition: background var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
  display: flex; align-items: center; gap: .4rem;
}
.sector-tab:hover{color: var(--ink)}
.sector-tab.active{background: var(--bg-elev); color: var(--ink); box-shadow: var(--sh-sm)}

.sector-panel{
  margin-top: 2rem;
  display: grid; grid-template-columns: 1.1fr 1fr; gap: 2.5rem;
  align-items: center;
}
.sector-content[hidden]{display: none !important}
.sector-modules{display: grid; grid-template-columns: repeat(2,1fr); gap: .75rem; margin-top: 1.25rem}
.sector-mod{
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: .9rem 1rem;
  display: flex; align-items: center; gap: .7rem;
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--ink-2);
}
.sector-mod .ic{width: 30px; height: 30px; background: var(--accent-soft); color: var(--accent); border-radius: 8px; display: grid; place-items: center; flex-shrink: 0}
.sector-mod .ic svg{width: 14px; height: 14px}

.sector-visual{
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  padding: 1.5rem;
  min-height: 320px;
  box-shadow: var(--sh-md);
  position: relative;
  overflow: hidden;
}

/* ---------- 17. Logo cloud / Trust strip ---------- */
.trust-strip{
  display:flex;
  align-items:center;
  padding-block: 2rem;
  border-block: 1px solid var(--line);
  opacity: .85;
  overflow:hidden;
  mask-image:linear-gradient(90deg, transparent, #000 10%, #000 90%, transparent);
}
.trust-track{
  display:flex;
  align-items:center;
  gap:2.5rem;
  width:max-content;
  min-width:200%;
  animation:trustSlide 42s linear infinite;
}
.trust-label{
  min-width:max-content;
  font-size:var(--fs-xs);
  color:var(--ink-5);
  letter-spacing:.1em;
  text-transform:uppercase;
  font-weight:500;
}
.trust-strip .logo{
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--fs-lg);
  color: var(--ink-4);
  letter-spacing: -.02em;
  display: flex; align-items: center; gap: .35rem;
  transition: color var(--t-base) var(--ease);
  min-width:max-content;
}
.trust-strip .logo:hover{color: var(--ink-2)}
.trust-strip .logo .b{font-size: 8px; padding: .15rem .4rem; background: var(--bg-soft); border-radius: 3px; color: var(--ink-5); letter-spacing: .05em; text-transform: uppercase; font-family: var(--font-mono); font-weight: 500}
@keyframes trustSlide{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* ---------- 18. Floating CTA + Sticky mobile bar ---------- */
.float-wa{
  position: fixed; bottom: 1.25rem; right: 1.25rem; z-index: 30;
  width: 56px; height: 56px;
  background: #25D366;
  color: #fff;
  border-radius: 50%;
  display: grid; place-items: center;
  box-shadow: 0 8px 24px rgba(37,211,102,.4);
  transition: transform var(--t-base) var(--ease-spring);
}
.float-wa:hover{transform: scale(1.08)}
.float-wa svg{width: 28px; height: 28px}

.sticky-mobile{
  position: fixed; bottom: 0; left: 0; right: 0;
  background: var(--bg-elev);
  border-top: 1px solid var(--line);
  padding: .75rem 1rem;
  display: none;
  z-index: 30;
  box-shadow: 0 -4px 16px rgba(15,23,42,.06);
}
.sticky-mobile .btn{flex: 1; justify-content: center}

/* ---------- 19. Footer ---------- */
.site-footer{
  background: var(--ink);
  color: rgba(255,255,255,.7);
  padding-block: clamp(3rem,5vw,4rem) 1.5rem;
  margin-top: clamp(3rem,5vw,4rem);
}
.site-footer h5{color: #fff; font-size: var(--fs-sm); margin-bottom: 1rem; font-weight: 500; letter-spacing: .03em; text-transform: uppercase; font-family: var(--font-body)}
.footer-grid{
  display: grid;
  grid-template-columns: 1.4fr repeat(4, 1fr);
  gap: 2.5rem 2rem;
  margin-bottom: 3rem;
}
.footer-grid a{display: block; padding-block: .35rem; color: rgba(255,255,255,.65); font-size: var(--fs-sm); transition: color var(--t-fast) var(--ease)}
.footer-grid a:hover{color: #fff}
.footer-brand{display:flex; flex-direction: column; gap: 1rem}
.footer-brand .brand{color: #fff}
.footer-brand p{color: rgba(255,255,255,.65); font-size: var(--fs-sm); max-width: 32ch; line-height: 1.6}
.footer-contact{display: flex; flex-direction: column; gap: .75rem; margin-top: .5rem}
.footer-contact a{
  display: inline-flex; align-items: center; gap: .55rem;
  padding: .55rem .85rem;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--r-md);
  width: fit-content;
  color: #fff;
}
.footer-contact a:hover{background: rgba(255,255,255,.1)}
.footer-contact svg{width: 16px; height: 16px}
.footer-bottom{
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 1.5rem;
  border-top: 1px solid rgba(255,255,255,.08);
  font-size: var(--fs-xs);
  color: rgba(255,255,255,.5);
  flex-wrap: wrap; gap: 1rem;
}
.footer-legal{display:flex; flex-direction: column; gap: .35rem; font-size: 11px; color: rgba(255,255,255,.5); line-height: 1.6}
.footer-legal strong{color: rgba(255,255,255,.7); font-weight: 500}

/* ---------- 20. Page hero (sub pages) ---------- */
.page-hero{
  position:relative;
  overflow:hidden;
  padding-block: clamp(3rem, 6vw, 5rem) clamp(2rem, 4vw, 3rem);
  border-bottom: 1px solid var(--line);
  background:
    radial-gradient(820px 440px at 85% 0%, rgba(37,99,235,.13), transparent 60%),
    radial-gradient(520px 320px at 10% 35%, rgba(56,189,248,.10), transparent 64%),
    var(--bg);
}
.page-hero::before{
  content:"";
  position:absolute;
  right:-140px;
  top:-180px;
  width:520px;
  height:520px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(37,99,235,.24), rgba(56,189,248,.12), transparent 70%);
  filter:blur(44px);
  animation:pageAura 7s ease-in-out infinite;
  pointer-events:none;
}
.page-hero::after{
  content:"";
  position:absolute;
  inset:0;
  opacity:.28;
  background-image:
    linear-gradient(rgba(15,23,42,.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(15,23,42,.045) 1px, transparent 1px);
  background-size:42px 42px;
  mask-image:linear-gradient(180deg, #000, transparent 76%);
  pointer-events:none;
}
.page-hero > .container{position:relative; z-index:1}
.page-hero .eyebrow,
.page-hero .crumbs,
.page-hero h1,
.page-hero p.lead{
  animation:pageHeroIn .65s var(--ease) both;
}
.page-hero .eyebrow{animation-delay:.05s}
.page-hero h1{animation-delay:.12s}
.page-hero p.lead{animation-delay:.18s}
@keyframes pageAura{
  0%,100%{scale:1; opacity:.75}
  50%{scale:1.1; opacity:1}
}
@keyframes pageHeroIn{
  from{opacity:0; transform:translateY(18px); filter:blur(8px)}
  to{opacity:1; transform:none; filter:blur(0)}
}
.page-hero .crumbs{display: flex; gap: .5rem; font-size: var(--fs-sm); color: var(--ink-4); margin-bottom: 1.25rem}
.page-hero .crumbs a{color: var(--ink-4); transition: color var(--t-fast) var(--ease)}
.page-hero .crumbs a:hover{color: var(--ink-2)}
.page-hero h1{font-size: var(--fs-5xl); margin-bottom: 1rem; max-width: 18ch}
.page-hero p.lead{max-width: 60ch; margin-bottom: 1.5rem}

/* ---------- 21. Toast ---------- */
.toast{
  position: fixed; bottom: 6rem; right: 1.25rem; z-index: 50;
  background: var(--ink); color: #fff;
  padding: .85rem 1.25rem;
  border-radius: var(--r-md);
  font-size: var(--fs-sm);
  font-weight: 500;
  box-shadow: var(--sh-xl);
  transform: translateY(80px); opacity: 0;
  transition: transform var(--t-base) var(--ease), opacity var(--t-base) var(--ease);
  pointer-events: none;
}
.toast.show{transform: translateY(0); opacity: 1}

/* ---------- 22. Generic content (blog/article) ---------- */
.prose{max-width: 70ch; margin-inline: auto}
.prose h2{margin-block: 2.5rem 1rem; font-size: var(--fs-3xl)}
.prose h3{margin-block: 2rem .85rem; font-size: var(--fs-2xl)}
.prose p{margin-block: 1rem; line-height: 1.7; color: var(--ink-2)}
.prose ul, .prose ol{margin: 1.25rem 0 1.25rem 1.25rem; padding-left: 1rem}
.prose ul li{list-style: disc} .prose ol li{list-style: decimal}
.prose li{margin-block: .5rem}

/* ---------- 23. Animations (reveal on scroll) ---------- */
.reveal{opacity: 0; transform: translateY(20px); transition: opacity .7s var(--ease), transform .7s var(--ease)}
.reveal.in{opacity: 1; transform: none}

/* ---------- 24. Responsive ---------- */
@media (max-width: 980px){
  .hero-inner{grid-template-columns: 1fr; gap: 2.5rem}
  .os-float.f1{right: 1rem; top: -10px}
  .os-float.f2{left: 1rem}
  .bento{grid-template-columns: repeat(4,1fr)}
  .b-lg{grid-column: span 4}
  .b-md{grid-column: span 2}
  .b-sm{grid-column: span 2}
  .b-w{grid-column: span 4}
  .pricing{grid-template-columns: 1fr; max-width: 460px; margin-inline: auto}
  .price-card.featured{transform: none}
  .lv-price-tabs{
    display: flex;
    overflow-x: auto;
    overscroll-behavior-inline: contain;
    scroll-snap-type: x proximity;
    padding: .1rem .15rem .75rem;
    margin-inline: calc(var(--container-pad) * -1);
    padding-inline: var(--container-pad);
  }
  .lv-price-tabs::-webkit-scrollbar{height: 6px}
  .lv-price-tabs::-webkit-scrollbar-thumb{background: rgba(148,163,184,.38); border-radius: var(--r-full)}
  .lv-price-tab{
    flex: 0 0 178px;
    min-height: 122px;
    scroll-snap-align: start;
  }
  .lv-price-panel-head{grid-template-columns: 1fr}
  .lv-price-panel-head h2{max-width: none}
  .lv-price-grid{grid-template-columns: repeat(2, minmax(0, 1fr))}
  .roi{grid-template-columns: 1fr; padding: 1.5rem}
  .sector-panel{grid-template-columns: 1fr; gap: 1.5rem}
  .footer-grid{grid-template-columns: 1fr 1fr; gap: 2rem 1.5rem}
  .compare-row{grid-template-columns: 1.2fr 1fr 1fr 1.1fr; font-size: var(--fs-xs)}
  .compare-row > div{padding: .75rem .85rem}
}
@media (max-width: 720px){
  .nav-links{display: none}
  .nav-cta .cta-desktop{display: none}
  .menu-toggle{display: inline-flex}
  body.has-sticky-cta{padding-bottom: 76px}
  .sticky-mobile{display: flex; gap: .5rem}
  h1{font-size: var(--fs-5xl)}
  h2{font-size: var(--fs-4xl)}
  .hero-trust{gap: 1rem 1.5rem}
  .hero-trust .v{display: none}
  .bento{grid-template-columns: repeat(2,1fr)}
  .b-lg, .b-md, .b-sm, .b-w{grid-column: span 2}
  .compare-row{grid-template-columns: 1fr 1fr; row-gap: 0}
  .compare-row > div:nth-child(2){display: none}
  .compare-row > div:nth-child(3){display: none}
  .compare-row.head > div:nth-child(2),
  .compare-row.head > div:nth-child(3){display: none}
  .lv-price-grid{grid-template-columns: 1fr}
  .lv-price-panel{padding: 1rem}
  .lv-package-card{padding: 1.15rem}
  .lv-price-note{flex-direction: column; gap: .25rem}
  .lv-pricing-cta .btn{width: 100%}
  .form-row{grid-template-columns: 1fr}
  .footer-grid{grid-template-columns: 1fr; gap: 2rem}
  .footer-bottom{flex-direction: column; align-items: flex-start}
  .os-float{display: none}
  .float-wa{bottom: 5rem}
  .case-result{flex-direction: column; align-items: flex-start}
}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration: 0s !important; transition-duration: 0s !important}
}

/* Print */
@media print{
  .site-header,.site-footer,.float-wa,.sticky-mobile{display:none}
  body{background: #fff}
}

/* ============================================================
   HERO V2 — Floating bubbles · Centered nav (Supsis tarzı)
   ============================================================ */

/* ---------- Centered Logo Nav ---------- */
.nav.nav-center{
  display: grid;
  grid-template-columns: minmax(0, 1.12fr) auto minmax(0, 1.12fr);
  column-gap: clamp(1.95rem, 4vw, 3.25rem);
}
.nav.nav-center .nav-left{
  display: flex; align-items: center; gap: clamp(.85rem, 1.5vw, 1.35rem);
  justify-self: end;
  font-size: var(--fs-sm);
}
.nav.nav-center .nav-left a,
.nav.nav-center .nav-left button{
  color: var(--ink-2); font-weight: 500;
  padding: .4rem 0;
  transition: color var(--t-fast) var(--ease);
}
.nav.nav-center .nav-left a:hover,
.nav.nav-center .nav-left button:hover{ color: var(--ink) }
.nav.nav-center .brand{
  justify-self: center;
  gap: .7rem;
}
.brand .logo-img{
  height: 36px; width: auto; display: block;
}
.nav.nav-center .nav-right{
  display: flex; align-items: center; gap: 1.22rem;
  justify-self: start;
}

/* ---------- Hero Splash ---------- */
.hero-splash{
  position: relative;
  overflow: hidden;
  padding-block: 0;
  min-height: 92vh;
  display: flex; flex-direction: column; align-items: center; justify-content: flex-end;
  --mx: 0;
  --my: 0;
  background: var(--bg);
  background-image:
    radial-gradient(900px 700px at 50% 30%, rgba(37,99,235,.08), transparent 65%),
    radial-gradient(500px 400px at 0% 60%, rgba(56,189,248,.07), transparent 60%),
    radial-gradient(600px 500px at 100% 10%, rgba(37,99,235,.06), transparent 60%);
}

.hero-orbits{
  position:absolute;
  inset: 9% -9% 21%;
  z-index: 0;
  pointer-events: none;
  transform: translate3d(calc(var(--mx) * 10px), calc(var(--my) * 10px), 0);
  transition: transform 260ms var(--ease);
}
.hero-orbits::before{
  content:"";
  position:absolute;
  left:50%;
  top:45%;
  width:min(900px, 92vw);
  height:min(520px, 56vw);
  transform:translate(-50%, -50%);
  border-radius:50%;
  background:
    radial-gradient(circle at 50% 50%, rgba(37,99,235,.13), transparent 34%),
    radial-gradient(circle at 42% 36%, rgba(56,189,248,.16), transparent 28%);
  filter: blur(20px);
  opacity:.8;
}
.orbit{
  position:absolute;
  left:50%;
  top:45%;
  border:1px solid rgba(37,99,235,.16);
  border-radius:50%;
  transform:translate(-50%, -50%) rotate(var(--tilt, 0deg));
  box-shadow: inset 0 0 28px rgba(37,99,235,.035);
  animation: orbitSpin var(--speed, 24s) linear infinite;
}
.orbit::before{
  content:"";
  position:absolute;
  inset:-1px;
  border-radius:inherit;
  border:1px dashed rgba(56,189,248,.18);
  opacity:.55;
}
.orbit-a{
  width:min(900px, 98vw);
  height:min(250px, 28vw);
  --tilt: -10deg;
  --speed: 34s;
}
.orbit-b{
  width:min(670px, 74vw);
  height:min(470px, 52vw);
  --tilt: 18deg;
  --speed: 46s;
  animation-direction: reverse;
  opacity:.9;
}
.orbit-c{
  width:min(1220px, 130vw);
  height:min(330px, 36vw);
  --tilt: 12deg;
  --speed: 58s;
  opacity:.68;
}
.hero-splash:hover .orbit-a{animation-duration: 22s}
.hero-splash:hover .orbit-b{animation-duration: 30s}
.hero-splash:hover .orbit-c{animation-duration: 40s}
.orb{
  position:absolute;
  width:12px;
  height:12px;
  border-radius:50%;
  background:#38BDF8;
  box-shadow: 0 0 0 6px rgba(56,189,248,.12), 0 0 24px rgba(37,99,235,.34);
}
.orb::after{
  content:"";
  position:absolute;
  inset:-11px;
  border-radius:50%;
  background: radial-gradient(circle, rgba(56,189,248,.18), transparent 65%);
}
.orb.n1{left:10%; top:47%}
.orb.n2{right:18%; top:11%; width:9px; height:9px; background:#2563EB}
.orb.n3{right:8%; bottom:23%; width:10px; height:10px}
.orb.n4{left:50%; top:-5px; width:11px; height:11px; background:#60A5FA}
.orb.n5{left:6%; top:62%; width:8px; height:8px; background:#93C5FD}
.orb.n6{right:13%; bottom:8%; width:10px; height:10px}
.orb.n7{left:23%; bottom:10%; width:9px; height:9px; background:#2563EB}
.orb.n8{right:29%; top:7%; width:8px; height:8px; background:#7DD3FC}
.orbit-line{
  position:absolute;
  left:50%;
  top:45%;
  height:1px;
  width:min(760px, 82vw);
  transform-origin:center;
  background: linear-gradient(90deg, transparent, rgba(37,99,235,.18), rgba(56,189,248,.22), transparent);
  opacity:.62;
}
.orbit-line.l1{transform:translate(-50%, -50%) rotate(-18deg)}
.orbit-line.l2{transform:translate(-50%, -50%) rotate(24deg); width:min(610px, 70vw); opacity:.42}
@keyframes orbitSpin{
  from{transform:translate(-50%, -50%) rotate(var(--tilt, 0deg))}
  to{transform:translate(-50%, -50%) rotate(calc(var(--tilt, 0deg) + 360deg))}
}

/* Hub center -- logo / brand element */
.hero-hub{
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -52%);
  display: flex; flex-direction: column; align-items: center; gap: 1.25rem;
  pointer-events: none;
  user-select: none;
  z-index: 1;
}
.hero-hub .hub-ring{
  position:relative;
  width: 140px; height: 140px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(37,99,235,.12), rgba(37,99,235,.04) 60%, transparent);
  border: 1px solid rgba(37,99,235,.15);
  display: grid; place-items: center;
  animation: hubPulse 3s ease-in-out infinite;
}
.hero-hub .hub-ring::before{
  content:"";
  position: absolute;
  width: 200px; height: 200px;
  border-radius: 50%;
  border: 1px dashed rgba(37,99,235,.1);
  animation: ringRotate 20s linear infinite;
}
.hero-hub .hub-ring::after{
  content:"";
  position: absolute;
  width: 280px; height: 280px;
  border-radius: 50%;
  border: 1px solid rgba(37,99,235,.06);
}
.hero-hub .hub-logo{
  height: 56px; width: auto;
  filter: drop-shadow(0 0 18px rgba(37,99,235,.3));
}
@keyframes hubPulse{
  0%,100%{box-shadow: 0 0 0 0 rgba(37,99,235,.12), 0 0 32px rgba(37,99,235,.08)}
  50%{box-shadow: 0 0 0 14px rgba(37,99,235,.04), 0 0 48px rgba(37,99,235,.12)}
}
@keyframes ringRotate{
  from{transform: rotate(0deg)}
  to{transform: rotate(360deg)}
}

/* Feature icon cards around hub */
.hero-feat{
  position: absolute;
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: .8rem 1rem;
  box-shadow: var(--sh-md);
  display: flex; align-items: center; gap: .65rem;
  white-space: nowrap;
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--ink-2);
  z-index: 2;
  animation: featureDrift var(--dur, 5s) ease-in-out infinite;
  animation-delay: var(--delay, 0s);
}
.hero-feat .fi{
  width: 36px; height: 36px; border-radius: 9px;
  display: grid; place-items: center; flex-shrink: 0;
}
.hero-feat .fi svg{ width: 18px; height: 18px }
.hero-feat.f-wa{ top: 28%; left: 8%; --dur: 6s; --delay: 0s }
.hero-feat.f-ig{ top: 29%; right: 9%; --dur: 5.5s; --delay: .8s }
.hero-feat.f-cal{ bottom: 40%; left: 6%; --dur: 7s; --delay: 1.6s }
.hero-feat.f-crm{ bottom: 32%; right: 7%; --dur: 5s; --delay: 2.4s }
@keyframes featureDrift{
  0%,100%{ transform: translateY(0) }
  50%{ transform: translateY(-8px) }
}

/* Floating chat bubbles */
.bubble{
  position: absolute;
  z-index: 3;
  display: flex; align-items: flex-end; gap: .45rem;
  animation: bubbleFly var(--dur, 5s) ease-in-out infinite;
  animation-delay: var(--delay, 0s);
}
.bubble .b-msg{
  padding: .55rem .9rem;
  border-radius: 18px 18px 18px 4px;
  font-size: 13px;
  font-weight: 500;
  max-width: 220px;
  line-height: 1.4;
  box-shadow: var(--sh-md);
  display: flex; align-items: center; gap: .45rem;
}
.bubble .b-msg.incoming{
  background: var(--bg-elev);
  color: var(--ink);
  border-radius: 18px 18px 18px 4px;
}
.bubble .b-msg.bot{
  background: var(--accent);
  color: #fff;
  border-radius: 18px 18px 4px 18px;
}
.bubble .b-av{
  width: 28px; height: 28px; border-radius: 50%;
  background: linear-gradient(135deg, #F472B6, #BE185D);
  display: grid; place-items: center;
  font-size: 11px; color: #fff; font-weight: 600;
  flex-shrink: 0;
}
.bubble .b-av.wa{ background: #25D366 }
.bubble .b-av.ig{ background: linear-gradient(135deg,#F58529,#DD2A7B) }
.bubble .b-av.web{ background: var(--accent-2) }
.bubble .ch-dot{
  width: 16px; height: 16px; border-radius: 50%;
  display: grid; place-items: center; flex-shrink: 0;
}
.bubble .ch-dot.wa-d{ background: #25D366 }
.bubble .ch-dot.ig-d{ background: linear-gradient(135deg,#F58529,#DD2A7B) }
.bubble .b-time{ font-size: 10px; color: var(--ink-5); margin-bottom: 2px }

.bubble.b1{ top: 15%; left: 4%; --dur: 6.5s; --delay: 0s }
.bubble.b2{ top: 12%; right: 5%; --dur: 5.8s; --delay: 1.2s }
.bubble.b3{ top: 42%; left: 3%; --dur: 7s; --delay: 2.4s }
.bubble.b4{ top: 38%; right: 4%; --dur: 6s; --delay: .6s }
.bubble.b5{ bottom: 26%; left: 8%; --dur: 5.5s; --delay: 3s }

@keyframes bubbleFly{
  0%,100%{ transform: translateY(0) }
  50%{ transform: translateY(-10px) }
}

/* Hero bottom content */
.hero-bottom{
  position: relative; z-index: 5;
  width: 100%;
  text-align: center;
  padding: 0 1.5rem 3.5rem;
  background: linear-gradient(to bottom, transparent 0%, var(--bg) 28%);
}
.hero-bottom h1{
  position: relative;
  z-index: 0;
  font-size: var(--fs-6xl);
  letter-spacing: -.04em;
  max-width: 18ch;
  margin: 0 auto .75rem;
  line-height: 1;
}
.hero-bottom h1::before{
  content:"";
  position:absolute;
  z-index:-1;
  left:50%;
  top:48%;
  width:min(1170px, 138vw);
  height:clamp(195px, 27vw, 345px);
  transform:translate(-50%, -50%);
  border-radius:999px;
  background:
    radial-gradient(ellipse at center, rgba(56,189,248,.34) 0%, rgba(96,165,250,.22) 36%, rgba(147,197,253,.10) 62%, transparent 78%);
  filter: blur(24px);
  opacity:.96;
  pointer-events:none;
}
.hero-bottom h1 .grad{
  background: linear-gradient(120deg, var(--accent) 0%, var(--accent-2) 50%, var(--accent) 100%);
  background-size: 200% 100%;
  -webkit-background-clip: text; background-clip: text; color: transparent;
  font-style: italic; font-weight: 500;
  animation: gradShift 8s linear infinite;
  padding-right: 0.2em;
}
.hero-bottom .lead{
  font-size: var(--fs-lg);
  color: var(--ink-3);
  max-width: 58ch;
  margin: 0 auto 1.75rem;
}
.hero-bottom .hero-actions{ justify-content: center }
.hero-bottom .hero-trust{
  justify-content: center;
  margin-top: 2rem;
}

/* Responsive splash */
@media(max-width: 980px){
  .hero-splash{ min-height: auto; padding-block: 5rem 0 }
  .hero-hub{ position: relative; top:auto; left:auto; transform:none; margin-bottom: 2rem }
  .hero-splash{ flex-direction: column; justify-content: flex-start; gap: 0 }
	  .hero-feat, .bubble{ display: none }
	  .zero-card,.about-trust{grid-template-columns:1fr}
	  .zero-steps,.audience-grid{grid-template-columns:1fr 1fr}
	}
	@media(max-width: 720px){
  .nav.nav-center{ grid-template-columns: 1fr auto; }
  .nav.nav-center .nav-left{ display: none }
  .nav.nav-center .brand{ justify-self: start }
  .nav.nav-center .nav-right{ justify-self: end }
  .nav.nav-center .nav-right .nav-link{ display: none }
  .nav.nav-center .nav-right .cta-desktop{ display: none }
  .hero-bottom h1{ font-size: var(--fs-5xl) }
  .hero-orbits{inset: 8% -18% 30%; opacity:.55}
  .orbit-a{width: 92vw; height: 42vw}
  .orbit-b{width: 72vw; height: 72vw}
	  .orbit-c,.orbit-line{display:none}
	  .zero-card,.about-trust{border-radius:24px}
	  .zero-steps,.audience-grid{grid-template-columns:1fr}
	  .roi{grid-template-columns:1fr; padding:1.25rem}
	  .roi-output{padding:1.25rem}
	  .roi-out-value{font-size:2rem}
	}

/* ============================================================
   HERO V3 — Lavio motion system
   ============================================================ */
.hero-splash{
  background-image:
    radial-gradient(900px 700px at 50% 30%, rgba(37,99,235,.12), transparent 65%),
    radial-gradient(520px 420px at 0% 60%, rgba(56,189,248,.10), transparent 60%),
    radial-gradient(640px 520px at 100% 10%, rgba(37,99,235,.08), transparent 60%);
}
.hero-aurora{
  position:absolute;
  inset:0;
  z-index:0;
  pointer-events:none;
  overflow:hidden;
}
.hero-aurora .aura{
  position:absolute;
  border-radius:999px;
  filter: blur(92px);
  opacity:.72;
  transform: translate3d(0,0,0);
  animation: auraBreathe var(--aura-dur, 8s) ease-in-out infinite;
}
.hero-aurora .a1{
  width:min(980px, 92vw);
  height:min(620px, 58vw);
  left:50%;
  top:42%;
  translate:-50% -50%;
  background: radial-gradient(ellipse, rgba(37,99,235,.34), rgba(56,189,248,.24) 45%, transparent 76%);
  --aura-dur: 7.4s;
}
.hero-aurora .a2{
  width:520px;
  height:420px;
  right:-130px;
  top:15%;
  background: radial-gradient(circle, rgba(56,189,248,.28), rgba(37,99,235,.12), transparent 70%);
  --aura-dur: 9s;
  animation-delay: -2s;
}
.hero-aurora .a3{
  width:560px;
  height:470px;
  left:-180px;
  bottom:18%;
  background: radial-gradient(circle, rgba(37,99,235,.30), rgba(125,211,252,.14), transparent 72%);
  --aura-dur: 10s;
  animation-delay: -4s;
}
.hero-aurora .mesh{
  position:absolute;
  inset:0;
  opacity:.35;
  background-image:
    linear-gradient(rgba(15,23,42,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(15,23,42,.05) 1px, transparent 1px);
  background-size: 46px 46px;
  mask-image: radial-gradient(ellipse at 50% 43%, #000 0%, transparent 70%);
}
@keyframes auraBreathe{
  0%,100%{scale:1; opacity:.54}
  50%{scale:1.12; opacity:.86}
}

.hero-orbits{z-index:1}
.hero-orbits::before{
  background:
    radial-gradient(circle at 50% 50%, rgba(37,99,235,.17), transparent 34%),
    radial-gradient(circle at 42% 36%, rgba(56,189,248,.16), transparent 30%);
  filter: blur(24px);
  opacity:.88;
}
.orbit{border-color:rgba(37,99,235,.18); box-shadow: inset 0 0 34px rgba(37,99,235,.045)}
.orbit::before{border-color:rgba(56,189,248,.20)}
.orb{background:#2563EB; box-shadow:0 0 0 6px rgba(37,99,235,.13), 0 0 24px rgba(37,99,235,.35)}
.orb::after{background:radial-gradient(circle, rgba(56,189,248,.20), transparent 65%)}
.orb.n2{background:#38BDF8}
.orb.n4{background:#22D3EE}
.orb.n5{background:#60A5FA}
.orb.n8{background:#93C5FD}
.orbit-line{background:linear-gradient(90deg, transparent, rgba(37,99,235,.18), rgba(56,189,248,.24), transparent)}

.hero-hub{
  z-index:4;
  animation: hubIntro .8s var(--ease) both;
}
.hero-hub .hub-ring{
  width:168px;
  height:168px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.88), rgba(255,255,255,.62)),
    radial-gradient(circle, rgba(37,99,235,.18), rgba(56,189,248,.08) 62%, transparent);
  border-color:rgba(37,99,235,.18);
  box-shadow:0 28px 80px rgba(15,23,42,.14), inset 0 1px 0 rgba(255,255,255,.9);
  backdrop-filter:blur(18px);
}
.hero-hub .hub-ring::before{width:232px; height:232px; border-color:rgba(37,99,235,.16)}
.hero-hub .hub-ring::after{width:330px; height:330px; border-color:rgba(56,189,248,.14)}
.hero-hub .hub-logo{height:78px; filter:drop-shadow(0 14px 28px rgba(15,23,42,.14))}
.hub-status{
  display:flex;
  align-items:center;
  gap:.45rem;
  padding:.5rem .72rem;
  border:1px solid rgba(15,23,42,.08);
  border-radius:999px;
  background:rgba(255,255,255,.78);
  box-shadow:0 12px 36px rgba(15,23,42,.08);
  backdrop-filter:blur(16px);
  color:var(--ink-3);
  font-size:11px;
  line-height:1;
}
.hub-status strong{font-family:var(--font-mono); color:var(--ink); font-size:11px}
.hub-status small{color:var(--ink-4)}
.live-dot{
  width:7px;
  height:7px;
  border-radius:50%;
  background:#10B981;
  box-shadow:0 0 0 5px rgba(16,185,129,.13);
  animation:liveBlink 1.4s ease-in-out infinite;
}
@keyframes hubIntro{
  from{opacity:0; transform:translate(-50%, -45%) scale(.86); filter:blur(10px)}
  to{opacity:1; transform:translate(-50%, -52%) scale(1); filter:blur(0)}
}
@keyframes liveBlink{
  0%,100%{opacity:1; scale:1}
  50%{opacity:.55; scale:.76}
}

.hero-tag{
  position:absolute;
  z-index:3;
  display:flex;
  align-items:center;
  gap:.48rem;
  padding:.56rem .68rem;
  border-radius:16px;
  border:1px solid rgba(15,23,42,.08);
  background:rgba(255,255,255,.76);
  box-shadow:0 16px 44px rgba(15,23,42,.10);
  backdrop-filter:blur(14px);
  color:var(--ink-2);
  font-size:12px;
  font-weight:600;
  animation:tagFloat var(--dur, 4.4s) ease-in-out infinite;
  animation-delay:var(--delay, 0s);
}
.hero-tag img{width:34px; height:34px; object-fit:contain}
.hero-tag.tag-auto{left:27%; top:24%; --dur:5.2s; --delay:.1s}
.hero-tag.tag-ai{right:27%; top:24%; --dur:4.8s; --delay:.35s}
.hero-tag.tag-n8n{left:24%; top:45%; --dur:5.8s; --delay:.7s}
.hero-tag.tag-panel{right:24%; top:45%; --dur:5.1s; --delay:1s}
@keyframes tagFloat{
  0%,100%{transform:translateY(0) scale(1)}
  50%{transform:translateY(-9px) scale(1.02)}
}

.hero-feat{
  background:rgba(255,255,255,.82);
  backdrop-filter:blur(14px);
}
.bubble{
  opacity:0;
  animation-name:bubbleIntro, bubbleFly;
  animation-duration:.75s, var(--dur, 5s);
  animation-timing-function:var(--ease), ease-in-out;
  animation-delay:var(--intro, .2s), calc(var(--intro, .2s) + .75s + var(--delay, 0s));
  animation-fill-mode:forwards, none;
  animation-iteration-count:1, infinite;
}
.bubble .b-av.ai{background:linear-gradient(135deg,#14B8A6,#2563EB)}
.bubble .ch-dot.ai-d{background:linear-gradient(135deg,#14B8A6,#2563EB)}
.bubble.b1{--delay:.1s; --intro:.05s}
.bubble.b2{--delay:.3s; --intro:.12s}
.bubble.b3{--delay:.5s; --intro:.18s}
.bubble.b4{--delay:.7s; --intro:.24s}
.bubble.b5{--delay:.9s; --intro:.3s}
.bubble.b6{bottom:23%; right:8%; --dur:6.4s; --delay:1.1s; --intro:.36s}
@keyframes bubbleIntro{
  from{opacity:0; transform:translateY(18px) scale(.72); filter:blur(8px)}
  to{opacity:1; transform:translateY(0) scale(1); filter:blur(0)}
}

.hero-bottom{z-index:6}

/* ---------- Channel orbit showcase ---------- */
.channel-showcase{
  position:relative;
  overflow:hidden;
  padding-top:clamp(4rem, 8vw, 7rem);
}
.channel-showcase::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(720px 460px at 78% 45%, rgba(37,99,235,.13), transparent 70%),
    radial-gradient(520px 360px at 15% 45%, rgba(56,189,248,.12), transparent 68%);
}
.channel-grid{
  position:relative;
  display:grid;
  grid-template-columns:minmax(0,.9fr) minmax(320px,1.1fr);
  align-items:center;
  gap:clamp(2rem, 6vw, 5rem);
}
.channel-grid .section-head{text-align:left; margin:0}
.channel-orbit{
  position:relative;
  min-height:540px;
  border-radius:40px;
  overflow:hidden;
  background:
    linear-gradient(180deg, rgba(255,255,255,.84), rgba(248,250,252,.66)),
    radial-gradient(circle at 50% 50%, rgba(37,99,235,.10), transparent 52%);
  border:1px solid rgba(15,23,42,.07);
  box-shadow:0 28px 90px rgba(15,23,42,.08);
  isolation:isolate;
}
.channel-orbit::before,
.channel-orbit::after{
  content:"";
  position:absolute;
  left:50%;
  top:50%;
  translate:-50% -50%;
  border-radius:50%;
  border:1px dashed rgba(15,23,42,.11);
  pointer-events:none;
}
.channel-orbit::before{width:min(78%, 430px); aspect-ratio:1}
.channel-orbit::after{width:min(96%, 540px); aspect-ratio:1; border-color:rgba(56,189,248,.18)}
.orbit-pulse{
  position:absolute;
  left:50%;
  top:50%;
  width:132px;
  height:132px;
  translate:-50% -50%;
  border-radius:50%;
  background:linear-gradient(135deg, rgba(37,99,235,.28), rgba(56,189,248,.22));
  filter:blur(18px);
  opacity:.8;
  animation:orbitPulse 2.8s ease-out infinite;
}
.orbit-core{
  position:absolute;
  left:50%;
  top:50%;
  width:116px;
  height:116px;
  translate:-50% -50%;
  border-radius:32px;
  display:grid;
  place-items:center;
  background:rgba(255,255,255,.86);
  border:1px solid rgba(15,23,42,.08);
  box-shadow:0 20px 64px rgba(15,23,42,.12), inset 0 1px 0 rgba(255,255,255,.9);
  backdrop-filter:blur(16px);
  z-index:3;
}
.orbit-core img{width:72px; height:auto}
.orbit-core span{
  position:absolute;
  bottom:-13px;
  padding:.24rem .5rem;
  border-radius:999px;
  background:#10B981;
  color:white;
  font-family:var(--font-mono);
  font-size:10px;
  line-height:1;
  box-shadow:0 8px 22px rgba(16,185,129,.28);
}
.channel-node{
  position:absolute;
  z-index:4;
  left:50%;
  top:50%;
  width:96px;
  height:96px;
  margin:-48px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:.38rem;
  border-radius:24px;
  border:1px solid rgba(15,23,42,.08);
  background:rgba(255,255,255,.82);
  box-shadow:0 18px 50px rgba(15,23,42,.10);
  backdrop-filter:blur(14px);
  color:var(--ink-2);
  font-size:12px;
  font-weight:700;
  animation:nodeDrift var(--dur, 5s) ease-in-out infinite;
  transition:box-shadow var(--t-base) var(--ease);
}
.channel-node:hover{box-shadow:0 24px 70px rgba(15,23,42,.14)}
.channel-node img{width:34px; height:34px; object-fit:contain}
.channel-node.n-wa{transform:translate(-168px,-122px); --dur:5.4s}
.channel-node.n-ig{transform:translate(104px,-136px); --dur:4.8s; animation-delay:.25s}
.channel-node.n-web{transform:translate(160px,8px); --dur:5.8s; animation-delay:.5s}
.channel-node.n-cal{transform:translate(86px,130px); --dur:5.1s; animation-delay:.75s}
.channel-node.n-crm{transform:translate(-158px,92px); --dur:5.9s; animation-delay:1s}
.channel-node.n-n8n{transform:translate(-12px,-188px); --dur:6.3s; animation-delay:1.25s}
@keyframes orbitPulse{
  0%{scale:.9; opacity:.72}
  70%{scale:1.8; opacity:0}
  100%{scale:.9; opacity:0}
}
@keyframes nodeDrift{
  0%,100%{translate:0 0}
  50%{translate:0 -10px}
}

.integration-marquee{
  overflow:hidden;
  padding:1.5rem 0 3rem;
  background:linear-gradient(180deg, transparent, rgba(248,250,252,.72));
}
.marquee-row{
  position:relative;
  display:flex;
  width:100%;
  overflow:hidden;
  mask-image:linear-gradient(90deg, transparent, #000 14%, #000 86%, transparent);
}
.marquee-row + .marquee-row{margin-top:.8rem}
.marquee-track{
  display:flex;
  gap:1rem;
  width:max-content;
  min-width:200%;
  animation:lavioMarquee 32s linear infinite;
}
.marquee-row.reverse .marquee-track{
  animation-name:lavioMarqueeReverse;
  animation-duration:28s;
}
.marquee-track span{
  display:inline-flex;
  align-items:center;
  gap:.55rem;
  min-width:max-content;
  padding:.72rem 1rem;
  border:1px solid rgba(15,23,42,.07);
  border-radius:999px;
  background:rgba(255,255,255,.82);
  box-shadow:0 10px 28px rgba(15,23,42,.05);
  color:var(--ink-3);
  font-size:var(--fs-sm);
  font-weight:700;
}
.marquee-track img{width:22px; height:22px; object-fit:contain}
@keyframes lavioMarquee{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}
@keyframes lavioMarqueeReverse{
  from{transform:translateX(-50%)}
  to{transform:translateX(0)}
}

@media(max-width:980px){
  .hero-hub{animation:none}
  .hero-feat, .bubble, .hero-tag{display:none}
  .channel-grid{grid-template-columns:1fr}
  .channel-grid .section-head{text-align:center; margin-inline:auto}
  .channel-orbit{min-height:460px}
  .channel-node{width:82px; height:82px; margin:-41px; border-radius:20px}
  .channel-node.n-wa{transform:translate(-150px,-112px)}
  .channel-node.n-ig{transform:translate(88px,-128px)}
  .channel-node.n-web{transform:translate(145px,4px)}
  .channel-node.n-cal{transform:translate(78px,120px)}
  .channel-node.n-crm{transform:translate(-145px,84px)}
  .channel-node.n-n8n{transform:translate(-8px,-174px)}
}
@media(max-width:720px){
  .hero-hub .hub-ring{width:148px; height:148px}
  .hero-hub .hub-logo{height:68px}
  .hero-hub .hub-ring::before{width:200px; height:200px}
  .hero-hub .hub-ring::after{width:260px; height:260px}
  .channel-orbit{min-height:390px; border-radius:28px}
  .orbit-core{width:96px; height:96px; border-radius:26px}
  .orbit-core img{width:60px}
  .channel-node{width:70px; height:70px; margin:-35px; font-size:10px; border-radius:18px}
  .channel-node img{width:28px; height:28px}
  .channel-node.n-wa{transform:translate(-112px,-90px)}
  .channel-node.n-ig{transform:translate(62px,-104px)}
  .channel-node.n-web{transform:translate(108px,0)}
  .channel-node.n-cal{transform:translate(58px,94px)}
  .channel-node.n-crm{transform:translate(-108px,66px)}
  .channel-node.n-n8n{transform:translate(-6px,-136px)}
  .marquee-track span{padding:.62rem .85rem}
}
@media (prefers-reduced-motion: reduce){
  .hero-aurora .aura,
  .orbit,
  .hero-hub .hub-ring,
  .hero-hub .hub-ring::before,
  .hero-feat,
  .hero-tag,
  .bubble,
  .channel-node,
  .orbit-pulse,
  .marquee-track{
    animation:none !important;
  }
}

/* v30 inner page effects */
.lv-effects-ready .page-hero,.lv-effects-ready .v11-detail-hero,.lv-effects-ready .v12-saas-hero{position:relative;overflow:hidden;isolation:isolate}
.lv-effects-ready .page-hero{background:radial-gradient(760px 420px at calc(82% + (var(--lv-mx,0) * 18%)) calc(4% + (var(--lv-my,0) * 10%)),rgba(37,99,235,.18),transparent 62%),radial-gradient(520px 340px at 8% 34%,rgba(14,165,233,.12),transparent 68%),linear-gradient(180deg,#fff 0%,#f6f8fb 100%)}
.lv-effects-ready .page-hero:after,.lv-effects-ready .v11-detail-hero:after,.lv-effects-ready .v12-saas-hero:after{content:"";position:absolute;inset:0;z-index:-1;opacity:.34;background-image:linear-gradient(rgba(30,64,175,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(30,64,175,.06) 1px,transparent 1px);background-size:42px 42px;mask-image:linear-gradient(180deg,#000 0%,transparent 76%);animation:lvGridDrift 16s linear infinite}
.lv-hero-effects{position:absolute;inset:0;z-index:0;pointer-events:none}.lv-hero-effects .lv-glow{position:absolute;border-radius:999px;filter:blur(30px);opacity:.72}.lv-glow-a{width:360px;height:360px;right:7%;top:12%;background:rgba(37,99,235,.22);animation:lvFloatSoft 7s ease-in-out infinite}.lv-glow-b{width:220px;height:220px;right:24%;bottom:8%;background:rgba(14,165,233,.18);animation:lvFloatSoft 8.5s ease-in-out infinite reverse}
.lv-signal-card{position:absolute;right:clamp(18px,7vw,120px);width:min(210px,30vw);padding:14px 16px;border:1px solid rgba(219,234,254,.94);border-radius:18px;background:rgba(255,255,255,.78);box-shadow:0 22px 60px rgba(15,23,42,.1);backdrop-filter:blur(18px);transform:translate3d(calc(var(--lv-mx,0) * -12px),calc(var(--lv-my,0) * -10px),0)}.lv-signal-card b{display:block;color:var(--ink);font-family:var(--font-display);font-size:14px;letter-spacing:-.02em}.lv-signal-card span{display:block;margin-top:3px;color:var(--ink-4);font-size:12px;font-weight:650}.lv-signal-a{top:26%;animation:lvCardFloat 6.5s ease-in-out infinite}.lv-signal-b{top:48%;right:clamp(28px,13vw,210px);animation:lvCardFloat 7.2s ease-in-out infinite reverse}
.lv-mini-flow{position:absolute;right:clamp(16px,6vw,100px);bottom:18%;display:flex;align-items:center;gap:8px;padding:10px;border:1px solid rgba(219,234,254,.95);border-radius:999px;background:rgba(255,255,255,.72);box-shadow:0 18px 50px rgba(15,23,42,.08);backdrop-filter:blur(18px);animation:lvHeroIn .72s cubic-bezier(.22,1,.36,1) .16s both}.lv-mini-flow span{height:30px;display:grid;place-items:center;padding:0 11px;border-radius:999px;background:#eef6ff;color:#075dcf;font-size:12px;font-weight:900}.lv-mini-flow i{width:24px;height:2px;border-radius:999px;background:linear-gradient(90deg,var(--accent-2),#0ea5e9)}
.lv-orbit-dots{position:absolute;right:9%;top:18%;width:310px;height:310px;border:1px solid rgba(37,99,235,.16);border-radius:50%;animation:lvOrbitSpin 18s linear infinite}.lv-orbit-dots span{position:absolute;width:10px;height:10px;border-radius:50%;background:linear-gradient(135deg,var(--accent-2),#0ea5e9);box-shadow:0 0 0 8px rgba(37,99,235,.1)}.lv-orbit-dots span:nth-child(1){left:50%;top:-5px}.lv-orbit-dots span:nth-child(2){right:-5px;top:50%}.lv-orbit-dots span:nth-child(3){left:50%;bottom:-5px}.lv-orbit-dots span:nth-child(4){left:-5px;top:50%}
.lv-flow-strip{overflow:hidden;border-block:1px solid rgba(226,232,240,.9);background:linear-gradient(90deg,#f8fbff,#fff,#f8fbff);padding:12px 0}.lv-flow-track{display:flex;width:max-content;gap:10px;animation:lvMarquee 36s linear infinite}.lv-flow-track span{display:inline-flex;align-items:center;min-height:36px;padding:0 14px;border:1px solid rgba(219,234,254,.95);border-radius:999px;background:#fff;color:#334155;font-size:12px;font-weight:850;box-shadow:0 10px 24px rgba(15,23,42,.045)}
.lv-auto-reveal{opacity:0;transform:translateY(22px) scale(.985);filter:blur(8px);transition:opacity .7s var(--ease),transform .7s var(--ease),filter .7s var(--ease),box-shadow .25s var(--ease),border-color .25s var(--ease);transition-delay:calc(var(--lv-i,0) * 38ms)}.lv-auto-reveal.lv-in{opacity:1;transform:none;filter:none}
.lv-effects-ready .card:hover,.lv-effects-ready .case-card:hover,.lv-effects-ready .project-card:hover,.lv-effects-ready .v11-card:hover,.lv-effects-ready .v12-box:hover,.lv-effects-ready .v12-saas-card:hover,.lv-effects-ready .v29-case:hover,.lv-effects-ready .v29-plan:hover{border-color:rgba(37,99,235,.24)!important;box-shadow:0 26px 80px rgba(15,23,42,.12)!important;transform:translateY(-4px)}
.lv-showcase-card{position:relative;transform:rotate(var(--lv-tilt,0deg))}.lv-showcase-card:before{content:"";position:absolute;inset:-1px;border-radius:inherit;background:linear-gradient(135deg,rgba(37,99,235,.28),transparent 34%,rgba(14,165,233,.22));opacity:0;transition:opacity .25s var(--ease);pointer-events:none}.lv-showcase-card:hover:before{opacity:1}
.lv-contact-pulse{position:absolute;right:clamp(14px,4vw,52px);bottom:-24px;z-index:2;display:flex;align-items:center;gap:14px;max-width:310px;padding:14px 16px;border:1px solid rgba(219,234,254,.95);border-radius:20px;background:rgba(255,255,255,.88);box-shadow:0 22px 70px rgba(15,23,42,.12);backdrop-filter:blur(18px);animation:lvCardFloat 6s ease-in-out infinite}.lv-contact-pulse b{display:block;color:var(--ink);font-family:var(--font-display)}.lv-contact-pulse span,.lv-contact-pulse small{color:var(--ink-4);font-size:12px;font-weight:750}.lv-contact-pulse small{padding:7px 9px;border-radius:999px;background:#eef6ff;color:#075dcf;white-space:nowrap}
@keyframes lvGridDrift{to{background-position:42px 42px}}@keyframes lvHeroIn{from{opacity:0;transform:translateY(18px);filter:blur(8px)}to{opacity:1;transform:none;filter:blur(0)}}@keyframes lvFloatSoft{0%,100%{transform:translate3d(0,0,0) scale(1)}50%{transform:translate3d(18px,-18px,0) scale(1.06)}}@keyframes lvCardFloat{0%,100%{translate:0 0}50%{translate:0 -12px}}@keyframes lvOrbitSpin{to{rotate:360deg}}@keyframes lvMarquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(max-width:980px){.lv-signal-card,.lv-orbit-dots{display:none}.lv-mini-flow{right:16px;left:16px;bottom:16px;justify-content:center;overflow:auto}.lv-hero-effects{opacity:.75}}
@media(max-width:680px){.lv-flow-strip{padding:9px 0}.lv-flow-track{animation-duration:26s}.lv-mini-flow{display:none}.lv-contact-pulse{position:relative;right:auto;bottom:auto;margin-top:16px}}
@media(prefers-reduced-motion:reduce){.lv-effects-ready .page-hero:after,.lv-effects-ready .v11-detail-hero:after,.lv-effects-ready .v12-saas-hero:after,.lv-glow-a,.lv-glow-b,.lv-signal-a,.lv-signal-b,.lv-mini-flow,.lv-orbit-dots,.lv-flow-track,.lv-contact-pulse{animation:none!important}.lv-auto-reveal{opacity:1!important;transform:none!important;filter:none!important;transition:none!important}}

/* v31 portfolio upgrade */
.lv-page-portfolio .section:not(.section-soft){background:linear-gradient(180deg,#fff 0%,#f8fbff 100%)}
.lv-page-portfolio .grid.grid-2{
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:clamp(18px,2.4vw,30px)!important;
  align-items:stretch;
}
.lv-page-portfolio .case-card{
  position:relative;
  overflow:hidden;
  min-height:0;
  padding:0!important;
  border:1px solid rgba(219,234,254,.95)!important;
  border-radius:32px!important;
  background:linear-gradient(180deg,rgba(255,255,255,.94),rgba(248,251,255,.98))!important;
  box-shadow:0 24px 80px rgba(15,23,42,.08)!important;
  transform:none!important;
}
.lv-page-portfolio .case-card:after{
  content:"";
  position:absolute;
  inset:auto -20% -38% 28%;
  height:220px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(37,99,235,.14),transparent 68%);
  pointer-events:none;
}
.lv-project-screen{
  position:relative;
  margin:14px 14px 0;
  border:1px solid rgba(191,219,254,.88);
  border-radius:24px;
  overflow:hidden;
  background:
    radial-gradient(circle at 18% 18%,rgba(37,99,235,.2),transparent 34%),
    linear-gradient(135deg,#07111f,#12356f 54%,#0ea5e9);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.18),0 18px 48px rgba(37,99,235,.16);
}
.lv-screen-top{
  height:42px;
  display:flex;
  align-items:center;
  gap:7px;
  padding:0 14px;
  border-bottom:1px solid rgba(255,255,255,.14);
  color:#dbeafe;
}
.lv-screen-top span{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.72)}
.lv-screen-top b{margin-left:auto;font-size:12px;letter-spacing:.14em}
.lv-screen-body{
  min-height:178px;
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:14px;
  padding:18px;
}
.lv-screen-main,.lv-screen-side{display:grid;gap:10px;align-content:center}
.lv-screen-main i,.lv-screen-side em{
  display:block;
  border-radius:14px;
  background:rgba(255,255,255,.15);
  border:1px solid rgba(255,255,255,.16);
}
.lv-screen-main i:nth-child(1){height:34px;width:74%}
.lv-screen-main i:nth-child(2){height:58px;width:100%;background:rgba(255,255,255,.22)}
.lv-screen-main i:nth-child(3){height:28px;width:58%}
.lv-screen-side em{height:32px}
.lv-screen-side em:nth-child(2){height:66px;background:linear-gradient(135deg,rgba(255,255,255,.28),rgba(255,255,255,.10))}
.lv-screen-caption{
  position:absolute;
  left:18px;
  bottom:14px;
  max-width:72%;
  color:#fff;
  font-weight:900;
  font-size:13px;
  text-shadow:0 8px 24px rgba(0,0,0,.22);
}
.lv-page-portfolio .case-tags,
.lv-page-portfolio .case-card h3,
.lv-page-portfolio .case-card>p,
.lv-page-portfolio .case-block,
.lv-page-portfolio .case-result{
  position:relative;
  z-index:1;
  margin-left:clamp(18px,2.3vw,28px)!important;
  margin-right:clamp(18px,2.3vw,28px)!important;
}
.lv-page-portfolio .case-tags{margin-top:22px!important}
.lv-page-portfolio .case-tag{
  background:#eef6ff!important;
  color:#075dcf!important;
  border:1px solid #dbeafe!important;
  font-weight:850!important;
}
.lv-page-portfolio .case-card h3{
  margin-top:15px!important;
  letter-spacing:-.045em;
}
.lv-page-portfolio .case-block{
  display:grid;
  gap:10px;
  padding:14px;
  border:1px solid rgba(226,232,240,.92);
  border-radius:20px;
  background:rgba(255,255,255,.72);
}
.lv-page-portfolio .case-result{
  margin-top:18px!important;
  margin-bottom:24px!important;
  border:1px solid rgba(191,219,254,.9);
  background:linear-gradient(135deg,#eef6ff,#fff);
  box-shadow:0 14px 36px rgba(37,99,235,.08);
}
.lv-page-portfolio .section-soft{
  background:linear-gradient(135deg,#07111f,#12356f)!important;
  color:#fff;
}
.lv-page-portfolio .section-soft [style*="color: var(--accent)"]{color:#7dd3fc!important}
.lv-page-portfolio .section-soft [style*="color: var(--ink-3)"]{color:#dbeafe!important}
@media(max-width:980px){.lv-page-portfolio .grid.grid-2{grid-template-columns:1fr!important}.lv-screen-body{min-height:150px}}
@media(max-width:620px){.lv-project-screen{margin:10px 10px 0;border-radius:20px}.lv-screen-body{grid-template-columns:1fr;min-height:132px}.lv-screen-side{display:none}}

/* v32 customer friendly homepage + portfolio clarity */
.customer-map{position:relative;overflow:hidden;background:linear-gradient(180deg,#fff 0%,#f8fbff 100%)}
.customer-map:before{content:"";position:absolute;inset:0;opacity:.32;background-image:linear-gradient(rgba(37,99,235,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(37,99,235,.06) 1px,transparent 1px);background-size:44px 44px;mask-image:linear-gradient(180deg,transparent,#000 20%,#000 80%,transparent);pointer-events:none}
.customer-map-grid{position:relative;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.customer-map-card{position:relative;overflow:hidden;min-height:210px;padding:24px;border:1px solid rgba(219,234,254,.95);border-radius:28px;background:rgba(255,255,255,.82);box-shadow:0 22px 70px rgba(15,23,42,.08);backdrop-filter:blur(16px)}
.customer-map-card:after{content:"";position:absolute;inset:auto -28% -38% 30%;height:150px;border-radius:50%;background:radial-gradient(circle,rgba(37,99,235,.16),transparent 70%)}
.customer-map-card span{display:inline-grid;place-items:center;width:38px;height:38px;border-radius:14px;background:#eef6ff;color:#075dcf;font-weight:900}
.customer-map-card h3{margin:22px 0 10px;font-size:clamp(22px,2vw,28px);letter-spacing:-.045em}
.customer-map-card p{position:relative;z-index:1;margin:0;color:var(--ink-3);line-height:1.65}
.lv-form-help{margin:0 0 12px;padding:12px 14px;border:1px solid rgba(219,234,254,.95);border-radius:16px;background:#eef6ff;color:#075dcf;font-size:13px;font-weight:750;line-height:1.45}
.lv-case-fit{position:relative;z-index:1;margin:14px clamp(18px,2.3vw,28px) 0!important;padding:14px 16px;border:1px solid rgba(219,234,254,.95);border-radius:18px;background:#f8fbff}
.lv-case-fit b{display:block;margin-bottom:5px;color:#075dcf;font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.08em}
.lv-case-fit span{display:block;color:#334155;font-size:14px;line-height:1.55;font-weight:650}
@media(max-width:900px){.customer-map-grid{grid-template-columns:1fr}.customer-map-card{min-height:0}}

/* ============================================================
   LAVIO Animation Integration — vanilla CSS motion layer
   ============================================================ */
.lavio-animated-grid{
  position:relative;
  overflow:hidden;
  isolation:isolate;
  background:
    radial-gradient(760px 420px at 82% 18%, rgba(37,99,235,.10), transparent 64%),
    radial-gradient(620px 360px at 12% 42%, rgba(56,189,248,.09), transparent 62%),
    linear-gradient(180deg, #fff 0%, #f8fbff 100%);
}
.lavio-animated-grid > .container{position:relative; z-index:1}
.customer-map.lavio-animated-grid:before,
.lavio-animated-grid::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:0;
  pointer-events:none;
  opacity:.42;
  background-image:
    linear-gradient(rgba(37,99,235,.075) 1px, transparent 1px),
    linear-gradient(90deg, rgba(37,99,235,.075) 1px, transparent 1px),
    radial-gradient(circle, rgba(14,165,233,.12) 1px, transparent 1.5px);
  background-size:52px 52px, 52px 52px, 26px 26px;
  background-position:0 0, 0 0, 13px 13px;
  mask-image:linear-gradient(180deg, transparent 0%, #000 16%, #000 84%, transparent 100%);
  animation:lavioGridDrift 26s linear infinite;
}
.lavio-animated-grid::after{
  content:"";
  position:absolute;
  inset:auto 8% 8% auto;
  width:min(460px, 65vw);
  height:min(460px, 65vw);
  z-index:0;
  border-radius:50%;
  pointer-events:none;
  background:radial-gradient(circle, rgba(37,99,235,.12), transparent 68%);
  filter:blur(10px);
}
@keyframes lavioGridDrift{
  from{background-position:0 0, 0 0, 13px 13px}
  to{background-position:52px 52px, 52px 52px, 39px 39px}
}

.lavio-reveal{
  opacity:0;
  transform:translateY(18px);
  transition:opacity .7s var(--ease), transform .7s var(--ease);
}
.lavio-reveal.in{opacity:1; transform:none}

.lavio-chip{
  display:inline-flex;
  align-items:center;
  min-height:32px;
  padding:.42rem .72rem;
  border:1px solid rgba(37,99,235,.16);
  border-radius:999px;
  background:linear-gradient(180deg, rgba(255,255,255,.92), rgba(239,246,255,.86));
  color:#0f3f91;
  font-size:var(--fs-xs);
  font-weight:700;
  box-shadow:0 10px 28px rgba(37,99,235,.07);
  transition:transform var(--t-base) var(--ease), box-shadow var(--t-base) var(--ease), border-color var(--t-base) var(--ease);
}
.lavio-chip:hover{
  transform:translateY(-2px);
  border-color:rgba(37,99,235,.28);
  box-shadow:0 16px 34px rgba(37,99,235,.12);
}
.zero-chips{
  display:flex;
  flex-wrap:wrap;
  gap:.55rem;
  margin-top:1.15rem;
}
.zero-steps article{
  transition:transform var(--t-base) var(--ease), box-shadow var(--t-base) var(--ease), border-color var(--t-base) var(--ease);
}
.zero-steps article:hover{
  transform:translateY(-3px);
  border-color:rgba(37,99,235,.25);
  box-shadow:0 22px 58px rgba(37,99,235,.10);
}
.zero-steps span{
  background:linear-gradient(135deg, #2563eb, #0a7cff);
  box-shadow:0 10px 24px rgba(37,99,235,.18);
}

.lavio-soft-orbit{
  background:
    linear-gradient(180deg, rgba(255,255,255,.90), rgba(248,251,255,.72)),
    radial-gradient(circle at 50% 50%, rgba(37,99,235,.12), transparent 54%);
  border-color:rgba(37,99,235,.14);
}
.lavio-soft-orbit::before,
.lavio-soft-orbit::after{
  border-color:rgba(37,99,235,.16);
  animation:lavioOrbitRing 38s linear infinite;
}
.lavio-soft-orbit::after{
  border-color:rgba(56,189,248,.20);
  animation-duration:52s;
  animation-direction:reverse;
}
@keyframes lavioOrbitRing{
  from{rotate:0deg}
  to{rotate:360deg}
}
.lavio-orbit-card{
  border-color:rgba(37,99,235,.14);
  background:linear-gradient(180deg, rgba(255,255,255,.95), rgba(248,251,255,.88));
  box-shadow:0 18px 50px rgba(15,23,42,.08), 0 0 0 1px rgba(37,99,235,.025);
  will-change:translate;
  transition:scale var(--t-base) var(--ease), box-shadow var(--t-base) var(--ease), border-color var(--t-base) var(--ease);
}
.lavio-orbit-card:hover{
  scale:1.055;
  border-color:rgba(37,99,235,.30);
  box-shadow:0 24px 72px rgba(37,99,235,.15), 0 0 0 5px rgba(37,99,235,.055);
}
.orbit-core span{
  background:linear-gradient(135deg, #0a7cff, #06b6d4);
  box-shadow:0 8px 22px rgba(37,99,235,.22);
}
.orbit-pulse{
  background:linear-gradient(135deg, rgba(37,99,235,.24), rgba(56,189,248,.18));
}

.lavio-ripple-btn,
.btn{
  overflow:hidden;
}
.lavio-ripple-btn::before,
.btn::before{
  content:"";
  position:absolute;
  inset:1px;
  border-radius:inherit;
  pointer-events:none;
  background:linear-gradient(120deg, transparent 0%, rgba(255,255,255,.34) 42%, rgba(255,255,255,.18) 52%, transparent 68%);
  transform:translateX(-130%);
  opacity:.72;
}
.lavio-ripple-btn:hover::before,
.btn:hover::before{
  animation:lavioButtonSheen 760ms var(--ease);
}
.lavio-ripple{
  position:absolute;
  width:12px;
  height:12px;
  left:var(--rx, 50%);
  top:var(--ry, 50%);
  border-radius:50%;
  pointer-events:none;
  background:radial-gradient(circle, rgba(255,255,255,.58), rgba(56,189,248,.26) 45%, transparent 72%);
  transform:translate(-50%, -50%) scale(0);
  animation:lavioRipple .58s var(--ease);
}
.btn-soft .lavio-ripple,
.btn-ghost .lavio-ripple{
  background:radial-gradient(circle, rgba(37,99,235,.18), rgba(56,189,248,.12) 45%, transparent 72%);
}
@keyframes lavioButtonSheen{
  from{transform:translateX(-130%)}
  to{transform:translateX(130%)}
}
@keyframes lavioRipple{
  to{transform:translate(-50%, -50%) scale(18); opacity:0}
}

.lv-package-features li::before,
.price-feature .ic{
  background-color:#dbeafe;
  color:#2563eb;
}
.lv-package-features li::before{
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='%232563EB' stroke-width='3' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
}
.os-tag.ai{
  background:#e0f2fe;
  color:#075985;
}

@media(max-width:720px){
  .lavio-animated-grid::before,
  .customer-map.lavio-animated-grid:before{
    opacity:.28;
    background-size:64px 64px, 64px 64px, 32px 32px;
    animation-duration:38s;
  }
  .lavio-orbit-card:hover{scale:1.025}
}
@media (prefers-reduced-motion: reduce){
  .lavio-animated-grid::before,
  .customer-map.lavio-animated-grid:before,
  .lavio-soft-orbit::before,
  .lavio-soft-orbit::after,
  .lavio-ripple-btn:hover::before,
  .btn:hover::before{
    animation:none !important;
  }
  .lavio-reveal{
    opacity:1 !important;
    transform:none !important;
  }
  .lavio-ripple{display:none}
}

/* v2 stronger premium motion pass */
.hero-orbits{
  opacity:1;
  filter:drop-shadow(0 20px 60px rgba(37,99,235,.10));
}
.hero-orbits::before{
  opacity:1;
  background:
    radial-gradient(circle at 50% 50%, rgba(37,99,235,.18), transparent 34%),
    radial-gradient(circle at 42% 36%, rgba(56,189,248,.22), transparent 30%);
}
.orbit{
  border-color:rgba(37,99,235,.28);
  box-shadow:inset 0 0 36px rgba(37,99,235,.07), 0 0 36px rgba(56,189,248,.08);
}
.orbit::before{
  border-color:rgba(14,165,233,.34);
  opacity:.9;
}
.orbit-line{
  height:2px;
  background:linear-gradient(90deg, transparent, rgba(37,99,235,.28), rgba(56,189,248,.34), rgba(37,99,235,.18), transparent);
  opacity:.82;
}
.hero-hub .hub-ring{
  background:
    radial-gradient(circle, rgba(255,255,255,.92) 0 38%, rgba(239,246,255,.78) 39% 62%, rgba(37,99,235,.10) 63% 100%);
  border-color:rgba(37,99,235,.22);
  box-shadow:0 0 0 12px rgba(37,99,235,.045), 0 28px 80px rgba(37,99,235,.18);
}
.hero-hub .hub-ring::before{
  border-color:rgba(37,99,235,.20);
}
.hero-hub .hub-ring::after{
  border-color:rgba(56,189,248,.18);
  box-shadow:0 0 60px rgba(37,99,235,.10);
}
.hero-feat{
  border-color:rgba(37,99,235,.18);
  box-shadow:0 18px 52px rgba(37,99,235,.11), inset 0 1px 0 rgba(255,255,255,.92);
  transition:transform var(--t-base) var(--ease), border-color var(--t-base) var(--ease), box-shadow var(--t-base) var(--ease);
}
.hero-feat:hover{
  transform:translateY(-4px) scale(1.035);
  border-color:rgba(37,99,235,.34);
  box-shadow:0 26px 70px rgba(37,99,235,.18), 0 0 0 5px rgba(37,99,235,.055);
}

.channel-orbit.lavio-soft-orbit{
  background:
    radial-gradient(circle at 50% 50%, rgba(37,99,235,.18), transparent 35%),
    radial-gradient(circle at 28% 20%, rgba(56,189,248,.14), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.94), rgba(248,251,255,.78));
  box-shadow:0 30px 96px rgba(37,99,235,.13), inset 0 1px 0 rgba(255,255,255,.92);
}
.channel-orbit.lavio-soft-orbit::before,
.channel-orbit.lavio-soft-orbit::after{
  border-width:1.5px;
  border-style:dashed;
  box-shadow:0 0 40px rgba(37,99,235,.08);
}
.channel-orbit.lavio-soft-orbit::before{border-color:rgba(37,99,235,.30)}
.channel-orbit.lavio-soft-orbit::after{border-color:rgba(56,189,248,.28)}
.orbit-core{
  box-shadow:0 24px 74px rgba(37,99,235,.20), 0 0 0 12px rgba(37,99,235,.055), inset 0 1px 0 rgba(255,255,255,.96);
}
.orbit-core::before{
  content:"";
  position:absolute;
  inset:-34px;
  z-index:-1;
  border-radius:42px;
  background:radial-gradient(circle, rgba(37,99,235,.20), rgba(56,189,248,.10) 46%, transparent 72%);
  filter:blur(10px);
  animation:lavioCoreGlow 3.8s ease-in-out infinite;
}
@keyframes lavioCoreGlow{
  0%,100%{opacity:.68; scale:.96}
  50%{opacity:1; scale:1.05}
}
.lavio-orbit-card{
  border-color:rgba(37,99,235,.22);
  box-shadow:0 20px 58px rgba(37,99,235,.12), inset 0 1px 0 rgba(255,255,255,.94);
  animation:nodeDrift var(--dur, 5s) ease-in-out infinite, lavioCardBreath 7s ease-in-out infinite;
}
.lavio-orbit-card:hover{
  scale:1.09;
  border-color:rgba(37,99,235,.48);
  box-shadow:0 28px 84px rgba(37,99,235,.22), 0 0 0 6px rgba(37,99,235,.08), inset 0 1px 0 rgba(255,255,255,.98);
}
@keyframes lavioCardBreath{
  0%,100%{filter:saturate(1)}
  50%{filter:saturate(1.12)}
}

.integration-marquee{
  position:relative;
  padding:2rem 0 3.5rem;
  background:
    radial-gradient(680px 190px at 50% 0%, rgba(37,99,235,.16), transparent 70%),
    linear-gradient(180deg, rgba(255,255,255,.0), rgba(239,246,255,.72));
  overflow:hidden;
}
.integration-marquee::before{
  content:"";
  position:absolute;
  inset:8px 6% auto;
  height:140px;
  pointer-events:none;
  border-radius:999px;
  background:radial-gradient(ellipse at center, rgba(56,189,248,.14), rgba(37,99,235,.07) 42%, transparent 72%);
  filter:blur(18px);
}
.marquee-row{
  mask-image:linear-gradient(90deg, transparent, #000 9%, #000 91%, transparent);
}
.marquee-track{
  gap:1.15rem;
  animation-duration:25s;
}
.marquee-row.reverse .marquee-track{animation-duration:29s}
.marquee-track span{
  position:relative;
  overflow:hidden;
  padding:.82rem 1.08rem;
  border-color:rgba(37,99,235,.16);
  background:linear-gradient(180deg, rgba(255,255,255,.88), rgba(239,246,255,.72));
  backdrop-filter:blur(14px);
  box-shadow:0 16px 42px rgba(37,99,235,.10), inset 0 1px 0 rgba(255,255,255,.92);
  transition:transform var(--t-base) var(--ease), border-color var(--t-base) var(--ease), box-shadow var(--t-base) var(--ease);
}
.marquee-track span::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(110deg, transparent, rgba(255,255,255,.42), transparent);
  transform:translateX(-120%);
}
.marquee-track span:hover{
  transform:translateY(-4px);
  border-color:rgba(37,99,235,.34);
  box-shadow:0 22px 58px rgba(37,99,235,.16), 0 0 0 5px rgba(37,99,235,.05);
}
.marquee-track span:hover::after{animation:lavioButtonSheen 760ms var(--ease)}

.customer-map.lavio-animated-grid:before,
.lavio-animated-grid::before{
  opacity:.68;
  background-image:
    linear-gradient(rgba(37,99,235,.115) 1px, transparent 1px),
    linear-gradient(90deg, rgba(37,99,235,.105) 1px, transparent 1px),
    radial-gradient(circle, rgba(14,165,233,.20) 1.15px, transparent 1.85px);
  background-size:48px 48px, 48px 48px, 24px 24px;
  animation:lavioGridDriftStrong 22s linear infinite;
}
.lavio-animated-grid::after{
  opacity:.95;
  background:radial-gradient(circle, rgba(37,99,235,.18), rgba(56,189,248,.08) 42%, transparent 70%);
}
@keyframes lavioGridDriftStrong{
  from{background-position:0 0, 0 0, 12px 12px}
  to{background-position:48px 48px, 48px 48px, 36px 36px}
}
.customer-map-card{
  border-color:rgba(37,99,235,.18);
  box-shadow:0 24px 74px rgba(37,99,235,.10), inset 0 1px 0 rgba(255,255,255,.92);
}

.btn{
  transition:transform var(--t-fast) var(--ease), box-shadow var(--t-base) var(--ease), background var(--t-base) var(--ease), border-color var(--t-base) var(--ease);
}
.btn:hover{
  box-shadow:0 16px 42px rgba(37,99,235,.18), 0 0 0 5px rgba(37,99,235,.07);
}
.btn-primary:hover{
  box-shadow:0 18px 46px rgba(37,99,235,.30), 0 0 0 6px rgba(37,99,235,.10), inset 0 1px 0 rgba(255,255,255,.22);
}
.btn-soft:hover,
.btn-ghost:hover{
  border-color:rgba(37,99,235,.30);
}
.lavio-ripple-btn::before,
.btn::before{
  background:linear-gradient(115deg, transparent 0%, rgba(255,255,255,.18) 33%, rgba(255,255,255,.70) 48%, rgba(56,189,248,.22) 58%, transparent 76%);
  opacity:.95;
}
.lavio-ripple{
  width:18px;
  height:18px;
  background:radial-gradient(circle, rgba(255,255,255,.82), rgba(56,189,248,.36) 38%, rgba(37,99,235,.18) 58%, transparent 74%);
  animation-duration:.68s;
}
.btn-soft .lavio-ripple,
.btn-ghost .lavio-ripple{
  background:radial-gradient(circle, rgba(37,99,235,.24), rgba(56,189,248,.20) 42%, rgba(37,99,235,.10) 60%, transparent 76%);
}

.lavio-stagger-reveal{
  opacity:0;
  transform:translateY(18px);
  transition:opacity .58s var(--ease), transform .58s var(--ease), box-shadow var(--t-base) var(--ease), border-color var(--t-base) var(--ease);
  transition-delay:var(--lv-delay, 0ms);
}
.lavio-stagger-reveal.in{
  opacity:1;
  transform:none;
}

@media(max-width:720px){
  .hero-orbits{opacity:.72}
  .orbit{border-color:rgba(37,99,235,.20)}
  .channel-orbit.lavio-soft-orbit{box-shadow:0 20px 60px rgba(37,99,235,.10)}
  .lavio-orbit-card:hover{scale:1.04}
  .marquee-track{animation-duration:34s}
  .customer-map.lavio-animated-grid:before,
  .lavio-animated-grid::before{
    opacity:.46;
    background-size:56px 56px, 56px 56px, 28px 28px;
    animation-duration:32s;
  }
}
@media (prefers-reduced-motion: reduce){
  .orbit,
  .hero-hub .hub-ring,
  .hero-hub .hub-ring::before,
  .orbit-core::before,
  .lavio-orbit-card,
  .marquee-track,
  .marquee-track span:hover::after,
  .customer-map.lavio-animated-grid:before,
  .lavio-animated-grid::before{
    animation:none !important;
  }
  .lavio-stagger-reveal{
    opacity:1 !important;
    transform:none !important;
    transition:none !important;
  }
}


/* v3 orbit position fix + Lavio system flow section */
.channel-node.n-wa{--node-pos:translate(-168px,-122px); transform:var(--node-pos)}
.channel-node.n-ig{--node-pos:translate(104px,-136px); transform:var(--node-pos)}
.channel-node.n-web{--node-pos:translate(160px,8px); transform:var(--node-pos)}
.channel-node.n-cal{--node-pos:translate(86px,130px); transform:var(--node-pos)}
.channel-node.n-crm{--node-pos:translate(-158px,92px); transform:var(--node-pos)}
.channel-node.n-n8n{--node-pos:translate(-12px,-188px); transform:var(--node-pos)}
.channel-node.lavio-stagger-reveal,
.channel-node.lavio-stagger-reveal.in{
  opacity:1;
  transform:var(--node-pos) !important;
}
.channel-node.lavio-orbit-card{
  transform:var(--node-pos);
  animation:nodeDrift var(--dur, 5s) ease-in-out infinite, lavioCardBreath 7s ease-in-out infinite;
}
.channel-node.lavio-orbit-card:hover{
  transform:var(--node-pos);
}
.channel-orbit.lavio-soft-orbit{
  box-shadow:0 24px 72px rgba(37,99,235,.10), inset 0 1px 0 rgba(255,255,255,.92);
}
.orbit-core{
  box-shadow:0 18px 54px rgba(37,99,235,.14), 0 0 0 8px rgba(37,99,235,.04), inset 0 1px 0 rgba(255,255,255,.96);
}
.orbit-core::before{
  inset:-24px;
  opacity:.74;
  background:radial-gradient(circle, rgba(37,99,235,.14), rgba(56,189,248,.07) 48%, transparent 72%);
}
.orbit-pulse{opacity:.48; filter:blur(20px)}

.lavio-flow-section{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(780px 360px at 78% 8%, rgba(37,99,235,.12), transparent 64%),
    radial-gradient(620px 320px at 8% 70%, rgba(56,189,248,.10), transparent 62%),
    linear-gradient(180deg,#fff 0%,#f8fbff 100%);
}
.lavio-flow-section::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  opacity:.36;
  background-image:
    linear-gradient(rgba(37,99,235,.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(37,99,235,.055) 1px, transparent 1px);
  background-size:54px 54px;
  mask-image:linear-gradient(180deg, transparent, #000 18%, #000 82%, transparent);
}
.lavio-flow-section .container{position:relative; z-index:1}
.lavio-flow-shell{
  display:grid;
  grid-template-columns:minmax(230px,.34fr) minmax(0,1fr);
  gap:clamp(1rem,3vw,1.6rem);
  align-items:stretch;
  padding:clamp(1rem,2vw,1.25rem);
  border:1px solid rgba(37,99,235,.14);
  border-radius:32px;
  background:linear-gradient(180deg, rgba(255,255,255,.84), rgba(248,251,255,.72));
  box-shadow:0 26px 84px rgba(37,99,235,.10), inset 0 1px 0 rgba(255,255,255,.92);
  backdrop-filter:blur(18px);
}
.lavio-flow-tabs{
  display:flex;
  flex-direction:column;
  gap:.62rem;
  padding:.55rem;
  border:1px solid rgba(37,99,235,.12);
  border-radius:24px;
  background:rgba(255,255,255,.68);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.86);
}
.lavio-flow-tab{
  position:relative;
  width:100%;
  min-height:48px;
  padding:.8rem .95rem;
  border:1px solid rgba(148,163,184,.18);
  border-radius:16px;
  background:linear-gradient(180deg,rgba(255,255,255,.92),rgba(248,251,255,.78));
  color:#334155;
  text-align:left;
  font-weight:800;
  font-size:var(--fs-sm);
  box-shadow:0 8px 22px rgba(15,23,42,.035);
  transition:transform var(--t-base) var(--ease), border-color var(--t-base) var(--ease), box-shadow var(--t-base) var(--ease), color var(--t-base) var(--ease), background var(--t-base) var(--ease);
}
.lavio-flow-tab:hover{
  transform:translateY(-2px);
  border-color:rgba(37,99,235,.26);
  color:#0f3f91;
  box-shadow:0 14px 32px rgba(37,99,235,.09);
}
.lavio-flow-tab.is-active{
  color:#fff;
  border-color:rgba(37,99,235,.36);
  background:linear-gradient(135deg,#2563eb,#0a7cff);
  box-shadow:0 16px 40px rgba(37,99,235,.22), inset 0 1px 0 rgba(255,255,255,.20);
}
.lavio-flow-panel{
  position:relative;
  overflow:hidden;
  min-height:420px;
  border:1px solid rgba(37,99,235,.14);
  border-radius:28px;
  padding:clamp(1.2rem,3vw,2rem);
  background:
    radial-gradient(520px 220px at 88% 12%, rgba(37,99,235,.13), transparent 64%),
    linear-gradient(180deg,rgba(255,255,255,.94),rgba(248,251,255,.84));
  box-shadow:0 22px 64px rgba(15,23,42,.08), inset 0 1px 0 rgba(255,255,255,.95);
}
.lavio-flow-panel::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  opacity:.28;
  background-image:radial-gradient(circle, rgba(37,99,235,.18) 1px, transparent 1.8px);
  background-size:24px 24px;
  mask-image:linear-gradient(135deg, transparent 0%, #000 22%, #000 72%, transparent 100%);
}
.lavio-flow-panel-head,
.lavio-flow-demo,
.lavio-flow-features{position:relative; z-index:1}
.lavio-flow-kicker{
  display:inline-flex;
  align-items:center;
  width:max-content;
  margin-bottom:.8rem;
  padding:.35rem .62rem;
  border:1px solid rgba(37,99,235,.18);
  border-radius:999px;
  background:#eff6ff;
  color:#075dcf;
  font-family:var(--font-mono);
  font-size:11px;
  font-weight:900;
  letter-spacing:.04em;
}
.lavio-flow-panel h3{
  font-size:clamp(1.65rem,2.7vw,2.35rem);
  letter-spacing:-.035em;
  margin:0 0 .65rem;
}
.lavio-flow-panel p{margin:0; color:#475569; line-height:1.65}
.lavio-flow-demo{
  display:grid;
  gap:.75rem;
  margin:1.35rem 0 1.2rem;
}
.lavio-flow-row{
  display:grid;
  grid-template-columns:104px minmax(0,1fr);
  gap:.75rem;
  align-items:center;
  padding:.82rem .95rem;
  border:1px solid rgba(37,99,235,.12);
  border-radius:18px;
  background:rgba(255,255,255,.82);
  box-shadow:0 12px 30px rgba(15,23,42,.045);
  animation:lavioFlowRow .42s var(--ease) both;
}
.lavio-flow-row:nth-child(2){animation-delay:.05s}
.lavio-flow-row:nth-child(3){animation-delay:.10s}
.lavio-flow-row:nth-child(4){animation-delay:.15s}
.lavio-flow-row span{
  display:inline-flex;
  justify-content:center;
  padding:.28rem .5rem;
  border-radius:999px;
  background:#f1f5f9;
  color:#475569;
  font-size:11px;
  font-weight:900;
}
.lavio-flow-row.is-system span,
.lavio-flow-row.is-team span{
  background:#dbeafe;
  color:#1d4ed8;
}
.lavio-flow-row p{font-weight:750; color:#0f172a; line-height:1.45}
.lavio-flow-features{
  display:flex;
  flex-wrap:wrap;
  gap:.55rem;
}
.lavio-flow-features span{
  display:inline-flex;
  align-items:center;
  min-height:32px;
  padding:.42rem .7rem;
  border:1px solid rgba(37,99,235,.16);
  border-radius:999px;
  background:linear-gradient(180deg,#fff,#eff6ff);
  color:#0f3f91;
  font-size:var(--fs-xs);
  font-weight:850;
  box-shadow:0 10px 24px rgba(37,99,235,.065);
}
.lavio-flow-panel.is-changing .lavio-flow-panel-head,
.lavio-flow-panel.is-changing .lavio-flow-demo,
.lavio-flow-panel.is-changing .lavio-flow-features{
  animation:lavioFlowSwap .26s var(--ease) both;
}
@keyframes lavioFlowRow{from{opacity:0; transform:translateY(8px)}to{opacity:1; transform:none}}
@keyframes lavioFlowSwap{from{opacity:.35; transform:translateY(6px)}to{opacity:1; transform:none}}

.integration-marquee{
  padding:1.6rem 0 2rem;
  min-height:auto;
}
.integration-marquee::before{
  inset:4px 8% auto;
  height:100px;
  filter:blur(16px);
}
.marquee-row{padding-block:.2rem .45rem}
.marquee-track{animation-duration:38s}
.marquee-row.reverse .marquee-track{animation-duration:42s}
.marquee-track span{
  padding:.68rem .95rem;
  color:#1e293b;
  line-height:1;
}

@media(max-width:980px){
  .channel-node.n-wa{--node-pos:translate(-150px,-112px); transform:var(--node-pos)}
  .channel-node.n-ig{--node-pos:translate(88px,-128px); transform:var(--node-pos)}
  .channel-node.n-web{--node-pos:translate(145px,4px); transform:var(--node-pos)}
  .channel-node.n-cal{--node-pos:translate(78px,120px); transform:var(--node-pos)}
  .channel-node.n-crm{--node-pos:translate(-145px,84px); transform:var(--node-pos)}
  .channel-node.n-n8n{--node-pos:translate(-8px,-174px); transform:var(--node-pos)}
  .lavio-flow-shell{grid-template-columns:1fr}
  .lavio-flow-tabs{
    flex-direction:row;
    overflow-x:auto;
    overscroll-behavior-inline:contain;
    scroll-snap-type:x proximity;
    padding:.5rem;
  }
  .lavio-flow-tabs::-webkit-scrollbar{height:6px}
  .lavio-flow-tabs::-webkit-scrollbar-thumb{background:rgba(37,99,235,.24); border-radius:999px}
  .lavio-flow-tab{flex:0 0 auto; width:auto; min-width:140px; scroll-snap-align:start; text-align:center}
  .lavio-flow-panel{min-height:390px}
}
@media(max-width:720px){
  .channel-node.n-wa{--node-pos:translate(-112px,-90px); transform:var(--node-pos)}
  .channel-node.n-ig{--node-pos:translate(62px,-104px); transform:var(--node-pos)}
  .channel-node.n-web{--node-pos:translate(108px,0); transform:var(--node-pos)}
  .channel-node.n-cal{--node-pos:translate(58px,94px); transform:var(--node-pos)}
  .channel-node.n-crm{--node-pos:translate(-108px,66px); transform:var(--node-pos)}
  .channel-node.n-n8n{--node-pos:translate(-6px,-136px); transform:var(--node-pos)}
  .lavio-flow-shell{border-radius:24px; padding:.75rem}
  .lavio-flow-panel{min-height:0; border-radius:22px; padding:1rem}
  .lavio-flow-row{grid-template-columns:1fr; gap:.4rem; padding:.75rem}
  .lavio-flow-row span{justify-content:flex-start; width:max-content}
  .integration-marquee{padding:1.25rem 0 1.6rem}
  .marquee-track span{padding:.62rem .82rem; font-size:12px}
}
@media (prefers-reduced-motion: reduce){
  .lavio-flow-row,
  .lavio-flow-panel.is-changing .lavio-flow-panel-head,
  .lavio-flow-panel.is-changing .lavio-flow-demo,
  .lavio-flow-panel.is-changing .lavio-flow-features{
    animation:none !important;
  }
}

/* v4 sales scenario flow + benefit-led modules */
.lavio-flow-shell{
  grid-template-columns:minmax(260px,.36fr) minmax(0,1fr);
}
.lavio-flow-tabs{
  background:linear-gradient(180deg,rgba(255,255,255,.82),rgba(239,246,255,.62));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.9), 0 18px 46px rgba(37,99,235,.075);
}
.lavio-flow-tab{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:.75rem;
  min-height:54px;
}
.lavio-flow-tab::after{
  content:"";
  width:8px;
  height:8px;
  border-radius:50%;
  background:rgba(37,99,235,.18);
  box-shadow:0 0 0 4px rgba(37,99,235,.045);
}
.lavio-flow-tab.is-active::after{
  background:#fff;
  box-shadow:0 0 0 5px rgba(255,255,255,.18), 0 0 18px rgba(255,255,255,.48);
}
.lavio-flow-panel{
  min-height:500px;
  display:flex;
  flex-direction:column;
}
.lavio-flow-panel-head{max-width:760px}
.lavio-flow-tags,
.lavio-flow-features{
  position:relative;
  z-index:1;
  display:flex;
  flex-wrap:wrap;
  gap:.55rem;
  margin:1rem 0 .25rem;
}
.lavio-flow-tags span,
.lavio-flow-features span{
  display:inline-flex;
  align-items:center;
  min-height:32px;
  padding:.42rem .72rem;
  border:1px solid rgba(37,99,235,.16);
  border-radius:999px;
  background:linear-gradient(180deg,#fff,#eff6ff);
  color:#0f3f91;
  font-size:var(--fs-xs);
  font-weight:850;
  box-shadow:0 10px 24px rgba(37,99,235,.065);
}
.lavio-flow-demo{
  margin-top:1.35rem;
  padding:1rem;
  border:1px solid rgba(37,99,235,.13);
  border-radius:24px;
  background:linear-gradient(180deg,rgba(255,255,255,.72),rgba(239,246,255,.58));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.92), 0 18px 48px rgba(37,99,235,.07);
}
.lavio-chat-bubble{
  width:min(560px,100%);
  padding:.9rem 1rem;
  border:1px solid rgba(37,99,235,.13);
  border-radius:20px 20px 20px 6px;
  background:#fff;
  color:#0f172a;
  font-weight:750;
  line-height:1.48;
  box-shadow:0 14px 34px rgba(15,23,42,.065);
  animation:lavioFlowRow .42s var(--ease) both;
}
.lavio-chat-bubble.is-system{
  margin-left:auto;
  border-radius:20px 20px 6px 20px;
  border-color:rgba(37,99,235,.20);
  background:linear-gradient(135deg,#eff6ff,#fff);
  color:#123b7a;
  animation-delay:.06s;
}
.lavio-flow-path{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:.42rem;
  padding:.75rem;
  border-radius:18px;
  background:rgba(255,255,255,.72);
  border:1px solid rgba(37,99,235,.12);
}
.lavio-flow-path span{
  display:inline-flex;
  align-items:center;
  min-height:30px;
  padding:.34rem .58rem;
  border-radius:999px;
  background:#eff6ff;
  color:#0f3f91;
  font-size:12px;
  font-weight:850;
}
.lavio-flow-path i{font-style:normal; color:#2563eb; font-weight:900}
.lavio-flow-result{
  display:flex;
  align-items:center;
  gap:.5rem;
  margin-top:.25rem;
  padding:.82rem .95rem;
  border:1px solid rgba(37,99,235,.18);
  border-radius:18px;
  background:linear-gradient(135deg,#dbeafe,#f8fbff);
  color:#0f3f91;
  font-weight:900;
  box-shadow:0 12px 34px rgba(37,99,235,.075);
  animation:lavioFlowRow .42s .12s var(--ease) both;
}
.lavio-flow-result::before{
  content:"";
  width:9px;
  height:9px;
  border-radius:50%;
  background:#0a7cff;
  box-shadow:0 0 0 5px rgba(37,99,235,.11);
}
.lavio-result-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:.65rem;
  animation:lavioFlowRow .42s .18s var(--ease) both;
}
.lavio-result-grid span{
  min-height:76px;
  padding:.85rem;
  border:1px solid rgba(37,99,235,.13);
  border-radius:18px;
  background:rgba(255,255,255,.86);
  color:#1e293b;
  font-size:var(--fs-sm);
  font-weight:800;
  line-height:1.35;
  box-shadow:0 12px 30px rgba(15,23,42,.05);
}
.lavio-flow-cta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  margin-top:1.25rem;
  padding:1.15rem 1.25rem;
  border:1px solid rgba(37,99,235,.14);
  border-radius:24px;
  background:linear-gradient(180deg,rgba(255,255,255,.90),rgba(239,246,255,.76));
  box-shadow:0 18px 54px rgba(37,99,235,.08), inset 0 1px 0 rgba(255,255,255,.94);
}
.lavio-flow-cta h3{font-size:var(--fs-2xl); margin:0 0 .35rem}
.lavio-flow-cta p{margin:0; max-width:72ch; color:#475569}
.lavio-flow-cta .btn{flex:0 0 auto}

.lavio-modules-section{
  background:linear-gradient(180deg,#fff 0%,#f8fbff 100%);
}
.lavio-sales-modules .b{
  border-color:rgba(37,99,235,.13);
  background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(248,251,255,.90));
  box-shadow:0 18px 52px rgba(37,99,235,.075), inset 0 1px 0 rgba(255,255,255,.95);
}
.lavio-sales-modules .b:hover{
  border-color:rgba(37,99,235,.28);
  box-shadow:0 24px 68px rgba(37,99,235,.13), inset 0 1px 0 rgba(255,255,255,.98);
}
.lavio-sales-modules .b .ico img{
  width:23px;
  height:23px;
  object-fit:contain;
}
.lavio-sales-modules .b h4{
  font-size:clamp(1.15rem,1.6vw,1.45rem);
  letter-spacing:-.025em;
}
.lavio-sales-modules .b p{
  color:#475569;
  line-height:1.6;
  margin-bottom:1.15rem;
}
.module-flow{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:.45rem;
  margin-top:auto;
  padding-top:1rem;
  border-top:1px solid rgba(37,99,235,.12);
}
.module-flow span{
  display:inline-flex;
  align-items:center;
  min-height:30px;
  padding:.34rem .58rem;
  border:1px solid rgba(37,99,235,.14);
  border-radius:999px;
  background:#eff6ff;
  color:#0f3f91;
  font-size:12px;
  font-weight:850;
}
.module-flow i{
  font-style:normal;
  color:#2563eb;
  font-weight:900;
}
.lavio-system-card{
  background:linear-gradient(135deg,#0f3f91,#0a7cff)!important;
  color:rgba(255,255,255,.88)!important;
  border-color:transparent!important;
}
.lavio-system-card h4{color:#fff}
.lavio-system-card p{color:rgba(255,255,255,.78)!important}
.lavio-system-card .ico{
  background:rgba(255,255,255,.14)!important;
  color:#fff!important;
}
.lavio-system-card .ico img{width:52px!important; height:auto!important}
.lavio-system-card .visual{
  border-top:1px solid rgba(255,255,255,.16);
  padding-top:1rem;
  margin-top:auto;
  color:#fff;
  box-shadow:none;
}
.lavio-system-card .visual span{font-weight:900; color:#fff}

@media(max-width:980px){
  .lavio-flow-panel{min-height:0}
  .lavio-flow-cta{align-items:flex-start; flex-direction:column}
}
@media(max-width:720px){
  .lavio-flow-demo{padding:.75rem; border-radius:20px}
  .lavio-result-grid{grid-template-columns:1fr}
  .lavio-result-grid span{min-height:0}
  .lavio-chat-bubble{font-size:14px}
  .lavio-flow-cta{border-radius:20px; padding:1rem}
  .lavio-flow-cta .btn{width:100%; justify-content:center; white-space:normal; text-align:center}
  .module-flow span{font-size:11px}
}

/* v5 sales flow board + home pricing summary */
.lavio-sales-board-section{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(820px 420px at 12% 18%, rgba(37,99,235,.10), transparent 64%),
    radial-gradient(700px 360px at 88% 34%, rgba(56,189,248,.10), transparent 62%),
    linear-gradient(180deg,#fff 0%,#f8fbff 100%);
}
.lavio-sales-board-section::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  opacity:.36;
  background-image:radial-gradient(circle, rgba(37,99,235,.16) 1px, transparent 1.8px), linear-gradient(rgba(37,99,235,.055) 1px, transparent 1px), linear-gradient(90deg, rgba(37,99,235,.045) 1px, transparent 1px);
  background-size:26px 26px, 56px 56px, 56px 56px;
  mask-image:linear-gradient(180deg, transparent, #000 14%, #000 86%, transparent);
}
.lavio-sales-board-section .container{position:relative; z-index:1}
.lavio-sales-board{
  position:relative;
  display:grid;
  grid-template-columns:minmax(230px,.92fr) minmax(360px,1.26fr) minmax(220px,.82fr);
  gap:clamp(1rem,2.5vw,1.35rem);
  align-items:stretch;
  padding:clamp(.9rem,2vw,1.15rem);
  border:1px solid rgba(37,99,235,.14);
  border-radius:34px;
  background:linear-gradient(180deg,rgba(255,255,255,.80),rgba(239,246,255,.58));
  box-shadow:0 28px 92px rgba(37,99,235,.11), inset 0 1px 0 rgba(255,255,255,.92);
  backdrop-filter:blur(18px);
  isolation:isolate;
}
.lavio-sales-board::before,
.lavio-sales-board::after{
  content:"";
  position:absolute;
  top:50%;
  width:clamp(38px,4vw,64px);
  height:2px;
  background:linear-gradient(90deg,transparent,rgba(37,99,235,.30),transparent);
  opacity:.7;
  transition:opacity var(--t-base) var(--ease);
}
.lavio-sales-board::before{left:29%}
.lavio-sales-board::after{right:25%}
.lavio-sales-board:hover::before,
.lavio-sales-board:hover::after{opacity:1}
.sales-board-column{display:flex; flex-direction:column; gap:.82rem}
.sales-board-label{
  width:max-content;
  padding:.36rem .65rem;
  border:1px solid rgba(37,99,235,.16);
  border-radius:999px;
  background:#eff6ff;
  color:#075dcf;
  font-family:var(--font-mono);
  font-size:11px;
  font-weight:900;
  letter-spacing:.05em;
  text-transform:uppercase;
}
.sales-channel-card,
.sales-output-card,
.sales-board-hub{
  position:relative;
  overflow:hidden;
  border:1px solid rgba(37,99,235,.14);
  background:linear-gradient(180deg,rgba(255,255,255,.94),rgba(248,251,255,.82));
  box-shadow:0 18px 52px rgba(37,99,235,.075), inset 0 1px 0 rgba(255,255,255,.94);
  transition:transform var(--t-base) var(--ease), border-color var(--t-base) var(--ease), box-shadow var(--t-base) var(--ease);
}
.sales-channel-card:hover,
.sales-output-card:hover,
.sales-board-hub:hover{
  transform:translateY(-5px);
  border-color:rgba(37,99,235,.30);
  box-shadow:0 26px 72px rgba(37,99,235,.14), 0 0 0 5px rgba(37,99,235,.045), inset 0 1px 0 rgba(255,255,255,.98);
}
.sales-channel-card{display:flex; flex-direction:column; gap:.55rem; padding:1rem; border-radius:22px; color:inherit}
.sales-channel-card.is-compact{padding:.95rem}
.sales-icon,
.price-icon{
  width:42px;
  height:42px;
  display:grid;
  place-items:center;
  border-radius:14px;
  background:linear-gradient(180deg,#fff,#eff6ff);
  border:1px solid rgba(37,99,235,.14);
  box-shadow:0 10px 24px rgba(37,99,235,.08);
}
.sales-icon img,.price-icon img{width:23px; height:23px; object-fit:contain}
.sales-channel-card strong{color:#0f172a; font-family:var(--font-display); font-size:1.05rem; line-height:1.15}
.sales-channel-card p{margin:0; color:#64748b; font-size:var(--fs-sm); line-height:1.5}
.mini-bubble{
  width:max-content;
  max-width:100%;
  padding:.48rem .68rem;
  border-radius:14px 14px 14px 4px;
  background:#eff6ff;
  color:#0f3f91;
  font-size:12px;
  font-weight:850;
}
.sales-channel-card small{color:#2563eb; font-weight:900}
.sales-board-center{display:flex; min-width:0}
.sales-board-hub{
  width:100%;
  min-height:100%;
  padding:clamp(1.15rem,2.4vw,1.55rem);
  border-radius:28px;
  background:
    radial-gradient(480px 220px at 76% 8%, rgba(37,99,235,.18), transparent 62%),
    linear-gradient(180deg,rgba(255,255,255,.96),rgba(248,251,255,.86));
  animation:lavioHubPulse 4.8s ease-in-out infinite;
}
.sales-board-hub::before{
  content:"";
  position:absolute;
  inset:0;
  opacity:.26;
  pointer-events:none;
  background-image:radial-gradient(circle, rgba(37,99,235,.18) 1px, transparent 1.8px);
  background-size:24px 24px;
  mask-image:linear-gradient(135deg, transparent, #000 24%, #000 76%, transparent);
}
@keyframes lavioHubPulse{
  0%,100%{box-shadow:0 22px 70px rgba(37,99,235,.10), 0 0 0 0 rgba(37,99,235,.0), inset 0 1px 0 rgba(255,255,255,.95)}
  50%{box-shadow:0 28px 82px rgba(37,99,235,.15), 0 0 0 8px rgba(37,99,235,.035), inset 0 1px 0 rgba(255,255,255,.98)}
}
.hub-topline,
.hub-card-head,
.hub-dashboard,
.hub-support-grid{position:relative; z-index:1}
.hub-topline{display:flex; align-items:center; gap:.45rem; color:#075dcf; font-family:var(--font-mono); font-size:11px; font-weight:900; letter-spacing:.04em; text-transform:uppercase; margin-bottom:1rem}
.hub-card-head{display:flex; justify-content:space-between; gap:1rem; align-items:flex-start; margin-bottom:1rem}
.hub-card-head h3{font-size:clamp(1.5rem,2.4vw,2rem); margin:0 0 .35rem; letter-spacing:-.035em}
.hub-card-head p{margin:0; color:#64748b; line-height:1.55}
.hub-status{flex:0 0 auto; padding:.38rem .62rem; border-radius:999px; background:#dbeafe; color:#1d4ed8; font-size:12px; font-weight:900}
.hub-dashboard{display:grid; gap:.55rem; margin-bottom:1rem}
.hub-row{display:flex; justify-content:space-between; gap:1rem; align-items:center; padding:.72rem .85rem; border:1px solid rgba(37,99,235,.11); border-radius:16px; background:rgba(255,255,255,.78); box-shadow:0 10px 24px rgba(15,23,42,.035)}
.hub-row span{color:#64748b; font-size:12px; font-weight:800}
.hub-row strong{color:#0f172a; font-size:13px; text-align:right}
.hub-support-grid{display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:.6rem}
.hub-support-grid a{display:flex; flex-direction:column; gap:.35rem; min-height:98px; padding:.75rem; border:1px solid rgba(37,99,235,.13); border-radius:18px; background:rgba(255,255,255,.72); color:inherit; transition:transform var(--t-base) var(--ease), border-color var(--t-base) var(--ease)}
.hub-support-grid a:hover{transform:translateY(-3px); border-color:rgba(37,99,235,.28)}
.hub-support-grid strong{font-size:13px; color:#0f172a; line-height:1.25}
.hub-support-grid span{font-size:11px; color:#2563eb; font-weight:850; line-height:1.35}
.sales-output-card{display:grid; grid-template-columns:auto 1fr; gap:.2rem .62rem; padding:.9rem; border-radius:20px}
.sales-output-card > span{grid-row:1 / span 2; width:10px; height:10px; margin-top:.3rem; border-radius:50%; background:#0a7cff; box-shadow:0 0 0 5px rgba(37,99,235,.10)}
.sales-output-card strong{color:#0f172a; font-size:14px}
.sales-output-card p{grid-column:2; margin:0; color:#64748b; font-size:12px; line-height:1.45}
.lavio-sales-final{
  position:relative;
  overflow:hidden;
  display:grid;
  grid-template-columns:1fr auto auto;
  align-items:center;
  gap:1rem;
  margin-top:1.15rem;
  padding:1.25rem 1.4rem;
  border:1px solid rgba(37,99,235,.18);
  border-radius:28px;
  background:linear-gradient(135deg,#eff6ff,#fff 48%,#dbeafe);
  box-shadow:0 22px 70px rgba(37,99,235,.12), inset 0 1px 0 rgba(255,255,255,.96);
  color:inherit;
}
.lavio-sales-final h3{font-size:var(--fs-2xl); margin:0 0 .35rem}
.lavio-sales-final p{margin:0; color:#475569; max-width:76ch}
.final-icons{display:flex; align-items:center; gap:.35rem}
.final-icons img{width:30px; height:30px; padding:5px; border-radius:10px; background:#fff; border:1px solid rgba(37,99,235,.13); box-shadow:0 8px 18px rgba(37,99,235,.08)}
.final-cta{display:inline-flex; align-items:center; min-height:40px; padding:.6rem .88rem; border-radius:999px; background:#2563eb; color:#fff; font-weight:900; box-shadow:0 14px 32px rgba(37,99,235,.22)}
.final-orbit{position:absolute; right:8%; top:50%; width:160px; height:80px; transform:translateY(-50%); opacity:.28; pointer-events:none}
.final-orbit span{position:absolute; inset:0; border:1px dashed rgba(37,99,235,.34); border-radius:50%; animation:lavioOrbitRing 32s linear infinite}
.final-orbit span:nth-child(2){inset:14px; animation-direction:reverse}.final-orbit span:nth-child(3){inset:28px}

.lavio-home-pricing{position:relative; overflow:hidden; background:linear-gradient(180deg,#fff 0%,#f8fbff 100%)}
.lavio-home-pricing::before{content:""; position:absolute; inset:0; pointer-events:none; opacity:.34; background-image:radial-gradient(circle, rgba(37,99,235,.15) 1px, transparent 1.8px); background-size:28px 28px; mask-image:linear-gradient(180deg, transparent, #000 16%, #000 84%, transparent)}
.lavio-home-pricing .container{position:relative; z-index:1}
.home-price-grid{display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:1rem}
.home-price-card{display:flex; flex-direction:column; gap:.72rem; min-height:100%; padding:1.2rem; border:1px solid rgba(37,99,235,.14); border-radius:24px; background:linear-gradient(180deg,rgba(255,255,255,.94),rgba(248,251,255,.86)); box-shadow:0 18px 52px rgba(37,99,235,.075), inset 0 1px 0 rgba(255,255,255,.95); color:inherit; transition:transform var(--t-base) var(--ease), border-color var(--t-base) var(--ease), box-shadow var(--t-base) var(--ease)}
.home-price-card:hover{transform:translateY(-5px); border-color:rgba(37,99,235,.30); box-shadow:0 26px 72px rgba(37,99,235,.14), 0 0 0 5px rgba(37,99,235,.045), inset 0 1px 0 rgba(255,255,255,.98)}
.home-price-card h3{font-size:var(--fs-xl); margin:0}
.home-price{font-family:var(--font-display); font-size:clamp(1.55rem,2.2vw,2rem); font-weight:800; color:#0f172a; letter-spacing:-.025em; line-height:1}
.home-price span{display:block; margin-top:.22rem; color:#64748b; font-family:var(--font-body); font-size:var(--fs-sm); font-weight:800; letter-spacing:0}
.home-price-card p{margin:0; color:#475569; font-size:var(--fs-sm); line-height:1.55}
.home-price-card ul{display:grid; gap:.42rem; margin-top:auto}
.home-price-card li{display:flex; gap:.45rem; color:#1e293b; font-size:13px; font-weight:750; line-height:1.35}
.home-price-card li::before{content:""; flex:0 0 16px; width:16px; height:16px; margin-top:1px; border-radius:50%; background:#dbeafe url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='%232563EB' stroke-width='3' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/10px no-repeat}
.home-price-note{display:grid; grid-template-columns:1fr auto; gap:.75rem 1rem; align-items:center; margin-top:1.1rem; padding:1.1rem 1.2rem; border:1px solid rgba(37,99,235,.14); border-radius:24px; background:linear-gradient(180deg,rgba(255,255,255,.90),rgba(239,246,255,.76)); box-shadow:0 18px 54px rgba(37,99,235,.08), inset 0 1px 0 rgba(255,255,255,.94)}
.home-price-note p{margin:0; color:#475569; max-width:82ch}.home-price-note p strong{color:#0f172a}.home-price-note > span{grid-column:1; color:#2563eb; font-weight:900; font-size:var(--fs-sm)}
.home-price-actions{grid-column:2; grid-row:1 / span 2; display:flex; gap:.65rem; flex-wrap:wrap; justify-content:flex-end}
@media(max-width:1080px){
  .lavio-sales-board{grid-template-columns:1fr; gap:1rem}.lavio-sales-board::before,.lavio-sales-board::after{display:none}.sales-board-center{order:-1}.sales-inputs{display:grid; grid-template-columns:repeat(3,minmax(0,1fr))}.sales-outputs{display:grid; grid-template-columns:repeat(2,minmax(0,1fr))}.sales-board-label{grid-column:1/-1}.home-price-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:720px){
  .lavio-sales-board{padding:.75rem; border-radius:24px}.sales-inputs,.sales-outputs{grid-template-columns:1fr}.hub-card-head,.lavio-sales-final{grid-template-columns:1fr}.hub-status{width:max-content}.hub-row{align-items:flex-start; flex-direction:column; gap:.22rem}.hub-row strong{text-align:left}.hub-support-grid{grid-template-columns:1fr}.final-icons{order:-1}.final-cta{width:100%; justify-content:center}.home-price-grid{grid-template-columns:1fr}.home-price-note{grid-template-columns:1fr}.home-price-note > span,.home-price-actions{grid-column:1; grid-row:auto}.home-price-actions{justify-content:stretch}.home-price-actions .btn{width:100%; justify-content:center; white-space:normal; text-align:center}
}
@media (prefers-reduced-motion: reduce){.sales-board-hub,.final-orbit span{animation:none!important}.sales-channel-card,.sales-output-card,.sales-board-hub,.home-price-card{transition:none!important}}

/* v6 sales board clarity copy support */
.sales-board-label{
  width:auto;
  max-width:100%;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:.22rem;
  text-transform:none;
  letter-spacing:0;
  line-height:1.25;
}
.sales-board-label strong{
  color:#075dcf;
  font-family:var(--font-display);
  font-size:13px;
  font-weight:900;
  letter-spacing:-.01em;
}
.sales-board-label small{
  color:#64748b;
  font-family:var(--font-body);
  font-size:12px;
  font-weight:700;
  line-height:1.4;
}
.hub-topline{
  align-items:flex-start;
  line-height:1.35;
}
.lavio-sales-clarity-cta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  margin-top:1rem;
  padding:1.1rem 1.2rem;
  border:1px solid rgba(37,99,235,.14);
  border-radius:24px;
  background:linear-gradient(180deg,rgba(255,255,255,.92),rgba(239,246,255,.78));
  box-shadow:0 18px 54px rgba(37,99,235,.08), inset 0 1px 0 rgba(255,255,255,.94);
}
.lavio-sales-clarity-cta h3{
  margin:0 0 .35rem;
  font-size:var(--fs-2xl);
  letter-spacing:-.025em;
}
.lavio-sales-clarity-cta p{
  margin:0;
  max-width:72ch;
  color:#475569;
}
.sales-clarity-actions{
  display:flex;
  gap:.65rem;
  flex-wrap:wrap;
  justify-content:flex-end;
  flex:0 0 auto;
}
@media(max-width:860px){
  .lavio-sales-clarity-cta{align-items:flex-start; flex-direction:column}
  .sales-clarity-actions{width:100%; justify-content:stretch}
  .sales-clarity-actions .btn{flex:1; justify-content:center; white-space:normal; text-align:center}
}
@media(max-width:520px){
  .sales-clarity-actions{flex-direction:column}
  .sales-clarity-actions .btn{width:100%}
}

/* v7 solution map / internal linking hub */
.lavio-solution-map{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(780px 420px at 12% 14%, rgba(37,99,235,.10), transparent 64%),
    radial-gradient(680px 360px at 86% 26%, rgba(56,189,248,.10), transparent 62%),
    linear-gradient(180deg,#fff 0%,#f8fbff 100%);
}
.lavio-solution-map::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  opacity:.34;
  background-image:
    radial-gradient(circle, rgba(37,99,235,.16) 1px, transparent 1.8px),
    linear-gradient(rgba(37,99,235,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(37,99,235,.045) 1px, transparent 1px);
  background-size:26px 26px, 58px 58px, 58px 58px;
  mask-image:linear-gradient(180deg, transparent, #000 14%, #000 86%, transparent);
}
.lavio-solution-map .container{position:relative;z-index:1}
.solution-filter-row{
  display:flex;
  gap:.55rem;
  overflow-x:auto;
  overscroll-behavior-inline:contain;
  padding:.2rem .1rem .85rem;
  margin-top:-.75rem;
  margin-bottom:1rem;
}
.solution-filter-row::-webkit-scrollbar{height:6px}
.solution-filter-row::-webkit-scrollbar-thumb{background:rgba(37,99,235,.22);border-radius:999px}
.solution-filter-row span{
  flex:0 0 auto;
  display:inline-flex;
  align-items:center;
  min-height:34px;
  padding:.46rem .78rem;
  border:1px solid rgba(37,99,235,.15);
  border-radius:999px;
  background:linear-gradient(180deg,rgba(255,255,255,.92),rgba(239,246,255,.78));
  color:#0f3f91;
  font-size:var(--fs-xs);
  font-weight:850;
  box-shadow:0 10px 24px rgba(37,99,235,.06);
}
.solution-card-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:1rem;
}
.solution-card{
  position:relative;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  gap:.7rem;
  min-height:100%;
  padding:1.15rem;
  border:1px solid rgba(37,99,235,.14);
  border-radius:24px;
  background:
    radial-gradient(260px 140px at 100% 0%, rgba(37,99,235,.08), transparent 62%),
    linear-gradient(180deg,rgba(255,255,255,.95),rgba(248,251,255,.86));
  color:inherit;
  box-shadow:0 18px 52px rgba(37,99,235,.075), inset 0 1px 0 rgba(255,255,255,.95);
  transition:transform var(--t-base) var(--ease), border-color var(--t-base) var(--ease), box-shadow var(--t-base) var(--ease);
}
.solution-card:hover{
  transform:translateY(-5px);
  border-color:rgba(37,99,235,.31);
  box-shadow:0 26px 74px rgba(37,99,235,.14),0 0 0 5px rgba(37,99,235,.045),inset 0 1px 0 rgba(255,255,255,.98);
}
.solution-card.is-featured{grid-column:span 2;min-height:260px}
.solution-icon{
  width:44px;
  height:44px;
  display:grid;
  place-items:center;
  border:1px solid rgba(37,99,235,.14);
  border-radius:15px;
  background:linear-gradient(180deg,#fff,#eff6ff);
  box-shadow:0 10px 24px rgba(37,99,235,.08);
}
.solution-icon img{width:24px;height:24px;object-fit:contain}
.solution-kicker{
  width:max-content;
  max-width:100%;
  padding:.28rem .52rem;
  border-radius:999px;
  background:#eff6ff;
  color:#075dcf;
  font-size:11px;
  font-weight:900;
}
.solution-card h3{font-size:clamp(1.18rem,1.6vw,1.42rem);margin:0;letter-spacing:-.025em}
.solution-card p{margin:0;color:#475569;font-size:var(--fs-sm);line-height:1.58}
.solution-tags{display:flex;flex-wrap:wrap;gap:.42rem;margin-top:auto}
.solution-tags span{
  display:inline-flex;
  align-items:center;
  min-height:28px;
  padding:.32rem .5rem;
  border:1px solid rgba(37,99,235,.13);
  border-radius:999px;
  background:rgba(255,255,255,.82);
  color:#0f3f91;
  font-size:11px;
  font-weight:850;
}
.solution-card strong{display:inline-flex;align-items:center;margin-top:.15rem;color:#2563eb;font-size:var(--fs-sm);font-weight:900}
.solution-subsection{
  margin-top:1rem;
  padding:1.15rem;
  border:1px solid rgba(37,99,235,.14);
  border-radius:28px;
  background:linear-gradient(180deg,rgba(255,255,255,.86),rgba(239,246,255,.68));
  box-shadow:0 18px 54px rgba(37,99,235,.08), inset 0 1px 0 rgba(255,255,255,.94);
}
.solution-subhead{display:flex;justify-content:space-between;gap:1rem;align-items:end;margin-bottom:.9rem}
.solution-subhead h3,.solution-guides h3{margin:0;font-size:var(--fs-2xl)}
.solution-subhead p,.solution-guides p{margin:.35rem 0 0;color:#64748b;max-width:64ch}
.sector-solution-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.75rem}
.sector-solution-grid a{
  display:flex;
  flex-direction:column;
  gap:.35rem;
  min-height:120px;
  padding:.9rem;
  border:1px solid rgba(37,99,235,.13);
  border-radius:20px;
  background:rgba(255,255,255,.82);
  color:inherit;
  box-shadow:0 12px 32px rgba(15,23,42,.045);
  transition:transform var(--t-base) var(--ease), border-color var(--t-base) var(--ease), box-shadow var(--t-base) var(--ease);
}
.sector-solution-grid a:hover{transform:translateY(-4px);border-color:rgba(37,99,235,.28);box-shadow:0 18px 46px rgba(37,99,235,.11)}
.sector-solution-grid strong{color:#0f172a;font-family:var(--font-display);font-size:1rem}
.sector-solution-grid span{color:#64748b;font-size:var(--fs-sm);line-height:1.5}
.solution-guides{
  display:grid;
  grid-template-columns:minmax(260px,1fr) repeat(3,minmax(160px,.7fr));
  gap:.75rem;
  align-items:stretch;
  margin-top:.9rem;
}
.solution-guides > div,
.solution-guides > a{
  padding:1rem;
  border:1px solid rgba(37,99,235,.13);
  border-radius:20px;
  background:rgba(255,255,255,.84);
  box-shadow:0 12px 32px rgba(15,23,42,.045);
}
.solution-guides > a{
  display:flex;
  align-items:center;
  color:#0f3f91;
  font-weight:900;
  line-height:1.35;
  transition:transform var(--t-base) var(--ease), border-color var(--t-base) var(--ease), box-shadow var(--t-base) var(--ease);
}
.solution-guides > a:hover{transform:translateY(-4px);border-color:rgba(37,99,235,.28);box-shadow:0 18px 46px rgba(37,99,235,.11)}
@media(max-width:1080px){
  .solution-card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .sector-solution-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .solution-guides{grid-template-columns:1fr 1fr}
  .solution-guides > div{grid-column:1/-1}
}
@media(max-width:680px){
  .solution-card-grid,.sector-solution-grid,.solution-guides{grid-template-columns:1fr}
  .solution-card.is-featured{grid-column:auto;min-height:0}
  .solution-subhead{display:block}
  .solution-subsection{padding:.9rem;border-radius:22px}
}

/* v40 portfolio case study upgrade */
.portfolio-hero{background:radial-gradient(circle at 14% 18%,rgba(37,99,235,.10),transparent 32%),linear-gradient(180deg,#fff 0%,#f8fbff 100%)}
.portfolio-hero .lead{max-width:760px}
.portfolio-hero-actions{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:1.5rem}
.portfolio-featured,.portfolio-cards-section,.portfolio-final-cta{position:relative;overflow:hidden;background:linear-gradient(180deg,#fff 0%,#f8fbff 100%)}
.portfolio-featured:before,.home-projects-preview:before{content:"";position:absolute;inset:0;opacity:.34;background-image:radial-gradient(rgba(37,99,235,.10) 1px,transparent 1px),linear-gradient(rgba(37,99,235,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(37,99,235,.045) 1px,transparent 1px);background-size:18px 18px,48px 48px,48px 48px;mask-image:linear-gradient(180deg,transparent,#000 18%,#000 82%,transparent);pointer-events:none}
.featured-case{position:relative;display:grid;grid-template-columns:minmax(0,.92fr) minmax(0,1.08fr);gap:clamp(22px,3.4vw,46px);align-items:start;padding:clamp(22px,3vw,38px);border:1px solid rgba(191,219,254,.95);border-radius:32px;background:rgba(255,255,255,.88);box-shadow:0 28px 90px rgba(15,23,42,.10);backdrop-filter:blur(18px)}
.featured-case:after{content:"";position:absolute;inset:auto -12% -34% 42%;height:260px;border-radius:50%;background:radial-gradient(circle,rgba(37,99,235,.13),transparent 70%);pointer-events:none}
.featured-case-copy,.featured-case-visual{position:relative;z-index:1}
.featured-case .case-tags{margin:0!important}
.featured-case h2{margin-top:1rem;font-size:clamp(2rem,4vw,3.8rem);line-height:.96;letter-spacing:-.055em}
.featured-intro{margin-top:1rem;color:var(--ink-3);font-size:var(--fs-lg);line-height:1.65}
.case-story-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:1.5rem}
.case-story-block,.case-outcome{border:1px solid rgba(219,234,254,.98);border-radius:20px;background:linear-gradient(180deg,#fff,#f8fbff);padding:18px;box-shadow:0 14px 34px rgba(15,23,42,.05)}
.case-story-block h3,.case-outcome h3{font-size:var(--fs-lg);letter-spacing:-.025em;margin-bottom:.7rem}
.case-story-block ul{display:grid;gap:.55rem;color:var(--ink-3);font-size:var(--fs-sm)}
.case-story-block li{position:relative;padding-left:1.05rem;line-height:1.55}
.case-story-block li:before{content:"";position:absolute;left:0;top:.62em;width:6px;height:6px;border-radius:50%;background:var(--accent-2)}
.module-cloud{display:flex;flex-wrap:wrap;gap:.55rem;margin-top:1.25rem}
.module-cloud span,.home-project-tags span,.home-project-mini span{display:inline-flex;align-items:center;min-height:34px;padding:.45rem .75rem;border:1px solid #bfdbfe;border-radius:999px;background:#eef6ff;color:#075dcf;font-size:12px;font-weight:800}
.case-outcome{margin-top:1.25rem;background:linear-gradient(135deg,#eef6ff,#fff)}
.case-outcome p{color:var(--ink-3);line-height:1.7}
.featured-case-visual{display:grid;gap:14px;min-width:0}
.mockup-frame{overflow:hidden;border:1px solid rgba(191,219,254,.95);border-radius:22px;background:#fff;box-shadow:0 18px 48px rgba(15,23,42,.10)}
.mockup-frame-large{border-radius:26px}
.mockup-top{display:flex;align-items:center;gap:7px;min-height:38px;padding:0 13px;border-bottom:1px solid rgba(219,234,254,.9);background:linear-gradient(180deg,#fff,#f8fbff)}
.mockup-top span{width:9px;height:9px;border-radius:50%;background:#bfdbfe}
.mockup-top b{margin-left:auto;color:#075dcf;font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase}
.mockup-frame img,.home-dashboard-card img{width:100%;aspect-ratio:16/8.1;object-fit:cover;object-position:top left}
.mockup-mini-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.mockup-mini-grid .mockup-frame img{aspect-ratio:16/9.5}
.mockup-frame figcaption{padding:10px 13px 12px;color:var(--ink-3);font-size:12px;font-weight:700}
.portfolio-project-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}
.portfolio-project-card{display:flex;flex-direction:column;gap:.8rem;min-height:100%;padding:22px;border:1px solid rgba(219,234,254,.98);border-radius:24px;background:#fff;box-shadow:0 18px 50px rgba(15,23,42,.07);transition:transform var(--t-base) var(--ease),box-shadow var(--t-base) var(--ease),border-color var(--t-base) var(--ease)}
.portfolio-project-card:hover{transform:translateY(-4px);border-color:rgba(37,99,235,.28);box-shadow:0 26px 70px rgba(15,23,42,.11)}
.project-type{width:max-content;max-width:100%;padding:.35rem .65rem;border:1px solid #bfdbfe;border-radius:999px;background:#eef6ff;color:#075dcf;font-size:11px;font-weight:850}
.portfolio-project-card h3{font-size:var(--fs-xl);letter-spacing:-.03em}
.portfolio-project-card p{color:var(--ink-3);font-size:var(--fs-sm);line-height:1.62}
.portfolio-project-card a:not(.btn){color:#075dcf;font-weight:750}
.project-card-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:auto;padding-top:.5rem;font-size:var(--fs-sm)}
.portfolio-cta-card{padding:clamp(2rem,5vw,3.5rem);border:1px solid rgba(191,219,254,.95);border-radius:32px;background:radial-gradient(circle at 80% 12%,rgba(37,99,235,.14),transparent 32%),linear-gradient(135deg,#fff,#eef6ff);box-shadow:0 26px 80px rgba(15,23,42,.10)}
.portfolio-cta-card h2{margin:.9rem auto 1rem;max-width:820px;font-size:var(--fs-4xl)}
.portfolio-cta-card p{max-width:680px;margin:0 auto 1.6rem;color:var(--ink-3);font-size:var(--fs-lg)}
.portfolio-cta-actions{display:flex;justify-content:center;gap:.75rem;flex-wrap:wrap}
.home-projects-preview{position:relative;overflow:hidden;background:linear-gradient(180deg,#fff 0%,#f8fbff 100%)}
.home-featured-project{position:relative;display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);gap:clamp(20px,3vw,40px);align-items:center;padding:clamp(22px,3vw,36px);border:1px solid rgba(191,219,254,.95);border-radius:30px;background:rgba(255,255,255,.9);box-shadow:0 24px 80px rgba(15,23,42,.09)}
.home-project-copy,.home-project-visual{position:relative;z-index:1}
.home-project-copy h3{margin-top:1rem;font-size:clamp(1.7rem,3vw,3rem);line-height:1;letter-spacing:-.05em}
.home-project-copy p{margin-top:1rem;color:var(--ink-3);font-size:var(--fs-lg);line-height:1.65}
.home-project-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.25rem}
.home-project-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.5rem}
.home-project-visual{min-width:0;padding:12px}
.home-dashboard-card{overflow:hidden;border:1px solid rgba(191,219,254,.95);border-radius:24px;background:#fff;box-shadow:0 20px 58px rgba(37,99,235,.14)}
.home-project-mini{display:flex;flex-wrap:wrap;gap:.5rem;margin:-18px 18px 0;position:relative;z-index:2}
.home-project-footer{display:flex;justify-content:center;margin-top:2rem}
@media(max-width:1100px){.featured-case,.home-featured-project{grid-template-columns:1fr}.portfolio-project-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:720px){.portfolio-hero-actions,.home-project-actions,.portfolio-cta-actions{align-items:stretch}.portfolio-hero-actions .btn,.home-project-actions .btn,.portfolio-cta-actions .btn{width:100%;justify-content:center}.featured-case,.home-featured-project{padding:18px;border-radius:24px}.featured-case h2{font-size:clamp(2rem,12vw,3rem)}.case-story-grid,.mockup-mini-grid,.portfolio-project-grid{grid-template-columns:1fr}.mockup-frame,.mockup-frame-large,.home-dashboard-card{border-radius:18px}.mockup-frame img,.home-dashboard-card img{aspect-ratio:16/10}.home-project-visual{padding:0}.home-project-mini{margin:10px 0 0}}

/* v41 Bakir Elektronik showcase gallery */
.bakir-showcase{
  gap:18px;
  align-self:stretch;
}
.showcase-head{
  padding:18px;
  border:1px solid rgba(191,219,254,.95);
  border-radius:24px;
  background:linear-gradient(135deg,#fff,#eef6ff);
  box-shadow:0 16px 42px rgba(37,99,235,.08);
}
.showcase-head span{
  display:block;
  color:#075dcf;
  font-family:var(--font-mono);
  font-size:11px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.showcase-head p{
  margin-top:.45rem;
  color:var(--ink-3);
  font-size:var(--fs-sm);
  line-height:1.55;
}
.showcase-gallery{
  display:grid;
  gap:14px;
  min-width:0;
}
.showcase-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}
.showcase-card{
  position:relative;
  display:grid;
  grid-template-rows:auto minmax(0,1fr) auto;
  overflow:hidden;
  min-width:0;
  text-align:left;
  border:1px solid rgba(191,219,254,.95);
  border-radius:22px;
  background:rgba(255,255,255,.94);
  box-shadow:0 16px 44px rgba(15,23,42,.08);
  isolation:isolate;
  cursor:zoom-in;
  opacity:0;
  transform:translateY(18px);
  transition:opacity .55s var(--ease),transform .55s var(--ease),border-color .24s var(--ease),box-shadow .24s var(--ease);
  transition-delay:calc(var(--reveal-i,0) * 58ms);
}
.showcase-card:before{
  content:"";
  position:absolute;
  inset:-1px;
  z-index:-1;
  background:linear-gradient(135deg,rgba(37,99,235,.18),transparent 34%,rgba(14,165,233,.16));
  opacity:0;
  transition:opacity .24s var(--ease);
}
.showcase-card.is-visible{opacity:1;transform:none}
.showcase-card:hover,
.showcase-card:focus-visible{
  transform:translateY(-5px);
  border-color:rgba(37,99,235,.35);
  box-shadow:0 28px 76px rgba(37,99,235,.16),0 12px 28px rgba(15,23,42,.08);
}
.showcase-card:hover:before,
.showcase-card:focus-visible:before{opacity:1}
.showcase-card-featured{
  border-radius:28px;
  box-shadow:0 24px 74px rgba(37,99,235,.13);
}
.showcase-card-featured .showcase-image img{aspect-ratio:16/8.2}
.showcase-image{
  display:block;
  overflow:hidden;
  background:#f8fbff;
}
.showcase-image img{
  width:100%;
  aspect-ratio:16/9.5;
  object-fit:cover;
  object-position:top left;
  transform:scale(1.001);
  transition:transform .5s var(--ease),filter .5s var(--ease);
}
.showcase-card:hover .showcase-image img,
.showcase-card:focus-visible .showcase-image img{
  transform:scale(1.035);
  filter:saturate(1.04) contrast(1.02);
}
.showcase-card .mockup-top{
  display:flex;
  min-height:38px;
  flex-shrink:0;
}
.mockup-top i{
  display:block;
  width:9px;
  height:9px;
  border-radius:50%;
  background:#bfdbfe;
}
.showcase-caption{
  display:grid;
  gap:3px;
  padding:13px 15px 15px;
  background:linear-gradient(180deg,#fff,#f8fbff);
}
.showcase-caption strong{
  color:var(--ink);
  font-family:var(--font-display);
  font-size:var(--fs-md);
  letter-spacing:-.02em;
}
.showcase-caption small{
  color:var(--ink-4);
  font-size:12px;
  line-height:1.45;
}
.gallery-lightbox{
  position:fixed;
  inset:0;
  z-index:9999;
  display:grid;
  grid-template-columns:minmax(44px,1fr) minmax(0,1120px) minmax(44px,1fr);
  align-items:center;
  gap:12px;
  padding:clamp(14px,3vw,30px);
  background:rgba(15,23,42,.48);
  backdrop-filter:blur(14px);
  opacity:0;
  pointer-events:none;
  transition:opacity .22s var(--ease);
}
.gallery-lightbox.is-open{
  opacity:1;
  pointer-events:auto;
}
.gallery-lightbox-panel{
  grid-column:2;
  overflow:hidden;
  border:1px solid rgba(219,234,254,.65);
  border-radius:24px;
  background:#fff;
  box-shadow:0 32px 110px rgba(2,6,23,.35);
  transform:translateY(14px) scale(.985);
  transition:transform .24s var(--ease);
}
.gallery-lightbox.is-open .gallery-lightbox-panel{transform:none}
.gallery-lightbox-panel img{
  width:100%;
  max-height:calc(100dvh - 170px);
  object-fit:contain;
  background:#f8fbff;
}
.gallery-lightbox-panel figcaption{
  display:grid;
  gap:4px;
  padding:14px 18px 16px;
  border-top:1px solid rgba(219,234,254,.95);
}
.gallery-lightbox-panel strong{
  color:var(--ink);
  font-family:var(--font-display);
  font-size:var(--fs-lg);
}
.gallery-lightbox-panel span{
  color:var(--ink-3);
  font-size:var(--fs-sm);
}
.gallery-lightbox-close,
.gallery-lightbox-nav{
  display:grid;
  place-items:center;
  border:1px solid rgba(255,255,255,.42);
  background:rgba(255,255,255,.92);
  color:#075dcf;
  box-shadow:0 18px 48px rgba(2,6,23,.20);
}
.gallery-lightbox-close{
  position:absolute;
  top:18px;
  right:18px;
  width:42px;
  height:42px;
  border-radius:999px;
  font-size:28px;
  line-height:1;
}
.gallery-lightbox-nav{
  width:46px;
  height:64px;
  border-radius:999px;
  font-size:38px;
  line-height:1;
}
.gallery-lightbox-prev{grid-column:1;justify-self:end}
.gallery-lightbox-next{grid-column:3;justify-self:start}
.gallery-lightbox-close:hover,
.gallery-lightbox-nav:hover{
  border-color:rgba(191,219,254,.9);
  background:#fff;
  box-shadow:0 22px 60px rgba(37,99,235,.20);
}
body.gallery-lock{overflow:hidden}
@media(max-width:720px){
  .showcase-head{border-radius:18px;padding:15px}
  .showcase-grid{grid-template-columns:1fr}
  .showcase-card,.showcase-card-featured{border-radius:18px}
  .showcase-card-featured .showcase-image img,
  .showcase-image img{aspect-ratio:16/10}
  .gallery-lightbox{
    grid-template-columns:1fr;
    grid-template-rows:1fr auto;
    gap:10px;
    padding:64px 12px 14px;
  }
  .gallery-lightbox-panel{
    grid-column:1;
    width:100%;
    align-self:center;
    border-radius:18px;
  }
  .gallery-lightbox-panel img{max-height:calc(100dvh - 210px)}
  .gallery-lightbox-prev,
  .gallery-lightbox-next{
    grid-column:1;
    grid-row:2;
    width:48px;
    height:48px;
    font-size:32px;
  }
  .gallery-lightbox-prev{justify-self:start}
  .gallery-lightbox-next{justify-self:end}
  .gallery-lightbox-close{top:12px;right:12px}
}
@media(prefers-reduced-motion:reduce){
  .showcase-card,
  .showcase-image img,
  .gallery-lightbox,
  .gallery-lightbox-panel{
    transition:none!important;
  }
  .showcase-card{opacity:1!important;transform:none!important}
}

/* v42 Bakir Elektronik premium case study reset */
.bakir-case-section{
  background:
    radial-gradient(760px 420px at 82% 8%,rgba(37,99,235,.14),transparent 62%),
    radial-gradient(520px 320px at 9% 36%,rgba(14,165,233,.10),transparent 66%),
    linear-gradient(180deg,#fff 0%,#f8fbff 100%);
}
.bakir-case{
  position:relative;
  overflow:hidden;
  padding:clamp(20px,3vw,38px);
  border:1px solid rgba(191,219,254,.95);
  border-radius:34px;
  background:rgba(255,255,255,.88);
  box-shadow:0 28px 90px rgba(15,23,42,.10);
  backdrop-filter:blur(18px);
}
.bakir-case:before{
  content:"";
  position:absolute;
  inset:0;
  opacity:.28;
  background-image:linear-gradient(rgba(37,99,235,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(37,99,235,.06) 1px,transparent 1px);
  background-size:42px 42px;
  mask-image:linear-gradient(180deg,#000,transparent 78%);
  pointer-events:none;
}
.bakir-case > *{position:relative;z-index:1}
.bakir-case-hero{
  display:grid;
  grid-template-columns:minmax(0,.88fr) minmax(0,1.12fr);
  gap:clamp(24px,4vw,54px);
  align-items:center;
}
.bakir-tags{margin:0!important}
.bakir-tags .case-tag{
  background:#eef6ff!important;
  color:#075dcf!important;
  border:1px solid #bfdbfe!important;
  font-weight:850!important;
}
.bakir-hero-copy h2{
  margin-top:1rem;
  font-size:clamp(2.2rem,4.6vw,4.25rem);
  line-height:.95;
  letter-spacing:-.06em;
  max-width:10.8ch;
}
.bakir-hero-copy p{
  margin-top:1.1rem;
  max-width:62ch;
  color:var(--ink-3);
  font-size:var(--fs-lg);
  line-height:1.68;
}
.bakir-hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:.75rem;
  margin-top:1.6rem;
}
.bakir-hero-preview{
  position:relative;
  overflow:hidden;
  min-width:0;
  border:1px solid rgba(147,197,253,.95);
  border-radius:30px;
  background:#fff;
  box-shadow:0 28px 86px rgba(37,99,235,.16),0 12px 26px rgba(15,23,42,.08);
  cursor:zoom-in;
  transition:transform .24s var(--ease),box-shadow .24s var(--ease),border-color .24s var(--ease);
}
.bakir-hero-preview:hover,
.bakir-hero-preview:focus-visible{
  transform:translateY(-5px);
  border-color:rgba(37,99,235,.42);
  box-shadow:0 34px 98px rgba(37,99,235,.20),0 14px 30px rgba(15,23,42,.10);
}
.bakir-preview-image{display:block;overflow:hidden;background:#f8fbff}
.bakir-preview-image img{
  width:100%;
  aspect-ratio:16/8.4;
  object-fit:cover;
  object-position:top left;
  transition:transform .5s var(--ease);
}
.bakir-hero-preview:hover img,
.bakir-hero-preview:focus-visible img{transform:scale(1.025)}
.bakir-story-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
  margin-top:clamp(24px,4vw,46px);
}
.bakir-story-card{
  padding:22px;
  border:1px solid rgba(219,234,254,.98);
  border-radius:24px;
  background:linear-gradient(180deg,rgba(255,255,255,.94),rgba(248,251,255,.94));
  box-shadow:0 18px 52px rgba(15,23,42,.07);
}
.bakir-story-card > span,
.bakir-section-head > span{
  display:inline-flex;
  margin-bottom:.75rem;
  color:#075dcf;
  font-family:var(--font-mono);
  font-size:11px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.bakir-story-card h3,
.bakir-section-head h3{
  font-size:clamp(1.35rem,2.1vw,1.9rem);
  letter-spacing:-.04em;
}
.bakir-story-card ul{
  display:grid;
  gap:.65rem;
  margin-top:1rem;
  color:var(--ink-3);
  font-size:var(--fs-sm);
}
.bakir-story-card li{
  position:relative;
  padding-left:1.1rem;
  line-height:1.6;
}
.bakir-story-card li:before{
  content:"";
  position:absolute;
  left:0;
  top:.65em;
  width:6px;
  height:6px;
  border-radius:50%;
  background:#2563eb;
  box-shadow:0 0 0 4px rgba(37,99,235,.10);
}
.bakir-story-card p{
  margin-top:1rem;
  color:var(--ink-3);
  line-height:1.68;
}
.bakir-story-card strong{
  display:block;
  margin-top:1rem;
  padding:.75rem .85rem;
  border:1px solid rgba(191,219,254,.95);
  border-radius:16px;
  background:#eef6ff;
  color:#075dcf;
  font-size:var(--fs-sm);
  line-height:1.45;
}
.bakir-story-result{
  background:linear-gradient(135deg,#eef6ff,#fff);
}
.bakir-modules,
.bakir-screens{
  margin-top:clamp(26px,4vw,48px);
}
.bakir-section-head{
  display:grid;
  gap:.25rem;
  max-width:760px;
  margin-bottom:1rem;
}
.bakir-section-head p{
  margin-top:.45rem;
  color:var(--ink-3);
  line-height:1.65;
}
.bakir-module-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
}
.bakir-module-grid article{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:.25rem .75rem;
  align-items:start;
  padding:18px;
  border:1px solid rgba(219,234,254,.98);
  border-radius:20px;
  background:rgba(255,255,255,.86);
  box-shadow:0 16px 42px rgba(15,23,42,.055);
}
.bakir-module-grid span{
  grid-row:1/3;
  display:grid;
  place-items:center;
  width:40px;
  height:40px;
  border-radius:14px;
  background:#eef6ff;
  color:#075dcf;
  font-size:11px;
  font-weight:900;
}
.bakir-module-grid h4{
  color:var(--ink);
  font-size:var(--fs-md);
  letter-spacing:-.02em;
}
.bakir-module-grid p{
  color:var(--ink-4);
  font-size:var(--fs-sm);
  line-height:1.45;
}
.bakir-gallery{
  display:grid;
  gap:14px;
}
.bakir-screen-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
}
.bakir-screen-card{
  position:relative;
  display:grid;
  grid-template-rows:auto minmax(0,1fr) auto;
  overflow:hidden;
  min-width:0;
  text-align:left;
  border:1px solid rgba(191,219,254,.95);
  border-radius:22px;
  background:#fff;
  box-shadow:0 18px 48px rgba(15,23,42,.08);
  cursor:zoom-in;
  opacity:0;
  transform:translateY(18px);
  transition:opacity .55s var(--ease),transform .55s var(--ease),border-color .24s var(--ease),box-shadow .24s var(--ease);
  transition-delay:calc(var(--reveal-i,0) * 55ms);
}
.bakir-screen-card.is-visible{opacity:1;transform:none}
.bakir-screen-card:hover,
.bakir-screen-card:focus-visible{
  transform:translateY(-5px);
  border-color:rgba(37,99,235,.36);
  box-shadow:0 28px 76px rgba(37,99,235,.16),0 12px 28px rgba(15,23,42,.08);
}
.bakir-screen-featured{
  border-radius:28px;
  box-shadow:0 24px 74px rgba(37,99,235,.13);
}
.bakir-screen-image{
  display:block;
  overflow:hidden;
  background:#f8fbff;
}
.bakir-screen-image img{
  width:100%;
  aspect-ratio:16/9.4;
  object-fit:cover;
  object-position:top left;
  transition:transform .5s var(--ease),filter .5s var(--ease);
}
.bakir-screen-featured .bakir-screen-image img{aspect-ratio:16/7.4}
.bakir-screen-card:hover img,
.bakir-screen-card:focus-visible img{
  transform:scale(1.035);
  filter:saturate(1.04) contrast(1.02);
}
.bakir-screen-meta{
  display:grid;
  gap:3px;
  padding:14px 16px 16px;
  background:linear-gradient(180deg,#fff,#f8fbff);
}
.bakir-screen-meta em{
  width:max-content;
  max-width:100%;
  padding:.22rem .5rem;
  border:1px solid #bfdbfe;
  border-radius:999px;
  background:#eef6ff;
  color:#075dcf;
  font-style:normal;
  font-size:10px;
  font-weight:900;
  letter-spacing:.05em;
  text-transform:uppercase;
}
.bakir-screen-meta strong{
  color:var(--ink);
  font-family:var(--font-display);
  font-size:var(--fs-md);
  letter-spacing:-.02em;
}
.bakir-screen-meta small{
  color:var(--ink-4);
  font-size:12px;
  line-height:1.45;
}
.gallery-lightbox[hidden]{display:none!important}
.gallery-lightbox{
  position:fixed;
  inset:0;
  z-index:9999;
  display:grid;
  place-items:center;
  padding:clamp(14px,3vw,30px);
  background:rgba(15,23,42,.50);
  backdrop-filter:blur(14px);
  opacity:0;
  pointer-events:none;
  transition:opacity .22s var(--ease);
}
.gallery-lightbox.is-open{
  opacity:1;
  pointer-events:auto;
}
.gallery-lightbox-dialog{
  position:relative;
  width:min(1120px,100%);
  display:grid;
  grid-template-columns:56px minmax(0,1fr) 56px;
  align-items:center;
  gap:12px;
}
.gallery-lightbox-panel{
  grid-column:2;
  overflow:hidden;
  border:1px solid rgba(219,234,254,.76);
  border-radius:24px;
  background:#fff;
  box-shadow:0 32px 110px rgba(2,6,23,.35);
  transform:translateY(14px) scale(.985);
  transition:transform .24s var(--ease);
}
.gallery-lightbox.is-open .gallery-lightbox-panel{transform:none}
.gallery-lightbox-panel img{
  width:100%;
  max-height:calc(100dvh - 170px);
  object-fit:contain;
  background:#f8fbff;
}
.gallery-lightbox-panel figcaption{
  display:grid;
  gap:4px;
  padding:14px 18px 16px;
  border-top:1px solid rgba(219,234,254,.95);
  background:#fff;
}
.gallery-lightbox-panel strong{
  color:var(--ink);
  font-family:var(--font-display);
  font-size:var(--fs-lg);
}
.gallery-lightbox-panel span{
  color:var(--ink-3);
  font-size:var(--fs-sm);
}
.gallery-lightbox-close,
.gallery-lightbox-nav{
  position:relative;
  display:grid;
  place-items:center;
  border:1px solid rgba(255,255,255,.52);
  background:rgba(255,255,255,.94);
  color:#075dcf;
  box-shadow:0 18px 48px rgba(2,6,23,.20);
}
.gallery-lightbox-close{
  position:absolute;
  top:-54px;
  right:0;
  width:42px;
  height:42px;
  border-radius:999px;
}
.gallery-lightbox-close:before,
.gallery-lightbox-close:after{
  content:"";
  position:absolute;
  width:16px;
  height:2px;
  border-radius:999px;
  background:#075dcf;
}
.gallery-lightbox-close:before{transform:rotate(45deg)}
.gallery-lightbox-close:after{transform:rotate(-45deg)}
.gallery-lightbox-nav{
  width:46px;
  height:64px;
  border-radius:999px;
}
.gallery-lightbox-nav:before{
  content:"";
  width:13px;
  height:13px;
  border-top:2px solid #075dcf;
  border-right:2px solid #075dcf;
}
.gallery-lightbox-prev{grid-column:1;justify-self:end}
.gallery-lightbox-next{grid-column:3;justify-self:start}
.gallery-lightbox-prev:before{transform:rotate(-135deg);margin-left:4px}
.gallery-lightbox-next:before{transform:rotate(45deg);margin-right:4px}
.gallery-lightbox-close:hover,
.gallery-lightbox-nav:hover{
  border-color:rgba(191,219,254,.9);
  background:#fff;
  box-shadow:0 22px 60px rgba(37,99,235,.20);
}
@media(max-width:1100px){
  .bakir-case-hero,
  .bakir-story-grid{grid-template-columns:1fr}
  .bakir-module-grid,
  .bakir-screen-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .bakir-hero-copy h2{max-width:13ch}
}
@media(max-width:720px){
  .bakir-case{padding:18px;border-radius:24px}
  .bakir-hero-actions{align-items:stretch}
  .bakir-hero-actions .btn{width:100%;justify-content:center}
  .bakir-hero-preview,
  .bakir-screen-featured,
  .bakir-screen-card{border-radius:18px}
  .bakir-module-grid,
  .bakir-screen-grid{grid-template-columns:1fr}
  .bakir-preview-image img,
  .bakir-screen-featured .bakir-screen-image img,
  .bakir-screen-image img{aspect-ratio:16/10}
  .gallery-lightbox{padding:64px 12px 14px}
  .gallery-lightbox-dialog{
    grid-template-columns:1fr 1fr;
    grid-template-rows:1fr auto;
    gap:10px;
  }
  .gallery-lightbox-panel{
    grid-column:1/-1;
    width:100%;
    align-self:center;
    border-radius:18px;
  }
  .gallery-lightbox-panel img{max-height:calc(100dvh - 220px)}
  .gallery-lightbox-prev,
  .gallery-lightbox-next{
    grid-row:2;
    width:48px;
    height:48px;
  }
  .gallery-lightbox-prev{grid-column:1;justify-self:start}
  .gallery-lightbox-next{grid-column:2;justify-self:end}
  .gallery-lightbox-close{top:-52px;right:0}
}
@media(prefers-reduced-motion:reduce){
  .bakir-hero-preview,
  .bakir-preview-image img,
  .bakir-screen-card,
  .bakir-screen-image img,
  .gallery-lightbox,
  .gallery-lightbox-panel{
    transition:none!important;
  }
  .bakir-screen-card{opacity:1!important;transform:none!important}
}

/* v43 Bakir case desktop scale polish */
.bakir-case-section .container{
  max-width:1280px;
}
.bakir-case{
  padding:clamp(28px,4vw,56px);
}
.bakir-case-hero{
  grid-template-columns:minmax(410px,.9fr) minmax(560px,1.1fr);
  gap:clamp(36px,5vw,72px);
}
.bakir-hero-copy h2{
  max-width:760px;
  font-size:clamp(2.45rem,3.9vw,4.6rem);
}
.bakir-hero-copy p{
  max-width:680px;
  font-size:clamp(1.05rem,1.1vw,1.22rem);
}
.bakir-hero-summary{
  display:flex;
  flex-wrap:wrap;
  gap:.55rem;
  margin-top:1.15rem;
}
.bakir-hero-summary span{
  display:inline-flex;
  align-items:center;
  min-height:36px;
  padding:.45rem .75rem;
  border:1px solid #bfdbfe;
  border-radius:999px;
  background:#eef6ff;
  color:#075dcf;
  font-size:12px;
  font-weight:850;
}
.bakir-hero-actions{margin-top:1.8rem}
.bakir-hero-preview{
  border-radius:32px;
}
.bakir-preview-image img{
  aspect-ratio:16/8.05;
}
.bakir-story-grid{
  gap:20px;
  margin-top:clamp(36px,5vw,64px);
}
.bakir-story-card{
  padding:clamp(24px,2.2vw,32px);
  min-height:100%;
}
.bakir-story-card h3,
.bakir-section-head h3{
  font-size:clamp(1.45rem,1.8vw,2.05rem);
}
.bakir-story-card ul,
.bakir-story-card p{
  font-size:clamp(.95rem,.9vw,1.02rem);
}
.bakir-modules,
.bakir-screens{
  margin-top:clamp(42px,5vw,72px);
}
.bakir-section-head{
  max-width:860px;
  margin-bottom:1.35rem;
}
.bakir-module-grid{
  gap:18px;
}
.bakir-module-grid article{
  padding:clamp(20px,1.8vw,26px);
  border-radius:22px;
}
.bakir-module-grid span{
  width:46px;
  height:46px;
}
.bakir-module-grid h4{
  font-size:clamp(1rem,1vw,1.12rem);
}
.bakir-module-grid p{
  font-size:.94rem;
}
.bakir-gallery{
  gap:18px;
}
.bakir-screen-grid{
  gap:18px;
}
.bakir-screen-card{
  border-radius:24px;
}
.bakir-screen-featured{
  border-radius:32px;
}
.bakir-screen-featured .bakir-screen-image img{
  aspect-ratio:16/7.1;
}
.bakir-screen-image img{
  aspect-ratio:16/8.8;
  object-fit:cover;
}
.bakir-screen-meta{
  padding:16px 18px 18px;
}
.bakir-screen-meta strong{
  font-size:clamp(1rem,1vw,1.12rem);
}
.bakir-screen-meta small{
  font-size:13px;
}
.gallery-lightbox-dialog{
  width:min(90vw,1380px);
  grid-template-columns:58px minmax(0,1fr) 58px;
}
.gallery-lightbox-panel img{
  max-height:82vh;
}
.gallery-lightbox-panel figcaption{
  padding:16px 20px 18px;
}
@media(min-width:1280px){
  .bakir-case-section .container{max-width:1320px}
  .bakir-case-hero{grid-template-columns:minmax(430px,.86fr) minmax(660px,1.14fr)}
  .bakir-screen-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
}
@media(max-width:1100px){
  .bakir-case-section .container{max-width:var(--container)}
  .bakir-case-hero{grid-template-columns:1fr}
}
@media(max-width:720px){
  .bakir-case{padding:18px}
  .bakir-hero-copy h2{font-size:clamp(2rem,11vw,3rem)}
  .bakir-hero-summary span{width:100%;justify-content:center}
  .bakir-story-grid{gap:14px;margin-top:26px}
  .bakir-modules,.bakir-screens{margin-top:32px}
  .bakir-screen-featured .bakir-screen-image img,
  .bakir-screen-image img,
  .bakir-preview-image img{aspect-ratio:16/10}
  .gallery-lightbox-dialog{width:100%}
  .gallery-lightbox-panel img{max-height:calc(100dvh - 220px)}
}

/* v44 interactive preview demos */
.demo-hub{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(760px 420px at 86% 14%,rgba(37,99,235,.13),transparent 62%),
    linear-gradient(180deg,#fff 0%,#f8fbff 100%);
}
.demo-hub:before{
  content:"";
  position:absolute;
  inset:0;
  opacity:.30;
  background-image:linear-gradient(rgba(37,99,235,.055) 1px,transparent 1px),linear-gradient(90deg,rgba(37,99,235,.055) 1px,transparent 1px);
  background-size:44px 44px;
  mask-image:linear-gradient(180deg,transparent,#000 18%,#000 82%,transparent);
  pointer-events:none;
}
.demo-hub .container{position:relative;z-index:1}
.demo-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
}
.demo-card{
  display:flex;
  flex-direction:column;
  gap:1rem;
  min-width:0;
  min-height:100%;
  padding:22px;
  border:1px solid rgba(191,219,254,.92);
  border-radius:26px;
  background:rgba(255,255,255,.84);
  box-shadow:0 22px 70px rgba(15,23,42,.08);
  backdrop-filter:blur(16px);
  transition:transform var(--t-base) var(--ease),box-shadow var(--t-base) var(--ease),border-color var(--t-base) var(--ease);
}
.demo-card:hover{
  transform:translateY(-5px);
  border-color:rgba(37,99,235,.34);
  box-shadow:0 30px 84px rgba(37,99,235,.13),0 14px 32px rgba(15,23,42,.08);
}
.demo-card-wide{grid-column:span 2}
.demo-card-head{
  display:flex;
  gap:.9rem;
  align-items:flex-start;
}
.demo-icon{
  flex:0 0 auto;
  display:grid;
  place-items:center;
  width:46px;
  height:46px;
  border:1px solid #bfdbfe;
  border-radius:16px;
  background:#eef6ff;
}
.demo-icon img{width:24px;height:24px;object-fit:contain}
.demo-card h3{
  margin:0 0 .3rem;
  font-size:var(--fs-xl);
  letter-spacing:-.03em;
}
.demo-card p{
  margin:0;
  color:var(--ink-3);
  font-size:var(--fs-sm);
  line-height:1.55;
}
.demo-flow{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:.45rem;
  color:#075dcf;
  font-size:11px;
  font-weight:850;
}
.demo-flow span{
  padding:.35rem .55rem;
  border:1px solid #bfdbfe;
  border-radius:999px;
  background:#eef6ff;
}
.demo-flow i{
  width:18px;
  height:1px;
  background:linear-gradient(90deg,#bfdbfe,#2563eb,#bfdbfe);
  animation:demoFlow 2.4s ease-in-out infinite;
}
.demo-preview{
  overflow:hidden;
  min-height:190px;
  margin-top:auto;
  padding:16px;
  border:1px solid rgba(219,234,254,.95);
  border-radius:22px;
  background:linear-gradient(180deg,#fff,#f8fbff);
}
.demo-preview-chat{
  display:flex;
  flex-direction:column;
  gap:.55rem;
}
.demo-chat-bubble{
  display:block;
  max-width:84%;
  padding:.72rem .82rem;
  border-radius:18px;
  font-size:13px;
  line-height:1.35;
  box-shadow:0 10px 26px rgba(15,23,42,.055);
}
.demo-chat-bubble.is-customer{
  align-self:flex-start;
  background:#fff;
  border:1px solid rgba(226,232,240,.95);
  color:var(--ink-2);
}
.demo-chat-bubble.is-system{
  align-self:flex-end;
  background:#eef6ff;
  border:1px solid #bfdbfe;
  color:#075dcf;
}
.demo-mini-card,
.demo-preview-card,
.demo-preview-dashboard,
.demo-preview-web{
  display:grid;
  gap:.45rem;
  border:1px solid rgba(191,219,254,.95);
  border-radius:16px;
  background:#fff;
  color:var(--ink-2);
}
.demo-mini-card{padding:.75rem;font-size:13px;font-weight:800}
.demo-preview-card{padding:1rem;align-content:center}
.demo-preview-card strong,
.demo-preview-web strong{font-family:var(--font-display);font-size:var(--fs-lg)}
.demo-preview-card span,
.demo-preview-card em,
.demo-preview-web span{color:var(--ink-4);font-size:13px;font-style:normal}
.demo-preview-card em,
.demo-preview-web em{
  width:max-content;
  padding:.4rem .58rem;
  border-radius:999px;
  background:#eef6ff;
  color:#075dcf;
  font-style:normal;
  font-size:12px;
  font-weight:850;
}
.demo-preview-dashboard{
  grid-template-columns:repeat(3,1fr);
  align-content:start;
  padding:1rem;
}
.demo-preview-dashboard span{
  height:34px;
  border-radius:12px;
  background:#eef6ff;
  border:1px solid #bfdbfe;
}
.demo-preview-dashboard strong,
.demo-preview-dashboard em{
  grid-column:1/-1;
  font-style:normal;
}
.demo-preview-dashboard em{color:var(--ink-4);font-size:13px}
.demo-preview-web{
  min-height:190px;
  grid-template-columns:1fr auto;
  align-items:end;
  padding:1rem;
}
.demo-open-btn{justify-content:center;margin-top:.1rem}
.demo-modal[hidden]{display:none!important}
.demo-modal{
  position:fixed;
  inset:0;
  z-index:10000;
  display:grid;
  place-items:center;
  padding:clamp(12px,3vw,28px);
  background:rgba(15,23,42,.48);
  backdrop-filter:blur(14px);
  opacity:0;
  pointer-events:none;
  transition:opacity .22s var(--ease);
}
.demo-modal.is-open{
  opacity:1;
  pointer-events:auto;
}
.demo-modal-panel{
  position:relative;
  width:min(1180px,100%);
  max-height:min(86dvh,840px);
  overflow:auto;
  border:1px solid rgba(219,234,254,.76);
  border-radius:30px;
  background:#fff;
  box-shadow:0 34px 120px rgba(2,6,23,.32);
  transform:translateY(14px) scale(.985);
  transition:transform .24s var(--ease);
}
.demo-modal.is-open .demo-modal-panel{transform:none}
.demo-modal-close{
  position:absolute;
  top:16px;
  right:16px;
  z-index:3;
  width:42px;
  height:42px;
  border:1px solid #bfdbfe;
  border-radius:999px;
  background:#fff;
  box-shadow:0 12px 30px rgba(15,23,42,.10);
}
.demo-modal-close:before,
.demo-modal-close:after{
  content:"";
  position:absolute;
  left:12px;
  top:19px;
  width:16px;
  height:2px;
  border-radius:999px;
  background:#075dcf;
}
.demo-modal-close:before{transform:rotate(45deg)}
.demo-modal-close:after{transform:rotate(-45deg)}
.demo-modal-head{
  padding:clamp(22px,3vw,34px) clamp(22px,3vw,36px) 0;
  max-width:780px;
}
.demo-modal-head span{
  color:#075dcf;
  font-family:var(--font-mono);
  font-size:11px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.demo-modal-head h3{
  margin:.65rem 0 .55rem;
  font-size:clamp(1.8rem,3vw,3rem);
  letter-spacing:-.05em;
}
.demo-modal-head p{margin:0;color:var(--ink-3);font-size:var(--fs-lg);line-height:1.55}
.demo-modal-body{
  display:grid;
  grid-template-columns:220px minmax(0,1fr) 250px;
  gap:18px;
  padding:clamp(20px,3vw,36px);
}
.demo-steps,
.demo-results,
.demo-screen{
  min-width:0;
  border:1px solid rgba(219,234,254,.95);
  border-radius:24px;
  background:linear-gradient(180deg,#fff,#f8fbff);
  box-shadow:0 16px 42px rgba(15,23,42,.055);
}
.demo-steps{display:grid;gap:.55rem;align-content:start;padding:14px}
.demo-step{
  display:flex;
  gap:.6rem;
  align-items:flex-start;
  padding:.75rem;
  border:1px solid transparent;
  border-radius:16px;
  color:var(--ink-4);
  font-size:13px;
}
.demo-step b{
  display:grid;
  place-items:center;
  flex:0 0 auto;
  width:24px;
  height:24px;
  border-radius:999px;
  background:#e2e8f0;
  color:#64748b;
  font-size:11px;
}
.demo-step.is-active{
  border-color:#bfdbfe;
  background:#eef6ff;
  color:#075dcf;
  font-weight:800;
}
.demo-step.is-active b{background:#2563eb;color:#fff}
.demo-screen{
  overflow:hidden;
  padding:18px;
}
.demo-screen-inner{
  display:grid;
  gap:14px;
  animation:demoStepIn .24s var(--ease) both;
}
.demo-option-row{display:flex;flex-wrap:wrap;gap:.55rem}
.demo-option{
  padding:.55rem .75rem;
  border:1px solid #bfdbfe;
  border-radius:999px;
  background:#fff;
  color:#075dcf;
  font-size:13px;
  font-weight:850;
}
.demo-option.is-selected{background:#2563eb;color:#fff;border-color:#2563eb}
.demo-lead-card,
.demo-dashboard,
.demo-form-preview,
.demo-notice{
  padding:16px;
  border:1px solid rgba(191,219,254,.95);
  border-radius:18px;
  background:#fff;
}
.demo-lead-card{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:.65rem;
}
.demo-lead-card h4,
.demo-dashboard h4,
.demo-form-preview h4{
  grid-column:1/-1;
  margin:0;
  font-size:var(--fs-lg);
}
.demo-lead-card span,
.demo-dashboard span,
.demo-form-preview span{
  display:block;
  padding:.65rem .75rem;
  border-radius:14px;
  background:#f8fbff;
  color:var(--ink-3);
  font-size:13px;
}
.demo-lead-card b,
.demo-dashboard b,
.demo-form-preview b{display:block;color:var(--ink);font-size:13px}
.demo-dashboard{
  display:grid;
  grid-template-columns:150px 1fr;
  gap:14px;
}
.demo-dashboard-nav{
  display:grid;
  gap:.5rem;
  align-content:start;
}
.demo-dashboard-nav span{
  background:#eef6ff;
  color:#075dcf;
  font-weight:850;
}
.demo-dashboard-main{display:grid;gap:.65rem}
.demo-notice{
  background:linear-gradient(135deg,#eef6ff,#fff);
  color:#075dcf;
  font-weight:850;
}
.demo-results{
  padding:16px;
  align-content:start;
}
.demo-results h4{margin:0 0 .85rem;font-size:var(--fs-lg)}
.demo-result-grid{display:grid;gap:.65rem;margin-bottom:1rem}
.demo-result-card{
  padding:.75rem .85rem;
  border:1px solid rgba(191,219,254,.95);
  border-radius:16px;
  background:#fff;
  color:var(--ink-2);
  font-size:13px;
  font-weight:800;
}
.demo-results .btn{width:100%;justify-content:center}
.demo-modal-actions{
  display:flex;
  justify-content:flex-end;
  gap:.75rem;
  padding:0 clamp(22px,3vw,36px) clamp(22px,3vw,34px);
}
body.demo-lock{overflow:hidden}
@keyframes demoFlow{0%,100%{opacity:.35}50%{opacity:1}}
@keyframes demoStepIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
@media(max-width:1120px){
  .demo-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .demo-card-wide{grid-column:span 2}
  .demo-modal-body{grid-template-columns:1fr}
  .demo-steps{display:flex;overflow:auto}
  .demo-step{min-width:160px}
  .demo-results{order:3}
}
@media(max-width:720px){
  .demo-grid{grid-template-columns:1fr}
  .demo-card-wide{grid-column:auto}
  .demo-card{padding:18px;border-radius:22px}
  .demo-card-head{align-items:flex-start}
  .demo-preview{min-height:160px}
  .demo-modal{padding:8px}
  .demo-modal-panel{
    width:100%;
    max-height:calc(100dvh - 16px);
    border-radius:22px;
  }
  .demo-modal-head{padding:22px 18px 0}
  .demo-modal-body{padding:18px;gap:12px}
  .demo-screen{padding:14px}
  .demo-lead-card,.demo-dashboard{grid-template-columns:1fr}
  .demo-modal-actions{
    flex-direction:column-reverse;
    padding:0 18px 18px;
  }
  .demo-modal-actions .btn{width:100%;justify-content:center}
}
@media(prefers-reduced-motion:reduce){
  .demo-card,
  .demo-modal,
  .demo-modal-panel,
  .demo-screen-inner,
  .demo-flow i{
    animation:none!important;
    transition:none!important;
  }
}

/* v45 richer interactive demo modal */
.demo-modal-panel{
  width:min(1320px,100%);
}
.demo-modal-head{
  max-width:none;
  padding-right:76px;
}
.demo-info-row{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:.65rem;
  margin-top:1.1rem;
}
.demo-info-row span{
  display:block;
  padding:.75rem .85rem;
  border:1px solid rgba(191,219,254,.95);
  border-radius:16px;
  background:linear-gradient(180deg,#fff,#f8fbff);
  color:#075dcf;
  font-size:13px;
  font-weight:800;
  text-transform:none;
  letter-spacing:0;
  font-family:var(--font-body);
}
.demo-info-row b{
  display:block;
  margin-bottom:2px;
  color:var(--ink-4);
  font-size:10px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.demo-modal-body{
  grid-template-columns:270px minmax(0,1fr) 280px;
}
.demo-step{
  opacity:.62;
  transition:opacity .2s var(--ease),transform .2s var(--ease),border-color .2s var(--ease),background .2s var(--ease);
}
.demo-step span{
  display:grid;
  gap:2px;
}
.demo-step strong{
  color:inherit;
  font-size:13px;
}
.demo-step small{
  color:var(--ink-4);
  font-size:11px;
  font-weight:600;
  line-height:1.35;
}
.demo-step.is-active{
  opacity:1;
  transform:translateX(3px);
  box-shadow:0 14px 34px rgba(37,99,235,.10);
}
.demo-step.is-active small{color:#2563eb}
.demo-step.is-done{
  opacity:1;
  border-color:rgba(191,219,254,.75);
  background:#fff;
  color:var(--ink-2);
}
.demo-step.is-done b{
  background:#dbeafe;
  color:#075dcf;
}
.demo-screen{
  background:
    radial-gradient(circle at 82% 8%,rgba(37,99,235,.10),transparent 34%),
    linear-gradient(180deg,#fff,#f8fbff);
}
.demo-screen-rich{
  gap:16px;
}
.demo-session-card{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:.65rem;
}
.demo-session-card span,
.demo-session-card em{
  display:block;
  padding:.72rem .78rem;
  border:1px solid rgba(191,219,254,.95);
  border-radius:16px;
  background:#fff;
  color:var(--ink-3);
  font-size:12px;
  font-style:normal;
  line-height:1.35;
}
.demo-session-card b{
  display:block;
  color:var(--ink);
  font-size:12px;
}
.demo-session-card em{
  background:#eef6ff;
  color:#075dcf;
  font-weight:850;
}
.demo-main-stage{
  min-height:310px;
  padding:16px;
  border:1px solid rgba(191,219,254,.95);
  border-radius:22px;
  background:rgba(255,255,255,.78);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.8);
}
.demo-activity{
  padding:14px 16px;
  border:1px solid rgba(191,219,254,.95);
  border-radius:20px;
  background:#fff;
}
.demo-activity strong{
  display:block;
  margin-bottom:.7rem;
  color:var(--ink);
  font-size:13px;
}
.demo-activity ul{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:.55rem;
}
.demo-activity li{
  display:flex;
  align-items:center;
  gap:.45rem;
  color:var(--ink-5);
  font-size:12px;
  line-height:1.35;
}
.demo-activity li span{
  width:8px;
  height:8px;
  border-radius:50%;
  background:#cbd5e1;
}
.demo-activity li.is-active{
  color:#075dcf;
  font-weight:800;
}
.demo-activity li.is-active span{
  background:#2563eb;
  box-shadow:0 0 0 4px rgba(37,99,235,.12);
}
.demo-kpi-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:.55rem;
  margin-bottom:.85rem;
}
.demo-kpi-grid span{
  padding:.75rem .85rem;
  border:1px solid rgba(191,219,254,.95);
  border-radius:16px;
  background:#fff;
  color:#075dcf;
  font-size:13px;
  font-weight:850;
}
.demo-kpi-grid b{
  display:block;
  color:var(--ink-4);
  font-size:10px;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.demo-result-card{
  opacity:.58;
  transition:opacity .2s var(--ease),border-color .2s var(--ease),background .2s var(--ease);
}
.demo-result-card.is-active{
  opacity:1;
  border-color:#bfdbfe;
  background:#eef6ff;
  color:#075dcf;
}
.demo-status-card{
  margin:.9rem 0 1rem;
  padding:.75rem .85rem;
  border:1px solid #bfdbfe;
  border-radius:16px;
  background:linear-gradient(135deg,#eef6ff,#fff);
  color:#075dcf;
  font-size:13px;
  font-weight:900;
}
.demo-calendar,
.demo-landing-preview{
  display:grid;
  gap:.6rem;
  padding:16px;
  border:1px solid rgba(191,219,254,.95);
  border-radius:18px;
  background:#fff;
}
.demo-calendar{
  grid-template-columns:repeat(4,minmax(0,1fr));
  align-items:center;
}
.demo-calendar b{
  grid-column:1/-1;
  color:var(--ink);
}
.demo-calendar span{
  padding:.65rem;
  border:1px solid rgba(226,232,240,.95);
  border-radius:14px;
  color:var(--ink-4);
  text-align:center;
  font-size:13px;
}
.demo-calendar .is-free{
  border-color:#bfdbfe;
  background:#eef6ff;
  color:#075dcf;
  font-weight:900;
}
.demo-landing-preview{
  grid-template-columns:repeat(3,minmax(0,1fr));
}
.demo-landing-preview h4,
.demo-landing-preview p{
  grid-column:1/-1;
  margin:0;
}
.demo-landing-preview p{color:var(--ink-3)}
.demo-landing-preview span{
  padding:.7rem;
  border:1px solid #bfdbfe;
  border-radius:14px;
  background:#eef6ff;
  color:#075dcf;
  font-size:13px;
  font-weight:850;
}
.demo-form-preview{
  gap:.65rem;
}
.demo-form-preview span{
  border:1px solid rgba(191,219,254,.8);
}
@media(max-width:1180px){
  .demo-info-row,
  .demo-session-card,
  .demo-activity ul{grid-template-columns:repeat(2,minmax(0,1fr))}
  .demo-modal-body{grid-template-columns:1fr}
}
@media(max-width:720px){
  .demo-modal-head{padding-right:18px}
  .demo-info-row,
  .demo-session-card,
  .demo-activity ul,
  .demo-calendar,
  .demo-landing-preview{grid-template-columns:1fr}
  .demo-main-stage{min-height:0;padding:12px}
  .demo-step{min-width:220px}
}

/* v46 product-like demo screens */
.demo-product-bar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding:14px 58px 14px 18px;
  border-bottom:1px solid rgba(219,234,254,.95);
  background:linear-gradient(180deg,#fff,#f8fbff);
}
.demo-product-bar strong{
  display:block;
  color:var(--ink);
  font-family:var(--font-display);
  font-size:1rem;
  letter-spacing:-.02em;
}
.demo-product-bar span{
  display:block;
  color:#64748b;
  font-size:12px;
}
.demo-product-bar > div:last-child{
  display:flex;
  flex-wrap:wrap;
  gap:.45rem;
  justify-content:flex-end;
}
.demo-product-bar em{
  padding:.35rem .55rem;
  border:1px solid #bfdbfe;
  border-radius:999px;
  background:#eef6ff;
  color:#075dcf;
  font-size:11px;
  font-style:normal;
  font-weight:850;
}
.demo-modal-head{
  padding-top:18px;
}
.demo-modal-head p{
  max-width:76ch;
  font-size:var(--fs-md);
}
.demo-modal-body{
  grid-template-columns:190px minmax(0,1fr) 250px;
  gap:14px;
  padding-top:18px;
}
.demo-modal-panel{
  max-height:min(92dvh,900px);
}
.demo-product-screen{
  display:grid;
  gap:12px;
}
.demo-product-metrics{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:10px;
}
.demo-product-metrics div{
  padding:12px;
  border:1px solid rgba(191,219,254,.95);
  border-radius:18px;
  background:#fff;
  box-shadow:0 10px 26px rgba(15,23,42,.04);
}
.demo-product-metrics b{
  display:block;
  color:#64748b;
  font-size:11px;
  font-weight:850;
}
.demo-product-metrics strong{
  display:block;
  margin:.16rem 0;
  color:#0f172a;
  font-family:var(--font-display);
  font-size:1.35rem;
  line-height:1;
}
.demo-product-metrics span{
  color:#075dcf;
  font-size:11px;
  font-weight:800;
}
.demo-product-workspace{
  display:grid;
  grid-template-columns:150px minmax(0,1fr) 245px;
  gap:12px;
  min-height:440px;
}
.demo-product-sidebar,
.demo-product-main,
.demo-product-detail{
  min-width:0;
  border:1px solid rgba(219,234,254,.95);
  border-radius:22px;
  background:rgba(255,255,255,.9);
  box-shadow:0 14px 36px rgba(15,23,42,.055);
}
.demo-product-sidebar{
  display:grid;
  gap:6px;
  align-content:start;
  padding:10px;
}
.demo-product-sidebar button{
  padding:.68rem .72rem;
  border-radius:14px;
  color:#64748b;
  font-size:12px;
  font-weight:800;
  text-align:left;
}
.demo-product-sidebar button.is-active{
  background:#eef6ff;
  color:#075dcf;
  box-shadow:inset 0 0 0 1px #bfdbfe;
}
.demo-product-main{
  overflow:hidden;
  padding:12px;
  background:linear-gradient(180deg,#fff,#f8fbff);
}
.demo-product-detail{
  display:grid;
  align-content:start;
  gap:12px;
  padding:14px;
}
.demo-product-detail h4{
  margin:0;
  font-size:var(--fs-lg);
}
.demo-product-detail .demo-lead-card{
  padding:0;
  border:0;
  box-shadow:none;
  background:transparent;
  grid-template-columns:1fr;
}
.demo-product-detail .demo-lead-card h4{display:none}
.demo-product-detail .btn{width:100%;justify-content:center}
.demo-action-row{
  display:grid;
  grid-template-columns:1fr;
  gap:.55rem;
}
.demo-preview-note{
  margin:0;
  color:#64748b;
  font-size:12px;
}
.demo-inbox-layout{
  display:grid;
  grid-template-columns:190px minmax(0,1fr);
  gap:12px;
  height:100%;
}
.demo-thread-list{
  display:grid;
  gap:8px;
  align-content:start;
}
.demo-thread-list button{
  display:grid;
  gap:3px;
  padding:12px;
  border:1px solid rgba(226,232,240,.95);
  border-radius:16px;
  background:#fff;
  color:#0f172a;
  font-size:13px;
  font-weight:850;
  text-align:left;
}
.demo-thread-list button small{
  color:#94a3b8;
  font-weight:700;
}
.demo-thread-list button.is-selected{
  border-color:#bfdbfe;
  background:#eef6ff;
  color:#075dcf;
}
.demo-chat-panel{
  display:flex;
  flex-direction:column;
  min-height:400px;
  padding:14px;
  border:1px solid rgba(219,234,254,.95);
  border-radius:18px;
  background:#fff;
}
.demo-chat-title{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  margin-bottom:12px;
  color:#0f172a;
  font-weight:900;
}
.demo-chat-panel .demo-screen-inner{
  flex:1;
  align-content:start;
}
.demo-status-badge{
  display:inline-flex;
  align-items:center;
  width:max-content;
  padding:.28rem .52rem;
  border:1px solid #bfdbfe;
  border-radius:999px;
  background:#eef6ff;
  color:#075dcf;
  font-size:11px;
  font-weight:900;
  white-space:nowrap;
}
.demo-status-badge.hot{
  background:#eff6ff;
  color:#1d4ed8;
}
.demo-status-badge.blue{
  background:#eef6ff;
  color:#075dcf;
}
.demo-appointment-board{
  display:grid;
  grid-template-columns:190px minmax(0,1fr);
  gap:12px;
}
.demo-mini-calendar,
.demo-slot-grid{
  display:grid;
  gap:10px;
  padding:14px;
  border:1px solid rgba(219,234,254,.95);
  border-radius:18px;
  background:#fff;
}
.demo-mini-calendar{
  grid-template-columns:repeat(2,1fr);
}
.demo-mini-calendar strong{
  grid-column:1/-1;
}
.demo-mini-calendar span,
.demo-slot-grid button{
  padding:.75rem;
  border:1px solid rgba(226,232,240,.95);
  border-radius:14px;
  color:#64748b;
  text-align:center;
  font-size:13px;
}
.demo-mini-calendar .is-selected,
.demo-slot-grid button.is-selected{
  border-color:#bfdbfe;
  background:#eef6ff;
  color:#075dcf;
  font-weight:900;
}
.demo-slot-grid{
  grid-template-columns:repeat(2,minmax(0,1fr));
}
.demo-slot-grid button{
  display:grid;
  gap:3px;
  background:#fff;
}
.demo-slot-grid button b{
  color:inherit;
}
.demo-slot-grid button small{
  color:#94a3b8;
}
.demo-slot-grid button.is-full{
  opacity:.55;
}
.demo-table-tools{
  display:flex;
  gap:.55rem;
  margin-bottom:10px;
}
.demo-table-tools input,
.demo-table-tools button{
  min-width:0;
  padding:.65rem .75rem;
  border:1px solid rgba(191,219,254,.95);
  border-radius:14px;
  background:#fff;
  color:#64748b;
  font-size:13px;
}
.demo-table-tools input{flex:1}
.demo-crm-table{
  width:100%;
  border-collapse:separate;
  border-spacing:0 8px;
  font-size:12px;
}
.demo-crm-table th{
  color:#64748b;
  font-size:11px;
  text-align:left;
  padding:0 10px;
}
.demo-crm-table td{
  padding:10px;
  background:#fff;
  border-top:1px solid rgba(226,232,240,.95);
  border-bottom:1px solid rgba(226,232,240,.95);
  color:#334155;
}
.demo-crm-table td:first-child{
  border-left:1px solid rgba(226,232,240,.95);
  border-radius:14px 0 0 14px;
  color:#0f172a;
  font-weight:900;
}
.demo-crm-table td:last-child{
  border-right:1px solid rgba(226,232,240,.95);
  border-radius:0 14px 14px 0;
}
.demo-crm-table tr.is-selected td{
  border-color:#bfdbfe;
  background:#eef6ff;
}
.demo-web-board{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:12px;
}
.demo-web-board .demo-landing-preview,
.demo-web-board .demo-form-preview{
  min-height:400px;
}
.demo-landing-preview button{
  grid-column:1/-1;
  padding:.75rem;
  border-radius:14px;
  background:#2563eb;
  color:#fff;
  font-weight:900;
}
.demo-action-toast{
  position:fixed;
  right:clamp(16px,4vw,40px);
  bottom:clamp(16px,4vw,40px);
  z-index:10020;
  max-width:320px;
  padding:12px 14px;
  border:1px solid #bfdbfe;
  border-radius:18px;
  background:#fff;
  color:#075dcf;
  font-size:13px;
  font-weight:900;
  box-shadow:0 22px 70px rgba(15,23,42,.18);
  opacity:0;
  transform:translateY(10px);
  pointer-events:none;
  transition:opacity .2s var(--ease),transform .2s var(--ease);
}
.demo-action-toast.is-visible{
  opacity:1;
  transform:none;
}
@media(max-width:1180px){
  .demo-product-workspace{grid-template-columns:1fr}
  .demo-product-sidebar{display:flex;overflow:auto}
  .demo-product-sidebar button{white-space:nowrap}
}
@media(max-width:720px){
  .demo-product-bar{
    align-items:flex-start;
    flex-direction:column;
    padding:14px 58px 14px 14px;
  }
  .demo-modal-head{display:none}
  .demo-product-metrics{grid-template-columns:repeat(2,minmax(0,1fr))}
  .demo-inbox-layout,
  .demo-appointment-board,
  .demo-web-board{grid-template-columns:1fr}
  .demo-chat-panel,
  .demo-web-board .demo-landing-preview,
  .demo-web-board .demo-form-preview{min-height:0}
  .demo-crm-table{display:block;overflow:auto;white-space:nowrap}
  .demo-action-toast{left:12px;right:12px;bottom:12px;max-width:none}
}
@media(prefers-reduced-motion:reduce){
  .demo-action-toast,
  .demo-thread-list button,
  .demo-crm-table tr,
  .demo-slot-grid button{
    transition:none!important;
  }
}

/* v47 product modal layout override */
.demo-modal-body{
  grid-template-columns:1fr!important;
  gap:12px;
}
.demo-steps{
  display:flex;
  overflow:auto;
  padding:10px;
}
.demo-step{
  flex:1 0 190px;
  min-width:190px;
}
.demo-screen{
  padding:0;
  border:0;
  background:transparent;
  box-shadow:none;
}
.demo-results{
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:10px;
  align-items:center;
  padding:12px;
  border-radius:20px;
}
.demo-results h4{
  margin:0;
  font-size:var(--fs-md);
}
.demo-result-grid{
  display:flex;
  flex-wrap:wrap;
  gap:.45rem;
  margin:0;
}
.demo-kpi-grid{
  display:flex;
  gap:.45rem;
  margin:0;
}
.demo-kpi-grid span,
.demo-result-card,
.demo-status-card{
  margin:0;
  padding:.5rem .65rem;
  border-radius:999px;
  white-space:nowrap;
}
.demo-kpi-grid b{display:none}
.demo-results .btn{
  width:auto;
  white-space:nowrap;
}
.demo-modal-actions{
  align-items:center;
  padding-top:0;
}
@media(min-width:1181px){
  .demo-product-workspace{min-height:390px}
  .demo-chat-panel,
  .demo-web-board .demo-landing-preview,
  .demo-web-board .demo-form-preview{min-height:350px}
}
@media(max-width:720px){
  .demo-results{
    grid-template-columns:1fr;
    align-items:stretch;
  }
  .demo-result-grid,
  .demo-kpi-grid{display:grid;grid-template-columns:1fr}
  .demo-results .btn{width:100%;justify-content:center}
}

.service-demo-link{
  background:linear-gradient(180deg,#fff 0%,#f8fbff 100%);
}
.service-demo-card{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1.25rem;
  padding:clamp(1.4rem,3vw,2rem);
  border:1px solid rgba(191,219,254,.95);
  border-radius:28px;
  background:rgba(255,255,255,.9);
  box-shadow:0 22px 70px rgba(15,23,42,.08);
}
.service-demo-card h2{
  margin:.65rem 0 .45rem;
  font-size:var(--fs-3xl);
}
.service-demo-card p{
  margin:0;
  max-width:68ch;
  color:var(--ink-3);
}
.service-demo-card .btn{flex:0 0 auto}
@media(max-width:760px){
  .service-demo-card{align-items:flex-start;flex-direction:column}
  .service-demo-card .btn{width:100%;justify-content:center}
}

/* v48 demo modal no-scroll desktop polish */
@media(min-width:1181px){
  .demo-modal{
    padding:10px;
  }
  .demo-modal-panel{
    display:flex;
    flex-direction:column;
    width:min(1340px,calc(100vw - 20px));
    height:calc(100dvh - 20px);
    max-height:900px;
    overflow:hidden;
  }
  .demo-product-bar{
    flex:0 0 auto;
    padding:9px 58px 9px 16px;
  }
  .demo-product-bar strong{
    font-size:.95rem;
  }
  .demo-product-bar span,
  .demo-product-bar em{
    font-size:10.5px;
  }
  .demo-product-bar em{
    padding:.25rem .48rem;
  }
  .demo-modal-head{
    flex:0 0 auto;
    display:grid;
    grid-template-columns:minmax(0,1fr) minmax(430px,.72fr);
    gap:10px 18px;
    align-items:end;
    padding:12px 24px 0;
  }
  .demo-modal-head > span{
    grid-column:1;
    margin:0;
    font-size:10px;
  }
  .demo-modal-head h3{
    grid-column:1;
    margin:.25rem 0 0;
    font-size:clamp(1.55rem,2.1vw,2.25rem);
    line-height:1;
  }
  .demo-modal-head p{
    grid-column:1;
    margin:0;
    max-width:70ch;
    font-size:13px;
    line-height:1.4;
  }
  .demo-info-row{
    grid-column:2;
    grid-row:1 / span 3;
    align-self:center;
    gap:6px;
    margin:0;
  }
  .demo-info-row span{
    min-height:0;
    padding:.48rem .58rem;
    border-radius:13px;
    font-size:11.5px;
    line-height:1.25;
  }
  .demo-info-row b{
    margin-bottom:1px;
    font-size:9px;
  }
  .demo-modal-body{
    flex:1 1 auto;
    min-height:0;
    display:flex;
    flex-direction:column;
    gap:9px;
    padding:12px 18px 10px;
    overflow:hidden;
  }
  .demo-steps{
    flex:0 0 auto;
    gap:6px;
    padding:6px;
    overflow:hidden;
  }
  .demo-step{
    flex:1 1 0;
    min-width:0;
    padding:.48rem .55rem;
    border-radius:13px;
  }
  .demo-step b{
    width:20px;
    height:20px;
    font-size:10px;
  }
  .demo-step strong{
    font-size:12px;
  }
  .demo-step small{
    display:none;
  }
  .demo-step.is-active small{
    display:block;
    font-size:10.5px;
    line-height:1.25;
  }
  .demo-screen{
    flex:1 1 auto;
    min-height:0;
    overflow:hidden;
  }
  .demo-product-screen{
    height:100%;
    display:grid;
    grid-template-rows:auto minmax(0,1fr) auto;
    gap:8px;
  }
  .demo-product-metrics{
    gap:7px;
  }
  .demo-product-metrics div{
    padding:8px 10px;
    border-radius:14px;
  }
  .demo-product-metrics b,
  .demo-product-metrics span{
    font-size:10px;
  }
  .demo-product-metrics strong{
    font-size:1.08rem;
  }
  .demo-product-workspace{
    min-height:0;
    height:100%;
    gap:9px;
    grid-template-columns:132px minmax(0,1fr) 230px;
  }
  .demo-product-sidebar{
    gap:4px;
    padding:7px;
    border-radius:18px;
  }
  .demo-product-sidebar button{
    padding:.5rem .55rem;
    border-radius:12px;
    font-size:11px;
  }
  .demo-product-main{
    padding:9px;
    border-radius:18px;
  }
  .demo-product-detail{
    gap:8px;
    padding:10px;
    border-radius:18px;
  }
  .demo-product-detail h4{
    font-size:1rem;
  }
  .demo-product-detail .demo-lead-card{
    gap:6px;
  }
  .demo-product-detail .demo-lead-card span{
    padding:.48rem .58rem;
    border-radius:12px;
    font-size:12px;
  }
  .demo-product-detail .demo-lead-card b{
    font-size:11px;
  }
  .demo-inbox-layout,
  .demo-appointment-board,
  .demo-web-board{
    gap:9px;
  }
  .demo-inbox-layout{
    grid-template-columns:170px minmax(0,1fr);
  }
  .demo-thread-list{
    gap:6px;
  }
  .demo-thread-list button{
    padding:9px;
    border-radius:13px;
    font-size:12px;
  }
  .demo-chat-panel{
    min-height:0;
    height:100%;
    padding:10px;
    border-radius:15px;
  }
  .demo-chat-title{
    margin-bottom:7px;
    font-size:13px;
  }
  .demo-chat-bubble{
    padding:.55rem .68rem;
    font-size:12.5px;
  }
  .demo-option-row{
    gap:.4rem;
  }
  .demo-option{
    padding:.42rem .6rem;
    font-size:12px;
  }
  .demo-mini-calendar,
  .demo-slot-grid,
  .demo-landing-preview,
  .demo-form-preview{
    padding:10px;
    border-radius:15px;
    gap:7px;
  }
  .demo-slot-grid button,
  .demo-mini-calendar span{
    padding:.55rem;
    border-radius:12px;
  }
  .demo-table-tools{
    margin-bottom:7px;
  }
  .demo-table-tools input,
  .demo-table-tools button{
    padding:.5rem .62rem;
    border-radius:12px;
    font-size:12px;
  }
  .demo-crm-table{
    border-spacing:0 6px;
    font-size:11.5px;
  }
  .demo-crm-table td{
    padding:8px;
  }
  .demo-web-board .demo-landing-preview,
  .demo-web-board .demo-form-preview{
    min-height:0;
    height:100%;
  }
  .demo-preview-note{
    font-size:11px;
  }
  .demo-results{
    flex:0 0 auto;
    padding:8px 10px;
    border-radius:16px;
    gap:7px;
  }
  .demo-results h4{
    font-size:13px;
  }
  .demo-kpi-grid,
  .demo-result-grid{
    gap:5px;
  }
  .demo-kpi-grid span,
  .demo-result-card,
  .demo-status-card{
    padding:.38rem .52rem;
    font-size:11.5px;
  }
  .demo-results .btn{
    min-height:36px;
    padding:.55rem .78rem;
    font-size:12px;
  }
  .demo-modal-actions{
    flex:0 0 auto;
    gap:8px;
    padding:0 18px 12px;
  }
  .demo-modal-actions .btn{
    min-height:36px;
    padding:.55rem .85rem;
    font-size:12px;
  }
}

/* v50 WhatsApp demo landing page */
.wa-demo-landing-hero{
  position:relative;
  overflow:hidden;
  padding:clamp(96px,12vw,150px) 0 clamp(56px,7vw,92px);
  background:
    radial-gradient(700px 380px at 88% 8%,rgba(37,99,235,.15),transparent 66%),
    linear-gradient(180deg,#fff 0%,#f7fbff 100%);
}
.wa-demo-landing-hero::before,
.wa-demo-page::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  opacity:.45;
  background-image:radial-gradient(circle at 1px 1px,rgba(37,99,235,.16) 1px,transparent 0);
  background-size:26px 26px;
  mask-image:linear-gradient(180deg,#000,transparent 82%);
}
.wa-demo-hero-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(0,1.05fr) 430px;
  gap:clamp(28px,5vw,64px);
  align-items:center;
}
.wa-demo-hero-copy h1{
  max-width:760px;
  margin:.9rem 0 1rem;
  color:var(--ink);
  font-family:var(--font-display);
  font-size:clamp(2.7rem,6vw,5.8rem);
  line-height:.94;
  letter-spacing:-.045em;
}
.wa-demo-hero-copy .lead{
  max-width:760px;
}
.wa-flow-preview{
  display:grid;
  gap:12px;
  padding:20px;
  border:1px solid rgba(191,219,254,.95);
  border-radius:32px;
  background:rgba(255,255,255,.82);
  box-shadow:0 28px 90px rgba(15,23,42,.11);
  backdrop-filter:blur(14px);
}
.wa-flow-step{
  display:grid;
  grid-template-columns:42px minmax(0,1fr);
  column-gap:12px;
  row-gap:2px;
  align-items:center;
  padding:14px;
  border:1px solid rgba(219,234,254,.95);
  border-radius:20px;
  background:#fff;
}
.wa-flow-step span{
  grid-row:1 / span 2;
  display:grid;
  width:42px;
  height:42px;
  place-items:center;
  border-radius:14px;
  background:#eef6ff;
  color:#075dcf;
  font-weight:900;
}
.wa-flow-step strong{
  color:var(--ink);
  font-size:15px;
}
.wa-flow-step small{
  color:var(--ink-4);
  font-size:12px;
  line-height:1.45;
}
.wa-flow-step.is-active{
  border-color:#93c5fd;
  box-shadow:0 16px 38px rgba(37,99,235,.12);
}
.wa-flow-line{
  width:2px;
  height:18px;
  margin:-2px 0 -2px 34px;
  border-radius:999px;
  background:#bfdbfe;
}
.wa-demo-page{
  position:relative;
  overflow:hidden;
  background:linear-gradient(180deg,#f7fbff 0%,#fff 100%);
}
.wa-demo-wide{
  max-width:1240px;
}
.wa-scenario-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
  margin:32px 0 22px;
}
.wa-scenario-card{
  display:grid;
  gap:8px;
  min-height:172px;
  padding:22px;
  border:1px solid rgba(191,219,254,.95);
  border-radius:24px;
  background:rgba(255,255,255,.9);
  color:var(--ink);
  text-align:left;
  box-shadow:0 16px 48px rgba(15,23,42,.06);
  transition:transform .2s var(--ease),box-shadow .2s var(--ease),border-color .2s var(--ease);
}
.wa-scenario-card:hover,
.wa-scenario-card.is-selected{
  transform:translateY(-3px);
  border-color:#60a5fa;
  box-shadow:0 24px 70px rgba(37,99,235,.13);
}
.wa-scenario-card span{
  width:max-content;
  padding:.42rem .62rem;
  border:1px solid #bfdbfe;
  border-radius:999px;
  background:#eef6ff;
  color:#075dcf;
  font-size:12px;
  font-weight:900;
}
.wa-scenario-card strong{
  color:var(--ink);
  font-family:var(--font-display);
  font-size:1.25rem;
  line-height:1.12;
}
.wa-scenario-card small{
  color:var(--ink-4);
  font-size:14px;
  line-height:1.5;
}
.wa-product-demo{
  position:relative;
  z-index:1;
  overflow:hidden;
  border:1px solid rgba(147,197,253,.9);
  border-radius:34px;
  background:rgba(255,255,255,.94);
  box-shadow:0 34px 110px rgba(15,23,42,.12);
}
.wa-product-topbar{
  display:flex;
  justify-content:space-between;
  gap:1rem;
  align-items:center;
  padding:18px 22px;
  border-bottom:1px solid rgba(219,234,254,.95);
  background:linear-gradient(180deg,#fff,#f8fbff);
}
.wa-product-topbar strong{
  display:block;
  color:var(--ink);
  font-family:var(--font-display);
  font-size:1.18rem;
}
.wa-product-topbar span{
  color:var(--ink-4);
  font-size:13px;
}
.wa-product-topbar em,
.wa-chat-head em{
  flex:0 0 auto;
  padding:.42rem .68rem;
  border:1px solid #bfdbfe;
  border-radius:999px;
  background:#eef6ff;
  color:#075dcf;
  font-size:12px;
  font-style:normal;
  font-weight:900;
}
.wa-demo-metrics{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
  padding:18px 22px 0;
}
.wa-demo-metrics article{
  padding:15px 16px;
  border:1px solid rgba(219,234,254,.95);
  border-radius:20px;
  background:#fff;
  box-shadow:0 12px 32px rgba(15,23,42,.045);
}
.wa-demo-metrics span{
  display:block;
  color:var(--ink-4);
  font-size:12px;
  font-weight:800;
}
.wa-demo-metrics strong{
  display:block;
  margin-top:.25rem;
  color:#075dcf;
  font-family:var(--font-display);
  font-size:clamp(1.55rem,2.3vw,2.1rem);
  line-height:1;
}
.wa-product-grid{
  display:grid;
  grid-template-columns:245px minmax(0,1fr) 315px;
  gap:16px;
  padding:22px;
}
.wa-inbox-panel,
.wa-chat-panel,
.wa-request-card,
.wa-explain-grid article{
  min-width:0;
  border:1px solid rgba(219,234,254,.95);
  border-radius:26px;
  background:linear-gradient(180deg,#fff,#f8fbff);
  box-shadow:0 16px 44px rgba(15,23,42,.06);
}
.wa-inbox-panel{
  display:grid;
  gap:10px;
  align-content:start;
  padding:14px;
}
.wa-panel-title{
  display:flex;
  justify-content:space-between;
  gap:.8rem;
  align-items:end;
  padding:4px 4px 8px;
}
.wa-panel-title strong{
  color:var(--ink);
}
.wa-panel-title span{
  color:var(--ink-4);
  font-size:12px;
  font-weight:800;
}
.wa-inbox-panel button{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:3px 8px;
  align-items:center;
  padding:13px;
  border:1px solid rgba(226,232,240,.95);
  border-radius:18px;
  background:#fff;
  color:var(--ink);
  text-align:left;
  transition:transform .2s var(--ease),border-color .2s var(--ease),background .2s var(--ease);
}
.wa-inbox-panel button:hover,
.wa-inbox-panel button.is-active{
  transform:translateY(-1px);
  border-color:#93c5fd;
  background:#eef6ff;
}
.wa-inbox-panel button strong{
  color:var(--ink);
  font-size:14px;
}
.wa-inbox-panel button span{
  grid-column:1;
  color:var(--ink-4);
  font-size:12px;
}
.wa-inbox-panel button em{
  grid-row:1 / span 2;
  grid-column:2;
  align-self:center;
  padding:.34rem .52rem;
  border-radius:999px;
  background:#f0f7ff;
  color:#075dcf;
  font-size:10px;
  font-style:normal;
  font-weight:900;
}
.wa-chat-panel{
  overflow:hidden;
}
.wa-chat-head{
  display:flex;
  justify-content:space-between;
  gap:1rem;
  align-items:center;
  padding:17px 19px;
  border-bottom:1px solid rgba(219,234,254,.95);
  background:#fff;
}
.wa-chat-head strong{
  display:block;
  color:var(--ink);
}
.wa-chat-head span{
  color:var(--ink-4);
  font-size:12px;
}
.wa-chat-body{
  display:flex;
  flex-direction:column;
  gap:12px;
  min-height:465px;
  padding:22px;
  background:
    radial-gradient(circle at 20% 16%,rgba(37,99,235,.07),transparent 34%),
    linear-gradient(180deg,#f8fbff,#fff);
}
.wa-chat-bubble{
  max-width:78%;
  padding:.82rem .95rem;
  border:1px solid rgba(219,234,254,.92);
  border-radius:18px;
  color:var(--ink);
  font-size:14px;
  line-height:1.45;
  box-shadow:0 10px 26px rgba(15,23,42,.055);
  animation:waBubbleIn .24s var(--ease) both;
}
.wa-chat-bubble.is-customer{
  align-self:flex-start;
  border-bottom-left-radius:7px;
  background:#fff;
}
.wa-chat-bubble.is-system{
  align-self:flex-end;
  border-color:#bfdbfe;
  border-bottom-right-radius:7px;
  background:#eef6ff;
  color:#075dcf;
}
.wa-choice-row{
  display:flex;
  flex-wrap:wrap;
  gap:.55rem;
  margin:.2rem 0;
}
.wa-choice-row button{
  padding:.6rem .8rem;
  border:1px solid #bfdbfe;
  border-radius:999px;
  background:#fff;
  color:#075dcf;
  font-size:13px;
  font-weight:850;
  transition:transform .18s var(--ease),background .18s var(--ease),color .18s var(--ease);
}
.wa-choice-row button:hover,
.wa-choice-row button.is-selected{
  transform:translateY(-1px);
  background:#2563eb;
  border-color:#2563eb;
  color:#fff;
}
.wa-request-card{
  display:grid;
  align-content:start;
  gap:10px;
  padding:18px;
}
.wa-request-head{
  display:grid;
  gap:4px;
  margin-bottom:2px;
}
.wa-request-head span{
  color:#075dcf;
  font-size:12px;
  font-weight:900;
}
.wa-request-head strong{
  color:var(--ink);
  font-family:var(--font-display);
  font-size:1.55rem;
}
.wa-card-row{
  display:flex;
  justify-content:space-between;
  gap:1rem;
  align-items:center;
  padding:10px 12px;
  border:1px solid rgba(219,234,254,.95);
  border-radius:15px;
  background:#fff;
}
.wa-card-row span{
  color:var(--ink-4);
  font-size:12px;
  font-weight:800;
}
.wa-card-row strong{
  color:var(--ink);
  font-size:13px;
  text-align:right;
}
.wa-action-stack{
  display:grid;
  gap:8px;
  margin-top:4px;
}
.wa-action-stack .btn{
  justify-content:center;
  min-height:42px;
}
.wa-activity-zone{
  margin:0 22px 22px;
  padding:18px;
  border:1px solid rgba(191,219,254,.95);
  border-radius:26px;
  background:linear-gradient(180deg,#fff,#f8fbff);
}
.wa-activity-head{
  display:flex;
  justify-content:space-between;
  gap:1rem;
  align-items:center;
  margin-bottom:14px;
}
.wa-activity-head strong{
  color:var(--ink);
  font-family:var(--font-display);
  font-size:1.08rem;
}
.wa-activity-head span{
  color:var(--ink-4);
  font-size:12px;
  font-weight:800;
}
.wa-activity-list{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:10px;
}
.wa-activity-item{
  position:relative;
  display:grid;
  gap:6px;
  min-height:92px;
  padding:13px;
  border:1px solid rgba(219,234,254,.95);
  border-radius:18px;
  background:#fff;
  color:var(--ink-4);
}
.wa-activity-item::before{
  content:"";
  width:10px;
  height:10px;
  border-radius:999px;
  background:#cbd5e1;
}
.wa-activity-item strong{
  color:var(--ink);
  font-size:13px;
}
.wa-activity-item span{
  font-size:12px;
  line-height:1.35;
}
.wa-activity-item.is-active{
  border-color:#93c5fd;
  background:#eef6ff;
  color:#075dcf;
  box-shadow:0 14px 34px rgba(37,99,235,.12);
}
.wa-activity-item.is-active::before{
  background:#2563eb;
}
.wa-demo-controls{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:10px;
  padding:0 22px 24px;
}
.wa-explain-section{
  background:#fff;
}
.wa-explain-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:18px;
}
.wa-explain-grid article{
  padding:30px;
}
.wa-explain-grid article span{
  display:inline-flex;
  margin-bottom:14px;
  padding:.45rem .7rem;
  border:1px solid #bfdbfe;
  border-radius:999px;
  background:#eef6ff;
  color:#075dcf;
  font-size:12px;
  font-weight:900;
}
.wa-explain-grid h2{
  max-width:520px;
  margin:0 0 18px;
  color:var(--ink);
  font-family:var(--font-display);
  font-size:clamp(1.75rem,3vw,2.6rem);
  line-height:1.05;
  letter-spacing:-.03em;
}
.wa-explain-grid ul{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
  margin:0;
  padding:0;
  list-style:none;
}
.wa-explain-grid li{
  padding:12px 13px;
  border:1px solid rgba(219,234,254,.95);
  border-radius:16px;
  background:#fff;
  color:var(--ink-3);
  font-weight:750;
}
.wa-demo-final{
  background:linear-gradient(180deg,#fff 0%,#f8fbff 100%);
}
.wa-demo-toast{
  position:fixed;
  right:clamp(16px,4vw,40px);
  bottom:clamp(16px,4vw,40px);
  z-index:1000;
  padding:13px 15px;
  border:1px solid #bfdbfe;
  border-radius:18px;
  background:#fff;
  color:#075dcf;
  font-size:13px;
  font-weight:900;
  box-shadow:0 22px 70px rgba(15,23,42,.16);
  opacity:0;
  transform:translateY(10px);
  pointer-events:none;
  transition:opacity .2s var(--ease),transform .2s var(--ease);
}
.wa-demo-toast.is-visible{
  opacity:1;
  transform:none;
}
@keyframes waBubbleIn{
  from{opacity:0;transform:translateY(7px)}
  to{opacity:1;transform:none}
}
@media(prefers-reduced-motion:reduce){
  .wa-chat-bubble{animation:none}
  .wa-scenario-card,
  .wa-inbox-panel button,
  .wa-choice-row button,
  .wa-demo-toast{
    transition:none;
  }
}
@media(max-width:1120px){
  .wa-demo-hero-grid,
  .wa-product-grid{
    grid-template-columns:1fr;
  }
  .wa-flow-preview{
    max-width:680px;
  }
  .wa-inbox-panel{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .wa-panel-title{
    grid-column:1 / -1;
  }
  .wa-activity-list{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
}
@media(max-width:820px){
  .wa-demo-landing-hero{
    padding:92px 0 48px;
  }
  .wa-scenario-grid,
  .wa-explain-grid{
    grid-template-columns:1fr;
  }
  .wa-product-topbar{
    align-items:flex-start;
    flex-direction:column;
  }
  .wa-demo-metrics{
    grid-template-columns:repeat(2,minmax(0,1fr));
    padding:14px 14px 0;
  }
  .wa-product-grid{
    padding:14px;
    gap:12px;
  }
  .wa-inbox-panel{
    grid-template-columns:1fr;
  }
  .wa-chat-body{
    min-height:0;
    padding:16px;
  }
  .wa-chat-bubble{
    max-width:92%;
  }
  .wa-card-row{
    align-items:flex-start;
    flex-direction:column;
    gap:.2rem;
  }
  .wa-card-row strong{
    text-align:left;
  }
  .wa-activity-zone{
    margin:0 14px 14px;
    padding:14px;
  }
  .wa-activity-head{
    align-items:flex-start;
    flex-direction:column;
  }
  .wa-activity-list,
  .wa-explain-grid ul{
    grid-template-columns:1fr;
  }
  .wa-demo-controls{
    align-items:stretch;
    flex-direction:column;
    padding:0 14px 16px;
  }
  .wa-demo-controls .btn{
    justify-content:center;
  }
  .wa-demo-toast{
    left:12px;
    right:12px;
    bottom:12px;
  }
}

/* v51 WhatsApp product tour simplification */
.wa-tour-hero{
  position:relative;
  overflow:hidden;
  padding:clamp(96px,12vw,148px) 0 clamp(48px,7vw,84px);
  background:
    radial-gradient(760px 420px at 86% 12%,rgba(37,99,235,.14),transparent 66%),
    linear-gradient(180deg,#fff 0%,#f7fbff 100%);
}
.wa-tour-hero::before,
.wa-tour-section::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  opacity:.42;
  background-image:radial-gradient(circle at 1px 1px,rgba(37,99,235,.14) 1px,transparent 0);
  background-size:26px 26px;
  mask-image:linear-gradient(180deg,#000,transparent 82%);
}
.wa-tour-hero-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(0,1fr) 360px;
  gap:clamp(28px,5vw,70px);
  align-items:center;
}
.wa-tour-hero h1{
  max-width:820px;
  margin:.9rem 0 1rem;
  color:var(--ink);
  font-family:var(--font-display);
  font-size:clamp(2.7rem,6vw,5.75rem);
  line-height:.94;
  letter-spacing:-.045em;
}
.wa-tour-hero .lead{
  max-width:760px;
}
.wa-hero-mini{
  display:grid;
  gap:12px;
  padding:20px;
  border:1px solid rgba(191,219,254,.95);
  border-radius:30px;
  background:rgba(255,255,255,.88);
  box-shadow:0 28px 90px rgba(15,23,42,.1);
  backdrop-filter:blur(14px);
}
.wa-hero-mini span{
  display:flex;
  align-items:center;
  min-height:54px;
  padding:14px 16px;
  border:1px solid rgba(219,234,254,.95);
  border-radius:18px;
  background:#fff;
  color:var(--ink);
  font-weight:850;
}
.wa-hero-mini i{
  width:2px;
  height:18px;
  margin:-4px 0 -4px 26px;
  border-radius:999px;
  background:#bfdbfe;
}
.wa-tour-section{
  position:relative;
  overflow:hidden;
  background:linear-gradient(180deg,#f7fbff 0%,#fff 100%);
}
.wa-tour-container{
  max-width:1200px;
}
.wa-tour-intro{
  position:relative;
  z-index:1;
  max-width:760px;
  margin:0 auto;
  text-align:center;
}
.wa-tour-intro h2{
  margin:.85rem 0 .8rem;
  color:var(--ink);
  font-family:var(--font-display);
  font-size:clamp(2rem,4vw,3.6rem);
  line-height:1;
  letter-spacing:-.04em;
}
.wa-tour-intro p{
  margin:0;
  color:var(--ink-3);
  font-size:var(--fs-lg);
}
.wa-tour-scenarios{
  position:relative;
  z-index:1;
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:10px;
  margin:28px 0;
}
.wa-tour-scenarios button{
  min-height:46px;
  padding:.74rem 1rem;
  border:1px solid #bfdbfe;
  border-radius:999px;
  background:#fff;
  color:#075dcf;
  font-weight:900;
  box-shadow:0 12px 30px rgba(15,23,42,.045);
  transition:transform .18s var(--ease),background .18s var(--ease),color .18s var(--ease),box-shadow .18s var(--ease);
}
.wa-tour-scenarios button:hover,
.wa-tour-scenarios button.is-selected{
  transform:translateY(-2px);
  background:#2563eb;
  border-color:#2563eb;
  color:#fff;
  box-shadow:0 18px 45px rgba(37,99,235,.18);
}
.wa-tour-demo{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(300px,400px) minmax(0,1fr);
  gap:clamp(22px,4vw,54px);
  align-items:start;
  padding:clamp(22px,4vw,44px);
  border:1px solid rgba(147,197,253,.9);
  border-radius:38px;
  background:rgba(255,255,255,.92);
  box-shadow:0 34px 110px rgba(15,23,42,.11);
}
.wa-phone-wrap{
  display:grid;
  place-items:start center;
}
.wa-phone{
  width:clamp(300px,28vw,370px);
  aspect-ratio:9 / 16;
  max-height:620px;
  padding:14px;
  border:1px solid rgba(147,197,253,.75);
  border-radius:44px;
  background:linear-gradient(180deg,#f8fbff,#eaf4ff);
  box-shadow:0 32px 90px rgba(15,23,42,.16);
}
.wa-phone-speaker{
  width:78px;
  height:6px;
  margin:4px auto 12px;
  border-radius:999px;
  background:#c7d2fe;
}
.wa-phone-screen{
  overflow:hidden;
  height:100%;
  min-height:0;
  border:1px solid rgba(191,219,254,.95);
  border-radius:34px;
  background:
    radial-gradient(circle at 20% 15%,rgba(37,99,235,.08),transparent 32%),
    linear-gradient(180deg,#fff,#f8fbff);
}
.wa-phone-head{
  display:flex;
  gap:12px;
  align-items:center;
  padding:16px;
  border-bottom:1px solid rgba(219,234,254,.95);
  background:#fff;
}
.wa-avatar{
  display:grid;
  width:42px;
  height:42px;
  place-items:center;
  border-radius:15px;
  background:#2563eb;
  color:#fff;
  font-family:var(--font-display);
  font-weight:900;
}
.wa-phone-head strong{
  display:block;
  color:var(--ink);
}
.wa-phone-head span{
  color:#16a34a;
  font-size:12px;
  font-weight:850;
}
.wa-phone-chat{
  display:flex;
  flex-direction:column;
  gap:10px;
  padding:14px;
}
.wa-phone-bubble{
  max-width:86%;
  padding:.66rem .78rem .5rem;
  border:1px solid rgba(219,234,254,.95);
  border-radius:20px;
  background:#fff;
  color:var(--ink);
  font-size:14px;
  line-height:1.38;
  box-shadow:0 12px 28px rgba(15,23,42,.06);
  animation:waBubbleIn .24s var(--ease) both;
}
.wa-phone-bubble.is-customer{
  align-self:flex-start;
  border-bottom-left-radius:8px;
}
.wa-phone-bubble.is-bot{
  align-self:flex-end;
  border-color:#bfdbfe;
  border-bottom-right-radius:8px;
  background:#eef6ff;
  color:#075dcf;
}
.wa-phone-choice{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-self:flex-end;
  max-width:90%;
}
.wa-phone-choice button{
  padding:.48rem .65rem;
  border:1px solid #bfdbfe;
  border-radius:999px;
  background:#fff;
  color:#075dcf;
  font-size:12px;
  font-weight:900;
}
.wa-phone-choice button.is-selected{
  background:#2563eb;
  border-color:#2563eb;
  color:#fff;
}
.wa-backstage{
  display:grid;
  gap:16px;
}
.wa-backstage-head span{
  display:inline-flex;
  margin-bottom:12px;
  padding:.42rem .68rem;
  border:1px solid #bfdbfe;
  border-radius:999px;
  background:#eef6ff;
  color:#075dcf;
  font-size:12px;
  font-weight:900;
}
.wa-backstage-head h2{
  max-width:560px;
  margin:0;
  color:var(--ink);
  font-family:var(--font-display);
  font-size:clamp(2rem,4vw,3.2rem);
  line-height:1.02;
  letter-spacing:-.04em;
}
.wa-backstage-list{
  display:grid;
  gap:12px;
}
.wa-backstage-card{
  display:grid;
  grid-template-columns:42px minmax(0,1fr);
  gap:13px;
  align-items:start;
  padding:18px;
  border:1px solid rgba(226,232,240,.95);
  border-radius:22px;
  background:#fff;
  opacity:.58;
  box-shadow:0 12px 32px rgba(15,23,42,.045);
  transition:opacity .18s var(--ease),border-color .18s var(--ease),box-shadow .18s var(--ease),transform .18s var(--ease);
}
.wa-backstage-card span{
  display:grid;
  width:42px;
  height:42px;
  place-items:center;
  border-radius:14px;
  background:#f1f5f9;
  color:#64748b;
  font-weight:950;
}
.wa-backstage-card strong{
  display:block;
  color:var(--ink);
  font-size:1rem;
}
.wa-backstage-card p{
  margin:.25rem 0 0;
  color:var(--ink-4);
  font-size:14px;
  line-height:1.5;
}
.wa-backstage-card.is-active{
  transform:translateY(-2px);
  opacity:1;
  border-color:#93c5fd;
  box-shadow:0 18px 48px rgba(37,99,235,.13);
}
.wa-backstage-card.is-active span{
  background:#2563eb;
  color:#fff;
}
.wa-tour-timeline{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:10px;
  margin:22px 0 0;
}
.wa-tour-step{
  display:flex;
  gap:10px;
  align-items:center;
  padding:13px;
  border:1px solid rgba(226,232,240,.95);
  border-radius:18px;
  background:#fff;
  color:var(--ink-4);
  font-weight:850;
}
.wa-tour-step span{
  display:grid;
  width:30px;
  height:30px;
  flex:0 0 auto;
  place-items:center;
  border-radius:10px;
  background:#f1f5f9;
  color:#64748b;
  font-size:12px;
  font-weight:950;
}
.wa-tour-step.is-active{
  border-color:#93c5fd;
  background:#eef6ff;
  color:#075dcf;
}
.wa-tour-step.is-active span{
  background:#2563eb;
  color:#fff;
}
.wa-tour-controls{
  position:relative;
  z-index:1;
  display:flex;
  justify-content:center;
  gap:10px;
  margin-top:22px;
}
.wa-tour-benefits{
  background:#fff;
}
.wa-benefit-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:18px;
}
.wa-benefit-grid article{
  padding:30px;
  border:1px solid rgba(191,219,254,.95);
  border-radius:28px;
  background:linear-gradient(180deg,#fff,#f8fbff);
  box-shadow:0 18px 52px rgba(15,23,42,.06);
}
.wa-benefit-grid span{
  display:inline-flex;
  margin-bottom:14px;
  padding:.45rem .7rem;
  border:1px solid #bfdbfe;
  border-radius:999px;
  background:#eef6ff;
  color:#075dcf;
  font-size:12px;
  font-weight:900;
}
.wa-benefit-grid ul{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
  margin:0;
  padding:0;
  list-style:none;
}
.wa-benefit-grid li{
  padding:12px 13px;
  border:1px solid rgba(219,234,254,.95);
  border-radius:16px;
  background:#fff;
  color:var(--ink-3);
  font-weight:750;
}
@media(max-width:980px){
  .wa-tour-hero-grid,
  .wa-tour-demo{
    grid-template-columns:1fr;
  }
  .wa-hero-mini{
    max-width:620px;
  }
  .wa-phone{
    width:min(100%,360px);
    max-width:360px;
  }
  .wa-tour-timeline{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}
@media(max-width:680px){
  .wa-tour-hero{
    padding:92px 0 46px;
  }
  .wa-tour-demo{
    padding:16px;
    border-radius:28px;
  }
  .wa-phone{
    border-radius:34px;
    padding:10px;
  }
  .wa-phone-screen{
    min-height:0;
    border-radius:26px;
  }
  .wa-phone-chat{
    gap:9px;
    padding:12px;
  }
  .wa-phone-bubble{
    max-width:94%;
  }
  .wa-tour-timeline,
  .wa-benefit-grid,
  .wa-benefit-grid ul{
    grid-template-columns:1fr;
  }
  .wa-tour-controls{
    align-items:stretch;
    flex-direction:column;
  }
  .wa-tour-controls .btn{
    justify-content:center;
  }
}

/* v52 WhatsApp tour polish */
body.whatsapp-demo-page{
  position:relative;
  overflow-x:hidden;
  background:
    radial-gradient(720px 420px at 12% 4%,rgba(37,211,102,.07),transparent 66%),
    radial-gradient(620px 360px at 86% 54%,rgba(18,140,126,.05),transparent 70%),
    linear-gradient(135deg,#fbfdff 0%,#f4fdf7 48%,#fff 100%);
}
body.whatsapp-demo-page::before{
  content:"";
  position:fixed;
  inset:0;
  z-index:-2;
  pointer-events:none;
  opacity:.22;
  background-image:
    linear-gradient(rgba(37,211,102,.09) 1px,transparent 1px),
    linear-gradient(90deg,rgba(37,211,102,.09) 1px,transparent 1px),
    radial-gradient(circle at 1px 1px,rgba(37,211,102,.12) 1px,transparent 0);
  background-size:64px 64px,64px 64px,22px 22px;
  animation:waGridDrift 42s linear infinite;
}
body.whatsapp-demo-page::after{
  content:"";
  position:fixed;
  inset:-20%;
  z-index:-1;
  pointer-events:none;
  opacity:.6;
  background:
    radial-gradient(520px 320px at 74% 18%,rgba(37,211,102,.08),transparent 72%),
    radial-gradient(460px 280px at 22% 72%,rgba(134,239,172,.07),transparent 72%),
    radial-gradient(520px 300px at 50% 92%,rgba(255,255,255,.72),transparent 72%);
  filter:blur(22px);
  animation:waGlowBreathe 18s ease-in-out infinite alternate;
}
.wa-tour-hero,
.wa-tour-section,
.wa-demo-final{
  background:transparent;
}
.wa-tour-benefits{
  background:linear-gradient(180deg,rgba(255,255,255,.74),rgba(248,251,255,.84));
}
.wa-phone{
  width:clamp(300px,28vw,370px);
  aspect-ratio:9 / 16;
  max-height:620px;
  border-color:rgba(96,165,250,.55);
  background:
    linear-gradient(145deg,rgba(255,255,255,.8),rgba(219,234,254,.88)),
    linear-gradient(180deg,#f8fbff,#eaf4ff);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.9),
    0 34px 90px rgba(15,23,42,.16),
    0 0 0 8px rgba(219,234,254,.24);
}
.wa-phone-screen{
  height:100%;
  min-height:0;
  background:
    radial-gradient(circle at 18% 10%,rgba(37,99,235,.075),transparent 28%),
    linear-gradient(180deg,#fff,#f7fbff);
}
.wa-phone-head{
  gap:11px;
  padding:16px 17px;
}
.wa-avatar{
  width:40px;
  height:40px;
  border-radius:999px;
  background:#eef6ff;
  border:1px solid #bfdbfe;
}
.wa-avatar span{
  display:block;
  width:12px;
  height:12px;
  border:3px solid #16a34a;
  border-radius:999px;
  background:#fff;
  box-shadow:0 0 0 4px rgba(22,163,74,.1);
}
.wa-phone-head strong{
  font-size:14px;
  letter-spacing:0;
}
.wa-phone-head span{
  color:var(--ink-4);
  font-size:11.5px;
  line-height:1.35;
}
.wa-phone-chat{
  gap:10px;
  padding:14px;
}
.wa-phone-bubble{
  display:grid;
  gap:3px;
  max-width:88%;
  padding:.62rem .74rem .46rem;
  box-shadow:0 10px 24px rgba(15,23,42,.045);
}
.wa-phone-bubble > b{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  align-items:center;
  color:var(--ink-4);
  font-size:9.5px;
  font-weight:900;
  letter-spacing:.03em;
  text-transform:uppercase;
}
.wa-phone-bubble > b em{
  padding:.16rem .38rem;
  border:1px solid #bfdbfe;
  border-radius:999px;
  background:#fff;
  color:#075dcf;
  font-size:9px;
  font-style:normal;
  text-transform:none;
  letter-spacing:0;
}
.wa-phone-bubble > span{
  font-size:13.5px;
  line-height:1.36;
}
.wa-phone-bubble > small{
  justify-self:end;
  color:#94a3b8;
  font-size:10px;
  font-weight:800;
}
.wa-phone-bubble.is-customer{
  align-self:flex-start;
  border-color:rgba(226,232,240,.95);
  background:#fff;
}
.wa-phone-bubble.is-bot{
  align-self:flex-end;
  border-color:#93c5fd;
  background:linear-gradient(180deg,#eef6ff,#e8f2ff);
  color:#075dcf;
  box-shadow:0 12px 28px rgba(37,99,235,.09);
}
.wa-phone-bubble.is-bot > b{
  color:#075dcf;
}
.wa-phone-choice{
  align-self:flex-end;
  gap:7px;
  justify-content:flex-end;
  padding:2px 0;
}
.wa-phone-choice button{
  min-height:34px;
  padding:.46rem .64rem;
  background:rgba(255,255,255,.88);
  box-shadow:0 8px 18px rgba(15,23,42,.045);
}
.wa-phone-choice small{
  flex-basis:100%;
  color:#94a3b8;
  font-size:10px;
  font-weight:800;
  text-align:right;
}
.wa-typing{
  display:inline-flex;
  gap:5px;
  align-items:center;
  align-self:flex-end;
  width:max-content;
  max-width:86%;
  padding:.48rem .66rem;
  border:1px solid #bfdbfe;
  border-radius:999px;
  background:#eef6ff;
  color:#075dcf;
  font-size:11px;
  font-weight:850;
}
.wa-typing i{
  width:5px;
  height:5px;
  border-radius:999px;
  background:#60a5fa;
  opacity:.75;
  animation:waTypingDot 1.1s ease-in-out infinite;
}
.wa-typing i:nth-child(2){animation-delay:.12s}
.wa-typing i:nth-child(3){animation-delay:.24s}
.wa-backstage-head span{
  margin-bottom:10px;
}
.wa-backstage-card{
  min-height:104px;
}
.wa-demo-final{
  position:relative;
  overflow:hidden;
}
.wa-demo-final::before{
  content:"";
  position:absolute;
  inset:auto 0 4% 0;
  height:280px;
  pointer-events:none;
  background:radial-gradient(520px 220px at 50% 50%,rgba(37,99,235,.13),transparent 70%);
}
.wa-premium-cta{
  position:relative;
  isolation:isolate;
  display:grid;
  grid-template-columns:minmax(260px,.95fr) minmax(260px,1fr) auto;
  gap:clamp(18px,3vw,34px);
  align-items:center;
  overflow:hidden;
  padding:clamp(26px,4vw,44px);
  border:1px solid rgba(147,197,253,.7);
  border-radius:34px;
  background:
    radial-gradient(540px 260px at 85% 0%,rgba(37,99,235,.18),transparent 70%),
    radial-gradient(420px 240px at 0% 100%,rgba(125,211,252,.18),transparent 70%),
    linear-gradient(135deg,rgba(255,255,255,.88),rgba(238,246,255,.9));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.9),
    0 30px 90px rgba(15,23,42,.11);
  backdrop-filter:blur(16px);
}
.wa-premium-cta::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:-1;
  opacity:.42;
  background-image:radial-gradient(circle at 1px 1px,rgba(37,99,235,.18) 1px,transparent 0);
  background-size:24px 24px;
}
.wa-cta-title span{
  display:inline-flex;
  margin-bottom:12px;
  padding:.48rem .72rem;
  border:1px solid #bfdbfe;
  border-radius:999px;
  background:#fff;
  color:#075dcf;
  font-size:12px;
  font-weight:900;
}
.wa-cta-title h2{
  margin:0;
  color:var(--ink);
  font-family:var(--font-display);
  font-size:clamp(2rem,4vw,3.4rem);
  line-height:1;
  letter-spacing:-.04em;
}
.wa-premium-cta p{
  margin:0;
  color:var(--ink-3);
  font-size:clamp(1rem,1.5vw,1.12rem);
  line-height:1.65;
}
.wa-cta-actions{
  display:grid;
  gap:10px;
  min-width:235px;
}
.wa-cta-actions .btn{
  justify-content:center;
  min-height:50px;
  white-space:nowrap;
}
.wa-cta-actions .btn-primary{
  box-shadow:0 18px 42px rgba(37,99,235,.24);
}
.wa-cta-actions .btn-primary:hover,
.wa-cta-actions .btn-ghost:hover{
  transform:translateY(-2px);
}
.wa-cta-actions .btn-ghost{
  border-color:rgba(147,197,253,.9);
  background:rgba(255,255,255,.78);
}
.wa-cta-orbit{
  position:absolute;
  inset:0;
  pointer-events:none;
}
.wa-cta-orbit span{
  position:absolute;
  padding:.38rem .58rem;
  border:1px solid rgba(191,219,254,.95);
  border-radius:999px;
  background:rgba(255,255,255,.72);
  color:#075dcf;
  font-size:11px;
  font-weight:900;
  box-shadow:0 12px 30px rgba(15,23,42,.06);
}
.wa-cta-orbit span:nth-child(1){top:18px;right:18px}
.wa-cta-orbit span:nth-child(2){bottom:18px;left:24px}
.wa-cta-orbit span:nth-child(3){top:18px;left:48%}
.wa-cta-orbit span:nth-child(4){bottom:20px;right:26%}
.wa-cta-orbit span:nth-child(5){top:50%;right:14px}
@keyframes waGridDrift{
  from{background-position:0 0,0 0,0 0}
  to{background-position:64px 64px,64px 64px,22px 22px}
}
@keyframes waGlowBreathe{
  from{transform:translate3d(0,0,0) scale(1);opacity:.58}
  to{transform:translate3d(1.2%,-1%,0) scale(1.03);opacity:.78}
}
@keyframes waTypingDot{
  0%,80%,100%{transform:translateY(0);opacity:.45}
  40%{transform:translateY(-2px);opacity:1}
}
@media(prefers-reduced-motion:reduce){
  body.whatsapp-demo-page::before,
  body.whatsapp-demo-page::after,
  .wa-typing i{
    animation:none;
  }
}
@media(max-width:1020px){
  .wa-premium-cta{
    grid-template-columns:1fr;
  }
  .wa-cta-actions{
    grid-template-columns:repeat(2,minmax(0,1fr));
    min-width:0;
  }
}
@media(max-width:680px){
  body.whatsapp-demo-page::before{
    opacity:.18;
    background-size:42px 42px,42px 42px,22px 22px;
  }
  body.whatsapp-demo-page::after{
    opacity:.38;
  }
  .wa-phone-head{
    align-items:flex-start;
  }
  .wa-phone-head span{
    display:block;
  }
  .wa-phone-chat{
    gap:9px;
  }
  .wa-premium-cta{
    padding:24px;
    border-radius:26px;
  }
  .wa-cta-actions{
    grid-template-columns:1fr;
  }
  .wa-cta-orbit{
    display:none;
  }
}

/* v53 ambient orbit background for inner pages */
body.has-ambient-bg{
  position:relative;
  overflow-x:hidden;
  background:
    radial-gradient(760px 420px at 14% 0%,rgba(37,99,235,.075),transparent 68%),
    radial-gradient(680px 420px at 92% 38%,rgba(14,165,233,.055),transparent 72%),
    linear-gradient(135deg,#fbfdff 0%,#f7fbff 44%,#fff 100%);
}
body.has-ambient-bg .site-header,
body.has-ambient-bg main,
body.has-ambient-bg .site-footer,
body.has-ambient-bg footer{
  position:relative;
  z-index:1;
}
.ambient-orbit-bg{
  position:fixed;
  inset:-12vh -8vw;
  z-index:0;
  overflow:hidden;
  pointer-events:none;
  opacity:.78;
  transform:translate3d(0,calc(var(--ambient-scroll,0px) * -.018),0);
  transition:transform .08s linear;
}
.ambient-grid-layer{
  position:absolute;
  inset:0;
  opacity:.22;
  background-image:
    linear-gradient(rgba(37,99,235,.08) 1px,transparent 1px),
    linear-gradient(90deg,rgba(37,99,235,.08) 1px,transparent 1px),
    radial-gradient(circle at 1px 1px,rgba(37,99,235,.12) 1px,transparent 0);
  background-size:58px 58px,58px 58px,24px 24px;
  mask-image:linear-gradient(180deg,#000 0%,rgba(0,0,0,.78) 42%,transparent 100%);
  animation:ambientGridDrift 90s linear infinite;
}
.ambient-orbit{
  position:absolute;
  display:block;
  border:1px solid rgba(37,99,235,.105);
  border-radius:50%;
  box-shadow:inset 0 0 42px rgba(37,99,235,.025);
  transform-origin:center;
  animation:ambientOrbitSpin 82s linear infinite;
}
.ambient-orbit::before{
  content:"";
  position:absolute;
  width:8px;
  height:8px;
  border-radius:999px;
  background:rgba(37,99,235,.22);
  box-shadow:0 0 0 8px rgba(37,99,235,.045);
}
.ambient-orbit-a{
  width:min(760px,76vw);
  height:min(360px,36vw);
  right:2vw;
  top:2vh;
  transform:rotate(-13deg);
}
.ambient-orbit-a::before{right:18%;top:8%}
.ambient-orbit-b{
  width:min(520px,58vw);
  height:min(520px,58vw);
  left:-8vw;
  top:32vh;
  border-color:rgba(14,165,233,.085);
  animation-duration:96s;
  animation-direction:reverse;
}
.ambient-orbit-b::before{left:50%;bottom:-4px;background:rgba(14,165,233,.18)}
.ambient-orbit-c{
  width:min(620px,70vw);
  height:min(250px,32vw);
  right:12vw;
  bottom:8vh;
  border-style:dashed;
  border-color:rgba(37,99,235,.075);
  animation-duration:110s;
}
.ambient-orbit-c::before{left:14%;top:20%;opacity:.65}
.ambient-glow{
  position:absolute;
  display:block;
  border-radius:999px;
  filter:blur(34px);
  opacity:.52;
  transform:translate3d(0,calc(var(--ambient-scroll,0px) * .012),0);
  animation:ambientGlowBreath 18s ease-in-out infinite alternate;
}
.ambient-glow-a{
  width:420px;
  height:280px;
  right:8vw;
  top:7vh;
  background:rgba(37,99,235,.115);
}
.ambient-glow-b{
  width:360px;
  height:260px;
  left:8vw;
  bottom:10vh;
  background:rgba(125,211,252,.13);
  animation-delay:-6s;
}
@keyframes ambientOrbitSpin{
  from{rotate:0deg}
  to{rotate:360deg}
}
@keyframes ambientGridDrift{
  from{background-position:0 0,0 0,0 0}
  to{background-position:58px 58px,58px 58px,24px 24px}
}
@keyframes ambientGlowBreath{
  from{opacity:.34;scale:1}
  to{opacity:.58;scale:1.035}
}
@media(prefers-reduced-motion:reduce){
  .ambient-orbit-bg,
  .ambient-orbit,
  .ambient-grid-layer,
  .ambient-glow{
    animation:none!important;
    transition:none!important;
    transform:none!important;
  }
}
@media(max-width:760px){
  body.has-ambient-bg{
    background:
      radial-gradient(520px 300px at 20% 0%,rgba(37,99,235,.055),transparent 70%),
      linear-gradient(135deg,#fbfdff 0%,#f8fbff 48%,#fff 100%);
  }
  .ambient-orbit-bg{
    inset:-8vh -28vw;
    opacity:.42;
    transform:translate3d(0,calc(var(--ambient-scroll,0px) * -.008),0);
  }
  .ambient-grid-layer{
    opacity:.14;
    background-size:46px 46px,46px 46px,24px 24px;
  }
  .ambient-orbit-a{
    width:112vw;
    height:52vw;
    right:-42vw;
    top:8vh;
  }
  .ambient-orbit-b{
    display:none;
  }
  .ambient-orbit-c{
    width:100vw;
    height:42vw;
    right:-34vw;
    bottom:10vh;
  }
  .ambient-glow{
    opacity:.32;
    filter:blur(28px);
  }
}

/* ======================================================
   Instagram DM Demo Page
   ====================================================== */
body.instagram-demo-page{
  position:relative;
  overflow-x:hidden;
  background:
    radial-gradient(720px 420px at 12% 4%,rgba(255,122,0,.07),transparent 66%),
    radial-gradient(620px 360px at 86% 54%,rgba(88,81,219,.06),transparent 70%),
    linear-gradient(135deg,#fbfdff 0%,#fef9f5 48%,#fff 100%);
}
body.instagram-demo-page::before{
  content:"";
  position:fixed;
  inset:0;
  z-index:-2;
  pointer-events:none;
  opacity:.22;
  background-image:
    linear-gradient(rgba(88,81,219,.09) 1px,transparent 1px),
    linear-gradient(90deg,rgba(88,81,219,.09) 1px,transparent 1px),
    radial-gradient(circle at 1px 1px,rgba(255,122,0,.12) 1px,transparent 0);
  background-size:64px 64px,64px 64px,22px 22px;
  animation:waGridDrift 42s linear infinite;
}
body.instagram-demo-page::after{
  content:"";
  position:fixed;
  inset:-20%;
  z-index:-1;
  pointer-events:none;
  opacity:.6;
  background:
    radial-gradient(520px 320px at 74% 18%,rgba(255,122,0,.07),transparent 72%),
    radial-gradient(460px 280px at 22% 72%,rgba(255,62,130,.05),transparent 72%),
    radial-gradient(520px 300px at 50% 92%,rgba(255,255,255,.72),transparent 72%);
  filter:blur(22px);
  animation:waGlowBreathe 18s ease-in-out infinite alternate;
}
.ig-tour-hero,
.ig-tour-section,
.ig-demo-final{
  background:transparent;
}
.ig-tour-benefits{
  background:linear-gradient(180deg,rgba(255,255,255,.74),rgba(255,249,245,.84));
}

/* ======================================================
   Randevu Demo Page
   ====================================================== */
body.randevu-demo-page{
  position:relative;
  overflow-x:hidden;
  background:
    radial-gradient(720px 420px at 12% 4%,rgba(6,182,212,.08),transparent 66%),
    radial-gradient(620px 360px at 86% 54%,rgba(59,130,246,.07),transparent 70%),
    linear-gradient(135deg,#fbfdff 0%,#f4fbff 48%,#fff 100%);
}
body.randevu-demo-page::before{
  content:"";
  position:fixed;
  inset:0;
  z-index:-2;
  pointer-events:none;
  opacity:.25;
  background-image:
    linear-gradient(rgba(6,182,212,.09) 1px,transparent 1px),
    linear-gradient(90deg,rgba(6,182,212,.09) 1px,transparent 1px),
    radial-gradient(circle at 1px 1px,rgba(6,182,212,.14) 1px,transparent 0);
  background-size:64px 64px,64px 64px,22px 22px;
  animation:waGridDrift 42s linear infinite;
}
body.randevu-demo-page::after{
  content:"";
  position:fixed;
  inset:-20%;
  z-index:-1;
  pointer-events:none;
  opacity:.6;
  background:
    radial-gradient(520px 320px at 74% 18%,rgba(6,182,212,.09),transparent 72%),
    radial-gradient(460px 280px at 22% 72%,rgba(59,130,246,.08),transparent 72%),
    radial-gradient(520px 300px at 50% 92%,rgba(255,255,255,.72),transparent 72%);
  filter:blur(20px);
  animation:waGlowBreathe 16s ease-in-out infinite alternate;
}
.rv-tour-hero,
.rv-tour-section,
.rv-demo-final{
  background:transparent;
}
.rv-tour-benefits{
  background:linear-gradient(180deg,rgba(255,255,255,.74),rgba(244,251,255,.84));
}

/* ======================================================
   Mouse parallax on demo channel backgrounds
   ====================================================== */
body.whatsapp-demo-page::before,
body.instagram-demo-page::before,
body.randevu-demo-page::before{
  transform:translate3d(calc(var(--mx,0)*8px),calc(var(--my,0)*8px),0);
  transition:transform .8s cubic-bezier(.25,.46,.45,.94);
}
body.whatsapp-demo-page::after,
body.instagram-demo-page::after,
body.randevu-demo-page::after{
  transform:translate3d(calc(var(--mx,0)*-5px),calc(var(--my,0)*-5px),0);
  transition:transform .9s cubic-bezier(.25,.46,.45,.94);
}
@media(prefers-reduced-motion:reduce){
  body.whatsapp-demo-page::before,
  body.instagram-demo-page::before,
  body.randevu-demo-page::before,
  body.whatsapp-demo-page::after,
  body.instagram-demo-page::after,
  body.randevu-demo-page::after{
    animation:none!important;
    transform:none!important;
    transition:none!important;
  }
}

/* ── Fix section-soft clash with ambient background ── */
body.has-ambient-bg .section-soft{
  background:rgba(247,251,255,.72);
}
body.has-ambient-bg .section-soft[style]{
  background:rgba(247,251,255,.72)!important;
}

/* ── Phone mockup flex fix so screen fills correctly ── */
.wa-phone{
  display:flex;
  flex-direction:column;
}
.wa-phone-speaker{
  flex-shrink:0;
}
.wa-phone-screen{
  flex:1;
  height:auto;
  min-height:0;
}

/* ── Slightly stronger ambient orbit visibility ── */
body.has-ambient-bg{
  background:
    radial-gradient(760px 420px at 14% 0%,rgba(37,99,235,.09),transparent 68%),
    radial-gradient(680px 420px at 92% 38%,rgba(14,165,233,.07),transparent 72%),
    linear-gradient(135deg,#fbfdff 0%,#f7fbff 44%,#fff 100%);
}
.ambient-orbit-bg{
  opacity:.88;
}
.ambient-grid-layer{
  opacity:.28;
}
.ambient-orbit{
  border-color:rgba(37,99,235,.14);
  box-shadow:inset 0 0 52px rgba(37,99,235,.035);
}
.ambient-glow{
  opacity:.58;
}
.ambient-glow-a{
  background:rgba(37,99,235,.13);
}
.ambient-glow-b{
  background:rgba(125,211,252,.15);
}

/* ── Instagram DM demo — channel accent on phone ── */
.instagram-demo-page .wa-avatar span{
  border-color:rgba(255,122,0,.7);
  background:rgba(255,122,0,.08);
  box-shadow:0 0 0 4px rgba(255,122,0,.08);
}
.instagram-demo-page .wa-phone-head span{
  color:rgba(255,122,0,.8);
}
.instagram-demo-page .wa-phone-head strong::after{
  content:" · Instagram";
  color:rgba(255,122,0,.55);
  font-size:11px;
  font-weight:700;
}
.instagram-demo-page .wa-phone-bubble.is-bot{
  border-color:rgba(255,122,0,.18);
  background:linear-gradient(180deg,#fff5f0,#fff9f5);
  color:#c2410c;
}
.instagram-demo-page .wa-phone-bubble.is-bot > b{
  color:#c2410c;
}
.instagram-demo-page .wa-phone-bubble.is-bot > b em{
  border-color:rgba(255,122,0,.2);
  background:rgba(255,249,245,.9);
  color:#c2410c;
}
.instagram-demo-page .wa-phone-choice button{
  border-color:rgba(255,122,0,.25);
  color:#c2410c;
}
.instagram-demo-page .wa-phone-choice button.is-selected{
  background:linear-gradient(135deg,#f97316,#fb923c);
  border-color:#f97316;
  color:#fff;
}

/* ── Randevu demo — channel accent on phone ── */
.randevu-demo-page .wa-avatar span{
  border-color:rgba(6,182,212,.7);
  background:rgba(6,182,212,.08);
  box-shadow:0 0 0 4px rgba(6,182,212,.08);
}
.randevu-demo-page .wa-phone-head span{
  color:rgba(6,182,212,.85);
}

/* ============================================================
   CINEMATIC WHATSAPP TOUR — ct-* prefix  (demo-whatsapp.html)
   ============================================================ */

@keyframes ctFloat{0%,100%{transform:translateY(0) rotate(var(--rot,0deg))}50%{transform:translateY(-10px) rotate(var(--rot,0deg))}}
@keyframes ctOrbit{0%,100%{transform:translate(0,0) scale(1)}40%{transform:translate(30px,-22px) scale(1.04)}70%{transform:translate(-16px,14px) scale(.97)}}
@keyframes ctScroll{0%,100%{transform:translateY(0);opacity:1}50%{transform:translateY(6px);opacity:.45}}

/* Hero */
.ct-hero{
  position:relative;overflow:hidden;
  min-height:100svh;display:flex;align-items:center;
  padding:clamp(7rem,14vw,12rem) 0 clamp(5rem,10vw,9rem);
  background:linear-gradient(168deg,#edf3ff 0%,#f4f8ff 55%,var(--bg) 100%);
}
.ct-hero::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(circle at 1px 1px,rgba(37,99,235,.11) 1px,transparent 0);
  background-size:28px 28px;
  mask-image:linear-gradient(180deg,rgba(0,0,0,.55) 0%,transparent 76%);
}
.ct-hero-bg{position:absolute;inset:0;z-index:0;pointer-events:none;}
.ct-hero-orb{position:absolute;border-radius:50%;filter:blur(72px);will-change:transform;}
.ct-hero-orb-a{width:620px;height:420px;top:-8%;right:-4%;background:radial-gradient(circle,rgba(37,99,235,.17),transparent 65%);animation:ctOrbit 22s ease-in-out infinite;}
.ct-hero-orb-b{width:440px;height:440px;bottom:0;left:-6%;background:radial-gradient(circle,rgba(147,197,253,.22),transparent 65%);animation:ctOrbit 28s ease-in-out infinite reverse;}
.ct-hero-inner{position:relative;z-index:2;text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--sp-5);max-width:900px;margin:0 auto;}
.ct-hero h1{font-size:clamp(3rem,5vw + 1rem,6.2rem);letter-spacing:-.046em;line-height:.9;color:var(--ink);}
.ct-hero-lead{font-size:clamp(var(--fs-md),1.45vw,var(--fs-xl));color:var(--ink-3);text-align:center;max-width:58ch;line-height:1.62;}
.ct-hero-ctas{display:flex;flex-wrap:wrap;gap:var(--sp-3);justify-content:center;margin-top:var(--sp-2);}
.ct-scroll-arrow{display:inline-block;animation:ctScroll 1.9s ease-in-out infinite;margin-left:.15rem;}

/* Floating chips */
.ct-chips{position:absolute;inset:0;pointer-events:none;}
.ct-chip{
  position:absolute;padding:.52rem 1.05rem;
  background:rgba(255,255,255,.92);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border:1px solid rgba(147,197,253,.55);border-radius:var(--r-full);
  font-size:var(--fs-sm);color:var(--ink-2);font-weight:500;white-space:nowrap;
  box-shadow:0 4px 18px rgba(37,99,235,.07),0 1px 4px rgba(0,0,0,.04);
}
.ct-chip-a{top:18%;left:7%;--rot:-2deg;animation:ctFloat 4.4s ease-in-out infinite;}
.ct-chip-b{top:63%;left:5%;--rot:3deg;animation:ctFloat 5.1s ease-in-out infinite;animation-delay:.9s;}
.ct-chip-c{top:21%;right:6%;--rot:3deg;animation:ctFloat 3.9s ease-in-out infinite;animation-delay:1.5s;}
.ct-chip-d{bottom:21%;right:8%;--rot:-3deg;animation:ctFloat 4.7s ease-in-out infinite;animation-delay:.45s;}

/* Shared scene */
.ct-scene{
  position:relative;min-height:88vh;display:flex;align-items:center;
  padding:clamp(4rem,8vw,7rem) 0;overflow:hidden;
}
.ct-scene-alt{background:linear-gradient(180deg,#f0f6ff 0%,#f8faff 60%,#fff 100%);}

/* Split layout */
.ct-split{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(2.5rem,6vw,5rem);align-items:center;width:100%;
}
@media(min-width:768px){
  .ct-split .ct-split-copy{order:-1;}
  .ct-split.ct-split-rev .ct-split-copy{order:unset;}
}

/* Copy side */
.ct-split-copy{display:flex;flex-direction:column;gap:var(--sp-5);}
.ct-step-badge{
  display:inline-flex;align-items:center;justify-content:center;
  width:46px;height:46px;border-radius:var(--r-full);
  background:var(--accent-soft);color:var(--accent);
  font-family:var(--font-mono);font-size:var(--fs-xs);font-weight:700;letter-spacing:.06em;
}
.ct-scene-h{font-family:var(--font-display);font-size:clamp(2.4rem,4vw,4rem);letter-spacing:-.04em;line-height:.93;color:var(--ink);}
.ct-scene-p{font-size:clamp(var(--fs-md),1.35vw,var(--fs-xl));color:var(--ink-4);max-width:38ch;line-height:1.65;}

/* Visual side */
.ct-split-phone{display:flex;justify-content:center;align-items:center;position:relative;}

/* Phone mockup */
.ct-phone{
  width:272px;height:544px;background:#fff;
  border-radius:46px;border:9px solid #0B1220;
  box-shadow:0 0 0 1px rgba(255,255,255,.06),0 32px 72px rgba(11,18,32,.2),0 10px 24px rgba(11,18,32,.1);
  overflow:hidden;display:flex;flex-direction:column;flex-shrink:0;
}
.ct-phone-topbar{
  height:28px;background:#0B1220;display:flex;justify-content:center;align-items:flex-end;padding-bottom:5px;flex-shrink:0;
}
.ct-phone-topbar::after{content:'';width:76px;height:14px;background:#000;border-radius:0 0 12px 12px;}
.ct-phone-head{
  flex-shrink:0;display:flex;align-items:center;gap:.6rem;padding:.65rem .9rem;
  background:#1E293B;border-bottom:1px solid rgba(255,255,255,.06);
}
.ct-ph-avatar{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.15);display:grid;place-items:center;font-size:16px;flex-shrink:0;}
.ct-ph-meta strong{display:block;font-size:13px;font-weight:600;color:#fff;line-height:1.2;}
.ct-ph-meta span{font-size:10px;color:rgba(255,255,255,.65);}
.ct-chat-bg{
  flex:1;overflow:hidden;background:#eef2f7;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:.75rem .65rem;gap:.35rem;
}

/* Message bubbles */
.ct-msg{
  max-width:84%;padding:.48rem .78rem;border-radius:16px;
  font-size:12.5px;line-height:1.45;
  opacity:0;transform:translateY(8px);
  transition:opacity .32s ease,transform .32s ease;
}
.ct-msg.ct-in{opacity:1;transform:none;}
.ct-msg-recv{align-self:flex-end;background:#dbeafe;color:var(--ink-2);border-bottom-right-radius:4px;}
.ct-msg-sent{align-self:flex-start;background:#fff;color:var(--ink-2);border-bottom-left-radius:4px;box-shadow:0 1px 3px rgba(0,0,0,.08);}
.ct-auto-tag{display:block;font-size:9px;font-weight:700;color:var(--accent);letter-spacing:.05em;text-transform:uppercase;margin-bottom:.18rem;}
.ct-msg-choice{background:#bfdbfe;font-weight:600;font-size:12px;}
.ct-msg-ts{font-size:9.5px;color:rgba(0,0,0,.3);align-self:flex-end;padding:0 .2rem;opacity:0;transition:opacity .3s ease;}
.ct-msg-ts.ct-in{opacity:1;}
.ct-quick-replies{align-self:flex-start;display:flex;flex-wrap:wrap;gap:.3rem;opacity:0;transform:translateY(6px);transition:opacity .32s ease,transform .32s ease;}
.ct-quick-replies.ct-in{opacity:1;transform:none;}
.ct-quick-replies span{padding:.34rem .64rem;background:#fff;border:1.5px solid var(--accent-2);border-radius:var(--r-full);color:var(--accent-2);font-size:10.5px;font-weight:600;}

/* Lead card */
.ct-lead-card{
  position:absolute;right:-18px;top:50%;
  transform:translateY(-50%) translateX(32px);
  opacity:0;width:185px;
  background:#fff;border:1px solid rgba(147,197,253,.7);
  border-radius:var(--r-xl);box-shadow:0 16px 44px rgba(37,99,235,.13),0 4px 12px rgba(37,99,235,.06);
  padding:.9rem;transition:opacity .5s ease,transform .5s ease;
}
.ct-lead-card.ct-in{opacity:1;transform:translateY(-50%) translateX(0);}
.ct-lc-head{display:flex;align-items:center;gap:.45rem;margin-bottom:.65rem;flex-wrap:wrap;}
.ct-lc-avatar{width:28px;height:28px;border-radius:50%;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;font-size:13px;font-weight:700;flex-shrink:0;}
.ct-lc-head strong{font-size:12px;color:var(--ink);}
.ct-lc-head>div>span{font-size:10px;color:var(--ink-4);}
.ct-lc-status{margin-left:auto;font-size:8px;padding:.2rem .42rem;background:#d1fae5;color:#065f46;border-radius:var(--r-full);font-weight:700;white-space:nowrap;}
.ct-lc-rows{display:flex;flex-direction:column;gap:.22rem;}
.ct-lc-rows div{display:flex;gap:.35rem;font-size:10.5px;color:var(--ink-4);}
.ct-lc-rows b{color:var(--ink-2);font-weight:600;min-width:34px;}

/* System cards */
.ct-sys-cards{display:flex;flex-direction:column;gap:var(--sp-4);width:100%;max-width:400px;}
.ct-sys-card{
  display:flex;align-items:flex-start;gap:.85rem;padding:1rem 1.15rem;
  background:#fff;border:1px solid var(--line-2);border-radius:var(--r-lg);box-shadow:var(--sh-sm);
  opacity:0;transform:translateY(14px);
  transition:opacity .4s ease,transform .4s ease,border-color .35s ease,box-shadow .35s ease;
}
.ct-sys-card.ct-in{opacity:1;transform:none;}
.ct-sys-card:nth-child(3).ct-in{border-color:rgba(147,197,253,.5);box-shadow:0 6px 20px rgba(37,99,235,.06);}
.ct-sys-card:nth-child(4).ct-in{border-color:rgba(37,99,235,.25);box-shadow:0 8px 26px rgba(37,99,235,.1);}
.ct-sys-icon{flex-shrink:0;width:34px;height:34px;display:grid;place-items:center;border-radius:var(--r-sm);font-size:16px;line-height:1;}
.ct-sys-icon-done{background:#dcfce7;}
.ct-sys-icon-pin{background:#fef9c3;}
.ct-sys-icon-bell{background:#dbeafe;}
.ct-sys-icon-arrow{background:var(--accent-soft);color:var(--accent);font-style:normal;font-weight:700;font-size:18px;}
.ct-sys-card div strong{display:block;font-size:var(--fs-sm);color:var(--ink);font-weight:600;line-height:1.3;}
.ct-sys-card div span{display:block;font-size:var(--fs-xs);color:var(--ink-4);margin-top:.1rem;}

/* Final CTA scene */
.ct-final-scene{
  min-height:72vh;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(145deg,#edf2ff 0%,#f0f6ff 50%,#f8fbff 100%);
  position:relative;overflow:hidden;padding:clamp(5rem,10vw,9rem) 0;
}
.ct-final-bg{position:absolute;inset:0;pointer-events:none;}
.ct-final-bg::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,rgba(37,99,235,.1) 1px,transparent 0);background-size:28px 28px;}
.ct-final-orb{position:absolute;border-radius:50%;filter:blur(80px);}
.ct-final-orb-a{width:500px;height:350px;top:0;right:0;background:radial-gradient(circle,rgba(37,99,235,.14),transparent 65%);animation:ctOrbit 22s ease-in-out infinite;}
.ct-final-orb-b{width:380px;height:380px;bottom:0;left:0;background:radial-gradient(circle,rgba(147,197,253,.18),transparent 65%);animation:ctOrbit 28s ease-in-out infinite reverse;}
.ct-final-inner{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--sp-6);max-width:760px;margin:0 auto;}
.ct-final-h{font-size:clamp(2.6rem,5vw,5rem);letter-spacing:-.04em;line-height:.91;color:var(--ink);}
.ct-final-p{font-size:clamp(var(--fs-lg),1.6vw,var(--fs-xl));color:var(--ink-3);text-align:center;max-width:55ch;}
.ct-final-ctas{display:flex;flex-wrap:wrap;gap:var(--sp-3);justify-content:center;margin-top:var(--sp-2);}

/* Reveal animations */
.ct-anim-left,.ct-anim-right,.ct-anim-up{opacity:0;transition:opacity .55s ease,transform .55s ease;}
.ct-anim-left{transform:translateX(-22px);}
.ct-anim-right{transform:translateX(22px);}
.ct-anim-up{transform:translateY(22px);}
.ct-scene.ct-ready .ct-anim-left,
.ct-scene.ct-ready .ct-anim-right,
.ct-scene.ct-ready .ct-anim-up,
.ct-final-scene.ct-ready .ct-anim-up{opacity:1;transform:none;}

/* Mobile */
@media(max-width:767px){
  .ct-hero h1{font-size:clamp(2.6rem,8.5vw,4rem);}
  .ct-hero-lead{font-size:var(--fs-md);}
  .ct-chips{display:none;}
  .ct-split{grid-template-columns:1fr;gap:var(--sp-8);}
  .ct-split .ct-split-copy{order:unset;}
  .ct-split-phone{order:-1;}
  .ct-scene{min-height:auto;padding:clamp(3.5rem,10vw,5rem) 0;}
  .ct-phone{width:240px;height:480px;border-radius:38px;border-width:8px;}
  .ct-lead-card{position:static;transform:none !important;top:auto;right:auto;width:100%;max-width:260px;margin:1rem auto 0;}
  .ct-lead-card.ct-in{opacity:1;transform:none !important;}
  .ct-sys-cards{max-width:100%;}
  .ct-final-h{font-size:clamp(2.2rem,7vw,3.5rem);}
  .ct-final-ctas{flex-direction:column;align-items:center;}
}

/* Reduced motion */
@media(prefers-reduced-motion:reduce){
  .ct-chip,.ct-scroll-arrow{animation:none;}
  .ct-hero-orb,.ct-final-orb{animation:none;}
  .ct-msg,.ct-quick-replies,.ct-lead-card,.ct-sys-card,
  .ct-anim-left,.ct-anim-right,.ct-anim-up{opacity:1!important;transform:none!important;transition:none!important;}
}

/* ============================================================
   CINEMATIC TOUR v2 — Premium Polish
   ============================================================ */

/* Hero orbs — more visible */
.ct-hero-orb-a{width:720px;height:500px;background:radial-gradient(circle,rgba(37,99,235,.21),transparent 65%);}
.ct-hero-orb-b{width:520px;height:520px;background:radial-gradient(circle,rgba(147,197,253,.27),transparent 65%);}

/* Hero orbit rings */
.ct-hero-bg::before,.ct-hero-bg::after{content:'';position:absolute;border-radius:50%;pointer-events:none;}
.ct-hero-bg::before{width:560px;height:560px;bottom:-80px;right:-60px;border:1px solid rgba(37,99,235,.08);}
.ct-hero-bg::after{width:780px;height:780px;bottom:-200px;right:-180px;border:1px solid rgba(147,197,253,.05);}

/* Chip depth + 5th chip position */
.ct-chip{padding:.56rem 1.1rem;box-shadow:0 6px 24px rgba(37,99,235,.09),0 1px 4px rgba(0,0,0,.05);}
.ct-chip-b{opacity:.62;}
.ct-chip-d{opacity:.54;}
.ct-chip-e{top:41%;right:13%;--rot:1.5deg;animation:ctFloat 5.8s ease-in-out infinite;animation-delay:2.1s;opacity:.68;}

/* Phone — larger with blue ambient glow */
.ct-phone{width:330px;height:660px;border-radius:50px;border-width:9px;
  box-shadow:0 0 0 1px rgba(255,255,255,.06),0 52px 104px rgba(11,18,32,.26),
  0 16px 36px rgba(11,18,32,.12),0 0 80px 20px rgba(37,99,235,.07),
  inset 0 1px 0 rgba(255,255,255,.06);}

/* Chat area */
.ct-chat-bg{padding:.9rem .8rem;gap:.48rem;}

/* Message bubbles — larger, scale-in animation */
.ct-msg{font-size:13.5px;padding:.56rem .9rem;border-radius:18px;
  transform:translateY(10px) scale(0.97);
  transition:opacity .52s cubic-bezier(0.22,1,0.36,1),transform .52s cubic-bezier(0.22,1,0.36,1);}
.ct-msg.ct-in{opacity:1;transform:none;}
.ct-msg-recv{border-radius:18px;border-bottom-right-radius:4px;}
.ct-msg-sent{border-radius:18px;border-bottom-left-radius:4px;}
.ct-msg-choice{font-size:13px;}
.ct-msg-ts{font-size:10.5px;}
.ct-auto-tag{font-size:10px;margin-bottom:.24rem;}

/* Quick replies — staggered reveal */
.ct-quick-replies{gap:.44rem;transition:opacity .45s cubic-bezier(0.22,1,0.36,1),transform .45s cubic-bezier(0.22,1,0.36,1);}
.ct-quick-replies span{padding:.4rem .76rem;font-size:11.5px;opacity:0;
  transform:translateY(6px) scale(0.95);transition:opacity .32s ease,transform .32s ease;}
.ct-quick-replies.ct-in span{opacity:1;transform:none;}
.ct-quick-replies.ct-in span:nth-child(2){transition-delay:.09s;}
.ct-quick-replies.ct-in span:nth-child(3){transition-delay:.18s;}

/* Lead card */
.ct-lead-card{right:-22px;width:200px;padding:1.05rem;
  transform:translateY(-50%) translateX(38px) scale(0.97);
  box-shadow:0 24px 60px rgba(37,99,235,.16),0 6px 18px rgba(37,99,235,.08);
  transition:opacity .58s cubic-bezier(0.22,1,0.36,1),transform .58s cubic-bezier(0.22,1,0.36,1);}
.ct-lead-card.ct-in{opacity:1;transform:translateY(-50%) translateX(0) scale(1);}

/* System cards — hover lift only after animation */
.ct-sys-card{padding:1.1rem 1.3rem;gap:1rem;transform:translateY(18px) scale(0.98);
  transition:opacity .55s cubic-bezier(0.22,1,0.36,1),transform .55s cubic-bezier(0.22,1,0.36,1),
  border-color .3s ease,box-shadow .3s ease;}
.ct-sys-card.ct-in{opacity:1;transform:none;}
.ct-sys-card.ct-in:hover{transform:translateY(-2px);border-color:rgba(147,197,253,.55);box-shadow:0 8px 24px rgba(37,99,235,.09);}
.ct-sys-icon{width:36px;height:36px;border-radius:var(--r-md);}

/* Step badge pulse on active scene */
.ct-step-badge{width:48px;height:48px;}
.ct-scene.ct-ready .ct-step-badge{box-shadow:0 0 0 6px rgba(37,99,235,.07);transition:box-shadow .7s cubic-bezier(0.22,1,0.36,1);}

/* Reveal animations — premium easing */
.ct-anim-left,.ct-anim-right,.ct-anim-up{transition:opacity .72s cubic-bezier(0.22,1,0.36,1),transform .72s cubic-bezier(0.22,1,0.36,1);}
.ct-anim-left{transform:translateX(-28px);}
.ct-anim-right{transform:translateX(28px);}
.ct-anim-up{transform:translateY(28px);}

/* Scene paragraph — slightly darker */
.ct-scene-p{color:var(--ink-3);}

/* Scene ambient — subtle radial fills */
.ct-scene:not(.ct-scene-alt):not(.ct-final-scene){
  background:radial-gradient(ellipse 55% 90% at 96% 50%,rgba(37,99,235,.05) 0%,transparent 70%),
    radial-gradient(ellipse 45% 70% at 4% 50%,rgba(147,197,253,.06) 0%,transparent 65%),#fff;}
.ct-scene-alt{
  background:radial-gradient(ellipse 50% 80% at 6% 52%,rgba(37,99,235,.06) 0%,transparent 65%),
    radial-gradient(ellipse 45% 65% at 90% 48%,rgba(147,197,253,.05) 0%,transparent 60%),
    linear-gradient(180deg,#f0f6ff 0%,#f8faff 60%,#fff 100%);}

/* Mobile overrides */
@media(max-width:767px){
  .ct-phone{width:240px;height:480px;border-radius:38px;border-width:8px;
    box-shadow:0 0 0 1px rgba(255,255,255,.06),0 24px 56px rgba(11,18,32,.22),0 8px 20px rgba(11,18,32,.1);}
  .ct-sys-card.ct-in:hover{transform:none;}
  .ct-hero-bg::before,.ct-hero-bg::after{display:none;}
}

/* Reduced motion v2 */
@media(prefers-reduced-motion:reduce){
  .ct-msg,.ct-quick-replies,.ct-quick-replies span,
  .ct-lead-card,.ct-sys-card,
  .ct-anim-left,.ct-anim-right,.ct-anim-up{opacity:1!important;transform:none!important;transition:none!important;}
  .ct-hero-orb-a,.ct-hero-orb-b{animation:none;}
}

/* ============================================================
   AUTOPLAY DEMO PLAYER  (ct-dp-*)
   ============================================================ */

.ct-dp-section{
  padding:clamp(4rem,9vw,6.5rem) 0;
  background:linear-gradient(180deg,#f8faff 0%,#fff 100%);
  overflow:hidden;
}

.ct-dp-wrap{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:clamp(2.5rem,6vw,5rem);
  align-items:start;
}

/* Phone column */
.ct-dp-phone-col{
  position:relative;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:.9rem;
}

/* Demo phone: inherits 330×660px from .ct-phone v2 rule; only override shadow */
.ct-dp-phone{
  box-shadow:0 0 0 1px rgba(255,255,255,.06),0 52px 104px rgba(11,18,32,.26),
    0 16px 36px rgba(11,18,32,.12),0 0 80px 20px rgba(37,99,235,.07),
    inset 0 1px 0 rgba(255,255,255,.06)!important;
}

/* Demo lead card — sits below phone as flow element */
.ct-dp-lead{
  width:100%;max-width:230px;
  background:#fff;
  border:1px solid rgba(147,197,253,.7);
  border-radius:var(--r-xl);
  box-shadow:0 16px 44px rgba(37,99,235,.13),0 4px 12px rgba(37,99,235,.06);
  padding:.9rem;
  opacity:0;
  transform:translateY(12px) scale(0.97);
  transition:opacity .55s cubic-bezier(0.22,1,0.36,1),transform .55s cubic-bezier(0.22,1,0.36,1);
}
.ct-dp-lead.ct-in{opacity:1;transform:none;}

/* Side column */
.ct-dp-side{
  display:flex;
  flex-direction:column;
  gap:1.4rem;
  padding-top:.5rem;
}

/* Step list */
.ct-dp-steps{display:flex;flex-direction:column;gap:.7rem;}

.ct-dp-step{
  display:flex;align-items:flex-start;gap:.7rem;
  cursor:default;
}

.ct-dp-dot{
  width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-top:.28em;
  background:rgba(37,99,235,.1);border:2px solid rgba(37,99,235,.2);
  transition:background .3s,border-color .3s,box-shadow .35s;
}

.ct-dp-stxt strong{
  display:block;font-size:var(--fs-sm);font-weight:600;color:var(--ink-3);
  transition:color .3s;
}
.ct-dp-stxt em{
  display:block;font-size:var(--fs-xs);color:var(--ink-4);font-style:normal;
  transition:color .3s;
}

.ct-dp-step.active .ct-dp-dot{
  background:var(--blue,#2563eb);border-color:var(--blue,#2563eb);
  box-shadow:0 0 0 4px rgba(37,99,235,.12);
}
.ct-dp-step.active .ct-dp-stxt strong{color:var(--ink);}
.ct-dp-step.active .ct-dp-stxt em{color:var(--ink-2);}
.ct-dp-step.done .ct-dp-dot{
  background:rgba(37,99,235,.5);border-color:rgba(37,99,235,.5);
}
.ct-dp-step.done .ct-dp-stxt strong{color:var(--ink-2);}

/* Progress bar */
.ct-dp-bar-wrap{
  height:3px;background:rgba(37,99,235,.1);
  border-radius:2px;overflow:hidden;
}
.ct-dp-bar{
  height:100%;width:0%;
  background:linear-gradient(90deg,var(--blue,#2563eb),#60a5fa);
  border-radius:2px;
  will-change:width;
}

/* Controls */
.ct-dp-ctrls{display:flex;gap:.55rem;}

.ct-dp-btn{
  display:inline-flex;align-items:center;gap:.38rem;
  padding:.36rem .78rem;
  border:1px solid rgba(37,99,235,.22);border-radius:var(--r-full);
  background:#fff;color:var(--ink-2);
  font-size:var(--fs-xs);font-weight:500;font-family:var(--font-body);
  cursor:pointer;line-height:1;
  transition:border-color .2s,color .2s,box-shadow .2s,background .15s;
}
.ct-dp-btn:hover{
  border-color:rgba(37,99,235,.5);color:var(--ink);
  box-shadow:0 2px 8px rgba(37,99,235,.1);
}

/* System cards panel */
.ct-dp-syscards{display:flex;flex-direction:column;gap:.5rem;}

/* Quick reply selected state */
#ct-dp-qr1.ct-dp-sel{
  background:var(--blue,#2563eb);color:#fff;
  border-color:var(--blue,#2563eb);
  transform:scale(1.04);
  transition:background .2s,color .2s,border-color .2s,transform .15s;
}

/* Final state glow */
.ct-dp-section.ct-dp-done .ct-dp-bar{
  background:linear-gradient(90deg,var(--blue,#2563eb),#93c5fd);
  box-shadow:0 0 6px rgba(37,99,235,.28);
}

/* Mobile */
@media(max-width:767px){
  .ct-dp-wrap{
    grid-template-columns:1fr;
    gap:1.8rem;
  }
  .ct-dp-phone-col{order:-1;}
  .ct-dp-lead{max-width:200px;}
  .ct-dp-steps{flex-direction:row;flex-wrap:wrap;gap:.4rem .8rem;}
  .ct-dp-stxt em{display:none;}
  .ct-dp-stxt strong{font-size:.72rem;}
  .ct-dp-syscards{display:none;}
}

/* Reduced motion: show all immediately */
@media(prefers-reduced-motion:reduce){
  .ct-dp-lead,#ct-dp-qr1{opacity:1!important;transform:none!important;transition:none!important;}
  .ct-dp-bar{transition:none;}
}
