:root{--fovp-accent:#ff7a18;--fovp-bg:#08090d;--fovp-card:rgba(18,20,29,.78);--fovp-border:rgba(255,255,255,.12);--fovp-text:#f7f7fb;--fovp-muted:#a8adbd}.fovp-wrap{font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;color:var(--fovp-text);background:radial-gradient(circle at top left,rgba(255,122,24,.22),transparent 34%),linear-gradient(145deg,#07080d,#11131b 48%,#08090d);min-height:100vh;padding:22px;border-radius:28px;overflow:hidden}.fovp-animated-bg:before{content:"";position:fixed;inset:auto -12% 10% auto;width:260px;height:260px;background:rgba(255,122,24,.18);filter:blur(50px);border-radius:50%;animation:fovpFloat 8s infinite alternate;pointer-events:none}.fovp-hero{display:grid;grid-template-columns:1.1fr .9fr;gap:24px;align-items:center;min-height:620px}.fovp-hero-copy h1,.fovp-board-head h1{font-size:clamp(34px,6vw,70px);line-height:.95;margin:18px 0}.fovp-hero-copy p,.fovp-card p,.fovp-status-card p{color:var(--fovp-muted);font-size:16px}.fovp-pill{display:inline-flex;align-items:center;border:1px solid rgba(255,122,24,.34);background:rgba(255,122,24,.12);color:#ffd7bb;border-radius:999px;padding:8px 12px;font-size:12px;letter-spacing:.04em}.fovp-card,.fovp-form-card,.fovp-status-card,.fovp-order-card,.fovp-modal-box{background:var(--fovp-card);border:1px solid var(--fovp-border);box-shadow:0 30px 80px rgba(0,0,0,.34),inset 0 1px 0 rgba(255,255,255,.08);backdrop-filter:blur(20px);border-radius:30px;padding:24px}.fovp-card h2,.fovp-form-card h2{margin-top:0;font-weight:500}.fovp-ajax label{display:block;color:#d7d9e4;font-size:13px;margin:12px 0}.fovp-ajax input,.fovp-ajax select,.fovp-ajax textarea{width:100%;box-sizing:border-box;margin-top:8px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06);border-radius:18px;padding:14px 16px;color:#fff;outline:none}.fovp-ajax textarea{min-height:110px}.fovp-btn{display:inline-flex;justify-content:center;align-items:center;gap:8px;border:0;border-radius:18px;background:linear-gradient(135deg,#ff9b36,#ff6118);color:#1b0c04!important;text-decoration:none;padding:14px 18px;cursor:pointer;box-shadow:0 14px 34px rgba(255,111,24,.25);font-weight:500}.fovp-muted{background:rgba(255,255,255,.08);color:#fff!important;box-shadow:none}.fovp-msg{margin-top:12px;color:#ffd7bb}.fovp-upload-grid,.fovp-action-grid,.fovp-order-grid,.fovp-live-dishes{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:14px}.fovp-agreement{max-height:220px;overflow:auto;border:1px solid rgba(255,255,255,.12);border-radius:20px;padding:16px;margin:18px 0;color:#d6d8e1;background:rgba(255,255,255,.04)}.fovp-check{display:flex!important;gap:10px;align-items:center}.fovp-check input{width:auto!important}.fovp-control{border-radius:34px;padding:22px;background:linear-gradient(135deg,rgba(17,19,28,.96),rgba(31,20,14,.9));border:1px solid var(--fovp-border);margin-bottom:18px}.fovp-topbar{display:grid;grid-template-columns:1fr 1.25fr 1fr;align-items:center;gap:16px}.fovp-avatar{width:92px;height:92px;border-radius:50%;object-fit:cover;border:3px solid rgba(255,255,255,.2)}.fovp-cart{width:min(100%,320px);margin:auto;display:block;filter:grayscale(1) saturate(0);opacity:.66}.is-live .fovp-cart{filter:none;opacity:1;animation:fovpCart 2.2s ease-in-out infinite}.fovp-live-box{text-align:center}.fovp-live-dot{display:inline-block;width:18px;height:18px;border-radius:50%;background:#777}.is-live .fovp-live-dot{background:#ff2626;box-shadow:0 0 0 0 rgba(255,38,38,.55);animation:fovpPulse 1.4s infinite}.fovp-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.72);z-index:99999;align-items:center;justify-content:center;padding:18px}.fovp-modal.show{display:flex}.fovp-modal-box{max-width:560px;width:100%;position:relative}.fovp-close{position:absolute;right:18px;top:14px;background:transparent;color:#fff;border:0;font-size:28px;cursor:pointer}.fovp-board-head{display:flex;justify-content:space-between;align-items:center;gap:20px;margin-bottom:20px}.fovp-order-card{break-inside:avoid}.fovp-order-title{display:flex;justify-content:space-between;align-items:center}.fovp-order-title h2{font-size:28px;margin:0}.fovp-item{display:flex;gap:12px;align-items:center;margin:10px 0;padding:10px;border-radius:18px;background:rgba(255,255,255,.05)}.fovp-item img,.fovp-dish-card img{width:64px;height:64px;border-radius:16px;object-fit:cover}.fovp-order-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.fovp-timer{font-size:22px;color:#ffd7bb}.fovp-dish-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:24px;padding:14px}.fovp-dish-card img{width:100%;height:170px}.fovp-error{outline:2px solid #ff453a!important}@keyframes fovpFloat{from{transform:translateY(0)}to{transform:translateY(-50px)}}@keyframes fovpCart{0%,100%{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(-8px) rotate(1deg)}}@keyframes fovpPulse{70%{box-shadow:0 0 0 18px rgba(255,38,38,0)}}@media(max-width:760px){.fovp-wrap{padding:14px;border-radius:0}.fovp-hero,.fovp-topbar{grid-template-columns:1fr;text-align:center}.fovp-board-head{display:block}.fovp-hero{min-height:auto}.fovp-card,.fovp-form-card,.fovp-status-card,.fovp-order-card{padding:18px;border-radius:22px}}@media print{body *{visibility:hidden}.fovp-order-card,.fovp-order-card *{visibility:visible}.fovp-order-card{position:relative;background:#fff!important;color:#000!important;box-shadow:none;border:0;width:72mm}.fovp-btn{display:none!important}}

/* Step stable edit: ring audio + vendor dish status */
.fovp-section-head{margin:26px 0 16px}.fovp-section-head h2{font-size:30px;margin:10px 0 6px;font-weight:500}.fovp-section-head p{color:var(--fovp-muted);margin:0}.fovp-dish-status-panel{margin-top:22px}.fovp-dish-status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}.fovp-dish-status-card{position:relative;display:grid;grid-template-columns:104px 1fr;gap:14px;align-items:center;padding:14px;border-radius:26px;background:linear-gradient(145deg,rgba(255,255,255,.09),rgba(255,255,255,.035));border:1px solid rgba(255,255,255,.12);box-shadow:0 20px 48px rgba(0,0,0,.22);overflow:hidden}.fovp-dish-status-card:before{content:"";position:absolute;inset:0 0 auto 0;height:3px;background:#ffb020}.fovp-dish-status-card.status-approved:before{background:#19d37a}.fovp-dish-status-card.status-blocked:before{background:#ff4d4f}.fovp-dish-thumb{width:104px;height:104px;border-radius:22px;overflow:hidden;background:rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;color:#aeb8cf}.fovp-dish-thumb img{width:100%;height:100%;object-fit:cover}.fovp-dish-info h3{margin:10px 0 6px;font-size:18px;font-weight:500}.fovp-dish-info p{margin:0 0 7px;color:#fff;font-size:18px}.fovp-dish-info small{color:#9fa7ba}.fovp-status-chip{display:inline-flex;padding:6px 10px;border-radius:999px;background:rgba(255,176,32,.14);color:#ffd38a;border:1px solid rgba(255,176,32,.25);font-size:12px}.status-approved .fovp-status-chip{background:rgba(25,211,122,.12);color:#8ff0bd;border-color:rgba(25,211,122,.25)}.status-blocked .fovp-status-chip{background:rgba(255,77,79,.12);color:#ffabab;border-color:rgba(255,77,79,.25)}.fovp-ring-box{display:flex;justify-content:space-between;gap:14px;align-items:center;margin:0 0 18px;padding:14px 16px;border-radius:22px;background:rgba(255,122,24,.09);border:1px solid rgba(255,122,24,.2)}.fovp-ring-box div{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.fovp-ring-box small{color:#aeb8cf}.fovp-ring-dot{width:12px;height:12px;border-radius:50%;background:#ff7a18;box-shadow:0 0 0 rgba(255,122,24,.5);animation:fovpPulse 1.3s infinite}@media(max-width:560px){.fovp-dish-status-card{grid-template-columns:80px 1fr}.fovp-dish-thumb{width:80px;height:80px}.fovp-ring-box{display:block}.fovp-ring-box .fovp-btn{margin-top:12px;width:100%}}

/* v1.2.1: keep partner control top section same layout on phone and desktop */
.fovp-control{overflow-x:auto;-webkit-overflow-scrolling:touch}.fovp-topbar{min-width:680px}.fovp-topbar>div:first-child{text-align:left}.fovp-live-box{text-align:center}@media(max-width:760px){.fovp-control{padding:18px;border-radius:28px}.fovp-topbar{display:grid!important;grid-template-columns:1fr 1.25fr 1fr!important;text-align:initial!important;gap:12px;align-items:center}.fovp-avatar{width:82px;height:82px}.fovp-cart{width:270px;max-width:none}.fovp-live-dot{width:18px;height:18px}.fovp-live-box .fovp-btn{white-space:nowrap;padding:12px 14px}.fovp-topbar h2{font-size:26px;margin:14px 0 8px}.fovp-topbar p{font-size:18px;margin:0}.fovp-dish-status-grid{grid-template-columns:1fr}.fovp-dish-status-card{grid-template-columns:104px 1fr}.fovp-dish-thumb{width:104px;height:104px}}

/* Dish approval dropdown actions */
.fovp-dish-action-form{
  display:inline-flex;
  align-items:center;
  gap:10px;
  margin:0 8px 0 0;
  vertical-align:middle;
}
.fovp-admin-select{
  min-width:150px;
  height:42px;
  border-radius:999px !important;
  border:1px solid rgba(148,163,184,.28) !important;
  background:#0b1020 !important;
  color:#fff !important;
  padding:0 38px 0 16px !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06), 0 12px 24px rgba(0,0,0,.22) !important;
}
.fovp-admin-select:focus{
  border-color:#ff8a18 !important;
  box-shadow:0 0 0 3px rgba(255,138,24,.16) !important;
  outline:none !important;
}
.fovp-update-button,
.fovp-approve-button{
  border-radius:999px !important;
  min-height:40px !important;
  padding:4px 18px !important;
}
.fovp-approve-button{
  background:#16a34a !important;
  color:#fff !important;
  border-color:#16a34a !important;
}

