/*=========================================
    Project Cards (Glassmorphism, Minimal)
=========================================*/

.project-item,
.project-item *,
.project-static-item,
.project-static-item * {
    animation: none !important;
    transition: none !important;
}

.project-card-media {
    display: block;
    width: 100%;
    position: relative;
    overflow: hidden;
    border-radius: 20px;
    aspect-ratio: 4 / 3;
    box-shadow:
        0 2px 8px rgba(15, 23, 42, 0.04),
        0 8px 32px rgba(15, 23, 42, 0.07);
    background: linear-gradient(145deg,
            rgba(175, 222, 248, 0.62) 0%,
            rgba(148, 205, 238, 0.54) 50%,
            rgba(130, 192, 230, 0.58) 100%);
    backdrop-filter: blur(28px) saturate(190%);
    -webkit-backdrop-filter: blur(28px) saturate(190%);
    border: 1px solid rgba(255, 255, 255, 0.60);
}

.project-card-visual {
    position: absolute;
    inset: 0;
    overflow: hidden;
    border-radius: 20px;
}

.project-card-bg {
    position: absolute;
    inset: 0;
    background: linear-gradient(160deg,
            rgba(165, 218, 248, 0.65) 0%,
            rgba(128, 195, 235, 0.55) 100%);
    z-index: 1;
}

/* Atmospheric soft gradient effect - no harsh shapes */
.project-card-pattern {
    position: absolute;
    inset: 0;
    z-index: 2;
    background:
        url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.72' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.09'/%3E%3C/svg%3E"),
        linear-gradient(160deg,
            rgba(255, 255, 255, 0.75) 0%,
            rgba(255, 255, 255, 0.22) 18%,
            transparent 55%,
            rgba(80, 160, 210, 0.06) 100%);
    background-size: 140px 140px, cover;
    opacity: 1;
    pointer-events: none;
}

.project-scene {
    position: absolute;
    inset: 14px;
    z-index: 3;
    overflow: hidden;
}

.project-device {
    position: absolute;
    background: linear-gradient(160deg, rgba(30, 40, 55, 0.93) 0%, rgba(20, 30, 46, 0.96) 100%);
    border: 0.5px solid rgba(45, 60, 80, 0.18);
    box-shadow:
        0 12px 36px rgba(10, 18, 35, 0.22),
        0 4px 10px rgba(10, 18, 35, 0.12),
        inset 0 0.5px 0 rgba(255, 255, 255, 0.1);
    overflow: hidden;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}

.project-device-tablet {
    width: 55%;
    height: 46%;
    border-radius: 14px;
}

.project-device-phone {
    width: 28%;
    min-width: 90px;
    max-width: 124px;
    height: 64%;
    border-radius: 30px;
}

.project-device-phone::before,
.project-device-phone::after {
    content: '';
    position: absolute;
    background: #3b455a;
    border-radius: 999px;
    z-index: 3;
}

/* Volume buttons (left side) */
.project-device-phone::before {
    left: 1px;
    top: 28%;
    width: 1.8px;
    height: 26px;
    box-shadow: 0 32px 0 #3b455a;
}

/* Power button (right side) */
.project-device-phone::after {
    right: 1px;
    top: 36%;
    width: 1.8px;
    height: 42px;
}

.device-screen {
    position: absolute;
    inset: 5px;
    border-radius: 10px;
    overflow: hidden;
    background: #0b1220;
}

.project-device-phone .device-screen {
    inset: 5px 5px 5px;
    border-radius: 24px;
}

.device-screen img {
    width: 100%;
    height: 100%;
    object-fit: cover !important;
    object-position: center;
    display: block;
    background: #0b1220;
}

/* General card-level images: contain (for standalone images outside devices) */
.project-card-media>img {
    object-fit: contain !important;
    object-position: center !important;
}

/* Device screen images MUST fill the screen — cover/stretch */
.project-card-media .device-screen img {
    object-fit: cover !important;
    object-position: top center !important;
}

