/* ==========================================================================
   goodsinfo.css — Product detail page (flat, clean, simple)
   Loaded by frontend/views/default/store/goodsinfo.html
   Scoped under .gi-wrap. Sibling of search.goods.css (.sg-) and
   search.store.css (.ss-); reuses the same design language.

   IMPORTANT: All class/id/ectype selectors used by goodsinfo.js are
   preserved as legacy hooks; the new .gi- classes are layered on top.
   ========================================================================== */

:root {
	/* Neutral surfaces */
	--gi-bg:            #f7f7f8;
	--gi-surface:       #ffffff;
	--gi-line:          #ececef;
	--gi-line-strong:   #d9d9de;

	/* Text */
	--gi-text-1:        #1a1a1a;
	--gi-text-2:        #555560;
	--gi-text-3:        #8a8a93;

	/* Single accent */
	--gi-accent:        #ff5a3c;
	--gi-accent-soft:   #fff1ed;
	--gi-accent-deep:   #e84a2d;

	/* Semantic */
	--gi-warning:       #f0a040;
	--gi-success:       #28a271;
	--gi-success-soft:  #ecf8ed;

	/* Type scale */
	--gi-fs-xs:         12px;
	--gi-fs-sm:         13px;
	--gi-fs-base:       14px;
	--gi-fs-md:         15px;
	--gi-fs-lg:         16px;
	--gi-fs-xl:         18px;
	--gi-fs-2xl:        22px;
	--gi-fs-3xl:        28px;

	/* Rhythm */
	--gi-r-1:           4px;
	--gi-r-2:           8px;
	--gi-r-3:           12px;
	--gi-r-4:           16px;
	--gi-r-5:           20px;
	--gi-r-6:           24px;
	--gi-r-7:           32px;

	/* Radius */
	--gi-radius-sm:     4px;
	--gi-radius:        8px;
	--gi-radius-lg:     12px;
	--gi-radius-pill:   999px;

	--gi-ease:          cubic-bezier(0.2, 0, 0, 1);
}

/* --------------------------------------------------------------------------
   Local reset
   -------------------------------------------------------------------------- */
.gi-wrap,
.gi-wrap *,
.gi-wrap *::before,
.gi-wrap *::after { box-sizing: border-box; }

.gi-wrap {
	font-family: -apple-system, BlinkMacSystemFont, "PingFang SC", "Microsoft YaHei", "Helvetica Neue", Arial, sans-serif;
	font-size: var(--gi-fs-base);
	line-height: 1.55;
	color: var(--gi-text-1);
	background: var(--gi-bg);
	padding: var(--gi-r-5) 0;
	border-radius: var(--gi-radius);
}

.gi-wrap a { color: inherit; text-decoration: none; transition: color .15s var(--gi-ease); }
/*.gi-wrap a:hover { color: #ffffff; }*/
.gi-wrap img { display: block; max-width: 100%; }
.gi-wrap button,
.gi-wrap input { font: inherit; color: inherit; }
.gi-wrap button { cursor: pointer; }
.gi-wrap ul,
.gi-wrap ol { list-style: none; margin: 0; padding: 0; }

/* --------------------------------------------------------------------------
   Top section: gallery (left) + product info (right)
   -------------------------------------------------------------------------- */
.gi-top {
	display: grid;
	grid-template-columns: 460px 1fr;
	gap: var(--gi-r-6);
	background: var(--gi-surface);
	border: 1px solid var(--gi-line);
	border-radius: var(--gi-radius);
	padding: var(--gi-r-5);
	margin-bottom: var(--gi-r-5);
}

@media (max-width: 1180px) {
	.gi-top { grid-template-columns: 380px 1fr; gap: var(--gi-r-5); }
}
@media (max-width: 900px) {
	.gi-top { grid-template-columns: 1fr; }
}

/* --- Gallery --- */
.gi-gallery {
	display: flex;
	flex-direction: column;
	gap: var(--gi-r-3);
	min-width: 0;
}

.gi-gallery-main {
	position: relative;
	width: 100%;
	aspect-ratio: 1 / 1;
	background: var(--gi-bg);
	border: 1px solid var(--gi-line);
	border-radius: var(--gi-radius);
	overflow: hidden;
	display: flex;
	justify-content: center;
	align-items: center;
}
.gi-gallery-main .big_pic,
.gi-gallery-main .big_pic a,
.gi-gallery-main .big_pic img {
	display: block;
	width: 100%;
	height: 100%;
}
.gi-gallery-main .big_pic a { cursor: zoom-in; }
.gi-gallery-main .big_pic img { object-fit: contain; }

/* Prev/next on big image (lightbox hint) */
.gi-gallery-arrow {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 5;
	width: 36px;
	height: 36px;
	display: none;             /* 旧 JS 没有 prev/next，留接口 */
	align-items: center;
	justify-content: center;
	background: rgba(255, 255, 255, .9);
	border: 1px solid var(--gi-line);
	border-radius: 50%;
	color: var(--gi-text-2);
	cursor: pointer;
	transition: color .15s var(--gi-ease), border-color .15s var(--gi-ease);
}
.gi-gallery-arrow:hover { color: var(--gi-accent); border-color: var(--gi-accent); }
.gi-gallery-arrow.is-left  { left: 12px; }
.gi-gallery-arrow.is-right { right: 12px; }

/* Thumbnail strip */
.gi-gallery-thumbs {
	position: relative;
	display: flex;
	align-items: center;
	gap: var(--gi-r-2);
}

.gi-thumbs-scroller {
	flex: 1 1 auto;
	overflow: hidden;
}

.gi-thumbs-list {
	display: flex;
	gap: var(--gi-r-2);
	transition: transform .25s var(--gi-ease);
}
.tiny-pics .list,
.tiny-pics .list.clearfix {
	display: flex;
	gap: var(--gi-r-2);
	transition: transform .25s var(--gi-ease);
	margin: 0;
	padding: 0;
}
.tiny-pics ul.list { margin: 0; padding: 0; }

.tiny-pics .list li {
	flex: 0 0 64px;
	width: 64px;
	height: 64px;
	border: 1px solid var(--gi-line);
	border-radius: var(--gi-radius-sm);
	overflow: hidden;
	background: var(--gi-bg);
	cursor: pointer;
	transition: border-color .15s var(--gi-ease);
}
.tiny-pics .list li img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.tiny-pics .list li.pic_hover,
.tiny-pics .list li:hover {
	border-color: var(--gi-accent);
}

