/* ===== Tokens — neobrutalism.dev ===== */
:root{
  --background:#d9f0ff;
  --secondary-background:#ffffff;
  --foreground:#000000;
  --border:#000000;
  --main:#00aaff;
  --main-foreground:#000000;
  --overlay:rgba(0,0,0,.8);

  --chart-blue:#5294ff;
  --chart-red:#ff4d50;
  --chart-yellow:#facc00;
  --chart-green:#05e17a;
  --chart-purple:#7a83ff;

  --radius-base:0px;
  --shadow-x:2px;
  --shadow-y:2px;
  --shadow:var(--shadow-x) var(--shadow-y) 0px 0px var(--border);
  --shadow-sm:1px 1px 0px 0px var(--border);

  --font-base:'DM Sans', sans-serif;
  --fw-base:500;
  --fw-heading:900;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;scroll-padding-top:90px;}
body{
  margin:0;
  background-color:var(--background);
  background-image:
    linear-gradient(to right, rgba(128,128,128,.25) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(128,128,128,.25) 1px, transparent 1px);
  background-size:48px 48px;
  color:var(--foreground);
  font-family:var(--font-base);
  font-weight:var(--fw-base);
  line-height:1.5;
}
img{max-width:100%;display:block;}
a{color:inherit;}
.wrap{max-width:1120px;margin:0 auto;padding:0 28px;}

:focus-visible{outline:3px solid var(--foreground);outline-offset:2px;}

@media (prefers-reduced-motion: reduce){
  *{animation:none !important;transition:none !important;}
}

.eyebrow{
  display:inline-block;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.06em;
  font-size:.78rem;
  background:var(--chart-yellow);
  border:2px solid var(--border);
  border-radius:var(--radius-base);
  padding:4px 10px;
  margin:0 0 14px;
}

h1,h2,h3{font-family:var(--font-base);font-weight:var(--fw-heading);line-height:1.08;margin:0;}
h1{font-size:clamp(2.3rem,4.3vw,3.5rem);}
h2{font-size:clamp(1.7rem,3vw,2.3rem);margin-bottom:34px;}
h3{font-size:1.05rem;}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:13px 22px;
  border-radius:var(--radius-base);
  font-weight:700;
  font-size:.95rem;
  text-decoration:none;
  border:2px solid var(--border);
  background:var(--secondary-background);
  color:var(--foreground);
  box-shadow:var(--shadow);
  transition:transform .1s ease, box-shadow .1s ease;
}
.btn:hover{transform:translate(1px,1px);box-shadow:var(--shadow-sm);}
.btn:active{transform:translate(2px,2px);box-shadow:0 0 0 0 var(--border);}
.btn-primary{background:var(--main);color:var(--main-foreground);}
.btn-line{background:var(--secondary-background);}
.btn-ghost{padding:10px 18px;font-size:.88rem;}
.btn-card{width:100%;justify-content:center;background:var(--chart-yellow);margin-top:auto;}

/* ===== Header ===== */
.site-header{
  position:sticky;top:0;z-index:20;
  background:var(--background);
  border-bottom:2px solid var(--border);
}
.header-row{display:flex;align-items:center;justify-content:space-between;padding-top:16px;padding-bottom:16px;gap:24px;}
.logo{
  display:flex;align-items:stretch;text-decoration:none;
  box-shadow:var(--shadow);
  border-radius:var(--radius-base);
}
.logo-btn{
  display:inline-flex;align-items:center;
  border:2px solid var(--border);
}
.logo-btn-icon{
  background:var(--chart-yellow);
  width:42px;justify-content:center;
  padding:7px;
  border-right:none;
  border-radius:var(--radius-base) 0 0 var(--radius-base);
}
.logo-btn-icon img{width:100%;height:100%;object-fit:contain;}
.logo-btn-text{
  background:#ffffff;
  color:#000000;
  padding:6px 14px;
  border-radius:0 var(--radius-base) var(--radius-base) 0;
  flex-direction:column;
  justify-content:center;
  font-size:.7rem;font-weight:700;line-height:1.3;letter-spacing:.02em;
}
.logo-name{display:block;color:#000000;}
.logo-sub{display:block;color:var(--main);}
.logo-footer{display:inline-flex;}
.main-nav{display:flex;gap:28px;font-size:.92rem;font-weight:700;}
.main-nav a{text-decoration:none;border-bottom:2px solid transparent;padding-bottom:4px;}
.main-nav a:hover{border-color:var(--foreground);}

/* ===== Hero ===== */
.hero{padding:64px 0 70px;}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:54px;align-items:center;}
.hero-lead{max-width:480px;font-size:1.05rem;margin:18px 0 28px;}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:38px;}
.hero-stats{display:flex;gap:34px;flex-wrap:wrap;}
.hero-stats div{display:flex;flex-direction:column;}
.hero-stats strong{font-size:1.25rem;font-weight:700;}
.hero-stats span{font-size:.74rem;text-transform:uppercase;letter-spacing:.04em;font-weight:500;}

