/*
  Final marketplace polish layer.
  Adds Digikala-inspired structure without external assets: tighter header, premium cards,
  smoother animations, stronger product media boxes and clearer ecommerce states.
*/
:root {
    --motion-fast: 160ms cubic-bezier(.2,.8,.2,1);
    --motion-smooth: 260ms cubic-bezier(.2,.8,.2,1);
    --card-lift: 0 18px 38px rgba(35,37,78,.11);
    --media-bg: linear-gradient(180deg, var(--surface-muted), var(--surface-subtle));
}

.dk-header { backdrop-filter: saturate(160%) blur(16px); }
.dk-header__servicebar { border-bottom: 1px solid var(--border-soft); background: color-mix(in srgb, var(--surface-strong) 88%, var(--site-accent) 12%); }
.dk-header__servicebar-inner { min-height: 34px; display: flex; align-items: center; justify-content: space-between; gap: 18px; color: var(--text-muted); font-size: .79rem; font-weight: 850; }
.dk-header__servicebar-inner span { display: inline-flex; align-items: center; gap: 7px; white-space: nowrap; }
.dk-header__servicebar-inner .svg-icon { color: var(--site-accent); }
.dk-header__topline { height: 3px; background-size: 240% 100%; animation: dkGradientSlide 9s ease infinite; }
.dk-header__inner { min-height: 76px; }
.dk-brand__logo, .brand-block__logo { box-shadow: 0 10px 24px rgb(var(--site-accent-rgb) / .10); }
.dk-search--premium { height: 50px; border-radius: 14px; box-shadow: inset 0 0 0 1px var(--border-soft); }
.dk-search__hint { height: 24px; min-width: 44px; align-items: center; justify-content: center; border-radius: 8px; background: var(--surface); border: 1px solid var(--border); color: var(--text-faint); font-size: .72rem; font-weight: 900; }
.dk-cart-action { position: relative; }
.dk-cart-action__bubble { position: absolute; inset-block-start: 7px; inset-inline-start: 9px; width: 8px; height: 8px; border-radius: 50%; background: var(--site-accent); box-shadow: 0 0 0 3px var(--surface); }
.dk-navbar { height: 46px; box-shadow: 0 8px 22px rgba(35,37,78,.035); }
.nav-chip::before, .dk-nav-chip::before { content: ""; position: absolute; inset-inline: 12px; inset-block-end: 3px; height: 2px; border-radius: 999px; background: var(--site-accent); transform: scaleX(0); transform-origin: center; transition: transform var(--motion-smooth); }
.nav-chip:hover::before, .dk-nav-chip:hover::before, .nav-chip.active::before { transform: scaleX(1); }

.home-hero, .shop-hero, .cart-hero, .payment-hero, .contact-hero, .cms-page-hero, .category-hero, .admin-hero, .account-hero-card, .product-hero {
    border-radius: 22px;
    box-shadow: 0 8px 26px rgba(35,37,78,.06);
}
.home-hero { min-height: 390px; border: 0; box-shadow: var(--shadow-md); background: radial-gradient(circle at 8% 12%, rgb(var(--site-accent-rgb) / .14), transparent 28rem), linear-gradient(135deg, var(--surface), var(--surface-subtle)); }
.hero-visual-card { box-shadow: inset 0 0 0 1px rgba(255,255,255,.24), 0 24px 52px rgb(var(--site-accent-rgb) / .18); }
.hero-mini-card, .feature-card, .content-card, .testimonial-card, .stat-card, .home-stat-card, .trust-card, .admin-metric-card, .account-stat { transition: transform var(--motion-smooth), box-shadow var(--motion-smooth), border-color var(--motion-smooth), background var(--motion-smooth); }
.hero-mini-card:hover, .feature-card:hover, .content-card:hover, .testimonial-card:hover, .stat-card:hover, .home-stat-card:hover, .trust-card:hover, .admin-metric-card:hover, .account-stat:hover { transform: translateY(-3px); box-shadow: var(--shadow-sm); border-color: rgb(var(--site-accent-rgb) / .22); }

.shop-grid { gap: 0; border: 1px solid var(--border-soft); border-radius: 18px; overflow: hidden; background: var(--surface); box-shadow: var(--shadow-xs); }
.shop-grid > .product-card { border: 0; border-inline-end: 1px solid var(--border-soft); border-bottom: 1px solid var(--border-soft); border-radius: var(--radius-card); box-shadow: none; }
.shop-grid > .product-card:nth-child(4n) { border-inline-end: 0; }
.product-card, .blog-card, .category-card, .favorite-card, .shop-card { position: relative; transition: transform var(--motion-smooth), box-shadow var(--motion-smooth), border-color var(--motion-smooth), background var(--motion-smooth); }
.product-card:hover, .blog-card:hover, .category-card:hover, .favorite-card:hover, .shop-card:hover { transform: translateY(-4px); box-shadow: var(--card-lift); z-index: 2; }
.product-card__media, .shop-card__media { background: var(--media-bg); min-height: 190px; display: grid; place-items: center; }
.product-card__media::after, .shop-card__media::after { content: ""; position: absolute; inset: 10px; border-radius: 14px; border: 1px solid rgba(255,255,255,.44); pointer-events: none; opacity: .56; }
.product-card__media-glow { position: absolute; inset: auto 16% -18% 16%; height: 46%; border-radius: 50%; background: radial-gradient(circle, rgb(var(--site-accent-rgb) / .12), transparent 68%); filter: blur(8px); pointer-events: none; transition: transform var(--motion-smooth), opacity var(--motion-smooth); }
.product-card:hover .product-card__media-glow { transform: scale(1.12); opacity: .85; }
.product-card__discount-badge { position: absolute; inset-block-start: 10px; inset-inline-start: 10px; z-index: 2; min-height: 28px; display: inline-flex; align-items: center; padding: 0 10px; border-radius: 999px; background: var(--site-accent); color: #fff; font-size: .72rem; font-weight: 950; box-shadow: 0 10px 24px rgb(var(--site-accent-rgb) / .26); }
.product-card__body { min-height: 238px; display: flex; flex-direction: column; }
.product-card__meta { min-height: 30px; display: flex; align-items: center; flex-wrap: wrap; gap: 5px; }
.product-card__title a { color: var(--text); }
.product-card__excerpt { min-height: 44px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; margin-top: 6px; }
.product-card__footer { margin-top: auto; align-items: flex-end; }
.product-card__price { display: grid; gap: 2px; }
.product-card__stock { display: inline-flex; align-items: center; gap: 5px; min-height: 28px; padding: 0 9px; border-radius: 999px; background: color-mix(in srgb, var(--success) 10%, var(--surface)); color: var(--success); font-weight: 900; font-size: .75rem; white-space: nowrap; }
.product-card__stock.is-low { background: color-mix(in srgb, var(--warning) 16%, var(--surface)); color: var(--warning); }
.product-card__actions { padding-top: 10px; border-top: 1px solid var(--border-soft); }
.shop-quantity-input { max-width: 72px; text-align: center; }
.category-card { isolation: isolate; }
.category-card::before { content: ""; position: absolute; inset: 0; background: linear-gradient(135deg, rgb(var(--site-accent-rgb) / .075), transparent 58%); opacity: 0; transition: opacity var(--motion-smooth); z-index: -1; }
.category-card:hover::before { opacity: 1; }

.product-hero__layout { grid-template-columns: minmax(360px, 470px) minmax(0, 1fr) !important; display: grid !important; }
.product-media-shell--premium { position: relative; overflow: hidden; background: var(--media-bg); }
.product-media-shell--premium::before { content: ""; position: absolute; inset: -22% auto auto -18%; width: 240px; height: 240px; border-radius: 50%; background: radial-gradient(circle, rgb(var(--site-accent-rgb) / .14), transparent 66%); pointer-events: none; }
.product-media-badges { position: absolute; z-index: 2; inset-block-start: 14px; inset-inline-start: 14px; display: flex; flex-wrap: wrap; gap: 6px; }
.product-main-image { object-fit: contain !important; padding: 18px; background: transparent !important; transition: transform var(--motion-smooth); }
.product-media-shell:hover .product-main-image { transform: scale(1.025); }
.thumb-grid__item { cursor: pointer; transition: transform var(--motion-fast), border-color var(--motion-fast), box-shadow var(--motion-fast); }
.thumb-grid__item:hover { transform: translateY(-2px); border-color: rgb(var(--site-accent-rgb) / .42); box-shadow: var(--shadow-xs); }
.product-side { box-shadow: var(--shadow-sm); }
.product-trust-strip { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 8px; margin: 12px 0 16px; }
.product-trust-strip span { min-height: 42px; display: flex; align-items: center; justify-content: center; gap: 6px; padding: 6px 8px; border-radius: 12px; background: var(--surface-subtle); color: var(--text-muted); border: 1px solid var(--border-soft); font-weight: 850; font-size: .78rem; text-align: center; }
.product-trust-strip .svg-icon { color: var(--site-accent); }
.variant-panel { padding: 12px; border-radius: 14px; border: 1px solid var(--border-soft); background: var(--surface-subtle); }
.variant-panel__title { font-weight: 950; color: var(--text); margin-bottom: 10px; }
.variant-chip-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 8px; }
.variant-chip { padding: 10px; border-radius: 12px; background: var(--surface); border: 1px solid var(--border); display: grid; gap: 2px; }
.variant-chip.is-default { border-color: rgb(var(--site-accent-rgb) / .44); box-shadow: inset 0 0 0 1px rgb(var(--site-accent-rgb) / .16); }
.variant-chip strong { color: var(--text); font-size: .86rem; }
.variant-chip span { color: var(--site-accent); font-weight: 950; }
.variant-chip small { color: var(--text-soft); }
.glass-kv-list { display: grid; gap: 8px; }
.glass-kv-row { min-height: 42px; display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 8px 10px; border-radius: 12px; background: var(--surface-subtle); border: 1px solid var(--border-soft); }
.feature-glass { border-radius: 14px; border: 1px solid var(--border-soft); background: linear-gradient(135deg, var(--surface), var(--surface-subtle)); transition: transform var(--motion-smooth), border-color var(--motion-smooth); }
.feature-glass:hover { transform: translateY(-2px); border-color: rgb(var(--site-accent-rgb) / .28); }

