/* ============================================================
   TAJ RESTAURANT MENU v5.0 — Styles
   FIXES: transparent backgrounds, z-index, popup rows,
          button visibility, mobile form
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@600;700&family=Outfit:wght@400;500;600;700&display=swap');

/* ── ROOT VARS ── */
.trm-wrap {
    --gold:    #C9A84C;
    --gold-dk: #8C6820;
    --black:   #0F0F0F;
    --white:   #FFFFFF;
    --bg:      #F5F3EF;
    --card:    #FFFFFF;
    --border:  #E4E0D8;
    --text:    #1A1A1A;
    --muted:   #7C7872;
    --green:   #1E6B2E;
    --red:     #B03020;
    --nav-h:   54px;
    --side-w:  360px;
    --r:       12px;
}

/* ── HARD RESET (prevent theme bleed) ── */
.trm-wrap, .trm-wrap *,
.trm-overlay, .trm-overlay * {
    box-sizing: border-box;
    margin: 0; padding: 0;
    -webkit-font-smoothing: antialiased;
}
/* Force solid backgrounds — fixes transparency issue */
.trm-wrap,
.trm-popup,
.trm-sidebar,
.trm-cart-wrap,
.trm-extra-row,
.trm-popup-hero,
.trm-popup-footer,
.trm-popup-main-item,
.trm-popup-extras,
.trm-extras-group,
.trm-promo-panel,
.trm-card {
    background-color: #fff !important;
}
.trm-wrap  { background-color: var(--bg) !important; }
.trm-body  { background-color: var(--bg) !important; }

.trm-wrap {
    font-family: 'Outfit', sans-serif;
    font-size: 16px;
    color: var(--text);
    overflow: visible;
    position: relative;
}
body.trm-noscroll { overflow: hidden !important; }

/* ── CONTAINER ── */
.trm-container { max-width: 1500px; margin: 0 auto; padding: 0 28px; }

/* ════════════════════════════════════════
   HEADER
════════════════════════════════════════ */
.trm-header {
    background-color: var(--black) !important;
    padding: 32px 0;
    position: relative;
}
.trm-header::after {
    content: ''; position: absolute; bottom:0; left:0; right:0; height:2px;
    background: linear-gradient(90deg, transparent, var(--gold) 50%, transparent);
}
.trm-name {
    font-family: 'Cormorant Garamond', serif;
    font-size: 42px; font-weight: 700;
    color: #FFFFFF !important;
    letter-spacing: .02em; line-height: 1.1; margin-bottom: 10px;
}
.trm-meta { display:flex; align-items:center; flex-wrap:wrap; gap:6px 14px; }
.trm-meta-item {
    display:flex; align-items:center; gap:6px;
    font-size: 15px; color: rgba(255,255,255,.62) !important;
}
.trm-meta-item svg { color: var(--gold) !important; flex-shrink:0; }
.trm-dot { color: rgba(255,255,255,.25) !important; }

/* ════════════════════════════════════════
   STICKY NAV — z-index 9999 beats Elementor
════════════════════════════════════════ */
.trm-nav {
    background-color: var(--black) !important;
    position: sticky;
    top: 0;
    z-index: 9999 !important;       /* HIGH z-index — beats Elementor, theme headers */
    height: var(--nav-h);
    border-bottom: 1px solid rgba(201,168,76,.20);
    width: 100%;
}
.trm-nav .trm-container { height: 100%; }
.trm-nav-inner { display:flex; align-items:center; height:100%; }
.trm-nav-scroll {
    display:flex; overflow-x:auto; scroll-behavior:smooth;
    scrollbar-width:none; flex:1; height:100%;
}
.trm-nav-scroll::-webkit-scrollbar { display:none; }

