#gsRefShowcase,
#gsRefShowcase * {
  box-sizing: border-box;
}

#gsRefShowcase {
  --gsrs-bg: #f6f8f8;
  --gsrs-text: #172023;
  --gsrs-muted: #667277;
  --gsrs-brand: #3f7f99;
  --gsrs-brand-dark: #26596d;
  --gsrs-accent: #f5b84b;
  --gsrs-card: rgba(255, 255, 255, 0.58);
  --gsrs-card-strong: rgba(255, 255, 255, 0.82);
  --gsrs-line: rgba(23, 32, 35, 0.1);
  --gsrs-shadow: 0 24px 70px rgba(23, 32, 35, 0.13);
  --gsrs-motion: cubic-bezier(0.19, 1, 0.22, 1);
  position: relative;
  overflow: hidden;
  padding: clamp(72px, 8vw, 128px) 18px;
  background:
    radial-gradient(circle at 12% 12%, rgba(63, 127, 153, 0.16), transparent 34%),
    radial-gradient(circle at 88% 20%, rgba(245, 184, 75, 0.14), transparent 30%),
    radial-gradient(circle at 52% 96%, rgba(63, 127, 153, 0.1), transparent 34%),
    linear-gradient(180deg, #ffffff 0%, var(--gsrs-bg) 100%);
  color: var(--gsrs-text);
  isolation: isolate;
}

#gsRefShowcase::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(23, 32, 35, 0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(23, 32, 35, 0.04) 1px, transparent 1px);
  background-size: 44px 44px;
  mask-image: radial-gradient(circle at center, black, transparent 78%);
  opacity: 0.55;
  pointer-events: none;
  z-index: -2;
}

#gsRefShowcase::after {
  content: "";
  position: absolute;
  width: 420px;
  height: 420px;
  left: var(--mx, 50%);
  top: var(--my, 32%);
  transform: translate(-50%, -50%);
  border-radius: 999px;
  background: radial-gradient(circle, rgba(63, 127, 153, 0.16), transparent 62%);
  filter: blur(10px);
  pointer-events: none;
  z-index: -1;
  opacity: 0.9;
}