/* v1.2.2 full screen + no horizontal cut fix */
.fovp-wrap{
  width:100vw !important;
  max-width:100vw !important;
  margin-left:calc(50% - 50vw) !important;
  margin-right:calc(50% - 50vw) !important;
  box-sizing:border-box !important;
  overflow-x:hidden !important;
}
.fovp-control{
  width:100% !important;
  box-sizing:border-box !important;
  overflow:hidden !important;
}
.fovp-topbar{
  min-width:0 !important;
  width:100% !important;
  grid-template-columns:minmax(155px,1fr) minmax(220px,1.25fr) minmax(120px,.8fr) !important;
  gap:14px !important;
}
.fovp-topbar>*{min-width:0 !important;}
.fovp-topbar>div:first-child{
  overflow:hidden !important;
}
.fovp-topbar h2,
.fovp-topbar p{
  overflow-wrap:anywhere !important;
  word-break:break-word !important;
}
.fovp-cart{
  max-width:100% !important;
  width:min(100%,330px) !important;
  height:auto !important;
}
.fovp-action-grid{
  width:100% !important;
  box-sizing:border-box !important;
}
body:has(.fovp-wrap){
  overflow-x:hidden !important;
}
@media(max-width:760px){
  html,body{overflow-x:hidden !important;}
  .fovp-wrap{
    padding:10px !important;
    border-radius:0 !important;
    min-height:100vh !important;
  }
  .fovp-control{
    padding:14px 10px !important;
    border-radius:24px !important;
  }
  .fovp-topbar{
    display:grid !important;
    grid-template-columns:minmax(92px,.9fr) minmax(130px,1.35fr) minmax(92px,.85fr) !important;
    gap:6px !important;
    align-items:center !important;
    text-align:initial !important;
  }
  .fovp-avatar{
    width:58px !important;
    height:58px !important;
  }
  .fovp-topbar h2{
    font-size:18px !important;
    line-height:1.1 !important;
    margin:10px 0 6px !important;
  }
  .fovp-topbar p{
    font-size:12px !important;
    line-height:1.25 !important;
    margin:0 !important;
  }
  .fovp-cart{
    width:100% !important;
    min-width:0 !important;
    max-width:190px !important;
  }
  .fovp-live-box p{
    font-size:15px !important;
    margin:8px 0 !important;
  }
  .fovp-live-dot{
    width:16px !important;
    height:16px !important;
  }
  .fovp-live-box .fovp-btn{
    padding:10px 10px !important;
    border-radius:15px !important;
    font-size:12px !important;
    white-space:nowrap !important;
  }
  .fovp-action-grid{
    grid-template-columns:1fr 1fr !important;
    gap:10px !important;
  }
}

