/* =========================================================
   THEME VARIABLES (DARK / LIGHT)
   ========================================================= */

   /* Color Options (Warna Bahan) */
.color-options{
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
  gap:16px;
  margin-top:24px;
}

.color-item{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid var(--line);
  background:var(--card);
}

.color-item span{
  width:28px;
  height:28px;
  border-radius:50%;
  background:var(--c);
  display:inline-block;
  border:1px solid rgba(0,0,0,.15);
}

.color-item span.border{
  border:1px solid #999; /* khusus putih agar terlihat */
}

.color-item small{
  font-weight:700;
  font-size:12.5px;
  color:var(--text);
}

   /* Additional images – diperkecil dan lebih proporsional */
.additional-images{
  display:flex;
  gap:24px;
  flex-wrap:wrap;
  align-items:flex-start;
}

.additional-item{
  margin:0;
  border:1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  padding: 12px;
  box-shadow: var(--shadow);

  /* batasi lebar card */
  max-width: 520px;   /* ubah ke 480 / 420 jika mau lebih kecil */
}

.additional-img{
  display:block;
  width:100%;
  height:auto;
  border-radius: 12px;
}

:root{
  --bg:#0b1220;
  --soft:#0b162a;
  --card:#0f1a2e;

  --text:#e9eefc;
  --muted:rgba(233,238,252,.72);
  --line:rgba(233,238,252,.12);

  --header-bg: rgba(11,18,32,.72);
  --chip-bg: rgba(255,255,255,.06);
  --chip-bg-hover: rgba(255,255,255,.08);

  --brand:#21c6b7;
  --brand2:#2a7cff;

  --radius:18px;
  --r2:14px;
  --shadow:0 14px 40px rgba(0,0,0,.28);
  --container:1120px;
}

/* LIGHT MODE OVERRIDE */
html[data-theme="light"]{
  --bg:#f6f8fc;
  --soft:#ffffff;
  --card:#ffffff;

  --text:#0b1220;
  --muted:rgba(11,18,32,.7);
  --line:rgba(11,18,32,.12);

  --header-bg: rgba(255,255,255,.75);
  --chip-bg: rgba(11,18,32,.06);
  --chip-bg-hover: rgba(11,18,32,.1);

  --shadow:0 14px 40px rgba(11,18,32,.12);
}

/* =========================================================
   BASE
   ========================================================= */
*{box-sizing:border-box}
html,body{margin:0;padding:0}

body{
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  background:
    radial-gradient(1200px 600px at 20% -10%, rgba(42,124,255,.18), transparent 60%),
    radial-gradient(900px 500px at 85% 10%, rgba(33,198,183,.16), transparent 55%),
    var(--bg);
  color:var(--text);
  line-height:1.6;
}

img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
.container{
  width:min(var(--container), calc(100% - 40px));
  margin:auto;
}
.muted{color:var(--muted)}

/* =========================================================
   HEADER
   ========================================================= */
.header{
  position:sticky;
  top:0;
  z-index:50;
  background:var(--header-bg);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}

.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:14px 0;
}

.logo{
  display:flex;
  align-items:center;
  gap:12px;
}

.logo-img{
  height:44px;
  width:auto;
  object-fit:contain;
}

.logo-text strong{
  display:block;
  font-weight:900;
}

.logo-text small{
  display:block;
  font-size:12.5px;
  font-weight:600;
  color:var(--muted);
}

.header-actions{
  display:flex;
  align-items:center;
  gap:14px;
}

.nav{
  display:flex;
  align-items:center;
  gap:14px;
}

.nav a{
  padding:10px 10px;
  border-radius:12px;
  font-weight:800;
  color:var(--text);
}

.nav a:hover{
  background:color-mix(in srgb, var(--text) 6%, transparent);
}

/* =========================================================
   BUTTONS
   ========================================================= */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:12px 16px;
  border-radius:14px;
  border:1px solid var(--line);
  background:color-mix(in srgb, var(--text) 4%, transparent);
  font-weight:900;
  transition:.12s ease;
}

.btn:hover{
  transform:translateY(-1px);
  background:color-mix(in srgb, var(--text) 7%, transparent);
}

.btn.primary{
  background:linear-gradient(135deg, var(--brand), var(--brand2));
  color:#06101f;
  border-color:transparent;
}

.btn.ghost{
  background:color-mix(in srgb, var(--text) 3%, transparent);
}

/* =========================================================
   THEME TOGGLE
   ========================================================= */
.theme-toggle{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid var(--line);
  background:color-mix(in srgb, var(--text) 4%, transparent);
  font-weight:900;
  cursor:pointer;
}

.theme-toggle:hover{
  background:color-mix(in srgb, var(--text) 7%, transparent);
}

.theme-dot{
  width:10px;
  height:10px;
  border-radius:50%;
  background:linear-gradient(135deg, var(--brand), var(--brand2));
}

.theme-text{font-size:12px}

/* =========================================================
   HERO
   ========================================================= */
.hero{padding:64px 0 32px}

.hero-inner{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:34px;
  align-items:center;
}

