/* ============ Barrely - bright & elegant, black + premium yellow ============ */

:root{
  --cream:        #FBF8F1;   /* warm off-white base */
  --cream-2:      #F3EEE2;   /* slightly deeper panel */
  --ink:          #161310;   /* warm near-black */
  --ink-soft:     #4A453C;   /* muted body text on light */
  --ink-faint:    #8A8275;   /* captions */
  --yellow:       #FFC400;   /* premium golden highlight */
  --yellow-deep:  #E0A400;   /* deeper gold for fine text on light */
  --gold-text:    #93650A;   /* readable gold on cream */
  --line:         #E5DFD1;   /* hairline on cream */
  --black:        #100E0B;   /* full black section */
  --black-soft:   #211D17;

  --font-display: "Fraunces", Georgia, "Times New Roman", serif;
  --font-sans:    "Hanken Grotesk", system-ui, -apple-system, sans-serif;

  --maxw: 1200px;
  --ease: cubic-bezier(.22,.61,.36,1);
}

*{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; }
html.has-lenis{ scroll-behavior:auto; }
html:not(.has-lenis){ scroll-behavior:smooth; }

body{
  margin:0;
  background:var(--cream);
  color:var(--ink);
  font-family:var(--font-sans);
  font-size:18px;
  line-height:1.6;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

img,svg{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
em{ font-style:italic; }

h1,h2,h3{ font-family:var(--font-display); font-weight:400; letter-spacing:-.015em; line-height:1.02; margin:0; }
h2{ font-size:clamp(2rem, 5vw, 3.6rem); }
h3{ font-size:clamp(1.4rem,2.5vw,2rem); letter-spacing:-.01em; }

.eyebrow{
  font-family:var(--font-sans);
  text-transform:uppercase;
  letter-spacing:.22em;
  font-size:.72rem;
  font-weight:700;
  color:var(--gold-text);
  margin:0 0 1.1rem;
}

/* ---------- Scroll progress ---------- */
.scroll-progress{
  position:fixed; top:0; left:0; right:0; height:3px; z-index:120;
  background:transparent; pointer-events:none;
}
.scroll-progress span{
  display:block; height:100%; width:0%;
  background:var(--yellow);
  transition:width .1s linear;
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.5rem; justify-content:center;
  font-family:var(--font-sans); font-weight:600; font-size:1rem;
  border-radius:999px; cursor:pointer; border:1.5px solid transparent;
  padding:.85rem 1.5rem; transition:transform .25s var(--ease), background .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease), box-shadow .25s var(--ease);
  will-change:transform;
}
.btn:active{ transform:translateY(1px); }
.btn-solid{ background:var(--ink); color:var(--cream); }
.btn-solid:hover{ background:var(--yellow); color:var(--ink); box-shadow:0 12px 30px -12px rgba(255,196,0,.7); transform:translateY(-2px); }
.btn-ghost{ background:transparent; color:var(--ink); border-color:var(--ink); }
.btn-ghost:hover{ background:var(--ink); color:var(--cream); transform:translateY(-2px); }
.btn-ghost svg{ transition:transform .25s var(--ease); }
.btn-ghost:hover svg{ transform:translateX(4px); }
.btn-pill{ padding:.6rem 1.15rem; font-size:.92rem; }
.btn-block{ width:100%; }

/* ---------- Header ---------- */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:100;
  display:flex; align-items:center; justify-content:space-between; gap:1rem;
  padding:1.05rem clamp(1.1rem,4vw,2.6rem);
  transition:background .35s var(--ease), padding .35s var(--ease), box-shadow .35s var(--ease), backdrop-filter .35s var(--ease);
}
.site-header.scrolled{
  background:rgba(251,248,241,.82);
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  box-shadow:0 1px 0 var(--line);
  padding-top:.7rem; padding-bottom:.7rem;
}
.brand{ display:inline-flex; align-items:center; gap:.55rem; font-weight:700; }
.brand-mark{ color:var(--ink); display:inline-flex; }
.brand-word{ font-family:var(--font-display); font-size:1.45rem; letter-spacing:-.02em; }
.nav-links{ display:flex; gap:2rem; font-weight:500; font-size:.98rem; }
.nav-links a{ position:relative; color:var(--ink-soft); transition:color .2s var(--ease); }
.nav-links a::after{ content:""; position:absolute; left:0; right:100%; bottom:-4px; height:2px; background:var(--yellow); transition:right .3s var(--ease); }
.nav-links a:hover{ color:var(--ink); }
.nav-links a:hover::after{ right:0; }
.nav-cta{ background:var(--yellow); color:var(--ink); }
.nav-cta:hover{ background:var(--ink); color:var(--cream); transform:translateY(-2px); }

