/* =========================================================
   UMKM Lokal — Katalog Digital
   Shared stylesheet (no external framework)
   ========================================================= */

:root{
  /* Palette: ekonomi kreatif lokal */
  --teal:#0E5C5C;        /* primary — alam & laut */
  --teal-dark:#083F3F;
  --teal-soft:#E3EFEC;
  --clay:#E07A3F;        /* accent — kerajinan / hangat */
  --clay-dark:#C2602B;
  --sand:#FAF6EF;        /* background */
  --ink:#22302E;         /* teks utama */
  --muted:#6B7B78;       /* teks sekunder */
  --line:#E5DDD0;        /* garis / border */
  --white:#FFFFFF;
  --wa:#25D366;          /* WhatsApp */
  --wa-dark:#1EBE5A;

  /* Kategori (warna pill) */
  --cat-wisata:#2F8F83;
  --cat-kuliner:#E07A3F;
  --cat-hotel:#3B6FB0;
  --cat-kriya:#9B5DE5;

  --radius:14px;
  --radius-sm:10px;
  --shadow:0 6px 24px rgba(14,92,92,.08);
  --shadow-hover:0 12px 36px rgba(14,92,92,.16);
  --maxw:1180px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  background:var(--sand);
  color:var(--ink);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4,.brand{font-family:'Plus Jakarta Sans','Inter',sans-serif;line-height:1.2}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:var(--maxw);margin:0 auto;padding:0 20px}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;border:none;cursor:pointer;
  font-family:inherit;font-weight:600;font-size:.95rem;padding:12px 20px;
  border-radius:var(--radius-sm);transition:.18s;text-align:center;justify-content:center}
.btn-primary{background:var(--teal);color:#fff}
.btn-primary:hover{background:var(--teal-dark)}
.btn-accent{background:var(--clay);color:#fff}
.btn-accent:hover{background:var(--clay-dark)}
.btn-ghost{background:transparent;color:var(--teal);border:1.5px solid var(--line)}
.btn-ghost:hover{border-color:var(--teal);background:var(--teal-soft)}
.btn-wa{background:var(--wa);color:#fff}
.btn-wa:hover{background:var(--wa-dark)}
.btn-sm{padding:8px 14px;font-size:.85rem}
.btn-block{width:100%}
.btn-danger{background:#fff;color:#c0392b;border:1.5px solid #f0c7c1}
.btn-danger:hover{background:#fdecea}

/* ---------- Header / Navbar ---------- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(250,246,239,.92);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:70px}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:1.25rem;color:var(--teal)}
.brand .mark{width:36px;height:36px;border-radius:10px;background:var(--teal);
  display:grid;place-items:center;color:#fff;font-size:1.1rem}
.brand .mark::after{content:"◆";} /* woven diamond motif */
.nav-links{display:flex;align-items:center;gap:6px;list-style:none}
.nav-links a{padding:9px 14px;border-radius:8px;font-weight:500;font-size:.95rem;color:var(--ink)}
.nav-links a:hover,.nav-links a.active{background:var(--teal-soft);color:var(--teal)}
.nav-actions{display:flex;align-items:center;gap:10px}
.nav-toggle{display:none;background:none;border:none;font-size:1.6rem;cursor:pointer;color:var(--teal)}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;padding:64px 0 72px}
.hero::before{content:"";position:absolute;inset:0;
  background:
    radial-gradient(900px 400px at 85% -10%,rgba(224,122,63,.16),transparent 60%),
    radial-gradient(700px 360px at 0% 110%,rgba(14,92,92,.12),transparent 60%);
  z-index:0}
.hero .container{position:relative;z-index:1;display:grid;grid-template-columns:1.1fr .9fr;
  gap:48px;align-items:center}
.hero .eyebrow{display:inline-block;background:var(--clay);color:#fff;font-size:.78rem;
  font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:6px 12px;border-radius:50px;margin-bottom:18px}
.hero h1{font-size:clamp(2rem,4.5vw,3.3rem);font-weight:800;color:var(--ink);margin-bottom:16px}
.hero h1 span{color:var(--teal)}
.hero p{font-size:1.08rem;color:var(--muted);max-width:520px;margin-bottom:26px}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap}
.hero-stats{display:flex;gap:28px;margin-top:34px}
.hero-stats .num{font-family:'Plus Jakarta Sans';font-size:1.7rem;font-weight:800;color:var(--teal)}
.hero-stats .lbl{font-size:.85rem;color:var(--muted)}
.hero-art{position:relative;aspect-ratio:4/3;border-radius:24px;overflow:hidden;box-shadow:var(--shadow-hover)}
.hero-art img{width:100%;height:100%;object-fit:cover}
.hero-badge{position:absolute;bottom:16px;left:16px;background:#fff;border-radius:14px;
  padding:12px 16px;box-shadow:var(--shadow);display:flex;align-items:center;gap:10px;font-size:.9rem}
.hero-badge .dot{width:34px;height:34px;border-radius:10px;background:var(--cat-kuliner);display:grid;place-items:center;font-size:1.1rem}

/* ---------- Search bar ---------- */
.searchbar{position:relative;z-index:2;max-width:680px;margin:-30px auto 0;
  background:#fff;border-radius:50px;box-shadow:var(--shadow);display:flex;
  padding:8px;border:1px solid var(--line)}
.searchbar input{flex:1;border:none;outline:none;background:transparent;font-size:1rem;
  padding:10px 18px;font-family:inherit;color:var(--ink)}
.searchbar .btn{border-radius:50px}

/* ---------- Sections ---------- */
.section{padding:56px 0}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;
  gap:16px;margin-bottom:28px;flex-wrap:wrap}
.section-head .eyebrow{color:var(--clay);font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.section-head h2{font-size:1.8rem;font-weight:800;margin-top:4px}
.section-head p{color:var(--muted);margin-top:4px}

/* ---------- Category chips ---------- */
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.cat-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:22px;text-align:center;cursor:pointer;transition:.18s}
.cat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover);border-color:transparent}
.cat-card .ico{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;
  font-size:1.6rem;margin:0 auto 12px}