.tag{
  display:inline-block;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid color-mix(in srgb, var(--brand) 35%, transparent);
  background:color-mix(in srgb, var(--brand) 12%, transparent);
  font-weight:850;
  margin-bottom:10px;
}

.hero h1{
  font-size:clamp(30px,3.2vw,46px);
  line-height:1.12;
  margin:0 0 12px;
}

.lead{
  max-width:60ch;
  color:var(--muted);
  margin-bottom:18px;
}

.hero-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-bottom:14px;
}

.mini-points{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.mini-points span{
  padding:8px 10px;
  border-radius:999px;
  border:1px solid var(--line);
  background:var(--chip-bg);
  font-size:13px;
  font-weight:750;
}

/* HERO IMAGE */
.hero-card{
  position:relative;
  border-radius:var(--radius);
  overflow:hidden;
  border:1px solid var(--line);
  background:var(--card);
  box-shadow:var(--shadow);
}

.hero-card img{
  width:100%;
  height:420px;
  object-fit:cover;
}

.hero-card-caption{
  position:absolute;
  inset:auto 0 0 0;
  padding:16px;
  background:linear-gradient(to top, rgba(0,0,0,.6), transparent);
}

/* =========================================================
   SECTION
   ========================================================= */
.section{padding:60px 0}

.section.soft{
  background:linear-gradient(180deg, color-mix(in srgb, var(--text) 3%, transparent), transparent);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}

.section-head{margin-bottom:18px}

.section-head h2{
  margin:0 0 8px;
  font-size:clamp(22px,2.2vw,32px);
}

/* =========================================================
   CATALOG CHIPS
   ========================================================= */
.chips{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin:18px 0;
}

.chip{
  min-width:180px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:10px 14px;
  border-radius:14px;
  border:1px solid var(--line);
  background:var(--chip-bg);
  cursor:pointer;
  transition:.12s ease;
}

.chip:hover{
  background:var(--chip-bg-hover);
}

.chip.active{
  border-color:color-mix(in srgb, var(--brand) 45%, transparent);
  background:color-mix(in srgb, var(--brand) 16%, transparent);
}

.chip-title{
  font-weight:900;
  font-size:13px;
  letter-spacing:.3px;
  color:var(--text);
}

.chip-menu{
  color:var(--text);
  opacity:.7;
}

/* =========================================================
   PANELS & GRID
   ========================================================= */
.panels{margin-top:12px}
.panel{display:none}
.panel.show{display:block}

.grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
}

.item{
  border:1px solid var(--line);
  background:var(--card);
  border-radius:var(--radius);
  overflow:hidden;
}

.item img{
  width:100%;
  height:200px;
  object-fit:cover;
}

.meta{
  padding:14px;
}

.meta strong{display:block;font-weight:900}
.meta small{color:var(--muted);font-weight:600}

/* =========================================================
   ADDITIONAL
   ========================================================= */
.addon-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
}

.addon{
  border:1px solid var(--line);
  background:var(--card);
  border-radius:var(--radius);
  padding:16px;
}

.addon-icon{
  width:44px;
  height:44px;
  border-radius:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:color-mix(in srgb, var(--brand) 18%, transparent);
  border:1px solid color-mix(in srgb, var(--brand) 40%, transparent);
  font-weight:900;
  margin-bottom:10px;
}

.addon h3{margin:0 0 6px;font-weight:900}
.addon p{margin:0 0 12px;color:var(--muted)}

