﻿:root {
      --cyan:#08a7da;
      --cyan-soft:#74e4ff;
      --dark:#0b0f12;
      --dark-2:#11171b;
      --panel:rgba(255,255,255,.065);
      --panel-2:rgba(255,255,255,.095);
      --text:#f4f8fb;
      --muted:#9eaaaf;
      --line:rgba(255,255,255,.12);
      --radius-xl:44px;
      --radius-lg:28px;
      --radius-md:18px;
      --shadow:0 24px 80px rgba(0,0,0,.35);

}

* {
    box-sizing:border-box
}

html {
    scroll-behavior:smooth
}

body {
    font-family:"Michroma",sans-serif;
    background:var(--dark);
    color:var(--text);
    overflow-x:hidden
}

body:before {
    content:"";
    position:fixed;
    inset:0;
    pointer-events:none;
    z-index:999;
    opacity:.055;
    background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 220 220' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.7' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='1'/%3E%3C/svg%3E")
}

a {
    color:inherit;
    text-decoration:none
}

.container {
    max-width:1180px
}

.site-bg {
    position:fixed;
    inset:0;
    z-index:-2;
    background:radial-gradient(circle at 75% 18%,rgba(8,167,218,.22),transparent 30%),radial-gradient(circle at 12% 82%,rgba(8,167,218,.13),transparent 28%),linear-gradient(135deg,#080b0d 0%,#11171b 48%,#0a0d10 100%)
}

.site-bg:after {
    content:"";
    position:absolute;
    inset:0;
    background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);
    background-size:72px 72px;
    mask-image:radial-gradient(circle at 50% 20%,black,transparent 72%)
}

.cursor-glow {
    position:fixed;
    width:360px;
    height:360px;
    border-radius:50%;
    background:radial-gradient(circle,rgba(8,167,218,.16),transparent 62%);
    pointer-events:none;
    z-index:-1;
    transform:translate(-50%,-50%);
    opacity:.7
}

.arc-bg {
    position:absolute;
    width:720px;
    height:720px;
    border-radius:50%;
    border:76px solid rgba(255,255,255,.055);
    border-right-color:transparent;
    border-bottom-color:transparent;
    transform:rotate(-8deg);
    pointer-events:none
}

.site-header {
    position:fixed;
    top:18px;
    left:0;
    width:100%;
    z-index:50;
    transition:.35s ease
}

.site-header.scrolled .nav-wrap {
    background:rgba(11,15,18,.78);
    border-color:rgba(255,255,255,.14);
    backdrop-filter:blur(18px);
    box-shadow:0 12px 42px rgba(0,0,0,.28)
}

.nav-wrap {
    min-height:74px;
    padding:0 18px 0 22px;
    border:1px solid transparent;
    border-radius:999px;
    transition:.35s ease
}

.brand {
    display:flex;
    align-items:center;
    gap:12px;
    font-family:"Audiowide",sans-serif;
    font-weight:700;
    letter-spacing:-.03em;
    color:#fff
}

.brand-mark {
    width:42px;
    height:42px;
    position:relative;
    border-radius:14px;
    overflow:hidden;
    background:rgba(255,255,255,.05);
    flex:0 0 auto
}

.brand-mark:before,.brand-mark:after {
    content:"";
    position:absolute;
    border-radius:50%;
    border-style:solid;
    transform:rotate(-8deg)
}

.brand-mark:before {
    width:64px;
    height:64px;
    border-width:9px;
    border-color:#222 transparent transparent #222;
    left:-34px;
    top:5px
}

.brand-mark:after {
    width:44px;
    height:44px;
    border-width:8px;
    border-color:#9fa4a4 transparent transparent var(--cyan);
    left:-16px;
    top:16px
}

.navbar-nav {
    gap:18px
}

.nav-link {
    color:rgba(255,255,255,.76)!important;
    font-size:14px;
    font-weight:700
}

.nav-link:hover,.nav-link.active {
    color:#fff!important
}

.nav-cta,.btn-brand {
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    border:1px solid rgba(255,255,255,.14);
    border-radius:999px;
    color:#fff;
    font-weight:800;
    transition:.25s ease;
    position:relative;
    overflow:hidden
}

.nav-cta {
    min-height:46px;
    padding:0 20px;
    background:rgba(8,167,218,.15)
}