/* v1.2.3 premium control room mobile = desktop-style compact layout */
.fovp-wrap{
  background:
    radial-gradient(circle at 8% 8%, rgba(255,122,24,.28), transparent 30%),
    radial-gradient(circle at 92% 72%, rgba(255,122,24,.20), transparent 28%),
    linear-gradient(145deg,#070a12,#11141d 48%,#08090e) !important;
}
.fovp-control{
  background:linear-gradient(135deg, rgba(18,19,28,.96), rgba(38,20,12,.88)) !important;
  border:1px solid rgba(255,255,255,.14) !important;
  box-shadow:0 24px 70px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.08) !important;
}
.fovp-topbar{
  grid-template-columns:minmax(160px,.9fr) minmax(280px,1.35fr) minmax(150px,.85fr) !important;
  align-items:center !important;
}
.fovp-avatar{
  width:118px !important;
  height:118px !important;
  border-radius:50% !important;
  border:2px solid rgba(255,255,255,.22) !important;
  box-shadow:0 16px 40px rgba(0,0,0,.28) !important;
}
.fovp-cart{
  width:min(100%,390px) !important;
  max-width:390px !important;
}
.fovp-live-dot{
  width:22px !important;
  height:22px !important;
}
.fovp-live-box p{
  font-size:24px !important;
  margin:18px 0 !important;
}
.fovp-live-box .fovp-btn{
  border-radius:18px !important;
  min-width:128px !important;
}
.fovp-action-grid{
  grid-template-columns:repeat(4,minmax(0,1fr)) !important;
  gap:18px !important;
  margin-top:22px !important;
}
.fovp-action-grid .fovp-btn{
  min-height:74px !important;
  border-radius:24px !important;
  font-size:18px !important;
}
.fovp-action-grid .fovp-muted{
  background:linear-gradient(135deg,rgba(255,255,255,.10),rgba(255,255,255,.05)) !important;
  color:#fff !important;
}
.fovp-section-head h2{
  font-size:34px !important;
  line-height:1.05 !important;
}
.fovp-section-head p{
  font-size:19px !important;
  line-height:1.45 !important;
}
.fovp-dish-status-grid{
  grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  gap:18px !important;
}
.fovp-dish-status-card{
  min-width:0 !important;
  grid-template-columns:120px minmax(0,1fr) !important;
  min-height:150px !important;
}
.fovp-dish-thumb{
  width:120px !important;
  height:120px !important;
}

