/* =========================
   Saba Kitchen - style.css
   Safe reset + responsive store + dashboard + modals
   (Designed to NOT break existing HTML/app.js)
   ========================= */

/* ---------- Reset / Base ---------- */

<link href="https://fonts.googleapis.com/css2?family=Playfair+Display:wght@500;700&family=Dancing+Script:wght@500;600&display=swap" rel="stylesheet">

* { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin: 0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color: rgba(255,255,255,0.92);
  background: radial-gradient(1200px 600px at 50% 0%, rgba(16,185,129,0.28), rgba(0,0,0,0.92) 60%),
              radial-gradient(900px 600px at 0% 20%, rgba(34,197,94,0.18), rgba(0,0,0,0) 55%),
              radial-gradient(900px 600px at 100% 20%, rgba(20,184,166,0.18), rgba(0,0,0,0) 55%),
              #05070a;
  overflow-x: hidden;
}

img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button, input { font: inherit; }

/* ---------- Shared helpers ---------- */
.glass {
  background: rgba(20, 25, 28, 0.55);
  border: 1px solid rgba(255,255,255,0.09);
  box-shadow: 0 18px 60px rgba(0,0,0,0.45);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-radius: 18px;
}

.btnSoft {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.14);
  background: rgba(255,255,255,0.06);
  box-shadow: 0 10px 30px rgba(0,0,0,0.35);
  cursor: pointer;
  transition: transform .12s ease, background .12s ease, border-color .12s ease;
}
.btnSoft:hover { transform: translateY(-1px); background: rgba(255,255,255,0.09); border-color: rgba(255,255,255,0.18); }
.btnSoft:active { transform: translateY(0px); }

.btnPrimary, .btn.primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 12px 16px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.12);
  background: linear-gradient(180deg, rgba(59,130,246,0.28), rgba(2,6,23,0.35));
  color: rgba(255,255,255,0.94);
  cursor: pointer;
  box-shadow: 0 16px 40px rgba(0,0,0,0.45);
  transition: transform .12s ease, filter .12s ease;
}
.btnPrimary:hover, .btn.primary:hover { filter: brightness(1.06); transform: translateY(-1px); }
.btnPrimary:active, .btn.primary:active { transform: translateY(0px); }
.btn.ghost {
  background: rgba(255,255,255,0.06);
}

.hidden { display: none !important; }

/* ---------- Layout: Store (index.php) ---------- */
.site { min-height: 100%; display: flex; flex-direction: column; }

.topbar {
  position: sticky;
  top: 0;
  z-index: 20;
  padding: calc(14px + env(safe-area-inset-top)) 18px 14px;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  background: linear-gradient(180deg, rgba(0,0,0,0.55), rgba(0,0,0,0));
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.main {
  width: min(1100px, 92vw);
  margin: 0 auto;
  padding: 18px 0 32px;
}

/* HERO */
.hero {
  width: 100%;
  margin: 8px 0 18px;
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.10);
  background:
    radial-gradient(900px 250px at 50% 0%, rgba(34,197,94,0.22), rgba(0,0,0,0) 70%),
    radial-gradient(700px 220px at 20% 30%, rgba(20,184,166,0.18), rgba(0,0,0,0) 65%),
    rgba(255,255,255,0.03);
  box-shadow: 0 22px 80px rgba(0,0,0,0.55);
}

.hero-overlay {
  padding: 40px 18px;
  text-align: center;
}

.hero-content h1 {
  font-size: clamp(34px, 4vw, 56px);
  font-weight: 800;
  letter-spacing: -0.02em;

  background: linear-gradient(
    90deg,
    #ffffff,
    #86efac,
    #22d3ee,
    #ffffff
  );
  background-size: 200% auto;

  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;

  animation: shineText 6s linear infinite;
}

@keyframes shineText {
  to { background-position: 200% center; }
}