.btn-brand {
    min-height:56px;
    padding:0 24px;
    background:linear-gradient(135deg,var(--cyan),#0479a3);
    box-shadow:0 18px 60px rgba(8,167,218,.24)
}

.btn-brand.secondary {
    background:rgba(255,255,255,.07);
    box-shadow:none
}

.btn-brand:hover,.nav-cta:hover {
    transform:translateY(-2px);
    border-color:rgba(94,220,255,.5);
    box-shadow:0 18px 70px rgba(8,167,218,.28);
    color:#fff
}

.navbar-toggler {
    border:1px solid rgba(255,255,255,.18);
    border-radius:14px;
    padding:10px;
    box-shadow:none!important
}

.navbar-toggler span {
    display:block;
    width:22px;
    height:2px;
    background:#fff;
    margin:4px 0;
    border-radius:2px
}

.section-fit {
    min-height:100vh;
    display:flex;
    align-items:center
}

.section-pad {
    padding:110px 0
}

.hero {
    padding:130px 0 50px;
    position:relative
}

.hero .arc-bg {
    right:-360px;
    top:-120px
}

.hero-row {
    min-height:calc(100vh - 180px)
}

.eyebrow {
    display:inline-flex;
    align-items:center;
    gap:10px;
    padding:9px 14px;
    border-radius:999px;
    border:1px solid rgba(255,255,255,.12);
    background:rgba(255,255,255,.055);
    color:var(--cyan-soft);
    font-size:13px;
    font-weight:800;
    letter-spacing:.04em;
    text-transform:uppercase;
    margin-bottom:24px
}

.eyebrow:before {
    content:"";
    width:8px;
    height:8px;
    border-radius:50%;
    background:var(--cyan);
    box-shadow:0 0 22px var(--cyan)
}

h1,h2,h3,h4,h5,h6 {
    font-family:"Audiowide",sans-serif;
    letter-spacing:-.055em;
    line-height:.96
}

h1 {
    font-size:clamp(54px,7vw,104px);
    max-width:760px;
    margin-bottom:26px
}

.gradient-text {
    background:linear-gradient(135deg,#fff,#9beeff 52%,var(--cyan));
    -webkit-background-clip:text;
    color:transparent
}

.hero-text p,.page-hero p {
    max-width:560px;
    color:var(--muted);
    font-size:18px;
    line-height:1.75;
    margin-bottom:34px
}

.hero-actions {
    display:flex;
    gap:14px;
    flex-wrap:wrap;
    margin-bottom:34px
}

.metric {
    height:100%;
    border:1px solid rgba(255,255,255,.1);
    border-radius:24px;
    padding:18px;
    background:rgba(255,255,255,.045)
}

.metric strong {
    display:block;
    font-family:"Audiowide",sans-serif;
    font-size:clamp(14px,1.0vw,18px);
    letter-spacing:-.02em;
    line-height:1.05;
    overflow-wrap:anywhere;
    word-break:break-word;
    color:#fff;
    margin-bottom:4px
}

.metric span {
    color:var(--muted);
    font-size:13px;
    line-height:1.45;
    overflow-wrap:anywhere;
    word-break:break-word
}

.visual-card {
    position:relative;
    height:min(640px,calc(100vh - 230px));
    min-height:500px;
    border-radius:88px 28px 88px 28px;
    overflow:hidden;
    border:1px solid rgba(255,255,255,.12);
    background:linear-gradient(135deg,rgba(255,255,255,.09),rgba(255,255,255,.02));
    box-shadow:var(--shadow);
    isolation:isolate
}

.visual-card:after {
    content:"";
    position:absolute;
    inset:26px;
    border-radius:68px 18px 68px 18px;
    border:1px solid rgba(255,255,255,.16);
    pointer-events:none;
    z-index:5
}

.heroSwiper,.heroSwiper .swiper-wrapper,.heroSwiper .swiper-slide {
    height:100%
}

.hero-slide {
    position:relative;
    background-size:cover;
    background-position:center;
    filter:saturate(.75) contrast(1.08)
}

.hero-slide:before {
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(180deg,rgba(8,167,218,.08),rgba(0,0,0,.72))
}

.slide-1 {
    background-image:url("../img/hero-1.svg")
}

.slide-2 {
    background-image:url("../img/hero-2.svg")
}

.slide-3 {
    background-image:url("../img/hero-3.svg")
}

.temp-chip {
    position:absolute;
    left:32px;
    bottom:32px;
    width:calc(100% - 64px);
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:18px;
    padding:18px;
    border-radius:32px;
    border:1px solid rgba(255,255,255,.16);
    background:rgba(8,12,14,.62);
    backdrop-filter:blur(18px);
    z-index:6
}

.temp-chip b {
    font-family:"Audiowide",sans-serif;
    font-size:54px;
    letter-spacing:-.07em
}

.temp-chip span {
    color:var(--muted);
    line-height:1.55;
    font-size:14px;
    max-width:250px
}

.swiper-pagination-bullet {
    background:#fff;
    opacity:.35
}

.swiper-pagination-bullet-active {
    background:var(--cyan);
    opacity:1
}

.section-head {
    display:grid;
    grid-template-columns:.85fr 1fr;
    gap:40px;
    align-items:end;
    margin-bottom:46px
}

.section-head h2 {
    font-size:clamp(42px,5vw,76px)
}

.section-head p {
    color:var(--muted);
    font-size:17px;
    line-height:1.75;
    max-width:620px
}

.service-card {
    height:100%;
    min-height:330px;
    padding:28px;
    border-radius:var(--radius-xl) var(--radius-md) var(--radius-xl) var(--radius-md);
    background:var(--panel);
    border:1px solid rgba(255,255,255,.1);
    position:relative;
    overflow:hidden;
    transition:.35s ease
}

.service-card:before {
    content:"";
    position:absolute;
    width:170px;
    height:170px;
    right:-70px;
    top:-70px;
    border-radius:50%;
    border:24px solid rgba(8,167,218,.18);
    border-left-color:transparent;
    border-bottom-color:transparent;
    transform:rotate(12deg);
    transition:.35s ease
}

.service-card:hover {
    transform:translateY(-8px);
    background:var(--panel-2);
    border-color:rgba(94,220,255,.36);
    box-shadow:0 24px 70px rgba(8,167,218,.13)
}

.service-card:hover:before {
    transform:rotate(42deg) scale(1.15);
    border-color:rgba(8,167,218,.35);
    border-left-color:transparent;
    border-bottom-color:transparent
}

.service-no {
    display:inline-flex;
    width:46px;
    height:46px;
    align-items:center;
    justify-content:center;
    border-radius:16px;
    background:rgba(8,167,218,.16);
    color:var(--cyan-soft);
    font-family:"Audiowide",sans-serif;
    font-weight:700;
    margin-bottom:80px
}

.service-card h3 {
    font-size:26px;
    line-height:1.04;
    margin-bottom:14px
}

.service-card p {
    color:var(--muted);
    font-size:14px;
    line-height:1.7
}

.flow-section {
    overflow:hidden
}

.flow-panel {
    display:grid;
    grid-template-columns:minmax(0,1.22fr) minmax(0,.78fr);
    gap:20px;
    min-height:560px;
    border-radius:86px 24px 86px 24px;
    border:1px solid rgba(255,255,255,.12);
    background:radial-gradient(circle at 16% 12%,rgba(8,167,218,.22),transparent 34%),rgba(255,255,255,.055);
    padding:26px;
    overflow:hidden
}

.flow-copy {
    display:flex;
    flex-direction:column;
    justify-content:flex-start;
    padding:38px;
    min-height:0
}

.flow-rich-scroll {
    max-height:220px;
    overflow:auto;
    padding-right:10px;
    margin-bottom:20px;
    scrollbar-width:thin;
    scrollbar-color:rgba(120,220,255,.42) transparent
}

.flow-rich-scroll::-webkit-scrollbar {
    width:8px
}

.flow-rich-scroll::-webkit-scrollbar-thumb {
    background:rgba(120,220,255,.42);
    border-radius:999px
}

.flow-rich-scroll::-webkit-scrollbar-track {
    background:transparent
}

@media (max-width: 991px) {
    .flow-rich-scroll {
        max-height:none;
        overflow:visible;
        padding-right:0
    }
}

.flow-copy h2 {
    font-size:clamp(44px,5vw,82px);
    margin-bottom:24px
}

.flow-copy h3 {
    font-size:clamp(34px,3.8vw,56px);
    margin-bottom:18px
}

.flow-copy p {
    color:var(--muted);
    line-height:1.8;
    font-size:17px;
    max-width:530px;
    margin-bottom:30px
}

.flow-rich {
    display:grid;
    gap:14px;
    margin-bottom:24px;
    max-width:560px
}

.flow-rich-block {
    color:#d7e5eb;
    font-size:14px;
    line-height:1.75
}

.flow-rich-block > *:last-child {
    margin-bottom:0
}

.flow-rich-block h1,
.flow-rich-block h2,
.flow-rich-block h3,
.flow-rich-block h4,
.flow-rich-block h5,
.flow-rich-block h6 {
    font-size:clamp(18px,2vw,24px);
    line-height:1.2;
    margin:0 0 8px
}

.flow-rich-block p,
.flow-rich-block ul,
.flow-rich-block ol {
    margin:0 0 10px
}

.flow-rich-block ul,
.flow-rich-block ol {
    padding-left:18px
}

.flow-list {
    display:grid;
    gap:12px;
    color:#dcebf0;
    font-weight:700
}

.flow-list div {
    display:flex;
    gap:12px;
    align-items:center
}

.flow-list div:before {
    content:"";
    width:9px;
    height:9px;
    border-radius:50%;
    background:var(--cyan);
    box-shadow:0 0 18px var(--cyan);
    flex:0 0 auto
}

.flow-image {
    border-radius:64px 16px 64px 16px;
    background:linear-gradient(180deg,rgba(0,0,0,.05),rgba(0,0,0,.62)),url("../img/about.svg") center/cover;
    min-height:100%;
    position:relative;
    overflow:hidden
}

.flow-image:after {
    content:"24/7 SERVICE";
    position:absolute;
    right:24px;
    bottom:24px;
    font-family:"Audiowide",sans-serif;
    font-size:54px;
    letter-spacing:-.06em;
    color:rgba(255,255,255,.18)
}

.flow-plan {
    border-radius:64px 16px 64px 16px;
    border:1px solid rgba(255,255,255,.11);
    background:linear-gradient(180deg,rgba(8,26,35,.58),rgba(9,18,24,.76));
    min-height:100%;
    padding:34px 28px;
    display:flex;
    flex-direction:column
}

.flow-plan-kicker {
    display:inline-flex;
    align-self:flex-start;
    padding:6px 12px;
    border-radius:999px;
    border:1px solid rgba(148,214,239,.34);
    color:#bde9fb;
    font-size:11px;
    letter-spacing:.08em;
    text-transform:uppercase;
    margin-bottom:14px
}

.flow-plan h4 {
    font-size:clamp(24px,2.2vw,32px);
    margin:0 0 18px;
    line-height:1.15
}

.flow-plan-list {
    display:grid;
    gap:12px;
    /* margin-top:auto */
}

.flow-plan-item {
    display:grid;
    grid-template-columns:auto 1fr;
    gap:12px;
    align-items:flex-start;
    padding:12px;
    border-radius:16px;
    border:1px solid rgba(170,214,231,.18);
    background:rgba(10,26,34,.44)
}

.flow-plan-no {
    width:34px;
    height:34px;
    border-radius:999px;
    border:1px solid rgba(148,214,239,.45);
    display:flex;
    align-items:center;
    justify-content:center;
    font-family:"Audiowide",sans-serif;
    font-size:12px;
    color:#dcf2fb;
    flex:0 0 auto
}

.flow-plan-item h5 {
    margin:0 0 4px;
    font-size:16px;
    line-height:1.3
}

.flow-plan-item p {
    margin:0;
    font-size:13px;
    line-height:1.55;
    color:#a9bfca
}

@media (max-width: 991px) {
    .flow-plan {
        min-height:420px
    }
}

@media (max-width: 767px) {
    .flow-plan {
        border-radius:42px 12px 42px 12px;
        min-height:auto;
        padding:24px 18px
    }

    .flow-plan h4 {
        font-size:24px
    }
}

.project-card {
    display:block;
    position:relative;
    height:430px;
    border-radius:54px 18px 54px 18px;
    overflow:hidden;
    border:1px solid rgba(255,255,255,.12);
    background:rgba(255,255,255,.055);
    transition:.35s ease
}

.project-card.large {
    height:440px
}

.project-card img {
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
    filter:saturate(.8) contrast(1.05);
    transition:.45s ease
}

.project-card:after {
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(180deg,transparent 35%,rgba(0,0,0,.82))
}

.project-card div {
    position:absolute;
    left:26px;
    right:26px;
    bottom:26px;
    z-index:2
}

.project-card span {
    color:var(--cyan-soft);
    font-size:13px;
    font-weight:800;
    text-transform:uppercase;
    letter-spacing:.06em
}

.project-card h3 {
    font-size:30px;
    margin-top:8px
}

.project-card:hover {
    transform:translateY(-8px);
    border-color:rgba(94,220,255,.35);
    box-shadow:0 24px 70px rgba(8,167,218,.13)
}

.project-card:hover img {
    transform:scale(1.06)
}

.swiper-controls {
    display:flex;
    gap:12px;
    justify-content:flex-end;
    margin-top:24px
}

.showcase-prev,.showcase-next {
    width:48px;
    height:48px;
    border-radius:50%;
    border:1px solid rgba(255,255,255,.16);
    background:rgba(255,255,255,.07);
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:34px;
    cursor:pointer;
    transition:.25s
}

.showcase-prev:hover,.showcase-next:hover {
    background:rgba(8,167,218,.22)
}

.process-card {
    height:100%;
    border-radius:34px;
    border:1px solid rgba(255,255,255,.1);
    background:rgba(255,255,255,.045);
    padding:30px;
    min-height:240px
}

.process-card span {
    color:var(--cyan-soft);
    font-weight:800;
    font-size:13px;
    letter-spacing:.08em
}

.process-card h3 {
    font-size:30px;
    margin:24px 0 14px
}

.process-card p {
    color:var(--muted);
    line-height:1.7;
    font-size:14px
}

.cta {
    padding-bottom:130px
}

.cta-box {
    position:relative;
    overflow:hidden;
    border-radius:96px 24px 96px 24px;
    padding:74px;
    border:1px solid rgba(255,255,255,.14);
    background:radial-gradient(circle at 84% 28%,rgba(94,220,255,.22),transparent 28%),linear-gradient(135deg,rgba(8,167,218,.2),rgba(255,255,255,.055));
    box-shadow:var(--shadow)
}

.cta-box:before {
    content:"";
    position:absolute;
    width:520px;
    height:520px;
    right:-230px;
    top:-250px;
    border-radius:50%;
    border:62px solid rgba(255,255,255,.08);
    border-left-color:transparent;
    border-bottom-color:transparent;
    transform:rotate(12deg)
}

.cta-box h2 {
    font-size:clamp(44px,5vw,82px);
    max-width:760px;
    margin-bottom:22px
}

.cta-box p {
    color:rgba(255,255,255,.72);
    line-height:1.8;
    max-width:650px;
    margin-bottom:30px;
    font-size:17px
}

.site-footer {
    padding:42px 0;
    border-top:1px solid rgba(255,255,255,.1);
    color:var(--muted);
    font-size:14px
}

.page-hero {
    position:relative;
    padding-top:180px
}

.page-hero .arc-bg {
    right:-390px;
    top:40px
}

.page-hero h1 {
    font-size:clamp(54px,7vw,104px)
}

.filter-tabs {
    display:flex;
    gap:12px;
    flex-wrap:wrap;
    margin-bottom:34px
}

.filter-tabs button {
    border:1px solid rgba(255,255,255,.14);
    background:rgba(255,255,255,.055);
    color:#fff;
    border-radius:999px;
    padding:12px 18px;
    font-weight:800
}

.filter-tabs button.active,.filter-tabs button:hover {
    background:rgba(8,167,218,.22);
    border-color:rgba(94,220,255,.4)
}

.project-item {
    transition:.25s ease
}

.project-item.is-hidden {
    display:none
}

.reveal {
    opacity:0;
    transform:translateY(28px);
    transition:.75s ease
}

.reveal.visible {
    opacity:1;
    transform:translateY(0)
}

/* Portfolio detail page */
.breadcrumb-line {
    display:flex;
    align-items:center;
    gap:10px;
    flex-wrap:wrap;
    margin-bottom:34px;
    color:var(--muted);
    font-size:14px;
    font-weight:700
}

.breadcrumb-line a {
    color:#dcebf0
}

.breadcrumb-line span {
    opacity:.42
}

.breadcrumb-line strong {
    color:var(--cyan-soft)
}

.project-detail-hero {
    position:relative;
    padding-top:180px;
    padding-bottom:64px
}

.project-detail-hero .arc-bg {
    right:-390px;
    top:60px
}

.detail-lead {
    max-width:760px;
    color:var(--muted);
    font-size:18px;
    line-height:1.8;
    margin-top:24px
}

.detail-summary-card {
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:14px;
    padding:18px;
    border:1px solid rgba(255,255,255,.12);
    border-radius:42px 14px 42px 14px;
    background:rgba(255,255,255,.055);
    backdrop-filter:blur(18px)
}

.detail-summary-card div {
    padding:18px;
    border:1px solid rgba(255,255,255,.09);
    border-radius:26px 10px 26px 10px;
    background:rgba(255,255,255,.04)
}

.detail-summary-card span {
    display:block;
    color:var(--muted);
    font-size:12px;
    font-weight:800;
    text-transform:uppercase;
    letter-spacing:.07em;
    margin-bottom:8px
}

.detail-summary-card strong {
    display:block;
    color:#fff;
    font-size:15px;
    line-height:1.35
}

.detail-cover-section {
    padding:0 0 34px
}

.detail-cover {
    position:relative;
    height:min(680px,62vw);
    min-height:430px;
    border-radius:86px 24px 86px 24px;
    overflow:hidden;
    border:1px solid rgba(255,255,255,.12);
    box-shadow:var(--shadow);
    background:rgba(255,255,255,.055)
}

.detail-cover:after {
    content:"";
    position:absolute;
    inset:24px;
    border-radius:66px 14px 66px 14px;
    border:1px solid rgba(255,255,255,.13);
    pointer-events:none
}

.detail-cover img {
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
    filter:saturate(.82) contrast(1.05)
}

.cover-badge {
    position:absolute;
    left:34px;
    bottom:34px;
    display:flex;
    align-items:center;
    gap:18px;
    padding:18px 22px;
    border-radius:30px 10px 30px 10px;
    border:1px solid rgba(255,255,255,.16);
    background:rgba(8,12,14,.64);
    backdrop-filter:blur(18px)
}

.cover-badge b {
    font-family:"Audiowide",sans-serif;
    font-size:48px;
    letter-spacing:-.07em
}

.cover-badge span {
    color:var(--muted);
    font-weight:800
}

.detail-content-card {
    padding:46px;
    border-radius:56px 18px 56px 18px;
    border:1px solid rgba(255,255,255,.11);
    background:rgba(255,255,255,.052)
}

.detail-content-card h2 {
    font-size:clamp(36px,4vw,58px);
    margin:18px 0 24px
}

.detail-content-card h3 {
    font-size:34px;
    margin:36px 0 20px
}

.detail-content-card p {
    color:var(--muted);
    font-size:17px;
    line-height:1.85
}

.detail-highlight-box {
    display:grid;
    gap:8px;
    margin:30px 0;
    padding:22px;
    border-radius:30px 10px 30px 10px;
    border:1px solid rgba(94,220,255,.25);
    background:rgba(8,167,218,.11)
}

.detail-highlight-box strong {
    color:#fff
}

.detail-highlight-box span {
    color:#c9d6dc;
    line-height:1.65
}

.scope-grid {
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:12px
}

.scope-grid div {
    padding:16px 18px;
    border-radius:22px 8px 22px 8px;
    border:1px solid rgba(255,255,255,.1);
    background:rgba(255,255,255,.045);
    color:#dcebf0;
    font-weight:800
}

.scope-grid div:before {
    content:"";
    display:inline-block;
    width:8px;
    height:8px;
    margin-right:10px;
    border-radius:50%;
    background:var(--cyan);
    box-shadow:0 0 18px var(--cyan)
}

.sticky-detail {
    position:sticky;
    top:120px
}

.detail-info-panel {
    padding:28px;
    border-radius:42px 14px 42px 14px;
    border:1px solid rgba(255,255,255,.12);
    background:rgba(255,255,255,.055)
}

.detail-info-panel h3 {
    font-size:30px;
    margin-bottom:22px
}

.detail-info-panel ul {
    list-style:none;
    padding:0;
    margin:0 0 24px;
    display:grid;
    gap:12px
}

.detail-info-panel li {
    display:flex;
    justify-content:space-between;
    gap:14px;
    padding-bottom:12px;
    border-bottom:1px solid rgba(255,255,255,.09)
}

.detail-info-panel li span {
    color:var(--muted);
    font-size:13px;
    font-weight:800
}

.detail-info-panel li strong {
    color:#fff;
    text-align:right
}

.detailGallery {
    overflow:visible
}

.detailGallery .swiper-slide {
    height:420px;
    border-radius:54px 18px 54px 18px;
    overflow:hidden;
    border:1px solid rgba(255,255,255,.12);
    background:rgba(255,255,255,.055)
}

.detailGallery .swiper-slide img {
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
    filter:saturate(.82) contrast(1.05)
}

.detail-gallery-link {
    display:block;
    width:100%;
    height:100%;
    cursor:zoom-in
}

.detail-prev,.detail-next {
    width:48px;
    height:48px;
    border-radius:50%;
    border:1px solid rgba(255,255,255,.16);
    background:rgba(255,255,255,.07);
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:34px;
    cursor:pointer;
    transition:.25s
}

.detail-prev:hover,.detail-next:hover {
    background:rgba(8,167,218,.22)
}

/* Portfolio detail page layout refinements */
.project-detail-hero {
    padding-top:160px;
    padding-bottom:34px
}

.detail-page-title {
    font-size:clamp(34px,3.4vw,52px);
    line-height:1.18;
    margin:10px 0 0
}

.detail-lead {
    font-size:16px;
    line-height:1.75;
    margin-top:16px;
    max-width:860px
}

.detail-cover-compact {
    height:100%;
    min-height:420px;
    border-radius:56px 18px 56px 18px
}

.detail-cover-compact:after {
    inset:18px;
    border-radius:42px 12px 42px 12px
}

.detail-info-panel {
    display:flex;
    flex-direction:column;
    justify-content:flex-start
}

.detail-info-panel h3 {
    font-size:clamp(28px,2.4vw,38px)
}

.detail-content-card {
    padding:36px;
    border-radius:46px 14px 46px 14px
}

.detail-content-card h2,.detail-content-card h3 {
    font-size:clamp(30px,2.6vw,44px);
    margin:0 0 18px
}

.detail-content-card p {
    font-size:16px
}

.detail-gallery-title {
    font-size:clamp(30px,2.5vw,42px)
}

.detail-gallery-shell {
    display:grid;
    grid-template-columns:56px minmax(0,1fr) 56px;
    align-items:center;
    gap:14px;
    width:100%
}

.detailGallery {
    overflow:hidden;
    width:100%
}

.detailGallery .swiper-slide {
    height:360px;
    border-radius:36px 14px 36px 14px
}

/* Project overrides (editable) */
h1 {
    font-size:clamp(46px,5.95vw,88px)
}

.page-hero h1 {
    font-size:clamp(46px,5.95vw,88px)
}

.hero h1 {
    font-size:clamp(32px,4.6vw,60px)
}

.brand {
    gap:0
}

.brand-logo {
    width:250px;
    height:auto;
    max-height:72px;
    object-fit:contain;
    display:block;
    /* border-radius:14px; */
    /* background:rgba(255,255,255,.05); */
    padding:6px
}

.cta-box .form-control {
    background:rgba(11,15,18,.55);
    border:1px solid rgba(255,255,255,.2);
    color:#fff
}

.cta-box .form-control:focus {
    background:rgba(11,15,18,.72);
    border-color:rgba(94,220,255,.55);
    box-shadow:0 0 0 .25rem rgba(8,167,218,.18);
    color:#fff
}

.cta-box .form-control::placeholder {
    color:rgba(255,255,255,.62)
}

.cta-box .alert {
    border-radius:14px
}

.cta-contact-btn {
    display:inline-flex;
    align-items:center;
    gap:10px;
    min-height:56px;
    padding:0 20px;
    border-radius:999px;
    border:1px solid rgba(255,255,255,.18);
    font-weight:800;
    transition:.25s ease
}

.cta-contact-btn:hover {
    transform:translateY(-2px);
    color:#fff
}

.cta-contact-icon {
    width:34px;
    height:34px;
    border-radius:999px;
    display:grid;
    place-items:center;
    background:rgba(255,255,255,.15)
}

.cta-contact-icon svg {
    width:18px;
    height:18px;
    display:block
}

.cta-contact-btn-phone {
    background:rgba(20,28,34,.72);
    color:#eaf4f8;
    border-color:rgba(160,205,224,.42)
}

.cta-contact-btn-phone:hover {
    background:rgba(34,50,63,.9);
    border-color:rgba(173,221,242,.75)
}

.cta-contact-btn-whatsapp {
    background:#25D366;
    color:#fff;
    border-color:#25D366;
    box-shadow:0 18px 60px rgba(37,211,102,.28)
}

.cta-contact-btn-whatsapp .cta-contact-icon {
    background:rgba(0,0,0,.16)
}

.cta-contact-btn-whatsapp:hover {
    background:#1fb95a;
    border-color:#1fb95a;
    box-shadow:0 18px 70px rgba(37,211,102,.34)
}

.cta-contact-btn-mail {
    background:rgba(8,167,218,.2);
    color:#dff6ff;
    border-color:rgba(94,220,255,.55)
}

.cta-contact-btn-mail:hover {
    background:rgba(8,167,218,.34);
    border-color:rgba(126,232,255,.75)
}

.hero-slider-wrap .temp-chip {
    border-radius:32px 32px 64px 16px
}

.references-panel {
    margin-top:28px;
    padding:30px;
    border-radius:26px;
    border:1px solid rgba(150,200,220,.22);
    background:linear-gradient(135deg,rgba(8,13,19,.75),rgba(13,24,31,.78))
}

.references-panel h3 {
    margin:0 0 18px;
    font-size:1.05rem;
    font-weight:800;
    letter-spacing:.02em;
    color:#e8f5fb
}

.references-grid {
    display:grid;
    grid-template-columns:repeat(5,minmax(0,1fr));
    gap:12px
}

.reference-item {
    min-height:84px;
    border-radius:16px;
    border:1px solid rgba(172,213,229,.2);
    background:rgba(8,14,20,.6);
    display:flex;
    align-items:center;
    justify-content:center;
    padding:14px;
    transition:.25s ease
}

.reference-item:hover {
    transform:translateY(-2px);
    border-color:rgba(174,219,238,.5);
    background:rgba(15,30,42,.75)
}

.reference-item img {
    max-width:100%;
    max-height:48px;
    width:auto;
    height:auto;
    filter:grayscale(100%) contrast(1.05);
    opacity:.9;
    transition:.25s ease
}

.reference-item:hover img {
    filter:grayscale(0%);
    opacity:1
}

.references-empty {
    grid-column:1 / -1;
    border-radius:14px;
    border:1px dashed rgba(172,213,229,.32);
    padding:14px;
    color:#bfd3de;
    text-align:center
}

@media (max-width: 991.98px) {
    .references-grid {
        grid-template-columns:repeat(3,minmax(0,1fr))
    }
}

@media (max-width: 575.98px) {
    .references-panel {
        padding:20px
    }

    .references-grid {
        grid-template-columns:repeat(2,minmax(0,1fr))
    }
}

.showcase-section .showcase-shell {
    display:grid;
    grid-template-columns:56px minmax(0,1fr) 56px;
    align-items:center;
    gap:14px
}

.showcase-section .showcaseSwiper {
    overflow:hidden;
    width:100%
}

.showcase-section .showcase-prev,
.showcase-section .showcase-next {
    width:48px;
    height:48px;
    margin:0 auto;
    backdrop-filter:blur(8px)
}

@media (max-width: 767px) {
    .showcase-section .showcase-shell {
        grid-template-columns:42px minmax(0,1fr) 42px;
        gap:8px
    }

    .showcase-section .showcase-prev,
    .showcase-section .showcase-next {
        width:42px;
        height:42px;
        font-size:30px
    }
}

.portfolio-hero-inline {
    margin-top:4px
}

.portfolio-page-title {
    font-size:clamp(36px,3.2vw,48px) !important;
    line-height:1.08;
    max-width:none
}

.portfolio-hero-inline p {
    max-width:none
}

@media (max-width: 991px) {
    .portfolio-page-title {
        font-size:clamp(36px,7.5vw,56px)
    }
}
