:root{
  --bg:#0a0a0b;           
  --surface:#0f1115;      
  --card:#12161d;         
  --line:#1a2230;         
  --text:#e8ecf1;        
  --muted:#9aa7b5;        
  --accent:#3b82f6;       
  --accent-weak:#60a5fa;  


  --r-xs:10px;
  --r-sm:12px;
  --r-md:14px;
  --r-lg:16px;

  --tr-fast:160ms;
  --tr-mid:240ms;
}

*{ box-sizing:border-box }

html,body{
  margin:0; padding:0;
  background:var(--bg);
  color:var(--text);
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,"Noto Sans",Cantarell,"Helvetica Neue",Arial,sans-serif;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

a{
  color:var(--accent);
  text-decoration:none;
  transition:color var(--tr-fast) ease, opacity var(--tr-fast) ease;
}
a:hover{ color:var(--accent-weak); }

img{ max-width:100%; display:block; }

.container{ max-width:1100px; margin:0 auto; padding:clamp(14px, 2.8vw, 24px); }


:focus-visible{
  outline:2px solid var(--accent);
  outline-offset:2px;
  border-radius:6px;
}

:root{
  --header-base-h: clamp(52px, 6vw, 60px);   
  --header-shrink-h: clamp(36px, 4.4vw, 44px); 
  --header-pb: clamp(8px, 1.2vw, 12px);      
}


header{
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 100;
  --header-h: var(--header-base-h);
  background: linear-gradient(180deg, rgba(10,10,11,.92), rgba(10,10,11,.82));
  backdrop-filter: blur(8px);
  border-bottom: none; 
}


header .container.nav{
  height: calc(var(--header-h) + (var(--header-pb) * 2));
  padding-block: var(--header-pb);
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  transition: height var(--tr-mid) ease, padding var(--tr-mid) ease;
}


header::after{
  content:"";
  position:absolute; left:0; right:0; bottom:0;
  height: 2px;
  background: var(--accent);
  box-shadow: 0 0 12px rgba(59,130,246,.4);
  opacity: .95;
  transition: opacity var(--tr-mid) ease;
}

header .brand{ display:flex; align-items:center; gap:12px; }
header .brand .logo{
  width: calc(var(--header-h) * 4);
  height: calc(var(--header-h) * 4);
  border-radius: 8px;
  object-fit: contain;
  transition: width var(--tr-mid) ease, height var(--tr-mid) ease;
}

header nav{ display:flex; align-items:center; gap:10px; }
header nav a{
  display:inline-flex; align-items:center; line-height:1;
  height: var(--header-h);     
  padding: 0 6px;              
}

.lang-switch{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height: calc(var(--header-h) - 8px);
  padding: 0;
  width: 88px;
  border-radius: 999px;
  border: 1px solid rgba(59,130,246,.34);
  background: linear-gradient(180deg, rgba(10,16,34,.96) 0%, rgba(14,22,46,.96) 100%);
  color: #fff;
  font: inherit;
  cursor: pointer;
  position: relative;
  overflow: hidden;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.03), 0 8px 20px rgba(59,130,246,.16);
  transition: transform var(--tr-fast) ease, box-shadow var(--tr-fast) ease, border-color var(--tr-fast) ease, background var(--tr-fast) ease;
}

.lang-switch:hover{
  transform: translateY(-1px);
  border-color: rgba(96,165,250,.56);
  background: linear-gradient(180deg, rgba(12,20,42,.98) 0%, rgba(16,26,54,.98) 100%);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.04), 0 10px 24px rgba(59,130,246,.2);
}

.lang-switch-track{
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  width: 100%;
  height: 100%;
  padding: 3px;
}

.lang-switch-thumb{
  position: absolute;
  top: 3px;
  left: 3px;
  width: calc(50% - 3px);
  height: calc(100% - 6px);
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  border: 2px solid rgba(255,255,255,.95);
  box-shadow: 0 3px 10px rgba(0,0,0,.24), inset 0 0 0 1px rgba(0,0,0,.08);
  backdrop-filter: blur(2px);
  transition: transform 220ms cubic-bezier(.22,.61,.36,1), border-color 160ms ease, background 160ms ease;
}

.lang-switch.is-en .lang-switch-thumb{
  transform: translateX(100%);
}

.lang-switch-option{
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  overflow: hidden;
  transition: transform 160ms ease, opacity 160ms ease;
  opacity: 1;
  color: #ffffff;
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.lang-switch-option--hr{
  border-radius: 999px 0 0 999px;
}

.lang-switch-option--en{
  border-radius: 0 999px 999px 0;
}

.lang-switch:not(.is-en) .lang-switch-option--hr,
.lang-switch.is-en .lang-switch-option--en{
  transform: scale(1.02);
  opacity: 1;
}


header.is-shrink{ --header-h: var(--header-shrink-h); }
header.is-shrink::after{ opacity: 1; }


.header-spacer{ height: calc(var(--header-base-h) + (var(--header-pb) * 2)); }


.hero{
  padding:80px 0 40px; text-align:center;
}
h1{
  font-size:clamp(28px,4vw,44px);
  line-height:1.08; margin:0 0 12px;
  color:#ffffff;
}
.subtitle,.hero .lead{
  color:var(--muted);
  max-width:64ch; margin:12px auto 24px; opacity:.95;
}


.cta-row{ display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }


.btn-primary{
  background:var(--accent); color:#fff;
  border:1px solid var(--accent);
  padding:10px 14px; border-radius:var(--r-sm);
  transition:filter var(--tr-fast) ease, transform var(--tr-fast) ease, background var(--tr-fast) ease;
}
.btn-primary:hover{
  filter:brightness(1.05);
  background:var(--accent-weak);
  transform:translateY(-1px);
}

.btn-ghost{
  color:var(--text);
  background:transparent;
  border:1px solid rgba(148,163,184,.3);
  padding:10px 14px; border-radius:var(--r-sm);
  transition:border-color var(--tr-fast) ease, background var(--tr-fast) ease, transform var(--tr-fast) ease;
}
.btn-ghost:hover{
  border-color:var(--accent);
  background:rgba(59,130,246,.10);
  transform:translateY(-1px);
}

.hero-card{
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
  border:1px solid var(--line);
  padding:18px 16px; border-radius:var(--r-lg);
}

.section{ padding:clamp(20px, 4vw, 28px) 0; }
.section h2{
  font-size:clamp(22px,3vw,32px); margin:0 0 16px; color:#fff;
}
.muted{ color:var(--muted); }

.grid{ display:grid; gap:20px; }
@media (min-width:820px){
  .grid-2{ grid-template-columns:1.2fr .8fr; }
}

.why-intro{
  max-width: none;
  margin-bottom: 18px;
}
.why-intro h2{
  margin-bottom: 10px;
  padding-bottom: 4px;
  line-height: 1.18;
  font-size: clamp(20px, 2.4vw, 31px);
  display: flex;
  align-items: center;
  gap: .18em;
  flex-wrap: wrap;
}

@media (min-width: 900px){
  .why-intro h2{
    flex-wrap: nowrap;
  }
}

@media (max-width: 899px){
  .why-intro h2{
    flex-wrap: wrap;
  }
}

.title-flip{
  display: inline-block;
  vertical-align: middle;
  transform: translateY(0);
  margin: 0 .18em;
  padding: 0 .12em;
  min-width: clamp(8.5ch, 16vw, 14ch);
  height: 1.2em;
  overflow: hidden;
  position: relative;
}

.title-flip-track{
  position: relative;
  display: block;
  width: 100%;
  height: 1.2em;
  perspective: 1200px;
}

.title-flip-word{
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #93c5fd;
  font-weight: 700;
  letter-spacing: .01em;
  text-shadow: 0 1px 0 rgba(147, 197, 253, .22);
  white-space: nowrap;
  line-height: 1.16;
  opacity: 0;
  transform: translateY(115%) rotateX(-88deg);
  transform-origin: 50% 100%;
  backface-visibility: hidden;
  animation: title-flip-word 10s infinite linear;
}

.title-flip-word:nth-child(2){ animation-delay: 2.5s; }
.title-flip-word:nth-child(3){ animation-delay: 5s; }
.title-flip-word:nth-child(4){ animation-delay: 7.5s; }

@keyframes title-flip-word{
  0%, 6%{
    opacity: 0;
    transform: translateY(115%) rotateX(-88deg);
  }

  7%{
    opacity: 1;
    transform: translateY(48%) rotateX(-66deg);
  }
  9%{
    opacity: 1;
    transform: translateY(0) rotateX(0deg);
  }

  9%, 21%{
    opacity: 1;
    transform: translateY(0) rotateX(0deg);
  }

  22%{
    opacity: 1;
    transform: translateY(-48%) rotateX(66deg);
    transform-origin: 50% 0%;
  }
  24%, 100%{
    opacity: 0;
    transform: translateY(-115%) rotateX(88deg);
    transform-origin: 50% 0%;
  }
}

@media (prefers-reduced-motion: reduce){
  .title-flip-word{
    animation: none;
    opacity: 0;
    transform: none;
  }

  .title-flip-word:first-child{
    opacity: 1;
  }
}

.feature-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(14px, 2vw, 22px);
}
@media (max-width: 740px){
  .feature-grid{ grid-template-columns: 1fr; }
}

