/* ============================================================
   MasnoonHub — Component 08 · AI Mode (conversational discovery)
   Built on the shared tokens in vendor-store.css. The advisor
   voice speaks in Spectral (display) for warmth; UI stays Hanken.
   All interactive classes prefixed .ai-  to avoid collisions.
   ============================================================ */

/* ---- the app surface inside the phone / desktop frame ---- */
.ai-app{ display:flex; flex-direction:column; height:100%; background:var(--app-bg); position:relative; }

/* slim context bar (navy chrome) */
.ai-bar{ flex:none; display:flex; align-items:center; gap:10px; padding:9px 12px; background:var(--navy); color:#fff; position:relative; z-index:20; }
.ai-bar .ai-back{ border:0; background:transparent; color:#fff; font-size:25px; line-height:1; cursor:pointer; width:28px; height:36px; display:grid; place-items:center; padding:0; }
.ai-bar__id{ flex:1; min-width:0; display:flex; align-items:center; gap:9px; }
.ai-bar__seal{ width:30px; height:30px; flex:none; }
.ai-bar__name{ display:flex; flex-direction:column; line-height:1.12; min-width:0; }
.ai-bar__name b{ font-family:var(--font-display); font-weight:600; font-size:15px; color:#fff; display:flex; align-items:center; gap:5px; }
.ai-bar__name b .tick{ width:14px; height:14px; border-radius:50%; background:var(--trust); display:grid; place-items:center; flex:none; }
.ai-bar__name b .tick svg{ width:9px; height:9px; color:#fff; }
.ai-bar__name span{ color:#aeb6cb; font-size:10.5px; font-weight:500; letter-spacing:.01em; }
.ai-bar .ai-cart{ position:relative; border:0; background:transparent; color:#fff; cursor:pointer; width:34px; height:36px; display:grid; place-items:center; padding:0; }
.ai-bar .ai-cart svg{ width:23px; height:23px; }
.ai-bar .ai-cart .n{ position:absolute; top:-1px; right:-2px; background:var(--brand); color:#fff; font-size:10px; font-weight:800; min-width:17px; height:17px; border-radius:9px; display:grid; place-items:center; padding:0 4px; border:1.5px solid var(--navy); font-variant-numeric:tabular-nums; }

/* ---- the certified-guide seal (the memorable mark) ---- */
.ai-seal{ position:relative; border-radius:50%; display:grid; place-items:center;
  background:radial-gradient(120% 120% at 30% 22%, var(--navy-soft), var(--navy-deep)); color:#fff; flex:none; }
.ai-seal svg{ width:58%; height:58%; }
.ai-seal .spark{ color:var(--star); }
/* the gold halo that marks "certified" guidance */
.ai-seal--halo::before{ content:""; position:absolute; inset:-4px; border-radius:50%;
  background:conic-gradient(from 0deg, transparent, color-mix(in srgb,var(--star) 70%,transparent), transparent 60%); opacity:.0; }

/* =====================================================================
   SCROLL REGION
   ===================================================================== */
.ai-scroll{ flex:1; overflow-y:auto; overflow-x:hidden; position:relative; scrollbar-width:none; }
.ai-scroll::-webkit-scrollbar{ display:none; }

/* =====================================================================
   1 · OPENING STATE — an inviting hero, not an empty chat box
   ===================================================================== */
.ai-hero{ display:flex; flex-direction:column; align-items:center; text-align:center;
  padding:34px 22px 26px; min-height:100%;
  background:
    radial-gradient(150% 80% at 50% -8%, var(--brand-soft) 0%, transparent 46%),
    radial-gradient(120% 60% at 88% 4%, var(--accent-soft) 0%, transparent 40%); }
.ai-hero__seal{ width:74px; height:74px; margin-bottom:18px; box-shadow:0 14px 34px -12px rgba(20,29,51,.5); }
.ai-hero__seal::after{ content:""; position:absolute; inset:-9px; border-radius:50%; border:1.5px solid color-mix(in srgb,var(--star) 45%,transparent); }
.ai-hero__kicker{ font-size:11px; font-weight:800; letter-spacing:.18em; text-transform:uppercase; color:var(--brand); margin-bottom:11px; display:flex; align-items:center; gap:7px; }
.ai-hero__kicker::before,.ai-hero__kicker::after{ content:""; width:16px; height:1px; background:color-mix(in srgb,var(--brand) 45%,transparent); }
.ai-hero__title{ font-family:var(--font-display); font-weight:600; font-size:27px; line-height:1.16; letter-spacing:-.01em; color:var(--ink); margin:0 0 12px; max-width:15ch; text-wrap:balance; }
.ai-hero__title em{ font-style:italic; color:var(--brand); }
.ai-hero__promise{ font-size:14px; line-height:1.5; color:var(--ink-2); margin:0 0 24px; max-width:30ch; }
.ai-hero__promise b{ color:var(--ink); font-weight:600; }

/* big welcoming composer */
.ai-bigcomposer{ width:100%; max-width:340px; background:#fff; border:1.6px solid var(--line);
  border-radius:22px; box-shadow:0 10px 30px -16px rgba(20,29,51,.35); padding:13px 13px 11px;
  display:flex; flex-direction:column; gap:11px; transition:border-color .18s, box-shadow .18s; }
.ai-bigcomposer:focus-within{ border-color:var(--brand); box-shadow:0 12px 34px -14px color-mix(in srgb,var(--brand) 40%,transparent); }
.ai-bigcomposer textarea{ border:0; outline:0; resize:none; width:100%; background:transparent;
  font-family:var(--font-body); font-size:15px; line-height:1.45; color:var(--ink); min-height:48px; max-height:120px; }
.ai-bigcomposer textarea::placeholder{ color:var(--ink-3); }
.ai-bigcomposer__row{ display:flex; align-items:center; gap:9px; }
.ai-bigcomposer__hint{ flex:1; font-size:11.5px; color:var(--ink-3); display:flex; align-items:center; gap:6px; text-align:left; line-height:1.3; }
.ai-bigcomposer__hint svg{ width:13px; height:13px; color:var(--trust); flex:none; }

.ai-mic{ flex:none; width:44px; height:44px; border-radius:50%; border:1.5px solid var(--line);
  background:#fff; color:var(--ink-2); display:grid; place-items:center; cursor:pointer; transition:.15s; -webkit-tap-highlight-color:transparent; }
.ai-mic svg{ width:20px; height:20px; }
.ai-mic:active{ transform:scale(.92); }
.ai-mic.is-rec{ border-color:var(--brand); color:var(--brand); background:var(--brand-soft); }
.ai-send{ flex:none; width:44px; height:44px; border-radius:50%; border:0;
  background:linear-gradient(180deg,var(--brand-bright),var(--brand)); color:#fff; display:grid; place-items:center;
  cursor:pointer; box-shadow:0 6px 16px -4px rgba(224,83,15,.55); transition:.15s; -webkit-tap-highlight-color:transparent; }
.ai-send svg{ width:21px; height:21px; }
.ai-send:active{ transform:scale(.9); }
.ai-send:disabled{ opacity:.4; box-shadow:none; cursor:default; }

/* example prompt chips — show the range */
.ai-examples{ width:100%; max-width:360px; margin-top:24px; }
.ai-examples__lbl{ font-size:11px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3); margin-bottom:12px; }
.ai-exgrid{ display:flex; flex-direction:column; gap:9px; }
.ai-ex{ display:flex; align-items:center; gap:11px; width:100%; text-align:left; cursor:pointer;
  background:#fff; border:1px solid var(--line); border-radius:14px; padding:12px 13px;
  font-family:var(--font-body); font-size:13.5px; font-weight:600; color:var(--ink); transition:.15s; -webkit-tap-highlight-color:transparent; }
.ai-ex:hover{ border-color:var(--brand); background:#fff; transform:translateY(-1px); box-shadow:var(--shadow-card); }
.ai-ex__ic{ width:32px; height:32px; border-radius:10px; flex:none; display:grid; place-items:center; }
.ai-ex__ic svg{ width:17px; height:17px; }
.ai-ex__tx{ flex:1; line-height:1.3; }
.ai-ex__go{ flex:none; color:var(--ink-3); font-size:18px; }
.ai-ex.cat-attar  .ai-ex__ic{ background:var(--accent-soft); color:var(--accent-ink); }
.ai-ex.cat-hijab  .ai-ex__ic{ background:#f8e2ea; color:#5b1730; }
.ai-ex.cat-tasbih .ai-ex__ic{ background:#dcf0e7; color:#0c3a27; }
.ai-ex.cat-books  .ai-ex__ic{ background:#e6e8f4; color:#1b2347; }

/* =====================================================================
   6 · CONVERSATION THREAD
   ===================================================================== */
.ai-thread{ display:none; flex-direction:column; gap:18px; padding:18px 14px 22px; }
.ai-app.is-chatting .ai-hero{ display:none; }
.ai-app.is-chatting .ai-thread{ display:flex; }

/* user message — orange-tinted bubble, right aligned */
.ai-turn{ display:flex; flex-direction:column; gap:14px; }
.ai-user{ align-self:flex-end; max-width:82%; background:var(--navy); color:#fff;
  padding:11px 15px; border-radius:18px 18px 5px 18px; font-size:14px; line-height:1.42; font-weight:500;
  box-shadow:0 6px 16px -10px rgba(20,29,51,.6); }

/* assistant message block */
.ai-asst{ display:flex; gap:10px; align-items:flex-start; }
.ai-asst__seal{ width:34px; height:34px; margin-top:2px; }
.ai-asst__body{ flex:1; min-width:0; }
.ai-asst__name{ display:flex; align-items:center; gap:6px; margin-bottom:6px; font-size:11px; font-weight:700;
  letter-spacing:.04em; color:var(--ink-2); }
.ai-asst__name .nm{ font-family:var(--font-display); font-size:13px; font-weight:600; letter-spacing:0; color:var(--ink); }
.ai-asst__name .vchip{ display:inline-flex; align-items:center; gap:3px; white-space:nowrap; font-size:9.5px; font-weight:800;
  text-transform:uppercase; letter-spacing:.03em; color:var(--trust); background:var(--trust-soft);
  padding:2px 6px 2px 5px; border-radius:var(--r-pill); }
.ai-asst__name .vchip svg{ width:10px; height:10px; }
/* the advisor's warm summary — Spectral voice */
.ai-say{ font-family:var(--font-display); font-size:16.5px; line-height:1.42; color:var(--ink); margin:0 0 5px; letter-spacing:-.005em; }
.ai-say b{ color:var(--brand-ink); font-weight:600; font-style:italic; }
.ai-say:lang(bn){ font-family:var(--font-body); font-size:15px; }
.ai-subsay{ font-size:12.5px; line-height:1.45; color:var(--ink-2); margin:0 0 13px; }

/* =====================================================================
   3 · THINKING STATE — calm, certified, not a spinner
   ===================================================================== */
.ai-think{ display:flex; gap:10px; align-items:flex-start; }
.ai-think__seal{ width:34px; height:34px; margin-top:2px; position:relative; }
.ai-think__seal::after{ content:""; position:absolute; inset:-5px; border-radius:50%;
  border:2px solid color-mix(in srgb,var(--star) 55%,transparent); border-top-color:var(--star);
  animation:ai-ring 1.5s linear infinite; }
@keyframes ai-ring{ to{ transform:rotate(360deg); } }
.ai-think__body{ flex:1; padding-top:1px; }
.ai-think__line{ font-family:var(--font-display); font-size:15.5px; color:var(--ink); display:flex; align-items:center; gap:9px; }
.ai-think__line .dots{ display:inline-flex; gap:4px; }
.ai-think__line .dots i{ width:6px; height:6px; border-radius:50%; background:var(--brand); opacity:.3; animation:ai-dot 1.1s ease-in-out infinite; }
.ai-think__line .dots i:nth-child(2){ animation-delay:.18s; }
.ai-think__line .dots i:nth-child(3){ animation-delay:.36s; }
@keyframes ai-dot{ 0%,100%{ opacity:.28; transform:translateY(0); } 45%{ opacity:1; transform:translateY(-3px); } }
.ai-think__re{ margin-top:9px; display:inline-flex; align-items:center; gap:7px; font-size:11.5px; font-weight:600;
  color:var(--trust); background:var(--trust-soft); padding:6px 11px; border-radius:var(--r-pill); }
.ai-think__re svg{ width:13px; height:13px; flex:none; }

/* =====================================================================
   4 · PRODUCT PICKS — Component 01 cards in a snap carousel
   ===================================================================== */
.ai-picks{ margin:0 -14px; padding:2px 14px 4px; display:flex; gap:11px; overflow-x:auto;
  scroll-snap-type:x mandatory; scrollbar-width:none; -webkit-overflow-scrolling:touch; }
.ai-picks::-webkit-scrollbar{ display:none; }
.ai-pick{ flex:none; width:188px; scroll-snap-align:start; display:flex; flex-direction:column; }
.ai-pick .mhub-card{ border-color:var(--line); }
/* "why this" note tied to the request + certification */
.ai-why{ margin-top:8px; display:flex; gap:8px; align-items:flex-start;
  background:color-mix(in srgb,var(--accent-soft) 60%,#fff); border:1px solid color-mix(in srgb,var(--accent) 26%,var(--line));
  border-radius:12px; padding:9px 11px; }
.ai-why__ic{ flex:none; width:18px; height:18px; border-radius:50%; background:var(--accent); display:grid; place-items:center; margin-top:1px; }
.ai-why__ic svg{ width:11px; height:11px; color:#fff; }
.ai-why__tx{ font-size:11.5px; line-height:1.4; color:var(--accent-ink); }
.ai-why__tx b{ font-weight:700; }
.ai-why__tx .lbl{ display:block; font-size:9.5px; font-weight:800; letter-spacing:.08em; text-transform:uppercase;
  color:color-mix(in srgb,var(--accent-ink) 65%,transparent); margin-bottom:2px; }

/* =====================================================================
   5 · REFINEMENT CHIPS — quick follow-ups, never retype
   ===================================================================== */
.ai-refine{ display:flex; flex-wrap:wrap; gap:8px; margin-top:14px; }
.ai-refine__lbl{ width:100%; font-size:10.5px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); margin-bottom:1px; }
.ai-rchip{ display:inline-flex; align-items:center; gap:6px; cursor:pointer; background:#fff; border:1px solid var(--line);
  color:var(--ink); font-family:var(--font-body); font-size:12.5px; font-weight:600; padding:8px 13px; border-radius:var(--r-pill);
  transition:.15s; -webkit-tap-highlight-color:transparent; }
.ai-rchip svg{ width:13px; height:13px; color:var(--brand); }
.ai-rchip:hover{ border-color:var(--brand); background:var(--brand-soft); color:var(--brand-ink); }
.ai-rchip:active{ transform:scale(.96); }

/* =====================================================================
   STICKY DOCK COMPOSER — appears once a conversation starts
   ===================================================================== */
.ai-dock{ flex:none; display:none; align-items:flex-end; gap:9px; padding:10px 12px;
  background:color-mix(in srgb,#fff 86%,var(--app-bg)); border-top:1px solid var(--line);
  -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px); position:relative; z-index:15; }
.ai-app.is-chatting .ai-dock{ display:flex; }
.ai-dock__field{ flex:1; display:flex; align-items:center; gap:8px; min-width:0; background:#fff;
  border:1.5px solid var(--line); border-radius:var(--r-pill); padding:6px 6px 6px 15px; transition:border-color .15s; }
.ai-dock__field:focus-within{ border-color:var(--brand); }
.ai-dock__field input{ flex:1; min-width:0; border:0; outline:0; background:transparent; font-family:var(--font-body);
  font-size:14px; color:var(--ink); height:32px; }
.ai-dock__field input::placeholder{ color:var(--ink-3); }
.ai-dock .ai-mic{ width:36px; height:36px; border:0; background:transparent; }
.ai-dock .ai-mic svg{ width:21px; height:21px; }
.ai-dock .ai-send{ width:40px; height:40px; }
.ai-dock .ai-send svg{ width:19px; height:19px; }

/* a calm reassurance strip under the dock (first turn only feel) */
.ai-dock__safe{ position:absolute; top:-23px; left:0; right:0; display:flex; justify-content:center; pointer-events:none; }
.ai-dock__safe span{ font-size:10.5px; font-weight:600; color:var(--trust); background:var(--trust-soft);
  padding:3px 11px; border-radius:var(--r-pill); display:inline-flex; align-items:center; gap:5px; box-shadow:var(--shadow-sm); }
.ai-dock__safe svg{ width:11px; height:11px; }

/* entrance */
@media (prefers-reduced-motion: no-preference){
  .ai-rise{ animation:ai-rise .42s cubic-bezier(.22,1,.36,1) both; }
  @keyframes ai-rise{ from{ opacity:0; transform:translateY(10px); } to{ opacity:1; transform:none; } }
}

/* =====================================================================
   TWEAK STATES (data-* on <body>)
   ===================================================================== */
body[data-voice="plain"] .ai-say{ font-family:var(--font-body); font-size:14px; line-height:1.5; }
body[data-voice="plain"] .ai-desk .ai-say{ font-size:15.5px; }
body[data-voice="plain"] .ai-say b{ font-style:normal; color:var(--ink); }
body[data-thinking="minimal"] .ai-think__re{ display:none; }
body[data-halo="off"] .ai-hero__seal::after{ display:none; }
body[data-halo="off"] .ai-think__seal::after{ border-color:color-mix(in srgb,var(--brand) 45%,transparent); border-top-color:var(--brand); }

/* =====================================================================
   DESKTOP COUNTERPART
   ===================================================================== */
.ai-desk{ display:flex; flex-direction:column; height:720px; background:var(--app-bg); }
.ai-desk .ai-scroll{ display:flex; justify-content:center; }
.ai-desk__col{ width:100%; max-width:720px; }

/* desktop hero is roomier */
.ai-desk .ai-hero{ padding:54px 40px 40px; }
.ai-desk .ai-hero__seal{ width:88px; height:88px; }
.ai-desk .ai-hero__title{ font-size:38px; max-width:18ch; }
.ai-desk .ai-hero__promise{ font-size:16px; max-width:46ch; }
.ai-desk .ai-bigcomposer{ max-width:560px; border-radius:26px; padding:16px 16px 13px; }
.ai-desk .ai-bigcomposer textarea{ font-size:16.5px; }
.ai-desk .ai-examples{ max-width:560px; }
.ai-desk .ai-exgrid{ flex-direction:row; flex-wrap:wrap; }
.ai-desk .ai-ex{ flex:1 1 calc(50% - 5px); min-width:230px; }

/* desktop thread + 3-up grid */
.ai-desk .ai-thread{ padding:26px 40px 30px; gap:24px; }
.ai-desk .ai-say{ font-size:19px; }
.ai-desk .ai-subsay{ font-size:13.5px; }
.ai-desk .ai-picks{ margin:0; padding:2px 0 4px; display:grid; grid-template-columns:repeat(3,1fr); gap:14px; overflow:visible; }
.ai-desk .ai-pick{ width:auto; }
.ai-desk .ai-user{ max-width:70%; font-size:15px; }
.ai-desk .ai-dock{ padding:14px 40px; justify-content:center; }
.ai-desk .ai-dock__inner{ width:100%; max-width:720px; display:flex; align-items:center; gap:10px; }
.ai-desk .ai-dock__field input{ height:38px; font-size:15px; }

/* desktop window chrome */
.aidesk-os{ display:flex; align-items:center; gap:8px; padding:11px 16px; background:var(--navy-deep); }
.aidesk-os .d{ width:11px; height:11px; border-radius:50%; background:rgba(255,255,255,.22); }
.aidesk-os .url{ margin-left:14px; font-size:12px; color:#aeb6cb; background:rgba(255,255,255,.07); padding:5px 14px; border-radius:var(--r-pill); }
.aidesk-os .url b{ color:#fff; font-weight:600; }
.aidesk-top{ display:flex; align-items:center; gap:16px; padding:11px 22px; background:var(--navy); }
.aidesk-top img{ height:30px; }
.aidesk-top .ai-bar__id{ flex:0 0 auto; }
.aidesk-top .grow{ flex:1; }
.aidesk-top .ai-cart{ color:#fff; }
.deskframe{ border-radius:16px; overflow:hidden; box-shadow:0 30px 80px -30px rgba(20,29,51,.5); border:1px solid var(--line); background:#fff; }

/* ============================================================
   MasnoonHub Express additions to the ported AI Mode styles:
   the certified pill on picks, the site-wide slide-in drawer,
   the full /ai-mode/ page wrapper, and responsive rules.
   ============================================================ */

/* structural: the mount fills its frame (was board chrome in the mockup) */
[data-aimode]{ flex:1; min-height:0; display:block; }
.mh-redrawer__panel .ai-app,
.mh-aimode-page .ai-app{ height:100%; }

/* Certification is vendor-level, so AI pick cards lead with the verified-vendor
   line (.mhub-vendor), not a per-product cert pill. */
/* the picks row carries .mh-catalog so the live .mhub-card styles apply; keep the
   carousel/grid layout from .ai-picks and drop the catalog container max-width. */
.ai-picks.mh-catalog{ max-width:none; overflow-x:auto; }

/* ---- site-wide slide-in drawer ---- */
.mh-redrawer{ position:fixed; inset:0; z-index:99990; display:none; }
.mh-redrawer.is-open{ display:block; }
.mh-redrawer__scrim{ position:absolute; inset:0; background:rgba(14,21,37,.5);
  opacity:0; transition:opacity .28s ease; -webkit-backdrop-filter:blur(2px); backdrop-filter:blur(2px); }
.mh-redrawer.is-open .mh-redrawer__scrim{ opacity:1; }
.mh-redrawer__panel{ position:absolute; top:0; right:0; height:100%; height:100dvh;
  width:min(420px,100vw); background:var(--app-bg);
  box-shadow:-24px 0 70px -34px rgba(20,29,51,.7);
  transform:translateX(100%); transition:transform .34s cubic-bezier(.22,1,.36,1);
  display:flex; flex-direction:column; will-change:transform; }
.mh-redrawer.is-open .mh-redrawer__panel{ transform:none; }
.mh-redrawer__panel [data-aimode]{ flex:1; min-height:0; }
.mh-redrawer .ai-bar .ai-back{ font-size:0; }
.mh-redrawer .ai-bar .ai-back svg{ width:20px; height:20px; }
body.mh-redrawer-lock{ overflow:hidden; }

/* ---- full /ai-mode/ page ---- */
.mh-aimode-page{ background:var(--paper); padding:clamp(18px,4vw,46px) clamp(14px,4vw,40px) clamp(40px,7vw,80px); }
.mh-aimode-wrap{ max-width:1040px; margin:0 auto; }
.mh-aimode-intro{ text-align:center; margin:0 auto clamp(20px,3vw,30px); max-width:62ch; }
.mh-aimode-intro .kick{ font-size:11px; font-weight:800; letter-spacing:.16em; text-transform:uppercase; color:var(--brand); display:inline-flex; gap:8px; align-items:center; justify-content:center; }
.mh-aimode-intro h1{ font-family:var(--font-display); font-weight:700; font-size:clamp(26px,4.4vw,40px); letter-spacing:-.01em; margin:12px 0 8px; line-height:1.08; }
.mh-aimode-intro h1 em{ font-style:italic; color:var(--brand); font-weight:600; }
.mh-aimode-intro p{ color:var(--ink-2); font-size:16px; margin:0; }
.mh-aimode-page .ai-desk{ height:auto; min-height:min(76vh,820px); }

/* ---- responsive: under 760px the page falls back toward single column ---- */
@media (max-width:760px){
  .mh-aimode-page .aidesk-os{ display:none; }
  .mh-aimode-page .ai-desk{ min-height:78vh; }
  .ai-desk .ai-hero{ padding:32px 20px 26px; }
  .ai-desk .ai-hero__title{ font-size:26px; max-width:16ch; }
  .ai-desk .ai-bigcomposer{ max-width:100%; }
  .ai-desk .ai-examples{ max-width:100%; }
  .ai-desk .ai-exgrid{ flex-direction:column; }
  .ai-desk .ai-thread{ padding:20px 16px 26px; }
  .ai-desk .ai-picks{ grid-template-columns:1fr 1fr; }
  .ai-desk .ai-dock{ padding:12px 16px; }
}
@media (max-width:430px){
  .ai-desk .ai-picks{ grid-template-columns:1fr; }
  .mh-redrawer__panel{ width:100vw; }
}

/* ---- self-contained product-card styles for AI picks (ported from
   woo-catalog.css so the drawer renders correctly on the homepage, which strips
   the storefront CSS). Scoped to .ai-pick so they never touch the catalog. ---- */
.ai-pick .mhub-card{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r-card); overflow:hidden; display:flex; flex-direction:column; transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease; }
.ai-pick .mhub-card:hover{ box-shadow:0 12px 30px -18px rgba(20,29,51,.26); border-color:var(--line-2); transform:translateY(-3px); }
.ai-pick .mhub-card__media{ position:relative; display:block; aspect-ratio:1/1; background:#fff; border-bottom:1px solid var(--line); }
.ai-pick .mhub-card__media img{ position:absolute; inset:0; width:100%; height:100%; object-fit:contain; }
.ai-pick .mhub-ph{ position:absolute; inset:0; background:repeating-linear-gradient(135deg, var(--accent-soft) 0 11px, transparent 11px 22px), var(--surface-2); display:grid; place-items:center; }
.ai-pick .mhub-ph span{ font-size:11px; letter-spacing:.06em; text-transform:uppercase; color:var(--accent-ink); background:rgba(255,255,255,.7); padding:4px 8px; border-radius:var(--r-pill); font-weight:600; }
.ai-pick .mhub-badge{ position:absolute; top:10px; left:10px; z-index:2; background:var(--red); color:#fff; font-weight:700; font-size:var(--fs-sm); padding:4px 9px; border-radius:var(--r-sm); box-shadow:var(--shadow-sm); font-variant-numeric:tabular-nums; }
.ai-pick .mhub-chip{ position:absolute; bottom:9px; left:9px; z-index:2; background:rgba(255,255,255,.86); color:var(--ink-2); font-weight:600; font-size:var(--fs-xs); padding:3px 9px; border-radius:var(--r-pill); display:inline-flex; align-items:center; gap:5px; box-shadow:0 1px 4px rgba(20,29,51,.10); backdrop-filter:saturate(1.3) blur(3px); }
.ai-pick .mhub-chip::before{ content:""; width:5px; height:5px; border-radius:50%; background:var(--accent); }
.ai-pick .mhub-wish{ position:absolute; top:8px; right:8px; z-index:3; width:30px; height:30px; min-width:0; padding:0; box-sizing:border-box; border-radius:50%; border:0; aspect-ratio:1; background:rgba(255,255,255,.78); cursor:pointer; display:grid; place-items:center; box-shadow:0 1px 4px rgba(20,29,51,.12); backdrop-filter:saturate(1.3) blur(3px); transition:background .15s ease; }
.ai-pick .mhub-wish:hover{ background:#fff; }
.ai-pick .mhub-wish svg{ width:17px; height:17px; transition:transform .15s ease; }
.ai-pick .mhub-wish svg path{ fill:none; stroke:var(--ink-2); stroke-width:1.8; transition:fill .15s ease, stroke .15s ease; }
.ai-pick .mhub-wish:active svg{ transform:scale(.86); }
.ai-pick .mhub-wish[aria-pressed="true"] svg path{ fill:var(--accent); stroke:var(--accent); }
.ai-pick .mhub-card__body{ padding:13px 14px 15px; display:flex; flex-direction:column; gap:7px; flex:1; }
.ai-pick .mhub-vendor{ display:inline-flex; align-items:center; gap:5px; align-self:flex-start; color:var(--ink-2); font-size:var(--fs-sm); font-weight:500; text-decoration:none; max-width:100%; }
.ai-pick .mhub-vendor span{ overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.ai-pick .mhub-vendor:hover span{ color:var(--brand); }
.ai-pick .mhub-verify{ flex:none; width:14px; height:14px; }
.ai-pick .mhub-title{ margin:0; font-size:var(--fs-md); line-height:1.34; font-weight:500; letter-spacing:-.003em; }
.ai-pick .mhub-title a{ color:var(--ink); text-decoration:none; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.ai-pick .mhub-title a:hover{ color:var(--brand); }
.ai-pick .mhub-title:lang(bn){ font-family:var(--font-body); }
.ai-pick .mhub-meta{ display:flex; align-items:center; gap:5px; flex-wrap:nowrap; font-size:11.5px; color:var(--ink-3); margin-top:1px; }
.ai-pick .mhub-stars{ --rating:5; flex:none; font-size:11px; line-height:1; letter-spacing:.5px; white-space:nowrap; background:linear-gradient(90deg, var(--star) calc(var(--rating) / 5 * 100%), #d8d3c9 calc(var(--rating) / 5 * 100%)); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent; }
.ai-pick .mhub-rate{ font-weight:700; color:var(--ink-2); flex:none; }
.ai-pick .mhub-sold{ position:relative; padding-left:9px; white-space:nowrap; flex:none; }
.ai-pick .mhub-sold::before{ content:""; position:absolute; left:1px; top:50%; transform:translateY(-50%); width:3px; height:3px; border-radius:50%; background:var(--ink-3); }
.ai-pick .mhub-price{ display:flex; align-items:baseline; gap:7px; margin-top:auto; padding-top:3px; }
.ai-pick .mhub-price__now{ font-size:var(--fs-lg); font-weight:700; color:var(--ink); font-variant-numeric:tabular-nums; letter-spacing:-.01em; }
.ai-pick .mhub-price__now .cur{ font-weight:600; font-size:.78em; margin-right:1px; }
.ai-pick .mhub-price__was{ font-size:var(--fs-sm); color:var(--ink-3); text-decoration:line-through; font-variant-numeric:tabular-nums; }
.ai-pick a.mhub-add{ margin-top:9px; height:44px; border:0; border-radius:var(--r-sm); cursor:pointer; background:var(--brand) !important; color:#fff !important; font-family:var(--font-body); font-weight:700; font-size:14px; display:flex; align-items:center; justify-content:center; gap:7px; width:100%; text-decoration:none; white-space:nowrap; transition:background .16s ease, transform .12s ease; }
.ai-pick a.mhub-add svg{ width:18px; height:18px; }
.ai-pick a.mhub-add:hover{ background:var(--navy) !important; }
.ai-pick a.mhub-add:active{ transform:scale(.985); }

/* ---- desktop /ai-mode/ window chrome (the aidesk-top New-search + cart),
   ported from the AI Mode board chrome so the page frame matches the design ---- */
.aidesk-top .ai-bar__name b{ color:#fff; }
.aidesk-top .dnew{ color:#aeb6cb; font-size:13px; font-weight:600; text-decoration:none; display:inline-flex; align-items:center; gap:6px; padding:7px 12px; border-radius:var(--r-pill); border:1px solid rgba(255,255,255,.16); cursor:pointer; background:transparent; font-family:var(--font-body); }
.aidesk-top .dnew:hover{ color:#fff; border-color:rgba(255,255,255,.4); }
.aidesk-top .dnew svg{ width:14px; height:14px; }
.aidesk-top .ai-cart{ position:relative; border:0; background:transparent; color:#fff; cursor:pointer; width:36px; height:36px; display:grid; place-items:center; padding:0; }
.aidesk-top .ai-cart svg{ width:22px; height:22px; }
.aidesk-top .ai-cart .n{ position:absolute; top:-2px; right:-3px; background:var(--brand); color:#fff; font-size:10px; font-weight:800; min-width:17px; height:17px; border-radius:9px; display:grid; place-items:center; padding:0 4px; border:1.5px solid var(--navy); font-variant-numeric:tabular-nums; }

/* =====================================================================
   DEEP SEARCH — the AI narration panel above product search results
   (archive-product.php, is_search). Reuses the gold seal/ring; resolves
   into a real grounded one-line summary + a path into the AI chat.
   ===================================================================== */
.mh-deepsearch{ background:linear-gradient(135deg,var(--trust-soft),#fff); border:1px solid color-mix(in srgb,var(--trust) 22%,var(--line)); border-radius:var(--r-lg); padding:15px 18px; margin:16px 24px 6px; box-shadow:0 12px 32px -24px rgba(20,29,51,.45); }
.mh-ds__top{ display:flex; align-items:center; gap:11px; margin-bottom:12px; }
.mh-ds__seal{ width:34px; height:34px; flex:none; position:relative; }
.mh-ds__seal::after{ content:""; position:absolute; inset:-5px; border-radius:50%; border:2px solid color-mix(in srgb,var(--star) 55%,transparent); border-top-color:var(--star); }
.mh-deepsearch:not(.mh-ds--answered):not(.mh-ds--done) .mh-ds__seal::after{ animation:ai-ring 1.5s linear infinite; }
.mh-deepsearch.mh-ds--answered .mh-ds__seal::after{ border-color:color-mix(in srgb,var(--trust) 45%,transparent); border-top-color:var(--trust); }
.mh-ds__id b{ font-family:var(--font-display); font-weight:600; font-size:15px; display:flex; align-items:center; gap:6px; color:var(--ink); line-height:1.1; }
.mh-ds__id b svg{ width:15px; height:15px; color:var(--star); }
.mh-ds__id span{ display:block; font-size:11.5px; color:var(--ink-2); margin-top:2px; }
.mh-ds__steps{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:9px; }
.mh-ds__step{ display:flex; align-items:center; gap:10px; font-size:13px; color:var(--ink-3); opacity:.45; transition:opacity .3s ease, color .3s ease; }
.mh-ds__step .ck{ width:19px; height:19px; border-radius:50%; border:2px solid var(--line-2); display:grid; place-items:center; flex:none; transition:.25s ease; }
.mh-ds__step .ck svg{ width:11px; height:11px; opacity:0; transition:opacity .2s ease; }
.mh-ds__step .q{ font-style:italic; color:var(--trust); font-weight:600; }
.mh-ds__step.done{ opacity:1; color:var(--ink); }
.mh-ds__step.done .ck{ background:var(--trust); border-color:var(--trust); }
.mh-ds__step.done .ck svg{ opacity:1; }
.mh-ds__answer{ margin-top:13px; padding-top:13px; border-top:1px solid color-mix(in srgb,var(--trust) 16%,var(--line)); }
.mh-ds__say{ font-family:var(--font-display); font-size:15.5px; line-height:1.45; color:var(--ink); margin:0 0 11px; }
.mh-ds__say:lang(bn){ font-family:var(--font-body); font-size:14.5px; }
.mh-ds__say b{ color:var(--brand-ink); font-weight:600; }
.mh-ds__cta{ display:inline-flex; align-items:center; gap:7px; cursor:pointer; 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:9px 16px; border-radius:var(--r-pill); box-shadow:0 6px 16px -6px rgba(224,83,15,.5); transition:transform .12s ease, box-shadow .15s ease; }
.mh-ds__cta:hover{ box-shadow:0 9px 22px -8px rgba(224,83,15,.6); }
.mh-ds__cta:active{ transform:scale(.97); }
.mh-ds__cta svg{ width:14px; height:14px; }
@media (max-width:960px){ .mh-deepsearch{ margin:14px 14px 6px; } }

/* the "✦ AI" sparkle cue added to product search bars by the smart-placeholder module */
.mh-ai-spark{ color:var(--star); flex:none; display:inline-grid; place-items:center; }
.mh-ai-spark svg{ width:15px; height:15px; }
