/* ============================================================
   COFFEE GATEWAY — TEMA MODERN
   Ditulis ulang: dua aksen (hijau + karamel), gradient,
   hierarki teks lebih tegas. Struktur HTML tidak diubah.
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,500;9..144,600;9..144,900&family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap');

:root{
  --bg:#F6F0E6;            /* krem hangat */
  --bg-2:#FFFCF6;
  --surface:#FFFFFF;
  --ink:#241C16;          /* teks utama */
  --muted:#8C8273;        /* teks sekunder */
  --line:#ECE3D3;

  --brand:#1E5C45;        /* hijau hutan - primer */
  --brand-2:#2E8B66;
  --caramel:#E0922F;      /* amber/karamel - sekunder */
  --caramel-2:#F2B24A;
  --berry:#B8432F;        /* merah bata - hapus/danger */
  --info:#3E6CC4;

  --grad-brand:linear-gradient(135deg,#1E5C45,#2E8B66);
  --brand-dark:#143b2d;   /* hijau gelap turunan */
  --order-bg:#13402f;     /* latar halaman pelanggan */
  --grad-warm:linear-gradient(135deg,#F2B24A,#E0922F 55%,#CE7C2A);

  --paid-fg:#1E7A4F;  --paid-bg:#DCF0E2;
  --pend-fg:#A9750F;  --pend-bg:#FBEBC8;
  --fail-fg:#B8432F;  --fail-bg:#F6DBD2;
  --exp-fg:#6B6256;   --exp-bg:#E8E1D4;

  --r:16px; --r-sm:11px; --r-lg:22px;
  --shadow:0 10px 30px -16px rgba(40,28,16,.28);
  --shadow-sm:0 4px 14px -8px rgba(40,28,16,.22);
  --maxw:1120px;
}

*{box-sizing:border-box}
html{ -webkit-text-size-adjust:100% }
body{
  margin:0;background:var(--bg);color:var(--ink);
  font-family:'Plus Jakarta Sans',system-ui,Segoe UI,sans-serif;
  font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased;
}
h1,h2,h3{font-family:'Fraunces',Georgia,serif;line-height:1.12;margin:0 0 .4em;letter-spacing:-.01em;font-weight:900}
h1{font-size:1.9rem} h2{font-size:1.4rem} h3{font-size:1.05rem;font-weight:600}
a{color:var(--brand);text-decoration:none}
p{margin:0 0 .8em}
small{color:var(--muted)}

/* ---------- LAYOUT ---------- */
.wrap{max-width:560px;margin:0 auto;padding:22px 18px 60px}
.topbar{
  background:var(--grad-brand);color:#fff;padding:14px 22px;
  display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;
  box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:30;
}
.topbar>b{font-family:'Fraunces',serif;font-size:1.15rem;font-weight:900;letter-spacing:-.01em}
.nav{display:flex;flex-wrap:wrap;gap:4px}
.nav a{
  color:rgba(255,255,255,.82);font-weight:600;font-size:13.5px;
  padding:7px 13px;border-radius:999px;transition:background .15s,color .15s;
}
.nav a:hover{background:rgba(255,255,255,.16);color:#fff}

/* konten admin (apa pun setelah topbar) diberi lebar & padding */
.topbar ~ h2,
.topbar ~ .grid,
.topbar ~ .card,
.topbar ~ .two,
.topbar ~ p{max-width:var(--maxw);margin-left:auto;margin-right:auto}
.topbar ~ h2{padding:26px 22px 4px}
.topbar ~ .grid,.topbar ~ .card,.topbar ~ .two{margin-top:18px}
body>.card,body>.grid,body>.two{padding-left:22px;padding-right:22px}

/* ---------- CARDS ---------- */
.card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r);
  padding:22px;box-shadow:var(--shadow-sm);margin:0 auto 20px;max-width:var(--maxw);
}
.card h3{color:var(--muted);font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;
  font-size:12.5px;text-transform:uppercase;letter-spacing:.06em}
.card h2{font-size:1.7rem}
.two{display:grid;grid-template-columns:1fr 1fr;gap:20px;max-width:var(--maxw);margin:0 auto}
.two .card{margin-bottom:0}