.gi-thumbs-arrow {
	flex: 0 0 auto;
	width: 28px;
	height: 28px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--gi-surface);
	border: 1px solid var(--gi-line);
	border-radius: 50%;
	color: var(--gi-text-2);
	cursor: pointer;
	transition: color .15s var(--gi-ease), border-color .15s var(--gi-ease);
}
.gi-thumbs-arrow:hover { color: var(--gi-accent); border-color: var(--gi-accent); }
.gi-thumbs-arrow::before {
	content: "";
	display: block;
	width: 7px;
	height: 7px;
	border-top: 1.5px solid currentColor;
	border-left: 1.5px solid currentColor;
}
.gi-thumbs-arrow.is-next::before { transform: rotate(135deg); }
.gi-thumbs-arrow.is-prev::before { transform: rotate(-45deg); }

/* Share / collect / report row */
/* === gi-gallery-actions (查看大图 / 加入收藏 / 虚假举报) ===
   The element carries the compound classes:
     class="gi-gallery-actions share w-full clearfix"
   - .gi-gallery-actions is the new modern hook
   - .share is the legacy hook used by older shop.css rules
   - .w-full and .clearfix are layout helpers from global.css
   We need to make this row clean, regardless of which class is targeted. */
.gi-gallery-actions,
.gi-gallery-actions.share {
	display: flex !important;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--gi-r-4);
	padding: var(--gi-r-3) 0 0 !important;
	border-top: 1px dashed var(--gi-line);
	margin: var(--gi-r-2) 0 0 0 !important;
	font-size: var(--gi-fs-sm);
	color: var(--gi-text-2);
	background: transparent !important;
	position: static !important;
	width: auto !important;
}

/* === Reset legacy .share rules leaking from shop.css === */
.gi-gallery-actions .view-big-imgs,
.gi-gallery-actions.share .view-big-imgs,
.gi-gallery-actions .zoom-pics .share .view-big-imgs {
	width: auto !important;
	height: auto !important;
	line-height: normal !important;
	padding: 0 !important;
	overflow: visible !important;
	background: none !important;
	background-image: none !important;
	float: none !important;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	margin: 0;
}
.gi-gallery-actions .view-big-imgs a,
.gi-gallery-actions.share .view-big-imgs a {
	color: var(--gi-text-2) !important;
	text-decoration: none !important;
	padding: 0 !important;
	background: transparent !important;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: var(--gi-fs-sm);
	cursor: pointer;
	transition: color .15s var(--gi-ease);
}
.gi-gallery-actions .view-big-imgs a:hover { color: var(--gi-accent); }
.gi-gallery-actions .view-big-imgs a.hidden { display: none !important; }

.gi-gallery-actions .collect-goods,
.gi-gallery-actions.share .collect-goods {
	float: none !important;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	margin: 0 !important;
	padding: 0;
	text-align: left;
	overflow: visible;
}
.gi-gallery-actions .collect-goods a,
.gi-gallery-actions.share .collect-goods a {
	display: inline-flex !important;
	align-items: center;
	gap: 6px;
	color: var(--gi-text-2) !important;
	text-decoration: none;
	background: transparent !important;
	background-image: none !important;
	width: auto !important;
	height: auto !important;
	line-height: normal !important;
	padding: 0 !important;
	font-size: var(--gi-fs-sm);
	cursor: pointer;
	transition: color .15s var(--gi-ease);
}
.gi-gallery-actions .collect-goods a:hover { color: var(--gi-accent); }

.gi-gallery-actions .report,
.gi-gallery-actions.share .report {
	font-size: var(--gi-fs-xs);
	color: var(--gi-text-3);
	text-decoration: none;
	margin-left: auto;   /* push report to the right end of the row */
	transition: color .15s var(--gi-ease);
}
.gi-gallery-actions .report:hover { color: var(--gi-accent); }

/* === SVG icons inside the gallery actions ===
   IMPORTANT: do NOT require `.gi-action` ancestor — the actual HTML
   places icons directly inside <a> / <span>. Without sizing, the
   SVG defaults to 300×150 and pushes the text below the icon. */
.gi-gallery-actions svg.gi-icon,
.gi-gallery-actions .gi-icon {
	width: 16px !important;
	height: 16px !important;
	flex: 0 0 16px;
	display: inline-block;
	vertical-align: middle;
}

/* === Legacy .gi-action rule kept as a fallback for any element
   that does carry the class (forward-compat) === */
.gi-gallery-actions .gi-action {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	cursor: pointer;
	user-select: none;
	transition: color .15s var(--gi-ease);
	color: var(--gi-text-2);
}
.gi-gallery-actions .gi-action:hover { color: var(--gi-accent); }

/* Mobile: stack actions vertically with proper touch targets */
@media (max-width: 640px) {
	.gi-gallery-actions {
		gap: var(--gi-r-3);
		justify-content: space-between;
	}
	.gi-gallery-actions .view-big-imgs,
	.gi-gallery-actions .collect-goods {
		min-height: 32px;
	}
	.gi-gallery-actions .report { margin-left: 0; }
}

/* --- Product info (right) --- */
.gi-info {
	display: flex;
	flex-direction: column;
	gap: var(--gi-r-4);
	min-width: 0;
}

.gi-name {
	font-size: var(--gi-fs-2xl);
	font-weight: 600;
	color: var(--gi-text-1);
	line-height: 1.35;
	letter-spacing: -0.2px;
}
.gi-brief {
	font-size: var(--gi-fs-sm);
	color: var(--gi-text-3);
	line-height: 1.5;
}

/* Price card — accent soft surface, big tabular price.
   NOTE: all color rules here use !important because the page
   also loads legacy shop.css / global.css whose `.price` rules
   (e.g. .mealgoods .price, .notice-word .price) can cascade in
   via the global cascade and reset the color to white. The
   !important here is intentional and load-bearing. */
