/* ================= RESET GLOBAL ================= */
*{
    margin:0;
    padding:0;
    box-sizing:border-box;
    font-family:'Segoe UI', Arial, sans-serif;
}

/* ================= BODY ================= */
body{
    background:#111;
    color:#fff;
}

/* ================= CONTAINER ================= */
.container{
    max-width:520px;
    margin:auto;
    padding:20px;
}

/* ================= JUDUL ================= */
h2{
    text-align:center;
    font-size:26px;
    letter-spacing:2px;
    color:#f5c16c;
    margin-bottom:6px;
}

p{
    text-align:center;
    font-size:13px;
    color:#aaa;
    margin-bottom:14px;
}

/* ================= INPUT ================= */
input, textarea{
    width:100%;
    padding:14px;
    margin-top:12px;
    background:#1c1c1c;
    border:1px solid #333;
    border-radius:14px;
    color:#fff;
    font-size:14px;
}

textarea{resize:none}

/* ================= MENU CARD ================= */
.menu-card{
    background:#161616;
    margin-top:22px;
    border-radius:22px;
    overflow:hidden;
    box-shadow:0 18px 45px rgba(0,0,0,.6);
}

.menu-card img{
    width:100%;
    height:220px;
    object-fit:cover;
    display:block;
}

.menu-info{
    padding:18px;
}

.menu-info h4{
    font-size:18px;
    color:#f5c16c;
    margin-bottom:6px;
}

.menu-info .desc{
    font-size:13px;
    color:#bbb;
    margin-bottom:10px;
}

.menu-info span{
    display:block;
    font-size:16px;
    font-weight:600;
    margin-bottom:10px;
}

/* ================= CATATAN ================= */
.menu-info .note{
    width:100%;
    padding:10px 12px;
    margin-bottom:12px;
    background:#202020;
    border:1px dashed #444;
    border-radius:12px;
    font-size:13px;
    color:#fff;
}

/* ================= QTY ================= */
.qty{
    display:flex;
    align-items:center;
    gap:14px;
}

.qty button{
    width:40px;
    height:40px;
    border:none;
    border-radius:50%;
    background:linear-gradient(145deg,#f5c16c,#d9a441);
    color:#000;
    font-size:22px;
    font-weight:bold;
}

.qty input{
    width:56px;
    text-align:center;
    border:none;
    background:#222;
    color:#fff;
    border-radius:12px;
    font-size:16px;
}

/* ================= TOTAL ================= */
#total{
    margin:26px 0 16px;
    text-align:center;
    font-size:26px;
    font-weight:bold;
    color:#f5c16c;
}

/* ================= TOMBOL UTAMA ================= */
.order-btn{
    width:100%;
    padding:18px;
    border:none;
    border-radius:22px;
    background:linear-gradient(145deg,#f5c16c,#d9a441);
    color:#000;
    font-size:17px;
    font-weight:bold;
    cursor:pointer;
}

/* ================= HASIL ================= */
#hasil{
    margin-top:18px;
    text-align:center;
}

#hasil a{
    color:#f5c16c;
    font-weight:bold;
    text-decoration:none;
}

/* ================================================= */
/* ================= ICON CART FLOATING ============= */
/* ================================================= */

.cart-floating{
    all: unset;                  /* reset total */
    position: fixed !important;

    top: 18px !important;
    right: 18px !important;
    left: auto !important;
    bottom: auto !important;

    width: 72px;
    height: 72px;
    background: linear-gradient(145deg,#f5c16c,#d9a441);
    color:#000;
    border-radius:50%;

    display:flex !important;
    justify-content:center;
    align-items:center;

    font-size:34px;
    font-weight:bold;
    cursor:pointer;

    box-shadow:0 10px 26px rgba(0,0,0,.6);
    z-index:999999;
}

/* ===== FLOATING CART FINAL ===== */
.cart-floating{
    position:fixed !important;
    top:16px;
    right:16px;
    left:auto !important;

    z-index:99999;

    width:56px;
    height:56px;
    border-radius:50%;

    background:linear-gradient(145deg,#f5c16c,#d9a441);
    color:#000;

    display:flex;
    align-items:center;
    justify-content:center;

    font-size:28px;
    box-shadow:0 8px 20px rgba(0,0,0,.7);
}

/* ===== BADGE JUMLAH ITEM ===== */
#cartCount{
    position:absolute;
    top:-6px;
    right:-6px;

    background:red;
    color:#fff;

    width:20px;
    height:20px;
    border-radius:50%;

    font-size:12px;
    font-weight:bold;

    display:none;
    align-items:center;
    justify-content:center;
}

.cart-icon{
    width:26px;
    height:26px;
    fill:#000; /* HITAM */
}
.menu-card{
    position:relative;
}

/* WATERMARK SOLD OUT */
.soldout-badge{
    position:absolute;
    inset:0;
    background:rgba(0,0,0,.65);
    color:#fff;
    font-size:22px;
    font-weight:bold;
    display:none;
    align-items:center;
    justify-content:center;
    letter-spacing:3px;
    border-radius:14px;
    z-index:5;
}

/* TAMPIL JIKA SOLD OUT */
.menu-card[data-soldout="1"] .soldout-badge{
    display:flex;
}

/* NONAKTIF */
.menu-card[data-soldout="1"] button,
.menu-card[data-soldout="1"] textarea{
    pointer-events:none;
    opacity:.5;
}

/* SOLD OUT MODE */
.menu-card[data-soldout="1"] .qty{
    display:none;
}

.menu-card[data-soldout="1"]::after{
    content:"HABIS";
    display:block;
    background:#444;
    color:#fff;
    text-align:center;
    padding:12px;
    border-radius:12px;
    margin-top:12px;
    font-weight:bold;
    letter-spacing:2px;
}

/* disable catatan */
.menu-card[data-soldout="1"] textarea{
    pointer-events:none;
    opacity:.4;
}
.menu-card.soldout{
    opacity:.55;
    pointer-events:none;
}

.menu-card.soldout img{
    filter:grayscale(100%);
}
/* ===== FILTER KATEGORI ===== */
.filter-bar{
    display:flex;
    gap:8px;
    padding:10px;
    position:sticky;
    top:0;
    background:#fff;
    z-index:99;
}

.filter-btn{
    flex:1;
    padding:10px;
    border:none;
    border-radius:10px;
    font-weight:bold;
    background:#eee;
}

.filter-btn.active{
    background:#00aa13;
    color:#fff;
}

.kategori-title{
    margin:14px 10px 6px;
    font-size:18px;
    font-weight:bold;
}

.kategori-wrap{
    display:block;
}