.addon-tags{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.addon-tags span{
  padding:8px 10px;
  border-radius:999px;
  border:1px solid var(--line);
  background:var(--chip-bg);
  font-size:12.5px;
  font-weight:800;
}

/* COLOR SWATCH */
.swatches{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.swatches i{
  width:34px;
  height:34px;
  border-radius:12px;
  border:1px solid var(--line);
}

.swatches i:nth-child(1){background:#0a0a0f}
.swatches i:nth-child(2){background:#0b1b3f}
.swatches i:nth-child(3){background:#1d4ed8}
.swatches i:nth-child(4){background:#dc2626}
.swatches i:nth-child(5){background:#16a34a}
.swatches i:nth-child(6){background:#f8fafc}

/* =========================================================
   CTA
   ========================================================= */
.cta{
  padding:56px 0;
  border-top:1px solid var(--line);
}

.cta-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
}

/* =========================================================
   FOOTER
   ========================================================= */
.footer{
  padding:18px 0;
  border-top:1px solid var(--line);
}

.footer-inner{
  display:flex;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media(max-width:980px){
  .hero-inner{grid-template-columns:1fr}
  .hero-card img{height:320px}
  .grid,.addon-grid{grid-template-columns:1fr}
}
/* toggle light background di dark mode */
html[data-theme="dark"] .theme-toggle{
  background: #ffffff;
  color: #0b1220;
  border-color: rgba(255,255,255,.6);
}

/* hover tetap halus */
html[data-theme="dark"] .theme-toggle:hover{
  background: #f1f5f9;
}

/* dot tetap brand */
html[data-theme="dark"] .theme-dot{
  background: linear-gradient(135deg, var(--brand), var(--brand2));
}

/* =========================================================
   HIGHLIGHT SECTION
   ========================================================= */
.highlight{
  padding:70px 0;
  background:
    radial-gradient(600px 300px at 70% 0%, rgba(33,198,183,.18), transparent 60%),
    radial-gradient(700px 360px at 20% 100%, rgba(42,124,255,.18), transparent 55%);
}

.highlight-inner{
  max-width:900px;
  text-align:center;
}

.highlight h2{
  font-size:clamp(26px,3vw,40px);
  font-weight:900;
  margin:0 0 16px;
}

.highlight-accent{
  color:var(--brand2);
  position:relative;
  white-space:nowrap;
}

.highlight-accent::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:-6px;
  height:4px;
  border-radius:999px;
  background:linear-gradient(90deg, var(--brand), var(--brand2));
}

.highlight-desc{
  color:var(--muted);
  font-size:16px;
  line-height:1.8;
}
/* =========================================================
   MOBILE HEADER FIX (hamburger + drawer)
   ========================================================= */

.menu-btn{
  display:none;
  width:44px;
  height:44px;
  border-radius:14px;
  border:1px solid var(--line);
  background: color-mix(in srgb, var(--text) 4%, transparent);
  cursor:pointer;
  padding:10px;
}
.menu-btn span{
  display:block;
  height:2px;
  margin:6px 0;
  background: var(--text);
  border-radius:2px;
}

/* Drawer */
.mobile-drawer{
  display:none;
  border-top:1px solid var(--line);
  background: var(--header-bg);
  backdrop-filter: blur(10px);
}
.mobile-drawer.open{ display:block; }

.mobile-panel{
  width:min(var(--container), calc(100% - 40px));
  margin:auto;
  padding:14px 0 18px;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.m-link{
  padding:12px 12px;
  border-radius:14px;
  border:1px solid var(--line);
  background: var(--chip-bg);
  font-weight:900;
}
.m-link:hover{ background: var(--chip-bg-hover); }
.m-cta{ width:100%; }

/* =====================
   Responsive rules
   ===================== */
@media (max-width: 820px){
  /* rapihin logo text biar tidak makan tempat */
  .logo-img{ height:38px; }
  .logo-text small{ display:none; }  /* sembunyikan subtext di mobile */

  /* nav desktop disembunyikan, pakai hamburger */
  .nav-desktop{ display:none; }
  .menu-btn{ display:inline-flex; align-items:center; justify-content:center; }

  /* header biar wrap rapi */
  .header-inner{
    gap:10px;
  }

  /* theme toggle biar tidak kepanjangan */
  .theme-toggle{
    padding:10px 10px;
  }
  .theme-text{ font-size:12px; }
}

@media (max-width: 420px){
  .logo-text strong{ font-size:14px; }
  .logo-img{ height:34px; }
}

/* =========================================================
   MOBILE MENU BUTTON
   ========================================================= */
  
.menu-btn{
  width:44px;
  height:44px;
  border-radius:14px;
  border:1px solid var(--line);
  background:#ffffff;
  color:#111;            /* warna ikon */
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
}

/* tampilkan hanya di mobile */
@media (min-width: 821px){
  .menu-btn{ display:none; }
}



/* tampilkan hamburger hanya di mobile */
@media (min-width: 821px){
  .menu-btn{ display:none; }
}

/* ===============================
   Hover Zoom Effect (Catalog)
   =============================== */

.item{
  position: relative;
  overflow: hidden;          /* PENTING: supaya zoom tidak keluar card */
  border-radius: 18px;
}

.item img{
  width: 100%;
  height: auto;
  display: block;
  transition: transform .45s ease, filter .45s ease;
  will-change: transform;
}

/* Hover effect hanya untuk device yang support hover */
@media (hover: hover) and (pointer: fine){
  .item:hover img{
    transform: scale(1.12);  /* tingkat zoom */
    filter: saturate(1.05);
  }
}

/* Optional: sedikit elevasi card */
@media (hover: hover) and (pointer: fine){
  .item:hover{
    box-shadow: 0 18px 40px rgba(0,0,0,.18);
  }
}
.item img{
  transform-origin: center center;
}

/* ===============================
   IMAGE HOVER ZOOM
================================ */
.grid .item{
  position:relative;
  overflow:hidden;
  cursor:zoom-in;
}

.grid .item img{
  width:100%;
  height:auto;
  display:block;
  transition:transform .4s ease;
}

.grid .item:hover img{
  transform:scale(1.15);
}

/* ===============================
   IMAGE MODAL FULLSCREEN
================================ */
.img-modal{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.85);
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:9999;
  opacity:0;
  pointer-events:none;
  transition:opacity .3s ease;
}

.img-modal.show{
  opacity:1;
  pointer-events:auto;
}

.img-modal img{
  max-width:92%;
  max-height:92%;
  border-radius:12px;
  box-shadow:0 30px 80px rgba(0,0,0,.6);
  cursor:zoom-out;
}

.img-close{
  position:absolute;
  top:20px;
  right:24px;
  font-size:36px;
  background:none;
  border:none;
  color:#fff;
  cursor:pointer;
  line-height:1;
}
