/* ============================================================
   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;
}
@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: 14ch;
}
.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: 18ch}
  .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;
}
.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}}