/* ---------- Reveal animation ---------- */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal[data-delay="1"]{ transition-delay:.08s; }
.reveal[data-delay="2"]{ transition-delay:.16s; }
.reveal[data-delay="3"]{ transition-delay:.24s; }
.reveal[data-delay="4"]{ transition-delay:.32s; }
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1 !important; transform:none !important; }
  *{ animation:none !important; }
}

/* ---------- Layout helpers ---------- */
section{ padding:clamp(4.5rem,9vw,8rem) clamp(1.2rem,5vw,3rem); }
.section-head{ max-width:var(--maxw); margin:0 auto clamp(2.5rem,5vw,4rem); }
.section-head h2{ max-width:16ch; }

/* ---------- HERO ---------- */
.hero{ padding-top:clamp(8rem,16vh,11rem); padding-bottom:0; position:relative; }
.hero-inner{
  max-width:var(--maxw); margin:0 auto;
  display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(2rem,5vw,4.5rem); align-items:center;
}
.hero-title{ font-size:clamp(2.9rem,7.2vw,5.6rem); margin:.4rem 0 1.6rem; }
.hero-title .line{ display:block; }
.hero-title em{ color:var(--ink); position:relative; white-space:nowrap; }
.hero-title em::after{
  content:""; position:absolute; left:-.04em; right:-.04em; bottom:.08em; height:.36em; z-index:-1;
  background:var(--yellow); border-radius:2px; transform:scaleX(0); transform-origin:left;
  transition:transform .9s var(--ease) .5s;
}
.hero-title em.lit::after{ transform:scaleX(1); }
.hero-sub{ font-size:clamp(1.05rem,1.6vw,1.28rem); color:var(--ink-soft); max-width:46ch; }
.hero-sub strong{ color:var(--ink); font-weight:600; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:.9rem; margin-top:2rem; }
.hero-note{ margin-top:1.4rem; font-size:.92rem; color:var(--ink-faint); letter-spacing:.01em; }

