/* ============================================================
   KisanDukaan — Landing Design System (v3, farmer-first)
   ============================================================ */

/* -------------------- Tokens -------------------- */
:root {
    /* Primary green — deep, rich, emerald — the "from-the-earth" green */
    --kd-g-50:  #e9f7ed;
    --kd-g-100: #c7ecd0;
    --kd-g-200: #9bdaab;
    --kd-g-300: #67c282;
    --kd-g-400: #2fa75b;
    --kd-g-500: #138a3e;
    --kd-g-600: #0c6e30;
    --kd-g-700: #075722;
    --kd-g-800: #04401a;
    --kd-g-900: #032b11;

    /* Saffron / tricolor warm — for accent, CTAs */
    --kd-s-50:  #fff4e6;
    --kd-s-100: #ffe1bd;
    --kd-s-300: #ffae5c;
    --kd-s-500: #ff7a1a;
    --kd-s-600: #e35e09;
    --kd-s-700: #b14705;

    /* Terracotta — secondary warm */
    --kd-t-500: #c44536;
    --kd-t-50:  #fbeae8;

    /* Cream / earth */
    --kd-cream-50:  #fbf6e9;
    --kd-cream-100: #f5ecd2;
    --kd-cream-200: #e8d9aa;

    /* Ink — high-contrast neutrals */
    --kd-ink-900: #0a1410;
    --kd-ink-800: #18241e;
    --kd-ink-700: #2c3b33;
    --kd-ink-600: #455349;
    --kd-ink-500: #5e6c63;
    --kd-ink-400: #80908a;
    --kd-ink-300: #aab5af;
    --kd-ink-200: #d2dad6;
    --kd-ink-100: #e6ece8;
    --kd-ink-50:  #f3f6f4;

    --kd-bg:       #ffffff;
    --kd-bg-soft:  #faf9f4;
    --kd-surface:  #ffffff;

    /* Type */
    --kd-font-sans:  'Plus Jakarta Sans', 'Inter', system-ui, -apple-system, sans-serif;
    --kd-font-serif: 'Fraunces', Georgia, serif;

    --kd-fs-xs:   12px;
    --kd-fs-sm:   13px;
    --kd-fs-base: 15px;
    --kd-fs-md:   17px;
    --kd-fs-lg:   19px;
    --kd-fs-xl:   24px;
    --kd-fs-2xl:  32px;
    --kd-fs-3xl:  44px;
    --kd-fs-4xl:  56px;
    --kd-fs-5xl:  72px;

    --kd-s-1:  4px;
    --kd-s-2:  8px;
    --kd-s-3: 12px;
    --kd-s-4: 16px;
    --kd-s-5: 20px;
    --kd-s-6: 24px;
    --kd-s-8: 32px;
    --kd-s-10: 40px;
    --kd-s-12: 48px;
    --kd-s-14: 56px;
    --kd-s-16: 72px;
    --kd-s-20: 96px;

    --kd-r-sm:  10px;
    --kd-r-md:  14px;
    --kd-r-lg:  18px;
    --kd-r-xl:  24px;
    --kd-r-2xl: 32px;
    --kd-r-pill: 999px;

    --kd-shadow-xs: 0 1px 2px rgba(10, 20, 16, 0.06);
    --kd-shadow-sm: 0 2px 6px rgba(10, 20, 16, 0.08), 0 1px 2px rgba(10, 20, 16, 0.04);
    --kd-shadow-md: 0 8px 24px rgba(10, 20, 16, 0.10), 0 2px 4px rgba(10, 20, 16, 0.05);
    --kd-shadow-lg: 0 24px 56px rgba(10, 20, 16, 0.16), 0 4px 8px rgba(10, 20, 16, 0.06);
    --kd-shadow-glow: 0 0 0 4px rgba(19, 138, 62, 0.15);

    --kd-max: 1280px;
    --kd-ease: cubic-bezier(.4, 0, .2, 1);
}

/* -------------------- Reset/page -------------------- */
body {
    background: var(--kd-bg) !important;
    color: var(--kd-ink-900) !important;
    font-family: var(--kd-font-sans) !important;
    font-size: var(--kd-fs-base) !important;
    font-weight: 500;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    line-height: 1.55;
}

/* Reset font-family for our enhancement components — override global * { font-family: 'Inter' } */
[class^="kd-"], [class*=" kd-"], [class^="kd-"] *, [class*=" kd-"] * {
    font-family: var(--kd-font-sans) !important;
}

/* -------------------- Header pills (v2 — depth, SVG icons, animations) -------------------- */
.kd-header-pills {
    display: flex; align-items: center; gap: 10px;
    flex-wrap: wrap;
    justify-content: flex-end;
    max-width: var(--kd-max); margin: 14px auto 0;
    padding: 0 var(--kd-s-5);
}

.kd-pill {
    display: inline-flex;
    align-items: center;
    gap: 9px;
    height: 42px;
    padding: 0 16px 0 6px;
    border: 0;
    border-radius: var(--kd-r-pill);
    cursor: pointer;
    font-family: var(--kd-font-sans) !important;
    font-size: 14px;
    font-weight: 800;
    letter-spacing: -0.005em;
    line-height: 1;
    position: relative;
    overflow: visible;
    transition: transform .2s var(--kd-ease), box-shadow .2s var(--kd-ease);
    white-space: nowrap;
}
.kd-pill:hover { transform: translateY(-2px); }

.kd-pill-iconbox {
    width: 30px; height: 30px;
    border-radius: 50%;
    display: grid; place-items: center;
    flex-shrink: 0;
    transition: all .25s var(--kd-ease);
}
.kd-pill-iconbox svg { width: 16px; height: 16px; display: block; }
.kd-pill-label { display: inline-block; }

/* ---- Primary: Ask KisanAI (deep emerald with glow + animated sparkle) ---- */
.kd-pill.kd-pill-primary {
    background:
        linear-gradient(180deg, rgba(255,255,255,.12), transparent 60%),
        linear-gradient(135deg, var(--kd-g-500) 0%, var(--kd-g-700) 100%);
    color: #fff;
    box-shadow: 0 6px 18px rgba(12,110,48,.36), inset 0 1px 0 rgba(255,255,255,.18);
}
.kd-pill.kd-pill-primary:hover {
    background:
        linear-gradient(180deg, rgba(255,255,255,.16), transparent 60%),
        linear-gradient(135deg, var(--kd-g-600) 0%, var(--kd-g-800) 100%);
    box-shadow: 0 12px 28px rgba(12,110,48,.45), inset 0 1px 0 rgba(255,255,255,.2);
}
.kd-pill-iconbox-ai {
    background: rgba(255,255,255,.18);
    color: #fff;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.22);
}
.kd-pill-iconbox-ai svg { animation: kd-ai-twinkle 2.4s ease-in-out infinite; }
@keyframes kd-ai-twinkle {
    0%, 100% { transform: rotate(0deg) scale(1); }
    25% { transform: rotate(-6deg) scale(1.08); }
    50% { transform: rotate(0deg) scale(1); }
    75% { transform: rotate(6deg) scale(1.08); }
}
.kd-pill-tag {
    margin-left: 2px;
    background: rgba(255,255,255,.95);
    color: var(--kd-g-700);
    font-size: 9px;
    font-weight: 800;
    padding: 3px 7px;
    border-radius: 4px;
    letter-spacing: 0.08em;
    line-height: 1;
}

/* ---- Accent: Kisan Coins (saffron with shine) ---- */
.kd-pill.kd-pill-accent {
    background:
        linear-gradient(180deg, rgba(255,255,255,.16), transparent 55%),
        linear-gradient(135deg, var(--kd-s-500) 0%, var(--kd-s-700) 100%);
    color: #fff;
    box-shadow: 0 6px 18px rgba(255,122,26,.34), inset 0 1px 0 rgba(255,255,255,.22);
}
.kd-pill.kd-pill-accent:hover {
    box-shadow: 0 12px 28px rgba(255,122,26,.42), inset 0 1px 0 rgba(255,255,255,.24);
}
.kd-pill-iconbox-coin {
    background: rgba(255,255,255,.22);
    color: #fff;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.25);
}

/* ---- Ghost: Language + Wishlist (white surface) ---- */
.kd-pill.kd-pill-ghost {
    background: var(--kd-surface);
    color: var(--kd-ink-900);
    border: 1.5px solid var(--kd-ink-100);
    box-shadow: var(--kd-shadow-xs);
    padding-right: 14px;
}
.kd-pill.kd-pill-ghost:hover {
    border-color: var(--kd-g-300);
    color: var(--kd-g-700);
    box-shadow: var(--kd-shadow-sm);
}
.kd-pill-iconbox-globe { background: var(--kd-g-50); color: var(--kd-g-700); border: 1px solid var(--kd-g-100); }
.kd-pill-iconbox-heart { background: #fdecec;        color: var(--kd-t-500); border: 1px solid #fbd6d3; }
.kd-pill.kd-pill-ghost:hover .kd-pill-iconbox-globe { background: var(--kd-g-100); }
.kd-pill.kd-pill-ghost:hover .kd-pill-iconbox-heart { background: #fbd6d3; }

.kd-pill-chev {
    width: 12px; height: 12px;
    color: var(--kd-ink-400);
    transition: transform .2s var(--kd-ease), color .2s var(--kd-ease);
    margin-left: -2px;
}
.kd-pill:hover .kd-pill-chev {
    color: var(--kd-g-700);
    transform: translateY(1px);
}

/* ---- Badge — refined for both light & dark pills ---- */
.kd-pill .kd-badge {
    min-width: 22px;
    height: 22px;
    padding: 0 7px;
    border-radius: var(--kd-r-pill);
    background: rgba(255,255,255,.22);
    color: #fff;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: -0.02em;
    display: inline-grid;
    place-items: center;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.2);
    line-height: 1;
}
.kd-pill.kd-pill-ghost .kd-badge {
    background: var(--kd-g-600);
    color: #fff;
    box-shadow: 0 2px 6px rgba(12,110,48,.3);
}
.kd-pill.kd-pill-ghost#kdWishBtn .kd-badge {
    background: var(--kd-t-500);
    box-shadow: 0 2px 6px rgba(196,69,54,.32);
}

@media (max-width: 600px) {
    .kd-pill { font-size: 13px; height: 38px; padding: 0 12px 0 4px; gap: 7px; }
    .kd-pill-iconbox { width: 28px; height: 28px; }
    .kd-pill-iconbox svg { width: 14px; height: 14px; }
    .kd-pill-tag { display: none; }
}

/* ============================================================
   Header pills — creative effects layer
   ============================================================ */

/* ---- Stagger entrance (each pill rises in 60ms after the previous) ---- */
.kd-pill {
    animation: kd-pill-enter .55s var(--kd-ease) both;
    animation-delay: calc(var(--i, 0) * 70ms);
}
@keyframes kd-pill-enter {
    from { opacity: 0; transform: translateY(8px) scale(.96); }
    to   { opacity: 1; transform: translateY(0)   scale(1);   }
}

/* ============================================================
   AI pill — animated gradient + glow halo + floating sparkle particles
   ============================================================ */

/* Slowly shifting gradient mesh on the AI button */
.kd-pill.kd-pill-primary {
    background:
        linear-gradient(180deg, rgba(255,255,255,.14), transparent 55%),
        linear-gradient(125deg,
            var(--kd-g-700) 0%,
            var(--kd-g-500) 25%,
            #2fa75b 50%,
            var(--kd-g-500) 75%,
            var(--kd-g-700) 100%) !important;
    background-size: 100% 100%, 220% 100% !important;
    animation: kd-ai-flow 8s ease-in-out infinite;
    position: relative;
    overflow: visible;
}
@keyframes kd-ai-flow {
    0%, 100% { background-position: 0 0, 0% 50%; }
    50%      { background-position: 0 0, 100% 50%; }
}

/* Soft expanding aura halo behind the AI pill (off until hover) */
.kd-pill-aura {
    position: absolute;
    inset: -6px;
    border-radius: var(--kd-r-pill);
    background: radial-gradient(closest-side, rgba(47,167,91,.55), rgba(47,167,91,0) 70%);
    opacity: 0;
    transform: scale(.9);
    transition: opacity .35s var(--kd-ease), transform .45s var(--kd-ease);
    pointer-events: none;
    z-index: -1;
    filter: blur(6px);
}
.kd-pill.kd-pill-primary:hover .kd-pill-aura {
    opacity: 1;
    transform: scale(1.05);
}

/* Floating sparkle particles around the AI pill (continuous) */
.kd-pill-particles {
    position: absolute;
    inset: -8px;
    pointer-events: none;
    z-index: 0;
}
.kd-particle {
    position: absolute;
    width: 4px; height: 4px;
    border-radius: 50%;
    background: radial-gradient(circle, #fff 0%, rgba(255,255,255,0) 70%);
    opacity: 0;
    animation: kd-particle-float 4.2s ease-in-out infinite;
}
.kd-particle.kd-p1 { top: 10%; left: 18%; animation-delay: 0s; }
.kd-particle.kd-p2 { top: 70%; left: 32%; animation-delay: 1.1s; width: 5px; height: 5px; }
.kd-particle.kd-p3 { top: 25%; left: 78%; animation-delay: 2.2s; width: 3px; height: 3px; }
.kd-particle.kd-p4 { top: 60%; left: 88%; animation-delay: 3.3s; width: 4px; height: 4px; }
@keyframes kd-particle-float {
    0%   { opacity: 0; transform: translateY(0) scale(0.4); }
    20%  { opacity: 1; transform: translateY(-6px) scale(1); }
    50%  { opacity: 0.8; transform: translateY(-12px) scale(1.2); }
    80%  { opacity: 0; transform: translateY(-18px) scale(0.6); }
    100% { opacity: 0; transform: translateY(-22px) scale(0.4); }
}

/* AI iconbox: keep the twinkle, add a subtle inner glow */
.kd-pill-iconbox-ai {
    position: relative;
    overflow: hidden;
}
.kd-pill-iconbox-ai::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: 50%;
    background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.45), transparent 60%);
    pointer-events: none;
}

/* ============================================================
   Coins pill — periodic sheen sweep + coin spin on hover
   ============================================================ */
.kd-pill.kd-pill-accent {
    position: relative;
    overflow: hidden;
}
.kd-pill-sheen {
    position: absolute;
    top: 0; left: -40%;
    width: 30%;
    height: 100%;
    background: linear-gradient(105deg, transparent 0%, rgba(255,255,255,.45) 50%, transparent 100%);
    transform: skewX(-20deg);
    pointer-events: none;
    animation: kd-sheen 5.5s ease-in-out infinite;
}
@keyframes kd-sheen {
    0%, 70%, 100% { left: -40%; opacity: 0; }
    78%           { opacity: 0.95; }
    100%          { left: 130%; opacity: 0; }
}

/* Coin icon: 3D flip on hover */
.kd-pill.kd-pill-accent:hover .kd-pill-iconbox-coin svg {
    animation: kd-coin-flip .8s var(--kd-ease);
}
@keyframes kd-coin-flip {
    0%   { transform: rotateY(0deg); }
    100% { transform: rotateY(360deg); }
}
.kd-pill-iconbox-coin { perspective: 200px; }

/* Badge pulse when value changes (set via JS class .is-bumped) — optional hook */
.kd-pill .kd-badge {
    transition: transform .25s var(--kd-ease);
}
.kd-pill .kd-badge.is-bumped {
    animation: kd-badge-bump .45s var(--kd-ease);
}
@keyframes kd-badge-bump {
    0%, 100% { transform: scale(1); }
    50%      { transform: scale(1.25); }
}

/* ============================================================
   Language pill — globe rotation on hover
   ============================================================ */
.kd-pill-iconbox-globe svg {
    transition: transform .8s var(--kd-ease);
}
.kd-pill#kdLangBtn:hover .kd-pill-iconbox-globe svg {
    transform: rotate(360deg);
}

/* Active state: when language has switched, pulse briefly — set via JS .is-switched */
.kd-pill#kdLangBtn.is-switched .kd-pill-iconbox-globe {
    animation: kd-globe-flash .6s var(--kd-ease);
}
@keyframes kd-globe-flash {
    0%   { background: var(--kd-g-50); }
    50%  { background: var(--kd-s-50); }
    100% { background: var(--kd-g-50); }
}

/* ============================================================
   Wishlist pill — heart beat (when count > 0) + click burst
   ============================================================ */
.kd-pill#kdWishBtn .kd-pill-iconbox-heart svg {
    animation: kd-heart-beat 1.8s ease-in-out infinite;
}
@keyframes kd-heart-beat {
    0%, 60%, 100% { transform: scale(1); }
    8%            { transform: scale(1.2); }
    16%           { transform: scale(0.95); }
    24%           { transform: scale(1.15); }
    32%           { transform: scale(1); }
}

/* Filled heart on hover */
.kd-pill#kdWishBtn:hover .kd-pill-iconbox-heart svg path {
    fill: var(--kd-t-500);
    transition: fill .25s var(--kd-ease);
}

/* Heart burst — appears on click, hearts float up & fade */
.kd-pill#kdWishBtn { position: relative; overflow: visible; }
.kd-heart-burst {
    position: absolute;
    top: 0; left: 50%;
    transform: translateX(-50%);
    color: var(--kd-t-500);
    font-size: 14px;
    pointer-events: none;
    animation: kd-burst-rise .9s ease-out forwards;
    letter-spacing: 6px;
    text-shadow: 0 2px 6px rgba(196,69,54,.4);
    white-space: nowrap;
    z-index: 10;
}
@keyframes kd-burst-rise {
    0%   { opacity: 0; transform: translateX(-50%) translateY(0)    scale(.4); }
    20%  { opacity: 1; transform: translateX(-50%) translateY(-6px) scale(1);   }
    100% { opacity: 0; transform: translateX(-50%) translateY(-44px) scale(1.2); }
}

/* ============================================================
   Universal hover micro-magnet — icon nudges in label direction
   ============================================================ */
.kd-pill:hover .kd-pill-iconbox {
    transform: scale(1.06);
}
.kd-pill .kd-pill-iconbox { transition: transform .25s var(--kd-ease); }

/* Reduced motion respect */
@media (prefers-reduced-motion: reduce) {
    .kd-pill,
    .kd-particle,
    .kd-pill-sheen,
    .kd-pill-iconbox-globe svg,
    .kd-pill#kdWishBtn .kd-pill-iconbox-heart svg,
    .kd-pill.kd-pill-primary { animation: none !important; }
}

/* ============================================================
   CARD #11 — The Movement (founder's mission)
   Aligned with approved design system: white card surface,
   1px ink-200 border, 24px radius, centered header pattern.
   ============================================================ */
.kd-mvm {
    max-width: var(--kd-max);
    margin: var(--kd-s-10) auto !important;
    padding: 0 var(--kd-s-5);
}
.kd-mvm-card {
    position: relative;
    overflow: hidden;
    background: var(--kd-surface);
    border: 1px solid var(--kd-ink-200);
    border-radius: var(--kd-r-xl);
    padding: 28px 26px 22px;
    box-shadow: var(--kd-shadow-xs);
}
.kd-mvm-glow { display: none; }   /* removed — light theme doesn't need them */