.cat-card h3{font-size:1.05rem}
.cat-card small{color:var(--muted)}
.ico-wisata{background:rgba(47,143,131,.14);color:var(--cat-wisata)}
.ico-kuliner{background:rgba(224,122,63,.14);color:var(--cat-kuliner)}
.ico-hotel{background:rgba(59,111,176,.14);color:var(--cat-hotel)}
.ico-kriya{background:rgba(155,93,229,.14);color:var(--cat-kriya)}

/* ---------- Filter pills ---------- */
.filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:26px}
.pill{border:1.5px solid var(--line);background:#fff;color:var(--ink);
  padding:8px 16px;border-radius:50px;font-size:.88rem;font-weight:600;cursor:pointer;transition:.15s}
.pill:hover{border-color:var(--teal)}
.pill.active{background:var(--teal);color:#fff;border-color:var(--teal)}

/* ---------- Product cards ---------- */
.product-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;transition:.2s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow-hover);border-color:transparent}
.card .thumb{aspect-ratio:4/3;overflow:hidden;position:relative}
.card .thumb img{width:100%;height:100%;object-fit:cover;transition:.3s}
.card:hover .thumb img{transform:scale(1.06)}
.cat-tag{position:absolute;top:10px;left:10px;color:#fff;font-size:.72rem;font-weight:700;
  padding:4px 10px;border-radius:50px;backdrop-filter:blur(2px)}
.tag-Pariwisata{background:var(--cat-wisata)}
.tag-Kuliner{background:var(--cat-kuliner)}
.tag-Hotel{background:var(--cat-hotel)}
.tag-Kerajinan{background:var(--cat-kriya)}
.card-body{padding:16px;display:flex;flex-direction:column;gap:6px;flex:1}
.card-body h3{font-size:1.02rem;font-weight:700;line-height:1.3}
.card-body h3 a:hover{color:var(--teal)}
.card .umkm{font-size:.82rem;color:var(--muted);display:flex;align-items:center;gap:5px}
.card .umkm a:hover{color:var(--teal);text-decoration:underline}
.card .price{font-family:'Plus Jakarta Sans';font-weight:800;color:var(--clay);font-size:1.15rem;margin-top:2px}
.card .desc{font-size:.86rem;color:var(--muted)}
.card-foot{margin-top:auto;padding:16px;padding-top:0}
.empty-state{grid-column:1/-1;text-align:center;padding:50px 20px;color:var(--muted)}
.empty-state .ico{font-size:2.4rem;margin-bottom:8px}

