/* ============ RORA SHOES — global styles ============ */
:root{
  --cream:#f3efe6;
  --cream-2:#e9e3d6;
  --ink:#14110d;
  --ink-soft:#5b554c;
  --accent:#ff4d2e;
  --line:rgba(20,17,13,.14);
  --line-light:rgba(243,239,230,.16);
  --ease:cubic-bezier(.16,1,.3,1);
  --font-display:'Archivo',sans-serif;
  --font-body:'Inter',sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-font-smoothing:antialiased;scroll-behavior:auto}
body{
  font-family:var(--font-body);
  background:var(--cream);
  color:var(--ink);
  overflow-x:hidden;
  cursor:none;
  font-size:16px;
  line-height:1.5;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:none}
em{font-style:normal;color:var(--accent)}
section{position:relative}
.lenis.lenis-smooth{scroll-behavior:auto!important}
::selection{background:var(--accent);color:#fff}

h1,h2,h3,h4,.display{font-family:var(--font-display);font-weight:900;letter-spacing:-.03em;line-height:.95}

/* ---------- PRELOADER ---------- */
.preloader{position:fixed;inset:0;z-index:9999;background:var(--ink);color:var(--cream);display:flex;flex-direction:column;align-items:center;justify-content:center}
.preloader__count{font-family:var(--font-body);font-size:14px;opacity:.55;position:absolute;top:6vh;right:6vw}
.preloader__word{display:flex;gap:.01em;font-family:var(--font-display);font-weight:900;font-size:clamp(60px,16vw,200px);line-height:.9;overflow:hidden}
.preloader__word span{display:inline-block;transform:translateY(110%)}
.preloader__bar{position:absolute;bottom:0;left:0;height:3px;width:100%;background:rgba(255,255,255,.12)}
.preloader__bar-fill{height:100%;width:0;background:var(--accent)}

/* ---------- CURSOR ---------- */
.cursor{position:fixed;top:0;left:0;width:12px;height:12px;border-radius:50%;background:var(--accent);pointer-events:none;z-index:9000;transform:translate(-50%,-50%);mix-blend-mode:difference;transition:width .3s var(--ease),height .3s var(--ease)}
.cursor.is-hover{width:60px;height:60px;background:#fff}
@media(hover:none){.cursor{display:none}body{cursor:auto}button,a{cursor:pointer}}

/* ---------- PROGRESS ---------- */
.scroll-progress{position:fixed;top:0;left:0;height:3px;width:0;background:var(--accent);z-index:8000}

/* ---------- NAV ---------- */
.nav{position:fixed;top:0;left:0;width:100%;z-index:5000;display:flex;align-items:center;justify-content:space-between;padding:20px clamp(20px,4vw,56px);mix-blend-mode:difference;color:#fff;transition:transform .5s var(--ease)}
.nav.hide{transform:translateY(-110%)}
.nav__logo{font-family:var(--font-display);font-weight:900;font-size:24px;letter-spacing:-.02em}
.nav__logo span{font-size:11px;vertical-align:super;color:var(--accent)}
.nav__menu{display:flex;gap:30px;font-size:14px;font-weight:500}
.nav__menu a{position:relative}
.nav__menu a::after{content:'';position:absolute;left:0;bottom:-4px;width:0;height:1px;background:currentColor;transition:width .4s var(--ease)}
.nav__menu a:hover::after,.nav__menu a.active::after{width:100%}
.nav__cta{border:1px solid currentColor;border-radius:40px;padding:9px 20px;font-size:13px;font-weight:600}
.nav__burger{display:none;flex-direction:column;gap:5px;width:28px;background:none;border:none}
.nav__burger span{height:2px;width:100%;background:currentColor;transition:transform .4s var(--ease),opacity .3s}
.nav__burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__burger.open span:nth-child(2){opacity:0}
.nav__burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
/* mobile drawer */
.mobile-menu{position:fixed;inset:0;z-index:4900;background:var(--ink);color:var(--cream);display:flex;flex-direction:column;justify-content:center;padding:0 8vw;transform:translateY(-100%);transition:transform .7s var(--ease)}
.mobile-menu.open{transform:translateY(0)}
.mobile-menu a{font-family:var(--font-display);font-weight:800;font-size:clamp(34px,9vw,64px);padding:10px 0;border-bottom:1px solid var(--line-light)}
.mobile-menu a em{color:var(--accent)}
@media(max-width:860px){.nav__menu,.nav__cta{display:none}.nav__burger{display:flex}}

/* ---------- BUTTONS ---------- */
.btn{display:inline-block;background:var(--accent);color:#fff;padding:16px 34px;border-radius:50px;font-weight:600;font-size:15px;overflow:hidden;position:relative;border:none}
.btn span{position:relative;z-index:2}
.btn::before{content:'';position:absolute;inset:0;background:var(--ink);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease);z-index:1}
.btn:hover::before{transform:scaleX(1)}
.btn--ghost{background:transparent;color:var(--ink);border:1px solid var(--ink)}
.btn--ghost::before{background:var(--ink)}
.btn--ghost:hover{color:var(--cream)}

/* ---------- HERO (home) ---------- */
.hero{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:14vh 20px 0;overflow:hidden}
.hero__bg-word{position:absolute;top:46%;left:50%;transform:translate(-50%,-50%);font-family:var(--font-display);font-weight:900;font-size:40vw;color:var(--ink);opacity:.045;white-space:nowrap;pointer-events:none;z-index:0}
.hero__tagline{display:flex;gap:14px;justify-content:center;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:22px}
.hero__title{font-size:clamp(46px,9.2vw,150px);text-align:center;position:relative;z-index:3}
.hero__title .line{display:block;overflow:hidden}
.hero__title .line span{display:block;transform:translateY(110%)}
.hero__sub{max-width:440px;margin:26px auto 0;color:var(--ink-soft);font-size:clamp(15px,1.4vw,18px);text-align:center;position:relative;z-index:3}
.hero__media{position:relative;z-index:2;width:min(92vw,1040px);margin:40px auto 0;border-radius:24px;overflow:hidden;aspect-ratio:16/9}
.hero__media img{width:100%;height:120%;object-fit:cover;transform:translateY(-8%)}
.hero__tag{position:absolute;bottom:18px;left:18px;z-index:4;background:rgba(20,17,13,.6);backdrop-filter:blur(8px);color:#fff;padding:10px 16px;border-radius:30px;font-size:13px;font-weight:500}
.hero__tag b{color:var(--accent)}
.hero__scroll{display:inline-flex;flex-direction:column;align-items:center;gap:8px;margin:26px auto 30px;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft)}
.arrow-down{width:1px;height:32px;background:var(--ink-soft);animation:scrollPulse 1.8s var(--ease) infinite}
@keyframes scrollPulse{0%{transform:scaleY(.2);transform-origin:top;opacity:0}50%{transform:scaleY(1);opacity:1}100%{transform:scaleY(.2);transform-origin:bottom;opacity:0}}

/* ---------- MARQUEE ---------- */
.marquee-wrap{overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:14px 0}
.marquee{display:flex;white-space:nowrap;font-family:var(--font-display);font-weight:800;font-size:15px;letter-spacing:.02em;will-change:transform}
.bigmarquee{padding:7vh 0;overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.marquee--big{font-size:clamp(40px,9vw,130px);letter-spacing:-.02em}
.bigmarquee em{color:var(--accent)}

/* ---------- STATEMENT ---------- */
.statement{padding:16vh clamp(20px,6vw,120px);max-width:1500px;margin:0 auto}
.statement__text{font-family:var(--font-display);font-weight:800;font-size:clamp(28px,5vw,78px);line-height:1.12;letter-spacing:-.02em}
.statement .word{display:inline-block;opacity:.13;transition:opacity .3s}
.statement .word.accent{color:var(--accent)}

/* ---------- COLLECTION (horizontal) ---------- */
.collection{background:var(--ink);color:var(--cream)}
.collection__pin{height:100vh;overflow:hidden;display:flex;align-items:center}
.collection__track{display:flex;gap:3vw;padding:0 6vw;will-change:transform}
.panel{flex:0 0 auto}
.collection__intro{width:46vw;max-width:520px;display:flex;flex-direction:column;justify-content:center}
.collection__heading{font-size:clamp(48px,7vw,104px)}
.collection__intro p{margin-top:22px;color:rgba(243,239,230,.5);font-size:15px;letter-spacing:.04em}
.card{width:clamp(290px,30vw,400px)}
.card__media{height:clamp(360px,50vh,520px);border-radius:16px;position:relative;overflow:hidden;background:var(--cream-2)}
.card__media img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.card:hover .card__media img{transform:scale(1.06)}
.card__num{position:absolute;top:18px;left:20px;font-family:var(--font-display);font-weight:900;font-size:30px;color:#fff;mix-blend-mode:difference}
.card__info{margin-top:18px;display:flex;justify-content:space-between;align-items:baseline}
.card__info h3{font-size:24px;font-weight:800}
.card__info p{color:rgba(243,239,230,.55);font-size:14px}

/* ---------- TECH ---------- */
.tech{display:flex;align-items:flex-start;padding:0 clamp(20px,5vw,90px);gap:6vw}
.tech__sticky{position:sticky;top:0;height:100vh;flex:1;display:flex;align-items:center;justify-content:center}
.tech__visual{position:relative;width:100%;max-width:540px;aspect-ratio:1;border-radius:24px;overflow:hidden;background:var(--ink)}
.tech__visual img{width:100%;height:100%;object-fit:cover}
.tech__steps{flex:1;padding:18vh 0}
.tech__step{min-height:60vh;display:flex;flex-direction:column;justify-content:center;opacity:.2;transition:opacity .5s var(--ease)}
.tech__step.is-active{opacity:1}
.tech__index{font-size:13px;letter-spacing:.06em;color:var(--accent);text-transform:uppercase;font-weight:600}
.tech__step h3{font-size:clamp(30px,4.2vw,60px);margin:14px 0 16px}
.tech__step p{max-width:440px;color:var(--ink-soft);font-size:clamp(15px,1.4vw,19px)}
@media(max-width:860px){.tech{flex-direction:column}.tech__sticky{height:56vh;width:100%}}

/* ---------- COLORS ---------- */
.colors{padding:14vh clamp(20px,5vw,90px);text-align:center;overflow:hidden}
.colors__head h2{font-size:clamp(38px,6vw,88px)}
.colors__head p{color:var(--ink-soft);margin-top:14px}
.colors__stage{position:relative;width:min(92vw,860px);height:48vh;min-height:340px;margin:30px auto 0;border-radius:24px;overflow:hidden;background:var(--cream-2)}
.colors__img{position:absolute;inset:0;opacity:0;transition:opacity .6s var(--ease)}
.colors__img img{width:100%;height:100%;object-fit:cover}
.colors__img.is-active{opacity:1}
.colors__name{margin-top:26px;font-family:var(--font-display);font-weight:900;font-size:clamp(28px,4vw,52px)}
.colors__swatches{display:flex;gap:16px;justify-content:center;margin-top:20px}
.swatch{width:44px;height:44px;border-radius:50%;background:var(--c);border:2px solid transparent;position:relative;transition:transform .3s var(--ease)}
.swatch::after{content:'';position:absolute;inset:-7px;border:1px solid var(--ink);border-radius:50%;opacity:0;transition:opacity .3s}
.swatch:hover{transform:scale(1.12)}
.swatch.is-active::after{opacity:1}

/* ---------- STATS ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;padding:11vh clamp(20px,5vw,90px);border-top:1px solid var(--line)}
.stat{text-align:center}
.stat__num,.stat__unit{font-family:var(--font-display);font-weight:900;font-size:clamp(44px,7vw,92px);letter-spacing:-.03em;line-height:1}
.stat__unit{color:var(--accent)}
.stat p{color:var(--ink-soft);margin-top:10px;font-size:14px}
@media(max-width:760px){.stats{grid-template-columns:repeat(2,1fr);gap:40px 20px}}

/* ---------- CTA ---------- */
.cta{padding:18vh clamp(20px,5vw,90px);text-align:center;background:var(--ink);color:var(--cream)}
.cta__title{font-size:clamp(54px,12vw,170px)}
.cta p{color:rgba(243,239,230,.6);margin:24px auto 0;max-width:440px;font-size:17px}
.cta .btn{margin-top:38px}
.cta__form{display:flex;gap:10px;max-width:480px;margin:42px auto 0;border-bottom:1px solid rgba(243,239,230,.3);padding-bottom:10px}
.cta__form input{flex:1;background:none;border:none;color:var(--cream);font-size:16px;outline:none;font-family:inherit}
.cta__form input::placeholder{color:rgba(243,239,230,.4)}
.cta__form button{background:none;border:none;color:var(--accent);font-weight:700;font-size:16px}

/* ---------- FOOTER ---------- */
.footer{padding:8vh clamp(20px,5vw,90px) 30px;background:var(--ink);color:var(--cream);border-top:1px solid var(--line-light)}
.footer__top{display:flex;justify-content:space-between;flex-wrap:wrap;gap:40px;padding-bottom:7vh}
.footer__brand{font-family:var(--font-display);font-weight:900;font-size:clamp(60px,12vw,150px);line-height:.85}
.footer__brand span{font-size:.2em;vertical-align:super;color:var(--accent)}
.footer__cols{display:flex;gap:56px}
.footer__cols h4{font-size:13px;text-transform:uppercase;letter-spacing:.06em;color:rgba(243,239,230,.4);margin-bottom:16px;font-weight:600}
.footer__cols a{display:block;margin-bottom:10px;font-size:15px;opacity:.85;transition:opacity .3s,color .3s}
.footer__cols a:hover{opacity:1;color:var(--accent)}
.footer__bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;padding-top:24px;border-top:1px solid var(--line-light);font-size:13px;color:rgba(243,239,230,.5)}

/* ---------- PAGE HEADER (subpages) ---------- */
.pagehead{padding:24vh clamp(20px,5vw,90px) 8vh;position:relative;overflow:hidden}
.pagehead__eyebrow{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);font-weight:600;margin-bottom:18px}
.pagehead__title{font-size:clamp(54px,11vw,170px)}
.pagehead__title .line{display:block;overflow:hidden}
.pagehead__title .line span{display:block;transform:translateY(110%)}
.pagehead p{max-width:520px;margin-top:24px;color:var(--ink-soft);font-size:clamp(16px,1.5vw,20px)}
.pagehead__bgword{position:absolute;right:-2vw;bottom:-4vh;font-family:var(--font-display);font-weight:900;font-size:28vw;color:var(--ink);opacity:.04;pointer-events:none}

/* ---------- SHOP GRID ---------- */
.shop{padding:4vh clamp(20px,5vw,90px) 14vh}
.shop__filters{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:46px}
.chip{padding:9px 20px;border:1px solid var(--line);border-radius:40px;font-size:14px;font-weight:500;background:none;transition:background .3s,color .3s,border-color .3s}
.chip.active,.chip:hover{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.shop__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
@media(max-width:900px){.shop__grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.shop__grid{grid-template-columns:1fr}}
.product{display:block}
.product__media{border-radius:16px;overflow:hidden;aspect-ratio:4/5;position:relative;background:var(--cream-2)}
.product__media img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.product:hover .product__media img{transform:scale(1.06)}
.product__badge{position:absolute;top:14px;left:14px;background:var(--accent);color:#fff;font-size:11px;font-weight:600;padding:6px 12px;border-radius:30px;text-transform:uppercase;letter-spacing:.04em}
.product__info{display:flex;justify-content:space-between;align-items:baseline;margin-top:16px}
.product__info h3{font-size:22px;font-weight:800}
.product__cat{color:var(--ink-soft);font-size:13px;margin-top:2px}
.product__price{font-weight:700;font-size:16px}

/* ---------- PRODUCT DETAIL ---------- */
.pdp{display:grid;grid-template-columns:1.1fr 1fr;gap:6vw;padding:18vh clamp(20px,5vw,90px) 12vh;align-items:start}
@media(max-width:900px){.pdp{grid-template-columns:1fr;gap:34px}.pdp .pdp__gallery{position:static}.pdp .pdp__main{aspect-ratio:4/3}}
.pdp__gallery{position:sticky;top:12vh}
.pdp__main{border-radius:20px;overflow:hidden;aspect-ratio:1;background:var(--cream-2)}
.pdp__main img{width:100%;height:100%;object-fit:cover}
.pdp__thumbs{display:flex;gap:14px;margin-top:14px}
.pdp__thumb{width:90px;height:90px;border-radius:12px;overflow:hidden;border:2px solid transparent;background:var(--cream-2)}
.pdp__thumb.active{border-color:var(--accent)}
.pdp__thumb img{width:100%;height:100%;object-fit:cover}
.pdp__eyebrow{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);font-weight:600}
.pdp__title{font-size:clamp(40px,6vw,76px);margin:14px 0 12px}
.pdp__price{font-size:26px;font-weight:700;margin-bottom:24px}
.pdp__desc{color:var(--ink-soft);font-size:17px;margin-bottom:30px;max-width:460px}
.pdp__label{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;margin-bottom:12px}
.pdp__opts{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:28px}
.size{min-width:50px;padding:12px 14px;border:1px solid var(--line);border-radius:10px;font-weight:600;font-size:15px;background:none;transition:.3s}
.size.active,.size:hover{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.pdp__buy{display:flex;gap:14px;flex-wrap:wrap;margin-top:8px}
.pdp__features{list-style:none;margin-top:40px;border-top:1px solid var(--line);padding-top:24px}
.pdp__features li{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--line);font-size:15px}
.pdp__features span:first-child{color:var(--ink-soft)}

/* ---------- ABOUT ---------- */
.about-intro{padding:8vh clamp(20px,5vw,90px);max-width:1100px}
.about-intro p{font-family:var(--font-display);font-weight:700;font-size:clamp(24px,3.6vw,48px);line-height:1.2;letter-spacing:-.02em}
.about-img{width:100%;aspect-ratio:21/9;border-radius:24px;overflow:hidden;margin:6vh 0;background:var(--cream-2)}
.about-img img{width:100%;height:100%;object-fit:cover}
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;padding:6vh clamp(20px,5vw,90px) 14vh}
@media(max-width:800px){.values{grid-template-columns:1fr}}
.value{padding:34px;border:1px solid var(--line);border-radius:18px}
.value__num{font-family:var(--font-display);font-weight:900;font-size:40px;color:var(--accent)}
.value h3{font-size:24px;margin:14px 0 12px;font-weight:800}
.value p{color:var(--ink-soft);font-size:15px}
.timeline{padding:0 clamp(20px,5vw,90px) 14vh;max-width:900px}
.tl-item{display:grid;grid-template-columns:120px 1fr;gap:30px;padding:34px 0;border-top:1px solid var(--line)}
.tl-item .yr{font-family:var(--font-display);font-weight:900;font-size:28px;color:var(--accent)}
.tl-item h3{font-size:22px;font-weight:800;margin-bottom:8px}
.tl-item p{color:var(--ink-soft);font-size:15px}

/* ---------- CONTACT ---------- */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:6vw;padding:4vh clamp(20px,5vw,90px) 14vh}
@media(max-width:800px){.contact{grid-template-columns:1fr;gap:40px}}
.contact__info h2{font-size:clamp(32px,4vw,52px);margin-bottom:24px}
.contact__row{padding:22px 0;border-top:1px solid var(--line)}
.contact__row span{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft)}
.contact__row p{font-size:20px;font-weight:600;margin-top:6px}
.form{display:flex;flex-direction:column;gap:18px}
.field label{display:block;font-size:13px;font-weight:600;margin-bottom:8px;text-transform:uppercase;letter-spacing:.04em}
.field input,.field textarea{width:100%;background:var(--cream-2);border:1px solid transparent;border-radius:12px;padding:16px;font-family:inherit;font-size:15px;outline:none;transition:border-color .3s}
.field input:focus,.field textarea:focus{border-color:var(--accent)}
.field textarea{min-height:140px;resize:vertical}
.faq{padding:0 clamp(20px,5vw,90px) 14vh;max-width:860px}
.faq h2{font-size:clamp(30px,4vw,52px);margin-bottom:30px}
.faq__item{border-top:1px solid var(--line);padding:24px 0;cursor:none}
.faq__q{display:flex;justify-content:space-between;align-items:center;font-size:19px;font-weight:600}
.faq__q i{font-style:normal;color:var(--accent);font-size:24px;transition:transform .4s var(--ease)}
.faq__item.open .faq__q i{transform:rotate(45deg)}
.faq__a{max-height:0;overflow:hidden;transition:max-height .5s var(--ease);color:var(--ink-soft);font-size:15px}
.faq__a p{padding-top:16px}

/* ---------- VIDEO ---------- */
.hero__media video,.tech__visual video,.pdp__main video{width:100%;height:100%;object-fit:cover;display:block}

/* ---------- SCROLL THREAD (garis mengalir) ---------- */
.thread{position:fixed;top:0;left:16px;width:2px;height:100vh;z-index:1500;pointer-events:none}
.thread__track{position:absolute;inset:0;background:var(--line)}
.thread__fill{position:absolute;top:0;left:0;width:100%;height:0;background:var(--accent)}
.thread__dot{position:absolute;left:50%;top:0;width:9px;height:9px;margin:-4px 0 0 -4px;border-radius:50%;background:var(--accent);box-shadow:0 0 14px var(--accent)}
@media(max-width:700px){.thread{display:none}}

/* ---------- FLOW LINE (garis lengkung saat scroll) ---------- */
.flowline{position:absolute;left:0;width:100%;height:100%;pointer-events:none;z-index:0;overflow:visible}
.flowline path{fill:none;stroke:var(--accent);stroke-width:2;opacity:.4}

/* ---------- HEADING REVEAL ---------- */
.reveal-clip{overflow:hidden}
.reveal-clip>.reveal-inner{display:block;transform:translateY(110%)}

/* ---------- HOVER MOTION ---------- */
.btn,.nav__cta{will-change:transform}
.nav__menu a{display:inline-block;transition:transform .3s var(--ease)}
.nav__menu a:hover{transform:translateY(-3px)}
.footer__cols a{transition:transform .3s var(--ease),color .3s,opacity .3s}
.footer__cols a:hover{transform:translateX(6px)}

/* ---------- REVEAL ---------- */
.reveal-up{opacity:0;transform:translateY(40px)}

@media(max-width:600px){
  .footer__cols{gap:30px;flex-wrap:wrap}
  .statement{padding:12vh 20px}
  .pdp__gallery{position:static}
}
