/* ============================================================
   AF Promotion — Warm Heritage design system
   Shared tokens + components for all pages
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;0,800;1,400;1,500;1,600&family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400;1,9..40,500&family=JetBrains+Mono:wght@400;500&display=swap');

:root{
  /* color */
  --cream:#FDF6EC;
  --paper:#F9F7F2;
  --maroon:#5E1B26;
  --maroon-deep:#43121B;
  --maroon-hover:#7C2433;
  --ochre:#C08A2D;
  --ochre-soft:#E7C77F;
  --ink:#2B2420;
  --muted:#7A6E64;
  --line:rgba(94,27,38,.14);
  --line-soft:rgba(94,27,38,.08);
  --white:#FFFFFF;
  --ok:#1B7A4B;

  /* type */
  --serif:"Playfair Display",Georgia,serif;
  --sans:"DM Sans",system-ui,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;

  /* spacing — 8px grid */
  --s1:8px;--s2:16px;--s3:24px;--s4:32px;--s5:40px;--s6:48px;--s7:64px;--s8:80px;--s9:112px;

  /* radius */
  --r-sm:10px;--r-md:16px;--r-lg:20px;--r-xl:28px;--r-pill:999px;

  /* shadow — warm */
  --sh-sm:0 1px 2px rgba(67,18,27,.06),0 2px 6px rgba(67,18,27,.05);
  --sh-md:0 8px 24px -10px rgba(67,18,27,.22);
  --sh-lg:0 24px 60px -22px rgba(67,18,27,.34);

  --maxw:1240px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;background:var(--cream);color:var(--ink);
  font-family:var(--sans);font-size:16px;line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
h1,h2,h3,h4{font-family:var(--serif);font-weight:700;color:var(--maroon);margin:0;line-height:1.08;letter-spacing:-.01em;}
p{margin:0;text-wrap:pretty;}
button{font-family:inherit;cursor:pointer;}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--s5);}
.section{padding:var(--s9) 0;}
@media(max-width:760px){.section{padding:var(--s8) 0;}.wrap{padding:0 var(--s3);}}

/* ---------- eyebrow / kicker ---------- */
.kicker{display:inline-flex;align-items:center;gap:10px;font:600 12px/1 var(--sans);
  letter-spacing:.18em;text-transform:uppercase;color:var(--ochre);}
.kicker::before{content:"";width:28px;height:1.5px;background:var(--ochre);display:inline-block;}
.kicker.center{justify-content:center;}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font:600 15px/1 var(--sans);padding:15px 26px;border-radius:var(--r-pill);
  border:1.5px solid transparent;white-space:nowrap;transition:transform .18s cubic-bezier(.2,.7,.3,1),background .18s,box-shadow .18s,color .18s;}
