/* =========================================================
   AROGYA CITA INDONESIA — Stylesheet v2
   Tokens taken directly from the Figma spec supplied by the client
   ========================================================= */
:root{
  --dark:        #212121;   /* Primary Color   */
  --lime:        #ACEB00;   /* Secondary Color */
  --lime-soft:   #CDF366;
  --lime-pale:   #EEFBCC;
  --s1:          #BDEF33;   /* product card bg */
  --s3:          #DEF799;   /* overlay tint / pale badge */
  --white:       #FAFAFA;   /* Ascent 1 */
  --ink:         #212121;
  --p2:          #4D4D4D;   /* muted text on white/lime */
  --p3:          #7A7A7A;   /* inactive carousel strip */
  --p4:          #D3D3D3;   /* form field bg */
  --p4-dark:     #A6A6A6;   /* placeholder text */
  --muted:       #b8b8b8;   /* muted text on dark */
  --radius-lg:   28px;
  --radius-md:   18px;
  --radius-sm:   10px;
  --container:   1320px;
  --nav-h:       76px;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--dark);
  color:var(--white);
  font-family:'Tomorrow', 'Inter', -apple-system, sans-serif;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; }
ul{ list-style:none; margin:0; padding:0; }
h1,h2,h3,h4{ margin:0; }
p{ margin:0; }

.container{ max-width:var(--container); margin:0 auto; padding:0 24px; }

/* ---------- Display / heading type ---------- */
.display{ font-family:'Tomorrow', sans-serif; font-weight:600; line-height:0.95; }
.display--slant{ font-style:italic; }
.display--xbold{ font-weight:800; }

.grad-text{
  background:linear-gradient(94deg, var(--lime) 9%, var(--lime-soft) 29%, var(--lime-pale) 50%, var(--lime-soft) 70%, var(--lime) 91%);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  color:transparent;
  text-shadow:6px 6px 10px rgba(0,0,0,.35);
}
.eyebrow{ font-family:'Tomorrow',sans-serif; font-weight:400; font-size:15px; letter-spacing:.02em; color:var(--muted); }

/* ---------- Texture / backgrounds ---------- */
.bg-dark{ background:var(--dark); }
.bg-dot-texture{
  background-color:var(--dark);
  background-image:radial-gradient(rgba(255,255,255,0.05) 1px, transparent 1px);
  background-size:10px 10px;
}
.bg-lime{ background:var(--lime); color:var(--ink); }
.bg-overlay-s3{ position:relative; }
.bg-overlay-s3::before{ content:""; position:absolute; inset:0; background:var(--s3); mix-blend-mode:multiply; pointer-events:none; }
.bg-overlay-s3 > *{ position:relative; z-index:1; }

.bg-glow{ position:relative; overflow:hidden; }
.bg-glow::after{
  content:""; position:absolute; right:-10%; bottom:-30%; width:70%; height:120%;
  background:radial-gradient(closest-side, rgba(172,235,0,.55), rgba(172,235,0,0) 70%);
  filter:blur(10px); pointer-events:none;
}