/* Dashboard stat cards — tiap kartu beda aksen biar tidak monoton */
.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;max-width:var(--maxw);margin:0 auto 20px}
.grid .card{position:relative;overflow:hidden;margin:0}
.grid .card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px}
.grid .card:nth-child(1)::before{background:var(--brand)}
.grid .card:nth-child(2)::before{background:var(--caramel)}
.grid .card:nth-child(3)::before{background:var(--info)}
.grid .card:nth-child(4)::before{background:var(--berry)}
.grid .card:nth-child(1) h2{color:var(--brand)}
.grid .card:nth-child(2) h2{color:var(--caramel)}
.grid .card:nth-child(3) h2{color:var(--info)}
.grid .card:nth-child(4) h2{color:var(--berry)}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:7px;
  font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;font-size:14px;
  padding:11px 18px;border-radius:999px;border:1.5px solid var(--line);
  background:var(--surface);color:var(--ink);cursor:pointer;text-decoration:none;
  transition:transform .14s,box-shadow .14s,background .14s,border-color .14s;
}
.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.btn.green,.btn.pos-save,.pos-save{
  background:var(--grad-brand);color:#fff;border-color:transparent;
  box-shadow:0 8px 18px -10px rgba(30,92,69,.7);
}
.btn.red,.cart-remove{
  background:#fff;color:var(--berry);border-color:rgba(184,67,47,.35);
}
.btn.red:hover{background:var(--berry);color:#fff;border-color:transparent}

/* ---------- FORMS ---------- */
label{display:block;font-weight:700;font-size:13px;margin:14px 0 6px;color:var(--ink)}
input,select,textarea{
  width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:var(--r-sm);
  background:var(--bg-2);font:inherit;color:var(--ink);transition:border-color .15s,box-shadow .15s;
}
input:focus,select:focus,textarea:focus{
  outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(46,139,102,.18);background:#fff;
}
textarea{min-height:84px;resize:vertical}

/* ---------- TABLE ---------- */
table{width:100%;border-collapse:collapse;font-size:14px}
th{
  text-align:left;font-weight:800;font-size:11.5px;letter-spacing:.05em;text-transform:uppercase;
  color:var(--muted);padding:10px 12px;border-bottom:2px solid var(--line);
}
td{padding:12px;border-bottom:1px solid var(--line);vertical-align:middle}
tr:last-child td{border-bottom:none}
table img{border-radius:9px;object-fit:cover}

/* ---------- BADGES ---------- */
.badge{
  display:inline-block;padding:4px 11px;border-radius:999px;font-size:12px;font-weight:800;
  letter-spacing:.02em;text-transform:capitalize;background:var(--exp-bg);color:var(--exp-fg);
}
.badge.paid{background:var(--paid-bg);color:var(--paid-fg)}
.badge.pending{background:var(--pend-bg);color:var(--pend-fg)}
.badge.failed{background:var(--fail-bg);color:var(--fail-fg)}
.badge.expired{background:var(--exp-bg);color:var(--exp-fg)}

.muted{color:var(--muted)}
.logo,.logo-preview,.app-logo{border-radius:12px;max-width:120px;height:auto;box-shadow:var(--shadow-sm)}
.menu-img{border-radius:9px}

/* ============================================================
   HALAMAN PELANGGAN (mobile-first)
   ============================================================ */
.mobile-order-body{background:var(--order-bg)}
.mobile-shell{max-width:480px;margin:0 auto;padding-bottom:96px;background:var(--bg)}

.app-hero,.hero{
  background:var(--grad-brand);color:#fff;padding:26px 22px 30px;
  border-radius:0 0 28px 28px;position:relative;overflow:hidden;
}
.app-hero::after{ /* motif matahari retro */
  content:"";position:absolute;right:-70px;top:-70px;width:220px;height:220px;border-radius:50%;
  background:repeating-conic-gradient(from 0deg,rgba(242,178,74,.28) 0 12deg,transparent 12deg 24deg);
}
.hero-topline{display:flex;align-items:center;gap:14px;position:relative;z-index:2}
.app-hero small{color:rgba(255,255,255,.8);font-weight:600}
.app-hero h1{color:#fff;font-size:1.7rem;margin:.1em 0 0}
.app-hero p{color:rgba(255,255,255,.85);margin:.7em 0 0;position:relative;z-index:2}
.table-pill{
  display:inline-flex;align-items:center;gap:6px;margin-top:16px;position:relative;z-index:2;
  background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.28);
  color:#fff;font-weight:700;font-size:13px;padding:7px 14px;border-radius:999px;backdrop-filter:blur(4px);
}

.promo-strip{
  display:flex;gap:10px;overflow-x:auto;padding:16px 22px;margin:0;scrollbar-width:none;
}
.promo-strip::-webkit-scrollbar{display:none}
.promo-strip>div{
  flex:none;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-sm);
  padding:10px 14px;font-size:13px;font-weight:600;box-shadow:var(--shadow-sm);white-space:nowrap;
}