.trm-tab {
    flex-shrink:0; background:none !important; border:none;
    border-bottom: 3px solid transparent;
    color: rgba(255,255,255,.50) !important;
    padding: 0 22px; height:100%;
    font-family:'Outfit',sans-serif; font-size:14.5px; font-weight:500;
    letter-spacing:.03em; cursor:pointer; white-space:nowrap;
    transition:color .2s, border-color .2s;
}
.trm-tab:hover  { color: #E8D090 !important; }
.trm-tab.active { color: var(--gold) !important; border-bottom-color: var(--gold); }

.trm-arrow {
    flex-shrink:0; background:none !important; border:none;
    color: var(--gold) !important; font-size:30px;
    padding: 0 12px; cursor:pointer; height:100%;
    display:flex; align-items:center; transition:opacity .2s;
}
.trm-arrow:hover { opacity:.65; }

/* ════════════════════════════════════════
   BODY / LAYOUT
════════════════════════════════════════ */
.trm-body { background-color: var(--bg) !important; padding-bottom: 60px; }
.trm-layout {
    display:grid; grid-template-columns:1fr var(--side-w);
    align-items:start; gap:20px;
}

/* ════════════════════════════════════════
   TOOLBAR
════════════════════════════════════════ */
.trm-toolbar {
    display:flex; align-items:center; gap:14px;
    padding: 26px 0 0; flex-wrap:wrap;
}
.trm-search {
    flex:1; min-width:220px;
    display:flex; align-items:center; gap:10px;
    background-color: var(--white) !important;
    border: 1.5px solid var(--border);
    border-radius: 50px; padding: 13px 20px;
    transition: border-color .2s, box-shadow .2s;
}
.trm-search:focus-within {
    border-color: var(--gold);
    box-shadow: 0 0 0 3px rgba(201,168,76,.12);
}
.trm-search input {
    border:none !important;
    outline:none;
    font-family:'Outfit',sans-serif; font-size:16px;
    color: var(--text) !important;
    background: transparent !important; flex:1; min-width:0;
}
.trm-search input::placeholder { color: #C0BDB5; }

.trm-promo-btn {
    display:flex; align-items:center; gap:8px;
    background-color: var(--black) !important; color: var(--gold) !important;
    border: 1.5px solid var(--gold);
    border-radius: 50px; padding: 13px 22px;
    font-family:'Outfit',sans-serif; font-size:15px; font-weight:600;
    cursor:pointer; white-space:nowrap; transition:background .2s, color .2s;
}
.trm-promo-btn:hover {
    background-color: var(--gold) !important; color: var(--black) !important;
}

/* ════════════════════════════════════════
   PROMO PANEL
════════════════════════════════════════ */
.trm-promo-panel {
    margin-top: 14px;
    background-color: var(--white) !important;
    border: 1.5px solid var(--border);
    border-radius: var(--r); padding: 20px 24px;
}
.trm-promo-row { display:flex; gap:10px; align-items:center; }
.trm-promo-row input {
    flex:1; padding:13px 18px;
    border: 1.5px solid var(--border); border-radius:50px;
    font-family:'Outfit',sans-serif; font-size:16px;
    color: var(--text) !important;
    background-color: var(--white) !important;
    outline:none; transition:border-color .2s; min-width:0;
}
.trm-promo-row input:focus { border-color: var(--gold); }
.trm-promo-row button {
    background-color: var(--black) !important; color: var(--white) !important;
    border:none; padding:13px 26px; border-radius:50px;
    font-family:'Outfit',sans-serif; font-size:14px; font-weight:700;
    letter-spacing:.04em; cursor:pointer; white-space:nowrap;
    transition:background .2s;
}
.trm-promo-row button:hover { background-color: var(--gold-dk) !important; }
.trm-promo-msg {
    margin-top:12px; font-size:15px; line-height:1.5;
    padding:12px 16px; border-radius:8px;
}
.trm-promo-msg.ok  { background-color:#EBF5EC; border:1px solid #A5D6A7; color:var(--green); }
.trm-promo-msg.err { background-color:#FDEEEC; border:1px solid #F5B7B1; color:var(--red); }

/* ════════════════════════════════════════
   CATEGORY SECTIONS
════════════════════════════════════════ */
.trm-section { padding: 32px 0 0; }
.trm-section:last-child { padding-bottom: 32px; }
.trm-section-title { margin-bottom:16px; padding-bottom:14px; border-bottom:2px solid var(--border); }
.trm-section-title h2 {
    
    font-size: 30px; font-weight:700;
    color: var(--black) !important; letter-spacing:.01em;
}
.trm-section-title p { font-size:15px; color:var(--muted); margin-top:5px; }

/* ════════════════════════════════════════
   PRODUCT CARDS
════════════════════════════════════════ */
.trm-cards { display:flex; flex-direction:column; gap:10px; }
.trm-card {
    display:flex; align-items:center; gap:20px;
    background-color: var(--white) !important;
    border: 1.5px solid transparent;
    border-radius: var(--r); padding: 20px 22px;
    cursor:pointer;
    transition: border-color .2s, box-shadow .2s, transform .15s;
}
.trm-card:hover {
    border-color: var(--gold);
    box-shadow: 0 4px 20px rgba(201,168,76,.15);
    transform: translateY(-2px);
}
.trm-card-body { flex:1; min-width:0; }
.trm-card-body h3 {
    font-size: 28px; font-weight:600;
    color: var(--black) !important; margin-bottom:6px; line-height:1.3;
}
.trm-card-desc {
    font-size: 18px; color: var(--muted) !important; line-height:1.55;
    margin-bottom: 14px;
    display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}
/* ── ADD BUTTON — solid, always visible ── */
.trm-add-btn {
    display: inline-flex !important;
    align-items: center;
    background-color: var(--black) !important;
    color: var(--white) !important;
    border: 2px solid var(--black) !important;
    padding: 11px 22px !important;
    border-radius: 50px !important;
    font-family: 'Outfit', sans-serif !important;
    font-size: 15px !important; font-weight: 700 !important;
    cursor: pointer; white-space: nowrap;
    transition: background .2s, color .2s !important;
    opacity: 1 !important; visibility: visible !important;
}
.trm-add-btn:hover {
    background-color: var(--gold) !important;
    border-color: var(--gold) !important;
    color: var(--black) !important;
}
.trm-card-img {
    flex-shrink:0; width:130px; height:130px;
    border-radius:10px; overflow:hidden;
    background-color: #EDE9E2 !important;
}
.trm-card-img img { width:100%; height:100% !important; object-fit:cover; display:block; transition:transform .35s; }
.trm-card:hover .trm-card-img img { transform:scale(1.07); }
.trm-card.trm-hidden { display:none; }

/* ════════════════════════════════════════
   SIDEBAR CART — solid white, sticky
════════════════════════════════════════ */
.trm-sidebar {
    background-color: var(--white) !important;
    border-left: 1px solid var(--border);
    position: sticky;
    top: 150px;
    align-self: start;
    max-height: calc(100vh - var(--nav-h));
    overflow-y: auto;
}
.trm-cart-wrap { padding: 26px 22px; }
.trm-cart-title {
   
    font-size:26px; font-weight:700;
    color: var(--black) !important;
    margin-bottom:18px; padding-bottom:14px;
    border-bottom:1.5px solid var(--border);
}
.trm-empty { text-align:center; padding:52px 16px; }
.trm-empty p { font-size:15px; color:#C0BDB5 !important; margin-top:12px; }

/* Cart item rows */
.trm-ci {
    display:flex; align-items:flex-start; gap:10px;
    padding:13px 0; border-bottom:1px solid var(--border);
}
.trm-ci-left { flex:1; min-width:0; }
.trm-ci-name { font-size:18px; font-weight:600; color:var(--black) !important; line-height:1.3; margin-bottom:3px; }
.trm-ci-extras { font-size:13px; color:var(--muted) !important; margin-bottom:7px; }
.trm-ci-price { font-size:18px; font-weight:700; color:var(--black) !important; white-space:nowrap; padding-top:1px; }

.trm-ci-qty { display:flex; align-items:center; gap:9px; }
.trm-qb {
    width:28px; height:28px;
    border:1.5px solid var(--border) !important;
    background-color: var(--white) !important;
    border-radius:50%; cursor:pointer;
    font-size:17px; font-weight:700; line-height:1;
    display:flex; align-items:center; justify-content:center;
    color: var(--text) !important;
    transition:border-color .15s, color .15s;
}
.trm-qb:hover { border-color:var(--gold) !important; color:var(--gold) !important; }
.trm-qn { font-size:15px; font-weight:700; min-width:20px; text-align:center; }

/* Totals */
.trm-totals { border-top:1.5px solid var(--border); padding-top:14px; margin-top:4px; }
.trm-row {
    display:flex; justify-content:space-between; align-items:center;
    font-size:17.5px; color:var(--muted) !important; padding:5px 0;
}
.trm-row span:first-child { color: var(--muted) !important; }
.trm-row span:last-child  { font-weight:600; color: var(--text) !important; }
.trm-green { color: var(--green) !important; }
.trm-delivery-msg { font-size:15px; color:var(--gold-dk) !important; font-weight:600; margin:6px 0 2px; min-height:18px; }

.trm-grand {
    display:flex; justify-content:space-between; align-items:baseline;
    padding:14px 0 18px; border-top:2px solid var(--border); margin-top:10px;
}
.trm-grand span:first-child {
   
    font-size:22px; font-weight:700; color:var(--black) !important;
}
.trm-grand span:last-child {
    
    font-size:28px; font-weight:700; color:var(--black) !important;
}
.trm-checkout-btn {
    display:block !important; width:100%;
    background-color: var(--black) !important; color: var(--white) !important;
    border: 2px solid var(--black) !important;
    padding: 16px 24px !important; border-radius:50px;
    font-family:'Outfit',sans-serif !important; font-size:17px !important; font-weight:700 !important;
    letter-spacing:.04em; cursor:pointer; text-align:center;
    transition:background .2s, color .2s;
}
.trm-checkout-btn:hover {
    background-color: var(--gold) !important;
    border-color: var(--gold) !important;
    color: var(--black) !important;
}
.trm-checkout-btn:disabled { opacity:.6; cursor:wait; }

/* ════════════════════════════════════════
   UPSELL POPUP — completely rebuilt, solid backgrounds
════════════════════════════════════════ */
.trm-overlay {
    display: none;
    position: fixed; inset: 0;
    background: rgba(10,10,10,.70) !important;
    backdrop-filter: blur(4px);
    z-index: 99999 !important;
    align-items: center; justify-content: center;
    padding: 16px;
}
.trm-overlay.active { display: flex; }

.trm-popup {
    background-color: var(--white) !important;
    border-radius: 18px;
    max-width: 580px; width: 100%;
    max-height: 80vh; overflow-y: auto;
    position: relative;
    box-shadow: 0 24px 64px rgba(0,0,0,.30);
    animation: trmPopIn .22s cubic-bezier(.22,.68,0,1.2);
    margin-top:120px;
}
@keyframes trmPopIn {
    from { transform:scale(.88) translateY(16px); opacity:0; }
    to   { transform:scale(1) translateY(0); opacity:1; }
}
.trm-popup-close {
    position:absolute; top:14px; right:14px;
    width:34px; height:34px;
    background-color: #1C1C1C !important; border:none; border-radius:50%;
    color: #fff !important; font-size:15px; cursor:pointer;
    display:flex; align-items:center; justify-content:center;
    z-index:10; transition:background .2s;
}
.trm-popup-close:hover { background-color: var(--red) !important; }

/* Popup hero section */
.trm-popup-hero {
    display:flex; align-items:flex-start; gap:18px;
    padding: 28px 28px 22px;
    background-color: #FAFAF8 !important;
    border-bottom: 1.5px solid var(--border);
    border-radius: 18px 18px 0 0;
}
#trmPopupImg {
    width:96px; height:80px; object-fit:cover;
    border-radius:12px; flex-shrink:0;
    background-color: #EDE9E2 !important;
    box-shadow: 0 4px 12px rgba(0,0,0,.10);
}
.trm-popup-info h2 {
  
    font-size:24px; font-weight:700; color:var(--black) !important; margin-bottom:7px;
}
.trm-popup-info p { font-size:14px; color:var(--muted) !important; line-height:1.55; }

/* Main dish row inside popup */
.trm-popup-main-item {
    padding: 16px 28px;
    background-color: #fff !important;
    border-bottom: 1px solid var(--border);
}
.trm-popup-main-row {
    display:flex; align-items:center; justify-content:space-between;
    padding: 14px 18px;
    background-color: #FFFAEF !important;
    border: 1.5px solid rgba(201,168,76,.40);
    border-radius: 10px;
}
.trm-pmr-info { display:flex; flex-direction:column; gap:4px; }
.trm-pmr-name { font-size:16px; font-weight:600; color:var(--black) !important; }
.trm-pmr-price { font-size:15px; font-weight:700; color:var(--gold-dk) !important; }
.trm-pmr-badge {
    background-color: var(--gold) !important; color: var(--black) !important;
    font-size:11px; font-weight:700; letter-spacing:.05em;
    padding:4px 12px; border-radius:20px; white-space:nowrap;
}

/* Extras area */
.trm-popup-extras {
    padding: 4px 28px 12px;
    background-color: #fff !important;
}
.trm-pop-loading { color:#bbb; font-size:14px; text-align:center; padding:20px 0; }
.trm-pop-err     { color:var(--red); font-size:14px; text-align:center; padding:14px 0; }

.trm-extras-group { margin-top:20px; }
.trm-extras-hd {
    display:flex; justify-content:space-between; align-items:center;
    margin-bottom:10px;
}
.trm-extras-title { font-size:16px; font-weight:700; color:var(--black) !important; }
.trm-optional-badge {
    font-size:11px; font-weight:600; color:var(--muted);
    background-color: #F0EDE6 !important; padding:3px 10px; border-radius:20px;
}

/* Extra product rows — SOLID WHITE always */
.trm-extra-row {
    display:flex; align-items:center; gap:14px;
    padding: 12px 16px;
    background-color: var(--white) !important;
    border: 1.5px solid var(--border);
    border-radius: 10px;
    margin-bottom: 8px;
    cursor: pointer;
    transition: border-color .2s, background-color .2s;
}
.trm-extra-row.trm-row-selected {
    border-color: var(--gold) !important;
    background-color: #FFFAEF !important;
}
.trm-extra-thumb {
    width:54px; height:46px; object-fit:cover;
    border-radius:8px; flex-shrink:0;
    background-color: #EDE9E2 !important;
}
.trm-extra-ph { background-color:#EDE9E2 !important; }
.trm-extra-body { flex:1; min-width:0; }
.trm-extra-name { display:block; font-size:15px; font-weight:600; color:var(--black) !important; margin-bottom:3px; }
.trm-extra-price { display:block; font-size:13.5px; color:var(--gold-dk) !important; font-weight:600; }

/* Extra ADD button — always solid, clearly visible */
.trm-extra-add-btn {
    flex-shrink:0;
    background-color: var(--white) !important;
    color: var(--black) !important;
    border: 1.5px solid var(--border) !important;
    padding: 8px 20px !important;
    border-radius: 50px;
    font-family:'Outfit',sans-serif !important;
    font-size: 14px !important; font-weight:600 !important;
    cursor:pointer; white-space:nowrap;
    transition:background .2s, color .2s, border-color .2s;
    min-width: 80px; text-align:center;
}
.trm-extra-add-btn:hover {
    border-color: var(--gold) !important; color: var(--gold) !important;
}
.trm-extra-add-btn.trm-selected {
    background-color: var(--gold) !important;
    color: var(--black) !important;
    border-color: var(--gold) !important;
}

/* Popup footer */
.trm-popup-footer {
    display:flex; align-items:center; justify-content:space-between;
    padding: 18px 28px 26px;
    background-color: #FAFAF8 !important;
    border-top: 1.5px solid var(--border);
    border-radius: 0 0 18px 18px;
    gap: 16px;
}
.trm-popup-total-wrap { display:flex; flex-direction:column; gap:2px; }
.trm-popup-total-label { font-size:12px; color:var(--muted) !important; font-weight:500; }
.trm-popup-total {
   
    font-size:30px; font-weight:700;
    color: var(--black) !important; line-height:1;
}
.trm-popup-confirm {
    flex:1;
    background-color: #000 !important; color: #fff !important;
    border:none !important; padding:15px 28px !important; border-radius:50px;
    font-family:'Outfit',sans-serif !important; font-weight:700 !important; font-size:16px !important;
    letter-spacing:.04em; cursor:pointer; transition:background .2s;
}
.trm-popup-confirm:hover { background-color: #8C6820 !important; }

/* ════════════════════════════════════════
   MOBILE FAB
════════════════════════════════════════ */
.trm-fab {
    display:none; position:fixed; bottom:24px; right:24px;
    background-color: #000 !important; color: #8C6820 !important;
    border: 2px solid #8C6820 !important; border-radius:50px;
    padding: 14px 22px; align-items:center; gap:8px;
    font-size:16px; font-weight:700; cursor:pointer; z-index:1001;
    box-shadow:0 8px 28px rgba(0,0,0,.30); transition:transform .15s;
}
.trm-fab:active { transform:scale(.95); }
.trm-fab-count {
    background-color: #8C6820 !important; color: #000 !important;
    border-radius:50%; width:24px; height:24px;
    font-size:13px; font-weight:800;
    display:flex; align-items:center; justify-content:center;
}
.trm-overlay-bg {
    display:none; position:fixed; inset:0;
    background:rgba(0,0,0,.48) !important; z-index:498;
}
.trm-overlay-bg.active { display:block; }
#trmFab{
    display:none !important;
}

/* ════════════════════════════════════════
   RESPONSIVE
════════════════════════════════════════ */
@media (max-width: 960px) {
    #trmFab{
    display:block !important;
}
    .trm-layout { grid-template-columns:1fr; }
    .trm-sidebar {
        position:fixed; top:0; right:0; bottom:0;
        width:min(380px, 94vw);
        transform:translateX(110%);
        transition:transform .3s cubic-bezier(.4,0,.2,1);
        z-index:9999; max-height:100vh;
        box-shadow:-6px 0 40px rgba(0,0,0,.22);
        border-radius:0; border-left:1px solid var(--border);
    }
    .trm-sidebar.open { transform:translateX(0); }
    .trm-fab { display:flex; }
    .trm-name { font-size:28px; }
    .trm-header { padding:22px 0; }
    .trm-section:last-child { padding-bottom:100px; }
    .trm-container { padding:0 16px; }
}

@media (max-width: 600px) {
    .trm-name { font-size:22px; }
    .trm-dot  { display:none; }
    .trm-meta { flex-direction:column; gap:5px; }
    .trm-meta-item { font-size:13.5px; }
    .trm-toolbar { padding-top:18px; gap:10px; }
    .trm-card { padding:16px 14px; gap:14px; }
    .trm-card-img { width:88px; height:72px; }
    .trm-card-body h3 { font-size:16px; }
    .trm-add-btn { padding:9px 16px !important; font-size:14px !important; }
    .trm-promo-row { flex-direction:column; }
    .trm-promo-row input, .trm-promo-row button { width:100%; }
    /* Popup as bottom sheet */
    .trm-overlay { align-items:flex-end; padding:0; }
    .trm-popup { max-height:80vh; border-radius:20px 20px 0 0; max-width:100%; margin-top:0px;position: relative;
        z-index: 99999;}
    .trm-popup-hero { border-radius:20px 20px 0 0; padding:20px 18px 16px; }
    .trm-popup-main-item { padding:12px 18px; }
    .trm-popup-extras { padding:4px 18px 8px; }
    .trm-popup-footer { padding:14px 18px 28px; border-radius:0; }
    .trm-popup-confirm { padding:14px 20px !important; }
    .trm-section-title h2 { font-size:24px; }
    .trm-checkout-btn { font-size:16px !important; padding:15px !important; }
    .main_head{text-align:center;}
}
