/* =============================================================
   Italicum 2.0 — Bottega italiana moderna
   Design language: editoriale, caldo, premium, ariosa.
   ============================================================= */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400&family=Inter:wght@400;500;600;700;800&display=swap');

/* -------------------------------------------------------------
   1. Tokens
   ------------------------------------------------------------- */
:root {
    /* Surfaces */
    --it-bg: #FAF6EF;
    --it-bg-warm: #F3ECDF;
    --it-bg-deep: #1F1B17;
    --it-surface: #FFFFFF;
    --it-surface-warm: #FBF7F0;

    /* Ink */
    --it-ink: #1A1816;
    --it-muted: #5F574D;
    --it-soft: #968B7E;
    --it-line: #E8E0D2;
    --it-line-soft: #F1EBDD;

    /* Brand: terracotta italiana */
    --it-brand: #C44132;
    --it-brand-strong: #8E2A21;
    --it-brand-soft: #F7E0DA;
    --it-brand-tint: #FBEDE8;

    /* Accent: oliva profondo */
    --it-olive: #2D5645;
    --it-olive-soft: #DCE7DF;
    --it-olive-tint: #ECF2EE;

    /* Oro caldo */
    --it-gold: #B68842;
    --it-gold-soft: #F5E9D0;

    /* Stato */
    --it-success: #2A7C4E;
    --it-success-soft: #DFF1E5;
    --it-danger: #B82A1E;
    --it-warn: #A36507;

    /* Type families */
    --it-font-display: 'Cormorant Garamond', 'Cormorant', Garamond, 'Apple Garamond', 'Times New Roman', serif;
    --it-font-body: 'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;

    /* Geometry */
    --it-radius-xs: 6px;
    --it-radius-sm: 10px;
    --it-radius: 16px;
    --it-radius-lg: 24px;
    --it-radius-xl: 32px;

    --it-shadow-xs: 0 1px 2px rgba(31, 27, 23, 0.04);
    --it-shadow-sm: 0 2px 8px rgba(31, 27, 23, 0.06);
    --it-shadow: 0 12px 28px rgba(31, 27, 23, 0.08);
    --it-shadow-lg: 0 28px 70px rgba(31, 27, 23, 0.14);
    --it-shadow-pop: 0 24px 60px rgba(142, 42, 33, 0.16);

    --it-ease: cubic-bezier(0.22, 1, 0.36, 1);
}

/* -------------------------------------------------------------
   2. Base / reset
   ------------------------------------------------------------- */
html,
body {
    background: var(--it-bg) !important;
    color: var(--it-ink);
    font-family: var(--it-font-body) !important;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    background-image:
        radial-gradient(circle at 12% -10%, rgba(196, 65, 50, 0.06), transparent 45%),
        radial-gradient(circle at 90% 8%, rgba(45, 86, 69, 0.05), transparent 50%) !important;
    background-size: auto !important;
}

h1, h2, h3, h4 {
    font-variant: normal !important;
    font-feature-settings: normal !important;
    text-transform: none;
}

* {
    letter-spacing: 0 !important;
}

h1, h2, h3, h4,
.sf-card__name,
.sf-blog-card__title,
.sf-product__title {
    font-family: var(--it-font-display);
    color: var(--it-ink);
    font-weight: 600;
    line-height: 1.08;
    margin: 0;
}

p { line-height: 1.6; }

a { color: var(--it-brand-strong); }

::selection { background: var(--it-brand-soft); color: var(--it-brand-strong); }

.sf-shell {
    width: min(100% - 48px, 1280px) !important;
    margin: 0 auto !important;
}

.sf-main {
    padding: 56px 0 96px !important;
}

/* -------------------------------------------------------------
   3. Topbar
   ------------------------------------------------------------- */
.sf-promo {
    background: var(--it-bg-deep) !important;
    color: rgba(255, 255, 255, 0.86) !important;
    border: 0 !important;
    font-family: var(--it-font-body) !important;
    font-size: 0.74rem !important;
    font-weight: 500;
    letter-spacing: 0.12em !important;
    text-transform: uppercase;
    text-align: center;
    padding: 10px 16px !important;
}

.sf-italicum-topbar {
    background: var(--it-bg-deep);
    color: rgba(255, 255, 255, 0.78);
    font-size: 0.76rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.sf-italicum-topbar__inner {
    min-height: 40px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
}

.sf-italicum-topbar__trust,
.sf-italicum-topbar__tools {
    display: flex;
    align-items: center;
    gap: 22px;
}

.sf-italicum-topbar__trust span {
    position: relative;
    white-space: nowrap;
    letter-spacing: 0.04em !important;
    text-transform: uppercase;
    font-size: 0.7rem;
    font-weight: 500;
}

.sf-italicum-topbar__trust span + span::before {
    content: "";
    position: absolute;
    left: -12px;
    top: 50%;
    width: 3px;
    height: 3px;
    border-radius: 50%;
    background: var(--it-gold);
    transform: translateY(-50%);
}

/* Lang switcher */
.sf-italicum-lang {
    display: inline-flex;
    padding: 3px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.12);
}

.sf-italicum-lang a {
    min-height: 24px !important;
    min-width: 32px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 10px !important;
    border: 0 !important;
    border-radius: 999px !important;
    background: transparent !important;
    color: rgba(255, 255, 255, 0.66) !important;
    font-size: 0.72rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.08em !important;
    text-decoration: none;
    transition: color 0.18s var(--it-ease), background 0.18s var(--it-ease);
}

.sf-italicum-lang a:hover { color: #ffffff !important; }

.sf-italicum-lang a.is-active {
    background: #ffffff !important;
    color: var(--it-ink) !important;
}

/* Currency */
.sf-italicum-currency {
    display: inline-flex;
    margin: 0;
}

.sf-italicum-currency select {
    -webkit-appearance: none;
    appearance: none;
    min-height: 30px !important;
    padding: 0 30px 0 14px !important;
    border: 1px solid rgba(255, 255, 255, 0.16) !important;
    border-radius: 999px !important;
    background-color: rgba(255, 255, 255, 0.08) !important;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='m6 9 6 6 6-6'/></svg>") !important;
    background-position: right 11px center !important;
    background-repeat: no-repeat !important;
    background-size: 11px 11px !important;
    color: #ffffff !important;
    font: inherit;
    font-size: 0.72rem !important;
    font-weight: 700;
    letter-spacing: 0.08em !important;
    text-transform: uppercase;
    cursor: pointer;
}

.sf-italicum-currency select option {
    color: var(--it-ink);
    background: #ffffff;
}

/* -------------------------------------------------------------
   4. Header
   ------------------------------------------------------------- */
.sf-header,
.sf-italicum-header {
    position: sticky;
    top: 0;
    z-index: 40;
    background: #ffffff !important;
    border-bottom: 1px solid var(--it-line) !important;
    box-shadow: none !important;
    backdrop-filter: none;
}

.sf-header__inner,
.sf-italicum-header__main {
    min-height: 88px !important;
    display: grid !important;
    grid-template-columns: minmax(220px, 1fr) auto minmax(260px, 1fr);
    align-items: center;
    gap: 24px !important;
    padding: 18px 0 !important;
}

.sf-italicum-brand {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 0;
}

.sf-brand__mark {
    max-height: 44px;
    width: auto;
    filter: none;
}

/* Search */
.sf-italicum-search,
.sf-search {
    position: relative;
    grid-column: 1;
    display: flex !important;
    align-items: center;
    gap: 10px;
    min-height: 50px !important;
    padding: 0 18px !important;
    border: 1px solid var(--it-line) !important;
    border-radius: 999px !important;
    background: var(--it-surface) !important;
    box-shadow: var(--it-shadow-xs) !important;
    transition: border-color 0.18s var(--it-ease), box-shadow 0.18s var(--it-ease);
}

.sf-italicum-search:focus-within,
.sf-search:focus-within {
    border-color: var(--it-brand) !important;
    box-shadow: 0 0 0 4px rgba(196, 65, 50, 0.12) !important;
}

.sf-italicum-search svg {
    color: var(--it-soft);
    flex: 0 0 auto;
}

.sf-italicum-search input,
.sf-search input {
    flex: 1;
    min-height: 100%;
    border: 0;
    background: transparent;
    color: var(--it-ink);
    font: inherit;
    font-size: 0.92rem;
    outline: none;
}

.sf-italicum-search input::placeholder {
    color: var(--it-soft);
}

/* Actions */
.sf-italicum-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 6px;
}

.sf-italicum-action {
    position: relative;
    width: 48px;
    height: 48px;
    display: inline-grid;
    place-items: center;
    padding: 0;
    border: 1px solid transparent;
    border-radius: 999px;
    color: var(--it-ink);
    text-decoration: none;
    background: transparent;
    transition: background 0.18s var(--it-ease), color 0.18s var(--it-ease), border-color 0.18s var(--it-ease);
}

.sf-italicum-action:hover {
    background: var(--it-brand-tint);
    color: var(--it-brand-strong);
    border-color: var(--it-brand-soft);
}

.sf-italicum-action > span:not(.sf-italicum-action__icon) {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.sf-italicum-action__icon {
    display: inline-grid;
    place-items: center;
}

.sf-italicum-action__icon svg {
    width: 22px !important;
    height: 22px !important;
    stroke-width: 1.8;
}

.sf-italicum-action.sf-cart-trigger::after {
    content: attr(data-count);
    position: absolute;
    top: 4px;
    right: 4px;
    min-width: 16px;
    height: 16px;
    display: grid;
    place-items: center;
    padding: 0 4px;
    border-radius: 999px;
    background: var(--it-brand);
    color: #ffffff;
    font-family: var(--it-font-body);
    font-size: 0.62rem;
    font-weight: 800;
    border: 2px solid #ffffff;
    box-sizing: border-box;
    line-height: 1;
    pointer-events: none;
}

.sf-italicum-action.sf-cart-trigger[data-count="0"]::after { display: none; }

/* -------------------------------------------------------------
   5. Mega menu
   ------------------------------------------------------------- */
.sf-italicum-mega {
    border-top: 1px solid var(--it-line-soft);
    background: rgba(255, 255, 255, 0.98);
}

.sf-italicum-mega__inner {
    position: relative;
    min-height: 52px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.sf-italicum-mega__item--category {
    position: relative;
}

.sf-italicum-mega__trigger,
.sf-italicum-mega__link {
    min-height: 36px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 0 13px;
    border-radius: 999px;
    border: 1px solid transparent;
    color: var(--it-ink);
    background: transparent;
    text-decoration: none;
    font-size: 0.86rem;
    font-weight: 760;
    text-transform: uppercase;
    cursor: pointer;
    white-space: nowrap;
    transition: background 0.18s var(--it-ease), color 0.18s var(--it-ease), border-color 0.18s var(--it-ease);
}

.sf-italicum-mega__trigger {
    background: var(--it-ink);
    color: #ffffff;
}

.sf-italicum-mega__trigger:hover,
.sf-italicum-mega__trigger:focus-visible {
    background: var(--it-brand-strong);
    color: #ffffff;
    border-color: transparent;
}

.sf-italicum-mega__link:hover,
.sf-italicum-mega__item--category:hover .sf-italicum-mega__link,
.sf-italicum-mega__item--category:focus-within .sf-italicum-mega__link {
    border-color: rgba(196, 65, 50, 0.18);
    background: var(--it-brand-tint);
    color: var(--it-brand-strong);
}

.sf-italicum-mega__link--soft {
    margin-left: auto;
    color: var(--it-muted);
}

.sf-italicum-mega__link--soft + .sf-italicum-mega__link--soft {
    margin-left: 0;
}

.sf-italicum-mega__item--category > .sf-italicum-mega__link::after {
    content: "";
    width: 0;
    height: 0;
    margin-top: 3px;
    border-left: 5px solid transparent;
    border-right: 5px solid transparent;
    border-top: 6px solid currentColor;
    opacity: 0.9;
}

.sf-italicum-mega__flyout {
    position: absolute;
    top: calc(100% + 8px);
    left: 0;
    z-index: 90;
    width: min(280px, 86vw);
    display: grid;
    gap: 6px;
    padding: 12px;
    border: 1px solid var(--it-line);
    border-radius: 14px;
    background: var(--it-surface);
    box-shadow: var(--it-shadow);
    opacity: 0;
    pointer-events: none;
    transform: translateY(6px);
    transition: opacity 0.14s var(--it-ease), transform 0.14s var(--it-ease);
}

.sf-italicum-mega__item--category:hover .sf-italicum-mega__flyout,
.sf-italicum-mega__item--category:focus-within .sf-italicum-mega__flyout {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
}

.sf-italicum-mega__flyout strong {
    padding: 4px 6px 7px;
    color: var(--it-ink);
    font-family: var(--it-font-body);
    font-size: 0.88rem;
    font-weight: 760;
    line-height: 1.2;
}

.sf-italicum-mega__flyout a {
    padding: 8px 9px;
    border-radius: 10px;
    color: var(--it-muted);
    font-size: 0.84rem;
    line-height: 1.2;
    text-decoration: none;
    transition: background 0.16s var(--it-ease), color 0.16s var(--it-ease);
}

.sf-italicum-mega__flyout a:hover {
    background: var(--it-brand-tint);
    color: var(--it-brand-strong);
}

.sf-italicum-mega__flyout-all {
    margin-top: 5px;
    border-top: 1px solid var(--it-line-soft);
    color: var(--it-brand-strong) !important;
    font-weight: 760;
    border-radius: 0 !important;
}

.sf-italicum-mega__panel { display: none; } /* panel non utilizzato nel nuovo layout */

/* -------------------------------------------------------------
   6. Buttons
   ------------------------------------------------------------- */
.sf-btn,
.sf-btn-primary,
.sf-btn-ghost {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 48px;
    padding: 0 22px !important;
    border-radius: 999px !important;
    font-family: var(--it-font-body) !important;
    font-size: 0.9rem;
    font-weight: 700 !important;
    letter-spacing: 0.02em !important;
    text-decoration: none;
    cursor: pointer;
    transition: background 0.2s var(--it-ease), color 0.2s var(--it-ease), border-color 0.2s var(--it-ease), transform 0.18s var(--it-ease), box-shadow 0.2s var(--it-ease);
}

.sf-btn-primary {
    background: var(--it-brand) !important;
    border: 1px solid var(--it-brand) !important;
    color: #ffffff !important;
    box-shadow: 0 8px 20px rgba(196, 65, 50, 0.22);
}

.sf-btn-primary:hover {
    background: var(--it-brand-strong) !important;
    border-color: var(--it-brand-strong) !important;
    color: #ffffff !important;
    transform: translateY(-1px);
    box-shadow: 0 14px 28px rgba(196, 65, 50, 0.28);
}

.sf-btn-ghost {
    background: var(--it-surface) !important;
    border: 1px solid var(--it-line) !important;
    color: var(--it-ink) !important;
}

.sf-btn-ghost:hover {
    border-color: var(--it-ink) !important;
    background: var(--it-bg-warm) !important;
}

.sf-btn--full {
    width: 100%;
}

/* -------------------------------------------------------------
   7. Eyebrow + Section heads
   ------------------------------------------------------------- */
.sf-italicum-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 14px;
    color: var(--it-brand-strong);
    font-family: var(--it-font-body);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.18em !important;
    text-transform: uppercase;
}

.sf-italicum-eyebrow::before {
    content: "";
    width: 28px;
    height: 1px;
    background: var(--it-brand);
}

.sf-section {
    margin-top: 96px !important;
}

.sf-section__head {
    display: flex !important;
    align-items: flex-end !important;
    justify-content: space-between;
    gap: 24px;
    margin-bottom: 32px !important;
    padding-bottom: 0 !important;
    border-bottom: 0 !important;
}

.sf-section__head > div {
    max-width: 640px;
}

.sf-section__head h2 {
    font-size: clamp(1.85rem, 3vw, 2.65rem) !important;
    line-height: 1.04 !important;
    margin: 0;
}

.sf-section__head p {
    margin: 10px 0 0;
    color: var(--it-muted) !important;
    font-size: 1rem;
    line-height: 1.55;
    max-width: 620px;
}

/* -------------------------------------------------------------
   8. Hero / Slider
   ------------------------------------------------------------- */
.sf-italicum-slider {
    position: relative;
    margin-top: 8px;
}

.sf-italicum-slider__track {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: 100%;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
}

.sf-italicum-slider__track::-webkit-scrollbar { display: none; }

.sf-italicum-slide {
    position: relative;
    min-height: 520px;
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
    gap: 48px;
    padding: 60px clamp(36px, 5vw, 72px);
    border-radius: var(--it-radius-xl);
    background:
        linear-gradient(140deg, #FBF7F0 0%, #F3E9D8 60%, #ECDCC1 100%);
    color: var(--it-ink);
    box-shadow: var(--it-shadow);
    scroll-snap-align: start;
    overflow: hidden;
}

.sf-italicum-slide::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 12% 90%, rgba(45, 86, 69, 0.12), transparent 40%),
        radial-gradient(circle at 88% 8%, rgba(196, 65, 50, 0.10), transparent 45%);
    pointer-events: none;
}

.sf-italicum-slide--background {
    grid-template-columns: minmax(0, 1fr);
    background-position: center;
    background-size: cover;
}

.sf-italicum-slide--background::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(120deg, rgba(31, 27, 23, 0.55) 0%, rgba(31, 27, 23, 0.25) 60%, rgba(31, 27, 23, 0.15) 100%);
}