.process-grid{
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(10px, 1.6vw, 16px);
  margin-top: clamp(14px, 2vw, 22px);
}

.process-intro{
  margin-top: clamp(30px, 5vw, 54px);
  padding-top: clamp(18px, 2.8vw, 28px);
  border-top: 1px solid rgba(148, 163, 184, .28);
  max-width: 74ch;
}

.process-intro h3{
  margin: 0 0 8px;
  color: #fff;
  font-size: clamp(1.2rem, 2vw, 1.65rem);
  line-height: 1.2;
}

.process-intro p{
  margin: 0;
  font-size: clamp(.95rem, 1.1vw, 1rem);
  line-height: 1.55;
}

.apps-start{
  margin-top: clamp(28px, 5vw, 56px);
  padding-top: clamp(16px, 2.5vw, 26px);
  border-top: 1px solid rgba(148, 163, 184, .28);
}

.apps-start h3{
  margin: 0;
  color: #fff;
  font-size: clamp(1.9rem, 5.2vw, 4.2rem);
  line-height: .95;
  letter-spacing: -.02em;
}

.apps-hero{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(40px, 6vw, 80px);
  align-items: center;
  margin-top: clamp(40px, 8vw, 80px);
  padding-top: clamp(40px, 8vw, 80px);
}

.apps-hero-left{
  display: flex;
  flex-direction: column;
  gap: clamp(16px, 2vw, 20px);
}

.apps-hero-left h2{
  margin: 0;
  font-size: clamp(24px, 4vw, 44px);
  line-height: 1.15;
  color: #fff;
  letter-spacing: -.01em;
}

.apps-hero-left p{
  margin: 0;
  color: var(--muted);
  font-size: clamp(0.95rem, 1.1vw, 1.1rem);
  line-height: 1.65;
  max-width: 50ch;
}

.apps-hero-left .btn-primary{
  align-self: flex-start;
  margin-top: clamp(8px, 1.5vw, 12px);
}


.apps-hero-right{
  display: flex;
  justify-content: center;
  align-items: center;
}

.phone-mockup{
  perspective: 1000px;
  filter: drop-shadow(0 20px 60px rgba(59, 130, 246, 0.25));
  position: relative;
}

.phone-frame{
  position: relative;
  width: clamp(280px, 20vw, 360px);
  aspect-ratio: 9 / 19.5;
  background: #000;
  border-radius: clamp(36px, 5vw, 60px);
  border: 8px solid #1a1a1a;
  overflow: hidden;
  box-shadow: inset 0 0 0 1px rgba(255,255,255, 0.08);
}

.phone-screen{
  position: absolute;
  inset: 0;
  background: #0a0a0b;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  overflow: hidden;
}

.app-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  width: 100%;
  height: 100%;
}