.gsrs-shell { width: min(1180px, 100%); margin: 0 auto; position: relative; z-index: 1; }
.gsrs-hero { display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(320px, 0.95fr); gap: clamp(32px, 5vw, 72px); align-items: center; }
.gsrs-kicker { display: inline-flex; align-items: center; gap: 10px; padding: 9px 14px; border: 1px solid rgba(63, 127, 153, 0.18); border-radius: 999px; background: rgba(255, 255, 255, 0.58); color: var(--gsrs-brand-dark); font-size: 13px; font-weight: 750; letter-spacing: 0.02em; backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px); box-shadow: 0 8px 20px rgba(23, 32, 35, 0.05); }
.gsrs-kicker::before { content: ""; width: 9px; height: 9px; border-radius: 999px; background: var(--gsrs-accent); box-shadow: 0 0 0 6px rgba(245, 184, 75, 0.15); animation: gsrsPulse 1.8s ease-in-out infinite; }
.gsrs-title { margin: 20px 0 18px; max-width: 760px; font-size: clamp(34px, 5.4vw, 72px); line-height: 0.96; letter-spacing: -0.065em; font-weight: 850; color: var(--gsrs-text); }
.gsrs-title span:last-child { color: transparent; background: linear-gradient(135deg, var(--gsrs-brand-dark), var(--gsrs-brand), #75a9ba); -webkit-background-clip: text; background-clip: text; }
.gsrs-lead { max-width: 650px; margin: 0; color: var(--gsrs-muted); font-size: clamp(16px, 1.45vw, 19px); line-height: 1.75; }
.gsrs-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 28px; }
.gsrs-btn { position: relative; display: inline-flex; align-items: center; justify-content: center; gap: 10px; min-height: 48px; padding: 13px 18px; border-radius: 999px; border: 1px solid rgba(23, 32, 35, 0.1); background: rgba(255, 255, 255, 0.62); color: var(--gsrs-text); text-decoration: none !important; font-size: 14px; font-weight: 760; overflow: hidden; backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px); transition: transform 0.24s ease, box-shadow 0.24s ease, border-color 0.24s ease, background 0.24s ease; }
.gsrs-btn-primary { background: linear-gradient(135deg, var(--gsrs-brand-dark), var(--gsrs-brand)); color: var(--gsrs-btn-primary-text, #fff) !important; border-color: rgba(255, 255, 255, 0.18); box-shadow: 0 16px 38px rgba(63, 127, 153, 0.25); }
.gsrs-btn::after { content: ""; position: absolute; inset: -80% auto auto -30%; width: 54%; height: 260%; transform: rotate(24deg); background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.36), transparent); transition: left 0.55s ease; }
.gsrs-btn:hover { transform: translateY(-2px); box-shadow: 0 18px 38px rgba(23, 32, 35, 0.12); }
.gsrs-btn:hover::after { left: 110%; }
.gsrs-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-top: 34px; max-width: 640px; }
.gsrs-stat { padding: 18px 16px; border-radius: 22px; border: 1px solid rgba(23, 32, 35, 0.08); background: rgba(255, 255, 255, 0.56); backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px); box-shadow: 0 10px 24px rgba(23, 32, 35, 0.05); transition: transform 0.24s ease, background 0.24s ease; }
.gsrs-stat:hover { transform: translateY(-4px); background: rgba(255, 255, 255, 0.78); }
.gsrs-stat strong { display: block; font-size: clamp(22px, 2.6vw, 34px); line-height: 1; letter-spacing: -0.04em; color: var(--gsrs-brand-dark); }
.gsrs-stat span { display: block; margin-top: 8px; color: var(--gsrs-muted); font-size: 13px; line-height: 1.35; font-weight: 650; }
.gsrs-stack-area { position: relative; min-height: 540px; display: flex; align-items: center; justify-content: center; perspective: 1600px; touch-action: pan-y; }
.gsrs-orbit { display: none !important; }
.gsrs-orbit::before, .gsrs-orbit::after { content: ""; position: absolute; width: 13px; height: 13px; border-radius: 999px; background: var(--gsrs-accent); box-shadow: 0 0 0 8px rgba(245, 184, 75, 0.14); }
.gsrs-orbit::before { top: 10%; left: 18%; }
.gsrs-orbit::after { right: 12%; bottom: 18%; background: var(--gsrs-brand); box-shadow: 0 0 0 8px rgba(63, 127, 153, 0.14); }
.gsrs-stack { position: relative; width: min(430px, 92vw); height: 500px; transform-style: preserve-3d; }
.gsrs-stack-card { --offset: 0; --abs-offset: 0; --dir: 1; --card-x: calc(var(--offset) * 24px); --card-y: calc(var(--offset) * 18px); --card-z: calc(var(--offset) * -70px); --card-rotate: calc(var(--offset) * -4.2deg); --card-rotate-y: calc(var(--offset) * -5deg); --card-scale: calc(1 - var(--offset) * 0.045); position: absolute; inset: 0; border-radius: 34px; border: 1px solid rgba(255, 255, 255, 0.56); background: linear-gradient(145deg, rgba(255, 255, 255, 0.72), rgba(255, 255, 255, 0.36)); backdrop-filter: blur(8px) saturate(120%); -webkit-backdrop-filter: blur(8px) saturate(120%); box-shadow: 0 14px 36px rgba(23, 32, 35, 0.1); overflow: hidden; opacity: calc(1 - var(--offset) * 0.17); pointer-events: none; will-change: transform, opacity, filter; transform: translate3d(var(--card-x), var(--card-y), var(--card-z)) rotateZ(var(--card-rotate)) rotateY(var(--card-rotate-y)) scale(var(--card-scale)); transition: transform 920ms var(--gsrs-motion), opacity 720ms ease, filter 720ms ease, box-shadow 520ms ease; display: flex; flex-direction: column; }
.gsrs-stack-card.is-active { pointer-events: auto; opacity: 1; filter: blur(0); box-shadow: 0 20px 48px rgba(23, 32, 35, 0.14), 0 8px 18px rgba(63, 127, 153, 0.08); }
.gsrs-stack-card.is-back { pointer-events: none; }
.gsrs-stack-card.is-hidden { opacity: 0; filter: blur(5px); transform: translate3d(92px, 52px, -340px) rotateZ(9deg) rotateY(-14deg) scale(0.82); }
.gsrs-stack-card.is-soft-enter { animation: gsrsSoftEnter 760ms var(--gsrs-motion) both; }
.gsrs-stack-card.is-soft-leave-next { animation: gsrsSoftLeaveNext 760ms var(--gsrs-motion) both; }
.gsrs-stack-card.is-soft-leave-prev { animation: gsrsSoftLeavePrev 760ms var(--gsrs-motion) both; }
.gsrs-stack-card.is-active:hover { transform: translate3d(0, -8px, 28px) rotateZ(-0.8deg) rotateY(2deg) scale(1.012); }
.gsrs-card-media { position: relative; flex: 0 0 54%; overflow: hidden; background: linear-gradient(135deg, rgba(63, 127, 153, 0.25), rgba(245, 184, 75, 0.16)), #dfe8eb; }
.gsrs-card-media img { width: 100%; height: 100%; object-fit: cover; display: block; transform: scale(1.04); transition: transform 900ms var(--gsrs-motion), filter 520ms ease; filter: saturate(0.98) contrast(0.98); }
.gsrs-stack-card.is-active:hover .gsrs-card-media img { transform: scale(1.105); filter: saturate(1.06) contrast(1.03); }
.gsrs-card-media::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 45%, rgba(0, 0, 0, 0.5)), radial-gradient(circle at 24% 18%, rgba(255, 255, 255, 0.3), transparent 34%); pointer-events: none; }
.gsrs-card-badge { position: absolute; top: 18px; left: 18px; z-index: 2; display: inline-flex; align-items: center; gap: 8px; padding: 9px 12px; border-radius: 999px; background: rgba(255, 255, 255, 0.74); color: var(--gsrs-brand-dark); font-size: 12px; font-weight: 800; backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px); border: 1px solid rgba(255, 255, 255, 0.45); }
.gsrs-card-badge::before { content: ""; width: 7px; height: 7px; border-radius: 99px; background: var(--gsrs-accent); }
.gsrs-card-body { padding: 20px 22px; flex: 1 1 auto; display: flex; flex-direction: column; justify-content: space-between; gap: 14px; min-height: 0; }
.gsrs-card-body h3 { margin: 0; font-size: clamp(22px, 2.1vw, 28px); line-height: 1.08; letter-spacing: -0.04em; color: var(--gsrs-text); font-weight: 840; }
.gsrs-card-body p { margin: 12px 0 0; color: var(--gsrs-muted); font-size: 14.5px; line-height: 1.62; }
.gsrs-card-link { display: inline-flex; align-items: center; justify-content: space-between; gap: 12px; width: 100%; padding: 13px 15px; border-radius: 16px; color: #fff !important; background: linear-gradient(135deg, var(--gsrs-brand-dark), var(--gsrs-brand)); text-decoration: none !important; font-size: 14px; font-weight: 800; box-shadow: 0 14px 32px rgba(63, 127, 153, 0.22); transition: transform 0.22s ease, box-shadow 0.22s ease; margin-top: auto; }
.gsrs-card-link:hover { transform: translateY(-2px); box-shadow: 0 18px 40px rgba(63, 127, 153, 0.3); }
.gsrs-card-link span:last-child { width: 30px; height: 30px; border-radius: 999px; display: grid; place-items: center; background: rgba(255, 255, 255, 0.18); transition: transform 0.22s ease; }
.gsrs-card-link:hover span:last-child { transform: translateX(3px); }
.gsrs-stack-controls { position: absolute; right: 8px; bottom: 8px; display: flex; gap: 10px; z-index: 60; }
.gsrs-stack-btn { width: 46px; height: 46px; border: 1px solid rgba(23, 32, 35, 0.1); border-radius: 999px; background: rgba(255, 255, 255, 0.72); color: var(--gsrs-text); cursor: pointer; display: grid; place-items: center; font-size: 20px; font-weight: 900; backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px); box-shadow: 0 10px 20px rgba(23, 32, 35, 0.08); transition: transform 0.22s ease, background 0.22s ease; }
.gsrs-stack-btn:hover { transform: translateY(-3px); background: rgba(255, 255, 255, 0.94); }
.gsrs-section-head { margin: clamp(58px, 7vw, 96px) 0 28px; display: flex; align-items: end; justify-content: space-between; gap: 22px; }
.gsrs-section-head h2 { margin: 0; max-width: 720px; font-size: clamp(28px, 3.4vw, 48px); line-height: 1.05; letter-spacing: -0.05em; font-weight: 840; }
.gsrs-section-head p { margin: 12px 0 0; color: var(--gsrs-muted); font-size: 15.5px; line-height: 1.65; max-width: 560px; }
.gsrs-taxonomy { display: flex; flex-wrap: wrap; gap: 10px; margin: 26px 0 18px; }
.gsrs-tax-btn { border: 1px solid rgba(23, 32, 35, 0.1); border-radius: 999px; padding: 11px 15px; background: rgba(255, 255, 255, 0.58); color: var(--gsrs-muted); cursor: pointer; font-size: 13px; font-weight: 800; white-space: nowrap; backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px); transition: transform 0.22s ease, background 0.22s ease, color 0.22s ease, border-color 0.22s ease, box-shadow 0.22s ease; }
.gsrs-tax-btn:hover { transform: translateY(-2px); color: var(--gsrs-text); background: rgba(255, 255, 255, 0.85); }
.gsrs-tax-btn.is-active { color: #fff; background: linear-gradient(135deg, var(--gsrs-brand-dark), var(--gsrs-brand)); border-color: transparent; box-shadow: 0 12px 28px rgba(63, 127, 153, 0.22); }
.gsrs-category-note { margin: 0 0 28px; color: var(--gsrs-muted); font-size: 14.5px; line-height: 1.65; }
.gsrs-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.gsrs-grid-card { position: relative; overflow: hidden; min-height: 340px; border-radius: 26px; background: #dfe8eb; border: 1px solid rgba(255, 255, 255, 0.55); box-shadow: 0 12px 30px rgba(23, 32, 35, 0.08); transform: translateY(16px); opacity: 0; transition: transform 0.55s cubic-bezier(.2, .8, .2, 1), opacity 0.5s ease, box-shadow 0.28s ease; }
.gsrs-grid-card.is-visible { transform: translateY(0); opacity: 1; }
.gsrs-grid-card img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transform: scale(1.04); transition: transform 0.68s cubic-bezier(.2, .8, .2, 1), filter 0.32s ease; }
.gsrs-grid-card::before { content: ""; position: absolute; inset: 0; z-index: 1; background: linear-gradient(180deg, rgba(0, 0, 0, 0.02) 20%, rgba(0, 0, 0, 0.74) 100%), radial-gradient(circle at 24% 14%, rgba(255, 255, 255, 0.28), transparent 34%); transition: opacity 0.28s ease; }
.gsrs-grid-card:hover { box-shadow: 0 18px 44px rgba(23, 32, 35, 0.14); }
.gsrs-grid-card:hover img { transform: scale(1.12); filter: saturate(1.08) contrast(1.03); }
.gsrs-grid-content { position: absolute; inset: auto 16px 16px 16px; z-index: 2; padding: 18px; border-radius: 22px; border: 1px solid rgba(255, 255, 255, 0.28); background: rgba(255, 255, 255, 0.16); backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px); transform: translateY(8px); transition: transform 0.28s ease, background 0.28s ease; }
.gsrs-grid-card:hover .gsrs-grid-content { transform: translateY(0); background: rgba(255, 255, 255, 0.2); }
.gsrs-grid-tag { display: inline-flex; margin-bottom: 10px; padding: 7px 10px; border-radius: 999px; background: rgba(255, 255, 255, 0.82); color: var(--gsrs-brand-dark); font-size: 11px; font-weight: 850; }
.gsrs-grid-content h3 { margin: 0; color: #fff; font-size: 21px; line-height: 1.12; letter-spacing: -0.035em; font-weight: 840; }
.gsrs-grid-content p { margin: 10px 0 14px; color: rgba(255, 255, 255, 0.82); font-size: 13.5px; line-height: 1.55; }
.gsrs-grid-content a { display: inline-flex; align-items: center; gap: 8px; color: #fff !important; font-size: 13px; font-weight: 850; text-decoration: none !important; }
.gsrs-grid-content a::after { content: "→"; transition: transform 0.2s ease; }
.gsrs-grid-content a:hover::after { transform: translateX(4px); }
.gsrs-cta { position: relative; margin-top: 24px; padding: clamp(24px, 4vw, 36px); border-radius: 34px; border: 1px solid rgba(255, 255, 255, 0.62); background: linear-gradient(135deg, rgba(255, 255, 255, 0.76), rgba(255, 255, 255, 0.42)), radial-gradient(circle at 20% 10%, rgba(63, 127, 153, 0.16), transparent 34%); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); box-shadow: 0 14px 36px rgba(23, 32, 35, 0.08); display: flex; align-items: center; justify-content: space-between; gap: 22px; overflow: hidden; }
.gsrs-cta::after { content: ""; position: absolute; width: 190px; height: 190px; right: -70px; top: -70px; border-radius: 999px; background: rgba(245, 184, 75, 0.18); pointer-events: none; }
.gsrs-cta h3 { margin: 0; font-size: clamp(23px, 2.5vw, 34px); letter-spacing: -0.045em; line-height: 1.1; font-weight: 840; }
.gsrs-cta p { margin: 10px 0 0; color: var(--gsrs-muted); line-height: 1.65; font-size: 15px; max-width: 640px; }
@keyframes gsrsPulse { 0%, 100% { transform: scale(1); opacity: 1; } 50% { transform: scale(0.72); opacity: 0.65; } }
@keyframes gsrsRotate { to { transform: rotate(360deg); } }
@keyframes gsrsSoftEnter { 0% { opacity: 0.4; filter: blur(4px);} 100% { opacity: 1; filter: blur(0);} }
@keyframes gsrsSoftLeaveNext { 0% { opacity: 1;} 65% { opacity: 0.72;} 100% { opacity: 0;} }
@keyframes gsrsSoftLeavePrev { 0% { opacity: 1;} 65% { opacity: 0.72;} 100% { opacity: 0;} }
@media (max-width: 980px) { .gsrs-hero { grid-template-columns: 1fr; } .gsrs-stack-area { min-height: 520px; } .gsrs-section-head { display: block; } .gsrs-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 767px) {
  #gsRefShowcase { padding: 64px 14px; }
  #gsRefShowcase::after { width: 300px; height: 300px; }
  .gsrs-title { font-size: clamp(34px, 11vw, 46px); line-height: 1; letter-spacing: -0.055em; }
  .gsrs-lead { font-size: 15.5px; line-height: 1.7; }
  .gsrs-actions { display: grid; grid-template-columns: 1fr; }
  .gsrs-btn { width: 100%; }
  .gsrs-stats { grid-template-columns: 1fr; gap: 10px; }
  .gsrs-stat { padding: 15px 16px; border-radius: 18px; }
  .gsrs-stack-area { min-height: 470px; margin-top: 8px; }
  .gsrs-orbit { width: min(340px, 92vw); }
  .gsrs-stack { width: min(360px, 94vw); height: 430px; }
  .gsrs-stack-card { --card-x: calc(var(--offset) * 11px); --card-y: calc(var(--offset) * 14px); --card-z: calc(var(--offset) * -48px); --card-rotate: calc(var(--offset) * -2.2deg); --card-rotate-y: calc(var(--offset) * -3deg); border-radius: 26px; transition: transform 820ms var(--gsrs-motion), opacity 680ms ease, filter 680ms ease, box-shadow 420ms ease; }
  .gsrs-stack-card.is-hidden { transform: translate3d(54px, 42px, -250px) rotateZ(6deg) rotateY(-8deg) scale(0.84); }
  .gsrs-stack-card.is-active:hover { transform: translate3d(0, -2px, 10px) rotateZ(-0.2deg) rotateY(0.5deg) scale(1.002); }
  .gsrs-card-media { flex-basis: 47%; }
  .gsrs-card-body { padding: 16px; gap: 10px; }
  .gsrs-card-body h3 { font-size: 20px; line-height: 1.1; }
  .gsrs-card-body p { font-size: 13px; line-height: 1.5; }
  .gsrs-card-link { padding: 11px 13px; border-radius: 14px; }
  .gsrs-stack-controls { left: 50%; right: auto; bottom: -14px; transform: translateX(-50%); }
  .gsrs-stack-btn { width: 44px; height: 44px; }
  .gsrs-section-head { margin-top: 70px; }
  .gsrs-section-head h2 { font-size: clamp(28px, 9vw, 38px); }
  .gsrs-taxonomy { flex-wrap: nowrap; overflow-x: auto; padding: 0 2px 10px; margin-left: -2px; margin-right: -2px; scrollbar-width: none; -webkit-overflow-scrolling: touch; }
  .gsrs-taxonomy::-webkit-scrollbar { display: none; }
  .gsrs-tax-btn { flex: 0 0 auto; }
  .gsrs-grid { grid-template-columns: 1fr; gap: 14px; }
  .gsrs-grid-card { min-height: 320px; border-radius: 22px; }
  .gsrs-grid-content { inset: auto 12px 12px 12px; padding: 16px; border-radius: 18px; }
  .gsrs-cta { display: block; border-radius: 26px; }
  .gsrs-cta .gsrs-btn { margin-top: 18px; }
}
@media (hover: none), (pointer: coarse) {
  .gsrs-orbit { animation: none !important; }
  .gsrs-stack-card.is-active:hover { transform: translate3d(0, 0, 0) rotateZ(0) rotateY(0) scale(1) !important; }
  .gsrs-stack-card.is-active:hover .gsrs-card-media img,
  .gsrs-grid-card:hover img { transform: none !important; filter: none !important; }
  .gsrs-grid-card:hover .gsrs-grid-content { transform: translateY(8px); background: rgba(255, 255, 255, 0.16); }
}
@media (max-width: 420px) { .gsrs-stack { height: 410px; } .gsrs-card-media { flex-basis: 44%; } .gsrs-card-badge { top: 14px; left: 14px; font-size: 11px; padding: 8px 10px; } .gsrs-grid-card { min-height: 300px; } }
@media (prefers-reduced-motion: reduce) {
  #gsRefShowcase *, #gsRefShowcase *::before, #gsRefShowcase *::after { animation: none !important; transition: none !important; scroll-behavior: auto !important; }
  .gsrs-orbit { display: none !important; }
  .gsrs-kicker, .gsrs-btn, .gsrs-stat, .gsrs-stack-card, .gsrs-card-badge, .gsrs-stack-btn, .gsrs-tax-btn, .gsrs-grid-content, .gsrs-cta {
    backdrop-filter: blur(2px) !important;
    -webkit-backdrop-filter: blur(2px) !important;
  }
}
