:root {
    --shop-bg: #f6faf3;
    --shop-surface: #ffffff;
    --shop-surface-soft: #eef8e9;
    --shop-surface-warm: #fff7e0;
    --shop-text: #1f2937;
    --shop-text-muted: #6b7280;
    --shop-border: #dbe7d3;
    --shop-primary: #27963c;
    --shop-primary-dark: #1c762d;
    --shop-primary-soft: #ddf4de;
    --shop-accent: #ff7a00;
    --shop-danger: #ef4444;
    --shop-shadow: 0 18px 45px rgba(25, 78, 35, 0.08);
    --shop-radius-lg: 28px;
    --shop-radius-md: 20px;
    --shop-radius-sm: 14px;
    --shop-container: 1280px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body.shop-body {
    margin: 0;
    color: var(--shop-text);
    background:
        radial-gradient(circle at top left, rgba(194, 236, 187, 0.45), transparent 28%),
        radial-gradient(circle at top right, rgba(255, 244, 201, 0.45), transparent 24%),
        var(--shop-bg);
    font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
.shop-shell { min-height: 100vh; }
.shop-container { width: min(calc(100% - 32px), var(--shop-container)); margin: 0 auto; }
.shop-main { padding: 28px 0 64px; }
.shop-stack { display: grid; gap: 28px; }
.shop-section {
    background: rgba(255, 255, 255, 0.82);
    border: 1px solid rgba(219, 231, 211, 0.85);
    border-radius: var(--shop-radius-lg);
    box-shadow: var(--shop-shadow);
}
.shop-surface {
    background: var(--shop-surface);
    border: 1px solid var(--shop-border);
    border-radius: var(--shop-radius-md);
    box-shadow: 0 12px 30px rgba(25, 78, 35, 0.06);
}
.button {
    display: inline-flex; align-items: center; justify-content: center; gap: 10px;
    min-height: 48px; padding: 0 20px; border: 1px solid transparent; border-radius: 999px;
    font-weight: 700; transition: 180ms ease; cursor: pointer;
}
.button:hover { transform: translateY(-1px); }
.button--primary { color: #fff; background: linear-gradient(135deg, var(--shop-primary), var(--shop-primary-dark)); }
.button--ghost { color: var(--shop-primary-dark); background: rgba(255,255,255,.9); border-color: var(--shop-border); }
.button--soft { color: var(--shop-primary-dark); background: var(--shop-primary-soft); }
.button--full { width: 100%; }
.field, .select, .textarea {
    width: 100%; min-height: 52px; padding: 0 16px; color: var(--shop-text); background: #fff;
    border: 1px solid var(--shop-border); border-radius: 16px; outline: none;
}
.textarea { min-height: 120px; padding: 14px 16px; resize: vertical; }
.field:focus, .select:focus, .textarea:focus { border-color: rgba(39,150,60,.6); box-shadow: 0 0 0 4px rgba(39,150,60,.12); }
.shop-topbar { padding: 4px 0 18px; }
.shop-header { display: grid; gap: 18px; padding: 20px 24px 18px; }
.shop-header__row { display: grid; grid-template-columns: 200px minmax(0,1fr) auto; gap: 18px; align-items: center; }
.shop-brand { display: inline-flex; align-items: center; gap: 14px; }
.shop-brand__mark {
    display: grid; place-items: center; width: 42px; height: 42px; font-size: 24px; border-radius: 14px;
    color: #fff; background: linear-gradient(145deg, var(--shop-primary), var(--shop-primary-dark));
    box-shadow: 0 10px 24px rgba(39,150,60,.22);
}
.shop-brand__mark svg { width: 22px; height: 22px; }
.shop-brand__title { display: block; font-size: 1.95rem; font-weight: 800; line-height: 1; }
.shop-brand__title span { color: var(--shop-primary); }
.shop-brand__subtitle { display: block; margin-top: 4px; color: var(--shop-text-muted); font-size: 1rem; }
.shop-search {
    display: grid; grid-template-columns: minmax(0,1fr) 170px 60px; align-items: center; overflow: hidden;
    background: #fff; border: 1px solid var(--shop-border); border-radius: 999px;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.85);
}
.shop-search__input, .shop-search__select { min-height: 58px; padding: 0 22px; border: 0; background: transparent; outline: none; }
.shop-search__input::placeholder { color: #8a928b; }
.shop-search__select { border-left: 1px solid var(--shop-border); color: #6b7280; appearance: none; }
.shop-search__button {
    min-height: 58px; border: 0; color: #fff; background: linear-gradient(135deg, var(--shop-primary), var(--shop-primary-dark));
    cursor: pointer; font-size: 1.2rem;
}
.shop-quicklinks { display: flex; align-items: center; justify-content: flex-end; gap: 12px; flex-wrap: wrap; }
.shop-quicklink-menu { position: relative; }
.shop-quicklink-menu summary { list-style: none; cursor: pointer; }
.shop-quicklink-menu summary::-webkit-details-marker { display: none; }
.shop-quicklink {
    display: inline-flex; align-items: center; gap: 12px; min-height: 62px; padding: 12px 16px; background: rgba(255,255,255,.94);
    border: 1px solid var(--shop-border); border-radius: 18px;
}
.shop-quicklink--location { min-width: 186px; }
.shop-quicklink__icon { font-size: 1.25rem; line-height: 1; }
.shop-quicklink__label { display: block; font-size: .78rem; color: var(--shop-text-muted); }
.shop-quicklink__value { display: block; font-weight: 800; }
.shop-quicklink-menu__dropdown {
    position: absolute; top: calc(100% + 12px); right: 0; z-index: 20; min-width: 180px; padding: 10px;
    background: rgba(255,255,255,.98); border: 1px solid var(--shop-border); border-radius: 18px;
    box-shadow: 0 20px 44px rgba(25, 78, 35, 0.12);
}
.shop-quicklink-menu__link {
    display: block; padding: 11px 14px; border-radius: 12px; font-weight: 600;
}
.shop-quicklink-menu__button {
    width: 100%;
    display: block;
    padding: 11px 14px;
    border: 0;
    border-radius: 12px;
    color: var(--shop-danger);
    background: transparent;
    font: inherit;
    font-weight: 700;
    text-align: left;
    cursor: pointer;
}
.shop-quicklink-menu__link:hover {
    color: var(--shop-primary-dark); background: rgba(39,150,60,.08);
}
.shop-quicklink-menu__button:hover {
    background: rgba(197, 48, 48, 0.08);
}
.shop-nav {
    display: flex; align-items: center; justify-content: space-between; gap: 18px; padding-top: 24px;
    border-top: 1px solid rgba(219,231,211,.9);
}
.shop-nav__left { display: flex; align-items: center; gap: 22px; flex-wrap: wrap; min-width: 0; }
.shop-nav__menu { display: flex; align-items: center; gap: 28px; flex-wrap: wrap; min-width: 0; }
.shop-nav__categories { position: relative; }
.shop-nav__categories summary { list-style: none; cursor: pointer; }
.shop-nav__categories summary::-webkit-details-marker { display: none; }
.shop-nav__pill {
    display: inline-flex; align-items: center; gap: 10px; min-height: 48px; padding: 0 18px; color: #fff;
    background: linear-gradient(135deg, var(--shop-primary), var(--shop-primary-dark)); border-radius: 14px; font-weight: 700;
    white-space: nowrap;
}
.shop-nav__pill-icon { font-size: 1rem; }
.shop-nav__dropdown {
    position: absolute; top: calc(100% + 12px); left: 0; z-index: 20; min-width: 260px; padding: 12px;
    background: rgba(255,255,255,.98); border: 1px solid var(--shop-border); border-radius: 18px;
    box-shadow: 0 20px 44px rgba(25, 78, 35, 0.12);
}
.shop-nav__dropdown-link {
    display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 12px 14px;
    border-radius: 12px; font-weight: 600;
}
.shop-nav__dropdown-link:hover {
    color: var(--shop-primary-dark); background: rgba(39,150,60,.08);
}
.shop-nav__dropdown-count {
    min-width: 28px; padding: 4px 8px; color: var(--shop-primary-dark); background: #edf8ea; border-radius: 999px;
    text-align: center; font-size: .82rem; font-weight: 700;
}
.shop-nav__menu a { position: relative; padding: 10px 0; font-weight: 500; color: #0f172a; white-space: nowrap; }
.shop-nav__menu a:hover, .shop-nav__menu a.is-active { color: var(--shop-primary-dark); }
.shop-nav__menu a.is-active::after, .shop-nav__menu a:hover::after {
    content: ""; position: absolute; left: 0; right: 0; bottom: -10px; height: 2px; border-radius: 999px; background: var(--shop-primary);
}
.shop-nav__promo {
    max-width: 286px; padding: 14px 18px; color: var(--shop-primary-dark); background: linear-gradient(135deg, #eff8e9, #fbf4cf);
    border: 1px solid #dfeecf; border-radius: 18px; font-weight: 800; line-height: 1.35;
}
.hero {
    display: grid; grid-template-columns: 1.05fr .95fr; gap: 30px; padding: 34px;
    background: radial-gradient(circle at 20% 20%, rgba(227,246,225,.9), transparent 38%), linear-gradient(135deg, #f7fbf2, #eef9eb 55%, #fefdeb);
}
.hero__content { display: grid; align-content: center; gap: 18px; }
.hero__eyebrow {
    display: inline-flex; align-items: center; width: fit-content; gap: 10px; padding: 10px 16px; color: var(--shop-primary-dark);
    background: rgba(255,255,255,.88); border: 1px solid rgba(39,150,60,.18); border-radius: 999px; font-weight: 700;
}
.hero__title { margin: 0; font-size: clamp(2.4rem, 5vw, 4.5rem); line-height: 1.02; }
.hero__title strong { color: var(--shop-primary); }
.hero__text { max-width: 560px; color: var(--shop-text-muted); font-size: 1.05rem; line-height: 1.8; }
.hero__actions, .hero__stats { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.hero__stat { min-width: 150px; padding: 16px 18px; background: rgba(255,255,255,.8); border: 1px solid rgba(219,231,211,.9); border-radius: 18px; }
.hero__stat strong { display: block; margin-bottom: 4px; color: var(--shop-primary-dark); }
.hero__visual { position: relative; min-height: 420px; display: grid; place-items: center; }
.hero__orb { position: absolute; inset: 36px 30px; border-radius: 50%; background: radial-gradient(circle, rgba(185,231,172,.5), rgba(255,255,255,.2)); filter: blur(4px); }
.hero__image { position: relative; z-index: 1; max-height: 430px; object-fit: contain; }
.hero__offer {
    position: absolute; right: 22px; bottom: 44px; z-index: 2; display: grid; place-items: center; width: 140px; height: 140px;
    color: #fff; text-align: center; border-radius: 50%; background: linear-gradient(145deg, #2ca53f, #1f7d30); box-shadow: 0 20px 40px rgba(39,150,60,.25);
}
.hero__offer strong { font-size: 2rem; line-height: 1; }
.section-head { display: flex; align-items: end; justify-content: space-between; gap: 16px; margin-bottom: 18px; }
.section-head h2, .section-head h1 { margin: 0; font-size: clamp(1.9rem, 3vw, 2.5rem); }
.section-head p { margin: 8px 0 0; color: var(--shop-text-muted); }
.category-grid { display: grid; grid-template-columns: repeat(6, minmax(0,1fr)); gap: 18px; }
.category-card {
    display: grid; gap: 12px; padding: 18px; background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(246,251,243,.98));
    border: 1px solid var(--shop-border); border-radius: 22px; transition: 180ms ease;
}
.category-card:hover { transform: translateY(-3px); border-color: rgba(39,150,60,.3); }
.category-card__media { aspect-ratio: 1/1; display: grid; place-items: center; padding: 14px; background: #fff; border-radius: 18px; }
.category-card__image { max-height: 84px; object-fit: contain; }
.category-card__title { font-weight: 700; }
.category-card__meta { color: var(--shop-text-muted); font-size: .92rem; }
.promo-banner {
    display: grid; grid-template-columns: 1fr auto; gap: 22px; align-items: center; padding: 24px 30px;
    background: radial-gradient(circle at center, rgba(255,243,199,.55), transparent 36%), linear-gradient(135deg, #fff5d8, #fffbe8);
}
.promo-banner__eyebrow { color: #f06a00; font-weight: 800; letter-spacing: .04em; text-transform: uppercase; }
.promo-banner__title { margin: 10px 0 8px; font-size: clamp(2rem, 4vw, 3rem); }
.promo-banner__title strong { color: var(--shop-accent); }
.promo-banner__code {
    padding: 14px 24px; color: var(--shop-primary-dark); background: rgba(255,255,255,.62); border: 2px dashed rgba(39,150,60,.45); border-radius: 20px; text-align: center;
}
.promo-banner__code strong { display: block; font-size: 2rem; }
.product-grid { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 20px; }
.product-card {
    position: relative; display: grid; gap: 16px; padding: 18px; background: linear-gradient(180deg, #fff, #fbfdf8);
    border: 1px solid var(--shop-border); border-radius: 24px; box-shadow: 0 14px 30px rgba(25,78,35,.05);
}
.product-card__image-wrap { aspect-ratio: 1/1; display: grid; place-items: center; padding: 18px; background: #fff; border-radius: 20px; }
.product-card__image { max-height: 180px; object-fit: contain; }
.product-card__body { display: grid; gap: 10px; }
.product-card__eyebrow { color: var(--shop-text-muted); font-size: .85rem; }
.product-card__title { font-size: 1.05rem; font-weight: 700; line-height: 1.4; }
.product-card__meta { display: flex; justify-content: space-between; gap: 10px; color: var(--shop-text-muted); font-size: .9rem; }
.product-card__price { display: flex; align-items: baseline; gap: 10px; }
.product-card__price-current { color: var(--shop-primary); font-size: 1.5rem; font-weight: 800; }
.product-card__price-old { color: #9ca3af; text-decoration: line-through; }
.product-badge {
    position: absolute; top: 16px; left: 16px; z-index: 2; display: inline-flex; align-items: center; min-height: 30px; padding: 0 10px;
    color: #fff; background: var(--shop-danger); border-radius: 999px; font-size: .82rem; font-weight: 700;
}
.product-badge--soft { color: var(--shop-primary-dark); background: #dcf7d6; }
.trust-grid { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 16px; }
.trust-card {
    display: flex; gap: 16px; padding: 18px 20px; align-items: flex-start; background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(243,249,238,.96));
    border: 1px solid var(--shop-border); border-radius: 20px;
}
.trust-card__icon { font-size: 1.6rem; }
.trust-card h3 { margin: 0 0 4px; font-size: 1rem; }
.trust-card p { margin: 0; color: var(--shop-text-muted); font-size: .94rem; }
.page-grid { display: grid; grid-template-columns: 300px minmax(0,1fr); gap: 24px; }
.sidebar-panel, .content-panel { padding: 24px; }
.filter-group + .filter-group { margin-top: 22px; padding-top: 22px; border-top: 1px solid rgba(219,231,211,.9); }
.filter-group h3 { margin: 0 0 14px; font-size: 1rem; }
.filter-list { display: grid; gap: 12px; }
.filter-link, .filter-item { display: flex; align-items: center; justify-content: space-between; gap: 10px; color: var(--shop-text); }
.filter-link:hover { color: var(--shop-primary-dark); }
.filter-muted { color: var(--shop-text-muted); font-size: .92rem; }
.toolbar { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-bottom: 18px; }
.toolbar__meta { color: var(--shop-text-muted); }
.detail-layout { display: grid; grid-template-columns: minmax(0,1.1fr) minmax(0,.95fr) 360px; gap: 24px; align-items: start; }
.gallery-panel, .detail-panel, .purchase-panel, .info-panel { padding: 24px; }
.gallery-main { display: grid; place-items: center; min-height: 420px; padding: 22px; background: #fff; border: 1px solid var(--shop-border); border-radius: 22px; }
.gallery-main img { max-height: 360px; object-fit: contain; }
.gallery-thumbs { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 12px; margin-top: 14px; }
.gallery-thumb { display: grid; place-items: center; min-height: 86px; padding: 10px; background: #fff; border: 1px solid var(--shop-border); border-radius: 18px; }
.detail-title { margin: 0 0 10px; font-size: clamp(2rem, 3vw, 3rem); }
.detail-rating, .detail-meta, .mini-meta { display: flex; gap: 12px; flex-wrap: wrap; color: var(--shop-text-muted); }
.detail-price { margin: 18px 0 10px; display: flex; align-items: baseline; gap: 14px; flex-wrap: wrap; }
.detail-price__current { color: var(--shop-primary); font-size: 2.3rem; font-weight: 800; }
.detail-price__old { color: #9ca3af; text-decoration: line-through; }
.detail-list { display: grid; gap: 12px; margin: 24px 0; }
.detail-list__item { display: flex; justify-content: space-between; gap: 10px; padding-bottom: 10px; border-bottom: 1px solid rgba(219,231,211,.85); }
.option-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 12px; }
.option-card, .choice-card { padding: 14px 16px; background: #fff; border: 1px solid var(--shop-border); border-radius: 18px; }
.option-card.is-active { color: #fff; background: linear-gradient(145deg, var(--shop-primary), var(--shop-primary-dark)); border-color: transparent; }
.quantity-row { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.quantity-input { width: 88px; text-align: center; }
.info-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 20px; }
.bullet-list { margin: 0; padding-left: 18px; color: var(--shop-text-muted); line-height: 1.8; }
.card-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 20px; }
.cart-layout { display: grid; grid-template-columns: minmax(0, 1.65fr) minmax(320px, .85fr); gap: 20px; align-items: start; }
.summary-card, .list-card, .form-card { padding: 24px; }
.summary-lines { display: grid; gap: 12px; }
.summary-line { display: flex; justify-content: space-between; gap: 16px; }
.summary-line--total { padding-top: 14px; border-top: 1px solid rgba(219,231,211,.9); font-size: 1.15rem; font-weight: 800; }
.profile-form { display: grid; gap: 24px; }
.profile-form__grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; }
.profile-form__field { display: grid; gap: 10px; color: var(--shop-text-muted); font-size: 0.95rem; font-weight: 700; }
.profile-form__field span { color: var(--shop-text); }
.profile-form__status {
    display: grid;
    gap: 10px;
    min-height: 52px;
    padding: 16px 18px;
    border: 1px solid var(--shop-border);
    border-radius: 16px;
    background: linear-gradient(180deg, #fff, #fbfdf9);
}
.profile-form__status small { color: var(--shop-text-muted); font-size: 0.85rem; }
.profile-form__actions { display: flex; justify-content: flex-end; }
.cart-count {
    color: var(--shop-text-muted);
    font-size: 1rem;
    font-weight: 600;
}
.cart-continue-link {
    min-height: 40px;
    padding: 0 18px;
    color: var(--shop-primary-dark);
    font-size: 0.9rem;
}
.cart-table-head,
.cart-item-row {
    display: grid;
    grid-template-columns: minmax(300px, 1.95fr) minmax(90px, .65fr) minmax(124px, .8fr) minmax(90px, .65fr) 32px;
    gap: 14px;
    align-items: center;
}
.cart-table-head {
    padding: 0 0 12px;
    color: var(--shop-text-muted);
    font-size: 0.76rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    border-bottom: 1px solid rgba(219,231,211,.9);
}
.cart-item-row {
    padding: 18px 0;
}
.cart-item-row + .cart-item-row {
    border-top: 1px solid rgba(219,231,211,.9);
}
.cart-item-product {
    display: grid;
    grid-template-columns: 76px minmax(0, 1fr);
    gap: 14px;
    align-items: center;
}
.cart-item-product__media {
    min-height: 76px;
    padding: 8px;
    border-radius: 14px;
}
.cart-item-product__media img {
    max-height: 58px;
}
.cart-item-product__details strong {
    display: block;
    margin-bottom: 4px;
    font-size: 0.98rem;
}
.cart-item-product__details .muted {
    font-size: 0.88rem;
}
.cart-item-price strong {
    font-size: 0.96rem;
}
.cart-stock-text {
    margin-top: 8px;
    color: var(--shop-primary);
    font-size: 0.84rem;
    font-weight: 700;
}
.cart-item-total strong {
    color: var(--shop-primary);
    font-size: 0.96rem;
}
.cart-qty-form {
    display: inline-grid;
    grid-template-columns: 30px 50px 30px;
    align-items: center;
    border: 1px solid var(--shop-border);
    border-radius: 10px;
    overflow: hidden;
    background: #fff;
}
.cart-qty-button {
    width: 30px;
    height: 30px;
    border: 0;
    color: var(--shop-text-muted);
    background: #f8faf7;
    font-size: 0.95rem;
    cursor: pointer;
}
.cart-qty-button:hover {
    color: var(--shop-primary-dark);
    background: #eef8e9;
}
.cart-qty-form .quantity-input {
    width: 50px;
    min-height: 30px;
    padding: 0;
    font-size: 0.92rem;
    text-align: center;
    border: 0;
    border-left: 1px solid var(--shop-border);
    border-right: 1px solid var(--shop-border);
    border-radius: 0;
    box-shadow: none;
}
.cart-remove-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border: 1px solid transparent;
    border-radius: 10px;
    color: #6b7280;
    background: transparent;
    cursor: pointer;
    transition: 180ms ease;
}
.cart-remove-icon:hover {
    color: var(--shop-danger);
    background: #fff4f4;
    border-color: #ffd7d7;
}
.cart-remove-icon svg {
    width: 16px;
    height: 16px;
}
.list-row { display: block; }
.list-row__media { display: grid; place-items: center; min-height: 84px; padding: 10px; background: #fff; border: 1px solid var(--shop-border); border-radius: 18px; }
.list-row__media img { max-height: 64px; object-fit: contain; }
.list-row__details,
.list-row__pricing,
.list-row__controls { min-width: 0; }
.list-row__details strong,
.list-row__pricing strong { display: block; }
.list-row__label {
    display: block;
    margin-bottom: 8px;
    color: var(--shop-text-muted);
    font-size: 0.82rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.list-row__total-amount {
    color: var(--shop-primary-dark);
    font-size: 1.05rem;
}
.list-row__controls {
    display: grid;
    gap: 10px;
    justify-items: start;
    align-content: start;
    padding: 16px 18px;
    background: linear-gradient(180deg, #fbfdf9, #f4faee);
    border: 1px solid rgba(219,231,211,.9);
    border-radius: 22px;
}
.list-row__controls .button {
    min-width: 110px;
}
.list-row__controls .button--soft {
    min-height: 44px;
    padding: 0 22px;
}
.list-row__controls .button--ghost {
    min-width: 0;
    min-height: 0;
    padding: 0;
    border: 0;
    background: transparent;
    border-radius: 0;
    color: var(--shop-text-muted);
    font-size: 0.92rem;
    font-weight: 600;
    box-shadow: none;
}
.list-row__controls .button--ghost:hover {
    color: var(--shop-danger);
    transform: none;
}
.cart-remove-button {
    text-decoration: underline;
    text-underline-offset: 3px;
}
.pill { display: inline-flex; align-items: center; gap: 8px; min-height: 34px; padding: 0 12px; color: var(--shop-primary-dark); background: var(--shop-primary-soft); border-radius: 999px; font-weight: 700; font-size: .9rem; }
.status-badge { display: inline-flex; align-items: center; min-height: 34px; padding: 0 12px; color: var(--shop-primary-dark); background: #e7f7e7; border-radius: 999px; font-weight: 700; }
.checkout-grid { display: grid; grid-template-columns: minmax(0,1fr) 380px; gap: 24px; }
.address-option, .payment-option {
    display: flex; gap: 12px; padding: 18px; border: 1px solid var(--shop-border); border-radius: 18px; background: linear-gradient(180deg, #fff, #fbfdf9);
}
.address-option + .address-option, .payment-option + .payment-option { margin-top: 14px; }
.address-option.is-selected, .payment-option.is-selected { border-color: rgba(39,150,60,.45); box-shadow: inset 0 0 0 1px rgba(39,150,60,.22); }
.policy-page { padding: 30px; }
.policy-page__intro {
    display: flex; align-items: center; justify-content: space-between; gap: 18px; padding-bottom: 22px;
    border-bottom: 1px solid rgba(219,231,211,.9);
}
.policy-page__intro p { margin: 0; max-width: 680px; }
.policy-page__sections { display: grid; gap: 22px; margin-top: 24px; }
.policy-page__section {
    padding: 24px; background: linear-gradient(180deg, #fff, #fbfdf8); border: 1px solid var(--shop-border); border-radius: 22px;
}
.policy-page__section h2 { margin: 0 0 14px; font-size: 1.2rem; }
.simple-table { width: 100%; border-collapse: collapse; }
.simple-table th, .simple-table td { padding: 16px 18px; text-align: left; border-bottom: 1px solid rgba(219,231,211,.9); }
.simple-table th { color: var(--shop-text-muted); font-size: .9rem; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; }
.footer { margin-top: 40px; padding: 34px 0 0; }
.footer__top { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr 1fr; gap: 24px; padding: 30px; }
.footer__brand p, .footer__col p, .footer__col li { color: var(--shop-text-muted); }
.footer__col h3 { margin: 0 0 14px; }
.footer__col ul { margin: 0; padding: 0; list-style: none; display: grid; gap: 10px; }
.footer__bottom {
    display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 18px 30px; color: #fff;
    background: linear-gradient(145deg, var(--shop-primary), var(--shop-primary-dark)); border-radius: 0 0 var(--shop-radius-lg) var(--shop-radius-lg);
}
.footer__copyright { color: #fff; font-weight: 600; }
.footer__apps,
.footer__payments { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; }
.footer__app-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 38px;
    padding: 0 14px;
    color: var(--shop-primary-dark);
    background: rgba(255,255,255,.92);
    border: 1px solid var(--shop-border);
    border-radius: 999px;
    font-weight: 700;
    font-size: .86rem;
}
.payment-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 32px;
    padding: 0 4px;
    background: #fff;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.28);
    box-shadow: 0 6px 14px rgba(6, 56, 17, 0.12);
}
.payment-icon svg {
    display: block;
    width: 48px;
    height: 20px;
}
.payment-icon--visa { color: transparent; }
.payment-icon--mastercard,
.payment-icon--ubl,
.payment-icon--jazzcash,
.payment-icon--cod { color: transparent; }
.empty-state { padding: 34px; text-align: center; }
.empty-state h2 { margin: 0 0 10px; }
.empty-state p { color: var(--shop-text-muted); }
.alert { padding: 16px 18px; border-radius: 18px; border: 1px solid; }
.alert--success { color: #166534; background: #ecfdf3; border-color: #bbf7d0; }
.alert--error { color: #9f1239; background: #fff1f2; border-color: #fecdd3; }
.muted { color: var(--shop-text-muted); }
.spaced-list { display: grid; gap: 18px; }
@media (max-width: 1180px) {
    .hero, .detail-layout, .checkout-grid, .footer__top { grid-template-columns: 1fr; }
    .shop-header__row { grid-template-columns: 1fr; }
    .category-grid { grid-template-columns: repeat(4, minmax(0,1fr)); }
    .product-grid { grid-template-columns: repeat(3, minmax(0,1fr)); }
    .page-grid, .card-grid, .cart-layout { grid-template-columns: 1fr; }
    .trust-grid, .info-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
    .shop-nav { flex-direction: column; align-items: stretch; }
    .shop-nav__promo { width: 100%; max-width: none; text-align: center; }
    .shop-quicklink-menu__dropdown { right: auto; left: 0; }
    .shop-nav__dropdown { position: static; margin-top: 12px; width: 100%; }
    .cart-table-head,
    .cart-item-row {
        grid-template-columns: minmax(220px, 1.5fr) minmax(84px, .65fr) minmax(116px, .8fr) minmax(84px, .65fr) 32px;
    }
}
@media (max-width: 860px) {
    .shop-container { width: min(calc(100% - 20px), var(--shop-container)); }
    .shop-header, .hero, .sidebar-panel, .content-panel, .gallery-panel, .detail-panel, .purchase-panel, .info-panel, .summary-card, .list-card, .form-card, .footer__top, .footer__bottom { padding: 20px; }
    .shop-search { grid-template-columns: 1fr; border-radius: 24px; }
    .shop-search__select { border-left: 0; border-top: 1px solid var(--shop-border); }
    .shop-search__button { border-radius: 0 0 24px 24px; }
    .category-grid, .product-grid, .trust-grid, .card-grid, .info-grid, .gallery-thumbs, .option-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
    .profile-form__grid { grid-template-columns: 1fr; }
    .profile-form__actions { justify-content: stretch; }
    .promo-banner { grid-template-columns: 1fr; }
    .toolbar, .footer__bottom { flex-direction: column; align-items: flex-start; }
    .policy-page,
    .policy-page__section { padding: 20px; }
    .policy-page__intro { flex-direction: column; align-items: flex-start; }
    .cart-table-head {
        display: none;
    }
    .cart-item-row {
        grid-template-columns: 1fr;
        gap: 14px;
        align-items: start;
    }
    .cart-item-product {
        grid-template-columns: 72px minmax(0, 1fr);
    }
    .cart-item-price,
    .cart-item-qty,
    .cart-item-total,
    .cart-item-remove {
        padding-left: 88px;
    }
    .cart-item-remove {
        padding-left: 0;
    }
    .simple-table, .simple-table thead, .simple-table tbody, .simple-table th, .simple-table td, .simple-table tr { display: block; }
    .simple-table thead { display: none; }
    .simple-table tr { padding: 12px 0; }
    .simple-table td { padding: 8px 0; border-bottom: 0; }
}
@media (max-width: 560px) {
    .category-grid, .product-grid, .trust-grid, .card-grid, .info-grid { grid-template-columns: 1fr; }
    .hero__stats, .shop-quicklinks, .shop-nav__menu, .shop-nav__left { width: 100%; }
    .shop-quicklink { width: 100%; }
    .shop-nav__menu { gap: 18px; }
    .shop-brand__title { font-size: 1.6rem; }
}

.auth-shell {
    min-height: 100vh;
    display: grid;
    grid-template-columns: minmax(320px, 1.05fr) minmax(360px, 0.95fr);
    background:
        radial-gradient(circle at top left, rgba(191, 236, 183, 0.55), transparent 30%),
        radial-gradient(circle at bottom right, rgba(255, 241, 191, 0.45), transparent 22%),
        linear-gradient(135deg, #f6faf3, #eef8e9 45%, #fdfdf7);
}
.auth-showcase {
    position: relative;
    display: grid;
    align-content: space-between;
    padding: 48px 56px;
    overflow: hidden;
}
.auth-showcase__back {
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 18% 20%, rgba(39, 150, 60, 0.14), transparent 24%),
        radial-gradient(circle at 80% 70%, rgba(255, 122, 0, 0.10), transparent 18%);
}
.auth-showcase__content,
.auth-showcase__cards { position: relative; z-index: 1; }
.auth-showcase__eyebrow {
    display: inline-flex; align-items: center; gap: 10px; min-height: 40px; padding: 0 16px;
    border-radius: 999px; color: var(--shop-primary-dark); background: rgba(255, 255, 255, 0.82);
    border: 1px solid rgba(39, 150, 60, 0.18); font-weight: 700;
}
.auth-showcase__title { max-width: 560px; margin: 20px 0 16px; font-size: clamp(2.6rem, 5vw, 4.6rem); line-height: 1.02; }
.auth-showcase__title strong { color: var(--shop-primary); }
.auth-showcase__text { max-width: 520px; margin: 0; color: var(--shop-text-muted); font-size: 1.06rem; line-height: 1.8; }
.auth-showcase__stats { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; margin-top: 28px; }
.auth-stat {
    padding: 18px 20px; background: rgba(255, 255, 255, 0.84); border: 1px solid rgba(219, 231, 211, 0.9);
    border-radius: 22px; box-shadow: 0 16px 30px rgba(25, 78, 35, 0.06);
}
.auth-stat strong { display: block; margin-bottom: 6px; color: var(--shop-primary-dark); }
.auth-stat span { color: var(--shop-text-muted); font-size: 0.94rem; }
.auth-showcase__cards { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 18px; align-items: end; }
.auth-floating-card {
    padding: 22px 22px 20px; background: rgba(255, 255, 255, 0.88); border: 1px solid rgba(219, 231, 211, 0.95);
    border-radius: 24px; box-shadow: 0 18px 34px rgba(25, 78, 35, 0.08);
}
.auth-floating-card h3, .auth-floating-card h4 { margin: 0 0 10px; }
.auth-floating-card p { margin: 0; color: var(--shop-text-muted); line-height: 1.7; }
.auth-floating-card--offer { transform: translateY(28px); background: linear-gradient(145deg, #fffef8, #f4faee); }
.auth-floating-card__pill {
    display: inline-flex; align-items: center; min-height: 32px; padding: 0 12px; border-radius: 999px;
    color: var(--shop-primary-dark); background: var(--shop-primary-soft); font-weight: 700; font-size: 0.84rem;
}
.auth-panel { display: grid; place-items: center; padding: 36px; }
.auth-card {
    width: min(100%, 520px); padding: 34px; background: rgba(255, 255, 255, 0.95); border: 1px solid rgba(219, 231, 211, 0.95);
    border-radius: 30px; box-shadow: 0 26px 54px rgba(25, 78, 35, 0.12);
}
.auth-brand { display: inline-flex; align-items: center; gap: 14px; }
.auth-brand__mark {
    display: grid; place-items: center; width: 54px; height: 54px; color: #fff; font-size: 1.45rem;
    border-radius: 16px; background: linear-gradient(145deg, var(--shop-primary), var(--shop-primary-dark));
}
.auth-brand__title { display: block; font-size: 1.9rem; font-weight: 800; line-height: 1; }
.auth-brand__title span { color: var(--shop-primary); }
.auth-brand__subtitle { display: block; margin-top: 4px; color: var(--shop-text-muted); }
.auth-card__intro { margin: 22px 0 28px; }
.auth-card__intro h1 { margin: 0 0 10px; font-size: clamp(2rem, 4vw, 2.7rem); }
.auth-card__intro p { margin: 0; color: var(--shop-text-muted); line-height: 1.75; }
.auth-form { display: grid; gap: 18px; }
.auth-form__row { display: grid; gap: 8px; }
.auth-form__footer {
    display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap;
}
.auth-form__actions {
    display: flex;
    align-items: stretch;
    justify-content: stretch;
    margin-top: 8px;
}
.auth-form__links {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 10px;
    border: 1px solid rgba(219, 231, 211, 0.95);
    border-radius: 20px;
    background: linear-gradient(180deg, rgba(246, 251, 243, 0.92), rgba(255, 255, 255, 0.98));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.9);
}
.auth-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 0 18px;
    border-radius: 999px;
    color: var(--shop-primary-dark);
    font-weight: 700;
    transition: 180ms ease;
}
.auth-link:hover {
    color: var(--shop-primary);
    background: rgba(39, 150, 60, 0.08);
}
.auth-checkbox { display: inline-flex; align-items: center; gap: 10px; color: var(--shop-text-muted); }
.auth-checkbox input { width: 18px; height: 18px; accent-color: var(--shop-primary); }
.auth-status { padding: 14px 16px; border-radius: 18px; color: #166534; background: #ecfdf3; border: 1px solid #bbf7d0; }
.auth-errors { margin: 0; padding-left: 18px; color: #b42318; line-height: 1.6; }
.auth-label { font-size: 0.92rem; font-weight: 700; color: var(--shop-text); }
.auth-input {
    width: 100%; min-height: 56px; padding: 0 16px; color: var(--shop-text); background: #fff; border: 1px solid var(--shop-border);
    border-radius: 16px; box-shadow: inset 0 1px 2px rgba(25, 78, 35, 0.04);
}
.auth-input:focus { outline: none; border-color: rgba(39, 150, 60, 0.62); box-shadow: 0 0 0 4px rgba(39, 150, 60, 0.12); }
.auth-button {
    display: inline-flex; align-items: center; justify-content: center; gap: 10px; min-height: 52px; padding: 0 22px; border: 1px solid transparent;
    border-radius: 999px; font-weight: 800; letter-spacing: 0.02em; cursor: pointer; transition: 180ms ease;
}
.auth-button:hover { transform: translateY(-1px); }
.auth-button--primary {
    width: 100%;
    color: #fff;
    background: linear-gradient(135deg, var(--shop-primary), var(--shop-primary-dark));
    box-shadow: 0 16px 32px rgba(39, 150, 60, 0.22);
}
.auth-button--secondary { color: var(--shop-primary-dark); background: rgba(255, 255, 255, 0.92); border-color: var(--shop-border); }
@media (max-width: 1100px) {
    .auth-shell { grid-template-columns: 1fr; }
    .auth-showcase { padding: 38px 24px 10px; }
    .auth-showcase__stats, .auth-showcase__cards { grid-template-columns: 1fr; }
    .auth-floating-card--offer { transform: none; }
    .auth-panel { padding: 12px 18px 36px; }
}
@media (max-width: 640px) {
    .auth-card { padding: 24px; border-radius: 24px; }
    .auth-showcase { padding: 30px 18px 0; }
    .auth-form__footer, .auth-form__actions, .auth-form__links { align-items: stretch; }
    .auth-form__links {
        flex-direction: column;
        padding: 12px;
    }
    .auth-form__actions .auth-button,
    .auth-form__links .auth-link {
        width: 100%;
        text-align: center;
        justify-content: center;
    }
}
.shop-pagination {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-top: 28px;
    padding-top: 18px;
    border-top: 1px solid rgba(219, 231, 211, 0.9);
}
.shop-pagination__meta {
    color: var(--shop-text-muted);
    font-size: 0.95rem;
}
.shop-pagination__controls {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    flex-wrap: wrap;
}
.shop-pagination__button,
.shop-pagination__ellipsis {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 44px;
    height: 44px;
    padding: 0 14px;
    border-radius: 999px;
    border: 1px solid var(--shop-border);
    background: #fff;
    color: var(--shop-text);
    font-weight: 700;
    line-height: 1;
}
.shop-pagination__button:hover {
    border-color: rgba(39, 150, 60, 0.35);
    color: var(--shop-primary-dark);
    transform: translateY(-1px);
}
.shop-pagination__button--active {
    color: #fff;
    background: linear-gradient(135deg, var(--shop-primary), var(--shop-primary-dark));
    border-color: transparent;
}
.shop-pagination__button--disabled {
    color: #9ca3af;
    background: #f8faf7;
    cursor: not-allowed;
}
.shop-pagination__ellipsis {
    min-width: 32px;
    border-color: transparent;
    background: transparent;
    color: var(--shop-text-muted);
}
@media (max-width: 640px) {
    .shop-pagination {
        flex-direction: column;
        align-items: stretch;
    }
    .shop-pagination__meta {
        text-align: center;
    }
}
