/* ==========================================================================
   Hermes Design System
   ==========================================================================
   Single source of truth for brand tokens. Imported into every page via
   templates/_new/base.html. Components reference --hermes-* properties so
   the palette can be re-tuned without touching markup.

   Conventions:
   - Token names follow `--hermes-<category>-<variant>`.
   - 4-px spacing grid (--hermes-space-1 = 4px, --hermes-space-2 = 8px, ...).
   - Type scale uses rem; root font-size stays at the user-agent default 16px.
   - All transitions go through the --hermes-transition-* tokens so the
     entire UI eases consistently.
   ========================================================================== */


/* --------------------------------------------------------------------------
   Self-hosted typography
   -------------------------------------------------------------------------- */

/* Manrope — variable font, weight axis 300..800.
   Two @font-face blocks per family because Google partitions latin and
   cyrillic subsets and the browser picks the right file per glyph. */
@font-face {
    font-family: 'Manrope';
    font-style: normal;
    font-weight: 300 800;
    font-display: swap;
    src: url('../fonts/manrope-latin.woff2') format('woff2');
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6,
                   U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F,
                   U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
    font-family: 'Manrope';
    font-style: normal;
    font-weight: 300 800;
    font-display: swap;
    src: url('../fonts/manrope-cyrillic.woff2') format('woff2');
    unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}

/* Inter — variable font, weight axis 300..700. */
@font-face {
    font-family: 'Inter';
    font-style: normal;
    font-weight: 300 700;
    font-display: swap;
    src: url('../fonts/inter-latin.woff2') format('woff2');
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6,
                   U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F,
                   U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
    font-family: 'Inter';
    font-style: normal;
    font-weight: 300 700;
    font-display: swap;
    src: url('../fonts/inter-cyrillic.woff2') format('woff2');
    unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}


/* --------------------------------------------------------------------------
   Tokens
   -------------------------------------------------------------------------- */
:root {

    /* ---- Brand colours ---- */
    --hermes-primary:        #0F4C81;      /* deep blue — the brand colour     */
    --hermes-primary-dark:   #0A365C;      /* hover / pressed states          */
    --hermes-primary-light:  #2E7BB5;      /* tints, hover backgrounds        */
    --hermes-primary-50:     #EEF4FA;      /* subtle backgrounds, chips       */

    /* Warm amber accent for primary CTAs against the cool blue brand.
       Chosen over green so #10B981 stays exclusively for "savings".         */
    --hermes-accent:         #F59E0B;
    --hermes-accent-dark:    #D97706;
    --hermes-accent-light:   #FBBF24;

    /* ---- Semantic ---- */
    --hermes-success:        #10B981;      /* savings ↓, "+N лв спестихте"   */
    --hermes-success-dark:   #047857;
    --hermes-success-light:  #D1FAE5;

    --hermes-warning:        #F59E0B;      /* same hue as accent; warning bg */
    --hermes-warning-dark:   #B45309;
    --hermes-warning-light:  #FEF3C7;

    --hermes-error:          #EF4444;
    --hermes-error-dark:     #B91C1C;
    --hermes-error-light:    #FEE2E2;

    --hermes-info:           #3B82F6;
    --hermes-info-light:     #DBEAFE;

    /* ---- Neutrals (slate family) ---- */
    --hermes-neutral-50:     #F8FAFC;
    --hermes-neutral-100:    #F1F5F9;
    --hermes-neutral-200:    #E2E8F0;
    --hermes-neutral-300:    #CBD5E1;
    --hermes-neutral-400:    #94A3B8;
    --hermes-neutral-500:    #64748B;
    --hermes-neutral-600:    #475569;
    --hermes-neutral-700:    #334155;
    --hermes-neutral-800:    #1E293B;
    --hermes-neutral-900:    #0F172A;

    /* Page surfaces */
    --hermes-bg:             #FFFFFF;
    --hermes-bg-muted:       var(--hermes-neutral-50);
    --hermes-bg-elevated:    #FFFFFF;
    --hermes-border:         var(--hermes-neutral-200);
    --hermes-border-strong:  var(--hermes-neutral-300);
    --hermes-text:           var(--hermes-neutral-900);
    --hermes-text-muted:     var(--hermes-neutral-500);
    --hermes-text-inverse:   #FFFFFF;

    /* ---- Typography ---- */
    --hermes-font-heading:   'Manrope', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', sans-serif;
    --hermes-font-body:      'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', sans-serif;
    --hermes-font-mono:      ui-monospace, 'SF Mono', Menlo, Consolas, monospace;

    --hermes-text-xs:        0.75rem;   /* 12 */
    --hermes-text-sm:        0.875rem;  /* 14 */
    --hermes-text-base:      1rem;      /* 16 */
    --hermes-text-lg:        1.125rem;  /* 18 */
    --hermes-text-xl:        1.25rem;   /* 20 */
    --hermes-text-2xl:       1.5rem;    /* 24 */
    --hermes-text-3xl:       1.875rem;  /* 30 */
    --hermes-text-4xl:       2.25rem;   /* 36 */
    --hermes-text-5xl:       3rem;      /* 48 */
    --hermes-text-6xl:       3.75rem;   /* 60 */

    --hermes-leading-none:    1;
    --hermes-leading-tight:   1.15;
    --hermes-leading-snug:    1.3;
    --hermes-leading-normal:  1.5;
    --hermes-leading-relaxed: 1.65;

    --hermes-weight-light:    300;
    --hermes-weight-regular:  400;
    --hermes-weight-medium:   500;
    --hermes-weight-semibold: 600;
    --hermes-weight-bold:     700;
    --hermes-weight-extrabold:800;

    /* ---- Spacing (4-px grid) ---- */
    --hermes-space-0:        0;
    --hermes-space-1:        0.25rem;   /* 4  */
    --hermes-space-2:        0.5rem;    /* 8  */
    --hermes-space-3:        0.75rem;   /* 12 */
    --hermes-space-4:        1rem;      /* 16 */
    --hermes-space-5:        1.25rem;   /* 20 */
    --hermes-space-6:        1.5rem;    /* 24 */
    --hermes-space-7:        2rem;      /* 32 */
    --hermes-space-8:        2.5rem;    /* 40 */
    --hermes-space-10:       3rem;      /* 48 */
    --hermes-space-12:       4rem;      /* 64 */
    --hermes-space-16:       6rem;      /* 96 */

    /* ---- Containers ---- */
    --hermes-container-sm:   640px;
    --hermes-container-md:   960px;
    --hermes-container-lg:   1200px;
    --hermes-container-xl:   1440px;

    /* ---- Border radius ---- */
    --hermes-radius-sm:      4px;
    --hermes-radius-md:      8px;
    --hermes-radius-lg:      12px;
    --hermes-radius-xl:      16px;
    --hermes-radius-2xl:     24px;
    --hermes-radius-full:    9999px;

    /* ---- Shadows (subtle; not Bootstrap-aggressive) ---- */
    --hermes-shadow-xs:      0 1px 2px  rgba(15, 23, 42, 0.04);
    --hermes-shadow-sm:      0 2px 4px  rgba(15, 23, 42, 0.06);
    --hermes-shadow-md:      0 4px 12px rgba(15, 23, 42, 0.08);
    --hermes-shadow-lg:      0 12px 24px rgba(15, 23, 42, 0.10);
    --hermes-shadow-xl:      0 24px 48px rgba(15, 23, 42, 0.12);
    --hermes-shadow-focus:   0 0 0 4px  rgba(15, 76, 129, 0.20);
    --hermes-shadow-focus-accent: 0 0 0 4px rgba(245, 158, 11, 0.25);

    /* ---- Transitions ---- */
    --hermes-ease:           cubic-bezier(0.2, 0, 0, 1);
    --hermes-transition-fast:    150ms var(--hermes-ease);
    --hermes-transition-normal:  250ms var(--hermes-ease);
    --hermes-transition-slow:    400ms var(--hermes-ease);

    /* ---- Z-index scale ---- */
    --hermes-z-dropdown:     1000;
    --hermes-z-sticky:       1020;
    --hermes-z-fixed:        1030;
    --hermes-z-modal:        1050;
    --hermes-z-popover:      1060;
    --hermes-z-tooltip:      1070;
    --hermes-z-toast:        1080;

    /* ---- Layout heights ---- */
    --hermes-topbar-height:  64px;
    --hermes-sidebar-width:  264px;
    --hermes-sidebar-collapsed-width: 64px;
}


/* --------------------------------------------------------------------------
   Base resets / typography
   -------------------------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
    margin: 0;
    background: var(--hermes-bg);
    color: var(--hermes-text);
    font-family: var(--hermes-font-body);
    font-size: var(--hermes-text-base);
    font-weight: var(--hermes-weight-regular);
    line-height: var(--hermes-leading-normal);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6 {
    font-family: var(--hermes-font-heading);
    font-weight: var(--hermes-weight-bold);
    color: var(--hermes-neutral-900);
    line-height: var(--hermes-leading-tight);
    margin-top: 0;
}

h1 { font-size: var(--hermes-text-4xl); }
h2 { font-size: var(--hermes-text-3xl); }
h3 { font-size: var(--hermes-text-2xl); }
h4 { font-size: var(--hermes-text-xl); }
h5 { font-size: var(--hermes-text-lg); }
h6 { font-size: var(--hermes-text-base); }

a {
    color: var(--hermes-primary);
    text-decoration: none;
    transition: color var(--hermes-transition-fast);
}
a:hover { color: var(--hermes-primary-dark); }

:focus-visible {
    outline: none;
    box-shadow: var(--hermes-shadow-focus);
    border-radius: var(--hermes-radius-sm);
}


/* --------------------------------------------------------------------------
   Layout helpers
   -------------------------------------------------------------------------- */
.hermes-main {
    min-height: calc(100vh - var(--hermes-topbar-height));
    background: var(--hermes-bg-muted);
}

.hermes-container {
    width: 100%;
    max-width: var(--hermes-container-lg);
    margin: 0 auto;
    padding-left: var(--hermes-space-4);
    padding-right: var(--hermes-space-4);
}

.hermes-section {
    padding-top: var(--hermes-space-10);
    padding-bottom: var(--hermes-space-10);
}


/* --------------------------------------------------------------------------
   Topbar (public)
   -------------------------------------------------------------------------- */
.hermes-topbar {
    position: sticky;
    top: 0;
    z-index: var(--hermes-z-sticky);
    height: var(--hermes-topbar-height);
    background: var(--hermes-bg);
    border-bottom: 1px solid transparent;
    transition: border-color var(--hermes-transition-fast),
                box-shadow var(--hermes-transition-fast);
}

.hermes-topbar.is-scrolled {
    border-bottom-color: var(--hermes-border);
    box-shadow: var(--hermes-shadow-sm);
}

.hermes-topbar__inner {
    display: flex;
    align-items: center;
    gap: var(--hermes-space-6);
    height: 100%;
    max-width: var(--hermes-container-xl);
    margin: 0 auto;
    padding: 0 var(--hermes-space-4);
}

.hermes-brand {
    display: flex;
    align-items: center;
    gap: var(--hermes-space-2);
    color: var(--hermes-neutral-900);
    font-family: var(--hermes-font-heading);
    font-weight: var(--hermes-weight-bold);
    font-size: var(--hermes-text-lg);
    letter-spacing: -0.01em;
    text-decoration: none;
}
.hermes-brand:hover { color: var(--hermes-primary); }
.hermes-brand img,
.hermes-brand svg { height: 28px; width: auto; }

.hermes-topbar__nav {
    display: flex;
    align-items: center;
    gap: var(--hermes-space-1);
    list-style: none;
    margin: 0;
    padding: 0;
}
.hermes-topbar__nav-link {
    display: inline-flex;
    align-items: center;
    gap: var(--hermes-space-2);
    padding: var(--hermes-space-2) var(--hermes-space-3);
    border-radius: var(--hermes-radius-md);
    color: var(--hermes-neutral-700);
    font-weight: var(--hermes-weight-medium);
    font-size: var(--hermes-text-sm);
    text-decoration: none;
    transition: background var(--hermes-transition-fast),
                color var(--hermes-transition-fast);
}
.hermes-topbar__nav-link:hover {
    background: var(--hermes-primary-50);
    color: var(--hermes-primary);
}
.hermes-topbar__nav-link.is-active {
    background: var(--hermes-primary-50);
    color: var(--hermes-primary);
}

.hermes-topbar__spacer { flex: 1 1 auto; }

.hermes-topbar__actions {
    display: flex;
    align-items: center;
    gap: var(--hermes-space-2);
}

.hermes-cart-button {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: var(--hermes-space-2);
    padding: var(--hermes-space-2) var(--hermes-space-3);
    border-radius: var(--hermes-radius-md);
    background: transparent;
    border: 1px solid var(--hermes-border);
    color: var(--hermes-neutral-700);
    font-weight: var(--hermes-weight-medium);
    font-size: var(--hermes-text-sm);
    text-decoration: none;
    transition: background var(--hermes-transition-fast),
                border-color var(--hermes-transition-fast);
}
.hermes-cart-button:hover {
    background: var(--hermes-primary-50);
    border-color: var(--hermes-primary-light);
    color: var(--hermes-primary);
}
.hermes-cart-button__count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 22px;
    height: 22px;
    padding: 0 6px;
    background: var(--hermes-accent);
    color: var(--hermes-text-inverse);
    border-radius: var(--hermes-radius-full);
    font-size: var(--hermes-text-xs);
    font-weight: var(--hermes-weight-bold);
    line-height: 1;
}

/* Mobile toggle */
.hermes-topbar__toggle {
    display: none;
    background: transparent;
    border: 0;
    padding: var(--hermes-space-2);
    border-radius: var(--hermes-radius-md);
    color: var(--hermes-neutral-700);
    cursor: pointer;
    font-size: var(--hermes-text-xl);
}
.hermes-topbar__toggle:hover { background: var(--hermes-neutral-100); }

/* Mobile-only group: cart icon + hamburger, right-aligned (outside the
   drawer). The whole group is hidden on desktop, where the labelled cart
   button lives in __actions. */
.hermes-topbar__mobile-actions { display: none; }

/* Mobile-only account section — hidden on desktop, expanded inside the
   hamburger drawer on phones (see the @media (max-width: 991.98px) block
   below). The desktop profile dropdown stays as-is. */
.hermes-topbar__mobile-account { display: none; }
.hermes-topbar__cart-mobile {
    display: none;
    position: relative;
    align-items: center;
    justify-content: center;
    width: 44px;            /* min touch target */
    height: 44px;
    color: var(--hermes-neutral-700);
    text-decoration: none;
    font-size: var(--hermes-text-xl);
    border-radius: var(--hermes-radius-md);
}
.hermes-topbar__cart-mobile:hover { background: var(--hermes-neutral-100); }
.hermes-topbar__cart-mobile .hermes-cart-counter {
    position: absolute;
    top: 5px;
    right: 2px;
    margin: 0;
    min-width: 18px;
    height: 18px;
    padding: 0 4px;
    font-size: 11px;
}


/* --------------------------------------------------------------------------
   Buttons
   -------------------------------------------------------------------------- */
.hermes-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--hermes-space-2);
    padding: var(--hermes-space-2) var(--hermes-space-4);
    background: var(--hermes-bg);
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-md);
    color: var(--hermes-neutral-700);
    font-family: var(--hermes-font-body);
    font-weight: var(--hermes-weight-semibold);
    font-size: var(--hermes-text-sm);
    line-height: 1.4;
    text-decoration: none;
    cursor: pointer;
    transition: background var(--hermes-transition-fast),
                border-color var(--hermes-transition-fast),
                color var(--hermes-transition-fast),
                box-shadow var(--hermes-transition-fast),
                transform var(--hermes-transition-fast);
    white-space: nowrap;
}
.hermes-btn:hover {
    background: var(--hermes-neutral-50);
    border-color: var(--hermes-border-strong);
}

.hermes-btn--primary {
    background: var(--hermes-primary);
    border-color: var(--hermes-primary);
    color: var(--hermes-text-inverse);
}
.hermes-btn--primary:hover {
    background: var(--hermes-primary-dark);
    border-color: var(--hermes-primary-dark);
    color: var(--hermes-text-inverse);
}

.hermes-btn--accent {
    background: var(--hermes-accent);
    border-color: var(--hermes-accent);
    color: var(--hermes-text-inverse);
}
.hermes-btn--accent:hover {
    background: var(--hermes-accent-dark);
    border-color: var(--hermes-accent-dark);
    color: var(--hermes-text-inverse);
}

.hermes-btn--ghost {
    background: transparent;
    border-color: transparent;
    color: var(--hermes-neutral-700);
}
.hermes-btn--ghost:hover {
    background: var(--hermes-neutral-100);
}