/* Two tablets (web/default) */
.project-scene-tablets .device-back {
    left: 10%;
    top: 14%;
    transform: translate3d(0, 0, 0);
    z-index: 1;
}

.project-scene-tablets .device-front {
    left: 24%;
    top: 42%;
    transform: translate3d(0, 0, 0);
    z-index: 2;
}

/* Mixed (custom software): tablet + phone — phone overlaps tablet right side */
.project-scene-mixed .device-back {
    left: 22%;
    top: 26%;
    z-index: 1;
}

.project-scene-mixed .device-front {
    right: 22%;
    top: 8%;
    z-index: 2;
}

/* Two mobiles (mobile app) */
.project-scene-mobiles .device-left {
    left: 19%;
    top: 18%;
}

.project-scene-mobiles .device-right {
    right: 19%;
    top: 18%;
}

/* No hover movement at all */
.project-card-link:hover,
.tp-portfolio-inner-thumb:hover,
.project-static-item:hover,
.project-card-media:hover,
.project-card-visual:hover {
    transform: translate3d(0, 0, 0) !important;
    box-shadow: inherit !important;
}

/* Keep thumb height tight to card media (prevents large empty gap) */
.project-static-item.tp-portfolio-inner-thumb {
    flex: 0 0 auto !important;
    margin-bottom: 6px !important;
}

/* Ensure overlay chips are positioned inside card media */
.project-static-item .project-card-media {
    position: relative !important;
}

/* Tech stack chips: RIGHT side, vertical column */
.project-static-item .project-card-media .tech-chips-container {
    position: absolute !important;
    left: auto !important;
    right: 10px !important;
    top: 50px !important;
    /* below the service chip */
    bottom: 56px !important;
    /* above the title bar */
    width: 64px !important;
    max-width: 64px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 5px !important;
    z-index: 10;
}

/* Tech icon chip — minimal padding */
.project-static-item .project-card-media .tech-chip-icon {
    padding: 0px 0px !important;
}

/* Icon-only glass chip - Atmospheric style */
.project-static-item .project-card-media .tech-chip {
    width: 46px !important;
    height: 46px !important;
    min-width: 46px !important;
    border-radius: 12px !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: rgba(255, 255, 255, 0.4) !important;
    backdrop-filter: blur(20px) saturate(200%) !important;
    -webkit-backdrop-filter: blur(20px) saturate(200%) !important;
    border: 1px solid rgba(255, 255, 255, 0.65) !important;
    box-shadow:
        0 4px 14px rgba(0, 0, 0, 0.05),
        0 1px 3px rgba(0, 0, 0, 0.03),
        inset 0 1px 0 rgba(255, 255, 255, 0.7) !important;
    font-size: 0 !important;
    letter-spacing: 0 !important;
    position: relative !important;
    cursor: default;
}

.project-static-item .project-card-media .tech-chip img {
    width: 34px !important;
    height: 34px !important;
    object-fit: contain !important;
    display: block !important;
    border-radius: 0 !important;
}

.project-static-item .project-card-media .tech-chip-abbr {
    font-size: 9px !important;
    font-weight: 700;
    color: #1e293b;
    line-height: 1;
    letter-spacing: 0;
}

/* Both chips above the top dark scrim (z-index 5) */
.project-static-item .project-card-media .portfolio-chip.chip-service {
    top: 10px !important;
    right: 10px !important;
    z-index: 11 !important;
}

.project-static-item .project-card-media .portfolio-chip.chip-industry {
    z-index: 11 !important;
}

/* Project title — seamlessly blended with glassy background */
.card-project-title-bar {
    position: absolute !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 10;
    padding: 60px 16px 14px;
    text-align: center;
    /* Atmospheric fade — matches card background exactly, no visible border */
    background: linear-gradient(to bottom,
            transparent 0%,
            rgba(148, 205, 238, 0.65) 45%,
            rgba(135, 195, 232, 0.97) 100%) !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    border-top: none !important;
    border-radius: 0 0 18px 18px !important;
}