.dk-footer { padding-top: 22px; }
.dk-footer-services { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 10px; margin-bottom: 24px; }
.dk-footer-service { min-height: 86px; display: grid; place-items: center; align-content: center; gap: 3px; text-align: center; border-radius: 16px; background: var(--surface-subtle); border: 1px solid var(--border-soft); color: var(--text-muted); }
.dk-footer-service .svg-icon { color: var(--site-accent); margin-bottom: 4px; }
.dk-footer-service strong { color: var(--text); font-weight: 950; }
.dk-footer-service span { font-size: .78rem; }
.footer-links a { position: relative; padding-inline-start: 10px; }
.footer-links a::before { content: ""; position: absolute; inset-inline-start: 0; inset-block: .72em auto; width: 4px; height: 4px; border-radius: 50%; background: var(--site-accent); opacity: .55; }

@keyframes dkGradientSlide { 0%,100% { background-position: 0 50%; } 50% { background-position: 100% 50%; } }
@keyframes softEnter { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
.page-card, .product-card, .blog-card, .category-card, .favorite-card, .admin-metric-card, .settings-panel { animation: softEnter .32s ease both; }

@media (max-width: 1199.98px) {
    .dk-bottom-nav { grid-template-columns: repeat(5, 1fr); height: 66px; }
    .shop-grid > .product-card:nth-child(4n) { border-inline-end: 1px solid var(--border-soft); }
    .shop-grid > .product-card:nth-child(3n) { border-inline-end: 0; }
    .product-hero__layout { grid-template-columns: 1fr !important; }
    .dk-footer-services { grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 767.98px) {
    .shop-grid { border-radius: 14px; }
    .shop-grid > .product-card { border-inline-end: 0 !important; }
    .product-card__media, .shop-card__media { min-height: 170px; padding: 10px; }
    .product-card__body { min-height: auto; }
    .product-card__meta .badge:nth-child(n+3) { display: none; }
    .product-card__excerpt { display: none; }
    .product-card__stock { font-size: .7rem; padding-inline: 7px; }
    .product-trust-strip, .variant-chip-grid { grid-template-columns: 1fr; }
    .dk-footer-services { grid-template-columns: 1fr; }
}
@media (max-width: 420px) {
    .shop-grid { grid-template-columns: 1fr !important; }
    .dk-bottom-nav a { font-size: .68rem; }
}
@media (prefers-reduced-motion: reduce) {
    .dk-header__topline, .page-card, .product-card, .blog-card, .category-card, .favorite-card, .admin-metric-card, .settings-panel { animation: none !important; }
}

/* Requested polish fixes: rounded cards everywhere, cleaner dynamic home, product detail, blog, forms and dynamic footer. */
:root {
    --radius-card: 22px;
    --radius-media: 18px;
    --radius-field: 14px;
}

/* 1) هیچ کارت یا باکس تعاملی گوشه تیز نداشته باشد */
.page-card, .card, .content-card, .shop-card, .blog-card, .product-card, .category-card, .favorite-card,
.admin-metric-card, .settings-panel, .contact-panel, .payment-card, .stat-card, .home-stat-card, .trust-card,
.account-stat, .feature-card, .testimonial-card, .variant-panel, .variant-chip, .feature-glass, .glass-kv-row,
.comment-summary-card, .comment-modal-card, .modal-content, .alert, .table-responsive, .dropdown-menu,
.dk-footer-service, .footer-trust__item, .mobile-menu-panel, .shop-filter-panel, .product-side, .product-info-card {
    border-radius: var(--radius-card) !important;
}

.shop-grid {
    gap: 14px !important;
    border: 0 !important;
    overflow: visible !important;
    background: transparent !important;
    box-shadow: none !important;
}
.shop-grid > .product-card {
    border: 1px solid var(--border-soft) !important;
    border-radius: var(--radius-card) !important;
    box-shadow: var(--shadow-xs) !important;
    overflow: hidden !important;
}
.shop-grid > .product-card:nth-child(n) { border-inline-end: 1px solid var(--border-soft) !important; }

.product-card__media, .shop-card__media, .blog-card__media, .favorite-card__media, .category-card__media,
.product-media-shell, .hero-visual-card, .footer-enamad, .footer-socials__item {
    border-radius: var(--radius-media) !important;
    overflow: hidden;
}
.product-card__media::after, .shop-card__media::after { border-radius: 15px !important; }
.btn, .icon-button, .header-action, .nav-chip, .dk-nav-chip, .badge, .status-pill, .chip-soft, .filter-chip,
.quantity-stepper, .quantity-stepper__btn { border-radius: 999px !important; }

/* 2) کارت داینامیک صفحه اصلی */
.hero-visual-card--dynamic {
    min-height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 18px;
    background: radial-gradient(circle at 80% 10%, rgb(var(--site-accent-rgb) / .18), transparent 34%), linear-gradient(145deg, var(--surface), var(--surface-subtle));
    border: 1px solid var(--border-soft);
    color: var(--text);
}
.hero-mini-grid--dynamic { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.hero-mini-grid--dynamic .hero-mini-card {
    min-height: 86px;
    align-content: center;
    background: color-mix(in srgb, var(--surface) 88%, var(--site-accent) 12%);
    border: 1px solid rgb(var(--site-accent-rgb) / .14);
}
.hero-mini-card strong { display: block; color: var(--text); font-size: 1.25rem; font-weight: 950; line-height: 1; }

/* 3) بازطراحی جزئیات محصول */
.product-detail-hero { padding: 18px !important; }
.product-detail-layout {
    display: grid;
    grid-template-columns: minmax(300px, 45%) minmax(0, 1fr);
    gap: 18px;
    align-items: stretch;
}
.product-detail-gallery, .product-detail-buybox { min-width: 0; }
.product-detail-title { font-size: clamp(1.35rem, 2.7vw, 2.4rem); letter-spacing: -.035em; }
.product-media-shell--premium {
    min-height: 520px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 18px;
    border: 1px solid var(--border-soft);
    box-shadow: var(--shadow-xs);
}
.product-main-image {
    width: 100%;
    height: min(55vh, 430px) !important;
    object-fit: contain !important;
    border-radius: 16px !important;
}
.thumb-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(68px, 1fr)); gap: 10px; }
.thumb-grid__item {
    aspect-ratio: 1;
    padding: 5px;
    background: var(--surface);
    border: 1px solid var(--border-soft);
    border-radius: 16px !important;
    overflow: hidden;
}
.product-buybox {
    background: linear-gradient(180deg, var(--surface), var(--surface-subtle));
    border: 1px solid var(--border-soft);
}
.product-price-panel {
    padding: 14px;
    border-radius: 18px;
    border: 1px solid var(--border-soft);
    background: var(--surface);
}
.product-action-panel { display: grid; gap: 10px; }
.product-detail-content-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);
    gap: 18px;
    align-items: start;
}
.product-detail-main, .product-detail-aside { min-width: 0; }
.product-info-card { border: 1px solid var(--border-soft); box-shadow: var(--shadow-xs); }

