| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981 |
- <script setup>
- import PageHero from "../components/PageHero.vue";
- import { Icon } from "@iconify/vue";
- import { onBeforeUnmount, onMounted, ref } from "vue";
- import platformCover from "../assets/images/pbg.png?url";
- import equipmentCover from "../assets/images/case2.png?url";
- import productionCover from "../assets/images/sence2.jpg?url";
- import qhseCover from "../assets/images/sence3.png?url";
- const activeTab = ref("platform");
- const tabBarRef = ref(null);
- const prefersReducedMotion = () =>
- typeof window !== "undefined" &&
- window.matchMedia &&
- window.matchMedia("(prefers-reduced-motion: reduce)").matches;
- const pillars = [
- {
- key: "platform",
- title: "工业互联网平台",
- lead: "油气专属底座,打通数采—数据—系统—AI,为全场景应用落地提供稳定支撑。",
- icon: "lucide:layers-3",
- cover: platformCover,
- items: [
- {
- title: "油气专属底座 · 适配全场景需求",
- desc: "聚焦油气领域专属场景,深度适配数采、大模型相关各类应用需求,可灵活承载勘探、开发等全环节数字化场景,贴合行业业务特性。",
- image: platformCover,
- },
- {
- title: "高兼容架构 · 打破系统壁垒",
- desc: "采用高兼容技术架构,可无缝对接油气领域各类数采设备、现有系统及大模型应用,实现数据互通、系统联动,降低对接成本。",
- image: new URL("../assets/images/news3.png", import.meta.url).href,
- },
- {
- title: "灵活可扩展 · 承载多元需求",
- desc: "平台底座具备高度灵活性与可扩展性,可根据油气领域不同场景、不同需求,灵活承载数采、大模型相关各类数字化应用落地。",
- image: new URL("../assets/images/case7.png", import.meta.url).href,
- },
- ],
- },
- {
- key: "equipment",
- title: "设备管理",
- lead: "围绕设备全生命周期,实现台账、巡检维保、预测维护与实时监控预警的闭环管理。",
- icon: "lucide:cpu",
- cover: equipmentCover,
- items: [
- {
- title: "全维度设备管理 · 筑牢管控基础",
- desc: "依托平台底座,承载油气领域设备全生命周期管理场景,兼容各类数采设备,实现设备台账、参数信息统一管控,适配不同型号、不同环节油气设备,高效统筹设备资源。",
- image: equipmentCover,
- },
- {
- title: "智慧维保巡检 · 降低运维成本",
- desc: "联动巡检、维保全流程,支持自定义巡检计划与维保流程,无缝对接现场数采数据,实现维保巡检标准化、规范化,减少人工冗余,提高运维效率。",
- image: new URL("../assets/images/a.png", import.meta.url).href,
- },
- {
- title: "预测性维护 · 防范设备风险",
- desc: "借助平台大模型与数采技术支撑,实时分析设备运行数据,精准预测潜在故障并提前触发维护提醒,规避停机风险,降低故障损失。",
- image: new URL("../assets/images/b.png", import.meta.url).href,
- },
- {
- title: "实时监控预警 · 保障作业安全",
- desc: "实时采集运行参数,实现设备状态可视化监控;异常情况快速预警、精准推送,适配油气现场复杂作业环境,筑牢安全生产防线。",
- image: new URL("../assets/images/c.png", import.meta.url).href,
- },
- ],
- },
- {
- key: "production",
- title: "生产管理",
- lead: "面向油气生产项目,贯通任务、计划、数据与报表,提升协同效率与过程可控性。",
- icon: "lucide:clipboard-check",
- cover: productionCover,
- items: [
- {
- title: "项目任务管理 · 联动平台高效统筹",
- desc: "承接油气领域生产项目全流程任务管理,无缝对接平台数据体系,实现任务分配、进度跟踪、闭环管理,统筹项目各环节,确保生产任务有序推进。",
- image: new URL("../assets/images/d.png", import.meta.url).href,
- },
- {
- title: "计划与实际联动 · 精准把控生产节奏",
- desc: "基于平台数采能力,科学制定生产计划;同步对接生产实际数据,自动匹配计划与实际差异,实时调整生产安排,保障流程高效衔接。",
- image: new URL("../assets/images/e.png", import.meta.url).href,
- },
- {
- title: "自动报表生成 · 沉淀核心数据资产",
- desc: "自动汇总数采数据、生产进度与任务完成情况,一键生成日报、月报等报表,减少人工录入,实现生产数据规范化保存与资产沉淀。",
- image: new URL("../assets/images/f.png", import.meta.url).href,
- },
- {
- title: "全流程数智赋能 · 提升生产整体效能",
- desc: "深度联动平台数采与数据管理能力,打造生产计划、任务执行、数据统计全链条,减少人工冗余,提升协同效率,实现数字化、智能化转型。",
- image: new URL("../assets/images/g.png", import.meta.url).href,
- },
- ],
- },
- {
- key: "qhse",
- title: "QHSE",
- lead: "以合规为底线,以数据为驱动,实现风险隐患闭环与作业全过程可控,助力管理升级。",
- icon: "lucide:shield-check",
- cover: qhseCover,
- items: [
- {
- title: "合规适配 QHSE 体系 · 筑牢安全底线",
- desc: "全面贴合 QHSE 管理体系标准,覆盖风险隐患、作业许可、环境管理等核心模块,确保管理流程合规达标,契合油气行业安全环保监管要求,规避合规风险。",
- image: new URL("../assets/images/value5.jpg", import.meta.url).href,
- },
- {
- title: "多系统集成联动 · 实现协同管控",
- desc: "深度集成设备管理、生产管理等系统,实现数据互通、流程联动,同步设备状态、作业计划等数据,打破系统壁垒,构建安全 + 生产 + 设备一体化管控体系。",
- image: new URL("../assets/images/h.png", import.meta.url).href,
- },
- {
- title: "全维度风险防控 · 保障作业安全",
- desc: "整合风险隐患管理、应急与健康管理、作业许可与过程监督等功能,借助数采与数据处理能力,实现风险精准识别、隐患闭环治理、作业全过程可控。",
- image: new URL("../assets/images/m.png", import.meta.url).href,
- },
- {
- title: "体系化支撑 · 赋能管理升级",
- desc: "涵盖目标管理、培训与体系支持等模块,联动平台数据资产,实现目标拆解、培训落地与体系落地,推动从被动应对到主动防控转型,提升管理效能。",
- image: new URL("../assets/images/k.png", import.meta.url).href,
- },
- ],
- },
- ];
- const deliver = [
- { title: "SaaS", desc: "开箱即用,按需订阅,快速试点与复制。" },
- { title: "私有化", desc: "数据本地化部署,适配企业安全与合规要求。" },
- { title: "混合云", desc: "核心数据本地,弹性算力上云,兼顾成本与性能。" },
- ];
- function headerOffsetPx() {
- const rootStyle = getComputedStyle(document.documentElement);
- const headerVar = rootStyle.getPropertyValue("--header-h")?.trim();
- const headerH = Number.parseFloat(headerVar || "72") || 72;
- const tabH = tabBarRef.value?.getBoundingClientRect?.().height || 0;
- return Math.round(headerH + tabH + 16);
- }
- function scrollToTab(key) {
- const el = document.getElementById(`product-${key}`);
- if (!el) return;
- activeTab.value = key;
- const offset = headerOffsetPx();
- const y = el.getBoundingClientRect().top + window.scrollY - offset;
- window.scrollTo({
- top: Math.max(0, y),
- behavior: prefersReducedMotion() ? "auto" : "smooth",
- });
- }
- let observer = null;
- const currentImageIndex = ref({
- platform: 0,
- equipment: 0,
- production: 0,
- qhse: 0,
- });
- const imageTimers = ref({});
- const getActiveIndex = (key, totalItems) => {
- const rawIndex = currentImageIndex.value[key];
- const index = Number.isFinite(rawIndex) ? rawIndex : 0;
- if (!totalItems || totalItems <= 0) return 0;
- return ((index % totalItems) + totalItems) % totalItems;
- };
- const getActiveItem = (pillar) => {
- const totalItems = pillar?.items?.length || 0;
- const index = getActiveIndex(pillar?.key, totalItems);
- return pillar?.items?.[index] || null;
- };
- const getActiveImageSrc = (pillar) =>
- getActiveItem(pillar)?.image || pillar.cover;
- const getActiveImageAlt = (pillar) =>
- getActiveItem(pillar)?.title || pillar.title;
- const startImageCarousel = (key, totalItems) => {
- if (prefersReducedMotion()) return;
- if (!totalItems || totalItems < 2) return;
- stopImageCarousel(key);
- imageTimers.value[key] = setInterval(() => {
- currentImageIndex.value[key] =
- (currentImageIndex.value[key] + 1) % totalItems;
- }, 4000);
- };
- const stopImageCarousel = (key) => {
- if (imageTimers.value[key]) {
- clearInterval(imageTimers.value[key]);
- imageTimers.value[key] = null;
- }
- };
- const goToImageSlide = (key, index, totalItems) => {
- currentImageIndex.value[key] = index;
- startImageCarousel(key, totalItems);
- };
- onMounted(() => {
- const offset = headerOffsetPx();
- observer = new IntersectionObserver(
- (entries) => {
- const visible = entries
- .filter((e) => e.isIntersecting)
- .sort(
- (a, b) => (b.intersectionRatio || 0) - (a.intersectionRatio || 0),
- )[0];
- if (visible?.target?.id)
- activeTab.value = visible.target.id.replace("product-", "");
- },
- {
- root: null,
- threshold: [0.25, 0.45, 0.6],
- rootMargin: `-${offset}px 0px -55% 0px`,
- },
- );
- for (const p of pillars) {
- const el = document.getElementById(`product-${p.key}`);
- if (el) observer.observe(el);
- }
- for (const p of pillars) {
- if (currentImageIndex.value[p.key] === undefined)
- currentImageIndex.value[p.key] = 0;
- startImageCarousel(p.key, p.items?.length || 0);
- }
- });
- onBeforeUnmount(() => {
- observer?.disconnect?.();
- observer = null;
- for (const key of Object.keys(imageTimers.value || {})) {
- stopImageCarousel(key);
- }
- });
- </script>
- <template>
- <div class="productsView">
- <PageHero
- kicker=""
- title="油气行业数智产品矩阵"
- subtitle="以工业互联网平台为底座,支撑从勘探开发到生产运营的全场景数字化。"
- >
- <template #actions>
- <RouterLink
- class="btn btn-primary"
- style="border-radius: 0"
- to="/contact"
- >获取产品资料</RouterLink
- >
- </template>
- </PageHero>
- <section class="section" style="padding-top: 0; margin-top: -10px">
- <div>
- <div
- ref="tabBarRef"
- class="tabBar"
- role="tablist"
- aria-label="产品域导航"
- >
- <button
- v-for="p in pillars"
- :key="p.key"
- class="tabBtn"
- :class="{ 'is-active': activeTab === p.key }"
- type="button"
- role="tab"
- :aria-selected="activeTab === p.key ? 'true' : 'false'"
- @click="scrollToTab(p.key)"
- >
- <span
- class="tabText"
- style="display: flex; align-items: center; gap: 10px"
- ><Icon :icon="p.icon" width="18" height="18" aria-hidden="true" />
- <span>{{ p.title }}</span></span
- >
- </button>
- </div>
- <div class="productStac container">
- <section
- v-for="p in pillars"
- :id="`product-${p.key}`"
- :key="p.key"
- class="productSection"
- >
- <header class="productHead">
- <div class="productHeadTop">
- <h2 class="productTitle">{{ p.title }}</h2>
- </div>
- <p class="productLead">{{ p.lead }}</p>
- </header>
- <div class="tabContentLayout">
- <div class="tabContentImage">
- <div class="imageCarouselWrapper">
- <div class="imageCarouselViewport">
- <Transition name="image-carousel-slide" mode="out-in">
- <div
- v-if="p.items?.length"
- :key="`${p.key}-${getActiveIndex(p.key, p.items.length)}`"
- class="imageCarouselSlide"
- >
- <img
- :src="getActiveImageSrc(p)"
- :alt="getActiveImageAlt(p)"
- loading="lazy"
- decoding="async"
- />
- </div>
- </Transition>
- </div>
- </div>
- <div class="carouselIndicators">
- <button
- v-for="(item, idx) in p.items"
- :key="idx"
- :class="[
- 'indicator',
- { 'is-active': idx === currentImageIndex[p.key] },
- ]"
- @click="goToImageSlide(p.key, idx, p.items.length)"
- @mouseenter="stopImageCarousel(p.key)"
- @mouseleave="startImageCarousel(p.key, p.items.length)"
- :aria-label="`第${idx + 1}张图片`"
- ></button>
- </div>
- </div>
- <div class="tabContentFeatures">
- <div
- v-for="(it, idx) in p.items"
- :key="it.title"
- class="tabFeatureRow"
- :class="{
- 'is-highlighted': idx === currentImageIndex[p.key],
- }"
- @mouseenter="
- () => {
- stopImageCarousel(p.key);
- currentImageIndex[p.key] = idx;
- }
- "
- @mouseleave="() => startImageCarousel(p.key, p.items.length)"
- >
- <div class="tabFeatureMain">
- <div class="featureTitle">{{ it.title }}</div>
- <div class="muted featureDesc">{{ it.desc }}</div>
- </div>
- </div>
- </div>
- </div>
- </section>
- </div>
- </div>
- </section>
- <section class="section section--soft">
- <div class="container">
- <div class="sectionHead">
- <div>
- <h2 class="h2">灵活适配企业 IT 与合规边界</h2>
- <div class="muted">
- 支持试点快速落地,也支持规模化推广与安全合规的长期运行。
- </div>
- </div>
- </div>
- <div class="grid grid-3">
- <div
- v-for="d in deliver"
- :key="d.title"
- class="card card-pad deliverCard"
- style="border: none; box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.05)"
- >
- <div class="deliverTitle">{{ d.title }}</div>
- <div class="muted">{{ d.desc }}</div>
- </div>
- </div>
- </div>
- </section>
- </div>
- </template>
- <style scoped>
- .productsView {
- --ink: rgba(2, 6, 23, 0.92);
- --tab-bg: rgba(255, 255, 255, 0.92);
- }
- .sectionHead {
- display: flex;
- align-items: flex-end;
- justify-content: space-between;
- gap: 18px;
- margin-bottom: 16px;
- }
- .productStac {
- display: flex;
- width: 100%;
- justify-content: center;
- align-items: center;
- flex-direction: column;
- }
- :deep(.pageHero) {
- background-image: url("../assets/images/bg3.png");
- background-size: cover, cover;
- background-position: center, center;
- background-repeat: no-repeat, no-repeat;
- background-blend-mode: overlay;
- color: #111;
- height: 50vh;
- border-bottom: none;
- padding: 80px 0;
- }
- :deep(.pageHero__subtitle) {
- color: #4f5055;
- }
- .tabBar {
- position: sticky;
- top: var(--header-h);
- padding: 0 30px;
- z-index: 20;
- display: grid;
- grid-template-columns: repeat(6, minmax(0, 1fr));
- gap: 0px;
- background: #eef5f8;
- margin: 10px 0 18px;
- height: 80px;
- border: 0;
- border-radius: 0;
- }
- .tabBtn {
- height: 80px;
- font-size: 20px;
- border: 0;
- background: #eef5f8;
- box-shadow: var(--tab-shadow);
- padding: 0 50px;
- display: inline-flex;
- align-items: center;
- justify-content: center;
- gap: 10px;
- color: var(--slate-700);
- letter-spacing: 0.01em;
- cursor: pointer;
- transition:
- transform 160ms ease,
- box-shadow 160ms ease,
- color 160ms ease;
- }
- .tabBtn.is-active {
- color: var(--brand-700);
- background-color: #fff;
- }
- .tabBtn:focus-visible {
- outline: none;
- box-shadow:
- 0 0 0 3px rgba(37, 99, 235, 0.24),
- var(--tab-shadow-hover);
- }
- .tabText {
- display: inline-block;
- white-space: nowrap;
- padding-bottom: 10px;
- background-image: linear-gradient(currentColor, currentColor);
- background-repeat: no-repeat;
- background-position: 0 100%;
- background-size: 0 2px;
- transition: background-size 160ms ease;
- }
- .tabBtn.is-active .tabText {
- background-size: 100% 2px;
- }
- .productSection {
- scroll-margin-top: calc(var(--header-h) + 84px);
- border: 0;
- border-radius: 0;
- background: transparent;
- box-shadow: none;
- margin-top: 50px;
- }
- .productHead {
- padding: 18px 18px 14px;
- text-align: center;
- }
- .productHeadTop {
- display: flex;
- align-items: center;
- justify-content: center;
- gap: 12px;
- }
- .productTitle {
- letter-spacing: -0.02em;
- color: var(--ink);
- font-size: 30px;
- line-height: 1.25;
- text-align: center;
- }
- .productLead {
- margin-top: 10px;
- max-width: 92ch;
- text-align: center;
- margin-left: auto;
- margin-right: auto;
- }
- .platformLayout {
- margin-top: 40px;
- display: grid;
- grid-template-columns: 1fr 1fr;
- gap: 50px;
- align-items: start;
- }
- .platformImage {
- /* border-radius: 16px; */
- overflow: hidden;
- box-shadow: 0 12px 40px rgba(2, 6, 23, 0.12);
- }
- .platformImage img {
- width: 100%;
- height: auto;
- object-fit: contain;
- display: block;
- }
- .platformFeatures {
- display: grid;
- gap: 24px;
- }
- .platformFeature {
- display: grid;
- grid-template-columns: 22px 1fr;
- align-items: start;
- gap: 10px;
- padding: 22px;
- padding-bottom: 0;
- background: #fff;
- /* border-radius: 16px; */
- box-shadow: 0 8px 24px rgba(2, 6, 23, 0.08);
- min-height: 160px;
- transition:
- transform 180ms ease,
- box-shadow 180ms ease;
- }
- .platformFeature:hover {
- transform: translateY(-2px);
- box-shadow: 0 12px 32px rgba(2, 6, 23, 0.12);
- }
- .tabContentLayout {
- margin-top: 40px;
- display: grid;
- grid-template-columns: 1fr 1.2fr;
- gap: 50px;
- align-items: start;
- }
- .tabContentImage {
- /* border-radius: 16px; */
- --carousel-h: 500px;
- overflow: hidden;
- box-shadow: 0 12px 40px rgba(2, 6, 23, 0.12);
- position: sticky;
- top: calc(var(--header-h) + 100px);
- }
- .tabContentImage img {
- width: 100%;
- height: var(--carousel-h);
- object-fit: cover;
- display: block;
- }
- .tabContentFeatures {
- display: grid;
- gap: 20px;
- }
- .tabFeatureRow {
- padding: 28px;
- background: #fff;
- /* border-radius: 16px; */
- box-shadow: 0 8px 24px rgba(2, 6, 23, 0.08);
- min-height: 140px;
- transition:
- transform 180ms ease,
- box-shadow 180ms ease;
- }
- .tabFeatureRow:hover {
- transform: translateY(-2px);
- box-shadow: 0 12px 32px rgba(2, 6, 23, 0.12);
- }
- .featureDot {
- width: 18px;
- height: 18px;
- border-radius: 999px;
- background: linear-gradient(180deg, #0766cd, #0d4a9e);
- box-shadow:
- 0 10px 22px rgba(10, 71, 156, 0.25),
- inset 0 0 0 2px rgba(255, 255, 255, 0.85);
- margin-top: 4px;
- }
- .featureMain,
- .tabFeatureMain {
- min-width: 0;
- }
- .featureTitle {
- letter-spacing: -0.01em;
- color: rgba(2, 6, 23, 0.9);
- font-size: 22px;
- font-weight: 700;
- line-height: 1.35;
- }
- .featureDesc {
- margin-top: 10px;
- line-height: 1.75;
- color: #666666;
- text-align: left;
- }
- .deliverTitle {
- /* font-weight: 900; */
- margin-bottom: 6px;
- }
- @media (max-width: 960px) {
- .sectionHead {
- flex-direction: column;
- align-items: flex-start;
- gap: 12px;
- }
- .tabBar {
- grid-template-columns: repeat(2, minmax(0, 1fr));
- }
- .platformLayout,
- .tabContentLayout {
- grid-template-columns: 1fr;
- gap: 30px;
- }
- .tabContentImage {
- position: static;
- --carousel-h: 300px;
- }
- }
- @media (max-width: 560px) {
- .platformFeature,
- .tabFeatureRow {
- padding: 20px;
- min-height: auto;
- }
- .featureTitle {
- font-size: 18px;
- }
- .featureDesc {
- font-size: 14px;
- }
- }
- @media (prefers-reduced-motion: reduce) {
- .tabBtn {
- transition: none !important;
- transform: none !important;
- }
- .tabText {
- transition: none !important;
- }
- .platformFeature,
- .tabFeatureRow {
- transition: none !important;
- transform: none !important;
- }
- }
- .imageCarouselWrapper {
- position: relative;
- display: flex;
- align-items: center;
- gap: 12px;
- }
- .imageCarouselViewport {
- flex: 1;
- overflow: hidden;
- position: relative;
- height: var(--carousel-h);
- }
- .imageCarouselSlide {
- position: absolute;
- top: 0;
- left: 0;
- width: 100%;
- height: 100%;
- }
- .imageCarouselSlide img {
- width: 100%;
- height: 100%;
- object-fit: cover;
- display: block;
- }
- .imageOverlay {
- position: absolute;
- bottom: 0;
- left: 0;
- right: 0;
- padding: 20px;
- background: linear-gradient(to top, rgba(0, 0, 0, 0.8), transparent);
- color: #fff;
- }
- .overlayText {
- font-size: 16px;
- font-weight: 600;
- line-height: 1.4;
- text-shadow: 0 2px 4px rgba(0, 0, 0, 0.5);
- }
- .image-carousel-slide-enter-active,
- .image-carousel-slide-leave-active {
- transition: all 0.6s ease;
- }
- .image-carousel-slide-enter-from {
- opacity: 0;
- transform: translateY(50px);
- }
- .image-carousel-slide-leave-to {
- opacity: 0;
- transform: translateY(-50px);
- }
- .carouselBtn {
- width: 44px;
- height: 44px;
- border-radius: 50%;
- border: 2px solid rgba(7, 102, 205, 0.3);
- background: rgba(255, 255, 255, 0.95);
- color: #0766cd;
- cursor: pointer;
- display: flex;
- align-items: center;
- justify-content: center;
- transition: all 0.2s ease;
- flex-shrink: 0;
- z-index: 2;
- }
- .carouselBtn:hover {
- background: #0766cd;
- color: #fff;
- border-color: #0766cd;
- transform: scale(1.08);
- }
- .carouselBtn:focus-visible {
- outline: none;
- box-shadow: 0 0 0 3px rgba(7, 102, 205, 0.24);
- }
- .carouselIndicators {
- display: flex;
- flex-direction: column;
- justify-content: center;
- align-items: end;
- gap: 10px;
- /* margin-top: 16px; */
- padding-right: 10px;
- position: relative;
- top: -300px;
- }
- .indicator {
- width: 8px;
- height: 8px;
- /* border-radius: 50%; */
- border: none;
- background: rgba(7, 102, 205, 0.25);
- cursor: pointer;
- padding: 0;
- transition: all 0.3s ease;
- }
- .indicator:hover {
- background: rgba(7, 102, 205, 0.6);
- transform: scale(1.3);
- }
- .indicator.is-active {
- background: #0766cd;
- }
- .indicator:focus-visible {
- outline: none;
- box-shadow: 0 0 0 3px rgba(7, 102, 205, 0.24);
- }
- /* .tabFeatureRow:hover {
- transform: translateY(-2px);
- box-shadow: 0 12px 32px rgba(2, 6, 23, 0.12);
- } */
- /* .tabFeatureRow.is-highlighted {
- border-left: 3px solid #0766cd;
- box-shadow: 0 8px 24px rgba(7, 102, 205, 0.15);
- } */
- .tabFeatureRow {
- padding: 28px;
- background: #fff;
- /* border-radius: 16px; */
- box-shadow: 0 8px 24px rgba(2, 6, 23, 0.08);
- min-height: 140px;
- transition:
- transform 180ms ease,
- box-shadow 180ms ease,
- border-left 0.3s ease;
- border-left: 3px solid transparent;
- position: relative;
- }
- .tabFeatureRow.is-highlighted {
- /* border-left: none; */
- /* box-shadow:
- 0 8px 24px rgba(7, 102, 205, 0.15),
- inset 0 0 0 1px rgba(7, 102, 205, 0.1); */
- }
- .tabFeatureRow.is-highlighted::before {
- content: "";
- position: absolute;
- top: 0;
- left: 20px;
- width: calc(100% - 40px);
- height: 4px;
- background: linear-gradient(90deg, #0766cd, #0d4a9e);
- border-radius: 2px 2px 0 0;
- }
- .tabFeatureRow.is-highlighted::after {
- content: "";
- position: absolute;
- bottom: -4px;
- left: 50%;
- transform: translateX(-50%);
- width: 60px;
- height: 4px;
- background: linear-gradient(90deg, transparent, #0766cd, transparent);
- border-radius: 2px;
- opacity: 0.6;
- }
- .tabContentImage {
- /* border-radius: 16px; */
- --carousel-h: 500px;
- overflow: hidden;
- box-shadow: 0 12px 40px rgba(2, 6, 23, 0.12);
- position: sticky;
- top: calc(var(--header-h) + 100px);
- }
- .imageCarouselWrapper {
- position: relative;
- display: flex;
- align-items: center;
- gap: 12px;
- }
- .imageCarouselViewport {
- flex: 1;
- overflow: hidden;
- position: relative;
- }
- .imageCarouselSlide {
- position: absolute;
- top: 0;
- left: 0;
- width: 100%;
- height: 100%;
- }
- .imageCarouselSlide img {
- width: 100%;
- height: 500px;
- object-fit: cover;
- display: block;
- }
- .carouselIndicators {
- position: absolute;
- right: 20px;
- top: 50%;
- transform: translateY(-50%);
- display: flex;
- flex-direction: column;
- justify-content: center;
- align-items: center;
- gap: 10px;
- z-index: 10;
- }
- .indicator {
- width: 8px;
- height: 8px;
- border-radius: 50%;
- border: none;
- background: rgba(255, 255, 255, 0.5);
- cursor: pointer;
- padding: 0;
- transition: all 0.3s ease;
- }
- .indicator:hover {
- background: rgba(255, 255, 255, 0.9);
- transform: scale(1.3);
- }
- .indicator.is-active {
- background: #014198;
- width: 6px;
- height: 20px;
- border-radius: 3px;
- }
- .indicator:focus-visible {
- outline: none;
- box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.5);
- }
- </style>
|