.card-project-title-text {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    font-size: 23px;
    font-weight: 600;
    font-family: p_m, sans-serif;
    line-height: 1.35;
    overflow: hidden;
    text-align: center;
    color: #1a3448;
    letter-spacing: 0.1px;
    text-shadow: 0 1px 3px rgba(255, 255, 255, 0.75);
}

/* Hide the old below-title area */
.project-animated-card .portfolio-content-below {
    display: none !important;
}

/* Cancel global portfolio hover scale from main.css on this card design */
.tp-portfolio-inner-item:hover .tp-portfolio-inner-thumb .project-card-media,
.tp-portfolio-inner-item:hover .tp-portfolio-inner-thumb .project-card-media img,
.tp-portfolio-inner-item:hover .tp-portfolio-inner-thumb .project-card-visual,
.tp-portfolio-inner-item:hover .tp-portfolio-inner-thumb .project-device,
.tp-portfolio-inner-item:hover .tp-portfolio-inner-thumb .device-screen img {
    transform: translate3d(0, 0, 0) !important;
}

.tp-portfolio-inner-thumb .project-card-media img,
.tp-portfolio-inner-thumb .device-screen img {
    transition: none !important;
}

@media (max-width: 991px) {
    .project-card-media {
        aspect-ratio: 16 / 12;
    }

    .project-device-tablet {
        width: 57%;
        height: 44%;
    }

    .project-device-phone {
        width: 28%;
        min-width: 80px;
        max-width: 110px;
        height: 62%;
    }

    .project-scene-mixed .device-back {
        left: 20%;
        top: 26%;
        z-index: 1;
    }

    .project-scene-mixed .device-front {
        right: 20%;
        top: 8%;
        z-index: 2;
    }

    .project-scene-mobiles .device-left {
        left: 17%;
    }

    .project-scene-mobiles .device-right {
        right: 17%;
    }
}

@media (max-width: 767px) {
    .project-card-media {
        border-radius: 14px;
        aspect-ratio: 16 / 12;
    }

    .project-card-visual {
        border-radius: 14px;
    }

    .project-scene {
        inset: 10px;
    }

    .project-device-tablet {
        width: 57%;
        height: 44%;
        border-radius: 12px;
    }

    .project-device-phone {
        width: 28%;
        min-width: 70px;
        max-width: 92px;
        height: 61%;
        border-radius: 24px;
    }

    .project-device-phone::before {
        width: 1.5px;
        height: 20px;
        box-shadow: 0 24px 0 #3b455a;
    }

    .project-device-phone::after {
        width: 1.5px;
        height: 32px;
    }

    .project-device-phone .device-screen {
        border-radius: 18px;
        inset: 5px 4px 5px;
    }

    .project-scene-tablets .device-back {
        left: 9%;
        top: 16%;
    }

    .project-scene-tablets .device-front {
        left: 22%;
        top: 44%;
    }

    .project-scene-mixed .device-back {
        left: 18%;
        top: 26%;
        z-index: 1;
    }

    .project-scene-mixed .device-front {
        right: 18%;
        top: 8%;
        z-index: 2;
    }

    .project-scene-mobiles .device-left {
        left: 16%;
        top: 20%;
    }

    .project-scene-mobiles .device-right {
        right: 16%;
        top: 20%;
    }

    .project-static-item.tp-portfolio-inner-thumb {
        margin-bottom: 0 !important;
    }

    /* Mobile: smaller vertical chips */
    .project-static-item .project-card-media .tech-chips-container {
        right: 8px !important;
        top: 42px !important;
        bottom: 48px !important;
        width: 48px !important;
        max-width: 48px !important;
        gap: 5px !important;
    }

    .project-static-item .project-card-media .tech-chip-icon {
        padding: 0px 0px !important;
    }

    .project-static-item .project-card-media .tech-chip {
        width: 40px !important;
        height: 40px !important;
        min-width: 40px !important;
        border-radius: 10px !important;
        backdrop-filter: blur(16px) saturate(200%) !important;
        -webkit-backdrop-filter: blur(16px) saturate(200%) !important;
    }

    .project-static-item .project-card-media .tech-chip img {
        width: 30px !important;
        height: 30px !important;
    }

    .project-static-item .project-card-media .portfolio-chip.chip-service {
        top: 8px !important;
        right: 8px !important;
    }

    .card-project-title-bar {
        padding: 48px 12px 10px !important;
        border-radius: 0 0 14px 14px !important;
        backdrop-filter: none !important;
        -webkit-backdrop-filter: none !important;
        border-top: none !important;
    }

    .card-project-title-text {
        font-size: 17px !important;
        color: #1a3448 !important;
    }
}