.tagline {
  margin-top: 14px;
  font-family: 'Dancing Script', cursive;
  font-size: clamp(18px, 2.2vw, 26px);
  font-weight: 500;
  color: #86efac;

  text-shadow:
    0 0 8px rgba(34,197,94,.3),
    0 8px 30px rgba(0,0,0,.6);

  animation: softFade 4s ease-in-out infinite;
}

@keyframes softFade {
  0%,100% { opacity: 1; }
  50% { opacity: .85; }
}


/* MENU SECTION */
.menu { margin-top: 10px; }
.sectionTitle {
  font-weight: 700;
  font-size: 15px;
  letter-spacing: 0.02em;
  color: rgba(255,255,255,0.92);
  margin: 14px 0 10px;
}

.cards {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.card {
  overflow: hidden;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,0.09);
  background: rgba(255,255,255,0.04);
  box-shadow: 0 18px 60px rgba(0,0,0,0.50);
}

.cardImg {
  width: 100%;
  height: 220px;
  object-fit: cover;
}

.cardBody { padding: 12px 12px 14px; }
.cardTop {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.itemName { font-size: 16px; font-weight: 800; }
.itemDesc { font-size: 12px; color: rgba(255,255,255,0.72); margin-top: 2px; }

/* Qty controls */
.qtyBox {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  border-radius: 14px;
  background: rgba(0,0,0,0.22);
  border: 1px solid rgba(255,255,255,0.10);
}
.pm {
  width: 36px;
  height: 36px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.06);
  color: rgba(255,255,255,0.92);
  cursor: pointer;
  transition: transform .12s ease, background .12s ease;
}
.pm:hover { background: rgba(255,255,255,0.10); transform: translateY(-1px); }
.pm:active { transform: translateY(0px); }
.qty {
  min-width: 26px;
  text-align: center;
  font-weight: 800;
  color: rgba(255,255,255,0.92);
}

/* Checkout bar (ONLY one checkout button in your HTML now) */
.checkoutBar {
  margin: 16px 0 10px;
  display: flex;
  justify-content: center;
}
.checkoutBig {
  width: min(760px, 100%);
  padding: 14px 18px;
  border-radius: 16px;
  font-weight: 800;
}

/* Advertisement section */
.adSection { margin-top: 24px; }

.adHeader{
  margin-top: 22px;
  margin-bottom: 12px;
  font-size: 12px;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: rgba(255,255,255,.55);
}

.adBox{
  width: 100%;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.35);
  box-shadow: 0 18px 60px rgba(0,0,0,.45);

  display: flex;
  align-items: center;
  justify-content: center;

  /* IMPORTANT: gives a nice banner shape without forcing zoom */
  aspect-ratio: 16 / 7;
}

.adBox img{
  width: 100%;
  height: 100%;
  object-fit: contain;      /* ✅ no zoom */
  object-position: center;
  display: block;
}



/* Footer */
.footer {
  margin-top: auto;
  padding: 22px 18px calc(18px + env(safe-area-inset-bottom));
  text-align: center;
  font-size: 12px;
  color: rgba(255,255,255,0.55);
}

/* ---------- Modals (Checkout + Success) ---------- */
.modal {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  padding: calc(14px + env(safe-area-inset-top)) 14px calc(14px + env(safe-area-inset-bottom));
  background: rgba(0,0,0,0.55);
  z-index: 50;
}
.modal.open { display: flex; }

.modalbox {
  width: min(560px, 100%);
  max-height: min(88vh, 760px);
  overflow: auto;              /* critical for mobile */
  -webkit-overflow-scrolling: touch;
  padding: 16px;
  border-radius: 18px;
}

.modalHeader {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 12px;
}
.modalTitle { font-weight: 900; font-size: 18px; }
.modalSub { font-size: 12px; color: rgba(255,255,255,0.70); margin-top: 2px; }