.gi-price-card {
	display: flex;
	flex-direction: column;
	gap: var(--gi-r-2);
	padding: var(--gi-r-4) var(--gi-r-5);
	background: var(--gi-accent-soft);
	border-radius: var(--gi-radius);
	position: relative;
	min-height: 64px;
}
.gi-price-card > p {
	margin: 0;
	display: block;
}
.gi-price-card > p[style*="display:none"],
.gi-price-card > p[style*="display: none"] {
	display: none !important;
}
.gi-price-card > p:not([style*="display"]) {
	display: block;
}
.gi-price-card .gi-price-row {
	display: flex;
	align-items: baseline;
	flex-wrap: wrap;
	gap: var(--gi-r-3);
}
.gi-price-card .gi-price-label {
	font-size: var(--gi-fs-sm);
	color: var(--gi-text-2);
}
.gi-price-card .gi-price,
.gi-price-card span.gi-price,
.gi-price-card span[ectype="goods_price"],
.gi-price-card span[ectype="goods_pro_price"],
.gi-price-card span.gi-price[ectype="goods_price"],
.gi-price-card span.gi-price[ectype="goods_pro_price"] {
	display: inline-block !important;
	font-size: var(--gi-fs-3xl) !important;
	font-weight: 600 !important;
	color: var(--gi-accent) !important;
	line-height: 1.1 !important;
	font-variant-numeric: tabular-nums;
	letter-spacing: -0.5px;
	min-height: 32px;
	visibility: visible !important;
	opacity: 1 !important;
	background: transparent;
}

/* The strikethrough original price inside the promo (J_IsPro)
   must stay muted gray — but never white. */
.gi-price-card del,
.gi-price-card del[ectype="goods_price"] {
	font-size: var(--gi-fs-md);
	color: var(--gi-text-3) !important;
	font-weight: 400;
	margin-left: var(--gi-r-2);
	background: transparent;
}

/* Reset the unwanted white-on-soft-pink from any global `.price`
   rule that might bleed into the price card (defensive). */
.gi-price-card span[ectype="goods_price"] *,
.gi-price-card span[ectype="goods_pro_price"] * {
	color: inherit;
	background: transparent;
}

.gi-price-card .gi-price small {
	font-size: var(--gi-fs-lg);
	font-weight: 500;
	margin-right: 2px;
	opacity: .9;
}
.gi-price-card .gi-promo {
	display: inline-flex;
	align-items: center;
	gap: var(--gi-r-2);
	flex-wrap: wrap;
}
.gi-price-card .gi-promo-tag {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 2px 8px;
	background: var(--gi-accent);
	color: #fff;
	border-radius: var(--gi-radius-sm);
	font-size: var(--gi-fs-xs);
	font-weight: 500;
}
.gi-price-card .gi-promo-name { color: var(--gi-text-2); font-size: var(--gi-fs-sm); }
.gi-price-card .gi-promo-price { color: var(--gi-accent); font-weight: 600; font-size: var(--gi-fs-lg); }
.gi-price-card .J_CountDown { display: none; }   /* JS will show if active */

/* Quick stats (sales / comments / stock) */
.gi-stats {
	display: flex;
	flex-wrap: wrap;
	gap: var(--gi-r-5);
	padding: var(--gi-r-3) 0;
	border-bottom: 1px solid var(--gi-line);
	font-size: var(--gi-fs-sm);
	color: var(--gi-text-2);
}
.gi-stats .gi-stat b {
	font-weight: 600;
	color: var(--gi-text-1);
	font-variant-numeric: tabular-nums;
}

/* Spec / attribute rows (handle) */
.handle { display: flex; flex-direction: column; gap: var(--gi-r-3); }
.handle ul {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--gi-r-2);
	font-size: var(--gi-fs-sm);
}
.handle .handle_title {
	flex: 0 0 64px;
	color: var(--gi-text-3);
	font-size: var(--gi-fs-sm);
}

/* Spec pill — produced by goodsinfo.js with class "solid" / "dotted" / "none" */
.handle ul li.solid a,
.handle ul li.dotted a {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	min-height: 32px;
	padding: 0 12px;
	background: var(--gi-surface);
	border: 1px solid var(--gi-line);
	border-radius: var(--gi-radius-sm);
	color: var(--gi-text-1);
	font-size: var(--gi-fs-sm);
	line-height: 1;
	cursor: pointer;
	transition: border-color .15s var(--gi-ease), color .15s var(--gi-ease);
	user-select: none;
}
.handle ul li.solid a:hover,
.handle ul li.dotted a:hover { border-color: var(--gi-accent); color: var(--gi-accent); }

.handle ul li.solid a {
	border-color: var(--gi-accent);
	color: var(--gi-accent);
	background: var(--gi-accent-soft);
	font-weight: 500;
}

.handle ul li a.none {
	cursor: not-allowed;
	color: var(--gi-text-3);
	background: transparent;
	border-style: dashed;
	text-decoration: line-through;
}
.handle ul li a.none img { opacity: .35; }
.handle ul li a span,
.handle ul li a img { display: inline-block; }
.handle ul li a img { width: 24px; height: 24px; border-radius: 2px; object-fit: cover; }
.handle ul li a b { display: none; }   /* legacy inner badge — visually replaced */

/* Quantity selector */
.gi-qty {
	display: flex;
	align-items: center;
	gap: var(--gi-r-2);
}
.buy-quantity {
	display: inline-flex;
	align-items: center;
	border: 1px solid var(--gi-line-strong);
	border-radius: var(--gi-radius-sm);
	background: var(--gi-surface);
	overflow: hidden;
}
.buy-quantity a {
	width: 32px;
	height: 32px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: var(--gi-text-2);
	cursor: pointer;
	user-select: none;
	transition: color .15s var(--gi-ease), background .15s var(--gi-ease);
}
.buy-quantity a:hover { color: var(--gi-accent); background: var(--gi-bg); }
.buy-quantity a::before {
	content: "";
	display: block;
	width: 10px;
	height: 1.5px;
	background: currentColor;
}
.buy-quantity a.add-btn::after {
	content: "";
	position: absolute;
	display: block;
	width: 1.5px;
	height: 10px;
	background: currentColor;
}
.buy-quantity .text {
	width: 56px;
	height: 32px;
	border: 0;
	border-left: 1px solid var(--gi-line);
	border-right: 1px solid var(--gi-line);
	text-align: center;
	font-size: var(--gi-fs-sm);
	font-variant-numeric: tabular-nums;
	color: var(--gi-text-1);
	background: var(--gi-surface);
}
.buy-quantity .text:focus-visible { outline: 2px solid var(--gi-accent); outline-offset: -2px; }
.quantity-select .stock { color: var(--gi-accent); font-weight: 600; }