/* Header — same pattern as the other cards (icon-top + centered title) */
.kd-mvm-head {
    text-align: center;
    max-width: 820px;
    margin: 0 auto 22px;
    padding-bottom: 22px;
    border-bottom: 1px solid var(--kd-ink-100);
}
.kd-mvm-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    background: var(--kd-g-50);
    color: var(--kd-g-800);
    border: 1.5px solid var(--kd-g-100);
    font-size: 11px;
    font-weight: 800;
    padding: 6px 13px;
    border-radius: var(--kd-r-pill);
    letter-spacing: 0.08em;
    text-transform: uppercase;
    margin-bottom: 12px;
    line-height: 1;
}
.kd-mvm-eyebrow .kd-dot {
    width: 6px; height: 6px; border-radius: 50%;
    background: var(--kd-g-500);
    box-shadow: 0 0 0 3px rgba(19,138,62,.18);
    animation: kd-blink 1.6s ease-in-out infinite;
}
.kd-mvm-title {
    font-family: var(--kd-font-sans);
    font-size: clamp(22px, 2.8vw, 32px);
    font-weight: 800;
    line-height: 1.12;
    letter-spacing: -0.025em;
    color: var(--kd-ink-900);
    margin: 0 0 10px;
}
.kd-mvm-title em {
    font-family: var(--kd-font-serif);
    font-style: italic;
    font-weight: 600;
    color: var(--kd-g-700);
}
.kd-mvm-sub {
    font-size: 14px;
    color: var(--kd-ink-600);
    line-height: 1.6;
    margin: 0;
    font-weight: 500;
}
.kd-mvm-sub strong { color: var(--kd-ink-900); font-weight: 700; }
.kd-mvm-sub em {
    font-family: var(--kd-font-serif);
    font-style: italic;
    font-weight: 500;
    color: var(--kd-g-700);
}

/* 3-tile grid — light tiles, aligned with category/slot tile look */
.kd-mvm-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
    margin-bottom: 22px;
}
@media (max-width: 1100px) { .kd-mvm-grid { grid-template-columns: 1fr; } }