.hermes-btn--sm { padding: var(--hermes-space-1) var(--hermes-space-3); font-size: var(--hermes-text-xs); }
.hermes-btn--lg { padding: var(--hermes-space-3) var(--hermes-space-5); font-size: var(--hermes-text-base); }


/* --------------------------------------------------------------------------
   Sidebar (admin)
   -------------------------------------------------------------------------- */
.hermes-staff-layout {
    display: grid;
    grid-template-columns: var(--hermes-sidebar-width) 1fr;
    min-height: 100vh;
}

.hermes-sidebar {
    position: sticky;
    top: 0;
    align-self: start;
    height: 100vh;
    overflow-y: auto;
    background: var(--hermes-neutral-900);
    color: var(--hermes-neutral-200);
    border-right: 1px solid var(--hermes-neutral-800);
    padding: var(--hermes-space-5) 0;
}
.hermes-sidebar__brand {
    display: flex;
    align-items: center;
    gap: var(--hermes-space-2);
    padding: 0 var(--hermes-space-5) var(--hermes-space-6);
    color: var(--hermes-text-inverse);
    font-family: var(--hermes-font-heading);
    font-weight: var(--hermes-weight-bold);
    font-size: var(--hermes-text-lg);
    text-decoration: none;
}
.hermes-sidebar__section {
    padding: var(--hermes-space-4) 0;
    border-top: 1px solid var(--hermes-neutral-800);
}
.hermes-sidebar__section:first-of-type { border-top: 0; }
.hermes-sidebar__section-title {
    padding: 0 var(--hermes-space-5);
    margin: 0 0 var(--hermes-space-2);
    color: var(--hermes-neutral-400);
    font-size: var(--hermes-text-xs);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-weight: var(--hermes-weight-semibold);
}
.hermes-sidebar__list {
    list-style: none;
    margin: 0;
    padding: 0;
}
.hermes-sidebar__link {
    display: flex;
    align-items: center;
    gap: var(--hermes-space-3);
    padding: var(--hermes-space-2) var(--hermes-space-5);
    color: var(--hermes-neutral-300);
    font-size: var(--hermes-text-sm);
    font-weight: var(--hermes-weight-medium);
    text-decoration: none;
    border-left: 3px solid transparent;
    transition: background var(--hermes-transition-fast),
                color var(--hermes-transition-fast),
                border-color var(--hermes-transition-fast);
}
.hermes-sidebar__link:hover {
    background: rgba(255, 255, 255, 0.04);
    color: var(--hermes-text-inverse);
}
.hermes-sidebar__link.is-active {
    background: rgba(46, 123, 181, 0.15);
    color: var(--hermes-text-inverse);
    border-left-color: var(--hermes-primary-light);
}
.hermes-sidebar__link i { font-size: var(--hermes-text-lg); }

.hermes-sidebar__user {
    margin: var(--hermes-space-5) var(--hermes-space-4) 0;
    padding: var(--hermes-space-3);
    background: var(--hermes-neutral-800);
    border-radius: var(--hermes-radius-md);
    font-size: var(--hermes-text-xs);
    color: var(--hermes-neutral-200);
}
.hermes-sidebar__user-name { font-weight: var(--hermes-weight-semibold); }
.hermes-sidebar__user-role { color: var(--hermes-neutral-400); }

.hermes-staff-content {
    background: var(--hermes-bg-muted);
    min-height: 100vh;
}


/* --------------------------------------------------------------------------
   Footer
   -------------------------------------------------------------------------- */
.hermes-footer {
    background: var(--hermes-neutral-50);
    border-top: 1px solid var(--hermes-border);
    padding-top: var(--hermes-space-10);
}
.hermes-footer__grid {
    display: grid;
    grid-template-columns: 2fr repeat(3, 1fr);
    gap: var(--hermes-space-8);
}
.hermes-footer__brand {
    display: flex;
    flex-direction: column;
    gap: var(--hermes-space-3);
    color: var(--hermes-neutral-700);
}
.hermes-footer__tagline {
    color: var(--hermes-neutral-500);
    font-size: var(--hermes-text-sm);
    max-width: 320px;
}
.hermes-footer__heading {
    font-family: var(--hermes-font-heading);
    font-weight: var(--hermes-weight-semibold);
    font-size: var(--hermes-text-sm);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--hermes-neutral-900);
    margin: 0 0 var(--hermes-space-3);
}
.hermes-footer__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: var(--hermes-space-2);
}
.hermes-footer__link {
    color: var(--hermes-neutral-600);
    font-size: var(--hermes-text-sm);
    text-decoration: none;
}
.hermes-footer__link:hover { color: var(--hermes-primary); }
.hermes-footer__bottom {
    margin-top: var(--hermes-space-8);
    padding: var(--hermes-space-4) 0;
    border-top: 1px solid var(--hermes-border);
    display: flex;
    align-items: center;
    justify-content: space-between;
    color: var(--hermes-neutral-500);
    font-size: var(--hermes-text-xs);
}
.hermes-footer__socials {
    display: flex;
    gap: var(--hermes-space-2);
}
.hermes-footer__disclaimer {
    margin: 0;
    padding-bottom: var(--hermes-space-4);
    color: var(--hermes-neutral-500);
    font-size: var(--hermes-text-xs);
    line-height: 1.5;
    text-align: center;
    opacity: 0.85;
}
.hermes-footer__social {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: var(--hermes-radius-full);
    background: var(--hermes-bg);
    border: 1px solid var(--hermes-border);
    color: var(--hermes-neutral-600);
    transition: background var(--hermes-transition-fast),
                color var(--hermes-transition-fast);
}
.hermes-footer__social:hover {
    background: var(--hermes-primary);
    color: var(--hermes-text-inverse);
    border-color: var(--hermes-primary);
}


/* --------------------------------------------------------------------------
   Breadcrumbs
   -------------------------------------------------------------------------- */
.hermes-breadcrumbs {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--hermes-space-2);
    margin: 0 0 var(--hermes-space-4);
    padding: 0;
    list-style: none;
    color: var(--hermes-neutral-500);
    font-size: var(--hermes-text-sm);
}
.hermes-breadcrumbs__sep { color: var(--hermes-neutral-300); }
.hermes-breadcrumbs a { color: var(--hermes-neutral-600); }
.hermes-breadcrumbs a:hover { color: var(--hermes-primary); }
.hermes-breadcrumbs__current { color: var(--hermes-neutral-900); font-weight: var(--hermes-weight-medium); }


/* --------------------------------------------------------------------------
   Empty state
   -------------------------------------------------------------------------- */
.hermes-empty {
    padding: var(--hermes-space-10) var(--hermes-space-4);
    text-align: center;
    color: var(--hermes-neutral-500);
}
.hermes-empty__icon {
    font-size: var(--hermes-text-5xl);
    color: var(--hermes-neutral-300);
    margin-bottom: var(--hermes-space-3);
}
.hermes-empty__title {
    color: var(--hermes-neutral-700);
    font-weight: var(--hermes-weight-semibold);
    margin-bottom: var(--hermes-space-2);
}
.hermes-empty__body {
    font-size: var(--hermes-text-sm);
    max-width: 420px;
    margin: 0 auto var(--hermes-space-4);
}


/* --------------------------------------------------------------------------
   Flash messages
   -------------------------------------------------------------------------- */
.hermes-flash {
    margin: var(--hermes-space-4) 0;
    padding: var(--hermes-space-3) var(--hermes-space-4);
    border-radius: var(--hermes-radius-md);
    border: 1px solid transparent;
    font-size: var(--hermes-text-sm);
}
.hermes-flash--success  { background: var(--hermes-success-light); border-color: var(--hermes-success); color: var(--hermes-success-dark); }
.hermes-flash--warning  { background: var(--hermes-warning-light); border-color: var(--hermes-warning); color: var(--hermes-warning-dark); }
.hermes-flash--error,
.hermes-flash--danger   { background: var(--hermes-error-light); border-color: var(--hermes-error); color: var(--hermes-error-dark); }
.hermes-flash--info,
.hermes-flash--debug    { background: var(--hermes-info-light); border-color: var(--hermes-info); color: var(--hermes-neutral-800); }


/* --------------------------------------------------------------------------
   Cart
   -------------------------------------------------------------------------- */

/* Topbar counter badge — sits on top of the cart icon. */
.hermes-cart-counter {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 20px;
    height: 20px;
    padding: 0 6px;
    margin-left: var(--hermes-space-1);
    border-radius: var(--hermes-radius-full);
    background: var(--hermes-accent);
    color: var(--hermes-text-inverse);
    font-size: var(--hermes-text-xs);
    font-weight: var(--hermes-weight-bold);
    line-height: 1;
}
.hermes-cart-counter.is-bumped {
    animation: hermes-counter-bump 350ms var(--hermes-ease);
}
@keyframes hermes-counter-bump {
    0%   { transform: scale(1); }
    40%  { transform: scale(1.4); }
    100% { transform: scale(1); }
}

/* Cart item row. Grid switches to stacked cards on mobile. */
.hermes-cart-items {
    display: flex;
    flex-direction: column;
    gap: var(--hermes-space-3);
}
.hermes-cart-item {
    display: grid;
    grid-template-columns: 80px 1fr 110px 130px 110px 48px;
    align-items: center;
    gap: var(--hermes-space-4);
    padding: var(--hermes-space-3) var(--hermes-space-4);
    background: var(--hermes-bg);
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-lg);
    box-shadow: var(--hermes-shadow-xs);
}
.hermes-cart-item__image {
    width: 64px;
    height: 64px;
    background: var(--hermes-bg-muted);
    border-radius: var(--hermes-radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    color: var(--hermes-neutral-400);
}
.hermes-cart-item__image img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}
.hermes-cart-item__name {
    color: var(--hermes-neutral-900);
    font-weight: var(--hermes-weight-semibold);
    text-decoration: none;
    line-height: var(--hermes-leading-snug);
    display: block;
    margin-bottom: var(--hermes-space-1);
}
.hermes-cart-item__name:hover { color: var(--hermes-primary); }
.hermes-cart-item__meta {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--hermes-space-2);
    font-size: var(--hermes-text-sm);
}
.hermes-cart-item__price,
.hermes-cart-item__subtotal {
    text-align: right;
    font-size: var(--hermes-text-sm);
}
.hermes-cart-item__subtotal { font-weight: var(--hermes-weight-semibold); }
.hermes-cart-item__qty {
    display: flex;
    align-items: center;
    gap: var(--hermes-space-1);
    justify-content: center;
}
.hermes-cart-item__remove { text-align: right; }
.hermes-quantity-input {
    width: 72px;
    padding: var(--hermes-space-1) var(--hermes-space-2);
    font-size: var(--hermes-text-sm);
    text-align: center;
    background: var(--hermes-bg);
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-md);
}
.hermes-quantity-input:focus {
    outline: none;
    border-color: var(--hermes-primary-light);
    box-shadow: var(--hermes-shadow-focus);
}

/* Cart summary block (totals + optimiser teaser) */
.hermes-cart-summary {
    display: grid;
    grid-template-columns: 1fr 1.4fr;
    gap: var(--hermes-space-5);
    padding: var(--hermes-space-5);
    background: var(--hermes-bg);
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-lg);
    box-shadow: var(--hermes-shadow-sm);
}
.hermes-cart-summary__amount {
    font-family: var(--hermes-font-heading);
    font-size: var(--hermes-text-4xl);
    font-weight: var(--hermes-weight-extrabold);
    color: var(--hermes-primary);
    line-height: 1.1;
    margin: var(--hermes-space-1) 0;
}
.hermes-cart-summary__optimize {
    background: linear-gradient(135deg, var(--hermes-primary-50), var(--hermes-bg));
    border: 1px dashed var(--hermes-primary-light);
    border-radius: var(--hermes-radius-md);
    padding: var(--hermes-space-4);
}

/* "Save as named basket" CTA on the cart page. */
.hermes-cart-summary__save {
    margin-top: var(--hermes-space-3);
    background: var(--hermes-bg-muted);
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-md);
    padding: var(--hermes-space-4);
}

/* Feature bullet list (named-baskets empty state). */
.hermes-feature-list {
    list-style: none;
    margin: var(--hermes-space-4) auto;
    padding: 0;
    max-width: 360px;
    text-align: left;
    display: flex;
    flex-direction: column;
    gap: var(--hermes-space-2);
}
.hermes-feature-list li {
    display: flex;
    align-items: center;
    gap: var(--hermes-space-2);
    color: var(--hermes-text);
    font-size: var(--hermes-text-sm);
}

/* Tier indicator banner */
.hermes-tier-indicator {
    display: flex;
    align-items: center;
    gap: var(--hermes-space-2);
    padding: var(--hermes-space-3) var(--hermes-space-4);
    border-radius: var(--hermes-radius-md);
    font-size: var(--hermes-text-sm);
    background: var(--hermes-info-light);
    color: var(--hermes-neutral-800);
    border: 1px solid transparent;
}
.hermes-tier-indicator--warn {
    background: var(--hermes-warning-light);
    color: var(--hermes-warning-dark);
    border-color: var(--hermes-warning);
}
.hermes-tier-indicator--success {
    background: var(--hermes-success-light);
    color: var(--hermes-success-dark);
}

/* Toast / flash for cart actions (positioned at top-right) */
.hermes-toast-host {
    position: fixed;
    top: calc(var(--hermes-topbar-height) + var(--hermes-space-3));
    right: var(--hermes-space-4);
    z-index: var(--hermes-z-toast);
    display: flex;
    flex-direction: column;
    gap: var(--hermes-space-2);
    pointer-events: none;
    max-width: min(360px, 90vw);
}
.hermes-toast {
    pointer-events: auto;
    display: flex;
    align-items: center;
    gap: var(--hermes-space-3);
    padding: var(--hermes-space-3) var(--hermes-space-4);
    border-radius: var(--hermes-radius-md);
    background: var(--hermes-neutral-900);
    color: var(--hermes-text-inverse);
    font-size: var(--hermes-text-sm);
    box-shadow: var(--hermes-shadow-lg);
    transform: translateY(-8px);
    opacity: 0;
    transition: opacity var(--hermes-transition-normal),
                transform var(--hermes-transition-normal);
}
.hermes-toast__action {
    flex: 0 0 auto;
    color: #fff;
    font-weight: 700;
    text-decoration: underline;
    white-space: nowrap;
}
.hermes-toast.is-visible {
    opacity: 1;
    transform: translateY(0);
}
.hermes-toast--success { background: var(--hermes-success-dark); }
.hermes-toast--error   { background: var(--hermes-error-dark); }


/* --------------------------------------------------------------------------
   Optimize result
   -------------------------------------------------------------------------- */

.hermes-optimize-hero {
    padding: var(--hermes-space-7) var(--hermes-space-5);
    text-align: center;
    background:
        radial-gradient(at top, rgba(15, 76, 129, 0.08), transparent 60%),
        var(--hermes-bg-elevated);
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-xl);
    box-shadow: var(--hermes-shadow-sm);
}
.hermes-optimize-hero__icon {
    font-size: var(--hermes-text-6xl);
    line-height: 1;
    margin-bottom: var(--hermes-space-3);
}
.hermes-optimize-hero__headline {
    font-family: var(--hermes-font-heading);
    font-weight: var(--hermes-weight-extrabold);
    font-size: var(--hermes-text-4xl);
    line-height: 1.15;
    margin: 0 0 var(--hermes-space-3);
}
.hermes-optimize-hero__body {
    font-size: var(--hermes-text-lg);
    color: var(--hermes-neutral-600);
    max-width: 640px;
    margin: 0 auto;
}
.hermes-optimize-savings {
    color: var(--hermes-success-dark);
    font-size: 1.2em;
    font-weight: var(--hermes-weight-extrabold);
    padding: 0 .25em;
    background: var(--hermes-success-light);
    border-radius: var(--hermes-radius-md);
}

/* Comparison grid */
.hermes-comparison-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: var(--hermes-space-4);
}