.app-item{
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: linear-gradient(135deg, #1e3a8a 0%, #1e40af 100%);
  border-radius: 0;
  padding: 0;
  border: 1px solid rgba(59, 130, 246, 0.3);
  color: #e8f0ff;
  font-size: clamp(0.75rem, 1.2vw, 0.9rem);
  font-weight: 600;
  text-align: center;
  transition: background 200ms ease;
  cursor: pointer;
}

.app-item:hover{
  background: linear-gradient(135deg, #1e40af 0%, #3b82f6 100%);
  border-color: rgba(59, 130, 246, 0.6);
}

.app-item.active{
  background: linear-gradient(135deg, #0c2d5c 0%, #1e3a8a 100%);
  border-color: rgba(59, 130, 246, 0.8);
}

.app-icon{
  font-size: clamp(1.8rem, 3vw, 2.4rem);
  display: block;
}


.phone-notch{
  position: absolute;
  top: clamp(6px, 1vw, 10px);
  left: 50%;
  transform: translateX(-50%);
  width: clamp(120px, 30%, 160px);
  height: clamp(20px, 2.5vw, 28px);
  background: #000;
  border-radius: 0 0 clamp(12px, 2vw, 18px) clamp(12px, 2vw, 18px);
  z-index: 10;
}

.phone-bezel{
  position: absolute;
  inset: 0;
  border-radius: clamp(36px, 5vw, 60px);
  pointer-events: none;
  box-shadow: inset 0 1px 2px rgba(255,255,255, 0.1), inset 0 -1px 2px rgba(0,0,0, 0.5);
}


.app-expanded{
  position: absolute;
  right: clamp(20px, 3vw, 40px);
  top: 50%;
  transform: translateY(-50%);
  width: clamp(240px, 22vw, 340px);
  max-height: clamp(200px, 60vh, 500px);
  background: linear-gradient(135deg, rgba(15, 23, 42, 0.95) 0%, rgba(15, 23, 42, 0.92) 100%);
  border: 1px solid rgba(59, 130, 246, 0.3);
  border-radius: 16px;
  padding: 0;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: all 300ms cubic-bezier(0.34, 1.56, 0.64, 1);
  z-index: 20;
  box-shadow: 0 20px 60px rgba(59, 130, 246, 0.2);
  backdrop-filter: blur(10px);
}

.app-expanded.active{
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(-50%) translateX(0);
  right: clamp(20px, 3vw, 40px);
}

.app-expanded-content{
  position: relative;
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  padding: clamp(20px, 2.5vw, 28px);
  gap: clamp(16px, 2vw, 20px);
  overflow-y: auto;
}

.app-close{
  position: absolute;
  top: clamp(12px, 1.5vw, 14px);
  right: clamp(12px, 1.5vw, 14px);
  width: 32px;
  height: 32px;
  background: rgba(59, 130, 246, 0.1);
  border: 1px solid rgba(59, 130, 246, 0.3);
  border-radius: 8px;
  color: #e8f0ff;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 200ms ease;
  font-size: 18px;
  font-weight: bold;
}

.app-close:hover{
  background: rgba(59, 130, 246, 0.2);
  border-color: rgba(59, 130, 246, 0.6);
}

.app-close::before{
  content: "×";
}

#appDetails{
  display: flex;
  flex-direction: column;
  gap: clamp(12px, 1.5vw, 16px);
}

.app-details-title{
  font-size: clamp(1.2rem, 2vw, 1.4rem);
  font-weight: 700;
  color: #fff;
  margin: 0;
  display: flex;
  align-items: center;
  gap: 8px;
}

.app-details-icon{
  font-size: clamp(1.6rem, 2.5vw, 2rem);
}

.app-details-text{
  font-size: clamp(0.9rem, 1vw, 1rem);
  color: var(--muted);
  line-height: 1.6;
  margin: 0;
}

@media (max-width: 900px){
  .apps-hero{
    grid-template-columns: 1fr;
    gap: clamp(30px, 5vw, 50px);
  }

  .apps-hero-left h2{
    font-size: clamp(22px, 3.5vw, 32px);
  }

  .apps-hero-right{
    order: -1;
  }

  .app-expanded{
    display: none;
  }
}

@media (max-width: 640px){
  .apps-hero{
    grid-template-columns: 1fr;
    margin-top: clamp(30px, 6vw, 50px);
    padding-top: clamp(24px, 5vw, 40px);
  }

  .phone-frame{
    width: clamp(240px, 70vw, 300px);
  }

  .app-item{
    padding: clamp(12px, 1.5vw, 14px);
    gap: 6px;
  }

  .app-expanded{
    display: none;
  }
}

.process-box{
  border: 1px solid #82a0bc;
  border-radius: 14px;
  background-color: #82a0bc !important;
  background-image: none !important;
  padding: clamp(18px, 2.3vw, 24px) clamp(16px, 2vw, 22px);
  min-height: clamp(180px, 18vw, 240px);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: 10px;
  box-shadow: 0 10px 26px rgba(130, 160, 188, .34);
  position: relative;
  overflow: hidden;
  isolation: isolate;
  --fill-progress: 0%;
}

.process-box::before{
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: var(--fill-progress);
  background: #2c6393;
  transition: width 120ms linear, height 120ms linear;
  z-index: 0;
}

.process-box > *{
  position: relative;
  z-index: 1;
}

.process-box h3{
  margin: 0;
  color: #f4f9ff;
  font-size: clamp(1.02rem, 1.25vw, 1.18rem);
  line-height: 1.3;
}

.process-box p{
  margin: 0;
  color: rgba(239, 247, 255, .92);
  font-size: clamp(.9rem, 1.05vw, .98rem);
  line-height: 1.5;
}

@media (max-width: 1100px){
  .process-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 640px){
  .process-grid{ grid-template-columns: 1fr; }
  .process-box::before{
    left: 0;
    right: 0;
    top: 0;
    bottom: auto;
    width: 100%;
    height: var(--fill-progress);
  }
}

.feature-card{
  position: relative;
  overflow: hidden;
  min-height: clamp(220px, 28vw, 270px);
  border-radius: 24px;
  padding: clamp(22px, 3vw, 32px);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 16px;
  border: 1px solid rgba(96, 165, 250, .18);
  color: #eaf2ff;
  box-shadow: 0 12px 30px rgba(5, 9, 24, .28);
  isolation: isolate;
}

.feature-card--sand{
  background: linear-gradient(180deg, rgba(15, 23, 42, .96), rgba(20, 35, 68, .94));
}
.feature-card--blue{
  background: linear-gradient(180deg, rgba(13, 27, 58, .97), rgba(22, 48, 102, .94));
}
.feature-card--lavender{
  background: linear-gradient(180deg, rgba(17, 25, 50, .97), rgba(34, 51, 96, .94));
}
.feature-card--mint{
  background: linear-gradient(180deg, rgba(10, 22, 46, .97), rgba(18, 59, 116, .92));
}

.feature-badge{
  display: inline-flex;
  align-self: flex-start;
  padding: 8px 12px;
  border-radius: 10px;
  background: rgba(255,255,255,.09);
  border: 1px solid rgba(96, 165, 250, .22);
  color: #dbeafe;
  font-size: .83rem;
  font-weight: 600;
  line-height: 1;
  box-shadow: 0 4px 18px rgba(0,0,0,.12);
}

.feature-copy{
  max-width: min(30ch, calc(100% - 110px));
  position: relative;
  z-index: 1;
}
.feature-copy h3{
  margin: 0 0 10px;
  color: #f8fbff;
  font-size: clamp(1.45rem, 2vw, 2.1rem);
  line-height: 1.05;
  letter-spacing: -.03em;
}
.feature-copy p{
  margin: 0;
  color: rgba(219, 234, 254, .84);
  font-size: clamp(.96rem, 1.18vw, 1.06rem);
  line-height: 1.5;
}

.feature-art{
  position: absolute;
  right: clamp(-10px, 1vw, 10px);
  top: 50%;
  transform: translateY(-50%);
  width: clamp(118px, 16vw, 176px);
  height: clamp(118px, 16vw, 176px);
  opacity: .28;
  pointer-events: none;
  z-index: 0;
}

.feature-art--diamond::before,
.feature-art--diamond::after,
.feature-art--quarter::before,
.feature-art--quarter::after,
.feature-art--ribbon::before,
.feature-art--ribbon::after,
.feature-art--hourglass::before,
.feature-art--hourglass::after{
  content: "";
  position: absolute;
  display: block;
}

.feature-art--diamond::before{
  width: 54%;
  height: 54%;
  right: 10%;
  top: 6%;
  background: rgba(96, 165, 250, .34);
  border-radius: 18px;
  transform: rotate(45deg);
}
.feature-art--diamond::after{
  width: 38%;
  height: 38%;
  right: 4%;
  bottom: 12%;
  background: rgba(96, 165, 250, .22);
  border-radius: 14px;
  transform: rotate(45deg);
  box-shadow: -58px -26px 0 0 rgba(96, 165, 250, .12);
}

.feature-art--quarter::before,
.feature-art--quarter::after{
  inset: 0;
  background:
    radial-gradient(circle at 0 0, rgba(96, 165, 250, .5) 0 52%, transparent 53%) top left/50% 50% no-repeat,
    radial-gradient(circle at 100% 0, rgba(96, 165, 250, .36) 0 52%, transparent 53%) top right/50% 50% no-repeat,
    radial-gradient(circle at 0 100%, rgba(147, 197, 253, .28) 0 52%, transparent 53%) bottom left/50% 50% no-repeat,
    radial-gradient(circle at 100% 100%, rgba(147, 197, 253, .18) 0 52%, transparent 53%) bottom right/50% 50% no-repeat;
}

.feature-art--ribbon::before{
  inset: 12% 8%;
  background:
    linear-gradient(90deg, transparent 0 28%, rgba(96, 165, 250, .34) 28% 72%, transparent 72% 100%),
    linear-gradient(180deg, transparent 0 28%, rgba(96, 165, 250, .22) 28% 72%, transparent 72% 100%);
  border-radius: 24px;
}
.feature-art--ribbon::after{
  inset: 0;
  border-radius: 28px;
  background: radial-gradient(circle at 100% 50%, rgba(147, 197, 253, .24), transparent 60%);
}

.feature-art--hourglass::before{
  inset: 6%;
  background: linear-gradient(135deg, rgba(96, 165, 250, .42), rgba(96, 165, 250, .14));
  clip-path: polygon(50% 0, 88% 34%, 58% 50%, 88% 66%, 50% 100%, 12% 66%, 42% 50%, 12% 34%);
}
.feature-art--hourglass::after{
  inset: 0;
  background: linear-gradient(135deg, rgba(147, 197, 253, .16), transparent 70%);
  clip-path: polygon(62% 0, 100% 38%, 100% 100%, 52% 58%, 78% 42%, 52% 18%);
}

@media (hover:hover){
  .feature-card{
    transition: transform 180ms ease, box-shadow 180ms ease;
  }

  .feature-card:hover{
    transform: translateY(-4px);
    box-shadow: 0 16px 36px rgba(5, 9, 24, .18);
  }
}

@media (prefers-reduced-motion: reduce){
  .feature-card,
  .feature-card:hover{
    transition: none;
    transform: none;
  }
}

.sla-card{
  border:1px solid var(--line);
  border-radius:16px;
  background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
  padding:18px 18px 20px;
  box-shadow: 0 8px 30px rgba(0,0,0,.28);
  margin-top: 12px;
}
.sla-head{ display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:10px; }
.sla-badges{ display:flex; flex-wrap:wrap; gap:8px; }
.badge{
  display:inline-flex; align-items:center; gap:8px;
  border:1px solid var(--line);
  border-radius:999px; padding:6px 10px; font-size:.86rem;
}
.badge.pos{ color:#d7e7ff; border-color: rgba(59,130,246,.35); background: rgba(59,130,246,.10); }
.badge.ghost{ color:#e6edf7; background: rgba(255,255,255,.04); }

.sla-scale{
  --max: 300;    
  --value: 60;
  position: relative;
  border-radius: 12px;
  padding: 12px 10px 24px;
  background: rgba(255,255,255,.02);
  border: 1px solid var(--line);
  overflow: hidden;
}
.sla-scale .track{
  height: 10px; border-radius: 999px;
  background: rgba(148,163,184,.18);
}
.sla-scale .fill{
  position: absolute; left: 10px; right: 10px; top: 12px; height: 10px;
  border-radius: 999px; width: 0%;
  background: linear-gradient(90deg, rgba(59,130,246,.9), rgba(96,165,250,.9));
  box-shadow: 0 0 18px rgba(59,130,246,.45);
  transform-origin: left center;
}

.sla-scale .tick{
  position: absolute; top: 32px; transform: translateX(-50%);
}
.sla-scale .tick span{
  display:inline-block; margin-top: 8px;
  color: var(--muted); font-size:.86rem; white-space:nowrap;
  background: rgba(255,255,255,.02);
  border:1px solid var(--line); border-radius: 8px; padding: 4px 6px;
}
.sla-scale .tick-exp::before,
.sla-scale .tick-nfk::before{
  content:""; position:absolute; bottom: 16px; left: 50%; transform: translateX(-50%);
  width: 2px; height: 14px; background: var(--accent);
  box-shadow: 0 0 10px rgba(59,130,246,.45);
}

.sla-meta ul{ margin: 10px 0 0; padding-left: 18px; }
.sla-meta li{ margin: 6px 0; color: var(--text); }

.ps-grid{
  display: grid; gap: 14px; margin-top: 16px;
}
@media (min-width: 900px){
  .ps-grid{ grid-template-columns: 1fr 1fr; }
}
.ps-col{
  border:1px solid var(--line);
  border-radius:16px;
  background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
  padding:18px 18px 20px;
  box-shadow: 0 8px 30px rgba(0,0,0,.22);
}
.ps-col h3{ margin:0 0 8px; color:#fff; }
.steps{
  counter-reset: step;
  margin:0; padding-left: 0; list-style:none;
}
.steps li{
  position:relative;
  display:flex; align-items:flex-start; gap:10px;
  padding-left: 2px; margin:8px 0;
  opacity:0; transform: translateY(8px);
  transition: opacity 260ms ease, transform 260ms ease;
  transition-delay: calc(var(--i, 0) * 80ms);
}
.steps li.reveal{ opacity:1; transform: translateY(0); }
.steps .dot{
  width:10px; height:10px; border-radius:999px; margin-top: 7px;
  background: rgba(59,130,246,.85);
  box-shadow: 0 0 12px rgba(59,130,246,.45);
}

@media (prefers-reduced-motion: reduce){
  .steps li{ opacity:1; transform:none; transition:none; }
  .sla-scale .fill{ transition:none; }
}


.ps-v2 [id]{ scroll-margin-top: calc(var(--header-shrink-h, 40px) + 20px); }

.sla-stage{
  display:flex; align-items: baseline; gap:10px;
  margin: 2px 0 8px;
}
.sla-stage .stage-pill{
  display:inline-flex; align-items:center;
  border:1px solid rgba(59,130,246,.40);
  background: rgba(59,130,246,.12);
  color:#eaf2ff;
  border-radius:999px; padding:6px 10px;
  font-size:.86rem; letter-spacing:.02em;
}
.sla-stage .stage-copy{
  margin:0; color: var(--muted);
}


.sla-stage.swapping{ opacity:.45; transition: opacity 140ms ease; }


.sla-scale .fill{
  transition: width 160ms cubic-bezier(.22,.61,.36,1);
}

@media (prefers-reduced-motion: reduce){
  .sla-stage.swapping{ transition: none; opacity:1; }
  .sla-scale .fill{ transition: none; }
}

.sla-meta ul.swapping{ opacity:.45; transition: opacity 140ms ease; }
@media (prefers-reduced-motion: reduce){
  .sla-meta ul.swapping{ transition:none; opacity:1; }
}

.cards{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(240px,1fr));
  gap:16px; margin-top:10px;
}
.card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:18px;
  padding:18px;
  display:flex; flex-direction:column; gap:14px;
  transition:transform var(--tr-fast) ease, border-color var(--tr-fast) ease, box-shadow var(--tr-fast) ease;
}
.card:hover{
  transform:translateY(-2px);
  border-color:rgba(59,130,246,.35);
  box-shadow:0 10px 30px rgba(0,0,0,.35);
}
.card h3{ margin:0; font-size:18px; color:#ffffff; }
.price{ font-size:24px; font-weight:700; color:#fff; }

.tag{
  display:inline-block; font-size:12px;
  color:var(--muted);
  border:1px solid var(--line);
  padding:4px 8px; border-radius:999px;
}

.card ul{ margin:0; padding-left:18px; color:var(--muted); }

.card .btn{
  margin-top:auto;
  border:1px solid rgba(59,130,246,.6);
  color:#fff; background:transparent;
  padding:10px 12px; border-radius:var(--r-sm);
  text-align:center;
  transition:background var(--tr-fast) ease, border-color var(--tr-fast) ease, transform var(--tr-fast) ease;
}
.card .btn:hover{
  background:rgba(59,130,246,.12);
  border-color:var(--accent);
  transform:translateY(-1px);
}

.table-wrap{
  position: relative;
  overflow: auto;          
  border: 1px solid var(--line);
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
  box-shadow: 0 8px 30px rgba(0,0,0,.22);
}

.table-wrap::before,
.table-wrap::after{
  content:""; position: sticky; top: 0; bottom: 0; width: 16px;
  pointer-events: none; z-index: 2;
}
.table-wrap::before{
  left: 0;
  background: linear-gradient(90deg, rgba(0,0,0,.0), rgba(0,0,0,.35));
  opacity: 0;
}
.table-wrap::after{
  right: 0;
  background: linear-gradient(270deg, rgba(0,0,0,.0), rgba(0,0,0,.35));
  opacity: 1;
}
.table-wrap.at-start::before{ opacity: 0; }
.table-wrap.at-start::after{ opacity: 1; }
.table-wrap.at-end::after{ opacity: 0; }
.table-wrap.at-end::before{ opacity: 1; }


.table-compare{
  width: 100%;
  border-spacing: 0; 
  min-width: 640px;  
}
.table-compare thead th{
  position: sticky; top: 0; z-index: 1;
  background: rgba(8,12,20,.65);
  backdrop-filter: blur(6px);
  border-bottom: 1px solid var(--line);
  text-align: left;
  color: #eaf2ff;
  font-weight: 600;
}
.table-compare th, .table-compare td{
  padding: 12px 14px;
  border-bottom: 1px solid rgba(255,255,255,.06);
  vertical-align: top;
}


.table-compare tbody tr:nth-child(odd) td{ background: rgba(255,255,255,.02); }
.table-compare tbody tr:hover td{ background: rgba(59,130,246,.06); }


.table-wrap[data-col="1"] td:nth-child(1),
.table-wrap[data-col="1"] th:nth-child(1),
.table-wrap[data-col="2"] td:nth-child(2),
.table-wrap[data-col="2"] th:nth-child(2),
.table-wrap[data-col="3"] td:nth-child(3),
.table-wrap[data-col="3"] th:nth-child(3),
.table-wrap[data-col="4"] td:nth-child(4),
.table-wrap[data-col="4"] th:nth-child(4){
  background: rgba(59,130,246,.10);
}


.table-compare td:first-child{ font-weight: 600; color:#fff; }
.table-compare td:last-child{ color:#dbe7ff; }


.visually-hidden{
  position:absolute !important; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0 0 0 0); white-space:nowrap; border:0;
}


@media (max-width: 720px){
  .table-compare{ min-width: 520px; }
}


.cards + .table-wrap{
  margin-top: clamp(20px, 3vw, 44px); 
}

.table-wrap{
  margin-bottom: clamp(16px, 2vw, 28px);
}


.timeline{ 
  position: relative;
  list-style: none;
  margin: 14px 0 0;
  padding: 0;
  --tl-progress: 0;
}

.timeline-counter{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 4px 0 10px;
  padding: 7px 12px;
  border-radius: 999px;
  border: 1px solid rgba(96,165,250,.3);
  background: rgba(11, 22, 47, .65);
  color: #dbeafe;
  font-size: .83rem;
  font-weight: 600;
  letter-spacing: .02em;
}
.timeline-counter .tc-dir{
  width: 1.2em;
  text-align: center;
  transition: transform 160ms ease;
}
.timeline-counter[data-dir="up"] .tc-dir{ transform: translateY(-1px); }
.timeline-counter[data-dir="down"] .tc-dir{ transform: translateY(1px); }


.timeline::before{
  content:"";
  position:absolute; left: 26px; top: 0; bottom: 0;
  width: 2px; 
  background: rgba(148,163,184,.22);
}

.timeline::after{
  content:"";
  position:absolute;
  left: 26px;
  top: 0;
  bottom: 0;
  width: 2px;
  background: linear-gradient(180deg, rgba(96,165,250,.95), rgba(59,130,246,.95));
  transform-origin: top;
  transform: scaleY(var(--tl-progress));
  box-shadow: 0 0 14px rgba(59,130,246,.38);
  pointer-events: none;
}

/* jedan korak */
.timeline .step{
  position: relative;
  display: grid;
  grid-template-columns: 52px 1fr;
  gap: 12px;
  align-items: start;
  padding: 12px 0;
  scroll-margin-top: calc(var(--header-shrink-h, 40px) + 18px); /* da anchor ne upadne ispod headera */
}

/* kružni čvor + broj */
.timeline .node{
  position: relative; width: 52px; height: 100%;
  display:grid; place-items:center;
}
.timeline .node::before{
  content:""; 
  position: absolute; 
  width: 14px; height: 14px; 
  border-radius: 999px;
  background: rgba(59,130,246,.9);
  border: 2px solid rgba(59,130,246,.45);
  box-shadow: 0 0 14px rgba(59,130,246,.45);
}
.timeline .node span{
  position: relative; z-index:1;
  font-size:.82rem; color:#cfe1ff;
}

/* kartica sadržaja */
.timeline .content{
  border: 1px solid var(--line);
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
  padding: 16px 18px;
  min-height: clamp(120px, 13vw, 160px);
  transition: 
    filter 200ms ease,
    opacity 200ms ease,
    transform 200ms ease,
    border-color 220ms ease,
    box-shadow 220ms ease;
}
.timeline .content h3{ margin: 0 0 6px; color:#fff; }

/* Desktop: 2x2 oko centralne vertikalne osi */
@media (min-width: 900px){
  .timeline{
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto auto;
    column-gap: clamp(22px, 6vw, 88px);
    row-gap: clamp(14px, 2vw, 24px);
    margin-top: 14px;
  }

  .timeline::before{
    left: 50%;
    transform: translateX(-50%);
    top: 4px;
    bottom: 4px;
  }

  .timeline::after{
    left: 50%;
    top: 4px;
    bottom: 4px;
    transform: translateX(-50%) scaleY(var(--tl-progress));
  }

  .timeline .step{
    display: block;
    padding: 0;
  }

  .timeline .step .node{ display: none; }

  .timeline .step .content{
    height: 100%;
  }

  .timeline .step:nth-child(1){ grid-column: 1; grid-row: 1; }
  .timeline .step:nth-child(2){ grid-column: 1; grid-row: 2; }
  .timeline .step:nth-child(3){ grid-column: 2; grid-row: 1; }
  .timeline .step:nth-child(4){ grid-column: 2; grid-row: 2; }

  .timeline .step:nth-child(odd) .content{
    text-align: left;
  }

  .timeline .step:nth-child(even) .content{
    text-align: left;
  }
}

.timeline.has-active .step .content{
  filter: blur(2px) saturate(.9);
  opacity: .55;
  transform: scale(.985);
}
.timeline .step.is-active .content{
  filter: none; opacity: 1; transform: translateX(0) scale(1);
  border-color: rgba(59,130,246,.35);
  box-shadow: 0 10px 28px rgba(0,0,0,.35);
}
.timeline .step.is-active .node::before{
  background: #fff; border-color: #7fb4ff; 
  box-shadow: 0 0 0 3px rgba(59,130,246,.22), 0 0 18px rgba(59,130,246,.55);
}


@media (hover:hover){
  .timeline .step:hover .content{ border-color: rgba(255,255,255,.2); }
}


@media (prefers-reduced-motion: reduce){
  .timeline .content{ transition: none; }
  .timeline.has-active .step .content{ filter: none; opacity: 1; transform: none; }
}


.timeline-section{ padding-bottom: clamp(18px, 4vw, 42px); }


.timeline .node span{ display:none !important; }


.faq details{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:14px; padding:12px 14px;
}
.faq details+details{ margin-top:10px; }
.faq summary{ cursor:pointer; font-weight:600; color:#fff; }
.faq p{ color:var(--muted); }

.site-footer{
  margin-top: clamp(24px, 5vw, 56px);
  border-top: 1px solid var(--line);
  background: linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.01));
}
.site-footer .container{ padding-top: 18px; padding-bottom: 14px; }


.footer-grid{
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: clamp(12px, 2.5vw, 20px);
  align-items: start;
}
@media (max-width: 920px){
  .footer-grid{ grid-template-columns: repeat(2, minmax(0,1fr)); }
  .footer-cta{ grid-column: 1 / -1; } 
}
@media (max-width: 600px){
  .footer-grid{ grid-template-columns: 1fr; }
}

.footer-title{
  margin: 0 0 8px;
  color: #fff;
  font-size: 1rem;
  font-weight: 600;
}


.footer-list{
  list-style: none;
  margin: 0; padding: 0;
  display: grid;
  gap: 8px; 
}

.footer-list a{
  color: var(--muted);
  text-decoration: none;
  transition: color 200ms ease;
}
.footer-list a:hover{ color:#fff; }


.contact-item{
  display: inline-flex; align-items: center; gap: 8px;
  color: #e6edf7; text-decoration: none;
  border: 1px solid var(--line);
  border-radius: 999px; padding: 6px 10px;
  background: rgba(255,255,255,.03);
  transition: border-color 220ms ease, background 220ms ease, transform 180ms ease;
}
.contact-item:hover{
  border-color: rgba(59,130,246,.35);
  background: rgba(59,130,246,.10);
  transform: translateY(-1px);
}
.contact-item svg{ width: 16px; height: 16px; display:block; color:#cfe1ff; }


.footer-cta .cta-link{
  display: inline-flex; width: 100%;
  align-items: center; justify-content: center; gap: 10px;
  border: 1px solid rgba(59,130,246,.45);
  border-radius: 12px;
  padding: 12px 16px;
  color: #eaf2ff; text-decoration: none;
  background: linear-gradient(180deg, rgba(59,130,246,.16), rgba(59,130,246,.10));
  box-shadow: 0 8px 26px rgba(0,0,0,.28), inset 0 0 0 1px rgba(59,130,246,.10);
  transition: transform 220ms cubic-bezier(.22,.61,.36,1), box-shadow 220ms ease, border-color 220ms ease;
}
.footer-cta .cta-link:hover{
  transform: translateY(-2px);
  box-shadow: 0 12px 34px rgba(0,0,0,.34);
  border-color: rgba(59,130,246,.55);
}
.footer-cta .cta-link svg{ width: 18px; height: 18px; }


.footer-bottom{
  margin-top: clamp(12px, 2vw, 18px);
  color: var(--muted);
  font-size: .95rem;
  border-top: 1px solid rgba(255,255,255,.06);
  padding-top: 10px;
}


.footer-list a:focus-visible,
.contact-item:focus-visible,
.footer-cta .cta-link:focus-visible{
  outline: 2px solid rgba(59,130,246,.6);
  outline-offset: 2px;
}


@media (prefers-reduced-motion: reduce){
  .contact-item, .footer-cta .cta-link{ transition: none; transform: none; }
}


.contact-modal{
  position: fixed;
  inset: 0;
  z-index: 1200;
  display: grid;
  place-items: center;
  padding: clamp(16px, 4vw, 32px);
}

.contact-modal[hidden]{
  display: none;
}

.contact-modal__backdrop{
  position: absolute;
  inset: 0;
  background: rgba(3, 8, 18, .72);
  backdrop-filter: blur(8px);
}

.contact-modal__dialog{
  position: relative;
  z-index: 1;
  width: min(640px, 100%);
  background: linear-gradient(180deg, rgba(10,16,34,.98), rgba(14,22,46,.98));
  border: 1px solid rgba(59,130,246,.28);
  border-radius: 22px;
  box-shadow: 0 24px 80px rgba(0,0,0,.5);
  padding: clamp(18px, 3vw, 28px);
}

.contact-modal__head{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 18px;
}

.contact-modal__head h3{
  margin: 0;
  color: #fff;
  font-size: clamp(1.25rem, 2vw, 1.6rem);
}

.contact-modal__close,
.contact-form__secondary,
.contact-form__primary{
  font: inherit;
  cursor: pointer;
}

.contact-modal__close{
  width: 40px;
  height: 40px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  color: #fff;
}

.contact-form{
  display: grid;
  gap: 14px;
}

.contact-form__grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.contact-form__field{
  display: grid;
  gap: 8px;
  color: #dce9ff;
  font-size: .95rem;
}

.contact-form__field input,
.contact-form__field textarea{
  width: 100%;
  border: 1px solid rgba(148,163,184,.22);
  background: rgba(8,12,20,.86);
  color: #fff;
  border-radius: 12px;
  padding: 12px 14px;
  resize: vertical;
}

.contact-form__field textarea{
  min-height: 140px;
}

.contact-form__actions{
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 4px;
}

.contact-form__secondary,
.contact-form__primary{
  border-radius: 12px;
  padding: 11px 16px;
  border: 1px solid rgba(59,130,246,.28);
}

.contact-form__secondary{
  background: transparent;
  color: #dce9ff;
}

.contact-form__primary{
  background: linear-gradient(180deg, rgba(59,130,246,.22), rgba(59,130,246,.12));
  color: #fff;
}

@media (max-width: 640px){
  .contact-form__grid{
    grid-template-columns: 1fr;
  }

  .contact-form__actions{
    flex-direction: column-reverse;
  }

  .contact-form__secondary,
  .contact-form__primary{
    width: 100%;
  }
}

.chat-launch{
  position:fixed; right:clamp(10px,2vw,18px); bottom:clamp(10px,2vw,18px);
  background:#111827;
  border:1px solid var(--line);
  color:#fff; border-radius:999px;
  padding:12px 14px; font-weight:600;
  box-shadow:0 6px 30px rgba(0,0,0,.35);
  transition:border-color var(--tr-fast) ease, transform var(--tr-fast) ease, background var(--tr-fast) ease;
}
.chat-launch:hover{
  border-color:var(--accent);
  background:#0e1625;
  transform:translateY(-1px);
}

.chat-panel{
  position:fixed; right:clamp(10px,2vw,18px); bottom:clamp(58px,10vh,76px);
  width:min(340px, calc(100vw - clamp(20px,4vw,36px))); max-height:min(68dvh, 620px);
  background:var(--card);
  border:1px solid var(--line);
  border-radius:16px;
  display:none; flex-direction:column; overflow:hidden;
  box-shadow:0 18px 60px rgba(0,0,0,.45);
}

.chat-head{
  padding:12px 14px;
  border-bottom:1px solid var(--line);
  display:flex; align-items:center; justify-content:space-between;
}

.chat-body{
  padding:12px 12px 8px;
  overflow:auto; display:flex; flex-direction:column; gap:8px;
}

.msg{ display:flex; gap:8px; align-items:flex-start; }

.bubble{
  padding:10px 12px; border-radius:14px;
  max-width:80%;
  border:1px solid var(--line);
}


.msg .b{ background:#0e1320; }
.msg .u{ background:#121a2a; }

.chat-foot{
  padding:10px;
  border-top:1px solid var(--line);
  display:flex; gap:8px;
}
.chat-foot input{
  flex:1;
  background:#0b1220;
  border:1px solid var(--line);
  border-radius:10px;
  padding:10px 12px; color:#fff;
}
.chat-foot input::placeholder{ color:#7f8ea1; }

.chat-foot button{
  border:1px solid rgba(59,130,246,.65);
  background:transparent; color:#fff;
  border-radius:10px; padding:10px 12px;
  transition:background var(--tr-fast) ease, border-color var(--tr-fast) ease, transform var(--tr-fast) ease;
}
.chat-foot button:hover{
  background:rgba(59,130,246,.12);
  border-color:var(--accent);
  transform:translateY(-1px);
}

.notice{ font-size:12px; color:var(--muted); }


.hide{ display:none !important; }
.center{ text-align:center; }
.narrow{ max-width:880px; margin:0 auto; text-align:center; }


.hero-split{
  position: relative;
  overflow: clip;
  min-height: calc(100dvh - (var(--header-base-h) + (var(--header-pb) * 2)));
  display: flex;
  align-items: stretch;
}


.hs-row{
  display: grid;
  grid-template-columns: 1fr clamp(270px, 27vw, 430px) 1fr;
  width: 100%;
  position: relative;
}


.hs-row::before{
  content: "";
  position: absolute;
  left: 50%;
  top: 0; bottom: 0;
  width: 2px;
  transform: translateX(-50%);
  background: linear-gradient(
    to bottom,
    transparent 0%,
    rgba(59,130,246,.55) 8%,
    rgba(59,130,246,.55) 92%,
    transparent 100%
  );
  pointer-events: none;
  z-index: 0;
}


.hs-half{
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: clamp(12px, 2.2vw, 22px);
  padding: clamp(16px, 3vw, 36px);
  transition: background 200ms ease;
  position: relative;
  z-index: 1;
}
.hs-half:hover{ background: rgba(29,78,216,.07); }

.hs-label{
  font-size: clamp(18px, 3vw, 42px);
  font-weight: 700;
  color: #fff;
  margin: 0;
  text-align: center;
  letter-spacing: -.01em;
}

.hs-box{
  position: relative;
  z-index: 2;
  align-self: center;
  margin: clamp(20px, 4vh, 52px) 0;
  background: rgba(10, 18, 48, 0.88);
  border: 1px solid rgba(59,130,246,.42);
  border-radius: 18px;
  padding: clamp(22px, 3.4vw, 44px) clamp(20px, 3vw, 38px);
  text-align: center;
  backdrop-filter: blur(12px);
  box-shadow: 0 0 0 5px rgba(10,14,40,.92), 0 12px 48px rgba(59,130,246,.14);
}
.hs-box h1{
  font-size: clamp(20px, 3vw, 42px);
  line-height: 1.12;
  margin: 0 0 12px;
  color: #fff;
}
.hs-box .lead{
  margin: 0 auto 20px;
  font-size: clamp(.86rem, 1.28vw, 1rem);
  color: var(--muted);
}
.hs-box .kicker{
  display: block;
  font-size: .75rem;
  letter-spacing: .09em;
  text-transform: uppercase;
  color: var(--accent);
  margin: 0 0 10px;
}
.hero-cta{ display:inline-flex; align-items:center; gap:8px; font-size:.92rem; padding:10px 18px; }

.btn-split{
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border: 1px solid rgba(59,130,246,.45);
  color: #eaf2ff;
  background: rgba(59,130,246,.08);
  padding: 10px 20px;
  border-radius: var(--r-sm);
  font-size: .93rem;
  transition: background 160ms ease, border-color 160ms ease, transform 160ms ease;
}
.btn-split:hover{
  background: rgba(59,130,246,.18);
  border-color: rgba(59,130,246,.7);
  transform: translateY(-2px);
  color: #fff;
}

@media (max-width: 980px){
  .hero-split{
    min-height: auto;
  }

  .hs-row{
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto auto;
  }

  .hs-box{
    grid-column: 1 / -1;
    margin: clamp(20px, 4vh, 40px) clamp(16px, 4vw, 24px) 0;
  }

  .hs-half{
    min-height: clamp(180px, 28vw, 240px);
  }

  .hs-half--left{
    grid-column: 1;
    grid-row: 2;
  }

  .hs-half--right{
    grid-column: 2;
    grid-row: 2;
  }
}


.metrics{
  display:flex; flex-wrap:wrap; gap:8px 12px;
  margin: 16px 0 0; padding:0; list-style:none;
  justify-content: center;
}
.metrics li{
  border:1px solid var(--line);
  border-radius:999px;
  padding:6px 10px;
  color: var(--muted);
  font-size:.92rem;
}


.hero-visual{ display:grid; place-items:center; }
.terminal{
  width: clamp(280px, 48vw, 600px); 
  background: #0b1220;
  border:1px solid rgba(59,130,246,.35);
  border-radius:16px;
  box-shadow: 0 30px 80px rgba(0,0,0,.45), 0 0 0 1px rgba(59,130,246,.08) inset;
  overflow:hidden;
}
.term-head{
  display:flex; gap:8px; align-items:center;
  padding:10px 12px; border-bottom:1px solid var(--line);
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
}
.term-head span{
  width:10px; height:10px; border-radius:999px; display:inline-block;
  background: rgba(255,255,255,.16);
}
.term-body{
  margin:0; padding:18px 16px 22px; color:#dbe7ff;
  font: 14.5px/1.6 ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  white-space:pre-wrap;
  max-height: calc(100svh - 190px); 
  overflow:auto;
}

.caret{
  display:inline-block;
  width: 0.6ch;
  border-left: 2px solid #cfe1ff;
  margin-left: 2px;
  animation: caretBlink 1s steps(1) infinite;
}
@keyframes caretBlink{ 50% { border-color: transparent; } }


.aurora{
  position:absolute; inset:-20% -10% -10% -10%;
  z-index:-1;
  filter: blur(30px) saturate(120%);
  opacity:.9;
  background:
    radial-gradient(40% 35% at 20% 20%, rgba(61,130,246,.80), transparent 60%),
    radial-gradient(35% 30% at 80% 30%, rgba(12,115,255,.55), transparent 65%),
    radial-gradient(55% 45% at 50% 85%, rgba(96,165,250,.45), transparent 70%);
  animation: auroraMove 18s ease-in-out infinite alternate;
}
@keyframes auroraMove{
  0%   { transform: translate3d(0px, -10px, 0) scale(1);    filter: blur(30px) saturate(120%); }
  50%  { transform: translate3d(0px, 10px, 0)  scale(1.06); filter: blur(34px) saturate(125%); }
  100% { transform: translate3d(0px, -6px, 0)  scale(1.03); filter: blur(32px) saturate(122%); }
}


@media (prefers-reduced-motion: reduce){
  .aurora{ animation: none; }
}



html{ scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior: auto; }
}


.section[id]{ scroll-margin-top: calc(var(--header-shrink-h, 40px) + 20px); }

.nav a{
  position: relative;
  transition: color 220ms ease;
}
.nav a::after{
  content:""; position:absolute; left:0; right:0; bottom:-8px; height:2px;
  background: linear-gradient(90deg, rgba(59,130,246,.9), rgba(96,165,250,.9));
  transform: scaleX(0); transform-origin: center;
  opacity: 0;
  transition: transform 280ms cubic-bezier(.22,.61,.36,1), opacity 180ms ease;
}
.nav a.is-active{ color:#fff; }
.nav a.is-active::after{
  opacity: 1; transform: scaleX(1);
}



.nav .dot{ opacity:.35; margin:0 10px; }


.nav-toggle{
  display:none; background:transparent; border:1px solid var(--line);
  color:#eaf2ff; border-radius:10px; padding:8px 10px; line-height:0;
}
.nav-toggle .icon-close{ display:none; }

@media (max-width: 900px){

  .nav-toggle{ display:inline-flex; align-items:center; gap:8px; }
  .nav .dot{ display:none; }

  #primaryNav{
    position: fixed;
    left: 12px; right: 12px;
    top: var(--nav-top, calc(var(--header-shrink-h, 40px) + 10px));
    z-index: 1000;
    display: grid; gap: 10px;
    padding: 12px;
    border:1px solid var(--line);
    border-radius: 14px;
    background: rgba(8,12,20,.92);
    backdrop-filter: blur(8px);
    transform: translateY(-8px) scale(.98);
    opacity: 0; pointer-events: none;
    transition: transform 220ms cubic-bezier(.22,.61,.36,1), opacity 160ms ease;
  }
  #primaryNav a{ display:block; padding:8px 8px; }
  #primaryNav .lang-switch{
    width: 100%;
    height: 42px;
    margin-top: 4px;
  }

  #primaryNav .lang-switch-option{
    font-size: 1.05rem;
  }
  #primaryNav .cta{
    text-align:center; border-radius: 10px;
  }

  .nav-overlay{
    position: fixed; inset: 0; z-index: 999;
    background: rgba(0,0,0,.4);
    opacity: 0; pointer-events: none;
    transition: opacity 180ms ease;
  }


  header.is-open #primaryNav{
    transform: translateY(0) scale(1); opacity: 1; pointer-events: auto;
  }
  header.is-open .nav-overlay{
    opacity: 1; pointer-events: auto;
  }


  header.is-open .nav-toggle .icon-bars{ display:none; }
  header.is-open .nav-toggle .icon-close{ display:block; }


  body.nav-open{ overflow:hidden; }
}


html{ scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
.section[id]{ scroll-margin-top: calc(var(--header-shrink-h, 40px) + 20px); }

.nav a{ position:relative; transition:color 220ms ease; }
.nav a::after{
  content:""; position:absolute; left:0; right:0; bottom:-8px; height:2px;
  background: linear-gradient(90deg, rgba(59,130,246,.9), rgba(96,165,250,.9));
  transform: scaleX(0); transform-origin:center; opacity:0;
  transition: transform 280ms cubic-bezier(.22,.61,.36,1), opacity 180ms ease;
}
.nav a.is-active{ color:#fff; }
.nav a.is-active::after{ opacity:1; transform: scaleX(1); }

.hero-copy, .hero-visual { min-width: 0; }

.terminal, .term-body, .terminal pre, .terminal code {
  max-width: 100%;
  white-space: pre-wrap;      
  word-break: break-word;
  overflow-wrap: anywhere;
}


html, body { overflow-x: hidden; }

@media (max-width: 900px){
  .hero { 
    padding-top: clamp(14px, 5vh, 24px);
    padding-bottom: clamp(12px, 5vh, 22px);
  }
  .hero .container.hero-grid{
    display: grid;
    grid-template-columns: 1fr;   
    gap: 12px;
    align-items: start;
  }
  .hero-copy{ order: 1; }
  .hero-visual{ order: 2; }

  .hero-copy.glass{
    padding: clamp(12px, 3vw, 18px) clamp(12px, 4vw, 20px);
    margin: 0; 
  }

  .hero-visual .terminal{
    margin: 0 auto;
    width: 100%;
    border-radius: 12px;
  }
  .hero-copy .metrics{ gap: 8px 10px; }
}


@media (max-width: 600px){
  .hero-copy h1{
    font-size: clamp(22px, 7vw, 30px);
    line-height: 1.14;
  }
  .hero-copy .lead{ font-size: 0.98rem; }
}


.hero img, .hero video{ max-width: 100%; height: auto; display: block; }


@media (max-width: 900px){
  .hero-video-wrap{ min-height: clamp(420px, 72vh, 720px); }
  .hero-overlay{ min-height: clamp(420px, 72vh, 720px); padding: 16px 0 14px; }
}