.iconBtn {
  width: 42px;
  height: 42px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.06);
  color: rgba(255,255,255,0.92);
  cursor: pointer;
}

.formGrid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}
.label { display: block; font-size: 12px; color: rgba(255,255,255,0.75); margin-bottom: 6px; }
input {
  width: 100%;
  padding: 12px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.14);
  background: rgba(0,0,0,0.20);
  color: rgba(255,255,255,0.92);
  outline: none;
}
input::placeholder { color: rgba(255,255,255,0.45); }
input:focus { border-color: rgba(59,130,246,0.35); box-shadow: 0 0 0 3px rgba(59,130,246,0.12); }

.summary {
  margin-top: 12px;
  padding: 12px;
  border-radius: 16px;
}
.sumRow {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 8px 6px;
  font-size: 13px;
  color: rgba(255,255,255,0.88);
}
.sumRow.total {
  border-top: 1px solid rgba(255,255,255,0.10);
  margin-top: 6px;
  padding-top: 10px;
  font-weight: 900;
}

.actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-top: 12px;
}
.btn {
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.06);
  color: rgba(255,255,255,0.92);
  cursor: pointer;
}

.spinner {
  width: 16px; height: 16px;
  border-radius: 999px;
  border: 2px solid rgba(255,255,255,0.30);
  border-top-color: rgba(255,255,255,0.92);
  animation: spin 0.9s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

.err {
  margin-top: 10px;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(239,68,68,0.35);
  background: rgba(239,68,68,0.12);
  color: rgba(255,255,255,0.95);
}

/* Success box */
.successBox { margin-top: 10px; padding: 14px; border-radius: 16px; text-align: center; }
.successLabel { font-size: 12px; color: rgba(255,255,255,0.70); }
.successId { font-size: 30px; font-weight: 1000; letter-spacing: 0.06em; margin-top: 4px; }

/* ---------- Dashboard (dashboard.php) ---------- */
/* =========================
   DASHBOARD FIX PACK
   (scoped so homepage stays intact)
   ========================= */

.dash{
  width: min(1150px, 92vw);
  margin: 0 auto;
  padding: 18px 0 40px;
}

.dashTop{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
  margin-bottom: 12px;
}

.dashH1{ font-size: 26px; font-weight: 900; }
.dashSub{ font-size: 12px; color: rgba(255,255,255,.70); margin-top: 4px; }

.dashTopRight{ display:flex; gap:10px; align-items:center; flex-wrap:wrap; }

/* Make + New Order look like a real button */
.dash #openManualBtn.btnPrimary{
  width: 100%;
  max-width: 520px;
  border-radius: 16px;
  padding: 14px 16px;
  font-weight: 900;
}

/* Controls */
.dashControls{ display:grid; gap: 12px; margin-top: 10px; }
.dash .input{
  width: 100%;
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.18);
  color: rgba(255,255,255,.92);
  outline: none;
}

/* Chips */
.dash .chips{ display:flex; flex-wrap:wrap; gap: 10px; align-items:center; }
.dash .chipLabel{
  font-size: 12px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(255,255,255,.55);
  margin-right: 6px;
}
.dash .chip{
  padding: 10px 12px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.92);
  font-weight: 800;
  cursor: pointer;
}
.dash .chip.isOn{
  background: rgba(59,130,246,.20);
  border-color: rgba(59,130,246,.28);
}

/* Orders that app.js renders */
.dash .groupTitle{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin: 16px 0 10px;
  font-weight: 900;
}
.dash .groupTitle .count{
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.75);
  font-size: 12px;
}

.dash .orderGrid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 14px;
}

.dash .orderCard{
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.05);
  box-shadow: 0 16px 44px rgba(0,0,0,.35);
  padding: 14px;
}

.dash .bigActions{
  display:flex;
  flex-wrap:wrap;
  gap: 8px;
  margin-top: 12px;
}
.dash .btnBig{
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.92);
  font-weight: 900;
  cursor: pointer;
}