.hermes-comparison-card {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: var(--hermes-space-3);
    padding: var(--hermes-space-5);
    background: var(--hermes-bg);
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-lg);
    box-shadow: var(--hermes-shadow-xs);
    transition: box-shadow var(--hermes-transition-fast),
                transform var(--hermes-transition-fast);
}
.hermes-comparison-card:hover {
    box-shadow: var(--hermes-shadow-md);
}
.hermes-comparison-card--recommended {
    border-color: var(--hermes-success);
    border-width: 2px;
    background: linear-gradient(180deg,
        var(--hermes-success-light) 0%,
        var(--hermes-bg) 30%);
    box-shadow: var(--hermes-shadow-md);
}
.hermes-comparison-card__badge {
    position: absolute;
    top: calc(-1 * var(--hermes-space-2));
    right: var(--hermes-space-4);
    padding: var(--hermes-space-1) var(--hermes-space-3);
    background: var(--hermes-success);
    color: var(--hermes-text-inverse);
    font-size: var(--hermes-text-xs);
    font-weight: var(--hermes-weight-bold);
    border-radius: var(--hermes-radius-full);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.hermes-comparison-card h3 {
    font-size: var(--hermes-text-xl);
    margin: 0;
}
.hermes-comparison-card__sub {
    color: var(--hermes-neutral-500);
    font-size: var(--hermes-text-sm);
    margin: var(--hermes-space-1) 0 0;
}
.hermes-comparison-card__price {
    font-family: var(--hermes-font-heading);
    font-size: var(--hermes-text-4xl);
    font-weight: var(--hermes-weight-extrabold);
    color: var(--hermes-primary);
    line-height: 1.1;
}
.hermes-comparison-card__list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: var(--hermes-space-2);
    font-size: var(--hermes-text-sm);
}
.hermes-comparison-card__list li {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: var(--hermes-space-2);
    padding-bottom: var(--hermes-space-1);
    border-bottom: 1px dashed var(--hermes-border);
}
.hermes-comparison-card__line-total {
    color: var(--hermes-neutral-700);
    font-weight: var(--hermes-weight-semibold);
}

/* Coverage indicators */
.hermes-coverage-indicator {
    display: inline-flex;
    align-items: center;
    gap: var(--hermes-space-1);
    padding: var(--hermes-space-1) var(--hermes-space-3);
    border-radius: var(--hermes-radius-full);
    font-size: var(--hermes-text-sm);
    font-weight: var(--hermes-weight-medium);
}
.hermes-coverage-indicator--full {
    background: var(--hermes-success-light);
    color: var(--hermes-success-dark);
}
.hermes-coverage-indicator--partial {
    background: var(--hermes-warning-light);
    color: var(--hermes-warning-dark);
}

/* Missing-items list */
.hermes-missing-items {
    margin-top: auto;
    padding: var(--hermes-space-3);
    background: var(--hermes-error-light);
    border: 1px solid var(--hermes-error);
    border-radius: var(--hermes-radius-md);
    font-size: var(--hermes-text-sm);
}
.hermes-missing-items__title {
    font-weight: var(--hermes-weight-semibold);
    color: var(--hermes-error-dark);
    margin-bottom: var(--hermes-space-1);
}
.hermes-missing-items ul {
    margin: 0;
    padding-left: var(--hermes-space-5);
    color: var(--hermes-neutral-700);
}

/* Optimise actions */
.hermes-optimize-actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--hermes-space-3);
    justify-content: center;
}
.hermes-chart-card {
    padding: var(--hermes-space-5);
    background: var(--hermes-bg);
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-lg);
    box-shadow: var(--hermes-shadow-xs);
}

/* Print-only shopping list (hidden on screen) */
.hermes-print-list h1 {
    font-size: 20pt;
    margin: 0 0 8pt;
}
.hermes-print-list h2 {
    font-size: 14pt;
    margin: 16pt 0 6pt;
    border-bottom: 1pt solid #000;
    padding-bottom: 2pt;
}
.hermes-print-checklist {
    list-style: none;
    padding: 0;
    margin: 0 0 8pt;
}
.hermes-print-checklist li {
    display: flex;
    align-items: center;
    gap: 6pt;
    padding: 3pt 0;
    border-bottom: 1pt dotted #ccc;
}
.hermes-print-checklist__price {
    margin-left: auto;
    font-weight: bold;
}
.hermes-print-total {
    text-align: right;
    font-size: 13pt;
    margin: 8pt 0;
}
.hermes-print-subtotal {
    text-align: right;
    font-size: 11pt;
    color: #444;
    margin: 4pt 0 0;
}

@media print {
    html, body {
        background: #fff !important;
        color: #000 !important;
    }
    .hermes-topbar,
    .hermes-footer,
    .hermes-toast-host,
    .d-print-none {
        display: none !important;
    }
    .d-print-block, .d-none.d-print-block {
        display: block !important;
    }
    .hermes-container {
        max-width: none;
        padding: 0;
    }
    .hermes-optimize-hero,
    .hermes-comparison-grid,
    .hermes-chart-card,
    .hermes-optimize-actions,
    nav[aria-label] {
        display: none !important;
    }
    .hermes-print-list {
        page-break-inside: avoid;
    }
}


/* --------------------------------------------------------------------------
   Landing (Phase D)
   -------------------------------------------------------------------------- */

/* Section helpers reused across landing/about/pricing */
.hermes-section--muted { background: var(--hermes-bg-muted); }
.hermes-section__heading {
    text-align: center;
    max-width: 720px;
    margin: 0 auto var(--hermes-space-7);
}
.hermes-section__heading h2 {
    font-size: var(--hermes-text-3xl);
    margin-bottom: var(--hermes-space-2);
}
.hermes-section__sub {
    color: var(--hermes-neutral-500);
    font-size: var(--hermes-text-lg);
    margin: 0;
}

/* Hero ===================================================================== */
.hermes-landing-hero {
    padding: var(--hermes-space-10) 0 var(--hermes-space-8);
    background:
        radial-gradient(circle at 80% 0%, rgba(15, 76, 129, 0.10), transparent 55%),
        radial-gradient(circle at 0% 80%, rgba(245, 158, 11, 0.07), transparent 50%),
        var(--hermes-bg);
    border-bottom: 1px solid var(--hermes-border);
}
.hermes-landing-hero__inner {
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: var(--hermes-space-7);
    align-items: center;
}
.hermes-landing-hero__headline {
    font-size: var(--hermes-text-6xl);
    font-weight: var(--hermes-weight-extrabold);
    line-height: 1.05;
    letter-spacing: -0.02em;
    margin: 0 0 var(--hermes-space-4);
}
.hermes-landing-hero__line { display: block; }
.hermes-landing-hero__accent {
    color: var(--hermes-primary);
}
.hermes-landing-hero__sub {
    font-size: var(--hermes-text-xl);
    color: var(--hermes-neutral-600);
    max-width: 560px;
    margin: 0 0 var(--hermes-space-6);
}
.hermes-landing-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--hermes-space-3);
}

.hermes-landing-hero__cart-preview {
    padding: var(--hermes-space-5);
    background: var(--hermes-bg);
    border-radius: var(--hermes-radius-xl);
    box-shadow: var(--hermes-shadow-lg);
    border: 1px solid var(--hermes-border);
    transform: rotate(-1deg);
}
.hermes-cart-preview__header {
    display: flex;
    align-items: center;
    gap: var(--hermes-space-2);
    font-family: var(--hermes-font-heading);
    font-weight: var(--hermes-weight-bold);
    color: var(--hermes-primary);
    margin-bottom: var(--hermes-space-4);
}
.hermes-cart-preview__list {
    list-style: none;
    padding: 0;
    margin: 0 0 var(--hermes-space-4);
}
.hermes-cart-preview__list li {
    display: grid;
    grid-template-columns: 1fr auto auto;
    gap: var(--hermes-space-2);
    align-items: center;
    padding: var(--hermes-space-2) 0;
    border-bottom: 1px dashed var(--hermes-border);
    font-size: var(--hermes-text-sm);
}
.hermes-cart-preview__list li:last-child { border-bottom: 0; }
.hermes-cart-preview__name {
    font-weight: var(--hermes-weight-medium);
}
.hermes-cart-preview__price {
    font-weight: var(--hermes-weight-semibold);
    color: var(--hermes-neutral-800);
}
.hermes-cart-preview__footer {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    padding-top: var(--hermes-space-3);
    border-top: 2px solid var(--hermes-success);
}
.hermes-cart-preview__savings {
    font-family: var(--hermes-font-heading);
    font-size: var(--hermes-text-2xl);
    font-weight: var(--hermes-weight-extrabold);
    color: var(--hermes-success-dark);
}

/* Stats bar =============================================================== */
.hermes-stats-bar {
    background: var(--hermes-neutral-900);
    color: var(--hermes-text-inverse);
}
.hermes-stats-bar__inner {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--hermes-space-4);
    padding: var(--hermes-space-5) var(--hermes-space-4);
    text-align: center;
}
.hermes-stat {
    display: flex;
    flex-direction: column;
    gap: var(--hermes-space-1);
}
.hermes-stat strong {
    font-family: var(--hermes-font-heading);
    font-size: var(--hermes-text-3xl);
    font-weight: var(--hermes-weight-extrabold);
    color: var(--hermes-accent-light);
}
.hermes-stat span {
    color: var(--hermes-neutral-300);
    font-size: var(--hermes-text-sm);
}

/* Step cards (how it works) ============================================== */
.hermes-step-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--hermes-space-5);
}
.hermes-step-card {
    position: relative;
    padding: var(--hermes-space-7) var(--hermes-space-5) var(--hermes-space-5);
    background: var(--hermes-bg);
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-lg);
    box-shadow: var(--hermes-shadow-xs);
    text-align: center;
    transition: transform var(--hermes-transition-fast),
                box-shadow var(--hermes-transition-fast);
}
.hermes-step-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--hermes-shadow-md);
}
.hermes-step-card__number {
    position: absolute;
    top: calc(-1 * var(--hermes-space-5));
    left: 50%;
    transform: translateX(-50%);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    background: var(--hermes-accent);
    color: var(--hermes-text-inverse);
    border-radius: var(--hermes-radius-full);
    font-family: var(--hermes-font-heading);
    font-size: var(--hermes-text-xl);
    font-weight: var(--hermes-weight-extrabold);
    box-shadow: var(--hermes-shadow-md);
}
.hermes-step-card__icon {
    font-size: var(--hermes-text-5xl);
    margin-top: var(--hermes-space-3);
    margin-bottom: var(--hermes-space-2);
}
.hermes-step-card h3 {
    font-size: var(--hermes-text-xl);
    margin: 0 0 var(--hermes-space-2);
}
.hermes-step-card p {
    color: var(--hermes-neutral-600);
    margin: 0;
    font-size: var(--hermes-text-sm);
}

/* Feature cards (2x2) ===================================================== */
.hermes-feature-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--hermes-space-4);
}
.hermes-feature-card {
    display: flex;
    flex-direction: column;
    gap: var(--hermes-space-2);
    padding: var(--hermes-space-5);
    background: var(--hermes-bg);
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-lg);
    box-shadow: var(--hermes-shadow-xs);
}
.hermes-feature-card__icon {
    font-size: var(--hermes-text-4xl);
    line-height: 1;
}
.hermes-feature-card h3 {
    font-size: var(--hermes-text-xl);
    margin: 0;
}
.hermes-feature-card p {
    color: var(--hermes-neutral-600);
    margin: 0;
    font-size: var(--hermes-text-sm);
}

/* Pricing cards ========================================================== */
.hermes-pricing-grid,
.hermes-pricing-teaser-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--hermes-space-5);
    align-items: stretch;
}
.hermes-pricing-card {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: var(--hermes-space-4);
    padding: var(--hermes-space-6);
    background: var(--hermes-bg);
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-lg);
    box-shadow: var(--hermes-shadow-xs);
    transition: transform var(--hermes-transition-fast),
                box-shadow var(--hermes-transition-fast);
}
.hermes-pricing-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--hermes-shadow-md);
}
.hermes-pricing-card h3 {
    font-size: var(--hermes-text-2xl);
    margin: 0;
}
.hermes-pricing-card__sub {
    color: var(--hermes-neutral-500);
    font-size: var(--hermes-text-sm);
    margin: var(--hermes-space-1) 0 0;
}
.hermes-pricing-card__price {
    display: flex;
    align-items: baseline;
    gap: var(--hermes-space-2);
}
.hermes-pricing-card__amount {
    font-family: var(--hermes-font-heading);
    font-size: var(--hermes-text-5xl);
    font-weight: var(--hermes-weight-extrabold);
    color: var(--hermes-primary);
    line-height: 1;
}
.hermes-pricing-card__unit {
    color: var(--hermes-neutral-600);
    font-weight: var(--hermes-weight-medium);
}
.hermes-pricing-card__tbd {
    font-family: var(--hermes-font-heading);
    font-size: var(--hermes-text-4xl);
    font-weight: var(--hermes-weight-extrabold);
    color: var(--hermes-neutral-400);
    line-height: 1;
}
.hermes-pricing-card__note {
    color: var(--hermes-neutral-500);
    font-size: var(--hermes-text-xs);
    margin: -8px 0 0;
}
.hermes-pricing-card__features {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: var(--hermes-space-2);
    flex-grow: 1;
}
.hermes-pricing-card__feature {
    display: flex;
    gap: var(--hermes-space-2);
    align-items: flex-start;
    font-size: var(--hermes-text-sm);
}
.hermes-pricing-card__feature--check i { color: var(--hermes-success); }
.hermes-pricing-card__feature--cross {
    color: var(--hermes-neutral-400);
    text-decoration: line-through;
}
.hermes-pricing-card__feature--cross i { color: var(--hermes-neutral-400); }
.hermes-pricing-card__badge {
    position: absolute;
    top: calc(-1 * var(--hermes-space-2));
    right: var(--hermes-space-4);
    padding: var(--hermes-space-1) var(--hermes-space-3);
    background: var(--hermes-success);
    color: var(--hermes-text-inverse);
    font-size: var(--hermes-text-xs);
    font-weight: var(--hermes-weight-bold);
    border-radius: var(--hermes-radius-full);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.hermes-pricing-card__badge--soon {
    background: var(--hermes-neutral-700);
}
.hermes-pricing-card--featured {
    border-color: var(--hermes-success);
    border-width: 2px;
    background: linear-gradient(180deg, var(--hermes-success-light) 0%, var(--hermes-bg) 25%);
}
.hermes-pricing-card--coming-soon {
    opacity: 0.85;
}
.hermes-pricing-teaser__link a {
    font-weight: var(--hermes-weight-semibold);
}

/* Final CTA ============================================================== */
.hermes-final-cta {
    background:
        linear-gradient(135deg, var(--hermes-primary) 0%, var(--hermes-primary-dark) 100%);
    color: var(--hermes-text-inverse);
    padding: var(--hermes-space-10) 0;
}
.hermes-final-cta__inner {
    text-align: center;
    max-width: 720px;
    margin: 0 auto;
}
.hermes-final-cta h2 {
    color: var(--hermes-text-inverse);
    font-size: var(--hermes-text-4xl);
    margin-bottom: var(--hermes-space-3);
}
.hermes-final-cta p {
    font-size: var(--hermes-text-lg);
    color: rgba(255, 255, 255, 0.85);
    margin-bottom: var(--hermes-space-6);
}

/* About / story =========================================================== */
.hermes-about-hero,
.hermes-pricing-hero {
    text-align: center;
    max-width: 720px;
    margin: 0 auto;
    padding: var(--hermes-space-7) 0;
}
.hermes-about-hero h1,
.hermes-pricing-hero h1 {
    font-size: var(--hermes-text-5xl);
    margin-bottom: var(--hermes-space-3);
}
.hermes-story-grid {
    display: grid;
    grid-template-columns: 3fr 2fr;
    gap: var(--hermes-space-7);
    align-items: center;
}
.hermes-story-grid__text h2 {
    margin-bottom: var(--hermes-space-3);
}
.hermes-story-grid__text p {
    font-size: var(--hermes-text-lg);
    color: var(--hermes-neutral-700);
}
.hermes-story-grid__visual {
    display: flex;
    justify-content: center;
}
.hermes-story-monogram {
    width: 240px;
    height: 240px;
    display: flex;
    align-items: center;
    justify-content: center;
    background:
        linear-gradient(135deg, var(--hermes-primary) 0%, var(--hermes-primary-light) 100%);
    color: var(--hermes-text-inverse);
    border-radius: var(--hermes-radius-2xl);
    box-shadow: var(--hermes-shadow-xl);
    font-family: var(--hermes-font-heading);
    font-size: 72px;
    font-weight: var(--hermes-weight-extrabold);
}
.hermes-mission {
    max-width: 760px;
    margin: 0 auto;
}
.hermes-mission h2 {
    margin-bottom: var(--hermes-space-4);
    text-align: center;
}
.hermes-mission p {
    font-size: var(--hermes-text-lg);
    color: var(--hermes-neutral-700);
    margin-bottom: var(--hermes-space-4);
}

/* FAQ accordion ========================================================== */
.hermes-faq {
    max-width: 760px;
    margin: 0 auto;
}
.hermes-faq__item {
    border-radius: var(--hermes-radius-md);
    margin-bottom: var(--hermes-space-2);
    overflow: hidden;
}

/* Contact card (Phase H) */
.hermes-contact-card {
    margin-top: var(--hermes-space-4);
    background: var(--hermes-bg);
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-lg);
    padding: var(--hermes-space-5);
    box-shadow: var(--hermes-shadow-sm);
}
.hermes-contact-card__row {
    display: flex;
    align-items: center;
    gap: var(--hermes-space-4);
}
.hermes-contact-card__row i {
    font-size: var(--hermes-text-3xl);
    color: var(--hermes-primary);
}
.hermes-contact-card__label {
    color: var(--hermes-neutral-500);
    font-size: var(--hermes-text-sm);
}
.hermes-contact-card__value {
    font-family: var(--hermes-font-heading);
    font-size: var(--hermes-text-xl);
    font-weight: var(--hermes-weight-semibold);
    color: var(--hermes-primary);
    text-decoration: none;
}
.hermes-contact-card__value:hover {
    color: var(--hermes-primary-dark);
    text-decoration: underline;
}


