:root{
  --purple:#5a3e92;
  --purple-2:#4d357f;
  --ink:#171717;
  --muted:#666;
  --bg:#ffffff;
  --line:#e6e6e6;
  --chip:#f3f3f3;
  --shadow:0 10px 24px rgba(0,0,0,.18);
}

*{box-sizing:border-box;}
html,body{height:100%;}
body{
  margin:0;
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  background:#111;
  display:grid;
  place-items:center;
}

/* Phone-only viewport */
.phone{
  width:min(430px, 100vw);
  height:100vh;
  max-height:900px;
  background:var(--bg);
  position:relative;
  overflow:hidden;
  border-radius:26px;
  box-shadow:var(--shadow);
}

@media (max-width: 480px){
  body{background:#000;}
  .phone{border-radius:0; height:100vh; max-height:none; box-shadow:none;}
}

.safe{
  height:100%;
  padding: max(16px, env(safe-area-inset-top))
           max(16px, env(safe-area-inset-right))
           max(16px, env(safe-area-inset-bottom))
           max(16px, env(safe-area-inset-left));
}

.screen{
  position:absolute;
  inset:0;
  background:var(--bg);
  display:none;
}
.screen--active{display:block;}

/* Splash */
.splashCenter{
  height:100%;
  display:grid;
  place-items:center;
  gap:18px;
}
.brandText{ text-align:center; color:var(--purple); }
.brandName{ font-weight:800; letter-spacing:2px; font-size:34px; }
.brandTag{ font-weight:700; font-size:16px; letter-spacing:1px; margin-top:6px; }

.brandMark{ display:grid; place-items:center; }
.bag{
  width:130px; height:105px;
  position:relative;
  background:var(--purple);
  border-radius:10px 10px 12px 12px;
  transform:skewX(-6deg);
}
.bag::after{
  content:"";
  position:absolute;
  right:-16px; top:8px;
  width:20px; height:92px;
  background:rgba(0,0,0,.10);
  border-radius:0 10px 12px 0;
}
.bagHandle{
  position:absolute;
  left:26px; top:-18px;
  width:78px; height:42px;
  border:10px solid var(--purple);
  border-bottom-color:transparent;
  border-left-color:transparent;
  border-right-color:transparent;
  border-radius:50px;
  transform:skewX(6deg);
  opacity:.95;
}
.bagM{
  position:absolute;
  inset:22px 18px 18px 18px;
  background:transparent;
  border-left:22px solid transparent;
  border-right:22px solid transparent;
  border-top:0;
}
.bagM::before{
  content:"";
  position:absolute;
  left:6px; top:12px;
  width:0; height:0;
  border-left:30px solid transparent;
  border-right:30px solid transparent;
  border-bottom:46px solid #fff;
  transform:skewX(6deg);
}
.bagM::after{
  content:"";
  position:absolute;
  left:20px; top:38px;
  width:70px; height:18px;
  background:#fff;
  transform:skewX(6deg) rotate(-12deg);
  clip-path:polygon(0 100%, 15% 0, 50% 70%, 85% 0, 100% 100%, 70% 100%, 50% 55%, 30% 100%);
}

/* Shared typography/buttons */
.h1{margin:0; font-size:22px; font-weight:800; color:var(--ink);}
.sub{margin:10px 0 18px; color:var(--muted); font-size:13px; line-height:1.35;}
.fine{margin:14px 0 0; color:var(--muted); font-size:11px; line-height:1.35; text-align:center;}
.linkish{color:var(--purple); font-weight:700;}
.muted{color:#888;}

.btn{
  width:100%;
  border-radius:12px;
  padding:13px 14px;
  font-weight:800;
  border:1px solid var(--line);
  background:#fff;
  color:var(--ink);
  box-shadow:0 4px 10px rgba(0,0,0,.10);
}
.btn:active{transform:translateY(1px);}
.btn--primary{
  border:0;
  background:var(--purple);
  color:#fff;
  box-shadow:0 6px 14px rgba(90,62,146,.35);
}
.btn--ghost{background:#fff;}
.btn--wide{margin-top:22px;}

/* Auth hero + sheet */
.heroArt{
  height:56%;
  background:#171717;
  position:relative;
  overflow:hidden;
}
.fireworks{
  position:absolute;
  inset:-40px -40px auto -40px;
  height:220px;
  background:
    radial-gradient(circle at 15% 40%, rgba(255,255,255,.18) 0 18px, transparent 20px),
    radial-gradient(circle at 25% 25%, rgba(255,255,255,.15) 0 14px, transparent 16px),
    radial-gradient(circle at 80% 35%, rgba(255,255,255,.18) 0 22px, transparent 24px),
    radial-gradient(circle at 75% 20%, rgba(255,255,255,.12) 0 16px, transparent 18px),
    radial-gradient(circle at 55% 30%, rgba(255,206,0,.14) 0 10px, transparent 12px),
    radial-gradient(circle at 40% 45%, rgba(255,206,0,.12) 0 8px, transparent 10px);
  opacity:.9;
}
.peopleSilhouette{
  position:absolute;
  left:0; right:0; bottom:0;
  height:70%;
  background:
    radial-gradient(circle at 30% 70%, rgba(255,255,255,.0) 0 30px, transparent 31px),
    linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,.35) 60%, rgba(0,0,0,.55) 100%);
}

.sheet{
  position:absolute;
  left:0; right:0; bottom:0;
  height:52%;
  background:#fff;
  border-radius:26px 26px 0 0;
  box-shadow:0 -10px 24px rgba(0,0,0,.14);
}
.sheetGrip{
  width:52px; height:5px;
  background:#cfcfcf;
  border-radius:999px;
  margin:10px auto 0;
}
.sheetBody{
  padding:18px 18px 22px;
  display:flex;
  flex-direction:column;
  gap:12px;
}

.pagerDots{display:grid; place-items:center; margin-top:0;}
.dot{width:6px; height:6px; border-radius:50%; background:#cfcfcf;}
.dot--active{background:#3f87ff;}

.socialRow{display:flex; gap:16px; justify-content:center; margin-top:4px;}
.socialBtn{
  width:118px; height:44px;
  border:1px solid var(--line);
  border-radius:12px;
  display:grid;
  place-items:center;
  font-weight:900;
  color:#444;
  background:#fff;
}

/* Phone number / OTP screens */
.topbar{height:44px; padding: max(10px, env(safe-area-inset-top)) 14px 0; display:flex; align-items:center;}
.back{
  border:0; background:transparent; color:var(--purple);
  font-weight:800; font-size:14px; padding:6px 4px;
}
.contentPad{padding:10px 16px 16px;}

.inputRow{position:relative; margin-top:10px;}
.iconPhone{
  position:absolute; left:10px; top:50%; transform:translateY(-50%);
  width:18px; height:18px;
  border:2px solid #bbb;
  border-radius:4px;
}
.input{
  width:100%;
  padding:14px 14px 14px 42px;
  border:2px solid rgba(90,62,146,.65);
  border-radius:12px;
  font-size:16px;
  outline:none;
}

.centerCol{display:flex; flex-direction:column; align-items:center;}
.shield{
  width:40px; height:40px;
  border-radius:12px;
  border:2px solid #ddd;
  margin-top:14px;
  position:relative;
}
.shield::before{
  content:"";
  position:absolute;
  left:50%; top:50%;
  transform:translate(-50%,-50%);
  width:0; height:0;
  border-left:10px solid transparent;
  border-right:10px solid transparent;
  border-top:14px solid #ddd;
  opacity:.8;
}

.otpRow{display:flex; gap:12px; margin:16px 0 6px;}
.otp{
  width:50px; height:50px;
  border-radius:10px;
  border:0;
  background:#dedede;
  text-align:center;
  font-weight:900;
  font-size:18px;
  outline: 2px solid transparent;
}
.otp:focus{outline-color: rgba(90,62,146,.70); background:#f1f1f1;}

.spacer{flex:1;}

.doneCenter{height:100%; display:grid; place-items:center; gap:14px;}
.checkCircle{
  width:110px; height:110px;
  border-radius:999px;
  background:var(--purple);
  display:grid; place-items:center;
}
.check{color:#fff; font-size:52px; font-weight:900; line-height:1;}
.doneLabel{color:var(--muted); font-weight:800;}

/* Home */
.homeSafe{padding: max(10px, env(safe-area-inset-top)) 12px max(10px, env(safe-area-inset-bottom)) 12px;}
.homeHeader{padding-bottom:78px;}

.searchBar{
  height:44px;
  background:#e6e6e6;
  border-radius:10px;
  display:flex;
  align-items:center;
  padding:0 10px;
  gap:8px;
}
.searchIcon{width:16px; height:16px; border:2px solid #666; border-radius:50%; position:relative;}
.searchIcon::after{content:""; position:absolute; width:8px; height:2px; background:#666; right:-7px; bottom:-2px; transform:rotate(45deg); border-radius:2px;}
.micIcon{width:14px; height:18px; border:2px solid #666; border-bottom:0; border-radius:7px 7px 4px 4px; position:relative; margin-left:auto;}
.micIcon::after{content:""; position:absolute; left:50%; bottom:-4px; transform:translateX(-50%); width:10px; height:2px; background:#666; border-radius:2px;}
.searchInput{flex:1; border:0; background:transparent; outline:none; font-weight:700; color:#222;}

.categoryRow{display:flex; gap:14px; padding:12px 2px 8px; overflow:auto;}
.categoryRow::-webkit-scrollbar{display:none;}
.cat{min-width:56px; display:flex; flex-direction:column; align-items:center; gap:6px;}
.catImg{width:44px; height:44px; border-radius:999px; background:#d9d9d9;}
.catLbl{font-size:11px; color:#444;}

.tileGrid{display:grid; grid-template-columns:1fr 1fr; gap:10px; padding:4px 0 10px;}
.tile{height:110px; border-radius:10px; background:#cfcfcf; position:relative; overflow:hidden;}
.tile--img{
  background:
    linear-gradient(180deg, rgba(0,0,0,.10) 0%, rgba(0,0,0,.45) 100%),
    linear-gradient(135deg, #d7d7d7, #bdbdbd);
}
.tileTag{
  position:absolute;
  left:0; right:0; top:0;
  padding:8px 8px;
  font-size:12px;
  color:#fff;
  font-weight:800;
}

.banner{
  margin:12px 0 10px;
  height:118px;
  border-radius:12px;
  background:linear-gradient(180deg, rgba(90,62,146,.20), rgba(90,62,146,.60));
  display:flex;
  overflow:hidden;
}
.bannerLeft{width:45%; display:flex; align-items:center; justify-content:center; padding:10px;}
.meeshoBadge{
  width:100%;
  background:#fff;
  border-radius:12px;
  padding:12px 10px;
  font-weight:900;
  color:var(--purple);
  line-height:1.05;
}
.super{color:#ff3b30;}
.deals{color:#ff3b30;}
.bannerRight{flex:1; padding:14px 12px; color:#fff;}
.bannerTitle{font-size:22px; font-weight:900; line-height:1.05;}
.bannerSub{font-size:11px; margin-top:6px; opacity:.95;}
.bannerLink{font-size:11px; margin-top:2px; text-decoration:underline;}

.homeSection{display:flex; align-items:center; justify-content:space-between; padding:6px 0 0;}
.homeTitle{font-weight:900; font-size:18px; color:#2a2a2a;}
.filterBtn{
  height:32px;
  border:0;
  background:#fff;
  border-radius:999px;
  padding:0 14px;
  box-shadow:0 6px 14px rgba(0,0,0,.15);
  font-weight:800;
  display:flex;
  align-items:center;
  gap:8px;
}
.sliders{width:16px; height:12px; position:relative;}
.sliders::before,.sliders::after{content:""; position:absolute; left:0; right:0; height:2px; background:#333; border-radius:2px;}
.sliders::before{top:2px;}
.sliders::after{bottom:2px;}

.productGrid{
  margin-top:10px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
.productCard{
  border:1px solid #e8e8e8;
  border-radius:10px;
  overflow:hidden;
  background:#fff;
}
.productImg{
  height:132px;
  background:linear-gradient(135deg,#d7d7d7,#bdbdbd);
  position:relative;
}
.productImg::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,0) 55%, rgba(0,0,0,.20) 100%);
}
.productBadge{
  position:absolute;
  left:8px;
  top:8px;
  z-index:1;
  height:20px;
  padding:0 8px;
  border-radius:999px;
  background:rgba(255,255,255,.92);
  font-size:11px;
  font-weight:900;
  display:flex;
  align-items:center;
  gap:6px;
}
.productBody{padding:10px 10px 12px;}
.productName{
  font-size:12px;
  font-weight:900;
  color:#222;
  line-height:1.2;
  height:30px;
  overflow:hidden;
}
.productPriceRow{display:flex; align-items:baseline; gap:8px; margin-top:8px;}
.productPrice{font-size:16px; font-weight:1000; color:#111;}
.productMrp{font-size:12px; color:#777; text-decoration:line-through;}
.productOff{font-size:12px; color:#1a7f37; font-weight:1000;}
.productMeta{margin-top:6px; font-size:11px; color:#666; font-weight:800;}
.productMeta b{color:#111;}

.tabbar{
  position:absolute;
  left:0; right:0; bottom:0;
  height:66px;
  padding:10px 10px max(10px, env(safe-area-inset-bottom));
  background:#fff;
  border-top:1px solid #eaeaea;
  display:flex;
  justify-content:space-around;
  align-items:center;
}
.tab{border:0; background:transparent; width:54px; height:46px; display:grid; place-items:center;}
.tabIcon{width:22px; height:22px; position:relative; opacity:.65;}
.tab--active .tabIcon{opacity:1;}
.tabIcon--home{border:2px solid var(--purple); border-bottom:0; border-radius:4px 4px 0 0;}
.tabIcon--home::after{content:""; position:absolute; left:5px; right:5px; bottom:-2px; height:10px; border:2px solid var(--purple); border-top:0; border-radius:0 0 4px 4px;}
.tabIcon--grid{background:transparent;}
.tabIcon--grid::before,.tabIcon--grid::after{content:""; position:absolute; inset:0; border:2px solid var(--purple); border-radius:4px;}
.tabIcon--grid::after{content:""; position:absolute; left:50%; top:0; bottom:0; width:2px; background:var(--purple); transform:translateX(-50%); box-shadow:0 0 0 0 var(--purple);} 
.tabIcon--user{border:2px solid var(--purple); border-radius:999px;}
.tabIcon--user::after{content:""; position:absolute; left:50%; bottom:-2px; width:18px; height:10px; border:2px solid var(--purple); border-top:0; border-radius:0 0 12px 12px; transform:translateX(-50%);} 
.tabIcon--bag{border:2px solid var(--purple); border-radius:4px;}
.tabIcon--bag::before{content:""; position:absolute; left:4px; right:4px; top:-6px; height:10px; border:2px solid var(--purple); border-bottom:0; border-radius:10px 10px 0 0;}
.tabIcon--store{border:2px solid var(--purple); border-radius:4px;}
.tabIcon--store::before{content:""; position:absolute; left:-2px; right:-2px; top:4px; height:2px; background:var(--purple);} 

/* Categories grid screen */
.catGrid{
  margin-top:10px;
  background:linear-gradient(180deg, rgba(90,62,146,.14), rgba(90,62,146,.28));
  border-radius:12px;
  padding:12px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
.catTile{
  height:128px;
  background:rgba(255,255,255,.60);
  border-radius:10px;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  border:1px solid rgba(255,255,255,.55);
}
.catTileArt{flex:1; background:#d6d6d6; position:relative;}
.catTileLbl{padding:8px 10px; font-weight:800; font-size:12px; color:#3b3b3b;}
.catTileArt::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 18% 30%, rgba(255,255,255,.55) 0 22px, transparent 24px),
    radial-gradient(circle at 75% 35%, rgba(255,255,255,.45) 0 18px, transparent 20px),
    linear-gradient(135deg, rgba(90,62,146,.18), rgba(0,0,0,.10));
}
.catArt--1{background:linear-gradient(135deg,#cfd6ff,#c7c7c7);} 
.catArt--2{background:linear-gradient(135deg,#ffd8c7,#c7c7c7);} 
.catArt--3{background:linear-gradient(135deg,#e7c7ff,#c7c7c7);} 
.catArt--4{background:linear-gradient(135deg,#c7ffe5,#c7c7c7);} 
.catArt--5{background:linear-gradient(135deg,#ffe7c7,#c7c7c7);} 
.catArt--6{background:linear-gradient(135deg,#c7f1ff,#c7c7c7);} 
.catArt--7{background:linear-gradient(135deg,#fff0c7,#c7c7c7);} 
.catArt--8{background:linear-gradient(135deg,#d0ffd4,#c7c7c7);} 

/* Profile screen */
.profileTop{
  padding:10px 8px 12px;
  position:relative;
}
.profileTopRight{
  position:absolute;
  right:6px;
  top:6px;
  display:flex;
  gap:10px;
}
.emojiIcon{
  border:0;
  background:transparent;
  font-size:18px;
  line-height:1;
  padding:6px;
}
.profileAvatar{
  width:96px;
  height:96px;
  border-radius:999px;
  border:2px solid #d9d0c6;
  margin:30px auto 10px;
  background:radial-gradient(circle at 50% 45%, #d8d0c6 0 20px, transparent 21px),
             radial-gradient(circle at 50% 85%, #d8d0c6 0 28px, transparent 29px);
}
.profileName{text-align:center; font-weight:900; font-size:18px; color:#222;}
.profileEdit{text-align:center; color:#666; font-size:12px; margin-top:2px;}
.profileBtns{
  display:flex;
  gap:14px;
  justify-content:center;
  margin-top:14px;
}
.pillBtn{
  min-width:140px;
  height:36px;
  border:0;
  border-radius:10px;
  background:linear-gradient(180deg, rgba(90,62,146,.35), rgba(90,62,146,.20));
  color:#2b2b2b;
  font-weight:900;
  font-size:12px;
}
.profileList{
  background:#fff;
  border-top:1px solid #e8e8e8;
  padding-bottom:80px;
}
.profileHdr{
  font-weight:900;
  font-size:12px;
  color:#2b2b2b;
  padding:12px 6px 6px;
}
.row{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 6px;
  border-top:1px solid #efefef;
  font-size:13px;
  color:#222;
}
.rowIcon{width:22px; text-align:center;}

/* Cart screen */
.deliverBar{
  font-size:12px;
  color:#333;
  padding:8px 2px 6px;
}
.giftBar{
  display:flex;
  align-items:center;
  gap:8px;
  background:#f6f0db;
  border-radius:6px;
  padding:8px 10px;
  font-size:12px;
  color:#333;
}
.tick{
  width:14px;
  height:14px;
  border-radius:3px;
  background:#d9d9d9;
  position:relative;
}
.tick::after{
  content:"";
  position:absolute;
  left:3px; top:6px;
  width:8px; height:4px;
  border-left:2px solid #666;
  border-bottom:2px solid #666;
  transform:rotate(-45deg);
}
.cartList{padding:10px 0 0; display:flex; flex-direction:column; gap:10px;}
.cartItem{
  display:grid;
  grid-template-columns:112px 1fr;
  gap:10px;
  border-top:1px solid #e6e6e6;
  padding-top:10px;
}
.cartThumb{
  height:110px;
  border-radius:6px;
  background:linear-gradient(135deg,#d7d7d7,#bdbdbd);
}
.cartThumb--book{background:linear-gradient(135deg,#d8b9ff,#b7b7b7);} 
.cartInfo{padding-right:2px;}
.cartTitle{font-size:12px; font-weight:800; color:#1f1f1f;}
.cartPrice{font-size:22px; font-weight:1000; color:#1f1f1f; margin-top:4px;}
.cartShip{font-size:12px; color:#444; margin-top:3px;}
.stock{font-size:12px; color:#228b22; font-weight:900; margin-top:6px;}
.meta{font-size:11px; color:#333; margin-top:2px;}
.qtyRow{display:flex; align-items:center; gap:10px; margin-top:8px;}
.qtyBtn{width:26px; height:22px; border-radius:4px; border:1px solid #d0d0d0; background:#fff; font-weight:900;}
.qty{min-width:18px; text-align:center; font-weight:900;}
.miniActions{display:flex; gap:10px; margin-top:6px;}
.miniBtn{height:22px; border:1px solid #d0d0d0; background:#fff; border-radius:4px; font-size:11px; font-weight:800; padding:0 8px;}
.subtotal{border-top:1px solid #e6e6e6; padding-top:12px; margin-top:12px;}
.subLbl{font-weight:900; font-size:18px;}
.subAmt{font-weight:1000; font-size:22px; margin-top:2px; color:#1f1f1f;}
.buyBtn{
  width:100%;
  margin-top:10px;
  height:44px;
  border:0;
  border-radius:4px;
  background:#f0c650;
  color:#111;
  font-weight:1000;
}

/* Supplier screen */
.supplierHero{
  margin-top:8px;
  height:320px;
  border-radius:12px;
  background:
    radial-gradient(circle at 18% 28%, rgba(90,62,146,.10) 0 70px, transparent 72px),
    radial-gradient(circle at 78% 24%, rgba(90,62,146,.08) 0 70px, transparent 72px),
    linear-gradient(180deg, #f7f7fb, #ffffff);
  position:relative;
  overflow:hidden;
}
.supplierHero::before{
  content:"";
  position:absolute;
  left:50%; top:52%;
  transform:translate(-50%,-50%);
  width:260px; height:160px;
  background:
    radial-gradient(circle at 30% 35%, rgba(90,62,146,.08) 0 26px, transparent 28px),
    radial-gradient(circle at 70% 45%, rgba(90,62,146,.08) 0 20px, transparent 22px),
    radial-gradient(circle at 55% 65%, rgba(90,62,146,.08) 0 22px, transparent 24px);
  opacity:.8;
}
.supplierHero::after{
  content:"";
  position:absolute;
  left:50%; top:54%;
  transform:translate(-50%,-50%);
  width:260px; height:160px;
  background:
    linear-gradient(135deg, rgba(60,110,255,.12), rgba(0,0,0,0));
  mask:
    radial-gradient(circle at 30% 35%, #000 0 26px, transparent 28px),
    radial-gradient(circle at 70% 45%, #000 0 20px, transparent 22px),
    radial-gradient(circle at 55% 65%, #000 0 22px, transparent 24px);
  opacity:.7;
}
.supplierText{text-align:center; margin-top:18px; padding-bottom:20px;}
.supplierTitle{font-size:20px; font-weight:1000; color:#111;}
.supplierLink{margin-top:10px; font-size:14px; font-weight:900; color:var(--purple);} 
.beeTrail{
  position:absolute;
  left:0; right:0; bottom:78px;
  height:140px;
  background:
    radial-gradient(circle at 88% 35%, rgba(0,0,0,.0) 0 10px, transparent 11px),
    radial-gradient(circle at 88% 35%, rgba(255,200,0,.0) 0 10px, transparent 11px);
}
.beeTrail::before{
  content:"";
  position:absolute;
  left:10%; right:10%; top:40px;
  height:70px;
  border-bottom:3px dashed #2b2b2b;
  border-radius:80px;
  transform:skewX(-8deg);
  opacity:.9;
}
.beeTrail::after{
  content:"🐝";
  position:absolute;
  right:14px;
  top:46px;
  font-size:18px;
}
