/*
Theme Name: Resvendor
Theme URI: https://www.resvendor.com
Author: Resvendor
Author URI: https://www.resvendor.com
Description: Tema bold/streetwear untuk brand konveksi & sablon Resvendor. Tanpa page builder, full custom.
Version: 1.3
License: GNU General Public License v2 or later
Text Domain: resvendor
*/

/* ============ TOKENS ============ */
:root{
  --ink:#0E0E0E;
  --paper:#F5F5F0;
  --acid:#E8FF3A;
  --burn:#FF5A1F;
  --concrete:#888888;
  --line:rgba(245,245,240,.14);
  --maxw:1240px;
  --font-display:"Archivo Black","Arial Black",sans-serif;
  --font-body:"Inter",system-ui,-apple-system,sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--ink);
  color:var(--paper);
  font-family:var(--font-body);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* ============ TYPE ============ */
.display{
  font-family:var(--font-display);
  text-transform:uppercase;
  line-height:.9;
  letter-spacing:-.02em;
}
.eyebrow{
  font-size:.72rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--acid);
  font-weight:700;
}

/* ============ HEADER ============ */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(14,14,14,.86);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{font-family:var(--font-display);font-size:1.5rem;text-transform:uppercase;letter-spacing:-.03em}
.brand span{color:var(--acid)}
.nav-menu{display:flex;gap:30px;list-style:none;align-items:center}
.nav-menu a{font-size:.82rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;transition:color .2s}
.nav-menu a:hover{color:var(--acid)}
.nav-cta{background:var(--acid);color:var(--ink)!important;padding:11px 20px;border-radius:2px;font-weight:800}
.nav-cta:hover{background:var(--burn);color:var(--paper)!important}
.burger{display:none;background:none;border:0;color:var(--paper);cursor:pointer;font-size:1.6rem}

/* ============ HERO ============ */
.hero{position:relative;padding:90px 0 70px;overflow:hidden}
.hero-grid-bg{
  position:absolute;inset:0;z-index:0;opacity:.5;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:64px 64px;
}
.hero .wrap{position:relative;z-index:2}
.hero-tag{display:inline-flex;gap:10px;align-items:center;border:1px solid var(--line);padding:8px 16px;border-radius:40px;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:28px}
.hero-tag .dot{width:8px;height:8px;background:var(--acid);border-radius:50%}
.hero-title{font-size:clamp(3rem,11vw,9rem);position:relative}
/* signature: misregistration print effect */
.hero-title .mis{position:relative;display:inline-block}
.hero-title .mis::before,.hero-title .mis::after{
  content:attr(data-t);position:absolute;top:0;left:0;width:100%;
}
.hero-title .mis::before{color:var(--burn);transform:translate(-5px,3px);opacity:.85;z-index:-1}
.hero-title .mis::after{color:var(--acid);transform:translate(5px,-3px);opacity:.85;z-index:-2}
.hero-sub{max-width:540px;margin:32px 0;color:#cfcfca;font-size:1.12rem}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.btn{display:inline-block;padding:15px 30px;border-radius:2px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;font-size:.86rem;transition:transform .15s,background .2s}
.btn-primary{background:var(--acid);color:var(--ink)}
.btn-primary:hover{background:var(--burn);color:var(--paper);transform:translateY(-2px)}
.btn-ghost{border:1px solid var(--paper);color:var(--paper)}
.btn-ghost:hover{background:var(--paper);color:var(--ink)}

/* marquee strip */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--acid);color:var(--ink);overflow:hidden;white-space:nowrap;padding:14px 0}
.marquee-track{display:inline-block;animation:scroll 22s linear infinite;font-family:var(--font-display);text-transform:uppercase;font-size:1.1rem;letter-spacing:.02em}
.marquee-track span{padding:0 26px}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============ SECTION ============ */
.section{padding:88px 0}
.section-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:54px;flex-wrap:wrap}
.section-title{font-size:clamp(2rem,5vw,3.4rem)}
.section-title em{color:var(--acid);font-style:normal}

/* products / services grid */
.grid{display:grid;gap:18px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}

