@font-face{font-family:'Gliker'; src:url('../font/Gliker-SemiBoldSemiExpanded.woff2') format('woff2'); font-weight:600; font-style:normal; font-stretch:112.5%; font-display:swap;}
:root{
  --purple-950:#10041a; --purple-900:#150724; --purple-850:#1b0830; --purple-800:#220a34; --purple-750:#2a0c40; --purple-700:#330e4f; --purple-650:#42106a; --purple-600:#4e1688; --purple-500:#6e26c7; --purple-400:#8a4df0; --purple-300:#b995ff; --white:#ffffff; --silver-1:#e6e7eb; --silver-2:#bfc3c8; --silver-3:#8e949c; --maxw:1200px; --radius:16px; --shadow-soft:0 10px 30px rgba(0,0,0,.25);
  --wordmark:'Gliker', Montserrat, system-ui, -apple-system, Segoe UI, Roboto, 'Helvetica Neue', Arial, 'Noto Sans';
  --check-purple:#7B5CFF; /* cool purple for badges */
  /* === Tuning panel === */
  --wordmark-weight: 600;  /* match Gliker SemiBold but its not really working grrrrr */
  /* Hero headline size */
  --hero-h1-min: 1.6rem;    /* small screens */
  --hero-h1-pref: 3.2vw;    /* responsive scale */
  --hero-h1-max: 3rem;      /* large screens */
  /* Spacing between lines */
  --hero-until-gap: 32px;   /* breathing room before "Until now." */
  /* Timing */
  --until-delay: 3s;        /* delay before "Until now." animates */
  --ellipsis-duration: .6s; /* speed per dot */
  --ellipsis-1-delay: .8s;  /* when dot 1 appears */
  --ellipsis-2-delay: 1.6s; /* when dot 2 appears */
  --ellipsis-3-delay: 2.4s; /* when dot 3 appears */
  --streak: #b743ec; /* accent */
}
html,body{height:100%;}
body{margin:0; font-family:Montserrat, system-ui, -apple-system, Segoe UI, Roboto, 'Helvetica Neue', Arial, 'Noto Sans'; color:var(--white); background:var(--purple-850);}    
.container{width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:24px;}
.wordmark{font-family:'Gliker', Montserrat, system-ui, -apple-system, Segoe UI, Roboto, 'Helvetica Neue', Arial, 'Noto Sans'; font-weight:var(--wordmark-weight,600); letter-spacing:.08em; font-stretch:112.5%;}
.sr-only{position:absolute;width:1px;height:1px;margin:-1px;padding:0;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}

/* accessibility */
.skip-link{position:absolute; left:-9999px; top:auto; width:1px; height:1px; overflow:hidden;}
.skip-link:focus{left:16px; top:16px; width:auto; height:auto; padding:.5rem .75rem; background:var(--white); color:var(--purple-700); border-radius:8px; z-index:1000;}

/* ===== HEADER (layout + brand + links) ===== */
header{
  position: sticky; top: 0;
  backdrop-filter: saturate(160%) blur(8px);
  background: linear-gradient(to bottom, rgba(21,7,36,.92), rgba(21,7,36,.66));
  border-bottom: 1px solid rgba(255,255,255,.08);
  z-index: 50; transition: transform .3s ease;
}
header.hide{ transform: translateY(-100%); }

/* 3-column grid: logo | centered links | CTA */
header .nav{
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 28px;
  height: 76px;
  padding-inline: 24px;
}

/* Center the list in the middle column */
header .nav > nav { justify-self: center; }
header .nav > nav ul{
  display: flex;
  gap: 56px;
  list-style: none;
  margin: 0;
  padding: 0;
  white-space: nowrap;
}

/* Keep CTA pinned right */
header .nav .btn-early{ justify-self: end; margin: 0; }

/* ---- Brand (logo-only variant: no purple pill) ---- */
.brand.brand-logo{
  display: inline-flex; align-items: center; gap: 10px;
  background: transparent; border-radius: 0; padding: 0; box-shadow: none;
}
.brand.brand-logo picture,
.brand.brand-logo img{ display: block; }
.brand.brand-logo img{ height: 28px; width: auto; }
header .brand.brand-logo img{ height: 28px; }
footer .brand.brand-logo img{ height: 24px; }

/* Old purple pill style — only apply when NOT using the logo variant */
.brand:not(.brand-logo){
  display:inline-flex; align-items:center; justify-content:center; gap:0;
  background: var(--purple-600);
  border-radius: 10px; padding: 10px 16px;
  box-shadow: 0 2px 0 rgba(0,0,0,.25) inset;
}

/* Hide empty tag badge if you still render it */
.brand .brand-tag:empty{ display:none; }

/* ---- Nav link styling + underline height ---- */
.nav-link{
  position: relative;
  display: inline-block;
  padding: 10px 2px;
  line-height: 1.1;
  color: var(--white);
  text-decoration: none;
  font-weight: 600;
  letter-spacing: .04em;
}
.nav-link::after{
  content:"";
  position:absolute; left:0; right:0; bottom:0;   /* sit inside the box */
  height:2px;
  background:linear-gradient(90deg, transparent, var(--purple-300), transparent);
  transform:scaleX(0); transform-origin:center;
  transition:transform .24s ease;
  filter:blur(.1px);
}
.nav-link:hover::after,
.nav-link:focus::after{ transform:scaleX(1); }
.nav-link:hover{ text-shadow:0 0 14px rgba(185,149,255,.35); }