.sf-italicum-slide--background .sf-italicum-slide__copy { color: #ffffff; position: relative; z-index: 2; }
.sf-italicum-slide--background .sf-italicum-slide__copy h1,
.sf-italicum-slide--background .sf-italicum-slide__copy h2 { color: #ffffff; }
.sf-italicum-slide--background .sf-italicum-slide__copy p { color: rgba(255, 255, 255, 0.86); }
.sf-italicum-slide--background .sf-italicum-slide__eyebrow { background: rgba(255, 255, 255, 0.92); color: var(--it-ink); }

.sf-italicum-slide__image-link {
    position: absolute;
    inset: 0;
    z-index: 3;
}

.sf-italicum-slide__full-image {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.sf-italicum-slide__copy {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
}

.sf-italicum-slide__eyebrow {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 0 14px;
    margin-bottom: 22px;
    border-radius: 999px;
    background: var(--it-ink);
    color: #ffffff;
    font-family: var(--it-font-body);
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.16em !important;
}

.sf-italicum-slide h1,
.sf-italicum-slide h2 {
    max-width: 720px;
    margin: 0;
    color: var(--it-ink);
    font-family: var(--it-font-display);
    font-size: clamp(2.6rem, 5vw, 4.2rem);
    font-weight: 500;
    line-height: 1;
}

.sf-italicum-slide p {
    max-width: 540px;
    margin: 22px 0 28px;
    color: var(--it-muted);
    font-size: 1.05rem;
    line-height: 1.6;
}

.sf-italicum-slide__visual {
    position: relative;
    z-index: 2;
    align-self: stretch;
    min-height: 380px;
    display: grid;
    place-items: center;
    overflow: visible;
}

.sf-italicum-slide__visual img {
    width: 100%;
    height: 100%;
    max-height: 460px;
    object-fit: contain;
    object-position: center;
    border-radius: var(--it-radius-lg);
    background: #ffffff;
    box-shadow: var(--it-shadow-pop);
}

.sf-italicum-slide__visual:not(:has(img))::before {
    content: "";
    position: absolute;
    inset: 8% 12% 8% 12%;
    border-radius: 999px;
    background:
        linear-gradient(140deg, var(--it-brand) 0%, var(--it-brand-strong) 50%, var(--it-olive) 100%);
    box-shadow: var(--it-shadow-pop);
}

.sf-italicum-slide__visual span { display: none; }

/* Slider nav */
.sf-italicum-slider__nav {
    position: absolute;
    bottom: 24px;
    right: 24px;
    z-index: 4;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 8px;
    border: 1px solid var(--it-line);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.92);
    backdrop-filter: blur(10px);
    box-shadow: var(--it-shadow-sm);
}

.sf-italicum-slider__arrow {
    width: 38px;
    height: 38px;
    display: inline-grid;
    place-items: center;
    border: 0;
    border-radius: 999px;
    background: transparent;
    color: var(--it-ink);
    cursor: pointer;
    transition: background 0.16s var(--it-ease), color 0.16s var(--it-ease);
}

.sf-italicum-slider__arrow:hover {
    background: var(--it-brand);
    color: #ffffff;
}

.sf-italicum-slider__dots {
    display: flex;
    align-items: center;
    gap: 6px;
}

.sf-italicum-slider__dots button {
    width: 8px;
    height: 8px;
    padding: 0;
    border: 0;
    border-radius: 999px;
    background: var(--it-line);
    cursor: pointer;
    transition: width 0.2s var(--it-ease), background 0.2s var(--it-ease);
}

.sf-italicum-slider__dots button.is-active {
    width: 28px;
    background: var(--it-brand);
}

.sf-italicum-slider--home {
    width: 100vw;
    margin-top: -56px;
    margin-right: calc(50% - 50vw);
    margin-left: calc(50% - 50vw);
}

.sf-italicum-slider--home .sf-italicum-slide {
    min-height: clamp(430px, 48vw, 680px);
    padding-right: max(48px, calc((100vw - 1280px) / 2 + 48px));
    padding-left: max(48px, calc((100vw - 1280px) / 2 + 48px));
    border-radius: 0;
    box-shadow: none;
}

.sf-italicum-slider--home .sf-italicum-slide--image-only {
    display: block;
    min-height: 0;
    height: clamp(180px, 27.35vw, 525px);
    padding: 0;
    background: #ffffff;
}

.sf-italicum-slider--home .sf-italicum-slide::before,
.sf-italicum-slider--home .sf-italicum-slide--background::after {
    content: none;
    display: none;
}

.sf-italicum-slider--home .sf-italicum-slide--background {
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    background-color: #ffffff;
}

.sf-italicum-slider--home .sf-italicum-slider__nav {
    right: max(24px, calc((100vw - 1280px) / 2 + 24px));
}

/* -------------------------------------------------------------
   9. Catbar (categories scroller in alcuni layout)
   ------------------------------------------------------------- */
.sf-catbar {
    background: transparent !important;
    border: 0 !important;
}

.sf-catbar__inner {
    gap: 6px !important;
    overflow-x: auto;
    scrollbar-width: none;
}

.sf-catbar__inner::-webkit-scrollbar { display: none; }

.sf-catbar a {
    border: 1px solid var(--it-line) !important;
    border-radius: 999px;
    padding: 8px 14px !important;
    background: var(--it-surface) !important;
    color: var(--it-ink) !important;
    font-weight: 600;
    white-space: nowrap;
    transition: background 0.16s var(--it-ease), color 0.16s var(--it-ease), border-color 0.16s var(--it-ease);
}

.sf-catbar a:hover {
    border-color: var(--it-brand) !important;
    color: var(--it-brand-strong) !important;
    background: var(--it-brand-tint) !important;
}

/* -------------------------------------------------------------
   10. Home: Shop by category (bento)
   ------------------------------------------------------------- */
.sf-italicum-shop-by .sf-section__head { margin-bottom: 24px !important; }

.sf-italicum-shopby-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
}

.sf-italicum-shopby-card {
    position: relative;
    display: block;
    aspect-ratio: 4 / 5;
    overflow: hidden;
    border-radius: var(--it-radius);
    background: var(--it-bg-warm);
    color: #ffffff;
    text-decoration: none;
    isolation: isolate;
    transition: transform 0.28s var(--it-ease), box-shadow 0.28s var(--it-ease);
}

.sf-italicum-shopby-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--it-shadow);
}

.sf-italicum-shopby-card__media {
    position: absolute;
    inset: 0;
    z-index: 0;
}

.sf-italicum-shopby-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    transition: transform 0.6s var(--it-ease);
}

.sf-italicum-shopby-card:hover .sf-italicum-shopby-card__media img {
    transform: scale(1.06);
}

.sf-italicum-shopby-card__overlay {
    position: absolute;
    inset: 0;
    z-index: 1;
    background:
        linear-gradient(180deg, rgba(15, 12, 10, 0) 30%, rgba(15, 12, 10, 0.85) 100%);
    transition: background 0.3s var(--it-ease);
}

.sf-italicum-shopby-card:hover .sf-italicum-shopby-card__overlay {
    background:
        linear-gradient(180deg, rgba(15, 12, 10, 0.18) 20%, rgba(142, 42, 33, 0.7) 100%);
}

.sf-italicum-shopby-card__body {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 2;
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 12px;
    padding: 16px 18px;
}

.sf-italicum-shopby-card__body strong {
    flex: 1;
    min-width: 0;
    color: #ffffff;
    font-family: var(--it-font-display);
    font-size: 1.35rem;
    font-weight: 500;
    line-height: 1.12;
    text-shadow: 0 2px 12px rgba(0, 0, 0, 0.55);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.sf-italicum-shopby-card__cta {
    flex: 0 0 auto;
    width: 36px;
    height: 36px;
    display: inline-grid;
    place-items: center;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.95);
    color: var(--it-brand-strong);
    transition: transform 0.24s var(--it-ease), background 0.24s var(--it-ease);
}

.sf-italicum-shopby-card:hover .sf-italicum-shopby-card__cta {
    background: var(--it-brand);
    color: #ffffff;
    transform: translateX(2px);
}

@media (max-width: 1180px) {
    .sf-italicum-shopby-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}
@media (max-width: 760px) {
    .sf-italicum-shopby-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .sf-italicum-shopby-card__body strong { font-size: 1.15rem; }
}

/* -------------------------------------------------------------
   11. Product card (lista, home, related)
   ------------------------------------------------------------- */
.sf-grid,
.sf-blog-grid,
.sf-italicum-product-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)) !important;
    gap: 20px !important;
    align-items: stretch;
}

.sf-italicum-product,
.sf-card {
    position: relative;
    display: grid !important;
    grid-template-rows: auto 1fr;
    overflow: hidden;
    border: 1px solid var(--it-line) !important;
    border-radius: var(--it-radius) !important;
    background: var(--it-surface) !important;
    box-shadow: none !important;
    transition: border-color 0.22s var(--it-ease), transform 0.22s var(--it-ease), box-shadow 0.22s var(--it-ease);
}

.sf-italicum-product:hover,
.sf-card:hover {
    border-color: var(--it-brand-soft) !important;
    transform: translateY(-4px);
    box-shadow: var(--it-shadow) !important;
}

.sf-italicum-product__media,
.sf-card__thumb {
    position: relative;
    aspect-ratio: 1 / 1 !important;
    display: grid !important;
    place-items: center;
    padding: 18px !important;
    background: #ffffff !important;
    overflow: hidden;
    text-decoration: none;
}

.sf-italicum-product__media img,
.sf-card__thumb img {
    display: block;
    width: auto !important;
    height: auto !important;
    max-width: 100% !important;
    max-height: 100% !important;
    margin: auto !important;
    object-fit: contain !important;
    object-position: center !important;
    mix-blend-mode: normal !important;
    image-rendering: -webkit-optimize-contrast;
    transition: transform 0.4s var(--it-ease);
}

.sf-italicum-product:hover .sf-italicum-product__media img,
.sf-card:hover .sf-card__thumb img {
    transform: scale(1.05);
}

.sf-italicum-product__body,
.sf-card__body {
    display: grid !important;
    align-content: start;
    gap: 8px !important;
    padding: 18px 18px 20px !important;
    min-height: 0;
}

.sf-italicum-product__brand,
.sf-card__brand {
    color: var(--it-soft) !important;
    font-size: 0.7rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.14em !important;
    text-transform: uppercase;
    min-height: 17px;
}

.sf-italicum-product__name,
.sf-card__name {
    color: var(--it-ink) !important;
    text-decoration: none;
    font-family: var(--it-font-display);
    font-size: 1.18rem !important;
    line-height: 1.18 !important;
    font-weight: 500 !important;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.sf-italicum-product__name:hover,
.sf-card__name:hover {
    color: var(--it-brand-strong) !important;
}

.sf-italicum-product__foot,
.sf-card__price-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-top: 6px;
}

.sf-italicum-product__foot strong,
.sf-card__price {
    color: var(--it-ink) !important;
    font-family: var(--it-font-body);
    font-size: 1.08rem !important;
    font-weight: 800 !important;
}

.sf-italicum-product__foot a,
.sf-card__cta {
    color: var(--it-brand-strong) !important;
    font-size: 0.82rem !important;
    font-weight: 700 !important;
    text-decoration: none;
    white-space: nowrap;
}

.sf-card__cta {
    width: fit-content;
    margin-top: auto;
    padding-top: 4px;
}

/* Wishlist heart */
.sf-wishlist-btn,
.sf-italicum-product__wish {
    position: absolute;
    top: 12px;
    right: 12px;
    z-index: 3;
    width: 38px;
    height: 38px;
    display: grid;
    place-items: center;
    padding: 0;
    border: 0;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.94);
    color: var(--it-ink);
    cursor: pointer;
    box-shadow: var(--it-shadow-xs);
    transition: background 0.18s var(--it-ease), color 0.18s var(--it-ease), transform 0.18s var(--it-ease);
    backdrop-filter: blur(4px);
}

.sf-wishlist-btn:hover {
    background: var(--it-brand);
    color: #ffffff;
    transform: scale(1.08);
}

.sf-wishlist-btn.is-active,
.sf-wishlist-btn[aria-pressed="true"] {
    background: var(--it-brand);
    color: #ffffff;
}

.sf-card__thumb-empty {
    display: grid;
    place-items: center;
    gap: 8px;
    color: var(--it-soft);
    font-size: 0.78rem;
    font-weight: 600;
}

/* -------------------------------------------------------------
   11.5 Blog
   ------------------------------------------------------------- */
.sf-blog-hero {
    margin: 0 0 30px;
    padding: clamp(28px, 4vw, 44px);
    border: 1px solid var(--it-line);
    border-radius: var(--it-radius-lg);
    background:
        linear-gradient(135deg, rgba(255, 255, 255, 0.96), rgba(251, 247, 240, 0.96)),
        radial-gradient(circle at 92% 12%, rgba(196, 65, 50, 0.10), transparent 42%);
}

.sf-blog-hero h1 {
    margin: 0;
    font-size: clamp(2.35rem, 4vw, 4rem);
    line-height: 0.98;
}

.sf-blog-hero p {
    max-width: 720px;
    margin: 14px 0 0;
    color: var(--it-muted);
    font-size: 1.03rem;
    line-height: 1.65;
}

.sf-blog-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 22px !important;
}

.sf-blog-card {
    overflow: hidden;
    border: 1px solid var(--it-line) !important;
    border-radius: var(--it-radius-lg) !important;
    background: var(--it-surface) !important;
    box-shadow: none !important;
    transition: border-color 0.22s var(--it-ease), transform 0.22s var(--it-ease), box-shadow 0.22s var(--it-ease);
}

.sf-blog-card:hover {
    border-color: var(--it-brand-soft) !important;
    transform: translateY(-4px);
    box-shadow: var(--it-shadow) !important;
}

.sf-blog-card__link {
    min-height: 100%;
    color: inherit !important;
    text-decoration: none;
}

.sf-blog-card__cover {
    aspect-ratio: 4 / 3;
    background:
        linear-gradient(135deg, var(--it-bg-warm), var(--it-surface-warm)) !important;
}

.sf-blog-card__cover img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s var(--it-ease);
}

.sf-blog-card:hover .sf-blog-card__cover img {
    transform: scale(1.04);
}

.sf-blog-card__cover.is-empty::before {
    content: "Italicum";
    display: grid;
    min-height: 100%;
    place-items: center;
    color: var(--it-soft);
    font-family: var(--it-font-display);
    font-size: 1.65rem;
}

.sf-blog-card__body {
    gap: 10px !important;
    padding: 22px !important;
}

.sf-blog-card__meta {
    color: var(--it-soft) !important;
    font-size: 0.72rem !important;
    font-weight: 700;
    letter-spacing: 0.12em !important;
    text-transform: uppercase;
}

.sf-blog-card__title {
    font-size: 1.42rem !important;
    line-height: 1.08 !important;
}

.sf-blog-card__summary {
    color: var(--it-muted) !important;
    font-size: 0.92rem !important;
    line-height: 1.62 !important;
}

.sf-blog-card__cta {
    color: var(--it-brand-strong) !important;
    font-weight: 760;
}

.sf-blog-grid .sf-blog-card:first-child {
    grid-column: span 2;
}

.sf-blog-grid .sf-blog-card:first-child .sf-blog-card__link {
    display: grid;
    grid-template-columns: minmax(0, 1.12fr) minmax(280px, 0.88fr);
}

.sf-blog-grid .sf-blog-card:first-child .sf-blog-card__cover {
    aspect-ratio: auto;
    min-height: 100%;
}

.sf-blog-grid .sf-blog-card:first-child .sf-blog-card__body {
    align-content: center;
    padding: clamp(26px, 4vw, 38px) !important;
}

.sf-blog-grid .sf-blog-card:first-child .sf-blog-card__title {
    font-size: clamp(1.85rem, 3vw, 2.55rem) !important;
}

.sf-blog-article {
    max-width: 920px !important;
}

.sf-blog-article__head {
    padding: clamp(26px, 4vw, 44px);
    border: 1px solid var(--it-line);
    border-radius: var(--it-radius-lg);
    background: var(--it-surface);
    text-align: center;
}

.sf-blog-article__head h1 {
    max-width: 820px;
    margin: 10px auto 0;
    font-size: clamp(2.1rem, 4vw, 3.7rem) !important;
    line-height: 1;
}

.sf-blog-article__summary {
    max-width: 720px;
    margin: 16px auto 0 !important;
    color: var(--it-muted) !important;
}

.sf-blog-article__cover {
    overflow: hidden;
    margin: 28px 0 0 !important;
    border-radius: var(--it-radius-lg) !important;
    border: 1px solid var(--it-line);
}

.sf-blog-article__body {
    margin-top: 28px;
    padding: clamp(28px, 4vw, 46px);
    border: 1px solid var(--it-line);
    border-radius: var(--it-radius-lg);
    background: var(--it-surface);
    color: var(--it-ink) !important;
}

.sf-blog-article__back {
    margin: 28px 0 0;
}

/* -------------------------------------------------------------
   12. Brand marquee
   ------------------------------------------------------------- */
.sf-italicum-brands-section .sf-section__head { border-bottom: 0 !important; }

.sf-italicum-brand-marquee {
    position: relative;
    overflow: hidden;
    padding: 12px 0;
    border-radius: var(--it-radius-lg);
    background: var(--it-surface);
    border: 1px solid var(--it-line);
}