/* Hero visual */
.hero-visual{ perspective:1400px; }
.grid-card{
  background:#fff; border:1px solid var(--line); border-radius:22px;
  box-shadow:0 40px 80px -40px rgba(22,19,16,.35), 0 8px 24px -16px rgba(22,19,16,.2);
  padding:1.1rem; transform:rotateY(-9deg) rotateX(3deg); transform-style:preserve-3d;
  transition:transform .6s var(--ease);
}
.hero-visual:hover .grid-card{ transform:rotateY(-3deg) rotateX(1deg); }
.grid-card-top{ display:flex; align-items:center; gap:.7rem; padding:.2rem .3rem .9rem; }
.dot-row{ display:inline-flex; gap:.32rem; }
.dot-row i{ width:9px; height:9px; border-radius:50%; background:var(--line); }
.dot-row i:first-child{ background:var(--yellow); }
.grid-card-title{ font-size:.8rem; color:var(--ink-faint); font-weight:600; letter-spacing:.02em; }
.timetable{ display:grid; grid-template-columns:repeat(3,1fr); gap:.5rem; background:var(--cream); border-radius:14px; padding:.6rem; }
.tt-col{ display:grid; grid-template-rows:auto repeat(6, 26px); gap:.32rem; position:relative; }
.tt-day{ font-size:.62rem; font-weight:700; letter-spacing:.14em; color:var(--ink-faint); text-align:center; padding-bottom:.2rem; }
.tt-slot{
  grid-row:calc(var(--row) + 1) / span var(--span);
  border-radius:9px; padding:.32rem .45rem; font-size:.62rem; line-height:1.15;
  display:flex; flex-direction:column; justify-content:center; gap:.1rem;
  border:1px solid rgba(22,19,16,.06); overflow:hidden;
}
.tt-slot b{ font-size:.7rem; font-weight:700; }
.tt-slot small{ color:var(--ink-soft); font-size:.58rem; }
.s-ballet{ background:#FFF1C2; }
.s-jazz{ background:#FFE08A; }
.s-tap{ background:#FBEAD0; }
.s-pointe{ background:var(--yellow); }
.s-hiphop{ background:#FFF1C2; }
.s-contemp{ background:#FBEAD0; }
.s-conflict{ background:var(--ink); color:var(--cream); border-color:var(--ink); }
.s-conflict small{ color:#E8C766; }
.s-conflict b{ color:var(--yellow); }
.grid-card-toast{
  display:flex; align-items:center; gap:.6rem; margin-top:.8rem;
  background:var(--ink); color:var(--cream); border-radius:12px; padding:.7rem .85rem;
  font-size:.78rem; line-height:1.3; font-weight:500;
}
.toast-tick{ flex:0 0 auto; width:26px; height:26px; border-radius:50%; background:var(--yellow); color:var(--ink); display:inline-flex; align-items:center; justify-content:center; }

/* Marquee */
.marquee{ margin-top:clamp(3.5rem,7vw,6rem); border-top:1px solid var(--line); border-bottom:1px solid var(--line); overflow:hidden; padding:1.1rem 0; }
.marquee-track{ display:inline-flex; align-items:center; gap:2.2rem; white-space:nowrap; animation:marquee 26s linear infinite; font-family:var(--font-display); font-size:clamp(1.3rem,2.6vw,2rem); }
.marquee-track span{ color:var(--ink); }
.marquee-track .sep{ color:var(--yellow); font-size:.8em; }
@keyframes marquee{ to{ transform:translateX(-50%); } }
.marquee:hover .marquee-track{ animation-play-state:paused; }

/* ---------- WHY ---------- */
.why{ background:var(--cream); }
.why-grid{ max-width:var(--maxw); margin:0 auto; display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(2rem,5vw,4rem); align-items:start; }
.why-lead{ font-size:clamp(1.2rem,2.2vw,1.7rem); font-family:var(--font-display); line-height:1.35; color:var(--ink); }
.pain-list{ list-style:none; padding:0; margin:0; }
.pain-list li{ display:flex; gap:1rem; align-items:baseline; padding:1.05rem 0; border-top:1px solid var(--line); font-size:1.05rem; color:var(--ink-soft); }
.pain-list li:last-child{ border-bottom:1px solid var(--line); }
.pain-list span{ font-family:var(--font-display); font-size:.95rem; color:var(--gold-text); font-weight:500; flex:0 0 auto; }

/* ---------- DIMENSIONS (pinned) ---------- */
.dimensions{ display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(1.5rem,4vw,4rem); max-width:var(--maxw); margin:0 auto; align-items:start; }
.dim-sticky{ position:sticky; top:clamp(6rem,14vh,9rem); align-self:start; }
.dim-sticky h2{ max-width:11ch; }
.dim-counter{ font-family:var(--font-display); font-size:3rem; margin-top:1.6rem; color:var(--ink); display:flex; align-items:baseline; gap:.1rem; }
.dim-counter i{ font-style:normal; font-size:1.2rem; color:var(--ink-faint); }
.dim-track{ display:flex; flex-direction:column; gap:1.1rem; }
.dim-card{
  background:#fff; border:1px solid var(--line); border-radius:20px;
  padding:clamp(1.5rem,3vw,2.4rem); transition:transform .5s var(--ease), box-shadow .5s var(--ease), border-color .5s var(--ease);
  opacity:.55; transform:translateY(20px) scale(.985);
}
.dim-card.in{ opacity:1; transform:none; }
.dim-card.active{ border-color:var(--ink); box-shadow:0 30px 60px -40px rgba(22,19,16,.4); }
.dim-card[data-dim="01"].active{ border-color:var(--yellow-deep); }
.dim-card .dim-tag{ display:inline-block; font-size:.7rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--gold-text); background:var(--cream-2); padding:.32rem .7rem; border-radius:999px; margin-bottom:1rem; }
.dim-card[data-dim="01"] .dim-tag{ background:var(--yellow); color:var(--ink); }
.dim-card h3{ margin-bottom:.7rem; }
.dim-card p{ color:var(--ink-soft); font-size:1.05rem; margin:0 0 1.1rem; }
.dim-card ul{ list-style:none; padding:0; margin:0; display:flex; flex-wrap:wrap; gap:.5rem; }
.dim-card ul li{ font-size:.85rem; font-weight:500; color:var(--ink); background:var(--cream); border:1px solid var(--line); border-radius:999px; padding:.35rem .75rem; }

/* ---------- DIFFERENCE (black section) ---------- */
.difference{ background:var(--black); color:var(--cream); border-radius:34px; margin:clamp(2rem,5vw,4rem) clamp(.8rem,3vw,2rem); }
.section-head.light h2{ color:var(--cream); }
.section-head.light .eyebrow{ color:var(--yellow); }
.compare{ max-width:var(--maxw); margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:1.2rem; }
.compare-col{ border-radius:22px; padding:clamp(1.6rem,3vw,2.6rem); }
.compare-them{ background:var(--black-soft); color:#C9C2B4; }
.compare-them h4{ color:#EDE7D9; }
.compare-us{ background:var(--cream); color:var(--ink); position:relative; }
.compare h4{ font-family:var(--font-display); font-size:1.7rem; margin:0 0 .3rem; }
.compare-sub{ font-size:.85rem; letter-spacing:.02em; margin:0 0 1.4rem; opacity:.8; }
.compare ul{ list-style:none; padding:0; margin:0; }
.compare li{ padding:.85rem 0; border-top:1px solid rgba(255,255,255,.1); font-size:1.02rem; display:flex; gap:.7rem; align-items:flex-start; }
.compare-us li{ border-top-color:var(--line); }
.compare-them li::before{ content:"✕"; color:#6E685C; font-size:.85em; flex:0 0 auto; }
.compare-us li::before{ content:"✓"; color:var(--yellow-deep); font-weight:700; flex:0 0 auto; }
.compare-badge{ position:absolute; top:-.9rem; left:clamp(1.6rem,3vw,2.6rem); background:var(--yellow); color:var(--ink); font-weight:700; font-size:.78rem; letter-spacing:.04em; padding:.4rem .9rem; border-radius:999px; }

/* ---------- FEATURES ---------- */
.feature-grid{ max-width:var(--maxw); margin:0 auto; display:grid; grid-template-columns:repeat(3,1fr); gap:1.1rem; }
.feature{ padding:1.8rem; border-radius:18px; border:1px solid var(--line); background:#fff; transition:transform .4s var(--ease), box-shadow .4s var(--ease); }
.feature:hover{ transform:translateY(-4px); box-shadow:0 24px 48px -34px rgba(22,19,16,.4); }
.feature h3{ font-size:1.25rem; margin-bottom:.6rem; }
.feature h3::before{ content:""; display:block; width:30px; height:4px; border-radius:2px; background:var(--yellow); margin-bottom:1rem; }
.feature p{ color:var(--ink-soft); font-size:1rem; margin:0; }

/* ---------- BETA ---------- */
.beta{ background:var(--cream-2); }
.beta-inner{ max-width:var(--maxw); margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4.5rem); align-items:center; }
.beta-copy h2{ max-width:13ch; margin-bottom:1.2rem; }
.beta-sub{ color:var(--ink-soft); font-size:1.1rem; max-width:42ch; }
.beta-points{ list-style:none; padding:0; margin:1.6rem 0 0; }
.beta-points li{ padding:.6rem 0 .6rem 1.8rem; position:relative; color:var(--ink); }
.beta-points li::before{ content:"✶"; position:absolute; left:0; color:var(--yellow-deep); }
.beta-form{ background:#fff; border:1px solid var(--line); border-radius:24px; padding:clamp(1.6rem,3vw,2.4rem); box-shadow:0 30px 60px -45px rgba(22,19,16,.5); }
.field{ margin-bottom:1.1rem; }
.field label{ display:block; font-size:.82rem; font-weight:600; letter-spacing:.02em; margin-bottom:.45rem; color:var(--ink); }
.field input{
  width:100%; font-family:var(--font-sans); font-size:1.02rem; color:var(--ink);
  padding:.95rem 1.05rem; border:1.5px solid var(--line); border-radius:12px; background:var(--cream);
  transition:border-color .2s var(--ease), box-shadow .2s var(--ease), background .2s var(--ease);
}
.field input::placeholder{ color:var(--ink-faint); }
.field input:focus{ outline:none; border-color:var(--ink); background:#fff; box-shadow:0 0 0 4px rgba(255,196,0,.25); }
.field input.invalid{ border-color:#C0392B; box-shadow:0 0 0 4px rgba(192,57,43,.12); }
.btn-block{ margin-top:.4rem; position:relative; }
.btn-spinner{ width:17px; height:17px; border-radius:50%; border:2px solid rgba(251,248,241,.4); border-top-color:var(--cream); animation:spin .7s linear infinite; display:none; }
.btn.loading .btn-spinner{ display:inline-block; }
.btn.loading .btn-label{ opacity:.7; }
@keyframes spin{ to{ transform:rotate(360deg); } }
.form-msg{ margin:1rem 0 0; font-size:.92rem; min-height:1.2em; }
.form-msg.ok{ color:#1E7A46; }
.form-msg.err{ color:#C0392B; }
.beta-form.done .field, .beta-form.done .btn-block{ display:none; }
.beta-done{ text-align:center; padding:1rem 0; }
.beta-done .tick{ width:54px; height:54px; border-radius:50%; background:var(--yellow); color:var(--ink); display:inline-flex; align-items:center; justify-content:center; margin-bottom:1rem; }
.beta-done h3{ margin-bottom:.5rem; }
.beta-done p{ color:var(--ink-soft); margin:0; }

/* ---------- FOOTER ---------- */
.site-footer{ background:var(--ink); color:var(--cream); padding:clamp(3rem,6vw,5rem) clamp(1.2rem,5vw,3rem) 2rem; }
.footer-top{ max-width:var(--maxw); margin:0 auto; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:1rem; padding-bottom:2.5rem; border-bottom:1px solid rgba(255,255,255,.12); }
.brand-footer .brand-mark{ color:var(--yellow); }
.footer-tag{ font-family:var(--font-display); font-size:1.3rem; margin:0; color:#E9E3D5; }
.footer-bottom{ max-width:var(--maxw); margin:0 auto; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:.6rem; padding-top:1.6rem; font-size:.9rem; color:#9C958657; }
.footer-bottom span{ color:#9C9586; }
.footer-bottom a{ color:var(--yellow); font-weight:600; }

/* ---------- PRICING ---------- */
.pricing{ background:var(--cream); }
.pricing-grid{ max-width:var(--maxw); margin:0 auto; display:grid; grid-template-columns:1.05fr .95fr; gap:1.2rem; align-items:stretch; }
.price-card{ background:var(--black); color:var(--cream); border-radius:24px; padding:clamp(1.8rem,3.5vw,2.8rem); display:flex; flex-direction:column; box-shadow:0 40px 80px -50px rgba(22,19,16,.6); }
.price-badge{ align-self:flex-start; background:var(--yellow); color:var(--ink); font-weight:700; font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; padding:.4rem .85rem; border-radius:999px; margin-bottom:1.5rem; }
.price-amount{ display:flex; align-items:baseline; gap:.05rem; font-family:var(--font-display); line-height:1; color:#fff; }
.price-currency{ font-size:2.2rem; color:var(--yellow); }
.price-number{ font-size:clamp(4rem,9vw,6rem); }
.price-period{ font-size:1.35rem; color:#B9B2A2; margin-left:.4rem; font-family:var(--font-sans); font-weight:500; }
.price-flat{ color:#D9D2C4; font-size:1.05rem; margin:1.1rem 0 1.7rem; max-width:36ch; }
.price-includes{ list-style:none; padding:0; margin:0 0 2rem; display:flex; flex-direction:column; gap:.75rem; }
.price-includes li{ position:relative; padding-left:2rem; color:#EDE7D9; font-size:1rem; }
.price-includes li::before{ content:"✓"; position:absolute; left:0; top:.05em; color:var(--ink); background:var(--yellow); width:1.3rem; height:1.3rem; border-radius:50%; display:inline-flex; align-items:center; justify-content:center; font-size:.78rem; font-weight:700; }
.price-card .btn-block{ margin-top:auto; }
.price-card .btn-solid{ background:var(--yellow); color:var(--ink); }
.price-card .btn-solid:hover{ background:#fff; color:var(--ink); box-shadow:none; }
.price-compare{ background:#fff; border:1px solid var(--line); border-radius:24px; padding:clamp(1.8rem,3.5vw,2.6rem); display:flex; flex-direction:column; }
.price-compare-title{ font-family:var(--font-display); font-size:1.4rem; margin:0 0 1.3rem; }
.price-table{ list-style:none; padding:0; margin:0 0 1.4rem; }
.price-row{ display:flex; justify-content:space-between; align-items:center; padding:.95rem 0; border-bottom:1px solid var(--line); }
.price-row:last-child{ border-bottom:0; }
.pr-name{ font-weight:600; color:var(--ink); }
.pr-cost{ font-family:var(--font-display); font-size:1.25rem; color:var(--ink-soft); white-space:nowrap; }
.pr-cost i{ font-style:normal; font-size:.8rem; color:var(--ink-faint); font-family:var(--font-sans); margin-left:.15rem; }
.price-row-us{ background:var(--yellow); margin:0 -.9rem .5rem; padding:.95rem .9rem; border-radius:12px; border-bottom:0; }
.price-row-us .pr-name{ font-weight:700; }
.price-row-us .pr-cost{ color:var(--ink); font-size:1.4rem; }
.price-row-us .pr-cost i{ color:var(--gold-text); }
.price-note{ margin:auto 0 0; font-size:.84rem; color:var(--ink-faint); line-height:1.55; }

/* ============ Responsive ============ */
@media (max-width:980px){
  .hero-inner{ grid-template-columns:1fr; gap:2.5rem; }
  .hero-visual{ order:2; max-width:480px; }
  .why-grid{ grid-template-columns:1fr; }
  .dimensions{ grid-template-columns:1fr; }
  .dim-sticky{ position:static; }
  .dim-counter{ display:none; }
  .compare{ grid-template-columns:1fr; }
  .pricing-grid{ grid-template-columns:1fr; }
  .feature-grid{ grid-template-columns:1fr 1fr; }
  .beta-inner{ grid-template-columns:1fr; }
}
@media (max-width:680px){
  body{ font-size:17px; }
  .nav-links{ display:none; }
  .feature-grid{ grid-template-columns:1fr; }
  .hero{ padding-top:7rem; }
  .difference{ border-radius:24px; margin-left:.4rem; margin-right:.4rem; }
  .footer-top{ flex-direction:column; align-items:flex-start; }
}
