/* ============================================================
   SHOPPING LIST / SUBSCRIPTION / RECIPE — 2025 redesign
   Scoped under .shopListPage2025, .subPage2025, .recipePage2025.
   Shares the cream/green design system used across /my-order,
   /cart, /helps, /add-address.
   ============================================================ */

.shopListPage2025,
.subPage2025,
.recipePage2025 {
    --sp-cream:      var(--rd-cream, #f5f1e8);
    --sp-cream-2:    var(--rd-cream-2, #ece5d2);
    --sp-cream-3:    var(--rd-cream-3, #faf6ec);
    --sp-cream-4:    #fffdf7;
    --sp-green:      var(--rd-green, #1f3d2e);
    --sp-green-2:    var(--rd-green-2, #2c5141);
    --sp-green-3:    var(--rd-green-3, #133023);
    --sp-orange:     var(--rd-orange, #f08a3a);
    --sp-gold:       var(--rd-gold, #d4a64b);
    --sp-ink:        var(--rd-ink, #1a2521);
    --sp-muted:      var(--rd-muted, #6b7568);
    --sp-line:       var(--rd-border, #e3ddc9);
    --sp-danger:     #c14040;
    --sp-radius:     18px;
    --sp-radius-md:  14px;
    --sp-radius-sm:  10px;
    --sp-serif:      'Times New Roman', Georgia, serif;
    --sp-shadow:     0 2px 8px rgba(20,40,30,0.04);
    --sp-shadow-lift:0 10px 24px rgba(20,40,30,0.10);

    background: linear-gradient(180deg, var(--sp-cream-3) 0%, var(--sp-cream) 100%);
    min-height: 80vh;
}

.shopListPage2025 .commonGridSection,
.subPage2025 .commonGridSection,
.recipePage2025 .commonGridSection {
    background: transparent !important;
    padding-block: 24px;
}
.shopListPage2025 .commonSectionHeader,
.subPage2025 .commonSectionHeader,
.recipePage2025 .commonSectionHeader { display: none !important; }

.shopListPage2025 .userdetail-cover,
.subPage2025 .userdetail-cover,
.recipePage2025 .userdetail-cover {
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    padding: 0 !important;
}

/* ============================================================
   LAYOUT — aside LEFT, rightside RIGHT (grid override)
   ============================================================ */
.shopListPage2025 .container1440,
.subPage2025 .container1440,
.recipePage2025 .container1440 {
    max-width: 1280px;
    margin: 0 auto;
    padding-inline: 24px;
}
.shopListPage2025 .userSidemenu,
.shopListPage2025 .userSidemenu.mt-5,
.subPage2025 .userSidemenu,
.subPage2025 .userSidemenu.mt-5,
.recipePage2025 .userSidemenu,
.recipePage2025 .userSidemenu.mt-5 {
    display: grid !important;
    grid-template-columns: 300px minmax(0, 1fr) !important;
    gap: 22px !important;
    padding: 0 !important;
    margin: 0 !important;
    min-height: 0 !important;
    border: 0 !important;
    position: relative !important;
    align-items: start;
}
.shopListPage2025 .userSidemenu > aside,
.shopListPage2025 .userSidemenu .nav-side-menu,
.shopListPage2025 .userSidemenu .sideDash2025,
.subPage2025 .userSidemenu > aside,
.subPage2025 .userSidemenu .nav-side-menu,
.subPage2025 .userSidemenu .sideDash2025,
.recipePage2025 .userSidemenu > aside,
.recipePage2025 .userSidemenu .nav-side-menu,
.recipePage2025 .userSidemenu .sideDash2025 {
    position: sticky !important;
    top: 96px !important;
    left: auto !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    height: auto !important;
    background: #fff !important;
    border: 1px solid var(--sp-line) !important;
    border-radius: var(--sp-radius) !important;
    padding: 0 !important;
    box-shadow: 0 10px 24px rgba(20,40,30,0.06);
    overflow: hidden !important;
    box-sizing: border-box;
    align-self: start;
}
.shopListPage2025 .rightside,
.subPage2025 .rightside,
.recipePage2025 .rightside {
    min-width: 0;
    width: 100%;
    padding: 0 !important;
    margin: 0 !important;
    background: transparent !important;
}

@media (max-width: 991px) {
    .shopListPage2025 .userSidemenu,
    .shopListPage2025 .userSidemenu.mt-5,
    .subPage2025 .userSidemenu,
    .subPage2025 .userSidemenu.mt-5,
    .recipePage2025 .userSidemenu,
    .recipePage2025 .userSidemenu.mt-5 {
        grid-template-columns: 1fr !important;
    }
    .shopListPage2025 .userSidemenu > aside,
    .shopListPage2025 .userSidemenu .nav-side-menu,
    .shopListPage2025 .userSidemenu .sideDash2025,
    .subPage2025 .userSidemenu > aside,
    .subPage2025 .userSidemenu .nav-side-menu,
    .subPage2025 .userSidemenu .sideDash2025,
    .recipePage2025 .userSidemenu > aside,
    .recipePage2025 .userSidemenu .nav-side-menu,
    .recipePage2025 .userSidemenu .sideDash2025 {
        position: relative !important;
        top: auto !important;
    }
}

/* ============================================================
   HERO STRIP
   ============================================================ */
.shopListPage2025 .sp-hero,
.subPage2025 .sp-hero,
.recipePage2025 .sp-hero {
    display: flex;
    align-items: center;
    gap: 22px;
    padding: 22px 28px;
    margin: 0 0 18px;
    background: linear-gradient(135deg, var(--sp-cream-3) 0%, var(--sp-cream) 100%);
    border: 1px solid var(--sp-line);
    border-radius: var(--sp-radius);
    position: relative;
    overflow: hidden;
    flex-wrap: wrap;
}
.shopListPage2025 .sp-hero::before,
.subPage2025 .sp-hero::before,
.recipePage2025 .sp-hero::before {
    content: "";
    position: absolute;
    top: -40px; right: -40px;
    width: 220px; height: 220px;
    background: radial-gradient(circle, rgba(212,166,75,0.22) 0%, transparent 70%);
    pointer-events: none;
}
.sp-hero-inner { flex: 1; min-width: 0; position: relative; z-index: 1; }
.sp-eyebrow {
    display: inline-block;
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--sp-green-3);
    margin-bottom: 6px;
}
.sp-eyebrow .sp-spark { color: var(--sp-orange); margin-right: 4px; }
.sp-title {
    font-family: var(--sp-serif);
    font-weight: 500;
    font-size: 34px;
    line-height: 1.1;
    color: var(--sp-ink);
    margin: 0 0 6px;
    letter-spacing: -0.01em;
}
.sp-title em { font-style: italic; color: var(--sp-green); font-weight: 500; }
.sp-title--detail { font-size: 26px; }
.sp-sub {
    font-size: 13px;
    color: var(--sp-muted);
    margin: 0;
    line-height: 1.55;
    max-width: 640px;
}
.sp-trust-row {
    display: flex; gap: 8px; flex-wrap: wrap; margin-top: 10px;
    position: relative; z-index: 1;
}
.sp-trust-pill {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 5px 11px; border-radius: 999px;
    background: rgba(255,255,255,0.75); border: 1px solid var(--sp-line);
    font-size: 10.5px; font-weight: 700; color: var(--sp-green-2);
    letter-spacing: 0.04em; text-transform: uppercase;
}
.sp-trust-pill i { color: var(--sp-orange); font-size: 10px; }
.sp-hero-aside {
    display: flex; flex-direction: column; gap: 6px;
    align-items: flex-end; position: relative; z-index: 1;
}
.sp-hero-counter {
    font-family: var(--sp-serif);
    font-size: 44px; line-height: 1; color: var(--sp-green);
    font-weight: 500;
}
.sp-hero-counter-lbl {
    font-size: 10px; font-weight: 800; letter-spacing: 0.16em;
    text-transform: uppercase; color: var(--sp-muted);
}

/* ============================================================
   SECTION HEADS
   ============================================================ */
.sp-section-head { margin: 18px 0 12px; padding: 0 2px;
    display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
.sp-section-head:first-child { margin-top: 4px; }
.sp-section-title {
    font-family: var(--sp-serif); font-weight: 500;
    font-size: 22px; line-height: 1.15; color: var(--sp-ink);
    margin: 0; letter-spacing: -0.01em;
}
.sp-section-title em { font-style: italic; color: var(--sp-green); font-weight: 500; }

/* ============================================================
   CARD GRID — generic
   ============================================================ */
.sp-card-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
    margin: 0;
}
@media (max-width: 991px) {
    .sp-card-grid { grid-template-columns: 1fr; }
}

.sp-card {
    background: #fff;
    border: 1px solid var(--sp-line);
    border-radius: var(--sp-radius);
    box-shadow: var(--sp-shadow);
    position: relative;
    overflow: hidden;
    transition: transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease;
}
.sp-card::before {
    content: "";
    position: absolute; left: 0; top: 0; bottom: 0;
    width: 3px; background: transparent;
    transition: background 0.15s ease;
}
.sp-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--sp-shadow-lift);
    border-color: rgba(31,61,46,0.25);
}
.sp-card:hover::before { background: var(--sp-green); }

/* ============================================================
   SHOPPING LIST / SUBSCRIPTION SUMMARY CARD
   ============================================================ */
.sp-list-card { min-height: 220px; display: flex; flex-direction: column; }
.sp-list-card-head {
    display: flex; align-items: flex-start; gap: 10px;
    padding: 14px 16px;
    background: linear-gradient(135deg, var(--sp-cream-3) 0%, var(--sp-cream) 100%);
    border-bottom: 1px solid var(--sp-line);
}
.sp-list-card-head-text { flex: 1; min-width: 0; }
.sp-list-card-eyebrow {
    display: block; font-size: 9.5px; font-weight: 800;
    letter-spacing: 0.16em; text-transform: uppercase;
    color: var(--sp-green-3); margin-bottom: 3px;
}
.sp-list-card-title {
    font-family: var(--sp-serif);
    font-size: 18px; line-height: 1.15;
    color: var(--sp-ink); margin: 0;
    font-weight: 500;
    word-break: break-word;
}
.sp-list-card-title em { color: var(--sp-green); font-style: italic; font-weight: 500; }
.sp-list-card-count {
    display: inline-flex; align-items: center; justify-content: center;
    min-width: 36px; height: 28px; padding: 0 10px;
    border-radius: 999px;
    background: var(--sp-green); color: #fff;
    font-size: 12px; font-weight: 700;
    flex-shrink: 0;
}

.sp-list-card-body { padding: 12px 16px; flex: 1; }
.sp-list-card-desc {
    font-size: 12.5px; color: var(--sp-muted);
    line-height: 1.45; margin: 0 0 10px;
    max-height: 40px; overflow: hidden;
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
}
.sp-list-card-thumbs {
    display: flex; gap: 6px; margin-bottom: 10px;
}
.sp-list-card-thumb {
    width: 38px; height: 38px; border-radius: 8px;
    background: var(--sp-cream-2);
    overflow: hidden; border: 1px solid var(--sp-line);
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 11px; color: var(--sp-green);
}
.sp-list-card-thumb img { width: 100%; height: 100%; object-fit: cover; }
.sp-list-card-thumb--more {
    background: var(--sp-green); color: var(--sp-gold);
    font-weight: 700; font-size: 11px;
}
.sp-list-card-meta {
    list-style: none; padding: 0; margin: 0;
    display: flex; flex-direction: column; gap: 4px;
    font-size: 11.5px; color: var(--sp-muted);
}
.sp-list-card-meta li {
    display: inline-flex; align-items: center; gap: 6px;
    list-style: none;
}
.sp-list-card-meta i { color: var(--sp-orange); font-size: 10px; }

.sp-list-card-footer {
    display: flex; gap: 6px; padding: 10px 12px;
    border-top: 1px solid var(--sp-line);
    background: var(--sp-cream-4);
    flex-wrap: wrap;
}
.sp-list-card-footer .sp-btn { flex: 1; min-width: 0; }

/* ============================================================
   BUTTONS
   ============================================================ */
.sp-btn {
    display: inline-flex; align-items: center; justify-content: center;
    gap: 6px;
    padding: 9px 16px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.03em;
    text-decoration: none !important;
    border: 1px solid transparent;
    cursor: pointer;
    transition: background 0.15s, color 0.15s, border-color 0.15s, box-shadow 0.15s, transform 0.1s;
    line-height: 1;
    white-space: nowrap;
}
.sp-btn:active { transform: translateY(1px); }
.sp-btn i { font-size: 11px; }

.sp-btn--primary {
    background: linear-gradient(135deg, var(--sp-green) 0%, var(--sp-green-2) 100%);
    color: #fff !important;
    box-shadow: 0 6px 14px rgba(31,61,46,0.18);
}
.sp-btn--primary:hover {
    background: var(--sp-green-3);
    color: #fff !important;
    box-shadow: 0 8px 20px rgba(31,61,46,0.26);
}
.sp-btn--primary .sp-btn-chip {
    width: 20px; height: 20px; border-radius: 50%;
    background: var(--sp-orange); color: var(--sp-green-3);
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 10px;
}

.sp-btn--ghost {
    background: #fff;
    color: var(--sp-green) !important;
    border-color: var(--sp-line);
}
.sp-btn--ghost:hover {
    background: var(--sp-cream-3);
    border-color: var(--sp-green);
}

.sp-btn--gold {
    background: linear-gradient(135deg, var(--sp-gold) 0%, var(--sp-orange) 100%);
    color: var(--sp-green-3) !important;
}
.sp-btn--gold:hover { filter: brightness(1.04); color: var(--sp-green-3) !important; }


.sp-btn--block { width: 100%; }
.sp-btn--sm { padding: 6px 12px; font-size: 11px; }

/* ============================================================
   EMPTY STATE
   ============================================================ */
.sp-empty {
    background: #fff;
    border: 1px solid var(--sp-line);
    border-radius: var(--sp-radius);
    padding: 36px 28px;
    text-align: center;
    box-shadow: var(--sp-shadow);
}
.sp-empty-art {
    width: 84px; height: 84px;
    margin: 0 auto 14px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--sp-cream-2) 0%, var(--sp-cream) 100%);
    display: flex; align-items: center; justify-content: center;
    font-size: 38px;
}
.sp-empty-title {
    font-family: var(--sp-serif);
    font-size: 22px; font-weight: 500;
    color: var(--sp-ink); margin: 0 0 6px;
}
.sp-empty-title em { color: var(--sp-green); font-style: italic; font-weight: 500; }
.sp-empty-sub {
    font-size: 13px; color: var(--sp-muted);
    margin: 0 auto 18px; max-width: 460px; line-height: 1.5;
}
.sp-empty .sp-btn { min-width: 220px; }

/* ============================================================
   ITEM ROW (detail view)
   ============================================================ */
.sp-items-card {
    background: #fff;
    border: 1px solid var(--sp-line);
    border-radius: var(--sp-radius);
    box-shadow: var(--sp-shadow);
    padding: 6px 0;
}
.sp-cat-head {
    padding: 10px 18px;
    font-size: 10.5px; font-weight: 800;
    letter-spacing: 0.16em; text-transform: uppercase;
    color: var(--sp-green-3);
    background: var(--sp-cream-3);
    border-bottom: 1px solid var(--sp-line);
    border-top: 1px solid var(--sp-line);
}
.sp-cat-head:first-child { border-top: 0; }
.sp-cat-head .sp-cat-count {
    float: right;
    background: var(--sp-green); color: #fff;
    padding: 1px 9px; border-radius: 999px;
    font-size: 10px;
}

.sp-item {
    display: grid;
    grid-template-columns: 56px 1fr auto auto auto;
    align-items: center;
    gap: 14px;
    padding: 12px 18px;
    border-bottom: 1px solid var(--sp-line);
    transition: background 0.12s;
}
.sp-item:last-child { border-bottom: 0; }
.sp-item:hover { background: var(--sp-cream-4); }

.sp-item-thumb {
    width: 56px; height: 56px; border-radius: 10px;
    background: var(--sp-cream-2); overflow: hidden;
    border: 1px solid var(--sp-line);
    display: inline-flex; align-items: center; justify-content: center;
}
.sp-item-thumb img { width: 100%; height: 100%; object-fit: cover; }

.sp-item-info { min-width: 0; }
.sp-item-brand {
    font-size: 10.5px; font-weight: 800;
    letter-spacing: 0.10em; text-transform: uppercase;
    color: var(--sp-orange); margin: 0 0 2px;
}
.sp-item-name {
    font-family: var(--sp-serif);
    font-size: 15px; line-height: 1.2;
    color: var(--sp-ink); margin: 0 0 3px;
    font-weight: 500;
}
.sp-item-pack {
    font-size: 11.5px; color: var(--sp-muted);
    margin: 0;
}

.sp-stepper {
    display: inline-flex; align-items: center;
    border: 1px solid var(--sp-line);
    border-radius: 999px;
    background: #fff;
    overflow: hidden;
    height: 32px;
}
.sp-stepper i {
    width: 28px; height: 32px;
    display: inline-flex; align-items: center; justify-content: center;
    color: var(--sp-green); font-size: 11px;
    cursor: pointer;
}
.sp-stepper i:hover { background: var(--sp-cream-3); color: var(--sp-orange); }
.sp-stepper input {
    width: 36px; height: 32px;
    border: 0; background: transparent;
    text-align: center;
    font-weight: 700; color: var(--sp-ink);
    font-size: 12px;
    outline: none;
}


.sp-item-delete {
    width: 30px; height: 30px; border-radius: 8px;
    border: 1px solid var(--sp-line);
    background: #fff;
    color: var(--sp-danger) !important;
    display: inline-flex; align-items: center; justify-content: center;
    text-decoration: none !important;
    font-size: 12px;
    transition: background 0.15s, color 0.15s;
}
.sp-item-delete:hover {
    background: var(--sp-danger);
    color: #fff !important;
    border-color: var(--sp-danger);
}

/* ============================================================
   DETAIL HEADER CARD (shopping-list-detail summary)
   ============================================================ */

.sp-detail-actions {
    display: flex; gap: 10px; margin-top: 16px; flex-wrap: wrap;
}
.sp-detail-actions .sp-btn { flex: 1 1 auto; min-width: 160px; }

.sp-back-link {
    display: inline-flex; align-items: center; gap: 6px;
    margin-top: 14px;
    color: var(--sp-green) !important;
    font-size: 12px; font-weight: 700;
    letter-spacing: 0.06em; text-transform: uppercase;
    text-decoration: none !important;
}
.sp-back-link:hover { color: var(--sp-orange) !important; }

/* ============================================================
   STATUS PILLS
   ============================================================ */

/* ============================================================
   SUBSCRIPTION FREQUENCY / DAY PICKER
   ============================================================ */
.sp-freq-pill.is-active,
.sp-freq-pill input:checked + span {
    background: var(--sp-green);
    color: #fff;
    border-color: var(--sp-green);
}

.sp-day-pill.is-active { background: var(--sp-green); color: #fff; border-color: var(--sp-green); }

.sp-slot-pill.is-active { background: var(--sp-green); color: #fff; border-color: var(--sp-green); }
.sp-slot-pill.is-active i { color: var(--sp-gold); }


/* ============================================================
   FORM FIELDS
   ============================================================ */
.sp-field { margin-bottom: 14px; }
.sp-field-label {
    display: block;
    font-size: 10.5px; font-weight: 800;
    letter-spacing: 0.14em; text-transform: uppercase;
    color: var(--sp-green-3);
    margin-bottom: 6px;
}
.sp-input, .sp-textarea, .sp-select {
    width: 100%;
    height: 42px;
    padding: 0 14px;
    border-radius: 12px;
    background: var(--sp-cream-3);
    border: 1px solid var(--sp-line);
    color: var(--sp-ink);
    font-size: 13px;
    transition: border-color 0.15s, box-shadow 0.15s, background 0.15s;
    outline: none;
}
.sp-textarea { height: auto; min-height: 88px; padding: 12px 14px; resize: vertical; line-height: 1.5; }
.sp-input:focus, .sp-textarea:focus, .sp-select:focus {
    border-color: var(--sp-green);
    background: #fff;
    box-shadow: 0 0 0 4px rgba(31,61,46,0.10);
}

/* ============================================================
   MODAL RESTYLE (delete / save)
   ============================================================ */
.shopListPage2025 .modal-content.sp-modal,
.subPage2025 .modal-content.sp-modal,
.recipePage2025 .modal-content.sp-modal {
    border-radius: var(--sp-radius) !important;
    overflow: hidden;
    border: 0;
}
.sp-modal-header {
    background: linear-gradient(135deg, var(--sp-gold) 0%, var(--sp-orange) 100%);
    color: var(--sp-green-3);
    padding: 14px 22px;
    font-family: var(--sp-serif);
    font-size: 18px; font-weight: 500;
    display: flex; align-items: center; justify-content: space-between;
}
.sp-modal-header .close { color: var(--sp-green-3); opacity: 0.8; }
.sp-modal-body { padding: 20px 22px; background: #fff; }
.sp-modal-footer {
    display: flex; gap: 10px; padding: 14px 22px;
    background: var(--sp-cream-3);
    border-top: 1px solid var(--sp-line);
}
.sp-modal-footer .sp-btn { flex: 1; }

/* ============================================================
   RECIPE CARDS / DETAIL — additive styles
   ============================================================ */

.sp-recipe-tag:hover, .sp-recipe-tag.is-active {
    background: var(--sp-green); color: #fff; border-color: var(--sp-green);
}

@media (max-width: 991px) {  }





/* Recipe categories */

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 767px) {
    .sp-title { font-size: 26px; }
    .sp-hero { padding: 18px 18px; }
    .sp-item {
        grid-template-columns: 48px 1fr;
        grid-template-rows: auto auto;
        row-gap: 8px;
    }
    .sp-item-thumb { width: 48px; height: 48px; }
    .sp-stepper, .sp-item-price, .sp-item-delete { grid-column: 2 / span 1; }
}