/* 4) بازطراحی بلاگ و عکس‌های منسجم */
.blog-hero-card {
    position: relative;
    overflow: hidden;
    border: 1px solid var(--border-soft);
    background: radial-gradient(circle at 10% 10%, rgb(var(--site-accent-rgb) / .12), transparent 28rem), linear-gradient(135deg, var(--surface), var(--surface-subtle));
}
.blog-grid--polished {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
    margin-top: 20px;
}
.blog-card--polished {
    display: flex;
    flex-direction: column;
    border: 1px solid var(--border-soft);
    box-shadow: var(--shadow-xs);
}
.blog-card--polished .blog-card__media {
    aspect-ratio: 16 / 9;
    min-height: unset;
    background: var(--media-bg);
    display: block;
    padding: 0;
}
.blog-card--polished .blog-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.blog-card__fallback {
    width: 100%;
    height: 100%;
    display: grid;
    place-items: center;
    align-content: center;
    gap: 12px;
    padding: 20px;
    text-align: center;
    color: var(--text-muted);
    background: linear-gradient(135deg, var(--surface-subtle), color-mix(in srgb, var(--surface) 82%, var(--site-accent) 18%));
}
.blog-card__fallback .svg-icon { color: var(--site-accent); }
.blog-card__fallback-title { color: var(--text); font-weight: 950; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.blog-card__body { flex: 1; display: grid; gap: 14px; align-content: start; }
.blog-card__footer { margin-top: auto; display: flex; align-items: center; justify-content: space-between; gap: 12px; padding-top: 12px; border-top: 1px solid var(--border-soft); }
.blog-card--polished:hover .blog-card__media img { transform: scale(1.035); }

/* 5) نظم فیلدها در همه صفحات */
.form-control, .form-select, textarea, input[type="text"], input[type="email"], input[type="password"], input[type="number"], input[type="tel"], input[type="search"], select {
    border-radius: var(--radius-field) !important;
    min-height: 46px;
    line-height: 1.6;
}
textarea.form-control, textarea { min-height: 118px; resize: vertical; }
.form-label { display: block; min-height: 22px; }
.field-stack, .form-field, .settings-field { display: grid; gap: 7px; }
.input-group { gap: 8px; align-items: stretch; }
.input-group > .form-control, .input-group > .form-select, .input-group > .input-group-text {
    border-radius: var(--radius-field) !important;
}
.row.g-3 > [class*="col"], .row.g-4 > [class*="col"] { min-width: 0; }
.inline-edit, .form-control.inline-edit { border-radius: var(--radius-field) !important; }

/* 6) فوتر داینامیک: شبکه‌های اجتماعی و اینماد/تصویر اعتماد */
.dk-footer__grid--dynamic { grid-template-columns: minmax(260px, 1.4fr) repeat(auto-fit, minmax(180px, .7fr)); align-items: start; }
.footer-brand__description--muted { opacity: .82; margin-top: -4px; }
.footer-socials { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 14px; }
.footer-socials__item {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    min-height: 38px;
    padding: 0 12px;
    color: var(--text-muted);
    background: var(--surface-subtle);
    border: 1px solid var(--border-soft);
    font-weight: 900;
    font-size: .84rem;
}
.footer-socials__item:hover { color: var(--site-accent); border-color: rgb(var(--site-accent-rgb) / .28); transform: translateY(-2px); }
.footer-enamad {
    width: 112px;
    min-height: 112px;
    margin-top: 12px;
    padding: 10px !important;
    display: grid !important;
    place-items: center;
    background: var(--surface);
    border: 1px solid var(--border-soft);
    box-shadow: var(--shadow-xs);
}
.footer-enamad::before { display: none !important; }
.footer-enamad img { max-width: 100%; max-height: 92px; object-fit: contain; display: block; border-radius: 12px; }

@media (max-width: 1199.98px) {
    .product-detail-layout, .product-detail-content-grid { grid-template-columns: 1fr; }
    .product-media-shell--premium { min-height: 420px; }
    .blog-grid--polished { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 767.98px) {
    .home-hero { min-height: unset; }
    .hero-mini-grid--dynamic { grid-template-columns: 1fr 1fr; }
    .product-detail-hero { padding: 12px !important; }
    .product-media-shell--premium { min-height: 320px; padding: 12px; }
    .product-main-image { height: 300px !important; }
    .product-trust-strip { grid-template-columns: 1fr; }
    .product-detail-content-grid { gap: 14px; }
    .blog-grid--polished { grid-template-columns: 1fr; gap: 14px; }
    .blog-card__footer { align-items: stretch; flex-direction: column; }
    .blog-card__footer .btn { width: 100%; }
    .dk-footer__grid--dynamic { grid-template-columns: 1fr; }
}
@media (max-width: 420px) {
    .hero-mini-grid--dynamic { grid-template-columns: 1fr; }
    .product-main-image { height: 250px !important; }
}

.product-detail-layout.product-hero__layout { grid-template-columns: minmax(300px, 45%) minmax(0, 1fr) !important; display: grid !important; }
@media (max-width:1199.98px){ .product-detail-layout.product-hero__layout { grid-template-columns: 1fr !important; } }

/* Final precision pass: rounded product cards, proportional grids, spacing normalization, blog/product detail polish. */
:root {
    --ui-gap-xs: 8px;
    --ui-gap-sm: 12px;
    --ui-gap-md: 16px;
    --ui-gap-lg: 22px;
    --ui-card-radius: 24px;
    --ui-media-radius: 20px;
}

/* 1) کارت‌های فروشگاه و صفحه اصلی بدون هیچ گوشه تیز */
.product-card,
.shop-grid > .product-card,
.page-card.product-card,
.blog-card,
.page-card.blog-card,
.shop-card,
.category-card,
.favorite-card,
.stat-card,
.home-stat-card,
.trust-card,
.feature-card,
.content-card,
.product-side,
.product-media-shell,
.product-buybox,
.product-price-panel,
.variant-panel,
.blog-article-layout,
.blog-article-aside,
.blog-article-hero-media,
.footer-enamad,
.footer-socials__item {
    border-radius: var(--ui-card-radius) !important;
}

.product-card,
.shop-grid > .product-card,
.page-card.product-card,
.blog-card,
.page-card.blog-card {
    overflow: hidden !important;
    isolation: isolate;
    background: var(--surface) !important;
    border: 1px solid var(--border-soft) !important;
}

.product-card__media,
.shop-card__media,
.blog-card__media,
.favorite-card__media,
.category-card__media,
.product-main-image,
.thumb-grid__item,
.product-card__media img,
.shop-card__media img,
.blog-card__media img,
.favorite-card__media img,
.category-card__media img {
    border-radius: var(--ui-media-radius) !important;
}

.product-card__media,
.shop-card__media {
    margin: 12px 12px 0;
    width: calc(100% - 24px);
    overflow: hidden !important;
    border: 1px solid var(--border-soft);
    background: linear-gradient(145deg, var(--surface-subtle), var(--surface));
}

.product-card__media img,
.shop-card__media img {
    width: 100%;
    height: 100%;
    object-fit: contain !important;
    padding: 10px;
}

.product-card__media::after,
.shop-card__media::after {
    inset: 8px !important;
    border-radius: 16px !important;
}

/* 2) فاصله‌ها استاندارد و یکدست شوند؛ نه فشرده، نه بیش از حد باز */
.page-section { margin-top: var(--ui-gap-lg) !important; }
.section-heading { margin-bottom: var(--ui-gap-md) !important; gap: var(--ui-gap-md) !important; }
.home-hero,
.shop-hero,
.cart-hero,
.payment-hero,
.contact-hero,
.cms-page-hero,
.category-hero,
.admin-hero,
.account-hero-card,
.product-hero {
    padding: clamp(16px, 2vw, 24px) !important;
}

.product-card__body,
.blog-card__body,
.shop-card__body,
.favorite-card__body {
    padding: 14px !important;
    gap: var(--ui-gap-sm);
}

.product-card__meta,
.d-flex.flex-wrap.gap-2,
.shop-hero__chips,
.product-action-panel,
.variant-chip-grid,
.product-trust-strip,
.footer-socials,
.dk-footer-trust,
.hero-actions {
    gap: var(--ui-gap-sm) !important;
}

.row.g-3 { --bs-gutter-x: var(--ui-gap-md); --bs-gutter-y: var(--ui-gap-md); }
.row.g-4 { --bs-gutter-x: var(--ui-gap-lg); --bs-gutter-y: var(--ui-gap-lg); }

.form-label { margin-bottom: 6px !important; }
.form-control,
.form-select,
textarea,
.input-group-text {
    min-height: 46px !important;
    padding-inline: 13px !important;
}

/* 3) گرید کارت‌ها: اندازه‌ها براساس اهمیت تغییر می‌کنند، نه هم‌اندازه‌ی خشک */
.shop-grid {
    display: grid !important;
    grid-template-columns: repeat(12, minmax(0, 1fr)) !important;
    grid-auto-flow: dense;
    gap: var(--ui-gap-md) !important;
    align-items: stretch;
}

.shop-grid > .product-card {
    grid-column: span 3;
    min-height: 100%;
    display: flex;
    flex-direction: column;
}

.shop-grid > .product-card:nth-child(12n + 1) {
    grid-column: span 6;
    grid-row: span 2;
}

.shop-grid > .product-card:nth-child(12n + 2),
.shop-grid > .product-card:nth-child(12n + 3) {
    grid-column: span 3;
}

.shop-grid > .product-card:nth-child(12n + 4),
.shop-grid > .product-card:nth-child(12n + 5),
.shop-grid > .product-card:nth-child(12n + 6) {
    grid-column: span 4;
}

.shop-grid > .product-card:nth-child(12n + 7),
.shop-grid > .product-card:nth-child(12n + 8) {
    grid-column: span 6;
}

.shop-grid > .product-card:nth-child(12n + 1) .product-card__media { min-height: 320px; }
.shop-grid > .product-card:nth-child(12n + 4) .product-card__media,
.shop-grid > .product-card:nth-child(12n + 5) .product-card__media,
.shop-grid > .product-card:nth-child(12n + 6) .product-card__media { min-height: 230px; }
.shop-grid > .product-card:nth-child(12n + 7) .product-card__media,
.shop-grid > .product-card:nth-child(12n + 8) .product-card__media { min-height: 260px; }

.shop-grid > .product-card:nth-child(12n + 1) .product-card__title { font-size: 1.08rem; min-height: auto; }
.shop-grid > .product-card:nth-child(12n + 1) .product-card__excerpt { -webkit-line-clamp: 3; min-height: 66px; }
.shop-grid > .product-card:nth-child(12n + 1) .product-card__body { padding: 18px !important; }

.product-card__body { min-height: unset !important; flex: 1; display: flex !important; flex-direction: column; }
.product-card__title { min-height: unset !important; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.product-card__excerpt { min-height: unset !important; margin: 4px 0 0 !important; }
.product-card__stock-row,
.product-card__footer { margin-top: auto !important; }
.product-card__footer + .product-card__actions,
.product-card__actions { margin-top: var(--ui-gap-sm) !important; }

/* 4) منطقه زمانی از ظاهر حذف شده؛ این پشتیبان CSS برای نسخه‌های کش‌شده/کامپوننت‌های مشابه است */
.timezone-field,
[data-field="timezone"],
.form-field--timezone {
    display: none !important;
}

/* 5) تصویر جزئیات بلاگ: قاب 4:3 با عرض بیشتر، بدون تصویر غول‌پیکر */
.blog-article-layout {
    gap: var(--ui-gap-lg) !important;
}

.blog-article-main {
    gap: var(--ui-gap-md) !important;
}

.blog-article-hero-media {
    width: min(100%, 760px);
    aspect-ratio: 4 / 3;
    margin: 0 auto var(--ui-gap-sm);
    overflow: hidden;
    border: 1px solid var(--border-soft);
    background: var(--surface-subtle);
    box-shadow: var(--shadow-xs);
}

.blog-article-hero-media .blog-article-hero-image,
.blog-article-hero-image {
    width: 100% !important;
    height: 100% !important;
    max-height: none !important;
    object-fit: cover !important;
    display: block;
    border-radius: inherit !important;
    margin: 0 !important;
}

.blog-article-content img {
    border-radius: var(--ui-media-radius) !important;
    max-height: 520px;
    object-fit: cover;
}

/* 6) جزئیات محصول: چیدمان متعادل‌تر، عکس بهتر، فاصله‌های دقیق‌تر */
.product-detail-hero {
    overflow: visible !important;
    margin-bottom: var(--ui-gap-lg) !important;
}

.product-detail-layout.product-hero__layout,
.product-detail-layout {
    grid-template-columns: minmax(330px, 42%) minmax(0, 1fr) !important;
    gap: var(--ui-gap-lg) !important;
    align-items: start !important;
}

.product-detail-gallery,
.product-detail-buybox {
    min-width: 0;
}

.product-media-shell--premium,
.product-media-shell {
    padding: 16px !important;
    min-height: unset !important;
    background: linear-gradient(145deg, var(--surface), var(--surface-subtle));
    border: 1px solid var(--border-soft);
    box-shadow: var(--shadow-xs);
}

.product-media-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 12px;
}

.product-main-image {
    width: 100% !important;
    height: clamp(310px, 42vw, 500px) !important;
    aspect-ratio: 1 / 1 !important;
    object-fit: contain !important;
    background: var(--surface) !important;
    border: 1px solid var(--border-soft);
    padding: clamp(10px, 1.5vw, 18px);
}

.thumb-grid {
    grid-template-columns: repeat(auto-fill, minmax(64px, 1fr)) !important;
    gap: 10px !important;
    margin-top: 12px !important;
}

.thumb-grid__item {
    background: var(--surface) !important;
    border: 1px solid var(--border-soft) !important;
    transition: transform var(--motion-smooth), border-color var(--motion-smooth), box-shadow var(--motion-smooth);
}

.thumb-grid__item:hover {
    transform: translateY(-2px);
    border-color: rgb(var(--site-accent-rgb) / .35) !important;
    box-shadow: var(--shadow-xs);
}

.product-buybox,
.product-side {
    padding: clamp(16px, 2vw, 22px) !important;
}

.product-detail-title {
    font-size: clamp(1.3rem, 2.2vw, 2rem) !important;
    line-height: 1.45 !important;
    margin-bottom: 8px !important;
}

.product-trust-strip {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin: var(--ui-gap-md) 0 !important;
}

.product-trust-strip span,
.variant-chip,
.feature-glass,
.glass-kv-row {
    border-radius: 18px !important;
}

.product-price-panel,
.price-box.product-price-panel {
    position: static !important;
    margin-bottom: var(--ui-gap-md) !important;
    padding: var(--ui-gap-md) !important;
}

.product-action-panel .btn,
.product-action-panel .form-control,
.quantity-stepper--wide {
    min-height: 48px !important;
}

.product-detail-content-grid {
    gap: var(--ui-gap-lg) !important;
}

.product-detail-main > .page-card,
.product-detail-aside > .page-card {
    margin-bottom: var(--ui-gap-md) !important;
}

@media (max-width: 1199.98px) {
    .shop-grid > .product-card { grid-column: span 4; }
    .shop-grid > .product-card:nth-child(12n + 1),
    .shop-grid > .product-card:nth-child(12n + 7),
    .shop-grid > .product-card:nth-child(12n + 8) { grid-column: span 6; grid-row: auto; }
    .shop-grid > .product-card:nth-child(12n + 4),
    .shop-grid > .product-card:nth-child(12n + 5),
    .shop-grid > .product-card:nth-child(12n + 6) { grid-column: span 4; }
    .product-detail-layout.product-hero__layout,
    .product-detail-layout { grid-template-columns: 1fr !important; }
    .product-trust-strip { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

@media (max-width: 767.98px) {
    :root { --ui-card-radius: 18px; --ui-media-radius: 15px; }
    .shop-grid { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; gap: 10px !important; }
    .shop-grid > .product-card,
    .shop-grid > .product-card:nth-child(n) { grid-column: span 1 !important; grid-row: auto !important; }
    .shop-grid > .product-card:nth-child(6n + 1) { grid-column: span 2 !important; }
    .shop-grid > .product-card:nth-child(6n + 1) .product-card__media { min-height: 230px; }
    .shop-grid > .product-card:nth-child(n) .product-card__media { min-height: 150px; }
    .product-card__media,
    .shop-card__media { margin: 8px 8px 0; width: calc(100% - 16px); }
    .product-card__body,
    .blog-card__body,
    .shop-card__body { padding: 10px !important; }
    .product-card__meta { gap: 5px !important; }
    .product-card__title { font-size: .9rem !important; }
    .product-card__footer { align-items: stretch !important; }
    .blog-article-hero-media { width: 100%; }
    .product-main-image { height: clamp(260px, 72vw, 340px) !important; }
    .product-trust-strip { grid-template-columns: 1fr !important; }
    .product-detail-content-grid { grid-template-columns: 1fr !important; gap: var(--ui-gap-md) !important; }
    .thumb-grid { grid-template-columns: repeat(4, minmax(0, 1fr)) !important; }
}

@media (max-width: 420px) {
    .shop-grid { grid-template-columns: 1fr !important; }
    .shop-grid > .product-card,
    .shop-grid > .product-card:nth-child(n) { grid-column: span 1 !important; }
}

/* === Final mandatory 10-point UI/UX repair pass === */
:root {
    --space-1: .25rem;
    --space-2: .5rem;
    --space-3: .75rem;
    --space-4: 1rem;
    --space-5: 1.25rem;
    --space-6: 1.5rem;
    --space-8: 2rem;
    --radius-card: 24px;
    --radius-media: 20px;
    --radius-field: 16px;
}

.dk-main > .page-frame { display: grid; gap: var(--space-6); }
.page-section { margin-block: var(--space-6) !important; }
.page-card, .product-card, .blog-card, .category-card, .cart-item-card, .contact-panel,
.contact-form-card, .contact-thread-card, .shop-toolbar, .shop-filter-panel, .product-side,
.product-media-shell, .blog-article-aside, .cms-page-body, .cms-page-hero,
.card, .modal-content, .dropdown-menu, .list-group-item, .alert, .table-responsive {
    border-radius: var(--radius-card) !important;
}

/* absolutely remove sharp product images in / and /shop */
.product-card, .shop-card { overflow: hidden !important; }
.product-card__media, .shop-card__media, .product-card__media > img, .shop-card__media > img,
.product-card__media .product-image-fallback, .shop-card__media .product-image-fallback {
    border-radius: var(--radius-media) !important;
    overflow: hidden !important;
}
.product-card__media > img, .shop-card__media > img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: contain !important;
    background: var(--media-bg) !important;
    padding: 10px;
    clip-path: inset(0 round var(--radius-media));
}
.product-card__media { background: var(--media-bg); padding: 10px !important; }
.product-card__media::before, .product-card__media::after { border-radius: var(--radius-media) !important; }

/* standard spacing and field layout everywhere */
.row { --bs-gutter-x: 1rem; --bs-gutter-y: 1rem; }
.d-grid.gap-4 { gap: var(--space-6) !important; }
.d-grid.gap-3 { gap: var(--space-4) !important; }
.form-control, .form-select, textarea.form-control, .input-with-icon, .inline-edit {
    border-radius: var(--radius-field) !important;
    min-height: 46px;
}
textarea.form-control { min-height: 112px; }
.field { display: grid; gap: .45rem; }
.form-label { margin-bottom: 0 !important; font-weight: 800; color: var(--text-muted); }
.btn { min-height: 42px; display: inline-flex; align-items: center; justify-content: center; gap: .45rem; }

/* simpler functional /shop top area: no extra marketing noise */
.shop-toolbar {
    display: grid;
    grid-template-columns: minmax(180px, 240px) minmax(0, 1fr);
    gap: var(--space-4);
    align-items: end;
    padding: var(--space-5);
    margin-bottom: 0 !important;
}
.shop-toolbar__title { display: grid; gap: .35rem; }
.shop-toolbar__filters {
    display: grid;
    grid-template-columns: minmax(170px, 1.2fr) minmax(150px, .85fr) auto auto auto;
    gap: var(--space-3);
    align-items: end;
}
.shop-toolbar__toggle {
    align-self: stretch;
    min-height: 46px;
    padding: 0 14px;
    border: 1px solid var(--border-soft);
    border-radius: var(--radius-field);
    background: var(--surface-subtle);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    white-space: nowrap;
}
.shop-hero, .blog-hero-card, .category-hero, .cart-hero, .contact-hero { padding: var(--space-5) !important; }

/* masonry-like marketplace cards: large + two medium + compact, responsive */
.shop-grid {
    display: grid !important;
    grid-template-columns: repeat(12, minmax(0, 1fr)) !important;
    gap: var(--space-4) !important;
    align-items: stretch;
}
.shop-grid > .product-card {
    grid-column: span 3;
    min-height: 420px;
    display: flex;
    flex-direction: column;
}
.shop-grid > .product-card:nth-child(10n + 1) { grid-column: span 6; min-height: 460px; }
.shop-grid > .product-card:nth-child(10n + 2),
.shop-grid > .product-card:nth-child(10n + 3) { grid-column: span 3; min-height: 460px; }
.shop-grid > .product-card:nth-child(10n + 4),
.shop-grid > .product-card:nth-child(10n + 5),
.shop-grid > .product-card:nth-child(10n + 6) { grid-column: span 4; }
.product-card__body { flex: 1; display: flex; flex-direction: column; gap: .8rem; padding: 14px !important; }
.product-card__footer { margin-top: auto; }
.product-card__actions { margin-top: .25rem; gap: .6rem !important; }
.shop-grid > .product-card:nth-child(10n + 1) .product-card__media { min-height: 260px; }
.shop-grid > .product-card:nth-child(10n + 2) .product-card__media,
.shop-grid > .product-card:nth-child(10n + 3) .product-card__media { min-height: 240px; }

/* homepage product grid uses same non-uniform rhythm */
.home-product-grid, section .shop-grid { margin-top: 0; }

/* blog listing and blog detail: coherent Digikala-like editorial cards */
.blog-grid--polished, .blog-grid {
    display: grid !important;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    gap: var(--space-4) !important;
}
.blog-grid > .blog-card { grid-column: span 4; display: flex; flex-direction: column; }
.blog-grid > .blog-card:nth-child(7n + 1) { grid-column: span 6; }
.blog-grid > .blog-card:nth-child(7n + 2), .blog-grid > .blog-card:nth-child(7n + 3) { grid-column: span 3; }
.blog-card__media, .blog-card__media img, .blog-card__fallback {
    aspect-ratio: 4 / 3 !important;
    border-radius: var(--radius-media) !important;
    overflow: hidden !important;
}
.blog-card__media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.blog-card__body { flex: 1; display: flex; flex-direction: column; gap: .85rem; }
.blog-card__footer { margin-top: auto; display: flex; justify-content: space-between; gap: .75rem; align-items: center; }
.blog-article-layout {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 340px);
    gap: var(--space-5) !important;
    align-items: start;
}
.blog-article-hero-media {
    width: min(760px, 100%);
    aspect-ratio: 4 / 3 !important;
    margin: 0 auto var(--space-4) !important;
    border-radius: var(--radius-media) !important;
    overflow: hidden !important;
    background: var(--media-bg);
}
.blog-article-hero-image { width: 100%; height: 100%; object-fit: cover; display: block; }
.blog-article-aside { position: sticky; top: 1rem; border: 1px solid var(--border-soft); background: var(--surface-subtle); }
.blog-article-content { line-height: 2; color: var(--text); }
.blog-article-content img { max-width: 100%; border-radius: var(--radius-media); }

/* product details: cleaner media, tighter spacing, more professional buybox */
.product-detail-layout {
    grid-template-columns: minmax(320px, 42%) minmax(0, 1fr) !important;
    gap: var(--space-5) !important;
}
.product-media-shell--premium {
    min-height: 480px !important;
    padding: var(--space-4) !important;
    display: grid !important;
    grid-template-rows: minmax(300px, 1fr) auto;
    gap: var(--space-3);
    align-items: center;
}
.product-main-image {
    width: 100% !important;
    height: min(430px, 52vh) !important;
    object-fit: contain !important;
    border-radius: var(--radius-media) !important;
    padding: 12px !important;
    background: var(--media-bg) !important;
    clip-path: inset(0 round var(--radius-media));
}
.thumb-grid { grid-template-columns: repeat(auto-fill, minmax(62px, 1fr)) !important; gap: .6rem !important; }
.thumb-grid__item, .thumb-grid__item img { border-radius: 16px !important; overflow: hidden; }
.product-buybox { display: grid; gap: var(--space-3); }
.product-trust-strip { margin: .25rem 0 .5rem !important; }
.product-price-panel { margin-bottom: var(--space-3) !important; }
.product-detail-content-grid { gap: var(--space-5) !important; margin-top: var(--space-5); }
.feature-glass, .glass-kv-row { min-height: 44px; }

/* cart, checkout, contact, category pages get consistent card positioning */
.cart-item-card, .cart-summary, .checkout-card, .payment-card, .contact-form-card, .contact-panel, .category-card {
    border: 1px solid var(--border-soft);
    box-shadow: var(--shadow-xs);
}
.product-line-thumb, .product-line-thumb img, .product-line-thumb__fallback {
    border-radius: 18px !important;
    overflow: hidden !important;
}
.category-grid {
    display: grid !important;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    gap: var(--space-4) !important;
}
.category-grid > .category-card { grid-column: span 4; }
.category-grid > .category-card:nth-child(5n + 1) { grid-column: span 6; }
.category-grid > .category-card:nth-child(5n + 2), .category-grid > .category-card:nth-child(5n + 3) { grid-column: span 3; }

/* dynamic header/footer service rows */
.dk-header__servicebar-inner { justify-content: center !important; gap: clamp(1rem, 4vw, 3rem) !important; }
.dk-footer-services { gap: var(--space-4) !important; }
.dk-footer-service { padding: var(--space-4); min-height: 96px; }
.dynamic-service-row, .settings-subsection, .footer-social-editor { border-radius: 18px !important; }

/* CMS pages must look like real pages */
.cms-page-hero { margin-bottom: 0 !important; }
.cms-page-body { max-width: 980px; margin-inline: auto; line-height: 2; }
.cms-page-body img { max-width: 100%; border-radius: var(--radius-media); }
.cms-page-body table { width: 100%; border-collapse: separate; border-spacing: 0; overflow: hidden; border-radius: var(--radius-media); }

@media (max-width: 1199.98px) {
    .shop-toolbar { grid-template-columns: 1fr; }
    .shop-toolbar__filters { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .shop-grid > .product-card, .shop-grid > .product-card:nth-child(n) { grid-column: span 4; }
    .blog-grid > .blog-card, .blog-grid > .blog-card:nth-child(n) { grid-column: span 6; }
    .category-grid > .category-card, .category-grid > .category-card:nth-child(n) { grid-column: span 6; }
    .product-detail-layout, .product-detail-content-grid, .blog-article-layout { grid-template-columns: 1fr !important; }
    .blog-article-aside { position: static; }
}
@media (max-width: 767.98px) {
    .dk-main > .page-frame { gap: var(--space-4); }
    .page-card, .shop-toolbar, .product-card, .blog-card { border-radius: 18px !important; }
    .shop-toolbar { padding: var(--space-4); }
    .shop-toolbar__filters { grid-template-columns: 1fr; }
    .shop-grid, .blog-grid, .category-grid { grid-template-columns: 1fr !important; gap: var(--space-3) !important; }
    .shop-grid > .product-card, .shop-grid > .product-card:nth-child(n),
    .blog-grid > .blog-card, .blog-grid > .blog-card:nth-child(n),
    .category-grid > .category-card, .category-grid > .category-card:nth-child(n) { grid-column: auto !important; min-height: auto; }
    .product-card__media { min-height: 190px !important; }
    .product-media-shell--premium { min-height: auto !important; }
    .product-main-image { height: 280px !important; }
    .blog-article-hero-media { width: 100%; }
}

/* === Formal enterprise UI normalization === */
:root {
    --formal-space-1: 4px;
    --formal-space-2: 8px;
    --formal-space-3: 12px;
    --formal-space-4: 16px;
    --formal-space-5: 20px;
    --formal-space-6: 24px;
    --formal-radius-card: 8px;
    --formal-radius-control: 8px;
    --formal-radius-media: 8px;
    --formal-shadow: 0 1px 2px rgba(16, 24, 40, .06), 0 1px 3px rgba(16, 24, 40, .08);
    --formal-shadow-hover: 0 8px 20px rgba(16, 24, 40, .08);
}

h1, h2, h3, h4, h5, h6,
.hero-title,
.dashboard-title,
.section-heading h1,
.section-heading h2,
.section-heading h3,
.dk-brand__name,
.brand-block__name {
    letter-spacing: 0 !important;
}

.hero-title {
    font-size: 2rem !important;
    line-height: 1.35 !important;
}

.home-hero .hero-title { font-size: 2.25rem !important; }
.product-detail-title { font-size: 1.8rem !important; }
.display-6 { font-size: 1.55rem !important; line-height: 1.35; }

.page-card,
.card,
.content-card,
.shop-card,
.product-card,
.blog-card,
.category-card,
.favorite-card,
.admin-metric-card,
.settings-panel,
.settings-mini-card,
.contact-panel,
.contact-form-card,
.contact-thread-card,
.payment-card,
.cart-item-card,
.address-card,
.address-editor-card,
.blog-admin-form-card,
.preview-panel,
.footer-section-card,
.comment-summary-card,
.comment-modal-card,
.modal-content,
.dropdown-menu,
.table-responsive,
.shop-toolbar,
.shop-filter-panel,
.product-side,
.product-media-shell,
.blog-article-aside,
.cms-page-body,
.cms-page-hero,
.alert {
    border-radius: var(--formal-radius-card) !important;
    box-shadow: var(--formal-shadow) !important;
}

.page-card,
.card,
.product-card,
.blog-card,
.category-card,
.favorite-card,
.settings-panel,
.cart-item-card,
.address-card,
.address-editor-card {
    border: 1px solid var(--border-soft) !important;
    background: var(--surface) !important;
}

.product-card:hover,
.blog-card:hover,
.category-card:hover,
.favorite-card:hover,
.shop-card:hover,
.page-card:hover {
    transform: translateY(-1px) !important;
    box-shadow: var(--formal-shadow-hover) !important;
}

.product-card:hover img,
.blog-card:hover img,
.favorite-card:hover img,
.product-media-shell:hover .product-main-image {
    transform: none !important;
}

.home-hero,
.shop-hero,
.cart-hero,
.payment-hero,
.contact-hero,
.cms-page-hero,
.category-hero,
.admin-hero,
.account-hero-card,
.product-hero,
.blog-hero-card {
    border-radius: var(--formal-radius-card) !important;
    background: var(--surface) !important;
    box-shadow: var(--formal-shadow) !important;
    overflow: hidden;
}

.home-hero::before,
.shop-hero::before,
.admin-hero::before,
.account-hero-card::before,
.category-card::before,
.product-media-shell--premium::before {
    display: none !important;
}

.home-hero {
    min-height: 0 !important;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 380px) !important;
    gap: var(--formal-space-5) !important;
    align-items: stretch !important;
}

.hero-visual-card {
    min-height: 280px !important;
    max-height: 360px;
    border-radius: var(--formal-radius-media) !important;
    box-shadow: none !important;
}

.hero-visual-card--image img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
}

.hero-visual-card__overlay {
    inset: auto var(--formal-space-3) var(--formal-space-3) var(--formal-space-3) !important;
    border-radius: var(--formal-radius-card) !important;
}

.hero-actions,
.section-heading,
.account-section-head,
.admin-hero,
.cart-hero .d-flex,
.shop-toolbar__filters {
    gap: var(--formal-space-3) !important;
}

.btn,
.icon-button,
.dk-icon-button,
.header-action,
.nav-chip,
.dk-nav-chip,
.quantity-stepper,
.quantity-stepper__btn,
.form-control,
.form-select,
textarea,
.input-group-text,
.input-with-icon,
.footer-socials__item,
.footer-enamad,
.thumb-grid__item {
    border-radius: var(--formal-radius-control) !important;
}

.btn {
    min-height: 40px !important;
    padding: 9px 14px !important;
    line-height: 1.35 !important;
    white-space: normal;
    text-align: center;
}

.btn-sm {
    min-height: 34px !important;
    padding: 7px 11px !important;
}

.btn-lg {
    min-height: 46px !important;
    padding: 11px 16px !important;
}

.btn span {
    min-width: 0;
}

.form-control,
.form-select,
textarea,
input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
input[type="tel"],
input[type="search"],
select {
    min-height: 44px !important;
    padding: 9px 12px !important;
}

textarea.form-control,
textarea {
    min-height: 108px !important;
}

.form-label {
    min-height: 0 !important;
    line-height: 1.5 !important;
}

.input-with-icon {
    position: relative;
    display: flex;
    align-items: center;
}

.input-with-icon__icon {
    position: absolute;
    inset-inline-start: 12px;
    color: var(--text-soft);
    pointer-events: none;
}

.input-with-icon .form-control {
    padding-inline-start: 38px !important;
}

.shop-toolbar {
    grid-template-columns: minmax(160px, 220px) minmax(0, 1fr) !important;
    padding: var(--formal-space-4) !important;
}

.shop-toolbar__filters {
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)) !important;
    align-items: end !important;
}

