/* =========================
   KAWAN100 — styles.css (full)
   ========================= */

:root{
  --bg:#0b0b0f;--panel:#12131a;--soft:#1a1c25;
  --brand:#f5c542;--brand-2:#f79d2d;
  --text:#f5f6f7;--muted:#b9bfcc;--accent:#ff4d4f;--ok:#20c997;
  --radius:18px;--shadow:0 10px 30px rgba(0,0,0,.35);
  --max:1200px;
}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,'Helvetica Neue',Arial,'Noto Sans',sans-serif;
  background:linear-gradient(180deg,#0b0b0f,#0d1017);
  color:var(--text)
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:100%;max-width:var(--max);margin-inline:auto;padding:0 16px}

/* Header */
header{
  position:sticky;top:0;z-index:60;
  background:rgba(11,11,15,.7);
  backdrop-filter:blur(8px);
  border-bottom:1px solid rgba(255,255,255,.06)
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:10px 0}
.brand{display:flex;align-items:center;gap:12px}
.brand-title{font-weight:800;letter-spacing:.5px}
.tag{
  padding:2px 8px;border-radius:999px;
  background:linear-gradient(90deg,var(--brand),var(--brand-2));
  color:#000;font-weight:700;font-size:.72rem
}
.logo{width:44px;height:44px;border-radius:12px;object-fit:cover;display:block}

/* Top nav (desktop) */
.menu{display:flex;gap:18px;align-items:center}
.menu a{opacity:.9}
.menu a:hover{opacity:1}
.cta{
  background:linear-gradient(90deg,var(--brand),var(--brand-2));
  color:#000;font-weight:800;border:none;padding:10px 16px;
  border-radius:12px;box-shadow:var(--shadow);cursor:pointer
}
.hamburger{display:none;background:none;border:none;font-size:26px;color:var(--text);line-height:1;padding:6px 10px;border-radius:10px}
.hamburger:active{transform:scale(.96)}

/* Hero */
.hero{position:relative;overflow:hidden}
.hero .wrap{
  display:grid;grid-template-columns:1.1fr .9fr;
  align-items:center;gap:30px;padding:48px 0
}
.pill{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08);
  padding:6px 10px;border-radius:999px;font-size:.86rem;color:var(--muted)
}
.hero h1{font-size:clamp(28px,4vw,48px);line-height:1.08;margin:14px 0}
.hero p{color:var(--muted);max-width:60ch}

/* Hero CTAs */
.hero-cta{display:flex;gap:12px;margin-top:16px;flex-wrap:wrap}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  border:1px solid rgba(255,255,255,.12);
  padding:12px 16px;border-radius:12px;color:var(--text)
}
.btn.primary{border:none;background:linear-gradient(90deg,var(--brand),var(--brand-2));color:#000;font-weight:800}
.btn.ghost{background:transparent}
.btn.link{border:none;padding:0}

/* Hero Auth buttons (Login / Daftar) */
.auth-cta{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap}
.btn.login{border-color:rgba(255,255,255,.18)}
.btn.login:hover{background:rgba(255,255,255,.06)}
.btn.signup{
  border:none;background:linear-gradient(90deg,var(--brand),var(--brand-2));
  color:#000;font-weight:900
}

/* Panels & sections */
.panel{
  background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius);box-shadow:var(--shadow)
}
section{padding:54px 0}
.section-head{display:flex;justify-content:space-between;align-items:end;gap:16px;margin-bottom:18px}
.section-head h2{margin:0;font-size:clamp(22px,2.6vw,32px)}
.section-head p{margin:0;color:var(--muted)}

/* Game grid */
.grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:16px}
@media (max-width:1100px){.grid{grid-template-columns:repeat(4,1fr)}}
@media (max-width:900px){.grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:600px){.grid{grid-template-columns:repeat(2,1fr)}}

.game-card{
  position:relative;background:var(--panel);
  border:1px solid rgba(255,255,255,.06);border-radius:16px;overflow:hidden;
  transition:transform .2s ease, box-shadow .2s ease
}
.game-card:hover{transform:translateY(-3px);box-shadow:0 12px 24px rgba(0,0,0,.35)}
.game-media{aspect-ratio:4/3;background:#0f1118;width:100%;height:auto}
.game-body{padding:12px}
.game-title{font-weight:700;margin:0 0 6px;font-size:1rem}
.game-cta{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-top:10px}
.game-cta .btn{padding:8px 10px;border-radius:10px}

/* Stars */
.stars{position:relative;display:inline-block;font-size:14px;line-height:1;color:#666}
.stars::before{content:'★★★★★';letter-spacing:2px;opacity:.35}
.stars-fill{position:absolute;left:0;top:0;white-space:nowrap;overflow:hidden;width:0}
.stars-fill::before{
  content:'★★★★★';letter-spacing:2px;
  background:linear-gradient(90deg,var(--brand),var(--brand-2));
  -webkit-background-clip:text;background-clip:text;color:transparent
}

/* Testimonials */
.testi{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media (max-width:900px){.testi{grid-template-columns:1fr}}
.testi-card{padding:18px}
.testi .who{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(90deg,#7f5cff,#2fb8ff)}
.badge-win{background:linear-gradient(90deg,#2af598,#009efd);color:#000;padding:4px 8px;border-radius:999px;font-size:.72rem;font-weight:800}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:16px}
@media (max-width:900px){.contact-grid{grid-template-columns:1fr}}
.map{min-height:280px;border:0;width:100%;border-radius:12px}

/* FAQ */
details{background:var(--panel);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:14px}
summary{cursor:pointer;font-weight:700}
details+details{margin-top:10px}

/* Footer */
footer{border-top:1px solid rgba(255,255,255,.06);padding:24px 0;color:var(--muted)}

/* Utilities */
.pill-k{background:linear-gradient(90deg,#ffd95a,#ffb84d);color:#000;padding:.2rem .5rem;border-radius:999px;font-weight:700;font-size:.72rem}
.muted{color:var(--muted)}
.mb8{margin-bottom:8px}
.mb16{margin-bottom:16px}
.mb24{margin-bottom:24px}

/* =========================
   Responsive / Mobile Nav
   ========================= */

/* default desktop looks (already set above) */

/* mobile: slide-in nav from right when .menu.open */
@media (max-width: 900px){
  .hamburger{display:inline-flex;align-items:center;justify-content:center}

  /* transform desktop row-menu into off-canvas panel */
  .menu{
    position:fixed;top:60px;right:-320px; /* hidden offscreen */
    height:calc(100vh - 60px);width:300px;z-index:100;
    display:flex;flex-direction:column;gap:12px;
    padding:16px;
    background:rgba(13,16,23,.98);
    border-left:1px solid rgba(255,255,255,.08);
    box-shadow:0 10px 30px rgba(0,0,0,.45);
    transition:right .25s ease;
  }
  .menu.open{right:0}

  .menu a{
    padding:10px 12px;border-radius:10px;
    border:1px solid rgba(255,255,255,.06);
    background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.01));
  }
  .menu .cta{width:100%}
}

/* Tiny screens: stack hero & tighten gaps */
@media (max-width:900px){
  .hero .wrap{grid-template-columns:1fr;gap:18px}
}
@media (max-width:600px){
  .hero h1{font-size:clamp(24px,6vw,34px)}
}