.cat-scroll{display:flex;gap:9px;overflow-x:auto;padding:6px 22px 10px;scrollbar-width:none}
.cat-scroll::-webkit-scrollbar{display:none}
.cat-chip{
  flex:none;display:flex;align-items:center;gap:7px;background:var(--surface);
  border:1.5px solid var(--line);border-radius:999px;padding:9px 16px;
  font-weight:700;font-size:13.5px;color:var(--ink);transition:.15s;
}
.cat-chip span{font-size:15px}
.cat-chip.active,.cat-chip:hover{
  background:var(--grad-warm);color:#3a2208;border-color:transparent;box-shadow:0 6px 14px -8px rgba(224,146,47,.8);
}

.menu-heading{padding:14px 22px 6px}
.menu-heading h2{margin:0;font-size:1.35rem}
.menu-heading p{color:var(--muted);margin:.2em 0 0;font-size:14px}

.food-list{display:flex;flex-direction:column;gap:14px;padding:12px 22px}
.food-card{
  display:flex;gap:14px;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r);padding:12px;box-shadow:var(--shadow-sm);position:relative;
  transition:transform .15s,box-shadow .15s;
}
.food-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.food-card.soldout{opacity:.55;filter:grayscale(.6)}
.soldout-badge{
  position:absolute;top:10px;left:10px;background:var(--berry);color:#fff;
  font-size:10.5px;font-weight:800;padding:3px 9px;border-radius:999px;letter-spacing:.05em;z-index:2;
}
.food-photo{
  width:96px;height:96px;flex:none;border-radius:12px;object-fit:cover;background:var(--bg);
}
.food-empty{display:flex;align-items:center;justify-content:center;color:var(--muted);
  font-size:11px;border:1px dashed var(--line)}