.shop-toolbar__filters > .btn {
    min-width: 108px;
}

.shop-toolbar__toggle {
    min-height: 44px !important;
    border-radius: var(--formal-radius-control) !important;
}

.shop-grid,
.blog-grid,
.blog-grid--polished,
.category-grid,
.favorite-grid,
.content-grid,
.feature-grid,
.trust-grid,
.testimonial-grid {
    display: grid !important;
    gap: var(--formal-space-4) !important;
    grid-auto-flow: row !important;
}

.shop-grid {
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)) !important;
}

.blog-grid,
.blog-grid--polished {
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)) !important;
}

.category-grid,
.favorite-grid,
.content-grid,
.feature-grid,
.trust-grid,
.testimonial-grid {
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)) !important;
}

.shop-grid > .product-card,
.shop-grid > .product-card:nth-child(n),
.blog-grid > .blog-card,
.blog-grid > .blog-card:nth-child(n),
.category-grid > .category-card,
.category-grid > .category-card:nth-child(n) {
    grid-column: auto !important;
    grid-row: auto !important;
    min-height: 0 !important;
}

.product-card,
.blog-card,
.favorite-card,
.shop-card {
    display: flex !important;
    flex-direction: column;
    overflow: hidden !important;
    isolation: isolate;
}

.product-card__media,
.shop-card__media {
    width: 100% !important;
    margin: 0 !important;
    padding: var(--formal-space-3) !important;
    aspect-ratio: 1 / 1 !important;
    min-height: 0 !important;
    height: auto !important;
    border: 0 !important;
    border-bottom: 1px solid var(--border-soft) !important;
    border-radius: 0 !important;
    background: var(--surface-subtle) !important;
    display: grid !important;
    place-items: center !important;
}