.kd-mvm-tile {
    position: relative;
    background: var(--kd-surface);
    border: 1.5px solid var(--kd-ink-100);
    border-radius: var(--kd-r-lg);
    padding: 20px 18px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    transition: all .22s var(--kd-ease);
}
.kd-mvm-tile:hover {
    border-color: var(--kd-g-300);
    transform: translateY(-3px);
    box-shadow: var(--kd-shadow-md);
}
.kd-mvm-tile.t-promoter {
    background: linear-gradient(180deg, var(--kd-s-50) 0%, #fff 60%);
    border-color: #ffd9b3;
}
.kd-mvm-tile.t-promoter:hover { border-color: var(--kd-s-500); }

.kd-mvm-tile-tag {
    position: absolute;
    top: -10px; right: 14px;
    background: linear-gradient(135deg, var(--kd-s-500), var(--kd-s-700));
    color: #fff;
    font-size: 10px;
    font-weight: 800;
    padding: 4px 10px;
    border-radius: var(--kd-r-pill);
    letter-spacing: 0.06em;
    text-transform: uppercase;
    box-shadow: 0 4px 10px rgba(255,122,26,.28);
}

.kd-mvm-icon {
    width: 44px; height: 44px;
    border-radius: var(--kd-r-md);
    display: grid;
    place-items: center;
    margin-bottom: 2px;
    flex-shrink: 0;
}
.kd-mvm-tile.t-grower   .kd-mvm-icon { background: var(--kd-g-50);  color: var(--kd-g-700); border: 1px solid var(--kd-g-100); }
.kd-mvm-tile.t-promoter .kd-mvm-icon { background: var(--kd-s-50);  color: var(--kd-s-700); border: 1px solid #ffd9b3; }
.kd-mvm-tile.t-buyer    .kd-mvm-icon { background: #eef0fb;         color: #36418f;        border: 1px solid #d8defb; }

.kd-mvm-tile-eye {
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    line-height: 1;
}
.kd-mvm-tile.t-grower   .kd-mvm-tile-eye { color: var(--kd-g-700); }
.kd-mvm-tile.t-promoter .kd-mvm-tile-eye { color: var(--kd-s-700); }
.kd-mvm-tile.t-buyer    .kd-mvm-tile-eye { color: #36418f; }

.kd-mvm-tile-title {
    font-family: var(--kd-font-sans);
    font-size: 18px;
    font-weight: 800;
    color: var(--kd-ink-900);
    line-height: 1.2;
    letter-spacing: -0.02em;
    margin: 0;
}
.kd-mvm-tile-title em {
    font-family: var(--kd-font-serif);
    font-style: italic;
    font-weight: 600;
}
.kd-mvm-tile.t-grower   .kd-mvm-tile-title em { color: var(--kd-g-700); }
.kd-mvm-tile.t-promoter .kd-mvm-tile-title em { color: var(--kd-s-700); }
.kd-mvm-tile.t-buyer    .kd-mvm-tile-title em { color: #36418f; }

.kd-mvm-tile-sub {
    font-size: 13px;
    color: var(--kd-ink-600);
    line-height: 1.55;
    margin: 0;
    font-weight: 500;
}
.kd-mvm-tile-sub strong { color: var(--kd-ink-900); font-weight: 700; }

.kd-mvm-points {
    list-style: none;
    padding: 0;
    margin: 4px 0 0;
    display: grid;
    gap: 6px;
}
.kd-mvm-points li {
    font-size: 12.5px;
    color: var(--kd-ink-700);
    display: flex;
    align-items: flex-start;
    gap: 8px;
    line-height: 1.5;
}
.kd-mvm-points li::before {
    content: "✓";
    font-weight: 800;
    font-size: 10px;
    width: 16px; height: 16px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    flex-shrink: 0;
    margin-top: 2px;
}
.kd-mvm-tile.t-grower   .kd-mvm-points li::before { color: #fff; background: var(--kd-g-600); }
.kd-mvm-tile.t-promoter .kd-mvm-points li::before { color: #fff; background: var(--kd-s-600); }
.kd-mvm-tile.t-buyer    .kd-mvm-points li::before { color: #fff; background: #36418f; }

.kd-mvm-cta {
    margin-top: auto;
    align-self: flex-start;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: var(--kd-g-600);
    color: #fff;
    border: 0;
    padding: 10px 18px;
    border-radius: var(--kd-r-md);
    font-family: var(--kd-font-sans);
    font-size: 13px;
    font-weight: 800;
    cursor: pointer;
    transition: all .2s var(--kd-ease);
    letter-spacing: -0.005em;
    box-shadow: 0 4px 12px rgba(12,110,48,.22);
}
.kd-mvm-cta:hover {
    background: var(--kd-g-700);
    transform: translateY(-2px);
    box-shadow: 0 8px 18px rgba(12,110,48,.32);
}
.kd-mvm-cta svg { transition: transform .2s var(--kd-ease); }
.kd-mvm-cta:hover svg { transform: translateX(2px); }

/* Per-role CTA tints */
.kd-mvm-tile.t-promoter .kd-mvm-cta {
    background: linear-gradient(135deg, var(--kd-s-500), var(--kd-s-700));
    box-shadow: 0 4px 12px rgba(255,122,26,.32);
}
.kd-mvm-tile.t-promoter .kd-mvm-cta:hover { box-shadow: 0 8px 18px rgba(255,122,26,.42); }
.kd-mvm-tile.t-buyer .kd-mvm-cta {
    background: #36418f;
    box-shadow: 0 4px 12px rgba(54,65,143,.28);
}
.kd-mvm-tile.t-buyer .kd-mvm-cta:hover { background: #2a3370; box-shadow: 0 8px 18px rgba(54,65,143,.38); }

/* Impact footer strip — light, with subtle dividers */
.kd-mvm-foot {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 14px;
    padding: 18px 0 14px;
    border-top: 1px solid var(--kd-ink-100);
}
@media (max-width: 800px) { .kd-mvm-foot { grid-template-columns: repeat(2, 1fr); } }

.kd-mvm-foot-stat { display: flex; flex-direction: column; gap: 3px; text-align: center; }
.kd-mvm-foot-stat .num {
    font-size: clamp(18px, 2vw, 22px);
    font-weight: 800;
    color: var(--kd-ink-900);
    letter-spacing: -0.02em;
    line-height: 1;
}
.kd-mvm-foot-stat .num span { color: var(--kd-g-600); font-size: 0.65em; margin-left: 2px; }
.kd-mvm-foot-stat .lbl {
    font-size: 10px;
    color: var(--kd-ink-500);
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    margin-top: 3px;
}

.kd-mvm-tagline {
    text-align: center;
    margin-top: 4px;
    padding-top: 12px;
    font-size: 13px;
    color: var(--kd-ink-600);
    font-weight: 500;
}
.kd-mvm-tagline em {
    font-family: var(--kd-font-serif);
    font-style: italic;
    font-weight: 600;
    color: var(--kd-g-700);
}

/* ============================================================
   FOOTER — lean, surgical enhancement
   Original footer markup left UNTOUCHED.
   Overrides only the two broken legacy rules that caused overlap:
     style.css L5525: column-gap: 185px !important   (way too wide)
     style.css L5529: .fw-link ul li a { width: 300px } (forces overflow)
   ============================================================ */
/* 1) Widen the footer container so it uses the full viewport (with padding) */
footer .footer-area > .container,
footer .copyright-wrap > .container {
    max-width: min(1600px, calc(100vw - 48px)) !important;
}

/* 2) Restructure the footer row: fixed-width logo + useful-links columns,
      categories takes ALL the remaining space */
footer .footer-area .row {
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: 32px !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    --bs-gutter-x: 0 !important;
}
footer .footer-area .row > [class*="col-"] {
    padding-left: 0 !important;
    padding-right: 0 !important;
}
footer .footer-area .col-xl-3 {
    flex: 0 0 260px !important;
    max-width: 260px !important;
    width: 260px !important;
}
footer .footer-area .col-xl-2 {
    flex: 0 0 180px !important;
    max-width: 180px !important;
    width: 180px !important;
}
footer .footer-area .col-xl-7 {
    flex: 1 1 auto !important;
    max-width: none !important;
    width: auto !important;
    min-width: 0 !important;
}
@media (max-width: 991.98px) {
    footer .footer-area .row { flex-wrap: wrap !important; gap: 24px !important; }
    footer .footer-area .col-xl-3,
    footer .footer-area .col-xl-2,
    footer .footer-area .col-xl-7 {
        flex: 1 1 100% !important;
        max-width: 100% !important;
        width: 100% !important;
    }
}

/* 3) Categories spread across now that the parent is wide */
footer .fw-link ul.columns {
    column-count: 5 !important;
    column-gap: 24px !important;
    column-fill: balance !important;
}
footer .fw-link ul.columns li {
    break-inside: avoid;
    page-break-inside: avoid;
    line-height: 1.45 !important;
}
footer .fw-link ul.columns li + li {
    margin-top: 6px !important;
}
footer .fw-link ul li a {
    width: auto !important;
    max-width: 100% !important;
    white-space: normal !important;
    overflow-wrap: break-word !important;
    word-break: normal !important;
    display: inline-block !important;
    font-size: 13px !important;
    line-height: 1.4 !important;
}
@media (max-width: 1599.98px) { footer .fw-link ul.columns { column-count: 4 !important; } }
@media (max-width: 1199.98px) { footer .fw-link ul.columns { column-count: 3 !important; } }
@media (max-width: 991.98px)  { footer .fw-link ul.columns { column-count: 2 !important; column-gap: 20px !important; } }
@media (max-width: 575.98px)  { footer .fw-link ul.columns { column-count: 1 !important; } }

/* Social section moved to a centered full-width strip at the bottom of the footer */
footer .footer-social.kd-foot-social-moved {
    width: 100% !important;
    margin: 28px 0 0 !important;
    padding: 24px 0 0 !important;
    border-top: 1px dashed var(--kd-ink-200) !important;
    display: flex !important;
    justify-content: center !important;
}
.kd-foot-social-wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 14px;
    width: 100%;
    max-width: 760px;
}
.kd-foot-sm-label {
    font-size: 14px;
    font-weight: 600;
    color: var(--kd-ink-700);
    margin: 0;
}
.kd-foot-sm-row {
    display: flex;
    align-items: center;
    gap: 18px;
    flex-wrap: wrap;
    justify-content: center;
}
.kd-foot-sm-row .social-icons {
    display: flex !important;
    gap: 10px !important;
    align-items: center !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none;
}
.kd-foot-sm-row .social-icons li { margin: 0 !important; }
.kd-foot-dl-divider {
    width: 1px;
    height: 24px;
    background: var(--kd-ink-200);
    display: inline-block;
    margin: 0 6px;
}
.kd-foot-dl-label {
    font-size: 14px;
    font-weight: 600;
    color: var(--kd-ink-700);
}
.kd-foot-sm-row > a {
    display: inline-flex;
    align-items: center;
    transition: transform .18s var(--kd-ease);
}
.kd-foot-sm-row > a:hover { transform: translateY(-2px); }
.kd-foot-sm-row > a img { display: block; }
@media (max-width: 575.98px) {
    .kd-foot-dl-divider { display: none; }
    .kd-foot-sm-row { gap: 12px; }
}
footer .social-icons li { margin: 0 !important; }
footer .social-icons a {
    width: 38px !important;
    height: 38px !important;
    border-radius: 50% !important;
    display: grid !important;
    place-items: center !important;
    background: var(--kd-bg-soft) !important;
    color: var(--kd-ink-700) !important;
    border: 1.5px solid var(--kd-ink-100) !important;
    transition: all .22s var(--kd-ease) !important;
    text-decoration: none !important;
}
footer .social-icons a svg {
    width: 16px;
    height: 16px;
    display: block;
    transition: transform .22s var(--kd-ease);
}
footer .social-icons a:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 18px rgba(10,20,16,.18);
}
footer .social-icons a:hover svg { transform: scale(1.08); }

/* Brand-specific hover colours */
footer .social-icons a[data-brand="facebook"]:hover  { background: #1877F2 !important; color: #fff !important; border-color: #1877F2 !important; }
footer .social-icons a[data-brand="twitter"]:hover   { background: #000000 !important; color: #fff !important; border-color: #000000 !important; }
footer .social-icons a[data-brand="youtube"]:hover   { background: #FF0000 !important; color: #fff !important; border-color: #FF0000 !important; }
footer .social-icons a[data-brand="linkedin"]:hover  { background: #0A66C2 !important; color: #fff !important; border-color: #0A66C2 !important; }
footer .social-icons a[data-brand="instagram"]:hover {
    background: linear-gradient(135deg, #f09433 0%,#e6683c 25%,#dc2743 50%,#cc2366 75%,#bc1888 100%) !important;
    color: #fff !important;
    border-color: transparent !important;
}

/* (Trust strip and Made-in-India tagline removed per request) */

/* ============================================================
   Floating scroll-to-top button
   ============================================================ */
.kd-scroll-top {
    position: fixed;
    bottom: 22px; right: 22px;
    width: 48px; height: 48px;
    border-radius: 50%;
    background: var(--kd-g-600);
    color: #fff;
    border: 0;
    display: grid;
    place-items: center;
    cursor: pointer;
    box-shadow: 0 10px 28px rgba(12,110,48,.42), 0 4px 8px rgba(0,0,0,.18);
    z-index: 9990;
    opacity: 0;
    transform: translateY(16px) scale(.9);
    pointer-events: none;
    transition: opacity .25s var(--kd-ease), transform .25s var(--kd-ease), background .18s var(--kd-ease);
}
.kd-scroll-top.is-visible {
    opacity: 1;
    transform: translateY(0) scale(1);
    pointer-events: auto;
}
.kd-scroll-top:hover {
    background: var(--kd-g-700);
    transform: translateY(-3px) scale(1.06);
    box-shadow: 0 14px 36px rgba(12,110,48,.5);
}
.kd-scroll-top svg { width: 20px; height: 20px; display: block; }
@media (max-width: 600px) {
    .kd-scroll-top { bottom: 16px; right: 16px; width: 42px; height: 42px; }
    .kd-scroll-top svg { width: 18px; height: 18px; }
}

/* -------------------- HERO — farmer-first emotional -------------------- */
.kd-hero {
    max-width: var(--kd-max); margin: var(--kd-s-5) auto var(--kd-s-6);
    padding: 0 var(--kd-s-5);
}
.kd-hero-card {
    position: relative;
    background:
        radial-gradient(800px 500px at 90% 10%, rgba(19,138,62,0.12) 0%, transparent 60%),
        radial-gradient(700px 400px at 5% 100%, rgba(255,122,26,0.10) 0%, transparent 60%),
        linear-gradient(180deg, #fbf9f1 0%, #fff 100%);
    border-radius: var(--kd-r-2xl);
    border: 1px solid var(--kd-ink-100);
    overflow: hidden;
    display: grid;
    grid-template-columns: 1.15fr 1fr;
    min-height: 460px;
}
@media (max-width: 900px) { .kd-hero-card { grid-template-columns: 1fr; min-height: auto; } }

.kd-hero-left {
    padding: var(--kd-s-12) var(--kd-s-12);
    display: flex; flex-direction: column; justify-content: center;
    position: relative; z-index: 2;
}
@media (max-width: 700px) { .kd-hero-left { padding: var(--kd-s-8) var(--kd-s-6); } }

.kd-hero-eyebrow {
    display: inline-flex; align-items: center; gap: 8px;
    background: var(--kd-g-50); color: var(--kd-g-800);
    font-size: 13px; font-weight: 800;
    padding: 7px 14px; border-radius: var(--kd-r-pill);
    letter-spacing: 0.04em; text-transform: uppercase;
    margin-bottom: var(--kd-s-5);
    width: fit-content;
    border: 1.5px solid var(--kd-g-100);
}
.kd-hero-eyebrow .kd-dot {
    width: 7px; height: 7px; border-radius: 50%;
    background: var(--kd-g-500);
    box-shadow: 0 0 0 4px rgba(19,138,62,.2);
    animation: kd-blink 1.6s ease-in-out infinite;
}
@keyframes kd-blink { 0%,100% { opacity: 1; transform: scale(1); } 50% { opacity: .4; transform: scale(.8); } }

.kd-hero-title {
    font-family: var(--kd-font-sans);
    font-size: clamp(34px, 5vw, 60px);
    font-weight: 800;
    line-height: 1.02;
    letter-spacing: -0.035em;
    color: var(--kd-ink-900);
    margin: 0 0 var(--kd-s-4);
}
.kd-hero-title .kd-line { display: block; }
.kd-hero-title .kd-accent {
    color: var(--kd-g-700);
    font-family: var(--kd-font-serif) !important;
    font-style: italic;
    font-weight: 600;
    position: relative;
    white-space: nowrap;
    padding: 0 6px;
}
.kd-hero-title .kd-accent::after {
    content: ""; position: absolute;
    left: 6px; right: 6px; bottom: 6px; height: 12px;
    background: var(--kd-s-300); opacity: .4; z-index: -1;
    border-radius: 6px;
}

.kd-hero-sub {
    font-size: var(--kd-fs-md);
    color: var(--kd-ink-700);
    line-height: 1.55;
    margin: 0 0 var(--kd-s-6);
    max-width: 520px;
    font-weight: 500;
}
.kd-hero-sub strong { color: var(--kd-ink-900); font-weight: 700; }

.kd-hero-ctas { display: flex; gap: var(--kd-s-3); flex-wrap: wrap; margin-bottom: var(--kd-s-8); }
.kd-btn {
    display: inline-flex; align-items: center; gap: 8px;
    border: 0; cursor: pointer;
    padding: 14px 26px;
    border-radius: var(--kd-r-md);
    font-family: var(--kd-font-sans) !important;
    font-size: 15px;
    font-weight: 700;
    letter-spacing: -0.005em;
    transition: all .2s var(--kd-ease);
    text-decoration: none;
    line-height: 1;
}
.kd-btn-primary { background: var(--kd-g-600); color: #fff; box-shadow: 0 8px 22px rgba(12,110,48,.32); }
.kd-btn-primary:hover { background: var(--kd-g-700); transform: translateY(-2px); box-shadow: 0 14px 32px rgba(12,110,48,.4); color: #fff; }
.kd-btn-ghost { background: var(--kd-surface); color: var(--kd-ink-900); border: 1.5px solid var(--kd-ink-200); }
.kd-btn-ghost:hover { border-color: var(--kd-ink-700); transform: translateY(-2px); box-shadow: var(--kd-shadow-sm); }
.kd-btn-saffron { background: linear-gradient(135deg, var(--kd-s-500), var(--kd-s-600)); color: #fff; box-shadow: 0 8px 22px rgba(255,122,26,.32); }
.kd-btn-saffron:hover { transform: translateY(-2px); color: #fff; box-shadow: 0 14px 32px rgba(255,122,26,.4); }

.kd-hero-trust {
    display: flex; gap: var(--kd-s-6);
    padding-top: var(--kd-s-5);
    border-top: 1.5px solid var(--kd-ink-100);
    flex-wrap: wrap;
}
.kd-htrust-num { font-size: var(--kd-fs-xl); font-weight: 800; color: var(--kd-ink-900); letter-spacing: -0.025em; line-height: 1; }
.kd-htrust-num .kd-unit { color: var(--kd-g-600); }
.kd-htrust-lbl { font-size: 12px; color: var(--kd-ink-600); margin-top: 4px; font-weight: 600; }

/* Hero right — illustrated farmer scene */
.kd-hero-right {
    position: relative;
    overflow: hidden;
    background: linear-gradient(160deg, var(--kd-cream-100) 0%, var(--kd-cream-50) 100%);
}
.kd-hero-scene { position: absolute; inset: 0; }
/* Sky/sun */
.kd-hero-scene::before {
    content: ""; position: absolute;
    top: 18%; right: 18%;
    width: 120px; height: 120px; border-radius: 50%;
    background: radial-gradient(circle, var(--kd-s-300) 0%, var(--kd-s-500) 100%);
    box-shadow: 0 0 80px rgba(255,122,26,.3);
    animation: kd-floatslow 8s ease-in-out infinite;
}
@keyframes kd-floatslow { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-8px); } }
/* Field horizon */
.kd-hero-scene::after {
    content: ""; position: absolute;
    bottom: 0; left: 0; right: 0; height: 45%;
    background:
        linear-gradient(180deg, transparent 0%, rgba(19,138,62,.18) 30%, rgba(12,110,48,.35) 100%);
}
.kd-hero-orb {
    position: absolute;
    border-radius: 50%;
    background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.6), transparent 50%),
                linear-gradient(135deg, var(--c1), var(--c2));
    box-shadow: 0 24px 60px rgba(10,20,16,.22);
    display: grid; place-items: center;
    font-size: 56px;
    z-index: 2;
    animation: kd-floatslow 6s ease-in-out infinite;
}
.kd-hero-orb.o1 { width: 200px; height: 200px; top: 12%;  left: 14%; --c1: #67c282; --c2: #075722; animation-delay: 0s; }
.kd-hero-orb.o2 { width: 150px; height: 150px; top: 38%; right: 12%; --c1: #ffae5c; --c2: #b14705; animation-delay: 1.2s; }
.kd-hero-orb.o3 { width: 120px; height: 120px; bottom: 14%; left: 38%; --c1: #f5ecd2; --c2: #e8d9aa; animation-delay: 2.4s; font-size: 42px; }

.kd-hero-floatcard {
    position: absolute;
    background: var(--kd-surface);
    border-radius: var(--kd-r-md);
    padding: 12px 16px;
    box-shadow: var(--kd-shadow-md);
    display: flex; align-items: center; gap: 10px;
    font-size: 14px; font-weight: 700;
    color: var(--kd-ink-900);
    border: 1px solid var(--kd-ink-100);
    z-index: 3;
}
.kd-hero-floatcard.f1 { top: 10%; right: 8%; }
.kd-hero-floatcard.f2 { bottom: 16%; left: 4%; }
.kd-hero-floatcard .kd-fc-icon {
    width: 36px; height: 36px; border-radius: var(--kd-r-sm);
    background: var(--kd-g-50); color: var(--kd-g-700);
    display: grid; place-items: center; font-size: 16px;
}
.kd-hero-floatcard.f2 .kd-fc-icon { background: var(--kd-s-50); color: var(--kd-s-700); }
.kd-hero-floatcard .kd-fc-mini { font-size: 11px; color: var(--kd-ink-500); font-weight: 500; margin-top: 1px; }

@media (max-width: 700px) {
    .kd-hero-orb.o1 { width: 130px; height: 130px; font-size: 38px; }
    .kd-hero-orb.o2 { width: 100px; height: 100px; font-size: 30px; }
    .kd-hero-orb.o3 { width: 90px; height: 90px; font-size: 28px; }
    .kd-hero-floatcard { padding: 8px 12px; font-size: 12px; }
}

/* -------------------- FARMER FINDER (restored, redesigned) -------------------- */
.kd-finder {
    max-width: var(--kd-max);
    margin: 0 auto var(--kd-s-10);
    padding: 0 var(--kd-s-5);
}
.kd-finder-card {
    background:
        radial-gradient(500px 250px at 0% 0%, rgba(19,138,62,.06) 0%, transparent 70%),
        var(--kd-surface);
    border: 1.5px solid var(--kd-g-100);
    border-radius: var(--kd-r-xl);
    padding: var(--kd-s-6);
    box-shadow: var(--kd-shadow-sm);
}
.kd-finder-head {
    display: flex; align-items: flex-start; justify-content: space-between;
    gap: var(--kd-s-3); flex-wrap: wrap;
    margin-bottom: var(--kd-s-5);
}
.kd-finder-title-wrap { display: flex; align-items: center; gap: var(--kd-s-3); }
.kd-finder-icon {
    width: 48px; height: 48px;
    border-radius: var(--kd-r-md);
    background: linear-gradient(135deg, var(--kd-g-500), var(--kd-g-700));
    color: #fff;
    display: grid; place-items: center;
    font-size: 22px;
    flex-shrink: 0;
    box-shadow: 0 6px 16px rgba(12,110,48,.28);
}
.kd-finder-title { font-size: var(--kd-fs-xl); font-weight: 800; color: var(--kd-ink-900); margin: 0; letter-spacing: -0.025em; line-height: 1.15; }
.kd-finder-sub   { font-size: var(--kd-fs-sm); color: var(--kd-ink-600); margin: 2px 0 0; }

.kd-finder-stats { display: flex; gap: var(--kd-s-5); align-items: center; }
.kd-finder-stats .num { font-size: var(--kd-fs-md); font-weight: 800; color: var(--kd-g-700); letter-spacing: -0.02em; }
.kd-finder-stats .lbl { font-size: 11px; color: var(--kd-ink-500); text-transform: uppercase; letter-spacing: .05em; font-weight: 700; }

/* Override existing #divVendorList layout (visible again, restyled) */
#divVendorList {
    display: grid !important;
    grid-template-columns: 1fr 1fr 1fr 2fr !important;
    gap: var(--kd-s-3) !important;
    align-items: center !important;
}
@media (max-width: 900px) { #divVendorList { grid-template-columns: 1fr 1fr !important; } }
@media (max-width: 600px) { #divVendorList { grid-template-columns: 1fr !important; } }

#divVendorList .vendor-select-box {
    width: 100% !important;
    min-width: 0 !important;
    max-width: none !important;
}
#divVendorList .filter-wrapper-container {
    display: contents !important;
}
#divVendorList select.vendor-dropdown {
    width: 100% !important;
    height: 50px !important;
    padding: 0 40px 0 18px !important;
    border-radius: var(--kd-r-md) !important;
    border: 1.5px solid var(--kd-ink-200) !important;
    background-color: var(--kd-surface) !important;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23455349' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>") !important;
    background-repeat: no-repeat !important;
    background-position: right 16px center !important;
    background-size: 14px !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    font-family: var(--kd-font-sans) !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: var(--kd-ink-900) !important;
    cursor: pointer !important;
    transition: all .18s var(--kd-ease) !important;
    box-shadow: var(--kd-shadow-xs) !important;
}
#divVendorList select.vendor-dropdown:hover { border-color: var(--kd-g-400) !important; }
#divVendorList select.vendor-dropdown:focus {
    border-color: var(--kd-g-500) !important;
    outline: none !important;
    box-shadow: var(--kd-shadow-glow) !important;
}
#divVendorList #filterCityChipsContainer {
    display: flex !important;
    align-items: center !important;
    gap: var(--kd-s-2) !important;
    overflow-x: auto !important;
    flex-wrap: nowrap !important;
    padding: 4px 0 !important;
    scrollbar-width: none !important;
    min-height: 50px !important;
}
#divVendorList #filterCityChipsContainer::-webkit-scrollbar { display: none !important; }
#divVendorList #filterCityChipsContainer .city-chip {
    flex-shrink: 0 !important;
    padding: 9px 18px !important;
    border-radius: var(--kd-r-pill) !important;
    border: 1.5px solid var(--kd-ink-100) !important;
    background: var(--kd-surface) !important;
    color: var(--kd-ink-800) !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    cursor: pointer !important;
    white-space: nowrap !important;
    transition: all .18s var(--kd-ease) !important;
}
#divVendorList #filterCityChipsContainer .city-chip:hover { border-color: var(--kd-g-300) !important; color: var(--kd-g-700) !important; }
#divVendorList #filterCityChipsContainer .city-chip.active {
    background: var(--kd-g-600) !important;
    color: #fff !important;
    border-color: var(--kd-g-600) !important;
    box-shadow: 0 4px 12px rgba(12,110,48,.28) !important;
}
#divVendorList #filterCityChipsContainer .more-cities-listing {
    color: var(--kd-s-600) !important;
    font-weight: 700 !important;
    font-size: 13px !important;
    cursor: pointer !important;
    margin-left: 4px !important;
}

/* Container for the finder must NOT hide #divVendorList anymore */
/* (intentional: prior version hid it) */

/* -------------------- IMPACT BANNER (nation-building counter strip) -------------------- */
.kd-impact {
    max-width: var(--kd-max); margin: var(--kd-s-10) auto;
    padding: 0 var(--kd-s-5);
}
.kd-impact-card {
    background:
        radial-gradient(700px 350px at 100% 0%, rgba(255,122,26,.18) 0%, transparent 60%),
        radial-gradient(500px 300px at 0% 100%, rgba(19,138,62,.16) 0%, transparent 60%),
        linear-gradient(135deg, var(--kd-g-900) 0%, var(--kd-g-700) 100%);
    border-radius: var(--kd-r-2xl);
    padding: var(--kd-s-10) var(--kd-s-10);
    color: #fff;
    position: relative;
    overflow: hidden;
}
@media (max-width: 700px) { .kd-impact-card { padding: var(--kd-s-8) var(--kd-s-6); } }
.kd-impact-eyebrow {
    display: inline-flex; align-items: center; gap: 8px;
    background: rgba(255,255,255,.12);
    color: #fff; font-size: 12px; font-weight: 800;
    padding: 6px 14px; border-radius: var(--kd-r-pill);
    letter-spacing: 0.06em; text-transform: uppercase;
    margin-bottom: var(--kd-s-4);
    border: 1px solid rgba(255,255,255,.2);
}
.kd-impact-title {
    font-size: clamp(28px, 4vw, 44px);
    font-weight: 800; letter-spacing: -0.03em; line-height: 1.1;
    margin: 0 0 var(--kd-s-3); max-width: 800px;
}
.kd-impact-title em {
    font-family: var(--kd-font-serif) !important;
    font-style: italic; font-weight: 600;
    color: var(--kd-s-300);
}
.kd-impact-sub {
    font-size: var(--kd-fs-md);
    opacity: 0.88;
    margin: 0 0 var(--kd-s-8);
    max-width: 640px;
    line-height: 1.6;
}
.kd-impact-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--kd-s-5);
}
@media (max-width: 800px) { .kd-impact-grid { grid-template-columns: repeat(2, 1fr); } }
.kd-impact-stat { display: flex; flex-direction: column; gap: 4px; }
.kd-impact-num {
    font-size: clamp(28px, 3.5vw, 42px);
    font-weight: 800; letter-spacing: -0.03em;
    color: #fff; line-height: 1;
}
.kd-impact-num .kd-unit { color: var(--kd-s-300); font-size: 0.7em; }
.kd-impact-lbl {
    font-size: 13px; color: rgba(255,255,255,.78);
    letter-spacing: 0.04em; text-transform: uppercase; font-weight: 700;
    margin-top: 4px;
}
.kd-impact-tagline {
    margin-top: var(--kd-s-8);
    padding-top: var(--kd-s-6);
    border-top: 1px solid rgba(255,255,255,.16);
    font-family: var(--kd-font-serif) !important;
    font-style: italic; font-weight: 500;
    font-size: var(--kd-fs-md);
    opacity: 0.92;
}
.kd-impact-tagline strong { color: var(--kd-s-300); font-weight: 700; }

/* -------------------- WHY DIRECT FROM FARMER (3 pillars) -------------------- */
.kd-why {
    max-width: var(--kd-max); margin: var(--kd-s-12) auto;
    padding: 0 var(--kd-s-5);
}
.kd-why-grid {
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: var(--kd-s-5);
}
@media (max-width: 800px) { .kd-why-grid { grid-template-columns: 1fr; } }
.kd-why-card {
    background: var(--kd-surface);
    border: 1.5px solid var(--kd-ink-100);
    border-radius: var(--kd-r-xl);
    padding: var(--kd-s-8);
    transition: all .2s var(--kd-ease);
}
.kd-why-card:hover { border-color: var(--kd-g-200); transform: translateY(-3px); box-shadow: var(--kd-shadow-md); }
.kd-why-num {
    font-family: var(--kd-font-serif) !important;
    font-size: 56px; font-weight: 600;
    color: var(--kd-g-200);
    line-height: 1;
    margin-bottom: var(--kd-s-3);
}
.kd-why-title {
    font-size: var(--kd-fs-lg); font-weight: 800;
    color: var(--kd-ink-900); margin: 0 0 var(--kd-s-2);
    letter-spacing: -0.02em;
}
.kd-why-text {
    font-size: var(--kd-fs-base); color: var(--kd-ink-600);
    line-height: 1.65; margin: 0;
}

/* -------------------- Section heading (unified) -------------------- */
.kd-section { max-width: var(--kd-max); margin: var(--kd-s-12) auto; padding: 0 var(--kd-s-5); }
.kd-section-tight { margin: var(--kd-s-8) auto; }
.kd-section-head {
    display: flex; align-items: flex-end; justify-content: space-between;
    margin-bottom: var(--kd-s-6);
    gap: var(--kd-s-3);
}
.kd-section-titlewrap { min-width: 0; max-width: 720px; }
.kd-section-eyebrow {
    font-size: 13px; font-weight: 800;
    color: var(--kd-s-700);
    letter-spacing: 0.08em; text-transform: uppercase;
    display: block; margin-bottom: 6px;
}
.kd-section-title {
    font-size: var(--kd-fs-2xl); font-weight: 800;
    color: var(--kd-ink-900); margin: 0;
    letter-spacing: -0.03em; line-height: 1.1;
}
.kd-section-title em {
    font-family: var(--kd-font-serif) !important;
    font-style: italic; font-weight: 600;
    color: var(--kd-g-700);
}
@media (max-width: 600px) { .kd-section-title { font-size: var(--kd-fs-xl); } }
.kd-section-sub {
    font-size: var(--kd-fs-base); color: var(--kd-ink-600);
    margin: 6px 0 0; line-height: 1.55;
}
.kd-section-tools { display: flex; align-items: center; gap: var(--kd-s-2); flex-shrink: 0; }
.kd-section-link {
    font-size: 14px; color: var(--kd-g-700); font-weight: 800;
    text-decoration: none; cursor: pointer;
    padding: 9px 14px; border-radius: var(--kd-r-sm);
    transition: background .18s var(--kd-ease);
}
.kd-section-link:hover { background: var(--kd-g-50); color: var(--kd-g-800); }

.kd-arrows { display: inline-flex; gap: 6px; }
.kd-arrow {
    width: 40px; height: 40px;
    border-radius: 50%;
    background: var(--kd-surface);
    border: 1.5px solid var(--kd-ink-100);
    color: var(--kd-ink-700);
    display: grid; place-items: center;
    cursor: pointer;
    transition: all .18s var(--kd-ease);
    box-shadow: var(--kd-shadow-xs);
}
.kd-arrow:hover { background: var(--kd-g-600); color: #fff; border-color: var(--kd-g-600); transform: translateY(-1px); box-shadow: var(--kd-shadow-sm); }
.kd-arrow:disabled { opacity: .35; cursor: not-allowed; transform: none; background: var(--kd-surface); color: var(--kd-ink-400); border-color: var(--kd-ink-100); }
.kd-arrow svg { width: 16px; height: 16px; }

.kd-scroller {
    display: flex; gap: var(--kd-s-4);
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding-bottom: var(--kd-s-2);
    scrollbar-width: none; scroll-behavior: smooth;
}
.kd-scroller::-webkit-scrollbar { display: none; }
.kd-scroller > * { scroll-snap-align: start; flex: 0 0 auto; }

/* -------------------- Mandi ticker -------------------- */
.kd-mandi { max-width: var(--kd-max); margin: 0 auto var(--kd-s-6); padding: 0 var(--kd-s-5); }
.kd-mandi-bar {
    background: var(--kd-surface);
    border: 1.5px solid var(--kd-ink-100);
    border-radius: var(--kd-r-md);
    padding: 12px 18px;
    overflow: hidden; display: flex; align-items: center;
    gap: var(--kd-s-4); box-shadow: var(--kd-shadow-xs);
}
.kd-mandi-label {
    flex-shrink: 0;
    font-size: 12px; font-weight: 800;
    color: #fff;
    background: linear-gradient(135deg, var(--kd-s-500), var(--kd-s-600));
    padding: 6px 12px; border-radius: var(--kd-r-sm);
    letter-spacing: 0.08em; text-transform: uppercase;
    display: inline-flex; align-items: center; gap: 6px;
}
.kd-mandi-label .kd-dot { width: 6px; height: 6px; border-radius: 50%; background: #fff; animation: kd-blink 1.4s infinite; }
.kd-mandi-track {
    display: flex; gap: var(--kd-s-10);
    animation: kd-marquee 50s linear infinite;
    white-space: nowrap;
}
.kd-mandi-bar:hover .kd-mandi-track { animation-play-state: paused; }
@keyframes kd-marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }
.kd-mandi-item { display: inline-flex; align-items: center; gap: 8px; font-size: 14px; color: var(--kd-ink-900); font-weight: 700; }
.kd-mandi-item .kd-mandi-name { color: var(--kd-ink-600); font-weight: 600; }
.kd-mandi-up   { color: var(--kd-g-600); font-weight: 800; }
.kd-mandi-down { color: var(--kd-t-500); font-weight: 800; }

/* -------------------- Live tracker -------------------- */
.kd-track { max-width: var(--kd-max); margin: 0 auto var(--kd-s-6); padding: 0 var(--kd-s-5); }
.kd-track-card {
    border-radius: var(--kd-r-lg);
    background:
        radial-gradient(500px 250px at 100% 0%, rgba(255,255,255,0.18) 0%, transparent 60%),
        linear-gradient(135deg, var(--kd-g-700) 0%, var(--kd-g-500) 100%);
    color: #fff;
    padding: 20px 24px;
    display: flex; align-items: center; gap: var(--kd-s-4);
    box-shadow: var(--kd-shadow-md);
    position: relative; overflow: hidden;
}
.kd-track-icon {
    width: 52px; height: 52px;
    border-radius: var(--kd-r-md);
    background: rgba(255,255,255,0.18);
    display: grid; place-items: center;
    font-size: 26px; flex-shrink: 0;
}
.kd-track-text { flex: 1; min-width: 0; }
.kd-track-text h4 { margin: 0; font-size: var(--kd-fs-md); font-weight: 800; letter-spacing: -0.015em; color: #fff; }
.kd-track-text p  { margin: 3px 0 0; font-size: var(--kd-fs-sm); opacity: .92; color: #fff; }
.kd-track-progress { margin-top: 10px; height: 5px; background: rgba(255,255,255,0.22); border-radius: 4px; overflow: hidden; }
.kd-track-progress-fill { height: 100%; background: linear-gradient(90deg, #fff 0%, var(--kd-s-300) 100%); width: 65%; border-radius: 4px; }
.kd-track-cta {
    background: #fff; color: var(--kd-g-700);
    border: 0; border-radius: var(--kd-r-sm);
    padding: 11px 18px; font-weight: 800; font-size: 13px;
    cursor: pointer; flex-shrink: 0;
}
.kd-track-cta:hover { transform: translateY(-1px); box-shadow: 0 6px 16px rgba(0,0,0,.18); }
@media (max-width: 600px) { .kd-track-card { flex-wrap: wrap; } .kd-track-cta { width: 100%; } }

/* -------------------- Existing-section overrides -------------------- */
/* Categories grid */
.category-grid-container.main-categories-section {
    max-width: var(--kd-max) !important;
    margin: var(--kd-s-12) auto !important;
    padding: 0 var(--kd-s-5) !important;
}
/* Old auto-injected heading via ::before/::after — disabled.
   Real header is now built by enhanceCategories() in JS — see Card #6 block. */
.category-grid-container.main-categories-section::before,
.category-grid-container.main-categories-section::after { content: none !important; }
.category-grid-container.main-categories-section #GetbyCategoryVendor {
    display: grid !important;
    grid-template-columns: repeat(6, 1fr) !important;
    gap: var(--kd-s-3) !important;
    flex-wrap: unset !important;
    overflow: visible !important;
}
@media (max-width: 1100px) { .category-grid-container.main-categories-section #GetbyCategoryVendor { grid-template-columns: repeat(4, 1fr) !important; } }
@media (max-width: 700px)  { .category-grid-container.main-categories-section #GetbyCategoryVendor { grid-template-columns: repeat(3, 1fr) !important; } }

.category-grid-container.main-categories-section .category-item {
    background: var(--kd-surface) !important;
    border: 1.5px solid var(--kd-ink-100) !important;
    border-radius: var(--kd-r-lg) !important;
    padding: var(--kd-s-4) var(--kd-s-2) var(--kd-s-3) !important;
    box-shadow: none !important;
    transition: all .22s var(--kd-ease) !important;
    flex-basis: auto !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
    cursor: pointer !important;
}
.category-grid-container.main-categories-section .category-item:hover {
    border-color: var(--kd-g-500) !important;
    transform: translateY(-4px) !important;
    box-shadow: var(--kd-shadow-md) !important;
}
.category-grid-container.main-categories-section .category-image-container {
    background: linear-gradient(135deg, #f7f3e2, #fdf8e8) !important;
    border-radius: var(--kd-r-md) !important;
    aspect-ratio: 1 / 1 !important;
    display: grid !important;
    place-items: center !important;
    margin-bottom: var(--kd-s-2) !important;
    overflow: hidden !important;
}
.category-grid-container.main-categories-section .category-image {
    width: 70% !important; height: 70% !important;
    object-fit: contain !important;
    transition: transform .3s var(--kd-ease) !important;
}
.category-grid-container.main-categories-section .category-item:hover .category-image { transform: scale(1.08) !important; }
.category-grid-container.main-categories-section .category-name {
    font-size: 14px !important;
    font-weight: 700 !important;
    color: var(--kd-ink-900) !important;
    text-align: center !important;
    letter-spacing: -0.005em !important;
    font-family: var(--kd-font-sans) !important;
}

.category-grid-container, .product-grid-container, .hotdeals-wrapper {
    max-width: var(--kd-max) !important;
    margin: var(--kd-s-10) auto !important;
}
.page-title {
    font-size: var(--kd-fs-2xl) !important;
    font-weight: 800 !important;
    color: var(--kd-ink-900) !important;
    letter-spacing: -0.03em !important;
    margin: 0 0 var(--kd-s-5) var(--kd-s-5) !important;
    line-height: 1.1 !important;
    font-family: var(--kd-font-sans) !important;
}
@media (max-width: 600px) { .page-title { font-size: var(--kd-fs-xl) !important; } }

.brand-section-container {
    background: linear-gradient(135deg, var(--kd-cream-50), #fff) !important;
    border-radius: var(--kd-r-xl) !important;
    padding: var(--kd-s-8) var(--kd-s-6) !important;
    border: 1.5px solid var(--kd-ink-100) !important;
    position: relative !important;
}
.brand-container { gap: var(--kd-s-4) !important; padding: 0 !important; }

/* legacy arrow buttons */
.hotdeals-scroll-btn {
    width: 44px !important; height: 44px !important;
    border-radius: 50% !important;
    background: var(--kd-surface) !important;
    border: 1.5px solid var(--kd-ink-100) !important;
    color: var(--kd-ink-700) !important;
    box-shadow: var(--kd-shadow-sm) !important;
    transition: all .18s var(--kd-ease) !important;
    display: grid !important; place-items: center !important;
}
.hotdeals-scroll-btn:hover:not(:disabled) {
    background: var(--kd-g-600) !important; color: #fff !important;
    border-color: var(--kd-g-600) !important;
    transform: translateY(-50%) !important;
    box-shadow: 0 8px 22px rgba(12,110,48,.32) !important;
}
.hotdeals-scroll-btn:disabled { opacity: .3 !important; cursor: not-allowed !important; }
.hotdeals-scroll-btn i { font-size: 14px !important; }
.hotdeals-scroll-btn.left  { left: -20px !important; }
.hotdeals-scroll-btn.right { right: -20px !important; }
@media (max-width: 600px) {
    .hotdeals-scroll-btn { width: 40px !important; height: 40px !important; }
    .hotdeals-scroll-btn.left  { left: 6px !important; }
    .hotdeals-scroll-btn.right { right: 6px !important; }
}

/* -------------------- Trust strip -------------------- */
.kd-trust { max-width: var(--kd-max); margin: var(--kd-s-10) auto; padding: 0 var(--kd-s-5); }
.kd-trust-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--kd-s-4); }
@media (max-width: 800px) { .kd-trust-grid { grid-template-columns: repeat(2, 1fr); } }
.kd-trust-card {
    background: var(--kd-surface);
    border: 1.5px solid var(--kd-ink-100);
    border-radius: var(--kd-r-lg);
    padding: var(--kd-s-6);
    display: flex; flex-direction: column; gap: var(--kd-s-3);
    transition: all .2s var(--kd-ease);
}
.kd-trust-card:hover { border-color: var(--kd-g-300); transform: translateY(-3px); box-shadow: var(--kd-shadow-md); }
.kd-trust-icon {
    width: 50px; height: 50px;
    border-radius: var(--kd-r-md);
    background: var(--kd-g-50); color: var(--kd-g-700);
    display: grid; place-items: center; font-size: 24px;
}
.kd-trust-title { font-size: var(--kd-fs-md); font-weight: 800; color: var(--kd-ink-900); letter-spacing: -0.015em; }
.kd-trust-sub { font-size: var(--kd-fs-sm); color: var(--kd-ink-600); line-height: 1.55; }

/* -------------------- Coupon -------------------- */
.kd-coupon { max-width: var(--kd-max); margin: 0 auto var(--kd-s-6); padding: 0 var(--kd-s-5); }
.kd-coupon-bar {
    background: linear-gradient(135deg, #fff5e6 0%, #fff 70%);
    border: 1.5px dashed var(--kd-s-500);
    border-radius: var(--kd-r-md);
    padding: 14px 20px;
    display: flex; align-items: center; gap: var(--kd-s-3);
    font-size: var(--kd-fs-base); color: var(--kd-ink-900);
    flex-wrap: wrap;
}
.kd-coupon-bar strong { color: var(--kd-s-700); font-weight: 800; }
.kd-coupon-code {
    background: var(--kd-surface);
    border: 1px dashed var(--kd-s-500);
    color: var(--kd-s-700);
    padding: 6px 14px; border-radius: var(--kd-r-sm);
    font-family: 'JetBrains Mono', monospace !important;
    font-weight: 800;
    cursor: pointer;
    margin-left: auto;
    transition: all .18s var(--kd-ease);
}
.kd-coupon-code:hover { background: var(--kd-s-500); color: #fff; }

/* -------------------- Slot picker -------------------- */
.kd-slot { max-width: var(--kd-max); margin: 0 auto var(--kd-s-8); padding: 0 var(--kd-s-5); }
.kd-slot-bar {
    background: var(--kd-surface);
    border: 1.5px solid var(--kd-ink-100);
    border-radius: var(--kd-r-lg);
    padding: var(--kd-s-4);
    display: flex; align-items: center; gap: var(--kd-s-2);
    overflow-x: auto; flex-wrap: nowrap;
    scrollbar-width: none;
}
.kd-slot-bar::-webkit-scrollbar { display: none; }
.kd-slot-label {
    font-size: 14px; font-weight: 800;
    color: var(--kd-ink-800); flex-shrink: 0;
    display: flex; align-items: center; gap: 8px; padding: 0 8px;
}
.kd-slot-label .kd-icn { color: var(--kd-s-600); }
.kd-slot-chip {
    flex-shrink: 0;
    padding: 10px 18px;
    border-radius: var(--kd-r-pill);
    border: 1.5px solid var(--kd-ink-100);
    background: var(--kd-surface);
    font-size: 13px; font-weight: 700;
    color: var(--kd-ink-800);
    cursor: pointer;
    transition: all .18s var(--kd-ease);
    white-space: nowrap;
    font-family: var(--kd-font-sans) !important;
}
.kd-slot-chip:hover { border-color: var(--kd-g-400); color: var(--kd-g-700); }
.kd-slot-chip.is-active {
    background: var(--kd-g-600); color: #fff;
    border-color: var(--kd-g-600);
    box-shadow: 0 4px 12px rgba(12,110,48,.28);
}

/* -------------------- Featured Farmer of the Week (emotional) -------------------- */
.kd-ff { max-width: var(--kd-max); margin: var(--kd-s-12) auto; padding: 0 var(--kd-s-5); }
.kd-ff-card {
    border-radius: var(--kd-r-2xl);
    overflow: hidden;
    background:
        radial-gradient(700px 400px at 100% 0%, rgba(255,174,92,.18) 0%, transparent 60%),
        linear-gradient(135deg, var(--kd-g-800) 0%, var(--kd-g-600) 100%);
    color: #fff;
    display: grid;
    grid-template-columns: 1.4fr 1fr;
    min-height: 420px;
    box-shadow: var(--kd-shadow-md);
    position: relative;
}
@media (max-width: 800px) { .kd-ff-card { grid-template-columns: 1fr; } }
.kd-ff-left { padding: var(--kd-s-12); position: relative; z-index: 2; display: flex; flex-direction: column; justify-content: center; }
@media (max-width: 700px) { .kd-ff-left { padding: var(--kd-s-8); } }
.kd-ff-eyebrow {
    display: inline-flex; align-items: center; gap: 8px;
    background: rgba(255,255,255,.18);
    padding: 7px 14px; border-radius: var(--kd-r-pill);
    font-size: 12px; font-weight: 800;
    letter-spacing: 0.08em; text-transform: uppercase;
    margin-bottom: var(--kd-s-5);
    width: fit-content;
    border: 1px solid rgba(255,255,255,.14);
}
.kd-ff-name {
    font-size: clamp(28px, 3.2vw, 40px);
    font-weight: 800; letter-spacing: -0.025em; line-height: 1.05;
    margin: 0 0 6px;
}
.kd-ff-loc {
    font-family: var(--kd-font-serif) !important;
    font-style: italic; font-weight: 500;
    font-size: var(--kd-fs-md); opacity: .88;
    margin: 0 0 var(--kd-s-5);
}
.kd-ff-quote {
    font-family: var(--kd-font-serif) !important;
    font-size: var(--kd-fs-lg);
    font-style: italic; font-weight: 500;
    line-height: 1.55; opacity: .96;
    margin: 0 0 var(--kd-s-6);
    border-left: 4px solid var(--kd-s-300);
    padding: 6px 0 6px 20px;
    max-width: 580px;
}
.kd-ff-meta { display: flex; gap: var(--kd-s-8); margin-bottom: var(--kd-s-6); flex-wrap: wrap; }
.kd-ff-mnum { font-size: var(--kd-fs-2xl); font-weight: 800; letter-spacing: -0.025em; line-height: 1; }
.kd-ff-mlbl { font-size: 11px; opacity: .8; text-transform: uppercase; letter-spacing: 0.06em; font-weight: 700; margin-top: 4px; }
.kd-ff-cta {
    background: #fff; color: var(--kd-g-800);
    padding: 13px 26px; border-radius: var(--kd-r-md); border: 0;
    font-weight: 800; font-size: 14px; cursor: pointer;
    width: fit-content;
    transition: all .18s var(--kd-ease);
    font-family: var(--kd-font-sans) !important;
}
.kd-ff-cta:hover { background: var(--kd-cream-100); transform: translateY(-1px); box-shadow: var(--kd-shadow-md); }

.kd-ff-right {
    background:
        radial-gradient(circle at 50% 50%, rgba(0,0,0,0) 0%, rgba(0,0,0,0.18) 100%);
    display: grid; place-items: center;
    padding: var(--kd-s-10); position: relative; z-index: 2;
}
.kd-ff-photo {
    width: 240px; height: 240px;
    border-radius: 50%;
    background: linear-gradient(135deg, #ffd2a4, #ff7a1a);
    color: #fff;
    display: grid; place-items: center;
    font-family: var(--kd-font-serif) !important;
    font-weight: 600;
    font-size: 84px;
    box-shadow: 0 20px 60px rgba(0,0,0,.35), 0 0 0 8px rgba(255,255,255,.18);
    position: relative;
}
.kd-ff-photo::after {
    content: "★"; position: absolute;
    top: 8px; right: 8px;
    width: 44px; height: 44px;
    border-radius: 50%;
    background: var(--kd-s-500);
    color: #fff;
    display: grid; place-items: center;
    font-size: 22px;
    box-shadow: 0 6px 14px rgba(0,0,0,.2);
}

/* -------------------- Product card -------------------- */
.kd-product-grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: var(--kd-s-4);
}
@media (max-width: 1100px) { .kd-product-grid { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 700px)  { .kd-product-grid { grid-template-columns: repeat(2, 1fr); } }
.kd-product {
    background: var(--kd-surface);
    border: 1.5px solid var(--kd-ink-100);
    border-radius: var(--kd-r-lg);
    padding: var(--kd-s-3);
    display: flex; flex-direction: column; gap: 8px;
    position: relative; cursor: pointer;
    transition: all .2s var(--kd-ease);
    overflow: hidden;
}
.kd-product:hover { border-color: var(--kd-g-300); transform: translateY(-4px); box-shadow: var(--kd-shadow-md); }
.kd-product-imgwrap {
    aspect-ratio: 1 / 1;
    background: linear-gradient(135deg, #fbf6e9, #f7eed1);
    border-radius: var(--kd-r-md);
    display: grid; place-items: center;
    font-size: 64px; position: relative;
}
.kd-product-tag {
    position: absolute; top: 8px; left: 8px;
    background: var(--kd-g-700); color: #fff;
    font-size: 10px; font-weight: 800;
    padding: 4px 8px; border-radius: 4px;
    letter-spacing: 0.06em; text-transform: uppercase;
    box-shadow: 0 2px 6px rgba(7,87,34,.3);
}
.kd-product-farmer {
    position: absolute; bottom: 8px; left: 8px; right: 8px;
    background: rgba(255,255,255,.94);
    backdrop-filter: blur(4px);
    padding: 4px 8px;
    border-radius: 4px;
    font-size: 10px;
    color: var(--kd-ink-700);
    font-weight: 600;
    text-align: center;
    letter-spacing: 0.02em;
}
.kd-product-farmer span { color: var(--kd-g-700); font-weight: 800; }
.kd-product-name { font-size: 14px; font-weight: 700; color: var(--kd-ink-900); letter-spacing: -0.005em; line-height: 1.3; }
.kd-product-prices { display: flex; align-items: baseline; gap: 7px; }
.kd-product-price  { font-size: var(--kd-fs-md); font-weight: 800; color: var(--kd-ink-900); letter-spacing: -0.015em; }
.kd-product-mrp    { font-size: 12px; color: var(--kd-ink-400); text-decoration: line-through; }
.kd-product-save   { font-size: 11px; color: var(--kd-s-700); font-weight: 800; background: var(--kd-s-50); padding: 2px 6px; border-radius: 3px; }
.kd-product-add {
    margin-top: 4px;
    background: var(--kd-g-600); color: #fff;
    border: 0; border-radius: var(--kd-r-sm);
    padding: 9px; font-weight: 800; font-size: 13px;
    cursor: pointer;
    transition: all .18s var(--kd-ease);
    font-family: var(--kd-font-sans) !important;
    letter-spacing: -0.005em;
}
.kd-product-add:hover { background: var(--kd-g-700); }

.kd-quality-badges { display: flex; gap: 4px; flex-wrap: wrap; }
.kd-q-badge {
    font-size: 10px; font-weight: 800;
    padding: 3px 7px; border-radius: 4px;
    letter-spacing: 0.04em; text-transform: uppercase;
}
.kd-q-organic { background: var(--kd-g-50); color: var(--kd-g-800); }
.kd-q-local   { background: var(--kd-s-50); color: var(--kd-s-700); }
.kd-q-fresh   { background: #e3effb; color: #1565c0; }
.kd-q-grade   { background: #f6e9ff; color: #7b1fa2; }

.kd-wishlist-btn {
    position: absolute;
    top: 8px; right: 8px;
    width: 32px; height: 32px;
    border-radius: 50%;
    background: rgba(255,255,255,.96);
    border: 1.5px solid var(--kd-ink-100);
    display: grid; place-items: center;
    cursor: pointer; z-index: 5;
    font-size: 14px;
    color: var(--kd-ink-400);
    transition: all .18s var(--kd-ease);
    box-shadow: var(--kd-shadow-xs);
}
.kd-wishlist-btn:hover { color: var(--kd-t-500); transform: scale(1.1); }
.kd-wishlist-btn.is-active { color: var(--kd-t-500); border-color: var(--kd-t-500); }

/* -------------------- Subscribe -------------------- */
.kd-sub-banner { max-width: var(--kd-max); margin: var(--kd-s-12) auto; padding: 0 var(--kd-s-5); }
.kd-sub-card {
    border-radius: var(--kd-r-2xl);
    overflow: hidden;
    background:
        radial-gradient(700px 350px at 100% 100%, rgba(255,174,92,.5) 0%, transparent 70%),
        linear-gradient(135deg, var(--kd-cream-100) 0%, #fffaf0 100%);
    border: 1.5px solid var(--kd-cream-200);
    padding: var(--kd-s-12);
    display: grid; grid-template-columns: 1.2fr 1fr;
    gap: var(--kd-s-10); align-items: center;
    position: relative; overflow: hidden;
}
@media (max-width: 800px) { .kd-sub-card { grid-template-columns: 1fr; padding: var(--kd-s-8); gap: var(--kd-s-6); } }
.kd-sub-eyebrow { color: var(--kd-s-700); font-size: 13px; font-weight: 800; letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 10px; }
.kd-sub-title { font-size: clamp(26px, 3vw, 40px); font-weight: 800; margin: 0 0 var(--kd-s-3); color: var(--kd-ink-900); letter-spacing: -0.025em; line-height: 1.1; }
.kd-sub-desc  { font-size: var(--kd-fs-md); color: var(--kd-ink-600); line-height: 1.6; margin: 0 0 var(--kd-s-5); }
.kd-sub-points { list-style: none; padding: 0; margin: 0 0 var(--kd-s-6); display: grid; gap: 8px; }
.kd-sub-points li { font-size: var(--kd-fs-base); color: var(--kd-ink-800); display: flex; align-items: center; gap: 10px; font-weight: 600; }
.kd-sub-points li::before {
    content: "✓"; color: #fff; font-weight: 800;
    background: var(--kd-g-600);
    width: 22px; height: 22px; border-radius: 50%;
    display: grid; place-items: center; font-size: 12px;
    flex-shrink: 0;
}
.kd-sub-mockup { background: var(--kd-surface); border-radius: var(--kd-r-xl); padding: var(--kd-s-6); box-shadow: var(--kd-shadow-md); }
.kd-sub-mockup-row { display: flex; justify-content: space-between; padding: 10px 0; border-bottom: 1px solid var(--kd-ink-100); font-size: 14px; }
.kd-sub-mockup-row:last-child { border: 0; padding-top: 14px; font-weight: 800; color: var(--kd-g-700); font-size: 16px; }
.kd-sub-mockup-row strong { color: var(--kd-ink-900); }

/* -------------------- Discover row -------------------- */
.kd-discover-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--kd-s-4); }
@media (max-width: 800px) { .kd-discover-grid { grid-template-columns: 1fr; } }
.kd-disc-tile {
    border-radius: var(--kd-r-xl);
    padding: var(--kd-s-8);
    color: #fff;
    display: flex; flex-direction: column; gap: var(--kd-s-2);
    min-height: 220px;
    cursor: pointer;
    transition: transform .22s var(--kd-ease), box-shadow .22s var(--kd-ease);
    position: relative; overflow: hidden;
}
.kd-disc-tile:hover { transform: translateY(-5px); box-shadow: var(--kd-shadow-lg); }
.kd-disc-tile.t-recipe { background: linear-gradient(135deg, var(--kd-s-500) 0%, var(--kd-s-700) 100%); }
.kd-disc-tile.t-b2b    { background: linear-gradient(135deg, #2a4d8c 0%, #15315e 100%); }
.kd-disc-tile.t-coins  { background: linear-gradient(135deg, #6b3cb5 0%, #3d2271 100%); }
.kd-disc-icon {
    width: 56px; height: 56px;
    border-radius: var(--kd-r-md);
    background: rgba(255,255,255,.2);
    display: grid; place-items: center;
    font-size: 28px;
    margin-bottom: var(--kd-s-2);
}
.kd-disc-title { font-size: var(--kd-fs-lg); font-weight: 800; margin: 0; letter-spacing: -0.015em; color: #fff; }
.kd-disc-sub { font-size: var(--kd-fs-sm); opacity: .92; margin: 4px 0 0; line-height: 1.55; color: #fff; }
.kd-disc-cta {
    margin-top: auto;
    background: rgba(255,255,255,.95);
    color: var(--kd-ink-900);
    border: 0; border-radius: var(--kd-r-sm);
    padding: 10px 18px; font-weight: 800; font-size: 13px;
    cursor: pointer; align-self: flex-start;
    font-family: var(--kd-font-sans) !important;
}

/* -------------------- Insights -------------------- */
.kd-insights-grid { display: grid; grid-template-columns: 1.3fr 1fr; gap: var(--kd-s-4); }
@media (max-width: 800px) { .kd-insights-grid { grid-template-columns: 1fr; } }
.kd-insight-card { background: var(--kd-surface); border: 1.5px solid var(--kd-ink-100); border-radius: var(--kd-r-lg); padding: var(--kd-s-6); }
.kd-insight-head { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: var(--kd-s-4); }
.kd-insight-title { font-size: var(--kd-fs-md); font-weight: 800; color: var(--kd-ink-900); margin: 0; letter-spacing: -0.015em; }
.kd-insight-sub { font-size: var(--kd-fs-sm); color: var(--kd-ink-500); margin: 3px 0 0; }
.kd-insight-tabs { display: flex; gap: 4px; }
.kd-insight-tab { background: var(--kd-ink-50); border: 0; padding: 5px 12px; border-radius: var(--kd-r-pill); font-size: 11px; font-weight: 700; color: var(--kd-ink-700); cursor: pointer; }
.kd-insight-tab.is-active { background: var(--kd-g-600); color: #fff; }
.kd-spark-rows { display: grid; gap: 10px; }
.kd-spark-row { display: grid; grid-template-columns: 1fr 100px 70px; align-items: center; gap: var(--kd-s-3); padding: 10px 0; border-bottom: 1px solid var(--kd-ink-100); }
.kd-spark-row:last-child { border: 0; }
.kd-spark-name { font-size: 14px; font-weight: 700; color: var(--kd-ink-900); }
.kd-spark-name .kd-spark-mini { font-size: 11px; color: var(--kd-ink-500); font-weight: 500; display: block; margin-top: 2px; }
.kd-spark-svg { width: 100px; height: 30px; }
.kd-spark-val { text-align: right; font-size: 14px; font-weight: 800; }
.kd-spark-up   { color: var(--kd-g-600); }
.kd-spark-down { color: var(--kd-t-500); }
.kd-calendar-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--kd-s-3); }
.kd-cal-item { background: var(--kd-cream-50); border: 1.5px solid var(--kd-cream-200); border-radius: var(--kd-r-sm); padding: 12px 14px; }
.kd-cal-month { font-size: 11px; color: var(--kd-s-700); font-weight: 800; letter-spacing: 0.08em; text-transform: uppercase; }
.kd-cal-crop { font-size: 14px; font-weight: 800; color: var(--kd-ink-900); margin-top: 3px; }
.kd-cal-stage { font-size: 11px; color: var(--kd-ink-500); margin-top: 3px; font-weight: 600; }

/* -------------------- Testimonials -------------------- */
.kd-testimonial-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--kd-s-4); }
@media (max-width: 900px) { .kd-testimonial-grid { grid-template-columns: 1fr; } }
.kd-testimonial { background: var(--kd-surface); border: 1.5px solid var(--kd-ink-100); border-radius: var(--kd-r-lg); padding: var(--kd-s-6); display: flex; flex-direction: column; gap: var(--kd-s-3); transition: all .2s var(--kd-ease); }
.kd-testimonial:hover { border-color: var(--kd-g-200); transform: translateY(-2px); box-shadow: var(--kd-shadow-sm); }
.kd-test-stars { color: var(--kd-s-500); font-size: 16px; letter-spacing: 3px; }
.kd-test-quote { font-family: var(--kd-font-serif) !important; font-size: var(--kd-fs-md); color: var(--kd-ink-900); line-height: 1.55; margin: 0; font-style: italic; font-weight: 500; }
.kd-test-author { display: flex; align-items: center; gap: 12px; margin-top: auto; }
.kd-test-avatar { width: 42px; height: 42px; border-radius: 50%; background: linear-gradient(135deg, var(--kd-g-300), var(--kd-g-600)); color: #fff; display: grid; place-items: center; font-weight: 800; font-size: 14px; }
.kd-test-name { font-size: 14px; font-weight: 800; color: var(--kd-ink-900); }
.kd-test-loc  { font-size: 12px; color: var(--kd-ink-500); }

/* -------------------- FAQ -------------------- */
.kd-faq-grid { display: grid; gap: var(--kd-s-2); max-width: 920px; margin: 0 auto; }
.kd-faq-item { background: var(--kd-surface); border: 1.5px solid var(--kd-ink-100); border-radius: var(--kd-r-md); overflow: hidden; }
.kd-faq-q {
    width: 100%; text-align: left;
    background: transparent; border: 0;
    padding: 16px 22px;
    font-size: var(--kd-fs-md); font-weight: 700;
    color: var(--kd-ink-900);
    cursor: pointer;
    display: flex; justify-content: space-between; align-items: center;
    gap: 14px;
    font-family: var(--kd-font-sans) !important;
}
.kd-faq-q::after { content: "+"; font-size: 24px; color: var(--kd-ink-400); transition: transform .25s var(--kd-ease); font-weight: 600; }
.kd-faq-item.is-open .kd-faq-q::after { transform: rotate(45deg); color: var(--kd-g-700); }
.kd-faq-a {
    max-height: 0; overflow: hidden;
    padding: 0 22px;
    color: var(--kd-ink-600);
    font-size: var(--kd-fs-base);
    line-height: 1.65;
    transition: max-height .28s var(--kd-ease), padding .28s var(--kd-ease);
}
.kd-faq-item.is-open .kd-faq-a { max-height: 240px; padding: 0 22px 18px; }

/* -------------------- Big CTA -------------------- */
.kd-bigcta { max-width: var(--kd-max); margin: var(--kd-s-12) auto var(--kd-s-10); padding: 0 var(--kd-s-5); }
.kd-bigcta-card {
    border-radius: var(--kd-r-2xl);
    background:
        radial-gradient(700px 400px at 80% 0%, rgba(255,174,92,.32) 0%, transparent 70%),
        radial-gradient(500px 300px at 0% 100%, rgba(19,138,62,.32) 0%, transparent 60%),
        linear-gradient(135deg, var(--kd-ink-900) 0%, var(--kd-g-900) 100%);
    color: #fff;
    padding: var(--kd-s-14);
    text-align: center;
    position: relative; overflow: hidden;
}
@media (max-width: 700px) { .kd-bigcta-card { padding: var(--kd-s-10) var(--kd-s-6); } }
.kd-bigcta-eyebrow { color: var(--kd-s-300); font-size: 12px; font-weight: 800; letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 16px; }
.kd-bigcta-title { font-size: clamp(28px, 4vw, 48px); font-weight: 800; margin: 0 0 var(--kd-s-3); letter-spacing: -0.03em; line-height: 1.1; }
.kd-bigcta-title em { font-family: var(--kd-font-serif) !important; font-style: italic; font-weight: 600; color: var(--kd-s-300); }
.kd-bigcta-sub { font-size: var(--kd-fs-md); opacity: .88; margin: 0 0 var(--kd-s-8); max-width: 580px; margin-left: auto; margin-right: auto; line-height: 1.6; }
.kd-bigcta-input {
    display: inline-flex;
    background: var(--kd-surface); border-radius: var(--kd-r-pill);
    padding: 6px;
    box-shadow: 0 14px 36px rgba(0,0,0,.35);
    align-items: center; gap: 4px;
    width: 100%; max-width: 460px;
}
.kd-bigcta-input input { flex: 1; border: 0; outline: 0; padding: 12px 22px; font-size: 15px; background: transparent; color: var(--kd-ink-900); font-family: var(--kd-font-sans) !important; font-weight: 600; }
.kd-bigcta-input button { background: var(--kd-g-600); color: #fff; border: 0; border-radius: var(--kd-r-pill); padding: 12px 26px; font-weight: 800; font-size: 14px; cursor: pointer; font-family: var(--kd-font-sans) !important; }
.kd-bigcta-input button:hover { background: var(--kd-g-700); }

/* -------------------- Skeleton -------------------- */
.kd-skel { background: linear-gradient(90deg, var(--kd-ink-50) 0%, var(--kd-ink-100) 50%, var(--kd-ink-50) 100%); background-size: 200% 100%; animation: kd-shimmer 1.4s infinite; border-radius: var(--kd-r-sm); }
@keyframes kd-shimmer { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }
.kd-skel-card { aspect-ratio: 4 / 5; }

/* -------------------- Modals -------------------- */
.kd-modal-backdrop {
    position: fixed; inset: 0;
    background: rgba(10, 20, 16, .55);
    backdrop-filter: blur(8px);
    z-index: 9998;
    display: none;
    align-items: flex-start; justify-content: center;
    padding-top: 8vh; padding-left: var(--kd-s-3); padding-right: var(--kd-s-3);
}
.kd-modal-backdrop.is-open { display: flex; }
.kd-modal { background: var(--kd-surface); border-radius: var(--kd-r-xl); width: min(580px, 100%); box-shadow: 0 30px 80px rgba(0,0,0,.32); overflow: hidden; animation: kd-pop .25s var(--kd-ease); }
@keyframes kd-pop { from { transform: translateY(20px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
.kd-modal-head { padding: var(--kd-s-6); color: #fff; display: flex; align-items: center; gap: var(--kd-s-3); position: relative; }
.kd-modal-head.h-ai { background: linear-gradient(135deg, var(--kd-g-700) 0%, var(--kd-g-500) 100%); }
.kd-modal-head.h-wallet { background: linear-gradient(135deg, #6b3cb5 0%, #3d2271 100%); }
.kd-modal-head.h-b2b { background: linear-gradient(135deg, #2a4d8c 0%, #15315e 100%); }
.kd-modal-head h3 { margin: 0; font-size: var(--kd-fs-md); font-weight: 800; letter-spacing: -0.015em; color: #fff; }
.kd-modal-head p  { margin: 3px 0 0; font-size: 13px; opacity: .9; color: #fff; }
.kd-modal-head .kd-modal-icon { width: 42px; height: 42px; border-radius: var(--kd-r-md); background: rgba(255,255,255,.18); display: grid; place-items: center; font-size: 20px; }
.kd-modal-close { position: absolute; top: 16px; right: 16px; background: rgba(255,255,255,.16); border: 0; color: #fff; font-size: 22px; width: 32px; height: 32px; border-radius: 50%; cursor: pointer; display: grid; place-items: center; }
.kd-modal-close:hover { background: rgba(255,255,255,.28); }
.kd-modal-body { padding: var(--kd-s-6); }

.kd-ai-input-wrap { position: relative; }
.kd-ai-input { width: 100%; border: 1.5px solid var(--kd-ink-100); border-radius: var(--kd-r-md); padding: 14px 56px 14px 18px; font-size: 15px; outline: none; transition: all .18s var(--kd-ease); font-family: var(--kd-font-sans) !important; font-weight: 500; }
.kd-ai-input:focus { border-color: var(--kd-g-500); box-shadow: var(--kd-shadow-glow); }
.kd-ai-mic { position: absolute; right: 8px; top: 50%; transform: translateY(-50%); width: 38px; height: 38px; border-radius: 50%; border: 0; background: var(--kd-g-50); color: var(--kd-g-700); cursor: pointer; display: grid; place-items: center; font-size: 16px; transition: all .18s var(--kd-ease); }
.kd-ai-mic:hover { background: var(--kd-g-100); }
.kd-ai-mic.is-listening { background: var(--kd-t-50); color: var(--kd-t-500); animation: kd-pulse 1s infinite; }
@keyframes kd-pulse { 0%,100% { box-shadow: 0 0 0 0 rgba(196,69,54,.5); } 50% { box-shadow: 0 0 0 12px rgba(196,69,54,0); } }
.kd-ai-sugg-label { font-size: 12px; color: var(--kd-ink-500); text-transform: uppercase; letter-spacing: 0.08em; margin: 16px 0 8px; font-weight: 800; }
.kd-ai-sugg-list { display: flex; flex-wrap: wrap; gap: 6px; }
.kd-ai-sugg { background: var(--kd-cream-50); border: 1.5px solid var(--kd-cream-200); color: var(--kd-ink-900); padding: 7px 14px; border-radius: var(--kd-r-pill); font-size: 13px; font-weight: 700; cursor: pointer; transition: all .18s var(--kd-ease); font-family: var(--kd-font-sans) !important; }
.kd-ai-sugg:hover { background: var(--kd-s-50); border-color: var(--kd-s-300); }
.kd-ai-results { margin-top: 16px; max-height: 280px; overflow-y: auto; }
.kd-ai-result-item { display: flex; gap: 12px; padding: 12px 10px; border-bottom: 1px solid var(--kd-ink-100); cursor: pointer; border-radius: var(--kd-r-sm); }
.kd-ai-result-item:hover { background: var(--kd-ink-50); }
.kd-ai-result-img { width: 48px; height: 48px; border-radius: var(--kd-r-sm); background: var(--kd-cream-50); display: grid; place-items: center; font-size: 24px; flex-shrink: 0; }

.kd-wallet-balance { text-align: center; padding: var(--kd-s-4) 0 var(--kd-s-5); }
.kd-wallet-points { font-size: 56px; font-weight: 800; color: var(--kd-ink-900); letter-spacing: -0.04em; line-height: 1; }
.kd-wallet-eq { font-size: var(--kd-fs-base); color: var(--kd-ink-500); margin-top: 6px; }
.kd-wallet-row { display: flex; justify-content: space-between; padding: 12px 0; border-bottom: 1px solid var(--kd-ink-100); font-size: 14px; }
.kd-wallet-row:last-of-type { border: 0; }
.kd-wallet-row .kd-w-label { color: var(--kd-ink-500); font-weight: 600; }
.kd-wallet-row .kd-w-value { font-weight: 800; color: var(--kd-ink-900); }

.kd-rfq-row { margin-bottom: var(--kd-s-4); }
.kd-rfq-row label { display: block; font-size: 12px; font-weight: 800; color: var(--kd-ink-700); margin-bottom: 6px; text-transform: uppercase; letter-spacing: 0.06em; }
.kd-rfq-row input, .kd-rfq-row textarea, .kd-rfq-row select { width: 100%; border: 1.5px solid var(--kd-ink-100); border-radius: var(--kd-r-sm); padding: 12px 14px; font-size: 15px; outline: none; background: var(--kd-surface); transition: all .18s var(--kd-ease); font-family: var(--kd-font-sans) !important; font-weight: 500; }
.kd-rfq-row input:focus, .kd-rfq-row textarea:focus, .kd-rfq-row select:focus { border-color: var(--kd-g-500); box-shadow: var(--kd-shadow-glow); }
.kd-modal-submit { width: 100%; background: var(--kd-g-600); color: #fff; border: 0; border-radius: var(--kd-r-md); padding: 14px; font-weight: 800; font-size: 15px; cursor: pointer; transition: background .18s var(--kd-ease); font-family: var(--kd-font-sans) !important; }
.kd-modal-submit:hover { background: var(--kd-g-700); }

img.kd-lazy { opacity: 0; transition: opacity .35s var(--kd-ease); }
img.kd-lazy.kd-loaded { opacity: 1; }

/* ============================================================
   BUG-FIX PATCH (high specificity, end-of-file)
   ============================================================ */

/* 1. White text contrast on dark sections — force pure white,
      defeat any cascading body color rule */
.kd-impact-card, .kd-impact-card * ,
.kd-ff-card, .kd-ff-card *,
.kd-bigcta-card, .kd-bigcta-card *,
.kd-track-card, .kd-track-card * {
    /* default: inherit */
}
.kd-impact-eyebrow, .kd-impact-title, .kd-impact-sub,
.kd-impact-num, .kd-impact-num *, .kd-impact-lbl, .kd-impact-tagline,
.kd-impact-tagline * { color: #fff !important; }
.kd-impact-title em { color: var(--kd-s-300) !important; }
.kd-impact-tagline strong { color: var(--kd-s-300) !important; }

.kd-ff-eyebrow, .kd-ff-name, .kd-ff-loc, .kd-ff-quote,
.kd-ff-meta, .kd-ff-meta *, .kd-ff-mnum, .kd-ff-mlbl { color: #fff !important; }
.kd-ff-loc { opacity: .92 !important; }

.kd-bigcta-card, .kd-bigcta-card h2, .kd-bigcta-card p,
.kd-bigcta-eyebrow { color: #fff !important; }
.kd-bigcta-eyebrow { color: var(--kd-s-300) !important; }
.kd-bigcta-title em { color: var(--kd-s-300) !important; }
.kd-bigcta-input input { color: var(--kd-ink-900) !important; }
.kd-bigcta-input button { color: #fff !important; }

.kd-track-card h4, .kd-track-card p { color: #fff !important; }
.kd-track-cta { color: var(--kd-g-700) !important; }

/* Tone down the wash-out overlays on dark cards */
.kd-impact-card {
    background:
        linear-gradient(135deg, var(--kd-g-800) 0%, var(--kd-g-700) 100%) !important;
}
.kd-bigcta-card {
    background:
        linear-gradient(135deg, var(--kd-ink-900) 0%, var(--kd-g-900) 100%) !important;
}
.kd-ff-card {
    background:
        linear-gradient(135deg, var(--kd-g-800) 0%, var(--kd-g-600) 100%) !important;
}

/* 2. Mandi marquee — wrap track so it can't overlap the label */
.kd-mandi-bar { gap: 14px; padding: 10px 14px !important; }
.kd-mandi-label {
    position: relative; z-index: 2;
    flex: 0 0 auto !important;
}
.kd-mandi-track-wrap {
    flex: 1 1 auto;
    min-width: 0;
    overflow: hidden;
    position: relative;
    mask-image: linear-gradient(90deg, transparent 0, #000 24px, #000 calc(100% - 24px), transparent 100%);
    -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 24px, #000 calc(100% - 24px), transparent 100%);
}

/* 3. Broken-image fallbacks — hide the broken icon, leave a clean tile */
.category-image-container img.category-image,
.brand-container img,
.product-grid-container img,
#productgrid img,
#divResentOrder img {
    /* If src fails, browsers still render alt + broken icon — kill that look */
    color: transparent;
    font-size: 0;
}
/* If the image is missing entirely, the wrapper still has a clean tinted bg */
.category-grid-container.main-categories-section .category-image-container::before {
    content: "🌾";
    font-size: 38px;
    opacity: .35;
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    z-index: 0;
    color: var(--kd-g-700);
}
.category-grid-container.main-categories-section .category-image-container { position: relative !important; }
.category-grid-container.main-categories-section .category-image { position: relative; z-index: 1; }
.category-grid-container.main-categories-section .category-image[src=""],
.category-grid-container.main-categories-section .category-image:not([src]) { display: none; }

/* Brand circles (in brand-container) clean fallback */
.brand-container .brand-item, .brand-container > * {
    background: var(--kd-surface) !important;
}
.brand-container img {
    background: var(--kd-cream-50);
}

/* Empty single-card section grace (Shop By Store) */
#GetShop:empty::before,
#divResentOrder:empty::before {
    content: "";
    display: block;
    height: 0;
}

/* 4. Hero — tighter, drop the awkward emoji orbs, simpler right side */
.kd-hero-card { min-height: 360px !important; }
@media (min-width: 901px) { .kd-hero-card { grid-template-columns: 1.3fr 1fr !important; } }
.kd-hero-left { padding: var(--kd-s-10) var(--kd-s-10) !important; }
@media (max-width: 700px) { .kd-hero-left { padding: var(--kd-s-6) var(--kd-s-5) !important; } }
.kd-hero-title { font-size: clamp(26px, 3.6vw, 44px) !important; line-height: 1.08 !important; }
.kd-hero-title .kd-line { display: inline; }
.kd-hero-sub { font-size: var(--kd-fs-base) !important; }
.kd-hero-eyebrow { padding: 5px 12px !important; font-size: 11px !important; margin-bottom: var(--kd-s-3) !important; }

/* Drop the playful orbs — replace with a clean composed scene */
.kd-hero-orb { display: none !important; }
.kd-hero-scene::before { display: none !important; } /* sun */
.kd-hero-scene::after { display: none !important; }  /* horizon */
.kd-hero-right {
    background:
        radial-gradient(400px 300px at 60% 40%, rgba(19,138,62,.10) 0%, transparent 70%),
        linear-gradient(135deg, var(--kd-cream-50) 0%, #fff 100%) !important;
    padding: var(--kd-s-6) !important;
}
.kd-hero-right::before {
    content: "";
    position: absolute;
    inset: 18%;
    border-radius: 50%;
    background:
        radial-gradient(circle at 35% 30%, rgba(255,255,255,.7), transparent 50%),
        linear-gradient(135deg, var(--kd-g-100) 0%, var(--kd-g-300) 100%);
    box-shadow: 0 30px 80px rgba(7,87,34,.18);
}
.kd-hero-right::after {
    content: "🌾";
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    font-size: 96px;
    z-index: 1;
    filter: drop-shadow(0 8px 20px rgba(7,87,34,.22));
}
.kd-hero-floatcard.f1 { top: 14% !important; right: 8% !important; }
.kd-hero-floatcard.f2 { bottom: 14% !important; left: 6% !important; }

/* 5. Finder — stats simpler, stack on small */
.kd-finder-head { align-items: center !important; }
.kd-finder-stats {
    background: var(--kd-g-50) !important;
    border-radius: var(--kd-r-md) !important;
    padding: 10px 16px !important;
    border: 1px solid var(--kd-g-100) !important;
}
.kd-finder-stats .num { color: var(--kd-g-700) !important; font-size: var(--kd-fs-md) !important; }
.kd-finder-stats .lbl { font-size: 10px !important; }
@media (max-width: 700px) {
    .kd-finder-head { flex-direction: column; align-items: flex-start !important; }
    .kd-finder-stats { width: 100%; justify-content: space-around; }
}
/* Hide the bare "Loading..." / "No cities found" text dribble */
#loadingMessage { display: none !important; }
#filterCityChipsContainer:empty::before {
    content: "Showing all stores";
    font-size: 13px; color: var(--kd-ink-500); font-weight: 600; padding: 0 8px;
}

/* 6. Pillar numbers (01/02/03) — make readable, not faint mint */
.kd-why-num { color: var(--kd-g-400) !important; opacity: .55; }

/* 7. Header pills — slightly tighter so they don't crowd hero */
.kd-header-pills { margin-top: var(--kd-s-2) !important; margin-bottom: var(--kd-s-3) !important; }
.kd-pill { padding: 7px 14px !important; font-size: 13px !important; }

/* 8. Section titles — guard against site CSS bleeding in */
.kd-section-title, .kd-section-title em { color: var(--kd-ink-900) !important; }
.kd-section-title em { color: var(--kd-g-700) !important; }
.kd-section-eyebrow { color: var(--kd-s-700) !important; }
.kd-section-sub { color: var(--kd-ink-600) !important; }

/* ============================================================
   HERO v3 — typography-led + live-activity feed
   ============================================================ */

/* Override the v2 hero shell + drop the right-side scene completely */
.kd-hero { margin: var(--kd-s-5) auto var(--kd-s-8) !important; }

.kd-hero-card {
    background:
        radial-gradient(800px 500px at 90% -10%, rgba(19,138,62,0.08) 0%, transparent 60%),
        radial-gradient(600px 400px at -10% 110%, rgba(255,122,26,0.06) 0%, transparent 60%),
        var(--kd-surface) !important;
    border: 1px solid var(--kd-ink-100) !important;
    border-radius: var(--kd-r-2xl) !important;
    grid-template-columns: 1.1fr 1fr !important;
    min-height: 380px !important;
    box-shadow: var(--kd-shadow-sm) !important;
    overflow: hidden !important;
}
@media (max-width: 900px) { .kd-hero-card { grid-template-columns: 1fr !important; min-height: auto !important; } }

.kd-hero-left {
    padding: 32px 36px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
}
@media (max-width: 700px) { .kd-hero-left { padding: 24px 20px !important; } }

.kd-hero-eyebrow {
    background: var(--kd-g-50) !important;
    color: var(--kd-g-800) !important;
    border: 1px solid var(--kd-g-100) !important;
    padding: 5px 12px !important;
    font-size: 11px !important;
    font-weight: 800 !important;
    letter-spacing: 0.06em !important;
    margin-bottom: 16px !important;
    text-transform: uppercase !important;
}
.kd-hero-eyebrow .kd-dot {
    width: 8px !important; height: 8px !important;
    background: var(--kd-g-500) !important;
    box-shadow: 0 0 0 4px rgba(19,138,62,.18) !important;
}

.kd-hero-title {
    font-family: var(--kd-font-sans) !important;
    font-size: clamp(28px, 3.6vw, 44px) !important;
    font-weight: 800 !important;
    line-height: 1.06 !important;
    letter-spacing: -0.03em !important;
    color: var(--kd-ink-900) !important;
    margin: 0 0 12px !important;
}
.kd-hero-title .kd-accent {
    font-family: var(--kd-font-serif) !important;
    font-style: italic !important;
    font-weight: 600 !important;
    color: var(--kd-g-700) !important;
    position: relative;
    padding: 0 4px;
}
.kd-hero-title .kd-accent::after {
    content: ""; position: absolute;
    left: 4px; right: 4px; bottom: 6px; height: 14px;
    background: var(--kd-s-300); opacity: .35;
    z-index: -1; border-radius: 4px;
}

.kd-hero-sub {
    font-size: 15px !important;
    color: var(--kd-ink-600) !important;
    line-height: 1.55 !important;
    margin: 0 0 20px !important;
    max-width: 480px !important;
    font-weight: 500 !important;
}
.kd-hero-sub strong { color: var(--kd-ink-900) !important; font-weight: 700 !important; }

.kd-hero-ctas { display: flex !important; gap: 10px !important; flex-wrap: wrap !important; margin-bottom: 22px !important; }

.kd-hero-trust {
    display: flex !important;
    gap: 28px !important;
    padding-top: 16px !important;
    border-top: 1px solid var(--kd-ink-100) !important;
    flex-wrap: wrap !important;
}
.kd-htrust-num {
    font-size: 22px !important;
    font-weight: 800 !important;
    color: var(--kd-ink-900) !important;
    letter-spacing: -0.025em !important;
    line-height: 1 !important;
}
.kd-htrust-num .kd-unit { color: var(--kd-g-600) !important; }
.kd-htrust-lbl {
    font-size: 11px !important;
    color: var(--kd-ink-500) !important;
    margin-top: 4px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.06em !important;
    font-weight: 700 !important;
}

/* Right side — live activity */
.kd-hero-right {
    background: linear-gradient(160deg, #fbf9f1 0%, #fff 100%) !important;
    padding: 22px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-left: 1px solid var(--kd-ink-100) !important;
}
.kd-hero-right::before, .kd-hero-right::after { display: none !important; }
@media (max-width: 900px) { .kd-hero-right { border-left: 0 !important; border-top: 1px solid var(--kd-ink-100) !important; padding: 24px !important; } }

.kd-hero-live {
    width: 100%; max-width: 380px;
    background: var(--kd-surface);
    border: 1px solid var(--kd-ink-100);
    border-radius: var(--kd-r-xl);
    box-shadow: 0 18px 48px rgba(10,20,16,0.08), 0 4px 12px rgba(10,20,16,0.04);
    overflow: hidden;
}

.kd-hl-head {
    display: flex; align-items: center; gap: 8px;
    padding: 14px 18px;
    border-bottom: 1px solid var(--kd-ink-100);
    background: var(--kd-bg-soft);
}
.kd-hl-dot {
    width: 8px; height: 8px; border-radius: 50%;
    background: var(--kd-t-500);
    box-shadow: 0 0 0 4px rgba(196,69,54,0.18);
    animation: kd-blink 1.4s ease-in-out infinite;
}
.kd-hl-title {
    font-size: 12px;
    font-weight: 800;
    color: var(--kd-ink-900);
    letter-spacing: 0.06em;
    text-transform: uppercase;
}
.kd-hl-time {
    margin-left: auto;
    font-size: 11px;
    color: var(--kd-ink-500);
    font-weight: 600;
}

.kd-hl-list {
    height: 264px;
    overflow: hidden;
    position: relative;
}

.kd-hl-row {
    display: flex; gap: 12px;
    padding: 14px 18px;
    border-bottom: 1px solid var(--kd-ink-100);
    transition: all .4s var(--kd-ease);
    background: var(--kd-surface);
}
.kd-hl-row:last-child { border-bottom: 0; }
.kd-hl-row.is-new {
    transform: translateY(-100%);
    opacity: 0;
}
.kd-hl-row.is-leaving {
    opacity: 0;
    transform: scale(0.96);
    max-height: 0;
    padding-top: 0;
    padding-bottom: 0;
    overflow: hidden;
    border-bottom: 0;
}

.kd-hl-avatar {
    width: 36px; height: 36px;
    border-radius: 50%;
    color: #fff;
    display: grid; place-items: center;
    font-weight: 800;
    font-size: 12px;
    flex-shrink: 0;
    letter-spacing: -0.01em;
    box-shadow: inset 0 -2px 4px rgba(0,0,0,.12);
}

.kd-hl-body { flex: 1; min-width: 0; }
.kd-hl-name {
    font-size: 13px;
    font-weight: 800;
    color: var(--kd-ink-900);
    letter-spacing: -0.005em;
}
.kd-hl-loc {
    font-weight: 600;
    color: var(--kd-ink-500);
    font-size: 12px;
}
.kd-hl-action {
    font-size: 12px;
    color: var(--kd-ink-700);
    margin-top: 2px;
    font-weight: 500;
    line-height: 1.4;
}
.kd-hl-arrow {
    color: var(--kd-ink-400);
    margin: 0 4px;
}
.kd-hl-paid {
    font-size: 11px;
    color: var(--kd-g-700);
    margin-top: 6px;
    font-weight: 600;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: var(--kd-g-50);
    padding: 3px 8px;
    border-radius: 4px;
}
.kd-hl-paid strong { font-weight: 800; }

.kd-hl-foot {
    padding: 12px 18px;
    background: var(--kd-bg-soft);
    border-top: 1px solid var(--kd-ink-100);
    display: flex; align-items: baseline; gap: 6px;
}
.kd-hl-foot-num {
    font-size: 18px;
    font-weight: 800;
    color: var(--kd-g-700);
    letter-spacing: -0.02em;
}
.kd-hl-foot-lbl {
    font-size: 12px;
    color: var(--kd-ink-600);
    font-weight: 600;
}

/* ============================================================
   CARD #2 — Welcome coupon
   Visual language: same as hero (cream surface, ink-100 border,
   saffron warmth on the offer side, serif italic accent)
   ============================================================ */
.kd-coupon { max-width: var(--kd-max); margin: 0 auto var(--kd-s-5) !important; padding: 0 var(--kd-s-5) !important; }

.kd-coupon-card {
    background:
        radial-gradient(400px 200px at 100% 50%, rgba(255,122,26,0.08) 0%, transparent 65%),
        linear-gradient(135deg, var(--kd-cream-50) 0%, #fff 100%);
    border: 1px solid var(--kd-cream-200);
    border-radius: var(--kd-r-lg);
    padding: 16px 20px;
    display: flex;
    align-items: center;
    gap: 18px;
    box-shadow: var(--kd-shadow-xs);
    position: relative;
    overflow: hidden;
}
.kd-coupon-card::before {
    content: "";
    position: absolute;
    left: 0; top: 0; bottom: 0;
    width: 4px;
    background: linear-gradient(180deg, var(--kd-s-300), var(--kd-s-500));
}
@media (max-width: 700px) {
    .kd-coupon-card { flex-wrap: wrap; gap: 14px; padding: 16px; }
}

.kd-coupon-icon {
    width: 44px; height: 44px;
    border-radius: var(--kd-r-md);
    background: var(--kd-s-50);
    color: var(--kd-s-600);
    display: grid; place-items: center;
    flex-shrink: 0;
    border: 1px solid #ffd9b3;
}

.kd-coupon-text {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.kd-coupon-label {
    font-size: 11px;
    font-weight: 800;
    color: var(--kd-s-700);
    letter-spacing: 0.08em;
    text-transform: uppercase;
}
.kd-coupon-line {
    font-size: 14px;
    color: var(--kd-ink-800);
    font-weight: 500;
    line-height: 1.45;
}
.kd-coupon-line strong {
    font-weight: 800;
    color: var(--kd-ink-900);
}
.kd-coupon-line em {
    font-family: var(--kd-font-serif) !important;
    font-style: italic;
    font-weight: 500;
    color: var(--kd-ink-700);
}

.kd-coupon-action {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-shrink: 0;
}
@media (max-width: 700px) {
    .kd-coupon-action { width: 100%; justify-content: space-between; }
}
.kd-coupon-codelabel {
    font-size: 11px;
    font-weight: 700;
    color: var(--kd-ink-500);
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.kd-coupon-code {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: var(--kd-surface);
    border: 1.5px dashed var(--kd-s-500);
    color: var(--kd-s-700);
    padding: 7px 14px;
    border-radius: var(--kd-r-sm);
    font-family: 'JetBrains Mono', 'Plus Jakarta Sans', monospace !important;
    font-weight: 800;
    font-size: 13px;
    letter-spacing: 0.04em;
    cursor: pointer;
    transition: all .18s var(--kd-ease);
}
.kd-coupon-code:hover {
    background: var(--kd-s-500);
    color: #fff;
    border-style: solid;
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(255,122,26,0.28);
}
.kd-coupon-code.is-copied {
    background: var(--kd-g-500);
    border-color: var(--kd-g-500);
    border-style: solid;
    color: #fff;
}
.kd-coupon-copy { opacity: .85; }

/* ============================================================
   CARD #3 — Delivery slot picker
   ============================================================ */
.kd-slot { max-width: var(--kd-max); margin: 0 auto var(--kd-s-8) !important; padding: 0 var(--kd-s-5) !important; }

.kd-slot-card {
    background: var(--kd-surface);
    border: 1px solid var(--kd-ink-100);
    border-radius: var(--kd-r-xl);
    padding: 22px 24px 24px;
    box-shadow: var(--kd-shadow-xs);
}

.kd-slot-head {
    display: flex;
    align-items: center;
    gap: 14px;
    padding-bottom: 18px;
    margin-bottom: 18px;
    border-bottom: 1px solid var(--kd-ink-100);
}
.kd-slot-icon {
    width: 42px; height: 42px;
    border-radius: var(--kd-r-md);
    background: var(--kd-g-50);
    color: var(--kd-g-700);
    display: grid; place-items: center;
    flex-shrink: 0;
    border: 1px solid var(--kd-g-100);
}
.kd-slot-title-wrap { flex: 1; min-width: 0; }
.kd-slot-eyebrow {
    font-size: 11px;
    font-weight: 800;
    color: var(--kd-g-700);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: 2px;
}
.kd-slot-title {
    font-size: 17px;
    font-weight: 800;
    color: var(--kd-ink-900);
    letter-spacing: -0.015em;
    line-height: 1.3;
}
.kd-slot-title em {
    font-family: var(--kd-font-serif) !important;
    font-style: italic;
    font-weight: 600;
    color: var(--kd-g-700);
}
.kd-slot-summary {
    text-align: right;
    flex-shrink: 0;
    padding-left: 14px;
    border-left: 1px solid var(--kd-ink-100);
}
@media (max-width: 600px) {
    .kd-slot-head { flex-wrap: wrap; }
    .kd-slot-summary { padding-left: 0; border-left: 0; text-align: left; width: 100%; padding-top: 8px; }
}
.kd-slot-summary-num {
    font-size: 18px;
    font-weight: 800;
    color: var(--kd-ink-900);
    letter-spacing: -0.02em;
    line-height: 1;
}
.kd-slot-summary-lbl {
    font-size: 11px;
    color: var(--kd-ink-500);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-weight: 700;
    margin-top: 4px;
}

.kd-slot-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
}
@media (max-width: 900px) { .kd-slot-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .kd-slot-grid { grid-template-columns: 1fr; } }

.kd-slot-tile {
    background: var(--kd-surface);
    border: 1.5px solid var(--kd-ink-100);
    border-radius: var(--kd-r-md);
    padding: 14px 16px;
    cursor: pointer;
    transition: all .18s var(--kd-ease);
    position: relative;
    text-align: left;
    font-family: var(--kd-font-sans) !important;
    display: flex;
    flex-direction: column;
    gap: 4px;
    overflow: hidden;
}
.kd-slot-tile:hover {
    border-color: var(--kd-g-300);
    transform: translateY(-2px);
    box-shadow: var(--kd-shadow-sm);
}
.kd-slot-tile.is-active {
    border-color: var(--kd-g-600);
    background: var(--kd-g-50);
    box-shadow: 0 0 0 3px rgba(19,138,62,0.12);
}

.kd-slot-tile-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
}
.kd-slot-time {
    font-size: 14px;
    font-weight: 800;
    color: var(--kd-ink-900);
    letter-spacing: -0.01em;
    line-height: 1.2;
}
.kd-slot-badge {
    background: var(--kd-s-50);
    color: var(--kd-s-700);
    font-size: 9px;
    font-weight: 800;
    padding: 2px 6px;
    border-radius: 4px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    white-space: nowrap;
    border: 1px solid #ffe1bd;
}
.kd-slot-window {
    font-size: 12px;
    color: var(--kd-ink-500);
    font-weight: 600;
    margin-bottom: 6px;
}

.kd-slot-foot {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 6px;
    padding-top: 6px;
    border-top: 1px dashed var(--kd-ink-100);
    margin-top: 4px;
}
.kd-slot-fee {
    font-size: 12px;
    font-weight: 800;
    letter-spacing: -0.005em;
}
.kd-slot-fee.is-free { color: var(--kd-g-700); }
.kd-slot-fee.is-paid { color: var(--kd-s-700); }
.kd-slot-feenote {
    font-weight: 600;
    color: var(--kd-ink-500);
    font-size: 11px;
}
.kd-slot-cap {
    font-size: 10px;
    color: var(--kd-ink-500);
    font-weight: 600;
    display: inline-flex;
    align-items: center;
    gap: 4px;
}
.kd-slot-cap-dot {
    width: 6px; height: 6px; border-radius: 50%;
    background: var(--kd-g-500);
    box-shadow: 0 0 0 3px rgba(19,138,62,0.15);
}

/* Active checkmark in top-right of selected tile */
.kd-slot-check {
    position: absolute;
    top: 10px; right: 10px;
    width: 22px; height: 22px;
    border-radius: 50%;
    background: var(--kd-g-600);
    color: #fff;
    display: grid; place-items: center;
    opacity: 0;
    transform: scale(0.6);
    transition: all .2s var(--kd-ease);
    pointer-events: none;
}
.kd-slot-tile.is-active .kd-slot-check {
    opacity: 1;
    transform: scale(1);
}
.kd-slot-tile.is-active .kd-slot-tile-head {
    padding-right: 28px;
}

/* ============================================================
   CARD #4 — Farmer & FPO finder (v2 — simplified)
   Wraps existing #divVendorList; preserves all IDs & wiring.
   ============================================================ */
.kd-finder { max-width: var(--kd-max); margin: 0 auto var(--kd-s-10) !important; padding: 0 var(--kd-s-5) !important; }

.kd-finder-card {
    background: var(--kd-surface) !important;
    border: 1px solid var(--kd-ink-100) !important;
    border-radius: var(--kd-r-xl) !important;
    padding: 28px 28px 22px !important;
    box-shadow: var(--kd-shadow-xs);
}
@media (max-width: 700px) { .kd-finder-card { padding: 22px 20px 18px !important; } }

/* ---- Clean header — icon left, title block centered (matches Card #6) ---- */
.kd-finder-head {
    display: grid !important;
    grid-template-columns: 52px 1fr 52px !important;
    align-items: center !important;
    gap: 16px !important;
    padding-bottom: 22px !important;
    margin-bottom: 22px !important;
    border-bottom: 1px solid var(--kd-ink-100) !important;
}
@media (max-width: 700px) {
    .kd-finder-head {
        grid-template-columns: 1fr !important;
        justify-items: center;
        gap: 12px !important;
    }
}

.kd-finder-icon {
    width: 52px !important; height: 52px !important;
    border-radius: var(--kd-r-md) !important;
    background: linear-gradient(135deg, var(--kd-g-500), var(--kd-g-700)) !important;
    color: #fff !important;
    display: grid !important;
    place-items: center !important;
    flex-shrink: 0 !important;
    box-shadow: 0 8px 20px rgba(12,110,48,0.32) !important;
    border: 0 !important;
    position: relative;
    overflow: hidden;
}
.kd-finder-icon::before {
    /* highlight to match Card #6 icon */
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 30% 25%, rgba(255,255,255,.25), transparent 60%);
    pointer-events: none;
}

.kd-finder-titletext {
    min-width: 0;
    text-align: center !important;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.kd-finder-eyebrow {
    font-size: 11px;
    font-weight: 800;
    color: var(--kd-g-700);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: 4px;
}
.kd-finder-title {
    font-size: clamp(22px, 2.6vw, 28px) !important;
    font-weight: 800 !important;
    color: var(--kd-ink-900) !important;
    margin: 0 0 6px !important;
    letter-spacing: -0.025em !important;
    line-height: 1.15 !important;
    text-align: center !important;
}
.kd-finder-title em {
    font-family: var(--kd-font-serif) !important;
    font-style: italic;
    font-weight: 600;
    color: var(--kd-g-700);
}
.kd-finder-sub {
    font-size: 14px !important;
    color: var(--kd-ink-600) !important;
    margin: 0 !important;
    line-height: 1.55 !important;
    font-weight: 500 !important;
    max-width: 640px;
    text-align: center !important;
}
.kd-finder-sub strong {
    color: var(--kd-ink-900) !important;
    font-weight: 800 !important;
}

/* ---- Existing #divVendorList re-styled (with inline ::before field labels) ---- */
#divVendorList {
    display: grid !important;
    grid-template-columns: 1fr 1fr 1fr 1.6fr !important;
    gap: 16px !important;
    align-items: stretch !important;
}
@media (max-width: 900px) { #divVendorList { grid-template-columns: 1fr 1fr !important; } }
@media (max-width: 600px) { #divVendorList { grid-template-columns: 1fr !important; } }

#divVendorList .vendor-select-box {
    width: 100% !important;
    min-width: 0 !important;
    max-width: none !important;
    position: relative !important;
    padding-top: 22px !important;
}
/* Field labels via ::before */
#divVendorList > .vendor-select-box:first-of-type::before { content: "Store"; }
#divVendorList .filter-wrapper-container .vendor-select-box:nth-child(1)::before { content: "Within distance"; }
#divVendorList .filter-wrapper-container .vendor-select-box:nth-child(2)::before { content: "State"; }
#divVendorList .vendor-select-box::before {
    position: absolute;
    top: 0; left: 2px;
    font-size: 11px;
    font-weight: 800;
    color: var(--kd-ink-600);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    line-height: 1;
}

#divVendorList #filterCityChipsContainer {
    position: relative !important;
    padding-top: 26px !important;
}
#divVendorList #filterCityChipsContainer::after {
    content: "Quick city pick";
    position: absolute;
    top: 0; left: 2px;
    font-size: 11px;
    font-weight: 800;
    color: var(--kd-ink-600);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    line-height: 1;
}
#divVendorList .filter-wrapper-container {
    display: contents !important;
}

#divVendorList select.vendor-dropdown {
    width: 100% !important;
    height: 52px !important;
    padding: 0 42px 0 16px !important;
    border-radius: var(--kd-r-md) !important;
    border: 1.5px solid var(--kd-ink-100) !important;
    background-color: var(--kd-surface) !important;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%230c6e30' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>") !important;
    background-repeat: no-repeat !important;
    background-position: right 16px center !important;
    background-size: 14px !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    font-family: var(--kd-font-sans) !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    color: var(--kd-ink-900) !important;
    cursor: pointer !important;
    transition: all .18s var(--kd-ease) !important;
    box-shadow: var(--kd-shadow-xs) !important;
    letter-spacing: -0.005em !important;
}
#divVendorList select.vendor-dropdown:hover {
    border-color: var(--kd-g-300) !important;
    transform: translateY(-1px) !important;
    box-shadow: var(--kd-shadow-sm) !important;
}
#divVendorList select.vendor-dropdown:focus {
    border-color: var(--kd-g-500) !important;
    outline: none !important;
    box-shadow: var(--kd-shadow-glow) !important;
}

/* ---- City chips ---- */
#divVendorList #filterCityChipsContainer {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    overflow-x: auto !important;
    flex-wrap: nowrap !important;
    padding: 4px 2px !important;
    scrollbar-width: none !important;
    min-height: 52px !important;
    -webkit-overflow-scrolling: touch !important;
}
#divVendorList #filterCityChipsContainer::-webkit-scrollbar { display: none !important; }
#divVendorList #filterCityChipsContainer .city-chip {
    flex-shrink: 0 !important;
    padding: 9px 18px !important;
    border-radius: var(--kd-r-pill) !important;
    border: 1.5px solid var(--kd-ink-100) !important;
    background: var(--kd-surface) !important;
    color: var(--kd-ink-800) !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    cursor: pointer !important;
    white-space: nowrap !important;
    transition: all .18s var(--kd-ease) !important;
    letter-spacing: -0.005em !important;
}
#divVendorList #filterCityChipsContainer .city-chip:hover {
    border-color: var(--kd-g-300) !important;
    color: var(--kd-g-700) !important;
    transform: translateY(-1px) !important;
    box-shadow: var(--kd-shadow-xs) !important;
}
#divVendorList #filterCityChipsContainer .city-chip.active {
    background: var(--kd-g-600) !important;
    color: #fff !important;
    border-color: var(--kd-g-600) !important;
    box-shadow: 0 4px 12px rgba(12,110,48,0.32) !important;
}
#divVendorList #filterCityChipsContainer .more-cities-listing {
    color: var(--kd-s-700) !important;
    font-weight: 800 !important;
    font-size: 13px !important;
    cursor: pointer !important;
    margin-left: 4px !important;
    flex-shrink: 0 !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 4px !important;
    padding: 9px 14px !important;
    border-radius: var(--kd-r-pill) !important;
    background: var(--kd-s-50) !important;
    border: 1.5px dashed var(--kd-s-500) !important;
    transition: all .18s var(--kd-ease) !important;
}
#divVendorList #filterCityChipsContainer .more-cities-listing:hover {
    background: var(--kd-s-500) !important;
    color: #fff !important;
    border-style: solid !important;
}

/* Empty-state grace for chips */
#filterCityChipsContainer:empty::before {
    content: "Showing all stores nearby";
    font-size: 13px;
    color: var(--kd-ink-500);
    font-weight: 600;
    padding: 0 12px;
    font-style: italic;
}

/* ---- Footer trust strip ---- */
.kd-finder-foot {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 28px;
    margin-top: 18px;
    padding-top: 16px;
    border-top: 1px solid var(--kd-ink-100);
}

/* ============================================================
   CARD #6 — Categories
   Wraps existing #GetbyCategoryVendor grid; preserves all IDs.
   ============================================================ */

/* Outer section becomes a CARD with visible 4-side border (matches Finder) */
.category-grid-container.main-categories-section {
    background: var(--kd-surface) !important;
    border: 1px solid var(--kd-ink-200) !important;
    border-radius: var(--kd-r-xl) !important;
    padding: 24px 26px 22px !important;
    box-shadow: var(--kd-shadow-xs);
    margin: var(--kd-s-10) auto !important;
}
@media (max-width: 700px) {
    .category-grid-container.main-categories-section { padding: 20px 18px 18px !important; }
}

/* Header — icon left, title centered, button right (3-column grid) */
.kd-cat-head {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 16px;
    padding-bottom: 18px;
    margin-bottom: 18px;
    border-bottom: 1px solid var(--kd-ink-100);
}
@media (max-width: 700px) {
    .kd-cat-head { grid-template-columns: 1fr; justify-items: center; gap: 10px; }
    .kd-cat-link { width: 100%; justify-content: center; }
}

.kd-cat-icon {
    width: 52px; height: 52px;
    border-radius: var(--kd-r-md);
    background: linear-gradient(135deg, var(--kd-g-500), var(--kd-g-700));
    color: #fff;
    display: grid; place-items: center;
    flex-shrink: 0;
    box-shadow: 0 8px 20px rgba(12,110,48,0.32);
    position: relative;
    overflow: hidden;
}
.kd-cat-icon::before {
    /* subtle highlight for depth */
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 30% 25%, rgba(255,255,255,.25), transparent 60%);
    pointer-events: none;
}

.kd-cat-titletext {
    min-width: 0;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.kd-cat-eyebrow {
    font-size: 11px !important;
    font-weight: 800 !important;
    color: var(--kd-g-700) !important;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: 3px;
    line-height: 1;
}
.kd-cat-title {
    font-size: clamp(20px, 2.4vw, 26px) !important;
    font-weight: 800 !important;
    color: var(--kd-ink-900) !important;
    margin: 0 0 4px !important;
    letter-spacing: -0.025em !important;
    line-height: 1.15 !important;
    font-family: var(--kd-font-sans) !important;
}
.kd-cat-title em {
    font-family: var(--kd-font-serif) !important;
    font-style: italic;
    font-weight: 600;
    color: var(--kd-g-700);
}
.kd-cat-sub {
    font-size: 13px !important;
    color: var(--kd-ink-600) !important;
    line-height: 1.5 !important;
    margin: 0 !important;
    font-weight: 500 !important;
    max-width: 640px;
    text-align: center;
}

/* "View all" — sits to the right of the header, real button */
.kd-cat-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-family: var(--kd-font-sans) !important;
    font-size: 13px;
    font-weight: 800;
    letter-spacing: -0.005em;
    color: #fff !important;
    text-decoration: none !important;
    padding: 10px 18px;
    border-radius: var(--kd-r-md);
    background: var(--kd-g-600);
    border: 0;
    cursor: pointer;
    box-shadow: 0 4px 12px rgba(12,110,48,0.28);
    transition: all .2s var(--kd-ease);
    flex-shrink: 0;
    line-height: 1;
}
.kd-cat-link:hover {
    background: var(--kd-g-700);
    color: #fff !important;
    transform: translateY(-1px);
    box-shadow: 0 8px 20px rgba(12,110,48,0.36);
    text-decoration: none !important;
}
.kd-cat-link svg { transition: transform .2s var(--kd-ease); }
.kd-cat-link:hover svg { transform: translateX(2px); }

/* Tile refinements — align with slot tile + product card design */
.category-grid-container.main-categories-section .category-item {
    background: var(--kd-surface) !important;
    border: 2px solid var(--kd-ink-200) !important;
    border-radius: var(--kd-r-lg) !important;
    padding: 14px 12px !important;
    box-shadow: 0 1px 0 rgba(10,20,16,0.04) !important;
    cursor: pointer !important;
    transition: all .22s var(--kd-ease) !important;
    flex-basis: auto !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
    position: relative !important;
    overflow: hidden !important;
}
.category-grid-container.main-categories-section .category-item::after {
    /* hover indicator arrow in top-right */
    content: "→";
    position: absolute;
    top: 10px; right: 12px;
    width: 24px; height: 24px;
    border-radius: 50%;
    background: var(--kd-g-600);
    color: #fff;
    font-size: 13px;
    font-weight: 800;
    display: grid;
    place-items: center;
    opacity: 0;
    transform: translate(-6px, 6px);
    transition: all .22s var(--kd-ease);
    pointer-events: none;
    box-shadow: 0 4px 10px rgba(12,110,48,0.32);
}
.category-grid-container.main-categories-section .category-item:hover {
    border-color: var(--kd-g-500) !important;
    transform: translateY(-4px) !important;
    box-shadow: var(--kd-shadow-md) !important;
}
.category-grid-container.main-categories-section .category-item:hover::after {
    opacity: 1;
    transform: translate(0, 0);
}

/* Image well — cream gradient with warm depth, plus emoji fallback */
.category-grid-container.main-categories-section .category-image-container {
    position: relative !important;
    background: linear-gradient(135deg, #fbf6e9 0%, #f5ecd2 100%) !important;
    border-radius: var(--kd-r-md) !important;
    aspect-ratio: 1 / 1 !important;
    display: grid !important;
    place-items: center !important;
    overflow: hidden !important;
    margin-bottom: 0 !important;
}
/* Default emoji (in case JS hasn't tagged yet); JS later sets data-emoji per category */
.category-grid-container.main-categories-section .category-image-container::before {
    content: "🌾";
    font-size: 56px;
    line-height: 1;
    z-index: 0;
    transition: transform .25s var(--kd-ease);
    filter: drop-shadow(0 2px 6px rgba(7,87,34,0.12));
}
.category-grid-container.main-categories-section .category-image-container[data-emoji]::before {
    content: attr(data-emoji);
}
.category-grid-container.main-categories-section .category-item:hover .category-image-container::before {
    transform: scale(1.12) rotate(-4deg);
}
.category-grid-container.main-categories-section .category-image {
    position: relative !important;
    z-index: 1 !important;
    width: 70% !important;
    height: 70% !important;
    object-fit: contain !important;
    transition: transform .25s var(--kd-ease) !important;
}
.category-grid-container.main-categories-section .category-item:hover .category-image {
    transform: scale(1.08) !important;
}

.category-grid-container.main-categories-section .category-name {
    font-size: 14px !important;
    font-weight: 700 !important;
    color: var(--kd-ink-900) !important;
    text-align: center !important;
    letter-spacing: -0.005em !important;
    line-height: 1.3 !important;
    font-family: var(--kd-font-sans) !important;
    margin: 0 !important;
    padding: 0 4px !important;
}

/* ============================================================
   CARD #7 — Shop by Store
   Reuses the kd-cat-head from Card #6; adds .kd-card-section
   styling for any other grid section that should look like a card.
   ============================================================ */

/* Generic card-section — same card chrome as Shop Essentials */
.kd-card-section {
    background: var(--kd-surface) !important;
    border: 1px solid var(--kd-ink-200) !important;
    border-radius: var(--kd-r-xl) !important;
    padding: 24px 26px 22px !important;
    box-shadow: var(--kd-shadow-xs);
    margin: var(--kd-s-10) auto !important;
    max-width: var(--kd-max) !important;
}
@media (max-width: 700px) { .kd-card-section { padding: 20px 18px 18px !important; } }

/* Inner grid (#GetShop) — same column behaviour as Shop Essentials */
.kd-card-section .category-grid#GetShop,
.kd-card-section.kd-store-section #GetShop {
    display: grid !important;
    grid-template-columns: repeat(6, 1fr) !important;
    gap: var(--kd-s-3) !important;
    flex-wrap: unset !important;
    overflow: visible !important;
    margin: 0 !important;
}
@media (max-width: 1100px) { .kd-card-section #GetShop { grid-template-columns: repeat(4, 1fr) !important; } }
@media (max-width: 700px)  { .kd-card-section #GetShop { grid-template-columns: repeat(3, 1fr) !important; } }

/* Tile styling for store items — mirrors Shop Essentials */
.kd-card-section .category-item {
    background: var(--kd-surface) !important;
    border: 2px solid var(--kd-ink-200) !important;
    border-radius: var(--kd-r-lg) !important;
    padding: 14px 12px !important;
    box-shadow: 0 1px 0 rgba(10,20,16,0.04) !important;
    cursor: pointer !important;
    transition: all .22s var(--kd-ease) !important;
    flex-basis: auto !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
    position: relative !important;
    overflow: hidden !important;
}
.kd-card-section .category-item::after {
    content: "→";
    position: absolute;
    top: 10px; right: 12px;
    width: 24px; height: 24px;
    border-radius: 50%;
    background: var(--kd-g-600);
    color: #fff;
    font-size: 13px;
    font-weight: 800;
    display: grid;
    place-items: center;
    opacity: 0;
    transform: translate(-6px, 6px);
    transition: all .22s var(--kd-ease);
    pointer-events: none;
    box-shadow: 0 4px 10px rgba(12,110,48,0.32);
}
.kd-card-section .category-item:hover {
    border-color: var(--kd-g-500) !important;
    transform: translateY(-4px) !important;
    box-shadow: var(--kd-shadow-md) !important;
}
.kd-card-section .category-item:hover::after {
    opacity: 1;
    transform: translate(0, 0);
}

.kd-card-section .category-image-container {
    position: relative !important;
    background: linear-gradient(135deg, #fbf6e9 0%, #f5ecd2 100%) !important;
    border-radius: var(--kd-r-md) !important;
    aspect-ratio: 1 / 1 !important;
    display: grid !important;
    place-items: center !important;
    overflow: hidden !important;
    margin-bottom: 0 !important;
}
.kd-card-section .category-image-container::before {
    content: "🏪";
    font-size: 56px;
    line-height: 1;
    z-index: 0;
    transition: transform .25s var(--kd-ease);
    filter: drop-shadow(0 2px 6px rgba(7,87,34,0.12));
}
.kd-card-section .category-image-container[data-emoji]::before {
    content: attr(data-emoji);
}
.kd-card-section .category-item:hover .category-image-container::before {
    transform: scale(1.12) rotate(-4deg);
}
.kd-card-section .category-image {
    position: relative !important;
    z-index: 1 !important;
    width: 70% !important;
    height: 70% !important;
    object-fit: contain !important;
    transition: transform .25s var(--kd-ease) !important;
}
.kd-card-section .category-item:hover .category-image {
    transform: scale(1.08) !important;
}
.kd-card-section .category-name {
    font-size: 14px !important;
    font-weight: 700 !important;
    color: var(--kd-ink-900) !important;
    text-align: center !important;
    letter-spacing: -0.005em !important;
    line-height: 1.3 !important;
    font-family: var(--kd-font-sans) !important;
    margin: 0 !important;
    padding: 0 4px !important;
}

/* Empty-state grace inside Shop By Store */
.kd-card-section .no-categories-container {
    grid-column: 1 / -1;
    padding: 32px 16px;
    text-align: center;
}

/* ============================================================
   CARD #8 — Hot Deals
   Reuses .kd-card-section + .kd-cat-head; saffron-tinted icon
   for heat/urgency semantic. Fixes legacy arrow positioning
   so they sit inside the new card padding.
   ============================================================ */

/* Saffron icon tile for Hot Deals (deal/heat semantic) */
.kd-icon-deals {
    background: linear-gradient(135deg, var(--kd-s-500), var(--kd-s-700)) !important;
    box-shadow: 0 8px 20px rgba(255,122,26,0.32) !important;
}
/* The eyebrow on the deals header takes the saffron family too */
.kd-deals-head .kd-cat-eyebrow {
    color: var(--kd-s-700) !important;
}

/* The card target is .product-grid-container.hotdeals — it already had
   .product-grid-container styling, neutralise that and let .kd-card-section win */
.kd-card-section.kd-deals-section {
    position: relative !important;
    overflow: visible !important;
}
.kd-card-section.kd-deals-section .sidebar-scroll-container {
    padding: 4px 8px 4px 8px;
}
.kd-card-section.kd-deals-section .product-grid {
    padding: 4px 0;
}

/* Re-position legacy arrows so they sit inside the card padding,
   not floating outside the card frame */
.kd-card-section.kd-deals-section .hotdeals-scroll-btn.left  { left: 14px !important; }
.kd-card-section.kd-deals-section .hotdeals-scroll-btn.right { right: 14px !important; }
@media (max-width: 600px) {
    .kd-card-section.kd-deals-section .hotdeals-scroll-btn.left  { left: 8px !important; }
    .kd-card-section.kd-deals-section .hotdeals-scroll-btn.right { right: 8px !important; }
}

/* Top-position the arrows below the header (so they don't sit on top of the title) */
.kd-card-section.kd-deals-section .hotdeals-scroll-btn {
    top: auto !important;
    bottom: 50% !important;
    transform: translateY(50%) !important;
    z-index: 4;
}
.kd-card-section.kd-deals-section .hotdeals-scroll-btn:hover:not(:disabled) {
    transform: translateY(50%) translateX(-2px) !important;
}
.kd-card-section.kd-deals-section .hotdeals-scroll-btn.right:hover:not(:disabled) {
    transform: translateY(50%) translateX(2px) !important;
}

/* Hot Deals — thin-line chevron arrows (no circle/bg/border) */
.kd-card-section.kd-deals-section .hotdeals-scroll-btn {
    width: 32px !important;
    height: 56px !important;
    border-radius: 0 !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    color: var(--kd-ink-500) !important;
    padding: 0 !important;
    display: grid !important;
    place-items: center !important;
    transition: color .18s var(--kd-ease), transform .18s var(--kd-ease) !important;
}
/* Hide the legacy Font Awesome <i> if it's still in the markup */
.kd-card-section.kd-deals-section .hotdeals-scroll-btn i { display: none !important; }
.kd-card-section.kd-deals-section .hotdeals-scroll-btn svg {
    width: 28px !important;
    height: 28px !important;
    display: block !important;
}
.kd-card-section.kd-deals-section .hotdeals-scroll-btn:hover:not(:disabled) {
    background: transparent !important;
    color: var(--kd-g-700) !important;
    box-shadow: none !important;
}
.kd-card-section.kd-deals-section .hotdeals-scroll-btn:disabled {
    opacity: .25 !important;
    background: transparent !important;
}

/* ============================================================
   CARD #9 — Shop by Brands
   Reuses .kd-card-section + .kd-cat-head; violet/indigo icon
   tint to differentiate from green (browse) / saffron (deals).
   ============================================================ */

/* Override the legacy .brand-section-container styling — we want
   a clean white card, not the old cream block. */
.kd-card-section.kd-brand-section.brand-section-container {
    background: var(--kd-surface) !important;
    border: 1px solid var(--kd-ink-200) !important;
    border-radius: var(--kd-r-xl) !important;
    padding: 24px 26px 22px !important;
    position: relative !important;
}

/* Indigo/violet icon tile for "trusted brands" semantic */
.kd-icon-brand {
    background: linear-gradient(135deg, #5b6cd9, #36418f) !important;
    box-shadow: 0 8px 20px rgba(54,65,143,0.32) !important;
}
.kd-brand-head .kd-cat-eyebrow {
    color: #36418f !important;
}

/* Brand container is a horizontal scroller — reset margins to align with header */
.kd-card-section.kd-brand-section .brand-container {
    gap: var(--kd-s-4) !important;
    padding: 8px 0 !important;
    margin: 0 !important;
}

/* Re-position the legacy arrows for the brand scroller too */
.kd-card-section.kd-brand-section .hotdeals-scroll-btn.left  { left: 14px !important; }
.kd-card-section.kd-brand-section .hotdeals-scroll-btn.right { right: 14px !important; }
@media (max-width: 600px) {
    .kd-card-section.kd-brand-section .hotdeals-scroll-btn.left  { left: 8px !important; }
    .kd-card-section.kd-brand-section .hotdeals-scroll-btn.right { right: 8px !important; }
}
.kd-card-section.kd-brand-section .hotdeals-scroll-btn {
    top: auto !important;
    bottom: 50% !important;
    transform: translateY(50%) !important;
    z-index: 4;
}
.kd-card-section.kd-brand-section .hotdeals-scroll-btn:hover:not(:disabled) {
    transform: translateY(50%) translateX(-2px) !important;
}
.kd-card-section.kd-brand-section .hotdeals-scroll-btn.right:hover:not(:disabled) {
    transform: translateY(50%) translateX(2px) !important;
}

/* Brand items — image circular, name below, no overlap */
.kd-card-section.kd-brand-section .brand-container > * {
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 10px !important;
    padding: 12px 8px !important;
    width: 110px !important;
    flex-shrink: 0 !important;
    transition: transform .22s var(--kd-ease) !important;
    cursor: pointer !important;
    text-align: center !important;
}
.kd-card-section.kd-brand-section .brand-container > *:hover {
    transform: translateY(-3px) !important;
}
/* The IMAGE inside each item is the circular badge (not the wrapper) */
.kd-card-section.kd-brand-section .brand-container img {
    width: 76px !important;
    height: 76px !important;
    border-radius: 50% !important;
    object-fit: cover !important;
    background: var(--kd-cream-50) !important;
    border: 1.5px solid var(--kd-ink-100) !important;
    box-shadow: 0 2px 6px rgba(10,20,16,0.06) !important;
    transition: all .22s var(--kd-ease) !important;
    flex-shrink: 0 !important;
}
.kd-card-section.kd-brand-section .brand-container > *:hover img {
    border-color: #5b6cd9 !important;
    box-shadow: 0 8px 20px rgba(54,65,143,0.28) !important;
}
/* Brand name label below the circle */
.kd-card-section.kd-brand-section .brand-container > * > *:not(img) {
    font-size: 12px !important;
    font-weight: 700 !important;
    color: var(--kd-ink-800) !important;
    line-height: 1.3 !important;
    margin: 0 !important;
    letter-spacing: -0.005em !important;
    font-family: var(--kd-font-sans) !important;
    word-break: break-word !important;
    max-width: 100% !important;
}

/* Thin-line arrows for the Brand scroller (matches Hot Deals) */
.kd-card-section.kd-brand-section .hotdeals-scroll-btn {
    width: 32px !important;
    height: 56px !important;
    border-radius: 0 !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    color: var(--kd-ink-500) !important;
    padding: 0 !important;
    display: grid !important;
    place-items: center !important;
    transition: color .18s var(--kd-ease), transform .18s var(--kd-ease) !important;
}
.kd-card-section.kd-brand-section .hotdeals-scroll-btn i { display: none !important; }
.kd-card-section.kd-brand-section .hotdeals-scroll-btn svg {
    width: 28px !important;
    height: 28px !important;
    display: block !important;
}
.kd-card-section.kd-brand-section .hotdeals-scroll-btn:hover:not(:disabled) {
    background: transparent !important;
    color: #36418f !important;
    box-shadow: none !important;
}
.kd-card-section.kd-brand-section .hotdeals-scroll-btn:disabled {
    opacity: .25 !important;
    background: transparent !important;
}

/* ============================================================
   CARD #10 — Dynamic Categories
   (Flour & Atta, Beverages, Bakery, Baby Care, Pulses & Legumes,
   …whichever come from the server)
   ============================================================ */

/* Each .dynamic-product-section becomes its own card */
.kd-card-section.kd-dyncat-section {
    background: var(--kd-surface) !important;
    border: 1px solid var(--kd-ink-200) !important;
    border-radius: var(--kd-r-xl) !important;
    padding: 24px 26px 22px !important;
    box-shadow: var(--kd-shadow-xs);
    margin: var(--kd-s-10) auto !important;
    max-width: var(--kd-max) !important;
    position: relative !important;
}

/* Wrap the wrapper so all dynamic sections sit inside the same canvas */
#dynaincCategoryVariants {
    background: transparent !important;
    border: 0 !important;
    padding: 0 var(--kd-s-5) !important;
    max-width: var(--kd-max) !important;
    margin: 0 auto !important;
    box-shadow: none !important;
}

/* Cream-tinted icon tile for dyncat (lighter feel; uses an emoji glyph as the mark) */
.kd-icon-dyncat {
    background: linear-gradient(135deg, #fbf6e9, #f4ecdb) !important;
    border: 1.5px solid var(--kd-cream-200) !important;
    box-shadow: 0 6px 14px rgba(196,127,30,0.12) !important;
    color: var(--kd-ink-900) !important;
}
.kd-icon-emoji {
    font-size: 28px;
    line-height: 1;
    filter: drop-shadow(0 1px 2px rgba(7,87,34,.18));
}

/* The dyncat eyebrow sits in saffron-700 for warm contrast on the cream tile */
.kd-dyncat-head .kd-cat-eyebrow {
    color: var(--kd-s-700) !important;
}

/* Inner scroller reset so it flows full-width inside the card padding */
.kd-card-section.kd-dyncat-section .sidebar-scroll-container {
    padding: 4px 8px !important;
    margin: 0 !important;
}
.kd-card-section.kd-dyncat-section .product-grid {
    padding: 4px 0 !important;
    margin: 0 !important;
}

/* Thin-line arrows (matches Hot Deals + Brands) */
.kd-card-section.kd-dyncat-section .hotdeals-scroll-btn {
    width: 32px !important;
    height: 56px !important;
    border-radius: 0 !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    color: var(--kd-ink-500) !important;
    padding: 0 !important;
    display: grid !important;
    place-items: center !important;
    transition: color .18s var(--kd-ease) !important;
    top: auto !important;
    bottom: 50% !important;
    transform: translateY(50%) !important;
    z-index: 4;
}
.kd-card-section.kd-dyncat-section .hotdeals-scroll-btn.left  { left: 14px !important; }
.kd-card-section.kd-dyncat-section .hotdeals-scroll-btn.right { right: 14px !important; }
@media (max-width: 600px) {
    .kd-card-section.kd-dyncat-section .hotdeals-scroll-btn.left  { left: 8px !important; }
    .kd-card-section.kd-dyncat-section .hotdeals-scroll-btn.right { right: 8px !important; }
}
.kd-card-section.kd-dyncat-section .hotdeals-scroll-btn i { display: none !important; }
.kd-card-section.kd-dyncat-section .hotdeals-scroll-btn svg {
    width: 28px !important;
    height: 28px !important;
    display: block !important;
}
.kd-card-section.kd-dyncat-section .hotdeals-scroll-btn:hover:not(:disabled) {
    background: transparent !important;
    color: var(--kd-s-700) !important;
    box-shadow: none !important;
    transform: translateY(50%) !important;
}
.kd-card-section.kd-dyncat-section .hotdeals-scroll-btn:disabled {
    opacity: .25 !important;
    background: transparent !important;
}
.kd-finder-foot-item {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    font-weight: 600;
    color: var(--kd-ink-600);
}
.kd-finder-foot-item svg {
    color: var(--kd-g-600);
    flex-shrink: 0;
}