@media(max-width:760px){
  .fovp-wrap{
    width:100vw !important;
    max-width:100vw !important;
    margin-left:calc(50% - 50vw) !important;
    margin-right:calc(50% - 50vw) !important;
    padding:10px !important;
    overflow-x:hidden !important;
  }
  .fovp-control{
    padding:16px 14px !important;
    border-radius:26px !important;
    margin-bottom:16px !important;
  }
  .fovp-topbar{
    display:grid !important;
    grid-template-columns:29% 43% 28% !important;
    gap:6px !important;
    align-items:center !important;
    width:100% !important;
    min-width:0 !important;
  }
  .fovp-topbar>div:first-child{
    text-align:left !important;
  }
  .fovp-avatar{
    width:64px !important;
    height:64px !important;
  }
  .fovp-topbar h2{
    font-size:20px !important;
    line-height:1.05 !important;
    margin:10px 0 5px !important;
    white-space:nowrap !important;
    overflow:hidden !important;
    text-overflow:ellipsis !important;
  }
  .fovp-topbar p{
    font-size:11px !important;
    line-height:1.15 !important;
    margin:0 !important;
    white-space:nowrap !important;
    overflow:hidden !important;
    text-overflow:ellipsis !important;
  }
  .fovp-cart{
    width:100% !important;
    max-width:178px !important;
    min-width:0 !important;
    margin:auto !important;
  }
  .fovp-live-box{
    text-align:center !important;
  }
  .fovp-live-dot{
    width:16px !important;
    height:16px !important;
  }
  .fovp-live-box p{
    font-size:16px !important;
    margin:8px 0 10px !important;
  }
  .fovp-live-box .fovp-btn{
    min-width:0 !important;
    width:auto !important;
    padding:9px 10px !important;
    border-radius:15px !important;
    font-size:12px !important;
    white-space:nowrap !important;
  }
  .fovp-action-grid{
    display:grid !important;
    grid-template-columns:repeat(3,minmax(0,1fr)) !important;
    gap:10px !important;
    margin-top:14px !important;
  }
  .fovp-action-grid .fovp-btn{
    min-height:58px !important;
    padding:10px 8px !important;
    border-radius:19px !important;
    font-size:15px !important;
  }
  .fovp-action-grid .fovp-muted:last-child{
    grid-column:1 / -1 !important;
  }
  .fovp-section-head{
    margin:22px 0 14px !important;
  }
  .fovp-section-head h2{
    font-size:28px !important;
    margin:12px 0 8px !important;
  }
  .fovp-section-head p{
    font-size:15px !important;
    line-height:1.45 !important;
  }
  .fovp-dish-status-grid{
    display:grid !important;
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
    gap:10px !important;
  }
  .fovp-dish-status-card{
    display:block !important;
    min-height:0 !important;
    padding:10px !important;
    border-radius:20px !important;
  }
  .fovp-dish-thumb{
    width:64px !important;
    height:64px !important;
    border-radius:16px !important;
    margin-bottom:9px !important;
  }
  .fovp-status-chip{
    font-size:10px !important;
    padding:5px 8px !important;
  }
  .fovp-dish-info h3{
    font-size:15px !important;
    line-height:1.15 !important;
    margin:8px 0 5px !important;
    white-space:nowrap !important;
    overflow:hidden !important;
    text-overflow:ellipsis !important;
  }
  .fovp-dish-info p{
    font-size:14px !important;
  }
  .fovp-dish-info small{
    display:block !important;
    font-size:10px !important;
    line-height:1.35 !important;
  }
}