.product-card__media::before,
.product-card__media::after,
.shop-card__media::before,
.shop-card__media::after,
.product-card__media-glow {
    display: none !important;
}

.product-card__media > img,
.shop-card__media > img {
    width: 100% !important;
    height: 100% !important;
    max-width: 200px !important;
    max-height: 200px !important;
    padding: 0 !important;
    object-fit: contain !important;
    background: transparent !important;
    border-radius: var(--formal-radius-media) !important;
    clip-path: none !important;
}

.product-placeholder,
.product-card__media .product-placeholder,
.shop-card__media .product-placeholder {
    width: 100%;
    height: 100% !important;
    min-height: 0;
    border-radius: var(--formal-radius-media) !important;
}

.product-placeholder__svg {
    width: 72%;
    max-width: 160px;
}

.product-card__body,
.blog-card__body,
.shop-card__body,
.favorite-card__body {
    flex: 1;
    display: flex !important;
    flex-direction: column;
    gap: var(--formal-space-3) !important;
    padding: var(--formal-space-4) !important;
    min-height: 0 !important;
}

.product-card__meta {
    min-height: 0 !important;
    gap: var(--formal-space-2) !important;
}

.product-card__title,
.blog-card__body h2,
.blog-card__body h3 {
    min-height: 0 !important;
    line-height: 1.6 !important;
}