/* ---- Mobile: hide center list, keep logo + CTA ---- */
@media (max-width: 980px){
  header .nav{ grid-template-columns: auto 1fr; }
  header .nav > nav{ display:none; }
  header .nav .btn-early{ justify-self:end; }
}


/* Early Access CTA — gradient + shine */
.btn{display:inline-flex; align-items:center; justify-content:center; gap:.5rem; font-weight:800; text-decoration:none; border-radius:999px; padding:12px 20px;}
.btn-early{color:#251446; background:linear-gradient(135deg, #ffffff 0%, #efe8ff 22%, #bba8ff 60%, #8e73ff 100%); border:none; box-shadow:inset 0 0 0 1px rgba(25, 12, 48, .28), 0 6px 18px rgba(123,92,255,.35); position:relative; overflow:hidden;}
.btn-early::after{content:""; position:absolute; inset:-120% -40% auto -40%; height:300%; background:linear-gradient(75deg, transparent, rgba(255,255,255,.7), transparent); transform:translateX(-100%);} 
.btn-early:hover::after{animation:shine 900ms ease forwards;} 
@keyframes shine{to{transform:translateX(120%);}}
.btn-early:focus{outline:2px solid #fff; outline-offset:2px;}

/* HERO */
.hero { position: relative; }

/* subtle #7718a4 streaks that actually r animated */
.hero::before{
  content:"";
  position:absolute; inset:0; pointer-events:none;
  background:
    linear-gradient(115deg, transparent 42%, rgba(119,24,164,.22) 47%, transparent 55%),
    linear-gradient(125deg, transparent 52%, rgba(119,24,164,.16) 56%, transparent 66%),
    linear-gradient(138deg, transparent 62%, rgba(119,24,164,.12) 66%, transparent 74%);
  /* make each gradient larger than the hero so sliding is visible */
  background-size: 200% 140%, 220% 140%, 240% 140%;
  /* start positions */
  background-position: 0% 0%, 0% 0%, 100% 0%;
  background-repeat:no-repeat;

  /* keep streaks on the right half */
  -webkit-mask: linear-gradient(to right, transparent 38%, #000 56%, #000 100%);
          mask: linear-gradient(to right, transparent 38%, #000 56%, #000 100%);

  mix-blend-mode: screen;
  opacity:.6;
  filter: blur(.6px);
  animation: streakDrift 18s linear infinite;
  z-index:0;
}
/* ensure content stacks above */
.hero > * { position: relative; z-index:1; }

@keyframes streakDrift{
  to {
    /* sweep the three layers at slightly different speeds */
    background-position: 100% 0%, 100% 0%, 0% 0%;
  }
}

/* respect reduced motion without killing other animations globally */
@media (prefers-reduced-motion: reduce){
  .hero::before{ animation:none; }
}


.hero-grid{display:grid; grid-template-columns:1.1fr .9fr; gap:48px; align-items:center;}
/* Tunable headline size */
.h1{font-size: clamp(var(--hero-h1-min, 1.6rem), var(--hero-h1-pref, 3.2vw), var(--hero-h1-max, 3rem)); line-height:1.08; font-weight:800; margin:0 0 12px;}
/* Ellipsis animation (staggered dot reveal) */
.ellipsis{display:inline-flex; margin-left:.1em}
.ellipsis span{opacity:0}
.ellipsis.play span:nth-child(1){animation:dotFade var(--ellipsis-duration, .6s) ease var(--ellipsis-1-delay, .8s) forwards}
.ellipsis.play span:nth-child(2){animation:dotFade var(--ellipsis-duration, .6s) ease var(--ellipsis-2-delay, 1.6s) forwards}
.ellipsis.play span:nth-child(3){animation:dotFade var(--ellipsis-duration, .6s) ease var(--ellipsis-3-delay, 2.4s) forwards}
@keyframes dotFade{from{opacity:0; transform:translateY(.25em)} to{opacity:1; transform:none}}

.until{display:block; position:relative; opacity:0; transform:translateY(18px); margin-top:var(--hero-until-gap, 28px);} /* breathing room */
.until.animate{animation:fadeRise 1.4s cubic-bezier(.2,.8,.2,1) 0s forwards;} /* starts after delay via JS */
@keyframes fadeRise{from{transform:translateY(18px); opacity:0;} 60%{opacity:1;} to{transform:translateY(0); opacity:1;}}

/* Bigger video frame */
.video-wrap{max-width:820px; width:100%; aspect-ratio:16/9; margin-inline:auto;}
.hero-video{width:100%; height:100%; object-fit:cover; border-radius:16px; display:block; box-shadow:var(--shadow-soft);} 
.video-meta{opacity:.6; font-size:.85rem; margin-top:8px; text-align:center}

/* SECTIONS */
section{padding-block:92px;}
.about{position:relative; overflow:hidden; background:
  radial-gradient(900px 500px at 12% 20%, rgba(185,149,255,.22), transparent 60%),
  radial-gradient(800px 500px at 85% 80%, rgba(110,38,199,.20), transparent 62%),
  linear-gradient(180deg, var(--purple-600), var(--purple-650) 65%);
}
/* chrome sheen + fun bokeh overlay */
.about::before{content:""; position:absolute; inset:-40% -30%; pointer-events:none; border-radius:40px; background:
  conic-gradient(from 210deg at 50% 50%, rgba(230,231,235,0) 0%, rgba(230,231,235,.22) 14%, rgba(191,195,200,.08) 28%, rgba(142,148,156,0) 45%, rgba(230,231,235,.12) 62%, rgba(191,195,200,0) 72%),
  radial-gradient(60% 30% at 50% 0%, rgba(255,255,255,.08), transparent 60%);
filter: blur(10px); opacity:.55;}
.about::after{content:""; position:absolute; inset:-10%; pointer-events:none; background-image:
  radial-gradient(circle, rgba(255,255,255,.25) 0 2px, transparent 3px);
background-size:48px 48px; opacity:.15; animation:aboutDrift 28s linear infinite;}
@keyframes aboutDrift{to{background-position:120px 90px;}}
    
.solution{background:var(--purple-750); position:relative; overflow:hidden;}    
/* Left-align only the content inside Solution cards */
.solution .card .lead { text-align: left; }
/* (optional) also left-align the whole card block */
.solution .card { text-align: left; }

/* === Popular Event Watchlists === */
.watchlists{position:relative; overflow:hidden; background:
    radial-gradient(900px 500px at 12% 20%, rgba(185,149,255,.16), transparent 60%),
    radial-gradient(800px 500px at 85% 80%, rgba(110,38,199,.12), transparent 62%),
    linear-gradient(180deg, var(--purple-700), var(--purple-750) 65%);
  }
  .watchlists .lead{max-width:860px; margin:10px auto 26px;}
  
  .wl-grid{display:grid; gap:16px; grid-template-columns:1fr; margin-top:16px;}
  @media (min-width: 860px){ .wl-grid{grid-template-columns:repeat(3,1fr);} }
  
  .wl-card{display:flex; flex-direction:column; gap:10px; padding:18px 16px; border-radius:16px;
    background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.10);
    box-shadow:inset 0 1px 0 rgba(255,255,255,.15);
  }

  /* Allow multi-line titles and keep the CTA anchored near the bottom */
.wl-card{ justify-content:space-between; 
  position: relative;   /* <-- key: anchors ::after to the card */
  overflow: visible;    /* in case the badge pokes past the radius */}

/* Title + meta line for dates/venue */
.wl-title{ margin:0; font-size:1.08rem; line-height:1.35; }
.wl-meta{ margin:0; opacity:.92; }


  .wl-title{margin:0; font-size:1.05rem;}
  .wl-copy{margin:0 0 6px; opacity:.9;}
  /* Center the CTA and give every button the same visual width */
  .wl-card .wl-btn{
    align-self:center;
    width:100%;
    max-width:280px;
  }

  /* Make every card a column and pin the button to the visual center */
.wl-card{ display:flex; flex-direction:column; }
.wl-card .wl-btn{
  margin-top: auto;
  align-self: center;          /* centers inside the card */
  width: min(420px, 90%);      /* consistent width so all 3 line up */
}


  /* Add class="popular" to any .wl-card you want to heat up */
/* Put the flame only on cards with class="popular" */
.wl-card.popular::after{
  content:'🔥';
  position:absolute;
  top:10px;            /* tweak to taste */
  right:12px;          /* inside the card corner */
  font-size:26px;
  line-height:1;
  pointer-events:none;
  filter: drop-shadow(0 0 6px rgba(255,140,0,.45));
  animation: flame 1.1s ease-in-out infinite alternate;
}

@keyframes flame{
  from{ transform:translateY(0) scale(1);   opacity:.95; }
  to  { transform:translateY(-2px) scale(1.06); opacity:1; }
}


  
  .wl-suggest{display:grid; place-items:center; margin-top:18px;}
  .btn-outline{color:#fff; border:1px solid rgba(255,255,255,.28); background:transparent; padding:12px 18px; border-radius:999px; font-weight:700;}
  .btn-outline:hover{background:rgba(255,255,255,.06);} 
  
  .wl-footnote{opacity:.7; font-size:.85rem; margin-top:16px; text-align:center;}
  
  /* Modal */
  .modal[hidden]{display:none}
  .modal{position:fixed; inset:0; z-index:60;}
  .modal-backdrop{position:absolute; inset:0; background:rgba(0,0,0,.5); backdrop-filter: blur(2px);}
  .modal-panel{position:relative; z-index:1; width:min(560px, 92%); margin:8vh auto; padding:20px; border-radius:18px;
    background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
    border:1px solid rgba(255,255,255,.14); box-shadow:var(--shadow-soft);
  }
  .modal-close{position:absolute; top:10px; right:12px; width:36px; height:36px; border-radius:10px; border:1px solid rgba(255,255,255,.25); background:rgba(255,255,255,.06); color:#fff; font-size:22px; line-height:1;}
  .modal-close:hover{background:rgba(255,255,255,.12)}

  

/* === CTA (refreshed background, on-brand stars) v4 lol === */
.cta{
    background: linear-gradient(180deg, var(--purple-500), var(--purple-650));
    position: relative;
    overflow: hidden;
  }
  .cta::before{
    content:"";
    position:absolute; inset:0;
    background:
      radial-gradient(600px 340px at 50% 32%, rgba(255,255,255,.14), transparent 70%),
      radial-gradient(900px 520px at 50% 120%, rgba(0,0,0,.12), transparent 60%);
    pointer-events:none;
  }
  
.cta::after{content:""; display:none;}   

/* form shell */
.cta-wrap{max-width:680px}
.form-shell{max-width:640px; margin:14px auto 0; padding:22px; border-radius:20px; background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.03)); box-shadow:inset 0 1px 0 rgba(255,255,255,.2); border:1px solid rgba(255,255,255,.14);}  

/* floating labels */
.field.floating{position:relative}
.field.floating label{position:absolute; left:14px; top:50%; transform:translateY(-50%); font-size:1rem; opacity:.9; transition:all .18s ease; background:transparent; padding:0 6px; pointer-events:none; color:var(--silver-1);}
.field.floating .input::placeholder{color:transparent}
.field.floating .input:focus + label,
.field.floating .input:not(:placeholder-shown) + label{top:-8px; left:12px; font-size:.8rem; opacity:1; background:rgba(37,20,70,.85); border-radius:8px;}
/* select needs JS to toggle has-value */
.field.floating.select-has-value label,
.field.floating select:focus + label{top:-8px; left:12px; font-size:.8rem; opacity:1; background:rgba(37,20,70,.85); border-radius:8px;}

/* inputs */
.field{display:flex; flex-direction:column; gap:6px}
.input, .select{background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.18); color:#fff; padding:18px 14px; border-radius:14px; outline:none;}
.input:focus, .select:focus{border-color:var(--purple-300); box-shadow:0 0 0 3px rgba(185,149,255,.18);}    
.field.error .input, .field.error .select{border-color:#ff9ca6; box-shadow:0 0 0 3px rgba(255,100,120,.18);} 
.field.error{animation:shake .28s ease}
@keyframes shake{10%{transform:translateX(-2px)} 30%{transform:translateX(2px)} 50%{transform:translateX(-1px)} 70%{transform:translateX(1px)} 100%{transform:none}} 

/* CTA button refinement (hover only; core styles below) */
/* I’m in — on-brand gradient + shine (matches navbar style) */
/* Canonical on-brand button */
.btn-im-in{
  position:relative;
  display:inline-flex; align-items:center; justify-content:center;
  width:100%; max-width:280px;
  padding:14px 22px; border-radius:999px;
  font-weight:800; letter-spacing:.04em; text-transform:none;
  color:#fff;
  background:linear-gradient(180deg,var(--purple-500),var(--purple-650));
  border:1px solid rgba(255,255,255,.18);
  box-shadow:0 8px 22px rgba(110,38,199,.35), inset 0 1px 0 rgba(255,255,255,.3);
  overflow:hidden;
}
.btn-im-in::after{
  content:""; position:absolute; inset:-120% -40% auto -40%; height:300%;
  background:linear-gradient(75deg, transparent, rgba(255,255,255,.65), transparent);
  transform:translateX(-100%);
}
.btn-im-in:hover{ transform:translateY(-1px); filter:brightness(1.06); }
.btn-im-in:hover::after{ animation:shine 900ms ease forwards; }
.btn-im-in:active{ transform:translateY(0); }
.btn-im-in:focus-visible{ outline:3px solid var(--purple-300); outline-offset:2px; }

  
.section-title{font-size: clamp(1.9rem, 2.4vw, 3rem); font-weight:800; text-align:center; margin:0 0 12px;}
/* Emphasis without underline: gentle glow */
.section-title.wordmark{ text-shadow:0 1px 0 rgba(0,0,0,.25), 0 12px 32px rgba(185,149,255,.25);} 
.lead{font-size:clamp(1.05rem, 1.2vw, 1.25rem); line-height:1.8; opacity:.95; text-align:center;}  
.lead-intro{max-width:980px; margin:14px auto 26px; text-align:center;}
/* CTA-specific spacing for helper line above form */
.cta .lead{margin:14px 0 26px;} 
.lead.small{font-size:1rem}
.center{max-width:900px; margin-inline:auto; text-align:center;} 

.chrome-wrap{position:relative; display:inline-block;}
.chrome-bar{display:none} /* removed underline */ 

.carousel{position:relative; overflow:hidden; border-radius:14px; background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08); margin-top:22px;}
.slides{display:grid;}
.slide{grid-area:1/1; padding:22px 20px; opacity:0; transform:translateY(8px); transition:opacity .4s ease, transform .4s ease;}
.slide.active{opacity:1; transform:none;}

.benefits-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:18px;}
.benefit{background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08); border-radius:14px; overflow:hidden}
.benefit img{width:100%; height:200px; object-fit:cover; display:block}
.benefit figcaption{text-align:center; padding:12px; font-weight:600}

.grid{display:grid; gap:18px; grid-template-columns:repeat(3, 1fr); margin-top:20px;}
.card{background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08); border-radius:16px; padding:18px 16px;}
.card h3{margin:10px 0 8px; font-size:1.1rem}
.icon{width:28px; height:28px; display:inline-flex;}
.icon svg{width:100%; height:100%;}