/* Manual modal: not chopped on mobile */
#manualModal.modal{
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 14px;
  background: rgba(0,0,0,.55);
  z-index: 9999;
}
#manualModal.open{ display:flex; }

#manualModal .modalbox{
  width: min(620px, 100%);
  max-height: calc(100dvh - 28px);
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  border-radius: 18px;
}

/* Force 1-column form on phones */
#manualModal .formGrid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
@media (max-width: 900px){
  .dash .orderGrid{ grid-template-columns: 1fr; }
  #manualModal .formGrid{ grid-template-columns: 1fr; }
}

/* iOS input zoom prevention */
#manualModal input,
#manualModal select,
#manualModal textarea{
  font-size: 16px;
}

/* ---------- Responsive ---------- */
@media (max-width: 900px) {
  .cards { grid-template-columns: 1fr; }
  .cardImg { height: 210px; }
  .orderGrid { grid-template-columns: 1fr; }
  .bigActions { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .dashTop { align-items: flex-start; flex-direction: column; }
  .dashTopRight { width: 100%; justify-content: flex-start; flex-wrap: wrap; }
}

@media (max-width: 480px) {
  .main { width: 92vw; }
  .hero-overlay { padding: 28px 14px; }
  .qtyBox { gap: 8px; padding: 8px 8px; }
  .pm { width: 34px; height: 34px; }
  .checkoutBig { border-radius: 16px; }
  .adBox img { height: 190px; }
  .modalbox { padding: 14px; }
  .actions { grid-template-columns: 1fr; } /* mobile: buttons stacked */
}

@media (max-width: 768px){
  .adBox{ aspect-ratio: 16 / 9; }
}

/* =========================================================
   DASHBOARD UI FIX (paste at bottom of style.css)
   ========================================================= */

/* Prevent random horizontal scroll on mobile */
html, body { overflow-x: hidden; }

/* --- Dashboard shell --- */
.dash{
  max-width: 1180px;
  margin: 26px auto 50px;
  padding: 0 18px;
}

.dashTop{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 14px;
  margin-bottom: 14px;
}

.dashH1{
  font-size: 28px;
  font-weight: 800;
  letter-spacing: .2px;
  color: rgba(255,255,255,.96);
}
.dashSub{
  margin-top: 4px;
  color: rgba(255,255,255,.72);
  font-size: 13px;
}

.dashTopRight{
  display:flex;
  align-items:center;
  gap: 10px;
}

/* Store / Refresh buttons already use btnSoft — make sure it looks good */
.btnSoft{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding: 10px 14px;
  border-radius: 999px;
  text-decoration:none;
  cursor:pointer;
  border: 1px solid rgba(255,255,255,.14);
  color: rgba(255,255,255,.92);
  background: rgba(255,255,255,.06);
  backdrop-filter: blur(10px);
}
.btnSoft:hover{ background: rgba(255,255,255,.10); }

/* --- Search --- */
#search{
  width: 100%;
  padding: 12px 14px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.35);
  color: rgba(255,255,255,.92);
  outline: none;
}
#search::placeholder{ color: rgba(255,255,255,.55); }

/* --- Filter rows / chips --- */
.filters{ margin: 10px 0 18px; }
.filterRow{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:10px;
  margin-top: 10px;
}
.filterRow .lbl{
  width: 60px;
  font-size: 12px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(255,255,255,.55);
}
.filterRow button[data-date],
.filterRow button[data-status]{
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.92);
  padding: 8px 12px;
  border-radius: 999px;
  cursor:pointer;
  transition: transform .08s ease, background .12s ease, box-shadow .12s ease;
}
.filterRow button[data-date]:hover,
.filterRow button[data-status]:hover{
  background: rgba(255,255,255,.10);
  transform: translateY(-1px);
}
.filterRow button.isOn{
  background: rgba(59,130,246,.22);
  border-color: rgba(59,130,246,.35);
  box-shadow: 0 0 0 1px rgba(59,130,246,.20) inset;
}