.product-card__excerpt {
    margin: 0 !important;
    min-height: 0 !important;
}

.product-card__footer {
    margin-top: auto !important;
    align-items: flex-end !important;
    gap: var(--formal-space-3) !important;
}

.product-card__price {
    text-align: start !important;
}

.product-card__actions {
    display: grid !important;
    grid-template-columns: 76px minmax(0, 1fr);
    gap: var(--formal-space-2) !important;
    align-items: stretch !important;
    padding-top: var(--formal-space-3) !important;
}

.product-card__actions--in-cart {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
}

.product-card__actions + .btn {
    margin-top: var(--formal-space-2);
}

.shop-quantity-input {
    width: 100% !important;
    max-width: none !important;
}

.blog-card__media {
    aspect-ratio: 16 / 9 !important;
    border-radius: 0 !important;
    border-bottom: 1px solid var(--border-soft);
}

.blog-card__media img,
.blog-card__fallback {
    width: 100% !important;
    height: 100% !important;
    border-radius: 0 !important;
    object-fit: cover !important;
}

.blog-card__footer {
    margin-top: auto !important;
}

.category-card {
    min-height: 86px !important;
    padding: var(--formal-space-4) !important;
}

.product-detail-layout,
.product-detail-layout.product-hero__layout {
    grid-template-columns: minmax(280px, 420px) minmax(0, 1fr) !important;
    gap: var(--formal-space-5) !important;
    align-items: start !important;
}