/* --------------------------------------------------------------------------
   Customer dashboard + settings (Phase E1)
   -------------------------------------------------------------------------- */

/* Tier badge — used in dashboard hero + settings info */
.hermes-tier-badge {
    display: inline-flex;
    align-items: center;
    gap: var(--hermes-space-1);
    padding: var(--hermes-space-1) var(--hermes-space-3);
    background: var(--hermes-primary-50);
    color: var(--hermes-primary);
    border: 1px solid var(--hermes-primary-light);
    border-radius: var(--hermes-radius-full);
    font-size: var(--hermes-text-sm);
    font-weight: var(--hermes-weight-semibold);
}
.hermes-tier-badge--free {
    background: var(--hermes-neutral-100);
    color: var(--hermes-neutral-700);
    border-color: var(--hermes-border);
}

/* Card helper used in cart history detail page */
.hermes-card {
    background: var(--hermes-bg);
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-lg);
    box-shadow: var(--hermes-shadow-xs);
}

/* Hero greeting */
.hermes-dashboard-hero {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: var(--hermes-space-5);
    align-items: flex-start;
    padding: var(--hermes-space-7);
    background:
        radial-gradient(circle at top right, rgba(15, 76, 129, 0.08), transparent 60%),
        var(--hermes-bg);
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-xl);
    box-shadow: var(--hermes-shadow-sm);
    margin-bottom: var(--hermes-space-6);
}
.hermes-dashboard-hero__eyebrow {
    color: var(--hermes-neutral-500);
    font-size: var(--hermes-text-lg);
    margin: 0 0 var(--hermes-space-1);
}
.hermes-dashboard-hero__headline {
    font-size: var(--hermes-text-4xl);
    line-height: 1.15;
    margin: 0 0 var(--hermes-space-2);
}
.hermes-dashboard-hero__amount {
    color: var(--hermes-success-dark);
    background: var(--hermes-success-light);
    padding: 0 .3em;
    border-radius: var(--hermes-radius-md);
    font-weight: var(--hermes-weight-extrabold);
}
.hermes-dashboard-hero__sub {
    color: var(--hermes-neutral-600);
    margin: 0 0 var(--hermes-space-4);
    font-size: var(--hermes-text-lg);
}
.hermes-dashboard-hero__actions {
    display: flex;
    gap: var(--hermes-space-2);
    flex-wrap: wrap;
}
.hermes-dashboard-hero__tier {
    align-self: flex-start;
}

/* Stats row */
.hermes-dashboard-stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--hermes-space-3);
    margin-bottom: var(--hermes-space-6);
}
.hermes-dashboard-stat {
    display: flex;
    flex-direction: column;
    gap: var(--hermes-space-1);
    padding: var(--hermes-space-4);
    background: var(--hermes-bg);
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-lg);
    box-shadow: var(--hermes-shadow-xs);
    text-align: center;
}
.hermes-dashboard-stat__icon {
    font-size: var(--hermes-text-3xl);
    line-height: 1;
}
.hermes-dashboard-stat__value {
    font-family: var(--hermes-font-heading);
    font-size: var(--hermes-text-2xl);
    font-weight: var(--hermes-weight-extrabold);
    color: var(--hermes-primary);
}
.hermes-dashboard-stat__label {
    color: var(--hermes-neutral-500);
    font-size: var(--hermes-text-sm);
}

/* Section wrapper inside dashboard */
.hermes-dashboard-section {
    margin-bottom: var(--hermes-space-7);
}
.hermes-dashboard-section__heading h2 {
    font-size: var(--hermes-text-2xl);
    margin: 0 0 var(--hermes-space-4);
}

/* Active cart widget */
.hermes-dashboard-active-cart {
    padding: var(--hermes-space-5);
    background:
        linear-gradient(135deg, var(--hermes-primary-50), var(--hermes-bg));
    border: 1px solid var(--hermes-primary-light);
    border-radius: var(--hermes-radius-lg);
}
.hermes-dashboard-active-cart__top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--hermes-space-4);
    flex-wrap: wrap;
}

/* Cart list row (dashboard widget) */
.hermes-dashboard-cart-list {
    display: flex;
    flex-direction: column;
    gap: var(--hermes-space-2);
}
.hermes-dashboard-cart-row {
    display: grid;
    grid-template-columns: 1.6fr 1fr 1fr 1fr 24px;
    align-items: center;
    gap: var(--hermes-space-3);
    padding: var(--hermes-space-3) var(--hermes-space-4);
    background: var(--hermes-bg);
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-md);
    color: inherit;
    text-decoration: none;
    transition: background var(--hermes-transition-fast),
                border-color var(--hermes-transition-fast);
}
.hermes-dashboard-cart-row:hover {
    background: var(--hermes-primary-50);
    border-color: var(--hermes-primary-light);
}
.hermes-dashboard-cart-row__name {
    font-weight: var(--hermes-weight-semibold);
}
.hermes-dashboard-cart-row__chev {
    color: var(--hermes-neutral-400);
    text-align: right;
}

/* Recommendations row */
.hermes-dashboard-recs {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--hermes-space-3);
}
.hermes-dashboard-rec-card {
    display: flex;
    flex-direction: column;
    gap: var(--hermes-space-2);
    padding: var(--hermes-space-3);
    background: var(--hermes-bg);
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-md);
}
.hermes-dashboard-rec-card__image {
    display: block;
    aspect-ratio: 4 / 3;
    background: var(--hermes-bg-muted);
    border-radius: var(--hermes-radius-md);
    overflow: hidden;
    color: var(--hermes-neutral-400);
    text-align: center;
}
.hermes-dashboard-rec-card__image img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}
.hermes-dashboard-rec-card__image i {
    font-size: var(--hermes-text-3xl);
    line-height: 100px;
}
.hermes-dashboard-rec-card__name {
    color: var(--hermes-neutral-900);
    font-weight: var(--hermes-weight-semibold);
    text-decoration: none;
    font-size: var(--hermes-text-sm);
}
.hermes-dashboard-rec-card__name:hover { color: var(--hermes-primary); }
.hermes-dashboard-rec-card__price {
    font-weight: var(--hermes-weight-bold);
    color: var(--hermes-primary);
}

/* Quick actions */
.hermes-dashboard-quick-actions {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--hermes-space-3);
}
.hermes-dashboard-quick {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--hermes-space-1);
    padding: var(--hermes-space-5) var(--hermes-space-3);
    background: var(--hermes-bg);
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-md);
    color: var(--hermes-neutral-700);
    text-decoration: none;
    text-align: center;
    transition: background var(--hermes-transition-fast),
                color var(--hermes-transition-fast),
                border-color var(--hermes-transition-fast);
}
.hermes-dashboard-quick:hover {
    background: var(--hermes-primary-50);
    color: var(--hermes-primary);
    border-color: var(--hermes-primary-light);
}
.hermes-dashboard-quick i { font-size: var(--hermes-text-2xl); }

/* Cart list page filters */
.hermes-cart-list-summary {
    display: flex;
    align-items: center;
    gap: var(--hermes-space-2);
    padding: var(--hermes-space-3) var(--hermes-space-4);
    background: var(--hermes-primary-50);
    border: 1px solid var(--hermes-primary-light);
    border-radius: var(--hermes-radius-md);
    font-size: 0.95rem;
}
.hermes-cart-list-summary .bi { color: var(--hermes-primary); }

.hermes-cart-list-filters {
    display: flex;
    gap: var(--hermes-space-2);
    flex-wrap: wrap;
}
.hermes-cart-list-filter {
    padding: var(--hermes-space-1) var(--hermes-space-4);
    background: var(--hermes-bg);
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-full);
    color: var(--hermes-neutral-700);
    text-decoration: none;
    font-size: var(--hermes-text-sm);
}
.hermes-cart-list-filter:hover { background: var(--hermes-primary-50); color: var(--hermes-primary); }
.hermes-cart-list-filter.is-active {
    background: var(--hermes-primary);
    color: var(--hermes-text-inverse);
    border-color: var(--hermes-primary);
}

/* Cart list rows */
.hermes-cart-list {
    display: flex;
    flex-direction: column;
    gap: var(--hermes-space-2);
}
.hermes-cart-list-row {
    display: grid;
    grid-template-columns: auto 1fr auto 24px;
    align-items: center;
    gap: var(--hermes-space-3);
    padding: var(--hermes-space-3) var(--hermes-space-4);
    background: var(--hermes-bg);
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-md);
    transition: background var(--hermes-transition-fast);
}
.hermes-cart-list-row--active {
    border-left: 3px solid var(--hermes-success);
}
.hermes-cart-list-row:hover { background: var(--hermes-bg-muted); }
.hermes-cart-list-row__main {
    color: inherit;
    text-decoration: none;
    display: flex;
    flex-direction: column;
    gap: var(--hermes-space-1);
}
.hermes-cart-list-row__name {
    font-weight: var(--hermes-weight-semibold);
}
.hermes-cart-list-row__chev {
    color: var(--hermes-neutral-400);
    text-align: right;
}

/* Settings sections */
.hermes-settings-section {
    padding: var(--hermes-space-6);
    background: var(--hermes-bg);
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-lg);
    box-shadow: var(--hermes-shadow-xs);
    margin-bottom: var(--hermes-space-5);
}
.hermes-settings-section h2 {
    font-size: var(--hermes-text-xl);
    margin: 0 0 var(--hermes-space-1);
}
.hermes-settings-section--disabled {
    opacity: 0.75;
    background: var(--hermes-bg-muted);
}
.hermes-settings-section--danger {
    border-color: var(--hermes-error-light);
}
.hermes-settings-section__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--hermes-space-3);
    flex-wrap: wrap;
    margin-bottom: var(--hermes-space-2);
}
.hermes-settings-section__head h2 { margin: 0; }