/* layanan: 1 besar + 3 stack */
.grid-2-feature{display:grid;grid-template-columns:1.1fr 1fr;gap:18px;align-items:stretch}
.grid-stack{display:grid;gap:18px}
.card-feature{display:flex;flex-direction:column;justify-content:center;background:#161616;border-color:var(--acid)}
.card-feature h3{font-size:1.9rem;margin-bottom:14px}
.card-feature p{font-size:1.02rem}
.feature-tags{list-style:none;display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}
.feature-tags li{border:1px solid var(--acid);color:var(--acid);padding:7px 14px;border-radius:40px;font-size:.76rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.card-ink h3{color:var(--acid)}
.card{border:1px solid var(--line);padding:30px 26px;border-radius:4px;background:#141414;transition:border-color .2s,transform .2s}
.card:hover{border-color:var(--acid);transform:translateY(-4px)}
.card .num{font-family:var(--font-display);color:var(--concrete);font-size:1rem;margin-bottom:18px}
.card h3{font-family:var(--font-display);text-transform:uppercase;font-size:1.3rem;margin-bottom:10px;letter-spacing:-.01em}
.card p{color:#b8b8b3;font-size:.96rem}

/* price cards */
.price-card{border:1px solid var(--line);background:#141414;border-radius:4px;padding:34px 30px;position:relative;overflow:hidden}
.price-card.feat{border-color:var(--acid)}
.price-card.feat::after{content:"BEST SELLER";position:absolute;top:18px;right:-34px;background:var(--acid);color:var(--ink);font-family:var(--font-display);font-size:.66rem;padding:5px 40px;transform:rotate(45deg);letter-spacing:.1em}
.price-card h3{font-family:var(--font-display);text-transform:uppercase;font-size:1.4rem;margin-bottom:6px}
.price-card .matl{color:var(--concrete);font-size:.85rem;margin-bottom:22px}
.price-card .amt{font-family:var(--font-display);font-size:2.6rem;color:var(--acid);line-height:1}
.price-card .amt small{font-size:.9rem;color:var(--paper);font-family:var(--font-body);font-weight:400}
.price-card ul{list-style:none;margin:22px 0;display:flex;flex-direction:column;gap:10px}
.price-card li{font-size:.92rem;color:#c9c9c4;padding-left:24px;position:relative}
.price-card li::before{content:"";position:absolute;left:0;top:8px;width:11px;height:11px;background:var(--acid);clip-path:polygon(0 50%,40% 100%,100% 0,80% 0,40% 70%,15% 40%)}

/* gallery */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.gallery .g-item{aspect-ratio:1;background:#1a1a1a;border:1px solid var(--line);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.gallery .g-item span{font-family:var(--font-display);color:var(--concrete);font-size:.8rem;text-transform:uppercase}
.gallery .g-item:hover{border-color:var(--acid)}

/* testimonials */
.quote{border-left:3px solid var(--acid);padding:8px 0 8px 26px}
.quote p{font-size:1.18rem;margin-bottom:18px}
.quote .who{font-family:var(--font-display);text-transform:uppercase;font-size:.95rem}
.quote .role{color:var(--concrete);font-size:.82rem}

/* stats band */
.stats{background:var(--acid);color:var(--ink);padding:60px 0}
.stats .grid-4{gap:24px}
.stat .n{font-family:var(--font-display);font-size:clamp(2.6rem,6vw,4rem);line-height:1}
.stat .l{text-transform:uppercase;font-weight:700;font-size:.82rem;letter-spacing:.08em;margin-top:6px}

/* CTA band */
.cta-band{background:#141414;border-top:1px solid var(--line);border-bottom:1px solid var(--line);text-align:center;padding:90px 0}
.cta-band h2{font-family:var(--font-display);text-transform:uppercase;font-size:clamp(2.2rem,6vw,4.5rem);line-height:.92;margin-bottom:24px}
.cta-band p{color:#c9c9c4;max-width:520px;margin:0 auto 34px}

/* ============ PROMO COUNTDOWN ============ */
.promo-banner{
  display:flex;justify-content:space-between;align-items:center;gap:30px;flex-wrap:wrap;
  background:linear-gradient(100deg,#161616,#1d1d12);
  border:1px solid var(--acid);border-radius:6px;
  padding:28px 34px;margin-bottom:36px;position:relative;overflow:hidden;
}
.promo-banner::before{
  content:"";position:absolute;top:0;right:0;width:240px;height:100%;
  background:radial-gradient(circle at top right,rgba(232,255,58,.18),transparent 70%);
  pointer-events:none;
}
.promo-left{position:relative;z-index:1}
.promo-flash{
  display:inline-block;background:var(--burn);color:var(--paper);
  font-family:var(--font-display);font-size:.72rem;letter-spacing:.1em;
  padding:5px 12px;border-radius:3px;margin-bottom:12px;
  animation:flash 1.4s ease-in-out infinite;
}
@keyframes flash{0%,100%{opacity:1}50%{opacity:.55}}
.promo-headline{font-family:var(--font-display);text-transform:uppercase;font-size:1.5rem;line-height:1.05;margin-bottom:8px}
.promo-desc{color:#b8b8b3;font-size:.94rem;max-width:420px}
.promo-timer{display:flex;align-items:center;gap:10px;position:relative;z-index:1}
.timer-unit{display:flex;flex-direction:column;align-items:center;background:var(--ink);border:1px solid var(--line);border-radius:6px;padding:12px 14px;min-width:66px}
.t-num{font-family:var(--font-display);font-size:2rem;line-height:1;color:var(--acid)}
.t-lbl{font-size:.62rem;text-transform:uppercase;letter-spacing:.12em;color:var(--concrete);margin-top:6px}
.t-sep{font-family:var(--font-display);font-size:1.6rem;color:var(--acid)}

/* badge diskon + harga coret */
.price-card{position:relative}
.discount-badge{
  position:absolute;top:18px;left:18px;z-index:3;
  background:var(--burn);color:var(--paper);
  font-family:var(--font-display);font-size:.7rem;letter-spacing:.04em;
  padding:6px 11px;border-radius:3px;transform:rotate(-3deg);
  box-shadow:0 4px 12px rgba(255,90,31,.35);
}
.old-price{
  display:block;font-family:var(--font-body);font-weight:600;font-size:1rem;
  color:var(--concrete);text-decoration:line-through;margin-bottom:2px;
}
/* beri ruang di atas saat ada badge diskon */
.price-card:has(.discount-badge) h3{margin-top:34px}

/* ============ FAQ ============ */
.faq-list{max-width:820px}
.faq-item{border:1px solid var(--line);border-radius:4px;margin-bottom:12px;background:#141414;overflow:hidden}
.faq-item summary{
  cursor:pointer;padding:22px 26px;font-family:var(--font-display);
  text-transform:uppercase;font-size:1.02rem;letter-spacing:-.01em;
  list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";color:var(--acid);font-size:1.6rem;line-height:1;transition:transform .2s}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item[open] summary{border-bottom:1px solid var(--line)}
.faq-answer{padding:20px 26px;color:#c9c9c4}
.faq-answer p{margin:0}

/* ============ FOOTER ============ */
.site-footer{padding:70px 0 30px}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;margin-bottom:50px}
.foot-grid .brand{font-size:2rem;margin-bottom:16px;display:inline-block}
.foot-grid p{color:#b8b8b3;font-size:.95rem;max-width:340px}
.foot-col h4{text-transform:uppercase;font-size:.78rem;letter-spacing:.16em;color:var(--concrete);margin-bottom:18px}
.foot-col a{display:block;font-size:.95rem;margin-bottom:10px;color:#cfcfca}
.foot-col a:hover{color:var(--acid)}
.foot-bottom{border-top:1px solid var(--line);padding-top:24px;display:flex;justify-content:space-between;font-size:.82rem;color:var(--concrete);flex-wrap:wrap;gap:10px}

/* ============ FLOATING WA ============ */
.wa-float{position:fixed;bottom:24px;right:24px;z-index:200;background:#25D366;color:#fff;width:58px;height:58px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px rgba(0,0,0,.4);transition:transform .2s}
.wa-float:hover{transform:scale(1.08)}
.wa-float svg{width:30px;height:30px}

/* ============ PAGE / POST ============ */
.page-hero{padding:70px 0 40px;border-bottom:1px solid var(--line)}
.page-hero h1{font-family:var(--font-display);text-transform:uppercase;font-size:clamp(2.4rem,7vw,5rem);line-height:.92}
.content-area{padding:60px 0;max-width:760px;margin:0 auto}
.content-area h2{font-family:var(--font-display);text-transform:uppercase;margin:34px 0 14px;font-size:1.6rem}
.content-area p{margin-bottom:18px;color:#d6d6d1}
.content-area a{color:var(--acid);text-decoration:underline}

/* ============ RESPONSIVE ============ */
@media(max-width:980px){
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .grid-2-feature{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
}
@media(max-width:760px){
  .burger{display:block}
  .promo-banner{flex-direction:column;align-items:flex-start;padding:24px}
  .timer-unit{min-width:58px;padding:10px}
  .t-num{font-size:1.6rem}
  .nav-menu{position:fixed;top:74px;left:0;right:0;background:var(--ink);flex-direction:column;padding:30px 24px;gap:20px;border-bottom:1px solid var(--line);transform:translateY(-130%);transition:transform .3s;height:auto}
  .nav-menu.open{transform:translateY(0)}
  .grid-3,.grid-4,.gallery,.foot-grid{grid-template-columns:1fr}
  .section{padding:60px 0}
  .section-head{flex-direction:column;align-items:flex-start}
}
@media(prefers-reduced-motion:reduce){
  .marquee-track{animation:none}
  *{transition:none!important}
}