/* --- Orders grid & cards --- */
.orderGrid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-bottom: 18px;
}

.orderCard{
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.40);
  border-radius: 16px;
  padding: 14px;
  box-shadow: 0 18px 40px rgba(0,0,0,.35);
}

.orderHead{
  display:flex;
  justify-content:space-between;
  gap: 12px;
  margin-bottom: 10px;
}
.customerNameBig{
  font-weight: 800;
  font-size: 16px;
  color: rgba(255,255,255,.96);
}
.orderIdSmall{
  font-size: 12px;
  color: rgba(255,255,255,.70);
  margin-top: 2px;
}
.meta{
  font-size: 12px;
  color: rgba(255,255,255,.72);
  margin-top: 6px;
  line-height: 1.35;
}

.items{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top: 10px;
}
.pill{
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.90);
  font-size: 12px;
}

/* status badge */
.badge{
  padding: 7px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.92);
  font-size: 12px;
  height: fit-content;
}
.badge.green{ background: rgba(16,185,129,.18); border-color: rgba(16,185,129,.30); }
.badge.blue{  background: rgba(59,130,246,.18); border-color: rgba(59,130,246,.30); }
.badge.red{   background: rgba(239,68,68,.18); border-color: rgba(239,68,68,.30); }
.badge.gray{  background: rgba(255,255,255,.06); border-color: rgba(255,255,255,.14); }

.bigActions{
  display:flex;
  flex-wrap:wrap;
  gap: 10px;
  margin-top: 12px;
}

.btnBig{
  flex: 1 1 auto;
  min-width: 110px;
  padding: 10px 12px;
  border-radius: 12px;
  cursor:pointer;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.92);
}
.btnBig:hover{ background: rgba(255,255,255,.10); }
.btnConfirm{ background: rgba(59,130,246,.18); border-color: rgba(59,130,246,.32); }
.btnReady{   background: rgba(99,102,241,.18); border-color: rgba(99,102,241,.32); }
.btnComplete{background: rgba(16,185,129,.18); border-color: rgba(16,185,129,.32); }
.btnReject{  background: rgba(239,68,68,.18); border-color: rgba(239,68,68,.32); }

/* --- Manual “+ New Order” button --- */
.newOrderBtn{
  display:inline-flex;
  align-items:center;
  gap: 10px;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.08);
  color: rgba(255,255,255,.95);
  cursor:pointer;
  margin: 10px 0 18px;
}
.newOrderBtn:hover{ background: rgba(255,255,255,.12); transform: translateY(-1px); }
.plusIcon{
  width: 28px;
  height: 28px;
  border-radius: 10px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(59,130,246,.20);
  border: 1px solid rgba(59,130,246,.28);
  font-weight: 900;
}

/* --- Modal (fix chopped/overlay issues) --- */
.modal{
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 18px;
  background: rgba(0,0,0,.55);
  z-index: 9999;
}

.modal.open{ display:flex; }

/* Your markup uses .modalbox — style both */
.modalbox,
.modal .box{
  width: min(760px, 92vw);
  max-height: 90vh;
  overflow: auto;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(16px);
  padding: 18px;
  box-shadow: 0 26px 70px rgba(0,0,0,.55);
}

.modalHead{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 12px;
  margin-bottom: 10px;
}
.modalH{
  font-size: 20px;
  font-weight: 900;
  color: rgba(255,255,255,.96);
}
.modalSub{
  margin-top: 4px;
  color: rgba(255,255,255,.72);
  font-size: 13px;
}
.modalX{
  width: 40px;
  height: 40px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.92);
  cursor:pointer;
}

.formGrid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 12px;
}
.formGrid .full{ grid-column: 1 / -1; }