/* Consistent "Скоро" pill for disabled settings sections */
.hermes-soon-badge {
    display: inline-flex;
    align-items: center;
    padding: var(--hermes-space-1) var(--hermes-space-3);
    background: var(--hermes-neutral-700);
    color: var(--hermes-text-inverse);
    border-radius: var(--hermes-radius-full);
    font-size: var(--hermes-text-xs);
    font-weight: var(--hermes-weight-semibold);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

/* Disabled-danger button — keeps the destructive intent visible without
   inviting clicks. */
.hermes-btn--danger-disabled,
.hermes-btn--danger-disabled[disabled] {
    background: var(--hermes-error-light);
    border-color: var(--hermes-error);
    color: var(--hermes-error-dark);
    opacity: 0.85;
    cursor: not-allowed;
}
.hermes-settings-info {
    display: grid;
    grid-template-columns: max-content 1fr;
    gap: var(--hermes-space-3) var(--hermes-space-5);
    margin: 0;
}
.hermes-settings-info dt {
    color: var(--hermes-neutral-500);
    font-weight: var(--hermes-weight-medium);
    font-size: var(--hermes-text-sm);
}
.hermes-settings-info dd { margin: 0; }

/* Cart history rename UI */
.hermes-cart-history-name {
    display: flex;
    align-items: center;
    gap: var(--hermes-space-2);
    flex-wrap: wrap;
}
.hermes-cart-history-name__display { margin: 0; }
.hermes-cart-history-name__edit {
    display: flex;
    align-items: center;
    gap: var(--hermes-space-1);
}

.hermes-cart-history-items {
    display: flex;
    flex-direction: column;
    gap: var(--hermes-space-2);
}


/* --------------------------------------------------------------------------
   Responsive
   -------------------------------------------------------------------------- */
@media (max-width: 991.98px) {
    /* Collapse the nav AND the (mobile-only) account section behind the
       hamburger. The desktop __actions block is hidden entirely on phones
       — its profile-dropdown items are surfaced through __mobile-account
       (the unified drawer) instead, so each destination appears once. */
    .hermes-topbar.is-menu-open { height: auto; }
    .hermes-topbar.is-menu-open .hermes-topbar__inner {
        flex-wrap: wrap;
        padding-bottom: var(--hermes-space-2);
    }
    .hermes-topbar__spacer { display: none; }
    .hermes-topbar__nav,
    .hermes-topbar__actions { display: none; }
    .hermes-topbar__nav.is-open,
    .hermes-topbar__mobile-account.is-open {
        display: flex;
        flex-direction: column;
        align-items: stretch;
        flex-basis: 100%;
        gap: var(--hermes-space-1);
        margin-top: var(--hermes-space-2);
    }
    .hermes-topbar__mobile-account.is-open {
        border-top: 1px solid var(--hermes-border);
        padding-top: var(--hermes-space-3);
        gap: var(--hermes-space-1);
    }
    /* The inner <ul> shares the .hermes-topbar__nav class, so the hide rule
       above caught it too — re-show it (stacked) when the menu is open. */
    .hermes-topbar__nav.is-open .hermes-topbar__nav {
        display: flex;
        flex-direction: column;
        align-items: stretch;
        flex-basis: auto;
        width: 100%;
        gap: var(--hermes-space-1);
        margin-top: 0;
    }
    /* Cart + hamburger as one right-aligned group, tight (8px) so they
       read as a pair flush against the screen edge, not two icons with
       a gap between them. The desktop labelled cart inside __actions is
       hidden so it never duplicates here. */
    .hermes-topbar__mobile-actions {
        display: flex;
        align-items: center;
        gap: var(--hermes-space-2);   /* ~8px between cart and hamburger */
        margin-left: auto;            /* push the group to the right */
    }
    .hermes-topbar__cart-mobile { display: inline-flex; }
    .hermes-topbar__toggle { display: inline-flex; }
    .hermes-topbar__actions .hermes-cart-button { display: none; }

    /* Mobile account drawer items (profile header, links, logout). */
    .hermes-topbar__mobile-account-header {
        display: flex;
        align-items: center;
        gap: var(--hermes-space-2);
        padding: var(--hermes-space-2) var(--hermes-space-3);
        font-weight: var(--hermes-weight-semibold);
        color: var(--hermes-neutral-900);
    }
    .hermes-topbar__mobile-account-link {
        display: inline-flex;
        align-items: center;
        gap: var(--hermes-space-2);
        padding: var(--hermes-space-3);   /* 44px-ish touch target */
        min-height: 44px;
        background: transparent;
        border: 0;
        width: 100%;
        text-align: left;
        color: var(--hermes-neutral-700);
        text-decoration: none;
        font-weight: var(--hermes-weight-medium);
        font-size: var(--hermes-text-sm);
        border-radius: var(--hermes-radius-md);
        cursor: pointer;
    }
    .hermes-topbar__mobile-account-link:hover {
        background: var(--hermes-primary-50);
        color: var(--hermes-primary);
    }
    .hermes-topbar__mobile-account-logout { display: block; width: 100%; }
}

@media (max-width: 767.98px) {
    .hermes-footer__grid {
        grid-template-columns: 1fr 1fr;
        gap: var(--hermes-space-6);
    }
    .hermes-footer__brand { grid-column: 1 / -1; }
}

@media (max-width: 575.98px) {
    .hermes-footer__grid {
        grid-template-columns: 1fr;
    }
    .hermes-footer__bottom {
        flex-direction: column;
        gap: var(--hermes-space-3);
        text-align: center;
    }
}

/* Staff sidebar collapses to a top drawer on phones */
@media (max-width: 991.98px) {
    .hermes-staff-layout {
        grid-template-columns: 1fr;
    }
    .hermes-sidebar {
        position: static;
        height: auto;
        max-height: 50vh;
    }
}

@media (max-width: 991.98px) {
    .hermes-cart-summary { grid-template-columns: 1fr; }
}

@media (max-width: 767.98px) {
    .hermes-cart-item {
        grid-template-columns: 64px 1fr 1fr;
        grid-template-areas:
            "image name name"
            "image price subtotal"
            "qty   qty   remove";
        row-gap: var(--hermes-space-2);
    }
    .hermes-cart-item__image    { grid-area: image; }
    .hermes-cart-item__body     { grid-area: name; }
    .hermes-cart-item__price    { grid-area: price; text-align: left; }
    .hermes-cart-item__subtotal { grid-area: subtotal; }
    .hermes-cart-item__qty      { grid-area: qty; justify-content: flex-start; }
    .hermes-cart-item__remove   { grid-area: remove; }
}

/* Landing responsive ====================================================== */
@media (max-width: 991.98px) {
    .hermes-landing-hero__inner { grid-template-columns: 1fr; }
    .hermes-landing-hero__headline { font-size: var(--hermes-text-5xl); }
    .hermes-step-grid          { grid-template-columns: 1fr; gap: var(--hermes-space-7); }
    .hermes-pricing-grid,
    .hermes-pricing-teaser-grid { grid-template-columns: 1fr; }
    .hermes-story-grid         { grid-template-columns: 1fr; }
    .hermes-story-monogram     { width: 180px; height: 180px; font-size: 56px; }
}

@media (max-width: 767.98px) {
    .hermes-feature-grid       { grid-template-columns: 1fr; }
    .hermes-stats-bar__inner   { grid-template-columns: repeat(2, 1fr); }
    .hermes-landing-hero__headline { font-size: var(--hermes-text-4xl); }
    .hermes-final-cta h2       { font-size: var(--hermes-text-3xl); }
    .hermes-landing-hero__cart-preview { transform: none; }
}

/* Dashboard / customer-area responsive */
@media (max-width: 991.98px) {
    .hermes-dashboard-hero       { grid-template-columns: 1fr; }
    .hermes-dashboard-stats      { grid-template-columns: repeat(2, 1fr); }
    .hermes-dashboard-recs       { grid-template-columns: repeat(2, 1fr); }
    .hermes-dashboard-quick-actions { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 575.98px) {
    .hermes-dashboard-stats      { grid-template-columns: 1fr 1fr; }
    .hermes-dashboard-cart-row   {
        grid-template-columns: 1fr auto;
        grid-template-areas:
            "name chev"
            "date items"
            "total total";
    }
    .hermes-dashboard-cart-row__name    { grid-area: name; }
    .hermes-dashboard-cart-row__date    { grid-area: date; }
    .hermes-dashboard-cart-row__items   { grid-area: items; text-align: right; }
    .hermes-dashboard-cart-row__total   { grid-area: total; }
    .hermes-dashboard-cart-row__chev    { grid-area: chev; }
    .hermes-cart-list-row {
        grid-template-columns: 1fr;
        grid-template-areas:
            "status"
            "main"
            "total";
    }
    .hermes-cart-list-row__status { grid-area: status; }
    .hermes-cart-list-row__main   { grid-area: main; }
    .hermes-cart-list-row__total  { grid-area: total; text-align: right; }
    .hermes-cart-list-row__chev   { display: none; }
}


/* --------------------------------------------------------------------------
   Impersonation banner
   Sticky alert shown at the top of every authenticated surface whenever the
   logged-in user is acting on behalf of another profile (UserCurrentProfile
   is set). Pinned above topbars and admin sidebars so the operator never
   loses the way back.
   -------------------------------------------------------------------------- */
.hermes-impersonation-banner {
    background: var(--hermes-warning-light);
    border-bottom: 2px solid var(--hermes-warning);
    color: var(--hermes-warning-dark);
    padding: var(--hermes-space-3) var(--hermes-space-6);
    position: sticky;
    top: 0;
    z-index: 1100;
    box-shadow: 0 1px 3px rgba(15, 23, 42, 0.06);
}

.hermes-impersonation-banner__inner {
    display: flex;
    align-items: center;
    gap: var(--hermes-space-4);
    max-width: 1400px;
    margin: 0 auto;
}

.hermes-impersonation-banner__icon {
    font-size: 1.25rem;
    line-height: 1;
    color: var(--hermes-warning-dark);
}

.hermes-impersonation-banner__content {
    flex: 1;
    display: flex;
    align-items: baseline;
    gap: var(--hermes-space-2);
    flex-wrap: wrap;
    min-width: 0;
}

.hermes-impersonation-banner__label {
    color: var(--hermes-warning-dark);
    font-weight: 600;
}

.hermes-impersonation-banner__target {
    font-weight: 700;
    color: var(--hermes-neutral-900);
}

.hermes-impersonation-banner__original {
    color: var(--hermes-neutral-600);
    font-size: 0.875rem;
}

.hermes-impersonation-banner__form {
    margin: 0;
}

.hermes-impersonation-banner__btn {
    background: var(--hermes-warning-dark);
    color: var(--hermes-text-inverse);
    border: none;
    padding: var(--hermes-space-2) var(--hermes-space-4);
    border-radius: var(--hermes-radius-md, 8px);
    font-weight: 600;
    font-size: 0.875rem;
    cursor: pointer;
    white-space: nowrap;
    display: inline-flex;
    align-items: center;
    gap: var(--hermes-space-2);
    transition: background 0.15s ease-in-out;
}

.hermes-impersonation-banner__btn:hover,
.hermes-impersonation-banner__btn:focus {
    background: #8B4A07;
    outline: none;
}

/* Admin shell already has its own sidebar at z-index ~1000; lift the banner. */
.hermes-admin-body .hermes-impersonation-banner { z-index: 1200; }

@media (max-width: 767.98px) {
    .hermes-impersonation-banner {
        padding: var(--hermes-space-3) var(--hermes-space-4);
    }
    .hermes-impersonation-banner__inner {
        flex-direction: column;
        align-items: stretch;
        gap: var(--hermes-space-3);
    }
    .hermes-impersonation-banner__content {
        justify-content: center;
        text-align: center;
    }
    .hermes-impersonation-banner__btn {
        width: 100%;
        justify-content: center;
    }
}


/* --------------------------------------------------------------------------
   Cart item EAN equivalent suggestion (Phase G1)
   Side-by-side alternative card rendered beneath a cart item when an
   EAN-matched, cheaper product exists in a different store. Uses the
   success palette to telegraph the savings opportunity without
   shouting like a promo banner.
   -------------------------------------------------------------------------- */
.hermes-cart-item__alternative {
    margin: var(--hermes-space-2) 0 var(--hermes-space-5);
    padding: var(--hermes-space-3) var(--hermes-space-4);
    background: var(--hermes-success-light);
    border: 2px dashed var(--hermes-success);
    border-radius: var(--hermes-radius-md, 10px);
}

.hermes-alternative-divider {
    display: flex;
    align-items: center;
    gap: var(--hermes-space-2);
    margin-bottom: var(--hermes-space-3);
    color: var(--hermes-success-dark);
    font-weight: 600;
    font-size: 0.95rem;
}

.hermes-alternative-card {
    display: grid;
    grid-template-columns: 80px 1fr auto;
    gap: var(--hermes-space-4);
    align-items: center;
}

.hermes-alternative-card__image {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 80px;
    height: 80px;
    background: var(--hermes-bg);
    border-radius: var(--hermes-radius-sm, 6px);
    overflow: hidden;
    color: var(--hermes-neutral-400);
    font-size: 1.5rem;
    text-decoration: none;
}

.hermes-alternative-card__image img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.hermes-alternative-card__details { min-width: 0; }

.hermes-alternative-card__name {
    display: block;
    font-weight: 600;
    color: var(--hermes-text);
    text-decoration: none;
    margin-bottom: var(--hermes-space-1);
}

.hermes-alternative-card__name:hover { color: var(--hermes-primary); }

.hermes-alternative-card__meta {
    display: flex;
    align-items: center;
    gap: var(--hermes-space-2);
    flex-wrap: wrap;
    font-size: 0.95rem;
    color: var(--hermes-neutral-700);
}

.hermes-savings-badge {
    display: inline-block;
    padding: 2px 8px;
    background: var(--hermes-success);
    color: var(--hermes-text-inverse);
    border-radius: var(--hermes-radius-sm, 6px);
    font-size: 0.8125rem;
    font-weight: 700;
    line-height: 1.4;
}

.hermes-alternative-card__action { align-self: center; }

@media (max-width: 767.98px) {
    .hermes-alternative-card {
        grid-template-columns: 64px 1fr;
        grid-template-areas:
            "image details"
            "action action";
        gap: var(--hermes-space-3);
    }
    .hermes-alternative-card__image  { grid-area: image; width: 64px; height: 64px; }
    .hermes-alternative-card__details { grid-area: details; }
    .hermes-alternative-card__action  { grid-area: action; }
    .hermes-alternative-card__action .hermes-btn {
        width: 100%;
        justify-content: center;
    }
}


/* --------------------------------------------------------------------------
   Confidence-scored alternative cards (Phase G2)
   Cart shows multiple matches per item, each with a confidence bar and
   colour-coded card border. High = success palette, medium = warning,
   low = neutral / muted.
   -------------------------------------------------------------------------- */
.hermes-cart-item__alternatives {
    margin: var(--hermes-space-2) 0 var(--hermes-space-5);
    padding: var(--hermes-space-3) var(--hermes-space-4);
    background: var(--hermes-bg-muted);
    border-radius: var(--hermes-radius-md, 10px);
    display: flex;
    flex-direction: column;
    gap: var(--hermes-space-3);
}

/* A card inside .hermes-cart-item__alternatives uses its own border
   colour by confidence, overriding the outer container background. */
.hermes-cart-item__alternatives .hermes-alternative-card {
    background: var(--hermes-bg);
    padding: var(--hermes-space-3) var(--hermes-space-4);
    border-radius: var(--hermes-radius-md, 10px);
    border: 2px solid transparent;
}

.hermes-alternative-card--high {
    border-color: var(--hermes-success);
    background: var(--hermes-success-light) !important;
}
.hermes-alternative-card--medium {
    border-color: var(--hermes-warning);
    background: var(--hermes-warning-light) !important;
}
.hermes-alternative-card--low {
    border-color: var(--hermes-border-strong);
    background: var(--hermes-neutral-50) !important;
    opacity: 0.92;
}

.hermes-alternative-card__confidence {
    margin: var(--hermes-space-2) 0;
}

.hermes-confidence-bar {
    height: 4px;
    background: var(--hermes-neutral-200);
    border-radius: 2px;
    overflow: hidden;
    margin-bottom: var(--hermes-space-1);
}

.hermes-confidence-bar__fill {
    height: 100%;
    background: var(--hermes-primary);
    transition: width 0.3s ease-in-out;
}

.hermes-alternative-card--high  .hermes-confidence-bar__fill { background: var(--hermes-success); }
.hermes-alternative-card--medium .hermes-confidence-bar__fill { background: var(--hermes-warning); }
.hermes-alternative-card--low   .hermes-confidence-bar__fill { background: var(--hermes-neutral-500); }

.hermes-confidence-label {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--hermes-text-muted);
}

.hermes-alternative-card--high  .hermes-confidence-label { color: var(--hermes-success-dark); }
.hermes-alternative-card--medium .hermes-confidence-label { color: var(--hermes-warning-dark); }

.hermes-price-diff {
    display: inline-block;
    padding: 2px 8px;
    background: var(--hermes-neutral-200);
    color: var(--hermes-neutral-700);
    border-radius: var(--hermes-radius-sm, 6px);
    font-size: 0.8125rem;
    font-weight: 700;
}

.hermes-price-diff--up {
    background: var(--hermes-error-light);
    color: var(--hermes-error-dark);
}

/* Confidence-tinted button modifiers. */
.hermes-btn--high {
    background: var(--hermes-success);
    color: var(--hermes-text-inverse);
    border-color: var(--hermes-success);
}
.hermes-btn--high:hover,
.hermes-btn--high:focus {
    background: var(--hermes-success-dark);
    border-color: var(--hermes-success-dark);
    color: var(--hermes-text-inverse);
}
.hermes-btn--medium {
    background: var(--hermes-warning);
    color: var(--hermes-text-inverse);
    border-color: var(--hermes-warning);
}
.hermes-btn--medium:hover,
.hermes-btn--medium:focus {
    background: var(--hermes-warning-dark);
    border-color: var(--hermes-warning-dark);
    color: var(--hermes-text-inverse);
}
.hermes-btn--low {
    background: var(--hermes-neutral-100);
    color: var(--hermes-text);
    border-color: var(--hermes-border-strong);
}


/* --------------------------------------------------------------------------
   Inflation dashboard (Phase H3)
   Public page at /инфлация/ showing today's basket-cost snapshots
   per store + the "Hermes mix" cheapest-across-stores virtual row.
   -------------------------------------------------------------------------- */
.hermes-inflation-hero {
    padding: var(--hermes-space-12) 0 var(--hermes-space-8);
    background: linear-gradient(135deg,
                var(--hermes-primary-50), var(--hermes-bg));
    border-bottom: 1px solid var(--hermes-border);
}

.hermes-inflation-hero h1 {
    margin: 0 0 var(--hermes-space-3);
    color: var(--hermes-primary);
}

.hermes-inflation-hero__lead {
    color: var(--hermes-text);
    font-size: 1.1rem;
    max-width: 720px;
    margin: 0 0 var(--hermes-space-4);
}

.hermes-inflation-hero__meta {
    color: var(--hermes-text-muted);
    font-size: 0.95rem;
    margin: 0;
}

.hermes-inflation-content {
    padding: var(--hermes-space-8) 0 var(--hermes-space-12);
}

.hermes-basket-card {
    background: var(--hermes-bg);
    border: 1px solid var(--hermes-border);
    border-radius: 12px;
    padding: var(--hermes-space-6);
    margin-bottom: var(--hermes-space-6);
    box-shadow: 0 2px 6px rgba(15, 23, 42, 0.04);
}

.hermes-basket-card__header {
    margin-bottom: var(--hermes-space-5);
    padding-bottom: var(--hermes-space-4);
    border-bottom: 1px solid var(--hermes-border);
}

.hermes-basket-card__header h2 {
    margin: 0 0 var(--hermes-space-1);
}

.hermes-basket-card__meta {
    color: var(--hermes-text-muted);
    font-size: 0.9rem;
    margin: 0 0 var(--hermes-space-2);
}

.hermes-basket-card__description {
    color: var(--hermes-text);
    font-size: 0.95rem;
    margin: 0;
}

.hermes-snapshot {
    padding: var(--hermes-space-4) var(--hermes-space-5);
    border-radius: 10px;
    background: var(--hermes-bg-muted);
    border: 2px solid transparent;
}

.hermes-snapshot--mix {
    background: linear-gradient(135deg,
                var(--hermes-warning-light), var(--hermes-bg));
    border-color: var(--hermes-warning);
    margin-bottom: var(--hermes-space-4);
}

.hermes-snapshot--cheapest {
    background: var(--hermes-success-light);
    border-color: var(--hermes-success);
}

.hermes-snapshot__label {
    font-weight: 600;
    color: var(--hermes-text);
    margin-bottom: var(--hermes-space-2);
    display: flex;
    align-items: baseline;
    gap: var(--hermes-space-2);
    flex-wrap: wrap;
}

.hermes-snapshot__label small {
    color: var(--hermes-text-muted);
    font-weight: 400;
    font-size: 0.85rem;
}

.hermes-snapshot__cost {
    font-family: var(--hermes-font-heading);
    font-size: 2rem;
    font-weight: 700;
    color: var(--hermes-primary);
    line-height: 1;
    margin-bottom: var(--hermes-space-2);
}

.hermes-snapshot--mix .hermes-snapshot__cost { color: var(--hermes-warning-dark); }
.hermes-snapshot--cheapest .hermes-snapshot__cost { color: var(--hermes-success-dark); }

.hermes-snapshot__details {
    color: var(--hermes-text-muted);
    font-size: 0.85rem;
}

.hermes-snapshots-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: var(--hermes-space-4);
}

.hermes-badge--cheap {
    background: var(--hermes-success);
    color: var(--hermes-text-inverse);
    border-radius: 12px;
    padding: 2px 8px;
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

/* Qualified "maybe cheapest" — coverage across stores isn't comparable. */
.hermes-badge--cheap-maybe {
    background: var(--hermes-warning-light);
    color: var(--hermes-warning-dark);
    border: 1px dashed var(--hermes-warning);
    border-radius: 12px;
    padding: 1px 8px;
    font-size: 0.7rem;
    font-weight: 700;
    cursor: help;
}

/* Average-per-product line on a store card. */
.hermes-snapshot__avg {
    font-size: var(--hermes-text-sm);
    font-weight: 600;
    color: var(--hermes-text);
    margin-bottom: 2px;
}

/* Apples-to-apples comparison over products common to all stores. */
.hermes-fair-compare {
    margin-top: var(--hermes-space-4);
    padding: var(--hermes-space-4);
    background: var(--hermes-bg-muted);
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-md);
}
.hermes-fair-compare h4 { margin: 0 0 var(--hermes-space-3); font-size: var(--hermes-text-base); }
.hermes-fair-compare h4 small { font-weight: 400; margin-left: var(--hermes-space-2); }
.hermes-fair-compare__list { list-style: none; margin: 0; padding: 0; }
.hermes-fair-compare__list li {
    display: grid;
    grid-template-columns: 1fr auto auto;
    gap: var(--hermes-space-3);
    align-items: baseline;
    padding: 4px 0;
    border-bottom: 1px solid var(--hermes-border);
}
.hermes-fair-compare__list li:last-child { border-bottom: none; }
.hermes-fair-compare__store { font-weight: 600; }
.hermes-fair-compare__delta { font-weight: 700; font-size: var(--hermes-text-sm); text-align: right; min-width: 72px; }
.hermes-fair-compare__note { font-size: var(--hermes-text-xs); margin: var(--hermes-space-2) 0 0; }