/* Region / delivery */
.gi-region {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: var(--gi-r-3);
	font-size: var(--gi-fs-sm);
	color: var(--gi-text-2);
}
.gi-region .gi-region-wrap {
	position: relative !important;
	display: inline-block !important;
	/* Hover bridge: extend the wrap's hit-box downward to cover the
	   visual gap between .J_Region and the dropdown. Negative margin
	   cancels the layout impact of the padding. */
	padding-bottom: 8px !important;
	margin-bottom: -8px !important;
}
.gi-region .J_Region {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 4px 10px;
	background: var(--gi-surface);
	border: 1px solid var(--gi-line);
	border-radius: var(--gi-radius-sm);
	color: var(--gi-text-1);
	cursor: pointer;
	transition: border-color .15s var(--gi-ease);
}
.gi-region .J_Region:hover { border-color: var(--gi-accent); }
.gi-region .postage-info { color: var(--gi-text-2); }
.gi-region .postage-area {
	position: absolute !important;
	top: 100% !important;
	left: 0 !important;
	z-index: 50 !important;
	min-width: 280px !important;
	max-width: 380px !important;
	padding: 10px !important;
	background: var(--gi-surface) !important;
	border: 1px solid var(--gi-line) !important;
	border-radius: var(--gi-radius) !important;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08) !important;
	color: var(--gi-text-2) !important;
	line-height: 1.6 !important;
}
.gi-region .postage-area ul {
	display: flex !important;
	flex-wrap: wrap !important;
	gap: 2px 0 !important;
	margin: 0 !important;
	padding: 0 !important;
	list-style: none !important;
}
.gi-region .postage-area ul.J_City {
	margin-top: 8px !important;
	padding-top: 8px !important;
	/* Override the inline style="border-top:1px #ddd dotted" in the HTML
	   and the JS that re-applies the same color on click. */
	border-top: 1px dashed var(--gi-line) !important;
}
.gi-region .postage-area a {
	display: inline-block !important;
	padding: 3px 10px !important;
	color: var(--gi-text-2) !important;
	text-decoration: none !important;
	border-radius: var(--gi-radius-sm) !important;
	font-size: var(--gi-fs-sm) !important;
	transition: background .15s var(--gi-ease), color .15s var(--gi-ease) !important;
}
.gi-region .postage-area a:hover,
.gi-region .postage-area a.selected {
	background: var(--gi-accent-soft) !important;
	color: var(--gi-accent) !important;
}

/* Service line (integral / shipping / brand / tags) */
.gi-services {
	display: flex;
	flex-direction: column;
	gap: var(--gi-r-2);
	padding: var(--gi-r-3) 0;
	border-top: 1px solid var(--gi-line);
	font-size: var(--gi-fs-sm);
	color: var(--gi-text-2);
}
.gi-services .gi-svc-row {
	display: flex;
	flex-wrap: wrap;
	gap: var(--gi-r-3);
	align-items: center;
}
.gi-services .gi-svc-row b { color: var(--gi-text-1); font-weight: 500; }
.gi-services .gi-svc-row .discount-info { display: inline-flex; align-items: center; gap: var(--gi-r-2); }
.gi-services .gi-svc-row .d-name { color: var(--gi-text-1); }
.gi-services .gi-svc-row .d-price { color: var(--gi-accent); font-weight: 500; }

