/* MasnoonHub Express — homepage component styles (mobile + desktop).
   Holds every homepage component: mobile (.m*, .flash, .shelf, .trend) and
   desktop (.dk-*) variants plus the single shared product card (.mhub-card).
   Design tokens live in tokens.css; page shells + the 960px switch in
   home-shell.css. Loaded on the front page only. */


/* ============================================================
   HERO / HEADER / DEPARTMENTS
   ============================================================ */
*{ box-sizing:border-box; }
html,body{ margin:0; }
body{ font-family:var(--font-body); color:var(--ink); background:var(--paper); -webkit-font-smoothing:antialiased; line-height:1.5; }
.wrap{ max-width:1180px; margin:0 auto; padding:0 clamp(20px,4vw,48px) 96px; }

.brandbar{ background:var(--navy); margin:0 calc(-1 * clamp(20px,4vw,48px)); padding:18px clamp(20px,4vw,48px); display:flex; align-items:center; gap:16px; }
.brandbar img{ height:42px; width:auto; display:block; }
.brandbar .tag{ margin-left:auto; color:#aeb6cb; font-size:12.5px; font-weight:500; letter-spacing:.04em; display:flex; align-items:center; gap:8px; }
.brandbar .tag b{ color:#fff; } .brandbar .tag .o{ color:var(--brand-bright); }
.intro{ padding-top:clamp(30px,5vw,52px); }
.topline{ display:flex; align-items:center; gap:11px; color:var(--ink-3); font-size:12px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; }
.topline .dot{ width:7px; height:7px; border-radius:50%; background:var(--brand); }
h1.board-title{ font-family:var(--font-display); font-weight:700; font-size:clamp(32px,5.6vw,44px); letter-spacing:-.01em; margin:13px 0 10px; line-height:1.05; }
h1.board-title em{ font-style:italic; color:var(--brand); font-weight:600; }
.lede{ max-width:62ch; color:var(--ink-2); font-size:17px; margin:0; } .lede b{ color:var(--ink); font-weight:600; }
.section{ margin-top:clamp(44px,7vw,74px); }
.section__head{ display:flex; align-items:baseline; gap:8px 14px; flex-wrap:wrap; margin-bottom:24px; padding-bottom:13px; border-bottom:1px solid var(--line); }
.section__num{ font-family:var(--font-display); font-weight:600; color:var(--brand); font-size:20px; }
.section__title{ font-family:var(--font-display); font-weight:600; font-size:25px; letter-spacing:-.01em; margin:0 auto 0 0; white-space:nowrap; }
.section__hint{ color:var(--ink-3); font-size:12.5px; font-weight:500; }
.caption{ text-align:center; color:var(--ink-3); font-size:12.5px; font-weight:600; margin:14px 0 0; letter-spacing:.02em; }
.notes{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r-md); padding:20px 22px; margin-top:22px; }
.notes h4{ margin:0 0 11px; font-family:var(--font-display); font-weight:600; font-size:17px; }
.notes ul{ margin:0; padding-left:18px; color:var(--ink-2); display:flex; flex-direction:column; gap:7px; font-size:14px; }
.notes ul b{ color:var(--ink); font-weight:600; }

.stage{ display:grid; gap:34px; grid-template-columns:1fr; align-items:start; }
@media(min-width:960px){ .stage{ grid-template-columns:auto 1fr; gap:48px; } }
.phone{ width:384px; max-width:100%; margin:0 auto; background:#0c0b12; border-radius:46px; padding:11px; box-shadow:var(--shadow-pop); }
.phone__screen{ background:var(--app-bg); border-radius:36px; overflow:hidden; position:relative; }
.phone__notch{ position:absolute; top:9px; left:50%; transform:translateX(-50%); width:120px; height:24px; background:#0c0b12; border-radius:14px; z-index:30; }
.statusbar{ height:40px; display:flex; align-items:center; justify-content:space-between; padding:0 22px 0 26px; font-size:12px; font-weight:600; background:var(--navy); color:#fff; }

/* mobile header (the original Component-02 header) */
.util{ background:var(--navy-deep); color:#9aa3bd; font-size:11px; font-weight:500; padding:6px 14px;
  display:flex; align-items:center; gap:10px; white-space:nowrap; overflow:hidden; border-bottom:1px solid var(--navy-line); }
.util .loc{ display:flex; align-items:center; gap:5px; color:#cdd3e3; }
.util .loc b{ color:#fff; font-weight:600; }
.util svg{ width:13px; height:13px; }
.util .right{ margin-left:auto; display:flex; align-items:center; gap:12px; }
.util .right a{ color:#9aa3bd; text-decoration:none; }
.util .right .lang{ color:#fff; font-weight:600; border:1px solid var(--navy-line); border-radius:var(--r-pill); padding:2px 8px; background:transparent; font-family:var(--font-body); font-size:11px; cursor:pointer; -webkit-tap-highlight-color:transparent; transition:background .15s ease; }
.util .right .lang:active{ background:rgba(255,255,255,.1); }
.head{ background:var(--navy); padding:10px 14px 12px; }
.head__row{ display:flex; align-items:center; gap:12px; margin-bottom:10px; }
.head__row img{ height:38px; width:auto; }
.head__row .sp{ flex:1; }
.iconbtn{ position:relative; border:0; background:rgba(255,255,255,.08); color:#fff; width:36px; height:36px;
  border-radius:10px; display:grid; place-items:center; cursor:pointer; }
.iconbtn svg{ width:20px; height:20px; }
.iconbtn .n{ position:absolute; top:-4px; right:-4px; background:var(--brand); color:#fff; font-size:10px;
  font-weight:700; min-width:16px; height:16px; border-radius:8px; display:grid; place-items:center; padding:0 4px; border:1.5px solid var(--navy); }
.search{ display:flex; align-items:center; gap:9px; background:#fff; border:1.8px solid var(--brand);
  border-radius:var(--r-pill); padding:9px 9px 9px 14px; }
.search svg{ width:18px; height:18px; flex:none; }
.search .ph{ flex:1; color:var(--ink-3); font-size:14px; font-weight:500; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; min-width:0; }
.search .cam{ color:var(--brand); width:20px; height:20px; display:flex; align-items:center; flex:none; }
.search .cam svg{ width:20px; height:20px; }
.search .aibtn{ flex:none; display:inline-flex; align-items:center; gap:3px; border:0; cursor:pointer;
  background:linear-gradient(180deg,var(--brand-bright),var(--brand)); color:#fff; font-family:var(--font-body);
  font-weight:800; font-size:11px; letter-spacing:.02em; padding:4px 8px 4px 6px; border-radius:var(--r-pill);
  margin-right:1px; }
.search .aibtn svg{ width:12px; height:12px; flex:none; }
.search .aibtn + .cam{ padding-left:8px; border-left:1px solid var(--line); box-sizing:content-box; }
.search .go{ background:linear-gradient(180deg,var(--brand-bright),var(--brand)); border:0; color:#fff;
  width:38px; height:34px; border-radius:var(--r-pill); display:grid; place-items:center; cursor:pointer; }
.search .go svg{ width:18px; height:18px; color:#fff; }
.deptnav{ background:#fff; border-bottom:1px solid var(--line); display:flex; align-items:stretch; gap:0; overflow:hidden; }
.deptnav .all{ flex:none; display:flex; align-items:center; gap:7px; padding:11px 13px; background:var(--brand-soft);
  color:var(--brand-ink); font-weight:700; font-size:13px; border-right:1px solid var(--line); text-decoration:none; }
.deptnav .all svg{ width:16px; height:16px; }
.deptnav .links{ display:flex; gap:2px; overflow:hidden; padding:0 4px; }
.deptnav .links a{ flex:none; display:flex; align-items:center; padding:11px 11px; color:var(--ink-2);
  text-decoration:none; font-size:13.5px; font-weight:600; position:relative; }
.deptnav .links a.is-active{ color:var(--brand); }
.deptnav .links a.is-active::after{ content:""; position:absolute; left:11px; right:11px; bottom:0; height:3px; background:var(--brand); border-radius:3px 3px 0 0; }
.marquee{ background:var(--navy); color:#dfe4f1; overflow:hidden; padding:7px 0; }
.marquee__track{ display:inline-flex; white-space:nowrap; will-change:transform; animation:marq 26s linear infinite; }
.marquee__track > span{ display:inline-flex; align-items:center; gap:9px; font-size:12px; font-weight:600; padding:0 22px; }
.marquee__track b{ color:#fff; } .marquee__track .o{ color:var(--brand-bright); }
.marquee__track .pip{ width:5px; height:5px; border-radius:50%; background:var(--brand); }
@keyframes marq{ to{ transform:translateX(-50%); } }
@media (prefers-reduced-motion: reduce){ .marquee__track{ animation:none; } }

.aibar{ margin:11px 12px 0; display:flex; align-items:center; gap:11px; padding:10px 13px; border-radius:14px;
  background:linear-gradient(100deg,#fde7da,#fff 72%); border:1px solid color-mix(in srgb,var(--brand) 30%,var(--line)); text-decoration:none; box-shadow:var(--shadow-sm); }
.aibar .spark{ width:34px; height:34px; border-radius:10px; background:linear-gradient(180deg,var(--brand-bright),var(--brand)); display:grid; place-items:center; flex:none; }
.aibar .spark svg{ width:18px; height:18px; color:#fff; }
.aibar .t{ flex:1; min-width:0; }
.aibar .t b{ display:block; font-size:14px; color:var(--ink); }
.aibar .t > span{ display:block; font-size:11.5px; color:var(--ink-2); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.aibar .go{ flex:none; color:var(--brand); width:18px; height:18px; }
/* mobile hero carousel */
.mhero{ position:relative; padding:12px 12px 4px; }
.mslides{ position:relative; height:176px; border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow-card); }
.crsl-track{ display:flex; height:100%; will-change:transform; transition:transform .5s cubic-bezier(.45,.02,.18,1); }
.mslide{ flex:0 0 100%; position:relative; padding:18px; background:linear-gradient(120deg,var(--accent-soft),#fff 88%); display:flex; flex-direction:column; align-items:flex-start; }
.mslide .kf{ font-size:10.5px; font-weight:800; letter-spacing:.08em; text-transform:uppercase; color:var(--accent-ink); white-space:nowrap; }
.mslide h3{ font-family:var(--font-display); font-weight:700; font-size:22px; line-height:1.1; margin:8px 0 5px; max-width:60%;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.mslide p{ margin:0; font-size:12.5px; color:var(--ink-2); max-width:60%;
  display:-webkit-box; -webkit-line-clamp:1; -webkit-box-orient:vertical; overflow:hidden; }
.mslide .cta{ margin-top:auto; display:inline-flex; align-items:center; gap:7px; background:var(--brand); color:#fff; font-weight:700; font-size:13px; padding:9px 16px; border-radius:var(--r-pill); text-decoration:none; white-space:nowrap; }
.mslide .cta svg{ width:14px; height:14px; }
.mslide .ph{ position:absolute; right:14px; bottom:14px; top:40px; width:38%; border-radius:var(--r-md);
  background:repeating-linear-gradient(135deg,rgba(255,255,255,.6) 0 9px,transparent 9px 18px),var(--accent-soft);
  border:1px solid rgba(0,0,0,.05); display:grid; place-items:end center; }
.mslide .ph span{ font-size:9.5px; color:var(--accent-ink); background:rgba(255,255,255,.7); padding:2px 7px; border-radius:var(--r-pill); margin-bottom:8px; font-weight:600; }
.mslide .off{ position:absolute; top:14px; right:14px; z-index:4; background:var(--red); color:#fff; font-weight:800; font-size:11px; padding:3px 8px; border-radius:var(--r-sm); }
.dots{ display:flex; justify-content:center; gap:6px; padding:9px 0 2px; }
.dots button{ width:7px; height:7px; border-radius:50%; border:0; background:var(--ink-3); opacity:.4; cursor:pointer; padding:0; }
.dots button.on{ opacity:1; background:var(--brand); width:18px; border-radius:4px; }

/* mobile shop by department */
.mdept{ background:#fff; margin:10px 0 0; padding:15px 14px 6px; }
.mdept h3{ font-family:var(--font-display); font-weight:700; font-size:17px; margin:0 0 13px; display:flex; align-items:center; }
.mdept h3 a{ margin-left:auto; color:var(--brand); font-family:var(--font-body); font-size:12.5px; font-weight:700; text-decoration:none; white-space:nowrap; }
.mdept-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px 6px; }
.mtile{ display:flex; flex-direction:column; align-items:center; gap:7px; text-decoration:none; }
.mtile .ic{ width:58px; height:58px; border-radius:16px; background:var(--accent-soft); border:1px solid color-mix(in srgb,var(--accent) 22%,transparent); display:grid; place-items:center; position:relative; }
.mtile .ic::before{ content:""; width:22px; height:22px; border-radius:7px; background:var(--accent); opacity:.85; }
.mtile .ic::after{ content:""; position:absolute; width:11px; height:11px; border-radius:50%; background:#fff; opacity:.5; }
.mtile .lb{ font-size:11.5px; font-weight:600; color:var(--ink); text-align:center; line-height:1.2; max-width:74px; }

/* mobile quick actions */
.mquick{ background:#fff; margin-top:10px; padding:14px 8px 8px; display:grid; grid-template-columns:repeat(4,1fr); gap:8px; }
.mqa{ display:flex; flex-direction:column; align-items:center; gap:7px; text-decoration:none; }
.mqa .ic{ width:46px; height:46px; border-radius:14px; display:grid; place-items:center; }
.mqa .ic svg{ width:22px; height:22px; }
.mqa.q1 .ic{ background:var(--red-soft); color:var(--red); }
.mqa.q2 .ic{ background:var(--trust-soft); color:var(--trust); }
.mqa.q3 .ic{ background:#fdeadf; color:var(--brand); }
.mqa.q4 .ic{ background:#e6e8ef; color:var(--navy); }
.mqa .lb{ font-size:11px; font-weight:600; color:var(--ink-2); text-align:center; line-height:1.15; min-height:25px; }

/* mobile product feed */
.mfeed{ background:#fff; margin-top:10px; padding:15px 12px 16px; }
.mfeed h3{ font-family:var(--font-display); font-weight:700; font-size:17px; margin:0 0 13px; display:flex; align-items:center; }
.mfeed h3 .o{ color:var(--brand); }
.mfeed h3 a{ margin-left:auto; color:var(--brand); font-family:var(--font-body); font-size:12.5px; font-weight:700; text-decoration:none; white-space:nowrap; }
.fgrid{ display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.fcard{ border:1px solid var(--line-2); border-radius:14px; overflow:hidden; background:#fff; text-decoration:none; display:flex; flex-direction:column; }
.fcard .im{ position:relative; aspect-ratio:1/1; background:linear-gradient(125deg,var(--accent-soft) 0 46%,color-mix(in srgb,var(--accent-soft) 40%,#fff) 46%); border-bottom:1px solid var(--line-2); }
.fcard .ph{ position:absolute; inset:0; display:grid; place-items:center; background:repeating-linear-gradient(135deg,var(--accent-soft) 0 11px,#fff 11px 22px); }
.fcard .ph span{ font-size:10px; letter-spacing:.05em; text-transform:uppercase; color:var(--accent-ink); background:rgba(255,255,255,.78); padding:3px 8px; border-radius:var(--r-pill); font-weight:600; }
.fcard .badge{ position:absolute; top:8px; left:8px; background:var(--red); color:#fff; font-weight:800; font-size:11px; padding:3px 7px; border-radius:var(--r-sm); }
.fcard .cartmini{ position:absolute; bottom:8px; right:8px; width:36px; height:36px; border-radius:50%; background:var(--brand); display:grid; place-items:center; box-shadow:0 4px 10px -2px rgba(224,83,15,.5); }
.fcard .cartmini svg{ width:18px; height:18px; color:#fff; }
.fcard .bd{ padding:8px 10px 10px; display:flex; flex-direction:column; gap:4px; }
.fcard .cert{ align-self:flex-start; display:inline-flex; align-items:center; gap:3px; white-space:nowrap; background:var(--trust-soft); color:var(--trust); font-size:9px; font-weight:700; letter-spacing:.02em; padding:2px 6px 2px 4px; border-radius:var(--r-xs); text-transform:uppercase; }
.fcard .cert svg{ width:11px; height:11px; }
.fcard .ti{ font-size:12.5px; line-height:1.3; font-weight:500; color:var(--ink); display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.fcard .pr{ display:flex; align-items:baseline; gap:6px; margin-top:1px; }
.fcard .pr .now{ font-size:17px; font-weight:800; color:var(--red); font-variant-numeric:tabular-nums; }
.fcard .pr .now b{ font-weight:600; font-size:.65em; }
.fcard .pr .was{ font-size:11px; color:var(--ink-3); text-decoration:line-through; }
.fcard .mt{ display:flex; align-items:center; gap:5px; font-size:11px; color:var(--ink-3); white-space:nowrap; }
.fcard .st{ color:var(--star); font-size:10px; letter-spacing:.5px; }

/* real product imagery dropped into the media slots */
.fcard .im{ overflow:hidden; }
.fcard .badge,.fcard .cartmini{ z-index:3; }
.pim{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block; }
.fcard .pim.fit{ object-fit:contain; background:transparent; padding:11%; }
.mslide .pim{ position:absolute; right:14px; top:40px; bottom:14px; left:auto; width:38%; height:auto; border-radius:var(--r-md); border:1px solid rgba(0,0,0,.06); background:linear-gradient(125deg,var(--accent-soft) 0 46%,color-mix(in srgb,var(--accent-soft) 40%,#fff) 46%); box-shadow:var(--shadow-sm); }
.mslide .pim.fit{ object-fit:contain; padding:5px; }
.hslide .aim{ position:absolute; right:36px; top:34px; bottom:34px; width:34%; border-radius:var(--r-md); object-fit:contain; background:linear-gradient(125deg,var(--accent-soft) 0 46%,color-mix(in srgb,var(--accent-soft) 40%,#fff) 46%); border:1px solid rgba(0,0,0,.06); box-shadow:var(--shadow-card); }
.hslide .aim.cover{ object-fit:cover; }
.feat .fim{ width:100%; aspect-ratio:3/2; object-fit:cover; border-radius:var(--r-sm); border:1px solid var(--line); display:block; background:linear-gradient(125deg,var(--accent-soft) 0 46%,color-mix(in srgb,var(--accent-soft) 40%,#fff) 46%); }
.feat .fim.fit{ object-fit:contain; background:linear-gradient(125deg,var(--accent-soft) 0 46%,color-mix(in srgb,var(--accent-soft) 40%,#fff) 46%); padding:6px; }
.feat .fim.fit{ object-fit:contain; }

/* mobile bottom tab bar */
.mtab{ background:#fff; border-top:1px solid var(--line); display:grid; grid-template-columns:repeat(5,1fr); padding:7px 4px 9px; position:sticky; bottom:0; }
.mtab a{ display:flex; flex-direction:column; align-items:center; gap:3px; text-decoration:none; color:var(--ink-3); font-size:10px; font-weight:600; }
.mtab a svg{ width:22px; height:22px; }
.mtab a.on{ color:var(--brand); }
.mtab a.aitab .dot{ width:23px; height:23px; border-radius:50%; background:linear-gradient(180deg,var(--brand-bright),var(--brand)); display:grid; place-items:center; }
.mtab a.aitab .dot svg{ width:14px; height:14px; color:#fff; }

/* mobile promo tiles */
.mpromos{ background:#fff; padding:6px 14px 18px; display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.mpromo{ border-radius:var(--r-md); padding:13px; min-height:74px; background:linear-gradient(120deg,var(--accent-soft),#fff); border:1px solid var(--line); text-decoration:none; }
.mpromo b{ display:block; font-size:13px; color:var(--ink); font-weight:700; }
.mpromo span{ font-size:11px; color:var(--ink-2); }
.mpromo.wide{ grid-column:1 / -1; display:flex; align-items:center; gap:10px; }
.mpromo.wide .o{ color:var(--brand); font-weight:800; }

/* ===== DESKTOP ===== */
.deskwrap{ border:1px solid var(--line); border-radius:var(--r-md); overflow:hidden; box-shadow:var(--shadow-card); background:#fff; }
.dk-strip{ background:var(--navy); color:#fff; display:flex; align-items:center; gap:24px; padding:11px 20px; }
.dk-strip img{ height:30px; }
.dk-strip .nav{ display:flex; gap:20px; margin-left:6px; }
.dk-strip .nav a{ color:#dfe4f1; text-decoration:none; font-weight:600; font-size:13.5px; }
.dk-strip .nav a.ainav{ color:var(--brand-bright); }
.dk-strip .s{ margin-left:auto; width:300px; display:flex; align-items:center; gap:8px; background:#fff; border:2px solid var(--brand); border-radius:var(--r-pill); padding:6px 6px 6px 14px; }
.dk-strip .s svg{ width:16px; height:16px; } .dk-strip .s .ph{ flex:1; color:var(--ink-3); font-size:13px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.dk-strip .s .go{ background:var(--brand); color:#fff; border:0; width:30px; height:28px; border-radius:var(--r-pill); display:grid; place-items:center; }
.dk-strip .s .go svg{ width:15px; height:15px; color:#fff; }

.dk-promo{ background:linear-gradient(90deg,#fdeadf,#fdf3ee); color:var(--ink); display:flex; align-items:center; gap:12px; padding:9px 22px; font-size:13px; font-weight:600; white-space:nowrap; overflow:hidden; }
.dk-promo>span:nth-of-type(2){ min-width:0; overflow:hidden; text-overflow:ellipsis; }
.dk-promo .spk{ color:var(--brand); display:flex; align-items:center; gap:7px; font-weight:800; }
.dk-promo .spk svg{ width:15px; height:15px; }
.dk-promo b{ color:var(--ink); }
.dk-promo .cta{ margin-left:auto; flex:none; display:flex; align-items:center; gap:8px; background:var(--navy); color:#fff; font-weight:700; padding:6px 16px; border-radius:var(--r-pill); text-decoration:none; white-space:nowrap; }
.dk-promo .cta svg{ width:15px; height:15px; }
.dk-bar{ background:var(--navy); display:flex; align-items:center; gap:26px; padding:15px 22px; }
.dk-bar img{ height:38px; width:auto; }
.dk-bar .right{ margin-left:auto; display:flex; align-items:center; gap:22px; }
.dk-deliver{ display:flex; flex-direction:column; line-height:1.15; font-size:11.5px; color:#9aa3bd; font-weight:500; }
.dk-deliver b{ color:#fff; font-size:13.5px; font-weight:700; display:flex; align-items:center; gap:6px; margin-top:1px; }
.dk-flag{ width:18px; height:12px; border-radius:2px; background:#006a4e; position:relative; flex:none; }
.dk-flag::after{ content:""; position:absolute; left:42%; top:50%; transform:translate(-50%,-50%); width:7px; height:7px; border-radius:50%; background:#f42a41; }
.dk-lang{ display:flex; align-items:center; gap:7px; color:#fff; font-weight:600; font-size:13.5px; }
.dk-lang svg{ width:18px; height:18px; color:#aeb6cb; }
.dk-iconrow{ display:flex; align-items:center; gap:18px; }
.dk-iconrow a{ position:relative; color:#dfe4f1; display:grid; place-items:center; }
.dk-iconrow a svg{ width:23px; height:23px; }
.dk-iconrow a .n{ position:absolute; top:-6px; right:-8px; background:var(--brand); color:#fff; font-size:10px; font-weight:700; min-width:16px; height:16px; border-radius:8px; display:grid; place-items:center; padding:0 4px; border:1.5px solid var(--navy); }
.dk-subnav{ background:#fff; border-bottom:1px solid var(--line); display:flex; align-items:center; gap:22px; padding:11px 22px; font-size:13.5px; white-space:nowrap; overflow:hidden; }
.dk-subnav a{ color:var(--ink-2); text-decoration:none; font-weight:600; display:flex; align-items:center; gap:7px; }
.dk-subnav a svg{ width:16px; height:16px; }
.dk-subnav .allcat{ color:var(--ink); font-weight:700; }
.dk-subnav .right{ margin-left:auto; display:flex; gap:22px; }
.dk-subnav .right a .o{ color:var(--brand); }
.dk-hero{ padding:20px 22px 26px; background:linear-gradient(180deg,#fdf4ee,#fff 65%); }
.dk-tabs{ display:flex; justify-content:center; align-items:center; gap:22px; }
.dk-tabs a{ font-size:23px; font-weight:800; color:var(--ink); text-decoration:none; position:relative; letter-spacing:-.01em; padding-bottom:8px; white-space:nowrap; }
.dk-tabs a.is-active{ color:var(--brand); }
.dk-tabs a.is-active::after{ content:""; position:absolute; left:0; right:0; bottom:0; height:3px; background:var(--brand); border-radius:3px; }
.dk-tabs .ai .sup{ font-size:11px; color:var(--brand); vertical-align:super; font-weight:800; }
.dk-tabs .sep{ width:1px; height:24px; background:var(--line); }
.dk-bigsearch{ max-width:1040px; margin:18px auto 0; border:2px solid var(--brand); border-radius:22px; padding:15px 20px 13px; background:#fff; box-shadow:0 12px 32px -18px rgba(224,83,15,.45); }
.dk-bigsearch .q{ color:var(--ink-3); font-size:17px; font-weight:500; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.dk-bigsearch .row{ display:flex; align-items:center; margin-top:14px; }
.dk-bigsearch .img{ display:flex; align-items:center; gap:9px; color:var(--ink-2); font-weight:600; font-size:14.5px; white-space:nowrap; }
.dk-bigsearch .img svg{ width:21px; height:21px; }
.dk-bigsearch .go{ margin-left:auto; display:flex; align-items:center; gap:9px; background:linear-gradient(180deg,var(--brand-bright),var(--brand)); color:#fff; border:0; font-weight:700; font-size:15px; padding:0 30px; height:46px; border-radius:var(--r-pill); cursor:pointer; }
.dk-bigsearch .go svg{ width:18px; height:18px; }

.dhero{ display:grid; grid-template-columns:248px minmax(0,1fr); gap:0; padding:16px; }
.deptmenu{ position:relative; background:#fff; border:1px solid var(--line); border-radius:var(--r-md); padding:6px 0; z-index:5; }
.deptmenu__hd{ font-weight:800; font-size:13px; padding:8px 16px 9px; color:var(--ink); display:flex; align-items:center; gap:8px; border-bottom:1px solid var(--line-2); }
.deptmenu__hd svg{ width:17px; height:17px; color:var(--brand); }
.dept{ display:flex; align-items:center; gap:11px; padding:9px 16px; text-decoration:none; color:var(--ink); position:relative; white-space:nowrap; cursor:pointer; }
.dept:hover{ background:var(--accent-soft); }
.dept .di{ width:24px; height:24px; border-radius:7px; background:var(--accent-soft); border:1px solid color-mix(in srgb,var(--accent) 30%,transparent); display:grid; place-items:center; flex:none; }
.dept .di::before{ content:""; width:10px; height:10px; border-radius:3px; background:var(--accent); }
.dept .dn{ font-size:13.5px; font-weight:600; flex:1; }
.dept .ch{ width:15px; height:15px; color:var(--ink-3); flex:none; }
.dept:hover .ch{ color:var(--brand); }
.flyout{ position:absolute; left:100%; top:-1px; width:540px; min-height:calc(100% + 2px); background:#fff;
  border:1px solid var(--line); border-radius:0 var(--r-md) var(--r-md) 0; box-shadow:var(--shadow-pop);
  padding:18px 20px; display:none; gap:24px; z-index:20; }
.dept:hover .flyout{ display:flex; }
.flyout .cols{ flex:1; display:grid; grid-template-columns:1fr 1fr; gap:6px 18px; align-content:start; }
.flyout .cols .gh{ grid-column:1 / -1; font-size:11px; font-weight:800; letter-spacing:.06em; text-transform:uppercase; color:var(--accent-ink); margin:2px 0 4px; }
.flyout .cols a{ color:var(--ink-2); text-decoration:none; font-size:13px; font-weight:500; padding:4px 0; white-space:nowrap; }
.flyout .cols a:hover{ color:var(--brand); }
.flyout .feat{ width:172px; flex:none; border-left:1px solid var(--line-2); padding-left:18px; display:flex; flex-direction:column; gap:9px; }
.flyout .feat .fp{ border-radius:var(--r-sm); aspect-ratio:3/2; background:repeating-linear-gradient(135deg,var(--accent-soft) 0 9px,#fff 9px 18px); border:1px solid var(--line); display:grid; place-items:end; }
.flyout .feat .fp span{ font-size:9px; color:var(--accent-ink); background:rgba(255,255,255,.78); padding:2px 6px; border-radius:var(--r-pill); margin:0 0 7px 7px; font-weight:600; }
.flyout .feat b{ font-size:12.5px; } .flyout .feat .price{ color:var(--red); font-weight:800; font-size:14px; }

.hero{ position:relative; margin-left:16px; }
.hslides{ position:relative; height:332px; border-radius:var(--r-md); overflow:hidden; box-shadow:var(--shadow-card); }
.hslide{ flex:0 0 100%; position:relative; display:flex; align-items:center; padding:36px 40px;
  background:linear-gradient(110deg,var(--accent-soft),#fff 92%); }
.hslide .tx{ width:52%; }
.hslide .kf{ font-size:12px; font-weight:800; letter-spacing:.09em; text-transform:uppercase; color:var(--accent-ink); }
.hslide h2{ font-family:var(--font-display); font-weight:800; font-size:38px; line-height:1.05; margin:10px 0 8px; letter-spacing:-.01em;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
/* ============================================================
   BANGLA LINE-HEIGHT OVERRIDES
   Noto Sans/Serif Bengali vowel matras extend higher than Latin
   ascenders. Bump line-height on every tight heading/title when
   <html class="lang-bn"> is active so nothing clips.
   ============================================================ */
.lang-bn .mslide h3,
.lang-bn .hslide h2,
.lang-bn .dk-faq__intro h3,
.lang-bn .faq__intro h3,
.lang-bn .dk-appdl__tx h3,
.lang-bn .appdl h3,
.lang-bn .appwait h3,
.lang-bn .trend__head h3,
.lang-bn .dk-trend__head h3,
.lang-bn .tcard h4,
.lang-bn .dk-trustb__head h3,
.lang-bn .trustb__lead,
.lang-bn .shelf__tx h3,
.lang-bn .dk-shelf__tx h3,
.lang-bn .dk-flash__head h3,
.lang-bn .flash__title h3,
.lang-bn .deal__ti,
.lang-bn .mhub-title,
.lang-bn .trow__ti,
.lang-bn .qa__btn,
.lang-bn .deptmenu__hd,
.lang-bn .dn,
.lang-bn .mqa .lb,
.lang-bn .store .tx{ line-height:1.35; }

.lang-bn .dk-deliver{ line-height:1.3; }

.hslide p{ margin:0 0 20px; font-size:15px; color:var(--ink-2); max-width:90%;
  display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; }
.hslide .cta{ display:inline-flex; align-items:center; gap:9px; background:var(--brand); color:#fff; font-weight:700; font-size:15px; padding:12px 24px; border-radius:var(--r-pill); text-decoration:none; white-space:nowrap; }
.hslide .cta svg{ width:16px; height:16px; }
.hslide .art{ position:absolute; right:36px; top:34px; bottom:34px; width:34%; border-radius:var(--r-md);
  background:repeating-linear-gradient(135deg,rgba(255,255,255,.55) 0 11px,transparent 11px 22px),var(--accent-soft);
  border:1px solid rgba(0,0,0,.05); display:grid; place-items:end center; }
.hslide .art span{ font-size:11px; color:var(--accent-ink); background:rgba(255,255,255,.72); padding:3px 9px; border-radius:var(--r-pill); margin-bottom:12px; font-weight:600; }
.hslide .off{ position:absolute; right:34px; top:34px; z-index:5; background:var(--red); color:#fff; font-weight:800; font-size:13px; padding:5px 11px; border-radius:var(--r-sm); }
.hdots{ position:absolute; bottom:14px; left:40px; display:flex; gap:7px; z-index:4; }
.hdots button{ width:8px; height:8px; border-radius:50%; border:0; background:var(--ink-3); opacity:.4; cursor:pointer; padding:0; }
.hdots button.on{ opacity:1; background:var(--brand); width:22px; border-radius:4px; }
.harrow{ position:absolute; top:50%; transform:translateY(-50%); width:38px; height:38px; border-radius:50%; border:0;
  background:rgba(255,255,255,.9); box-shadow:var(--shadow-card); display:grid; place-items:center; cursor:pointer; z-index:4; }
.harrow svg{ width:18px; height:18px; color:var(--ink); } .harrow.prev{ left:14px; } .harrow.next{ right:14px; }

.promostrip{ padding:0 16px 18px; display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.pcard{ border-radius:var(--r-md); padding:16px; min-height:96px; background:linear-gradient(120deg,var(--accent-soft),#fff); border:1px solid var(--line); text-decoration:none; display:flex; flex-direction:column; justify-content:center; }
.pcard .kf{ font-size:10px; font-weight:800; letter-spacing:.06em; text-transform:uppercase; color:var(--accent-ink); }
.pcard b{ font-size:15px; color:var(--ink); margin:4px 0 2px; font-family:var(--font-display); font-weight:700; }
.pcard span{ font-size:12px; color:var(--ink-2); }

@media (prefers-reduced-motion: reduce){ .crsl-track{ transition:none; } }

/* ============================================================
   FLASH DEALS
   ============================================================ */
/* =========================================================
   FLASH DEALS — shared
   ========================================================= */
.flash{ background:var(--navy); color:#fff; }
.flash__head{ display:flex; align-items:center; gap:12px; padding:15px 14px 13px; }
.flash__title{ display:flex; align-items:center; gap:9px; min-width:0; }
.flash__bolt{ width:30px; height:30px; flex:none; border-radius:9px; background:linear-gradient(180deg,var(--brand-bright),var(--brand)); display:grid; place-items:center; box-shadow:0 5px 14px -4px rgba(224,83,15,.7); }
.flash__bolt svg{ width:17px; height:17px; color:#fff; }
.flash__title h3{ font-family:var(--font-display); font-weight:700; font-size:21px; margin:0 0 3px; line-height:1.15; }
.flash__title .sub{ display:block; font-family:var(--font-body); font-size:11px; font-weight:600; color:#aeb6cb; letter-spacing:.02em; margin-top:0; line-height:1.4; }
.flash__timer{ margin-left:auto; display:flex; align-items:center; gap:6px; }
.flash__timer .lab{ font-size:10px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:#aeb6cb; margin-right:2px; white-space:nowrap; }
.tbox{ background:rgba(255,255,255,.08); border:1px solid var(--navy-line); border-radius:7px; min-width:30px; padding:5px 4px 4px; text-align:center; }
.tbox b{ display:block; font-family:var(--font-body); font-variant-numeric:tabular-nums; font-weight:800; font-size:16px; line-height:1; color:#fff; }
.tbox.is-red b{ color:#ffd0c4; }
.tcolon{ font-weight:800; font-size:15px; color:var(--brand-bright); }
.flash__seeall{ display:block; text-align:center; color:#aeb6cb; text-decoration:none; font-size:12.5px; font-weight:700; padding:0 0 14px; }
.flash__seeall .o{ color:var(--brand-bright); }

/* deal rail */
.deal-rail{ display:flex; gap:11px; padding:0 14px 16px; overflow-x:auto; scroll-snap-type:x mandatory; -webkit-overflow-scrolling:touch; scrollbar-width:none; }
.deal-rail::-webkit-scrollbar{ display:none; }
.deal{ flex:0 0 150px; scroll-snap-align:start; background:#fff; border-radius:var(--r-md); overflow:hidden; display:flex; flex-direction:column; color:var(--ink); text-decoration:none; }
.deal__media{ position:relative; aspect-ratio:1/1; background:#fff; border-bottom:1px solid var(--line-2); }
.deal__off{ position:absolute; top:8px; left:8px; z-index:2; background:var(--red); color:#fff; font-weight:800; font-size:11.5px; padding:3px 7px; border-radius:var(--r-sm); font-variant-numeric:tabular-nums; box-shadow:var(--shadow-sm); }
.deal__pim{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block; }
.deal__pim.fit{ object-fit:contain; padding:11%; }
.deal__ph{ position:absolute; inset:0; display:grid; place-items:center; background:var(--accent-soft); background-image:repeating-linear-gradient(135deg,var(--accent) 0 2px,transparent 2px 14px), repeating-linear-gradient(45deg,rgba(255,255,255,.35) 0 2px,transparent 2px 14px); }
.deal__ph span{ font-family:"SF Mono",ui-monospace,Menlo,monospace; font-size:9.5px; letter-spacing:.03em; color:#fff; background:var(--accent); padding:4px 9px; border-radius:var(--r-pill); }
.deal__bd{ padding:9px 10px 11px; display:flex; flex-direction:column; gap:6px; flex:1; }
.deal__ti{ font-size:12px; line-height:1.3; font-weight:500; color:var(--ink); display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; min-height:31px; }
.deal__ti:lang(bn){ font-size:11.5px; }
.deal__pr{ display:flex; align-items:baseline; gap:6px; }
.deal__now{ font-size:17px; font-weight:800; color:var(--red); font-variant-numeric:tabular-nums; letter-spacing:-.01em; line-height:1; }
.deal__now b{ font-weight:600; font-size:.62em; }
.deal__was{ font-size:11px; color:var(--ink-3); text-decoration:line-through; }
.deal__bar{ margin-top:1px; }
.deal__track{ height:7px; border-radius:var(--r-pill); background:var(--line); overflow:hidden; position:relative; }
.deal__fill{ position:absolute; inset:0; right:auto; border-radius:var(--r-pill); background:linear-gradient(90deg,var(--brand),var(--brand-bright)); }
.deal__claim{ display:flex; align-items:center; gap:5px; margin-top:5px; font-size:10.5px; font-weight:700; color:var(--ink-2); }
.deal__claim .hot{ color:var(--red); display:inline-flex; align-items:center; gap:3px; }
.deal__claim .hot svg{ width:11px; height:11px; }
.deal.is-low .deal__fill{ background:linear-gradient(90deg,var(--red),#f2685f); }

/* ===== DESKTOP ===== */
.dk-flash{ background:linear-gradient(120deg,var(--navy-deep),var(--navy) 60%); color:#fff; padding:20px 22px 22px; }
.dk-flash__head{ display:flex; align-items:center; gap:16px; margin-bottom:18px; }
.dk-flash__head .flash__bolt{ width:38px; height:38px; border-radius:11px; }
.dk-flash__head .flash__bolt svg{ width:21px; height:21px; }
.dk-flash__head h3{ font-family:var(--font-display); font-weight:700; font-size:28px; margin:0 0 4px; line-height:1.15; }
.dk-flash__head .sub{ font-size:13px; font-weight:600; color:#aeb6cb; margin-top:0; line-height:1.4; max-width:60ch; }
.dk-timer{ display:flex; align-items:center; gap:7px; }
.dk-timer .lab{ font-size:11px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:#aeb6cb; margin-right:3px; }
.dk-timer .tbox{ min-width:40px; padding:7px 6px 6px; }
.dk-timer .tbox b{ font-size:21px; }
.dk-timer .tcolon{ font-size:19px; }
.dk-flash__cta{ margin-left:auto; display:flex; align-items:center; gap:8px; background:rgba(255,255,255,.08); border:1px solid var(--navy-line); color:#fff; font-family:var(--font-body); font-weight:700; font-size:13.5px; padding:9px 16px; border-radius:var(--r-pill); text-decoration:none; white-space:nowrap; }
.dk-flash__cta svg{ width:15px; height:15px; }
/* auto-scrolling flash-deals marquee (desktop): loops infinitely, pauses on hover */
.dk-deal-rail{ position:relative; overflow:hidden;
  -webkit-mask:linear-gradient(90deg, transparent 0, #000 2.5%, #000 97.5%, transparent 100%);
          mask:linear-gradient(90deg, transparent 0, #000 2.5%, #000 97.5%, transparent 100%); }
.dk-deal-rail .dk-deal-track{ display:flex; width:max-content; will-change:transform; }
.dk-deal-dupe{ display:contents; }
.dk-deal-rail .deal{ flex:0 0 200px; margin-right:14px; }
@media (min-width:961px){
  .dk-deal-rail .dk-deal-track{ animation:dk-marquee 42s linear infinite; }
  .dk-deal-rail:hover .dk-deal-track,
  .dk-deal-rail:focus-within .dk-deal-track{ animation-play-state:paused; }
}
@keyframes dk-marquee{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }
.dk-deal-rail .deal__ti{ font-size:13px; min-height:34px; }
.dk-deal-rail .deal__now{ font-size:19px; }
.dk-arrow{ position:absolute; top:38%; width:38px; height:38px; border-radius:50%; border:0; background:#fff; box-shadow:var(--shadow-pop); display:grid; place-items:center; cursor:pointer; z-index:4; }
.dk-arrow svg{ width:18px; height:18px; color:var(--navy); }
.dk-arrow.next{ right:-12px; } .dk-arrow.prev{ left:-12px; }

@media (prefers-reduced-motion: reduce){ *{ scroll-behavior:auto; } }

/* ============================================================
   CURATED SHELVES
   ============================================================ */
/* =========================================================
   SHELF
   ========================================================= */
.shelf{ background:#fff; padding:15px 0 18px; }
.shelf + .shelf{ border-top:8px solid var(--app-bg); }
.shelf__head{ display:flex; align-items:flex-end; gap:11px; padding:0 14px; margin-bottom:13px; }
.shelf__bar{ width:5px; align-self:stretch; min-height:38px; border-radius:var(--r-pill); background:var(--accent); flex:none; }
.shelf__tx{ min-width:0; flex:1; }
.shelf__kf{ display:block; font-size:10.5px; font-weight:800; letter-spacing:.09em; text-transform:uppercase; color:var(--accent-ink); }
.shelf__tx h3{ font-family:var(--font-display); font-weight:700; font-size:19px; margin:2px 0 0; line-height:1.1; letter-spacing:-.01em; }
.shelf__see{ flex:none; align-self:center; display:inline-flex; align-items:center; gap:4px; color:var(--brand); font-size:12.5px; font-weight:700; text-decoration:none; white-space:nowrap; }
.shelf__see svg{ width:14px; height:14px; }
.shelf__rail{ display:flex; gap:11px; padding:2px 14px 2px; overflow-x:auto; scroll-snap-type:x proximity; -webkit-overflow-scrolling:touch; scrollbar-width:none; }
.shelf__rail::-webkit-scrollbar{ display:none; }

/* product card (compact) — VERBATIM from the homepage design board (home.css).
   Simple browse card: media (badge / image / cart FAB on mobile / category chip)
   + body (certified badge, 2-line title, price now/was, stars + rating). */
.mhub-card{ flex:0 0 152px; scroll-snap-align:start; background:var(--surface); border:1px solid var(--line-2); border-radius:var(--r-card); overflow:hidden; display:flex; flex-direction:column; text-decoration:none; transition:transform .18s ease, box-shadow .18s ease; }
.mhub-card:hover{ box-shadow:var(--shadow-card); transform:translateY(-2px); }
.mhub-card__media{ position:relative; display:block; aspect-ratio:1/1; background:#fff; border-bottom:1px solid var(--line-2); }
.mhub-ph{ position:absolute; inset:0; display:grid; place-items:center; background:var(--accent-soft); background-image:repeating-linear-gradient(135deg,var(--accent) 0 2px,transparent 2px 14px), repeating-linear-gradient(45deg,rgba(255,255,255,.35) 0 2px,transparent 2px 14px); }
.mhub-ph span{ font-family:"SF Mono",ui-monospace,Menlo,monospace; font-size:9.5px; letter-spacing:.03em; color:#fff; background:var(--accent); padding:4px 9px; border-radius:var(--r-pill); }
.mhub-pim{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block; }
.mhub-pim.fit{ object-fit:contain; padding:11%; }
.mhub-badge{ position:absolute; top:8px; left:8px; z-index:2; background:var(--red); color:#fff; font-weight:800; font-size:11px; padding:3px 7px; border-radius:var(--r-sm); font-variant-numeric:tabular-nums; box-shadow:var(--shadow-sm); }
.mhub-chip{ position:absolute; bottom:8px; left:8px; z-index:2; background:rgba(255,255,255,.84); color:var(--accent-ink); font-weight:600; font-size:10px; padding:3px 8px; border-radius:var(--r-pill); letter-spacing:.04em; text-transform:uppercase; display:inline-flex; align-items:center; gap:5px; -webkit-backdrop-filter:blur(3px); backdrop-filter:blur(3px); }
.mhub-chip::before{ content:""; width:5px; height:5px; border-radius:50%; background:var(--accent); }
.mhub-cart{ position:absolute; bottom:8px; right:8px; z-index:3; width:44px; height:44px; border:0; border-radius:50%; background:var(--brand); cursor:pointer; display:grid; place-items:center; box-shadow:0 4px 11px -2px rgba(224,83,15,.5); transition:transform .14s ease, background .14s ease; }
.mhub-cart svg{ width:21px; height:21px; color:#fff; }
.mhub-cart:active{ transform:scale(.9); }
.mhub-card__body{ padding:8px 10px 11px; display:flex; flex-direction:column; gap:5px; flex:1; }
.mhub-cert{ align-self:flex-start; display:inline-flex; align-items:center; gap:4px; white-space:nowrap; background:var(--trust-soft); color:var(--trust); font-size:9px; font-weight:700; letter-spacing:.02em; padding:2px 6px 2px 4px; border-radius:var(--r-xs); text-transform:uppercase; }
.mhub-cert svg{ width:11px; height:11px; }
.mhub-title{ margin:0; font-size:12.5px; line-height:1.32; font-weight:500; }
.mhub-title a{ color:var(--ink); text-decoration:none; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.mhub-title a:hover{ color:var(--brand); }
.mhub-title:lang(bn) a{ font-family:var(--font-body); }
.mhub-price{ display:flex; align-items:baseline; gap:6px; margin-top:2px; flex-wrap:wrap; }
.mhub-now{ font-size:18px; font-weight:800; color:var(--ink); font-variant-numeric:tabular-nums; letter-spacing:-.02em; line-height:1; }
.mhub-now b{ font-weight:600; font-size:.62em; }
.mhub-was{ font-size:11px; color:var(--ink-3); text-decoration:line-through; }
.mhub-meta{ display:flex; align-items:center; gap:5px; font-size:11px; color:var(--ink-3); }
.mhub-stars{ color:var(--star); font-size:10px; letter-spacing:.5px; flex:none; }
.mhub-rate{ font-weight:700; color:var(--ink-2); }

/* ===== DESKTOP ===== */
.dk-shelf{ background:#fff; padding:22px 24px 8px; }
.dk-shelf + .dk-shelf{ border-top:1px solid var(--line); }
.dk-shelf__head{ display:flex; align-items:flex-end; gap:13px; margin-bottom:16px; }
.dk-shelf__bar{ width:6px; height:40px; border-radius:var(--r-pill); background:var(--accent); flex:none; }
.dk-shelf__tx{ flex:1; min-width:0; }
.dk-shelf__kf{ font-size:11px; font-weight:800; letter-spacing:.09em; text-transform:uppercase; color:var(--accent-ink); }
.dk-shelf__tx h3{ font-family:var(--font-display); font-weight:700; font-size:24px; margin:2px 0 0; letter-spacing:-.01em; }
.dk-shelf__see{ display:inline-flex; align-items:center; gap:5px; color:var(--brand); font-size:13.5px; font-weight:700; text-decoration:none; white-space:nowrap; }
.dk-shelf__see svg{ width:15px; height:15px; }
.dk-shelf__rail{ position:relative; display:grid; grid-template-columns:repeat(5,1fr); gap:14px; padding-bottom:18px; }
.dk-shelf__rail .mhub-card{ flex:none; }
.dk-shelf__rail .mhub-title{ font-size:13px; }
.dk-shelf__rail .mhub-now{ font-size:20px; }
.dk-shelf-arrow{ position:absolute; top:34%; width:36px; height:36px; border-radius:50%; border:0; background:#fff; box-shadow:var(--shadow-pop); display:grid; place-items:center; cursor:pointer; z-index:4; }
.dk-shelf-arrow svg{ width:17px; height:17px; color:var(--navy); }
.dk-shelf-arrow.next{ right:-10px; } .dk-shelf-arrow.prev{ left:-10px; }

@media (prefers-reduced-motion: reduce){ *{ transition:none !important; } }

/* ============================================================
   TRENDING LIST
   ============================================================ */
/* =========================================================
   TRENDING — numbered editorial list
   ========================================================= */
.trend{ background:#fff; padding:6px 0 12px; }
.trend__head{ display:flex; align-items:center; gap:11px; padding:15px 16px 12px; }
.trend__head .fire{ width:30px; height:30px; flex:none; border-radius:9px; background:var(--brand-soft); display:grid; place-items:center; }
.trend__head .fire svg{ width:17px; height:17px; color:var(--brand); }
.trend__head > div{ flex:1; min-width:0; }
.trend__head h3{ font-family:var(--font-display); font-weight:700; font-size:19px; margin:0 0 4px; line-height:1.2; }
.trend__head .sub{ display:block; font-size:11px; font-weight:600; color:var(--ink-3); margin-top:0; line-height:1.4; }
.trend__see{ margin-left:auto; display:inline-flex; align-items:center; gap:4px; color:var(--brand); font-size:12.5px; font-weight:700; text-decoration:none; white-space:nowrap; }
.trend__see svg{ width:14px; height:14px; }

.trow{ display:flex; align-items:center; gap:12px; padding:10px 16px; text-decoration:none; color:var(--ink); border-top:1px solid var(--line-2); }
.trow:first-of-type{ border-top:0; }
.trow__rank{ flex:none; width:34px; text-align:center; font-family:var(--font-display); font-weight:700; font-size:30px; line-height:1; letter-spacing:-.02em; color:var(--ink-3); font-variant-numeric:tabular-nums; }
.trow.is-top .trow__rank{ color:var(--brand); }
.trow__thumb{ flex:none; width:54px; height:54px; border-radius:var(--r-sm); overflow:hidden; position:relative; background:#fff; border:1px solid var(--line-2); }
.trow__thumb img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.trow__thumb img.fit{ object-fit:contain; padding:6%; }
.trow__ph{ position:absolute; inset:0; background:var(--accent-soft); background-image:repeating-linear-gradient(135deg,var(--accent) 0 2px,transparent 2px 10px), repeating-linear-gradient(45deg,rgba(255,255,255,.35) 0 2px,transparent 2px 10px); }
.trow__bd{ flex:1; min-width:0; display:flex; flex-direction:column; gap:3px; }
.trow__ti{ font-size:13px; line-height:1.3; font-weight:500; color:var(--ink); display:-webkit-box; -webkit-line-clamp:1; -webkit-box-orient:vertical; overflow:hidden; }
.trow__ti:lang(bn){ font-size:12.5px; }
.trow__sub{ display:flex; align-items:center; gap:7px; flex-wrap:wrap; }
.trow__price{ font-size:15px; font-weight:800; color:var(--ink); font-variant-numeric:tabular-nums; letter-spacing:-.01em; }
.trow__price b{ font-weight:600; font-size:.66em; }
.trow__rate{ display:inline-flex; align-items:center; gap:3px; font-size:11px; font-weight:700; color:var(--ink-2); }
.trow__rate .st{ color:var(--star); font-size:10px; }
.trow__cert{ display:inline-flex; align-items:center; gap:3px; white-space:nowrap; background:var(--trust-soft); color:var(--trust); font-size:8.5px; font-weight:700; letter-spacing:.02em; padding:2px 6px 2px 4px; border-radius:var(--r-xs); text-transform:uppercase; }
.trow__cert svg{ width:10px; height:10px; }
.trow__add{ flex:none; width:34px; height:34px; border-radius:50%; background:var(--brand-soft); display:grid; place-items:center; }
.trow__add svg{ width:17px; height:17px; color:var(--brand); }

/* ===== DESKTOP — two columns ===== */
.dk-trend{ background:#fff; padding:24px 24px 26px; }
.dk-trend__head{ display:flex; align-items:center; gap:13px; margin-bottom:18px; }
.dk-trend__head .fire{ width:38px; height:38px; border-radius:11px; }
.dk-trend__head .fire svg{ width:21px; height:21px; }
.dk-trend__head > div{ flex:1; min-width:0; }
.dk-trend__head h3{ font-family:var(--font-display); font-weight:700; font-size:26px; margin:0 0 5px; line-height:1.2; letter-spacing:-.01em; }
.dk-trend__head .sub{ font-size:12.5px; font-weight:600; color:var(--ink-3); margin-top:0; line-height:1.4; }
.dk-trend__see{ margin-left:auto; display:inline-flex; align-items:center; gap:5px; color:var(--brand); font-size:13.5px; font-weight:700; text-decoration:none; }
.dk-trend__see svg{ width:15px; height:15px; }
.dk-trend__grid{ display:grid; grid-template-columns:1fr 1fr; gap:0 40px; }
.dk-trend__grid .trow{ padding:13px 0; }
.dk-trend__grid .trow__rank{ font-size:34px; width:42px; }
.dk-trend__grid .trow__thumb{ width:60px; height:60px; }
.dk-trend__grid .trow__ti{ font-size:14px; }
.dk-trend__grid .trow__price{ font-size:16px; }
.dk-trend__grid .trow__add{ width:38px; height:38px; }

@media (prefers-reduced-motion: reduce){ *{ transition:none !important; } }

/* ============================================================
   FAQ / TRUST BUILDER
   ============================================================ */
/* =========================================================
   FAQ / TRUST BUILDER — navy band
   ========================================================= */
.faq{ background:var(--navy); color:var(--ft-fg); }
.faq__intro{ padding:22px 16px 6px; }
.faq__kf{ display:inline-flex; align-items:center; gap:7px; font-size:11px; font-weight:800; letter-spacing:.1em; text-transform:uppercase; color:var(--gold); }
.faq__kf::before{ content:""; width:16px; height:1.5px; background:var(--gold); }
.faq__intro h3{ font-family:var(--font-display); font-weight:700; font-size:24px; line-height:1.12; margin:11px 0 9px; color:#fff; letter-spacing:-.01em; }
.faq__intro h3 em{ font-style:italic; color:var(--gold); font-weight:600; }
.faq__intro p{ margin:0 0 15px; font-size:13.5px; color:var(--ft-mut); max-width:34ch; }
.faq__btns{ display:flex; gap:9px; flex-wrap:wrap; }
.faq__btn{ display:inline-flex; align-items:center; gap:7px; white-space:nowrap; font-family:var(--font-body); font-weight:700; font-size:13px; padding:10px 16px; border-radius:var(--r-pill); text-decoration:none; cursor:pointer; border:1px solid transparent; }
.faq__btn svg{ width:15px; height:15px; }
.faq__btn.primary{ background:linear-gradient(180deg,var(--brand-bright),var(--brand)); color:#fff; }
.faq__btn.ghost{ background:transparent; color:var(--ft-fg); border-color:var(--ft-line); }

.faq__list{ padding:14px 14px 20px; display:flex; flex-direction:column; gap:9px; }
.qa{ background:rgba(255,255,255,.04); border:1px solid var(--ft-line); border-radius:var(--r-md); overflow:hidden; transition:border-color .2s ease; }
.qa.is-open{ border-color:color-mix(in srgb,var(--gold) 45%,var(--ft-line)); background:rgba(255,255,255,.06); }
.qa__btn{ width:100%; background:none; border:0; cursor:pointer; color:#fff; font-family:var(--font-body); display:flex; align-items:center; gap:12px; padding:14px 15px; font-size:14px; font-weight:600; text-align:left; line-height:1.3; }
.qa__q{ flex:1; min-width:0; }
.qa__chev{ flex:none; width:18px; height:18px; color:var(--ft-mut-2); transition:transform .28s cubic-bezier(.45,.02,.18,1); }
.qa.is-open .qa__chev{ transform:rotate(180deg); color:var(--gold); }
.qa__panel{ display:grid; grid-template-rows:0fr; transition:grid-template-rows .3s cubic-bezier(.45,.02,.18,1); }
.qa.is-open .qa__panel{ grid-template-rows:1fr; }
.qa__inner{ overflow:hidden; }
.qa__a{ margin:0; padding:0 15px 15px 15px; font-size:13px; color:var(--ft-mut); line-height:1.55; max-width:54ch; }
.qa__a b{ color:var(--ft-fg); font-weight:600; }

/* ===== DESKTOP — split ===== */
.dk-faq{ background:var(--navy); color:var(--ft-fg); display:grid; grid-template-columns:1fr 1.15fr; gap:0; }
.dk-faq__intro{ padding:44px 40px; border-right:1px solid var(--ft-line); display:flex; flex-direction:column; }
.dk-faq__intro .faq__kf{ font-size:12px; }
.dk-faq__intro h3{ font-family:var(--font-display); font-weight:700; font-size:34px; line-height:1.08; margin:15px 0 14px; color:#fff; letter-spacing:-.015em; }
.dk-faq__intro h3 em{ font-style:italic; color:var(--gold); font-weight:600; }
.dk-faq__intro p{ margin:0 0 22px; font-size:15px; color:var(--ft-mut); max-width:38ch; line-height:1.6; }
.dk-faq__btns{ display:flex; gap:11px; flex-wrap:wrap; }
.dk-faq__btns .faq__btn{ font-size:14px; padding:12px 20px; }
.dk-faq__support{ margin-top:auto; padding-top:28px; display:flex; align-items:center; gap:11px; }
.dk-faq__support .av{ width:38px; height:38px; border-radius:50%; background:linear-gradient(135deg,var(--navy-soft),var(--navy-line)); border:1px solid var(--ft-line); display:grid; place-items:center; color:var(--gold); flex:none; }
.dk-faq__support .av svg{ width:19px; height:19px; }
.dk-faq__support .tx{ font-size:12.5px; color:var(--ft-mut); line-height:1.4; }
.dk-faq__support .tx b{ display:block; color:#fff; font-size:13.5px; font-weight:600; }
.dk-faq__list{ padding:34px 40px 36px; display:flex; flex-direction:column; gap:10px; }
.dk-faq__list .qa__btn{ font-size:15px; padding:16px 18px; }
.dk-faq__list .qa__a{ font-size:13.5px; padding:0 18px 17px; max-width:none; }

@media (prefers-reduced-motion: reduce){ .qa__panel,.qa__chev{ transition:none; } }

/* ============================================================
   APP LAUNCH NOTIFY (replaces app download)
   ============================================================ */
.appwait{ background:var(--navy-deep); color:#fff; padding:28px 18px 24px; text-align:center; }
.appwait__in{ max-width:340px; margin:0 auto; display:flex; flex-direction:column; align-items:center; gap:6px; }
.appwait__ic{ width:46px; height:46px; border-radius:14px; background:rgba(255,255,255,.06); border:1px solid var(--navy-line); display:grid; place-items:center; margin-bottom:4px; }
.appwait__ic svg{ width:24px; height:24px; color:var(--gold); }
.appwait__kf{ font-size:11px; font-weight:800; letter-spacing:.12em; text-transform:uppercase; color:var(--gold); }
.appwait h3{ font-family:var(--font-display); font-weight:700; font-size:22px; line-height:1.12; margin:6px 0 4px; letter-spacing:-.01em; }
.appwait p{ margin:0 0 14px; font-size:13.5px; color:var(--ft-mut); line-height:1.5; max-width:34ch; }
.appwait__form{ width:100%; position:relative; }
.appwait__field{ display:flex; gap:0; border-radius:var(--r-pill); overflow:hidden; border:1px solid var(--navy-line); background:rgba(255,255,255,.06); }
.appwait__field input{ flex:1; min-width:0; border:0; background:transparent; padding:12px 16px; font-family:var(--font-body); font-size:14px; color:#fff; outline:none; }
.appwait__field input::placeholder{ color:var(--ft-mut-2); }
.appwait__field button{ flex:none; border:0; background:linear-gradient(180deg,var(--brand-bright),var(--brand)); color:#fff; font-family:var(--font-body); font-weight:700; font-size:13px; padding:12px 18px; cursor:pointer; white-space:nowrap; transition:opacity .15s ease; }
.appwait__field button:active{ opacity:.8; }
.appwait__ok{ display:none; font-size:13px; font-weight:600; color:var(--gold); margin-top:10px; }
.appwait__form.is-done .appwait__field{ display:none; }
.appwait__form.is-done .appwait__ok{ display:block; }
.appwait__note{ font-size:11px; color:var(--ft-mut-2); margin-top:8px; }


/* =========================================================
   APP DOWNLOAD — navy-deep band
   ========================================================= */
.appdl{ background:var(--navy-deep); color:#fff; position:relative; overflow:hidden; }
.appdl::after{ content:""; position:absolute; right:-60px; top:-60px; width:200px; height:200px; border-radius:50%; background:radial-gradient(circle,rgba(224,83,15,.22),transparent 70%); pointer-events:none; }
.appdl__in{ position:relative; padding:22px 18px 6px; }
.appdl__kf{ display:inline-flex; align-items:center; gap:7px; font-size:11px; font-weight:800; letter-spacing:.1em; text-transform:uppercase; color:var(--gold); }
.appdl__kf::before{ content:""; width:16px; height:1.5px; background:var(--gold); }
.appdl h3{ font-family:var(--font-display); font-weight:700; font-size:25px; line-height:1.08; margin:11px 0 8px; letter-spacing:-.01em; }
.appdl p{ margin:0 0 16px; font-size:13.5px; color:var(--ft-mut); max-width:32ch; }
.appdl p b{ color:#fff; font-weight:600; }
.stores{ display:flex; gap:9px; flex-wrap:wrap; }
.store{ display:inline-flex; align-items:center; gap:9px; background:#000; border:1px solid #2a2f3e; border-radius:11px; padding:8px 14px 8px 12px; text-decoration:none; }
.store svg{ width:22px; height:22px; color:#fff; flex:none; }
.store .tx{ display:flex; flex-direction:column; line-height:1.05; white-space:nowrap; }
.store .tx small{ font-size:9px; font-weight:500; letter-spacing:.02em; color:#c9cdd8; }
.store .tx b{ font-size:15px; font-weight:700; color:#fff; }

/* app mockup */
.appdl__mock{ position:relative; margin-top:18px; height:148px; }
.mini-phone{ position:absolute; left:50%; bottom:-6px; transform:translateX(-50%); width:172px; background:#0c0b12; border-radius:24px 24px 6px 6px; padding:7px 7px 0; box-shadow:0 -10px 40px -16px rgba(0,0,0,.7); border:1px solid #20232f; }
.mini-phone__screen{ border-radius:18px 18px 0 0; overflow:hidden; background:var(--app-bg); }
.mini-phone__bar{ height:24px; background:var(--navy); display:flex; align-items:center; justify-content:space-between; padding:0 12px; }
.mini-phone__bar i{ display:block; height:5px; border-radius:3px; background:#fff; opacity:.85; }
.mini-phone__bar i:first-child{ width:26px; }
.mini-phone__bar i:last-child{ width:14px; }
.mini-phone__body{ padding:9px; display:flex; flex-direction:column; gap:7px; }
.mini-phone__hero{ height:46px; border-radius:8px; background:repeating-linear-gradient(135deg,var(--brand-soft) 0 9px,#fff 9px 18px); display:grid; place-items:center; }
.mini-phone__hero span{ font-family:"SF Mono",ui-monospace,Menlo,monospace; font-size:8px; color:var(--brand-ink); background:rgba(255,255,255,.8); padding:2px 6px; border-radius:var(--r-pill); }
.mini-phone__row{ display:grid; grid-template-columns:1fr 1fr; gap:7px; }
.mini-phone__card{ height:54px; border-radius:7px; background:#fff; border:1px solid var(--line-2); }

/* ===== DESKTOP — two columns ===== */
.dk-appdl{ background:var(--navy-deep); color:#fff; position:relative; overflow:hidden; display:grid; grid-template-columns:1.2fr 1fr; align-items:center; }
.dk-appdl::after{ content:""; position:absolute; left:46%; top:-80px; width:320px; height:320px; border-radius:50%; background:radial-gradient(circle,rgba(224,83,15,.2),transparent 70%); pointer-events:none; }
.dk-appdl__tx{ position:relative; padding:42px 44px; }
.dk-appdl__tx .appdl__kf{ font-size:12px; }
.dk-appdl__tx h3{ font-family:var(--font-display); font-weight:700; font-size:36px; line-height:1.06; margin:15px 0 12px; letter-spacing:-.015em; }
.dk-appdl__tx p{ margin:0 0 22px; font-size:15.5px; color:var(--ft-mut); max-width:40ch; line-height:1.55; }
.dk-appdl__tx p b{ color:#fff; font-weight:600; }
.dk-stores{ display:flex; align-items:center; gap:11px; flex-wrap:wrap; }
.dk-stores .store{ padding:10px 18px 10px 15px; border-radius:12px; }
.dk-stores .store svg{ width:25px; height:25px; }
.dk-stores .store .tx b{ font-size:16px; }
.dk-qr{ display:flex; align-items:center; gap:11px; margin-top:24px; }
.dk-qr__box{ width:74px; height:74px; border-radius:10px; background:#fff; padding:8px; flex:none; }
.dk-qr__box .grid{ width:100%; height:100%; background:
  conic-gradient(#0e1525 90deg,transparent 0) 0 0/12px 12px,
  conic-gradient(#0e1525 90deg,transparent 0) 6px 6px/12px 12px; background-color:#fff; border-radius:3px; }
.dk-qr__tx{ font-size:12.5px; color:var(--ft-mut); line-height:1.45; max-width:18ch; }
.dk-qr__tx b{ display:block; color:#fff; font-size:13.5px; font-weight:600; }
.dk-appdl__art{ position:relative; height:330px; }
.dk-appdl__art .mini-phone{ width:214px; bottom:auto; top:50%; transform:translate(-50%,-50%) rotate(-5deg); border-radius:30px; padding:9px 9px 0; }
.dk-appdl__art .mini-phone__screen{ border-radius:23px 23px 0 0; }
.dk-appdl__art .mini-phone__body{ padding:11px; gap:9px; }
.dk-appdl__art .mini-phone__hero{ height:64px; }
.dk-appdl__art .mini-phone__card{ height:72px; }

@media (prefers-reduced-motion: reduce){ *{ transition:none !important; } }

/* ============================================================
   BACK TO TOP
   ============================================================ */
/* =========================================================
   BACK TO TOP STRIP
   ========================================================= */
.b2t{ width:100%; background:var(--navy); border:0; cursor:pointer; color:#fff; font-family:var(--font-body);
  display:flex; align-items:center; justify-content:center; gap:9px; padding:15px 16px; font-size:13.5px; font-weight:700;
  letter-spacing:.01em; transition:background .18s ease; }
.b2t:hover{ background:#1b2542; }
.b2t:active{ background:var(--navy-deep); }
.b2t__ic{ width:20px; height:20px; border-radius:50%; border:1.5px solid rgba(255,255,255,.45); display:grid; place-items:center; transition:transform .18s ease, border-color .18s ease; }
.b2t__ic svg{ width:12px; height:12px; color:#fff; }
.b2t:hover .b2t__ic{ transform:translateY(-2px); border-color:var(--brand-bright); }

/* scroll demo */
.demo{ height:460px; overflow-y:auto; scrollbar-width:thin; scroll-behavior:smooth; }
.demo::-webkit-scrollbar{ width:5px; } .demo::-webkit-scrollbar-thumb{ background:rgba(20,29,51,.18); border-radius:4px; }
.filler{ padding:14px; display:flex; flex-direction:column; gap:12px; background:var(--app-bg); }
.fblock{ background:#fff; border:1px solid var(--line-2); border-radius:var(--r-md); padding:13px; }
.fblock .h{ height:11px; width:42%; border-radius:4px; background:var(--line); margin-bottom:11px; }
.fbar{ height:7px; border-radius:4px; background:var(--line-2); margin-top:7px; }
.fbar.s{ width:64%; }
.fgridmini{ display:grid; grid-template-columns:1fr 1fr; gap:9px; margin-top:10px; }
.ftile{ aspect-ratio:1/1.15; border-radius:8px; background:repeating-linear-gradient(135deg,var(--app-bg) 0 9px,#fff 9px 18px); border:1px solid var(--line-2); }
.flabel{ font-family:"SF Mono",ui-monospace,Menlo,monospace; font-size:10px; color:var(--ink-3); letter-spacing:.03em; }
.f-toptag{ text-align:center; padding:11px; font-family:"SF Mono",ui-monospace,Menlo,monospace; font-size:10px; color:var(--brand); letter-spacing:.04em; background:var(--brand-soft); border-bottom:1px solid color-mix(in srgb,var(--brand) 18%,var(--line)); }

/* desktop variant */
.deskwrap .demo{ height:400px; }
.deskwrap .filler{ padding:20px 24px; }
.deskwrap .fgridmini{ grid-template-columns:repeat(4,1fr); }
.dk-b2t{ font-size:14px; padding:17px; }

@media (prefers-reduced-motion: reduce){ .demo{ scroll-behavior:auto; } .b2t,.b2t__ic{ transition:none; } }

/* ============================================================
   PRE-FOOTER TRUST BANNER
   ============================================================ */
/* =========================================================
   PRE-FOOTER TRUST BANNER — warm band between two navy bands
   ========================================================= */
.trustb{ background:linear-gradient(180deg,#efe6d8,#e9ddca); padding:22px 14px 24px; border-top:1px solid #ddd0bb; }
.trustb__kf{ text-align:center; font-size:11px; font-weight:800; letter-spacing:.12em; text-transform:uppercase; color:var(--brand-ink); margin:0 0 4px; }
.trustb__lead{ text-align:center; font-family:var(--font-display); font-weight:700; font-size:20px; letter-spacing:-.01em; margin:0 0 16px; color:var(--ink); }
.trustb__grid{ display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.tcard{ background:#fff; border:1px solid #e7dcc9; border-radius:var(--r-md); padding:14px 13px; display:flex; flex-direction:column; gap:9px; box-shadow:0 1px 2px rgba(92,37,9,.05); }
.tcard__ic{ width:38px; height:38px; border-radius:11px; display:grid; place-items:center; flex:none; }
.tcard__ic svg{ width:20px; height:20px; }
.tcard.t1 .tcard__ic{ background:var(--trust-soft); color:var(--trust); }
.tcard.t2 .tcard__ic{ background:var(--green-soft); color:var(--green); }
.tcard.t3 .tcard__ic{ background:var(--gold-soft); color:var(--gold); }
.tcard.t4 .tcard__ic{ background:var(--brand-soft); color:var(--brand); }
.tcard h4{ font-family:var(--font-display); font-weight:700; font-size:15px; margin:0; line-height:1.15; letter-spacing:-.01em; }
.tcard p{ margin:0; font-size:11.5px; color:var(--ink-2); line-height:1.4; }
.tcard p b{ color:var(--ink); font-weight:600; }
.tcard__marks{ display:flex; gap:5px; margin-top:1px; }
.tmark{ height:19px; padding:0 7px; border-radius:5px; background:var(--paper); display:inline-flex; align-items:center; font-weight:800; font-size:9.5px; color:var(--ink); border:1px solid var(--line); }
.tmark.bk{ color:var(--bkash); font-family:var(--font-display); font-style:italic; }
.tmark.ng{ color:var(--nagad); font-family:var(--font-display); }
.tmark.cod{ color:var(--ink-2); }

/* ===== DESKTOP — 4 in a row ===== */
.dk-trustb{ background:linear-gradient(180deg,#efe6d8,#e9ddca); padding:34px 24px 36px; }
.dk-trustb__head{ text-align:center; margin-bottom:24px; }
.dk-trustb__head .trustb__kf{ font-size:12px; }
.dk-trustb__head h3{ font-family:var(--font-display); font-weight:700; font-size:28px; letter-spacing:-.015em; margin:6px 0 0; color:var(--ink); }
.dk-trustb__head h3 em{ font-style:italic; color:var(--brand); font-weight:600; }
.dk-trustb__grid{ max-width:1100px; margin:0 auto; display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.dk-trustb__grid .tcard{ padding:22px 20px; gap:12px; border-radius:var(--r-lg); }
.dk-trustb__grid .tcard__ic{ width:46px; height:46px; border-radius:13px; }
.dk-trustb__grid .tcard__ic svg{ width:24px; height:24px; }
.dk-trustb__grid .tcard h4{ font-size:18px; }
.dk-trustb__grid .tcard p{ font-size:13px; }
.dk-trustb__grid .tmark{ height:22px; font-size:11px; }

@media (prefers-reduced-motion: reduce){ *{ transition:none !important; } }

/* ============================================================
   SITE FOOTER
   ============================================================ */
/* =========================================================
   MOBILE FOOTER (.ft)
   ========================================================= */
.ft{ background:var(--navy); color:var(--ft-fg); font-size:14px; }
.ft a{ color:inherit; text-decoration:none; }

/* trust ribbon */
.ft-trust{ background:var(--navy-deep); border-bottom:1px solid var(--ft-line); }
.ft-trust__in{ display:flex; gap:8px; padding:12px 14px; overflow-x:auto; scroll-snap-type:x proximity;
  -webkit-overflow-scrolling:touch; scrollbar-width:none; }
.ft-trust__in::-webkit-scrollbar{ display:none; }
.ft-sig{ flex:0 0 auto; scroll-snap-align:start; display:flex; align-items:center; gap:7px; white-space:nowrap;
  padding:6px 11px 6px 7px; border-radius:var(--r-pill); background:rgba(255,255,255,.04); border:1px solid var(--ft-line); }
.ft-sig .ic{ width:24px; height:24px; border-radius:7px; flex:none; display:grid; place-items:center;
  background:color-mix(in srgb,var(--gold) 16%,transparent); color:var(--gold); }
.ft-sig .ic svg{ width:13px; height:13px; }
.ft-sig b{ font-size:11.5px; font-weight:700; color:var(--ft-fg); }

/* newsletter (compact) */
.ft-news{ padding:16px 16px 18px; border-bottom:1px solid var(--ft-line); }
.ft-news h4{ font-family:var(--font-display); font-weight:600; font-size:16px; margin:0 0 3px; color:#fff; }
.ft-news p{ margin:0 0 10px; font-size:12px; color:var(--ft-mut); }
.ft-news form{ display:flex; gap:8px; }
.ft-field{ flex:1; min-width:0; display:flex; align-items:center; gap:8px; background:#fff; border-radius:var(--r-pill); padding:0 4px 0 13px; height:42px; border:1px solid transparent; }
.ft-field:focus-within{ border-color:var(--gold); box-shadow:0 0 0 3px color-mix(in srgb,var(--gold) 30%,transparent); }
.ft-field svg{ width:16px; height:16px; color:var(--ink-3); flex:none; }
.ft-field input{ flex:1; min-width:0; border:0; outline:0; font-family:var(--font-body); font-size:13.5px; color:var(--ink); background:transparent; height:100%; }
.ft-field input::placeholder{ color:var(--ink-3); }
.ft-sub{ flex:none; border:0; cursor:pointer; background:linear-gradient(180deg,var(--brand-bright),var(--brand)); color:#fff;
  font-family:var(--font-body); font-weight:700; font-size:13px; padding:0 16px; height:42px; border-radius:var(--r-pill); display:inline-flex; align-items:center; gap:6px; white-space:nowrap; }
.ft-news__ok{ margin:9px 0 0; font-size:11.5px; color:var(--gold); font-weight:600; display:none; align-items:center; gap:6px; }
.ft-news__ok svg{ width:13px; height:13px; }
.ft-news.is-done .ft-news__ok{ display:flex; }

/* accordion link columns */
.ft-cols{ border-bottom:1px solid var(--ft-line); }
.ft-col{ border-bottom:1px solid var(--ft-line); }
.ft-col:last-child{ border-bottom:0; }
.ft-col__btn{ width:100%; background:none; border:0; cursor:pointer; color:var(--ft-fg); font-family:var(--font-body);
  display:flex; align-items:center; gap:10px; padding:14px 16px; font-size:13.5px; font-weight:700; text-align:left; }
.ft-col__btn .chev{ margin-left:auto; width:16px; height:16px; color:var(--ft-mut-2); transition:transform .28s cubic-bezier(.45,.02,.18,1); flex:none; }
.ft-col.is-open .ft-col__btn .chev{ transform:rotate(180deg); color:var(--gold); }
.ft-col__panel{ display:grid; grid-template-rows:0fr; transition:grid-template-rows .3s cubic-bezier(.45,.02,.18,1); }
.ft-col.is-open .ft-col__panel{ grid-template-rows:1fr; }
.ft-col__inner{ overflow:hidden; }
.ft-col__panel ul{ list-style:none; margin:0; padding:0 16px 12px; display:flex; flex-direction:column; gap:0; }
.ft-col__panel a{ display:block; padding:6px 0; font-size:13px; color:var(--ft-mut); font-weight:500; }
.ft-col__panel a:active{ color:#fff; }
.ft-col__panel a .badge{ margin-left:6px; font-size:9px; font-weight:800; letter-spacing:.04em; text-transform:uppercase; color:var(--gold); border:1px solid color-mix(in srgb,var(--gold) 40%,transparent); padding:1px 5px; border-radius:var(--r-pill); }

/* charity + payments + contact — merged compact zone */
.ft-compact{ padding:14px 16px 16px; border-bottom:1px solid var(--ft-line); display:flex; flex-direction:column; gap:14px; }
.ft-charity-line{ display:flex; align-items:center; gap:9px; font-size:12.5px; color:var(--ft-mut); }
.ft-charity-line svg{ width:16px; height:16px; flex:none; color:var(--gold); }
.ft-charity-line b{ color:var(--gold); font-weight:700; }
.ft-marks{ display:flex; flex-wrap:wrap; gap:7px; }
.ft-mark{ height:30px; min-width:40px; padding:0 9px; border-radius:6px; background:#fff; display:inline-flex; align-items:center; justify-content:center; gap:4px; white-space:nowrap;
  font-weight:800; font-size:11px; color:var(--ink); border:1px solid rgba(255,255,255,.5); }
.ft-mark.bk{ color:var(--bkash); font-family:var(--font-display); font-style:italic; letter-spacing:-.02em; font-size:12px; }
.ft-mark.ng{ color:var(--nagad); font-family:var(--font-display); font-size:12px; }
.ft-mark .visa{ background:#1a1f71; color:#fff; font-size:8px; font-weight:800; padding:2px 4px; border-radius:2px; line-height:1; }
.ft-mark .mc{ background:#eb001b; color:#fff; font-size:8px; font-weight:800; padding:2px 4px; border-radius:2px; line-height:1; }
.ft-mark .ssl{ font-size:8.5px; font-weight:700; color:var(--ink-3); }
.ft-mark.cod{ background:transparent; color:var(--ft-fg); border:1px solid var(--ft-line); font-size:11px; }
.ft-mark.cod svg{ width:14px; height:14px; }
.ft-contact-row{ display:flex; flex-wrap:wrap; gap:8px 20px; font-size:12px; color:var(--ft-mut); }
.ft-contact-row a{ display:flex; align-items:center; gap:6px; color:var(--ft-fg); font-weight:500; font-size:12.5px; }
.ft-contact-row svg{ width:14px; height:14px; color:var(--gold); flex:none; }
.ft-social{ display:flex; gap:8px; }
.ft-social a{ width:34px; height:34px; border-radius:9px; display:grid; place-items:center; color:var(--ft-fg);
  background:rgba(255,255,255,.06); border:1px solid var(--ft-line); }
.ft-social a svg{ width:16px; height:16px; }

/* bottom bar */
.ft-bottom{ background:var(--navy-deep); padding:14px 16px; display:flex; flex-wrap:wrap; align-items:center; gap:10px 14px; }
.ft-bottom img{ height:22px; width:auto; }
.ft-bottom .cc{ font-size:11px; color:var(--ft-mut-2); }
.ft-seg{ display:inline-flex; background:rgba(255,255,255,.05); border:1px solid var(--ft-line); border-radius:var(--r-pill); padding:2px; }
.ft-seg button{ border:0; cursor:pointer; background:transparent; color:var(--ft-mut); font-family:var(--font-body); font-weight:600; font-size:11px; padding:4px 10px; border-radius:var(--r-pill); white-space:nowrap; }
.ft-seg button.bn{ font-family:var(--font-bn); }
.ft-seg button.on{ background:var(--gold); color:#23200f; }
.ft-legal{ display:flex; flex-wrap:wrap; gap:4px 12px; }
.ft-legal a{ font-size:11px; color:var(--ft-mut-2); font-weight:500; }

/* =========================================================
   DESKTOP FOOTER (.ftd) — compact 2-band layout
   ========================================================= */
.deskwrap{ border:1px solid var(--line); border-radius:var(--r-md); overflow:hidden; box-shadow:var(--shadow-card); background:#fff; }
.deskwrap .above{ height:72px; background:repeating-linear-gradient(135deg,#f3f1ec 0 16px,#efece6 16px 32px); border-bottom:1px solid var(--line); display:grid; place-items:center; }
.deskwrap .above span{ font-family:"SF Mono",ui-monospace,Menlo,monospace; font-size:11px; letter-spacing:.06em; color:var(--ink-3); background:rgba(255,255,255,.7); padding:4px 12px; border-radius:var(--r-pill); }

.ftd{ background:var(--navy); color:var(--ft-fg); font-size:13px; }
.ftd a{ color:inherit; text-decoration:none; }

/* trust strip — thin horizontal */
.ftd-trust{ background:var(--navy-deep); border-bottom:1px solid var(--ft-line); }
.ftd-trust__in{ max-width:1140px; margin:0 auto; display:flex; align-items:center; justify-content:center; gap:28px; padding:11px 24px; flex-wrap:wrap; }
.ftd-sig{ display:flex; align-items:center; gap:8px; white-space:nowrap; }
.ftd-sig .ic{ width:22px; height:22px; flex:none; display:grid; place-items:center; color:var(--gold); }
.ftd-sig .ic svg{ width:16px; height:16px; }
.ftd-sig b{ font-size:12px; font-weight:700; color:var(--ft-fg); }
.ftd-sig span{ font-size:11px; color:var(--ft-mut-2); margin-left:2px; }

/* main row — brand col + 4 link cols */
.ftd-main{ max-width:1140px; margin:0 auto; padding:32px 24px 28px; display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr 1fr; gap:32px; }
.ftd-brandcol{ display:flex; flex-direction:column; gap:12px; }
.ftd-brandcol img{ height:30px; width:auto; align-self:flex-start; }
.ftd-brandcol .blurb{ font-size:12.5px; color:var(--ft-mut); max-width:30ch; line-height:1.5; }
.ftd-news{ margin-top:4px; }
.ftd-news p{ margin:0 0 8px; font-size:11.5px; color:var(--ft-mut-2); }
.ftd-news form{ display:flex; gap:6px; max-width:300px; }
.ftd-news .ft-field{ height:38px; font-size:12.5px; padding:0 4px 0 11px; } 
.ftd-news .ft-field input{ font-size:12.5px; }
.ftd-news .ft-sub{ height:38px; padding:0 14px; font-size:12px; }
.ftd-news .ft-news__ok{ margin-top:8px; font-size:11px; }
.ftd-news.is-done .ft-news__ok{ display:flex; }

.ftd-col h5{ margin:0 0 12px; font-weight:700; font-size:12.5px; color:#fff; letter-spacing:.01em; }
.ftd-col h5 .badge{ font-size:8.5px; font-weight:800; letter-spacing:.04em; text-transform:uppercase; color:var(--gold); border:1px solid color-mix(in srgb,var(--gold) 40%,transparent); padding:1px 5px; border-radius:var(--r-pill); margin-left:5px; }
.ftd-col ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:8px; }
.ftd-col a{ font-size:12.5px; color:var(--ft-mut); font-weight:500; }
.ftd-col a:hover{ color:#fff; }

/* bottom bar — everything else in one line */
.ftd-bottom{ background:var(--navy-deep); border-top:1px solid var(--ft-line); }
.ftd-bottom__in{ max-width:1140px; margin:0 auto; padding:14px 24px; display:flex; align-items:center; gap:14px 20px; flex-wrap:wrap; }
.ftd-charity-line{ display:flex; align-items:center; gap:7px; font-size:11.5px; color:var(--ft-mut); }
.ftd-charity-line svg{ width:15px; height:15px; flex:none; color:var(--gold); }
.ftd-charity-line b{ color:var(--gold); font-weight:700; }
.ftd-sep{ width:1px; height:18px; background:var(--ft-line); flex:none; }
.ftd-marks{ display:flex; align-items:center; gap:7px; }
.ftd-marks .ft-mark{ height:26px; min-width:36px; padding:0 8px; border-radius:5px; font-size:10px; }
.ftd-marks .ft-mark.bk{ font-size:11px; } .ftd-marks .ft-mark.ng{ font-size:11px; }
.ftd-marks .ft-mark .visa,.ftd-marks .ft-mark .mc{ font-size:7.5px; padding:1px 3px; }
.ftd-marks .ft-mark .ssl{ font-size:8px; }
.ftd-marks .ft-mark.cod{ font-size:10px; }
.ftd-marks .ft-mark.cod svg{ width:13px; height:13px; }
.ftd-right{ margin-left:auto; display:flex; align-items:center; gap:12px; flex-wrap:wrap; }
.ftd-social{ display:flex; gap:6px; }
.ftd-social a{ width:28px; height:28px; border-radius:7px; display:grid; place-items:center; color:var(--ft-mut);
  background:rgba(255,255,255,.05); border:1px solid var(--ft-line); }
.ftd-social a:hover{ color:#fff; }
.ftd-social a svg{ width:14px; height:14px; }
.ftd-legal{ display:flex; gap:12px; }
.ftd-legal a{ font-size:11px; color:var(--ft-mut-2); font-weight:500; }
.ftd-legal a:hover{ color:#fff; }

/* full-bleed: navy-deep must reach both page edges like .ftd-bottom above it,
   or the parent .ftd navy shows through at the bottom corners (the "holes"). The
   short copyright line stays centred via text-align, so no inner wrap is needed. */
.ftd-copy{ padding:10px 24px; text-align:center; font-size:11px; color:var(--ft-mut-2); background:var(--navy-deep); border-top:1px solid color-mix(in srgb,var(--ft-line) 50%,transparent); }
.ftd-copy b{ color:var(--ft-mut); font-weight:600; }

@media (prefers-reduced-motion: reduce){ .ft-col__panel,.ft-col__btn .chev{ transition:none; } }


/* ============================================================
   Design tokens (:root vars + .cat-* accents) now live once in
   tokens.css, loaded site-wide ahead of this file. Nothing to see here.
   ============================================================ */


/* ============================================================
   HOMEPAGE FUNCTIONAL PASS — real search inputs + static hero banner
   (replaces the fake search divs and the broken hero carousels)
   ============================================================ */

/* real search fields (desktop big search + mobile search bar) */
.dk-bigsearch input.q{ width:100%; border:0; outline:none; background:transparent; font-family:var(--font-body); color:var(--ink); font-size:17px; font-weight:500; padding:0; }
.dk-bigsearch input.q::placeholder{ color:var(--ink-3); opacity:1; }
.search input.ph{ flex:1; min-width:0; border:0; outline:none; background:transparent; font-family:var(--font-body); color:var(--ink); font-size:14px; font-weight:500; padding:0; }
.search input.ph::placeholder{ color:var(--ink-3); opacity:1; }
.search .aibtn{ cursor:pointer; }

/* desktop hero banner (single, static) */
.dk-herobanner{ position:relative; min-height:300px; display:flex; align-items:center; gap:24px; padding:40px 44px; border-radius:var(--r-md); overflow:hidden;
  background:linear-gradient(120deg, var(--accent-soft, var(--brand-soft)) 0%, #fff 70%); border:1px solid var(--line); }
.dk-herobanner__tx{ width:56%; position:relative; z-index:2; }
.dk-herobanner__tx .kf{ font-size:12px; font-weight:800; letter-spacing:.09em; text-transform:uppercase; color:var(--accent-ink, var(--brand-ink)); }
.dk-herobanner__tx h2{ font-family:var(--font-display); font-weight:800; font-size:38px; line-height:1.05; margin:10px 0 10px; letter-spacing:-.01em; color:var(--navy); }
.dk-herobanner__tx p{ margin:0 0 22px; font-size:15px; color:var(--ink-2); max-width:42ch; line-height:1.55; }
.dk-herobanner__tx .cta{ display:inline-flex; align-items:center; gap:9px; background:linear-gradient(180deg,var(--brand-bright),var(--brand)); color:#fff; font-weight:700; font-size:15px; padding:12px 24px; border-radius:var(--r-pill); text-decoration:none; box-shadow:0 8px 20px -8px rgba(224,83,15,.6); }
.dk-herobanner__tx .cta svg{ width:16px; height:16px; }
.dk-herobanner__feat{ position:absolute; right:36px; top:30px; bottom:30px; width:32%; display:flex; flex-direction:column; align-items:center; justify-content:center; text-decoration:none; }
.dk-herobanner__feat .aim{ width:100%; flex:1; min-height:0; object-fit:contain; border-radius:var(--r-md); background:linear-gradient(125deg,#fff,color-mix(in srgb,var(--accent-soft) 50%,#fff)); border:1px solid rgba(0,0,0,.06); box-shadow:var(--shadow-card); padding:12px; }
.dk-herobanner__feat .off{ position:absolute; right:6px; top:6px; z-index:3; background:var(--red); color:#fff; font-weight:800; font-size:12px; padding:4px 9px; border-radius:var(--r-sm); }
.dk-herobanner__feat .cap{ margin-top:10px; text-align:center; }
.dk-herobanner__feat .cap b{ display:block; font-size:13px; color:var(--ink); font-weight:700; line-height:1.25; }
.dk-herobanner__feat .cap .pr{ display:block; font-size:14px; font-weight:800; color:var(--brand); margin-top:3px; }
.dk-herobanner__feat .cap .pr b{ display:inline; font-weight:600; font-size:.7em; color:var(--brand); }

/* mobile hero banner (single, static) */
.mbanner{ position:relative; margin:0; padding:20px 16px; min-height:148px; border-radius:var(--r-md); overflow:hidden;
  background:linear-gradient(120deg, var(--accent-soft, var(--brand-soft)) 0%, #fff 88%); border:1px solid var(--line); display:flex; flex-direction:column; align-items:flex-start; }
.mbanner .kf{ font-size:10.5px; font-weight:800; letter-spacing:.08em; text-transform:uppercase; color:var(--accent-ink, var(--brand-ink)); }
.mbanner h3{ font-family:var(--font-display); font-weight:700; font-size:21px; line-height:1.12; margin:8px 0 5px; max-width:64%; color:var(--navy); letter-spacing:-.01em; }
.mbanner p{ margin:0 0 14px; font-size:12.5px; color:var(--ink-2); max-width:62%; line-height:1.45; }
.mbanner .cta{ display:inline-flex; align-items:center; gap:7px; background:var(--brand); color:#fff; font-weight:700; font-size:13px; padding:9px 16px; border-radius:var(--r-pill); text-decoration:none; }
.mbanner .cta svg{ width:14px; height:14px; }
.mbanner__feat{ position:absolute; right:14px; top:38px; bottom:16px; width:34%; display:block; }
.mbanner__feat .pim{ width:100%; height:100%; object-fit:contain; border-radius:var(--r-md); border:1px solid rgba(0,0,0,.06); background:linear-gradient(125deg,#fff,color-mix(in srgb,var(--accent-soft) 45%,#fff)); box-shadow:var(--shadow-sm); padding:6px; }