.btn:active{transform:translateY(1px);}
.btn-primary{background:var(--maroon);color:var(--cream);}
.btn-primary:hover{background:var(--maroon-hover);box-shadow:var(--sh-md);}
.btn-dark{background:var(--ink);color:var(--cream);}
.btn-dark:hover{background:#3a322c;}
.btn-outline{background:transparent;color:var(--maroon);border-color:var(--line);}
.btn-outline:hover{border-color:var(--maroon);background:rgba(94,27,38,.04);}
.btn-ochre{background:var(--ochre);color:#3a2a08;}
.btn-ochre:hover{background:#d09a3a;box-shadow:var(--sh-md);}
.btn-wa{background:#1FA855;color:#fff;}
.btn-wa:hover{background:#178a45;box-shadow:var(--sh-md);}
.btn-lg{padding:18px 32px;font-size:16px;}
.btn-sm{padding:11px 18px;font-size:14px;}
.btn-block{display:flex;width:100%;}
.linkarrow{display:inline-flex;align-items:center;gap:8px;font:600 15px/1 var(--sans);color:var(--maroon);}
.linkarrow svg{transition:transform .2s;}
.linkarrow:hover svg{transform:translateX(4px);}

/* ---------- icons ---------- */
.ic{width:20px;height:20px;flex:none;stroke:currentColor;stroke-width:1.7;fill:none;
  stroke-linecap:round;stroke-linejoin:round;}

/* ---------- placeholder imagery (striped, labelled) ---------- */
.ph{background:repeating-linear-gradient(135deg,rgba(94,27,38,.05) 0 11px,rgba(94,27,38,.09) 11px 22px);
  border:1px solid var(--line-soft);display:flex;align-items:center;justify-content:center;
  color:rgba(94,27,38,.5);font:500 11px/1.4 var(--mono);letter-spacing:.08em;
  text-transform:uppercase;text-align:center;padding:12px;overflow:hidden;}
.ph.dark{background:repeating-linear-gradient(135deg,rgba(255,255,255,.05) 0 11px,rgba(255,255,255,.09) 11px 22px);
  border-color:rgba(255,255,255,.12);color:rgba(255,255,255,.5);}

/* ---------- chips / badges ---------- */
.chip{display:inline-flex;align-items:center;gap:7px;font:600 12px/1 var(--sans);
  padding:7px 12px;border-radius:var(--r-pill);background:var(--paper);border:1px solid var(--line);color:var(--maroon);}
.badge{display:inline-flex;align-items:center;gap:6px;font:700 10.5px/1 var(--sans);
  letter-spacing:.08em;text-transform:uppercase;padding:6px 10px;border-radius:7px;}
.badge-polos{background:rgba(192,138,45,.16);color:#8a5e12;}
.badge-custom{background:var(--maroon);color:var(--cream);}
.badge-ready{background:rgba(27,122,75,.14);color:var(--ok);}

/* ============================================================
   NAVBAR
   ============================================================ */
.nav{position:sticky;top:0;z-index:50;background:rgba(253,246,236,.86);
  backdrop-filter:blur(12px);border-bottom:1px solid var(--line-soft);}
.nav-inner{max-width:var(--maxw);margin:0 auto;padding:14px var(--s5);
  display:flex;align-items:center;gap:var(--s5);}
.brand{display:flex;align-items:center;gap:11px;}
.brand img{width:40px;height:auto;}
.brand .bn{font-family:var(--sans);font-weight:700;font-size:21px;color:var(--maroon);letter-spacing:-.01em;white-space:nowrap;}
.nav-links{display:flex;gap:var(--s4);margin-left:var(--s2);}
.nav-links a{font:500 15px/1 var(--sans);color:var(--ink);opacity:.82;transition:opacity .15s,color .15s;position:relative;padding:6px 0;}
.nav-links a:hover,.nav-links a.active{opacity:1;color:var(--maroon);}
.nav-links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--ochre);border-radius:2px;}
.nav-actions{margin-left:auto;display:flex;align-items:center;gap:14px;}
.iconbtn{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;
  border:1px solid var(--line);background:var(--white);color:var(--maroon);transition:background .15s,border-color .15s;position:relative;}
.iconbtn:hover{background:var(--paper);border-color:var(--maroon);}
.cart-count{position:absolute;top:-6px;right:-6px;min-width:19px;height:19px;padding:0 5px;border-radius:999px;
  background:var(--ochre);color:#3a2a08;font:700 11px/19px var(--sans);text-align:center;}
.nav-burger{display:none;}
@media(max-width:980px){
  .nav-links,.nav-actions .btn,.nav-actions .iconbtn.search{display:none;}
  .nav-burger{display:flex;}
}
@media(max-width:760px){
  .nav-inner{padding:12px var(--s3);gap:var(--s2);}
  .brand .bn{font-size:19px;}
  .nav-actions{gap:10px;}
}

/* ---------- mobile nav drawer (off-canvas, di-toggle tombol burger) ---------- */
.m-overlay{position:fixed;inset:0;z-index:90;background:rgba(43,36,32,.5);
  opacity:0;visibility:hidden;transition:opacity .25s;backdrop-filter:blur(2px);}
.m-overlay.open{opacity:1;visibility:visible;}
.m-drawer{position:fixed;top:0;right:0;bottom:0;z-index:100;width:min(86vw,360px);
  background:var(--cream);box-shadow:var(--sh-lg);display:flex;flex-direction:column;
  transform:translateX(100%);transition:transform .28s cubic-bezier(.2,.7,.3,1);
  overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;}
.m-drawer.open{transform:translateX(0);}
.m-drawer-head{display:flex;align-items:center;justify-content:space-between;
  padding:18px 20px;border-bottom:1px solid var(--line-soft);position:sticky;top:0;background:var(--cream);z-index:2;}
.m-drawer-head .bn{font-family:var(--sans);font-weight:700;font-size:18px;color:var(--maroon);}
.m-search{padding:16px 20px 8px;position:relative;}
.m-search .input{width:100%;}
.m-links{display:flex;flex-direction:column;padding:8px 12px;}
.m-links a{font:600 16px/1 var(--sans);color:var(--ink);padding:14px 12px;border-radius:var(--r-sm);
  transition:background .12s,color .12s;}
.m-links a:hover,.m-links a.active{background:var(--white);color:var(--maroon);}
.m-auth{margin-top:auto;padding:18px 20px;border-top:1px solid var(--line-soft);
  display:flex;flex-direction:column;gap:10px;}
.m-account{display:flex;align-items:center;gap:12px;padding:4px 2px 14px;}
.m-account .av{width:42px;height:42px;border-radius:999px;flex:none;
  background:linear-gradient(150deg,var(--maroon-hover),var(--maroon-deep));color:var(--cream);
  display:flex;align-items:center;justify-content:center;font:700 18px/1 var(--serif);}
.m-account b{font:600 14px/1.3 var(--sans);color:var(--ink);display:block;}
.m-account span{font-size:12.5px;color:var(--muted);word-break:break-all;}
.m-logout{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;
  font:600 14px/1 var(--sans);color:#b53a2a;background:transparent;border:1.5px solid rgba(181,58,42,.3);
  border-radius:var(--r-pill);padding:13px 18px;cursor:pointer;transition:background .15s;}
.m-logout:hover{background:rgba(181,58,42,.06);}
.m-logout form{margin:0;width:100%;}
@media(min-width:981px){.m-drawer,.m-overlay{display:none;}}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--maroon-deep);color:rgba(253,246,236,.72);}
.footer h4{color:var(--cream);font-family:var(--sans);font-weight:700;font-size:13px;
  letter-spacing:.1em;text-transform:uppercase;margin-bottom:18px;}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:var(--s6);padding-top:var(--s8);padding-bottom:var(--s6);}
.footer a{display:block;padding:6px 0;color:rgba(253,246,236,.72);font-size:14px;transition:color .15s;}
.footer a:hover{color:var(--ochre-soft);}
.footer .brand .bn{color:var(--cream);}
.footer-bottom{border-top:1px solid rgba(253,246,236,.14);padding-top:22px;padding-bottom:22px;display:flex;
  align-items:center;justify-content:space-between;font-size:13px;color:rgba(253,246,236,.55);gap:16px;flex-wrap:wrap;}
.pay-badge{font:600 11px/1 var(--sans);padding:7px 11px;border-radius:7px;background:rgba(253,246,236,.1);
  color:var(--cream);border:1px solid rgba(253,246,236,.16);}
@media(max-width:900px){.footer-grid{grid-template-columns:1fr 1fr;gap:var(--s5) var(--s4);}}
@media(max-width:560px){.footer-grid{grid-template-columns:1fr;gap:var(--s4);padding-top:var(--s6);padding-bottom:var(--s5);}}

/* ---------- trust bar ---------- */
.trustbar{background:var(--maroon);color:var(--cream);}
.trustbar-inner{max-width:var(--maxw);margin:0 auto;padding:18px var(--s5);display:flex;
  align-items:center;justify-content:space-between;gap:var(--s4);flex-wrap:wrap;}
.trust-item{display:flex;align-items:center;gap:11px;font:500 14px/1.3 var(--sans);color:rgba(253,246,236,.9);}
.trust-item .ic{color:var(--ochre-soft);width:22px;height:22px;flex:none;}
@media(max-width:760px){
  .trustbar-inner{display:grid;grid-template-columns:1fr 1fr;gap:14px 18px;justify-items:start;padding:18px var(--s3);}
}
@media(max-width:420px){.trustbar-inner{grid-template-columns:1fr;}}

/* ---------- generic card ---------- */
.card{background:var(--white);border:1px solid var(--line-soft);border-radius:var(--r-lg);box-shadow:var(--sh-sm);}

/* utility */
.center{text-align:center;}
.mono{font-family:var(--mono);}
.serif{font-family:var(--serif);}
.muted{color:var(--muted);}
.price{font:700 18px/1 var(--sans);color:var(--maroon);}
.price s{color:var(--muted);font-weight:500;font-size:.8em;margin-right:6px;}
.stars{color:var(--ochre);letter-spacing:2px;font-size:14px;}
.divider{height:1px;background:var(--line-soft);border:0;margin:0;}

/* ---------- WhatsApp float ---------- */
.wa-float{position:fixed;right:22px;bottom:22px;z-index:60;display:inline-flex;align-items:center;gap:10px;
  background:#1FA855;color:#fff;padding:13px 18px 13px 15px;border-radius:var(--r-pill);
  box-shadow:0 12px 30px -8px rgba(31,168,85,.6);font:600 14px/1 var(--sans);transition:transform .2s,box-shadow .2s;}
.wa-float:hover{transform:translateY(-2px);box-shadow:0 16px 36px -8px rgba(31,168,85,.7);}
.wa-float .ic{width:22px;height:22px;}
@media(max-width:600px){.wa-float span{display:none;}.wa-float{padding:14px;}}

/* ---------- product card (shared: home + catalog) ---------- */
.pcard{background:var(--white);border:1px solid var(--line-soft);border-radius:var(--r-md);overflow:hidden;
  box-shadow:var(--sh-sm);transition:transform .22s cubic-bezier(.2,.7,.3,1),box-shadow .22s;display:flex;flex-direction:column;}
.pcard:hover{transform:translateY(-6px);box-shadow:var(--sh-lg);}
.pcard-media{position:relative;aspect-ratio:1/1;}
.pcard-media .ph{position:absolute;inset:0;}
.pcard-badges{position:absolute;top:12px;left:12px;display:flex;gap:6px;flex-wrap:wrap;}
.pcard-fav{position:absolute;top:12px;right:12px;width:34px;height:34px;border-radius:999px;background:rgba(255,255,255,.9);
  border:1px solid var(--line-soft);display:flex;align-items:center;justify-content:center;color:var(--maroon);opacity:0;transition:opacity .2s,background .15s;}
.pcard:hover .pcard-fav{opacity:1;}
.pcard-fav:hover{background:#fff;}
/* favorit aktif (tersimpan): hati terisi + tetap terlihat tanpa hover */
.pcard-fav.active{opacity:1;color:var(--maroon);}
.pcard-fav.active .ic{fill:var(--maroon);stroke:var(--maroon);}
.pcard-add{position:absolute;left:12px;right:12px;bottom:12px;transform:translateY(calc(100% + 16px));opacity:0;
  transition:transform .24s cubic-bezier(.2,.7,.3,1),opacity .2s;}
.pcard:hover .pcard-add{transform:translateY(0);opacity:1;}
.pcard-body{padding:16px 16px 18px;display:flex;flex-direction:column;gap:8px;flex:1;}
.pcard-cat{font:600 11px/1 var(--sans);letter-spacing:.1em;text-transform:uppercase;color:var(--ochre);}
.pcard-title{font:600 16px/1.3 var(--sans);color:var(--ink);}
.pcard-meta{display:flex;align-items:center;justify-content:space-between;margin-top:auto;}
.pcard-rating{font:500 12px/1 var(--sans);color:var(--muted);display:flex;align-items:center;gap:5px;}

/* ---------- category split cards ---------- */
.catcard{position:relative;border-radius:var(--r-xl);overflow:hidden;padding:40px;display:flex;flex-direction:column;
  min-height:340px;transition:transform .22s,box-shadow .22s;}
.catcard:hover{transform:translateY(-5px);box-shadow:var(--sh-lg);}
.catcard.polos{background:var(--paper);border:1px solid var(--line);color:var(--ink);}
.catcard.custom{background:linear-gradient(150deg,var(--maroon),var(--maroon-deep));color:var(--cream);}
.catcard .ph{position:absolute;}

/* ---------- step / how-it-works ---------- */
.step{background:var(--white);border:1px solid var(--line-soft);border-radius:var(--r-lg);padding:30px 28px;position:relative;box-shadow:var(--sh-sm);}
.step-num{font-family:var(--serif);font-weight:700;font-size:46px;color:var(--ochre);line-height:1;opacity:.9;}
.step h3{font-family:var(--sans);font-weight:700;font-size:20px;color:var(--maroon);margin:14px 0 8px;}

/* ---------- forms ---------- */
.field{display:flex;flex-direction:column;gap:7px;}
.field label{font:600 13px/1 var(--sans);color:var(--ink);}
.input,select.input,textarea.input{font:500 15px/1.4 var(--sans);color:var(--ink);background:var(--white);
  border:1.5px solid var(--line);border-radius:var(--r-sm);padding:13px 15px;transition:border-color .15s,box-shadow .15s;width:100%;}
.input:focus,textarea.input:focus,select.input:focus{outline:none;border-color:var(--maroon);box-shadow:0 0 0 3px rgba(94,27,38,.1);}
textarea.input{resize:vertical;min-height:90px;}
/* dropdown/select — chevron Warm Heritage agar semua select selaras (provinsi, kota, kecamatan, dll) */
select.input{appearance:none;-webkit-appearance:none;-moz-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%235E1B26' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 15px center;padding-right:42px;cursor:pointer;}
select.input:disabled{opacity:.55;cursor:not-allowed;background-color:var(--paper);color:var(--muted);}

/* ============================================================
   OVERLAY PENCARIAN (tombol kaca pembesar navbar)
   ============================================================ */
.search-overlay{position:fixed;inset:0;z-index:120;background:rgba(43,36,32,.5);backdrop-filter:blur(3px);
  opacity:0;visibility:hidden;transition:opacity .2s;display:flex;align-items:flex-start;justify-content:center;padding:0 20px;}
.search-overlay.open{opacity:1;visibility:visible;}
.search-overlay-inner{width:100%;max-width:640px;margin-top:14vh;}
.search-box{display:flex;align-items:center;gap:12px;background:var(--white);border:1px solid var(--line);
  border-radius:var(--r-pill);padding:6px 8px 6px 20px;box-shadow:var(--sh-lg);position:relative;}
.search-box .search-ic{color:var(--maroon);width:22px;height:22px;flex:none;}
.search-field{flex:1;min-width:0;border:none;outline:none;background:transparent;
  font:500 17px/1.4 var(--sans);color:var(--ink);padding:14px 0;}
.search-field::placeholder{color:var(--muted);}
.search-close{width:42px;height:42px;border-radius:999px;border:none;background:var(--paper);color:var(--maroon);
  display:flex;align-items:center;justify-content:center;flex:none;cursor:pointer;transition:background .15s;}
.search-close:hover{background:var(--line-soft);}
.search-hint{text-align:center;color:rgba(253,246,236,.85);font-size:13px;margin-top:14px;}
.search-hint b{background:rgba(253,246,236,.16);padding:2px 7px;border-radius:5px;font-weight:600;}
@media(max-width:560px){.search-overlay-inner{margin-top:10vh;}.search-field{font-size:16px;}}

/* ============================================================
   TOAST NOTIFIKASI
   ============================================================ */
.af-toast{position:fixed;left:50%;bottom:28px;transform:translateX(-50%) translateY(20px);z-index:200;
  background:var(--ink);color:var(--cream);font:600 14px/1.3 var(--sans);padding:13px 20px;border-radius:var(--r-pill);
  box-shadow:var(--sh-lg);opacity:0;visibility:hidden;transition:opacity .2s,transform .2s;max-width:90vw;text-align:center;}
.af-toast.show{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);}
.af-toast.err{background:#b53a2a;color:#fff;}

/* ============================================================
   KARTU PRODUK DI PERANGKAT SENTUH (tanpa hover) — tampilkan
   tombol favorit & tambah keranjang agar tetap bisa dipakai.
   ============================================================ */
@media(hover:none){
  .pcard-fav{opacity:1;}
  .pcard-add{transform:translateY(0);opacity:1;}
}