/* Prominent fairness disclaimer below the legend. */
.hermes-fairness-note {
    margin-top: var(--hermes-space-4);
    padding: var(--hermes-space-5);
    background: var(--hermes-warning-light);
    border: 1px solid var(--hermes-warning);
    border-radius: var(--hermes-radius-lg);
    color: var(--hermes-warning-dark);
}
.hermes-fairness-note h3 { margin: 0 0 var(--hermes-space-3); color: var(--hermes-warning-dark); }
.hermes-fairness-note p { color: var(--hermes-text); }
.hermes-fairness-note ul { margin: var(--hermes-space-2) 0 0; padding-left: var(--hermes-space-5); color: var(--hermes-text); }
.hermes-fairness-note li { margin-bottom: 4px; }

.hermes-coming-soon {
    margin-top: var(--hermes-space-8);
    padding: var(--hermes-space-6);
    background: var(--hermes-bg-muted);
    border: 2px dashed var(--hermes-border-strong);
    border-radius: 12px;
    text-align: center;
}

.hermes-coming-soon h3 {
    margin: 0 0 var(--hermes-space-2);
    color: var(--hermes-text);
}

.hermes-coming-soon p {
    color: var(--hermes-text-muted);
    margin: 0;
    max-width: 600px;
    margin-left: auto;
    margin-right: auto;
}

.hermes-empty-state {
    text-align: center;
    padding: var(--hermes-space-12) var(--hermes-space-4);
    color: var(--hermes-text-muted);
}

.hermes-empty-state h2 { color: var(--hermes-text); }


/* --------------------------------------------------------------------------
   Inflation detail page (Phase H3.5)
   Per-(basket, store) breakdown listing every category + chosen
   product. Reuses the success/warning palette from the overview.
   -------------------------------------------------------------------------- */
.hermes-inflation-detail {
    padding: var(--hermes-space-8) 0 var(--hermes-space-12);
}

.hermes-breadcrumb {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--hermes-space-2);
    font-size: 0.9rem;
    color: var(--hermes-text-muted);
    margin-bottom: var(--hermes-space-5);
}

.hermes-breadcrumb a {
    color: var(--hermes-primary);
    text-decoration: none;
}

.hermes-breadcrumb a:hover { text-decoration: underline; }

.hermes-breadcrumb__separator { color: var(--hermes-neutral-400); }

.hermes-detail-header {
    margin-bottom: var(--hermes-space-8);
    padding-bottom: var(--hermes-space-5);
    border-bottom: 2px solid var(--hermes-border);
}

.hermes-detail-header h1 {
    margin: 0 0 var(--hermes-space-5);
    color: var(--hermes-text);
}

.hermes-detail-stats {
    display: flex;
    flex-wrap: wrap;
    gap: var(--hermes-space-8);
    margin-bottom: var(--hermes-space-3);
}

.hermes-detail-stat {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.hermes-detail-stat__label {
    font-size: 0.8rem;
    color: var(--hermes-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    font-weight: 600;
}

.hermes-detail-stat__value {
    font-family: var(--hermes-font-heading);
    font-size: 2rem;
    font-weight: 700;
    color: var(--hermes-text);
    line-height: 1;
}

.hermes-detail-stat--total .hermes-detail-stat__value {
    color: var(--hermes-primary);
}

.hermes-detail-stat--warning .hermes-detail-stat__value {
    color: var(--hermes-warning-dark);
}

.hermes-detail-meta {
    color: var(--hermes-text-muted);
    font-size: 0.95rem;
    margin: 0;
}

.hermes-detail-section {
    margin-bottom: var(--hermes-space-8);
}

.hermes-detail-section h2 {
    margin: 0 0 var(--hermes-space-4);
    display: flex;
    align-items: center;
    gap: var(--hermes-space-2);
    color: var(--hermes-text);
    font-size: 1.4rem;
}

.hermes-detail-section--missing h2 {
    color: var(--hermes-warning-dark);
}

.hermes-items-list {
    background: var(--hermes-bg);
    border: 1px solid var(--hermes-border);
    border-radius: 10px;
    overflow: hidden;
}

.hermes-item-row {
    display: flex;
    flex-direction: column;
    gap: var(--hermes-space-3);
    padding: var(--hermes-space-4) var(--hermes-space-5);
    border-bottom: 1px solid var(--hermes-border);
}

.hermes-item-row:last-child { border-bottom: none; }

.hermes-item-row__main {
    display: grid;
    grid-template-columns: 220px 1fr auto;
    gap: var(--hermes-space-5);
    align-items: center;
}

.hermes-item-row__category strong { color: var(--hermes-text); }

.hermes-item-row__product { color: var(--hermes-text); }

.hermes-item-row__store {
    color: var(--hermes-text-muted);
    font-size: 0.85rem;
    margin-left: var(--hermes-space-1);
}

.hermes-item-row__pricing {
    text-align: right;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.hermes-item-row__unit {
    color: var(--hermes-text-muted);
    font-size: 0.85rem;
}

.hermes-item-row__total {
    color: var(--hermes-primary);
    font-size: 1.1rem;
    font-weight: 700;
}

.hermes-missing-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: var(--hermes-space-3);
    margin-top: var(--hermes-space-3);
}

.hermes-missing-tile {
    padding: var(--hermes-space-4);
    background: var(--hermes-warning-light);
    border: 1px dashed var(--hermes-warning);
    border-radius: 10px;
    color: var(--hermes-warning-dark);
    font-weight: 600;
    text-align: center;
}

.hermes-detail-actions {
    margin-top: var(--hermes-space-8);
    padding-top: var(--hermes-space-5);
    border-top: 1px solid var(--hermes-border);
}

.hermes-snapshot__detail-link {
    display: inline-block;
    margin-top: var(--hermes-space-3);
    color: var(--hermes-primary);
    font-weight: 600;
    text-decoration: none;
    font-size: 0.9rem;
}

.hermes-snapshot__detail-link:hover { text-decoration: underline; }

.hermes-snapshot--mix .hermes-snapshot__detail-link {
    color: var(--hermes-warning-dark);
}

.hermes-snapshot--cheapest .hermes-snapshot__detail-link {
    color: var(--hermes-success-dark);
}

@media (max-width: 767.98px) {
    .hermes-item-row {
        padding: var(--hermes-space-3) var(--hermes-space-4);
    }
    .hermes-item-row__main {
        grid-template-columns: 1fr;
        gap: var(--hermes-space-2);
    }
    .hermes-item-row__pricing {
        text-align: left;
        flex-direction: row;
        justify-content: space-between;
        align-items: baseline;
    }
    .hermes-detail-stats { gap: var(--hermes-space-4); }
    .hermes-detail-stat__value { font-size: 1.5rem; }
}

/* ----------------------------------------------------------------------
   Dual-currency price (EUR primary + BGN secondary) — eurozone 2026
   EUR is legal tender; BGN shown transitionally, muted & smaller.
   ---------------------------------------------------------------------- */
.hermes-price {
    display: inline-flex;
    align-items: baseline;
    gap: var(--hermes-space-2);
    flex-wrap: wrap;
}
.hermes-price__eur {
    font-weight: 700;
    color: inherit;
}
/* BGN scales relative to the EUR context font-size, so a hero € price
   gets a proportionally larger лв and a table cell gets a smaller one. */
.hermes-price__bgn {
    color: var(--hermes-text-muted);
    font-size: 0.82em;
    font-weight: 500;
    white-space: nowrap;
}
.hermes-price--lg { gap: var(--hermes-space-3); }
.hermes-price--lg .hermes-price__bgn { font-size: 0.55em; }
.hermes-price--sm { gap: var(--hermes-space-1); }
.hermes-price--sm .hermes-price__bgn { font-size: 0.8em; }

/* ----------------------------------------------------------------------
   Inflation deltas + charts (Phase H4 / H5)
   ---------------------------------------------------------------------- */

/* Delta chip — a coloured pill showing a period's price change. */
.hermes-delta-chip {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 2px 8px;
    border-radius: var(--hermes-radius-full);
    font-size: var(--hermes-text-xs);
    font-weight: 600;
    line-height: 1.4;
    white-space: nowrap;
    border: 1px solid transparent;
}

.hermes-delta-chip__period {
    color: var(--hermes-text-muted);
    font-weight: 500;
}

.hermes-delta-chip__arrow { font-size: 0.7em; }

.hermes-delta-chip--up {
    background: var(--hermes-error-light);
    color: var(--hermes-error-dark);
}
.hermes-delta-chip--down {
    background: var(--hermes-success-light);
    color: var(--hermes-success-dark);
}
.hermes-delta-chip--flat {
    background: var(--hermes-bg-muted);
    color: var(--hermes-text-muted);
}

/* Estimated deltas: dashed border + faded, never mistaken for real. */
.hermes-delta-chip--estimate {
    border-style: dashed;
    border-color: var(--hermes-warning);
    opacity: 0.92;
}
.hermes-delta-chip__badge {
    color: var(--hermes-warning-dark);
    font-weight: 700;
}

.hermes-snapshot__deltas {
    display: flex;
    flex-wrap: wrap;
    gap: var(--hermes-space-2);
    margin-top: var(--hermes-space-3);
}

/* Basket sparkline canvas wrapper. */
.hermes-sparkline {
    margin-top: var(--hermes-space-3);
    height: 44px;
}
.hermes-sparkline canvas { width: 100% !important; }

/* Detail header basket deltas. */
.hermes-detail-deltas {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--hermes-space-2);
    margin-top: var(--hermes-space-4);
}
.hermes-detail-deltas__label {
    color: var(--hermes-text-muted);
    font-size: var(--hermes-text-sm);
    font-weight: 600;
}

/* Per-product extras inside an item row. */
.hermes-item-row__deltas {
    display: flex;
    flex-wrap: wrap;
    gap: var(--hermes-space-2);
}
.hermes-item-row__chart {
    height: 160px;
    background: var(--hermes-bg);
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-md);
    padding: var(--hermes-space-2);
}

/* Real vs estimated legend (replaces the old "coming soon" block). */
.hermes-data-legend {
    margin-top: var(--hermes-space-8);
    padding: var(--hermes-space-6);
    background: var(--hermes-bg-muted);
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-lg);
}
.hermes-data-legend h3 {
    margin: 0 0 var(--hermes-space-4);
    color: var(--hermes-text);
}
.hermes-data-legend__list {
    list-style: none;
    margin: 0 0 var(--hermes-space-4);
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: var(--hermes-space-3);
}
.hermes-data-legend__list li {
    display: flex;
    align-items: center;
    gap: var(--hermes-space-3);
    color: var(--hermes-text);
    font-size: var(--hermes-text-sm);
}
.hermes-data-legend__note {
    color: var(--hermes-text-muted);
    font-size: var(--hermes-text-sm);
    margin: 0;
    max-width: 640px;
}



/* ----------------------------------------------------------------------
   Price alerts (hermes_alerts)
   ---------------------------------------------------------------------- */
.hermes-bell-button {
    position: relative;
    display: inline-flex;
    align-items: center;
    padding: var(--hermes-space-2) var(--hermes-space-3);
    border-radius: var(--hermes-radius-md);
    background: transparent;
    border: 1px solid var(--hermes-border);
    color: var(--hermes-neutral-700);
    text-decoration: none;
    transition: background var(--hermes-transition-fast),
                border-color var(--hermes-transition-fast);
}
.hermes-bell-button:hover {
    background: var(--hermes-primary-50);
    border-color: var(--hermes-primary-light);
    color: var(--hermes-primary);
}
.hermes-bell-counter {
    position: absolute;
    top: -6px;
    right: -6px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    border-radius: var(--hermes-radius-full);
    background: var(--hermes-error);
    color: var(--hermes-text-inverse);
    font-size: 0.7rem;
    font-weight: 700;
    line-height: 1;
}

.hermes-alerts-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--hermes-space-4);
    flex-wrap: wrap;
    margin-bottom: var(--hermes-space-6);
}

.hermes-alert-list {
    display: flex;
    flex-direction: column;
    gap: var(--hermes-space-3);
}
.hermes-alert-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--hermes-space-4);
    padding: var(--hermes-space-4) var(--hermes-space-5);
    background: var(--hermes-bg);
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-lg);
}
.hermes-alert-card--paused { opacity: 0.65; }
.hermes-alert-card__title {
    display: flex;
    align-items: center;
    gap: var(--hermes-space-2);
    flex-wrap: wrap;
    margin-bottom: var(--hermes-space-1);
}
.hermes-alert-card__cond { font-size: var(--hermes-text-sm); }
.hermes-alert-card__meta { font-size: var(--hermes-text-xs); }
.hermes-alert-card__actions {
    display: flex;
    gap: var(--hermes-space-2);
    flex-shrink: 0;
}
.hermes-badge--type {
    background: var(--hermes-primary-50);
    color: var(--hermes-primary);
    border-radius: var(--hermes-radius-full);
    padding: 2px 10px;
    font-size: var(--hermes-text-xs);
    font-weight: 700;
}

.hermes-alert-target {
    background: var(--hermes-primary-50);
    border: 1px solid var(--hermes-primary-light);
    border-radius: var(--hermes-radius-md);
    padding: var(--hermes-space-3) var(--hermes-space-4);
    margin-bottom: var(--hermes-space-4);
}
.hermes-alert-form .form-label { font-weight: 600; margin-top: var(--hermes-space-2); }

.hermes-event-feed {
    display: flex;
    flex-direction: column;
    gap: var(--hermes-space-2);
}
.hermes-event {
    display: flex;
    gap: var(--hermes-space-3);
    padding: var(--hermes-space-3) var(--hermes-space-4);
    background: var(--hermes-bg);
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-md);
}
.hermes-event--unread {
    border-left: 3px solid var(--hermes-primary);
    background: var(--hermes-primary-50);
}
.hermes-event__icon { font-size: 1.4rem; }
.hermes-event__headline { color: var(--hermes-text); }
.hermes-event__meta { font-size: var(--hermes-text-xs); margin-top: 2px; }

.hermes-pagination {
    display: flex;
    align-items: center;
    gap: var(--hermes-space-3);
    margin-top: var(--hermes-space-5);
}

@media (max-width: 575.98px) {
    .hermes-alert-card { flex-direction: column; align-items: stretch; }
    .hermes-alert-card__actions { justify-content: flex-end; }
}

/* ----------------------------------------------------------------------
   Single-store substitution optimiser
   ---------------------------------------------------------------------- */
.hermes-comparison-card--link {
    text-decoration: none;
    color: inherit;
    transition: border-color var(--hermes-transition-fast),
                box-shadow var(--hermes-transition-fast);
}
.hermes-comparison-card--link:hover {
    border-color: var(--hermes-primary-light);
    box-shadow: 0 2px 10px rgba(15,76,129,0.08);
}
.hermes-comparison-card.is-selected {
    border: 3px solid var(--hermes-primary);
    background: rgba(15, 76, 129, 0.05);
    box-shadow: 0 4px 12px rgba(15, 76, 129, 0.15);
}
.hermes-comparison-card--link.is-selected:hover {
    /* keep the active treatment distinct from the plain hover */
    border-color: var(--hermes-primary);
    box-shadow: 0 4px 14px rgba(15, 76, 129, 0.22);
}
/* ✓ marker (top-left, away from the top-right "Най-евтино" badge) */
.hermes-comparison-card.is-selected::after {
    content: "\2713";
    position: absolute;
    top: var(--hermes-space-3);
    left: var(--hermes-space-3);
    width: 22px;
    height: 22px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--hermes-primary);
    color: #fff;
    border-radius: 50%;
    font-size: 0.78rem;
    font-weight: 700;
    line-height: 1;
}

/* Store brand-colour badges (Bootstrap .badge base + these). Referenced across
   the app (product list/detail, cart, dashboards) — defined here so they
   actually render in the stores' colours. */