/* CTAs */
.gi-cta {
	display: flex;
	gap: var(--gi-r-3);
	margin-top: var(--gi-r-2);
}
.buy-btn {
	flex: 1 1 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--gi-r-2);
	min-height: 48px;
	padding: 0 var(--gi-r-5);
	border-radius: var(--gi-radius);
	font-size: var(--gi-fs-lg);
	font-weight: 500;
	line-height: 1.2;
	cursor: pointer;
	transition: background .15s var(--gi-ease), color .15s var(--gi-ease), border-color .15s var(--gi-ease);
	user-select: none;
	border: 1px solid transparent;
	text-align: center;
}
.buy-btn:focus-visible { outline: 2px solid var(--gi-accent); outline-offset: 2px; }
.buy-btn.buy-now {
	background: var(--gi-accent);
	color: #fff;
	border-color: var(--gi-accent);
}
.buy-btn.buy-now:hover { background: var(--gi-accent-deep); border-color: var(--gi-accent-deep); }
.buy-btn.add-to-cart {
	background: var(--gi-warning);
	color: #fff;
	border-color: var(--gi-warning);
}
.buy-btn.add-to-cart:hover { background: #dd8a30; border-color: #dd8a30; }

/* --------------------------------------------------------------------------
   Tab bar — matches sg-/ss- tab style
   -------------------------------------------------------------------------- */
.gi-tabbar {
	display: flex;
	align-items: center;
	gap: 0;
	padding: 0 var(--gi-r-5);
	background: var(--gi-surface);
	border: 1px solid var(--gi-line);
	border-bottom: 0;
	border-top-left-radius: var(--gi-radius);
	border-top-right-radius: var(--gi-radius);
}
.attr-tabs { background: transparent; border: 0; padding: 0; }
.gi-tab {
	flex: 0 0 auto;
	padding: var(--gi-r-4) var(--gi-r-5);
	font-size: var(--gi-fs-md);
	color: var(--gi-text-2);
	cursor: pointer;
	position: relative;
	transition: color .15s var(--gi-ease);
}
.gi-tab:hover { color: var(--gi-accent); }
.gi-tab.is-active {
	color: var(--gi-accent);
	font-weight: 500;
}
.gi-tab.is-active::after {
	content: "";
	position: absolute;
	left: var(--gi-r-3);
	right: var(--gi-r-3);
	bottom: -1px;
	height: 2px;
	background: var(--gi-accent);
	border-radius: 2px 2px 0 0;
}
.gi-tab .gi-tab-count {
	display: inline-block;
	margin-left: 4px;
	padding: 0 6px;
	min-width: 20px;
	height: 18px;
	line-height: 18px;
	background: var(--gi-bg);
	color: var(--gi-text-3);
	border-radius: var(--gi-radius-pill);
	font-size: var(--gi-fs-xs);
	font-weight: 500;
	text-align: center;
	vertical-align: middle;
}
.gi-tab.is-active .gi-tab-count {
	background: var(--gi-accent-soft);
	color: var(--gi-accent);
}

.gi-tabbar-spacer { flex: 1 1 auto; }
.gi-tabbar-extra {
	display: inline-flex;
	align-items: center;
	gap: var(--gi-r-2);
	font-size: var(--gi-fs-sm);
	color: var(--gi-text-3);
}

.gi-tabpanel {
	background: var(--gi-surface);
	border: 1px solid var(--gi-line);
	border-radius: var(--gi-radius);
	border-top-left-radius: 0;
	padding: var(--gi-r-5);
	margin-bottom: var(--gi-r-5);
}

.option_box { background: transparent; border: 0; padding: 0; }

/* Detail info — images from the description editor */
.detail-info {
	font-size: var(--gi-fs-base);
	color: var(--gi-text-1);
	line-height: 1.7;
}
.detail-info img { max-width: 100%; height: auto; margin: var(--gi-r-2) 0; }
.detail-info p { margin: var(--gi-r-3) 0; }
.detail-info table { max-width: 100%; }

/* Props table */
.gi-props {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 0;
	padding: 0;
	margin: 0 0 var(--gi-r-4) 0;
	background: var(--gi-surface);
	border: 1px solid var(--gi-line);
	border-radius: var(--gi-radius);
	overflow: hidden;
}
.gi-props .gi-prop {
	display: flex;
	gap: var(--gi-r-2);
	padding: var(--gi-r-3) var(--gi-r-4);
	font-size: var(--gi-fs-sm);
	color: var(--gi-text-2);
	border-right: 1px solid var(--gi-line);
	border-bottom: 1px solid var(--gi-line);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.gi-props .gi-prop b {
	flex: 0 0 auto;
	color: var(--gi-text-3);
	font-weight: 400;
}
.gi-props .gi-prop span {
	color: var(--gi-text-1);
	overflow: hidden;
	text-overflow: ellipsis;
}

/* --------------------------------------------------------------------------
   Store info card (right side of the gallery)
   Compound class on the root: .gi-store-card.store-info
   Section layout (top → bottom):
     1. .gi-store-head            — store name (gray band)
     2. .content > .total_evaluation — overall rating row
     3. .content > .rate-info     — three sub-ratings (vertical list)
     4. .content > .dl-c-s ×N     — credit / cert / tel / address meta rows
     5. .content > .go2store      — single primary CTA

   IMPORTANT: legacy shop.css has high-specificity rules on .store-info
   (0,3,1 ~ 0,4,1) that override this card. We use the compound class
   .gi-store-card.store-info + .content to match the same specificity
   (0,3,1) and combine with !important on critical properties to win.
   -------------------------------------------------------------------------- */

/* === 1. Card container === */
.gi-store-card,
.gi-store-card.store-info,
.gi-store-card.store-info .content {
	background: var(--gi-surface) !important;
	border: 1px solid var(--gi-line) !important;
	border-radius: var(--gi-radius) !important;
	padding: 0 !important;
	margin: 0 !important;
	color: var(--gi-text-1) !important;
	font-size: var(--gi-fs-sm) !important;
	display: flex !important;
	flex-direction: column !important;
	width: 100% !important;
	box-sizing: border-box !important;
	overflow: hidden !important;
	min-width: 0;
}
.gi-store-card.store-info .content {
	border: 0 !important;
	border-radius: 0 !important;
}

/* === 2. Header (store name) — beat .store-info h3 / h3 span === */
.gi-store-card .gi-store-head,
.gi-store-card.store-info .gi-store-head {
	display: flex !important;
	align-items: center !important;
	gap: var(--gi-r-2) !important;
	padding: 14px var(--gi-r-4) !important;
	background: var(--gi-bg) !important;
	border: 0 !important;
	border-bottom: 1px solid var(--gi-line) !important;
	border-radius: 0 !important;
	margin: 0 !important;
}
.gi-store-card .gi-store-head h3,
.gi-store-card .gi-store-head h3 span,
.gi-store-card.store-info .gi-store-head h3,
.gi-store-card.store-info .gi-store-head h3 span {
	display: block !important;
	visibility: visible !important;
	opacity: 1 !important;
	margin: 0 !important;
	padding: 0 !important;
	border: 0 !important;
	background: transparent !important;
	font: 600 var(--gi-fs-md) / 1.4 -apple-system, BlinkMacSystemFont, "PingFang SC", "Microsoft YaHei", Arial, sans-serif !important;
	color: var(--gi-text-1) !important;
	flex: 1 1 auto !important;
	min-width: 0 !important;
	max-width: 100% !important;
	overflow: hidden !important;
	text-overflow: ellipsis !important;
	white-space: nowrap !important;
	letter-spacing: 0 !important;
	text-align: left !important;
	width: auto !important;
	height: auto !important;
	float: none !important;
}

/* === 3. Content wrapper === */
.gi-store-card.store-info .content,
.gi-store-card .content {
	padding: 0 !important;
	background: transparent !important;
	border: 0 !important;
	display: flex !important;
	flex-direction: column !important;
	gap: 0 !important;
}

/* === 4. Inner section reset — kill legacy .w-full / .clearfix / border-b === */
.gi-store-card.store-info .content .total_evaluation,
.gi-store-card.store-info .content .rate-info,
.gi-store-card.store-info .content .dl-c-s,
.gi-store-card.store-info .content .go2store,
.gi-store-card .total_evaluation,
.gi-store-card .rate-info,
.gi-store-card .dl-c-s,
.gi-store-card .go2store {
	padding-left: var(--gi-r-4) !important;
	padding-right: var(--gi-r-4) !important;
	margin: 0 !important;
	border-left: 0 !important;
	border-right: 0 !important;
	width: auto !important;
	float: none !important;
	background: var(--gi-surface) !important;
	display: block !important;
}

/* === 5. Overall rating row — beat .store-info .content .total_evaluation === */
.gi-store-card.store-info .content .total_evaluation,
.gi-store-card .total_evaluation {
	display: flex !important;
	align-items: baseline !important;
	justify-content: space-between !important;
	gap: var(--gi-r-3) !important;
	padding-top: 14px !important;
	padding-bottom: 8px !important;
	font-size: var(--gi-fs-sm) !important;
	color: var(--gi-text-2) !important;
	border: 0 !important;
}
.gi-store-card.store-info .content .total_evaluation dt,
.gi-store-card .total_evaluation dt {
	flex: 0 0 auto !important;
	color: var(--gi-text-2) !important;
	font-size: var(--gi-fs-sm) !important;
	display: inline-block !important;
	width: auto !important;
	text-align: left !important;
	margin: 0 !important;
	padding: 0 !important;
	vertical-align: baseline !important;
	letter-spacing: normal !important;
	word-spacing: normal !important;
	float: none !important;
}
.gi-store-card.store-info .content .total_evaluation dd,
.gi-store-card .total_evaluation dd {
	flex: 0 0 auto !important;
	color: var(--gi-text-1) !important;
	font-size: var(--gi-fs-sm) !important;
	display: inline-flex !important;
	align-items: baseline !important;
	gap: 0 !important;
	text-align: right !important;
	white-space: nowrap !important;
	overflow: visible !important;
	margin: 0 !important;
	padding: 0 !important;
	width: auto !important;
	float: none !important;
	letter-spacing: normal !important;
	word-spacing: normal !important;
	vertical-align: baseline !important;
}
.gi-store-card.store-info .content .total_evaluation b,
.gi-store-card .total_evaluation b {
	color: var(--gi-warning) !important;
	font-size: var(--gi-fs-2xl) !important;
	font-weight: 700 !important;
	font-variant-numeric: tabular-nums !important;
	line-height: 1 !important;
	margin: 0 !important;
	padding: 0 !important;
	vertical-align: baseline !important;
}

/* === 6. Sub-rating list — beat .store-info .content .rate-info === */
.gi-store-card.store-info .content .rate-info,
.gi-store-card .rate-info {
	display: flex !important;
	flex-direction: column !important;
	gap: 6px !important;
	padding-top: 4px !important;
	padding-bottom: 14px !important;
	border: 0 !important;
	border-bottom: 1px dashed var(--gi-line) !important;
	color: var(--gi-text-2) !important;
	width: auto !important;
}
.gi-store-card.store-info .content .rate-info > p,
.gi-store-card .rate-info > p {
	display: flex !important;
	align-items: baseline !important;
	gap: 6px !important;
	margin: 0 0 4px 0 !important;
	color: var(--gi-text-3) !important;
	font-size: var(--gi-fs-xs) !important;
	line-height: 1.4 !important;
	font-weight: normal !important;
}
.gi-store-card.store-info .content .rate-info > p strong,
.gi-store-card .rate-info > p strong {
	color: var(--gi-text-1) !important;
	font-weight: 600 !important;
	font-size: var(--gi-fs-sm) !important;
	margin-right: 4px !important;
}
.gi-store-card.store-info .content .rate-info ul,
.gi-store-card .rate-info ul {
	display: flex !important;
	flex-direction: column !important;
	gap: 4px !important;
	margin: 0 !important;
	padding: 0 !important;
	list-style: none !important;
}
.gi-store-card.store-info .content .rate-info li,
.gi-store-card .rate-info li {
	display: grid !important;
	grid-template-columns: 56px 40px 1fr !important;
	gap: 10px !important;
	align-items: center !important;
	margin: 0 !important;
	padding: 0 !important;
	font-size: var(--gi-fs-sm) !important;
	color: var(--gi-text-2) !important;
	line-height: 1.5 !important;
}
.gi-store-card.store-info .content .rate-info li .credit,
.gi-store-card .rate-info li .credit {
	color: var(--gi-text-1) !important;
	font-weight: 600 !important;
	font-size: var(--gi-fs-md) !important;
	font-variant-numeric: tabular-nums !important;
	text-align: left !important;
	background: transparent !important;
	border: 0 !important;
	padding: 0 !important;
	margin: 0 !important;
	width: auto !important;
	display: inline-block !important;
}
.gi-store-card.store-info .content .rate-info li span.equal,
.gi-store-card.store-info .content .rate-info li span.high,
.gi-store-card.store-info .content .rate-info li span.low,
.gi-store-card .rate-info li span.equal,
.gi-store-card .rate-info li span.high,
.gi-store-card .rate-info li span.low {
	justify-self: end !important;
	display: inline-flex !important;
	align-items: center !important;
	gap: 3px !important;
	color: var(--gi-text-3) !important;
	font-size: var(--gi-fs-xs) !important;
	padding: 0 !important;
	margin: 0 !important;
	background: transparent !important;
	border: 0 !important;
	font-weight: normal !important;
}
.gi-store-card.store-info .content .rate-info li span em,
.gi-store-card .rate-info li span em {
	font-style: normal !important;
	color: inherit !important;
	background: transparent !important;
	border: 0 !important;
	padding: 0 !important;
	margin: 0 !important;
	display: inline !important;
	width: auto !important;
	height: auto !important;
	line-height: inherit !important;
}
.gi-store-card.store-info .content .rate-info li span i,
.gi-store-card .rate-info li span i {
	display: none !important;
}

/* === 7. Meta info rows (dl.dl-c-s) — beat .store-info .content .dl-c-s { display:none } === */
.gi-store-card.store-info .content .dl-c-s,
.gi-store-card .dl-c-s {
	display: grid !important;
	grid-template-columns: 56px 1fr !important;
	gap: 8px 12px !important;
	align-items: center !important;
	padding-top: 9px !important;
	padding-bottom: 9px !important;
	border: 0 !important;
	border-bottom: 1px dashed var(--gi-line) !important;
	font-size: var(--gi-fs-sm) !important;
	color: var(--gi-text-2) !important;
	line-height: 1.5 !important;
	width: auto !important;
}
.gi-store-card.store-info .content .dl-c-s:last-of-type,
.gi-store-card .dl-c-s:last-of-type {
	border-bottom: 0 !important;
}
.gi-store-card.store-info .content .dl-c-s dt,
.gi-store-card.store-info .content .dl-c-s dd,
.gi-store-card .dl-c-s dt,
.gi-store-card .dl-c-s dd {
	display: block !important;
	margin: 0 !important;
	padding: 0 !important;
	float: none !important;
	width: auto !important;
	min-width: 0 !important;
	letter-spacing: normal !important;
	word-spacing: normal !important;
	vertical-align: top !important;
	line-height: 1.5 !important;
}
.gi-store-card.store-info .content .dl-c-s dt,
.gi-store-card .dl-c-s dt {
	color: var(--gi-text-3) !important;
	text-align: left !important;
}
.gi-store-card.store-info .content .dl-c-s dd,
.gi-store-card .dl-c-s dd {
	color: var(--gi-text-1) !important;
	word-break: break-all !important;
}
.gi-store-card.store-info .content .dl-c-s img,
.gi-store-card .dl-c-s img {
	display: inline-block !important;
	height: 16px !important;
	vertical-align: middle !important;
	margin-right: 4px !important;
	border-radius: 2px !important;
}

/* Hide the duplicate store_name row (it's now in the header) */
.gi-store-card.store-info .content > dl.dl-c-s:nth-of-type(2),
.gi-store-card .content > dl.dl-c-s:nth-of-type(2) {
	display: none !important;
}

/* === 8. Action button (go2store) — beat .store-info .content .go2store === */
.gi-store-card.store-info .content .go2store,
.gi-store-card .go2store {
	display: flex !important;
	gap: var(--gi-r-2) !important;
	padding-top: 14px !important;
	padding-bottom: 14px !important;
	background: var(--gi-bg) !important;
	border: 0 !important;
	border-top: 1px solid var(--gi-line) !important;
	margin: 0 !important;
	text-align: left !important;
}
.gi-store-card.store-info .content .go2store a,
.gi-store-card .go2store a {
	flex: 1 1 0 !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 4px !important;
	padding: 10px 0 !important;
	background: var(--gi-accent) !important;
	border: 1px solid var(--gi-accent) !important;
	border-radius: var(--gi-radius-sm) !important;
	color: #fff !important;
	font-size: var(--gi-fs-sm) !important;
	font-weight: 500 !important;
	text-decoration: none !important;
	margin: 0 !important;
	min-height: 40px !important;
	transition: background .15s var(--gi-ease), border-color .15s var(--gi-ease) !important;
}
.gi-store-card.store-info .content .go2store a:hover,
.gi-store-card .go2store a:hover {
	background: var(--gi-accent-deep) !important;
	border-color: var(--gi-accent-deep) !important;
	color: #fff !important;
	text-decoration: none !important;
}

/* === 8. Final nuclear reset: kill every legacy sprite / color / width === */
.gi-store-card .raty,
.gi-store-card .raty span,
.gi-store-card .rate-info li span em,
.gi-store-card .rate-info li span i,
.gi-store-card .hotsale .content .rank-nav li a,
.gi-store-card .hotsale .content ul li .price strong,
.gi-store-card .hotsale .content ul li .sale,
.gi-store-card .hotsale .content ul li .collecter {
	background-image: none !important;
}

/* === 9. Responsive === */
@media (max-width: 640px) {
	.gi-store-card .dl-c-s {
		grid-template-columns: 56px 1fr;
	}
	.gi-store-card .rate-info li span.equal,
	.gi-store-card .rate-info li span.high,
	.gi-store-card .rate-info li span.low {
		margin-left: 0;
		width: 100%;
		justify-content: flex-end;
	}
}

/* --------------------------------------------------------------------------
   Sidebar (left.html) — keep legacy classes, restyle
   -------------------------------------------------------------------------- */
.gi-side .store-info,
.gi-side .store-search,
.gi-side .gcategroy,
.gi-side .hotsale,
.gi-side .goods-history {
	background: var(--gi-surface);
	border: 1px solid var(--gi-line);
	border-radius: var(--gi-radius);
	margin-bottom: var(--gi-r-4);
	overflow: hidden;
}
.gi-side h3 {
	display: flex;
	align-items: center;
	padding: var(--gi-r-3) var(--gi-r-4);
	font-size: var(--gi-fs-md);
	font-weight: 600;
	color: var(--gi-text-1);
	background: var(--gi-surface);
	border-bottom: 1px solid var(--gi-line);
}
.gi-side h3 span { flex: 1 1 auto; }
.gi-side .content { padding: var(--gi-r-3) var(--gi-r-4); }

.gi-side .store-search form { display: flex; gap: var(--gi-r-2); }
.gi-side .store-search .text {
	flex: 1 1 auto;
	height: 32px;
	padding: 0 10px;
	border: 1px solid var(--gi-line);
	border-radius: var(--gi-radius-sm);
	font-size: var(--gi-fs-sm);
}
.gi-side .store-search .btn {
	padding: 0 14px;
	background: var(--gi-accent);
	color: #fff;
	border: 0;
	border-radius: var(--gi-radius-sm);
	font-size: var(--gi-fs-sm);
	cursor: pointer;
}
.gi-side .store-search .btn:hover { background: var(--gi-accent-deep); }

.gi-side .gcategroy .list { padding: 0; }
.gi-side .gcategroy .list li {
	border-bottom: 1px dashed var(--gi-line);
}
.gi-side .gcategroy .list li:last-child { border-bottom: 0; }
.gi-side .gcategroy .list li h3 {
	padding: 0;
	background: transparent;
	border-bottom: 0;
	font-size: var(--gi-fs-sm);
	font-weight: 500;
	color: var(--gi-text-1);
	display: flex;
	align-items: center;
	gap: var(--gi-r-2);
}
.gi-side .gcategroy .list li h3 a { color: var(--gi-text-1); flex: 1; }
.gi-side .gcategroy .list li h3 a:hover { color: var(--gi-accent); }
.gi-side .gcategroy .list li h3 i { cursor: pointer; opacity: .5; }
.gi-side .gcategroy .sub_gcate {
	padding: 4px 0 8px var(--gi-r-4);
	display: none;
}
.gi-side .gcategroy .sub_gcate li { padding: 4px 0; }
.gi-side .gcategroy .sub_gcate a { font-size: var(--gi-fs-sm); color: var(--gi-text-2); }
.gi-side .gcategroy .sub_gcate a:hover { color: var(--gi-accent); }

.gi-side .rank-nav { display: flex; gap: 0; border-bottom: 1px solid var(--gi-line); }
.gi-side .rank-nav li {
	flex: 1 1 0;
	padding: var(--gi-r-3) 0;
	text-align: center;
	font-size: var(--gi-fs-sm);
	color: var(--gi-text-2);
	cursor: pointer;
	border-bottom: 2px solid transparent;
	transition: color .15s var(--gi-ease), border-color .15s var(--gi-ease);
}
.gi-side .rank-nav li.curr {
	color: var(--gi-accent);
	border-bottom-color: var(--gi-accent);
	font-weight: 500;
}
.gi-side .rank-c { padding: 0; }
.gi-side .rank-c li {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 4px var(--gi-r-2);
	padding: var(--gi-r-3) 0;
	border-bottom: 1px dashed var(--gi-line);
	font-size: var(--gi-fs-sm);
}
.gi-side .rank-c li:last-child { border-bottom: 0; }
.gi-side .rank-c li .pic {
	flex: 0 0 40px;
	width: 40px;
	height: 40px;
	border: 1px solid var(--gi-line);
	border-radius: var(--gi-radius-sm);
	overflow: hidden;
	background: var(--gi-bg);
	display: block;
	align-self: flex-start;
}
.gi-side .rank-c li .pic img { width: 100%; height: 100%; object-fit: cover; display: block; }
.gi-side .rank-c li .desc {
	flex: 1 0 60%;
	min-width: 0;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	font-size: var(--gi-fs-sm);
	color: var(--gi-text-1);
	line-height: 1.4;
	word-break: break-word;
}
.gi-side .rank-c li .desc a {
	color: var(--gi-text-1);
	text-decoration: none;
	display: inline;
}
.gi-side .rank-c li .desc a:hover { color: var(--gi-accent); }
.gi-side .rank-c li .price {
	flex: 0 0 auto;
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	gap: 2px 4px;
	margin: 0;
	white-space: nowrap;
}
.gi-side .rank-c li .price strong {
	color: var(--gi-accent);
	font-weight: 600;
	font-size: var(--gi-fs-sm);
	font-variant-numeric: tabular-nums;
}
.gi-side .rank-c li .sale,
.gi-side .rank-c li .collecter {
	flex: 0 0 auto;
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	gap: 2px 4px;
	color: var(--gi-text-3);
	font-size: var(--gi-fs-xs);
	margin: 0;
	white-space: nowrap;
}
.gi-side .rank-c li .sale strong,
.gi-side .rank-c li .collecter strong {
	color: var(--gi-text-2);
	font-weight: 500;
	font-variant-numeric: tabular-nums;
}

.gi-side .goods-history ul { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--gi-r-2); }
.gi-side .goods-history li {
	aspect-ratio: 1 / 1;
	border: 1px solid var(--gi-line);
	border-radius: var(--gi-radius-sm);
	overflow: hidden;
	background: var(--gi-bg);
}
.gi-side .goods-history li img { width: 100%; height: 100%; object-fit: cover; }

/* --------------------------------------------------------------------------
   Empty / notice
   -------------------------------------------------------------------------- */
.gi-empty {
	padding: var(--gi-r-7) var(--gi-r-5);
	text-align: center;
	color: var(--gi-text-3);
	font-size: var(--gi-fs-md);
}

/* --------------------------------------------------------------------------
   Responsive
   -------------------------------------------------------------------------- */
@media (max-width: 640px) {
	.gi-wrap { padding: var(--gi-r-3) 0; }
	.gi-top  { padding: var(--gi-r-3); gap: var(--gi-r-4); }
	.gi-name { font-size: var(--gi-fs-xl); }
	.gi-price-card .gi-price { font-size: var(--gi-fs-2xl); }
	.gi-cta { flex-direction: column; }
	.gi-tabbar { padding: 0 var(--gi-r-3); overflow-x: auto; }
	.gi-tab { padding: var(--gi-r-3) var(--gi-r-3); }
}

/* --------------------------------------------------------------------------
   Breadcrumb — .location
   Replaces the legacy .location in shop.css (#666 + 1px bordered boxes +
   simsun font + 15px auto margins) with a flat, modern breadcrumb that
   uses the gi- design tokens.
   -------------------------------------------------------------------------- */
#page-goods-index .location,
#page-goods-index nav.location {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	column-gap: 6px;
	row-gap: 4px;
	margin: 0;
	padding: 16px 0;
	font-size: var(--gi-fs-sm);
	line-height: 1.5;
	color: var(--gi-text-1);            /* current page uses darker color */
	font-family: -apple-system, BlinkMacSystemFont, "PingFang SC", "Microsoft YaHei", "Helvetica Neue", Arial, sans-serif;
}