.food-info{flex:1;min-width:0;display:flex;flex-direction:column}
.food-cat{font-size:11.5px;font-weight:700;color:var(--caramel);text-transform:uppercase;letter-spacing:.04em}
.food-info h3{margin:2px 0 2px;font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;font-size:15.5px}
.food-info p{font-size:12.5px;color:var(--muted);margin:0 0 8px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.food-bottom{margin-top:auto;display:flex;align-items:center;justify-content:space-between}
.food-bottom strong{font-size:16px;color:var(--brand);font-weight:800}

.add-circle{
  width:38px;height:38px;border-radius:12px;background:var(--grad-brand);color:#fff;
  display:grid;place-items:center;font-size:22px;font-weight:700;text-decoration:none;
  box-shadow:0 6px 14px -8px rgba(30,92,69,.8);transition:transform .12s;
}
.add-circle:hover{transform:scale(1.08)}
.qty-box{display:flex;align-items:center;gap:4px;background:var(--bg);border-radius:12px;padding:4px}
.qty-btn{
  width:30px;height:30px;border-radius:9px;background:var(--surface);border:1px solid var(--line);
  display:grid;place-items:center;font-size:18px;font-weight:700;color:var(--brand);text-decoration:none;
}
.qty-btn:hover{background:var(--brand);color:#fff;border-color:transparent}
.qty-number{min-width:22px;text-align:center;font-weight:800;font-size:15px}
.soldout-btn{background:var(--exp-bg);color:var(--exp-fg);border:none;border-radius:10px;
  padding:8px 14px;font-weight:700;font-size:12.5px}

.note-form{display:flex;gap:8px;margin-top:10px;align-items:center}
.note-form input{
  flex:1;padding:9px 12px;border:1.5px solid var(--line);border-radius:10px;
  background:var(--bg-2);font-size:13px;
}
.note-form input:focus{border-color:var(--caramel);box-shadow:0 0 0 3px rgba(224,146,47,.18);background:#fff}
.note-save{
  flex:none;border:none;background:var(--bg);color:var(--brand);font-weight:700;font-size:12.5px;
  padding:9px 14px;border-radius:10px;cursor:pointer;transition:.15s;
}
.note-save:hover{background:var(--brand);color:#fff}

.floating-cart{
  position:fixed;left:50%;transform:translateX(-50%);bottom:18px;width:min(440px,calc(100% - 32px));
  background:var(--grad-warm);color:#3a2208;border-radius:16px;padding:14px 20px;
  display:flex;align-items:center;justify-content:space-between;text-decoration:none;
  box-shadow:0 16px 30px -12px rgba(224,146,47,.7);z-index:40;font-weight:700;
}
.floating-cart small{display:block;color:#5a3c12;font-size:11px;font-weight:600}
.floating-cart b{font-size:15px}
.floating-cart span{font-weight:800}

/* ---------- KERANJANG ---------- */
.cart-wrap-mobile,.cart-list-mobile{max-width:480px;margin:0 auto;padding:0 18px}
.cart-card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r);
  padding:14px;margin-bottom:12px;box-shadow:var(--shadow-sm);
}
.cart-item-mobile{display:flex;align-items:center;gap:12px}
.cart-item-main{flex:1;min-width:0}
.item-name,.cart-item-main b{font-weight:700;font-size:15px}
.cart-item-price{color:var(--brand);font-weight:800}
.cart-item-qty,.qty{display:flex;align-items:center;gap:8px;font-weight:700}
.cart-remove{padding:7px 12px;border-radius:10px;font-size:13px;font-weight:700;cursor:pointer}
.cart-total-box{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r);
  padding:18px;margin:8px 18px 16px;max-width:480px;box-shadow:var(--shadow-sm);
  display:flex;align-items:center;justify-content:space-between;
}
.cart-total-box>span{color:var(--muted);font-weight:700}
.cart-total-box>b{font-size:20px;font-weight:800;color:var(--brand)}
.detail-row,.total-row,.row{display:flex;justify-content:space-between;padding:6px 0;font-size:14px}
.total-row{border-top:1.5px dashed var(--line);margin-top:8px;padding-top:12px;font-weight:800;font-size:17px}

/* Ringkasan POS: kontainer menumpuk, tiap baris kiri-kanan */
.pos-total{margin-top:14px;border-top:1.5px dashed var(--line);padding-top:14px;
  display:flex;flex-direction:column;gap:9px;font-size:14px}
.pos-total>div{display:flex;align-items:center;justify-content:space-between;gap:10px}
.pos-total>div>span{color:var(--muted)}
.pos-total>div>b{font-weight:700;white-space:nowrap}
.pos-total #discount{width:120px;text-align:right;padding:8px 11px;margin:0}
.pos-total .grand{margin-top:4px;border-top:1.5px dashed var(--line);padding-top:12px;font-size:18px;font-weight:800}
.pos-total .grand span{color:var(--ink)}
.pos-total .grand b{color:var(--brand)}
.cart-actions{display:flex;gap:10px;margin:14px 18px;max-width:480px}
.cart-actions .btn{flex:1}
.cartbar{max-width:480px;margin:0 auto}

/* ============================================================
   KASIR / POS
   ============================================================ */
.pos-page{display:grid;grid-template-columns:1fr 380px;gap:22px;max-width:var(--maxw);
  margin:22px auto;padding:0 22px;align-items:start}
.pos-main{min-width:0}
.pos-head{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:16px}
.pos-head h1{margin:0;font-size:1.6rem}
.pos-head p{color:var(--muted);margin:.2em 0 0;font-size:13.5px}

.pos-cats{display:flex;gap:8px;overflow-x:auto;padding-bottom:12px;scrollbar-width:none}
.pos-cats::-webkit-scrollbar{display:none}
.pos-cats button{
  flex:none;background:var(--surface);border:1.5px solid var(--line);border-radius:999px;
  padding:9px 16px;font-weight:700;font-size:13.5px;cursor:pointer;color:var(--ink);transition:.15s;width:auto;
}
.pos-cats button:hover,.pos-cats button.active{background:var(--brand);color:#fff;border-color:transparent}

.pos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:14px}
.pos-menu{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:10px;
  cursor:pointer;display:flex;flex-direction:column;gap:3px;box-shadow:var(--shadow-sm);
  transition:transform .14s,box-shadow .14s,border-color .14s;text-align:left;
}
.pos-menu:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--caramel)}
.pos-menu img,.pos-noimg{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:11px;background:var(--bg)}
.pos-noimg{display:grid;place-items:center;color:var(--muted);font-size:11px;border:1px dashed var(--line)}
.pos-menu b{font-size:14px;font-weight:700;margin-top:4px}
.pos-menu small{color:var(--muted);font-size:11.5px}
.pos-menu strong{color:var(--brand);font-weight:800;font-size:14.5px}