.pw-badge-kaufland { background-color: #E10915; color: #fff; }
.pw-badge-lidl     { background-color: #0050AA; color: #fff; }
.pw-badge-tmarket  { background-color: #00A651; color: #fff; }
.pw-badge-billa    { background-color: #E2001A; color: #fff; }

/* Compact inline store badge for the substitution suggestion rows. */
.hermes-store-badge {
    font-size: 0.68rem;
    font-weight: 600;
    padding: 1px 6px;
    vertical-align: middle;
    margin-right: 4px;
    white-space: nowrap;
}
.hermes-sub-arrow {
    margin-top: var(--hermes-space-1);
    font-size: var(--hermes-text-sm);
    color: var(--hermes-success-dark);
}
.hermes-sub-badge {
    display: inline-block;
    padding: 1px 8px;
    border-radius: var(--hermes-radius-full);
    font-size: var(--hermes-text-xs);
    font-weight: 700;
    margin-right: 4px;
}
.hermes-sub-badge--high   { background: var(--hermes-success-light); color: var(--hermes-success-dark); }
.hermes-sub-badge--medium { background: var(--hermes-primary-50);   color: var(--hermes-primary); }
.hermes-sub-badge--low    { background: var(--hermes-warning-light); color: var(--hermes-warning-dark); }

/* Substitution detail — clickable product (thumbnail + name) → product page */
.hermes-sub-link {
    display: flex;
    align-items: center;
    gap: var(--hermes-space-3);
    text-decoration: none;
    color: inherit;
    min-width: 0;
}
.hermes-sub-link:hover .hermes-sub-name {
    color: var(--hermes-primary);
    text-decoration: underline;
}
.hermes-sub-thumb {
    flex: 0 0 auto;
    width: 48px;
    height: 48px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--hermes-neutral-100);
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-md);
    overflow: hidden;
    color: var(--hermes-text-muted);
}
.hermes-sub-thumb img { width: 100%; height: 100%; object-fit: contain; }
.hermes-sub-name { font-weight: 600; color: var(--hermes-text); min-width: 0; }
@media (max-width: 575.98px) {
    .hermes-sub-thumb { width: 40px; height: 40px; }
}

/* Link inside a landing feature card (named-baskets promo). */
.hermes-feature-card__link {
    display: inline-block;
    margin-top: var(--hermes-space-2);
    color: var(--hermes-primary);
    font-weight: 600;
    font-size: var(--hermes-text-sm);
    text-decoration: none;
}
.hermes-feature-card__link:hover { text-decoration: underline; }

/* ----------------------------------------------------------------------
   Named-basket form method cards + product picker
   ---------------------------------------------------------------------- */
.hermes-method-cards {
    display: flex;
    flex-direction: column;
    gap: var(--hermes-space-3);
    margin-top: var(--hermes-space-2);
}
.hermes-method-card {
    display: flex;
    gap: var(--hermes-space-3);
    padding: var(--hermes-space-4);
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-lg);
    cursor: pointer;
    transition: border-color var(--hermes-transition-fast),
                background var(--hermes-transition-fast);
}
.hermes-method-card:hover { border-color: var(--hermes-primary-light); }
/* Highlight the card whose radio is checked. */
.hermes-method-card:has(input:checked) {
    border-color: var(--hermes-primary);
    background: var(--hermes-primary-50);
    box-shadow: 0 0 0 1px var(--hermes-primary);
}
.hermes-method-card__radio { padding-top: 2px; }
.hermes-method-card__body { display: flex; flex-direction: column; gap: 2px; }
.hermes-method-card__title { font-weight: 700; color: var(--hermes-text); }
.hermes-method-card__desc {
    font-size: var(--hermes-text-sm);
    color: var(--hermes-text-muted);
}
.hermes-method-card__desc em {
    display: block;
    margin-top: 2px;
    color: var(--hermes-primary);
    font-style: normal;
    font-weight: 600;
}

.hermes-basket-search {
    display: flex;
    gap: var(--hermes-space-2);
    margin-bottom: var(--hermes-space-3);
}
.hermes-basket-search input { flex: 1; }

.hermes-search-results {
    display: flex;
    flex-direction: column;
    gap: var(--hermes-space-2);
}
.hermes-search-result {
    display: flex;
    align-items: center;
    gap: var(--hermes-space-3);
    padding: var(--hermes-space-3) var(--hermes-space-4);
    background: var(--hermes-bg);
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-md);
}
.hermes-search-result__info {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-width: 0;
}
.hermes-search-result__info span { font-size: var(--hermes-text-sm); }
.hermes-search-result__price { white-space: nowrap; }

.hermes-qty-form { display: inline-flex; align-items: center; gap: 4px; }
.hermes-qty-form .hermes-quantity-input { width: 72px; }

@media (max-width: 575.98px) {
    .hermes-basket-search { flex-direction: column; }
    .hermes-search-result { flex-wrap: wrap; }
}

/* ----------------------------------------------------------------------
   Named-basket polish: thumbnails, history explainer, lock hint
   ---------------------------------------------------------------------- */
.hermes-thumb {
    flex-shrink: 0;
    width: 48px;
    height: 48px;
    border-radius: var(--hermes-radius-md);
    background: var(--hermes-bg-muted);
    border: 1px solid var(--hermes-border);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    color: var(--hermes-text-muted);
}
.hermes-thumb img { width: 100%; height: 100%; object-fit: contain; }

.hermes-item-row--withthumb {
    flex-direction: row;
    align-items: center;
    gap: var(--hermes-space-3);
}
.hermes-item-row--withthumb .hermes-item-row__main { flex: 1; min-width: 0; }

.hermes-history-explainer {
    background: var(--hermes-bg-muted);
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-lg);
    padding: var(--hermes-space-5);
}
.hermes-history-explainer h2 { margin-top: 0; }
.hermes-history-explainer p { color: var(--hermes-text-muted); max-width: 640px; }
.hermes-history-skeleton { margin-top: var(--hermes-space-3); text-align: center; }
.hermes-history-skeleton svg { width: 100%; height: 80px; }

.hermes-lock-hint { margin-top: var(--hermes-space-3); max-width: 680px; }

/* ----------------------------------------------------------------------
   Inflation clarity (delta legend, partial flag, mix explainer)
   ---------------------------------------------------------------------- */
.hermes-delta-chip__partial {
    font-size: 0.62rem;
    font-weight: 600;
    color: var(--hermes-text-muted);
    text-transform: lowercase;
    margin-left: 2px;
}
.hermes-data-legend__sources {
    margin-top: var(--hermes-space-3);
    font-size: var(--hermes-text-sm);
    color: var(--hermes-text);
}
.hermes-data-legend__sources ul {
    margin: 0 0 var(--hermes-space-2);
    padding-left: var(--hermes-space-5);
    color: var(--hermes-text-muted);
}
.hermes-snapshot__explain {
    font-size: var(--hermes-text-xs);
    margin: var(--hermes-space-2) 0 0;
    line-height: 1.5;
}
.hermes-sparkline__caption {
    font-size: 0.68rem;
    margin: 2px 0 0;
    text-align: center;
}

/* ----------------------------------------------------------------------
   Legal / transparency pages (privacy, terms, how-it-works)
   ---------------------------------------------------------------------- */
.hermes-legal { max-width: 760px; }
.hermes-legal__header { margin-bottom: var(--hermes-space-6); }
.hermes-legal h2 {
    margin-top: var(--hermes-space-6);
    margin-bottom: var(--hermes-space-2);
    font-size: var(--hermes-text-xl);
}
.hermes-legal p, .hermes-legal li { line-height: 1.65; color: var(--hermes-text); }
.hermes-legal ul { padding-left: var(--hermes-space-5); }
.hermes-legal li { margin-bottom: var(--hermes-space-2); }
.hermes-legal__cta {
    margin-top: var(--hermes-space-8);
    display: flex;
    gap: var(--hermes-space-2);
    flex-wrap: wrap;
}

/* Telegram link section on the alert-settings page. */
.hermes-tg-link { border-top: 1px solid var(--hermes-border); padding-top: var(--hermes-space-5); }
.hermes-tg-link__steps { padding-left: var(--hermes-space-5); }
.hermes-tg-link__steps li { margin-bottom: var(--hermes-space-2); }
.hermes-tg-code {
    display: inline-block;
    background: var(--hermes-neutral-900);
    color: #fff;
    padding: 4px 10px;
    border-radius: var(--hermes-radius-sm);
    font-family: monospace;
    margin-left: var(--hermes-space-2);
    user-select: all;
}

/* ============================================================
   SEO category landing pages (/inflation/categories/, /category/<slug>/)
   ============================================================ */
.hermes-category-hero h1 { display: flex; align-items: center; gap: var(--hermes-space-3); }
.hermes-category-hero__icon { font-size: 2.2rem; line-height: 1; }

.hermes-detail-stat__sub {
    font-size: 0.85rem;
    color: var(--hermes-text-muted);
    font-weight: 600;
}
.hermes-category-stats { gap: var(--hermes-space-10, 2.5rem); }
.hermes-yoy--up   { color: #EF4444; }
.hermes-yoy--down { color: #10B981; }

.hermes-category-chart {
    position: relative;
    height: 300px;
    background: var(--hermes-bg);
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-lg);
    padding: var(--hermes-space-4);
}

/* Per-store breakdown tiles */
.hermes-store-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: var(--hermes-space-4);
}
.hermes-store-tile {
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-lg);
    padding: var(--hermes-space-4);
    background: var(--hermes-bg);
}
.hermes-store-tile--best {
    border-color: var(--hermes-primary-light);
    box-shadow: var(--hermes-shadow-sm);
}
.hermes-store-tile__name {
    font-weight: 700;
    display: flex;
    align-items: center;
    gap: var(--hermes-space-2);
    margin-bottom: var(--hermes-space-2);
}
.hermes-store-tile__price { font-size: 1.25rem; font-weight: 700; }
.hermes-store-tile__meta { font-size: 0.85rem; margin-top: var(--hermes-space-1); }
.hermes-badge--best {
    background: var(--hermes-primary-50);
    color: var(--hermes-primary);
    font-size: 0.7rem;
    padding: 2px 8px;
    border-radius: var(--hermes-radius-full);
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

/* Clickable product rows */
.hermes-item-row--link {
    display: block;
    text-decoration: none;
    color: inherit;
    border-radius: var(--hermes-radius-md);
    transition: background-color .12s ease;
}
.hermes-item-row--link:hover { background: var(--hermes-primary-50); color: inherit; }

/* Explainer list */
.hermes-category-explainer ul { margin: 0; padding-left: 1.2rem; color: var(--hermes-text-muted); }
.hermes-category-explainer li { margin-bottom: var(--hermes-space-2); }

/* Cross-link chips */
.hermes-category-links { display: flex; flex-wrap: wrap; gap: var(--hermes-space-2); }
.hermes-category-chip {
    display: inline-flex;
    align-items: center;
    gap: var(--hermes-space-2);
    padding: var(--hermes-space-2) var(--hermes-space-4);
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-full);
    background: var(--hermes-bg);
    text-decoration: none;
    color: var(--hermes-text);
    font-weight: 600;
    font-size: 0.9rem;
}
.hermes-category-chip:hover {
    border-color: var(--hermes-primary-light);
    background: var(--hermes-primary-50);
    color: var(--hermes-primary);
}

/* Index grid of category cards */
.hermes-category-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: var(--hermes-space-5);
    margin-bottom: var(--hermes-space-8);
}
.hermes-category-card {
    display: flex;
    align-items: center;
    gap: var(--hermes-space-4);
    padding: var(--hermes-space-5);
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-lg);
    background: var(--hermes-bg);
    text-decoration: none;
    color: var(--hermes-text);
    box-shadow: var(--hermes-shadow-xs);
    transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease;
}
.hermes-category-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--hermes-shadow-md);
    border-color: var(--hermes-primary-light);
    color: var(--hermes-text);
}
.hermes-category-card__icon { font-size: 2rem; line-height: 1; }
.hermes-category-card__body { flex: 1; min-width: 0; }
.hermes-category-card__title { margin: 0 0 var(--hermes-space-1); font-size: 1.15rem; }
.hermes-category-card__price { font-weight: 700; }
.hermes-category-card__price .text-muted { font-weight: 400; font-size: 0.8rem; margin-right: 4px; }
.hermes-category-card__meta { font-size: 0.82rem; margin-top: 2px; }
.hermes-category-card__arrow { color: var(--hermes-primary); font-size: 1.2rem; }