.product-media-shell,
.product-media-shell--premium {
    min-height: 0 !important;
    display: grid !important;
    grid-template-rows: auto auto !important;
    gap: var(--formal-space-3) !important;
    padding: var(--formal-space-4) !important;
    background: var(--surface) !important;
}

.product-media-badges {
    position: static !important;
    margin: 0 !important;
}

.product-main-image {
    width: 100% !important;
    height: min(420px, 52vh) !important;
    max-height: 420px !important;
    aspect-ratio: 1 / 1 !important;
    object-fit: contain !important;
    padding: var(--formal-space-3) !important;
    border: 1px solid var(--border-soft) !important;
    border-radius: var(--formal-radius-media) !important;
    background: var(--surface-subtle) !important;
    clip-path: none !important;
}

.thumb-grid {
    grid-template-columns: repeat(auto-fill, minmax(56px, 1fr)) !important;
    gap: var(--formal-space-2) !important;
}

.thumb-grid__item {
    padding: var(--formal-space-1) !important;
}

.thumb-grid__item img {
    object-fit: contain !important;
    border-radius: calc(var(--formal-radius-media) - 2px) !important;
    background: var(--surface-subtle);
}

.product-buybox,
.product-side {
    display: grid;
    gap: var(--formal-space-3) !important;
}

.product-trust-strip {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: var(--formal-space-2) !important;
}

