/* ════════ MAJORITY PORTAL CSS ════════ */
:root {
  --blue: #005DF4; --blue-light: #1a70ff; --blue-glow: rgba(0,93,244,0.3);
  --black: #0A0A0A; --dark: #111318; --dark2: #1a1d24; --dark3: #22262f;
  --white: #fff; --gray: #8892a4; --gray-light: #c8d0dc;
  --border: rgba(255,255,255,0.08); --font: 'Outfit',sans-serif;
  --radius: 12px; --radius-sm: 8px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--font);background:var(--black);color:var(--white);min-height:100vh}
a{text-decoration:none;color:inherit}
button{cursor:pointer;border:none;background:none;font-family:var(--font)}
.text-blue{color:var(--blue)}
.section-container{max-width:1280px;margin:0 auto;padding:0 24px}

/* ── LOGIN ── */
.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(ellipse at center,#0d1626 0%,var(--black) 70%)}
.login-card{background:var(--dark);border:1px solid var(--border);border-radius:20px;padding:48px 40px;width:100%;max-width:480px;text-align:center;box-shadow:0 24px 80px rgba(0,0,0,0.6)}
.login-logo{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:16px}
.logo-badge{width:42px;height:42px;background:var(--blue);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:900;box-shadow:0 0 20px var(--blue-glow)}
.logo-text{font-size:1.4rem;font-weight:800;letter-spacing:4px}
.login-badge{display:inline-block;background:rgba(0,93,244,0.15);border:1px solid rgba(0,93,244,0.3);color:var(--blue-light);font-size:0.72rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:5px 14px;border-radius:20px;margin-bottom:24px}
.login-title{font-size:2.2rem;font-weight:800;margin-bottom:8px}
.login-sub{color:var(--gray);font-size:0.92rem;margin-bottom:32px;line-height:1.5}
.login-form{display:flex;flex-direction:column;gap:14px}
.input-wrap input{width:100%;padding:14px 18px;background:var(--dark3);border:1px solid var(--border);border-radius:var(--radius);color:var(--white);font-family:var(--font);font-size:1rem;font-weight:600;letter-spacing:2px;text-transform:uppercase;text-align:center;transition:border-color .2s}
.input-wrap input:focus{outline:none;border-color:var(--blue)}
.input-wrap input::placeholder{text-transform:none;letter-spacing:0;font-weight:400}
.input-hint{font-size:0.72rem;color:var(--gray);margin-top:6px}
.login-error{color:#ff5555;font-size:0.85rem;min-height:20px}
.btn-login{padding:15px;background:var(--blue);color:var(--white);font-family:var(--font);font-size:1rem;font-weight:700;border-radius:var(--radius);transition:background .2s,transform .2s;box-shadow:0 4px 20px var(--blue-glow)}
.btn-login:hover{background:var(--blue-light);transform:translateY(-2px)}
.login-footer{display:flex;justify-content:space-between;align-items:center;margin-top:24px;font-size:0.82rem;color:var(--gray)}
.back-link:hover,.login-footer a:hover{color:var(--white)}

/* ── PORTAL NAV ── */
.portal-nav{position:sticky;top:0;z-index:100;background:rgba(10,10,10,0.9);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);height:66px}
.portal-nav-inner{max-width:1280px;margin:0 auto;padding:0 24px;height:100%;display:flex;align-items:center;gap:16px}
.nav-logo{display:flex;align-items:center;gap:10px;margin-right:auto}
.nav-tag{background:rgba(0,93,244,0.15);border:1px solid rgba(0,93,244,0.3);color:var(--blue-light);font-size:0.7rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:3px 10px;border-radius:12px}
.nav-client{font-size:0.85rem;color:var(--gray-light);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}
.btn-cart-nav{position:relative;padding:9px 18px;background:var(--dark3);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--white);font-size:0.88rem;font-weight:600;transition:border-color .2s}
.btn-cart-nav:hover{border-color:var(--blue)}
.cart-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;background:var(--blue);border-radius:10px;font-size:0.65rem;font-weight:700;padding:0 4px;margin-left:6px}
.btn-logout{padding:9px 14px;background:transparent;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--gray);font-size:0.82rem;transition:all .2s}
.btn-logout:hover{border-color:#ff5555;color:#ff5555}

/* ── WELCOME BAR ── */
.welcome-bar{background:linear-gradient(90deg,#050e2a,#0a1945);border-bottom:1px solid rgba(0,93,244,0.2);padding:20px 0}
.welcome-inner{max-width:1280px;margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.welcome-inner h2{font-size:1.3rem;font-weight:700;margin-bottom:4px}
.welcome-inner p{color:var(--gray-light);font-size:0.85rem}
.discount-badge{background:rgba(0,93,244,0.2);border:1px solid rgba(0,93,244,0.4);border-radius:12px;padding:12px 20px;text-align:center;white-space:nowrap}
.disc-num{display:block;font-size:2rem;font-weight:900;color:var(--blue-light);line-height:1}

/* ── FILTERS ── */
.portal-filters{padding:20px 0;background:var(--dark);border-bottom:1px solid var(--border);position:sticky;top:66px;z-index:50}
.filter-row{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.search-input{padding:10px 16px;background:var(--dark3);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--white);font-family:var(--font);font-size:0.88rem;width:220px;transition:border-color .2s}
.search-input:focus{outline:none;border-color:var(--blue)}
.filter-btns { display: flex; gap: 8px; flex-wrap: wrap; justify-content: center; }
.f-btn{padding:8px 18px;border-radius:20px;font-family:var(--font);font-size:0.82rem;font-weight:600;color:var(--gray);background:var(--dark2);border:1px solid var(--border);transition:all .2s}
.f-btn:hover{color:var(--white)}
.f-btn.active{background:var(--blue);color:var(--white);border-color:var(--blue);box-shadow:0 2px 12px var(--blue-glow)}

/* ── PRODUCTS ── */
.portal-main{padding-bottom:60px}
.products-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;padding:32px 0}
.loading-msg{grid-column:1/-1;text-align:center;color:var(--gray);padding:40px}

.m-card{background:var(--dark2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:transform .25s,border-color .25s}
.m-card:hover{transform:translateY(-4px);border-color:rgba(0,93,244,0.35)}
.m-card-img{aspect-ratio:1;background:var(--dark3);display:flex;align-items:center;justify-content:center;padding:24px;position:relative}
.m-cat-badge{position:absolute;top:10px;left:10px;background:rgba(0,93,244,.2);border:1px solid rgba(0,93,244,.4);color:var(--blue-light);font-size:.65rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:3px 8px;border-radius:10px}
.m-card-img svg, .m-card-img img { width: auto; max-width: 100%; height: auto; max-height: 100%; object-fit: contain; }
.m-card-body{padding:16px}
.m-name{font-size:.95rem;font-weight:700;margin-bottom:6px}
.m-desc{font-size:.75rem;color:var(--gray);margin-bottom:12px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.m-prices{display:flex;flex-direction:column;gap:2px;margin-bottom:14px}
.m-price-pub{font-size:.72rem;color:var(--gray);text-decoration:line-through}
.m-price-row{display:flex;align-items:center;gap:8px}
.m-price-maj{font-size:1.3rem;font-weight:800}
.m-price-save{background:rgba(0,200,100,.15);border:1px solid rgba(0,200,100,.3);color:#00c864;font-size:.68rem;font-weight:700;padding:2px 8px;border-radius:10px}
.btn-m-add{width:100%;padding:11px;background:var(--blue);color:var(--white);font-family:var(--font);font-size:.85rem;font-weight:700;border-radius:var(--radius-sm);border:none;transition:background .2s;cursor:pointer}
.btn-m-add:hover{background:var(--blue-light)}

/* ── CART SIDEBAR ── */
.cart-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:200;opacity:0;pointer-events:none;transition:opacity .3s;backdrop-filter:blur(4px)}
.cart-overlay.active{opacity:1;pointer-events:all}
.cart-sidebar{position:fixed;top:0;right:-440px;width:440px;height:100vh;background:var(--dark);border-left:1px solid var(--border);z-index:201;display:flex;flex-direction:column;transition:right .35s cubic-bezier(.25,.46,.45,.94)}
.cart-sidebar.open{right:0}
.cart-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--border)}
.cart-head h2{font-size:1.05rem;font-weight:700}
.cart-head button{width:32px;height:32px;border-radius:6px;background:var(--dark3);color:var(--white);display:flex;align-items:center;justify-content:center}
.cart-client-info{padding:12px 22px;background:rgba(0,93,244,.08);border-bottom:1px solid var(--border);font-size:.82rem;color:var(--gray-light)}
.cart-body{flex:1;overflow-y:auto;padding:14px 22px;display:flex;flex-direction:column;gap:12px}
.cart-empty-msg{color:var(--gray);text-align:center;padding:40px 0;font-size:.9rem}
.c-item{display:flex;gap:12px;padding:12px;background:var(--dark2);border:1px solid var(--border);border-radius:var(--radius-sm);align-items:center}
.c-item-icon{width:46px;height:46px;background:var(--dark3);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.c-item-icon svg{width:26px;height:26px}
.c-item-info{flex:1;min-width:0}
.c-item-name{font-size:.85rem;font-weight:600;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.c-item-flavor{font-size:.72rem;color:var(--gray);margin-bottom:8px}
.c-item-controls{display:flex;align-items:center;gap:6px}
.qty-btn{width:24px;height:24px;border-radius:5px;background:var(--dark3);color:var(--white);font-size:.9rem;display:flex;align-items:center;justify-content:center;transition:background .2s;cursor:pointer}
.qty-btn:hover{background:var(--blue)}
.qty-num{font-size:.88rem;font-weight:600;min-width:18px;text-align:center}
.c-item-rm{color:var(--gray);font-size:.7rem;cursor:pointer;transition:color .2s}
.c-item-rm:hover{color:#ff5555}
.c-item-price{font-size:.95rem;font-weight:700;white-space:nowrap}
.cart-foot{padding:18px 22px;border-top:1px solid var(--border);background:var(--dark2)}
.cart-total-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.cart-total-row strong{font-size:1.5rem;font-weight:800}
.btn-whatsapp{width:100%;padding:14px;background:#25D366;color:#fff;font-family:var(--font);font-size:.95rem;font-weight:700;border-radius:var(--radius);border:none;display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:8px;cursor:pointer;transition:background .2s}
.btn-whatsapp:hover{background:#1ebe5d}
.btn-clear{width:100%;padding:10px;background:transparent;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--gray);font-family:var(--font);font-size:.85rem;cursor:pointer;transition:color .2s,border-color .2s}
.btn-clear:hover{color:#ff5555;border-color:#ff5555}

/* ── FLAVOR MODAL ── */
.fmodal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:300;display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;pointer-events:none;transition:opacity .3s;backdrop-filter:blur(8px)}
.fmodal-overlay.active{opacity:1;pointer-events:all}
.fmodal-box{background:var(--dark);border:1px solid var(--border);border-radius:16px;padding:32px;width:100%;max-width:440px;position:relative;transform:scale(.92);transition:transform .3s;box-shadow:0 24px 80px rgba(0,0,0,.7)}
.fmodal-overlay.active .fmodal-box{transform:scale(1)}
.fmodal-close{position:absolute;top:12px;right:12px;width:32px;height:32px;border-radius:6px;background:var(--dark3);color:var(--white);display:flex;align-items:center;justify-content:center;cursor:pointer}
.fmodal-box h3{font-size:1.1rem;font-weight:700;margin-bottom:16px}
.fmodal-flavors{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}
.fm-flavor{padding:9px 16px;border-radius:8px;background:var(--dark3);border:1px solid var(--border);color:var(--gray-light);font-size:.85rem;cursor:pointer;transition:all .2s;font-family:var(--font)}
.fm-flavor:hover,.fm-flavor.selected{border-color:var(--blue);background:rgba(0,93,244,.15);color:var(--white)}
.fmodal-qty{margin-bottom:20px}
.fmodal-qty label{font-size:.8rem;color:var(--gray);display:block;margin-bottom:8px}
.qty-row{display:flex;align-items:center;gap:10px}
.qty-row button{width:36px;height:36px;border-radius:8px;background:var(--dark3);color:var(--white);font-size:1.1rem;display:flex;align-items:center;justify-content:center;cursor:pointer;border:1px solid var(--border);transition:background .2s}
.qty-row button:hover{background:var(--blue)}
.qty-row input{width:60px;padding:8px;background:var(--dark3);border:1px solid var(--border);border-radius:8px;color:var(--white);font-family:var(--font);font-size:1rem;font-weight:600;text-align:center}
.qty-row input:focus{outline:none;border-color:var(--blue)}
.btn-fmodal-add{width:100%;padding:14px;background:var(--blue);color:var(--white);font-family:var(--font);font-size:.95rem;font-weight:700;border-radius:var(--radius);border:none;cursor:pointer;transition:background .2s}
.btn-fmodal-add:hover{background:var(--blue-light)}

@media(max-width:900px){.products-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.products-grid{grid-template-columns:1fr}.portal-filters{position:static}.filter-row{flex-direction:column;align-items:stretch}.search-input{width:100%}.cart-sidebar{width:100%;right:-100%}.welcome-inner{flex-direction:column;gap:12px}.nav-client{display:none}}