@media (max-width: 640px) {
    .hermes-category-stats { gap: var(--hermes-space-6); }
    .hermes-category-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   Premium billing (hermes_billing): badges, pricing, manage, lock chips
   ============================================================ */
/* Base badge (public pages only define modifiers otherwise). */
.hermes-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: var(--hermes-neutral-200, #e2e8f0);
    color: var(--hermes-text, #1e293b);
    border-radius: var(--hermes-radius-full);
    padding: 2px 10px;
    font-size: var(--hermes-text-xs);
    font-weight: 700;
    line-height: 1.6;
}
.hermes-badge--pro   { background: var(--hermes-primary); color: #fff; }
.hermes-badge--trial { background: var(--hermes-warning-light); color: var(--hermes-warning-dark); }
.hermes-badge--warn  { background: var(--hermes-warning-light); color: var(--hermes-warning-dark); }
.hermes-topbar__plan { margin: 0 4px; font-size: 0.65rem; padding: 1px 7px; }

/* Confirm / success / manage cards */
.hermes-billing-confirm,
.hermes-billing-manage { max-width: 640px; }
.hermes-billing-back,
.hermes-billing-back-link a { color: var(--hermes-text-muted); text-decoration: none; font-size: 0.9rem; }
.hermes-billing-back:hover { color: var(--hermes-primary); }
.hermes-billing-card {
    position: relative;
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-lg);
    padding: var(--hermes-space-6);
    background: var(--hermes-bg);
    box-shadow: var(--hermes-shadow-sm);
    margin-top: var(--hermes-space-4);
}
.hermes-billing-card--success { text-align: center; }
.hermes-billing-success__icon { font-size: 3rem; line-height: 1; }
.hermes-billing-card h1 { margin: var(--hermes-space-2) 0; color: var(--hermes-primary); }
.hermes-billing-price { display: flex; align-items: baseline; gap: var(--hermes-space-2); margin: var(--hermes-space-3) 0; }
.hermes-billing-price__period { color: var(--hermes-text-muted); font-weight: 600; }
.hermes-billing-save { color: var(--hermes-warning-dark); font-weight: 600; margin: 0 0 var(--hermes-space-4); }
.hermes-billing-note { color: var(--hermes-text-muted); font-size: 0.88rem; margin-top: var(--hermes-space-3); }
.hermes-billing-testbadge { color: var(--hermes-text-muted); background: #fff7e6; border: 1px dashed #e0b341; border-radius: 6px; padding: 4px 10px; display: inline-block; margin-bottom: var(--hermes-space-3); }
.hermes-billing-lead { font-size: 1.05rem; margin: var(--hermes-space-3) 0; }
.hermes-billing-perks { list-style: none; padding: 0; margin: var(--hermes-space-4) 0; display: grid; gap: var(--hermes-space-2); }
.hermes-billing-perks li { display: flex; align-items: center; gap: var(--hermes-space-2); }
.hermes-billing-perks .bi-check-circle-fill { color: #10B981; }
.hermes-billing-actions { display: flex; flex-wrap: wrap; gap: var(--hermes-space-3); margin-top: var(--hermes-space-4); }
.hermes-billing-actions form { margin: 0; }
.hermes-billing-status { display: flex; align-items: center; gap: var(--hermes-space-3); margin-bottom: var(--hermes-space-2); }

/* Plan picker (manage page, free/expired) */
.hermes-billing-plan-pick { display: grid; grid-template-columns: 1fr 1fr; gap: var(--hermes-space-3); margin: var(--hermes-space-4) 0; }
.hermes-billing-plan {
    position: relative;
    display: flex; flex-direction: column; gap: 4px;
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-lg);
    padding: var(--hermes-space-4);
    text-decoration: none; color: var(--hermes-text);
    transition: border-color .12s ease, box-shadow .12s ease;
}
.hermes-billing-plan:hover { border-color: var(--hermes-primary-light); box-shadow: var(--hermes-shadow-sm); color: var(--hermes-text); }
.hermes-billing-plan--best { border-color: var(--hermes-primary); }
.hermes-billing-plan__name { font-weight: 700; }
.hermes-billing-plan__price { font-size: 1.1rem; }
.hermes-billing-plan__price small { color: var(--hermes-text-muted); font-weight: 400; }
.hermes-billing-plan__save {
    position: absolute; top: -10px; right: var(--hermes-space-3);
    background: var(--hermes-warning); color: #fff;
    border-radius: var(--hermes-radius-full); padding: 1px 8px;
    font-size: 0.7rem; font-weight: 700;
}

/* Lock / frozen affordance (B6) */
.hermes-frozen-banner {
    display: flex; flex-wrap: wrap; align-items: center; gap: var(--hermes-space-3);
    background: var(--hermes-warning-light); color: var(--hermes-warning-dark);
    border: 1px solid var(--hermes-warning); border-radius: var(--hermes-radius-lg);
    padding: var(--hermes-space-3) var(--hermes-space-4);
    margin-bottom: var(--hermes-space-5);
}
.hermes-frozen-banner__cta { margin-left: auto; }
.hermes-alert-card--frozen { opacity: 0.72; background: var(--hermes-neutral-100, #f1f5f9); }
.hermes-badge--frozen { background: var(--hermes-warning-light); color: var(--hermes-warning-dark); }

@media (max-width: 640px) {
    .hermes-billing-plan-pick { grid-template-columns: 1fr; }
    .hermes-frozen-banner__cta { margin-left: 0; }
}

/* ============================================================
   Inflation storytelling landing (/inflation/)
   ============================================================ */
.hermes-story-hero {
    padding: var(--hermes-space-12) 0 var(--hermes-space-8);
    background: linear-gradient(135deg, var(--hermes-primary-50), var(--hermes-bg));
    border-bottom: 1px solid var(--hermes-border);
    text-align: center;
}
.hermes-story-hero h1 { color: var(--hermes-primary); margin: 0 0 var(--hermes-space-4); }
.hermes-story-hero__stat { margin: var(--hermes-space-3) 0; display: flex; flex-direction: column; align-items: center; gap: 4px; }
.hermes-story-hero__big {
    font-family: var(--hermes-font-heading);
    font-size: clamp(3rem, 12vw, 5.5rem);
    font-weight: 800;
    line-height: 1;
    color: var(--hermes-warning-dark);
}
.hermes-story-hero__statlabel { font-size: 1.15rem; color: var(--hermes-text); max-width: 540px; }
.hermes-story-hero__sub { color: var(--hermes-text-muted); max-width: 620px; margin: var(--hermes-space-3) auto; }
.hermes-story-hero__date { color: var(--hermes-text-muted); font-size: 0.9rem; margin: 0; }

.hermes-story-examples {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: var(--hermes-space-4);
    margin-top: var(--hermes-space-5);
}
.hermes-story-example {
    position: relative;
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-lg);
    padding: var(--hermes-space-4);
    background: var(--hermes-bg);
    box-shadow: var(--hermes-shadow-xs);
}
.hermes-story-example__name { font-weight: 700; margin-bottom: var(--hermes-space-3); min-height: 2.6em; }
.hermes-story-example__row { display: flex; align-items: center; gap: var(--hermes-space-2); }
.hermes-story-example__then, .hermes-story-example__now { display: flex; flex-direction: column; gap: 2px; flex: 1; }
.hermes-story-example__year { font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.04em; color: var(--hermes-text-muted); font-weight: 700; }
.hermes-story-example__arrow { color: var(--hermes-primary); font-size: 1.3rem; }
.hermes-story-example__delta {
    position: absolute; top: var(--hermes-space-3); right: var(--hermes-space-3);
    background: var(--hermes-warning-light); color: var(--hermes-warning-dark);
    border-radius: var(--hermes-radius-full); padding: 2px 10px;
    font-weight: 800; font-size: 0.95rem;
}
.hermes-story-note { font-size: 0.85rem; margin-top: var(--hermes-space-4); }
.hermes-story-chart {
    position: relative; height: 340px;
    background: var(--hermes-bg); border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-lg); padding: var(--hermes-space-4);
}

.hermes-story-premium { text-align: center; }
.hermes-story-perks { max-width: 460px; margin: var(--hermes-space-4) auto; text-align: left; }
.hermes-story-cta { margin-top: var(--hermes-space-5); }
.hermes-story-cta__lead { font-size: 1.1rem; font-weight: 700; margin-bottom: var(--hermes-space-3); }
.hermes-story-cta__fine { color: var(--hermes-text-muted); font-size: 0.85rem; margin-top: var(--hermes-space-3); }

.hermes-story-method { max-width: 760px; }
.hermes-story-power { text-align: center; }
.hermes-story-power__links { display: flex; flex-wrap: wrap; gap: var(--hermes-space-3); justify-content: center; margin-top: var(--hermes-space-4); }

@media (max-width: 640px) {
    .hermes-story-chart { height: 280px; }
}

/* ============================================================
   Premium paywall (substitution optimizer locked preview)
   ============================================================ */
.hermes-paywall {
    max-width: 620px;
    margin: var(--hermes-space-6) auto;
    padding: var(--hermes-space-8) var(--hermes-space-6);
    text-align: center;
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-xl);
    background: linear-gradient(160deg, var(--hermes-primary-50), var(--hermes-bg));
    box-shadow: var(--hermes-shadow-sm);
}
.hermes-paywall__icon { font-size: 2.6rem; line-height: 1; }
.hermes-paywall h2 { color: var(--hermes-primary); margin: var(--hermes-space-2) 0; }
.hermes-paywall__lead { color: var(--hermes-text); margin: 0 auto var(--hermes-space-4); max-width: 460px; }
.hermes-paywall__example {
    background: var(--hermes-bg);
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-lg);
    padding: var(--hermes-space-3) var(--hermes-space-4);
    margin: 0 auto var(--hermes-space-4);
    max-width: 480px;
}
.hermes-paywall__swap { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: var(--hermes-space-2); }
.hermes-paywall__arrow { color: var(--hermes-primary); font-weight: 700; }
.hermes-paywall__locked { list-style: none; padding: 0; margin: 0 auto var(--hermes-space-5); max-width: 360px; text-align: left; color: var(--hermes-text-muted); }
.hermes-paywall__locked li { padding: 4px 0; }

/* ============================================================
   Classic comparison matrix (/cart/optimize/)
   ============================================================ */
.hermes-compare-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.hermes-compare-table {
    width: 100%;
    border-collapse: collapse;
    min-width: 560px;
    font-size: 0.92rem;
}
.hermes-compare-table th,
.hermes-compare-table td {
    padding: var(--hermes-space-3);
    border-bottom: 1px solid var(--hermes-border);
    text-align: center;
    vertical-align: middle;
}
.hermes-compare-table thead th {
    background: var(--hermes-primary-50);
    color: var(--hermes-primary);
    font-weight: 700;
    white-space: nowrap;
}
.hermes-compare-table thead th.is-cheapest-store { background: #DCFCE7; color: #166534; }
.hermes-compare-table__item { text-align: left; font-weight: 600; max-width: 220px; }
.hermes-compare-cell__price { display: block; font-weight: 700; }
.hermes-compare-cell.is-cheapest { background: #F0FDF4; }
.hermes-compare-cell.is-cheapest .hermes-compare-cell__price { color: #166534; }
.hermes-compare-cell.is-missing { background: var(--hermes-neutral-100, #f1f5f9); }
.hermes-compare-cell__tag {
    display: inline-block; margin-top: 2px;
    font-size: 0.72rem; color: var(--hermes-text-muted);
}
.hermes-compare-cell__tag--alt { color: var(--hermes-primary); text-decoration: none; }
.hermes-compare-cell__tag--alt:hover { text-decoration: underline; }
.hermes-compare-cell__missing { color: var(--hermes-text-muted); font-size: 0.82rem; }
.hermes-compare-table__totals td, .hermes-compare-table__totals th {
    border-top: 2px solid var(--hermes-border-strong);
    background: var(--hermes-bg);
}
.hermes-compare-table__totals td.is-cheapest { background: #DCFCE7; }

/* ============================================================
   Receipts (hermes_receipts) — upload, review
   ============================================================ */
.hermes-receipt-upload, .hermes-receipt-review { max-width: 920px; }
.hermes-receipt-drop {
    display: flex; flex-direction: column; align-items: center; gap: var(--hermes-space-2);
    padding: var(--hermes-space-8); text-align: center; cursor: pointer;
    border: 2px dashed var(--hermes-border-strong); border-radius: var(--hermes-radius-xl);
    background: var(--hermes-primary-50); color: var(--hermes-text-muted);
    transition: border-color .12s ease;
}
.hermes-receipt-drop:hover { border-color: var(--hermes-primary); }
.hermes-receipt-drop input { margin-bottom: var(--hermes-space-2); }
.hermes-receipt-drop__icon { font-size: 2.4rem; line-height: 1; }
.hermes-receipt-review__grid { display: grid; grid-template-columns: minmax(0,300px) 1fr; gap: var(--hermes-space-6); align-items: start; }
.hermes-receipt-review__image img { width: 100%; border-radius: var(--hermes-radius-lg); border: 1px solid var(--hermes-border); }
.hermes-receipt-correct { display: flex; gap: var(--hermes-space-2); margin-top: var(--hermes-space-2); }
.hermes-receipt-correct__input { width: 120px; padding: 4px 8px; border: 1px solid var(--hermes-border); border-radius: var(--hermes-radius-sm); }
@media (max-width: 640px) {
    .hermes-receipt-review__grid { grid-template-columns: 1fr; }
}

/* Named-basket create form — tracking explainer (replaces method picker) */
.hermes-tracking-explainer {
    display: flex;
    gap: var(--hermes-space-2);
    align-items: flex-start;
    padding: var(--hermes-space-3) var(--hermes-space-4);
    background: var(--hermes-primary-50);
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-lg);
    color: var(--hermes-text);
    font-size: 0.9rem;
    line-height: 1.5;
}
.hermes-tracking-explainer .bi { color: var(--hermes-primary); margin-top: 2px; }

/* Alert form — current cheapest price hint box */
.hermes-alert-current {
    display: flex; align-items: center; gap: var(--hermes-space-2);
    background: var(--hermes-primary-50);
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-md);
    padding: var(--hermes-space-2) var(--hermes-space-3);
    margin-bottom: var(--hermes-space-3);
    font-size: 0.9rem;
}
.hermes-alert-current .bi { color: var(--hermes-primary); }

/* Alert form — direction (below/above) radio cards */
.hermes-alert-form fieldset { border: 0; padding: 0; margin: 0; }
.hermes-alert-form fieldset legend {
    float: none; width: auto; font-size: 1rem; margin-bottom: var(--hermes-space-2);
}
.hermes-alert-direction { display: flex; flex-direction: column; gap: var(--hermes-space-2); }
.hermes-alert-direction__opt {
    display: flex; align-items: center; gap: var(--hermes-space-2);
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-md);
    padding: var(--hermes-space-3) var(--hermes-space-4);
    cursor: pointer; margin: 0;
    transition: border-color .12s ease, background .12s ease;
}
.hermes-alert-direction__opt:hover { border-color: var(--hermes-primary-light); }
.hermes-alert-direction__opt:has(input:checked) {
    border-color: var(--hermes-primary);
    background: var(--hermes-primary-50);
    font-weight: 600;
}
.hermes-alert-direction__opt input { margin: 0; flex: 0 0 auto; }

/* Product detail — cheaper similar products (Premium) */
/* Tiered feature locks — Premium gate (💎) + registration gate (📊). */
.hermes-premium-lock {
    text-align: center;
    padding: var(--hermes-space-5) var(--hermes-space-4);
    background: var(--hermes-primary-50);
    border: 1px dashed var(--hermes-primary-light);
    border-radius: var(--hermes-radius-md);
}
.hermes-premium-lock--register {
    background: var(--hermes-neutral-100);
    border-color: var(--hermes-border);
}
.hermes-premium-lock__icon { font-size: 1.8rem; line-height: 1; }
.hermes-premium-lock__title { font-size: 1rem; font-weight: 700; margin: var(--hermes-space-2) 0 var(--hermes-space-1); }
.hermes-premium-lock__body { color: var(--hermes-text-muted); font-size: 0.9rem; margin-bottom: var(--hermes-space-3); }
.hermes-premium-lock__alt { display: inline-block; margin-top: var(--hermes-space-2); font-size: 0.85rem; }

.hermes-cheaper-alts--locked {
    background: var(--hermes-primary-50);
    border: 1px dashed var(--hermes-primary-light);
    border-radius: var(--hermes-radius-md);
    padding: var(--hermes-space-4);
}
.hermes-alt-list { display: flex; flex-direction: column; gap: var(--hermes-space-2); }
.hermes-alt-row {
    display: flex;
    align-items: center;
    gap: var(--hermes-space-3);
    padding: var(--hermes-space-2) var(--hermes-space-3);
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-md);
    text-decoration: none;
    color: inherit;
    transition: border-color .12s ease, box-shadow .12s ease;
}
.hermes-alt-row:hover {
    border-color: var(--hermes-primary);
    box-shadow: var(--hermes-shadow-sm);
}
.hermes-alt-row:hover .hermes-alt-row__name {
    color: var(--hermes-primary);
    text-decoration: underline;
}
.hermes-alt-row__thumb {
    flex: 0 0 auto;
    width: 48px;
    height: 48px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--hermes-neutral-100);
    border-radius: var(--hermes-radius-md);
    overflow: hidden;
    color: var(--hermes-text-muted);
}
.hermes-alt-row__thumb img { width: 100%; height: 100%; object-fit: contain; }
.hermes-alt-row__body { flex: 1 1 auto; min-width: 0; display: flex; flex-direction: column; }
.hermes-alt-row__name { font-weight: 600; color: var(--hermes-text); }
.hermes-alt-row__price { flex: 0 0 auto; white-space: nowrap; }
.hermes-alt-row .hermes-savings-badge { flex: 0 0 auto; }
@media (max-width: 575.98px) {
    .hermes-alt-row__thumb { width: 40px; height: 40px; }
    .hermes-alt-row { flex-wrap: wrap; }
}

/* ------------------------------------------------------------------ */
/* Cookie consent banner (GDPR) — discreet sticky bottom, brand colours */
/* ------------------------------------------------------------------ */
.hermes-cookie-consent {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: var(--hermes-z-modal);
    display: flex;
    align-items: center;
    gap: var(--hermes-space-4);
    flex-wrap: wrap;
    padding: var(--hermes-space-3) var(--hermes-space-4);
    background: var(--hermes-primary);
    color: #fff;
    box-shadow: var(--hermes-shadow-lg);
}
.hermes-cookie-consent.is-hidden { display: none; }
.hermes-cookie-consent__text {
    margin: 0;
    flex: 1 1 320px;
    font-size: 0.92rem;
    line-height: 1.5;
}
.hermes-cookie-consent__actions {
    display: flex;
    align-items: center;
    gap: var(--hermes-space-2);
    flex-wrap: wrap;
}
.hermes-cookie-consent__link {
    color: #fff;
    text-decoration: underline;
    font-size: 0.88rem;
    white-space: nowrap;
}
.hermes-cookie-consent__link:hover { color: var(--hermes-accent-light); }
/* The "reject" button reads as a quiet ghost on the blue bar. */
.hermes-cookie-consent .hermes-btn:not(.hermes-btn--accent) {
    background: transparent;
    color: #fff;
    border: 1px solid rgba(255, 255, 255, 0.55);
}
.hermes-cookie-consent .hermes-btn:not(.hermes-btn--accent):hover {
    background: rgba(255, 255, 255, 0.12);
}

@media (max-width: 600px) {
    .hermes-cookie-consent {
        flex-direction: column;
        align-items: stretch;
        gap: var(--hermes-space-2);
        text-align: center;
    }
    .hermes-cookie-consent__actions { justify-content: center; }
}

/* ------------------------------------------------------------------ */
/* Admin monitoring viewers (cron logs / errors / product updates)    */
/* ------------------------------------------------------------------ */
.hermes-admin-nav-section {
    margin: var(--hermes-space-3) var(--hermes-space-3) var(--hermes-space-1);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--hermes-text-muted);
}
.hermes-log-pre {
    background: #0f172a;
    color: #e2e8f0;
    padding: var(--hermes-space-4);
    border-radius: var(--hermes-radius-md);
    font-size: 0.8rem;
    line-height: 1.5;
    overflow-x: auto;
    white-space: pre-wrap;
    word-break: break-word;
    max-height: 70vh;
}
.hermes-error-list { display: grid; gap: var(--hermes-space-3); }
.hermes-error-card {
    border: 1px solid var(--hermes-border);
    border-radius: var(--hermes-radius-md);
    padding: var(--hermes-space-3) var(--hermes-space-4);
    background: var(--hermes-bg);
}
.hermes-error-card__head {
    display: flex;
    align-items: center;
    gap: var(--hermes-space-2);
    flex-wrap: wrap;
    margin-bottom: var(--hermes-space-1);
}
.hermes-error-card__msg { font-weight: 500; word-break: break-word; }
.hermes-error-card details { margin-top: var(--hermes-space-2); }
.hermes-error-card summary { cursor: pointer; color: var(--hermes-primary); }
.hermes-admin-mini-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 4px; }
.hermes-admin-mini-list li {
    display: flex; justify-content: space-between; gap: var(--hermes-space-2);
    padding: 4px 0; border-bottom: 1px solid var(--hermes-border-light, #eee);
}
.hermes-admin-empty { padding: var(--hermes-space-6); text-align: center; }