.product-trust-strip span,
.variant-panel,
.variant-chip,
.feature-glass,
.glass-kv-row,
.summary-row,
.chip-soft,
.filter-chip,
.status-pill,
.badge {
    border-radius: var(--formal-radius-control) !important;
}

.product-detail-content-grid,
.blog-article-layout {
    grid-template-columns: minmax(0, 1fr) minmax(280px, 340px) !important;
    gap: var(--formal-space-5) !important;
}

.blog-article-main {
    padding: var(--formal-space-5) !important;
    border: 1px solid var(--border-soft);
    border-radius: var(--formal-radius-card) !important;
    background: var(--surface);
}

.blog-article-hero-media {
    width: min(100%, 720px) !important;
    aspect-ratio: 16 / 9 !important;
    margin: 0 auto var(--formal-space-4) !important;
    border-radius: var(--formal-radius-media) !important;
}

.blog-article-hero-image {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    border-radius: inherit !important;
}

.blog-article-content img,
.cms-page-body img,
.cms-page-live-content img,
.product-description img {
    width: auto !important;
    max-width: 100% !important;
    height: auto !important;
    max-height: 420px !important;
    object-fit: contain !important;
    margin-inline: auto;
    border-radius: var(--formal-radius-media) !important;
}

.product-line-thumb,
.product-line-thumb img,
.product-line-thumb__fallback,
.favorite-card__media,
.favorite-card__media img {
    border-radius: var(--formal-radius-media) !important;
}

.product-line-thumb img {
    width: 100%;
    height: 100%;
    object-fit: contain !important;
    background: var(--surface-subtle);
}

.cart-item-card,
.payment-line,
.product-line,
.dashboard-item,
.admin-list-row,
.contact-reply-item {
    align-items: center !important;
}

.account-pro-shell {
    grid-template-columns: 260px minmax(0, 1fr) !important;
    gap: var(--formal-space-5) !important;
}

.account-pro-sidebar,
.cart-summary--sticky,
.price-box,
.shop-filter-panel,
.blog-article-aside,
.product-info-card {
    top: 104px !important;
}

.account-stat-grid,
.admin-metric-grid,
.hero-stats,
.shop-stats,
.home-stat-grid,
.payment-summary-grid,
.comment-summary-grid {
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)) !important;
    gap: var(--formal-space-3) !important;
}

.address-manager-grid {
    grid-template-columns: minmax(0, 1fr) minmax(280px, 380px) !important;
    gap: var(--formal-space-4) !important;
}

.favorite-card__media {
    aspect-ratio: 16 / 9 !important;
    overflow: hidden;
    background: var(--surface-subtle);
}

.favorite-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.dk-footer-services,
.dk-footer__grid--dynamic,
.footer-grid {
    gap: var(--formal-space-5) !important;
}

.dk-footer-service,
.footer-trust__item {
    border-radius: var(--formal-radius-card) !important;
}

.footer-enamad {
    width: 104px !important;
    min-height: 104px !important;
}

.footer-enamad img {
    max-height: 82px !important;
    object-fit: contain !important;
}

@media (max-width: 1199.98px) {
    .home-hero,
    .product-detail-layout,
    .product-detail-layout.product-hero__layout,
    .product-detail-content-grid,
    .blog-article-layout,
    .account-pro-shell,
    .address-manager-grid {
        grid-template-columns: 1fr !important;
    }

    .account-pro-sidebar,
    .cart-summary--sticky,
    .price-box,
    .shop-filter-panel,
    .blog-article-aside,
    .product-info-card {
        position: static !important;
    }
}

@media (max-width: 767.98px) {
    :root {
        --formal-space-4: 14px;
        --formal-space-5: 16px;
        --formal-space-6: 20px;
    }

    .hero-title,
    .home-hero .hero-title,
    .product-detail-title {
        font-size: 1.5rem !important;
    }

    .page-frame {
        width: min(100% - 16px, var(--container)) !important;
    }

    .home-hero,
    .shop-toolbar,
    .cart-hero,
    .payment-hero,
    .contact-hero,
    .cms-page-hero,
    .category-hero,
    .admin-hero,
    .account-hero-card,
    .product-hero,
    .blog-hero-card {
        padding: var(--formal-space-4) !important;
    }

    .section-heading,
    .account-section-head,
    .cart-hero .d-flex,
    .admin-hero {
        align-items: stretch !important;
        flex-direction: column !important;
    }

    .section-heading .btn,
    .hero-actions .btn,
    .cart-hero .btn,
    .admin-hero .btn,
    .account-section-head .btn {
        width: 100%;
    }

    .shop-toolbar {
        grid-template-columns: 1fr !important;
    }

    .shop-toolbar__filters {
        grid-template-columns: 1fr !important;
    }

    .shop-toolbar__filters > .btn {
        width: 100%;
    }

    .shop-grid,
    .blog-grid,
    .blog-grid--polished,
    .category-grid,
    .favorite-grid,
    .content-grid,
    .feature-grid {
        grid-template-columns: 1fr !important;
    }

    .product-card__media,
    .shop-card__media {
        aspect-ratio: 4 / 3 !important;
    }

    .product-card__media > img,
    .shop-card__media > img {
        max-width: 180px !important;
        max-height: 180px !important;
    }

    .product-card__footer,
    .blog-card__footer {
        align-items: stretch !important;
        flex-direction: column !important;
    }

    .product-card__actions,
    .product-card__actions--in-cart {
        grid-template-columns: 1fr !important;
    }

    .product-main-image {
        height: 280px !important;
        max-height: 280px !important;
    }

    .product-trust-strip {
        grid-template-columns: 1fr !important;
    }

    .blog-article-main {
        padding: var(--formal-space-4) !important;
    }

    .blog-article-hero-media {
        width: 100% !important;
    }

    .cart-item-card,
    .payment-line,
    .product-line,
    .dashboard-item,
    .admin-list-row,
    .contact-reply-item {
        align-items: stretch !important;
        flex-direction: column !important;
    }
}

@media (max-width: 420px) {
    .product-main-image {
        height: 240px !important;
        max-height: 240px !important;
    }

    .product-card__media > img,
    .shop-card__media > img {
        max-width: 160px !important;
        max-height: 160px !important;
    }
}

/* Checkout flow */
.checkout-page {
    display: grid;
    gap: var(--formal-space-5);
    padding: var(--formal-space-5) !important;
}

.checkout-page > .d-flex:first-child {
    align-items: center !important;
    gap: var(--formal-space-4);
}

.checkout-progress {
    overflow: hidden;
    border-radius: var(--formal-radius-control) !important;
    background: var(--surface-subtle);
}

.checkout-progress .progress-bar {
    background: var(--site-accent);
}

.checkout-step-panel,
.checkout-summary-panel,
.checkout-address-option {
    border-color: var(--border-soft) !important;
    border-radius: var(--formal-radius-card) !important;
    background: var(--surface) !important;
}

.checkout-step-panel {
    display: grid;
    gap: var(--formal-space-4);
}

.checkout-step-panel h2,
.checkout-summary-panel h2 {
    margin-bottom: 0 !important;
}

.checkout-address-option {
    cursor: pointer;
    transition: border-color .18s ease, box-shadow .18s ease, background .18s ease;
}

.checkout-address-option:hover {
    border-color: rgb(var(--site-accent-rgb) / .34) !important;
    box-shadow: var(--focus-ring);
}

.checkout-summary-panel {
    position: sticky;
    top: 104px;
}

.checkout-summary-panel .product-line {
    align-items: center !important;
    border-radius: var(--formal-radius-card) !important;
    background: var(--surface-subtle);
}

@media (max-width: 991.98px) {
    .checkout-summary-panel {
        position: static;
    }
}

@media (max-width: 767.98px) {
    .checkout-page {
        padding: var(--formal-space-4) !important;
    }

    .checkout-page > .d-flex:first-child {
        align-items: stretch !important;
        flex-direction: column;
    }

    .checkout-step-panel .d-flex.justify-content-between,
    .checkout-step-panel .d-flex.justify-content-end {
        align-items: stretch !important;
        flex-direction: column;
        gap: var(--formal-space-2);
    }

    .checkout-step-panel .btn {
        width: 100%;
    }
}