.formGrid label{
  display:block;
  font-size: 12px;
  color: rgba(255,255,255,.70);
  margin-bottom: 6px;
}

.formGrid input,
.formGrid select,
.formGrid textarea{
  width: 100%;
  padding: 11px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.35);
  color: rgba(255,255,255,.92);
  outline: none;
}
.formGrid textarea{ min-height: 90px; resize: vertical; }

.modalActions{
  display:flex;
  gap: 10px;
  margin-top: 14px;
}
.modalActions button{
  flex:1;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.92);
  cursor:pointer;
}
.modalActions .primary{
  background: rgba(59,130,246,.22);
  border-color: rgba(59,130,246,.32);
}

/* --- Mobile --- */
@media (max-width: 760px){
  .orderGrid{ grid-template-columns: 1fr; }
  .dashTop{ flex-direction: column; align-items: stretch; }
  .dashTopRight{ justify-content: flex-start; }
  .filterRow .lbl{ width: 100%; }
  .formGrid{ grid-template-columns: 1fr; }
  .btnBig{ min-width: 0; }
}

/* ========== Ad + Floating Review (Fixed spacing + dark theme) ========== */
.ad-wrap{
  position: relative;
  width: min(1100px, 92%);
  margin: 28px auto 14px;

  /* RESERVE SPACE so the floating bar doesn't overlap the ad */
  padding-top: 128px;
}

.ad-card{
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(10,10,10,0.55);
  box-shadow: 0 18px 40px rgba(0,0,0,0.55);
  .ad-card img{
  width: 100%;
  height: auto;
  display: block;
}

}

/* Floating bar */
.review-float{
  position: absolute;
  left: 14px;
  right: 14px;
  top: 14px;               /* no negative top now */
  z-index: 10;

  display: grid;
  grid-template-columns: auto 1fr;
  gap: 12px;
  align-items: center;

  padding: 12px 14px;
  border-radius: 16px;

  /* Dark glass to match your theme */
  background: rgba(15, 20, 28, 0.78);
  border: 1px solid rgba(255,255,255,0.10);
  box-shadow: 0 14px 32px rgba(0,0,0,0.55);
  backdrop-filter: blur(10px);
}

/* left area */
.rf-left{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  white-space: nowrap;
}

.rf-badge{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 6px 10px;
  border-radius: 999px;

  /* warm desi accent but subtle */
  background: rgba(245,158,11,0.14);
  border: 1px solid rgba(245,158,11,0.28);
  color: rgba(255,255,255,0.92);

  font-weight: 900;
  font-size: 0.9rem;
}

.rf-title{
  font-weight: 900;
  color: rgba(255,255,255,0.92);
  font-size: 0.95rem;
}

.rf-sub{
  color: rgba(255,255,255,0.65);
  font-size: 0.85rem;
}

/* ticker */
.rf-ticker{
  overflow: hidden;
  min-width: 0;
  padding-left: 10px;
  border-left: 1px solid rgba(255,255,255,0.10);
}

.rf-track{
  display: inline-flex;
  gap: 14px;
  align-items: center;
  white-space: nowrap;

  animation: rfscroll 22s linear infinite;
}

.review-float:hover .rf-track{ animation-play-state: paused; }

.rf-item{
  font-size: 0.9rem;
  color: rgba(255,255,255,0.80);
}

.rf-dot{ opacity: 0.45; color: rgba(255,255,255,0.7); }

@keyframes rfscroll{
  0%{ transform: translateX(0); }
  100%{ transform: translateX(-45%); }
}

/* Mobile: stack nicely + increase reserved space */
@media (max-width: 900px){
  .ad-wrap{ padding-top: 132px; }
  .review-float{
    grid-template-columns: 1fr;
    gap: 5px;
  }
  .rf-left{
    flex-wrap: wrap;
    white-space: normal;
  }
  .rf-ticker{
    border-left: none;
    padding-left: 0;
  }
}