/* Small tablets and large phones (576px - 767px) - 2 columns */
@media (min-width: 576px) and (max-width: 767.98px) {
    .project-item {
        padding-left: 6px !important;
        padding-right: 6px !important;
        margin-bottom: 12px !important;
    }

    .project-card-media {
        aspect-ratio: 4 / 3;
        border-radius: 12px;
    }

    .project-card-visual {
        border-radius: 12px;
    }

    .project-scene {
        inset: 6px;
    }

    /* Device sizing for 2-column cards */
    .project-device-tablet {
        width: 58%;
        height: 44%;
        border-radius: 10px;
    }

    .project-device-phone {
        width: 30%;
        min-width: 60px;
        max-width: 90px;
        height: 60%;
        border-radius: 20px;
    }

    .project-device-phone .device-screen {
        border-radius: 14px;
        inset: 4px 3px 4px;
    }

    .project-device-phone::before {
        width: 1.2px;
        height: 16px;
        box-shadow: 0 20px 0 #3b455a;
    }

    .project-device-phone::after {
        width: 1.2px;
        height: 26px;
    }

    /* Scene positions for narrower cards */
    .project-scene-tablets .device-back {
        left: 6%;
        top: 12%;
    }

    .project-scene-tablets .device-front {
        left: 18%;
        top: 40%;
    }

    .project-scene-mixed .device-back {
        left: 14%;
        top: 20%;
    }

    .project-scene-mixed .device-front {
        right: 14%;
        top: 6%;
    }

    .project-scene-mobiles .device-left {
        left: 12%;
        top: 16%;
    }

    .project-scene-mobiles .device-right {
        right: 12%;
        top: 16%;
    }

    /* Smaller chips for narrower 2-column cards */
    .project-static-item .project-card-media .tech-chips-container {
        right: 4px !important;
        top: 34px !important;
        bottom: 40px !important;
        width: 30px !important;
        max-width: 30px !important;
        gap: 2px !important;
        flex-wrap: nowrap !important;
        overflow: hidden !important;
    }

    .project-static-item .project-card-media .tech-chip {
        width: 26px !important;
        height: 26px !important;
        min-width: 26px !important;
        border-radius: 6px !important;
    }

    .project-static-item .project-card-media .tech-chip img {
        width: 18px !important;
        height: 18px !important;
    }

    .project-static-item .project-card-media .portfolio-chip.chip-service {
        top: 5px !important;
        right: 5px !important;
        font-size: 8px !important;
        padding: 2px 6px !important;
    }

    .project-static-item .project-card-media .portfolio-chip.chip-industry {
        top: 5px !important;
        left: 5px !important;
        font-size: 8px !important;
        padding: 2px 6px !important;
        max-width: 48%;
    }

    .card-project-title-bar {
        padding: 30px 6px 6px !important;
        border-radius: 0 0 12px 12px !important;
    }

    .card-project-title-text {
        font-size: 13px !important;
        line-height: 1.25;
        -webkit-line-clamp: 1;
        line-clamp: 1;
    }

    /* Reduce card bottom spacing */
    .project-static-item.tp-portfolio-inner-thumb {
        margin-bottom: 0 !important;
    }
}