/* Strip legacy .mt10 / .mb10 from curlocal.html — gi-page already
   provides vertical rhythm, no extra 10px margin needed. */
#page-goods-index .location.mt10,
#page-goods-index .location.mb10 {
	margin-top: 0;
	margin-bottom: 0;
}

#page-goods-index .location a {
	color: var(--gi-text-2);
	text-decoration: none;
	padding: 2px 0;
	border: 0;
	border-radius: 0;
	background: transparent;
	transition: color .15s var(--gi-ease);
}

#page-goods-index .location a:hover,
#page-goods-index .location a:focus-visible {
	color: var(--gi-accent);
	text-decoration: none;
	border: 0;
	background: transparent;
	outline: none;
}

#page-goods-index .location .sep,
#page-goods-index .location span[aria-hidden] {
	color: var(--gi-text-3);
	margin: 0 2px;
	opacity: .55;
	font-family: inherit;
	font-size: var(--gi-fs-sm);
	user-select: none;
	line-height: 1;
}

#page-goods-index .location .current {
	color: var(--gi-text-1);
	font-weight: 500;
	max-width: 100%;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

/* Mobile — keep separator visible but tighten the gap */
@media (max-width: 640px) {
	#page-goods-index .location {
		padding: 12px 0;
		column-gap: 4px;
		font-size: var(--gi-fs-xs);
	}
	#page-goods-index .location a,
	#page-goods-index .location .current {
		max-width: 160px;
		overflow: hidden;
		text-overflow: ellipsis;
		white-space: nowrap;
	}
}