.ticket{
  background:var(--secondary-background);
  border:2px solid var(--border);
  border-radius:var(--radius-base);
  padding:26px 24px;
  position:relative;
  box-shadow:4px 4px 0px 0px var(--border);
  transform:rotate(-1.4deg);
}
.ticket-top{
  display:flex;justify-content:space-between;
  font-size:.72rem;font-weight:700;letter-spacing:.04em;
  text-transform:uppercase;
  border-bottom:2px dashed var(--border);padding-bottom:14px;margin-bottom:16px;
}
.ticket-stamp{
  font-size:2.6rem;font-weight:700;color:var(--foreground);
  background:var(--chart-green);
  border:3px solid var(--border);
  width:74px;height:74px;border-radius:var(--radius-base);
  display:flex;align-items:center;justify-content:center;
  transform:rotate(10deg);
  position:absolute;top:-16px;right:-14px;
  box-shadow:var(--shadow-sm);
}
.ticket-checks{list-style:none;margin:0;padding:0;font-size:.92rem;font-weight:500;}
.ticket-checks li{padding:7px 0;border-bottom:1px solid #00000022;}
.ticket-checks li::before{content:"✓ ";color:#04a85c;font-weight:700;}
.ticket-foot{margin-top:14px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;}

/* ===== Grade section ===== */
.grade{
  padding:60px 0;
  background-color:var(--main);
  background-image:
    linear-gradient(to right, rgba(0,0,0,.2) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(0,0,0,.2) 1px, transparent 1px);
  background-size:48px 48px;
  border-top:2px solid var(--border);border-bottom:2px solid var(--border);
}
.grade .eyebrow{background:var(--secondary-background);}
.grade h2{max-width:560px;}
.grade-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.grade-card{
  background:var(--secondary-background);
  border:2px solid var(--border);
  border-radius:var(--radius-base);
  box-shadow:var(--shadow);
  padding:26px 22px;
}
.grade-letter{
  font-size:2.4rem;font-weight:700;
  display:inline-flex;align-items:center;justify-content:center;
  width:54px;height:54px;
  background:var(--chart-yellow);
  border:2px solid var(--border);border-radius:var(--radius-base);
  margin-bottom:14px;
}
.grade-card h3{margin-bottom:8px;}
.grade-card p{font-size:.92rem;margin:0;}

/* ===== Catalog ===== */
.catalog{padding:70px 0;}
.catalog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.card{
  background:var(--secondary-background);
  border:2px solid var(--border);
  border-radius:var(--radius-base);
  box-shadow:var(--shadow);
  overflow:hidden;
  display:flex;
  flex-direction:column;
}
.card-media{
  background:var(--tint,var(--background));
  aspect-ratio:1/1;position:relative;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
  border-bottom:2px solid var(--border);
}
.card-media img{
  width:100%;height:100%;object-fit:cover;object-position:center;
}
.grade-badge{
  position:absolute;top:10px;right:10px;
  font-weight:700;font-size:.72rem;
  padding:4px 10px;border:2px solid var(--border);border-radius:var(--radius-base);
  background:var(--secondary-background);color:var(--foreground);
  box-shadow:var(--shadow-sm);
}
.grade-badge.grade-a{background:var(--chart-green);}
.grade-badge.grade-b{background:var(--chart-yellow);}
.grade-badge.grade-acc{background:var(--chart-purple);color:#fff;}
.card-body{padding:20px 20px 22px;display:flex;flex-direction:column;flex:1;}
.card-body h3{font-size:1rem;margin-bottom:8px;}
.specs{font-size:.78rem;font-weight:500;margin:0 0 12px;}
.price-now{font-weight:700;font-size:1.1rem;margin-right:8px;}
.price-old{font-size:.82rem;font-weight:500;color:#00000066;text-decoration:line-through;}

/* ===== Cara Beli ===== */
.cara-beli{padding:70px 0 80px;}
.steps{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(3,1fr);gap:26px;}
.steps li{
  background:var(--secondary-background);
  border:2px solid var(--border);border-radius:var(--radius-base);
  box-shadow:var(--shadow);
  padding:22px 20px;
}
.step-no{
  display:inline-flex;align-items:center;justify-content:center;
  width:32px;height:32px;
  background:var(--chart-red);color:#fff;font-weight:700;font-size:.85rem;
  border:2px solid var(--border);border-radius:var(--radius-base);
  margin-bottom:12px;
}
.steps h3{margin-bottom:8px;}
.steps li{margin-bottom:36px;}
.steps p{font-size:.94rem;margin:0;}

/* ===== Footer ===== */
.site-footer{background:var(--foreground);color:#fff;padding:56px 0 0;margin-top:20px;border-top:2px solid var(--border);}
.footer-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:34px;padding-bottom:40px;border-bottom:2px solid #ffffff33;}
.footer-tagline{font-size:.92rem;margin-top:14px;max-width:240px;}
.footer-col h4{font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;font-weight:700;color:var(--chart-yellow);margin:0 0 12px;}
.footer-col p{margin:0 0 8px;font-size:.9rem;}
.footer-col a{text-decoration:none;}
.footer-col a:hover{color:var(--chart-yellow);}
.footer-bottom{padding:18px 0 24px;font-size:.74rem;color:#ffffff99;}

/* ===== Responsive ===== */
@media (max-width:900px){
  .hero-grid{grid-template-columns:1fr;}
  .hero-ticket{order:-1;max-width:340px;}
  .grade-grid, .catalog-grid, .steps, .footer-grid{grid-template-columns:repeat(2,1fr);}
  .footer-grid{grid-template-columns:1fr;}
}
@media (max-width:640px){
  .main-nav{display:none;}
  .grade-grid, .catalog-grid, .steps{grid-template-columns:1fr;}
}