/* Extra small devices (phones, less than 576px) */
@media (max-width: 575.98px) {
    .project-card-media {
        aspect-ratio: 4 / 3.2;
        border-radius: 12px;
    }

    .project-card-visual {
        border-radius: 12px;
    }

    .project-scene {
        inset: 8px;
    }

    /* Device sizing for single-column mobile */
    .project-device-tablet {
        width: 60%;
        height: 46%;
        border-radius: 12px;
    }

    .project-device-phone {
        width: 30%;
        min-width: 70px;
        max-width: 100px;
        height: 62%;
        border-radius: 22px;
    }

    .project-device-phone .device-screen {
        border-radius: 16px;
        inset: 4px 3px 4px;
    }

    /* Scene positioning — devices fill more of the card */
    .project-scene-tablets .device-back {
        left: 6%;
        top: 12%;
    }

    .project-scene-tablets .device-front {
        left: 18%;
        top: 40%;
    }

    .project-scene-mixed .device-back {
        left: 12%;
        top: 18%;
    }

    .project-scene-mixed .device-front {
        right: 12%;
        top: 4%;
    }

    .project-scene-mobiles .device-left {
        left: 12%;
        top: 14%;
    }

    .project-scene-mobiles .device-right {
        right: 12%;
        top: 14%;
    }

    /* Smaller chips for mobile */
    .project-static-item .project-card-media .tech-chips-container {
        right: 6px !important;
        top: 42px !important;
        bottom: 50px !important;
        width: 32px !important;
        max-width: 32px !important;
        gap: 3px !important;
        flex-wrap: nowrap !important;
        overflow: hidden !important;
    }

    .project-static-item .project-card-media .tech-chip {
        width: 28px !important;
        height: 28px !important;
        min-width: 28px !important;
        border-radius: 6px !important;
        flex-shrink: 0 !important;
    }

    .project-static-item .project-card-media .tech-chip img {
        width: 20px !important;
        height: 20px !important;
    }

    .project-static-item .project-card-media .portfolio-chip.chip-service {
        top: 6px !important;
        right: 6px !important;
        font-size: 10px !important;
        padding: 4px 8px !important;
    }

    .project-static-item .project-card-media .portfolio-chip.chip-industry {
        font-size: 10px !important;
        padding: 4px 8px !important;
    }

    /* Title bar adjustments */
    .card-project-title-bar {
        padding: 40px 10px 8px !important;
        border-radius: 0 0 12px 12px !important;
    }

    .card-project-title-text {
        font-size: 15px !important;
        line-height: 1.3;
        -webkit-line-clamp: 2;
    }

    /* Card spacing in grid */
    .project-item {
        padding-left: 8px !important;
        padding-right: 8px !important;
        margin-bottom: 16px !important;
    }

    .project-item .row {
        margin-left: -8px !important;
        margin-right: -8px !important;
    }
}

/* Very small devices (small phones, less than 360px) */
@media (max-width: 359.98px) {
    .project-card-media {
        aspect-ratio: 4 / 3.4;
    }

    .project-device-tablet {
        width: 60%;
        height: 44%;
        border-radius: 10px;
    }

    .project-device-phone {
        width: 32%;
        min-width: 58px;
        max-width: 85px;
        height: 58%;
        border-radius: 18px;
    }

    .project-device-phone .device-screen {
        border-radius: 14px;
        inset: 3px 2px 3px;
    }

    .card-project-title-text {
        font-size: 13px !important;
    }

    .project-static-item .project-card-media .tech-chips-container {
        width: 28px !important;
        max-width: 28px !important;
        gap: 2px !important;
        top: 40px !important;
        bottom: 48px !important;
    }

    .project-static-item .project-card-media .tech-chip {
        width: 24px !important;
        height: 24px !important;
        min-width: 24px !important;
        border-radius: 5px !important;
    }

    .project-static-item .project-card-media .tech-chip img {
        width: 16px !important;
        height: 16px !important;
    }
}