.blur-blob{
  position:absolute; border-radius:40%;
  filter:blur(18px); opacity:.5;
  z-index: 1;
  background:linear-gradient(135deg, #6b6b6b, #2a2a2a);
  pointer-events:none;
}

.plus-mark{ position:absolute; color:var(--lime-pale); font-size:28px; line-height:1; pointer-events:none; }

/* =========================================================
   NAVBAR
   ========================================================= */
.navbar{ position:sticky; top:0; z-index:100; height:var(--nav-h); display:flex; align-items:center; background:var(--dark); border-bottom:1px solid rgba(255,255,255,.06); }
.navbar .container{ display:flex; align-items:center; justify-content:space-between; width:100%; }

.brand{   display:flex;
    align-items:center;
    flex-shrink:0;
}
.brand-logo{
    height:36px;
    width:auto;
    display:block;
}

.brand-logo-img{ height:28px; width:auto; }

.brand svg{ width:26px; height:26px; }

.nav-links{ display:none; align-items:center; gap:8px; margin-left: auto; font-weight:400; font-size:16px; }
.nav-links a{ position:relative; padding:8px 16px; border-radius:100px; color:var(--white); transition:color .2s ease, background .2s ease; }
.nav-links a:hover{ color:var(--lime); }
.nav-links a.active{ color:var(--ink); background:var(--lime); }

.nav-cta{ display:none; align-items:center; gap:14px; }
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:13px 24px; border-radius:100px; font-weight:400; font-family:'Tomorrow',sans-serif; font-size:15px;
  border:2px solid transparent; transition:transform .15s ease, background .2s ease, color .2s ease, border-color .2s ease;
  white-space:nowrap;
}
.btn:active{ transform:scale(.97); }
.btn-white{ background:var(--white); color:var(--ink); }
.btn-white:hover{ background:var(--lime); }
.btn-outline-lime{ border-color:var(--lime); color:var(--white); background:transparent; }
.btn-outline-lime:hover{ background:var(--lime); color:var(--ink); }
.btn-ink{ background:var(--ink); color:var(--white); }
.btn-ink:hover{ background:#000; }
.btn-lime{ background:var(--lime); color:var(--white); }
.btn-lime:hover{ filter:brightness(1.08); }
.btn-block{ width:100%; }
.btn-lg{ padding:18px 28px; font-size:17px; }
.btn-sq{ border-radius:12px; }

.menu-toggle{ display:flex; align-items:center; justify-content:center; width:44px; height:44px; border:1.5px solid var(--lime); border-radius:10px; background:transparent; color:var(--lime); }
.menu-toggle svg{ width:20px; height:20px; }

/* ---------- Mobile menu overlay ---------- */
.mobile-menu{ position:fixed; inset:0; z-index:200; background:var(--dark); display:flex; flex-direction:column; transform:translateX(100%); transition:transform .35s cubic-bezier(.65,0,.35,1); }
.mobile-menu.is-open{ transform:translateX(0); }
.mobile-menu-top{ display:flex; align-items:center; justify-content:space-between; height:var(--nav-h); padding:0 24px; border-bottom:1px solid rgba(255,255,255,.06); }
.mobile-menu-badge{ display:flex; justify-content:center; padding:36px 0 12px; }
.mobile-menu-badge svg{ width:150px; height:150px; }
.mobile-nav-links{ display:flex; flex-direction:column; gap:6px; padding:12px 32px 0; }
.mobile-nav-links a{ font-family:'Tomorrow',sans-serif; font-style:italic; font-weight:600; font-size:28px; padding:16px 0; border-bottom:1px solid rgba(255,255,255,.08); color:var(--white); }
.mobile-nav-links a.active{ color:var(--lime); }
.mobile-menu-foot{ margin-top:auto; padding:24px 32px 36px; display:flex; gap:12px; }

.badge-svg{ display:block; }

/* =========================================================
   HERO
   ========================================================= */
.hero{
    position:relative;
    overflow:hidden;
    padding:64px 0 72px;
    background-color:#212121;
}

.hero .container{ position:relative; z-index:3; }
.hero-title{ font-size:44px; margin-bottom:22px; }
.hero-sub{ max-width:520px; margin:0 auto 32px; color:var(--muted); font-size:15px; line-height:1.6; }
.consult-sub{
    margin:0;
    text-align:center;
}
.hero-actions{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
.hero::before{

    content:"";

    position:absolute;

    inset:0;

    background-image:
        radial-gradient(rgba(255,255,255,.05) 1px, transparent 1px);

    background-size:10px 10px;

    z-index:0;
}
.hero-bg{

    position:absolute;

    left:50%;

    bottom:-180px;

    transform:translateX(-50%);

    width:1440px;

    height:895px;

    background-image:url("../pictures/dumbellbg.png");

    background-repeat:no-repeat;

    background-size:contain;

    background-position:center bottom;

    z-index:2;

    pointer-events:none;
}


.section{ padding:64px 0; }
.section-tight{ padding:48px 0; }
.section-head{ text-align:center; margin-bottom:36px; }
.section-title{ font-size:34px; margin-bottom:12px; }
.section-desc{ color:rgba(18,18,18,.62); font-size:15px; }
.bg-dark .section-desc,
.bg-dot-texture .section-desc{ color:var(--muted); }

/* =========================================================
   HOME — brand slider / stats / CTA
   ========================================================= */
.scroll-row{
    display: flex;
    flex-wrap: nowrap;          /* WAJIB */
    gap: 20px;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 20px 24px;

    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
}

.scroll-row::-webkit-scrollbar{
    display:none;
}

.brand-card img{
    width:100%;
    height:auto;
    display:block;
}

.brand-card{
    flex: 0 0 auto;             /* jangan mengecil */
    width: 180px;               /* sesuaikan dengan Figma */
    scroll-snap-align: start;
}



.brand-card .icon{ height:40px; margin:0 auto 12px; }
.brand-card .name{ font-family:'Tomorrow',sans-serif; font-weight:600; font-size:15px; letter-spacing:.02em; color:var(--white); }

.stats-row{ display:flex; flex-direction:column; gap:36px; max-width:520px; margin:0 auto; text-align:center; }
.stat{ padding:8px 0; }
.stat + .stat{ border-top:1px solid rgba(255,255,255,.14); padding-top:36px; }
.stat-num{ font-size:64px; margin-bottom:10px; font-weight:600; }
.stat-label{ font-family:'Tomorrow',sans-serif; font-style:italic; font-weight:600; color:var(--lime-pale); font-size:20px; max-width:320px; margin:0 auto; line-height:1.3; }

.choice-cta{ position:relative; text-align:center; padding:72px 0 56px; }
.choice-cta .plus{ color:var(--lime); font-size:26px; margin-bottom:14px; }
.choice-cta .kicker{ color:var(--muted); margin-bottom:10px; font-size:15px; }
.choice-cta h2{ font-size:36px; margin-bottom:34px; }

/* =========================================================
   WHO WE ARE
   ========================================================= */
.about-hero{ text-align:center; padding:64px 0; position:relative; }
.about-hero p{ font-family:'Tomorrow',sans-serif; font-style:italic; font-weight:600; font-size:26px; line-height:1.3; max-width:780px; margin:0 auto; }

.vision-block{ display:grid; gap:32px; align-items:center; }
.vision-copy h2{ font-size:38px; margin-bottom:16px; }
.vision-copy p{ font-size:15px; line-height:1.7; color:var(--ink); opacity:.85; max-width:460px; }
.vision-photo{ position:relative; display:flex; justify-content:center; }
.vision-img{ width:88%; max-width:420px; border-radius:18px; filter:drop-shadow(-10px 6px 0px rgba(33,33,33,.2)); }
.vision-img-fallback{ display:none; align-items:center; justify-content:center; width:100%; }
.cross-icon{ position:absolute; height:auto; pointer-events:none; }

.mission-list{ display:grid; gap:36px; max-width:780px; margin:0 auto; }
.mission-item{ display:grid; grid-template-columns:70px 1fr; gap:20px; align-items:start; padding-bottom:28px; border-bottom:1px solid rgba(255,255,255,.08); }
.mission-item:last-child{ border-bottom:none; }
.mission-num{ font-family:'Tomorrow',sans-serif; font-style:italic; font-weight:600; font-size:38px; color:var(--white); }
.mission-item p{ color:var(--lime); font-size:16px; line-height:1.55; }

/* =========================================================
   CATALOG — carousel banner
   ========================================================= */
.catalog-carousel{ position:relative; padding:56px 0 40px; overflow:hidden; }
.carousel-grid{ display:grid; gap:28px; align-items:center; position:relative; z-index:1; }
.carousel-frame{ position:relative; background:var(--dark); border-radius:var(--radius-lg); aspect-ratio:4/5; display:flex; align-items:center; justify-content:center; overflow:hidden; }
.carousel-frame svg{ width:78%; height:78%; }
.carousel-copy{ position:relative; }
.carousel-copy .eyebrow{ display:block; margin-bottom:14px; color:var(--white); }
.carousel-copy h2{ font-size:36px; line-height:1.05; margin-bottom:28px; }
.carousel-strips{ display:flex; gap:14px; }
.carousel-strip{ height:6px; width:60px; border-radius:20px; background:var(--p3); cursor:pointer; transition:background .2s ease; }
.carousel-strip.is-active{ background:var(--lime); }
.carousel-slide{ display:none; }
.carousel-slide.is-active{ display:block; }

/* =========================================================
   CATALOG — product grid
   ========================================================= */
.product-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:18px; }
.product-card{ background:var(--s1); border-radius:var(--radius-md); padding:16px; color:var(--ink); display:flex; flex-direction:column; box-shadow:4px 4px 9px rgba(0,0,0,.2); }
.product-photo{ background:var(--white); border-radius:var(--radius-sm); aspect-ratio:4/3; display:flex; align-items:center; justify-content:center; margin-bottom:16px; padding:14px; }
.product-photo svg{ width:72%; height:72%; opacity:.85; }
.product-name{ font-family:'Tomorrow',sans-serif; font-weight:400; font-size:18px; line-height:1.2; margin-bottom:10px; }
.product-tag{ font-size:11.5px; color:var(--p2); margin-bottom:4px; }
.product-price{ font-size:12.5px; font-weight:600; margin-bottom:16px; }
.product-card .btn{ margin-top:auto; padding:11px 18px; border-radius:12px; font-size:13px; }

/* =========================================================
   CONSULT — How it works / Booking form
   ========================================================= */
.panel{ background:var(--white); color:var(--ink); border-radius:var(--radius-lg); padding:34px 24px; }
.panel-title{ font-family:'Tomorrow',sans-serif; font-style:italic; font-weight:600; color:var(--lime); font-size:32px; margin-bottom:28px; }

.steps-list{ display:grid; gap:30px; }
.step-item{ display:grid; grid-template-columns:56px 1fr; gap:16px; }
.step-num{ font-family:'Tomorrow',sans-serif; font-style:italic; font-weight:600; font-size:30px; color:var(--ink); }
.step-item h4{ font-family:'Tomorrow',sans-serif; font-weight:400; font-size:19px; margin-bottom:6px; }
.step-item p{ font-size:13.5px; color:#6b6b6b; line-height:1.55; }

.form-title{ font-family:'Tomorrow',sans-serif; font-style:italic; font-weight:600; font-size:32px; color:var(--lime); margin-bottom:6px; }
.form-subtitle{ font-family:'Tomorrow',sans-serif; font-size:22px; font-weight:400; color:var(--p2); margin-bottom:26px; }
.field{ margin-bottom:20px; }
.field label{ display:block; font-size:14px; font-weight:400; margin-bottom:8px; }
.field input,
.field textarea{ width:100%; border:none; background:var(--p4); border-radius:8px; padding:15px 16px; font-size:14.5px; font-family:'Tomorrow',sans-serif; color:var(--ink); }
.field input::placeholder,
.field textarea::placeholder{ color:var(--p4-dark); }
.field input:focus,
.field textarea:focus{ outline:2px solid var(--lime); outline-offset:1px; }
.field textarea{ resize:vertical; min-height:88px; }

.budget-grid{ display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-bottom:28px; }
.budget-opt{ background:var(--s3); border-radius:100px; padding:16px 10px; font-family:'Tomorrow',sans-serif; font-size:13.5px; font-weight:400; color:var(--ink); transition:background .15s ease, color .15s ease; }
.budget-opt.is-selected{ background:var(--lime); color:var(--white); box-shadow:inset 0 0 0 2px var(--ink); }

.form-note{ font-size:12.5px; color:#7a7a7a; margin-top:14px; text-align:center; line-height:1.6; }
.form-success{ display:none; background:var(--s3); border:1.5px solid var(--lime); border-radius:12px; padding:16px; font-size:13.5px; margin-bottom:20px; color:#3c5900; }
.form-success.is-visible{ display:block; }

/* =========================================================
   FOOTER
   ========================================================= */
.footer{ background:var(--dark); padding-top:56px; border-top:1px solid rgba(255,255,255,.06); }
.footer-grid{ display:grid; gap:40px; align-items:start; }
.footer-badge img{ width:150px; height:150px; object-fit:contain; }
.footer-links{ display:flex; flex-direction:column; gap:18px; font-family:'Tomorrow',sans-serif; font-weight:400; font-size:16px; }
.footer-links a:hover{ color:var(--lime); }
.footer-addr{ color:var(--muted); font-size:14px; line-height:1.7; font-family:'Tomorrow',sans-serif; }
.footer-addr strong{ display:block; color:var(--white); margin-bottom:8px; font-size:14.5px; }
.footer-contact{ margin-top:20px; display:flex; flex-direction:column; gap:6px; font-size:14px; }
.footer-contact a:hover{ color:var(--lime); }
.footer-bottom{ margin-top:40px; background:var(--lime); color:var(--ink); text-align:center; font-size:12.5px; font-weight:600; padding:14px 20px; }


.consult-grid{
    display: flex;
    flex-direction: column;
    gap: 24px;
}


/* =========================================================
   RESPONSIVE — Desktop
   ========================================================= */
@media (min-width:900px){
  :root{ --nav-h:88px; }
  .container{ padding:0 48px; }
  .nav-links{ display:flex; margin-left: auto; }
  .nav-cta{ display:flex; }
  .menu-toggle{ display:none; }

  .hero{ padding:110px 0 130px; }
  .hero-title{ font-size:80px; max-width:1050px; margin:0 auto 22px; }
  .hero-sub{ max-width:640px; font-size:18px; }


  .section{ padding:100px 0; }
  .section-title{ font-size:48px; }
  .section-desc{ font-size:18px; }

.scroll-row{
    display:flex;
    flex-wrap:nowrap;
    overflow-x:auto;
    overflow-y:hidden;
    gap:20px;
    padding:10px 0;

    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
}

.scroll-row::-webkit-scrollbar{
    display:none;
}

.brand-card{
    flex:0 0 240px;      /* lebar card */
    scroll-snap-align:start;
}

  .stats-row{ flex-direction:row; max-width:1000px; gap:0; }
  .stat{ flex:1; padding:0 40px; }
  .stat + .stat{ border-top:none; border-left:1px solid rgba(255,255,255,.16); padding-top:8px; }
  .stat-num{ font-size:88px; }
  .stat-label{ font-size:26px; max-width:420px; }

  .choice-cta h2{ font-size:56px; max-width:760px; margin-left:auto; margin-right:auto; }

  .about-hero p{ font-size:38px; max-width:1000px; }

  .vision-block{ grid-template-columns:1fr 1fr; text-align:left; }
  .vision-copy h2{ font-size:56px; }
  .vision-copy p{ font-size:18px; max-width:480px; }

  .mission-item{ grid-template-columns:110px 1fr; }
  .mission-num{ font-size:52px; }
  .mission-item p{ font-size:19px; }

  .catalog-carousel .container{ padding:0 48px; }
  .carousel-grid{ grid-template-columns:.85fr 1fr; }
  .carousel-copy h2{ font-size:58px; }
  .carousel-frame{ aspect-ratio:5/6; }

  .product-grid{ grid-template-columns:repeat(3,1fr); gap:26px; }
  .product-name{ font-size:22px; }

  .consult-grid{ display:grid; grid-template-columns:.95fr 1.25fr; gap:28px; align-items:start; }
  .panel{ padding:44px; }
  .budget-grid{ grid-template-columns:repeat(4,1fr); }

  .footer-grid{ grid-template-columns:auto 1fr 1.3fr; }
}

@media (min-width:1280px){
  .hero-title{ font-size:92px; }
}