/* ---------- UMKM cards (unggulan) ---------- */
.umkm-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.umkm-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;text-align:center;transition:.2s}
.umkm-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-hover);border-color:transparent}
.umkm-card .cover{height:84px;background:linear-gradient(120deg,var(--teal),var(--cat-wisata))}
.umkm-card .logo{width:70px;height:70px;border-radius:18px;background:#fff;margin:-35px auto 10px;
  display:grid;place-items:center;font-size:1.8rem;box-shadow:var(--shadow);border:3px solid #fff}
.umkm-card h3{font-size:1.05rem;padding:0 12px}
.umkm-card .meta{color:var(--muted);font-size:.84rem;margin:4px 0 14px}
.umkm-card .pad{padding:0 16px 18px}

/* ---------- CTA banner ---------- */
.cta-banner{background:linear-gradient(120deg,var(--teal),var(--teal-dark));
  border-radius:24px;padding:48px;color:#fff;text-align:center;position:relative;overflow:hidden}
.cta-banner::after{content:"◆ ◆ ◆ ◆ ◆";position:absolute;top:14px;right:20px;
  opacity:.12;font-size:1.4rem;letter-spacing:8px}
.cta-banner h2{font-size:2rem;margin-bottom:10px}
.cta-banner p{opacity:.9;max-width:520px;margin:0 auto 22px}

/* ---------- Footer ---------- */
.footer{background:var(--ink);color:#cfd9d7;padding:54px 0 26px;margin-top:40px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:32px}
.footer h4{color:#fff;margin-bottom:14px;font-size:1rem}
.footer .brand{color:#fff;margin-bottom:12px}
.footer .brand .mark{background:var(--clay)}
.footer a{display:block;padding:5px 0;font-size:.9rem;color:#a9b8b5}
.footer a:hover{color:#fff}
.footer p{font-size:.9rem;color:#9fb0ad;max-width:280px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:34px;padding-top:20px;
  text-align:center;font-size:.85rem;color:#8aa09c}

/* ---------- Auth pages ---------- */
.auth-wrap{min-height:calc(100vh - 70px);display:grid;grid-template-columns:1fr 1fr}
.auth-side{background:linear-gradient(150deg,var(--teal),var(--teal-dark));color:#fff;
  padding:56px;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden}
.auth-side::after{content:"";position:absolute;inset:0;
  background:radial-gradient(500px 300px at 80% 20%,rgba(224,122,63,.25),transparent 60%)}
.auth-side .inner{position:relative;z-index:1}
.auth-side h2{font-size:2rem;margin-bottom:12px}
.auth-side p{opacity:.9;max-width:360px}
.auth-side ul{list-style:none;margin-top:24px;display:flex;flex-direction:column;gap:12px}
.auth-side li{display:flex;gap:10px;align-items:center;font-size:.95rem}
.auth-side li .chk{width:26px;height:26px;border-radius:8px;background:rgba(255,255,255,.18);
  display:grid;place-items:center}
.auth-main{display:flex;align-items:center;justify-content:center;padding:40px 20px}
.auth-card{width:100%;max-width:440px}
.auth-card .brand{margin-bottom:8px}
.auth-card h1{font-size:1.6rem;margin-bottom:6px}
.auth-card .sub{color:var(--muted);margin-bottom:24px}

/* ---------- Forms ---------- */
.field{margin-bottom:16px}
.field label{display:block;font-size:.88rem;font-weight:600;margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;padding:12px 14px;border:1.5px solid var(--line);
  border-radius:var(--radius-sm);font-family:inherit;font-size:.95rem;background:#fff;color:var(--ink);outline:none;transition:.15s}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-soft)}
.field textarea{resize:vertical;min-height:90px}
.field .hint{font-size:.8rem;color:var(--muted);margin-top:4px}
.row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-foot{margin-top:8px;font-size:.9rem;color:var(--muted);text-align:center}
.form-foot a{color:var(--teal);font-weight:600}

/* ---------- Dashboard / Admin layout ---------- */
.app-shell{display:grid;grid-template-columns:248px 1fr;min-height:calc(100vh - 70px);align-items:stretch}
.sidebar{background:var(--teal-dark);color:#cfe3e0;padding:0}
.sidebar .sb-inner{padding:24px 16px;position:sticky;top:70px}
.sidebar .sb-title{font-size:.75rem;text-transform:uppercase;letter-spacing:.06em;color:#7fb3ad;
  padding:0 12px;margin:18px 0 8px}
.sidebar a{display:flex;align-items:center;gap:10px;padding:11px 12px;border-radius:10px;
  font-size:.92rem;font-weight:500;color:#cfe3e0;margin-bottom:2px}
.sidebar a:hover{background:rgba(255,255,255,.08)}
.sidebar a.active{background:var(--clay);color:#fff}
.app-main{padding:30px;overflow:auto}
.app-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:14px}
.app-head h1{font-size:1.6rem}
.app-head .sub{color:var(--muted);font-size:.92rem}

/* ---------- Stat cards ---------- */
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:26px}
.stat{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:20px}
.stat .ico{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;font-size:1.3rem;margin-bottom:12px}
.stat .num{font-family:'Plus Jakarta Sans';font-size:2rem;font-weight:800}
.stat .lbl{color:var(--muted);font-size:.88rem}

/* ---------- Panels & tables ---------- */
.panel{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;margin-bottom:24px}
.panel-head{padding:18px 20px;border-bottom:1px solid var(--line);display:flex;
  justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
.panel-head h3{font-size:1.1rem}
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:.9rem}
th,td{text-align:left;padding:13px 20px;border-bottom:1px solid var(--line);vertical-align:middle}
th{font-size:.76rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:700}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover{background:var(--sand)}
.td-prod{display:flex;align-items:center;gap:12px}
.td-prod img{width:46px;height:46px;border-radius:8px;object-fit:cover}
.badge{font-size:.74rem;font-weight:700;padding:4px 10px;border-radius:50px;display:inline-block}
.badge-ok{background:rgba(37,211,102,.15);color:#1a8c47}
.badge-wait{background:rgba(224,122,63,.16);color:var(--clay-dark)}
.badge-off{background:#eee;color:#777}
.badge-rej{background:rgba(192,57,43,.14);color:#c0392b}
.badge-paid{background:rgba(14,92,92,.14);color:var(--teal)}
.badge-exp{background:rgba(155,93,229,.14);color:#7a3fb0}
.actions{display:flex;gap:8px;flex-wrap:wrap}

/* ---------- Profile page ---------- */
.profile-banner{height:220px;background:linear-gradient(120deg,var(--teal),var(--cat-wisata));position:relative}
.profile-banner img{width:100%;height:100%;object-fit:cover;opacity:.9}
.profile-head{display:flex;gap:22px;align-items:flex-end;margin-top:-60px;position:relative;z-index:2;flex-wrap:wrap}
.profile-logo{width:120px;height:120px;border-radius:24px;background:#fff;display:grid;place-items:center;
  font-size:3rem;box-shadow:var(--shadow);border:4px solid #fff}
.profile-info{flex:1;padding-bottom:6px;min-width:240px}
.profile-info h1{font-size:1.9rem}
.profile-meta{display:flex;gap:16px;flex-wrap:wrap;color:var(--muted);font-size:.92rem;margin-top:6px}
.profile-meta span{display:flex;align-items:center;gap:6px}
.profile-grid{display:grid;grid-template-columns:1fr 320px;gap:30px;margin-top:30px}
.about-box,.contact-box{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;margin-bottom:20px}
.contact-box h3{margin-bottom:14px}
.contact-row{display:flex;gap:10px;align-items:flex-start;padding:9px 0;border-bottom:1px solid var(--line);font-size:.92rem}
.contact-row:last-of-type{border-bottom:none}
.contact-row .k{color:var(--muted);min-width:80px}

/* ---------- Product detail ---------- */
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-top:30px}
.detail-img{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:1/1}
.detail-img img{width:100%;height:100%;object-fit:cover}
.detail-info h1{font-size:2rem;margin:8px 0}
.detail-info .price{font-family:'Plus Jakarta Sans';font-size:2rem;font-weight:800;color:var(--clay);margin:14px 0}
.detail-info .by{color:var(--muted);margin-bottom:18px}
.detail-info .by a{color:var(--teal);font-weight:600}
.detail-desc{margin:20px 0;color:#445;line-height:1.7}
.breadcrumb{font-size:.86rem;color:var(--muted);margin-top:18px}
.breadcrumb a:hover{color:var(--teal)}

/* ---------- Page header (generic) ---------- */
.page-hero{background:var(--teal-soft);padding:40px 0;border-bottom:1px solid var(--line)}
.page-hero h1{font-size:2rem}
.page-hero p{color:var(--muted)}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .hero .container{grid-template-columns:1fr}
  .hero-art{order:-1}
  .product-grid,.cat-grid,.umkm-grid,.stat-grid{grid-template-columns:repeat(2,1fr)}
  .detail-grid,.profile-grid{grid-template-columns:1fr}
  .auth-wrap{grid-template-columns:1fr}
  .auth-side{display:none}
  .app-shell{grid-template-columns:1fr}
  .sidebar{position:static;height:auto}
  .sidebar .sb-inner{position:static;display:flex;gap:6px;overflow-x:auto;padding:12px 14px}
  .sidebar .sb-title{display:none}
  .sidebar a{white-space:nowrap;margin-bottom:0}
  /* Beranda dikecualikan: tetap layout desktop penuh */
  #view-beranda .hero .container{grid-template-columns:1.1fr .9fr}
  #view-beranda .hero-art{order:0}
  #view-beranda .product-grid,#view-beranda .cat-grid,#view-beranda .umkm-grid{grid-template-columns:repeat(4,1fr)}
}
@media (max-width:640px){
  .nav-links{display:none;position:absolute;top:70px;left:0;right:0;background:var(--sand);
    flex-direction:column;padding:12px;border-bottom:1px solid var(--line);box-shadow:var(--shadow)}
  .nav-links.open{display:flex}
  .nav-links a{width:100%}
  .nav-toggle{display:block}
  .product-grid,.cat-grid,.umkm-grid,.stat-grid{grid-template-columns:1fr}
  .row-2{grid-template-columns:1fr}
  .hero-stats{gap:18px}
  .cta-banner{padding:32px 22px}
  th,td{padding:11px 14px}
  /* Beranda dikecualikan: navbar & grid tetap versi desktop */
  body:has(#view-beranda.active) .nav-links{display:flex;position:static;flex-direction:row;
    background:none;padding:0;border:none;box-shadow:none;width:auto}
  body:has(#view-beranda.active) .nav-links a{width:auto}
  body:has(#view-beranda.active) .nav-toggle{display:none}
  #view-beranda .product-grid,#view-beranda .cat-grid,#view-beranda .umkm-grid{grid-template-columns:repeat(4,1fr)}
  #view-beranda .cta-banner{padding:48px}
}


/* ---------- SPA view switching ---------- */
.view{display:none}
.view.active{display:block}
body.app-mode .site-header{display:none} /* dashboard/admin punya header sendiri */

/* ---------- Landing page: selalu tampil desktop penuh ----------
   Beranda dikunci ke lebar desktop minimum. Di layar sempit (HP),
   halaman bisa di-scroll horizontal, bukan menyusut ke 1 kolom.
   Halaman lain (dashboard, admin, form, login) tetap responsif normal. */
#view-beranda{min-width:1180px}
body:has(#view-beranda.active){overflow-x:auto}
/* Header publik ikut lebar desktop saat berada di beranda agar navbar tidak terpotong */
body:has(#view-beranda.active) #public-header .container{min-width:1180px}
.spa-note{position:fixed;bottom:14px;left:14px;z-index:99;background:var(--ink);color:#fff;
  font-size:.78rem;padding:8px 14px;border-radius:50px;opacity:.85;box-shadow:var(--shadow)}

/* ---------- Form page (menggantikan modal) ---------- */
.form-page{padding:32px 0 64px;min-height:calc(100vh - 70px)}
.form-page-head{display:flex;align-items:flex-start;gap:16px;margin-bottom:22px}
.form-page-head h1{font-size:1.7rem}
.form-page-head .sub{color:var(--muted);font-size:.95rem;margin-top:2px}
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  max-width:760px;box-shadow:var(--shadow);overflow:hidden;animation:formIn .22s ease}
@keyframes formIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
#form-page-body{padding:28px 30px}
.form-page-foot{display:flex;gap:12px;justify-content:flex-end;padding:18px 30px;
  border-top:1px solid var(--line);background:var(--sand)}
.img-preview{width:100%;aspect-ratio:16/9;border:1.5px dashed var(--line);border-radius:var(--radius-sm);
  overflow:hidden;display:grid;place-items:center;color:var(--muted);font-size:.85rem;background:var(--sand)}
.img-preview img{width:100%;height:100%;object-fit:cover}
.toast{position:fixed;bottom:24px;right:24px;z-index:300;background:var(--teal);color:#fff;
  padding:13px 20px;border-radius:var(--radius-sm);box-shadow:var(--shadow-hover);
  font-size:.92rem;font-weight:600;transform:translateY(80px);opacity:0;transition:.28s}
.toast.show{transform:none;opacity:1}
.toast.err{background:#c0392b}
.form-err{color:#c0392b;font-size:.82rem;margin-top:4px;display:none}
.field input.invalid,.field select.invalid,.field textarea.invalid{border-color:#c0392b}
.kt-sec{font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;
  color:var(--teal);margin:22px 0 12px;padding-bottom:6px;border-bottom:2px solid var(--teal-soft)}
.kt-sec:first-of-type{margin-top:4px}

/* ---------- Setting Web: tab ---------- */
.settings-tabs{display:flex;gap:6px;flex-wrap:wrap;border-bottom:1px solid var(--line);margin-bottom:24px}
.settings-tabs button{background:none;border:none;font-family:inherit;font-size:.92rem;font-weight:600;
  color:var(--muted);padding:11px 16px;cursor:pointer;border-bottom:2.5px solid transparent;margin-bottom:-1px;transition:.15s}
.settings-tabs button:hover{color:var(--teal)}
.settings-tabs button.active{color:var(--teal);border-bottom-color:var(--teal)}
.settings-pane{display:none}
.settings-pane.active{display:block}
.settings-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:20px;
  padding-top:18px;border-top:1px solid var(--line)}

/* ---------- Upload field (file → preview) ---------- */
.upload-drop{border:1.5px dashed var(--line);border-radius:var(--radius-sm);background:var(--sand);
  padding:14px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:.15s}
.upload-drop:hover{border-color:var(--teal);background:var(--teal-soft)}
.upload-drop .ic{width:42px;height:42px;border-radius:10px;background:#fff;display:grid;place-items:center;
  font-size:1.2rem;flex-shrink:0;border:1px solid var(--line)}
.upload-drop .txt{font-size:.88rem;color:var(--muted);line-height:1.3}
.upload-drop .txt strong{color:var(--teal);display:block}
.upload-drop input[type=file]{display:none}
/* preview multi-foto (thumbnail grid dengan tombol hapus) */
.thumbs{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}
.thumb-item{position:relative;width:84px;height:84px;border-radius:var(--radius-sm);overflow:hidden;
  border:1px solid var(--line);background:var(--sand)}
.thumb-item img{width:100%;height:100%;object-fit:cover}
.thumb-item .rm{position:absolute;top:3px;right:3px;width:22px;height:22px;border-radius:6px;border:none;
  background:rgba(192,57,43,.92);color:#fff;font-size:.9rem;line-height:1;cursor:pointer;display:grid;place-items:center}
.thumb-item.cover-badge::after{content:"Utama";position:absolute;bottom:0;left:0;right:0;
  background:var(--teal);color:#fff;font-size:.62rem;text-align:center;padding:2px;font-weight:700}
.thumb-single{width:120px;height:120px}
.thumb-banner{width:100%;height:120px}

/* ---------- Carousel produk (detail) ---------- */
.carousel{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);
  aspect-ratio:1/1;background:var(--sand)}
.carousel-track{display:flex;height:100%;transition:transform .35s ease}
.carousel-slide{min-width:100%;height:100%}
.carousel-slide img{width:100%;height:100%;object-fit:cover}
.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);width:42px;height:42px;border-radius:50%;
  border:none;background:rgba(255,255,255,.9);box-shadow:var(--shadow);cursor:pointer;font-size:1.1rem;
  display:grid;place-items:center;color:var(--ink);transition:.15s;z-index:2}
.carousel-btn:hover{background:#fff}
.carousel-btn.prev{left:12px}.carousel-btn.next{right:12px}
.carousel-dots{position:absolute;bottom:12px;left:0;right:0;display:flex;justify-content:center;gap:7px;z-index:2}
.carousel-dots button{width:9px;height:9px;border-radius:50%;border:none;background:rgba(255,255,255,.6);cursor:pointer;padding:0}
.carousel-dots button.active{background:#fff;width:22px;border-radius:50px}
.carousel-count{position:absolute;top:12px;right:12px;background:rgba(8,40,40,.6);color:#fff;
  font-size:.75rem;font-weight:600;padding:3px 9px;border-radius:50px;z-index:2}
/* mini-carousel di kartu produk (hanya tampilkan foto pertama + badge jumlah) */
.card .thumb .multi-badge{position:absolute;bottom:10px;right:10px;background:rgba(8,40,40,.7);color:#fff;
  font-size:.72rem;font-weight:600;padding:3px 8px;border-radius:50px;display:flex;align-items:center;gap:4px}

/* ---------- Mitra: logo slider (marquee otomatis) ---------- */
.mitra-slider{overflow:hidden;position:relative;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.mitra-track{display:flex;gap:18px;width:max-content;animation:mitraScroll 28s linear infinite}
.mitra-slider:hover .mitra-track{animation-play-state:paused}
@keyframes mitraScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.mitra-item{flex:0 0 auto;width:180px;height:110px;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:8px;cursor:pointer;transition:.18s;padding:14px;text-decoration:none}
.mitra-item:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover);border-color:transparent}
.mitra-item .logo-box{width:54px;height:54px;border-radius:12px;background:var(--teal-soft);
  display:grid;place-items:center;overflow:hidden;font-size:1.6rem;color:var(--teal);flex-shrink:0}
.mitra-item .logo-box img{width:100%;height:100%;object-fit:contain}
.mitra-item .nm{font-size:.86rem;font-weight:600;color:var(--ink);text-align:center;line-height:1.2}
/* halaman detail mitra */
.mitra-detail{max-width:720px;margin:0 auto;text-align:center}
.mitra-detail .big-logo{width:130px;height:130px;border-radius:24px;background:var(--teal-soft);
  display:grid;place-items:center;margin:0 auto 22px;overflow:hidden;font-size:3rem;color:var(--teal);box-shadow:var(--shadow)}
.mitra-detail .big-logo img{width:100%;height:100%;object-fit:contain}
.mitra-detail h1{font-size:2rem;margin-bottom:14px}
.mitra-detail .desc{color:#445;line-height:1.8;font-size:1.05rem;margin-bottom:24px}
/* grid mitra di admin */
.mitra-admin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}
.mitra-admin-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:16px;text-align:center}
.mitra-admin-card .logo-box{width:60px;height:60px;border-radius:12px;background:var(--teal-soft);
  display:grid;place-items:center;margin:0 auto 10px;overflow:hidden;font-size:1.7rem;color:var(--teal)}
.mitra-admin-card .logo-box img{width:100%;height:100%;object-fit:contain}
.mitra-admin-card h4{font-size:1rem;margin-bottom:4px}
.mitra-admin-card .lk{font-size:.78rem;color:var(--muted);word-break:break-all;margin-bottom:12px}

/* ---------- Link sosial & marketplace (profil publik) ---------- */
.social-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}
.social-btn{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;font-size:1.15rem;
  background:var(--teal-soft);color:var(--teal);border:1px solid var(--line);transition:.15s;text-decoration:none}
.social-btn:hover{background:var(--teal);color:#fff;transform:translateY(-2px)}
.market-list{display:flex;flex-direction:column;gap:8px;margin-top:8px}
.market-btn{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:var(--radius-sm);
  border:1px solid var(--line);background:#fff;font-weight:600;font-size:.9rem;color:var(--ink);transition:.15s;text-decoration:none}
.market-btn:hover{border-color:var(--teal);background:var(--teal-soft)}
.market-btn .mk-ic{width:26px;height:26px;border-radius:7px;display:grid;place-items:center;color:#fff;font-size:.8rem;flex-shrink:0;font-weight:800}
.mk-shopee{background:#ee4d2d}.mk-tokopedia{background:#42b549}.mk-tiktokshop{background:#000}.mk-lazada{background:#0f146d}.mk-web{background:var(--teal)}
/* tombol share */
.share-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.share-btn{display:inline-flex;align-items:center;gap:7px;padding:8px 13px;border-radius:50px;
  font-size:.84rem;font-weight:600;color:#fff;border:none;cursor:pointer;transition:.15s;text-decoration:none}
.share-btn:hover{opacity:.88;transform:translateY(-1px)}
.sh-wa{background:var(--wa)}.sh-fb{background:#1877f2}.sh-tw{background:#111}.sh-tg{background:#229ED9}.sh-copy{background:var(--muted)}
/* CTA marketplace di kartu/detail produk */
.btn-market{background:var(--clay);color:#fff}
.btn-market:hover{background:var(--clay-dark)}

/* ---------- Dashboard analitik akses publik ---------- */
.analytics-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-bottom:26px}
.analytics-grid .panel{margin-bottom:0}
.an-section-title{font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;
  color:var(--muted);margin:30px 0 14px}
.mini-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}
.mini-stat{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:16px}
.mini-stat .v{font-family:'Plus Jakarta Sans';font-size:1.5rem;font-weight:800;color:var(--ink)}
.mini-stat .l{font-size:.8rem;color:var(--muted);margin-top:2px}
.mini-stat .t{font-size:.72rem;font-weight:700;margin-top:6px}
.t-up{color:#1a8c47}.t-down{color:#c0392b}
/* bar chart tren */
.bars{display:flex;align-items:flex-end;gap:10px;height:160px;padding:10px 4px 0}
.bars .bar{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;height:100%;justify-content:flex-end}
.bars .bar .col{width:100%;max-width:38px;background:linear-gradient(var(--teal),var(--cat-wisata));
  border-radius:6px 6px 0 0;transition:.4s;min-height:4px}
.bars .bar:hover .col{filter:brightness(1.1)}
.bars .bar .lb{font-size:.72rem;color:var(--muted)}
.bars .bar .vn{font-size:.7rem;font-weight:700;color:var(--ink)}
/* progress bar (sumber trafik) */
.prog-row{margin-bottom:14px}
.prog-row .top{display:flex;justify-content:space-between;font-size:.85rem;margin-bottom:5px}
.prog-row .top .pv{font-weight:700}
.prog-bar{height:9px;border-radius:50px;background:var(--sand);overflow:hidden}
.prog-bar span{display:block;height:100%;border-radius:50px}
.src-1{background:var(--teal)}.src-2{background:var(--clay)}.src-3{background:var(--cat-hotel)}.src-4{background:var(--cat-kriya)}
/* perangkat donut-ish list */
.device-row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--line)}
.device-row:last-child{border-bottom:none}
.device-row .ic{font-size:1.3rem}
.device-row .nm{flex:1;font-size:.9rem}
.device-row .pv{font-weight:800;font-family:'Plus Jakarta Sans'}
/* ranking list */
.rank-row{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--line);font-size:.9rem}
.rank-row:last-child{border-bottom:none}
.rank-row .rk{width:24px;height:24px;border-radius:7px;background:var(--teal-soft);color:var(--teal);
  display:grid;place-items:center;font-weight:800;font-size:.8rem;flex-shrink:0}
.rank-row .nm{flex:1}
.rank-row .nm a:hover{color:var(--teal)}
.rank-row .vv{font-weight:700;color:var(--muted);font-size:.85rem}

/* ---------- Rich Text Editor (gaya WordPress) ---------- */
.rte{border:1.5px solid var(--line);border-radius:var(--radius-sm);overflow:hidden;background:#fff;transition:.15s}
.rte:focus-within{border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-soft)}
.rte-toolbar{display:flex;flex-wrap:wrap;gap:2px;padding:6px 8px;background:var(--sand);border-bottom:1px solid var(--line)}
.rte-toolbar button{min-width:32px;height:30px;border:none;background:none;border-radius:6px;cursor:pointer;
  font-size:.9rem;color:var(--ink);display:grid;place-items:center;transition:.12s;font-family:inherit;padding:0 6px}
.rte-toolbar button:hover{background:var(--teal-soft);color:var(--teal)}
.rte-toolbar button.on{background:var(--teal);color:#fff}
.rte-toolbar .sep{width:1px;background:var(--line);margin:3px 4px}
.rte-toolbar select{border:1px solid var(--line);border-radius:6px;background:#fff;font-family:inherit;
  font-size:.82rem;padding:2px 6px;cursor:pointer;color:var(--ink)}
.rte-area{min-height:140px;max-height:340px;overflow-y:auto;padding:12px 14px;font-size:.95rem;line-height:1.6;outline:none;color:var(--ink)}
.rte-area:empty::before{content:attr(data-ph);color:var(--muted)}
.rte-area p{margin:0 0 8px}.rte-area p:last-child{margin-bottom:0}
.rte-area h2{font-size:1.3rem;margin:10px 0 6px;font-family:'Plus Jakarta Sans'}
.rte-area h3{font-size:1.1rem;margin:8px 0 5px;font-family:'Plus Jakarta Sans'}
.rte-area ul,.rte-area ol{margin:0 0 8px;padding-left:22px}
.rte-area li{margin-bottom:3px}
.rte-area a{color:var(--teal);text-decoration:underline}
.rte-area blockquote{border-left:3px solid var(--teal);margin:8px 0;padding:4px 0 4px 14px;color:var(--muted);font-style:italic}
/* tampilan konten kaya di publik */
.rich{line-height:1.7;color:#445}
.rich p{margin:0 0 12px}.rich p:last-child{margin-bottom:0}
.rich h2{font-size:1.35rem;margin:16px 0 8px;color:var(--ink);font-family:'Plus Jakarta Sans'}
.rich h3{font-size:1.15rem;margin:14px 0 7px;color:var(--ink);font-family:'Plus Jakarta Sans'}
.rich ul,.rich ol{margin:0 0 12px;padding-left:24px}
.rich li{margin-bottom:5px}
.rich a{color:var(--teal);text-decoration:underline}
.rich a:hover{color:var(--teal-dark)}
.rich blockquote{border-left:3px solid var(--teal);margin:12px 0;padding:6px 0 6px 16px;color:var(--muted);font-style:italic}
.rich strong{font-weight:700}.rich em{font-style:italic}


/* =========================================================
   Pelengkap server-side (PHP/MVC) — tidak ada di prototipe
   ========================================================= */

/* Alert / flash */
.alert{padding:12px 16px;border-radius:var(--radius-sm);font-size:.92rem;margin:0 0 14px;
  display:flex;align-items:center;gap:10px;border:1px solid transparent}
.alert-success{background:#e7f6ee;color:#1d7a4d;border-color:#bfe6d0}
.alert-error{background:#fdecea;color:#c0392b;border-color:#f3c9c2}
.alert-info{background:var(--teal-soft);color:var(--teal-dark);border-color:#c9e2dc}
.flash-wrap{max-width:1180px;margin:16px auto 0;padding:0 24px}

/* Badge status (alias ke gaya prototipe) */
.badge-approved{background:rgba(47,143,131,.16);color:var(--cat-wisata)}
.badge-pending{background:rgba(224,122,63,.16);color:var(--clay-dark)}
.badge-rejected{background:rgba(201,42,42,.12);color:#c0392b}
.badge-eksekutif{background:var(--clay);color:#fff}
.badge-biasa{background:var(--teal-soft);color:var(--teal-dark)}

/* Kotak akun demo di halaman login */
.demo-box{margin-top:18px;padding:12px 14px;background:var(--teal-soft);
  border-radius:var(--radius-sm);font-size:.85rem;line-height:1.7}
.demo-box code{background:#fff;padding:2px 6px;border-radius:4px}

/* Util kecil */
.text-muted{color:var(--muted)}
.mt-2{margin-top:8px}.mt-3{margin-top:14px}.mt-4{margin-top:20px}

/* =========================================================
   Selaras dashboard/admin server-side dengan bahasa visual patokan
   (memetakan kelas dash-* ke gaya panel/stat/sidebar prototipe)
   ========================================================= */

/* Shell dashboard */
.dash-wrap{display:grid;grid-template-columns:248px 1fr;gap:24px;align-items:start;
  max-width:1180px;margin:0 auto;padding:24px}
.dash-main{min-width:0}

/* Sidebar gelap ala prototipe */
.dash-side{background:var(--teal-dark);color:#cfe3e0;border:none;border-radius:var(--radius);
  padding:18px 14px;position:sticky;top:86px}
.dash-side .grp{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;
  color:#8fb8b2;padding:14px 10px 6px;font-weight:700}
.dash-side a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;
  color:#dcebe9;font-weight:500;font-size:.92rem;margin-bottom:2px}
.dash-side a:hover{background:rgba(255,255,255,.08);color:#fff}
.dash-side a.active{background:var(--clay);color:#fff}

/* Kartu statistik -> gaya .stat prototipe */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:18px;margin-bottom:24px}
.stat-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:20px}
.stat-card .num{font-family:'Plus Jakarta Sans',sans-serif;font-size:1.9rem;font-weight:800;color:var(--teal)}
.stat-card .lbl{color:var(--muted);font-size:.85rem;margin-top:4px}

/* Tabel -> gaya panel + table-wrap prototipe */
.tbl{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);overflow:hidden}
.tbl th,.tbl td{padding:12px 14px;text-align:left;border-bottom:1px solid var(--line);font-size:.9rem}
.tbl th{background:var(--teal-soft);color:var(--teal-dark);font-weight:600}
.tbl tr:last-child td{border-bottom:none}
.tbl .actions{display:flex;gap:6px;flex-wrap:wrap}
.tbl-wrap{overflow-x:auto}

/* Kartu form di dashboard */
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:24px;max-width:760px}

@media(max-width:860px){
  .dash-wrap{grid-template-columns:1fr}
  .dash-side{position:static}
}

/* Pelengkap sidebar dashboard (badge SUPER & ikon emoji menu) */
.sidebar .role-badge{font-size:.6rem;background:var(--clay);color:#fff;padding:1px 7px;border-radius:50px;margin-left:6px;letter-spacing:.04em}
.sidebar a .ic{width:20px;text-align:center;display:inline-block}

/* Baris field 2 kolom di form pengaturan */
.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:0 16px}
.hdr-badge{font-size:.7rem;background:var(--clay);color:#fff;padding:2px 8px;border-radius:50px;margin-left:4px}
.app-head-actions{display:flex;gap:8px;flex-wrap:wrap}