@media(max-width:380px){
  .fovp-topbar{grid-template-columns:28% 42% 30% !important;gap:4px !important;}
  .fovp-avatar{width:56px !important;height:56px !important;}
  .fovp-cart{max-width:150px !important;}
  .fovp-live-box .fovp-btn{font-size:11px !important;padding:8px 8px !important;}
  .fovp-action-grid .fovp-btn{font-size:13px !important;}
}

/* FreshOne Vendor Wallet */
.fovp-wallet-page{min-height:100vh;}
.fovp-wallet-hero{display:flex;align-items:center;justify-content:space-between;gap:18px;background:radial-gradient(circle at 15% 20%,rgba(255,122,24,.28),transparent 35%),linear-gradient(145deg,#090d18,#10182a);border:1px solid rgba(255,255,255,.10);border-radius:30px;padding:24px;box-shadow:0 28px 80px rgba(0,0,0,.34);}
.fovp-wallet-hero h1{margin:10px 0 4px;color:#fff;font-size:34px;font-weight:600;letter-spacing:-.04em;}
.fovp-wallet-hero p{margin:0;color:#b8c2d9;}
.fovp-wallet-balance{min-width:190px;text-align:right;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:24px;padding:18px;}
.fovp-wallet-balance small,.fovp-wallet-stats span{display:block;color:#9aa6bf;font-size:12px;text-transform:uppercase;letter-spacing:.12em;}
.fovp-wallet-balance strong{display:block;color:#fff;font-size:34px;margin-top:8px;}
.fovp-wallet-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin:16px 0;}
.fovp-wallet-stats>div{background:linear-gradient(145deg,rgba(255,255,255,.10),rgba(255,255,255,.04));border:1px solid rgba(255,255,255,.10);border-radius:24px;padding:18px;}
.fovp-wallet-stats strong{display:block;color:#fff;font-size:23px;margin-top:8px;}
.fovp-wallet-actions{margin:16px 0;}
.fovp-wallet-history{margin-top:18px;}
.fovp-wallet-table{display:grid;gap:9px;}
.fovp-wallet-row{display:grid;grid-template-columns:1.1fr 1fr .8fr .8fr .9fr .8fr .9fr;gap:8px;align-items:center;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.10);border-radius:18px;padding:13px;color:#eef3ff;font-size:13px;}
.fovp-wallet-row.head{background:transparent;color:#9aa6bf;text-transform:uppercase;letter-spacing:.12em;font-size:11px;border:0;padding-bottom:4px;}
@media(max-width:760px){.fovp-wallet-hero{display:block}.fovp-wallet-balance{text-align:left;margin-top:14px}.fovp-wallet-stats{grid-template-columns:repeat(2,minmax(0,1fr))}.fovp-wallet-row{grid-template-columns:1fr 1fr;border-radius:18px}.fovp-wallet-row.head{display:none}.fovp-wallet-row span{display:flex;justify-content:space-between;gap:8px}.fovp-wallet-row span:nth-child(1)::before{content:'Date';color:#9aa6bf}.fovp-wallet-row span:nth-child(2)::before{content:'Type';color:#9aa6bf}.fovp-wallet-row span:nth-child(3)::before{content:'Order';color:#9aa6bf}.fovp-wallet-row span:nth-child(4)::before{content:'Gross';color:#9aa6bf}.fovp-wallet-row span:nth-child(5)::before{content:'Commission';color:#9aa6bf}.fovp-wallet-row span:nth-child(6)::before{content:'Net';color:#9aa6bf}.fovp-wallet-row span:nth-child(7)::before{content:'Status';color:#9aa6bf}}