/* --------------------------------------------------------------------------
   Page-level layout — #page-goods-index
   Single source of truth for the whole product detail page: keeps
   the top gallery (.gi-top) and the lower sidebar+main (.gi-page-body)
   in one consistent grid system. Replaces the legacy .w-shop / .col-sub /
   .col-main / .w210 / .w980 float hack.
   -------------------------------------------------------------------------- */
.gi-page {
	display: block;
	max-width: 1200px;
	width: 100%;
	margin-left: auto;
	margin-right: auto;
	padding-left: 24px;
	padding-right: 24px;
	box-sizing: border-box;
	overflow-x: hidden;
}

#page-goods-index {
	overflow-x: hidden;
}

.gi-page-body {
	display: grid;
	grid-template-columns: 230px 1fr;
	gap: 20px;
	align-items: start;
	margin-top: 20px;
	min-width: 0;
}

.gi-page-side {
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.gi-page-side > .store-info,
.gi-page-side > .store-search,
.gi-page-side > .gcategroy,
.gi-page-side > .hotsale,
.gi-page-side > .goods-history {
	width: 100%;
	margin: 0;
	/* reset legacy .gi-side margin-bottom so it doesn't compound
	   with the flex gap above */
	margin-bottom: 0;
}

.gi-page-main {
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 16px;
}

/* Make sure the bottom sections don't pick up legacy float / width
   rules from .col-sub, .col-main, .w210, .w980, .w-shop, .border, etc. */
#page-goods-index .w-shop,
#page-goods-index .col-sub,
#page-goods-index .col-main,
#page-goods-index .gi-page-side.col-sub,
#page-goods-index .gi-page-main.col-main {
	float: none;
	width: auto;
	margin: 0;
	padding: 0;
}

@media (max-width: 1024px) {
	.gi-page-body {
		grid-template-columns: 1fr;
		gap: 16px;
	}
	.gi-page {
		padding-left: 16px;
		padding-right: 16px;
	}
}

@media (max-width: 640px) {
	.gi-page {
		padding-left: 12px;
		padding-right: 12px;
	}
}

/* --------------------------------------------------------------------------
   A11y / motion
   -------------------------------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
	.gi-wrap *,
	.gi-wrap *::before,
	.gi-wrap *::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
		scroll-behavior: auto !important;
	}
}