.sf-italicum-brand-marquee::before,
.sf-italicum-brand-marquee::after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    z-index: 2;
    width: 100px;
    pointer-events: none;
}

.sf-italicum-brand-marquee::before {
    left: 0;
    background: linear-gradient(90deg, var(--it-surface), rgba(255, 255, 255, 0));
}

.sf-italicum-brand-marquee::after {
    right: 0;
    background: linear-gradient(270deg, var(--it-surface), rgba(255, 255, 255, 0));
}

.sf-italicum-brand-track {
    display: flex;
    gap: 14px;
    width: max-content;
    padding: 22px 24px;
    animation: it-brand-swipe 40s linear infinite;
}

.sf-italicum-brand-marquee:hover .sf-italicum-brand-track {
    animation-play-state: paused;
}

.sf-italicum-brand-tile {
    flex: 0 0 auto;
    min-width: 180px;
    min-height: 96px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 12px 26px;
    border: 1px solid var(--it-line);
    border-radius: var(--it-radius);
    background: var(--it-bg-warm);
    transition: transform 0.24s var(--it-ease), border-color 0.24s var(--it-ease), background 0.24s var(--it-ease);
}

.sf-italicum-brand-tile:hover {
    transform: translateY(-3px);
    border-color: var(--it-brand-soft);
    background: var(--it-surface);
}

.sf-italicum-brand-tile img {
    max-width: 140px;
    max-height: 56px;
    width: auto;
    height: auto;
    object-fit: contain;
    filter: grayscale(1) brightness(0.7);
    opacity: 0.78;
    transition: filter 0.24s var(--it-ease), opacity 0.24s var(--it-ease);
}

.sf-italicum-brand-tile:hover img {
    filter: grayscale(0) brightness(1);
    opacity: 1;
}

.sf-italicum-brand-tile__text {
    color: var(--it-ink);
    font-family: var(--it-font-display);
    font-size: 1.3rem;
    font-weight: 500;
    letter-spacing: 0.02em;
    white-space: nowrap;
}

@keyframes it-brand-swipe {
    from { transform: translateX(0); }
    to   { transform: translateX(-50%); }
}

@media (prefers-reduced-motion: reduce) {
    .sf-italicum-brand-track { animation: none; }
}

/* -------------------------------------------------------------
   12.5 Values strip + Newsletter (home additions)
   ------------------------------------------------------------- */
.sf-italicum-values {
    margin: 56px 0 0;
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0;
    padding: 22px clamp(20px, 3vw, 36px);
    border-radius: var(--it-radius-lg);
    background: var(--it-surface);
    border: 1px solid var(--it-line);
}

.sf-italicum-value {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 14px 22px;
    border-right: 1px solid var(--it-line-soft);
}

.sf-italicum-value:last-child {
    border-right: 0;
}

.sf-italicum-value__icon {
    width: 46px;
    height: 46px;
    flex: 0 0 auto;
    display: grid;
    place-items: center;
    border-radius: 999px;
    background: var(--it-brand-tint);
    color: var(--it-brand-strong);
}

.sf-italicum-value strong {
    display: block;
    color: var(--it-ink);
    font-family: var(--it-font-display);
    font-size: 1.12rem;
    font-weight: 600;
    line-height: 1.18;
}

.sf-italicum-value small {
    display: block;
    color: var(--it-muted);
    font-size: 0.82rem;
    line-height: 1.4;
    margin-top: 2px;
}

.sf-italicum-seo-copy {
    margin: 24px 0 0;
    padding: 22px clamp(20px, 3vw, 34px);
    border-radius: var(--it-radius-lg);
    background: var(--it-surface);
    border: 1px solid var(--it-line);
}

.sf-italicum-seo-copy h2 {
    margin: 0;
    color: var(--it-ink);
    font-family: var(--it-font-display);
    font-size: clamp(1.22rem, 2vw, 1.62rem);
    line-height: 1.18;
    letter-spacing: 0;
}

.sf-italicum-seo-copy p {
    margin: 10px 0 0;
    max-width: 920px;
    color: var(--it-muted);
    font-size: 0.96rem;
    line-height: 1.7;
}

@media (max-width: 980px) {
    .sf-italicum-values {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        padding: 14px 18px;
    }
    .sf-italicum-value {
        padding: 12px 14px;
        border-right: 0;
        border-bottom: 1px solid var(--it-line-soft);
    }
    .sf-italicum-value:nth-child(odd) {
        border-right: 1px solid var(--it-line-soft);
    }
    .sf-italicum-value:nth-last-child(-n+2) {
        border-bottom: 0;
    }
}

@media (max-width: 640px) {
    .sf-italicum-values {
        grid-template-columns: 1fr;
    }
    .sf-italicum-value {
        border-right: 0 !important;
        border-bottom: 1px solid var(--it-line-soft);
    }
    .sf-italicum-value:last-child {
        border-bottom: 0;
    }
}

/* Newsletter */
.sf-italicum-newsletter {
    position: relative;
    margin: 96px 0 0;
    padding: clamp(40px, 5vw, 64px) clamp(28px, 4vw, 56px);
    border-radius: var(--it-radius-xl);
    background:
        linear-gradient(135deg, var(--it-olive) 0%, #1F3A2D 100%);
    color: #ffffff;
    overflow: hidden;
    isolation: isolate;
}

.sf-italicum-newsletter::before {
    content: "";
    position: absolute;
    top: -100px;
    right: -100px;
    width: 360px;
    height: 360px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(196, 65, 50, 0.4), transparent 65%);
    z-index: 0;
}

.sf-italicum-newsletter::after {
    content: "";
    position: absolute;
    bottom: -160px;
    left: -80px;
    width: 380px;
    height: 380px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(182, 136, 66, 0.32), transparent 65%);
    z-index: 0;
}

.sf-italicum-newsletter__inner {
    position: relative;
    z-index: 2;
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(320px, 0.9fr);
    align-items: center;
    gap: 48px;
}

.sf-italicum-newsletter__copy .sf-italicum-eyebrow {
    color: var(--it-gold);
}

.sf-italicum-newsletter__copy .sf-italicum-eyebrow::before {
    background: var(--it-gold);
}

.sf-italicum-newsletter__copy h2 {
    margin: 0;
    color: #ffffff;
    font-family: var(--it-font-display);
    font-size: clamp(1.8rem, 3vw, 2.6rem);
    font-weight: 500;
    line-height: 1.08;
    max-width: 540px;
}

.sf-italicum-newsletter__copy p {
    margin: 14px 0 0;
    color: rgba(255, 255, 255, 0.74);
    font-size: 0.96rem;
}

.sf-italicum-newsletter__form {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.96);
    box-shadow: 0 14px 36px rgba(0, 0, 0, 0.18);
}

.sf-italicum-newsletter__field {
    flex: 1;
    min-width: 0;
}

.sf-italicum-newsletter__field input {
    width: 100%;
    min-height: 48px;
    padding: 0 18px;
    border: 0;
    background: transparent;
    color: var(--it-ink);
    font: inherit;
    font-size: 0.96rem;
    outline: none;
}

.sf-italicum-newsletter__field input::placeholder {
    color: var(--it-soft);
}

.sf-italicum-newsletter__form .sf-btn-primary {
    min-height: 48px;
    padding: 0 22px !important;
    flex: 0 0 auto;
}

.sf-sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

@media (max-width: 980px) {
    .sf-italicum-newsletter__inner {
        grid-template-columns: 1fr;
        gap: 28px;
    }
    .sf-italicum-newsletter__form {
        flex-direction: column;
        border-radius: var(--it-radius);
        padding: 14px;
        align-items: stretch;
    }
    .sf-italicum-newsletter__field input {
        border: 1px solid var(--it-line);
        border-radius: var(--it-radius-sm);
    }
}

/* -------------------------------------------------------------
   13. Editorial blocks (spotlight / text)
   ------------------------------------------------------------- */
.sf-italicum-block {
    margin-top: 32px;
    padding: 36px clamp(28px, 4vw, 56px);
    border-radius: var(--it-radius-lg);
    background: var(--it-surface);
    border: 1px solid var(--it-line);
}

.sf-italicum-block h2 {
    margin: 0;
    font-family: var(--it-font-display);
    font-size: clamp(1.65rem, 2.6vw, 2.2rem);
    line-height: 1.06;
    font-weight: 500;
}

.sf-italicum-block p {
    margin: 12px 0 0;
    color: var(--it-muted);
    line-height: 1.65;
}

.sf-italicum-block--spotlight,
.sf-italicum-block--text {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 28px;
    flex-wrap: wrap;
}