/* === Form grid (single column) === */
.form{
    max-width:520px;
    margin:10px auto 0;
    display:grid;
    grid-template-columns:1fr;
    gap:12px;                     /* controls space between ALL fields */
  }
  .field{display:flex; flex-direction:column; gap:6px;}
  .input, .select{
    background:rgba(255,255,255,.06);
    border:1px solid rgba(255,255,255,.18);
    color:#fff; padding:14px 12px; border-radius:12px; outline:none;
  }
  .input:focus, .select:focus{border-color:var(--purple-300); box-shadow:0 0 0 3px rgba(185,149,255,.18);}
  
  /* only add extra space before the button (not the select) */
  .actions{display:grid; place-items:center; margin-top:10px;}
  
  /* disclaimer styling + spacing */
  .form-note{opacity:.85; text-align:center; margin-top:8px;}
  
  @media (min-width:720px){
    .form{grid-template-columns:1fr;}              /* still single column on desktop */
    .form .actions, .form-note{grid-column:1/-1;}  /* full width */
  }

/* === Button: on-brand gradient == */
.btn-im-in{position:relative; display:inline-grid; place-items:center; min-width:168px; padding:14px 22px; border-radius:999px; font-weight:900; letter-spacing:.08em; text-transform:uppercase; color:#fff; background:linear-gradient(135deg, var(--purple-400) 0%, var(--purple-500) 45%, var(--purple-650) 100%); border:1px solid rgba(255,255,255,.16); box-shadow:0 6px 18px rgba(123,92,255,.35), inset 0 1px 0 rgba(255,255,255,.32); overflow:hidden;}
.btn-im-in::after{content:""; position:absolute; inset:-120% -40% auto -40%; height:300%; background:linear-gradient(75deg, transparent, rgba(255,255,255,.65), transparent); transform:translateX(-100%);} 
.btn-im-in:hover::after{animation:shine 950ms ease forwards;}
.btn-label{position:relative; z-index:1}
.btn-spinner{position:absolute; width:16px; height:16px; border-radius:999px; border:2.5px solid rgba(37,20,70,.25); border-top-color:#fff; animation:spin 1s linear infinite; opacity:0; transform:scale(.8);} 
@keyframes spin{to{transform:rotate(360deg)}}
.btn-im-in.loading .btn-label{opacity:0}
.btn-im-in.loading .btn-spinner{opacity:1}
.btn-im-in:active{transform:translateY(1px)}
.form-note{opacity:.8}
.success{display:none; margin-top:18px; font-weight:700}
.success.show{display:block}

footer{background:var(--purple-900); padding-block:40px;}
.footer-grid{display:grid; grid-template-columns: 1fr auto; gap:24px; align-items:center;}
.links{display:flex; flex-direction:column; gap:8px; margin-top:12px;}
.links a{color:#e9defa; text-decoration:none;}
.links a:hover,.links a:focus{text-decoration:underline;}
.footer-right{text-align:right}
.socials{display:flex; align-items:center; gap:12px; flex-wrap:wrap;}
.sbtn{display:inline-flex; width:40px; height:40px; border:1.5px solid rgba(255,255,255,.5); border-radius:12px; align-items:center; justify-content:center; transition:transform .12s ease;}
.sbtn:hover{transform:translateY(-1px);}    
.socials svg{width:22px; height:22px; fill:currentColor; color:#fff;}
.copy{opacity:.8; font-size:.95rem; margin-top:12px;}
.contact-link{color:#fff; text-decoration:none; background:linear-gradient(90deg, transparent, #fff, transparent); background-repeat:no-repeat; background-size:0 2px; background-position:0 100%; transition:background-size .25s ease; padding-bottom:2px}
.contact-link:hover{background-size:100% 2px}


/* Section background system */
.solution .section-bg{position:absolute; inset:0; z-index:0; pointer-events:none;}
.solution .container{position:relative; z-index:1;}
.section-bg.bg-waves::before,
.section-bg.bg-waves::after{content:""; position:absolute; inset:-25%; border-radius:50%;}
.section-bg.bg-waves::before{background:conic-gradient(from 0deg at 30% 30%, rgba(185,149,255,.16), rgba(110,38,199,.06), transparent 70%); animation:swirl 80s linear infinite;}
.section-bg.bg-waves::after{background:conic-gradient(from 90deg at 70% 70%, rgba(185,149,255,.10), rgba(110,38,199,.05), transparent 70%); animation:swirl 120s linear infinite reverse;}
.section-bg.bg-waves{opacity:.5}
@keyframes swirl{to{transform:rotate(360deg)}}

@media (max-width: 980px){
  nav ul{display:none;}
  .hero-grid{grid-template-columns:1fr;}
  .grid{grid-template-columns:1fr 1fr;}
  .footer-grid { grid-template-columns: 1fr auto; gap:24px; align-items: start; } 
  .footer-right{
    display:flex;
    flex-direction:column;
    align-items:flex-end;
    row-gap:12px;
  }
  
}
@media (max-width:640px){
  .grid{grid-template-columns:1fr;}
  .benefits-grid{grid-template-columns:1fr;}
}

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


/* Chrome callout + problem list  */
.chrome-callout{display:none} /* retired */
.chrome-callout::before{content:""; position:absolute; inset:0; border-radius:16px; padding:1.5px; background:linear-gradient(90deg, var(--silver-3), var(--silver-1), var(--silver-2)); -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0); -webkit-mask-composite: xor; mask-composite: exclude; opacity:.7;}
.chrome-list{list-style:none; padding:0; margin:22px 0 0; display:grid; grid-template-columns:1fr 1fr; gap:16px;}
.chrome-item{position:relative; display:flex; align-items:center; gap:14px; padding:16px 18px; border-radius:22px; overflow:hidden; background:
  linear-gradient(180deg, var(--silver-3), var(--silver-1), var(--silver-2)) left/4px 100% no-repeat,
  radial-gradient(120% 120% at 20% 0%, rgba(255,255,255,.12), rgba(255,255,255,.02) 60%),
  linear-gradient(180deg, rgba(0,0,0,.18), rgba(255,255,255,.06) 28%, rgba(0,0,0,.2) 85%);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.25), inset 0 -8px 18px rgba(0,0,0,.35);
}
.chrome-item::before{content:""; position:absolute; inset:0; border-radius:22px; padding:1.5px; background:linear-gradient(90deg, var(--silver-3), var(--silver-1), var(--silver-2)); -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0); -webkit-mask-composite: xor; mask-composite: exclude; opacity:.85; pointer-events:none;}
.chrome-item::after{content:""; position:absolute; inset:1px; border-radius:inherit; background:linear-gradient(100deg, transparent 35%, rgba(255,255,255,.18) 50%, transparent 65%); opacity:0; transform:translateX(-25%); transition:opacity .28s ease, transform .6s ease; pointer-events:none;}
.chrome-item:hover::after{opacity:1; transform:translateX(115%);} 
.ci-icon{width:36px; height:36px; flex-shrink:0; border-radius:999px; display:grid; place-items:center; position:relative; margin-left:8px; background:radial-gradient(60% 60% at 35% 35%, #ffffff 0%, #e6e7eb 45%, #c9ccd3 70%, #a5abb5 100%); box-shadow:0 1px 2px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.8); overflow:hidden;}  
.ci-icon::after{content:""; position:absolute; inset:-3px; border-radius:inherit; z-index:0; background:linear-gradient(90deg, #bfc3c8, #e6e7eb, #8e949c); -webkit-mask:radial-gradient(circle, transparent 58%, #000 60%, #000 72%, transparent 74%); mask:radial-gradient(circle, transparent 58%, #000 60%, #000 72%, transparent 74%);}   
.ci-icon .ci-check{width:20px; height:20px; color:var(--check-purple); position:relative; z-index:1; filter:drop-shadow(0 0 2px rgba(123,92,255,.7));}   
.ci-icon .ci-check path{stroke-width:3.6; stroke-linecap:round; stroke-linejoin:round;}  
.ci-text{line-height:1.6; background:linear-gradient(90deg, #e9ebf3, #ffffff 45%, #dfe3ec 90%); -webkit-background-clip:text; background-clip:text; color:transparent; text-shadow:0 1px 0 rgba(0,0,0,.18);}  
.ci-text strong{font-weight:800;}  
/* gentle reveal */
.reveal-up{opacity:0; transform:translateY(10px);} 
.reveal-up.revealed{opacity:1; transform:none; transition:opacity .5s ease, transform .5s ease;}
@media (max-width: 800px){ .chrome-list{grid-template-columns:1fr;} }
/* --- Overrides: CTA button (clean purple pill) --- */
.actions{display:grid;place-items:center;}
.form .actions .btn-im-in{width:100%;max-width:280px;}

.btn-im-in{
  display:inline-flex;align-items:center;justify-content:center;
  padding:14px 22px;border-radius:999px;
  font-weight:800;letter-spacing:.04em;text-transform:none;
  color:#fff;
  background:linear-gradient(180deg,var(--purple-500),var(--purple-650));
  border:1px solid rgba(255,255,255,.18);
  box-shadow:0 8px 22px rgba(110,38,199,.35),inset 0 1px 0 rgba(255,255,255,.3);
}

.btn-im-in:hover{transform:translateY(-1px);filter:brightness(1.06);} 
.btn-im-in:active{transform:translateY(0);} 
.btn-im-in:focus-visible{outline:3px solid var(--purple-300);outline-offset:2px;}


/* --- How It Works (section) --- */

#how-it-works .hiw__head{ position:static !important; background:none; backdrop-filter:none; border:0; }


.hiw{
  background: radial-gradient(90% 140% at 50% 0%, var(--purple-800), var(--purple-900));
  color: var(--white);
  padding-block: 92px;                 /* matches other sections */
}
.hiw__wrap{
  max-width: var(--maxw);
  margin-inline: auto;
  padding-inline: 24px;                /* same as .container */
  text-align: center;                  /* mirror About section */
}

/* Use the SAME headline scale as 'We are Tixster' */
.hiw .section-title{
  /* already using .wordmark so family/weight match */
  font-size: clamp(1.9rem, 2.4vw, 3rem);
  line-height: 1.08;
  margin: 0 0 12px;
}
.hiw .lead-intro{
  font-size: clamp(1.05rem, 1.2vw, 1.25rem);
  line-height: 1.8;
  color: var(--silver-2);
  max-width: 980px;
  margin: 14px auto 26px;
}

/* --- Sliders --- */
.hiw__controls{
  display: grid;
  gap: 16px;
  grid-template-columns: 1fr;
  max-width: 980px;                    /* same column width as About pills */
  margin: 0 auto 24px;
  text-align: left;
}
@media (min-width: 900px){
  .hiw__controls{ grid-template-columns: 1fr 1fr; }
}

.slider{ display: grid; gap: 8px; }
.slider__label{ font-size: 12px; color: var(--silver-2); }
.slider__track{
  position:relative; display:grid; grid-template-columns:1fr 1fr;
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.14);
  border-radius:999px; padding:5px; outline:none;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.45),
    inset 0 -6px 18px rgba(0,0,0,.25),
    0 12px 26px rgba(110,38,199,.25);
  /* subtle animated purple rim */
  background-image:
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02)),
    linear-gradient(135deg, var(--purple-700), var(--purple-600) 40%, var(--purple-500));
  background-blend-mode: normal, soft-light;
  background-size: auto, 200% 200%;
  animation: gradientShift 10s ease-in-out infinite alternate;
}

.slider__thumb{
  position:absolute; inset:5px; width:calc(50% - 10px); border-radius:999px;
  background:linear-gradient(180deg, #ffffff, #efe8ff 45%, #d8cfff 100%);
  box-shadow:
    0 12px 28px rgba(0,0,0,.28),
    inset 0 1px 0 rgba(255,255,255,.8);
  transform:translateX(var(--x,0%));
  transition:transform .28s cubic-bezier(.2,.7,.2,1);
}
.slider__thumb::after{            /* soft sheen */
  content:""; position:absolute; inset:0; border-radius:inherit;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.25), transparent);
  opacity:.6;
}

/* positions */
.slider__track[data-active="buyer"] .slider__thumb,
.slider__track[data-active="physical"] .slider__thumb{ --x:0%; }
.slider__track[data-active="seller"] .slider__thumb,
.slider__track[data-active="digital"] .slider__thumb{ --x:100%; }


.slider__opt{
  position: relative; z-index: 2;
  appearance: none; border: 0; background: transparent;
  color: var(--silver-1); font-weight: 600;
  padding: 10px 12px; border-radius: 999px; cursor: pointer;
}
/* ensure label sits above the thumb */
.slider__opt{ z-index: 2; }

/* selected state: dark text on light thumb */
.slider__track[data-active="buyer"]   .slider__opt[data-value="buyer"],
.slider__track[data-active="seller"]  .slider__opt[data-value="seller"],
.slider__track[data-active="physical"] .slider__opt[data-value="physical"],
.slider__track[data-active="digital"]  .slider__opt[data-value="digital"]{
  color:#2b1650;            /* deep purple for contrast */
  text-shadow:0 1px 0 rgba(255,255,255,.4);
  font-weight:800;
}

/* unselected state stays light */
.slider__opt[aria-pressed="false"]{ color:var(--silver-1); }


/* --- Tiles --- */
.hiw__tiles{
  list-style: none; padding: 0; margin: 0;
  display: grid; gap: 18px; grid-template-columns: 1fr;
}
@media (min-width: 720px){
  .hiw__tiles{ grid-template-columns: repeat(3, 1fr); }
}
.hiw__tile{
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: var(--radius,16px);
  padding: 24px;                       /* beefier to match your pill cards */
  min-height: 160px;
  transform: translateY(8px) scale(.98);
  opacity: 0;
  animation: pop .44s both cubic-bezier(.2,.7,.2,1);
  box-shadow: 0 10px 30px rgba(0,0,0,.25);
}
.hiw__tile .num{
  width: 40px; height: 40px;           /* slightly larger badge */
  border-radius: 50%;
  display: grid; place-items: center;
  background: var(--purple-500);
  color: var(--white); font-weight: 700; margin-bottom: 8px;
}
.hiw__tile h3{ margin: 6px 0 8px; font-size: 1.2rem; }
.hiw__tile p{ margin: 0; color: var(--silver-1); font-size: 1rem; line-height: 1.6; }

.hiw__note{
  margin-top: 16px; color: var(--silver-2); font-size: 12px; text-align: center;
}

/* Animations */
@keyframes gradientShift{ 0%{background-position:0% 50%} 100%{background-position:100% 50%} }
@keyframes pop{ from{opacity:0; transform:translateY(14px) scale(.965)} to{opacity:1; transform:translateY(0) scale(1)} }

@media (prefers-reduced-motion: reduce){
  .slider__track{ animation: none; }
  .hiw__tile{ animation: none; opacity: 1; transform: none; }
}

/* hide honeypot but keep it in DOM for bots */
.hp {
  position:absolute !important;
  left:-9999px !important;
  width:1px; height:1px;
  opacity:0;
}

.inline-error{ margin-top:6px; font-size:.9rem; color:#ff9ca6; opacity:.95; }

.hide { display: none !important; }

/* === Watchlist modal – solid panel + inline success === */
.modal-backdrop{
  background: rgba(10, 0, 25, .65) !important;  /* darker overlay */
  backdrop-filter: none !important;             /* no blur */
}

.modal-panel{
  background: #130a1e !important;               /* solid – not translucent */
  border: 1px solid rgba(255,255,255,.08) !important;
  box-shadow: 0 20px 60px rgba(0,0,0,.6), 0 0 0 1px rgba(178,132,255,.12) inset;
  backdrop-filter: none !important;
}

.modal-close{
  position:absolute; top:10px; right:12px;
  width:36px; height:36px; border-radius:10px;
  border:1px solid rgba(255,255,255,.22);
  background:rgba(255,255,255,.06);
  color:#fff; font-size:22px; line-height:1; cursor:pointer;
}
.modal-close:hover{ background:rgba(255,255,255,.12); }

/* tidy spacing inside the solid panel */
.modal-body{ padding: 28px 28px 22px; }

/* fieldset options */
#role-field .opt{ display:inline-flex; gap:.5rem; align-items:center; margin-right:18px; }
#role-field .opt-sub{ display:block; margin-top:8px; opacity:.95; }

/* inline success view (hidden until success) */
.form-success{
  text-align:center;
  padding: 10px 6px 4px;
}
.form-success h4{ margin:0 0 6px; }
.form-success p{ margin:0 0 14px; }
.success-badge{
  width:48px; height:48px; line-height:48px; margin:0 auto 8px;
  border-radius:50%; text-align:center; font-weight:800;
  border:1px solid rgba(185,149,255,.5);
}

/* inline errors in the modal */
#notify-modal .inline-error{ color:#ff9ca6; display:block; margin-top:6px; font-size:.9rem; }

/* small note / error line under the button */
#notify-error{ display:block; opacity:.9; margin-top:8px; text-align:center; }

/* --- Suggest button: glass outline + animated border --- */
.suggest-btn{
  --btn-h: 52px;
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  height: var(--btn-h);
  padding: 0 22px 0 18px;
  border-radius: 999px;
  font-weight: 800;
  letter-spacing: .02em;
  color: #efe8ff;
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  backdrop-filter: saturate(140%);
  cursor: pointer;
  border: 0;                    /* border is drawn by ::before */
  transition: transform .15s ease, filter .15s ease;
}

/* Animated gradient ring (masked so it's only a 1.5px stroke) */
.suggest-btn::before{
  content:"";
  position:absolute; inset:0;
  padding:1.5px; border-radius:inherit;
  background:
    conic-gradient(from 0deg, #b995ff, #8a4df0, #6e26c7, #b995ff);
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  animation: spinRing 8s linear infinite;
  opacity:.9;
}

/* Soft inner glow */
.suggest-btn::after{
  content:"";
  position:absolute; inset:2px;
  border-radius:inherit;
  background: radial-gradient(120% 140% at 50% -20%, rgba(255,255,255,.10), rgba(255,255,255,0));
  pointer-events:none;
}

/* Icon chip */
.suggest-icon{
  display:inline-grid; place-items:center;
  width:28px; height:28px;
  border-radius:999px;
  font-weight:900; line-height:1;
  background: radial-gradient(60% 60% at 35% 30%, #fff, #efe8ff 48%, #d8cfff);
  color:#2b1650;
  box-shadow: 0 2px 8px rgba(0,0,0,.25), inset 0 1px 0 rgba(255,255,255,.8);
}

/* Hover / focus */
.suggest-btn:hover{ transform: translateY(-1px); filter: brightness(1.06); }
.suggest-btn:active{ transform: translateY(0); }
.suggest-btn:focus-visible{
  outline: 3px solid var(--purple-300);
  outline-offset: 2px;
}

/* Keep motion-friendly */
@media (prefers-reduced-motion: reduce){
  .suggest-btn::before{ animation: none; }
}

/* Ring animation */
@keyframes spinRing { to { transform: rotate(360deg); } }

.suggest-btn.pulse{ animation: pulse .32s ease; }
@keyframes pulse { 0%{transform:scale(1)} 50%{transform:scale(1.02)} 100%{transform:scale(1)} }


/* Smooth anchor scrolling everywhere */
html { scroll-behavior: smooth; }

/* Make anchors land *below* the sticky header */
#watchlists { scroll-margin-top: 88px; } /* header is ~76px; add a bit of breathing room */

/* optional "arrived" cue */
#watchlists.flash {
  box-shadow: 0 0 0 2px rgba(185,149,255,.25) inset, 0 0 28px rgba(185,149,255,.18);
  animation: wlFlash .7s ease;
}
@keyframes wlFlash { from { opacity:.96 } to { opacity:1 } }

/* Suggest button – calm, no orbit ring */
#btn-suggest {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 18px;
  border-radius: 999px;
  font-weight: 800;
  color: #fff;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.22);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.25);
}

/* nuke the ring/pulse underline if it exists */
#btn-suggest::before,
#btn-suggest::after { content: none !important; }
#btn-suggest.pulse { animation: none !important; }
#btn-suggest:hover { background: rgba(255,255,255,.10); }

/* Header primary links */
header nav ul{
  display: grid;               /* steadier than flex for even spacing */
  grid-auto-flow: column;
  justify-content: center;     /* center the whole group */
  align-items: center;         /* vertical alignment */
  gap: 56px;                   /* even spacing between items */
  padding: 0;
  margin: 0;
}

header nav a{
  display: inline-block;
  padding: 10px 12px;          /* same click area for all */
  line-height: 1;              /* keeps baselines aligned */
}

.wl-title__where { display: inline; }
@media (min-width: 700px){
  .wl-title__where { display: block; }
}

/* shared styles.css */
.footer-right { text-align: right; }
.footer-right .lead {
  margin: 0 0 12px;     /* tighter, no big gap above icons */
  text-align: right;    /* undo the center from .lead */
  max-width: none;
}

/* optional: keep spacing between the two footer rows consistent */
.footer-right{
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  row-gap: 12px;
}


.sbtn { display:inline-flex; align-items:center; justify-content:center;
  width:40px; height:40px; border:1.5px solid rgba(255,255,255,.5);
  border-radius:12px; line-height:0; }

.socials svg { 
display:block;            /* kill baseline gap */
width:22px; height:22px;  /* square box */
/* defaults to preserveAspectRatio="xMidYMid meet", but we set it anyway */
fill:currentColor; color:#fff;
}