.pos-sidebar{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:20px;box-shadow:var(--shadow);position:sticky;top:90px;
}
.pos-sidebar h2{margin-top:0}
.order-type-toggle{display:flex;gap:8px;margin-bottom:6px}
.order-type-toggle label{
  flex:1;margin:0;display:flex;align-items:center;justify-content:center;gap:6px;
  border:1.5px solid var(--line);border-radius:11px;padding:10px;cursor:pointer;font-size:13.5px;
  background:var(--bg-2);transition:.15s;
}
.order-type-toggle input{width:auto;margin:0}
.order-type-toggle label:has(input:checked){background:var(--brand);color:#fff;border-color:transparent}
.pos-cart-item{display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:10px 0;border-bottom:1px solid var(--line)}
.pos-qty{display:flex;align-items:center;gap:6px}
.pos-qty button{width:28px;height:28px;border-radius:8px;border:1px solid var(--line);
  background:var(--bg);font-weight:700;cursor:pointer;color:var(--brand)}
.pos-empty{color:var(--muted);text-align:center;padding:26px 0;font-size:14px}
.pos-save{width:100%;margin-top:14px;padding:14px;font-size:15px}

/* ---------- RESPONSIVE ---------- */
@media(max-width:920px){
  .grid{grid-template-columns:repeat(2,1fr)}
  .pos-page{grid-template-columns:1fr}
  .pos-sidebar{position:static}
}
@media(max-width:560px){
  .grid,.two{grid-template-columns:1fr}
  .topbar{padding:12px 16px}
  .nav a{padding:6px 10px;font-size:12.5px}
}
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible{
  outline:3px solid var(--caramel);outline-offset:2px;border-radius:8px}
@media(prefers-reduced-motion:reduce){*{transition:none!important}}

/* ============================================================
   LAYOUT PELANGGAN DUA PANEL (kategori kiri + menu kanan)
   ============================================================ */
.order-top{
  display:flex;align-items:center;gap:10px;background:var(--grad-brand);color:#fff;
  padding:14px 16px;position:sticky;top:0;z-index:20;
}
.order-top .ot-logo{width:30px;height:30px;border-radius:7px;object-fit:cover}
.order-top .ot-title{font-family:'Fraunces',serif;font-weight:900;font-size:16px;flex:1;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.order-top .ot-mode{font-size:11.5px;font-weight:700;color:#fff;background:rgba(255,255,255,.16);
  border:1px solid rgba(255,255,255,.22);padding:5px 10px;border-radius:999px;white-space:nowrap}

.order-body{display:flex;align-items:stretch;background:var(--surface)}

.cat-rail{
  flex:none;width:120px;background:linear-gradient(180deg,var(--brand),var(--brand-dark));border-right:none;
  display:flex;flex-direction:column;
}
.cat-rail a{
  display:block;padding:16px 14px;font-size:12.5px;font-weight:700;line-height:1.25;
  color:rgba(255,255,255,.74);border-bottom:1px solid rgba(255,255,255,.10);text-transform:uppercase;letter-spacing:.01em;
  position:relative;transition:background .12s,color .12s;
}
.cat-rail a.active{background:#F6F0E6;color:var(--brand)}
.cat-rail a.active::before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:4px;
  background:var(--caramel);border-radius:0 4px 4px 0}
.cat-rail a:active{background:#F6F0E6}

.menu-pane{flex:1;min-width:0;background:var(--surface)}
.menu-pane-top{padding:16px 16px 10px;border-bottom:1px solid var(--line)}
.menu-pane-top h2{font-family:'Fraunces',serif;font-size:18px;margin:0 0 10px}
.search-box{display:flex;gap:8px}
.search-box input{flex:1;padding:9px 12px;border:1.5px solid var(--line);border-radius:10px;
  background:var(--bg-2);font-size:13px}
.search-box input:focus{outline:none;border-color:var(--brand);background:#fff;
  box-shadow:0 0 0 3px rgba(46,139,102,.15)}
.search-box button{flex:none;border:none;background:var(--brand);color:#fff;font-weight:700;
  font-size:13px;padding:9px 14px;border-radius:10px;cursor:pointer}

.mlist{display:flex;flex-direction:column}
.mlist-empty{padding:30px 16px;color:var(--muted);font-size:14px;text-align:center}
.mrow{display:flex;gap:12px;padding:14px 16px;border-bottom:1px solid var(--line);position:relative}
.mrow.soldout{opacity:.55;filter:grayscale(.5)}
.mrow-photo{width:78px;height:78px;flex:none;border-radius:12px;object-fit:cover;background:var(--bg)}
.mrow-empty{display:flex;align-items:center;justify-content:center;color:var(--muted);
  font-size:10px;border:1px dashed var(--line)}
.mrow-info{flex:1;min-width:0;display:flex;flex-direction:column}
.mrow-name{font-weight:700;font-size:15px;color:var(--ink)}
.mrow-desc{font-size:12.5px;color:var(--muted);margin-top:2px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.mrow-foot{display:flex;align-items:center;justify-content:space-between;margin-top:8px;gap:10px}
.mrow-price{font-weight:800;font-size:15px;color:var(--ink)}
.mrow-add{
  width:40px;height:40px;flex:none;border-radius:50%;background:var(--brand);color:#fff;
  display:grid;place-items:center;font-size:24px;line-height:1;text-decoration:none;
  transition:transform .12s,background .12s;
}
.mrow-add:hover{transform:scale(1.08);background:var(--brand-dark)}

/* ikon kategori di rail (di atas teks) */
.cat-rail a{text-align:center}
.cat-rail a .cr-ico{display:block;font-size:20px;margin-bottom:5px;text-transform:none;line-height:1}

/* catatan per item di kasir/POS */
.pos-cart-item{flex-direction:column;align-items:stretch;gap:8px}
.pci-top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.pos-note{width:100%;padding:8px 11px;border:1.5px solid var(--line);border-radius:9px;
  background:var(--bg-2);font-size:12.5px;font-family:inherit}
.pos-note:focus{outline:none;border-color:var(--brand);background:#fff;box-shadow:0 0 0 3px rgba(46,139,102,.15)}

/* banner sambutan halaman pelanggan (background bisa diganti via Setting) */
.order-hero{position:relative;padding:20px 18px 18px;min-height:120px;display:flex;flex-direction:column;
  justify-content:flex-end;background:var(--grad-brand);background-size:cover;background-position:center;
  color:#fff;overflow:hidden}
.order-hero::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(20,44,28,.10) 0%,rgba(20,44,28,.80) 100%)}
.order-hero>*{position:relative;z-index:1}
.order-hero h3{font-family:'Fraunces',serif;font-weight:900;font-size:22px;margin:0;line-height:1.2}
.order-hero p{margin:6px 0 0;font-size:13px;line-height:1.45;opacity:.95}