.sf-italicum-block--spotlight {
    background: linear-gradient(135deg, var(--it-ink) 0%, #2A211A 100%);
    color: #ffffff;
    border-color: transparent;
}

.sf-italicum-block--spotlight h2 { color: #ffffff; }
.sf-italicum-block--spotlight p { color: rgba(255, 255, 255, 0.78); }

.sf-italicum-block__image {
    width: min(260px, 100%);
    aspect-ratio: 4 / 3;
    object-fit: cover;
    border-radius: var(--it-radius);
    border: 0;
    flex: 0 0 auto;
}

/* -------------------------------------------------------------
   14. Category page
   ------------------------------------------------------------- */
.sf-breadcrumb {
    padding: 8px 14px !important;
    border: 1px solid var(--it-line-soft) !important;
    border-radius: 999px;
    background: var(--it-surface);
    color: var(--it-muted);
    font-size: 0.82rem;
    margin-bottom: 22px;
    width: fit-content;
    max-width: 100%;
    overflow-x: auto;
    box-shadow: none;
}

.sf-breadcrumb a {
    color: var(--it-muted);
    text-decoration: none;
}

.sf-breadcrumb a:hover {
    color: var(--it-brand-strong);
}

.sf-breadcrumb__sep {
    margin: 0 10px;
    color: var(--it-soft);
}

.sf-italicum-category-hero {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 140px;
    align-items: end;
    gap: 24px;
    padding: 38px clamp(28px, 4vw, 44px) !important;
    border-radius: var(--it-radius-lg);
    background:
        linear-gradient(135deg, var(--it-surface) 0%, var(--it-bg-warm) 100%);
    border: 1px solid var(--it-line);
}

.sf-italicum-category-hero__eyebrow {
    display: inline-flex;
    align-items: center;
    min-height: 26px;
    padding: 0 12px;
    margin-bottom: 14px;
    border-radius: 999px;
    background: var(--it-brand);
    color: #ffffff;
    font-family: var(--it-font-body);
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.16em !important;
}

.sf-italicum-category-hero h1 {
    max-width: 760px;
    margin: 0;
    font-family: var(--it-font-display);
    font-size: clamp(2rem, 4vw, 3.2rem) !important;
    font-weight: 500;
    line-height: 1.02 !important;
}

.sf-italicum-category-hero p {
    max-width: 680px;
    margin: 14px 0 0;
    color: var(--it-muted) !important;
    font-size: 1rem;
    line-height: 1.6;
}

.sf-italicum-category-hero__meta {
    min-height: 120px;
    display: grid;
    align-content: center;
    justify-items: center;
    padding: 18px;
    border-radius: var(--it-radius);
    background: var(--it-ink);
    color: #ffffff;
}

.sf-italicum-category-hero__meta strong {
    font-family: var(--it-font-display);
    font-size: 2.4rem;
    font-weight: 500;
    line-height: 1;
}

.sf-italicum-category-hero__meta span {
    margin-top: 6px;
    color: rgba(255, 255, 255, 0.72);
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

/* Subcategories */
.sf-italicum-subcategories {
    margin-top: 36px;
}

.sf-italicum-subcat-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
    gap: 14px;
    margin-top: 16px;
}

.sf-italicum-subcat-card {
    position: relative;
    display: grid;
    grid-template-columns: 60px minmax(0, 1fr) auto;
    align-items: center;
    gap: 14px;
    min-height: 84px;
    padding: 12px 16px 12px 12px;
    border: 1px solid var(--it-line);
    border-radius: var(--it-radius);
    background: var(--it-surface);
    color: var(--it-ink);
    text-decoration: none;
    transition: border-color 0.18s var(--it-ease), transform 0.18s var(--it-ease), box-shadow 0.18s var(--it-ease);
}

.sf-italicum-subcat-card:hover {
    border-color: var(--it-brand-soft);
    transform: translateY(-1px);
    box-shadow: var(--it-shadow-xs);
}

.sf-italicum-subcat-card__media {
    width: 60px;
    height: 60px;
    display: grid;
    place-items: center;
    border-radius: var(--it-radius-sm);
    background: var(--it-bg-warm);
    color: var(--it-brand-strong);
    overflow: hidden;
}

.sf-italicum-subcat-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.sf-italicum-subcat-card__body {
    min-width: 0;
    display: flex;
    align-items: center;
}

.sf-italicum-subcat-card__body strong {
    font-family: var(--it-font-body);
    font-size: 0.94rem;
    font-weight: 600;
    line-height: 1.25;
    color: var(--it-ink);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.sf-italicum-subcat-card__arrow {
    width: 28px;
    height: 28px;
    display: grid;
    place-items: center;
    border-radius: 999px;
    background: var(--it-brand-tint);
    color: var(--it-brand-strong);
    transition: background 0.18s var(--it-ease), color 0.18s var(--it-ease), transform 0.18s var(--it-ease);
}

.sf-italicum-subcat-card:hover .sf-italicum-subcat-card__arrow {
    background: var(--it-brand);
    color: #ffffff;
    transform: translateX(2px);
}

/* Layout filtri + risultati */
.sf-italicum-category-layout {
    display: grid;
    grid-template-columns: 280px minmax(0, 1fr);
    gap: 28px;
    margin-top: 32px;
    align-items: start;
}

/* Filter panel */
.sf-italicum-filter-panel {
    position: sticky;
    top: 120px;
    display: grid;
    padding: 0;
    border: 1px solid var(--it-line);
    border-radius: var(--it-radius);
    background: var(--it-surface);
    overflow: hidden;
}

.sf-italicum-filter-panel__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 18px 20px;
    border-bottom: 1px solid var(--it-line-soft);
    background: var(--it-surface-warm);
}

.sf-italicum-filter-panel__head h2 {
    margin: 0;
    font-family: var(--it-font-display);
    font-size: 1.2rem;
    font-weight: 500;
}

.sf-italicum-filter-panel__head a {
    color: var(--it-brand-strong);
    font-family: var(--it-font-body);
    font-size: 0.78rem;
    font-weight: 700;
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.sf-italicum-filter-group {
    display: grid;
    margin: 0;
    padding: 14px 20px;
    border: 0;
    border-bottom: 1px solid var(--it-line-soft);
}

.sf-italicum-filter-group:last-of-type {
    border-bottom: 0;
}

.sf-italicum-filter-group summary {
    min-height: 36px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    color: var(--it-ink);
    font-size: 0.84rem;
    font-weight: 700;
    cursor: pointer;
    list-style: none;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.sf-italicum-filter-group summary::-webkit-details-marker {
    display: none;
}

.sf-italicum-filter-group summary::after {
    content: "+";
    width: 24px;
    height: 24px;
    display: grid;
    place-items: center;
    border-radius: 999px;
    background: var(--it-bg-warm);
    color: var(--it-ink);
    font-size: 1rem;
    font-weight: 800;
    transition: background 0.18s var(--it-ease), color 0.18s var(--it-ease);
}

.sf-italicum-filter-group[open] summary::after {
    content: "−";
    background: var(--it-brand);
    color: #ffffff;
}

.sf-italicum-filter-options {
    display: grid;
    gap: 4px;
    padding-top: 12px;
    max-height: 260px;
    overflow-y: auto;
    scrollbar-width: thin;
}

.sf-italicum-check {
    display: flex;
    align-items: center;
    gap: 10px;
    min-height: 38px;
    padding: 6px 10px;
    border-radius: var(--it-radius-sm);
    color: var(--it-muted);
    font-size: 0.86rem;
    cursor: pointer;
    transition: background 0.16s var(--it-ease), color 0.16s var(--it-ease);
}

.sf-italicum-check:hover {
    background: var(--it-bg-warm);
    color: var(--it-ink);
}

.sf-italicum-check:has(input:checked) {
    background: var(--it-brand-tint);
    color: var(--it-ink);
}

.sf-italicum-check input {
    position: absolute;
    opacity: 0;
}

.sf-italicum-check i {
    width: 18px;
    height: 18px;
    display: inline-grid;
    place-items: center;
    flex: 0 0 auto;
    border: 1.5px solid var(--it-line);
    border-radius: 5px;
    background: var(--it-surface);
    transition: border-color 0.14s var(--it-ease), background 0.14s var(--it-ease);
}

.sf-italicum-check input:checked + i {
    border-color: var(--it-brand);
    background: var(--it-brand);
}

.sf-italicum-check input:checked + i::after {
    content: "";
    width: 8px;
    height: 5px;
    border-left: 2px solid #ffffff;
    border-bottom: 2px solid #ffffff;
    transform: rotate(-45deg) translateY(-1px);
}

.sf-italicum-check span { flex: 1; }

/* Price slider */
.sf-italicum-price {
    display: grid;
    gap: 18px;
    padding: 14px 0 4px;
}

.sf-italicum-price__slider {
    position: relative;
    height: 28px;
    margin: 6px 6px 0;
}

.sf-italicum-price__track {
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    height: 4px;
    transform: translateY(-50%);
    border-radius: 999px;
    background: var(--it-line);
}

.sf-italicum-price__fill {
    position: absolute;
    top: 50%;
    height: 4px;
    transform: translateY(-50%);
    border-radius: 999px;
    background: var(--it-brand);
}

.sf-italicum-price__range {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 28px;
    margin: 0;
    padding: 0;
    background: transparent;
    -webkit-appearance: none;
    appearance: none;
    pointer-events: none;
    z-index: 2;
}

.sf-italicum-price__range::-webkit-slider-runnable-track {
    height: 28px; background: transparent; border: 0;
}

.sf-italicum-price__range::-moz-range-track {
    height: 28px; background: transparent; border: 0;
}

.sf-italicum-price__range::-webkit-slider-thumb {
    -webkit-appearance: none;
    pointer-events: auto;
    width: 22px;
    height: 22px;
    border-radius: 999px;
    background: var(--it-surface);
    border: 2px solid var(--it-brand);
    box-shadow: var(--it-shadow-sm);
    cursor: grab;
    margin-top: 3px;
    transition: transform 0.14s var(--it-ease), box-shadow 0.14s var(--it-ease);
}

.sf-italicum-price__range::-moz-range-thumb {
    pointer-events: auto;
    width: 22px;
    height: 22px;
    border-radius: 999px;
    background: var(--it-surface);
    border: 2px solid var(--it-brand);
    box-shadow: var(--it-shadow-sm);
    cursor: grab;
}

.sf-italicum-price__range:active::-webkit-slider-thumb {
    cursor: grabbing;
    transform: scale(1.1);
    box-shadow: 0 0 0 6px rgba(196, 65, 50, 0.16);
}

.sf-italicum-price__values {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
}

.sf-italicum-price__values label {
    display: grid;
    gap: 4px;
    color: var(--it-muted);
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.sf-italicum-price__input {
    position: relative;
    display: flex;
    align-items: center;
}

.sf-italicum-price__input input {
    width: 100%;
    min-height: 40px;
    padding: 0 28px 0 12px;
    border: 1px solid var(--it-line);
    border-radius: var(--it-radius-sm);
    background: var(--it-surface);
    color: var(--it-ink);
    font: inherit;
    font-size: 0.92rem;
    -moz-appearance: textfield;
}

.sf-italicum-price__input input::-webkit-inner-spin-button,
.sf-italicum-price__input input::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.sf-italicum-price__input input:focus {
    outline: none;
    border-color: var(--it-brand);
    box-shadow: 0 0 0 3px rgba(196, 65, 50, 0.12);
}

.sf-italicum-price__input span {
    position: absolute;
    right: 10px;
    color: var(--it-soft);
    font-weight: 700;
    pointer-events: none;
}

.sf-italicum-filter-panel .sf-btn-primary {
    width: calc(100% - 40px);
    margin: 16px 20px 20px;
}

/* Toolbar + results */
.sf-italicum-category-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    min-height: 64px;
    margin-bottom: 18px;
    padding: 14px 18px;
    border: 1px solid var(--it-line);
    border-radius: var(--it-radius);
    background: var(--it-surface);
}

.sf-italicum-category-toolbar > div {
    display: grid;
    gap: 2px;
}

.sf-italicum-category-toolbar strong {
    font-family: var(--it-font-body);
    font-size: 0.98rem;
    font-weight: 700;
}

.sf-italicum-category-toolbar span {
    color: var(--it-soft);
    font-size: 0.8rem;
}

.sf-italicum-sort {
    display: grid;
    grid-template-columns: auto minmax(180px, 1fr);
    gap: 10px;
    align-items: center;
    color: var(--it-muted);
    font-size: 0.78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

select {
    -webkit-appearance: none;
    appearance: none;
    min-height: 40px !important;
    padding: 0 38px 0 14px !important;
    border: 1px solid var(--it-line) !important;
    border-radius: var(--it-radius-sm) !important;
    background-color: var(--it-surface) !important;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%235F574D' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='m6 9 6 6 6-6'/></svg>") !important;
    background-repeat: no-repeat !important;
    background-position: right 12px center !important;
    background-size: 14px 14px !important;
    color: var(--it-ink);
    font: inherit;
    font-size: 0.92rem;
    cursor: pointer;
}

select:focus {
    outline: none;
    border-color: var(--it-brand) !important;
    box-shadow: 0 0 0 3px rgba(196, 65, 50, 0.12) !important;
}

/* Chip */
.sf-chip,
.sf-chip-reset,
.sf-tag,
.sf-pill,
.sf-product__brand,
.sf-stock {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    min-height: 30px;
    padding: 4px 12px !important;
    border-radius: 999px !important;
    background: var(--it-bg-warm) !important;
    color: var(--it-ink) !important;
    border: 1px solid var(--it-line) !important;
    font-size: 0.78rem;
    font-weight: 600;
    text-decoration: none;
}

.sf-chip small {
    color: var(--it-soft);
    font-size: 0.7rem;
    font-weight: 700;
}

.sf-chip-reset {
    border-color: var(--it-brand-soft) !important;
    background: var(--it-brand-tint) !important;
    color: var(--it-brand-strong) !important;
}

.sf-stock {
    background: var(--it-success-soft) !important;
    color: var(--it-success) !important;
    border-color: transparent !important;
    text-transform: uppercase;
    font-size: 0.7rem;
    letter-spacing: 0.06em !important;
    font-weight: 700;
}

.sf-stock.is-out {
    background: #FCE4E0 !important;
    color: var(--it-danger) !important;
}

.sf-active-filters {
    display: flex !important;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 22px !important;
}

.sf-italicum-category-description {
    margin: 36px 0 0 !important;
    padding: 32px clamp(24px, 3vw, 40px) !important;
    border-radius: var(--it-radius-lg) !important;
    border: 1px solid var(--it-line) !important;
    background: var(--it-surface);
    box-shadow: none !important;
}

.sf-italicum-category-description h2 {
    font-family: var(--it-font-display);
    font-size: 1.65rem;
    font-weight: 500;
    margin-bottom: 14px;
}

.sf-italicum-category-description div {
    line-height: 1.75;
    color: var(--it-muted);
}

.sf-empty-state {
    padding: 48px 24px;
    border: 1px dashed var(--it-line);
    border-radius: var(--it-radius);
    background: var(--it-surface);
    text-align: center;
}

.sf-empty-state h3 {
    font-family: var(--it-font-display);
    font-size: 1.5rem;
}

.sf-empty-state p {
    color: var(--it-muted);
    margin: 8px 0 18px;
}

/* -------------------------------------------------------------
   15. Categories index page (categories.php)
   ------------------------------------------------------------- */
.sf-italicum-categories-hero {
    display: grid;
    gap: 14px;
    margin-bottom: 32px;
    padding: 44px clamp(28px, 4vw, 52px);
    border-radius: var(--it-radius-lg);
    background:
        linear-gradient(135deg, var(--it-surface) 0%, var(--it-bg-warm) 100%);
    border: 1px solid var(--it-line);
}

.sf-italicum-categories-hero span {
    width: fit-content;
    padding: 4px 12px;
    border-radius: 999px;
    background: var(--it-brand);
    color: #ffffff;
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.16em !important;
    text-transform: uppercase;
}

.sf-italicum-categories-hero h1 {
    margin: 0;
    font-family: var(--it-font-display);
    font-size: clamp(2.2rem, 4.5vw, 3.6rem);
    font-weight: 500;
    line-height: 1;
}

.sf-italicum-categories-hero p {
    max-width: 680px;
    margin: 0;
    color: var(--it-muted);
    font-size: 1.04rem;
    line-height: 1.55;
}

.sf-italicum-all-categories {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 16px;
}

.sf-italicum-all-category {
    display: grid;
    gap: 14px;
    padding: 18px;
    border: 1px solid var(--it-line);
    border-radius: var(--it-radius);
    background: var(--it-surface);
    transition: border-color 0.2s var(--it-ease), transform 0.2s var(--it-ease), box-shadow 0.2s var(--it-ease);
}

.sf-italicum-all-category:hover {
    border-color: var(--it-brand-soft);
    transform: translateY(-2px);
    box-shadow: var(--it-shadow-sm);
}

.sf-italicum-all-category__main {
    display: grid;
    grid-template-columns: 60px minmax(0, 1fr) auto;
    align-items: center;
    gap: 14px;
    color: var(--it-ink);
    text-decoration: none;
}

.sf-italicum-all-category__media {
    width: 60px;
    height: 60px;
    display: grid;
    place-items: center;
    border-radius: var(--it-radius-sm);
    background: var(--it-bg-warm);
    color: var(--it-brand-strong);
    font-family: var(--it-font-display);
    font-size: 1.4rem;
    font-weight: 600;
    overflow: hidden;
}

.sf-italicum-all-category__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.sf-italicum-all-category__body {
    min-width: 0;
    display: grid;
    gap: 4px;
}

.sf-italicum-all-category__body strong {
    font-family: var(--it-font-body);
    font-size: 0.98rem;
    font-weight: 600;
    line-height: 1.25;
    color: var(--it-ink);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.sf-italicum-all-category__body small,
.sf-italicum-all-category__arrow {
    color: var(--it-brand-strong);
    font-weight: 700;
    font-size: 0.78rem;
    letter-spacing: 0.04em;
}

.sf-italicum-all-category__children {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    padding-left: 74px;
}

.sf-italicum-all-category__children a {
    padding: 5px 11px;
    border-radius: 999px;
    background: var(--it-bg-warm);
    color: var(--it-muted);
    font-size: 0.78rem;
    font-weight: 600;
    text-decoration: none;
    transition: background 0.16s var(--it-ease), color 0.16s var(--it-ease);
}

.sf-italicum-all-category__children a:hover {
    background: var(--it-brand-tint);
    color: var(--it-brand-strong);
}

/* -------------------------------------------------------------
   16. Product page (product.php)
   ------------------------------------------------------------- */
.sf-italicum-product-page {
    display: grid;
    grid-template-columns: minmax(0, 0.62fr) minmax(420px, 0.78fr);
    gap: 48px;
    align-items: start;
}

.sf-italicum-product-gallery {
    min-width: 0;
}

.sf-gallery__main {
    position: relative;
    display: grid !important;
    place-items: center;
    width: 100%;
    aspect-ratio: 1 / 1;
    padding: 24px !important;
    box-sizing: border-box;
    border: 1px solid var(--it-line) !important;
    border-radius: var(--it-radius-lg) !important;
    background: #ffffff !important;
    cursor: zoom-in;
    overflow: hidden;
    appearance: none;
    -webkit-appearance: none;
    color: inherit;
    font: inherit;
}

.sf-gallery__main img {
    display: block;
    width: auto !important;
    height: auto !important;
    max-width: 100% !important;
    max-height: 100% !important;
    margin: auto !important;
    object-fit: contain !important;
    object-position: center !important;
    mix-blend-mode: normal !important;
    image-rendering: -webkit-optimize-contrast;
}

.sf-gallery__main-empty {
    color: var(--it-soft);
    font-style: italic;
}

.sf-gallery__zoom-hint {
    position: absolute;
    right: 14px;
    bottom: 14px;
    z-index: 2;
    width: 40px;
    height: 40px;
    display: grid;
    place-items: center;
    border-radius: 999px;
    background: var(--it-ink);
    color: #ffffff;
    pointer-events: none;
    opacity: 0;
    transform: translateY(4px);
    transition: opacity 0.18s var(--it-ease), transform 0.18s var(--it-ease);
}

.sf-gallery__main:hover .sf-gallery__zoom-hint {
    opacity: 1;
    transform: translateY(0);
}

.sf-gallery__thumbs {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(72px, 90px));
    gap: 10px;
    margin-top: 14px;
}

.sf-gallery__thumb {
    aspect-ratio: 1;
    padding: 8px;
    border: 1px solid var(--it-line) !important;
    border-radius: var(--it-radius-sm) !important;
    background: var(--it-surface) !important;
    cursor: pointer;
    transition: border-color 0.16s var(--it-ease), box-shadow 0.16s var(--it-ease);
}

.sf-gallery__thumb img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.sf-gallery__thumb.is-active {
    border-color: var(--it-brand) !important;
    box-shadow: 0 0 0 2px rgba(196, 65, 50, 0.18);
}

/* Lightbox */
.sf-gallery__lightbox {
    position: fixed;
    inset: 0;
    z-index: 200;
    display: grid;
    place-items: center;
    padding: 32px;
    background: rgba(15, 12, 10, 0.88);
    backdrop-filter: blur(8px);
    animation: it-lightbox-fade 0.2s ease-out;
}

.sf-gallery__lightbox[hidden] { display: none; }

@keyframes it-lightbox-fade {
    from { opacity: 0; }
    to   { opacity: 1; }
}

.sf-gallery__lightbox-img {
    display: block;
    max-width: min(92vw, 1100px);
    max-height: 88vh;
    width: auto;
    height: auto;
    object-fit: contain;
    border-radius: var(--it-radius);
    background: var(--it-surface);
    box-shadow: 0 30px 80px rgba(0, 0, 0, 0.5);
}

.sf-gallery__lightbox-close,
.sf-gallery__lightbox-nav {
    position: absolute;
    width: 48px;
    height: 48px;
    display: inline-grid;
    place-items: center;
    border: 0;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.95);
    color: var(--it-ink);
    cursor: pointer;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3);
    transition: background 0.16s var(--it-ease), transform 0.16s var(--it-ease);
}

.sf-gallery__lightbox-close:hover,
.sf-gallery__lightbox-nav:hover {
    background: var(--it-brand);
    color: #ffffff;
    transform: scale(1.05);
}

.sf-gallery__lightbox-close { top: 24px; right: 24px; }
.sf-gallery__lightbox-nav--prev { left: 24px; }
.sf-gallery__lightbox-nav--next { right: 24px; }

/* Buybox */
.sf-italicum-buybox {
    position: sticky;
    top: 120px;
    align-self: start;
    display: grid;
    gap: 18px;
    padding: 32px clamp(24px, 3vw, 36px);
    border: 1px solid var(--it-line);
    border-radius: var(--it-radius-lg);
    background: var(--it-surface);
    box-shadow: var(--it-shadow-sm);
}

.sf-product__brand {
    width: fit-content;
    background: var(--it-bg-warm) !important;
    color: var(--it-ink) !important;
    font-family: var(--it-font-body);
    font-size: 0.72rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.14em !important;
    text-transform: uppercase;
}

.sf-product__title {
    margin: 0 !important;
    font-family: var(--it-font-display);
    font-size: clamp(1.95rem, 3.4vw, 2.65rem) !important;
    font-weight: 500;
    line-height: 1.04 !important;
}

.sf-product__meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px !important;
    margin: 0 !important;
    color: var(--it-muted);
    font-size: 0.82rem;
}

.sf-product__meta > span:first-child {
    font-family: 'SF Mono', 'JetBrains Mono', Menlo, monospace;
    font-size: 0.74rem;
    letter-spacing: 0.04em !important;
    color: var(--it-soft);
}

.sf-italicum-review-link {
    color: var(--it-brand-strong);
    font-weight: 700;
    text-decoration: none;
}

.sf-italicum-review-link:hover {
    text-decoration: underline;
}

.sf-product__pricebox {
    display: grid;
    gap: 4px;
    padding: 20px 22px !important;
    border-radius: var(--it-radius) !important;
    background: linear-gradient(135deg, var(--it-brand-tint), #FBF7F0) !important;
    border: 1px solid var(--it-brand-soft) !important;
    box-shadow: none !important;
}

.sf-product__price,
.sf-product__price[data-price-box] {
    font-family: var(--it-font-display) !important;
    color: var(--it-brand-strong) !important;
    font-size: 2.4rem !important;
    font-weight: 600;
    line-height: 1 !important;
}

.sf-product__price-secondary {
    color: var(--it-muted);
    font-size: 0.82rem;
}

.sf-product__short {
    margin: 0 !important;
    padding-bottom: 18px;
    border-bottom: 1px solid var(--it-line-soft);
    color: var(--it-muted);
    line-height: 1.65;
}

/* Form options */
.sf-italicum-product-form {
    display: grid;
    gap: 18px;
}

.sf-italicum-options {
    display: grid;
    gap: 14px;
}

.sf-italicum-options h2 {
    margin: 0;
    font-family: var(--it-font-display);
    font-size: 1.15rem;
    font-weight: 500;
}

.sf-italicum-option {
    display: grid;
    gap: 12px;
    margin: 0;
    padding: 16px;
    border: 1px solid var(--it-line);
    border-radius: var(--it-radius-sm);
    background: var(--it-surface-warm);
}

.sf-italicum-option legend {
    display: flex;
    align-items: center;
    gap: 8px;
    font-family: var(--it-font-body);
    font-weight: 700;
    color: var(--it-ink);
}

.sf-italicum-option legend span {
    padding: 3px 8px;
    border-radius: 999px;
    background: var(--it-brand-tint);
    color: var(--it-brand-strong);
    font-size: 0.68rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.sf-italicum-option-values {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.sf-italicum-option-values label {
    min-height: 42px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 14px;
    border: 1px solid var(--it-line);
    border-radius: 999px;
    background: var(--it-surface);
    color: var(--it-ink);
    font-size: 0.88rem;
    font-weight: 600;
    cursor: pointer;
    transition: border-color 0.16s var(--it-ease), background 0.16s var(--it-ease), color 0.16s var(--it-ease);
}

.sf-italicum-option-values label:has(input:checked) {
    border-color: var(--it-brand);
    background: var(--it-brand-tint);
    color: var(--it-brand-strong);
}

.sf-italicum-option-values input {
    width: 16px;
    height: 16px;
    accent-color: var(--it-brand);
}

.sf-italicum-option-values.is-image label {
    border-radius: var(--it-radius-sm);
}

.sf-italicum-option-values img {
    width: 38px;
    height: 38px;
    border-radius: 8px;
    object-fit: cover;
}

.sf-italicum-option-values small {
    color: var(--it-brand-strong);
    font-weight: 700;
}

.sf-italicum-qty-row {
    display: grid;
    grid-template-columns: 110px minmax(0, 1fr);
    gap: 12px;
    align-items: end;
}

.sf-italicum-qty-row label {
    display: grid;
    gap: 6px;
    color: var(--it-muted);
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.sf-italicum-qty-row input {
    min-height: 50px;
    padding: 0 12px;
    border: 1px solid var(--it-line);
    border-radius: var(--it-radius-sm);
    background: var(--it-surface);
    color: var(--it-ink);
    font: inherit;
    font-size: 1rem;
    text-align: center;
}

.sf-italicum-qty-row input:focus {
    outline: none;
    border-color: var(--it-brand);
    box-shadow: 0 0 0 3px rgba(196, 65, 50, 0.12);
}

.sf-italicum-qty-row .sf-btn,
.sf-italicum-product-form .sf-btn {
    min-height: 50px;
}

/* Tabs sotto */
.sf-italicum-product-tabs {
    margin-top: 64px;
}

.sf-italicum-tabs {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 4px;
    padding: 5px;
    margin: 0 0 18px;
    border: 1px solid var(--it-line);
    border-radius: 999px;
    background: var(--it-surface);
}

.sf-italicum-tabs button {
    min-height: 38px;
    display: inline-flex;
    align-items: center;
    padding: 0 18px;
    border: 0;
    border-radius: 999px;
    background: transparent;
    color: var(--it-ink);
    font: inherit;
    font-size: 0.86rem;
    font-weight: 700;
    cursor: pointer;
    transition: background 0.16s var(--it-ease), color 0.16s var(--it-ease);
}

.sf-italicum-tabs button:hover {
    background: var(--it-bg-warm);
}

.sf-italicum-tabs button.is-active {
    background: var(--it-ink);
    color: #ffffff;
}

.sf-product__description,
.sf-product__specs,
.sf-reviews {
    padding: 32px clamp(22px, 3vw, 36px) !important;
    border: 1px solid var(--it-line) !important;
    border-radius: var(--it-radius-lg) !important;
    background: var(--it-surface);
    box-shadow: none !important;
}

.sf-product__description h2,
.sf-product__specs h2,
.sf-reviews h2 {
    font-family: var(--it-font-display);
    font-size: 1.65rem;
    font-weight: 500;
    margin: 0 0 18px;
}

.sf-italicum-spec-grid,
.sf-italicum-attribute-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    margin-top: 8px;
}

.sf-italicum-spec-grid div,
.sf-italicum-attribute-list div {
    display: grid;
    gap: 4px;
    padding: 14px 16px;
    border: 1px solid var(--it-line-soft);
    border-radius: var(--it-radius-sm);
    background: var(--it-surface-warm);
}

.sf-italicum-spec-grid span,
.sf-italicum-attribute-list span {
    color: var(--it-soft);
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.sf-italicum-spec-grid strong,
.sf-italicum-attribute-list strong {
    color: var(--it-ink);
    font-family: var(--it-font-body);
    font-size: 0.96rem;
    font-weight: 700;
}

/* Reviews */
.sf-reviews__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 20px;
    flex-wrap: wrap;
}

.sf-reviews__avg {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: var(--it-muted);
}

.sf-reviews__avg strong {
    color: var(--it-ink);
    font-family: var(--it-font-display);
    font-size: 1.65rem;
}

.sf-reviews__stars { color: var(--it-gold); letter-spacing: 2px; }
.sf-reviews__stars .on { color: var(--it-gold); }
.sf-reviews__stars :not(.on) { color: var(--it-line); }

.sf-reviews__list {
    display: grid;
    gap: 14px;
    list-style: none;
    padding: 0;
    margin: 0;
}

.sf-review {
    padding: 18px;
    border: 1px solid var(--it-line-soft);
    border-radius: var(--it-radius);
    background: var(--it-surface-warm);
}

.sf-review__head {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    margin-bottom: 8px;
}

.sf-review-form,
.sf-review-cta {
    margin-top: 24px;
    padding: 22px;
    border: 1px dashed var(--it-line);
    border-radius: var(--it-radius);
    background: var(--it-surface-warm);
    display: grid;
    gap: 12px;
}

.sf-review-form h3 {
    font-family: var(--it-font-display);
    font-size: 1.3rem;
    font-weight: 500;
    margin: 0;
}

.sf-review-form__field {
    display: grid;
    gap: 6px;
}

.sf-review-form__field textarea {
    min-height: 110px;
    padding: 12px;
    border: 1px solid var(--it-line);
    border-radius: var(--it-radius-sm);
    background: var(--it-surface);
    color: var(--it-ink);
    font: inherit;
    line-height: 1.5;
}

.sf-review-form__field textarea:focus {
    outline: none;
    border-color: var(--it-brand);
    box-shadow: 0 0 0 3px rgba(196, 65, 50, 0.12);
}

.sf-review-form__rating {
    display: inline-flex;
    flex-direction: row-reverse;
    justify-content: flex-end;
    gap: 4px;
    border: 0;
    margin: 0;
    padding: 0;
}

.sf-review-form__rating input { position: absolute; opacity: 0; }
.sf-review-form__rating label {
    color: var(--it-line);
    font-size: 1.4rem;
    cursor: pointer;
}

.sf-review-form__rating input:checked ~ label,
.sf-review-form__rating label:hover,
.sf-review-form__rating label:hover ~ label {
    color: var(--it-gold);
}

/* -------------------------------------------------------------
   17. Cart / Form fields (inherits from core, lift styling)
   ------------------------------------------------------------- */
.sf-field input,
.sf-field select,
.sf-field textarea,
.sf-checkout input,
.sf-checkout select,
.sf-checkout textarea {
    min-height: 44px;
    padding: 0 14px;
    border: 1px solid var(--it-line);
    border-radius: var(--it-radius-sm);
    background: var(--it-surface);
    color: var(--it-ink);
    font: inherit;
    font-size: 0.94rem;
}

.sf-field input:focus,
.sf-field select:focus,
.sf-field textarea:focus,
.sf-checkout input:focus,
.sf-checkout select:focus,
.sf-checkout textarea:focus {
    outline: none;
    border-color: var(--it-brand);
    box-shadow: 0 0 0 3px rgba(196, 65, 50, 0.12);
}

.sf-checkout textarea,
.sf-field textarea { min-height: 100px; padding: 12px 14px; }

.sf-payment-option,
.sf-checkbox {
    border-radius: var(--it-radius-sm) !important;
    border: 1px solid var(--it-line) !important;
    background: var(--it-surface) !important;
    padding: 14px !important;
    transition: border-color 0.18s var(--it-ease), background 0.18s var(--it-ease), box-shadow 0.18s var(--it-ease);
}

.sf-payment-option:hover,
.sf-payment-option:has(input:checked) {
    border-color: var(--it-brand) !important;
    background: var(--it-brand-tint) !important;
    box-shadow: 0 0 0 3px rgba(196, 65, 50, 0.08);
}

.sf-cart__grid {
    grid-template-columns: minmax(0, 1fr) minmax(320px, 0.36fr) !important;
    gap: 28px !important;
}

.sf-cart-table,
.sf-orders-table {
    border-radius: var(--it-radius) !important;
    overflow: hidden;
}

.sf-cart__summary,
.sf-form--card,
.sf-account-card,
.sf-order-confirmation__head,
.sf-order-confirmation__body {
    border-radius: var(--it-radius-lg) !important;
    border: 1px solid var(--it-line) !important;
    background: var(--it-surface);
    box-shadow: none !important;
}

.sf-toast { background: var(--it-ink) !important; color: #ffffff !important; }

.sf-minicart__panel {
    border-radius: var(--it-radius-lg) 0 0 var(--it-radius-lg);
}

.sf-minicart__head {
    background: var(--it-bg-warm);
}

/* -------------------------------------------------------------
   17b. Cart page (sf-cart)
   ------------------------------------------------------------- */
.sf-cart {
    display: grid;
    gap: 22px;
}

.sf-cart > header {
    margin: 0 !important;
}

.sf-cart > header h1 {
    font-family: var(--it-font-display);
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 500;
    line-height: 1.04;
}

.sf-cart > header p {
    margin: 8px 0 0 !important;
    color: var(--it-muted) !important;
    font-size: 0.98rem;
}

.sf-cart__list {
    display: grid;
    gap: 18px;
    padding: 8px;
    border: 1px solid var(--it-line);
    border-radius: var(--it-radius-lg);
    background: var(--it-surface);
}

.sf-cart-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0 6px;
}

.sf-cart-table thead {
    display: none;
}

.sf-cart-table tbody tr {
    display: grid;
    grid-template-columns: 96px minmax(0, 1fr) auto auto auto;
    align-items: center;
    gap: 16px;
    padding: 12px 14px;
    border: 1px solid var(--it-line-soft);
    border-radius: var(--it-radius);
    background: var(--it-surface);
    transition: border-color 0.2s var(--it-ease), background 0.2s var(--it-ease);
}

.sf-cart-table tbody tr:hover {
    border-color: var(--it-brand-soft);
    background: var(--it-surface-warm);
}

.sf-cart-table tbody tr.is-unavailable {
    background: #FCF6EE;
    border-style: dashed;
}

.sf-cart-table tbody td {
    padding: 0;
    border: 0;
    vertical-align: middle;
}

.sf-cart-table__thumb {
    width: 96px;
    height: 96px;
    grid-column: 1 / 2;
    grid-row: 1 / span 3;
}

.sf-cart-table__thumb a {
    display: grid;
    place-items: center;
    width: 96px;
    height: 96px;
    border-radius: var(--it-radius-sm);
    background: #ffffff;
    border: 1px solid var(--it-line);
    overflow: hidden;
}

.sf-cart-table__thumb img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    padding: 8px;
    box-sizing: border-box;
}

.sf-cart-table__no-img {
    color: var(--it-soft);
    font-family: var(--it-font-display);
    font-weight: 600;
}

.sf-cart-table__name {
    display: inline-block;
    color: var(--it-ink);
    font-family: var(--it-font-display);
    font-size: 1.18rem;
    font-weight: 500;
    line-height: 1.18;
    text-decoration: none;
    margin-bottom: 4px;
}

.sf-cart-table__name:hover {
    color: var(--it-brand-strong);
}

.sf-cart-table tbody tr td:nth-child(3) {
    color: var(--it-muted);
    font-size: 0.92rem;
    font-weight: 600;
}

.sf-cart-table__qty {
    width: 70px;
    min-height: 42px !important;
    padding: 0 10px !important;
    border: 1px solid var(--it-line) !important;
    border-radius: var(--it-radius-sm) !important;
    background: var(--it-surface) !important;
    color: var(--it-ink);
    font: inherit;
    font-size: 0.94rem;
    text-align: center;
}

.sf-cart-table__qty:focus {
    outline: none;
    border-color: var(--it-brand) !important;
    box-shadow: 0 0 0 3px rgba(196, 65, 50, 0.12);
}

.sf-cart-table tbody tr td:nth-child(5) {
    font-family: var(--it-font-display);
    font-weight: 600;
    font-size: 1.15rem;
    color: var(--it-ink);
    text-align: right;
    font-variant-numeric: tabular-nums;
    min-width: 90px;
}

.sf-cart-table tbody tr td:nth-child(6) .sf-btn {
    min-height: 36px;
    padding: 0 12px !important;
    background: transparent !important;
    border: 0 !important;
    color: var(--it-soft) !important;
    font-size: 0.78rem !important;
    font-weight: 600 !important;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    box-shadow: none !important;
}

.sf-cart-table tbody tr td:nth-child(6) .sf-btn:hover {
    color: var(--it-danger) !important;
    transform: none !important;
}

.sf-cart__actions {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
    padding: 4px 4px 8px;
}

/* Summary box */
.sf-cart__summary {
    position: sticky;
    top: 116px;
    align-self: start;
    display: flex;
    flex-direction: column;
    gap: 0;
    padding: 0 !important;
    border-radius: var(--it-radius-lg) !important;
    overflow: hidden;
}

.sf-cart__summary:not(.sf-checkout__aside) > *:not(.sf-cart__guest) {
    padding-left: clamp(18px, 2vw, 24px);
    padding-right: clamp(18px, 2vw, 24px);
}

.sf-cart__summary:not(.sf-checkout__aside) h2 {
    margin: 0;
    padding-top: 18px;
    padding-bottom: 14px;
    border-bottom: 1px solid var(--it-line-soft);
    font-family: var(--it-font-body);
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--it-ink);
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

.sf-cart__summary:not(.sf-checkout__aside) .sf-cart__coupon {
    padding-top: 16px !important;
    padding-bottom: 12px !important;
}

.sf-cart__summary:not(.sf-checkout__aside) > a.sf-btn-primary {
    margin: 16px clamp(18px, 2vw, 24px) 20px;
    width: calc(100% - clamp(36px, 4vw, 48px));
    padding-left: 22px !important;
    padding-right: 22px !important;
}

.sf-cart__summary:not(.sf-checkout__aside) .sf-cart__guest {
    margin: 0 clamp(18px, 2vw, 24px) 18px;
    padding-top: 16px;
    border-top: 1px dashed var(--it-line);
}

.sf-cart__summary:not(.sf-checkout__aside) .sf-checkout-summary__rows {
    padding-top: 4px !important;
    padding-bottom: 14px !important;
}

.sf-cart__coupon {
    margin: 0;
}

.sf-cart__coupon-row {
    display: flex;
    gap: 8px;
}

.sf-cart__coupon-row input[type="text"] {
    flex: 1;
    min-width: 0;
    min-height: 42px;
    padding: 0 12px;
    border: 1px solid var(--it-line);
    border-radius: var(--it-radius-sm);
    background: var(--it-surface);
    color: var(--it-ink);
    font: inherit;
    font-size: 0.9rem;
    text-transform: uppercase;
    letter-spacing: 0.02em;
}

.sf-cart__coupon-row input[type="text"]:focus {
    outline: none;
    border-color: var(--it-brand);
    box-shadow: 0 0 0 3px rgba(196, 65, 50, 0.12);
}

.sf-cart__coupon-row .sf-btn-ghost {
    min-height: 42px;
    padding: 0 14px !important;
    font-size: 0.82rem !important;
    flex: 0 0 auto;
}

.sf-cart__summary-tax {
    margin: 4px 0 14px;
    color: var(--it-soft);
    font-size: 0.78rem;
    text-align: right;
}

.sf-checkout-summary {
    list-style: none;
    margin: 0 0 8px;
    padding: 0;
    display: grid;
    gap: 0;
}

.sf-checkout-summary li {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    padding: 12px 0;
    border-bottom: 1px solid var(--it-line-soft);
    font-size: 0.92rem;
}

.sf-checkout-summary li:last-child {
    border-bottom: 0;
}

.sf-checkout-summary li strong {
    font-family: var(--it-font-display);
    font-weight: 500;
    font-size: 1rem;
    color: var(--it-ink);
}

.sf-checkout-summary__rows {
    padding-top: 6px !important;
    padding-bottom: 14px !important;
}

.sf-checkout-summary__row {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 12px;
    padding: 6px 0;
    color: var(--it-muted);
    font-size: 0.92rem;
}

.sf-checkout-summary__row span:last-child {
    color: var(--it-ink);
    font-weight: 700;
    font-variant-numeric: tabular-nums;
}

.sf-checkout-summary__row--discount span:last-child {
    color: var(--it-success);
}

.sf-checkout-summary__row--discount small {
    color: var(--it-soft);
    margin-left: 4px;
    font-weight: 500;
}

.sf-checkout-summary__row--total {
    align-items: center;
    margin-top: 10px;
    padding-top: 14px;
    border-top: 1px solid var(--it-line);
    color: var(--it-ink);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: 0.74rem;
}

.sf-checkout-summary__row--total strong {
    font-family: var(--it-font-body);
    font-size: 1.55rem;
    font-weight: 800;
    color: var(--it-brand-strong);
    text-transform: none;
    letter-spacing: 0;
    line-height: 1;
    font-variant-numeric: tabular-nums;
}

.sf-cart__summary-tax {
    margin: 8px 0 0;
    padding-top: 8px;
    color: var(--it-soft);
    font-size: 0.78rem;
    text-align: right;
}

.sf-cart__guest {
    margin-top: 14px;
    padding-top: 16px;
    border-top: 1px dashed var(--it-line);
    display: grid;
    gap: 10px;
    text-align: center;
}

.sf-cart__guest p {
    margin: 0;
    color: var(--it-muted);
    font-size: 0.86rem;
}

/* Alerts */
.sf-alert {
    padding: 14px 18px;
    border-radius: var(--it-radius-sm);
    font-size: 0.92rem;
    font-weight: 500;
}

.sf-alert--success {
    background: var(--it-success-soft);
    color: var(--it-success);
    border: 1px solid rgba(42, 124, 78, 0.18);
}

.sf-alert--error {
    background: #FCE7E3;
    color: var(--it-danger);
    border: 1px solid rgba(184, 42, 30, 0.18);
}

/* -------------------------------------------------------------
   17c. Checkout v2 — sf-co-* (new clean checkout)
   ------------------------------------------------------------- */
.sf-co {
    --co-radius: 14px;
    --co-radius-sm: 10px;
    --co-border: var(--it-line);
    --co-border-soft: var(--it-line-soft);
    --co-surface: #ffffff;
    --co-ink: var(--it-ink);
    --co-muted: var(--it-muted);
    --co-soft: var(--it-soft);
    --co-brand: var(--it-brand);
    --co-brand-strong: var(--it-brand-strong);
    --co-brand-tint: var(--it-brand-tint);
    --co-success: var(--it-success);
    --co-success-soft: var(--it-success-soft);
    --co-bg-warm: var(--it-bg-warm);
    --co-surface-warm: var(--it-surface-warm);
    display: grid;
    gap: 16px;
    max-width: 1180px;
    margin: 0 auto;
}

.sf-co * { box-sizing: border-box; }

/* Back link */
.sf-co__back {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    width: fit-content;
    color: var(--co-muted);
    text-decoration: none;
    font-size: 0.82rem;
    font-weight: 600;
    padding: 4px 0;
}
.sf-co__back:hover { color: var(--co-brand-strong); }

/* Hero header */
.sf-co__hero {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: end;
    gap: 28px;
    padding: 4px 0 6px;
}

.sf-co__hero h1 {
    margin: 0;
    font-family: var(--it-font-display);
    font-size: clamp(1.8rem, 2.6vw, 2.4rem);
    font-weight: 500;
    line-height: 1;
    color: var(--co-ink);
}

.sf-co__hero p {
    margin: 8px 0 0;
    color: var(--co-muted);
    font-size: 0.92rem;
}

/* Progress steps */
.sf-co__progress {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: nowrap;
}

.sf-co__progress li {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 14px 6px 6px;
    border-radius: 999px;
    background: var(--co-bg-warm);
    color: var(--co-muted);
    font: 700 0.78rem/1 var(--it-font-body);
    letter-spacing: 0.02em;
    white-space: nowrap;
}

.sf-co__progress li + li::before {
    content: "";
    display: inline-block;
    width: 14px;
    height: 1px;
    background: var(--co-border);
    margin-right: -2px;
}

.sf-co__progress li span {
    width: 24px;
    height: 24px;
    display: inline-grid;
    place-items: center;
    border-radius: 999px;
    background: #ffffff;
    color: var(--co-muted);
    font-weight: 800;
    font-size: 0.78rem;
    border: 1px solid var(--co-border);
}

.sf-co__progress li.is-done {
    background: var(--co-success-soft);
    color: var(--co-success);
}
.sf-co__progress li.is-done span {
    background: var(--co-success);
    color: #ffffff;
    border-color: var(--co-success);
}

.sf-co__progress li.is-active {
    background: var(--co-brand);
    color: #ffffff;
}
.sf-co__progress li.is-active span {
    background: #ffffff;
    color: var(--co-brand-strong);
    border-color: transparent;
}

/* Alerts */
.sf-co__alert {
    padding: 12px 16px;
    border-radius: var(--co-radius-sm);
    font-size: 0.9rem;
    font-weight: 500;
}
.sf-co__alert--success { background: var(--co-success-soft); color: var(--co-success); }
.sf-co__alert--error { background: #FCE7E3; color: var(--it-danger); }

/* Grid layout */
.sf-co__grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 360px;
    gap: 18px;
    align-items: start;
}

.sf-co__form {
    display: grid;
    gap: 14px;
    min-width: 0;
}

/* Card */
.sf-co__card {
    display: grid;
    gap: 14px;
    padding: 22px 24px;
    border: 1px solid var(--co-border);
    border-radius: var(--co-radius);
    background: var(--co-surface);
}

.sf-co__card-head {
    display: grid;
    grid-template-columns: 32px minmax(0, 1fr);
    gap: 14px;
    align-items: center;
}

.sf-co__num {
    width: 32px;
    height: 32px;
    display: grid;
    place-items: center;
    border-radius: 999px;
    background: var(--co-ink);
    color: #ffffff;
    font: 700 0.86rem/1 var(--it-font-body);
}

.sf-co__card-head h2 {
    margin: 0 !important;
    font-family: var(--it-font-body) !important;
    font-size: 1.04rem !important;
    font-weight: 700 !important;
    color: var(--co-ink) !important;
    line-height: 1.2 !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    font-variant: normal !important;
    font-feature-settings: normal !important;
}

.sf-co__card-head p {
    margin: 3px 0 0 !important;
    color: var(--co-muted);
    font-size: 0.82rem;
}

.sf-co__card-head p a {
    color: var(--co-brand-strong);
    font-weight: 700;
    text-decoration: none;
}
.sf-co__card-head p a:hover { text-decoration: underline; }

/* Field */
.sf-co__field {
    display: grid;
    gap: 5px;
    min-width: 0;
}

.sf-co__field label {
    color: var(--co-muted);
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.sf-co__field label small {
    color: var(--co-soft);
    font-weight: 600;
    text-transform: none;
    letter-spacing: 0;
    margin-left: 4px;
    font-size: 0.7rem;
}

.sf-co__field input,
.sf-co__field textarea,
.sf-co__field select,
.sf-co__notes textarea {
    width: 100%;
    min-height: 44px;
    padding: 0 14px;
    border: 1px solid var(--co-border);
    border-radius: var(--co-radius-sm);
    background: var(--co-surface);
    color: var(--co-ink);
    font: inherit;
    font-size: 0.94rem;
    transition: border-color 0.16s var(--it-ease), box-shadow 0.16s var(--it-ease);
}

.sf-co__field textarea,
.sf-co__notes textarea {
    min-height: 84px;
    padding: 11px 14px;
    line-height: 1.5;
    resize: vertical;
}

.sf-co__field input:focus,
.sf-co__field textarea:focus,
.sf-co__field select:focus,
.sf-co__notes textarea:focus {
    outline: none;
    border-color: var(--co-brand);
    box-shadow: 0 0 0 3px rgba(196, 65, 50, 0.12);
}

.sf-co__row {
    display: grid;
    gap: 12px;
}

.sf-co__row--2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.sf-co__row--3 { grid-template-columns: 110px minmax(0, 1fr) 90px; }

.sf-co__field--2x { grid-column: span 1; }

/* Saved addresses */
.sf-co__addresses {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 8px;
}

.sf-co__addr {
    display: grid;
    grid-template-columns: 18px minmax(0, 1fr);
    align-items: flex-start;
    gap: 12px;
    padding: 12px 14px;
    border: 1px solid var(--co-border);
    border-radius: var(--co-radius-sm);
    background: var(--co-surface);
    cursor: pointer;
    transition: border-color 0.15s var(--it-ease), background 0.15s var(--it-ease);
}

.sf-co__addr:hover { border-color: var(--co-brand-tint); background: var(--co-surface-warm); }

.sf-co__addr input[type="radio"] {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.sf-co__addr-dot {
    margin-top: 2px;
    width: 16px;
    height: 16px;
    border-radius: 999px;
    border: 2px solid var(--co-border);
    background: #ffffff;
    flex-shrink: 0;
    transition: border-color 0.15s var(--it-ease), background 0.15s var(--it-ease), box-shadow 0.15s var(--it-ease);
}

.sf-co__addr:has(input:checked) {
    border-color: var(--co-brand);
    background: var(--co-brand-tint);
}

.sf-co__addr:has(input:checked) .sf-co__addr-dot {
    border-color: var(--co-brand);
    background: var(--co-brand);
    box-shadow: inset 0 0 0 3px #ffffff;
}

.sf-co__addr-body { display: grid; gap: 4px; min-width: 0; }

.sf-co__addr-label {
    display: flex;
    align-items: center;
    gap: 6px;
    color: var(--co-ink);
    font-size: 0.86rem;
    font-weight: 700;
}

.sf-co__addr-label em {
    padding: 2px 7px;
    border-radius: 999px;
    background: var(--it-gold-soft);
    color: var(--it-warn);
    font: 800 0.66rem/1 var(--it-font-body);
    letter-spacing: 0.06em;
    text-transform: uppercase;
    font-style: normal;
}

.sf-co__addr-detail {
    color: var(--co-muted);
    font-size: 0.82rem;
    line-height: 1.4;
}

.sf-co__addr-detail strong {
    display: block;
    color: var(--co-ink);
    font-size: 0.84rem;
    font-weight: 600;
    margin-bottom: 2px;
}

.sf-co__addr--new {
    border-style: dashed;
}

/* Checkbox */
.sf-co__checkbox {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 0 4px;
    color: var(--co-ink);
    font-size: 0.9rem;
    font-weight: 500;
    cursor: pointer;
}

.sf-co__checkbox input { position: absolute; opacity: 0; pointer-events: none; }

.sf-co__checkbox span {
    width: 20px;
    height: 20px;
    flex-shrink: 0;
    border: 1.5px solid var(--co-border);
    border-radius: 5px;
    background: #ffffff;
    display: inline-grid;
    place-items: center;
    transition: border-color 0.15s var(--it-ease), background 0.15s var(--it-ease);
}

.sf-co__checkbox input:checked + span {
    background: var(--co-brand);
    border-color: var(--co-brand);
}

.sf-co__checkbox input:checked + span::after {
    content: "";
    width: 10px;
    height: 6px;
    border-left: 2px solid #ffffff;
    border-bottom: 2px solid #ffffff;
    transform: rotate(-45deg) translate(1px, -1px);
}

/* Billing fields */
.sf-co__billing {
    display: grid;
    gap: 12px;
    padding: 18px;
    margin-top: 4px;
    border: 1px dashed var(--co-border);
    border-radius: var(--co-radius-sm);
    background: var(--co-surface-warm);
}

.sf-co__billing h3 {
    margin: 0 0 4px !important;
    font: 700 0.78rem/1 var(--it-font-body) !important;
    color: var(--co-muted) !important;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

/* Methods (shipping + payment) */
.sf-co__methods {
    display: grid;
    gap: 8px;
}

.sf-co__method {
    display: grid;
    grid-template-columns: 18px minmax(0, 1fr) auto;
    align-items: center;
    gap: 14px;
    padding: 14px 16px;
    border: 1px solid var(--co-border);
    border-radius: var(--co-radius-sm);
    background: var(--co-surface);
    cursor: pointer;
    transition: border-color 0.15s var(--it-ease), background 0.15s var(--it-ease);
}

.sf-co__method:hover { border-color: var(--co-brand-tint); background: var(--co-surface-warm); }

.sf-co__method input[type="radio"] { position: absolute; opacity: 0; pointer-events: none; }

.sf-co__method:has(input:checked) {
    border-color: var(--co-brand);
    background: var(--co-brand-tint);
}

.sf-co__method:has(input:checked) .sf-co__addr-dot {
    border-color: var(--co-brand);
    background: var(--co-brand);
    box-shadow: inset 0 0 0 3px #ffffff;
}

.sf-co__method-body { display: grid; gap: 2px; min-width: 0; }

.sf-co__method-body strong {
    font-family: var(--it-font-body);
    font-size: 0.94rem;
    font-weight: 700;
    color: var(--co-ink);
}

.sf-co__method-body small {
    color: var(--co-muted);
    font-size: 0.8rem;
    line-height: 1.4;
}

.sf-co__method-price {
    font: 700 0.94rem/1 var(--it-font-body);
    color: var(--co-ink);
    white-space: nowrap;
    font-variant-numeric: tabular-nums;
}

/* Discount collapsible */
.sf-co__discount {
    margin-top: 4px;
    border-top: 1px dashed var(--co-border);
    padding-top: 14px;
}

.sf-co__discount summary {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: var(--co-brand-strong);
    font-size: 0.86rem;
    font-weight: 700;
    cursor: pointer;
    list-style: none;
    user-select: none;
}

.sf-co__discount summary::-webkit-details-marker { display: none; }

.sf-co__discount summary::before {
    content: "+";
    display: inline-grid;
    place-items: center;
    width: 18px;
    height: 18px;
    border-radius: 999px;
    background: var(--co-brand-tint);
    color: var(--co-brand-strong);
    font-weight: 800;
    font-size: 0.84rem;
}

.sf-co__discount[open] summary::before { content: "−"; }

.sf-co__discount-row {
    display: flex;
    gap: 8px;
    margin-top: 10px;
}

.sf-co__discount-row input {
    flex: 1;
    min-width: 0;
    min-height: 42px;
    padding: 0 14px;
    border: 1px solid var(--co-border);
    border-radius: var(--co-radius-sm);
    background: var(--co-surface);
    font: inherit;
    font-size: 0.9rem;
    text-transform: uppercase;
    letter-spacing: 0.02em;
}

.sf-co__discount-row input:focus {
    outline: none;
    border-color: var(--co-brand);
    box-shadow: 0 0 0 3px rgba(196, 65, 50, 0.12);
}

.sf-co__btn-ghost {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0 18px;
    border: 1px solid var(--co-border);
    border-radius: 999px;
    background: var(--co-surface);
    color: var(--co-ink);
    font: 700 0.84rem/1 var(--it-font-body);
    cursor: pointer;
    transition: border-color 0.16s var(--it-ease), background 0.16s var(--it-ease);
    white-space: nowrap;
}

.sf-co__btn-ghost:hover {
    border-color: var(--co-ink);
    background: var(--co-bg-warm);
}

/* Notes */
.sf-co__notes {
    display: grid;
    gap: 5px;
    margin-top: 6px;
}

.sf-co__notes label {
    color: var(--co-muted);
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.sf-co__notes label small {
    color: var(--co-soft);
    font-weight: 600;
    text-transform: none;
    letter-spacing: 0;
    margin-left: 4px;
    font-size: 0.7rem;
}

/* Submit */
.sf-co__submit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    width: 100%;
    min-height: 56px;
    margin-top: 6px;
    padding: 0 22px;
    border: 0;
    border-radius: 999px;
    background: var(--co-brand);
    color: #ffffff;
    font: 800 1rem/1 var(--it-font-body);
    letter-spacing: 0.02em;
    cursor: pointer;
    box-shadow: 0 12px 28px rgba(196, 65, 50, 0.26);
    transition: background 0.18s var(--it-ease), transform 0.18s var(--it-ease), box-shadow 0.18s var(--it-ease);
}

.sf-co__submit:hover:not(:disabled) {
    background: var(--co-brand-strong);
    transform: translateY(-1px);
    box-shadow: 0 16px 36px rgba(196, 65, 50, 0.32);
}

.sf-co__submit:disabled {
    background: var(--co-border);
    color: var(--co-muted);
    cursor: not-allowed;
    box-shadow: none;
}

/* Trust */
.sf-co__trust {
    list-style: none;
    margin: 12px 0 0;
    padding: 14px 0 0;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 22px;
    flex-wrap: wrap;
    border-top: 1px solid var(--co-border-soft);
}

.sf-co__trust li {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: var(--co-muted);
    font-size: 0.78rem;
}

.sf-co__trust svg { color: var(--it-olive); flex-shrink: 0; }

/* Empty payment */
.sf-co__empty {
    margin: 0;
    padding: 16px;
    border: 1px dashed var(--co-border);
    border-radius: var(--co-radius-sm);
    background: var(--co-surface-warm);
    color: var(--co-muted);
    font-size: 0.88rem;
    text-align: center;
}

/* === Cart lines === */
.sf-co__lines-card { padding-bottom: 16px; }

.sf-co__lines {
    display: grid;
    gap: 10px;
    margin: 0;
}

.sf-co__line {
    display: grid;
    grid-template-columns: 84px minmax(0, 1fr) 92px 100px 36px;
    align-items: center;
    gap: 16px;
    padding: 14px;
    border: 1px solid var(--co-border-soft);
    border-radius: var(--co-radius-sm);
    background: var(--co-surface);
    transition: border-color 0.18s var(--it-ease), background 0.18s var(--it-ease);
}

.sf-co__line:hover {
    border-color: var(--co-brand-tint);
    background: var(--co-surface-warm);
}

.sf-co__line.is-unavailable {
    background: var(--co-surface-warm);
    border-style: dashed;
    opacity: 0.78;
}

.sf-co__line-thumb {
    display: grid;
    place-items: center;
    width: 84px;
    height: 84px;
    background: #ffffff;
    border: 1px solid var(--co-border);
    border-radius: var(--co-radius-sm);
    overflow: hidden;
}

.sf-co__line-thumb img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    padding: 6px;
    box-sizing: border-box;
}

.sf-co__line-info {
    display: grid;
    gap: 3px;
    min-width: 0;
}

.sf-co__line-name {
    color: var(--co-ink);
    font: 600 0.98rem/1.25 var(--it-font-body);
    text-decoration: none;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.sf-co__line-name:hover { color: var(--co-brand-strong); }

.sf-co__line-meta,
.sf-co__line-options {
    color: var(--co-soft);
    font-size: 0.78rem;
    font-variant-numeric: tabular-nums;
}

.sf-co__line-options {
    color: var(--co-muted);
}

.sf-co__line-warn {
    margin-top: 2px;
    display: inline-flex;
    width: fit-content;
    padding: 2px 8px;
    border-radius: 999px;
    background: #FCE7E3;
    color: var(--it-danger);
    font: 700 0.7rem/1.4 var(--it-font-body);
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.sf-co__line-qty input {
    width: 72px;
    min-height: 42px;
    padding: 0 10px;
    border: 1px solid var(--co-border);
    border-radius: var(--co-radius-sm);
    background: var(--co-surface);
    color: var(--co-ink);
    font: inherit;
    font-size: 0.94rem;
    text-align: center;
    -moz-appearance: textfield;
}

.sf-co__line-qty input::-webkit-inner-spin-button,
.sf-co__line-qty input::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.sf-co__line-qty input:focus {
    outline: none;
    border-color: var(--co-brand);
    box-shadow: 0 0 0 3px rgba(196, 65, 50, 0.12);
}

.sf-co__line-total {
    font: 700 1.05rem/1 var(--it-font-body);
    color: var(--co-ink);
    text-align: right;
    font-variant-numeric: tabular-nums;
}

.sf-co__line-remove {
    width: 36px;
    height: 36px;
    display: grid;
    place-items: center;
    border: 0;
    border-radius: 999px;
    background: transparent;
    color: var(--co-soft);
    cursor: pointer;
    transition: background 0.16s var(--it-ease), color 0.16s var(--it-ease);
}

.sf-co__line-remove:hover {
    background: #FCE7E3;
    color: var(--it-danger);
}

.sf-co__lines-actions {
    display: flex;
    justify-content: space-between;
    gap: 10px;
    flex-wrap: wrap;
    padding-top: 4px;
}

.sf-co__lines-actions .sf-co__btn-ghost {
    min-height: 40px;
    padding: 0 16px !important;
    font-size: 0.82rem !important;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

/* === Coupon in cart aside === */
.sf-co__aside-coupon {
    display: flex;
    gap: 8px;
    margin: 0;
    padding: 12px 20px;
    border-bottom: 1px solid var(--co-border-soft);
}

.sf-co__aside-coupon input {
    flex: 1;
    min-width: 0;
    min-height: 42px;
    padding: 0 12px;
    border: 1px solid var(--co-border);
    border-radius: var(--co-radius-sm);
    background: var(--co-surface);
    color: var(--co-ink);
    font: inherit;
    font-size: 0.88rem;
    text-transform: uppercase;
    letter-spacing: 0.02em;
}

.sf-co__aside-coupon input:focus {
    outline: none;
    border-color: var(--co-brand);
    box-shadow: 0 0 0 3px rgba(196, 65, 50, 0.12);
}

.sf-co__aside-coupon .sf-co__btn-ghost {
    min-height: 42px;
    padding: 0 14px !important;
    font-size: 0.8rem !important;
    flex: 0 0 auto;
}

/* CTA inside aside */
.sf-co__aside-cta {
    padding: 14px 20px 16px;
    display: grid;
    gap: 10px;
    border-top: 1px solid var(--co-border-soft);
}

.sf-co__aside-cta .sf-co__submit {
    margin: 0;
}

.sf-co__guest-hint {
    margin: 0;
    color: var(--co-muted);
    font-size: 0.82rem;
    text-align: center;
}

.sf-co__guest-hint a {
    color: var(--co-brand-strong);
    font-weight: 700;
    text-decoration: none;
}

.sf-co__guest-hint a:hover { text-decoration: underline; }

/* Trust strip in aside */
.sf-co__trust--aside {
    border-top: 1px solid var(--co-border-soft);
    margin: 0;
    padding: 12px 20px 16px;
    flex-direction: column;
    align-items: flex-start;
    gap: 7px;
    background: var(--co-surface-warm);
}

/* Empty state */
.sf-co__empty-state {
    display: grid;
    place-items: center;
    gap: 12px;
    padding: 64px 28px;
    border: 1px dashed var(--co-border);
    border-radius: var(--co-radius);
    background: var(--co-surface);
    text-align: center;
}

.sf-co__empty-state svg {
    color: var(--co-soft);
    margin-bottom: 4px;
}

.sf-co__empty-state h2 {
    margin: 0 !important;
    font-family: var(--it-font-display) !important;
    font-size: 1.6rem !important;
    font-weight: 500 !important;
    color: var(--co-ink) !important;
    line-height: 1 !important;
    font-variant: normal !important;
    font-feature-settings: normal !important;
}

.sf-co__empty-state p {
    margin: 0;
    color: var(--co-muted);
    max-width: 360px;
}

@media (max-width: 760px) {
    .sf-co__line {
        grid-template-columns: 72px minmax(0, 1fr) auto;
        grid-template-areas:
            "thumb info info"
            "thumb qty  total"
            "thumb rm   rm";
        gap: 10px;
    }
    .sf-co__line-thumb { grid-area: thumb; width: 72px; height: 72px; }
    .sf-co__line-info { grid-area: info; }
    .sf-co__line-qty { grid-area: qty; }
    .sf-co__line-total { grid-area: total; }
    .sf-co__line-remove { grid-area: rm; justify-self: end; }
}

.sr-only {
    position: absolute !important;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0,0,0,0);
    white-space: nowrap;
    border: 0;
}

/* Aside summary */
.sf-co__aside {
    position: sticky;
    top: 110px;
    min-width: 0;
}

.sf-co__aside-inner {
    border: 1px solid var(--co-border);
    border-radius: var(--co-radius);
    background: var(--co-surface);
    overflow: hidden;
}

.sf-co__aside-inner h2 {
    margin: 0 !important;
    padding: 16px 20px 14px !important;
    font-family: var(--it-font-body) !important;
    font-size: 0.78rem !important;
    font-weight: 700 !important;
    color: var(--co-ink) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.1em !important;
    line-height: 1 !important;
    font-variant: normal !important;
    font-feature-settings: normal !important;
    border-bottom: 1px solid var(--co-border-soft);
    background: var(--co-surface-warm);
}

.sf-co__items {
    list-style: none;
    margin: 0;
    padding: 6px 20px;
    display: grid;
    gap: 0;
}

.sf-co__items li {
    display: grid;
    grid-template-columns: 48px minmax(0, 1fr) auto;
    align-items: center;
    gap: 12px;
    padding: 10px 0;
    border-bottom: 1px solid var(--co-border-soft);
    font-size: 0.88rem;
}

.sf-co__items li:last-child { border-bottom: 0; }

.sf-co__item-thumb {
    position: relative;
    width: 48px;
    height: 48px;
    display: grid;
    place-items: center;
    background: #ffffff;
    border: 1px solid var(--co-border);
    border-radius: var(--co-radius-sm);
    overflow: hidden;
}

.sf-co__item-thumb img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    padding: 3px;
    box-sizing: border-box;
}

.sf-co__item-thumb em {
    position: absolute;
    top: -6px;
    right: -6px;
    min-width: 20px;
    height: 20px;
    display: inline-grid;
    place-items: center;
    padding: 0 5px;
    border-radius: 999px;
    background: var(--co-ink);
    color: #ffffff;
    font: 800 0.68rem/1 var(--it-font-body);
    font-style: normal;
    border: 2px solid #ffffff;
    box-sizing: border-box;
}

.sf-co__item-info {
    display: grid;
    gap: 2px;
    min-width: 0;
}

.sf-co__item-info strong {
    font: 600 0.9rem/1.25 var(--it-font-body);
    color: var(--co-ink);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.sf-co__item-info small {
    color: var(--co-soft);
    font-size: 0.78rem;
}

.sf-co__item-price {
    font: 700 0.92rem/1 var(--it-font-body);
    color: var(--co-ink);
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
}

/* Totals */
.sf-co__totals {
    padding: 10px 20px 16px;
    border-top: 1px solid var(--co-border-soft);
    display: grid;
    gap: 0;
}

.sf-co__totals > div {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 12px;
    padding: 6px 0;
    color: var(--co-muted);
    font-size: 0.9rem;
}

.sf-co__totals > div span:last-child {
    color: var(--co-ink);
    font-weight: 700;
    font-variant-numeric: tabular-nums;
}

.sf-co__totals .is-discount span:last-child { color: var(--co-success); }

.sf-co__totals .is-discount em {
    color: var(--co-soft);
    font-style: normal;
    margin-left: 4px;
    font-weight: 500;
}

.sf-co__totals .is-total {
    align-items: center;
    margin-top: 8px;
    padding-top: 14px;
    border-top: 1px solid var(--co-border);
    color: var(--co-ink);
    font: 700 0.74rem/1 var(--it-font-body);
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.sf-co__totals .is-total strong {
    font: 800 1.55rem/1 var(--it-font-body);
    color: var(--co-brand-strong);
    text-transform: none;
    letter-spacing: 0;
    font-variant-numeric: tabular-nums;
}

.sf-co__totals p {
    margin: 6px 0 0;
    color: var(--co-soft);
    font-size: 0.76rem;
    text-align: right;
}

/* Responsive */
@media (max-width: 980px) {
    .sf-co__grid { grid-template-columns: 1fr; }
    .sf-co__aside { position: static; }
    .sf-co__hero { grid-template-columns: 1fr; align-items: start; }
    .sf-co__progress { overflow-x: auto; padding: 0 2px 4px; scrollbar-width: none; }
    .sf-co__progress::-webkit-scrollbar { display: none; }
    .sf-co__row--3 { grid-template-columns: 1fr; }
    .sf-co__row--2 { grid-template-columns: 1fr; }
}

/* === Legacy .sf-checkout still used by base layout — minimal reset === */
.sf-checkout {
    max-width: none !important;
}

.sf-checkout__header {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 24px;
    padding: 4px 4px 6px !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
}

.sf-checkout__header h1 {
    margin: 0;
    font-family: var(--it-font-display);
    font-size: clamp(1.7rem, 2.6vw, 2.2rem);
    font-weight: 500;
    line-height: 1.02;
}

.sf-checkout__header p {
    margin: 6px 0 0 !important;
    color: var(--it-muted);
    font-size: 0.9rem;
}

.sf-checkout__steps {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    flex-wrap: nowrap;
}

.sf-checkout__step {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 5px 12px 5px 5px;
    border-radius: 999px;
    background: var(--it-bg-warm);
    color: var(--it-muted);
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    white-space: nowrap;
}

.sf-checkout__step b {
    width: 22px;
    height: 22px;
    display: grid;
    place-items: center;
    border-radius: 999px;
    background: var(--it-surface);
    color: var(--it-muted);
    font: 700 0.72rem/1 var(--it-font-body);
}

.sf-checkout__step.is-active { background: var(--it-brand); color: #ffffff; }
.sf-checkout__step.is-active b { background: #ffffff; color: var(--it-brand-strong); }

.sf-checkout__step.is-done { background: var(--it-success-soft); color: var(--it-success); }
.sf-checkout__step.is-done b { background: #ffffff; color: var(--it-success); }

.sf-checkout__step-sep {
    width: 18px;
    height: 1px;
    background: var(--it-line);
}

.sf-checkout .sf-cart__grid {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 360px !important;
    gap: 16px !important;
    align-items: start;
}

.sf-checkout .sf-form--card {
    display: grid;
    padding: 0 !important;
    border-radius: var(--it-radius-lg) !important;
    background: var(--it-surface);
    border: 1px solid var(--it-line) !important;
    overflow: hidden;
}

.sf-fieldset {
    display: grid;
    gap: 12px;
    margin: 0;
    padding: 20px 24px !important;
    border: 0 !important;
    border-bottom: 1px solid var(--it-line-soft) !important;
}

.sf-fieldset:last-of-type { border-bottom: 0 !important; }

.sf-fieldset legend {
    margin: 0 0 4px;
    padding: 0;
    color: var(--it-ink);
    font-family: var(--it-font-body);
    font-size: 0.8rem;
    font-weight: 700;
    line-height: 1.1;
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

.sf-fieldset--inline {
    padding: 18px 28px !important;
}

.sf-fieldset--inline legend {
    font-family: var(--it-font-body);
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--it-muted);
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.sf-checkout__guest-hint {
    margin: 0;
    color: var(--it-muted);
    font-size: 0.84rem;
}

.sf-checkout__guest-hint a {
    color: var(--it-brand-strong);
    font-weight: 700;
    text-decoration: none;
}

.sf-checkout__guest-hint a:hover { text-decoration: underline; }

.sf-checkout__billing {
    display: grid;
    gap: 14px;
    margin-top: 6px;
}

/* Coupon row inline */
.sf-checkout__coupon {
    display: flex;
    gap: 8px;
}

.sf-checkout__coupon input {
    flex: 1;
    min-width: 0;
    min-height: 44px !important;
    padding: 0 14px !important;
    border: 1px solid var(--it-line) !important;
    border-radius: var(--it-radius-sm) !important;
    background: var(--it-surface) !important;
    color: var(--it-ink);
    font: inherit;
    font-size: 0.92rem;
    text-transform: uppercase;
    letter-spacing: 0.02em;
}

.sf-checkout__coupon input:focus {
    outline: none;
    border-color: var(--it-brand) !important;
    box-shadow: 0 0 0 3px rgba(196, 65, 50, 0.12);
}

.sf-checkout__coupon .sf-btn-ghost {
    min-height: 44px;
    padding: 0 16px !important;
    font-size: 0.84rem !important;
    flex: 0 0 auto;
}

/* Notes textarea */
.sf-checkout__notes {
    width: 100%;
    min-height: 90px;
    padding: 12px 14px !important;
    border: 1px solid var(--it-line) !important;
    border-radius: var(--it-radius-sm) !important;
    background: var(--it-surface) !important;
    color: var(--it-ink);
    font: inherit;
    font-size: 0.92rem;
    line-height: 1.5;
    resize: vertical;
    box-sizing: border-box;
}

.sf-checkout__notes:focus {
    outline: none;
    border-color: var(--it-brand) !important;
    box-shadow: 0 0 0 3px rgba(196, 65, 50, 0.12);
}

/* Method list (shipping + payment) */
.sf-method-list {
    display: grid;
    gap: 8px;
}

.sf-payment-option {
    display: grid !important;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 14px;
    padding: 14px 16px !important;
    border-radius: var(--it-radius-sm) !important;
    border: 1px solid var(--it-line) !important;
    background: var(--it-surface) !important;
    cursor: pointer;
}

.sf-payment-option:hover { border-color: var(--it-brand-soft) !important; background: var(--it-surface-warm) !important; }

.sf-payment-option:has(input:checked) {
    border-color: var(--it-brand) !important;
    background: var(--it-brand-tint) !important;
    box-shadow: 0 0 0 3px rgba(196, 65, 50, 0.08);
}

.sf-payment-option input[type="radio"] {
    width: 18px;
    height: 18px;
    accent-color: var(--it-brand);
    margin: 0;
}

.sf-payment-option > div {
    display: grid;
    gap: 2px;
}

.sf-payment-option strong {
    font-family: var(--it-font-body);
    font-size: 0.96rem;
    font-weight: 700;
    color: var(--it-ink);
}

.sf-payment-option .sf-soft {
    color: var(--it-muted);
    font-size: 0.82rem;
    line-height: 1.4;
}

.sf-payment-option__price {
    font-family: var(--it-font-body);
    font-size: 0.96rem;
    font-weight: 700;
    color: var(--it-ink);
    white-space: nowrap;
}

/* CTA finale */
.sf-checkout > div > form > button[type="submit"]:last-child,
.sf-checkout .sf-btn-primary.sf-btn--full {
    margin: 18px 24px 22px;
    width: calc(100% - 48px);
    min-height: 52px;
    font-size: 0.95rem !important;
}

/* Sidebar summary */
.sf-checkout__aside {
    padding: 0 !important;
    overflow: hidden;
    gap: 0 !important;
}

.sf-checkout__aside h2 {
    margin: 0 !important;
    padding: 16px 22px 12px !important;
    font-family: var(--it-font-body) !important;
    font-size: 0.78rem !important;
    font-weight: 700 !important;
    line-height: 1 !important;
    color: var(--it-ink) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.1em !important;
    font-variant: normal !important;
    font-feature-settings: normal !important;
    border-bottom: 1px solid var(--it-line-soft) !important;
}

.sf-checkout-summary {
    list-style: none;
    margin: 0;
    padding: 4px 22px;
    display: grid;
    gap: 0;
}

.sf-checkout-summary li {
    display: grid;
    grid-template-columns: 48px minmax(0, 1fr) auto;
    align-items: center;
    gap: 12px;
    padding: 10px 0;
    border-bottom: 1px solid var(--it-line-soft);
    font-size: 0.9rem;
    border-radius: 0;
}

.sf-checkout-summary li:last-child { border-bottom: 0; }

.sf-checkout-summary__thumb {
    position: relative;
    width: 48px;
    height: 48px;
    border-radius: var(--it-radius-sm);
    background: #ffffff;
    border: 1px solid var(--it-line);
    display: grid;
    place-items: center;
    overflow: hidden;
}

.sf-checkout-summary__thumb img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    padding: 3px;
    box-sizing: border-box;
}

.sf-checkout-summary__thumb em {
    position: absolute;
    top: -6px;
    right: -6px;
    min-width: 20px;
    height: 20px;
    display: grid;
    place-items: center;
    padding: 0 5px;
    border-radius: 999px;
    background: var(--it-ink);
    color: #ffffff;
    font-style: normal;
    font-family: var(--it-font-body);
    font-size: 0.7rem;
    font-weight: 800;
    border: 2px solid var(--it-surface);
    line-height: 1;
    box-sizing: content-box;
}

.sf-checkout-summary__info {
    display: grid;
    gap: 2px;
    min-width: 0;
}

.sf-checkout-summary__info strong {
    font-family: var(--it-font-body);
    font-weight: 600;
    font-size: 0.92rem;
    color: var(--it-ink);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    line-height: 1.25;
}

.sf-checkout-summary__info small {
    color: var(--it-soft);
    font-size: 0.78rem;
}

.sf-checkout-summary__price {
    font-family: var(--it-font-body);
    font-weight: 700;
    color: var(--it-ink);
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
}

.sf-checkout__aside .sf-checkout-summary__rows {
    padding: 10px 22px 14px !important;
    border-top: 1px solid var(--it-line-soft);
}

.sf-checkout__aside .sf-cart__summary-tax {
    margin: 6px 0 0;
}

.sf-checkout__trust {
    list-style: none;
    margin: 0;
    padding: 12px 22px 18px;
    display: grid;
    gap: 7px;
    border-top: 1px solid var(--it-line-soft);
    background: var(--it-surface-warm);
}

.sf-checkout__trust li {
    display: flex;
    align-items: center;
    gap: 10px;
    color: var(--it-muted);
    font-size: 0.84rem;
}

.sf-checkout__trust svg {
    flex: 0 0 auto;
    color: var(--it-olive);
}

.sf-back-link {
    color: var(--it-muted);
    text-decoration: none;
    font-size: 0.82rem;
    font-weight: 600;
    padding: 4px 0;
    transition: color 0.16s var(--it-ease);
}

.sf-back-link:hover {
    color: var(--it-brand-strong);
}

.sf-checkout__aside {
    position: sticky;
    top: 110px;
}

.sf-form__row {
    display: grid;
    gap: 14px;
}

.sf-form__row--2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.sf-form__row--3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.sf-field {
    display: grid;
    gap: 6px;
    margin: 0;
}

.sf-field__label {
    color: var(--it-muted);
    font-size: 0.74rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

/* Saved address picker */
.sf-saved-addresses {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 10px;
    margin-bottom: 6px;
}

.sf-saved-address {
    position: relative;
    padding: 14px 16px;
    border: 1px solid var(--it-line);
    border-radius: var(--it-radius);
    background: var(--it-surface);
    cursor: pointer;
    transition: border-color 0.18s var(--it-ease), background 0.18s var(--it-ease), box-shadow 0.18s var(--it-ease);
}

.sf-saved-address:hover {
    border-color: var(--it-brand-soft);
    background: var(--it-surface-warm);
}

.sf-saved-address input[type="radio"] {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.sf-saved-address:has(input:checked) {
    border-color: var(--it-brand) !important;
    background: var(--it-brand-tint) !important;
    box-shadow: 0 0 0 3px rgba(196, 65, 50, 0.1);
}

.sf-saved-address__top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    margin-bottom: 6px;
}

.sf-saved-address__label {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: var(--it-ink);
    font-size: 0.84rem;
    font-weight: 700;
}

.sf-saved-address__label::before {
    content: "";
    width: 14px;
    height: 14px;
    border-radius: 999px;
    border: 2px solid var(--it-line);
    background: #ffffff;
    transition: border-color 0.16s var(--it-ease), background 0.16s var(--it-ease);
}

.sf-saved-address:has(input:checked) .sf-saved-address__label::before {
    border-color: var(--it-brand);
    background: var(--it-brand);
    box-shadow: inset 0 0 0 3px #ffffff;
}

.sf-saved-address__badge {
    padding: 2px 8px;
    border-radius: 999px;
    background: var(--it-gold-soft);
    color: var(--it-warn);
    font-size: 0.68rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.sf-saved-address__body {
    color: var(--it-muted);
    font-size: 0.84rem;
    line-height: 1.5;
}

.sf-saved-address__body strong {
    display: block;
    color: var(--it-ink);
    font-family: var(--it-font-body);
    font-size: 0.92rem;
    font-weight: 700;
    margin-bottom: 2px;
}

.sf-checkbox {
    display: flex !important;
    align-items: center !important;
    gap: 10px;
}

.sf-checkbox input { accent-color: var(--it-brand); width: 18px; height: 18px; }

.sf-checkout .is-disabled,
.sf-checkout .sf-btn[disabled] {
    background: var(--it-line) !important;
    border-color: var(--it-line) !important;
    color: var(--it-muted) !important;
    cursor: not-allowed;
    box-shadow: none !important;
}

@media (max-width: 980px) {
    .sf-cart__grid,
    .sf-checkout .sf-cart__grid {
        grid-template-columns: 1fr !important;
    }

    .sf-cart-table tbody tr {
        grid-template-columns: 76px minmax(0, 1fr);
        grid-template-areas:
            "thumb name"
            "thumb meta"
            "qty   total"
            "rm    rm";
    }

    .sf-cart-table__thumb { grid-area: thumb; width: 76px; height: 76px; }
    .sf-cart-table__thumb a { width: 76px; height: 76px; }
    .sf-cart-table tbody tr td:nth-child(2) { grid-area: name; }
    .sf-cart-table tbody tr td:nth-child(3) { grid-area: meta; }
    .sf-cart-table tbody tr td:nth-child(4) { grid-area: qty; }
    .sf-cart-table tbody tr td:nth-child(5) { grid-area: total; text-align: right; }
    .sf-cart-table tbody tr td:nth-child(6) { grid-area: rm; }

    .sf-cart__summary,
    .sf-checkout .sf-cart__summary {
        position: static;
    }
}

/* -------------------------------------------------------------
   17d. Related products slider
   ------------------------------------------------------------- */
.sf-italicum-related {
    margin-top: 80px !important;
}

.sf-italicum-related__head {
    display: flex !important;
    align-items: flex-end !important;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 22px !important;
    flex-wrap: wrap;
}

.sf-italicum-related__nav {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 5px;
    border: 1px solid var(--it-line);
    border-radius: 999px;
    background: var(--it-surface);
}

.sf-italicum-related__arrow {
    width: 38px;
    height: 38px;
    display: inline-grid;
    place-items: center;
    border: 0;
    border-radius: 999px;
    background: transparent;
    color: var(--it-ink);
    cursor: pointer;
    transition: background 0.18s var(--it-ease), color 0.18s var(--it-ease);
}

.sf-italicum-related__arrow:hover:not(:disabled) {
    background: var(--it-brand);
    color: #ffffff;
}

.sf-italicum-related__arrow:disabled {
    color: var(--it-line);
    cursor: default;
}

.sf-italicum-related__viewport {
    position: relative;
    margin: 0 calc(-1 * var(--it-shell-pad, 0px));
    padding: 0 var(--it-shell-pad, 0px);
    overflow: hidden;
}

.sf-italicum-related__track {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: minmax(0, calc((100% - 60px) / 4));
    gap: 20px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    scrollbar-width: none;
    padding-bottom: 8px;
}

.sf-italicum-related__track::-webkit-scrollbar { display: none; }

.sf-italicum-related__slide {
    scroll-snap-align: start;
    min-width: 0;
    display: grid;
}

.sf-italicum-related__slide > .sf-italicum-product,
.sf-italicum-related__slide > .sf-card-wrap,
.sf-italicum-related__slide > .sf-card {
    height: 100%;
    width: 100%;
}

@media (max-width: 1180px) {
    .sf-italicum-related__track {
        grid-auto-columns: minmax(0, calc((100% - 40px) / 3));
    }
}

@media (max-width: 820px) {
    .sf-italicum-related__track {
        grid-auto-columns: minmax(0, calc((100% - 20px) / 2));
    }
}

@media (max-width: 520px) {
    .sf-italicum-related__track {
        grid-auto-columns: 80%;
    }
    .sf-italicum-related__nav { display: none; }
}

/* -------------------------------------------------------------
   18. Footer
   ------------------------------------------------------------- */
.sf-footer,
.sf-italicum-footer {
    margin-top: 96px;
    padding: 56px 0 32px !important;
    background: var(--it-bg-deep) !important;
    color: #E6DFD3 !important;
}

.sf-italicum-footer__cta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 28px;
    margin-bottom: 56px;
    padding: 36px clamp(28px, 4vw, 48px);
    border-radius: var(--it-radius-lg);
    background:
        linear-gradient(135deg, var(--it-brand) 0%, var(--it-brand-strong) 100%);
    color: #ffffff;
}

.sf-italicum-footer__cta span {
    display: inline-block;
    margin-bottom: 10px;
    color: rgba(255, 255, 255, 0.85);
    font-family: var(--it-font-body);
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.16em !important;
}

.sf-italicum-footer__title {
    display: block;
    margin: 0;
    max-width: 720px;
    color: #ffffff;
    font-family: var(--it-font-display);
    font-size: clamp(1.65rem, 3vw, 2.4rem);
    font-weight: 500;
    line-height: 1.06;
}

.sf-italicum-footer__cta .sf-btn-primary {
    background: #ffffff !important;
    border-color: #ffffff !important;
    color: var(--it-brand-strong) !important;
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.16);
}

.sf-italicum-footer__cta .sf-btn-primary:hover {
    background: var(--it-ink) !important;
    border-color: var(--it-ink) !important;
    color: #ffffff !important;
}

.sf-italicum-footer__grid {
    display: grid;
    grid-template-columns: minmax(280px, 1.4fr) repeat(3, minmax(160px, 0.8fr));
    gap: 40px;
}

.sf-italicum-footer__brand strong {
    display: block;
    margin-bottom: 14px;
    color: #ffffff;
    font-family: var(--it-font-display);
    font-size: 1.5rem;
    font-weight: 500;
}

.sf-italicum-footer__brand p {
    margin: 0;
    max-width: 380px;
    color: #B1A797;
    line-height: 1.7;
}

.sf-italicum-footer__badges {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 18px;
}

.sf-italicum-footer__badges span {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 0 12px;
    border: 1px solid rgba(255, 255, 255, 0.16);
    border-radius: 999px;
    color: #ffffff;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.sf-italicum-footer__group h3 {
    margin: 0 0 14px;
    color: #ffffff;
    font-family: var(--it-font-display);
    font-size: 1.05rem;
    font-weight: 500;
}

.sf-italicum-footer__group ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 10px;
    color: #B1A797;
    font-size: 0.9rem;
}

.sf-italicum-footer__group a {
    color: #DCD3C4 !important;
    text-decoration: none;
    transition: color 0.16s var(--it-ease);
}

.sf-italicum-footer__group a:hover {
    color: #ffffff !important;
}

.sf-italicum-footer__bar {
    display: flex;
    justify-content: space-between;
    gap: 18px;
    margin-top: 48px;
    padding-top: 24px;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    color: #8B8378;
    font-size: 0.82rem;
}

/* -------------------------------------------------------------
   19. Responsive
   ------------------------------------------------------------- */
@media (max-width: 1180px) {
    .sf-italicum-slide h1,
    .sf-italicum-slide h2 { font-size: 3rem; }
}

@media (max-width: 980px) {
    .sf-shell {
        width: min(100% - 32px, 1280px) !important;
    }

    .sf-italicum-topbar__inner {
        flex-direction: row;
        align-items: center;
        gap: 12px;
        padding: 10px 0;
    }

    .sf-italicum-topbar__trust {
        flex-wrap: wrap;
        gap: 8px 18px;
    }

    .sf-italicum-header__main,
    .sf-header__inner {
        grid-template-columns: minmax(140px, 1fr) auto !important;
        grid-template-areas:
            "brand actions"
            "search search";
        padding: 16px 0 !important;
        min-height: 0 !important;
    }

    .sf-italicum-brand { grid-area: brand; }
    .sf-italicum-search,
    .sf-search { grid-area: search; grid-column: 1 / -1; }
    .sf-italicum-actions { grid-area: actions; justify-content: flex-end; }

    .sf-italicum-action span:not(.sf-italicum-action__icon) {
        display: none;
    }

    .sf-italicum-mega__inner {
        overflow-x: auto;
        scrollbar-width: none;
        min-height: 48px;
        width: calc(100% - 24px) !important;
        scroll-snap-type: x proximity;
    }
    .sf-italicum-mega__inner::-webkit-scrollbar { display: none; }
    .sf-italicum-mega__link--soft { margin-left: 0; }

    .sf-italicum-mega__item--category,
    .sf-italicum-mega__inner > .sf-italicum-mega__link {
        flex: 0 0 auto;
        min-width: 0;
        scroll-snap-align: start;
    }

    .sf-italicum-mega__link {
        min-height: 36px;
        font-size: 0.84rem;
        padding-inline: 12px;
    }

    .sf-italicum-mega__flyout {
        left: 0;
        top: calc(100% + 8px);
        max-height: min(54vh, 380px);
        overflow: auto;
    }

    .sf-italicum-slide {
        grid-template-columns: 1fr;
        gap: 32px;
        padding: 44px;
        min-height: 0;
    }

    .sf-italicum-slide__visual { min-height: 280px; order: -1; }
    .sf-italicum-slide__visual img { max-height: 320px; }

    .sf-italicum-slider__nav { bottom: auto; top: 16px; right: 16px; }

    .sf-section { margin-top: 72px !important; }
    .sf-main { padding: 40px 0 72px !important; }

    .sf-italicum-slider--home {
        margin-top: -40px;
    }

    .sf-italicum-slider--home .sf-italicum-slide {
        min-height: clamp(360px, 62vw, 520px);
        padding-right: 28px;
        padding-left: 28px;
    }

    .sf-italicum-slider--home .sf-italicum-slider__nav {
        right: 16px;
    }

    .sf-blog-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    .sf-blog-grid .sf-blog-card:first-child {
        grid-column: 1 / -1;
    }

    .sf-blog-grid .sf-blog-card:first-child .sf-blog-card__link {
        grid-template-columns: 1fr;
    }

    .sf-blog-grid .sf-blog-card:first-child .sf-blog-card__cover {
        aspect-ratio: 16 / 9;
    }

    .sf-italicum-category-hero {
        grid-template-columns: 1fr;
    }

    .sf-italicum-category-layout {
        grid-template-columns: 1fr;
    }

    .sf-italicum-filter-panel {
        position: static;
    }

    .sf-italicum-product-page {
        grid-template-columns: 1fr;
        gap: 32px;
    }

    .sf-italicum-buybox {
        position: static;
    }

    .sf-italicum-footer__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 640px) {
    .sf-shell {
        width: min(100% - 24px, 1280px) !important;
    }

    .sf-italicum-topbar__inner {
        align-items: flex-start;
        flex-direction: column;
    }

    .sf-italicum-topbar__tools {
        width: 100%;
        justify-content: space-between;
    }

    .sf-italicum-header__main,
    .sf-header__inner {
        grid-template-columns: 1fr auto !important;
        gap: 12px !important;
        padding: 12px 0 !important;
    }

    .sf-brand__mark {
        max-width: 190px;
        max-height: 38px;
    }

    .sf-italicum-search,
    .sf-search {
        min-height: 44px !important;
        padding-inline: 14px !important;
    }

    .sf-italicum-action {
        width: 44px;
        height: 44px;
    }
    .sf-italicum-action__icon svg {
        width: 20px !important;
        height: 20px !important;
    }

    .sf-italicum-slide {
        padding: 28px 22px;
        border-radius: var(--it-radius);
    }

    .sf-italicum-slider--home .sf-italicum-slide {
        min-height: 300px;
        padding-right: 18px;
        padding-left: 18px;
        border-radius: 0;
    }

    .sf-italicum-slider--home .sf-italicum-slide--image-only {
        min-height: 0;
        height: clamp(150px, 27.35vw, 300px);
        padding: 0;
    }

    .sf-italicum-slide--background {
        min-height: 280px;
        background-size: cover;
        background-repeat: no-repeat;
        background-position: center;
    }

    .sf-italicum-slider--home .sf-italicum-slide--background {
        min-height: 0;
    }

    .sf-italicum-slide--image-only .sf-italicum-slide__copy {
        min-height: 230px;
    }

    .sf-italicum-slide h1,
    .sf-italicum-slide h2 { font-size: 2.2rem; }

    .sf-grid,
    .sf-blog-grid,
    .sf-italicum-product-grid {
        grid-template-columns: 1fr !important;
    }

    .sf-blog-hero {
        padding: 24px 20px;
        border-radius: var(--it-radius);
    }

    .sf-blog-card,
    .sf-blog-article__head,
    .sf-blog-article__cover,
    .sf-blog-article__body {
        border-radius: var(--it-radius) !important;
    }

    .sf-italicum-subcat-grid,
    .sf-italicum-all-categories {
        grid-template-columns: 1fr;
    }

    .sf-italicum-all-category__children {
        padding-left: 0;
    }

    .sf-italicum-footer__cta {
        flex-direction: column;
        align-items: flex-start;
    }

    .sf-italicum-footer__grid {
        grid-template-columns: 1fr;
    }

    .sf-italicum-footer__bar {
        flex-direction: column;
    }

    .sf-gallery__lightbox { padding: 14px; }
    .sf-gallery__lightbox-close { top: 12px; right: 12px; }
    .sf-gallery__lightbox-nav--prev { left: 12px; }
    .sf-gallery__lightbox-nav--next { right: 12px; }
    .sf-gallery__lightbox-close,
    .sf-gallery__lightbox-nav { width: 42px; height: 42px; }
}
