/* =====================================================================
   Project Detail Page Custom Styles (Only for resources/views/frontend/pages/project-detail.blade.php)
   ===================================================================== */

.creative-image-block {
    position: relative;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.2rem 0 1.2rem 0;
}
.creative-image-wrapper {
    position: relative;
    width: 100%;
    max-width: 420px;
    margin: 0 auto;
    border-radius: 1.5rem;
    overflow: visible;
}
.creative-image-main {
    width: 100%;
    height: 320px;
    object-fit: contain;
    border-radius: 1.5rem;
    background: #fff;
    box-shadow: 0 2px 12px 0 rgba(80, 120, 255, 0.10);
    position: relative;
    z-index: 2;
    border: 2px solid #e6eaff;
    padding: 0.5rem;
}
.creative-image-decor {
    position: absolute;
    bottom: -18px;
    right: -18px;
    width: 80px;
    height: 80px;
    background: radial-gradient(circle, #c7d2fe 0%, #e0e7ff 80%, transparent 100%);
    opacity: 0.18;
    border-radius: 50%;
    z-index: 1;
}
.creative-desc-block {
    background: linear-gradient(120deg, #f8fafc 60%, #e3f0ff 100%);
    border-radius: 1.5rem;
    box-shadow: 0 6px 24px 0 rgba(80, 120, 255, 0.10);
    padding: 2.1rem 2.2rem 1.5rem 2.2rem;
    margin-bottom: 0.5rem;
    min-height: 220px;
    position: relative;
    z-index: 1;
}
.creative-desc-header {
    display: flex;
    align-items: center;
    margin-bottom: 1.1rem;
}
.desc-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.1rem;
    height: 2.1rem;
    background: linear-gradient(135deg, #e0e7ff 60%, #f0f4ff 100%);
    color: #3b4a6b;
    border-radius: 50%;
    font-size: 1.18rem;
    margin-right: 0.8rem;
    box-shadow: 0 2px 8px rgba(80,120,255,0.09);
}
.creative-desc-title {
    font-weight: 600;
    font-size: 1.25rem;
    color: #3b4a6b;
    margin-bottom: 0;
    letter-spacing: 0.01em;
}
.creative-desc-text p {
    color: #4b5a7a;
    font-size: 1.08rem;
    margin-bottom: 0;
    line-height: 1.7;
}
.project-meta-modern {
    background: linear-gradient(120deg, #f8fafc 60%, #e3f0ff 100%);
    border-radius: 1.2rem;
    box-shadow: 0 2px 12px 0 rgba(80, 120, 255, 0.07);
    padding: 1.2rem 1.1rem 1.1rem 1.1rem;
    margin-bottom: 1.2rem;
    min-height: 120px;
    transition: box-shadow 0.2s, transform 0.2s;
}
.project-meta-modern:hover {
    box-shadow: 0 6px 24px 0 rgba(80, 120, 255, 0.13);
    transform: translateY(-2px) scale(1.02);
}
.project-meta-modern h6 {
    font-weight: 700;
    font-size: 1.08rem;
    color: #1245a8;
    margin-bottom: 0.5rem;
}
.project-meta-modern p {
    margin-bottom: 0;
    color: #222;
    font-size: 1.01rem;
}
.creative-meta-row {
    margin-bottom: 1.2rem;
}
.creative-meta-block {
    background: linear-gradient(120deg, #f5faff 60%, #e3f0ff 100%);
    border-radius: 1.5rem;
    box-shadow: 0 6px 24px 0 rgba(80, 120, 255, 0.13);
    padding: 1.3rem 1.1rem 1.1rem 1.1rem;
    min-height: 120px;
    border: 1.5px solid #e6eaff;
    transition: box-shadow 0.22s, transform 0.22s;
    position: relative;
    overflow: hidden;
    text-align: center;
    margin-bottom: 0.5rem;
}
.creative-meta-block:before {
    content: "";
    position: absolute;
    top: -40px;
    right: -40px;
    width: 110px;
    height: 110px;
    background: radial-gradient(circle, #c7d2fe 0%, #e0e7ff 80%, transparent 100%);
    opacity: 0.18;
    z-index: 0;
}
.creative-meta-block:hover {
    box-shadow: 0 12px 36px 0 rgba(80, 120, 255, 0.19);
    transform: translateY(-3px) scale(1.035);
}
.meta-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.2rem;
    height: 2.2rem;
    background: linear-gradient(135deg, #e0e7ff 60%, #f0f4ff 100%);
    color: #3b4a6b;
    border-radius: 50%;
    font-size: 1.25rem;
    margin: 0 auto 0.7rem auto;
    box-shadow: 0 2px 8px rgba(80,120,255,0.09);
    z-index: 1;
    position: relative;
}
.meta-label {
    font-weight: 600;
    font-size: 1.01rem;
    color: #3b4a6b;
    letter-spacing: 0.01em;
    margin-bottom: 0.2rem;
    z-index: 1;
    position: relative;
}
.creative-meta-row > [class^="col-"],
.creative-meta-row > [class*=" col-"] {
    display: flex;
    align-items: stretch;
}
.creative-meta-block {
    height: 100%;
    min-height: 120px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.meta-value {
    font-size: 1.01rem;
    color: #4b5a7a;
    font-weight: 500;
    z-index: 1;
    position: relative;
}
.creative-tags-block {
    background: linear-gradient(120deg, #f5faff 60%, #e3f0ff 100%);
    border-radius: 1.5rem;
    box-shadow: 0 6px 24px 0 rgba(80, 120, 255, 0.13);
    padding: 1.3rem 1.1rem 1.1rem 1.1rem;
    min-height: 120px;
    border: 1.5px solid #e6eaff;
    transition: box-shadow 0.22s, transform 0.22s;
    position: relative;
    overflow: hidden;
    text-align: center;
}
.creative-tags-block:before {
    content: "";
    position: absolute;
    top: -40px;
    right: -40px;
    width: 110px;
    height: 110px;
    background: radial-gradient(circle, #c7d2fe 0%, #e0e7ff 80%, transparent 100%);
    opacity: 0.25;
    z-index: 0;
}
.tags-header {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 0.7rem;
    z-index: 1;
    position: relative;
}
.tags-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.2rem;
    height: 2.2rem;
    background: linear-gradient(135deg, #e0e7ff 60%, #f0f4ff 100%);
    color: #3b4a6b;
    border-radius: 50%;
    font-size: 1.25rem;
    margin-right: 0.7rem;
    box-shadow: 0 2px 8px rgba(80,120,255,0.09);
}
.tags-title {
    font-weight: 600;
    font-size: 1.13rem;
    color: #3b4a6b;
    letter-spacing: 0.02em;
    text-shadow: 0 1px 0 #fff;
}
.tags-list {
    z-index: 1;
    position: relative;
}
.tag-creative {
    display: inline-block;
    background: linear-gradient(90deg, #e0e7ff 0%, #f0f4ff 100%);
    color: #4b5a7a;
    font-weight: 600;
    border-radius: 2em;
    padding: 0.38em 1.2em 0.38em 1.2em;
    margin: 0 0.22em 0.22em 0;
    font-size: 1.01em;
    box-shadow: 0 2px 8px rgba(80,120,255,0.09);
    border: 1.2px solid #dbeafe;
    transition: background 0.18s, color 0.18s, box-shadow 0.18s;
    letter-spacing: 0.01em;
}
.tag-creative:hover {
    background: linear-gradient(90deg, #c7d2fe 0%, #e0e7ff 100%);
    color: #1245a8;
    box-shadow: 0 4px 16px rgba(80,120,255,0.15);
}
.tag-creative.tag-empty {
    background: #f3f4f6;
    color: #b0b4c3;
    border-style: dashed;
    font-style: italic;
    font-weight: 400;
}

.media-tabs-creative .nav-link {
                            background: #f8f9fa;
                            border: none;
                            border-radius: 1.2rem 1.2rem 0 0;
                            margin: 0 2px;
                            padding: 0.7rem 0.3rem 0.3rem 0.3rem;
                            display: flex;
                            flex-direction: column;
                            align-items: center;
                            font-weight: 600;
                            font-size: 0.93rem;
                            color: #495057;
                            box-shadow: 0 2px 8px rgba(0,0,0,0.03);
                            position: relative;
                            transition: all 0.18s;
                        }
                        .media-tabs-creative .nav-link .tab-icon-bg {
                            display: flex;
                            align-items: center;
                            justify-content: center;
                            width: 1.7rem;
                            height: 1.7rem;
                            border-radius: 50%;
                            background: #fff;
                            margin-bottom: 0.2rem;
                            box-shadow: 0 1px 4px rgba(0,0,0,0.06);
                            font-size: 1rem;
                        }
                        .media-tabs-creative .nav-link.active, .media-tabs-creative .nav-link:focus {
                            background: #fff;
                            color: #0d6efd;
                            box-shadow: 0 4px 16px rgba(0,0,0,0.07);
                            z-index: 2;
                        }
                        .media-tabs-creative .nav-link.active .tab-icon-bg {
                            background: #e9f2ff;
                        }
                        .media-tabs-creative .nav-link:not(.active):hover {
                            background: #e9ecef;
                            color: #0d6efd;
                        }
                        .media-tabs-creative .tab-label {
                            font-size: 0.85rem;
                            margin-top: 0.05rem;
                        }
                        @media (max-width: 767px) {
                            .media-tabs-creative .nav-link {
                                font-size: 0.85rem;
                                padding: 0.5rem 0.1rem 0.2rem 0.1rem;
                            }
                            .media-tabs-creative .tab-label {
                                font-size: 0.78rem;
                            }
                            .media-tabs-creative .nav-link .tab-icon-bg {
                                width: 1.2rem;
                                height: 1.2rem;
                                font-size: 0.8rem;
                            }
                        }
