/* ===============================
   RESET & BASE
================================ */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

:root {
    --black: #050505;
    --black-soft: #111111;
    --black-card: #181818;
    --red: #c1121f;
    --red-dark: #8f0d17;
    --gold: #f5b700;
    --white: #f8f8f8;
    --gray: #b5b5b5;
    --gray-dark: #777777;
    --border: rgba(255, 255, 255, 0.1);
    --radius: 22px;
    --transition: 0.3s ease;
}

html {
    scroll-behavior: smooth;
}

body {
    font-family: Arial, Helvetica, sans-serif;
    background: var(--black);
    color: var(--white);
    line-height: 1.6;
}

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

img {
    max-width: 100%;
    display: block;
}

.container {
    width: min(1120px, 92%);
    margin: 0 auto;
}

.section-padding {
    padding: 90px 0;
}

/* ===============================
   HEADER
================================ */
.site-header {
    position: sticky;
    top: 0;
    z-index: 100;
    background: rgba(5, 5, 5, 0.86);
    backdrop-filter: blur(16px);
    border-bottom: 1px solid var(--border);
}

.header-inner {
    height: 76px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
}

.logo,
.footer-logo {
    font-size: 24px;
    font-weight: 800;
    letter-spacing: -1px;
}

.logo span,
.footer-logo span {
    color: var(--gold);
}

.main-nav {
    display: flex;
    align-items: center;
    gap: 26px;
}

.main-nav a {
    color: var(--gray);
    font-size: 15px;
    font-weight: 700;
    letter-spacing: 0.3px;
    transition: var(--transition);
}

.main-nav a:hover {
    color: var(--gold);
}

.header-cta {
    padding: 11px 18px;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--red), var(--gold));
    color: var(--white);
    font-weight: 700;
}

.menu-toggle {
    display: none;
    background: none;
    border: 1px solid var(--border);
    color: var(--white);
    font-size: 24px;
    border-radius: 12px;
    padding: 8px 12px;
    cursor: pointer;
}

/* ===============================
   BUTTONS
================================ */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 14px 22px;
    border-radius: 999px;
    font-weight: 700;
    transition: var(--transition);
    border: 1px solid transparent;
}

.btn-primary {
    background: linear-gradient(135deg, var(--red), var(--gold));
    color: var(--white);
}

.btn-primary:hover {
    transform: translateY(-3px);
    box-shadow: 0 18px 40px rgba(193, 18, 31, 0.3);
}

.btn-outline {
    border-color: var(--border);
    color: var(--white);
}

.btn-outline:hover {
    border-color: var(--gold);
    color: var(--gold);
}

/* ===============================
   HERO
================================ */
.hero {
    min-height: calc(100vh - 76px);
    display: flex;
    align-items: center;
    background:
        radial-gradient(circle at top left, rgba(193, 18, 31, 0.24), transparent 34%),
        radial-gradient(circle at bottom right, rgba(245, 183, 0, 0.16), transparent 30%),
        var(--black);
}

.hero-grid {
    display: grid;
    grid-template-columns: 1.1fr 0.9fr;
    align-items: center;
    gap: 60px;
    padding: 70px 0;
}

.eyebrow {
    color: var(--gold);
    text-transform: uppercase;
    letter-spacing: 2px;
    font-size: 13px;
    font-weight: 800;
    margin-bottom: 14px;
}

.hero h1 {
    font-size: clamp(42px, 6vw, 76px);
    line-height: 1.05;
    letter-spacing: -3px;
    margin-bottom: 24px;
}

.hero-description {
    color: var(--gray);
    font-size: 18px;
    max-width: 620px;
    margin-bottom: 34px;
}

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

.hero-visual {
    position: relative;
    min-height: 460px;
}

.visual-card {
    position: absolute;
    inset: 20px 20px 60px 20px;
    border-radius: 34px;
    background:
        linear-gradient(145deg, rgba(255,255,255,0.08), rgba(255,255,255,0.02)),
        linear-gradient(135deg, rgba(193,18,31,0.25), rgba(245,183,0,0.12));
    border: 1px solid var(--border);
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 34px;
    box-shadow: 0 30px 90px rgba(0,0,0,0.45);
}

.visual-card span {
    color: var(--gold);
    font-weight: 800;
    letter-spacing: 2px;
    margin-bottom: 12px;
}

.visual-card h3 {
    font-size: 34px;
    margin-bottom: 8px;
}

.visual-card p {
    color: var(--gray);
}

.floating-card {
    position: absolute;
    padding: 16px 20px;
    border-radius: 18px;
    background: rgba(17, 17, 17, 0.9);
    border: 1px solid var(--border);
    color: var(--white);
    font-weight: 800;
    box-shadow: 0 20px 60px rgba(0,0,0,0.35);
    animation: float 3s ease-in-out infinite;
}

.card-one {
    top: 40px;
    right: 0;
}

.card-two {
    bottom: 90px;
    left: -20px;
    animation-delay: 1s;
}

@keyframes float {
    0%, 100% {
        transform: translateY(0);
    }

    50% {
        transform: translateY(-14px);
    }
}

/* ===============================
   STATS
================================ */
.stats {
    background: var(--black-soft);
}

.stats-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    overflow: hidden;
}

.stats-grid div {
    padding: 34px;
    border-right: 1px solid var(--border);
}

.stats-grid div:last-child {
    border-right: 0;
}

.stats-grid h3 {
    font-size: 36px;
    color: var(--gold);
}

.stats-grid p {
    color: var(--gray);
}

/* ===============================
   SECTION
================================ */
.section-heading {
    max-width: 680px;
    margin-bottom: 42px;
}

.section-heading h2 {
    font-size: clamp(32px, 4vw, 52px);
    letter-spacing: -2px;
    line-height: 1.12;
    margin-bottom: 14px;
}

.section-heading p {
    color: var(--gray);
}

/* ===============================
   SERVICES
================================ */
.services-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 22px;
}

.service-card {
    padding: 28px;
    border-radius: var(--radius);
    background: var(--black-card);
    border: 1px solid var(--border);
    transition: var(--transition);
}

.service-card:hover {
    transform: translateY(-8px);
    border-color: rgba(245, 183, 0, 0.45);
}

.service-card span {
    color: var(--gold);
    font-weight: 800;
}

.service-card h3 {
    margin: 18px 0 12px;
    font-size: 22px;
}

.service-card p {
    color: var(--gray);
}

/* ===============================
   PROJECTS
================================ */
.dark-section {
    background: var(--black-soft);
}

.projects-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}

.project-card {
    border-radius: var(--radius);
    overflow: hidden;
    background: var(--black-card);
    border: 1px solid var(--border);
    transition: var(--transition);
}

.project-card:hover {
    transform: translateY(-8px);
}

.project-image {
    height: 240px;
    background:
        linear-gradient(135deg, rgba(193,18,31,0.35), rgba(245,183,0,0.12)),
        #222;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.project-one {
    background:
        linear-gradient(135deg, rgba(193,18,31,0.65), rgba(245,183,0,0.25)),
        #222;
}

.project-two {
    background:
        linear-gradient(135deg, rgba(245,183,0,0.48), rgba(193,18,31,0.35)),
        #202020;
}

.project-three {
    background:
        linear-gradient(135deg, rgba(193,18,31,0.35), rgba(245,183,0,0.48)),
        #181818;
}

.project-content {
    padding: 24px;
}

.project-content p {
    color: var(--gold);
    font-weight: 700;
    margin-bottom: 8px;
}

.project-content h3 {
    font-size: 22px;
}

/* ===============================
   PRICING
================================ */
.pricing-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}

.price-card {
    position: relative;
    padding: 32px;
    border-radius: var(--radius);
    background: var(--black-card);
    border: 1px solid var(--border);
}

.price-card.popular {
    border-color: rgba(245, 183, 0, 0.5);
    transform: scale(1.04);
}

.badge {
    display: inline-block;
    margin-bottom: 18px;
    padding: 7px 12px;
    border-radius: 999px;
    background: rgba(245, 183, 0, 0.14);
    color: var(--gold);
    font-size: 13px;
    font-weight: 800;
}

.price-card h3 {
    font-size: 26px;
}

.price {
    color: var(--gold);
    font-size: 28px;
    font-weight: 900;
    margin: 18px 0;
}

.price-card ul {
    list-style: none;
    margin-bottom: 28px;
}

.price-card li {
    color: var(--gray);
    margin-bottom: 10px;
}

.price-card li::before {
    content: "✓";
    color: var(--gold);
    margin-right: 8px;
}

/* ===============================
   CTA
================================ */
.cta-section {
    padding: 60px 0 100px;
}

.cta-box {
    border-radius: 34px;
    padding: 44px;
    background:
        linear-gradient(135deg, rgba(193,18,31,0.35), rgba(245,183,0,0.18)),
        var(--black-card);
    border: 1px solid var(--border);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
}

.cta-box h2 {
    font-size: clamp(30px, 4vw, 48px);
    letter-spacing: -2px;
}

.cta-box p {
    color: var(--gray);
}

/* ===============================
   FOOTER
================================ */
.site-footer {
    background: #030303;
    border-top: 1px solid var(--border);
    padding-top: 70px;
}

.footer-grid {
    display: grid;
    grid-template-columns: 1.4fr 1fr 1fr 1fr;
    gap: 34px;
}

.footer-grid p,
.footer-grid a {
    display: block;
    color: var(--gray);
    margin-top: 10px;
}

.footer-grid a:hover {
    color: var(--gold);
}

.footer-grid h4 {
    margin-bottom: 12px;
}

.footer-bottom {
    margin-top: 50px;
    padding: 24px;
    border-top: 1px solid var(--border);
    text-align: center;
    color: var(--gray-dark);
}

/* ===============================
   RESPONSIVE
================================ */
@media (max-width: 992px) {
    .header-cta {
        display: none;
    }

    .main-nav {
        position: fixed;
        top: 76px;
        left: 0;
        width: 100%;
        background: var(--black-soft);
        flex-direction: column;
        padding: 24px;
        border-bottom: 1px solid var(--border);
        transform: translateY(-140%);
        opacity: 0;
        pointer-events: none;
        transition: var(--transition);
    }

    .main-nav.active {
        transform: translateY(0);
        opacity: 1;
        pointer-events: auto;
    }

    .menu-toggle {
        display: block;
    }

    .hero-grid,
    .footer-grid {
        grid-template-columns: 1fr;
    }

    .hero-visual {
        min-height: 360px;
    }

    .services-grid,
    .projects-grid,
    .pricing-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .stats-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .cta-box {
        flex-direction: column;
        align-items: flex-start;
    }
}

@media (max-width: 640px) {
    .section-padding {
        padding: 64px 0;
    }

    .hero h1 {
        letter-spacing: -2px;
    }

    .services-grid,
    .projects-grid,
    .pricing-grid,
    .stats-grid {
        grid-template-columns: 1fr;
    }

    .stats-grid div {
        border-right: 0;
        border-bottom: 1px solid var(--border);
    }

    .stats-grid div:last-child {
        border-bottom: 0;
    }

    .price-card.popular {
        transform: none;
    }

    .cta-box {
        padding: 30px;
    }

    .visual-card {
        inset: 20px 0;
    }
}
/* ===============================
   AUTH LOGIN PAGE
================================ */
.auth-page {
    min-height: 100vh;
    display: grid;
    place-items: center;
    padding: 24px;
    background:
        radial-gradient(circle at top left, rgba(193, 18, 31, 0.25), transparent 34%),
        radial-gradient(circle at bottom right, rgba(245, 183, 0, 0.18), transparent 30%),
        var(--black);
}

.auth-card {
    width: min(440px, 100%);
    padding: 38px;
    border-radius: 28px;
    background: rgba(17, 17, 17, 0.92);
    border: 1px solid var(--border);
    box-shadow: 0 30px 90px rgba(0, 0, 0, 0.45);
}

.auth-logo {
    display: inline-block;
    margin-bottom: 28px;
}

.auth-card h1 {
    font-size: 34px;
    letter-spacing: -1.5px;
    margin-bottom: 10px;
}

.auth-card p {
    color: var(--gray);
    margin-bottom: 24px;
}

.auth-form {
    display: grid;
    gap: 18px;
}

.form-group {
    display: grid;
    gap: 8px;
}

.form-group label {
    font-weight: 700;
    color: var(--white);
}

.form-group input,
.form-group textarea,
.form-group select {
    width: 100%;
    padding: 14px 16px;
    border-radius: 14px;
    border: 1px solid var(--border);
    background: #0b0b0b;
    color: var(--white);
    outline: none;
    font: inherit;
}

.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus {
    border-color: var(--gold);
}

.full-btn {
    width: 100%;
    margin-top: 8px;
    cursor: pointer;
}

.alert-error {
    padding: 13px 15px;
    border-radius: 14px;
    background: rgba(193, 18, 31, 0.14);
    border: 1px solid rgba(193, 18, 31, 0.4);
    color: #ffb4b4;
    margin-bottom: 18px;
}

.back-home {
    display: inline-block;
    margin-top: 22px;
    color: var(--gray);
}

.back-home:hover {
    color: var(--gold);
}

/* ===============================
   ADMIN DASHBOARD
================================ */
.admin-layout {
    min-height: 100vh;
    display: grid;
    grid-template-columns: 280px 1fr;
    background: var(--black);
}

.admin-sidebar {
    border-right: 1px solid var(--border);
    background: #080808;
    padding: 28px;
}

.admin-logo {
    display: inline-block;
    margin-bottom: 36px;
}

.admin-nav {
    display: grid;
    gap: 10px;
}

.admin-nav a {
    padding: 13px 15px;
    border-radius: 14px;
    color: var(--gray);
    transition: var(--transition);
}

.admin-nav a:hover,
.admin-nav a.active {
    background: rgba(245, 183, 0, 0.12);
    color: var(--gold);
}

.admin-main {
    padding: 36px;
}

.admin-topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    margin-bottom: 32px;
}

.admin-topbar h1 {
    font-size: clamp(30px, 4vw, 48px);
    letter-spacing: -2px;
}

.admin-stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 18px;
    margin-bottom: 28px;
}

.admin-stat-card {
    padding: 24px;
    border-radius: 22px;
    background: var(--black-card);
    border: 1px solid var(--border);
}

.admin-stat-card span {
    color: var(--gold);
    font-weight: 800;
}

.admin-stat-card h2 {
    font-size: 42px;
    margin: 10px 0;
}

.admin-stat-card p {
    color: var(--gray);
}

.admin-panel {
    padding: 30px;
    border-radius: 24px;
    background: var(--black-card);
    border: 1px solid var(--border);
}

.admin-panel h2 {
    font-size: 30px;
    margin-bottom: 10px;
}

.admin-panel p {
    color: var(--gray);
    max-width: 760px;
}

.admin-actions {
    display: flex;
    gap: 14px;
    flex-wrap: wrap;
    margin-top: 24px;
}

@media (max-width: 992px) {
    .admin-layout {
        grid-template-columns: 1fr;
    }

    .admin-sidebar {
        border-right: 0;
        border-bottom: 1px solid var(--border);
    }

    .admin-stats {
        grid-template-columns: repeat(2, 1fr);
    }

    .admin-topbar {
        flex-direction: column;
        align-items: flex-start;
    }
}

@media (max-width: 640px) {
    .admin-stats {
        grid-template-columns: 1fr;
    }

    .admin-main {
        padding: 24px;
    }

    .auth-card {
        padding: 28px;
    }
}
/* ===============================
   ADMIN TABLE & FORM
================================ */
.admin-table-wrapper {
    width: 100%;
    overflow-x: auto;
    margin-top: 24px;
}

.admin-table {
    width: 100%;
    border-collapse: collapse;
    min-width: 900px;
}

.admin-table th,
.admin-table td {
    padding: 16px;
    border-bottom: 1px solid var(--border);
    text-align: left;
    color: var(--gray);
}

.admin-table th {
    color: var(--white);
    background: rgba(255, 255, 255, 0.03);
}

.admin-table tr:hover td {
    background: rgba(255, 255, 255, 0.02);
}

.table-thumb {
    width: 82px;
    height: 52px;
    object-fit: cover;
    border-radius: 10px;
    border: 1px solid var(--border);
}

.no-image {
    font-size: 13px;
    color: var(--gray-dark);
}

.table-link {
    color: var(--gold);
    font-weight: 700;
}

.admin-form {
    display: grid;
    gap: 20px;
    margin-top: 24px;
}

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

.form-group textarea {
    resize: vertical;
    min-height: 130px;
}

.checkbox-row {
    display: flex;
    align-items: center;
    gap: 10px;
    color: var(--gray);
    cursor: pointer;
}

.checkbox-row input {
    width: 18px;
    height: 18px;
    accent-color: var(--gold);
}

.alert-success {
    padding: 13px 15px;
    border-radius: 14px;
    background: rgba(46, 204, 113, 0.14);
    border: 1px solid rgba(46, 204, 113, 0.4);
    color: #a8ffca;
    margin-bottom: 18px;
}

@media (max-width: 768px) {
    .form-grid {
        grid-template-columns: 1fr;
    }
}
.project-client {
    display: block;
    margin-top: 10px;
    color: var(--gray);
    font-size: 14px;
}

.section-actions {
    margin-top: 32px;
}

.empty-state {
    padding: 30px;
    border-radius: var(--radius);
    background: var(--black-card);
    border: 1px solid var(--border);
    color: var(--gray);
}
/* ===============================
   PAGE HERO
================================ */
.page-hero {
    padding: 110px 0 70px;
    background:
        radial-gradient(circle at top left, rgba(193, 18, 31, 0.22), transparent 34%),
        radial-gradient(circle at bottom right, rgba(245, 183, 0, 0.12), transparent 30%),
        var(--black);
    border-bottom: 1px solid var(--border);
}

.page-hero h1 {
    font-size: clamp(42px, 6vw, 76px);
    line-height: 1.05;
    letter-spacing: -3px;
    margin-bottom: 20px;
}

.page-hero p {
    max-width: 720px;
    color: var(--gray);
    font-size: 18px;
}

/* ===============================
   PUBLIC PROJECT PAGE
================================ */
.project-desc {
    color: var(--gray);
    margin-top: 12px;
    font-size: 15px;
}

.project-meta {
    display: grid;
    gap: 6px;
    margin-top: 16px;
    color: var(--gray);
    font-size: 14px;
}

.project-video-link {
    display: inline-block;
    margin-top: 18px;
    color: var(--gold);
    font-weight: 800;
}

.project-video-link:hover {
    color: var(--white);
}
/* ===============================
   EDIT PROJECT
================================ */
.current-image {
    display: grid;
    gap: 10px;
}

.current-image p {
    color: var(--gray);
}

.current-image img {
    width: 260px;
    max-width: 100%;
    height: 150px;
    object-fit: cover;
    border-radius: 16px;
    border: 1px solid var(--border);
}

.delete-form {
    margin-top: 30px;
    padding-top: 24px;
    border-top: 1px solid var(--border);
}

.btn-danger {
    background: rgba(193, 18, 31, 0.15);
    border-color: rgba(193, 18, 31, 0.5);
    color: #ffb4b4;
    cursor: pointer;
}

.btn-danger:hover {
    background: var(--red);
    color: var(--white);
}
/* ===============================
   BLOG PUBLIC PAGE
================================ */
.blog-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}

.blog-card {
    border-radius: var(--radius);
    overflow: hidden;
    background: var(--black-card);
    border: 1px solid var(--border);
    transition: var(--transition);
}

.blog-card:hover {
    transform: translateY(-8px);
    border-color: rgba(245, 183, 0, 0.35);
}

.blog-image {
    height: 230px;
    background:
        linear-gradient(135deg, rgba(193,18,31,0.45), rgba(245,183,0,0.18)),
        #222;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.blog-content {
    padding: 24px;
}

.blog-meta {
    color: var(--gold);
    font-size: 13px;
    font-weight: 800;
    margin-bottom: 12px;
}

.blog-content h2 {
    font-size: 23px;
    line-height: 1.25;
    margin-bottom: 12px;
}

.blog-content h2 a:hover {
    color: var(--gold);
}

.blog-excerpt {
    color: var(--gray);
    margin-bottom: 18px;
}

.read-more {
    color: var(--gold);
    font-weight: 800;
}

.read-more:hover {
    color: var(--white);
}

/* ===============================
   POST DETAIL PAGE
================================ */
.post-hero {
    padding: 110px 0 60px;
    background:
        radial-gradient(circle at top left, rgba(193, 18, 31, 0.22), transparent 34%),
        radial-gradient(circle at bottom right, rgba(245, 183, 0, 0.12), transparent 30%),
        var(--black);
    border-bottom: 1px solid var(--border);
}

.post-hero h1 {
    max-width: 940px;
    font-size: clamp(38px, 5.5vw, 70px);
    line-height: 1.08;
    letter-spacing: -3px;
    margin-bottom: 20px;
}

.post-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    color: var(--gray);
}

.post-container {
    max-width: 900px;
}

.post-thumbnail {
    width: 100%;
    max-height: 520px;
    object-fit: cover;
    border-radius: 28px;
    border: 1px solid var(--border);
    margin-bottom: 36px;
}

.post-excerpt-large {
    font-size: 22px;
    color: var(--gray);
    line-height: 1.7;
    margin-bottom: 34px;
}

.post-content {
    color: #e6e6e6;
    font-size: 18px;
    line-height: 1.9;
}

.post-content p {
    margin-bottom: 18px;
}

.post-back {
    margin-top: 40px;
}

/* ===============================
   BLOG RESPONSIVE
================================ */
@media (max-width: 992px) {
    .blog-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 640px) {
    .blog-grid {
        grid-template-columns: 1fr;
    }

    .post-hero h1 {
        letter-spacing: -2px;
    }

    .post-excerpt-large {
        font-size: 18px;
    }

    .post-content {
        font-size: 16px;
    }
}
/* ===============================
   CONTACT PAGE
================================ */
.contact-grid {
    display: grid;
    grid-template-columns: 0.9fr 1.1fr;
    gap: 36px;
    align-items: start;
}

.contact-info,
.contact-form-card {
    border-radius: 28px;
    background: var(--black-card);
    border: 1px solid var(--border);
    padding: 34px;
}

.contact-info h2,
.contact-form-card h2 {
    font-size: clamp(30px, 4vw, 46px);
    line-height: 1.1;
    letter-spacing: -2px;
    margin-bottom: 14px;
}

.contact-info > p,
.contact-form-card > p {
    color: var(--gray);
    margin-bottom: 28px;
}

.contact-list {
    display: grid;
    gap: 18px;
    margin-top: 28px;
}

.contact-list div {
    padding: 18px;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid var(--border);
}

.contact-list span {
    color: var(--gold);
    font-weight: 800;
}

.contact-list p {
    color: var(--gray);
    margin-top: 6px;
}

.contact-form {
    display: grid;
    gap: 18px;
}

/* ===============================
   BOOKING ADMIN
================================ */
.table-message {
    max-width: 320px;
    line-height: 1.6;
}

.status-badge {
    display: inline-block;
    padding: 7px 11px;
    border-radius: 999px;
    font-size: 13px;
    font-weight: 800;
}

.status-new {
    background: rgba(245, 183, 0, 0.15);
    color: var(--gold);
}

.status-contacted {
    background: rgba(52, 152, 219, 0.15);
    color: #8fd3ff;
}

.status-done {
    background: rgba(46, 204, 113, 0.15);
    color: #a8ffca;
}

.status-cancelled {
    background: rgba(193, 18, 31, 0.15);
    color: #ffb4b4;
}

.status-form {
    display: flex;
    gap: 8px;
    align-items: center;
}

.status-form select {
    min-width: 130px;
    padding: 10px 12px;
    border-radius: 12px;
    border: 1px solid var(--border);
    background: #0b0b0b;
    color: var(--white);
}

.table-small-btn {
    padding: 10px 14px;
    border-radius: 12px;
    border: 0;
    background: var(--gold);
    color: #111;
    font-weight: 800;
    cursor: pointer;
}

.table-small-btn:hover {
    opacity: 0.9;
}

@media (max-width: 992px) {
    .contact-grid {
        grid-template-columns: 1fr;
    }
}
/* ===============================
   ABOUT PAGE
================================ */
.about-grid {
    display: grid;
    grid-template-columns: 1.05fr 0.95fr;
    gap: 40px;
    align-items: center;
}

.about-content h2 {
    font-size: clamp(34px, 4vw, 54px);
    line-height: 1.1;
    letter-spacing: -2px;
    margin-bottom: 22px;
}

.about-content p {
    color: var(--gray);
    margin-bottom: 18px;
    font-size: 17px;
}

.about-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    margin-top: 28px;
}

.about-card {
    min-height: 420px;
    border-radius: 34px;
    padding: 36px;
    background:
        linear-gradient(145deg, rgba(255,255,255,0.08), rgba(255,255,255,0.02)),
        linear-gradient(135deg, rgba(193,18,31,0.32), rgba(245,183,0,0.16));
    border: 1px solid var(--border);
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    box-shadow: 0 30px 90px rgba(0,0,0,0.35);
}

.about-card span {
    color: var(--gold);
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 2px;
    margin-bottom: 12px;
}

.about-card h3 {
    font-size: 38px;
    line-height: 1.1;
    margin-bottom: 12px;
}

.about-card p {
    color: var(--gray);
}

.values-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 22px;
}

.value-card {
    padding: 28px;
    border-radius: var(--radius);
    background: var(--black-card);
    border: 1px solid var(--border);
    transition: var(--transition);
}

.value-card:hover {
    transform: translateY(-8px);
    border-color: rgba(245,183,0,0.35);
}

.value-card span {
    color: var(--gold);
    font-weight: 900;
}

.value-card h3 {
    margin: 16px 0 10px;
    font-size: 22px;
}

.value-card p {
    color: var(--gray);
}

/* ===============================
   SERVICES DETAIL PAGE
================================ */
.services-detail-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
}

.service-detail-card {
    padding: 32px;
    border-radius: 26px;
    background: var(--black-card);
    border: 1px solid var(--border);
    transition: var(--transition);
}

.service-detail-card:hover {
    transform: translateY(-8px);
    border-color: rgba(245,183,0,0.4);
}

.service-detail-card span {
    color: var(--gold);
    font-weight: 900;
}

.service-detail-card h2 {
    font-size: 30px;
    margin: 18px 0 12px;
    letter-spacing: -1px;
}

.service-detail-card p {
    color: var(--gray);
    margin-bottom: 18px;
}

.service-detail-card ul {
    list-style: none;
    display: grid;
    gap: 10px;
}

.service-detail-card li {
    color: var(--gray);
}

.service-detail-card li::before {
    content: "✓";
    color: var(--gold);
    font-weight: 900;
    margin-right: 8px;
}

/* ===============================
   PRICING PAGE
================================ */
.package-desc {
    color: var(--gray);
    margin-bottom: 20px;
}

.process-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 22px;
}

.process-card {
    padding: 28px;
    border-radius: var(--radius);
    background: var(--black-card);
    border: 1px solid var(--border);
}

.process-card span {
    color: var(--gold);
    font-weight: 900;
}

.process-card h3 {
    margin: 16px 0 10px;
    font-size: 22px;
}

.process-card p {
    color: var(--gray);
}

/* ===============================
   RESPONSIVE STATIC PAGES
================================ */
@media (max-width: 992px) {
    .about-grid,
    .services-detail-grid {
        grid-template-columns: 1fr;
    }

    .values-grid,
    .process-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .about-card {
        min-height: 320px;
    }
}

@media (max-width: 640px) {
    .values-grid,
    .process-grid {
        grid-template-columns: 1fr;
    }

    .service-detail-card,
    .value-card,
    .process-card {
        padding: 24px;
    }

    .about-card h3 {
        font-size: 30px;
    }
}
/* ===============================
   ADMIN QUICK ACTIONS
================================ */
.quick-actions {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 18px;
    margin-top: 28px;
}

.quick-action-card {
    display: block;
    padding: 24px;
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid var(--border);
    transition: var(--transition);
}

.quick-action-card:hover {
    transform: translateY(-6px);
    border-color: rgba(245, 183, 0, 0.4);
    background: rgba(245, 183, 0, 0.08);
}

.quick-action-card span {
    display: inline-flex;
    width: 38px;
    height: 38px;
    align-items: center;
    justify-content: center;
    border-radius: 12px;
    background: rgba(245, 183, 0, 0.14);
    color: var(--gold);
    font-weight: 900;
    margin-bottom: 16px;
}

.quick-action-card h3 {
    font-size: 20px;
    margin-bottom: 8px;
}

.quick-action-card p {
    color: var(--gray);
    font-size: 14px;
}

@media (max-width: 992px) {
    .quick-actions {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 640px) {
    .quick-actions {
        grid-template-columns: 1fr;
    }
}
/* ===============================
   FIX PARTNER LOGO MARQUEE
================================ */

/* Khu vực đối tác có khoảng cách đẹp hơn, không sát mép web */
.partners-section {
    overflow: hidden;
    padding: 80px 0;
}

/* Khung chạy logo */
.partners-marquee {
    width: 100%;
    overflow: hidden;
    position: relative;
    padding: 12px 0;
}

/* Làm mờ nhẹ 2 mép cho đẹp */
.partners-marquee::before,
.partners-marquee::after {
    content: "";
    position: absolute;
    top: 0;
    width: 120px;
    height: 100%;
    z-index: 2;
    pointer-events: none;
}

.partners-marquee::before {
    left: 0;
    background: linear-gradient(to right, var(--black), transparent);
}

.partners-marquee::after {
    right: 0;
    background: linear-gradient(to left, var(--black), transparent);
}

/* Track chạy từ phải sang trái nhưng vẫn có logo xuất hiện ngay từ đầu */
.partners-track {
    display: flex;
    align-items: center;
    gap: 28px;
    width: max-content;
    animation: partnersSlide 28s linear infinite;
    padding-left: 0;
}

/* Dừng khi hover vào khu đối tác */
.partners-marquee:hover .partners-track {
    animation-play-state: paused;
}

/* Card logo đối tác */
.partner-card {
    flex: 0 0 auto;
    width: 210px;
    height: 96px;
    border-radius: 24px;
    padding: 22px 28px;
    background: rgba(255, 255, 255, 0.035);
    border: 1px solid rgba(255, 255, 255, 0.12);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: 0.35s ease;
    position: relative;
    overflow: hidden;
}

/* Viền gradient đỏ vàng khi hover */
.partner-card::before {
    content: "";
    position: absolute;
    inset: 0;
    padding: 1.5px;
    border-radius: inherit;
    background: linear-gradient(135deg, var(--red), var(--gold));
    opacity: 0;
    transition: 0.35s ease;

    -webkit-mask:
        linear-gradient(#fff 0 0) content-box,
        linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
}

.partner-card:hover::before {
    opacity: 1;
}

/* Hiệu ứng nổi nhẹ khi hover */
.partner-card:hover {
    transform: translateY(-6px);
    background: rgba(255, 255, 255, 0.06);
    box-shadow: 0 18px 50px rgba(193, 18, 31, 0.18);
}

/* Logo đối tác hiển thị màu ngay từ đầu */
.partner-card img,
.partner-logo {
    max-width: 100%;
    max-height: 54px;
    width: auto;
    height: auto;
    object-fit: contain;

    filter: none !important;
    grayscale: 0 !important;
    opacity: 1 !important;
    mix-blend-mode: normal !important;

    transition: 0.35s ease;
}

/* Hover logo sáng hơn nhẹ, không đổi sang đen trắng */
.partner-card:hover img,
.partner-card:hover .partner-logo {
    filter: none !important;
    opacity: 1 !important;
    transform: scale(1.04);
}

/* Animation chạy ngang */
@keyframes partnersSlide {
    from {
        transform: translateX(0);
    }

    to {
        transform: translateX(-50%);
    }
}

/* Responsive */
@media (max-width: 768px) {
    .partner-card {
        width: 170px;
        height: 82px;
        padding: 18px 22px;
    }

    .partner-card img,
    .partner-logo {
        max-height: 44px;
    }

    .partners-track {
        gap: 18px;
        animation-duration: 22s;
    }

    .partners-marquee::before,
    .partners-marquee::after {
        width: 60px;
    }
}
/* =====================================================
   FINAL FIX - PARTNERS MARQUEE / LOGO COLOR / HOVER BORDER
   Ghi đè toàn bộ CSS cũ của phần đối tác
===================================================== */
.partners-section,
section.partners-section {
    overflow: hidden !important;
    padding: 90px 0 !important;
    background: var(--black-soft) !important;
}

.partners-section .section-heading {
    text-align: center !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

.partners-marquee {
    width: min(1120px, 92vw) !important;
    max-width: 1120px !important;
    margin: 34px auto 0 !important;
    overflow: hidden !important;
    position: relative !important;
    padding: 14px 0 !important;
}

.partners-marquee::before,
.partners-marquee::after {
    content: "" !important;
    position: absolute !important;
    top: 0 !important;
    width: 70px !important;
    height: 100% !important;
    z-index: 5 !important;
    pointer-events: none !important;
}

.partners-marquee::before {
    left: 0 !important;
    background: linear-gradient(to right, var(--black-soft) 0%, rgba(17,17,17,0.85) 25%, transparent 100%) !important;
}

.partners-marquee::after {
    right: 0 !important;
    background: linear-gradient(to left, var(--black-soft) 0%, rgba(17,17,17,0.85) 25%, transparent 100%) !important;
}

.partners-track {
    display: flex !important;
    align-items: center !important;
    gap: 28px !important;
    width: max-content !important;
    padding-left: 90px !important;
    padding-right: 90px !important;
    animation: partnersSlideFinal 32s linear infinite !important;
    will-change: transform !important;
}

.partners-marquee:hover .partners-track {
    animation-play-state: paused !important;
}

.partner-card,
.partner-item,
.partner-logo-card,
.partners-item,
.partners-card {
    flex: 0 0 auto !important;
    width: 220px !important;
    height: 100px !important;
    padding: 22px 28px !important;
    border-radius: 24px !important;
    background: rgba(255, 255, 255, 0.045) !important;
    border: 1px solid rgba(255, 255, 255, 0.12) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    position: relative !important;
    overflow: hidden !important;
    opacity: 1 !important;
    filter: none !important;
    -webkit-filter: none !important;
    transition: transform .35s ease, background .35s ease, box-shadow .35s ease, border-color .35s ease !important;
}

.partner-card::after,
.partner-item::after,
.partner-logo-card::after,
.partners-item::after,
.partners-card::after {
    display: none !important;
    content: none !important;
}

.partner-card::before,
.partner-item::before,
.partner-logo-card::before,
.partners-item::before,
.partners-card::before {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    padding: 2px !important;
    border-radius: inherit !important;
    background: linear-gradient(135deg, var(--red), var(--gold)) !important;
    opacity: 0 !important;
    transition: opacity .35s ease !important;
    pointer-events: none !important;
    z-index: 1 !important;
    -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0) !important;
    -webkit-mask-composite: xor !important;
    mask-composite: exclude !important;
}

.partner-card:hover,
.partner-item:hover,
.partner-logo-card:hover,
.partners-item:hover,
.partners-card:hover {
    transform: translateY(-6px) !important;
    background: rgba(255, 255, 255, 0.075) !important;
    border-color: transparent !important;
    box-shadow: 0 18px 50px rgba(193, 18, 31, 0.18) !important;
}

.partner-card:hover::before,
.partner-item:hover::before,
.partner-logo-card:hover::before,
.partners-item:hover::before,
.partners-card:hover::before {
    opacity: 1 !important;
}

.partner-card img,
.partner-item img,
.partner-logo-card img,
.partners-item img,
.partners-card img,
.partner-logo,
[class*="partner"] img,
[class*="Partner"] img {
    position: relative !important;
    z-index: 2 !important;
    max-width: 100% !important;
    max-height: 58px !important;
    width: auto !important;
    height: auto !important;
    object-fit: contain !important;
    opacity: 1 !important;
    filter: none !important;
    -webkit-filter: none !important;
    mix-blend-mode: normal !important;
    transform: none !important;
    transition: transform .35s ease !important;
}

.partner-card:hover img,
.partner-item:hover img,
.partner-logo-card:hover img,
.partners-item:hover img,
.partners-card:hover img,
[class*="partner"]:hover img {
    opacity: 1 !important;
    filter: none !important;
    -webkit-filter: none !important;
    mix-blend-mode: normal !important;
    transform: scale(1.04) !important;
}

@keyframes partnersSlideFinal {
    0% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(-50%);
    }
}

@media (max-width: 768px) {
    .partners-marquee {
        width: 92vw !important;
        margin-top: 24px !important;
    }

    .partners-track {
        gap: 18px !important;
        padding-left: 46px !important;
        padding-right: 46px !important;
        animation-duration: 24s !important;
    }

    .partner-card,
    .partner-item,
    .partner-logo-card,
    .partners-item,
    .partners-card {
        width: 170px !important;
        height: 82px !important;
        padding: 18px 22px !important;
        border-radius: 18px !important;
    }

    .partner-card img,
    .partner-item img,
    .partner-logo-card img,
    .partners-item img,
    .partners-card img,
    .partner-logo,
    [class*="partner"] img,
    [class*="Partner"] img {
        max-height: 44px !important;
    }

    .partners-marquee::before,
    .partners-marquee::after {
        width: 42px !important;
    }
}


/* =====================================================
   FINAL FIX - FONT RENDERING / BOLD TEXT
   Sửa lỗi chữ in đậm bị viền, bị nhòe, bị tách màu
===================================================== */

/* Tối ưu render chữ toàn website */
html,
body {
    -webkit-font-smoothing: antialiased !important;
    -moz-osx-font-smoothing: grayscale !important;
    text-rendering: geometricPrecision !important;
}

/* Tuyệt đối không dùng stroke/shadow giả đậm cho chữ */
body,
body * {
    -webkit-text-stroke: 0 !important;
    text-shadow: none !important;
}

/* Font hệ thống mượt và ổn định hơn Arial khi dùng tiếng Việt */
body,
button,
input,
textarea,
select {
    font-family: "Segoe UI", Arial, Helvetica, sans-serif !important;
}

/* Heading đậm vừa đủ, không bị vỡ nét */
h1, h2, h3, h4, h5, h6,
.hero h1,
.section-heading h2,
.price-card h3,
.price,
.blog-content h2,
.project-content h3,
.service-card h3,
.about-content h2,
.cta-box h2,
.post-hero h1,
.page-hero h1,
.admin-topbar h1,
.admin-panel h2 {
    font-family: "Segoe UI", Arial, Helvetica, sans-serif !important;
    font-weight: 750 !important;
    -webkit-text-stroke: 0 !important;
    text-shadow: none !important;
}

/* Các chữ cần nhấn mạnh vẫn đậm nhưng không quá gắt */
.btn,
.header-cta,
.main-nav a,
.badge,
.eyebrow,
.price-card li::before,
.service-card span,
.admin-nav a,
.table-link {
    font-family: "Segoe UI", Arial, Helvetica, sans-serif !important;
    font-weight: 700 !important;
    -webkit-text-stroke: 0 !important;
    text-shadow: none !important;
}

/* Menu header: đậm, gọn, không lỗi font */
.site-header .main-nav a {
    font-size: 15px !important;
    font-weight: 700 !important;
    color: #ffffff !important;
    letter-spacing: 0.15px !important;
    line-height: 1.2 !important;
    white-space: nowrap !important;
    -webkit-text-stroke: 0 !important;
    text-shadow: none !important;
}

.site-header .main-nav a:hover {
    color: var(--gold) !important;
    -webkit-text-stroke: 0 !important;
    text-shadow: none !important;
}

/* Giá tiền dùng 800 là đủ, tránh font bị bể */
.price {
    font-weight: 800 !important;
}

/* Nếu trình duyệt không hỗ trợ weight 750 thì tự rơi về 700 */
@supports not (font-variation-settings: normal) {
    h1, h2, h3, h4, h5, h6,
    .hero h1,
    .section-heading h2,
    .price-card h3,
    .blog-content h2,
    .project-content h3 {
        font-weight: 700 !important;
    }
}
/* =====================================================
   FINAL MOBILE FIX
===================================================== */

/* Footer logo */
.footer-logo-img {
    max-width: 150px;
    max-height: 58px;
    width: auto;
    height: auto;
    object-fit: contain;
}

/* Mobile header */
@media (max-width: 768px) {
    .site-header {
        position: sticky;
        top: 0;
        z-index: 9999;
    }

    .header-inner,
    .site-header .header-inner {
        height: 92px !important;
        padding: 0 4px;
        gap: 16px !important;
    }

    .site-logo-img {
        max-width: 160px !important;
        max-height: 64px !important;
        width: auto !important;
        height: auto !important;
    }

    .menu-toggle {
        display: inline-flex !important;
        align-items: center;
        justify-content: center;
        width: 54px;
        height: 54px;
        border-radius: 18px;
        font-size: 30px;
        line-height: 1;
        z-index: 10001;
    }

    .main-nav,
    .site-header .main-nav {
        position: fixed !important;
        top: 92px !important;
        left: 0 !important;
        width: 100% !important;
        background: rgba(5, 5, 5, 0.98) !important;
        backdrop-filter: blur(18px);
        flex-direction: column !important;
        align-items: flex-start !important;
        justify-content: flex-start !important;
        gap: 0 !important;
        padding: 18px 24px 24px !important;
        border-bottom: 1px solid var(--border);
        transform: translateY(-130%) !important;
        opacity: 0 !important;
        pointer-events: none !important;
        transition: 0.3s ease !important;
        z-index: 10000 !important;
    }

    .main-nav.active,
    .site-header .main-nav.active {
        transform: translateY(0) !important;
        opacity: 1 !important;
        pointer-events: auto !important;
    }

    .main-nav a,
    .site-header .main-nav a {
        width: 100%;
        padding: 15px 0;
        font-size: 18px !important;
        font-weight: 700 !important;
        border-bottom: 1px solid rgba(255,255,255,0.08);
    }

    .header-cta {
        display: none !important;
    }
}

/* Mobile hero layout */
@media (max-width: 768px) {
    .hero {
        min-height: auto !important;
        padding: 40px 0 70px;
        align-items: flex-start;
    }

    .hero-grid {
        display: grid;
        grid-template-columns: 1fr !important;
        gap: 42px;
        padding: 36px 0 20px;
    }

    .hero-content {
        position: relative;
        z-index: 2;
    }

    .hero h1 {
        font-size: clamp(38px, 12vw, 56px);
        line-height: 1.08;
        letter-spacing: -2px;
        margin-bottom: 20px;
    }

    .hero-description {
        font-size: 17px;
        line-height: 1.7;
        margin-bottom: 28px;
    }

    .hero-actions {
        gap: 14px;
    }

    .hero-actions .btn {
        padding: 14px 22px;
        font-size: 16px;
    }

    .hero-visual {
        min-height: auto !important;
        position: relative;
        padding: 0;
    }

    .visual-card {
        position: relative !important;
        inset: auto !important;
        min-height: 330px;
        padding: 30px;
        border-radius: 30px;
    }

    .visual-card h3 {
        font-size: 42px;
        line-height: 1.1;
        letter-spacing: -1px;
        margin-bottom: 14px;
    }

    .visual-card p {
        font-size: 17px;
    }

    .floating-card {
        font-size: 16px;
        padding: 13px 16px;
        border-radius: 16px;
    }

    .card-one {
        top: 34px !important;
        right: 0 !important;
    }

    .card-two {
        left: -20px !important;
        bottom: 110px !important;
    }
}

@media (max-width: 420px) {
    .hero-actions {
        flex-direction: row;
    }

    .hero-actions .btn {
        flex: 1;
        min-width: 0;
        text-align: center;
        padding-left: 14px;
        padding-right: 14px;
    }

    .visual-card h3 {
        font-size: 38px;
    }

    .card-two {
        left: -28px !important;
    }
}

/* Mobile sections */
@media (max-width: 768px) {
    .section-padding {
        padding: 70px 0;
    }

    .section-heading h2,
    .cta-box h2 {
        font-size: clamp(34px, 10vw, 48px);
        letter-spacing: -1.5px;
    }

    .projects-grid,
    .pricing-grid,
    .blog-grid,
    .services-grid {
        grid-template-columns: 1fr !important;
    }

    .price-card.popular {
        transform: none !important;
    }

    .cta-box {
        padding: 30px;
        border-radius: 28px;
    }
}
/* =====================================================
   FIX MOBILE HERO VISUAL CARD
   Sửa lỗi card Cinematic Production bị tràn/che chữ
===================================================== */
@media (max-width: 768px) {
    .hero-visual {
        width: 100%;
        min-height: auto !important;
        margin-top: 10px;
        overflow: visible;
    }

    .visual-card {
        position: relative !important;
        inset: auto !important;
        width: 100% !important;
        min-height: 300px !important;
        padding: 34px 26px 30px !important;
        border-radius: 28px !important;
        overflow: hidden !important;
    }

    .visual-card span {
        font-size: 13px !important;
        letter-spacing: 2px !important;
        margin-bottom: 16px !important;
    }

    .visual-card h3 {
        font-size: clamp(34px, 10vw, 44px) !important;
        line-height: 1.08 !important;
        letter-spacing: -1.5px !important;
        max-width: 100% !important;
        margin-bottom: 14px !important;
        word-break: normal !important;
        overflow-wrap: break-word !important;
    }

    .visual-card p {
        font-size: 16px !important;
        line-height: 1.5 !important;
        max-width: 100% !important;
    }

    .floating-card {
        font-size: 14px !important;
        padding: 11px 14px !important;
        border-radius: 14px !important;
        z-index: 3 !important;
    }

    .card-one {
        top: 22px !important;
        right: 18px !important;
    }

    .card-two {
        left: 18px !important;
        bottom: 22px !important;
    }
}

@media (max-width: 430px) {
    .visual-card {
        min-height: 285px !important;
        padding: 32px 24px 28px !important;
    }

    .visual-card h3 {
        font-size: clamp(32px, 9.6vw, 40px) !important;
        line-height: 1.08 !important;
    }

    .visual-card p {
        font-size: 15px !important;
        padding-right: 0 !important;
    }

    .card-one {
        top: 18px !important;
        right: 16px !important;
    }

    .card-two {
        left: 16px !important;
        bottom: 18px !important;
    }
}

@media (max-width: 390px) {
    .visual-card {
        min-height: 270px !important;
    }

    .visual-card h3 {
        font-size: 34px !important;
    }

    .floating-card {
        font-size: 13px !important;
    }
}

/* =====================================================
   HERO MOBILE FINAL FIX - NO OVERLAY
   Cách xử lý mới: đưa 2 floating badge ra khỏi card trên mobile
   để không che chữ "Cinematic Production".
===================================================== */
@media (max-width: 768px) {
    .hero {
        min-height: auto !important;
        padding: 34px 0 64px !important;
        align-items: flex-start !important;
    }

    .hero-grid {
        grid-template-columns: 1fr !important;
        gap: 36px !important;
        padding: 30px 0 0 !important;
    }

    .hero-visual {
        width: 100% !important;
        min-height: auto !important;
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 12px !important;
        position: relative !important;
        overflow: visible !important;
        margin-top: 4px !important;
    }

    .hero-visual .visual-card {
        order: 2 !important;
        position: relative !important;
        inset: auto !important;
        width: 100% !important;
        min-height: 300px !important;
        padding: 34px 26px 32px !important;
        border-radius: 28px !important;
        overflow: hidden !important;
        display: flex !important;
        flex-direction: column !important;
        justify-content: flex-end !important;
    }

    .hero-visual .visual-card span {
        font-size: 13px !important;
        line-height: 1.2 !important;
        letter-spacing: 2px !important;
        margin-bottom: 14px !important;
    }

    .hero-visual .visual-card h3 {
        font-size: clamp(34px, 9.5vw, 42px) !important;
        line-height: 1.08 !important;
        letter-spacing: -1.4px !important;
        margin-bottom: 14px !important;
        max-width: 100% !important;
        overflow-wrap: break-word !important;
        word-break: normal !important;
    }

    .hero-visual .visual-card p {
        font-size: 16px !important;
        line-height: 1.5 !important;
        max-width: 100% !important;
    }

    .hero-visual .floating-card {
        position: static !important;
        inset: auto !important;
        transform: none !important;
        animation: none !important;
        width: fit-content !important;
        max-width: 100% !important;
        font-size: 14px !important;
        line-height: 1 !important;
        padding: 12px 15px !important;
        border-radius: 15px !important;
        z-index: 1 !important;
    }

    .hero-visual .card-one {
        order: 1 !important;
        justify-self: end !important;
        margin-right: 8px !important;
    }

    .hero-visual .card-two {
        order: 3 !important;
        justify-self: start !important;
        margin-left: 8px !important;
        margin-top: -4px !important;
    }
}

@media (max-width: 430px) {
    .hero-visual .visual-card {
        min-height: 285px !important;
        padding: 32px 24px 30px !important;
    }

    .hero-visual .visual-card h3 {
        font-size: clamp(32px, 9.2vw, 38px) !important;
        line-height: 1.08 !important;
    }

    .hero-visual .visual-card p {
        font-size: 15px !important;
    }
}

@media (max-width: 390px) {
    .hero-visual .visual-card {
        min-height: 270px !important;
        padding: 30px 22px 28px !important;
    }

    .hero-visual .visual-card h3 {
        font-size: 33px !important;
    }

    .hero-visual .floating-card {
        font-size: 13px !important;
        padding: 11px 14px !important;
    }
}
/* =====================================================
   RESTORE MOBILE FLOATING ANIMATION
   Khôi phục hiệu ứng trồi lên trồi xuống cho 4K Video / Live Event
===================================================== */
@media (max-width: 768px) {
    .hero-visual .floating-card {
        animation: mobileFloat 3.2s ease-in-out infinite !important;
        will-change: transform !important;
    }

    .hero-visual .card-one {
        animation-delay: 0s !important;
    }

    .hero-visual .card-two {
        animation-delay: 1.1s !important;
    }
}

@keyframes mobileFloat {
    0%, 100% {
        transform: translateY(0);
    }

    50% {
        transform: translateY(-10px);
    }
}
/* =====================================================
   FORCE RESTORE MOBILE FLOAT ANIMATION
   Không dùng transform để tránh bị CSS khác ghi đè
===================================================== */
@media (max-width: 768px) {
    .hero-visual .floating-card,
    .hero-visual .card-one,
    .hero-visual .card-two {
        animation-name: mobileFloatSafe !important;
        animation-duration: 3s !important;
        animation-timing-function: ease-in-out !important;
        animation-iteration-count: infinite !important;
        animation-play-state: running !important;
        will-change: margin-top, translate !important;
    }

    .hero-visual .card-one {
        animation-delay: 0s !important;
    }

    .hero-visual .card-two {
        animation-delay: 1.1s !important;
    }
}

@keyframes mobileFloatSafe {
    0% {
        margin-top: 0;
        translate: 0 0;
    }

    50% {
        margin-top: -10px;
        translate: 0 -10px;
    }

    100% {
        margin-top: 0;
        translate: 0 0;
    }
}
/* =====================================================
   FIX CTA DESKTOP BUTTON
   Sửa lỗi nút Đặt lịch tư vấn bị xuống dòng trên desktop
===================================================== */
@media (min-width: 769px) {
    .cta-box {
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) auto !important;
        align-items: center !important;
        gap: 40px !important;
    }

    .cta-box > div {
        min-width: 0 !important;
        max-width: 760px !important;
    }

    .cta-box .btn,
    .cta-box .btn-primary,
    .cta-box a.btn {
        min-width: 190px !important;
        width: auto !important;
        white-space: nowrap !important;
        flex-shrink: 0 !important;
        padding-left: 26px !important;
        padding-right: 26px !important;
    }
}
/* =====================================================
   FINAL FIX CTA SECTION DESKTOP + FONT RENDER
   Sửa nút CTA bị xuống dòng và chữ đậm bị lỗi
===================================================== */

/* Reset lại cách render chữ để tránh lỗi viền/nhòe tiếng Việt */
html,
body,
body * {
    -webkit-text-stroke: 0 !important;
    text-shadow: none !important;
    text-rendering: auto !important;
}

body,
button,
input,
textarea,
select {
    font-family: Arial, Helvetica, sans-serif !important;
}

/* Riêng CTA cuối trang */
.cta-section .cta-box {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) max-content !important;
    align-items: center !important;
    gap: 48px !important;
}

/* Khối chữ bên trái */
.cta-section .cta-box > div {
    min-width: 0 !important;
    max-width: 820px !important;
}

/* Tiêu đề CTA: đậm vừa đủ, không bị lỗi font */
.cta-section .cta-box h2 {
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: clamp(34px, 4vw, 56px) !important;
    font-weight: 700 !important;
    line-height: 1.15 !important;
    letter-spacing: -1.5px !important;
    text-shadow: none !important;
    -webkit-text-stroke: 0 !important;
}

/* Nút bên phải: không cho xuống dòng */
.cta-section .cta-box > a.btn,
.cta-section .cta-box > a.btn-primary {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: auto !important;
    min-width: 210px !important;
    max-width: none !important;
    height: 68px !important;
    padding: 0 34px !important;
    white-space: nowrap !important;
    word-break: keep-all !important;
    overflow-wrap: normal !important;
    flex-shrink: 0 !important;
    font-size: 17px !important;
    font-weight: 800 !important;
    line-height: 1 !important;
}

/* Tablet */
@media (max-width: 992px) {
    .cta-section .cta-box {
        grid-template-columns: 1fr !important;
        gap: 28px !important;
    }

    .cta-section .cta-box > a.btn,
    .cta-section .cta-box > a.btn-primary {
        width: fit-content !important;
        min-width: 210px !important;
    }
}

/* Mobile */
@media (max-width: 640px) {
    .cta-section .cta-box {
        padding: 30px !important;
        border-radius: 28px !important;
    }

    .cta-section .cta-box h2 {
        font-size: 34px !important;
        line-height: 1.18 !important;
        letter-spacing: -1px !important;
    }

    .cta-section .cta-box > a.btn,
    .cta-section .cta-box > a.btn-primary {
        width: 100% !important;
        min-width: 0 !important;
        height: 60px !important;
    }
}

/* =====================================================
   ULTIMATE FIX - CTA + FONT RENDERING
   Đặt cuối file để ghi đè toàn bộ các block cũ phía trên
===================================================== */

/* Font render sạch hơn cho tiếng Việt */
html,
body {
    -webkit-font-smoothing: antialiased !important;
    -moz-osx-font-smoothing: grayscale !important;
    text-rendering: auto !important;
}

body,
button,
input,
textarea,
select {
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif !important;
}

/* Xóa mọi hiệu ứng làm chữ bị viền / nhòe */
body * {
    -webkit-text-stroke-width: 0 !important;
    -webkit-text-stroke-color: transparent !important;
    text-shadow: none !important;
}

/* Giảm độ đậm heading toàn site để không bị bể nét */
h1, h2, h3, h4, h5, h6,
.hero h1,
.section-heading h2,
.price-card h3,
.blog-content h2,
.project-content h3,
.service-card h3,
.about-content h2,
.cta-box h2,
.post-hero h1,
.page-hero h1 {
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif !important;
    font-weight: 650 !important;
    text-shadow: none !important;
    -webkit-text-stroke: 0 transparent !important;
}

/* Riêng CTA cuối trang desktop */
@media (min-width: 993px) {
    .cta-section {
        padding: 70px 0 110px !important;
    }

    .cta-section .container.cta-box,
    .cta-section .cta-box {
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) 240px !important;
        column-gap: 42px !important;
        row-gap: 0 !important;
        align-items: center !important;
        justify-content: stretch !important;
        padding: 44px 44px !important;
        overflow: visible !important;
    }

    .cta-section .cta-box > div {
        min-width: 0 !important;
        max-width: none !important;
        width: 100% !important;
    }

    .cta-section .cta-box .eyebrow {
        font-weight: 700 !important;
        letter-spacing: 2.5px !important;
    }

    .cta-section .cta-box h2 {
        font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif !important;
        font-size: clamp(36px, 3.45vw, 50px) !important;
        font-weight: 650 !important;
        line-height: 1.16 !important;
        letter-spacing: -1.2px !important;
        max-width: 760px !important;
        margin-bottom: 12px !important;
        text-shadow: none !important;
        -webkit-text-stroke: 0 transparent !important;
        color: #fff !important;
    }

    .cta-section .cta-box p {
        max-width: 680px !important;
    }

    .cta-section .cta-box > a.btn,
    .cta-section .cta-box > a.btn-primary,
    .cta-section .cta-box a[href*="contact"] {
        justify-self: end !important;
        align-self: center !important;
        display: flex !important;
        width: 240px !important;
        min-width: 240px !important;
        max-width: 240px !important;
        height: 68px !important;
        padding: 0 24px !important;
        align-items: center !important;
        justify-content: center !important;
        text-align: center !important;
        white-space: nowrap !important;
        word-break: normal !important;
        overflow-wrap: normal !important;
        line-height: 1 !important;
        font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif !important;
        font-size: 17px !important;
        font-weight: 700 !important;
        border-radius: 999px !important;
        flex: none !important;
        text-shadow: none !important;
        -webkit-text-stroke: 0 transparent !important;
    }
}

/* Tablet: CTA xuống dòng đẹp */
@media (max-width: 992px) {
    .cta-section .container.cta-box,
    .cta-section .cta-box {
        display: flex !important;
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 28px !important;
    }

    .cta-section .cta-box h2 {
        font-weight: 650 !important;
        line-height: 1.16 !important;
    }

    .cta-section .cta-box > a.btn,
    .cta-section .cta-box > a.btn-primary,
    .cta-section .cta-box a[href*="contact"] {
        width: auto !important;
        min-width: 220px !important;
        white-space: nowrap !important;
        line-height: 1 !important;
    }
}

/* Mobile */
@media (max-width: 640px) {
    .cta-section .cta-box {
        padding: 30px !important;
    }

    .cta-section .cta-box h2 {
        font-size: 34px !important;
        font-weight: 650 !important;
        letter-spacing: -1px !important;
    }

    .cta-section .cta-box > a.btn,
    .cta-section .cta-box > a.btn-primary,
    .cta-section .cta-box a[href*="contact"] {
        width: 100% !important;
        min-width: 0 !important;
        height: 60px !important;
    }
}
/* =====================================================
   STATS COUNT-UP EFFECT
===================================================== */
.stat-item {
    position: relative;
    overflow: hidden;
}

.stat-item::before {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at top left, rgba(245, 183, 0, 0.12), transparent 42%);
    opacity: 0;
    transition: 0.4s ease;
    pointer-events: none;
}

.stat-item:hover::before {
    opacity: 1;
}

.stat-number {
    display: inline-block;
    min-width: 72px;
    color: var(--gold);
    font-variant-numeric: tabular-nums;
    letter-spacing: -1px;
}

.stats-grid div {
    transition: 0.35s ease;
}

.stats-grid div:hover {
    background: rgba(255, 255, 255, 0.025);
}

@media (max-width: 768px) {
    .stat-number {
        min-width: auto;
    }
}
/* =====================================================
   PROJECT DETAIL PAGE
===================================================== */
.project-detail-hero {
    padding: 110px 0 80px;
    background:
        radial-gradient(circle at top left, rgba(193, 18, 31, 0.22), transparent 34%),
        radial-gradient(circle at bottom right, rgba(245, 183, 0, 0.14), transparent 30%),
        var(--black);
    border-bottom: 1px solid var(--border);
}

.project-detail-grid {
    display: grid;
    grid-template-columns: 0.95fr 1.05fr;
    gap: 46px;
    align-items: center;
}

.project-detail-content h1 {
    font-size: clamp(42px, 5vw, 72px);
    line-height: 1.05;
    letter-spacing: -3px;
    margin-bottom: 20px;
}

.project-detail-client {
    color: var(--gray);
    font-size: 17px;
    margin-bottom: 20px;
}

.project-detail-client strong {
    color: var(--gold);
}

.project-detail-desc {
    color: var(--gray);
    font-size: 17px;
    line-height: 1.8;
    max-width: 680px;
    margin-bottom: 30px;
}

.project-detail-actions {
    display: flex;
    gap: 14px;
    flex-wrap: wrap;
}

.project-detail-media {
    border-radius: 34px;
    overflow: hidden;
    border: 1px solid var(--border);
    background: var(--black-card);
    box-shadow: 0 30px 90px rgba(0, 0, 0, 0.4);
}

.project-detail-media img {
    width: 100%;
    height: 460px;
    object-fit: cover;
}

.project-detail-placeholder {
    height: 460px;
    display: grid;
    place-items: center;
    color: var(--gold);
    font-size: 28px;
    font-weight: 900;
    letter-spacing: -1px;
    background:
        linear-gradient(135deg, rgba(193,18,31,0.35), rgba(245,183,0,0.12)),
        var(--black-card);
}

.project-case-box {
    max-width: 1120px;
}

.case-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 22px;
}

.case-card {
    padding: 28px;
    border-radius: 24px;
    background: var(--black-card);
    border: 1px solid var(--border);
    transition: 0.3s ease;
}

.case-card:hover {
    transform: translateY(-8px);
    border-color: rgba(245, 183, 0, 0.35);
}

.case-card span {
    color: var(--gold);
    font-weight: 900;
}

.case-card h3 {
    margin: 16px 0 10px;
    font-size: 22px;
}

.case-card p {
    color: var(--gray);
}

@media (max-width: 992px) {
    .project-detail-grid {
        grid-template-columns: 1fr;
    }

    .project-detail-media img,
    .project-detail-placeholder {
        height: 360px;
    }

    .case-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 640px) {
    .project-detail-hero {
        padding: 80px 0 60px;
    }

    .project-detail-content h1 {
        font-size: 38px;
        letter-spacing: -2px;
    }

    .project-detail-media img,
    .project-detail-placeholder {
        height: 260px;
        border-radius: 24px;
    }

    .project-detail-actions .btn {
        width: 100%;
    }
}
.project-card {
    cursor: pointer;
}
/* FIX PROJECT DETAIL IMAGE */
.project-detail-media {
    background: #ffffff;
}

.project-detail-media img {
    width: 100%;
    height: 460px;
    object-fit: contain !important;
    padding: 28px;
    background: #ffffff;
}
/* =====================================================
   FIX PROJECT DETAIL IMAGE DISPLAY
   Ảnh dự án hiển thị đầy card, không còn viền trắng dày
===================================================== */
.project-detail-media {
    border-radius: 34px !important;
    overflow: hidden !important;
    border: 1px solid var(--border) !important;
    background: var(--black-card) !important;
    box-shadow: 0 30px 90px rgba(0, 0, 0, 0.4) !important;
}

.project-detail-media img {
    width: 100% !important;
    height: 460px !important;
    object-fit: cover !important;
    object-position: center !important;
    padding: 0 !important;
    background: transparent !important;
    display: block !important;
}
/* =====================================================
   PROJECT DETAIL GALLERY
===================================================== */
.project-gallery-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 22px;
}

.project-gallery-item {
    position: relative;
    border-radius: 24px;
    overflow: hidden;
    border: 1px solid var(--border);
    background: var(--black-card);
    min-height: 260px;
}

.project-gallery-item img {
    width: 100%;
    height: 280px;
    object-fit: cover;
    transition: 0.4s ease;
}

.project-gallery-item:hover img {
    transform: scale(1.06);
}

.project-gallery-item figcaption {
    position: absolute;
    left: 18px;
    right: 18px;
    bottom: 18px;
    padding: 10px 13px;
    border-radius: 14px;
    background: rgba(0, 0, 0, 0.58);
    backdrop-filter: blur(12px);
    color: var(--white);
    font-weight: 700;
    font-size: 14px;
}

@media (max-width: 992px) {
    .project-gallery-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 640px) {
    .project-gallery-grid {
        grid-template-columns: 1fr;
    }

    .project-gallery-item img {
        height: 240px;
    }
}
/* =====================================================
   PROJECT GALLERY LIGHTBOX
===================================================== */
.project-gallery-item {
    cursor: zoom-in;
}

.gallery-lightbox {
    position: fixed;
    inset: 0;
    z-index: 999999;
    background: rgba(0, 0, 0, 0.88);
    backdrop-filter: blur(16px);
    display: none;
    align-items: center;
    justify-content: center;
    padding: 28px;
}

.gallery-lightbox.active {
    display: flex;
}

.gallery-lightbox-content {
    width: min(1100px, 94vw);
    max-height: 88vh;
    display: grid;
    gap: 14px;
    animation: lightboxZoom 0.25s ease;
}

.gallery-lightbox-content img {
    width: 100%;
    max-height: 78vh;
    object-fit: contain;
    border-radius: 24px;
    border: 1px solid var(--border);
    background: #080808;
}

.gallery-lightbox-content p {
    color: var(--white);
    text-align: center;
    font-weight: 700;
}

.gallery-lightbox-close {
    position: fixed;
    top: 24px;
    right: 24px;
    width: 52px;
    height: 52px;
    border-radius: 18px;
    border: 1px solid var(--border);
    background: rgba(255, 255, 255, 0.08);
    color: var(--white);
    font-size: 34px;
    line-height: 1;
    cursor: pointer;
    z-index: 1000000;
    transition: 0.25s ease;
}

.gallery-lightbox-close:hover {
    background: var(--red);
    transform: rotate(90deg);
}

@keyframes lightboxZoom {
    from {
        opacity: 0;
        transform: scale(0.96);
    }

    to {
        opacity: 1;
        transform: scale(1);
    }
}

@media (max-width: 640px) {
    .gallery-lightbox {
        padding: 16px;
    }

    .gallery-lightbox-close {
        top: 14px;
        right: 14px;
        width: 46px;
        height: 46px;
        border-radius: 14px;
        font-size: 30px;
    }

    .gallery-lightbox-content img {
        border-radius: 18px;
    }
}

/* =====================================================
   FINAL FIX - PROJECT DETAIL GALLERY + LIGHTBOX
   Sửa lỗi ký tự thừa, căn gallery và popup ảnh
===================================================== */

.project-gallery-grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 24px !important;
    align-items: stretch !important;
}

.project-gallery-item {
    position: relative !important;
    min-height: 280px !important;
    margin: 0 !important;
    border-radius: 24px !important;
    overflow: hidden !important;
    border: 1px solid var(--border) !important;
    background: var(--black-card) !important;
    cursor: zoom-in !important;
}

.project-gallery-item img {
    width: 100% !important;
    height: 280px !important;
    object-fit: cover !important;
    object-position: center !important;
    display: block !important;
    transition: transform 0.4s ease !important;
}

.project-gallery-item:hover img {
    transform: scale(1.06) !important;
}

.project-gallery-item figcaption {
    position: absolute !important;
    left: 18px !important;
    right: 18px !important;
    bottom: 18px !important;
    padding: 10px 13px !important;
    border-radius: 14px !important;
    background: rgba(0, 0, 0, 0.58) !important;
    backdrop-filter: blur(12px) !important;
    color: var(--white) !important;
    font-weight: 700 !important;
    font-size: 14px !important;
}

.gallery-lightbox {
    position: fixed !important;
    inset: 0 !important;
    z-index: 999999 !important;
    background: rgba(0, 0, 0, 0.9) !important;
    backdrop-filter: blur(16px) !important;
    display: none !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 28px !important;
}

.gallery-lightbox.active {
    display: flex !important;
}

.gallery-lightbox-content {
    width: min(1100px, 94vw) !important;
    max-height: 88vh !important;
    display: grid !important;
    gap: 14px !important;
    animation: lightboxZoom 0.25s ease !important;
}

.gallery-lightbox-content img {
    width: 100% !important;
    max-height: 78vh !important;
    object-fit: contain !important;
    border-radius: 24px !important;
    border: 1px solid var(--border) !important;
    background: #080808 !important;
}

.gallery-lightbox-content p {
    color: var(--white) !important;
    text-align: center !important;
    font-weight: 700 !important;
}

.gallery-lightbox-close {
    position: fixed !important;
    top: 24px !important;
    right: 24px !important;
    width: 52px !important;
    height: 52px !important;
    border-radius: 18px !important;
    border: 1px solid var(--border) !important;
    background: rgba(255, 255, 255, 0.08) !important;
    color: var(--white) !important;
    font-size: 34px !important;
    line-height: 1 !important;
    cursor: pointer !important;
    z-index: 1000000 !important;
    transition: 0.25s ease !important;
}

.gallery-lightbox-close:hover {
    background: var(--red) !important;
    transform: rotate(90deg) !important;
}

@keyframes lightboxZoom {
    from {
        opacity: 0;
        transform: scale(0.96);
    }

    to {
        opacity: 1;
        transform: scale(1);
    }
}

@media (max-width: 992px) {
    .project-gallery-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 640px) {
    .project-gallery-grid {
        grid-template-columns: 1fr !important;
    }

    .project-gallery-item,
    .project-gallery-item img {
        height: 240px !important;
        min-height: 240px !important;
    }

    .gallery-lightbox {
        padding: 16px !important;
    }

    .gallery-lightbox-close {
        top: 14px !important;
        right: 14px !important;
        width: 46px !important;
        height: 46px !important;
        border-radius: 14px !important;
        font-size: 30px !important;
    }

    .gallery-lightbox-content img {
        border-radius: 18px !important;
    }
}
/* =====================================================
   FORCE PROJECT GALLERY LIGHTBOX
===================================================== */
.project-gallery-item {
    cursor: zoom-in !important;
}

.gallery-lightbox {
    position: fixed !important;
    inset: 0 !important;
    z-index: 999999 !important;
    background: rgba(0, 0, 0, 0.9) !important;
    backdrop-filter: blur(16px) !important;
    display: none !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 28px !important;
}

.gallery-lightbox.active {
    display: flex !important;
}

.gallery-lightbox-content {
    width: min(1100px, 94vw) !important;
    max-height: 88vh !important;
    display: grid !important;
    gap: 14px !important;
    animation: lightboxZoom 0.25s ease !important;
}

.gallery-lightbox-content img {
    width: 100% !important;
    max-height: 78vh !important;
    object-fit: contain !important;
    border-radius: 24px !important;
    border: 1px solid var(--border) !important;
    background: #080808 !important;
}

.gallery-lightbox-content p {
    color: var(--white) !important;
    text-align: center !important;
    font-weight: 700 !important;
}

.gallery-lightbox-close {
    position: fixed !important;
    top: 24px !important;
    right: 24px !important;
    width: 52px !important;
    height: 52px !important;
    border-radius: 18px !important;
    border: 1px solid var(--border) !important;
    background: rgba(255, 255, 255, 0.1) !important;
    color: #ffffff !important;
    font-size: 34px !important;
    line-height: 1 !important;
    cursor: pointer !important;
    z-index: 1000000 !important;
}

.gallery-lightbox-close:hover {
    background: var(--red) !important;
}

@keyframes lightboxZoom {
    from {
        opacity: 0;
        transform: scale(0.96);
    }

    to {
        opacity: 1;
        transform: scale(1);
    }
}
/* =====================================================
   PROJECT DETAIL PREV / NEXT NAVIGATION
===================================================== */
.project-navigation-section {
    padding: 30px 0 70px;
    background: var(--black);
}

.project-navigation {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
}

.project-nav-card {
    min-height: 150px;
    padding: 28px;
    border-radius: 26px;
    background:
        linear-gradient(135deg, rgba(255,255,255,0.06), rgba(255,255,255,0.02)),
        var(--black-card);
    border: 1px solid var(--border);
    transition: 0.35s ease;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.project-nav-card:hover {
    transform: translateY(-6px);
    border-color: rgba(245, 183, 0, 0.45);
    box-shadow: 0 24px 70px rgba(0, 0, 0, 0.35);
}

.project-nav-card span {
    color: var(--gold);
    font-weight: 800;
    margin-bottom: 18px;
}

.project-nav-card p {
    color: var(--gray);
    font-size: 14px;
    margin-bottom: 6px;
}

.project-nav-card h3 {
    color: var(--white);
    font-size: 24px;
    line-height: 1.2;
    letter-spacing: -0.8px;
}

.project-nav-next {
    text-align: right;
}

@media (max-width: 768px) {
    .project-navigation {
        grid-template-columns: 1fr;
    }

    .project-nav-next {
        text-align: left;
    }

    .project-nav-card {
        min-height: 130px;
        padding: 24px;
    }

    .project-nav-card h3 {
        font-size: 21px;
    }
}
/* =====================================================
   PREMIUM PROJECT GALLERY
===================================================== */
.project-gallery-premium {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    grid-auto-rows: 180px;
    gap: 18px;
}

.project-gallery-premium .project-gallery-item {
    position: relative;
    margin: 0;
    border-radius: 26px;
    overflow: hidden;
    border: 1px solid var(--border);
    background: var(--black-card);
    cursor: zoom-in;
    box-shadow: 0 22px 70px rgba(0, 0, 0, 0.28);
}

.project-gallery-premium .gallery-featured {
    grid-column: span 2;
    grid-row: span 2;
}

.project-gallery-premium .project-gallery-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    transition: transform 0.5s ease, filter 0.5s ease;
}

.project-gallery-premium .project-gallery-item:hover img {
    transform: scale(1.08);
    filter: brightness(0.82);
}

.gallery-overlay {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(
        135deg,
        rgba(193, 18, 31, 0.18),
        rgba(245, 183, 0, 0.12)
    );
    opacity: 0;
    transition: 0.35s ease;
}

.project-gallery-item:hover .gallery-overlay {
    opacity: 1;
}

.gallery-overlay span {
    padding: 10px 16px;
    border-radius: 999px;
    background: rgba(0, 0, 0, 0.58);
    backdrop-filter: blur(12px);
    color: var(--white);
    font-size: 14px;
    font-weight: 800;
}

.project-gallery-premium .project-gallery-item figcaption {
    position: absolute;
    left: 18px;
    right: 18px;
    bottom: 18px;
    padding: 10px 14px;
    border-radius: 14px;
    background: rgba(0, 0, 0, 0.62);
    backdrop-filter: blur(14px);
    color: var(--white);
    font-weight: 700;
    font-size: 14px;
    line-height: 1.4;
}

/* Tablet */
@media (max-width: 992px) {
    .project-gallery-premium {
        grid-template-columns: repeat(2, 1fr);
        grid-auto-rows: 190px;
    }

    .project-gallery-premium .gallery-featured {
        grid-column: span 2;
        grid-row: span 2;
    }
}

/* Mobile */
@media (max-width: 640px) {
    .project-gallery-premium {
        grid-template-columns: 1fr;
        grid-auto-rows: auto;
        gap: 16px;
    }

    .project-gallery-premium .gallery-featured {
        grid-column: auto;
        grid-row: auto;
    }

    .project-gallery-premium .project-gallery-item {
        height: 240px;
        border-radius: 22px;
    }
}
/* =====================================================
   FINAL PREMIUM PROJECT GALLERY + PROJECT NAV FIX
   Làm đẹp gallery và nút dự án trước/tiếp theo
===================================================== */

/* Gallery section spacing */
.project-gallery-premium {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 22px !important;
}

/* Nếu chỉ có 1 ảnh thì không kéo ảnh dài toàn dòng nữa */
.project-gallery-premium .project-gallery-item,
.project-gallery-premium .gallery-featured {
    grid-column: auto !important;
    grid-row: auto !important;
    height: 320px !important;
    min-height: 320px !important;
    border-radius: 28px !important;
    overflow: hidden !important;
    background: var(--black-card) !important;
    border: 1px solid rgba(255, 255, 255, 0.12) !important;
    box-shadow: 0 22px 70px rgba(0, 0, 0, 0.28) !important;
    position: relative !important;
}

/* Khi gallery chỉ có 1 ảnh: căn giữa cho đẹp */
.project-gallery-premium:has(.project-gallery-item:only-child) {
    grid-template-columns: minmax(320px, 720px) !important;
    justify-content: center !important;
}

/* Ảnh nằm đầy card nhưng không bị quá mỏng */
.project-gallery-premium .project-gallery-item img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center !important;
    transition: transform 0.45s ease, filter 0.45s ease !important;
}

.project-gallery-premium .project-gallery-item:hover img {
    transform: scale(1.06) !important;
    filter: brightness(0.72) !important;
}

/* Overlay tối nhẹ toàn ảnh */
.project-gallery-premium .project-gallery-item::after {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    background:
        linear-gradient(
            180deg,
            transparent 35%,
            rgba(0, 0, 0, 0.72) 100%
        ) !important;
    opacity: 1 !important;
    pointer-events: none !important;
    z-index: 1 !important;
}

/* Nút "Xem ảnh" đẹp hơn */
.gallery-overlay {
    position: absolute !important;
    inset: 0 !important;
    z-index: 3 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    opacity: 0 !important;
    background:
        linear-gradient(
            135deg,
            rgba(193, 18, 31, 0.18),
            rgba(245, 183, 0, 0.12)
        ) !important;
    transition: 0.35s ease !important;
}

.project-gallery-item:hover .gallery-overlay {
    opacity: 1 !important;
}

.gallery-overlay span {
    padding: 12px 18px !important;
    border-radius: 999px !important;
    background: rgba(5, 5, 5, 0.72) !important;
    border: 1px solid rgba(255, 255, 255, 0.16) !important;
    backdrop-filter: blur(14px) !important;
    color: #ffffff !important;
    font-weight: 800 !important;
    font-size: 14px !important;
    box-shadow: 0 14px 40px rgba(0, 0, 0, 0.35) !important;
}

/* Caption đẹp hơn, không dính sát mép */
.project-gallery-premium .project-gallery-item figcaption {
    position: absolute !important;
    left: 18px !important;
    right: 18px !important;
    bottom: 18px !important;
    z-index: 4 !important;
    padding: 12px 14px !important;
    border-radius: 16px !important;
    background: rgba(0, 0, 0, 0.58) !important;
    border: 1px solid rgba(255, 255, 255, 0.12) !important;
    backdrop-filter: blur(14px) !important;
    color: var(--white) !important;
    font-size: 14px !important;
    font-weight: 800 !important;
    line-height: 1.35 !important;
}

/* Nếu không muốn hiện tiêu đề dưới ảnh, có thể bật dòng này */
/*
.project-gallery-premium .project-gallery-item figcaption {
    display: none !important;
}
*/


/* =====================================================
   FIX PROJECT PREV/NEXT NAVIGATION
===================================================== */
.project-navigation-section {
    padding: 70px 0 !important;
    background:
        radial-gradient(circle at left top, rgba(193, 18, 31, 0.14), transparent 32%),
        var(--black) !important;
    border-top: 1px solid var(--border) !important;
}

.project-navigation {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 24px !important;
}

.project-nav-card {
    min-height: 170px !important;
    padding: 30px !important;
    border-radius: 28px !important;
    background:
        linear-gradient(135deg, rgba(255,255,255,0.07), rgba(255,255,255,0.025)),
        var(--black-card) !important;
    border: 1px solid rgba(255,255,255,0.12) !important;
    position: relative !important;
    overflow: hidden !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: space-between !important;
    transition: transform 0.35s ease, border-color 0.35s ease, box-shadow 0.35s ease !important;
}

/* Gradient viền khi hover */
.project-nav-card::before {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    padding: 1.5px !important;
    border-radius: inherit !important;
    background: linear-gradient(135deg, var(--red), var(--gold)) !important;
    opacity: 0 !important;
    transition: 0.35s ease !important;
    pointer-events: none !important;

    -webkit-mask:
        linear-gradient(#fff 0 0) content-box,
        linear-gradient(#fff 0 0) !important;
    -webkit-mask-composite: xor !important;
    mask-composite: exclude !important;
}

.project-nav-card:hover::before {
    opacity: 1 !important;
}

.project-nav-card:hover {
    transform: translateY(-8px) !important;
    border-color: transparent !important;
    box-shadow: 0 24px 80px rgba(0, 0, 0, 0.42) !important;
}

.project-nav-card span {
    color: var(--gold) !important;
    font-size: 14px !important;
    font-weight: 900 !important;
    letter-spacing: 0.4px !important;
    text-transform: uppercase !important;
    margin-bottom: 20px !important;
}

.project-nav-card p {
    color: var(--gray) !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    margin-bottom: 8px !important;
}

.project-nav-card h3 {
    color: var(--white) !important;
    font-size: clamp(22px, 2.2vw, 30px) !important;
    line-height: 1.16 !important;
    letter-spacing: -1px !important;
    max-width: 90% !important;
}

.project-nav-next {
    text-align: right !important;
    align-items: flex-end !important;
}

.project-nav-next h3 {
    margin-left: auto !important;
}

/* Khi chỉ có 1 nút dự án trước hoặc tiếp theo */
.project-navigation > div:empty {
    display: none !important;
}

.project-navigation:has(> div:empty) {
    grid-template-columns: 1fr !important;
}

.project-navigation:has(> div:empty) .project-nav-card {
    max-width: 620px !important;
}

.project-navigation:has(.project-nav-next):has(> div:empty) {
    justify-items: end !important;
}

/* Responsive */
@media (max-width: 992px) {
    .project-gallery-premium {
        grid-template-columns: repeat(2, 1fr) !important;
    }

    .project-gallery-premium:has(.project-gallery-item:only-child) {
        grid-template-columns: 1fr !important;
    }

    .project-gallery-premium .project-gallery-item,
    .project-gallery-premium .gallery-featured {
        height: 280px !important;
        min-height: 280px !important;
    }
}

@media (max-width: 640px) {
    .project-gallery-premium {
        grid-template-columns: 1fr !important;
        gap: 16px !important;
    }

    .project-gallery-premium .project-gallery-item,
    .project-gallery-premium .gallery-featured {
        height: 240px !important;
        min-height: 240px !important;
        border-radius: 22px !important;
    }

    .project-navigation {
        grid-template-columns: 1fr !important;
    }

    .project-nav-card {
        min-height: 140px !important;
        padding: 24px !important;
        border-radius: 22px !important;
    }

    .project-nav-next {
        text-align: left !important;
        align-items: flex-start !important;
    }

    .project-nav-next h3 {
        margin-left: 0 !important;
    }
}
/* =====================================================
   PROJECT DETAIL GALLERY - SHOWCASE FINAL
   Ghi đè gallery cũ, làm dạng portfolio đẹp hơn
===================================================== */

.project-gallery-showcase {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 22px !important;
    align-items: stretch !important;
}

/* Nếu chỉ có 1 ảnh */
.project-gallery-showcase.count-1 {
    grid-template-columns: minmax(280px, 760px) !important;
    justify-content: center !important;
}

/* Nếu có 2 ảnh */
.project-gallery-showcase.count-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

/* Card ảnh */
.showcase-item {
    position: relative !important;
    margin: 0 !important;
    height: 320px !important;
    min-height: 320px !important;
    border-radius: 28px !important;
    overflow: hidden !important;
    cursor: zoom-in !important;
    background: #111 !important;
    border: 1px solid rgba(255,255,255,0.12) !important;
    box-shadow: 0 22px 70px rgba(0, 0, 0, 0.32) !important;
}

/* Ảnh đầu tiên chỉ nổi bật khi có từ 3 ảnh trở lên */
.project-gallery-showcase:not(.count-1):not(.count-2) .showcase-item.is-featured {
    grid-column: span 2 !important;
    grid-row: span 2 !important;
    height: 662px !important;
}

/* Ảnh */
.showcase-item img {
    width: 100% !important;
    height: 100% !important;
    display: block !important;
    object-fit: cover !important;
    object-position: center !important;
    padding: 0 !important;
    background: transparent !important;
    transition: transform 0.5s ease, filter 0.5s ease !important;
}

/* Overlay tối nhẹ */
.showcase-item::after {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    z-index: 1 !important;
    background:
        linear-gradient(
            180deg,
            rgba(0,0,0,0.05) 0%,
            rgba(0,0,0,0.18) 45%,
            rgba(0,0,0,0.78) 100%
        ) !important;
    pointer-events: none !important;
}

/* Hover */
.showcase-item:hover img {
    transform: scale(1.07) !important;
    filter: brightness(0.72) saturate(1.08) !important;
}

/* Nút Xem ảnh ở giữa */
.showcase-hover {
    position: absolute !important;
    inset: 0 !important;
    z-index: 4 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    opacity: 0 !important;
    transition: 0.35s ease !important;
    background:
        linear-gradient(
            135deg,
            rgba(193,18,31,0.20),
            rgba(245,183,0,0.14)
        ) !important;
}

.showcase-item:hover .showcase-hover {
    opacity: 1 !important;
}

.showcase-hover span {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 12px 18px !important;
    border-radius: 999px !important;
    background: rgba(5,5,5,0.72) !important;
    border: 1px solid rgba(255,255,255,0.16) !important;
    backdrop-filter: blur(14px) !important;
    color: #fff !important;
    font-size: 14px !important;
    font-weight: 800 !important;
    box-shadow: 0 16px 40px rgba(0,0,0,0.38) !important;
}

/* Caption */
.showcase-item figcaption {
    position: absolute !important;
    z-index: 5 !important;
    left: 18px !important;
    right: 18px !important;
    bottom: 18px !important;
    padding: 12px 15px !important;
    border-radius: 16px !important;
    background: rgba(0,0,0,0.60) !important;
    border: 1px solid rgba(255,255,255,0.12) !important;
    backdrop-filter: blur(14px) !important;
    color: #fff !important;
    font-size: 14px !important;
    font-weight: 800 !important;
    line-height: 1.35 !important;
}

/* Ẩn caption nếu chỉ là tên dự án lặp lại, nhìn gọn hơn */
.showcase-item figcaption:empty {
    display: none !important;
}

/* Mobile */
@media (max-width: 992px) {
    .project-gallery-showcase,
    .project-gallery-showcase.count-1,
    .project-gallery-showcase.count-2 {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    .project-gallery-showcase:not(.count-1):not(.count-2) .showcase-item.is-featured {
        grid-column: span 2 !important;
        height: 420px !important;
    }

    .showcase-item {
        height: 260px !important;
        min-height: 260px !important;
    }
}

@media (max-width: 640px) {
    .project-gallery-showcase,
    .project-gallery-showcase.count-1,
    .project-gallery-showcase.count-2 {
        grid-template-columns: 1fr !important;
    }

    .project-gallery-showcase:not(.count-1):not(.count-2) .showcase-item.is-featured,
    .showcase-item {
        grid-column: auto !important;
        grid-row: auto !important;
        height: 240px !important;
        min-height: 240px !important;
        border-radius: 22px !important;
    }

    .showcase-hover {
        opacity: 1 !important;
        background: transparent !important;
        align-items: flex-end !important;
        justify-content: flex-start !important;
        padding: 16px !important;
    }

    .showcase-hover span {
        font-size: 13px !important;
        padding: 9px 13px !important;
    }
}


/* =====================================================
   PROJECT SWITCH CARD FINAL
   Làm đẹp nút dự án trước / tiếp theo
===================================================== */

.project-switch-section {
    padding: 64px 0 76px !important;
    background:
        radial-gradient(circle at top left, rgba(193,18,31,0.14), transparent 34%),
        var(--black) !important;
    border-top: 1px solid var(--border) !important;
}

.project-switch-grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 24px !important;
}

.project-switch-grid:has(.project-switch-card:only-child) {
    grid-template-columns: minmax(280px, 620px) !important;
}

.project-switch-card {
    min-height: 178px !important;
    padding: 30px !important;
    border-radius: 30px !important;
    background:
        linear-gradient(135deg, rgba(255,255,255,0.07), rgba(255,255,255,0.025)),
        var(--black-card) !important;
    border: 1px solid rgba(255,255,255,0.12) !important;
    position: relative !important;
    overflow: hidden !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: space-between !important;
    transition: 0.35s ease !important;
}

/* Nền gradient mờ */
.project-switch-card::after {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    background:
        radial-gradient(circle at top right, rgba(245,183,0,0.16), transparent 36%),
        radial-gradient(circle at bottom left, rgba(193,18,31,0.18), transparent 38%) !important;
    opacity: 0 !important;
    transition: 0.35s ease !important;
    pointer-events: none !important;
}

/* Viền gradient */
.project-switch-card::before {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    padding: 1.5px !important;
    border-radius: inherit !important;
    background: linear-gradient(135deg, var(--red), var(--gold)) !important;
    opacity: 0 !important;
    transition: 0.35s ease !important;
    pointer-events: none !important;

    -webkit-mask:
        linear-gradient(#fff 0 0) content-box,
        linear-gradient(#fff 0 0) !important;
    -webkit-mask-composite: xor !important;
    mask-composite: exclude !important;
}

.project-switch-card:hover {
    transform: translateY(-8px) !important;
    border-color: transparent !important;
    box-shadow: 0 26px 80px rgba(0,0,0,0.45) !important;
}

.project-switch-card:hover::before,
.project-switch-card:hover::after {
    opacity: 1 !important;
}

.project-switch-card > * {
    position: relative !important;
    z-index: 2 !important;
}

.switch-label {
    color: var(--gold) !important;
    font-size: 14px !important;
    font-weight: 900 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.8px !important;
}

.project-switch-card p {
    color: var(--gray) !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    margin-top: 26px !important;
    margin-bottom: 8px !important;
}

.project-switch-card h3 {
    color: var(--white) !important;
    font-size: clamp(22px, 2.4vw, 32px) !important;
    line-height: 1.15 !important;
    letter-spacing: -1px !important;
}

.project-switch-card.is-next {
    text-align: right !important;
    align-items: flex-end !important;
}

@media (max-width: 768px) {
    .project-switch-grid,
    .project-switch-grid:has(.project-switch-card:only-child) {
        grid-template-columns: 1fr !important;
    }

    .project-switch-card,
    .project-switch-card.is-next {
        text-align: left !important;
        align-items: flex-start !important;
        min-height: 150px !important;
        padding: 24px !important;
        border-radius: 24px !important;
    }
}


/* =====================================================
   CLEAN PROJECT DETAIL GALLERY + SWITCH FINAL
   Bản ổn định cho project-detail.php
===================================================== */
.project-gallery-section .section-heading {
    margin-bottom: 34px !important;
}

.project-gallery-showcase {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 22px !important;
    align-items: stretch !important;
}

.project-gallery-showcase.count-1 {
    grid-template-columns: minmax(280px, 760px) !important;
    justify-content: center !important;
}

.project-gallery-showcase.count-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

.showcase-item {
    position: relative !important;
    margin: 0 !important;
    height: 320px !important;
    min-height: 320px !important;
    border-radius: 28px !important;
    overflow: hidden !important;
    cursor: zoom-in !important;
    background: #111 !important;
    border: 1px solid rgba(255,255,255,0.12) !important;
    box-shadow: 0 22px 70px rgba(0, 0, 0, 0.32) !important;
}

.project-gallery-showcase:not(.count-1):not(.count-2) .showcase-item.is-featured {
    grid-column: span 2 !important;
    grid-row: span 2 !important;
    height: 662px !important;
}

.showcase-item img {
    width: 100% !important;
    height: 100% !important;
    display: block !important;
    object-fit: cover !important;
    object-position: center !important;
    padding: 0 !important;
    background: transparent !important;
    transition: transform 0.5s ease, filter 0.5s ease !important;
}

.showcase-item::after {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    z-index: 1 !important;
    background: linear-gradient(180deg, rgba(0,0,0,0.05) 0%, rgba(0,0,0,0.18) 45%, rgba(0,0,0,0.78) 100%) !important;
    pointer-events: none !important;
}

.showcase-item:hover img {
    transform: scale(1.07) !important;
    filter: brightness(0.72) saturate(1.08) !important;
}

.showcase-hover {
    position: absolute !important;
    inset: 0 !important;
    z-index: 4 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    opacity: 0 !important;
    transition: 0.35s ease !important;
    background: linear-gradient(135deg, rgba(193,18,31,0.20), rgba(245,183,0,0.14)) !important;
}

.showcase-item:hover .showcase-hover {
    opacity: 1 !important;
}

.showcase-hover span {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 12px 18px !important;
    border-radius: 999px !important;
    background: rgba(5,5,5,0.72) !important;
    border: 1px solid rgba(255,255,255,0.16) !important;
    backdrop-filter: blur(14px) !important;
    color: #fff !important;
    font-size: 14px !important;
    font-weight: 800 !important;
    box-shadow: 0 16px 40px rgba(0,0,0,0.38) !important;
}

.showcase-item figcaption {
    position: absolute !important;
    z-index: 5 !important;
    left: 18px !important;
    right: 18px !important;
    bottom: 18px !important;
    padding: 12px 15px !important;
    border-radius: 16px !important;
    background: rgba(0,0,0,0.60) !important;
    border: 1px solid rgba(255,255,255,0.12) !important;
    backdrop-filter: blur(14px) !important;
    color: #fff !important;
    font-size: 14px !important;
    font-weight: 800 !important;
    line-height: 1.35 !important;
}

.project-switch-section {
    padding: 64px 0 76px !important;
    background: radial-gradient(circle at top left, rgba(193,18,31,0.14), transparent 34%), var(--black) !important;
    border-top: 1px solid var(--border) !important;
}

.project-switch-grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 24px !important;
}

.project-switch-grid:has(.project-switch-card:only-child) {
    grid-template-columns: minmax(280px, 620px) !important;
}

.project-switch-card {
    min-height: 178px !important;
    padding: 30px !important;
    border-radius: 30px !important;
    background: linear-gradient(135deg, rgba(255,255,255,0.07), rgba(255,255,255,0.025)), var(--black-card) !important;
    border: 1px solid rgba(255,255,255,0.12) !important;
    position: relative !important;
    overflow: hidden !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: space-between !important;
    transition: 0.35s ease !important;
}

.project-switch-card::after {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    background: radial-gradient(circle at top right, rgba(245,183,0,0.16), transparent 36%), radial-gradient(circle at bottom left, rgba(193,18,31,0.18), transparent 38%) !important;
    opacity: 0 !important;
    transition: 0.35s ease !important;
    pointer-events: none !important;
}

.project-switch-card::before {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    padding: 1.5px !important;
    border-radius: inherit !important;
    background: linear-gradient(135deg, var(--red), var(--gold)) !important;
    opacity: 0 !important;
    transition: 0.35s ease !important;
    pointer-events: none !important;
    -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0) !important;
    -webkit-mask-composite: xor !important;
    mask-composite: exclude !important;
}

.project-switch-card:hover {
    transform: translateY(-8px) !important;
    border-color: transparent !important;
    box-shadow: 0 26px 80px rgba(0,0,0,0.45) !important;
}

.project-switch-card:hover::before,
.project-switch-card:hover::after {
    opacity: 1 !important;
}

.project-switch-card > * {
    position: relative !important;
    z-index: 2 !important;
}

.switch-label {
    color: var(--gold) !important;
    font-size: 14px !important;
    font-weight: 900 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.8px !important;
}

.project-switch-card p {
    color: var(--gray) !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    margin-top: 26px !important;
    margin-bottom: 8px !important;
}

.project-switch-card h3 {
    color: var(--white) !important;
    font-size: clamp(22px, 2.4vw, 32px) !important;
    line-height: 1.15 !important;
    letter-spacing: -1px !important;
}

.project-switch-card.is-next {
    text-align: right !important;
    align-items: flex-end !important;
}

@media (max-width: 992px) {
    .project-gallery-showcase,
    .project-gallery-showcase.count-1,
    .project-gallery-showcase.count-2 {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    .project-gallery-showcase:not(.count-1):not(.count-2) .showcase-item.is-featured {
        grid-column: span 2 !important;
        height: 420px !important;
    }

    .showcase-item {
        height: 260px !important;
        min-height: 260px !important;
    }
}

@media (max-width: 640px) {
    .project-gallery-showcase,
    .project-gallery-showcase.count-1,
    .project-gallery-showcase.count-2 {
        grid-template-columns: 1fr !important;
    }

    .project-gallery-showcase:not(.count-1):not(.count-2) .showcase-item.is-featured,
    .showcase-item {
        grid-column: auto !important;
        grid-row: auto !important;
        height: 240px !important;
        min-height: 240px !important;
        border-radius: 22px !important;
    }

    .showcase-hover {
        opacity: 1 !important;
        background: transparent !important;
        align-items: flex-end !important;
        justify-content: flex-start !important;
        padding: 16px !important;
    }

    .showcase-hover span {
        font-size: 13px !important;
        padding: 9px 13px !important;
    }

    .project-switch-grid,
    .project-switch-grid:has(.project-switch-card:only-child) {
        grid-template-columns: 1fr !important;
    }

    .project-switch-card,
    .project-switch-card.is-next {
        text-align: left !important;
        align-items: flex-start !important;
        min-height: 150px !important;
        padding: 24px !important;
        border-radius: 24px !important;
    }
}
/* =====================================================
   FIX SMALLER NEXT / PREV PROJECT CARD
===================================================== */
.project-switch-section {
    padding: 42px 0 64px !important;
}

.project-switch-grid {
    display: flex !important;
    justify-content: flex-end !important;
    gap: 18px !important;
}

.project-switch-card {
    width: 360px !important;
    min-height: 118px !important;
    padding: 22px 24px !important;
    border-radius: 22px !important;
}

.project-switch-card .switch-label {
    font-size: 12px !important;
    margin-bottom: 14px !important;
}

.project-switch-card p {
    font-size: 13px !important;
    margin-top: 12px !important;
    margin-bottom: 4px !important;
}

.project-switch-card h3 {
    font-size: 22px !important;
    line-height: 1.2 !important;
    letter-spacing: -0.5px !important;
}

.project-switch-card.is-next {
    text-align: right !important;
}

/* Nếu có cả dự án trước và tiếp theo thì chia đều vừa phải */
.project-switch-grid:has(.project-switch-card:nth-child(2)) {
    justify-content: space-between !important;
}

@media (max-width: 768px) {
    .project-switch-grid {
        display: grid !important;
        grid-template-columns: 1fr !important;
    }

    .project-switch-card {
        width: 100% !important;
        min-height: 110px !important;
        padding: 20px !important;
    }

    .project-switch-card,
    .project-switch-card.is-next {
        text-align: left !important;
    }

    .project-switch-card h3 {
        font-size: 20px !important;
    }
}
/* =====================================================
   404 ERROR PAGE
===================================================== */
.error-page {
    min-height: calc(100vh - 76px);
    display: flex;
    align-items: center;
    background:
        radial-gradient(circle at top left, rgba(193, 18, 31, 0.25), transparent 34%),
        radial-gradient(circle at bottom right, rgba(245, 183, 0, 0.16), transparent 30%),
        var(--black);
    padding: 100px 0;
}

.error-box {
    max-width: 780px;
    text-align: center;
}

.error-box h1 {
    font-size: clamp(48px, 7vw, 96px);
    line-height: 1.02;
    letter-spacing: -4px;
    margin-bottom: 22px;
}

.error-box > p {
    color: var(--gray);
    font-size: 18px;
    line-height: 1.8;
    max-width: 620px;
    margin: 0 auto 34px;
}

.error-actions {
    display: flex;
    justify-content: center;
    gap: 14px;
    flex-wrap: wrap;
}

@media (max-width: 640px) {
    .error-page {
        padding: 80px 0;
        min-height: auto;
    }

    .error-box h1 {
        letter-spacing: -2px;
    }

    .error-actions .btn {
        width: 100%;
    }
}
/* =====================================================
   ADMIN DASHBOARD UPGRADE
===================================================== */
.dashboard-top-actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}

.dashboard-stats .admin-stat-card {
    text-decoration: none;
    color: inherit;
}

.dashboard-stat-link {
    transition: 0.3s ease;
}

.dashboard-stat-link:hover {
    transform: translateY(-6px);
    border-color: rgba(245, 183, 0, 0.38);
}

.admin-stat-card.has-new-leads {
    border-color: rgba(245, 183, 0, 0.45);
    box-shadow: 0 18px 55px rgba(245, 183, 0, 0.08);
}

.admin-stat-card.has-new-leads h2 {
    color: var(--gold);
}

.dashboard-panel-heading {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 24px;
}

.dashboard-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 24px;
    margin-top: 28px;
}

.dashboard-list-panel {
    min-height: 420px;
}

.dashboard-list-title {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 22px;
}

.dashboard-list-title h2 {
    margin-bottom: 0;
}

.dashboard-list {
    display: grid;
    gap: 14px;
}

.dashboard-list-item {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    padding: 16px;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.035);
    border: 1px solid rgba(255, 255, 255, 0.08);
    transition: 0.25s ease;
}

.dashboard-list-link:hover,
.dashboard-list-item:hover {
    background: rgba(255, 255, 255, 0.055);
    border-color: rgba(245, 183, 0, 0.25);
}

.dashboard-list-item h3 {
    font-size: 17px;
    line-height: 1.35;
    margin-bottom: 6px;
}

.dashboard-list-item p {
    color: var(--gray);
    font-size: 14px;
}

.dashboard-list-item small {
    display: block;
    margin-top: 8px;
    color: var(--gray-dark);
    line-height: 1.5;
}

.dashboard-item-meta {
    display: grid;
    justify-items: end;
    gap: 8px;
    flex-shrink: 0;
}

.dashboard-item-meta em {
    color: var(--gray-dark);
    font-size: 13px;
    font-style: normal;
    white-space: nowrap;
}

.dashboard-status-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 14px;
    margin-top: 20px;
}

.dashboard-status-grid div {
    padding: 20px;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.035);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.dashboard-status-grid span {
    display: block;
    color: var(--gold);
    font-size: 32px;
    font-weight: 900;
    margin-bottom: 6px;
}

.dashboard-status-grid p {
    color: var(--gray);
}

.dashboard-note {
    margin-top: 22px;
    padding: 18px;
    border-radius: 18px;
    background: rgba(245, 183, 0, 0.08);
    border: 1px solid rgba(245, 183, 0, 0.18);
}

.dashboard-note p {
    color: var(--gray);
}

.dashboard-note strong {
    color: var(--gold);
}

@media (max-width: 992px) {
    .dashboard-grid {
        grid-template-columns: 1fr;
    }

    .dashboard-list-panel {
        min-height: auto;
    }
}

@media (max-width: 640px) {
    .dashboard-top-actions {
        width: 100%;
    }

    .dashboard-top-actions .btn {
        width: 100%;
    }

    .dashboard-list-title {
        flex-direction: column;
    }

    .dashboard-list-item {
        flex-direction: column;
    }

    .dashboard-item-meta {
        justify-items: start;
    }

    .dashboard-status-grid {
        grid-template-columns: 1fr;
    }
}
/* =====================================================
   FAQ PAGE
===================================================== */
.faq-container {
    max-width: 920px;
}

.faq-list {
    display: grid;
    gap: 16px;
}

.faq-item {
    border-radius: 22px;
    background: var(--black-card);
    border: 1px solid var(--border);
    overflow: hidden;
    transition: 0.3s ease;
}

.faq-item:hover {
    border-color: rgba(245, 183, 0, 0.35);
}

.faq-item summary {
    list-style: none;
    cursor: pointer;
    padding: 24px 28px;
    color: var(--white);
    font-size: 18px;
    font-weight: 800;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
}

.faq-item summary::-webkit-details-marker {
    display: none;
}

.faq-item summary::after {
    content: "+";
    color: var(--gold);
    font-size: 28px;
    font-weight: 900;
    transition: 0.25s ease;
}

.faq-item[open] summary::after {
    transform: rotate(45deg);
}

.faq-answer {
    padding: 0 28px 26px;
    color: var(--gray);
    line-height: 1.8;
}
/* =====================================================
   ADMIN FAQ
===================================================== */
.faq-admin-list {
    display: grid;
    gap: 20px;
    margin-top: 24px;
}

.faq-admin-card {
    padding: 22px;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.035);
    border: 1px solid var(--border);
}

.faq-admin-card textarea {
    min-height: 120px;
}

.faq-admin-card .admin-actions {
    margin-top: 18px;
}
/* =====================================================
   WORK PROCESS PAGE
===================================================== */
.process-timeline {
    position: relative;
    display: grid;
    gap: 22px;
    max-width: 980px;
    margin: 0 auto;
}

.process-timeline::before {
    content: "";
    position: absolute;
    left: 38px;
    top: 20px;
    bottom: 20px;
    width: 2px;
    background: linear-gradient(
        180deg,
        var(--red),
        var(--gold)
    );
    opacity: 0.5;
}

.process-step-card {
    position: relative;
    display: grid;
    grid-template-columns: 80px 1fr;
    gap: 24px;
    padding: 28px;
    border-radius: 28px;
    background: var(--black-card);
    border: 1px solid var(--border);
    transition: 0.3s ease;
}

.process-step-card:hover {
    transform: translateY(-6px);
    border-color: rgba(245, 183, 0, 0.35);
    box-shadow: 0 22px 70px rgba(0, 0, 0, 0.28);
}

.process-step-number {
    position: relative;
    z-index: 2;
    width: 76px;
    height: 76px;
    border-radius: 22px;
    display: grid;
    place-items: center;
    color: var(--gold);
    font-size: 24px;
    font-weight: 900;
    background:
        linear-gradient(135deg, rgba(193, 18, 31, 0.24), rgba(245, 183, 0, 0.12)),
        #0b0b0b;
    border: 1px solid rgba(255, 255, 255, 0.12);
}

.process-step-content h2 {
    font-size: clamp(24px, 3vw, 34px);
    line-height: 1.15;
    letter-spacing: -1px;
    margin-bottom: 10px;
}

.process-step-content p {
    color: var(--gray);
    line-height: 1.8;
}

@media (max-width: 640px) {
    .process-timeline::before {
        left: 28px;
    }

    .process-step-card {
        grid-template-columns: 58px 1fr;
        gap: 18px;
        padding: 22px;
        border-radius: 22px;
    }

    .process-step-number {
        width: 56px;
        height: 56px;
        border-radius: 16px;
        font-size: 18px;
    }
}
/* =====================================================
   PROCESS HORIZONTAL ARROW STYLE
===================================================== */
.process-progress-box {
    position: relative;
    padding: 38px;
    border-radius: 34px;
    background:
        linear-gradient(135deg, rgba(255,255,255,0.08), rgba(255,255,255,0.025)),
        radial-gradient(circle at top left, rgba(193,18,31,0.18), transparent 36%),
        radial-gradient(circle at bottom right, rgba(245,183,0,0.14), transparent 32%),
        var(--black-card);
    border: 1px solid rgba(255,255,255,0.12);
    box-shadow: 0 28px 90px rgba(0,0,0,0.36);
    overflow: hidden;
}

.process-progress-box::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(120deg, rgba(255,255,255,0.06), transparent 35%),
        repeating-linear-gradient(
            90deg,
            rgba(255,255,255,0.025) 0,
            rgba(255,255,255,0.025) 1px,
            transparent 1px,
            transparent 80px
        );
    pointer-events: none;
}

.process-progress-header {
    position: relative;
    z-index: 2;
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 24px;
    margin-bottom: 34px;
}

.process-progress-header h2 {
    font-size: clamp(30px, 4vw, 48px);
    line-height: 1.08;
    letter-spacing: -1.8px;
}

.process-icons {
    display: flex;
    align-items: center;
    gap: 14px;
    color: var(--gold);
    font-size: 24px;
    opacity: 0.95;
}

.process-icons span {
    width: 44px;
    height: 44px;
    display: grid;
    place-items: center;
    border-radius: 16px;
    background: rgba(0,0,0,0.32);
    border: 1px solid rgba(255,255,255,0.12);
    backdrop-filter: blur(12px);
}

.process-arrow-row {
    position: relative;
    z-index: 2;
    display: flex;
    align-items: stretch;
    gap: 0;
    width: 100%;
}

.process-arrow-step {
    position: relative;
    flex: 1;
    min-height: 118px;
    padding: 24px 34px 24px 42px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    background: linear-gradient(135deg, #f7f1df, #caa85e);
    color: #101010;
    clip-path: polygon(
        0 0,
        calc(100% - 34px) 0,
        100% 50%,
        calc(100% - 34px) 100%,
        0 100%,
        34px 50%
    );
    margin-left: -26px;
    transition: 0.3s ease;
}

.process-arrow-step.is-first {
    margin-left: 0;
    clip-path: polygon(
        0 0,
        calc(100% - 34px) 0,
        100% 50%,
        calc(100% - 34px) 100%,
        0 100%
    );
    background: linear-gradient(135deg, #ffffff, #e7e7e7);
}

.process-arrow-step.is-last {
    background: linear-gradient(135deg, #f2dc9b, #b8903e);
}

.process-arrow-step:hover {
    transform: translateY(-8px);
    z-index: 5;
    filter: brightness(1.08);
}

.process-arrow-step span {
    display: block;
    margin-bottom: 8px;
    font-size: 14px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.8px;
    color: rgba(0,0,0,0.64);
}

.process-arrow-step h3 {
    font-size: clamp(18px, 2vw, 24px);
    line-height: 1.2;
    letter-spacing: -0.6px;
    font-weight: 900;
    color: #101010;
}

/* Chi tiết từng bước bên dưới */
.process-detail-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 22px;
    margin-top: 34px;
}

.process-detail-card {
    padding: 28px;
    border-radius: 26px;
    background: var(--black-card);
    border: 1px solid var(--border);
    transition: 0.3s ease;
}

.process-detail-card:hover {
    transform: translateY(-6px);
    border-color: rgba(245,183,0,0.35);
}

.process-detail-card span {
    display: inline-flex;
    margin-bottom: 18px;
    color: var(--gold);
    font-size: 18px;
    font-weight: 900;
}

.process-detail-card h3 {
    font-size: 24px;
    line-height: 1.2;
    margin-bottom: 12px;
}

.process-detail-card p {
    color: var(--gray);
    line-height: 1.75;
}

/* Tablet */
@media (max-width: 992px) {
    .process-progress-header {
        flex-direction: column;
        align-items: flex-start;
    }

    .process-arrow-row {
        display: grid;
        gap: 14px;
    }

    .process-arrow-step,
    .process-arrow-step.is-first,
    .process-arrow-step.is-last {
        margin-left: 0;
        clip-path: none;
        border-radius: 22px;
        min-height: auto;
        padding: 24px;
    }

    .process-detail-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* Mobile */
@media (max-width: 640px) {
    .process-progress-box {
        padding: 24px;
        border-radius: 26px;
    }

    .process-icons {
        flex-wrap: wrap;
    }

    .process-icons span {
        width: 40px;
        height: 40px;
        font-size: 20px;
    }

    .process-detail-grid {
        grid-template-columns: 1fr;
    }

    .process-arrow-step h3 {
        font-size: 20px;
    }
}

/* =====================================================
   HOME PROCESS SECTION - 10-BIT MEDIA
   Quy trình triển khai dự án trên trang chủ
===================================================== */
.home-process-section {
    position: relative;
    overflow: hidden;
}

.home-process-board {
    position: relative;
    padding: 34px;
    border-radius: 34px;
    background:
        linear-gradient(135deg, rgba(193, 18, 31, 0.18), rgba(245, 183, 0, 0.08)),
        radial-gradient(circle at top left, rgba(193, 18, 31, 0.22), transparent 34%),
        radial-gradient(circle at bottom right, rgba(245, 183, 0, 0.16), transparent 32%),
        #121212;
    border: 1px solid rgba(245, 183, 0, 0.18);
    box-shadow: 0 30px 90px rgba(0, 0, 0, 0.35);
    overflow: hidden;
}

.home-process-board::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(120deg, rgba(255, 255, 255, 0.05), transparent 38%),
        repeating-linear-gradient(
            90deg,
            rgba(255, 255, 255, 0.025) 0,
            rgba(255, 255, 255, 0.025) 1px,
            transparent 1px,
            transparent 90px
        );
    pointer-events: none;
}

.home-process-board::after {
    content: "";
    position: absolute;
    width: 300px;
    height: 300px;
    right: -120px;
    bottom: -140px;
    background: radial-gradient(circle, rgba(245, 183, 0, 0.20), transparent 68%);
    pointer-events: none;
}

.home-process-icons {
    position: relative;
    z-index: 2;
    display: flex;
    justify-content: flex-end;
    flex-wrap: wrap;
    gap: 12px;
    margin-bottom: 26px;
}

.home-process-icons span {
    width: 42px;
    height: 42px;
    border-radius: 15px;
    display: grid;
    place-items: center;
    background:
        linear-gradient(135deg, rgba(193, 18, 31, 0.28), rgba(245, 183, 0, 0.14)),
        rgba(0, 0, 0, 0.38);
    border: 1px solid rgba(245, 183, 0, 0.25);
    box-shadow: 0 10px 28px rgba(0, 0, 0, 0.28);
    font-size: 20px;
}

.home-process-arrows {
    position: relative;
    z-index: 3;
    display: flex;
    align-items: stretch;
    gap: 0;
    width: 100%;
}

.home-process-arrow {
    position: relative;
    flex: 1;
    min-height: 108px;
    padding: 22px 32px 22px 42px;
    margin-left: -24px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    background:
        linear-gradient(135deg, #3a1515 0%, #7b1e22 48%, #b46d14 100%);
    color: #ffffff;
    clip-path: polygon(
        0 0,
        calc(100% - 34px) 0,
        100% 50%,
        calc(100% - 34px) 100%,
        0 100%,
        34px 50%
    );
    transition: 0.3s ease;
}

.home-process-arrow:first-child {
    margin-left: 0;
    background:
        linear-gradient(135deg, #f5b700 0%, #ff8a00 48%, #c1121f 100%);
    clip-path: polygon(
        0 0,
        calc(100% - 34px) 0,
        100% 50%,
        calc(100% - 34px) 100%,
        0 100%
    );
}

.home-process-arrow:last-child {
    background:
        linear-gradient(135deg, #c1121f 0%, #ff5a1f 48%, #f5b700 100%);
}

.home-process-arrow::after {
    content: "";
    position: absolute;
    inset: 1px;
    background:
        linear-gradient(135deg, rgba(255, 255, 255, 0.18), transparent 45%, rgba(245, 183, 0, 0.14));
    clip-path: inherit;
    pointer-events: none;
    opacity: 0.75;
}

.home-process-arrow:hover {
    transform: translateY(-7px) scale(1.012);
    z-index: 8;
    filter: brightness(1.12) saturate(1.08);
}

.home-process-arrow small,
.home-process-arrow h3 {
    position: relative;
    z-index: 2;
}

.home-process-arrow small {
    display: block;
    margin-bottom: 7px;
    font-size: 13px;
    font-weight: 900;
    color: rgba(255, 255, 255, 0.78);
    text-transform: uppercase;
    letter-spacing: 0.7px;
}

.home-process-arrow h3 {
    color: #ffffff;
    font-size: clamp(17px, 1.5vw, 22px);
    line-height: 1.18;
    font-weight: 900;
    letter-spacing: -0.5px;
}

@media (max-width: 992px) {
    .home-process-board {
        padding: 28px;
    }

    .home-process-icons {
        justify-content: flex-start;
    }

    .home-process-arrows {
        display: grid;
        gap: 14px;
    }

    .home-process-arrow,
    .home-process-arrow:first-child,
    .home-process-arrow:last-child {
        margin-left: 0;
        clip-path: none;
        border-radius: 22px;
        min-height: auto;
        padding: 22px;
    }

    .home-process-arrow::after {
        clip-path: none;
        border-radius: inherit;
    }
}

@media (max-width: 640px) {
    .home-process-board {
        padding: 22px;
        border-radius: 26px;
    }

    .home-process-icons span {
        width: 38px;
        height: 38px;
        font-size: 18px;
    }

    .home-process-arrow h3 {
        font-size: 19px;
    }
}
/* =====================================================
   ADMIN TESTIMONIALS
===================================================== */
.testimonial-admin-list {
    display: grid;
    gap: 22px;
    margin-top: 24px;
}

.testimonial-admin-card {
    padding: 24px;
    border-radius: 24px;
    background: rgba(255, 255, 255, 0.035);
    border: 1px solid var(--border);
}

.testimonial-admin-preview {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 22px;
    padding: 16px;
    border-radius: 18px;
    background: rgba(0, 0, 0, 0.18);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.testimonial-admin-preview img,
.testimonial-avatar-placeholder {
    width: 62px;
    height: 62px;
    border-radius: 18px;
    object-fit: cover;
    flex-shrink: 0;
}

.testimonial-avatar-placeholder {
    display: grid;
    place-items: center;
    color: var(--gold);
    font-weight: 900;
    font-size: 24px;
    background:
        linear-gradient(135deg, rgba(193,18,31,0.28), rgba(245,183,0,0.14)),
        #101010;
    border: 1px solid rgba(245,183,0,0.18);
}

.testimonial-admin-preview strong {
    color: var(--white);
    font-size: 18px;
}

.testimonial-admin-preview p {
    color: var(--gray);
    margin: 4px 0;
}

.testimonial-admin-preview span {
    color: var(--gold);
    letter-spacing: 2px;
}


/* =====================================================
   HOME TESTIMONIALS
===================================================== */
.testimonials-section {
    background:
        radial-gradient(circle at top left, rgba(193, 18, 31, 0.13), transparent 34%),
        radial-gradient(circle at bottom right, rgba(245, 183, 0, 0.10), transparent 30%),
        var(--black);
}

.testimonials-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}

.testimonial-card {
    position: relative;
    padding: 30px;
    border-radius: 28px;
    background:
        linear-gradient(135deg, rgba(255,255,255,0.055), rgba(255,255,255,0.018)),
        var(--black-card);
    border: 1px solid rgba(255,255,255,0.10);
    overflow: hidden;
    transition: 0.35s ease;
}

.testimonial-card::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at top right, rgba(245, 183, 0, 0.14), transparent 36%),
        radial-gradient(circle at bottom left, rgba(193, 18, 31, 0.15), transparent 38%);
    opacity: 0;
    transition: 0.35s ease;
    pointer-events: none;
}

.testimonial-card:hover {
    transform: translateY(-8px);
    border-color: rgba(245,183,0,0.36);
    box-shadow: 0 26px 80px rgba(0,0,0,0.34);
}

.testimonial-card:hover::before {
    opacity: 1;
}

.testimonial-stars,
.testimonial-content,
.testimonial-author {
    position: relative;
    z-index: 2;
}

.testimonial-stars {
    color: var(--gold);
    letter-spacing: 3px;
    font-size: 17px;
    margin-bottom: 20px;
}

.testimonial-content {
    color: #e7e7e7;
    line-height: 1.8;
    font-size: 16px;
    margin-bottom: 28px;
}

.testimonial-author {
    display: flex;
    align-items: center;
    gap: 14px;
}

.testimonial-author img,
.testimonial-avatar {
    width: 58px;
    height: 58px;
    border-radius: 18px;
    object-fit: cover;
    flex-shrink: 0;
}

.testimonial-avatar {
    display: grid;
    place-items: center;
    color: var(--gold);
    font-size: 22px;
    font-weight: 900;
    background:
        linear-gradient(135deg, rgba(193,18,31,0.28), rgba(245,183,0,0.14)),
        #101010;
    border: 1px solid rgba(245,183,0,0.18);
}

.testimonial-author h3 {
    font-size: 18px;
    line-height: 1.25;
}

.testimonial-author span {
    display: block;
    margin-top: 4px;
    color: var(--gray);
    font-size: 14px;
}

@media (max-width: 992px) {
    .testimonials-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 640px) {
    .testimonials-grid {
        grid-template-columns: 1fr;
    }

    .testimonial-card {
        padding: 24px;
        border-radius: 24px;
    }
}
/* =====================================================
   FIX HOME TESTIMONIALS - 10BIT MEDIA
===================================================== */
.testimonials-section {
    background:
        radial-gradient(circle at top left, rgba(193, 18, 31, 0.14), transparent 34%),
        radial-gradient(circle at bottom right, rgba(245, 183, 0, 0.10), transparent 32%),
        var(--black);
    overflow: hidden;
}

.testimonials-section .section-heading {
    max-width: 760px;
}

.testimonials-grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 24px !important;
    align-items: stretch;
}

.testimonial-card {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: 30px !important;
    border-radius: 28px !important;
    background:
        linear-gradient(135deg, rgba(255,255,255,0.055), rgba(255,255,255,0.018)),
        var(--black-card) !important;
    border: 1px solid rgba(255,255,255,0.10) !important;
    overflow: hidden;
    min-height: 360px;
    transition: 0.35s ease;
}

.testimonial-card::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at top right, rgba(245, 183, 0, 0.14), transparent 36%),
        radial-gradient(circle at bottom left, rgba(193, 18, 31, 0.16), transparent 38%);
    opacity: 0;
    transition: 0.35s ease;
    pointer-events: none;
}

.testimonial-card:hover {
    transform: translateY(-8px);
    border-color: rgba(245,183,0,0.36) !important;
    box-shadow: 0 26px 80px rgba(0,0,0,0.34);
}

.testimonial-card:hover::before {
    opacity: 1;
}

.testimonial-stars,
.testimonial-content,
.testimonial-author {
    position: relative;
    z-index: 2;
}

.testimonial-stars {
    color: var(--gold);
    letter-spacing: 3px;
    font-size: 16px;
    margin-bottom: 18px;
    line-height: 1;
}

.testimonial-content {
    color: #e7e7e7;
    line-height: 1.75;
    font-size: 16px;
    margin-bottom: 28px;
}

.testimonial-author {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-top: auto;
}

.testimonial-author img {
    width: 58px !important;
    height: 58px !important;
    min-width: 58px !important;
    max-width: 58px !important;
    max-height: 58px !important;
    border-radius: 18px !important;
    object-fit: cover !important;
    display: block !important;
}

.testimonial-avatar {
    width: 58px;
    height: 58px;
    min-width: 58px;
    border-radius: 18px;
    display: grid;
    place-items: center;
    color: var(--gold);
    font-size: 22px;
    font-weight: 900;
    background:
        linear-gradient(135deg, rgba(193,18,31,0.28), rgba(245,183,0,0.14)),
        #101010;
    border: 1px solid rgba(245,183,0,0.18);
}

.testimonial-author h3 {
    font-size: 18px !important;
    line-height: 1.25;
    margin: 0 0 4px !important;
    color: var(--white);
}

.testimonial-author span {
    display: block;
    color: var(--gray);
    font-size: 14px;
    line-height: 1.4;
}

/* Tablet */
@media (max-width: 992px) {
    .testimonials-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

/* Mobile */
@media (max-width: 640px) {
    .testimonials-grid {
        grid-template-columns: 1fr !important;
    }

    .testimonial-card {
        padding: 24px !important;
        border-radius: 24px !important;
        min-height: auto;
    }

    .testimonial-author img,
    .testimonial-avatar {
        width: 52px !important;
        height: 52px !important;
        min-width: 52px !important;
        max-width: 52px !important;
        max-height: 52px !important;
        border-radius: 16px !important;
    }
}

/* =====================================================
   FINAL OVERRIDE V2 - HOME TESTIMONIALS
   Ép đúng layout card và avatar nhỏ
===================================================== */
.testimonials-section {
    background:
        radial-gradient(circle at top left, rgba(193, 18, 31, 0.14), transparent 34%),
        radial-gradient(circle at bottom right, rgba(245, 183, 0, 0.10), transparent 32%),
        var(--black) !important;
    overflow: hidden !important;
}

.testimonials-section .section-heading {
    max-width: 760px !important;
}

.testimonials-grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 24px !important;
    align-items: stretch !important;
}

.testimonial-card {
    position: relative !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: space-between !important;
    padding: 30px !important;
    border-radius: 28px !important;
    background:
        linear-gradient(135deg, rgba(255,255,255,0.055), rgba(255,255,255,0.018)),
        var(--black-card) !important;
    border: 1px solid rgba(255,255,255,0.10) !important;
    overflow: hidden !important;
    min-height: 360px !important;
    transition: 0.35s ease !important;
}

.testimonial-card::before {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    background:
        radial-gradient(circle at top right, rgba(245, 183, 0, 0.14), transparent 36%),
        radial-gradient(circle at bottom left, rgba(193, 18, 31, 0.16), transparent 38%) !important;
    opacity: 0 !important;
    transition: 0.35s ease !important;
    pointer-events: none !important;
}

.testimonial-card:hover {
    transform: translateY(-8px) !important;
    border-color: rgba(245,183,0,0.36) !important;
    box-shadow: 0 26px 80px rgba(0,0,0,0.34) !important;
}

.testimonial-card:hover::before {
    opacity: 1 !important;
}

.testimonial-stars,
.testimonial-content,
.testimonial-author {
    position: relative !important;
    z-index: 2 !important;
}

.testimonial-stars {
    color: var(--gold) !important;
    letter-spacing: 3px !important;
    font-size: 16px !important;
    margin-bottom: 18px !important;
    line-height: 1 !important;
}

.testimonial-content {
    color: #e7e7e7 !important;
    line-height: 1.75 !important;
    font-size: 16px !important;
    margin-bottom: 28px !important;
}

.testimonial-author {
    display: flex !important;
    align-items: center !important;
    gap: 14px !important;
    margin-top: auto !important;
}

.testimonial-author img,
.testimonial-avatar {
    width: 58px !important;
    height: 58px !important;
    min-width: 58px !important;
    max-width: 58px !important;
    max-height: 58px !important;
    border-radius: 18px !important;
    object-fit: cover !important;
    flex-shrink: 0 !important;
}

.testimonial-author img {
    display: block !important;
}

.testimonial-avatar {
    display: grid !important;
    place-items: center !important;
    color: var(--gold) !important;
    font-size: 22px !important;
    font-weight: 900 !important;
    background:
        linear-gradient(135deg, rgba(193,18,31,0.28), rgba(245,183,0,0.14)),
        #101010 !important;
    border: 1px solid rgba(245,183,0,0.18) !important;
}

.testimonial-author h3 {
    font-size: 18px !important;
    line-height: 1.25 !important;
    margin: 0 0 4px !important;
    color: var(--white) !important;
}

.testimonial-author span {
    display: block !important;
    color: var(--gray) !important;
    font-size: 14px !important;
    line-height: 1.4 !important;
}

@media (max-width: 992px) {
    .testimonials-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 640px) {
    .testimonials-grid {
        grid-template-columns: 1fr !important;
    }

    .testimonial-card {
        padding: 24px !important;
        border-radius: 24px !important;
        min-height: auto !important;
    }

    .testimonial-author img,
    .testimonial-avatar {
        width: 52px !important;
        height: 52px !important;
        min-width: 52px !important;
        max-width: 52px !important;
        max-height: 52px !important;
        border-radius: 16px !important;
    }
}
/* =====================================================
   COMPACT TESTIMONIALS - THU NHỎ REVIEW CARD
===================================================== */
.testimonials-section {
    padding: 72px 0 !important;
}

.testimonials-section .section-heading {
    max-width: 680px !important;
    margin-bottom: 32px !important;
}

.testimonials-section .section-heading h2 {
    font-size: clamp(34px, 4vw, 52px) !important;
    line-height: 1.08 !important;
}

.testimonials-section .section-heading p {
    font-size: 16px !important;
    max-width: 720px !important;
}

.testimonials-grid {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 18px !important;
}

.testimonial-card {
    min-height: 260px !important;
    padding: 22px !important;
    border-radius: 22px !important;
}

.testimonial-stars {
    font-size: 13px !important;
    letter-spacing: 2px !important;
    margin-bottom: 14px !important;
}

.testimonial-content {
    font-size: 14.5px !important;
    line-height: 1.65 !important;
    margin-bottom: 22px !important;
}

.testimonial-author {
    gap: 11px !important;
}

.testimonial-author img,
.testimonial-avatar {
    width: 46px !important;
    height: 46px !important;
    min-width: 46px !important;
    max-width: 46px !important;
    max-height: 46px !important;
    border-radius: 14px !important;
}

.testimonial-author h3 {
    font-size: 15.5px !important;
    line-height: 1.2 !important;
}

.testimonial-author span {
    font-size: 12.5px !important;
    line-height: 1.35 !important;
}

/* Nếu có 4 review thì chia 4 cột cho gọn.
   Tablet xuống 2 cột, mobile xuống 1 cột. */
@media (max-width: 1180px) {
    .testimonials-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 640px) {
    .testimonials-section {
        padding: 60px 0 !important;
    }

    .testimonials-grid {
        grid-template-columns: 1fr !important;
        gap: 16px !important;
    }

    .testimonial-card {
        min-height: auto !important;
        padding: 20px !important;
        border-radius: 20px !important;
    }

    .testimonial-content {
        font-size: 14px !important;
    }
}


/* =====================================================
   TESTIMONIALS MARQUEE - COMPACT SLIDER
   Review khách hàng chạy ngang giống phần đối tác
===================================================== */
.testimonials-marquee-section {
    padding: 68px 0 !important;
    background:
        radial-gradient(circle at top left, rgba(193, 18, 31, 0.12), transparent 34%),
        radial-gradient(circle at bottom right, rgba(245, 183, 0, 0.08), transparent 32%),
        var(--black) !important;
    overflow: hidden !important;
}

.testimonials-heading {
    max-width: 700px !important;
    margin-bottom: 28px !important;
}

.testimonials-heading h2 {
    font-size: clamp(32px, 4vw, 50px) !important;
    line-height: 1.08 !important;
    letter-spacing: -1.7px !important;
}

.testimonials-heading p {
    max-width: 720px !important;
    font-size: 16px !important;
}

.testimonials-marquee {
    width: 100% !important;
    overflow: hidden !important;
    position: relative !important;
    padding: 10px 0 18px !important;
}

.testimonials-marquee::before,
.testimonials-marquee::after {
    content: "" !important;
    position: absolute !important;
    top: 0 !important;
    width: 120px !important;
    height: 100% !important;
    z-index: 5 !important;
    pointer-events: none !important;
}

.testimonials-marquee::before {
    left: 0 !important;
    background: linear-gradient(to right, var(--black) 0%, rgba(5,5,5,0.9) 25%, transparent 100%) !important;
}

.testimonials-marquee::after {
    right: 0 !important;
    background: linear-gradient(to left, var(--black) 0%, rgba(5,5,5,0.9) 25%, transparent 100%) !important;
}

.testimonials-track {
    display: flex !important;
    align-items: stretch !important;
    gap: 18px !important;
    width: max-content !important;
    padding-left: max(4vw, 54px) !important;
    padding-right: max(4vw, 54px) !important;
    animation: testimonialsMarqueeSlide 38s linear infinite !important;
    will-change: transform !important;
}

.testimonials-marquee:hover .testimonials-track {
    animation-play-state: paused !important;
}

.testimonial-slide-card {
    position: relative !important;
    flex: 0 0 310px !important;
    width: 310px !important;
    min-height: 220px !important;
    padding: 20px !important;
    border-radius: 22px !important;
    background:
        linear-gradient(135deg, rgba(255,255,255,0.055), rgba(255,255,255,0.018)),
        var(--black-card) !important;
    border: 1px solid rgba(255,255,255,0.10) !important;
    overflow: hidden !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: space-between !important;
    transition: 0.35s ease !important;
}

.testimonial-slide-card::before {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    background:
        radial-gradient(circle at top right, rgba(245,183,0,0.14), transparent 36%),
        radial-gradient(circle at bottom left, rgba(193,18,31,0.16), transparent 38%) !important;
    opacity: 0 !important;
    transition: 0.35s ease !important;
    pointer-events: none !important;
}

.testimonial-slide-card:hover {
    transform: translateY(-6px) !important;
    border-color: rgba(245,183,0,0.36) !important;
    box-shadow: 0 22px 60px rgba(0,0,0,0.30) !important;
}

.testimonial-slide-card:hover::before {
    opacity: 1 !important;
}

.testimonial-slide-card .testimonial-stars,
.testimonial-slide-card .testimonial-content,
.testimonial-slide-card .testimonial-author {
    position: relative !important;
    z-index: 2 !important;
}

.testimonial-slide-card .testimonial-stars {
    color: var(--gold) !important;
    letter-spacing: 2px !important;
    font-size: 13px !important;
    line-height: 1 !important;
    margin-bottom: 14px !important;
}

.testimonial-slide-card .testimonial-content {
    color: #e7e7e7 !important;
    font-size: 14px !important;
    line-height: 1.62 !important;
    margin-bottom: 20px !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 4 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
}

.testimonial-slide-card .testimonial-author {
    display: flex !important;
    align-items: center !important;
    gap: 11px !important;
    margin-top: auto !important;
}

.testimonial-slide-card .testimonial-author img,
.testimonial-slide-card .testimonial-avatar {
    width: 44px !important;
    height: 44px !important;
    min-width: 44px !important;
    max-width: 44px !important;
    max-height: 44px !important;
    border-radius: 14px !important;
    object-fit: cover !important;
    flex-shrink: 0 !important;
}

.testimonial-slide-card .testimonial-avatar {
    display: grid !important;
    place-items: center !important;
    color: var(--gold) !important;
    font-size: 18px !important;
    font-weight: 900 !important;
    background:
        linear-gradient(135deg, rgba(193,18,31,0.28), rgba(245,183,0,0.14)),
        #101010 !important;
    border: 1px solid rgba(245,183,0,0.18) !important;
}

.testimonial-slide-card .testimonial-author h3 {
    color: var(--white) !important;
    font-size: 15px !important;
    line-height: 1.2 !important;
    margin: 0 0 3px !important;
}

.testimonial-slide-card .testimonial-author span {
    display: block !important;
    color: var(--gray) !important;
    font-size: 12px !important;
    line-height: 1.35 !important;
}

@keyframes testimonialsMarqueeSlide {
    from {
        transform: translateX(0);
    }

    to {
        transform: translateX(-50%);
    }
}

@media (max-width: 768px) {
    .testimonials-marquee-section {
        padding: 56px 0 !important;
    }

    .testimonials-heading {
        margin-bottom: 22px !important;
    }

    .testimonials-heading h2 {
        font-size: 34px !important;
        letter-spacing: -1.2px !important;
    }

    .testimonials-track {
        gap: 14px !important;
        padding-left: 24px !important;
        padding-right: 24px !important;
        animation-duration: 30s !important;
    }

    .testimonial-slide-card {
        flex-basis: 270px !important;
        width: 270px !important;
        min-height: 210px !important;
        padding: 18px !important;
        border-radius: 20px !important;
    }

    .testimonials-marquee::before,
    .testimonials-marquee::after {
        width: 48px !important;
    }
}


/* =====================================================
   TESTIMONIALS MARQUEE FINAL - 10BIT MEDIA
   Review chạy ngang giống phần đối tác, card nhỏ gọn
===================================================== */
.tm-section {
    position: relative !important;
    padding: 68px 0 !important;
    background:
        radial-gradient(circle at top left, rgba(193, 18, 31, 0.13), transparent 34%),
        radial-gradient(circle at bottom right, rgba(245, 183, 0, 0.10), transparent 32%),
        var(--black) !important;
    overflow: hidden !important;
}

.tm-section .tm-heading {
    max-width: 720px !important;
    margin-bottom: 30px !important;
}

.tm-section .tm-heading h2 {
    font-size: clamp(32px, 4vw, 50px) !important;
    line-height: 1.08 !important;
}

.tm-section .tm-heading p {
    font-size: 16px !important;
}

.tm-marquee {
    position: relative !important;
    width: 100% !important;
    overflow: hidden !important;
    padding: 8px 0 14px !important;
}

.tm-marquee::before,
.tm-marquee::after {
    content: "" !important;
    position: absolute !important;
    top: 0 !important;
    width: 130px !important;
    height: 100% !important;
    z-index: 5 !important;
    pointer-events: none !important;
}

.tm-marquee::before {
    left: 0 !important;
    background: linear-gradient(to right, var(--black) 0%, rgba(5,5,5,0.86) 35%, transparent 100%) !important;
}

.tm-marquee::after {
    right: 0 !important;
    background: linear-gradient(to left, var(--black) 0%, rgba(5,5,5,0.86) 35%, transparent 100%) !important;
}

.tm-track {
    display: flex !important;
    align-items: stretch !important;
    gap: 18px !important;
    width: max-content !important;
    padding-left: max(4vw, 42px) !important;
    padding-right: max(4vw, 42px) !important;
    animation: tmSlide 34s linear infinite !important;
    will-change: transform !important;
}

.tm-marquee:hover .tm-track {
    animation-play-state: paused !important;
}

.tm-card {
    position: relative !important;
    flex: 0 0 330px !important;
    width: 330px !important;
    min-height: 218px !important;
    padding: 20px !important;
    border-radius: 22px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: space-between !important;
    background:
        linear-gradient(135deg, rgba(255,255,255,0.055), rgba(255,255,255,0.018)),
        var(--black-card) !important;
    border: 1px solid rgba(255,255,255,0.11) !important;
    overflow: hidden !important;
    transition: transform .3s ease, border-color .3s ease, box-shadow .3s ease !important;
}

.tm-card::before {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    background:
        radial-gradient(circle at top right, rgba(245,183,0,0.13), transparent 38%),
        radial-gradient(circle at bottom left, rgba(193,18,31,0.16), transparent 42%) !important;
    opacity: 0 !important;
    transition: opacity .3s ease !important;
    pointer-events: none !important;
}

.tm-card:hover {
    transform: translateY(-6px) !important;
    border-color: rgba(245,183,0,0.38) !important;
    box-shadow: 0 20px 60px rgba(0,0,0,0.30) !important;
}

.tm-card:hover::before {
    opacity: 1 !important;
}

.tm-stars,
.tm-content,
.tm-author {
    position: relative !important;
    z-index: 2 !important;
}

.tm-stars {
    color: var(--gold) !important;
    font-size: 13px !important;
    line-height: 1 !important;
    letter-spacing: 2px !important;
    margin-bottom: 13px !important;
}

.tm-content {
    color: #e8e8e8 !important;
    font-size: 14px !important;
    line-height: 1.62 !important;
    margin: 0 0 20px !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 4 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
}

.tm-author {
    display: flex !important;
    align-items: center !important;
    gap: 11px !important;
    margin-top: auto !important;
}

.tm-author img,
.tm-avatar {
    width: 44px !important;
    height: 44px !important;
    min-width: 44px !important;
    max-width: 44px !important;
    max-height: 44px !important;
    border-radius: 14px !important;
    object-fit: cover !important;
    flex-shrink: 0 !important;
    display: block !important;
}

.tm-avatar {
    display: grid !important;
    place-items: center !important;
    color: var(--gold) !important;
    font-size: 18px !important;
    font-weight: 900 !important;
    background:
        linear-gradient(135deg, rgba(193,18,31,0.28), rgba(245,183,0,0.14)),
        #101010 !important;
    border: 1px solid rgba(245,183,0,0.18) !important;
}

.tm-author-info {
    min-width: 0 !important;
}

.tm-author h3 {
    color: var(--white) !important;
    font-size: 15px !important;
    line-height: 1.2 !important;
    margin: 0 0 3px !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

.tm-author span {
    display: block !important;
    color: var(--gray) !important;
    font-size: 12px !important;
    line-height: 1.3 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

@keyframes tmSlide {
    from {
        transform: translateX(0);
    }

    to {
        transform: translateX(-50%);
    }
}

@media (max-width: 768px) {
    .tm-section {
        padding: 58px 0 !important;
    }

    .tm-card {
        flex-basis: 280px !important;
        width: 280px !important;
        min-height: 210px !important;
        padding: 18px !important;
        border-radius: 20px !important;
    }

    .tm-track {
        gap: 14px !important;
        padding-left: 24px !important;
        padding-right: 24px !important;
        animation-duration: 28s !important;
    }

    .tm-marquee::before,
    .tm-marquee::after {
        width: 52px !important;
    }

    .tm-section .tm-heading h2 {
        font-size: clamp(30px, 9vw, 42px) !important;
    }
}
/* =====================================================
   TESTIMONIALS SLIDER FINAL - UNIQUE TM CLASSES
===================================================== */
.tm-testimonials {
    padding: 72px 0 !important;
    background:
        radial-gradient(circle at top left, rgba(193, 18, 31, 0.12), transparent 34%),
        radial-gradient(circle at bottom right, rgba(245, 183, 0, 0.10), transparent 32%),
        var(--black) !important;
    overflow: hidden !important;
}

.tm-testimonials .section-heading {
    max-width: 720px !important;
    margin-bottom: 28px !important;
}

.tm-testimonials .section-heading h2 {
    font-size: clamp(32px, 4vw, 50px) !important;
    line-height: 1.08 !important;
}

.tm-testimonials .section-heading p {
    font-size: 16px !important;
}

.tm-marquee {
    width: 100% !important;
    overflow: hidden !important;
    position: relative !important;
    padding: 10px 0 14px !important;
}

.tm-marquee::before,
.tm-marquee::after {
    content: "" !important;
    position: absolute !important;
    top: 0 !important;
    width: 130px !important;
    height: 100% !important;
    z-index: 5 !important;
    pointer-events: none !important;
}

.tm-marquee::before {
    left: 0 !important;
    background: linear-gradient(to right, var(--black), transparent) !important;
}

.tm-marquee::after {
    right: 0 !important;
    background: linear-gradient(to left, var(--black), transparent) !important;
}

.tm-track {
    display: flex !important;
    align-items: stretch !important;
    gap: 18px !important;
    width: max-content !important;
    padding-left: max(4vw, 42px) !important;
    padding-right: max(4vw, 42px) !important;
    animation: tmSlide 34s linear infinite !important;
    will-change: transform !important;
}

.tm-marquee:hover .tm-track {
    animation-play-state: paused !important;
}

.tm-card {
    flex: 0 0 330px !important;
    width: 330px !important;
    min-height: 218px !important;
    padding: 20px !important;
    border-radius: 22px !important;
    background:
        linear-gradient(135deg, rgba(255,255,255,0.055), rgba(255,255,255,0.018)),
        var(--black-card) !important;
    border: 1px solid rgba(255,255,255,0.11) !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: space-between !important;
    overflow: hidden !important;
    transition: 0.3s ease !important;
}

.tm-card:hover {
    transform: translateY(-6px) !important;
    border-color: rgba(245, 183, 0, 0.38) !important;
    box-shadow: 0 20px 60px rgba(0,0,0,0.32) !important;
}

.tm-stars {
    color: var(--gold) !important;
    font-size: 13px !important;
    letter-spacing: 2px !important;
    line-height: 1 !important;
    margin-bottom: 14px !important;
}

.tm-content {
    color: #e8e8e8 !important;
    font-size: 14px !important;
    line-height: 1.65 !important;
    margin-bottom: 20px !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 4 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
}

.tm-author {
    display: flex !important;
    align-items: center !important;
    gap: 11px !important;
    margin-top: auto !important;
}

.tm-author img,
.tm-avatar {
    width: 44px !important;
    height: 44px !important;
    min-width: 44px !important;
    max-width: 44px !important;
    max-height: 44px !important;
    border-radius: 14px !important;
    object-fit: cover !important;
    flex-shrink: 0 !important;
}

.tm-avatar {
    display: grid !important;
    place-items: center !important;
    color: var(--gold) !important;
    font-size: 18px !important;
    font-weight: 900 !important;
    background:
        linear-gradient(135deg, rgba(193,18,31,0.28), rgba(245,183,0,0.14)),
        #101010 !important;
    border: 1px solid rgba(245,183,0,0.18) !important;
}

.tm-author h3 {
    font-size: 15px !important;
    line-height: 1.2 !important;
    margin: 0 0 3px !important;
    color: var(--white) !important;
}

.tm-author span {
    display: block !important;
    color: var(--gray) !important;
    font-size: 12px !important;
    line-height: 1.3 !important;
}

@keyframes tmSlide {
    from {
        transform: translateX(0);
    }

    to {
        transform: translateX(-50%);
    }
}

@media (max-width: 768px) {
    .tm-testimonials {
        padding: 58px 0 !important;
    }

    .tm-card {
        flex-basis: 280px !important;
        width: 280px !important;
        min-height: 210px !important;
        padding: 18px !important;
    }

    .tm-track {
        gap: 14px !important;
        animation-duration: 28s !important;
    }

    .tm-marquee::before,
    .tm-marquee::after {
        width: 54px !important;
    }
}


/* =====================================================
   REVIEW SLIDER FINAL - RVX UNIQUE CLASSES
   Dự phòng trong style.css
===================================================== */
.rvx-section {
    position: relative !important;
    padding: 70px 0 !important;
    background:
        radial-gradient(circle at top left, rgba(193, 18, 31, 0.12), transparent 34%),
        radial-gradient(circle at bottom right, rgba(245, 183, 0, 0.10), transparent 32%),
        var(--black) !important;
    overflow: hidden !important;
}

.rvx-section .rvx-heading {
    max-width: 720px !important;
    margin-bottom: 28px !important;
}

.rvx-section .rvx-heading h2 {
    font-size: clamp(32px, 4vw, 50px) !important;
    line-height: 1.08 !important;
}

.rvx-section .rvx-heading p {
    font-size: 16px !important;
}

.rvx-marquee {
    width: 100% !important;
    overflow: hidden !important;
    position: relative !important;
    padding: 8px 0 12px !important;
}

.rvx-marquee::before,
.rvx-marquee::after {
    content: "" !important;
    position: absolute !important;
    top: 0 !important;
    width: 120px !important;
    height: 100% !important;
    z-index: 5 !important;
    pointer-events: none !important;
}

.rvx-marquee::before {
    left: 0 !important;
    background: linear-gradient(to right, var(--black), rgba(5,5,5,0.86) 35%, transparent) !important;
}

.rvx-marquee::after {
    right: 0 !important;
    background: linear-gradient(to left, var(--black), rgba(5,5,5,0.86) 35%, transparent) !important;
}

.rvx-track {
    display: flex !important;
    align-items: stretch !important;
    gap: 16px !important;
    width: max-content !important;
    padding-left: max(4vw, 42px) !important;
    padding-right: max(4vw, 42px) !important;
    animation: rvxSlide 34s linear infinite !important;
    will-change: transform !important;
}

.rvx-marquee:hover .rvx-track {
    animation-play-state: paused !important;
}

.rvx-card {
    position: relative !important;
    flex: 0 0 315px !important;
    width: 315px !important;
    min-height: 205px !important;
    padding: 18px !important;
    border-radius: 20px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: space-between !important;
    background:
        linear-gradient(135deg, rgba(255,255,255,0.055), rgba(255,255,255,0.018)),
        var(--black-card) !important;
    border: 1px solid rgba(255,255,255,0.11) !important;
    overflow: hidden !important;
    transition: transform .3s ease, border-color .3s ease, box-shadow .3s ease !important;
}

.rvx-card::before {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    background:
        radial-gradient(circle at top right, rgba(245,183,0,0.13), transparent 38%),
        radial-gradient(circle at bottom left, rgba(193,18,31,0.16), transparent 42%) !important;
    opacity: 0 !important;
    transition: opacity .3s ease !important;
    pointer-events: none !important;
}

.rvx-card:hover {
    transform: translateY(-6px) !important;
    border-color: rgba(245,183,0,0.38) !important;
    box-shadow: 0 20px 60px rgba(0,0,0,0.30) !important;
}

.rvx-card:hover::before {
    opacity: 1 !important;
}

.rvx-stars,
.rvx-content,
.rvx-author {
    position: relative !important;
    z-index: 2 !important;
}

.rvx-stars {
    color: var(--gold) !important;
    font-size: 12px !important;
    line-height: 1 !important;
    letter-spacing: 2px !important;
    margin-bottom: 12px !important;
}

.rvx-content {
    color: #e8e8e8 !important;
    font-size: 13.5px !important;
    line-height: 1.6 !important;
    margin: 0 0 18px !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 4 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
}

.rvx-author {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    margin-top: auto !important;
}

.rvx-author img,
.rvx-avatar {
    width: 42px !important;
    height: 42px !important;
    min-width: 42px !important;
    max-width: 42px !important;
    max-height: 42px !important;
    border-radius: 13px !important;
    object-fit: cover !important;
    flex-shrink: 0 !important;
    display: block !important;
}

.rvx-avatar {
    display: grid !important;
    place-items: center !important;
    color: var(--gold) !important;
    font-size: 17px !important;
    font-weight: 900 !important;
    background:
        linear-gradient(135deg, rgba(193,18,31,0.28), rgba(245,183,0,0.14)),
        #101010 !important;
    border: 1px solid rgba(245,183,0,0.18) !important;
}

.rvx-author-info {
    min-width: 0 !important;
}

.rvx-author h3 {
    color: var(--white) !important;
    font-size: 14.5px !important;
    line-height: 1.2 !important;
    margin: 0 0 3px !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

.rvx-author span {
    display: block !important;
    color: var(--gray) !important;
    font-size: 11.5px !important;
    line-height: 1.3 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

@keyframes rvxSlide {
    from {
        transform: translateX(0);
    }

    to {
        transform: translateX(-50%);
    }
}

@media (max-width: 768px) {
    .rvx-section {
        padding: 58px 0 !important;
    }

    .rvx-card {
        flex-basis: 270px !important;
        width: 270px !important;
        min-height: 200px !important;
        padding: 17px !important;
    }

    .rvx-track {
        gap: 14px !important;
        animation-duration: 28s !important;
    }

    .rvx-marquee::before,
    .rvx-marquee::after {
        width: 52px !important;
    }
}




/* =====================================================
   FEEDBACK PREMIUM SLIDER - FDX UNIQUE CLASSES
   Card cao cấp: ảnh nền mờ, quote lớn, swipe mobile
===================================================== */
.fdx-section {
    position: relative !important;
    padding: 82px 0 88px !important;
    background:
        radial-gradient(circle at 10% 18%, rgba(193,18,31,0.18), transparent 32%),
        radial-gradient(circle at 86% 82%, rgba(245,183,0,0.12), transparent 30%),
        linear-gradient(180deg, #050505 0%, #080808 100%) !important;
    overflow: hidden !important;
}

.fdx-heading {
    max-width: 760px !important;
    margin: 0 auto 34px !important;
    text-align: center !important;
}

.fdx-heading .eyebrow {
    margin-bottom: 12px !important;
}

.fdx-heading h2 {
    font-size: clamp(32px, 4.4vw, 56px) !important;
    line-height: 1.06 !important;
    letter-spacing: -2px !important;
    margin-bottom: 14px !important;
}

.fdx-heading p {
    color: var(--gray) !important;
    font-size: 16.5px !important;
    line-height: 1.75 !important;
}

.fdx-slider-shell {
    position: relative !important;
    width: min(1080px, 92vw) !important;
    margin: 0 auto !important;
    padding: 8px 58px 0 !important;
}

.fdx-viewport {
    position: relative !important;
    overflow: hidden !important;
    width: 100% !important;
    padding: 58px 0 26px !important;
    cursor: grab !important;
    touch-action: pan-y !important;
}

.fdx-viewport.is-dragging {
    cursor: grabbing !important;
}

.fdx-track {
    display: flex !important;
    align-items: stretch !important;
    gap: 24px !important;
    will-change: transform !important;
    transition: transform 0.72s cubic-bezier(.22, 1, .36, 1) !important;
}

.fdx-viewport.is-dragging .fdx-track {
    transition: none !important;
}

.fdx-slide {
    position: relative !important;
    flex: 0 0 min(430px, 78vw) !important;
    width: min(430px, 78vw) !important;
    min-height: 318px !important;
    padding: 58px 28px 28px !important;
    border-radius: 32px !important;
    background:
        linear-gradient(145deg, rgba(255,255,255,0.96), rgba(246,241,232,0.98)) !important;
    border: 2px solid rgba(245,183,0,0.72) !important;
    box-shadow:
        0 30px 80px rgba(0,0,0,0.42),
        inset 0 1px 0 rgba(255,255,255,0.78) !important;
    overflow: visible !important;
    opacity: 0.58 !important;
    transform: scale(0.92) translateY(10px) !important;
    transition:
        opacity 0.55s ease,
        transform 0.55s ease,
        border-color 0.55s ease,
        box-shadow 0.55s ease !important;
}

.fdx-slide.is-active {
    opacity: 1 !important;
    transform: scale(1) translateY(0) !important;
    border-color: rgba(255,78,36,0.92) !important;
    box-shadow:
        0 38px 100px rgba(0,0,0,0.54),
        0 0 0 1px rgba(245,183,0,0.18),
        inset 0 1px 0 rgba(255,255,255,0.8) !important;
}

.fdx-slide::before {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    border-radius: inherit !important;
    background:
        linear-gradient(180deg, rgba(255,255,255,0.78), rgba(255,255,255,0.92)),
        var(--fdx-bg, radial-gradient(circle at top left, rgba(245,183,0,0.25), transparent 46%)) !important;
    background-size: cover !important;
    background-position: center !important;
    filter: blur(0px) !important;
    opacity: 0.58 !important;
    pointer-events: none !important;
    z-index: 0 !important;
}

.fdx-slide::after {
    content: "“" !important;
    position: absolute !important;
    left: 26px !important;
    top: 18px !important;
    z-index: 1 !important;
    color: rgba(193,18,31,0.16) !important;
    font-size: 118px !important;
    line-height: .8 !important;
    font-family: Georgia, serif !important;
    font-weight: 900 !important;
    pointer-events: none !important;
}

.fdx-avatar-wrap {
    position: absolute !important;
    left: 50% !important;
    top: -48px !important;
    z-index: 4 !important;
    transform: translateX(-50%) !important;
}

.fdx-avatar,
.fdx-avatar-fallback {
    width: 92px !important;
    height: 92px !important;
    border-radius: 50% !important;
    border: 6px solid var(--red) !important;
    outline: 5px solid var(--gold) !important;
    box-shadow: 0 16px 38px rgba(0,0,0,0.34) !important;
    object-fit: cover !important;
    background: #fff !important;
    display: grid !important;
    place-items: center !important;
}

.fdx-avatar-fallback {
    color: #fff !important;
    font-size: 34px !important;
    font-weight: 900 !important;
    background: linear-gradient(135deg, var(--red), var(--gold)) !important;
}

.fdx-content,
.fdx-person,
.fdx-rating {
    position: relative !important;
    z-index: 2 !important;
}

.fdx-title {
    color: #1f1f1f !important;
    font-size: 28px !important;
    line-height: 1.18 !important;
    font-weight: 900 !important;
    text-align: center !important;
    margin: 0 0 12px !important;
    letter-spacing: -0.8px !important;
}

.fdx-text {
    max-width: 350px !important;
    min-height: 92px !important;
    margin: 0 auto 18px !important;
    color: #4a4a4a !important;
    font-size: 15.5px !important;
    line-height: 1.65 !important;
    text-align: center !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 4 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
}

.fdx-person {
    text-align: center !important;
    margin-top: auto !important;
}

.fdx-person h3 {
    color: #1f1f1f !important;
    font-size: 19px !important;
    line-height: 1.2 !important;
    font-weight: 900 !important;
    margin: 0 0 4px !important;
}

.fdx-person span {
    display: block !important;
    color: #717171 !important;
    font-size: 13px !important;
    line-height: 1.4 !important;
}

.fdx-rating {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 5px !important;
    min-width: 142px !important;
    padding: 8px 16px !important;
    border-radius: 999px !important;
    background: linear-gradient(135deg, #ffd24a, var(--gold)) !important;
    border: 4px solid var(--red) !important;
    color: #7a3d00 !important;
    font-size: 17px !important;
    line-height: 1 !important;
    letter-spacing: 2px !important;
    font-weight: 900 !important;
    position: absolute !important;
    left: 50% !important;
    bottom: -22px !important;
    transform: translateX(-50%) !important;
    box-shadow: 0 12px 26px rgba(193,18,31,0.26) !important;
}

.fdx-nav {
    position: absolute !important;
    top: 55% !important;
    transform: translateY(-50%) !important;
    z-index: 12 !important;
    width: 48px !important;
    height: 48px !important;
    border-radius: 50% !important;
    border: 1px solid rgba(255,255,255,0.14) !important;
    background: rgba(17,17,17,0.88) !important;
    color: #fff !important;
    display: grid !important;
    place-items: center !important;
    cursor: pointer !important;
    font-size: 23px !important;
    line-height: 1 !important;
    transition: transform .25s ease, background .25s ease, border-color .25s ease !important;
}

.fdx-nav:hover {
    background: linear-gradient(135deg, var(--red), var(--gold)) !important;
    border-color: transparent !important;
    transform: translateY(-50%) scale(1.07) !important;
}

.fdx-prev { left: 0 !important; }
.fdx-next { right: 0 !important; }

.fdx-dots {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 9px !important;
    margin-top: 18px !important;
}

.fdx-dot {
    width: 10px !important;
    height: 10px !important;
    border: 0 !important;
    border-radius: 999px !important;
    background: rgba(255,255,255,0.22) !important;
    cursor: pointer !important;
    transition: width .28s ease, background .28s ease !important;
    padding: 0 !important;
}

.fdx-dot.is-active {
    width: 34px !important;
    background: linear-gradient(135deg, var(--red), var(--gold)) !important;
}

@media (max-width: 992px) {
    .fdx-slider-shell {
        width: min(760px, 92vw) !important;
        padding: 0 52px !important;
    }

    .fdx-slide {
        flex-basis: min(390px, 78vw) !important;
        width: min(390px, 78vw) !important;
    }
}

@media (max-width: 640px) {
    .fdx-section {
        padding: 58px 0 66px !important;
    }

    .fdx-heading {
        margin-bottom: 22px !important;
    }

    .fdx-heading h2 {
        font-size: 32px !important;
        letter-spacing: -1.2px !important;
    }

    .fdx-heading p {
        font-size: 14.5px !important;
    }

    .fdx-slider-shell {
        width: 100% !important;
        padding: 0 !important;
    }

    .fdx-viewport {
        padding: 50px 0 24px !important;
    }

    .fdx-track {
        gap: 16px !important;
    }

    .fdx-slide {
        flex: 0 0 84vw !important;
        width: 84vw !important;
        min-height: 286px !important;
        padding: 50px 20px 26px !important;
        border-radius: 26px !important;
        opacity: 0.42 !important;
        transform: scale(0.94) !important;
    }

    .fdx-slide.is-active {
        opacity: 1 !important;
        transform: scale(1) !important;
    }

    .fdx-avatar,
    .fdx-avatar-fallback {
        width: 78px !important;
        height: 78px !important;
        border-width: 5px !important;
        outline-width: 4px !important;
    }

    .fdx-avatar-wrap {
        top: -40px !important;
    }

    .fdx-slide::after {
        font-size: 88px !important;
        left: 18px !important;
        top: 18px !important;
    }

    .fdx-title {
        font-size: 22px !important;
    }

    .fdx-text {
        min-height: 86px !important;
        font-size: 14px !important;
        line-height: 1.58 !important;
        -webkit-line-clamp: 4 !important;
    }

    .fdx-person h3 {
        font-size: 17px !important;
    }

    .fdx-person span {
        font-size: 12px !important;
    }

    .fdx-rating {
        min-width: 124px !important;
        font-size: 15px !important;
        padding: 7px 14px !important;
        bottom: -19px !important;
    }

    .fdx-nav {
        display: none !important;
    }

    .fdx-dots {
        margin-top: 14px !important;
    }
}



/* =====================================================
   CONTACT SETTINGS / FOOTER / FLOATING CONTACT
===================================================== */
.footer-socials {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 22px;
}

.footer-socials a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-top: 0;
    padding: 9px 13px;
    border-radius: 999px;
    color: var(--white);
    font-size: 13px;
    font-weight: 800;
    background:
        linear-gradient(135deg, rgba(193, 18, 31, 0.26), rgba(245, 183, 0, 0.12)),
        rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.10);
    transition: 0.3s ease;
}

.footer-socials a:hover {
    color: var(--gold);
    border-color: rgba(245, 183, 0, 0.38);
    transform: translateY(-3px);
}

.floating-contact-group {
    position: fixed;
    right: 22px;
    bottom: 24px;
    z-index: 9998;
    display: grid;
    gap: 10px;
}

.floating-contact-button {
    width: 54px;
    height: 54px;
    border-radius: 999px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #ffffff;
    border: 1px solid rgba(255, 255, 255, 0.14);
    box-shadow: 0 16px 38px rgba(0, 0, 0, 0.34);
    transition: 0.28s ease;
    overflow: hidden;
    position: relative;
}

.floating-contact-button span {
    position: relative;
    z-index: 2;
    font-size: 20px;
    font-weight: 900;
}

.floating-contact-button strong {
    position: absolute;
    right: 64px;
    top: 50%;
    transform: translateY(-50%) translateX(10px);
    opacity: 0;
    pointer-events: none;
    white-space: nowrap;
    padding: 8px 11px;
    border-radius: 999px;
    font-size: 13px;
    background: rgba(0, 0, 0, 0.78);
    border: 1px solid rgba(255, 255, 255, 0.12);
    transition: 0.28s ease;
}

.floating-contact-button:hover {
    transform: translateY(-4px) scale(1.04);
}

.floating-contact-button:hover strong {
    opacity: 1;
    transform: translateY(-50%) translateX(0);
}

.floating-messenger {
    background: linear-gradient(135deg, #0078ff, #00c6ff);
}

.floating-zalo {
    background: linear-gradient(135deg, #0068ff, #00a3ff);
}

.floating-phone {
    background: linear-gradient(135deg, var(--red), var(--gold));
}

.admin-form-section {
    padding: 24px;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.035);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.admin-form-section h3 {
    font-size: 22px;
    margin-bottom: 18px;
    color: var(--white);
}

.contact-settings-form textarea {
    min-height: 100px;
}

.contact-toggle-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
}

.contact-toggle-card {
    padding: 16px;
    border-radius: 18px;
    background: rgba(0, 0, 0, 0.18);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.admin-help-text {
    margin-top: 14px;
    color: var(--gray);
    font-size: 14px;
}

@media (max-width: 768px) {
    .floating-contact-group {
        right: 14px;
        bottom: 16px;
        gap: 8px;
    }

    .floating-contact-button {
        width: 48px;
        height: 48px;
    }

    .floating-contact-button strong {
        display: none;
    }

    .contact-toggle-grid {
        grid-template-columns: 1fr;
    }
}



/* =====================================================
   PREMIUM CONTACT SETTINGS / FOOTER SOCIALS SUPPORT
   Hỗ trợ giao diện admin cài đặt nút nổi & footer social
===================================================== */
.admin-form-section {
    padding: 24px !important;
    border-radius: 22px !important;
    background: rgba(255, 255, 255, 0.035) !important;
    border: 1px solid rgba(255, 255, 255, 0.08) !important;
}

.admin-form-section h3 {
    font-size: 22px !important;
    margin-bottom: 18px !important;
    color: var(--white) !important;
}

.contact-settings-form textarea {
    min-height: 100px !important;
}

.contact-toggle-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)) !important;
    gap: 14px !important;
}

.contact-toggle-card {
    padding: 16px !important;
    border-radius: 18px !important;
    background: rgba(0, 0, 0, 0.18) !important;
    border: 1px solid rgba(255, 255, 255, 0.08) !important;
}

.admin-help-text {
    margin-top: 14px !important;
    color: var(--gray) !important;
    font-size: 14px !important;
}

.footer-socials {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 18px;
}

.footer-socials a {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    margin-top: 0 !important;
    padding: 9px 13px;
    border-radius: 999px;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.10);
    color: var(--gray);
    font-size: 13px;
    font-weight: 800;
    transition: 0.25s ease;
}

.footer-socials a:hover {
    color: var(--gold);
    border-color: rgba(245, 183, 0, 0.38);
    transform: translateY(-3px);
}

@media (max-width: 768px) {
    .contact-toggle-grid {
        grid-template-columns: 1fr !important;
    }
}


/* =====================================================
   HOME SETTINGS ADMIN - FULL FORM SUPPORT
===================================================== */
.home-settings-admin .admin-form-section {
    padding: 24px;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.035);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.home-settings-admin .admin-form-section h3 {
    font-size: 22px;
    margin-bottom: 18px;
    color: var(--white);
}

.home-settings-admin textarea {
    min-height: 108px;
}

.home-settings-admin .settings-divider {
    border: 0;
    border-top: 1px solid var(--border);
    margin: 12px 0;
}

.home-settings-admin .admin-help-text {
    color: var(--gray);
    font-size: 14px;
    margin-top: 8px;
}

.home-settings-admin .checkbox-row {
    padding: 14px 16px;
    border-radius: 16px;
    background: rgba(0,0,0,0.18);
    border: 1px solid rgba(255,255,255,0.08);
}

.home-settings-admin input[type="file"] {
    padding: 12px;
}

.home-settings-admin .current-path {
    margin-top: 8px;
    color: var(--gray);
    font-size: 13px;
    word-break: break-all;
}

.home-settings-admin .quick-note {
    padding: 16px 18px;
    border-radius: 18px;
    background: rgba(245, 183, 0, 0.08);
    border: 1px solid rgba(245, 183, 0, 0.18);
    color: var(--gray);
}

.home-settings-admin .quick-note strong {
    color: var(--gold);
}

@media (max-width: 768px) {
    .home-settings-admin .admin-form-section {
        padding: 20px;
    }
}



/* =====================================================
   HERO SLIDE ADMIN EDITOR
===================================================== */
.hero-slide-admin-heading {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 18px;
}

.hero-slide-editor {
    display: grid;
    gap: 18px;
}

.hero-slide-admin-card {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 20px;
    padding: 18px;
    border-radius: 22px;
    background: rgba(255,255,255,0.035);
    border: 1px solid rgba(255,255,255,0.10);
}

.hero-slide-preview {
    min-height: 210px;
    border-radius: 20px;
    padding: 20px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    background:
        linear-gradient(180deg, rgba(5,5,5,.12), rgba(5,5,5,.76)),
        linear-gradient(135deg, rgba(193,18,31,.38), rgba(245,183,0,.18)),
        #151515;
    background-size: cover;
    background-position: center;
    border: 1px solid rgba(255,255,255,0.12);
    overflow: hidden;
}

.hero-slide-preview span {
    color: var(--gold);
    font-weight: 900;
    letter-spacing: 2px;
    font-size: 12px;
    margin-bottom: 8px;
}

.hero-slide-preview strong {
    color: var(--white);
    font-size: 25px;
    line-height: 1.1;
}

.hero-slide-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    flex-wrap: wrap;
}

.danger-check span {
    color: #ffb4b4;
}

@media (max-width: 920px) {
    .hero-slide-admin-heading {
        align-items: flex-start;
        flex-direction: column;
    }

    .hero-slide-admin-card {
        grid-template-columns: 1fr;
    }
}



/* =====================================================
   HOME SERVICES FROM ADMIN
===================================================== */
.home-services-admin-grid{align-items:stretch}.home-service-card{position:relative;min-height:260px;display:flex;flex-direction:column;overflow:hidden}.home-service-card::after{content:"";position:absolute;inset:auto -20% -45% auto;width:170px;height:170px;border-radius:50%;background:radial-gradient(circle,rgba(245,183,0,.18),transparent 70%);opacity:0;transition:var(--transition)}.home-service-card:hover::after{opacity:1}.home-service-icon{width:54px;height:54px;border-radius:18px;display:grid;place-items:center;font-size:28px;background:rgba(245,183,0,.10);border:1px solid rgba(245,183,0,.22);color:var(--gold)}.home-service-card h3{margin-top:20px}.home-service-card p{flex:1}.home-service-more{display:inline-flex;margin-top:18px;color:var(--gold);font-size:14px;position:relative;z-index:2}
/* =====================================================
   ADMIN SERVICES SETTINGS
===================================================== */
.admin-form-section{padding:24px;border-radius:22px;background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.08)}.admin-form-section h3{font-size:22px;margin-bottom:18px;color:var(--white)}.admin-help-text{margin-top:8px;color:var(--gray);font-size:14px}.services-admin-heading{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;margin-bottom:18px}.services-admin-list{display:grid;gap:18px}.service-admin-card{display:grid;grid-template-columns:280px 1fr;gap:20px;padding:18px;border-radius:22px;background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.10)}.service-admin-preview{min-height:230px;border-radius:20px;padding:22px;display:flex;flex-direction:column;justify-content:flex-end;background:radial-gradient(circle at 20% 15%,rgba(245,183,0,.18),transparent 34%),linear-gradient(145deg,rgba(193,18,31,.26),rgba(245,183,0,.10)),#151515;border:1px solid rgba(255,255,255,.12)}.service-admin-preview span{width:58px;height:58px;border-radius:18px;display:grid;place-items:center;font-size:30px;background:rgba(0,0,0,.26);border:1px solid rgba(255,255,255,.12);margin-bottom:20px}.service-admin-preview h4{font-size:25px;line-height:1.15;color:var(--white);margin-bottom:10px}.service-admin-preview p{color:var(--gray);font-size:14px}.service-admin-fields textarea{min-height:110px}.service-admin-actions{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}.danger-check span{color:#ffb4b4}.new-service-card{border-color:rgba(245,183,0,.26)}@media(max-width:920px){.services-admin-heading{align-items:flex-start;flex-direction:column}.service-admin-card{grid-template-columns:1fr}.service-admin-preview{min-height:200px}}



/* =====================================================
   SERVICES PAGE DYNAMIC FROM ADMIN
===================================================== */
.services-page-hero {
    position: relative;
    overflow: hidden;
}

.services-page-hero::after {
    content: "";
    position: absolute;
    right: -120px;
    top: 20px;
    width: 360px;
    height: 360px;
    border-radius: 50%;
    background:
        radial-gradient(circle, rgba(245,183,0,0.16), transparent 68%);
    pointer-events: none;
}

.services-dynamic-grid {
    align-items: stretch;
}

.service-dynamic-card {
    position: relative;
    min-height: 360px;
    overflow: hidden;
}

.service-dynamic-card::after {
    content: "";
    position: absolute;
    right: -60px;
    bottom: -60px;
    width: 180px;
    height: 180px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(245,183,0,0.14), transparent 68%);
    opacity: 0;
    transition: var(--transition);
}

.service-dynamic-card:hover::after {
    opacity: 1;
}

.service-detail-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    margin-bottom: 18px;
}

.service-detail-number {
    color: var(--gold);
    font-weight: 900;
    letter-spacing: 2px;
}

.service-detail-icon {
    width: 58px;
    height: 58px;
    border-radius: 18px;
    display: grid;
    place-items: center;
    font-size: 30px;
    background: rgba(245,183,0,0.10);
    border: 1px solid rgba(245,183,0,0.22);
}

.service-dynamic-card h2,
.service-dynamic-card p,
.service-dynamic-card ul {
    position: relative;
    z-index: 2;
}

/* =====================================================
   ADMIN SERVICES SETTINGS
===================================================== */
.admin-form-section {
    padding: 24px;
    border-radius: 22px;
    background: rgba(255,255,255,0.035);
    border: 1px solid rgba(255,255,255,0.08);
}

.admin-help-text {
    margin-top: 8px;
    color: var(--gray);
    font-size: 14px;
}

.services-admin-heading {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 18px;
    margin: 24px 0 18px;
}

.services-admin-list {
    display: grid;
    gap: 18px;
}

.service-admin-card {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 20px;
    padding: 18px;
    border-radius: 22px;
    background: rgba(255,255,255,0.035);
    border: 1px solid rgba(255,255,255,0.10);
}

.service-admin-preview {
    min-height: 230px;
    border-radius: 20px;
    padding: 22px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    background:
        radial-gradient(circle at 20% 15%, rgba(245,183,0,0.18), transparent 34%),
        linear-gradient(145deg, rgba(193,18,31,0.26), rgba(245,183,0,0.10)),
        #151515;
    border: 1px solid rgba(255,255,255,0.12);
}

.service-admin-preview span {
    width: 58px;
    height: 58px;
    border-radius: 18px;
    display: grid;
    place-items: center;
    font-size: 30px;
    background: rgba(0,0,0,0.26);
    border: 1px solid rgba(255,255,255,0.12);
    margin-bottom: 20px;
}

.service-admin-preview h4 {
    font-size: 25px;
    line-height: 1.15;
    color: var(--white);
    margin-bottom: 10px;
}

.service-admin-preview p {
    color: var(--gray);
    font-size: 14px;
}

.service-admin-fields textarea {
    min-height: 110px;
}

.service-admin-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    flex-wrap: wrap;
}

.danger-check span {
    color: #ffb4b4;
}

.new-service-card {
    border-color: rgba(245,183,0,0.26);
}

@media (max-width: 920px) {
    .services-admin-heading {
        align-items: flex-start;
        flex-direction: column;
    }

    .service-admin-card {
        grid-template-columns: 1fr;
    }

    .service-admin-preview {
        min-height: 200px;
    }
}



/* =====================================================
   PRICING DYNAMIC + ADMIN SETTINGS
===================================================== */
.pricing-dynamic-grid {
    align-items: stretch;
}

.pricing-dynamic-card {
    display: flex;
    flex-direction: column;
    min-height: 430px;
    overflow: hidden;
}

.pricing-dynamic-card::after {
    content: "";
    position: absolute;
    right: -70px;
    bottom: -70px;
    width: 180px;
    height: 180px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(245,183,0,0.14), transparent 68%);
    opacity: 0;
    transition: var(--transition);
}

.pricing-dynamic-card:hover::after {
    opacity: 1;
}

.pricing-dynamic-card ul {
    flex: 1;
}

.pricing-dynamic-card .btn {
    margin-top: auto;
    position: relative;
    z-index: 2;
}

.pricing-page-hero {
    position: relative;
    overflow: hidden;
}

.pricing-page-hero::after {
    content: "";
    position: absolute;
    right: -120px;
    top: 20px;
    width: 360px;
    height: 360px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(245,183,0,0.16), transparent 68%);
    pointer-events: none;
}

.pricing-admin-heading {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 18px;
    margin: 24px 0 18px;
}

.pricing-admin-list {
    display: grid;
    gap: 18px;
}

.pricing-admin-card {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 20px;
    padding: 18px;
    border-radius: 22px;
    background: rgba(255,255,255,0.035);
    border: 1px solid rgba(255,255,255,0.10);
}

.pricing-admin-preview {
    min-height: 260px;
    border-radius: 20px;
    padding: 24px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    background:
        radial-gradient(circle at 20% 15%, rgba(245,183,0,0.16), transparent 34%),
        linear-gradient(145deg, rgba(193,18,31,0.22), rgba(245,183,0,0.10)),
        #151515;
    border: 1px solid rgba(255,255,255,0.12);
}

.pricing-admin-preview.is-popular-preview {
    border-color: rgba(245,183,0,0.48);
    box-shadow: 0 22px 70px rgba(245,183,0,0.08);
}

.pricing-admin-preview h4 {
    font-size: 25px;
    line-height: 1.15;
    color: var(--white);
    margin-bottom: 12px;
}

.pricing-admin-preview strong {
    color: var(--gold);
    font-size: 28px;
    margin-bottom: 14px;
}

.pricing-admin-preview p {
    color: var(--gray);
    font-size: 14px;
}

.pricing-admin-fields textarea {
    min-height: 110px;
}

.pricing-admin-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    flex-wrap: wrap;
}

.admin-help-text {
    margin-top: 8px;
    color: var(--gray);
    font-size: 14px;
}

.danger-check span {
    color: #ffb4b4;
}

.new-pricing-card {
    border-color: rgba(245,183,0,0.26);
}

@media (max-width: 920px) {
    .pricing-admin-heading {
        align-items: flex-start;
        flex-direction: column;
    }

    .pricing-admin-card {
        grid-template-columns: 1fr;
    }

    .pricing-admin-preview {
        min-height: 220px;
    }
}



/* =====================================================
   PROCESS DYNAMIC + ADMIN SETTINGS
===================================================== */
.process-dynamic-grid {
    align-items: stretch;
}

.process-dynamic-card {
    position: relative;
    overflow: hidden;
    min-height: 250px;
    transition: var(--transition);
}

.process-dynamic-card::after {
    content: "";
    position: absolute;
    right: -70px;
    bottom: -70px;
    width: 170px;
    height: 170px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(245,183,0,0.14), transparent 68%);
    opacity: 0;
    transition: var(--transition);
}

.process-dynamic-card:hover {
    transform: translateY(-8px);
    border-color: rgba(245,183,0,0.40);
}

.process-dynamic-card:hover::after {
    opacity: 1;
}

.process-card-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    margin-bottom: 14px;
}

.process-card-top span {
    color: var(--gold);
    font-weight: 900;
    letter-spacing: 2px;
}

.process-card-top strong {
    width: 46px;
    height: 46px;
    border-radius: 16px;
    display: grid;
    place-items: center;
    background: rgba(245,183,0,0.10);
    border: 1px solid rgba(245,183,0,0.20);
    font-size: 24px;
}

.process-admin-heading {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 18px;
    margin: 24px 0 18px;
}

.process-admin-list {
    display: grid;
    gap: 18px;
}

.process-admin-card {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 20px;
    padding: 18px;
    border-radius: 22px;
    background: rgba(255,255,255,0.035);
    border: 1px solid rgba(255,255,255,0.10);
}

.process-admin-preview {
    min-height: 240px;
    border-radius: 20px;
    padding: 24px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    background:
        radial-gradient(circle at 20% 15%, rgba(245,183,0,0.16), transparent 34%),
        linear-gradient(145deg, rgba(193,18,31,0.22), rgba(245,183,0,0.10)),
        #151515;
    border: 1px solid rgba(255,255,255,0.12);
}

.process-admin-preview div {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 18px;
}

.process-admin-preview span {
    color: var(--gold);
    font-weight: 900;
    letter-spacing: 2px;
}

.process-admin-preview strong {
    width: 54px;
    height: 54px;
    border-radius: 18px;
    display: grid;
    place-items: center;
    font-size: 28px;
    background: rgba(0,0,0,0.26);
    border: 1px solid rgba(255,255,255,0.12);
}

.process-admin-preview h4 {
    font-size: 25px;
    line-height: 1.15;
    color: var(--white);
    margin-bottom: 10px;
}

.process-admin-preview p {
    color: var(--gray);
    font-size: 14px;
}

.process-admin-fields textarea {
    min-height: 110px;
}

.process-admin-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 14px;
    flex-wrap: wrap;
}

.admin-help-text {
    margin-top: 8px;
    color: var(--gray);
    font-size: 14px;
}

.danger-check span {
    color: #ffb4b4;
}

.new-process-card {
    border-color: rgba(245,183,0,0.26);
}

@media (max-width: 920px) {
    .process-admin-heading {
        align-items: flex-start;
        flex-direction: column;
    }

    .process-admin-card {
        grid-template-columns: 1fr;
    }

    .process-admin-preview {
        min-height: 210px;
    }
}



/* =====================================================
   TESTIMONIALS ADMIN SETTINGS
===================================================== */
.testimonials-admin-heading {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 18px;
    margin: 24px 0 18px;
}

.testimonials-admin-list {
    display: grid;
    gap: 18px;
}

.testimonial-admin-card {
    display: grid;
    grid-template-columns: 300px 1fr;
    gap: 20px;
    padding: 18px;
    border-radius: 22px;
    background: rgba(255,255,255,0.035);
    border: 1px solid rgba(255,255,255,0.10);
}

.testimonial-admin-preview {
    min-height: 310px;
    border-radius: 22px;
    padding: 24px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    background:
        radial-gradient(circle at 20% 12%, rgba(245,183,0,0.16), transparent 34%),
        linear-gradient(145deg, rgba(193,18,31,0.22), rgba(245,183,0,0.10)),
        #151515;
    border: 1px solid rgba(255,255,255,0.12);
}

.testimonial-admin-avatar {
    width: 76px;
    height: 76px;
    border-radius: 50%;
    margin-bottom: 18px;
    overflow: hidden;
    border: 3px solid rgba(245,183,0,0.65);
    background: rgba(0,0,0,0.28);
    display: grid;
    place-items: center;
}

.testimonial-admin-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.testimonial-admin-avatar span {
    color: var(--gold);
    font-size: 30px;
    font-weight: 900;
}

.testimonial-admin-stars {
    color: var(--gold);
    letter-spacing: 2px;
    font-size: 17px;
    margin-bottom: 12px;
}

.testimonial-admin-preview p {
    color: var(--gray);
    font-size: 14px;
    line-height: 1.65;
    margin-bottom: 16px;
}

.testimonial-admin-preview h4 {
    color: var(--white);
    font-size: 22px;
    line-height: 1.15;
    margin-bottom: 4px;
}

.testimonial-admin-preview small {
    color: var(--gray);
}

.testimonial-admin-fields textarea {
    min-height: 120px;
}

.testimonial-admin-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    flex-wrap: wrap;
}

.admin-help-text {
    margin-top: 8px;
    color: var(--gray);
    font-size: 14px;
}

.danger-check span {
    color: #ffb4b4;
}

.new-testimonial-card {
    border-color: rgba(245,183,0,0.26);
}

/* Public testimonial fallback */
.fdx-avatar-fallback {
    width: 92px;
    height: 92px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background: linear-gradient(135deg, var(--red), var(--gold));
    color: var(--white);
    font-weight: 900;
    font-size: 34px;
    border: 6px solid rgba(255,255,255,0.92);
    outline: 5px solid rgba(245,183,0,0.55);
}

@media (max-width: 920px) {
    .testimonials-admin-heading {
        align-items: flex-start;
        flex-direction: column;
    }

    .testimonial-admin-card {
        grid-template-columns: 1fr;
    }

    .testimonial-admin-preview {
        min-height: 250px;
    }
}



/* =====================================================
   CTA SETTINGS - PUBLIC + ADMIN
===================================================== */
.cta-section-admin .cta-box {
    position: relative;
    overflow: hidden;
}

.cta-section-admin .cta-box::before {
    content: "";
    position: absolute;
    inset: -80px auto auto -80px;
    width: 220px;
    height: 220px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(245,183,0,0.20), transparent 68%);
    pointer-events: none;
}

.cta-section-admin .cta-box > * {
    position: relative;
    z-index: 2;
}

.cta-style-brand .cta-box {
    background:
        radial-gradient(circle at top left, rgba(245,183,0,0.20), transparent 34%),
        linear-gradient(135deg, rgba(193,18,31,0.34), rgba(245,183,0,0.18)),
        var(--black-card);
}

.cta-style-gradient .cta-box {
    background:
        linear-gradient(135deg, rgba(193,18,31,0.92), rgba(245,183,0,0.72)),
        var(--black-card);
}

.cta-style-gradient .eyebrow,
.cta-style-gradient .cta-box p {
    color: rgba(255,255,255,0.86);
}

.cta-style-dark .cta-box {
    background:
        radial-gradient(circle at bottom right, rgba(245,183,0,0.12), transparent 32%),
        #0b0b0b;
    border-color: rgba(245,183,0,0.18);
}

.cta-admin-preview {
    border-radius: 26px;
    padding: 30px;
    background:
        radial-gradient(circle at top left, rgba(245,183,0,0.18), transparent 34%),
        linear-gradient(135deg, rgba(193,18,31,0.28), rgba(245,183,0,0.12)),
        #151515;
    border: 1px solid rgba(255,255,255,0.12);
}

.cta-admin-preview h3 {
    color: var(--white);
    font-size: clamp(28px, 4vw, 42px);
    letter-spacing: -1.5px;
    line-height: 1.1;
    margin-bottom: 10px;
}

.cta-admin-preview p {
    color: var(--gray);
    margin-bottom: 18px;
}

.cta-admin-style-options {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
}

.cta-style-option {
    padding: 16px;
    border-radius: 18px;
    background: rgba(255,255,255,0.035);
    border: 1px solid rgba(255,255,255,0.10);
    cursor: pointer;
    transition: var(--transition);
}

.cta-style-option:hover {
    border-color: rgba(245,183,0,0.34);
}

.cta-style-option input {
    margin-right: 8px;
    accent-color: var(--gold);
}

.cta-style-option strong {
    display: block;
    margin-bottom: 6px;
    color: var(--white);
}

.cta-style-option span {
    display: block;
    color: var(--gray);
    font-size: 13px;
}

@media (max-width: 768px) {
    .cta-admin-style-options {
        grid-template-columns: 1fr;
    }
}



/* =====================================================
   ABOUT SETTINGS - DYNAMIC ABOUT PAGE
===================================================== */
.about-page-hero {
    position: relative;
    overflow: hidden;
}

.about-page-hero::after {
    content: "";
    position: absolute;
    right: -120px;
    top: 30px;
    width: 360px;
    height: 360px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(245,183,0,0.14), transparent 68%);
    pointer-events: none;
}

.about-dynamic-card {
    position: relative;
    overflow: hidden;
}

.about-dynamic-card::after {
    content: "";
    position: absolute;
    right: -80px;
    bottom: -80px;
    width: 210px;
    height: 210px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(245,183,0,0.20), transparent 68%);
}

.about-dynamic-card > * {
    position: relative;
    z-index: 2;
}

.about-mission-section {
    background: var(--black);
}

.about-mission-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
}

.about-mission-card {
    padding: 32px;
    border-radius: 28px;
    background:
        radial-gradient(circle at 18% 12%, rgba(245,183,0,0.12), transparent 34%),
        var(--black-card);
    border: 1px solid var(--border);
}

.about-mission-card span {
    color: var(--gold);
    font-weight: 900;
    letter-spacing: 2px;
    text-transform: uppercase;
}

.about-mission-card h3 {
    font-size: 30px;
    margin: 16px 0 12px;
    letter-spacing: -1px;
}

.about-mission-card p {
    color: var(--gray);
}

.about-values-grid {
    align-items: stretch;
}

.about-value-card {
    position: relative;
    overflow: hidden;
}

.about-value-card::after {
    content: "";
    position: absolute;
    right: -70px;
    bottom: -70px;
    width: 170px;
    height: 170px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(245,183,0,0.13), transparent 68%);
    opacity: 0;
    transition: var(--transition);
}

.about-value-card:hover::after {
    opacity: 1;
}

.about-value-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
}

.about-value-top strong {
    width: 46px;
    height: 46px;
    border-radius: 16px;
    display: grid;
    place-items: center;
    background: rgba(245,183,0,0.10);
    border: 1px solid rgba(245,183,0,0.20);
    font-size: 24px;
}

/* Admin About */
.admin-form-section {
    padding: 24px;
    border-radius: 22px;
    background: rgba(255,255,255,0.035);
    border: 1px solid rgba(255,255,255,0.08);
}

.admin-form-section h3 {
    font-size: 22px;
    margin-bottom: 18px;
}

.admin-help-text {
    margin-top: 8px;
    color: var(--gray);
    font-size: 14px;
}

.about-admin-preview {
    min-height: 220px;
    border-radius: 22px;
    padding: 24px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    margin-bottom: 20px;
    background:
        radial-gradient(circle at 18% 14%, rgba(245,183,0,0.18), transparent 34%),
        linear-gradient(135deg, rgba(193,18,31,0.28), rgba(245,183,0,0.12)),
        #151515;
    border: 1px solid rgba(255,255,255,0.12);
}

.about-admin-preview span {
    color: var(--gold);
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 2px;
    margin-bottom: 10px;
}

.about-admin-preview h4 {
    color: var(--white);
    font-size: 30px;
    line-height: 1.12;
    margin-bottom: 10px;
}

.about-admin-preview p {
    color: var(--gray);
}

.about-values-heading {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 18px;
    margin: 24px 0 18px;
}

.about-values-admin-list {
    display: grid;
    gap: 18px;
}

.about-value-admin-card {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 20px;
    padding: 18px;
    border-radius: 22px;
    background: rgba(255,255,255,0.035);
    border: 1px solid rgba(255,255,255,0.10);
}

.about-value-admin-preview {
    min-height: 230px;
    border-radius: 20px;
    padding: 22px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    background:
        radial-gradient(circle at 20% 15%, rgba(245,183,0,0.18), transparent 34%),
        linear-gradient(145deg, rgba(193,18,31,0.26), rgba(245,183,0,0.10)),
        #151515;
    border: 1px solid rgba(255,255,255,0.12);
}

.about-value-admin-preview div {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 18px;
}

.about-value-admin-preview span {
    color: var(--gold);
    font-weight: 900;
    letter-spacing: 2px;
}

.about-value-admin-preview strong {
    width: 54px;
    height: 54px;
    border-radius: 18px;
    display: grid;
    place-items: center;
    font-size: 28px;
    background: rgba(0,0,0,0.26);
    border: 1px solid rgba(255,255,255,0.12);
}

.about-value-admin-preview h4 {
    font-size: 25px;
    line-height: 1.15;
    color: var(--white);
    margin-bottom: 10px;
}

.about-value-admin-preview p {
    color: var(--gray);
    font-size: 14px;
}

.about-value-admin-fields textarea {
    min-height: 110px;
}

.danger-check span {
    color: #ffb4b4;
}

.new-about-value-card {
    border-color: rgba(245,183,0,0.26);
}

@media (max-width: 992px) {
    .about-mission-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 920px) {
    .about-values-heading {
        align-items: flex-start;
        flex-direction: column;
    }

    .about-value-admin-card {
        grid-template-columns: 1fr;
    }

    .about-value-admin-preview {
        min-height: 200px;
    }
}



/* =====================================================
   FOOTER SETTINGS - DYNAMIC FOOTER + ADMIN
===================================================== */
.footer-dynamic {
    position: relative;
    overflow: hidden;
}

.footer-dynamic::before {
    content: "";
    position: absolute;
    right: -120px;
    top: -120px;
    width: 340px;
    height: 340px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(245,183,0,0.10), transparent 68%);
    pointer-events: none;
}

.footer-dynamic .footer-grid,
.footer-dynamic .footer-bottom {
    position: relative;
    z-index: 2;
}

.footer-socials {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 22px;
}

.footer-socials a {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    min-height: 38px;
    padding: 9px 14px;
    border-radius: 999px;
    background: rgba(245,183,0,0.09);
    border: 1px solid rgba(245,183,0,0.18);
    color: var(--gold) !important;
    font-size: 13px;
    font-weight: 800;
    transition: var(--transition);
}

.footer-socials a:hover {
    transform: translateY(-3px);
    background: rgba(245,183,0,0.16);
    border-color: rgba(245,183,0,0.45);
}

/* Admin footer settings */
.admin-form-section {
    padding: 24px;
    border-radius: 22px;
    background: rgba(255,255,255,0.035);
    border: 1px solid rgba(255,255,255,0.08);
}

.admin-form-section h3 {
    font-size: 22px;
    margin-bottom: 18px;
}

.admin-help-text {
    margin-top: 8px;
    color: var(--gray);
    font-size: 14px;
}

.footer-admin-preview {
    min-height: 190px;
    border-radius: 22px;
    padding: 24px;
    margin: 18px 0 22px;
    display: flex;
    align-items: flex-end;
    background:
        radial-gradient(circle at 18% 14%, rgba(245,183,0,0.18), transparent 34%),
        linear-gradient(135deg, rgba(193,18,31,0.26), rgba(245,183,0,0.10)),
        #151515;
    border: 1px solid rgba(255,255,255,0.12);
}

.footer-admin-preview img {
    max-width: 170px;
    max-height: 70px;
    width: auto;
    height: auto;
    object-fit: contain;
    margin-bottom: 14px;
}

.footer-admin-preview strong {
    font-size: 28px;
    line-height: 1.1;
    color: var(--white);
    display: inline-block;
    margin-bottom: 14px;
}

.footer-admin-preview strong span {
    color: var(--gold);
}

.footer-admin-preview p {
    color: var(--gray);
    max-width: 600px;
}

.footer-links-heading {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 18px;
}

.footer-links-admin-list {
    display: grid;
    gap: 18px;
}

.footer-link-admin-card {
    display: grid;
    grid-template-columns: 260px 1fr;
    gap: 20px;
    padding: 18px;
    border-radius: 22px;
    background: rgba(255,255,255,0.035);
    border: 1px solid rgba(255,255,255,0.10);
}

.footer-link-preview {
    min-height: 180px;
    border-radius: 20px;
    padding: 22px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    background:
        radial-gradient(circle at 20% 15%, rgba(245,183,0,0.18), transparent 34%),
        linear-gradient(145deg, rgba(193,18,31,0.24), rgba(245,183,0,0.10)),
        #151515;
    border: 1px solid rgba(255,255,255,0.12);
}

.footer-link-preview span {
    color: var(--gold);
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 2px;
    font-size: 12px;
    margin-bottom: 12px;
}

.footer-link-preview h4 {
    font-size: 24px;
    line-height: 1.15;
    color: var(--white);
    margin-bottom: 8px;
}

.footer-link-preview p {
    color: var(--gray);
    font-size: 14px;
    word-break: break-word;
}

.footer-link-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    flex-wrap: wrap;
}

.danger-check span {
    color: #ffb4b4;
}

.new-footer-link-card {
    border-color: rgba(245,183,0,0.26);
}

@media (max-width: 920px) {
    .footer-links-heading {
        align-items: flex-start;
        flex-direction: column;
    }

    .footer-link-admin-card {
        grid-template-columns: 1fr;
    }

    .footer-link-preview {
        min-height: 160px;
    }
}

@media (max-width: 768px) {
    .footer-socials {
        gap: 8px;
    }

    .footer-socials a {
        min-height: 36px;
        padding: 8px 12px;
    }
}



/* =====================================================
   HEADER SETTINGS - DYNAMIC HEADER + ADMIN
===================================================== */
.header-admin-preview {
    min-height: 160px;
    border-radius: 22px;
    padding: 24px;
    margin: 18px 0 22px;
    display: flex;
    align-items: center;
    background:
        radial-gradient(circle at 18% 14%, rgba(245,183,0,0.18), transparent 34%),
        linear-gradient(135deg, rgba(193,18,31,0.26), rgba(245,183,0,0.10)),
        #151515;
    border: 1px solid rgba(255,255,255,0.12);
}

.header-admin-bar {
    width: 100%;
    min-height: 70px;
    padding: 14px 18px;
    border-radius: 18px;
    background: rgba(5,5,5,0.74);
    border: 1px solid rgba(255,255,255,0.10);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
}

.header-admin-bar img {
    max-width: 160px;
    max-height: 56px;
    width: auto;
    height: auto;
    object-fit: contain;
}

.header-admin-bar strong {
    font-size: 24px;
    color: var(--white);
}

.header-admin-bar strong span {
    color: var(--gold);
}

.header-admin-bar nav {
    display: flex;
    gap: 14px;
    color: var(--gray);
    font-size: 13px;
    font-weight: 700;
}

.header-admin-bar em {
    font-style: normal;
    padding: 10px 14px;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--red), var(--gold));
    color: var(--white);
    font-weight: 800;
    font-size: 13px;
    white-space: nowrap;
}

.admin-form-section {
    padding: 24px;
    border-radius: 22px;
    background: rgba(255,255,255,0.035);
    border: 1px solid rgba(255,255,255,0.08);
}

.admin-form-section h3 {
    font-size: 22px;
    margin-bottom: 18px;
}

.admin-help-text {
    margin-top: 8px;
    color: var(--gray);
    font-size: 14px;
}

.header-links-heading {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 18px;
}

.header-links-admin-list {
    display: grid;
    gap: 18px;
}

.header-link-admin-card {
    display: grid;
    grid-template-columns: 260px 1fr;
    gap: 20px;
    padding: 18px;
    border-radius: 22px;
    background: rgba(255,255,255,0.035);
    border: 1px solid rgba(255,255,255,0.10);
}

.header-link-preview {
    min-height: 180px;
    border-radius: 20px;
    padding: 22px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    background:
        radial-gradient(circle at 20% 15%, rgba(245,183,0,0.18), transparent 34%),
        linear-gradient(145deg, rgba(193,18,31,0.24), rgba(245,183,0,0.10)),
        #151515;
    border: 1px solid rgba(255,255,255,0.12);
}

.header-link-preview span {
    color: var(--gold);
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 2px;
    font-size: 12px;
    margin-bottom: 12px;
}

.header-link-preview h4 {
    font-size: 24px;
    line-height: 1.15;
    color: var(--white);
    margin-bottom: 8px;
}

.header-link-preview p {
    color: var(--gray);
    font-size: 14px;
    word-break: break-word;
}

.header-link-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 14px;
    flex-wrap: wrap;
}

.danger-check span {
    color: #ffb4b4;
}

.new-header-link-card {
    border-color: rgba(245,183,0,0.26);
}

@media (max-width: 920px) {
    .header-links-heading {
        align-items: flex-start;
        flex-direction: column;
    }

    .header-link-admin-card {
        grid-template-columns: 1fr;
    }

    .header-link-preview {
        min-height: 160px;
    }

    .header-admin-bar {
        align-items: flex-start;
        flex-direction: column;
    }

    .header-admin-bar nav {
        flex-wrap: wrap;
    }
}



/* =====================================================
   CONTACT PAGE SETTINGS - DYNAMIC CONTACT PAGE + ADMIN
===================================================== */
.contact-page-hero {
    position: relative;
    overflow: hidden;
}

.contact-page-hero::after {
    content: "";
    position: absolute;
    right: -120px;
    top: 30px;
    width: 360px;
    height: 360px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(245,183,0,0.14), transparent 68%);
    pointer-events: none;
}

.contact-dynamic-info {
    position: relative;
    overflow: hidden;
}

.contact-dynamic-info::after {
    content: "";
    position: absolute;
    right: -80px;
    bottom: -80px;
    width: 210px;
    height: 210px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(245,183,0,0.12), transparent 68%);
    pointer-events: none;
}

.contact-dynamic-info > * {
    position: relative;
    z-index: 2;
}

.contact-list a {
    color: var(--gray);
}

.contact-list a:hover {
    color: var(--gold);
}

.contact-socials {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 24px;
}

.contact-socials a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 40px;
    padding: 10px 15px;
    border-radius: 999px;
    background: rgba(245,183,0,0.09);
    border: 1px solid rgba(245,183,0,0.18);
    color: var(--gold);
    font-size: 13px;
    font-weight: 800;
    transition: var(--transition);
}

.contact-socials a:hover {
    transform: translateY(-3px);
    background: rgba(245,183,0,0.16);
    border-color: rgba(245,183,0,0.45);
}

.contact-map-section {
    padding: 0 0 90px;
}

.contact-map-frame {
    overflow: hidden;
    border-radius: 28px;
    border: 1px solid var(--border);
    background: var(--black-card);
}

.contact-map-frame iframe {
    width: 100%;
    min-height: 380px;
    display: block;
    border: 0;
}

/* Admin Contact Page Settings */
.admin-form-section {
    padding: 24px;
    border-radius: 22px;
    background: rgba(255,255,255,0.035);
    border: 1px solid rgba(255,255,255,0.08);
}

.admin-form-section h3 {
    font-size: 22px;
    margin-bottom: 18px;
}

.admin-help-text {
    margin-top: 8px;
    color: var(--gray);
    font-size: 14px;
}

.contact-admin-preview {
    min-height: 220px;
    border-radius: 22px;
    padding: 24px;
    margin-bottom: 20px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    background:
        radial-gradient(circle at 18% 14%, rgba(245,183,0,0.18), transparent 34%),
        linear-gradient(135deg, rgba(193,18,31,0.26), rgba(245,183,0,0.10)),
        #151515;
    border: 1px solid rgba(255,255,255,0.12);
}

.contact-admin-preview h4 {
    color: var(--white);
    font-size: 30px;
    line-height: 1.12;
    margin-bottom: 10px;
}

.contact-admin-preview p {
    color: var(--gray);
}

@media (max-width: 768px) {
    .contact-socials {
        gap: 8px;
    }

    .contact-socials a {
        min-height: 38px;
        padding: 9px 13px;
    }

    .contact-map-frame iframe {
        min-height: 300px;
    }
}



/* =====================================================
   PROJECTS PAGE SETTINGS - DYNAMIC PROJECTS PAGE + ADMIN
===================================================== */
.projects-page-hero {
    position: relative;
    overflow: hidden;
}

.projects-page-hero::after {
    content: "";
    position: absolute;
    right: -120px;
    top: 30px;
    width: 360px;
    height: 360px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(245,183,0,0.14), transparent 68%);
    pointer-events: none;
}

.projects-page-head {
    display: grid;
    gap: 18px;
    margin-bottom: 34px;
}

.project-filter-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.project-filter-bar a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 10px 16px;
    border-radius: 999px;
    background: rgba(255,255,255,0.035);
    border: 1px solid var(--border);
    color: var(--gray);
    font-weight: 800;
    font-size: 14px;
    transition: var(--transition);
}

.project-filter-bar a:hover,
.project-filter-bar a.active {
    color: var(--gold);
    border-color: rgba(245,183,0,0.45);
    background: rgba(245,183,0,0.10);
}

.projects-dynamic-grid {
    align-items: stretch;
}

.project-dynamic-card {
    position: relative;
    cursor: pointer;
}

.project-dynamic-card::after {
    content: "";
    position: absolute;
    right: -70px;
    bottom: -70px;
    width: 170px;
    height: 170px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(245,183,0,0.12), transparent 68%);
    opacity: 0;
    transition: var(--transition);
    pointer-events: none;
}

.project-dynamic-card:hover {
    border-color: rgba(245,183,0,0.36);
}

.project-dynamic-card:hover::after {
    opacity: 1;
}

.projects-layout-masonry .project-card:nth-child(3n + 2) .project-image {
    height: 310px;
}

.projects-layout-masonry .project-card:nth-child(3n) .project-image {
    height: 200px;
}

.projects-layout-compact .project-image {
    height: 185px;
}

.projects-layout-compact .project-content {
    padding: 20px;
}

.projects-layout-compact .project-content h3 {
    font-size: 20px;
}

.project-pagination {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 34px;
}

.project-pagination a {
    width: 42px;
    height: 42px;
    border-radius: 14px;
    display: grid;
    place-items: center;
    color: var(--gray);
    background: rgba(255,255,255,0.035);
    border: 1px solid var(--border);
    font-weight: 800;
    transition: var(--transition);
}

.project-pagination a:hover,
.project-pagination a.active {
    color: var(--gold);
    border-color: rgba(245,183,0,0.45);
    background: rgba(245,183,0,0.10);
}

/* Admin Projects Page Settings */
.admin-form-section {
    padding: 24px;
    border-radius: 22px;
    background: rgba(255,255,255,0.035);
    border: 1px solid rgba(255,255,255,0.08);
}

.admin-form-section h3 {
    font-size: 22px;
    margin-bottom: 18px;
}

.projects-page-admin-preview {
    min-height: 220px;
    border-radius: 22px;
    padding: 24px;
    margin-bottom: 20px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    background:
        radial-gradient(circle at 18% 14%, rgba(245,183,0,0.18), transparent 34%),
        linear-gradient(135deg, rgba(193,18,31,0.26), rgba(245,183,0,0.10)),
        #151515;
    border: 1px solid rgba(255,255,255,0.12);
}

.projects-page-admin-preview h4 {
    color: var(--white);
    font-size: 30px;
    line-height: 1.12;
    margin-bottom: 10px;
}

.projects-page-admin-preview p {
    color: var(--gray);
}

@media (max-width: 768px) {
    .project-filter-bar {
        gap: 8px;
    }

    .project-filter-bar a {
        min-height: 38px;
        padding: 9px 13px;
    }

    .projects-layout-masonry .project-card:nth-child(n) .project-image {
        height: 230px;
    }
}



/* =====================================================
   BLOG PAGE SETTINGS - DYNAMIC BLOG PAGE + ADMIN
===================================================== */
.blog-page-hero {
    position: relative;
    overflow: hidden;
}

.blog-page-hero::after {
    content: "";
    position: absolute;
    right: -120px;
    top: 30px;
    width: 360px;
    height: 360px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(245,183,0,0.14), transparent 68%);
    pointer-events: none;
}

.blog-page-head {
    display: grid;
    gap: 18px;
    margin-bottom: 34px;
}

.blog-dynamic-grid {
    align-items: stretch;
}

.blog-dynamic-card {
    position: relative;
    overflow: hidden;
}

.blog-dynamic-card::after {
    content: "";
    position: absolute;
    right: -70px;
    bottom: -70px;
    width: 170px;
    height: 170px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(245,183,0,0.12), transparent 68%);
    opacity: 0;
    transition: var(--transition);
    pointer-events: none;
}

.blog-dynamic-card:hover::after {
    opacity: 1;
}

.blog-layout-compact .blog-image {
    height: 170px;
}

.blog-layout-compact .blog-content {
    padding: 20px;
}

.blog-layout-compact .blog-content h2 {
    font-size: 20px;
}

.blog-layout-featured .is-featured-blog-card {
    grid-column: span 2;
    display: grid;
    grid-template-columns: 1.15fr 0.85fr;
}

.blog-layout-featured .is-featured-blog-card .blog-image {
    height: 100%;
    min-height: 360px;
}

.blog-layout-featured .is-featured-blog-card .blog-content {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 34px;
}

.blog-layout-featured .is-featured-blog-card .blog-content h2 {
    font-size: clamp(28px, 3vw, 42px);
    letter-spacing: -1.5px;
}

.blog-pagination {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 34px;
}

.blog-pagination a {
    width: 42px;
    height: 42px;
    border-radius: 14px;
    display: grid;
    place-items: center;
    color: var(--gray);
    background: rgba(255,255,255,0.035);
    border: 1px solid var(--border);
    font-weight: 800;
    transition: var(--transition);
}

.blog-pagination a:hover,
.blog-pagination a.active {
    color: var(--gold);
    border-color: rgba(245,183,0,0.45);
    background: rgba(245,183,0,0.10);
}

/* Admin Blog Page Settings */
.admin-form-section {
    padding: 24px;
    border-radius: 22px;
    background: rgba(255,255,255,0.035);
    border: 1px solid rgba(255,255,255,0.08);
}

.admin-form-section h3 {
    font-size: 22px;
    margin-bottom: 18px;
}

.blog-page-admin-preview {
    min-height: 220px;
    border-radius: 22px;
    padding: 24px;
    margin-bottom: 20px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    background:
        radial-gradient(circle at 18% 14%, rgba(245,183,0,0.18), transparent 34%),
        linear-gradient(135deg, rgba(193,18,31,0.26), rgba(245,183,0,0.10)),
        #151515;
    border: 1px solid rgba(255,255,255,0.12);
}

.blog-page-admin-preview h4 {
    color: var(--white);
    font-size: 30px;
    line-height: 1.12;
    margin-bottom: 10px;
}

.blog-page-admin-preview p {
    color: var(--gray);
}

@media (max-width: 992px) {
    .blog-layout-featured .is-featured-blog-card {
        grid-column: span 2;
        grid-template-columns: 1fr;
    }

    .blog-layout-featured .is-featured-blog-card .blog-image {
        height: 300px;
        min-height: 300px;
    }
}

@media (max-width: 640px) {
    .blog-layout-featured .is-featured-blog-card {
        grid-column: span 1;
    }

    .blog-layout-featured .is-featured-blog-card .blog-image {
        height: 230px;
        min-height: 230px;
    }
}



/* =====================================================
   POST DETAIL SETTINGS - DYNAMIC POST DETAIL + ADMIN
===================================================== */
.post-detail-hero-dynamic {
    position: relative;
    overflow: hidden;
}

.post-detail-hero-dynamic::after {
    content: "";
    position: absolute;
    right: -120px;
    top: 30px;
    width: 360px;
    height: 360px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(245,183,0,0.14), transparent 68%);
    pointer-events: none;
}

.post-detail-container {
    position: relative;
}

.post-detail-thumbnail {
    box-shadow: 0 28px 80px rgba(0,0,0,0.32);
}

.post-detail-excerpt {
    padding: 26px 28px;
    border-radius: 24px;
    background: rgba(255,255,255,0.035);
    border: 1px solid rgba(255,255,255,0.08);
    color: #d8d8d8;
}

.post-detail-content {
    padding: 34px 0 0;
}

.post-detail-content a {
    color: var(--gold);
    font-weight: 800;
}

.post-detail-content h1,
.post-detail-content h2,
.post-detail-content h3 {
    margin: 30px 0 14px;
    color: var(--white);
}

.related-posts-section {
    position: relative;
    overflow: hidden;
}

.related-posts-section::before {
    content: "";
    position: absolute;
    left: -140px;
    top: 20px;
    width: 340px;
    height: 340px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(193,18,31,0.12), transparent 68%);
    pointer-events: none;
}

.related-posts-section .container {
    position: relative;
    z-index: 2;
}

.related-post-card {
    position: relative;
    overflow: hidden;
}

.related-post-card::after {
    content: "";
    position: absolute;
    right: -70px;
    bottom: -70px;
    width: 170px;
    height: 170px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(245,183,0,0.12), transparent 68%);
    opacity: 0;
    transition: var(--transition);
    pointer-events: none;
}

.related-post-card:hover::after {
    opacity: 1;
}

/* Admin post detail settings */
.admin-form-section {
    padding: 24px;
    border-radius: 22px;
    background: rgba(255,255,255,0.035);
    border: 1px solid rgba(255,255,255,0.08);
}

.admin-form-section h3 {
    font-size: 22px;
    margin-bottom: 18px;
}

.post-detail-admin-preview {
    min-height: 220px;
    border-radius: 22px;
    padding: 24px;
    margin-bottom: 20px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    background:
        radial-gradient(circle at 18% 14%, rgba(245,183,0,0.18), transparent 34%),
        linear-gradient(135deg, rgba(193,18,31,0.26), rgba(245,183,0,0.10)),
        #151515;
    border: 1px solid rgba(255,255,255,0.12);
}

.post-detail-admin-preview h4 {
    color: var(--white);
    font-size: 30px;
    line-height: 1.12;
    margin-bottom: 10px;
}

.post-detail-admin-preview p {
    color: var(--gray);
}

@media (max-width: 768px) {
    .post-detail-excerpt {
        padding: 22px;
    }

    .post-detail-content {
        padding-top: 22px;
    }
}



/* =====================================================
   PROJECT DETAIL SETTINGS - DYNAMIC PROJECT DETAIL + ADMIN
===================================================== */
.project-detail-dynamic-hero {
    position: relative;
    overflow: hidden;
}

.project-detail-dynamic-hero::after {
    content: "";
    position: absolute;
    right: -130px;
    top: 30px;
    width: 370px;
    height: 370px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(245,183,0,0.13), transparent 68%);
    pointer-events: none;
}

.project-detail-dynamic-hero .container {
    position: relative;
    z-index: 2;
}

.project-detail-not-found {
    min-height: 60vh;
    display: flex;
    align-items: center;
}

.related-projects-section {
    position: relative;
    overflow: hidden;
}

.related-projects-section::before {
    content: "";
    position: absolute;
    left: -140px;
    top: 20px;
    width: 340px;
    height: 340px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(193,18,31,0.12), transparent 68%);
    pointer-events: none;
}

.related-projects-section .container {
    position: relative;
    z-index: 2;
}

.related-project-card {
    cursor: pointer;
    position: relative;
    overflow: hidden;
}

.related-project-card::after {
    content: "";
    position: absolute;
    right: -70px;
    bottom: -70px;
    width: 170px;
    height: 170px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(245,183,0,0.12), transparent 68%);
    opacity: 0;
    transition: var(--transition);
    pointer-events: none;
}

.related-project-card:hover::after {
    opacity: 1;
}

.related-project-card .read-more {
    display: inline-block;
    margin-top: 16px;
}

/* Admin project detail settings */
.project-detail-admin-preview {
    min-height: 220px;
    border-radius: 22px;
    padding: 24px;
    margin-bottom: 20px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    background:
        radial-gradient(circle at 18% 14%, rgba(245,183,0,0.18), transparent 34%),
        linear-gradient(135deg, rgba(193,18,31,0.26), rgba(245,183,0,0.10)),
        #151515;
    border: 1px solid rgba(255,255,255,0.12);
}

.project-detail-admin-preview h4 {
    color: var(--white);
    font-size: 30px;
    line-height: 1.12;
    margin-bottom: 10px;
}

.project-detail-admin-preview p {
    color: var(--gray);
}

.admin-form-section {
    padding: 24px;
    border-radius: 22px;
    background: rgba(255,255,255,0.035);
    border: 1px solid rgba(255,255,255,0.08);
}

.admin-form-section h3 {
    font-size: 22px;
    margin-bottom: 18px;
}

@media (max-width: 992px) {
    .project-detail-grid {
        grid-template-columns: 1fr !important;
        gap: 34px !important;
    }

    .project-detail-media img,
    .project-detail-placeholder {
        height: 360px !important;
    }

    .case-grid {
        grid-template-columns: 1fr !important;
    }
}

@media (max-width: 640px) {
    .project-detail-content h1 {
        font-size: clamp(36px, 11vw, 54px) !important;
        letter-spacing: -2px !important;
    }

    .project-detail-media img,
    .project-detail-placeholder {
        height: 280px !important;
    }

    .pd-switch-card {
        width: 100% !important;
        max-width: 100% !important;
        flex: 1 1 100% !important;
    }

    .pd-switch-grid,
    .pd-switch-grid.single,
    .pd-switch-grid.single.next-only {
        justify-content: stretch !important;
        flex-direction: column !important;
    }
}
/* =====================================================
   HOME WORK PROCESS SECTION
===================================================== */
.work-process-section {
    position: relative;
    overflow: hidden;
    background:
        radial-gradient(circle at 12% 18%, rgba(193, 18, 31, 0.14), transparent 34%),
        radial-gradient(circle at 88% 80%, rgba(245, 183, 0, 0.12), transparent 34%),
        #080808;
}

.work-process-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 22px;
}

.work-process-card {
    position: relative;
    min-height: 250px;
    padding: 28px;
    border-radius: 28px;
    background:
        linear-gradient(145deg, rgba(255,255,255,0.07), rgba(255,255,255,0.025)),
        #141414;
    border: 1px solid rgba(255,255,255,0.09);
    overflow: hidden;
    transition: 0.35s ease;
}

.work-process-card::before {
    content: "";
    position: absolute;
    right: -80px;
    bottom: -80px;
    width: 190px;
    height: 190px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(245,183,0,0.16), transparent 68%);
    opacity: 0;
    transition: 0.35s ease;
}

.work-process-card:hover {
    transform: translateY(-6px);
    border-color: rgba(245,183,0,0.35);
    box-shadow: 0 28px 80px rgba(0,0,0,0.35);
}

.work-process-card:hover::before {
    opacity: 1;
}

.work-process-top {
    position: relative;
    z-index: 2;
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 34px;
}

.work-process-number {
    color: rgba(255,255,255,0.18);
    font-size: 42px;
    line-height: 1;
    font-weight: 900;
    letter-spacing: -2px;
}

.work-process-icon {
    width: 54px;
    height: 54px;
    border-radius: 18px;
    display: grid;
    place-items: center;
    color: var(--gold);
    background: rgba(245,183,0,0.1);
    border: 1px solid rgba(245,183,0,0.22);
    font-size: 24px;
}

.work-process-card h3 {
    position: relative;
    z-index: 2;
    color: var(--white);
    font-size: 23px;
    line-height: 1.2;
    margin-bottom: 12px;
}

.work-process-card p {
    position: relative;
    z-index: 2;
    color: var(--gray);
    font-size: 15.5px;
    line-height: 1.72;
}

@media (max-width: 992px) {
    .work-process-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 640px) {
    .work-process-grid {
        grid-template-columns: 1fr;
    }

    .work-process-card {
        min-height: auto;
        padding: 24px;
        border-radius: 24px;
    }

    .work-process-number {
        font-size: 36px;
    }
}
/* =====================================================
   HOME PROCESS PREMIUM ROADMAP - 10-BIT MEDIA
   Giao diện quy trình mới cho trang chủ
===================================================== */
.hp-process-section {
    position: relative !important;
    overflow: hidden !important;
    background:
        radial-gradient(circle at 8% 18%, rgba(193, 18, 31, 0.18), transparent 34%),
        radial-gradient(circle at 92% 82%, rgba(245, 183, 0, 0.14), transparent 34%),
        linear-gradient(180deg, #080808 0%, #050505 100%) !important;
}

.hp-process-section::before {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    background:
        linear-gradient(90deg, rgba(255, 255, 255, 0.022) 1px, transparent 1px),
        linear-gradient(180deg, rgba(255, 255, 255, 0.018) 1px, transparent 1px) !important;
    background-size: 82px 82px !important;
    opacity: 0.55 !important;
    pointer-events: none !important;
}

.hp-process-section .container {
    position: relative !important;
    z-index: 2 !important;
}

.hp-process-header {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    align-items: end !important;
    gap: 32px !important;
    margin-bottom: 38px !important;
}

.hp-process-heading {
    max-width: 760px !important;
}

.hp-process-heading h2 {
    color: var(--white) !important;
    font-size: clamp(34px, 4.6vw, 58px) !important;
    line-height: 1.06 !important;
    letter-spacing: -2px !important;
    margin-bottom: 14px !important;
}

.hp-process-heading p {
    color: var(--gray) !important;
    font-size: 16.5px !important;
    line-height: 1.78 !important;
}

.hp-process-header-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 54px !important;
    padding: 0 22px !important;
    border-radius: 999px !important;
    color: var(--white) !important;
    font-size: 15px !important;
    font-weight: 800 !important;
    white-space: nowrap !important;
    background:
        linear-gradient(135deg, rgba(193, 18, 31, 1), rgba(245, 183, 0, 0.96)) !important;
    box-shadow: 0 18px 46px rgba(193, 18, 31, 0.24) !important;
    transition: 0.3s ease !important;
}

.hp-process-header-btn:hover {
    transform: translateY(-4px) !important;
    box-shadow: 0 24px 60px rgba(193, 18, 31, 0.32) !important;
}

.hp-process-board {
    position: relative !important;
    padding: 34px !important;
    border-radius: 34px !important;
    background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.07), rgba(255, 255, 255, 0.022)),
        radial-gradient(circle at 14% 12%, rgba(193, 18, 31, 0.18), transparent 38%),
        radial-gradient(circle at 88% 88%, rgba(245, 183, 0, 0.16), transparent 36%),
        rgba(17, 17, 17, 0.92) !important;
    border: 1px solid rgba(255, 255, 255, 0.10) !important;
    box-shadow:
        0 34px 100px rgba(0, 0, 0, 0.42),
        inset 0 1px 0 rgba(255, 255, 255, 0.06) !important;
    overflow: hidden !important;
}

.hp-process-board::before {
    content: "" !important;
    position: absolute !important;
    left: 34px !important;
    right: 34px !important;
    top: 96px !important;
    height: 2px !important;
    background:
        linear-gradient(
            90deg,
            transparent 0%,
            rgba(193, 18, 31, 0.78) 12%,
            rgba(245, 183, 0, 0.9) 50%,
            rgba(193, 18, 31, 0.72) 88%,
            transparent 100%
        ) !important;
    opacity: 0.75 !important;
    pointer-events: none !important;
}

.hp-process-decor {
    position: absolute !important;
    border-radius: 50% !important;
    pointer-events: none !important;
    filter: blur(1px) !important;
}

.hp-process-decor-one {
    width: 230px !important;
    height: 230px !important;
    left: -90px !important;
    top: -110px !important;
    background: radial-gradient(circle, rgba(193, 18, 31, 0.22), transparent 70%) !important;
}

.hp-process-decor-two {
    width: 280px !important;
    height: 280px !important;
    right: -120px !important;
    bottom: -130px !important;
    background: radial-gradient(circle, rgba(245, 183, 0, 0.18), transparent 68%) !important;
}

.hp-process-track {
    position: relative !important;
    z-index: 2 !important;
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 22px !important;
}

.hp-process-card {
    position: relative !important;
    min-height: 282px !important;
    padding: 26px !important;
    border-radius: 28px !important;
    background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.075), rgba(255, 255, 255, 0.025)),
        rgba(10, 10, 10, 0.78) !important;
    border: 1px solid rgba(255, 255, 255, 0.10) !important;
    overflow: hidden !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: space-between !important;
    transition:
        transform 0.34s ease,
        border-color 0.34s ease,
        box-shadow 0.34s ease,
        background 0.34s ease !important;
}

.hp-process-card::before {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    padding: 1.4px !important;
    border-radius: inherit !important;
    background: linear-gradient(135deg, var(--red), var(--gold)) !important;
    opacity: 0 !important;
    pointer-events: none !important;
    transition: 0.34s ease !important;

    -webkit-mask:
        linear-gradient(#fff 0 0) content-box,
        linear-gradient(#fff 0 0) !important;
    -webkit-mask-composite: xor !important;
    mask-composite: exclude !important;
}

.hp-process-card::after {
    content: "" !important;
    position: absolute !important;
    right: -90px !important;
    bottom: -100px !important;
    width: 220px !important;
    height: 220px !important;
    border-radius: 50% !important;
    background: radial-gradient(circle, rgba(245, 183, 0, 0.16), transparent 68%) !important;
    opacity: 0 !important;
    transition: 0.34s ease !important;
    pointer-events: none !important;
}

.hp-process-card:hover {
    transform: translateY(-8px) !important;
    border-color: rgba(245, 183, 0, 0.36) !important;
    background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.09), rgba(255, 255, 255, 0.032)),
        rgba(12, 12, 12, 0.92) !important;
    box-shadow: 0 28px 90px rgba(0, 0, 0, 0.42) !important;
}

.hp-process-card:hover::before,
.hp-process-card:hover::after {
    opacity: 1 !important;
}

.hp-process-line-dot {
    position: absolute !important;
    top: 55px !important;
    left: 50% !important;
    width: 13px !important;
    height: 13px !important;
    border-radius: 50% !important;
    background: var(--gold) !important;
    box-shadow:
        0 0 0 6px rgba(245, 183, 0, 0.12),
        0 0 24px rgba(245, 183, 0, 0.45) !important;
    transform: translateX(-50%) !important;
    z-index: 5 !important;
}

.hp-process-card-top {
    position: relative !important;
    z-index: 2 !important;
    display: flex !important;
    align-items: flex-start !important;
    justify-content: space-between !important;
    gap: 16px !important;
    margin-bottom: 44px !important;
}

.hp-process-number {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: rgba(255, 255, 255, 0.15) !important;
    font-size: 58px !important;
    line-height: 0.9 !important;
    font-weight: 900 !important;
    letter-spacing: -3px !important;
}

.hp-process-icon {
    width: 58px !important;
    height: 58px !important;
    min-width: 58px !important;
    border-radius: 20px !important;
    display: grid !important;
    place-items: center !important;
    color: var(--gold) !important;
    font-size: 25px !important;
    background:
        linear-gradient(135deg, rgba(193, 18, 31, 0.24), rgba(245, 183, 0, 0.12)),
        rgba(0, 0, 0, 0.32) !important;
    border: 1px solid rgba(245, 183, 0, 0.22) !important;
    box-shadow: 0 14px 34px rgba(0, 0, 0, 0.28) !important;
}

.hp-process-card-body {
    position: relative !important;
    z-index: 2 !important;
}

.hp-process-card h3 {
    color: var(--white) !important;
    font-size: clamp(22px, 2.1vw, 29px) !important;
    line-height: 1.14 !important;
    letter-spacing: -0.9px !important;
    margin: 0 0 12px !important;
}

.hp-process-card p {
    color: rgba(255, 255, 255, 0.66) !important;
    font-size: 15px !important;
    line-height: 1.72 !important;
    margin: 0 !important;
}

/* Tablet */
@media (max-width: 992px) {
    .hp-process-header {
        grid-template-columns: 1fr !important;
        align-items: start !important;
        gap: 22px !important;
    }

    .hp-process-header-btn {
        width: fit-content !important;
    }

    .hp-process-board {
        padding: 28px !important;
        border-radius: 30px !important;
    }

    .hp-process-board::before {
        display: none !important;
    }

    .hp-process-track {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    .hp-process-line-dot {
        display: none !important;
    }

    .hp-process-card {
        min-height: 250px !important;
    }

    .hp-process-card-top {
        margin-bottom: 30px !important;
    }
}

/* Mobile */
@media (max-width: 640px) {
    .hp-process-section {
        padding: 64px 0 !important;
    }

    .hp-process-heading h2 {
        font-size: 34px !important;
        line-height: 1.12 !important;
        letter-spacing: -1.4px !important;
    }

    .hp-process-heading p {
        font-size: 14.5px !important;
        line-height: 1.72 !important;
    }

    .hp-process-header-btn {
        width: 100% !important;
        min-height: 52px !important;
    }

    .hp-process-board {
        padding: 18px !important;
        border-radius: 26px !important;
    }

    .hp-process-track {
        grid-template-columns: 1fr !important;
        gap: 16px !important;
    }

    .hp-process-card {
        min-height: auto !important;
        padding: 22px !important;
        border-radius: 22px !important;
    }

    .hp-process-card-top {
        align-items: center !important;
        margin-bottom: 26px !important;
    }

    .hp-process-number {
        font-size: 44px !important;
        letter-spacing: -2px !important;
    }

    .hp-process-icon {
        width: 52px !important;
        height: 52px !important;
        min-width: 52px !important;
        border-radius: 18px !important;
        font-size: 22px !important;
    }

    .hp-process-card h3 {
        font-size: 22px !important;
    }

    .hp-process-card p {
        font-size: 14.5px !important;
    }
}
/* =====================================================
   10BIT PROCESS CINEMATIC TIMELINE
   Giao diện quy trình mới - gọn, sang, đúng brand
===================================================== */
.tbp-process-section {
    position: relative !important;
    overflow: hidden !important;
    background:
        radial-gradient(circle at 12% 10%, rgba(193, 18, 31, 0.18), transparent 32%),
        radial-gradient(circle at 88% 90%, rgba(245, 183, 0, 0.13), transparent 34%),
        linear-gradient(180deg, #080808 0%, #050505 100%) !important;
}

.tbp-process-section::before {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    background:
        linear-gradient(90deg, rgba(255,255,255,0.018) 1px, transparent 1px),
        linear-gradient(180deg, rgba(255,255,255,0.014) 1px, transparent 1px) !important;
    background-size: 78px 78px !important;
    opacity: 0.55 !important;
    pointer-events: none !important;
}

.tbp-process-section .container {
    position: relative !important;
    z-index: 2 !important;
}

.tbp-process-head {
    display: grid !important;
    grid-template-columns: minmax(0, 0.95fr) minmax(320px, 0.72fr) !important;
    gap: 42px !important;
    align-items: end !important;
    margin-bottom: 48px !important;
}

.tbp-process-head h2 {
    color: var(--white) !important;
    font-size: clamp(36px, 4.8vw, 62px) !important;
    line-height: 1.04 !important;
    letter-spacing: -2.4px !important;
    max-width: 760px !important;
}

.tbp-process-head > p {
    color: rgba(255, 255, 255, 0.64) !important;
    font-size: 16.5px !important;
    line-height: 1.78 !important;
    max-width: 520px !important;
    margin-left: auto !important;
}

.tbp-process-timeline {
    position: relative !important;
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 0 !important;
    padding: 34px 0 8px !important;
}

.tbp-process-timeline::before {
    content: "" !important;
    position: absolute !important;
    left: 8% !important;
    right: 8% !important;
    top: 67px !important;
    height: 2px !important;
    background:
        linear-gradient(
            90deg,
            transparent,
            rgba(193, 18, 31, 0.95),
            rgba(245, 183, 0, 0.95),
            rgba(193, 18, 31, 0.95),
            transparent
        ) !important;
    box-shadow: 0 0 28px rgba(245, 183, 0, 0.25) !important;
    pointer-events: none !important;
}

.tbp-process-item {
    position: relative !important;
    display: grid !important;
    gap: 28px !important;
    padding: 0 11px !important;
}

.tbp-process-marker {
    position: relative !important;
    z-index: 5 !important;
    display: flex !important;
    justify-content: center !important;
}

.tbp-process-marker span {
    width: 66px !important;
    height: 66px !important;
    border-radius: 22px !important;
    display: grid !important;
    place-items: center !important;
    color: var(--gold) !important;
    font-size: 25px !important;
    background:
        linear-gradient(145deg, rgba(255,255,255,0.08), rgba(255,255,255,0.02)),
        #101010 !important;
    border: 1px solid rgba(245, 183, 0, 0.34) !important;
    box-shadow:
        0 0 0 8px rgba(245, 183, 0, 0.06),
        0 18px 46px rgba(0,0,0,0.42) !important;
}

.tbp-process-card {
    position: relative !important;
    min-height: 270px !important;
    padding: 28px !important;
    border-radius: 30px !important;
    background:
        linear-gradient(145deg, rgba(255,255,255,0.075), rgba(255,255,255,0.022)),
        rgba(18, 18, 18, 0.92) !important;
    border: 1px solid rgba(255,255,255,0.10) !important;
    overflow: hidden !important;
    transition: 0.34s ease !important;
}

.tbp-process-card::before {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    background:
        radial-gradient(circle at 22% 14%, rgba(245, 183, 0, 0.16), transparent 34%),
        radial-gradient(circle at 92% 94%, rgba(193, 18, 31, 0.18), transparent 38%) !important;
    opacity: 0 !important;
    transition: 0.34s ease !important;
    pointer-events: none !important;
}

.tbp-process-card::after {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    padding: 1.5px !important;
    border-radius: inherit !important;
    background: linear-gradient(135deg, var(--red), var(--gold)) !important;
    opacity: 0 !important;
    pointer-events: none !important;
    transition: 0.34s ease !important;

    -webkit-mask:
        linear-gradient(#fff 0 0) content-box,
        linear-gradient(#fff 0 0) !important;
    -webkit-mask-composite: xor !important;
    mask-composite: exclude !important;
}

.tbp-process-item:hover .tbp-process-card {
    transform: translateY(-8px) !important;
    border-color: rgba(245, 183, 0, 0.28) !important;
    box-shadow: 0 30px 90px rgba(0,0,0,0.42) !important;
}

.tbp-process-item:hover .tbp-process-card::before,
.tbp-process-item:hover .tbp-process-card::after {
    opacity: 1 !important;
}

.tbp-process-number {
    position: relative !important;
    z-index: 2 !important;
    display: block !important;
    color: rgba(255, 255, 255, 0.13) !important;
    font-size: 64px !important;
    line-height: 0.9 !important;
    font-weight: 900 !important;
    letter-spacing: -4px !important;
    margin-bottom: 38px !important;
}

.tbp-process-card h3 {
    position: relative !important;
    z-index: 2 !important;
    color: var(--white) !important;
    font-size: clamp(21px, 2vw, 28px) !important;
    line-height: 1.14 !important;
    letter-spacing: -0.9px !important;
    margin: 0 0 13px !important;
}

.tbp-process-card p {
    position: relative !important;
    z-index: 2 !important;
    color: rgba(255,255,255,0.64) !important;
    font-size: 15px !important;
    line-height: 1.74 !important;
    margin: 0 !important;
}

/* Nếu có 5 hoặc 6 bước thì tự xuống hàng đẹp hơn */
.tbp-process-timeline:has(.tbp-process-item:nth-child(5)) {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    row-gap: 34px !important;
}

.tbp-process-timeline:has(.tbp-process-item:nth-child(5))::before {
    display: none !important;
}

/* Tablet */
@media (max-width: 1080px) {
    .tbp-process-head {
        grid-template-columns: 1fr !important;
        gap: 18px !important;
        margin-bottom: 38px !important;
    }

    .tbp-process-head > p {
        margin-left: 0 !important;
        max-width: 760px !important;
    }

    .tbp-process-timeline,
    .tbp-process-timeline:has(.tbp-process-item:nth-child(5)) {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 24px !important;
        padding-top: 0 !important;
    }

    .tbp-process-timeline::before {
        display: none !important;
    }

    .tbp-process-item {
        gap: 18px !important;
        padding: 0 !important;
    }

    .tbp-process-marker {
        justify-content: flex-start !important;
        margin-left: 22px !important;
        margin-bottom: -48px !important;
    }

    .tbp-process-card {
        padding-top: 76px !important;
        min-height: 260px !important;
    }

    .tbp-process-number {
        margin-bottom: 28px !important;
    }
}

/* Mobile */
@media (max-width: 640px) {
    .tbp-process-section {
        padding: 66px 0 !important;
    }

    .tbp-process-head h2 {
        font-size: 34px !important;
        line-height: 1.12 !important;
        letter-spacing: -1.4px !important;
    }

    .tbp-process-head > p {
        font-size: 14.5px !important;
        line-height: 1.72 !important;
    }

    .tbp-process-timeline,
    .tbp-process-timeline:has(.tbp-process-item:nth-child(5)) {
        grid-template-columns: 1fr !important;
        gap: 20px !important;
    }

    .tbp-process-marker span {
        width: 58px !important;
        height: 58px !important;
        border-radius: 19px !important;
        font-size: 22px !important;
    }

    .tbp-process-card {
        min-height: auto !important;
        padding: 72px 22px 24px !important;
        border-radius: 24px !important;
    }

    .tbp-process-number {
        font-size: 48px !important;
        letter-spacing: -2.5px !important;
        margin-bottom: 26px !important;
    }

    .tbp-process-card h3 {
        font-size: 22px !important;
    }

    .tbp-process-card p {
        font-size: 14.5px !important;
    }
}
/* =========================================================
   10BIT MEDIA - PROCESS ARROW SECTION
   Quy trình dạng mũi tên ngang
========================================================= */
.process-arrow-section {
    position: relative;
    background:
        radial-gradient(circle at top left, rgba(193, 18, 31, 0.12), transparent 28%),
        radial-gradient(circle at bottom right, rgba(212, 175, 55, 0.10), transparent 30%),
        linear-gradient(180deg, #0b0b0b 0%, #050505 100%);
    overflow: hidden;
}

.process-arrow-section::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px),
        linear-gradient(180deg, rgba(255,255,255,0.02) 1px, transparent 1px);
    background-size: 60px 60px;
    opacity: 0.25;
    pointer-events: none;
}

.process-arrow-section .container {
    position: relative;
    z-index: 2;
}

.process-arrow-heading {
    text-align: center;
    max-width: 900px;
    margin: 0 auto 42px;
}

.process-arrow-heading h2 {
    margin-bottom: 14px;
}

.process-arrow-heading .section-description {
    color: rgba(255, 255, 255, 0.72);
    max-width: 760px;
    margin: 0 auto;
    line-height: 1.8;
}

.process-arrow-wrapper {
    display: flex;
    align-items: stretch;
    justify-content: center;
    gap: 0;
    flex-wrap: nowrap;
    margin-top: 14px;
}

.process-arrow-step {
    position: relative;
    flex: 1 1 0;
    min-width: 0;
    padding-top: 58px;
}

.process-arrow-icon {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    z-index: 3;
}

.process-arrow-icon span {
    width: 58px;
    height: 58px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
    background: #111111;
    border: 1px solid rgba(212, 175, 55, 0.45);
    box-shadow: 0 10px 30px rgba(0,0,0,0.28);
}

.process-arrow-shape {
    position: relative;
    height: 100%;
    min-height: 180px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 28px 34px 28px 48px;
    clip-path: polygon(0 0, calc(100% - 28px) 0, 100% 50%, calc(100% - 28px) 100%, 0 100%, 18px 50%);
    margin-right: -10px;
    transition: transform 0.25s ease, box-shadow 0.25s ease, filter 0.25s ease;
    box-shadow: 0 16px 35px rgba(0, 0, 0, 0.20);
}

.process-arrow-step:first-child .process-arrow-shape {
    clip-path: polygon(0 0, calc(100% - 28px) 0, 100% 50%, calc(100% - 28px) 100%, 0 100%, 0 0);
    padding-left: 34px;
}

.process-arrow-step:last-child .process-arrow-shape {
    margin-right: 0;
}

.process-arrow-step:hover .process-arrow-shape {
    transform: translateY(-6px);
    box-shadow: 0 22px 44px rgba(0,0,0,0.28);
    filter: brightness(1.03);
}

.process-arrow-content {
    text-align: center;
    width: 100%;
}

.process-arrow-number {
    display: inline-block;
    font-size: 14px;
    font-weight: 700;
    margin-bottom: 10px;
    letter-spacing: 0.4px;
    text-transform: uppercase;
}

.process-arrow-content h3 {
    margin: 0 0 8px;
    font-size: clamp(22px, 2vw, 34px);
    line-height: 1.2;
    font-weight: 800;
}

.process-arrow-content p {
    margin: 0;
    font-size: 14px;
    line-height: 1.7;
    opacity: 0.85;
}

/* ===== Theme màu ===== */
.arrow-theme-light .process-arrow-shape {
    background: linear-gradient(135deg, #f7f7f7 0%, #ececec 100%);
    border: 1px solid rgba(0,0,0,0.08);
}

.arrow-theme-light .process-arrow-number,
.arrow-theme-light .process-arrow-content h3,
.arrow-theme-light .process-arrow-content p {
    color: #111111;
}

.arrow-theme-light .process-arrow-icon span {
    background: #ffffff;
    color: #111111;
    border-color: rgba(0,0,0,0.12);
}

.arrow-theme-gold .process-arrow-shape {
    background: linear-gradient(135deg, #f1dfab 0%, #e3c978 100%);
    border: 1px solid rgba(120, 90, 10, 0.16);
}

.arrow-theme-gold .process-arrow-number,
.arrow-theme-gold .process-arrow-content h3,
.arrow-theme-gold .process-arrow-content p {
    color: #171717;
}

.arrow-theme-gold .process-arrow-icon span {
    background: #151515;
    color: #e5c96a;
    border-color: rgba(229, 201, 106, 0.45);
}

.arrow-theme-dark .process-arrow-shape {
    background: linear-gradient(135deg, #1b1b1b 0%, #111111 100%);
    border: 1px solid rgba(255,255,255,0.08);
}

.arrow-theme-dark .process-arrow-number {
    color: #d4af37;
}

.arrow-theme-dark .process-arrow-content h3 {
    color: #ffffff;
}

.arrow-theme-dark .process-arrow-content p {
    color: rgba(255,255,255,0.72);
}

.arrow-theme-dark .process-arrow-icon span {
    background: #0f0f0f;
    color: #d4af37;
    border-color: rgba(212, 175, 55, 0.4);
}

/* ===== Responsive ===== */
@media (max-width: 1100px) {
    .process-arrow-wrapper {
        flex-wrap: wrap;
        gap: 18px;
    }

    .process-arrow-step {
        flex: 1 1 calc(50% - 18px);
    }

    .process-arrow-shape,
    .process-arrow-step:first-child .process-arrow-shape {
        clip-path: polygon(0 0, calc(100% - 24px) 0, 100% 50%, calc(100% - 24px) 100%, 0 100%, 0 0);
        margin-right: 0;
        padding: 30px 26px;
    }
}

@media (max-width: 767px) {
    .process-arrow-wrapper {
        flex-direction: column;
        gap: 18px;
    }

    .process-arrow-step {
        flex: 1 1 100%;
        width: 100%;
        padding-top: 52px;
    }

    .process-arrow-shape,
    .process-arrow-step:first-child .process-arrow-shape {
        min-height: 150px;
        clip-path: polygon(0 0, 100% 0, 100% calc(100% - 22px), 50% 100%, 0 calc(100% - 22px));
        padding: 26px 18px 34px;
    }

    .process-arrow-content h3 {
        font-size: 24px;
    }

    .process-arrow-content p {
        font-size: 14px;
    }

    .process-arrow-icon span {
        width: 52px;
        height: 52px;
        font-size: 22px;
    }
}
/* =====================================================
   10BIT MEDIA - CLEAN ARROW PROCESS V2
   Sửa lỗi mũi tên bị bóp hẹp, chữ bị xấu
===================================================== */
.tb-arrow-section {
    position: relative !important;
    overflow: hidden !important;
    background:
        radial-gradient(circle at 10% 12%, rgba(193, 18, 31, 0.16), transparent 32%),
        radial-gradient(circle at 88% 86%, rgba(245, 183, 0, 0.13), transparent 34%),
        linear-gradient(180deg, #080808 0%, #050505 100%) !important;
}

.tb-arrow-section::before {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    background:
        linear-gradient(90deg, rgba(255,255,255,0.018) 1px, transparent 1px),
        linear-gradient(180deg, rgba(255,255,255,0.014) 1px, transparent 1px) !important;
    background-size: 72px 72px !important;
    opacity: 0.45 !important;
    pointer-events: none !important;
}

.tb-arrow-section .container {
    position: relative !important;
    z-index: 2 !important;
}

.tb-arrow-heading {
    max-width: 840px !important;
    margin: 0 auto 46px !important;
    text-align: center !important;
}

.tb-arrow-heading h2 {
    color: var(--white) !important;
    font-size: clamp(38px, 5vw, 64px) !important;
    line-height: 1.04 !important;
    letter-spacing: -2.4px !important;
    margin-bottom: 16px !important;
}

.tb-arrow-heading p {
    max-width: 760px !important;
    margin: 0 auto !important;
    color: rgba(255,255,255,0.66) !important;
    font-size: 16.5px !important;
    line-height: 1.75 !important;
}

/* Mấu chốt: 3 mũi tên mỗi hàng, không ép 6 cái chung 1 hàng */
.tb-arrow-grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 24px 28px !important;
    align-items: stretch !important;
}

.tb-arrow-card {
    position: relative !important;
    min-height: 190px !important;
    padding-top: 34px !important;
    transition: transform 0.3s ease, filter 0.3s ease !important;
}

.tb-arrow-card:hover {
    transform: translateY(-7px) !important;
    filter: brightness(1.04) !important;
}

.tb-arrow-icon {
    position: absolute !important;
    top: 0 !important;
    left: 32px !important;
    z-index: 5 !important;
    width: 64px !important;
    height: 64px !important;
    border-radius: 999px !important;
    display: grid !important;
    place-items: center !important;
    font-size: 25px !important;
    background: #111 !important;
    color: var(--gold) !important;
    border: 1px solid rgba(245, 183, 0, 0.42) !important;
    box-shadow:
        0 16px 38px rgba(0,0,0,0.36),
        0 0 0 7px rgba(245,183,0,0.07) !important;
}

.tb-arrow-inner {
    position: relative !important;
    min-height: 170px !important;
    height: 100% !important;
    padding: 42px 48px 30px 34px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    clip-path: polygon(
        0 0,
        calc(100% - 42px) 0,
        100% 50%,
        calc(100% - 42px) 100%,
        0 100%,
        22px 50%
    ) !important;
    border-radius: 0 !important;
    box-shadow: 0 26px 70px rgba(0,0,0,0.28) !important;
    overflow: hidden !important;
}

.tb-arrow-card:nth-child(3n + 1) .tb-arrow-inner {
    clip-path: polygon(
        0 0,
        calc(100% - 42px) 0,
        100% 50%,
        calc(100% - 42px) 100%,
        0 100%
    ) !important;
}

.tb-arrow-inner::before {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    background:
        linear-gradient(120deg, rgba(255,255,255,0.18), transparent 38%),
        radial-gradient(circle at 12% 18%, rgba(255,255,255,0.18), transparent 26%) !important;
    pointer-events: none !important;
    opacity: 0.55 !important;
}

.tb-arrow-inner > * {
    position: relative !important;
    z-index: 2 !important;
}

.tb-arrow-number {
    display: block !important;
    margin-bottom: 7px !important;
    font-size: 13px !important;
    line-height: 1 !important;
    font-weight: 900 !important;
    letter-spacing: 1.2px !important;
    text-transform: uppercase !important;
}

.tb-arrow-card h3 {
    margin: 0 0 8px !important;
    font-size: clamp(24px, 2.4vw, 34px) !important;
    line-height: 1.12 !important;
    letter-spacing: -1.1px !important;
    font-weight: 850 !important;
}

.tb-arrow-card p {
    margin: 0 !important;
    font-size: 14.5px !important;
    line-height: 1.6 !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
}

/* Màu 1: trắng */
.tb-arrow-light .tb-arrow-inner {
    background:
        linear-gradient(135deg, #ffffff 0%, #eeeeee 100%) !important;
    border: 1px solid rgba(0,0,0,0.06) !important;
}

.tb-arrow-light .tb-arrow-number,
.tb-arrow-light h3,
.tb-arrow-light p {
    color: #101010 !important;
}

.tb-arrow-light .tb-arrow-icon {
    background: #ffffff !important;
    color: #c1121f !important;
    border-color: rgba(0,0,0,0.10) !important;
}

/* Màu 2: vàng */
.tb-arrow-gold .tb-arrow-inner {
    background:
        linear-gradient(135deg, #f8e8ad 0%, #dbbd63 100%) !important;
    border: 1px solid rgba(120,90,10,0.14) !important;
}

.tb-arrow-gold .tb-arrow-number,
.tb-arrow-gold h3,
.tb-arrow-gold p {
    color: #111111 !important;
}

/* Màu 3: đen */
.tb-arrow-dark .tb-arrow-inner {
    background:
        linear-gradient(135deg, #1d1d1d 0%, #0e0e0e 100%) !important;
    border: 1px solid rgba(255,255,255,0.10) !important;
}

.tb-arrow-dark .tb-arrow-number {
    color: var(--gold) !important;
}

.tb-arrow-dark h3 {
    color: #ffffff !important;
}

.tb-arrow-dark p {
    color: rgba(255,255,255,0.72) !important;
}

/* Tablet */
@media (max-width: 1080px) {
    .tb-arrow-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 22px !important;
    }

    .tb-arrow-card:nth-child(n) .tb-arrow-inner {
        clip-path: polygon(
            0 0,
            calc(100% - 38px) 0,
            100% 50%,
            calc(100% - 38px) 100%,
            0 100%
        ) !important;
    }
}

/* Mobile */
@media (max-width: 640px) {
    .tb-arrow-section {
        padding: 66px 0 !important;
    }

    .tb-arrow-heading {
        margin-bottom: 34px !important;
    }

    .tb-arrow-heading h2 {
        font-size: 36px !important;
        line-height: 1.1 !important;
        letter-spacing: -1.5px !important;
    }

    .tb-arrow-heading p {
        font-size: 14.5px !important;
        line-height: 1.7 !important;
    }

    .tb-arrow-grid {
        grid-template-columns: 1fr !important;
        gap: 20px !important;
    }

    .tb-arrow-card {
        min-height: auto !important;
        padding-top: 30px !important;
    }

    .tb-arrow-icon {
        left: 24px !important;
        width: 58px !important;
        height: 58px !important;
        font-size: 22px !important;
    }

    .tb-arrow-card:nth-child(n) .tb-arrow-inner {
        min-height: 158px !important;
        padding: 40px 26px 28px !important;
        clip-path: polygon(
            0 0,
            100% 0,
            100% calc(100% - 28px),
            50% 100%,
            0 calc(100% - 28px)
        ) !important;
        border-radius: 22px 22px 0 0 !important;
    }

    .tb-arrow-card h3 {
        font-size: 25px !important;
    }

    .tb-arrow-card p {
        font-size: 14px !important;
        -webkit-line-clamp: 3 !important;
    }
}

/* =====================================================
   10-BIT MEDIA - UPDATE QUY TRÌNH MŨI TÊN
   Bản cập nhật: số bước to hơn + màu thương hiệu đỏ/vàng
   Cách dùng: đặt block này ở CUỐI FILE style.css
===================================================== */

.tb-arrow-section {
    background:
        radial-gradient(circle at 8% 18%, rgba(193, 18, 31, 0.16), transparent 34%),
        radial-gradient(circle at 90% 78%, rgba(245, 183, 0, 0.12), transparent 34%),
        linear-gradient(180deg, #050505 0%, #0a0a0a 100%) !important;
}

.tb-arrow-heading {
    max-width: 820px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    text-align: center !important;
}

.tb-arrow-heading .eyebrow {
    color: var(--gold) !important;
    letter-spacing: 3px !important;
}

.tb-arrow-heading h2 {
    font-size: clamp(42px, 5vw, 72px) !important;
    line-height: 1.02 !important;
    letter-spacing: -2.8px !important;
}

.tb-arrow-heading p {
    max-width: 760px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    color: rgba(255, 255, 255, 0.68) !important;
    font-size: 17px !important;
    line-height: 1.75 !important;
}

.tb-arrow-grid {
    max-width: 1120px !important;
    margin: 48px auto 0 !important;
    gap: 28px 34px !important;
}

.tb-arrow-card {
    isolation: isolate !important;
    padding-top: 38px !important;
}

.tb-arrow-inner {
    min-height: 190px !important;
    padding: 42px 42px 34px 34px !important;
    box-shadow:
        0 26px 80px rgba(0, 0, 0, 0.38),
        inset 0 1px 0 rgba(255, 255, 255, 0.12) !important;
    transition:
        transform 0.32s ease,
        box-shadow 0.32s ease,
        filter 0.32s ease !important;
}

.tb-arrow-card:hover .tb-arrow-inner {
    transform: translateY(-8px) !important;
    filter: saturate(1.04) brightness(1.03) !important;
    box-shadow:
        0 34px 100px rgba(0, 0, 0, 0.48),
        0 0 0 1px rgba(245, 183, 0, 0.10),
        inset 0 1px 0 rgba(255, 255, 255, 0.16) !important;
}

/* Icon nổi phía trên */
.tb-arrow-icon {
    left: 34px !important;
    width: 66px !important;
    height: 66px !important;
    border-radius: 999px !important;
    font-size: 25px !important;
    background:
        linear-gradient(135deg, rgba(17, 17, 17, 0.96), rgba(5, 5, 5, 0.96)) !important;
    border: 1px solid rgba(245, 183, 0, 0.42) !important;
    box-shadow:
        0 16px 34px rgba(0, 0, 0, 0.38),
        0 0 0 7px rgba(245, 183, 0, 0.08) !important;
}

/* SỐ BƯỚC - TO HƠN + MÀU THƯƠNG HIỆU */
.tb-arrow-number {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 88px !important;
    height: 58px !important;
    padding: 0 20px !important;
    margin-bottom: 16px !important;
    border-radius: 16px !important;
    background:
        linear-gradient(135deg, var(--red) 0%, #ff5a1f 46%, var(--gold) 100%) !important;
    color: #ffffff !important;
    font-size: 31px !important;
    line-height: 1 !important;
    font-weight: 900 !important;
    letter-spacing: 1px !important;
    border: 1px solid rgba(255, 255, 255, 0.18) !important;
    box-shadow:
        0 12px 30px rgba(193, 18, 31, 0.26),
        0 10px 26px rgba(245, 183, 0, 0.18) !important;
}

/* Ép đồng nhất màu số trên cả 3 loại card */
.tb-arrow-light .tb-arrow-number,
.tb-arrow-gold .tb-arrow-number,
.tb-arrow-dark .tb-arrow-number {
    background:
        linear-gradient(135deg, var(--red) 0%, #ff5a1f 46%, var(--gold) 100%) !important;
    color: #ffffff !important;
}

/* Chữ trong mũi tên */
.tb-arrow-card h3 {
    margin: 0 0 12px !important;
    font-size: clamp(26px, 2.4vw, 36px) !important;
    line-height: 1.06 !important;
    letter-spacing: -1.3px !important;
    font-weight: 850 !important;
}

.tb-arrow-card p {
    font-size: 15.5px !important;
    line-height: 1.62 !important;
    -webkit-line-clamp: 2 !important;
}

/* Card trắng */
.tb-arrow-light .tb-arrow-inner {
    background:
        linear-gradient(135deg, #ffffff 0%, #eeeeee 100%) !important;
}

/* Card vàng */
.tb-arrow-gold .tb-arrow-inner {
    background:
        linear-gradient(135deg, #f9e9aa 0%, #dbbd63 100%) !important;
}

/* Card đen */
.tb-arrow-dark .tb-arrow-inner {
    background:
        linear-gradient(135deg, #202020 0%, #0d0d0d 100%) !important;
}

/* Tablet */
@media (max-width: 1080px) {
    .tb-arrow-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 24px !important;
    }

    .tb-arrow-inner {
        min-height: 178px !important;
    }

    .tb-arrow-number {
        min-width: 82px !important;
        height: 54px !important;
        font-size: 28px !important;
    }
}

/* Mobile */
@media (max-width: 640px) {
    .tb-arrow-section {
        padding: 64px 0 !important;
    }

    .tb-arrow-heading h2 {
        font-size: 38px !important;
        letter-spacing: -1.4px !important;
    }

    .tb-arrow-heading p {
        font-size: 14.5px !important;
    }

    .tb-arrow-grid {
        grid-template-columns: 1fr !important;
        margin-top: 34px !important;
        gap: 22px !important;
    }

    .tb-arrow-card {
        padding-top: 34px !important;
    }

    .tb-arrow-icon {
        left: 24px !important;
        width: 58px !important;
        height: 58px !important;
        font-size: 22px !important;
    }

    .tb-arrow-card:nth-child(n) .tb-arrow-inner {
        min-height: 178px !important;
        padding: 42px 26px 30px !important;
        clip-path: polygon(
            0 0,
            100% 0,
            100% calc(100% - 30px),
            50% 100%,
            0 calc(100% - 30px)
        ) !important;
        border-radius: 24px 24px 0 0 !important;
    }

    .tb-arrow-number {
        min-width: 72px !important;
        height: 48px !important;
        padding: 0 15px !important;
        margin-bottom: 14px !important;
        border-radius: 13px !important;
        font-size: 24px !important;
    }

    .tb-arrow-card h3 {
        font-size: 27px !important;
        letter-spacing: -0.9px !important;
    }

    .tb-arrow-card p {
        font-size: 14px !important;
        -webkit-line-clamp: 3 !important;
    }
}

/* =====================================================
   10-BIT MEDIA - COMPACT UPDATE QUY TRÌNH MŨI TÊN
   Bản này làm nhỏ lại card + số bước, giữ màu thương hiệu
   Đặt CUỐI FILE style.css để ghi đè bản trước
===================================================== */

.tb-arrow-section {
    padding: 70px 0 78px !important;
}

.tb-arrow-heading {
    max-width: 760px !important;
}

.tb-arrow-heading .eyebrow {
    font-size: 12px !important;
    letter-spacing: 2.6px !important;
    margin-bottom: 10px !important;
}

.tb-arrow-heading h2 {
    font-size: clamp(34px, 4.2vw, 56px) !important;
    line-height: 1.04 !important;
    letter-spacing: -2px !important;
    margin-bottom: 14px !important;
}

.tb-arrow-heading p {
    max-width: 700px !important;
    font-size: 15.5px !important;
    line-height: 1.68 !important;
}

.tb-arrow-grid {
    max-width: 1040px !important;
    margin: 36px auto 0 !important;
    gap: 22px 26px !important;
}

.tb-arrow-card {
    padding-top: 28px !important;
}

/* Thu nhỏ thân mũi tên */
.tb-arrow-inner {
    min-height: 150px !important;
    padding: 30px 34px 26px 26px !important;
    box-shadow:
        0 18px 52px rgba(0, 0, 0, 0.34),
        inset 0 1px 0 rgba(255, 255, 255, 0.10) !important;
}

.tb-arrow-card:hover .tb-arrow-inner {
    transform: translateY(-5px) !important;
    box-shadow:
        0 24px 70px rgba(0, 0, 0, 0.42),
        0 0 0 1px rgba(245, 183, 0, 0.10),
        inset 0 1px 0 rgba(255, 255, 255, 0.14) !important;
}

/* Thu nhỏ icon tròn */
.tb-arrow-icon {
    left: 26px !important;
    top: 0 !important;
    width: 52px !important;
    height: 52px !important;
    font-size: 21px !important;
    box-shadow:
        0 12px 26px rgba(0, 0, 0, 0.36),
        0 0 0 5px rgba(245, 183, 0, 0.08) !important;
}

/* Thu nhỏ số bước nhưng vẫn nổi bật */
.tb-arrow-number {
    min-width: 64px !important;
    height: 40px !important;
    padding: 0 14px !important;
    margin-bottom: 12px !important;
    border-radius: 12px !important;
    font-size: 22px !important;
    line-height: 1 !important;
    letter-spacing: 0.5px !important;
    box-shadow:
        0 8px 20px rgba(193, 18, 31, 0.22),
        0 7px 18px rgba(245, 183, 0, 0.14) !important;
}

/* Chữ trong card nhỏ và gọn hơn */
.tb-arrow-card h3 {
    font-size: clamp(21px, 2vw, 28px) !important;
    line-height: 1.08 !important;
    letter-spacing: -0.8px !important;
    margin: 0 0 8px !important;
}

.tb-arrow-card p {
    font-size: 14px !important;
    line-height: 1.55 !important;
    -webkit-line-clamp: 2 !important;
}

/* Tablet */
@media (max-width: 1080px) {
    .tb-arrow-section {
        padding: 64px 0 72px !important;
    }

    .tb-arrow-grid {
        max-width: 760px !important;
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 20px !important;
    }

    .tb-arrow-inner {
        min-height: 145px !important;
    }

    .tb-arrow-number {
        min-width: 60px !important;
        height: 38px !important;
        font-size: 20px !important;
    }

    .tb-arrow-card h3 {
        font-size: 24px !important;
    }
}

/* Mobile */
@media (max-width: 640px) {
    .tb-arrow-section {
        padding: 56px 0 64px !important;
    }

    .tb-arrow-heading h2 {
        font-size: 34px !important;
        letter-spacing: -1.2px !important;
    }

    .tb-arrow-heading p {
        font-size: 14px !important;
    }

    .tb-arrow-grid {
        grid-template-columns: 1fr !important;
        margin-top: 30px !important;
        gap: 18px !important;
    }

    .tb-arrow-card {
        padding-top: 26px !important;
    }

    .tb-arrow-icon {
        left: 22px !important;
        width: 48px !important;
        height: 48px !important;
        font-size: 19px !important;
    }

    .tb-arrow-card:nth-child(n) .tb-arrow-inner {
        min-height: 145px !important;
        padding: 32px 24px 26px !important;
        border-radius: 22px 22px 0 0 !important;
    }

    .tb-arrow-number {
        min-width: 56px !important;
        height: 36px !important;
        padding: 0 12px !important;
        margin-bottom: 10px !important;
        border-radius: 11px !important;
        font-size: 19px !important;
    }

    .tb-arrow-card h3 {
        font-size: 23px !important;
        letter-spacing: -0.6px !important;
    }

    .tb-arrow-card p {
        font-size: 13.5px !important;
        -webkit-line-clamp: 3 !important;
    }
}


/* =====================================================
   HOME DARK OPTION B - 10-BIT MEDIA
   Giao diện trang chủ darkmode premium.
   Scope chính: .home-dark-root để không phá các trang khác.
===================================================== */
:root {
    --hd-bg: #050505;
    --hd-bg-soft: #0c0c0c;
    --hd-card: #151515;
    --hd-card-2: #1b1b1b;
    --hd-red: var(--red, #c1121f);
    --hd-gold: var(--gold, #f5b700);
    --hd-white: #ffffff;
    --hd-muted: #b9b9b9;
    --hd-border: rgba(255,255,255,0.12);
    --hd-border-gold: rgba(245,183,0,0.34);
}

body {
    background: var(--hd-bg) !important;
}

.site-header {
    background: rgba(5, 5, 5, 0.92) !important;
    border-bottom: 1px solid rgba(245, 183, 0, 0.12) !important;
    backdrop-filter: blur(18px) !important;
}

.site-header .header-inner {
    height: 84px !important;
}

.site-header .main-nav a {
    position: relative !important;
    color: rgba(255,255,255,0.88) !important;
}

.site-header .main-nav a::after {
    content: "" !important;
    position: absolute !important;
    left: 0 !important;
    right: 0 !important;
    bottom: -10px !important;
    height: 2px !important;
    border-radius: 999px !important;
    background: linear-gradient(90deg, var(--hd-red), var(--hd-gold)) !important;
    transform: scaleX(0) !important;
    transform-origin: center !important;
    transition: transform .25s ease !important;
}

.site-header .main-nav a:hover::after {
    transform: scaleX(1) !important;
}

.home-dark-root {
    background:
        radial-gradient(circle at 0% 8%, rgba(193,18,31,0.15), transparent 28%),
        radial-gradient(circle at 100% 35%, rgba(245,183,0,0.09), transparent 30%),
        #050505 !important;
    color: var(--hd-white) !important;
    overflow: hidden !important;
}

.home-dark-root .container {
    width: min(1320px, 90vw) !important;
}

.home-dark-root h1,
.home-dark-root h2,
.home-dark-root h3 {
    color: var(--hd-white) !important;
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif !important;
    font-weight: 760 !important;
    letter-spacing: -1.6px !important;
}

.home-dark-root p {
    color: var(--hd-muted) !important;
}

.hd-kicker {
    color: var(--hd-gold) !important;
    text-transform: uppercase !important;
    letter-spacing: 3px !important;
    font-size: 12px !important;
    line-height: 1.2 !important;
    font-weight: 850 !important;
    margin: 0 0 16px !important;
}

.hd-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    min-height: 54px !important;
    padding: 0 24px !important;
    border-radius: 999px !important;
    font-size: 15px !important;
    font-weight: 800 !important;
    line-height: 1 !important;
    white-space: nowrap !important;
    transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease, background .25s ease !important;
}

.hd-btn-primary {
    color: #fff !important;
    background: linear-gradient(135deg, #ff3131 0%, #ff6a1a 48%, #f5b700 100%) !important;
    box-shadow: 0 18px 44px rgba(193,18,31,0.28) !important;
}

.hd-btn-ghost {
    color: #fff !important;
    background: rgba(255,255,255,0.03) !important;
    border: 1px solid rgba(245,183,0,0.38) !important;
}

.hd-btn:hover {
    transform: translateY(-3px) !important;
    box-shadow: 0 22px 56px rgba(0,0,0,0.34) !important;
}

.hd-text-link {
    display: inline-flex !important;
    align-items: center !important;
    width: fit-content !important;
    color: var(--hd-gold) !important;
    font-weight: 850 !important;
    margin-top: 20px !important;
    transition: color .25s ease, transform .25s ease !important;
}

.hd-text-link:hover {
    color: #fff !important;
    transform: translateX(4px) !important;
}

/* HERO */
.hd-hero-section {
    position: relative !important;
    min-height: 720px !important;
    display: flex !important;
    align-items: center !important;
    padding: 88px 0 80px !important;
    background:
        radial-gradient(circle at 18% 42%, rgba(193,18,31,0.20), transparent 28%),
        radial-gradient(circle at 86% 32%, rgba(245,183,0,0.10), transparent 30%),
        linear-gradient(180deg, #060606 0%, #080808 100%) !important;
    border-bottom: 1px solid rgba(255,255,255,0.08) !important;
    overflow: hidden !important;
}

.hd-hero-bg-mark {
    position: absolute !important;
    left: -8vw !important;
    top: 50% !important;
    width: min(720px, 62vw) !important;
    aspect-ratio: 1 !important;
    transform: translateY(-50%) !important;
    border-radius: 50% !important;
    background:
        conic-gradient(from 210deg, rgba(193,18,31,0.0), rgba(193,18,31,0.48), rgba(245,183,0,0.38), rgba(193,18,31,0.0) 72%),
        radial-gradient(circle, transparent 38%, rgba(255,255,255,0.04) 39%, transparent 41%) !important;
    opacity: .52 !important;
    filter: blur(.1px) !important;
    pointer-events: none !important;
}

.hd-hero-bg-mark::after {
    content: "" !important;
    position: absolute !important;
    inset: 22% !important;
    border-radius: 50% !important;
    background: #060606 !important;
    box-shadow: inset 0 0 80px rgba(0,0,0,.56) !important;
}

.hd-hero-layout {
    position: relative !important;
    z-index: 2 !important;
    display: grid !important;
    grid-template-columns: minmax(0, .92fr) minmax(560px, 1.08fr) !important;
    align-items: center !important;
    gap: 56px !important;
}

.hd-hero-copy {
    max-width: 620px !important;
}

.hd-hero-copy h1 {
    font-size: clamp(44px, 5vw, 72px) !important;
    line-height: .98 !important;
    margin: 0 0 24px !important;
    letter-spacing: -3px !important;
}

.hd-hero-desc {
    max-width: 600px !important;
    font-size: 17px !important;
    line-height: 1.78 !important;
    margin: 0 0 34px !important;
}

.hd-hero-actions {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 14px !important;
}

.hd-hero-showcase {
    display: grid !important;
    grid-template-columns: minmax(0, 1.15fr) minmax(230px, .72fr) !important;
    gap: 18px !important;
    align-items: stretch !important;
}

.hd-feature-card,
.hd-mini-card {
    position: relative !important;
    overflow: hidden !important;
    background-size: cover !important;
    background-position: center !important;
    background-color: #191919 !important;
    border: 1px solid rgba(245,183,0,0.28) !important;
    box-shadow: 0 32px 80px rgba(0,0,0,0.42) !important;
}

.hd-feature-card::before,
.hd-mini-card::before {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    background: linear-gradient(180deg, rgba(0,0,0,.04) 0%, rgba(0,0,0,.82) 100%) !important;
    pointer-events: none !important;
}

.hd-feature-card {
    min-height: 390px !important;
    border-radius: 28px !important;
    display: flex !important;
    align-items: flex-end !important;
}

.hd-side-cards {
    display: grid !important;
    gap: 18px !important;
}

.hd-mini-card {
    min-height: 186px !important;
    border-radius: 24px !important;
    padding: 26px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-end !important;
}

.hd-card-content {
    position: relative !important;
    z-index: 2 !important;
    padding: 34px !important;
    max-width: 520px !important;
}

.hd-card-content span,
.hd-mini-card span,
.hd-project-content span,
.hd-blog-card span {
    color: var(--hd-gold) !important;
    text-transform: uppercase !important;
    letter-spacing: 1.4px !important;
    font-size: 12px !important;
    font-weight: 900 !important;
}

.hd-card-content h2 {
    font-size: clamp(30px, 3vw, 42px) !important;
    line-height: 1.05 !important;
    margin: 10px 0 12px !important;
}

.hd-card-content p,
.hd-mini-card p {
    color: rgba(255,255,255,.78) !important;
    margin: 0 0 14px !important;
}

.hd-card-content a {
    color: var(--hd-gold) !important;
    font-weight: 900 !important;
}

.hd-mini-card > * {
    position: relative !important;
    z-index: 2 !important;
}

.hd-mini-card h3 {
    font-size: 24px !important;
    line-height: 1.08 !important;
    margin: 8px 0 8px !important;
}

/* STATS */
.hd-stats-section {
    position: relative !important;
    z-index: 3 !important;
    margin-top: -38px !important;
    padding-bottom: 34px !important;
}

.hd-stats-panel {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr) !important;
    border-radius: 24px !important;
    background: rgba(18,18,18,0.88) !important;
    border: 1px solid rgba(255,255,255,0.14) !important;
    backdrop-filter: blur(16px) !important;
    overflow: hidden !important;
    box-shadow: 0 24px 70px rgba(0,0,0,0.34) !important;
}

.hd-stats-panel article {
    display: grid !important;
    grid-template-columns: 56px 1fr !important;
    align-items: center !important;
    column-gap: 16px !important;
    padding: 28px 34px !important;
    border-right: 1px solid rgba(255,255,255,0.10) !important;
}

.hd-stats-panel article:last-child {
    border-right: 0 !important;
}

.hd-stat-icon {
    grid-row: span 2 !important;
    width: 48px !important;
    height: 48px !important;
    border-radius: 16px !important;
    display: grid !important;
    place-items: center !important;
    color: var(--hd-gold) !important;
    background: rgba(245,183,0,0.08) !important;
    border: 1px solid rgba(245,183,0,0.30) !important;
    font-size: 24px !important;
}

.hd-stats-panel strong {
    color: var(--hd-white) !important;
    font-size: 38px !important;
    line-height: 1 !important;
    font-weight: 850 !important;
}

.hd-stats-panel p {
    margin: 7px 0 0 !important;
    font-size: 14px !important;
}

/* SHARED SECTIONS */
.hd-section {
    padding: 84px 0 !important;
    position: relative !important;
}

.hd-row-layout {
    display: grid !important;
    grid-template-columns: minmax(230px, 280px) minmax(0, 1fr) !important;
    gap: 42px !important;
    align-items: start !important;
}

.hd-section-side {
    position: sticky !important;
    top: 110px !important;
    align-self: start !important;
}

.hd-section-side h2 {
    font-size: clamp(30px, 3vw, 46px) !important;
    line-height: 1.08 !important;
    margin: 0 0 16px !important;
}

.hd-section-side p:not(.hd-kicker) {
    font-size: 15.5px !important;
    line-height: 1.72 !important;
    margin: 0 !important;
}

.hd-services-section,
.hd-projects-section,
.hd-blog-section {
    background: #101010 !important;
}

.hd-process-section,
.hd-pricing-section,
.hd-feedback-section {
    background:
        radial-gradient(circle at 8% 20%, rgba(193,18,31,0.09), transparent 32%),
        radial-gradient(circle at 92% 80%, rgba(245,183,0,0.07), transparent 28%),
        #080808 !important;
    border-top: 1px solid rgba(255,255,255,0.06) !important;
    border-bottom: 1px solid rgba(255,255,255,0.06) !important;
}

.hd-empty-card {
    padding: 26px !important;
    border-radius: 22px !important;
    background: var(--hd-card) !important;
    border: 1px solid var(--hd-border) !important;
    color: var(--hd-muted) !important;
}

/* SERVICES */
.hd-services-grid {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 18px !important;
}

.hd-service-card {
    position: relative !important;
    min-height: 260px !important;
    padding: 26px !important;
    border-radius: 24px !important;
    background: linear-gradient(145deg, rgba(255,255,255,0.06), rgba(255,255,255,0.018)), var(--hd-card) !important;
    border: 1px solid rgba(255,255,255,0.12) !important;
    overflow: hidden !important;
    transition: transform .28s ease, border-color .28s ease, box-shadow .28s ease !important;
}

.hd-service-card::after,
.hd-price-card::after,
.hd-feedback-card::after {
    content: "" !important;
    position: absolute !important;
    right: -70px !important;
    bottom: -70px !important;
    width: 170px !important;
    height: 170px !important;
    border-radius: 50% !important;
    background: radial-gradient(circle, rgba(245,183,0,0.16), transparent 70%) !important;
    opacity: 0 !important;
    transition: opacity .28s ease !important;
}

.hd-service-card:hover,
.hd-project-card:hover,
.hd-price-card:hover,
.hd-blog-card:hover,
.hd-feedback-card:hover {
    transform: translateY(-7px) !important;
    border-color: rgba(245,183,0,0.40) !important;
    box-shadow: 0 26px 70px rgba(0,0,0,0.36) !important;
}

.hd-service-card:hover::after,
.hd-price-card:hover::after,
.hd-feedback-card:hover::after {
    opacity: 1 !important;
}

.hd-service-card span {
    width: 56px !important;
    height: 56px !important;
    display: grid !important;
    place-items: center !important;
    border-radius: 17px !important;
    color: var(--hd-gold) !important;
    background: rgba(245,183,0,0.08) !important;
    border: 1px solid rgba(245,183,0,0.25) !important;
    font-size: 27px !important;
}

.hd-service-card h3 {
    font-size: 22px !important;
    line-height: 1.16 !important;
    margin: 22px 0 12px !important;
}

.hd-service-card p {
    font-size: 14.5px !important;
    line-height: 1.68 !important;
    margin: 0 0 22px !important;
}

.hd-service-card strong {
    position: relative !important;
    z-index: 2 !important;
    color: var(--hd-gold) !important;
    font-size: 14px !important;
}

/* PROCESS */
.hd-process-layout {
    align-items: center !important;
}

.hd-process-track {
    position: relative !important;
    display: grid !important;
    grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
    gap: 22px !important;
    padding: 12px 0 !important;
}

.hd-process-track::before {
    content: "" !important;
    position: absolute !important;
    left: 6% !important;
    right: 6% !important;
    top: 53px !important;
    height: 1px !important;
    background: linear-gradient(90deg, transparent, rgba(245,183,0,0.56), rgba(193,18,31,0.38), transparent) !important;
}

.hd-process-item {
    position: relative !important;
    z-index: 2 !important;
    text-align: center !important;
}

.hd-process-dot {
    position: relative !important;
    width: 74px !important;
    height: 74px !important;
    margin: 0 auto 16px !important;
    border-radius: 50% !important;
    display: grid !important;
    place-items: center !important;
    background: #0b0b0b !important;
    border: 1px solid rgba(245,183,0,0.55) !important;
    box-shadow: 0 0 0 8px rgba(245,183,0,0.045), 0 14px 30px rgba(0,0,0,0.32) !important;
}

.hd-process-dot span {
    width: 50px !important;
    height: 50px !important;
    display: grid !important;
    place-items: center !important;
    border-radius: 50% !important;
    color: #fff !important;
    font-size: 18px !important;
    font-weight: 900 !important;
    background: linear-gradient(135deg, #ff3030, #ff7a1b, #f5b700) !important;
}

.hd-process-icon {
    color: var(--hd-gold) !important;
    font-size: 22px !important;
    line-height: 1 !important;
    margin-bottom: 12px !important;
}

.hd-process-item h3 {
    font-size: 17px !important;
    line-height: 1.25 !important;
    letter-spacing: -0.4px !important;
    margin: 0 0 10px !important;
}

.hd-process-item p {
    font-size: 13.4px !important;
    line-height: 1.55 !important;
    margin: 0 auto !important;
    max-width: 150px !important;
}

/* PROJECTS */
.hd-project-grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 22px !important;
}

.hd-project-card,
.hd-blog-card,
.hd-price-card,
.hd-feedback-card {
    position: relative !important;
    overflow: hidden !important;
    border-radius: 24px !important;
    background: var(--hd-card) !important;
    border: 1px solid rgba(255,255,255,0.12) !important;
    transition: transform .28s ease, border-color .28s ease, box-shadow .28s ease !important;
}

.hd-project-card {
    cursor: pointer !important;
}

.hd-project-image,
.hd-blog-image {
    display: block !important;
    min-height: 235px !important;
    background-size: cover !important;
    background-position: center !important;
    background-color: #222 !important;
}

.hd-project-content {
    padding: 22px !important;
}

.hd-project-content h3 {
    font-size: 22px !important;
    line-height: 1.2 !important;
    margin: 8px 0 8px !important;
}

.hd-project-content p {
    font-size: 13.5px !important;
    margin: 0 !important;
}

/* PARTNERS OVERRIDE */
.home-dark-root + .partners-section,
.home-dark-root .partners-section,
.partners-section {
    background: #101010 !important;
}

/* PRICING */
.hd-pricing-grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 22px !important;
}

.hd-price-card {
    min-height: 430px !important;
    padding: 30px !important;
    display: flex !important;
    flex-direction: column !important;
}

.hd-price-card.is-popular {
    border-color: rgba(245,183,0,0.56) !important;
    box-shadow: 0 24px 80px rgba(245,183,0,0.08) !important;
}

.hd-badge {
    width: fit-content !important;
    display: inline-flex !important;
    padding: 7px 13px !important;
    border-radius: 999px !important;
    color: var(--hd-gold) !important;
    background: rgba(245,183,0,0.14) !important;
    font-size: 12px !important;
    font-weight: 900 !important;
    margin-bottom: 16px !important;
}

.hd-price-card h3 {
    font-size: 24px !important;
    margin: 0 0 14px !important;
}

.hd-price-card > strong {
    color: #ff3d35 !important;
    font-size: 30px !important;
    line-height: 1.1 !important;
    font-weight: 900 !important;
    margin-bottom: 18px !important;
}

.hd-price-card p {
    font-size: 14px !important;
    line-height: 1.65 !important;
    margin: 0 0 18px !important;
}

.hd-price-card ul {
    list-style: none !important;
    display: grid !important;
    gap: 9px !important;
    margin: 0 0 28px !important;
    padding: 0 !important;
}

.hd-price-card li {
    color: var(--hd-muted) !important;
    font-size: 14px !important;
    line-height: 1.45 !important;
}

.hd-price-card li::before {
    content: "✓" !important;
    color: var(--hd-gold) !important;
    margin-right: 8px !important;
    font-weight: 900 !important;
}

.hd-price-btn {
    position: relative !important;
    z-index: 2 !important;
    margin-top: auto !important;
    min-height: 50px !important;
    border-radius: 999px !important;
    display: grid !important;
    place-items: center !important;
    color: #fff !important;
    border: 1px solid rgba(245,183,0,0.42) !important;
    font-weight: 850 !important;
    transition: background .25s ease, transform .25s ease !important;
}

.hd-price-card.is-popular .hd-price-btn,
.hd-price-btn:hover {
    background: linear-gradient(135deg, #ff3131, #ff7a1a, #f5b700) !important;
    border-color: transparent !important;
}

/* BLOG */
.hd-blog-grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 22px !important;
}

.hd-blog-card {
    background: #171717 !important;
}

.hd-blog-card > div:not(.hd-blog-image) {
    padding: 22px !important;
}

.hd-blog-card h3 {
    font-size: 21px !important;
    line-height: 1.24 !important;
    margin: 10px 0 12px !important;
}

.hd-blog-card p {
    font-size: 14.5px !important;
    line-height: 1.65 !important;
    margin: 0 !important;
}

/* FEEDBACK */
.hd-feedback-grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 22px !important;
}

.hd-feedback-card {
    min-height: 250px !important;
    padding: 26px !important;
}

.hd-quote-mark {
    color: #ff3d35 !important;
    font-family: Georgia, serif !important;
    font-size: 64px !important;
    line-height: .7 !important;
    margin-bottom: 18px !important;
}

.hd-feedback-card > p {
    font-size: 15px !important;
    line-height: 1.7 !important;
    margin: 0 0 24px !important;
}

.hd-feedback-author {
    display: flex !important;
    align-items: center !important;
    gap: 14px !important;
    margin-top: auto !important;
}

.hd-feedback-author img,
.hd-feedback-author > span {
    width: 52px !important;
    height: 52px !important;
    min-width: 52px !important;
    border-radius: 50% !important;
    object-fit: cover !important;
    display: grid !important;
    place-items: center !important;
    color: #fff !important;
    background: linear-gradient(135deg, var(--hd-red), var(--hd-gold)) !important;
    border: 2px solid rgba(245,183,0,0.55) !important;
    font-weight: 900 !important;
}

.hd-feedback-author strong {
    display: block !important;
    color: #fff !important;
    font-size: 15px !important;
}

.hd-feedback-author em {
    display: block !important;
    color: var(--hd-muted) !important;
    font-style: normal !important;
    font-size: 12px !important;
    margin-top: 2px !important;
}

.hd-feedback-author small {
    display: block !important;
    color: var(--hd-gold) !important;
    letter-spacing: 2px !important;
    font-size: 12px !important;
    margin-top: 5px !important;
}

/* CTA */
.hd-cta-section {
    padding: 64px 0 78px !important;
    background: #080808 !important;
}

.hd-cta-box {
    position: relative !important;
    overflow: hidden !important;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    align-items: center !important;
    gap: 34px !important;
    padding: 42px !important;
    border-radius: 28px !important;
    background:
        radial-gradient(circle at 100% 0%, rgba(245,183,0,0.26), transparent 34%),
        linear-gradient(135deg, rgba(193,18,31,0.72), rgba(245,183,0,0.30)),
        #171717 !important;
    border: 1px solid rgba(245,183,0,0.36) !important;
    box-shadow: 0 28px 90px rgba(0,0,0,0.34) !important;
}

.hd-cta-box h2 {
    font-size: clamp(32px, 4vw, 54px) !important;
    line-height: 1.08 !important;
    margin: 0 0 12px !important;
}

.hd-cta-box p:not(.hd-kicker) {
    margin: 0 !important;
    max-width: 720px !important;
}

/* RESPONSIVE */
@media (max-width: 1180px) {
    .hd-hero-layout {
        grid-template-columns: 1fr !important;
        gap: 42px !important;
    }

    .hd-hero-copy {
        max-width: 820px !important;
    }

    .hd-hero-showcase {
        grid-template-columns: 1.1fr .9fr !important;
    }

    .hd-services-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    .hd-process-track {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
        row-gap: 34px !important;
    }

    .hd-process-track::before {
        display: none !important;
    }
}

@media (max-width: 992px) {
    .home-dark-root .container {
        width: min(100% - 36px, 760px) !important;
    }

    .hd-row-layout {
        grid-template-columns: 1fr !important;
        gap: 28px !important;
    }

    .hd-section-side {
        position: static !important;
        max-width: 760px !important;
    }

    .hd-stats-panel {
        grid-template-columns: repeat(2, 1fr) !important;
    }

    .hd-stats-panel article:nth-child(2) {
        border-right: 0 !important;
    }

    .hd-stats-panel article:nth-child(1),
    .hd-stats-panel article:nth-child(2) {
        border-bottom: 1px solid rgba(255,255,255,0.10) !important;
    }

    .hd-project-grid,
    .hd-pricing-grid,
    .hd-blog-grid,
    .hd-feedback-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    .hd-cta-box {
        grid-template-columns: 1fr !important;
        align-items: start !important;
    }
}

@media (max-width: 768px) {
    .hd-hero-section {
        min-height: auto !important;
        padding: 58px 0 62px !important;
    }

    .hd-hero-copy h1 {
        font-size: clamp(38px, 11vw, 56px) !important;
        letter-spacing: -2px !important;
    }

    .hd-hero-showcase {
        grid-template-columns: 1fr !important;
    }

    .hd-feature-card {
        min-height: 320px !important;
    }

    .hd-side-cards {
        grid-template-columns: 1fr !important;
    }

    .hd-mini-card {
        min-height: 170px !important;
    }

    .hd-section {
        padding: 64px 0 !important;
    }

    .hd-services-grid,
    .hd-project-grid,
    .hd-pricing-grid,
    .hd-blog-grid,
    .hd-feedback-grid,
    .hd-process-track {
        grid-template-columns: 1fr !important;
    }

    .hd-process-item {
        display: grid !important;
        grid-template-columns: 70px 1fr !important;
        column-gap: 16px !important;
        text-align: left !important;
        align-items: start !important;
        padding: 18px !important;
        border-radius: 22px !important;
        background: rgba(255,255,255,0.035) !important;
        border: 1px solid rgba(255,255,255,0.09) !important;
    }

    .hd-process-dot {
        grid-row: span 3 !important;
        width: 60px !important;
        height: 60px !important;
        margin: 0 !important;
    }

    .hd-process-dot span {
        width: 42px !important;
        height: 42px !important;
        font-size: 15px !important;
    }

    .hd-process-icon {
        margin-bottom: 8px !important;
    }

    .hd-process-item p {
        max-width: none !important;
        margin: 0 !important;
    }

    .hd-stats-panel {
        grid-template-columns: 1fr !important;
    }

    .hd-stats-panel article {
        border-right: 0 !important;
        border-bottom: 1px solid rgba(255,255,255,0.10) !important;
        padding: 24px !important;
    }

    .hd-stats-panel article:last-child {
        border-bottom: 0 !important;
    }

    .hd-cta-box {
        padding: 30px !important;
        border-radius: 24px !important;
    }

    .hd-cta-box .hd-btn {
        width: 100% !important;
    }
}

@media (max-width: 520px) {
    .home-dark-root .container {
        width: min(100% - 28px, 460px) !important;
    }

    .hd-hero-actions {
        flex-direction: column !important;
    }

    .hd-btn {
        width: 100% !important;
    }

    .hd-card-content {
        padding: 26px !important;
    }

    .hd-feature-card {
        min-height: 285px !important;
        border-radius: 24px !important;
    }

    .hd-card-content h2 {
        font-size: 29px !important;
    }

    .hd-section-side h2 {
        font-size: 34px !important;
    }

    .hd-project-image,
    .hd-blog-image {
        min-height: 220px !important;
    }
}

/* =====================================================
   MOBILE PREMIUM MOCKUP - 10BIT MEDIA
   Tối ưu riêng cho mobile theo layout compact/cinematic.
   Đặt cuối CSS để ghi đè các block mobile cũ.
===================================================== */
@media (max-width: 768px) {
    html,
    body {
        background: #020202 !important;
        overflow-x: hidden !important;
    }

    body {
        font-size: 14px !important;
    }

    body::before {
        content: "" !important;
        position: fixed !important;
        inset: 0 !important;
        pointer-events: none !important;
        z-index: -1 !important;
        background:
            radial-gradient(circle at 18% 4%, rgba(193,18,31,.16), transparent 28%),
            radial-gradient(circle at 88% 18%, rgba(245,183,0,.10), transparent 24%),
            #020202 !important;
    }

    .site-header {
        position: sticky !important;
        top: 0 !important;
        z-index: 9999 !important;
        width: min(100% - 18px, 430px) !important;
        margin: 0 auto !important;
        border-left: 1px solid rgba(255,255,255,.13) !important;
        border-right: 1px solid rgba(255,255,255,.13) !important;
        border-bottom: 1px solid rgba(255,255,255,.13) !important;
        border-radius: 0 0 18px 18px !important;
        background: rgba(5,5,5,.94) !important;
        box-shadow: 0 16px 44px rgba(0,0,0,.36) !important;
        backdrop-filter: blur(18px) !important;
    }

    .site-header .container,
    .site-header .header-inner {
        width: 100% !important;
        max-width: none !important;
    }

    .site-header .header-inner {
        height: 78px !important;
        padding: 0 18px !important;
        gap: 12px !important;
    }

    .site-header .logo.has-image,
    .site-header .logo {
        max-width: 142px !important;
        min-width: 0 !important;
    }

    .site-logo-img {
        width: auto !important;
        max-width: 128px !important;
        max-height: 54px !important;
        min-width: 0 !important;
    }

    .menu-toggle {
        width: 46px !important;
        height: 46px !important;
        border-radius: 14px !important;
        border: 1px solid rgba(255,255,255,.16) !important;
        background: rgba(255,255,255,.035) !important;
        color: #fff !important;
        font-size: 26px !important;
        padding: 0 !important;
        box-shadow: inset 0 1px 0 rgba(255,255,255,.06) !important;
    }

    .site-header .main-nav {
        top: 78px !important;
        left: 50% !important;
        width: min(100% - 18px, 430px) !important;
        transform: translate(-50%, -130%) !important;
        border: 1px solid rgba(255,255,255,.12) !important;
        border-top: 0 !important;
        border-radius: 0 0 18px 18px !important;
        background: rgba(5,5,5,.985) !important;
        padding: 12px 20px 18px !important;
    }

    .site-header .main-nav.active {
        transform: translate(-50%, 0) !important;
    }

    .site-header .main-nav a {
        font-size: 15px !important;
        padding: 13px 0 !important;
    }

    .home-dark-root {
        width: min(100% - 18px, 430px) !important;
        margin: 0 auto 18px !important;
        border-left: 1px solid rgba(255,255,255,.13) !important;
        border-right: 1px solid rgba(255,255,255,.13) !important;
        border-bottom: 1px solid rgba(255,255,255,.13) !important;
        border-radius: 0 0 22px 22px !important;
        background:
            linear-gradient(180deg, rgba(255,255,255,.025), transparent 18%),
            radial-gradient(circle at 16% 0%, rgba(193,18,31,.12), transparent 26%),
            radial-gradient(circle at 88% 9%, rgba(245,183,0,.10), transparent 22%),
            #050505 !important;
        box-shadow: 0 30px 80px rgba(0,0,0,.48) !important;
        overflow: hidden !important;
    }

    .home-dark-root .container {
        width: calc(100% - 28px) !important;
        max-width: 402px !important;
        margin-left: auto !important;
        margin-right: auto !important;
    }

    .home-dark-root h1,
    .home-dark-root h2,
    .home-dark-root h3 {
        letter-spacing: -0.8px !important;
    }

    .hd-kicker {
        font-size: 11px !important;
        letter-spacing: 1.8px !important;
        margin-bottom: 10px !important;
        color: #ffc400 !important;
    }

    .hd-section {
        padding: 22px 0 !important;
        background: transparent !important;
        border: 0 !important;
    }

    .hd-row-layout {
        display: block !important;
    }

    .hd-section-side {
        position: static !important;
        margin-bottom: 14px !important;
    }

    .hd-section-side h2 {
        font-size: 20px !important;
        line-height: 1.12 !important;
        margin: 0 0 8px !important;
    }

    .hd-section-side p:not(.hd-kicker) {
        display: none !important;
    }

    .hd-section-side .hd-text-link {
        margin-top: 8px !important;
        font-size: 12px !important;
    }

    /* HERO compact: text trái + hình phải giống mockup mobile */
    .hd-hero-section {
        min-height: auto !important;
        padding: 0 !important;
        border-bottom: 0 !important;
        background:
            linear-gradient(90deg, rgba(0,0,0,.88), rgba(0,0,0,.55)),
            radial-gradient(circle at 88% 22%, rgba(245,183,0,.18), transparent 28%),
            radial-gradient(circle at 38% 30%, rgba(193,18,31,.16), transparent 32%),
            #070707 !important;
    }

    .hd-hero-section > .container {
        width: 100% !important;
        max-width: none !important;
    }

    .hd-hero-bg-mark {
        left: auto !important;
        right: -48px !important;
        top: 96px !important;
        width: 210px !important;
        opacity: .9 !important;
        transform: none !important;
        background: conic-gradient(from 210deg, rgba(193,18,31,0), rgba(255,45,65,.92), rgba(245,183,0,.88), rgba(193,18,31,0) 72%) !important;
        filter: drop-shadow(0 16px 36px rgba(193,18,31,.28)) !important;
    }

    .hd-hero-bg-mark::after {
        inset: 22% !important;
        background: rgba(5,5,5,.28) !important;
        box-shadow: none !important;
    }

    .hd-hero-layout {
        display: grid !important;
        grid-template-columns: 1fr 132px !important;
        gap: 0 !important;
        align-items: center !important;
        min-height: 278px !important;
        padding: 28px 14px 22px !important;
        overflow: hidden !important;
        position: relative !important;
    }

    .hd-hero-copy {
        max-width: none !important;
        padding-right: 4px !important;
        z-index: 4 !important;
    }

    .hd-hero-copy .hd-kicker {
        display: none !important;
    }

    .hd-hero-copy h1 {
        max-width: 230px !important;
        font-size: 23px !important;
        line-height: 1.14 !important;
        letter-spacing: -0.8px !important;
        text-transform: uppercase !important;
        margin: 0 0 12px !important;
    }

    .hd-hero-copy h1::first-line {
        color: #fff !important;
    }

    .hd-hero-desc {
        max-width: 218px !important;
        font-size: 12.5px !important;
        line-height: 1.62 !important;
        margin: 0 0 16px !important;
        color: rgba(255,255,255,.74) !important;
        display: -webkit-box !important;
        -webkit-line-clamp: 4 !important;
        -webkit-box-orient: vertical !important;
        overflow: hidden !important;
    }

    .hd-hero-actions {
        display: flex !important;
        flex-direction: row !important;
        flex-wrap: nowrap !important;
        gap: 8px !important;
    }

    .hd-btn {
        width: auto !important;
        min-height: 40px !important;
        padding: 0 13px !important;
        border-radius: 10px !important;
        font-size: 12px !important;
        gap: 6px !important;
    }

    .hd-hero-actions .hd-btn-primary {
        min-width: 116px !important;
    }

    .hd-hero-actions .hd-btn-ghost {
        min-width: 0 !important;
        padding: 0 11px !important;
        background: rgba(255,255,255,.045) !important;
        border-color: rgba(255,255,255,.22) !important;
    }

    .hd-hero-showcase {
        display: block !important;
        position: relative !important;
        z-index: 3 !important;
        width: 145px !important;
        height: 210px !important;
        align-self: center !important;
    }

    .hd-feature-card {
        position: absolute !important;
        right: -30px !important;
        top: 4px !important;
        width: 178px !important;
        height: 198px !important;
        min-height: 0 !important;
        border: 0 !important;
        border-radius: 0 !important;
        background-size: cover !important;
        background-position: center !important;
        clip-path: inset(0 round 20px) !important;
        box-shadow: none !important;
        opacity: .96 !important;
    }

    .hd-feature-card::before {
        background: linear-gradient(180deg, rgba(0,0,0,.04), rgba(0,0,0,.22)) !important;
    }

    .hd-feature-card .hd-card-content {
        display: none !important;
    }

    .hd-side-cards {
        display: none !important;
    }

    /* STATS compact 4 cột */
    .hd-stats-section {
        margin: 0 !important;
        padding: 14px 0 18px !important;
        background: transparent !important;
    }

    .hd-stats-panel {
        grid-template-columns: repeat(4, 1fr) !important;
        border-radius: 16px !important;
        overflow: hidden !important;
        background: linear-gradient(145deg, rgba(255,255,255,.065), rgba(255,255,255,.018)) !important;
        border: 1px solid rgba(255,255,255,.14) !important;
    }

    .hd-stats-panel article {
        min-width: 0 !important;
        padding: 12px 5px !important;
        gap: 4px !important;
        display: grid !important;
        justify-items: center !important;
        text-align: center !important;
        border-right: 1px solid rgba(255,255,255,.10) !important;
        border-bottom: 0 !important;
    }

    .hd-stats-panel article:last-child {
        border-right: 0 !important;
    }

    .hd-stat-icon {
        width: 30px !important;
        height: 30px !important;
        min-width: 30px !important;
        border-radius: 10px !important;
        font-size: 14px !important;
        margin-bottom: 2px !important;
    }

    .hd-stats-panel h3 {
        font-size: 20px !important;
        line-height: 1 !important;
        margin: 0 !important;
    }

    .hd-stats-panel p {
        font-size: 9px !important;
        line-height: 1.15 !important;
        margin: 0 !important;
        color: rgba(255,255,255,.64) !important;
    }

    /* SERVICES icon cards */
    .hd-services-section {
        padding-top: 10px !important;
    }

    .hd-services-section .hd-section-side .hd-kicker {
        display: none !important;
    }

    .hd-services-section .hd-section-side h2 {
        font-size: 17px !important;
        text-transform: uppercase !important;
        letter-spacing: .2px !important;
        margin-bottom: 12px !important;
    }

    .hd-services-grid {
        display: grid !important;
        grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
        gap: 7px !important;
        overflow: visible !important;
    }

    .hd-service-card {
        min-height: 96px !important;
        padding: 12px 6px 10px !important;
        border-radius: 12px !important;
        text-align: center !important;
        background: linear-gradient(145deg, rgba(255,255,255,.065), rgba(255,255,255,.018)), #101010 !important;
        border-color: rgba(255,255,255,.13) !important;
    }

    .hd-service-card span {
        width: 34px !important;
        height: 34px !important;
        border-radius: 10px !important;
        margin: 0 auto 8px !important;
        font-size: 18px !important;
        color: #ff2f45 !important;
        background: rgba(255,47,69,.06) !important;
        border-color: rgba(245,183,0,.22) !important;
    }

    .hd-service-card h3 {
        font-size: 11.5px !important;
        line-height: 1.18 !important;
        letter-spacing: -0.15px !important;
        margin: 0 0 7px !important;
    }

    .hd-service-card p {
        display: none !important;
    }

    .hd-service-card strong {
        font-size: 15px !important;
        color: #fff !important;
    }

    .hd-service-card strong::before {
        content: "" !important;
    }

    .hd-service-card strong {
        font-size: 0 !important;
    }

    .hd-service-card strong::after {
        content: "→" !important;
        font-size: 16px !important;
    }

    /* PROCESS timeline ngang */
    .hd-process-section {
        padding-top: 8px !important;
    }

    .hd-process-layout .hd-section-side .hd-kicker {
        display: none !important;
    }

    .hd-process-layout .hd-section-side h2 {
        font-size: 17px !important;
        text-transform: uppercase !important;
        margin-bottom: 12px !important;
    }

    .hd-process-track {
        display: flex !important;
        grid-template-columns: none !important;
        gap: 0 !important;
        overflow-x: auto !important;
        padding: 6px 2px 10px !important;
        scrollbar-width: none !important;
    }

    .hd-process-track::-webkit-scrollbar {
        display: none !important;
    }

    .hd-process-track::before {
        display: block !important;
        left: 26px !important;
        right: 26px !important;
        top: 34px !important;
        height: 2px !important;
        background: linear-gradient(90deg, #ff2f45, #f5b700, #ff2f45) !important;
        opacity: .55 !important;
    }

    .hd-process-item {
        flex: 0 0 78px !important;
        display: block !important;
        padding: 0 !important;
        background: transparent !important;
        border: 0 !important;
        text-align: center !important;
    }

    .hd-process-dot {
        width: 42px !important;
        height: 42px !important;
        margin: 0 auto 8px !important;
        background: #0b0b0b !important;
        border-color: rgba(245,183,0,.58) !important;
        box-shadow: 0 0 0 5px rgba(245,183,0,.055) !important;
    }

    .hd-process-dot span {
        width: 32px !important;
        height: 32px !important;
        font-size: 11px !important;
        background: linear-gradient(135deg, #ff2f45, #ff6330, #f5b700) !important;
    }

    .hd-process-icon {
        font-size: 20px !important;
        margin: 0 0 6px !important;
        min-height: 20px !important;
    }

    .hd-process-item h3 {
        font-size: 11px !important;
        line-height: 1.18 !important;
        margin: 0 !important;
        letter-spacing: -0.1px !important;
        color: rgba(255,255,255,.86) !important;
    }

    .hd-process-item p {
        display: none !important;
    }

    /* PROJECT horizontal cards */
    .hd-projects-section .hd-section-side .hd-kicker,
    .hd-pricing-section .hd-section-side .hd-kicker,
    .hd-feedback-section .hd-section-side .hd-kicker,
    .hd-blog-section .hd-section-side .hd-kicker {
        display: none !important;
    }

    .hd-projects-section .hd-section-side,
    .hd-pricing-section .hd-section-side,
    .hd-feedback-section .hd-section-side,
    .hd-blog-section .hd-section-side {
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        gap: 12px !important;
    }

    .hd-projects-section .hd-section-side h2,
    .hd-pricing-section .hd-section-side h2,
    .hd-feedback-section .hd-section-side h2,
    .hd-blog-section .hd-section-side h2 {
        font-size: 17px !important;
        text-transform: uppercase !important;
        margin: 0 !important;
    }

    .hd-project-grid,
    .hd-blog-grid {
        display: flex !important;
        grid-template-columns: none !important;
        gap: 10px !important;
        overflow-x: auto !important;
        padding: 2px 1px 8px !important;
        scroll-snap-type: x mandatory !important;
        scrollbar-width: none !important;
    }

    .hd-project-grid::-webkit-scrollbar,
    .hd-blog-grid::-webkit-scrollbar {
        display: none !important;
    }

    .hd-project-card,
    .hd-blog-card {
        flex: 0 0 152px !important;
        width: 152px !important;
        border-radius: 13px !important;
        scroll-snap-align: start !important;
    }

    .hd-project-image,
    .hd-blog-image {
        min-height: 92px !important;
        height: 92px !important;
    }

    .hd-project-content,
    .hd-blog-card > div:not(.hd-blog-image) {
        padding: 10px !important;
    }

    .hd-project-content span,
    .hd-blog-card span {
        font-size: 8.5px !important;
        letter-spacing: .5px !important;
        padding: 3px 6px !important;
        border-radius: 999px !important;
        background: linear-gradient(135deg, #ff3030, #f5b700) !important;
        color: #fff !important;
        display: inline-flex !important;
        margin-bottom: 4px !important;
    }

    .hd-project-content h3,
    .hd-blog-card h3 {
        font-size: 12.5px !important;
        line-height: 1.18 !important;
        margin: 3px 0 !important;
        letter-spacing: -0.2px !important;
    }

    .hd-project-content p,
    .hd-blog-card p {
        font-size: 10px !important;
        line-height: 1.28 !important;
        display: -webkit-box !important;
        -webkit-line-clamp: 2 !important;
        -webkit-box-orient: vertical !important;
        overflow: hidden !important;
    }

    .hd-blog-card .hd-text-link {
        display: none !important;
    }

    /* PRICING: 3 card compact như mockup */
    .hd-pricing-grid {
        display: flex !important;
        grid-template-columns: none !important;
        gap: 10px !important;
        overflow-x: auto !important;
        padding: 2px 1px 10px !important;
        scroll-snap-type: x mandatory !important;
        scrollbar-width: none !important;
    }

    .hd-pricing-grid::-webkit-scrollbar {
        display: none !important;
    }

    .hd-price-card {
        flex: 0 0 152px !important;
        width: 152px !important;
        min-height: 220px !important;
        padding: 14px 12px !important;
        border-radius: 14px !important;
        scroll-snap-align: start !important;
    }

    .hd-badge {
        position: absolute !important;
        top: 10px !important;
        right: 10px !important;
        font-size: 8px !important;
        padding: 4px 7px !important;
        margin: 0 !important;
    }

    .hd-price-card h3 {
        font-size: 13px !important;
        line-height: 1.2 !important;
        margin: 0 0 8px !important;
        padding-right: 36px !important;
    }

    .hd-price-card > strong {
        font-size: 20px !important;
        margin-bottom: 10px !important;
        color: #ff2f45 !important;
    }

    .hd-price-card.is-popular > strong {
        color: #f5b700 !important;
    }

    .hd-price-card p {
        display: none !important;
    }

    .hd-price-card ul {
        gap: 5px !important;
        margin-bottom: 12px !important;
    }

    .hd-price-card li {
        font-size: 10.5px !important;
        line-height: 1.25 !important;
    }

    .hd-price-card li::before {
        margin-right: 4px !important;
    }

    .hd-price-btn {
        min-height: 36px !important;
        font-size: 11px !important;
        border-radius: 10px !important;
    }

    /* FEEDBACK one-card compact */
    .hd-feedback-grid {
        display: flex !important;
        grid-template-columns: none !important;
        gap: 12px !important;
        overflow-x: auto !important;
        padding: 2px 1px 12px !important;
        scroll-snap-type: x mandatory !important;
        scrollbar-width: none !important;
    }

    .hd-feedback-grid::-webkit-scrollbar {
        display: none !important;
    }

    .hd-feedback-card {
        flex: 0 0 100% !important;
        min-height: 122px !important;
        padding: 18px 18px 18px 92px !important;
        border-radius: 16px !important;
        scroll-snap-align: start !important;
    }

    .hd-quote-mark {
        position: absolute !important;
        left: 16px !important;
        top: 16px !important;
        font-size: 34px !important;
        margin: 0 !important;
    }

    .hd-feedback-card > p {
        font-size: 12px !important;
        line-height: 1.48 !important;
        margin: 0 0 10px !important;
        display: -webkit-box !important;
        -webkit-line-clamp: 3 !important;
        -webkit-box-orient: vertical !important;
        overflow: hidden !important;
    }

    .hd-feedback-author {
        gap: 9px !important;
    }

    .hd-feedback-author img,
    .hd-feedback-author > span {
        position: absolute !important;
        left: 36px !important;
        top: 46px !important;
        width: 48px !important;
        height: 48px !important;
        min-width: 48px !important;
    }

    .hd-feedback-author strong {
        font-size: 11.5px !important;
    }

    .hd-feedback-author em {
        font-size: 10px !important;
    }

    .hd-feedback-author small {
        font-size: 10px !important;
        letter-spacing: 1px !important;
    }

    /* CTA */
    .hd-cta-section {
        padding: 18px 0 12px !important;
        background: transparent !important;
    }

    .hd-cta-box {
        grid-template-columns: 54px 1fr !important;
        gap: 12px !important;
        padding: 16px !important;
        border-radius: 14px !important;
        background: linear-gradient(135deg, #ff2f45 0%, #ff6033 48%, #f5b700 100%) !important;
        border-color: rgba(255,255,255,.14) !important;
    }

    .hd-cta-box::before {
        content: "🚀" !important;
        width: 54px !important;
        height: 54px !important;
        display: grid !important;
        place-items: center !important;
        border-radius: 16px !important;
        background: rgba(255,255,255,.13) !important;
        font-size: 28px !important;
        grid-row: span 2 !important;
    }

    .hd-cta-box .hd-kicker {
        display: none !important;
    }

    .hd-cta-box h2 {
        font-size: 19px !important;
        line-height: 1.15 !important;
        margin: 0 0 4px !important;
    }

    .hd-cta-box p:not(.hd-kicker) {
        font-size: 11px !important;
        line-height: 1.35 !important;
        color: rgba(255,255,255,.84) !important;
        margin: 0 !important;
    }

    .hd-cta-box .hd-btn {
        grid-column: 2 !important;
        width: 100% !important;
        min-height: 40px !important;
        background: #050505 !important;
        color: #fff !important;
        border-radius: 10px !important;
        box-shadow: none !important;
        margin-top: 6px !important;
    }

    /* Footer trong khung mobile */
    .site-footer {
        width: min(100% - 18px, 430px) !important;
        margin: -18px auto 18px !important;
        border-left: 1px solid rgba(255,255,255,.13) !important;
        border-right: 1px solid rgba(255,255,255,.13) !important;
        border-bottom: 1px solid rgba(255,255,255,.13) !important;
        border-radius: 0 0 22px 22px !important;
        padding-top: 22px !important;
        background: #050505 !important;
        overflow: hidden !important;
    }

    .site-footer .container {
        width: calc(100% - 28px) !important;
        max-width: 402px !important;
    }

    .footer-grid {
        grid-template-columns: 1.1fr .9fr !important;
        gap: 18px !important;
    }

    .footer-grid > div:nth-child(n+3) {
        display: none !important;
    }

    .footer-logo-img {
        max-width: 112px !important;
    }

    .footer-grid p,
    .footer-grid a {
        font-size: 11px !important;
        line-height: 1.45 !important;
    }

    .footer-grid h4 {
        font-size: 12px !important;
        text-transform: uppercase !important;
        letter-spacing: .5px !important;
    }

    .footer-socials a {
        width: 34px !important;
        height: 34px !important;
        min-height: 34px !important;
        padding: 0 !important;
        font-size: 0 !important;
    }

    .footer-socials a::first-letter {
        font-size: 12px !important;
    }

    .footer-bottom {
        margin-top: 18px !important;
        padding: 14px !important;
        font-size: 11px !important;
        text-align: left !important;
    }

    .floating-contact-group {
        right: 12px !important;
        bottom: 12px !important;
        transform: scale(.86) !important;
        transform-origin: right bottom !important;
    }
}

@media (max-width: 390px) {
    .hd-hero-layout {
        grid-template-columns: 1fr 112px !important;
        min-height: 260px !important;
    }

    .hd-hero-copy h1 {
        font-size: 20px !important;
        max-width: 205px !important;
    }

    .hd-hero-desc {
        max-width: 200px !important;
        font-size: 11.7px !important;
        -webkit-line-clamp: 3 !important;
    }

    .hd-feature-card {
        right: -42px !important;
        width: 160px !important;
        height: 182px !important;
    }

    .hd-services-grid {
        gap: 6px !important;
    }

    .hd-service-card {
        min-height: 88px !important;
        padding: 10px 4px 8px !important;
    }

    .hd-service-card h3 {
        font-size: 10.2px !important;
    }

    .hd-project-card,
    .hd-blog-card,
    .hd-price-card {
        flex-basis: 142px !important;
        width: 142px !important;
    }
}



/* =====================================================
   MOBILE HOTFIX V3 - FIX TRÀN NGANG / STATS / CARD MOBILE
   Đặt cuối inline CSS để ghi đè toàn bộ mobile cũ.
===================================================== */
@media (max-width: 768px) {
    html,
    body {
        width: 100% !important;
        max-width: 100% !important;
        overflow-x: hidden !important;
        background: #050505 !important;
    }

    body * {
        box-sizing: border-box !important;
    }

    .site-header,
    .home-dark-root,
    .site-footer {
        max-width: 430px !important;
    }

    .home-dark-root {
        overflow: hidden !important;
    }

    .home-dark-root *,
    .site-footer * {
        max-width: 100% !important;
    }

    .home-dark-root .container {
        width: calc(100% - 28px) !important;
        max-width: 402px !important;
    }

    /* HERO: bỏ tràn phải, ảnh nằm gọn trong khung */
    .hd-hero-layout {
        grid-template-columns: minmax(0, 1fr) 128px !important;
        min-height: 292px !important;
        padding: 30px 14px 22px !important;
        overflow: hidden !important;
    }

    .hd-hero-copy {
        min-width: 0 !important;
        max-width: 100% !important;
        padding-right: 6px !important;
    }

    .hd-hero-copy h1 {
        max-width: 255px !important;
        font-size: clamp(24px, 7.2vw, 30px) !important;
        line-height: 1.13 !important;
        letter-spacing: -0.9px !important;
        margin-bottom: 12px !important;
    }

    .hd-hero-desc {
        max-width: 240px !important;
        font-size: 12.6px !important;
        line-height: 1.55 !important;
        -webkit-line-clamp: 4 !important;
        margin-bottom: 15px !important;
    }

    .hd-hero-actions {
        gap: 7px !important;
        max-width: 245px !important;
    }

    .hd-hero-actions .hd-btn {
        min-height: 38px !important;
        height: 38px !important;
        padding: 0 11px !important;
        font-size: 11.5px !important;
        border-radius: 11px !important;
    }

    .hd-hero-actions .hd-btn-primary {
        min-width: 106px !important;
    }

    .hd-hero-showcase {
        width: 128px !important;
        height: 205px !important;
        min-width: 0 !important;
        overflow: visible !important;
    }

    .hd-feature-card {
        right: -12px !important;
        top: 18px !important;
        width: 145px !important;
        height: 168px !important;
        border-radius: 22px !important;
        clip-path: none !important;
        opacity: .86 !important;
        overflow: hidden !important;
        box-shadow: 0 18px 42px rgba(0,0,0,.30) !important;
    }

    .hd-feature-card::before {
        background: linear-gradient(180deg, rgba(0,0,0,.10), rgba(0,0,0,.42)) !important;
    }

    .hd-hero-bg-mark {
        right: -38px !important;
        top: 84px !important;
        width: 176px !important;
        opacity: .72 !important;
    }

    /* STATS: sửa lỗi 200+50+ bị dính nhau */
    .hd-stats-section {
        padding: 12px 0 18px !important;
    }

    .hd-stats-panel {
        display: grid !important;
        grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
        width: 100% !important;
        overflow: hidden !important;
        border-radius: 16px !important;
    }

    .hd-stats-panel article {
        min-width: 0 !important;
        width: auto !important;
        padding: 12px 3px !important;
        display: grid !important;
        justify-items: center !important;
        align-content: start !important;
        gap: 4px !important;
        text-align: center !important;
    }

    .hd-stat-icon {
        width: 28px !important;
        height: 28px !important;
        min-width: 28px !important;
        font-size: 12px !important;
        border-radius: 10px !important;
    }

    .hd-stats-panel strong {
        display: block !important;
        width: 100% !important;
        min-width: 0 !important;
        max-width: 100% !important;
        font-size: clamp(22px, 7vw, 30px) !important;
        line-height: .92 !important;
        letter-spacing: -1.3px !important;
        text-align: center !important;
        white-space: nowrap !important;
        color: #f5b700 !important;
    }

    .hd-stats-panel .stat-number {
        display: inline !important;
        min-width: 0 !important;
        width: auto !important;
        letter-spacing: inherit !important;
    }

    .hd-stats-panel p {
        font-size: 9.2px !important;
        line-height: 1.15 !important;
        max-width: 72px !important;
        margin: 0 auto !important;
    }

    /* SERVICES: 4 card vừa khung, không đẩy ngang */
    .hd-services-grid {
        display: grid !important;
        grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
        gap: 8px !important;
        overflow: hidden !important;
        width: 100% !important;
    }

    .hd-services-grid .hd-service-card:nth-child(n+5) {
        display: none !important;
    }

    .hd-service-card {
        min-height: 108px !important;
        width: auto !important;
        padding: 13px 5px 10px !important;
        border-radius: 13px !important;
        display: grid !important;
        align-content: start !important;
        text-align: center !important;
    }

    .hd-service-card span {
        width: 36px !important;
        height: 36px !important;
        min-width: 36px !important;
        border-radius: 11px !important;
        margin: 0 auto 8px !important;
        font-size: 18px !important;
    }

    .hd-service-card h3 {
        font-size: 12.4px !important;
        line-height: 1.12 !important;
        min-height: 28px !important;
        margin: 0 0 7px !important;
        display: -webkit-box !important;
        -webkit-line-clamp: 2 !important;
        -webkit-box-orient: vertical !important;
        overflow: hidden !important;
    }

    .hd-service-card p {
        display: none !important;
    }

    .hd-service-card strong {
        font-size: 18px !important;
        line-height: 1 !important;
        margin-top: 0 !important;
    }

    /* PROCESS: timeline nhỏ gọn, không thành card dọc */
    .hd-process-track {
        display: flex !important;
        grid-template-columns: none !important;
        gap: 0 !important;
        overflow-x: auto !important;
        padding: 4px 0 8px !important;
        scrollbar-width: none !important;
    }

    .hd-process-track::-webkit-scrollbar {
        display: none !important;
    }

    .hd-process-item {
        flex: 0 0 78px !important;
        width: 78px !important;
        min-width: 78px !important;
        display: grid !important;
        grid-template-columns: 1fr !important;
        padding: 0 !important;
        background: transparent !important;
        border: 0 !important;
        border-radius: 0 !important;
        text-align: center !important;
        position: relative !important;
    }

    .hd-process-item:not(:last-child)::after {
        content: "" !important;
        position: absolute !important;
        top: 18px !important;
        right: -20px !important;
        width: 42px !important;
        border-top: 2px dotted rgba(255,55,55,.72) !important;
    }

    .hd-process-dot {
        width: 42px !important;
        height: 42px !important;
        margin: 0 auto 6px !important;
        grid-row: auto !important;
    }

    .hd-process-dot span {
        width: 32px !important;
        height: 32px !important;
        font-size: 11px !important;
    }

    .hd-process-icon {
        font-size: 21px !important;
        margin: 0 auto 4px !important;
    }

    .hd-process-item h3 {
        font-size: 11px !important;
        line-height: 1.18 !important;
        margin: 0 !important;
        letter-spacing: -0.1px !important;
    }

    .hd-process-item p {
        display: none !important;
    }

    /* PROJECT + BLOG: card vừa màn hình, không lệch */
    .hd-project-grid,
    .hd-blog-grid {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 12px !important;
        overflow: visible !important;
        padding: 0 !important;
        width: 100% !important;
    }

    .hd-project-card,
    .hd-blog-card {
        width: 100% !important;
        flex: none !important;
        border-radius: 16px !important;
    }

    .hd-project-card {
        display: grid !important;
        grid-template-columns: 42% 1fr !important;
        min-height: 118px !important;
    }

    .hd-project-image {
        min-height: 118px !important;
        height: 100% !important;
    }

    .hd-project-content {
        padding: 13px !important;
    }

    .hd-project-content h3,
    .hd-blog-card h3 {
        font-size: 15px !important;
        line-height: 1.2 !important;
    }

    .hd-project-content p,
    .hd-blog-card p {
        font-size: 11.5px !important;
        line-height: 1.35 !important;
    }

    .hd-blog-card {
        display: grid !important;
        grid-template-columns: 112px minmax(0, 1fr) !important;
        min-height: 136px !important;
    }

    .hd-blog-image {
        height: 100% !important;
        min-height: 136px !important;
    }

    .hd-blog-card > div:not(.hd-blog-image) {
        padding: 13px !important;
    }

    .hd-blog-card .hd-text-link {
        display: inline-flex !important;
        font-size: 11px !important;
        margin-top: 8px !important;
    }

    /* PRICING: 3 cột nhỏ gọn, không bị cắt ngang */
    .hd-pricing-grid {
        display: grid !important;
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
        gap: 8px !important;
        overflow: visible !important;
        padding: 0 !important;
        width: 100% !important;
    }

    .hd-price-card {
        width: auto !important;
        min-width: 0 !important;
        flex: none !important;
        min-height: 248px !important;
        padding: 13px 9px !important;
        border-radius: 14px !important;
    }

    .hd-badge {
        top: 8px !important;
        right: 8px !important;
        font-size: 7px !important;
        padding: 3px 5px !important;
    }

    .hd-price-card h3 {
        font-size: 11.5px !important;
        line-height: 1.18 !important;
        padding-right: 0 !important;
        margin-bottom: 7px !important;
        min-height: 28px !important;
    }

    .hd-price-card > strong {
        font-size: 17px !important;
        line-height: 1.05 !important;
        margin-bottom: 9px !important;
        word-break: keep-all !important;
    }

    .hd-price-card ul {
        gap: 5px !important;
        margin-bottom: 10px !important;
    }

    .hd-price-card li {
        font-size: 9.4px !important;
        line-height: 1.22 !important;
        display: -webkit-box !important;
        -webkit-line-clamp: 2 !important;
        -webkit-box-orient: vertical !important;
        overflow: hidden !important;
    }

    .hd-price-card li:nth-child(n+5) {
        display: none !important;
    }

    .hd-price-btn {
        min-height: 34px !important;
        font-size: 10px !important;
        border-radius: 10px !important;
        padding: 0 6px !important;
    }

    /* FEEDBACK: bỏ absolute gây vỡ layout */
    .hd-feedback-grid {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 12px !important;
        overflow: visible !important;
        padding: 0 !important;
    }

    .hd-feedback-card {
        width: 100% !important;
        min-height: auto !important;
        flex: none !important;
        padding: 20px !important;
        border-radius: 18px !important;
    }

    .hd-quote-mark {
        position: static !important;
        font-size: 34px !important;
        line-height: .7 !important;
        margin: 0 0 8px !important;
    }

    .hd-feedback-card > p {
        font-size: 13.2px !important;
        line-height: 1.55 !important;
        margin: 0 0 14px !important;
        -webkit-line-clamp: 4 !important;
    }

    .hd-feedback-author {
        display: flex !important;
        gap: 11px !important;
        align-items: center !important;
    }

    .hd-feedback-author img,
    .hd-feedback-author > span {
        position: static !important;
        width: 52px !important;
        height: 52px !important;
        min-width: 52px !important;
        max-width: 52px !important;
    }

    .hd-feedback-author strong {
        font-size: 13.5px !important;
    }

    .hd-feedback-author em {
        font-size: 11.5px !important;
    }

    .hd-feedback-author small {
        font-size: 11px !important;
        letter-spacing: 1px !important;
    }

    .hd-cta-box {
        width: 100% !important;
        border-radius: 18px !important;
    }

    .hd-cta-box h2 {
        font-size: 18px !important;
        line-height: 1.18 !important;
    }

    .hd-cta-box .hd-btn {
        min-height: 42px !important;
    }

    /* Floating contact: trên mobile chỉ giữ Gọi + Lên đầu trang, tránh che nội dung */
    body #floating-contact-pro {
        right: 10px !important;
        bottom: 14px !important;
        gap: 8px !important;
        z-index: 9999 !important;
    }

    body #floating-contact-pro .fc-btn:not(.fc-btn-phone):not(.fc-btn-top) {
        display: none !important;
    }

    body #floating-contact-pro .fc-btn {
        width: 44px !important;
        height: 44px !important;
        min-width: 44px !important;
        min-height: 44px !important;
        max-width: 44px !important;
        max-height: 44px !important;
    }

    body #floating-contact-pro .fc-btn svg {
        width: 21px !important;
        height: 21px !important;
    }

    body #floating-contact-pro .fc-label {
        display: none !important;
    }
}

@media (max-width: 390px) {
    .hd-hero-layout {
        grid-template-columns: minmax(0, 1fr) 108px !important;
        min-height: 278px !important;
        padding-left: 12px !important;
        padding-right: 12px !important;
    }

    .hd-hero-copy h1 {
        max-width: 214px !important;
        font-size: 22px !important;
    }

    .hd-hero-desc {
        max-width: 208px !important;
        font-size: 11.8px !important;
    }

    .hd-hero-showcase {
        width: 108px !important;
    }

    .hd-feature-card {
        right: -10px !important;
        width: 126px !important;
        height: 152px !important;
    }

    .hd-stats-panel strong {
        font-size: 24px !important;
    }

    .hd-stats-panel p {
        font-size: 8.4px !important;
    }

    .hd-service-card h3 {
        font-size: 11px !important;
    }

    .hd-price-card {
        padding: 12px 7px !important;
    }

    .hd-price-card > strong {
        font-size: 15px !important;
    }

    .hd-price-card li {
        font-size: 8.8px !important;
    }
}



/* =====================================================
   MOBILE HOTFIX V4 - SAFE MOBILE LAYOUT
   Sửa khu vực hero / stats / dịch vụ / floating bị tràn trên điện thoại.
   Đặt cuối file và cuối inline CSS trong index.php.
===================================================== */
@media (max-width: 768px) {
    html,
    body {
        width: 100% !important;
        max-width: 100% !important;
        overflow-x: hidden !important;
        background: #050505 !important;
    }

    body {
        margin: 0 !important;
    }

    .site-header,
    .home-dark-root,
    .site-footer {
        width: min(100% - 18px, 430px) !important;
        max-width: 430px !important;
        margin-left: auto !important;
        margin-right: auto !important;
        overflow: hidden !important;
    }

    .home-dark-root .container,
    .site-footer .container {
        width: calc(100% - 28px) !important;
        max-width: 402px !important;
        padding-left: 0 !important;
        padding-right: 0 !important;
        margin-left: auto !important;
        margin-right: auto !important;
    }

    .home-dark-root *,
    .site-header *,
    .site-footer * {
        box-sizing: border-box !important;
    }

    /* HERO: giảm chữ, giữ ảnh nằm gọn bên phải, không đẩy tràn màn */
    .hd-hero-section {
        overflow: hidden !important;
        border-bottom: 1px solid rgba(255,255,255,0.08) !important;
    }

    .hd-hero-section > .container {
        width: 100% !important;
        max-width: none !important;
    }

    .hd-hero-layout {
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) 118px !important;
        gap: 8px !important;
        align-items: center !important;
        min-height: 264px !important;
        padding: 26px 14px 22px !important;
        overflow: hidden !important;
    }

    .hd-hero-copy {
        min-width: 0 !important;
        max-width: 100% !important;
        padding-right: 0 !important;
        position: relative !important;
        z-index: 5 !important;
    }

    .hd-hero-copy h1 {
        max-width: 218px !important;
        font-size: clamp(21px, 6.25vw, 25px) !important;
        line-height: 1.13 !important;
        letter-spacing: -0.7px !important;
        margin: 0 0 12px !important;
        text-transform: uppercase !important;
    }

    .hd-hero-desc {
        max-width: 214px !important;
        font-size: 12.2px !important;
        line-height: 1.52 !important;
        margin: 0 0 15px !important;
        color: rgba(255,255,255,0.72) !important;
        display: -webkit-box !important;
        -webkit-line-clamp: 4 !important;
        -webkit-box-orient: vertical !important;
        overflow: hidden !important;
    }

    .hd-hero-actions {
        display: flex !important;
        flex-wrap: nowrap !important;
        gap: 7px !important;
        max-width: 222px !important;
    }

    .hd-hero-actions .hd-btn {
        height: 38px !important;
        min-height: 38px !important;
        padding: 0 10px !important;
        border-radius: 11px !important;
        font-size: 11.2px !important;
        line-height: 1 !important;
        white-space: nowrap !important;
    }

    .hd-hero-actions .hd-btn-primary {
        min-width: 104px !important;
    }

    .hd-hero-actions .hd-btn-ghost {
        min-width: 104px !important;
    }

    .hd-hero-showcase {
        width: 118px !important;
        min-width: 0 !important;
        height: 178px !important;
        position: relative !important;
        overflow: visible !important;
        z-index: 3 !important;
    }

    .hd-feature-card {
        right: 0 !important;
        left: auto !important;
        top: 16px !important;
        width: 118px !important;
        height: 146px !important;
        min-height: 0 !important;
        border-radius: 20px !important;
        clip-path: none !important;
        opacity: 0.82 !important;
        overflow: hidden !important;
        transform: none !important;
        box-shadow: 0 18px 38px rgba(0,0,0,0.32) !important;
    }

    .hd-feature-card .hd-card-content,
    .hd-side-cards {
        display: none !important;
    }

    .hd-hero-bg-mark {
        right: -46px !important;
        top: 76px !important;
        width: 164px !important;
        height: 164px !important;
        opacity: 0.62 !important;
        pointer-events: none !important;
    }

    /* STATS: chuyển 2x2 để hết dính 200+50+ và không cắt 24/7 */
    .hd-stats-section {
        padding: 12px 0 20px !important;
        overflow: hidden !important;
    }

    .hd-stats-panel {
        width: 100% !important;
        display: grid !important;
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 0 !important;
        overflow: hidden !important;
        border-radius: 18px !important;
        background: linear-gradient(145deg, rgba(255,255,255,0.07), rgba(255,255,255,0.022)) !important;
    }

    .hd-stats-panel article {
        min-width: 0 !important;
        width: 100% !important;
        display: grid !important;
        grid-template-columns: 34px minmax(0, 1fr) !important;
        grid-template-rows: auto auto !important;
        column-gap: 9px !important;
        row-gap: 2px !important;
        align-items: center !important;
        justify-items: start !important;
        text-align: left !important;
        padding: 13px 12px !important;
        border-right: 1px solid rgba(255,255,255,0.10) !important;
        border-bottom: 1px solid rgba(255,255,255,0.10) !important;
    }

    .hd-stats-panel article:nth-child(2n) {
        border-right: 0 !important;
    }

    .hd-stats-panel article:nth-child(n+3) {
        border-bottom: 0 !important;
    }

    .hd-stat-icon {
        grid-row: 1 / span 2 !important;
        width: 32px !important;
        height: 32px !important;
        min-width: 32px !important;
        border-radius: 11px !important;
        font-size: 13px !important;
        margin: 0 !important;
    }

    .hd-stats-panel strong {
        display: block !important;
        width: auto !important;
        max-width: none !important;
        min-width: 0 !important;
        font-size: 25px !important;
        line-height: 1 !important;
        letter-spacing: -0.8px !important;
        white-space: nowrap !important;
        text-align: left !important;
        color: #f5b700 !important;
    }

    .hd-stats-panel .stat-number {
        display: inline !important;
        min-width: 0 !important;
        width: auto !important;
        letter-spacing: inherit !important;
    }

    .hd-stats-panel p {
        max-width: 100% !important;
        margin: 0 !important;
        font-size: 10.4px !important;
        line-height: 1.15 !important;
        text-align: left !important;
        color: rgba(255,255,255,0.64) !important;
    }

    /* SERVICES: đổi 2 cột để card không bị cắt chữ */
    .hd-services-section {
        padding-top: 16px !important;
        overflow: hidden !important;
    }

    .hd-services-section .hd-section-side,
    .hd-process-section .hd-section-side,
    .hd-projects-section .hd-section-side,
    .hd-pricing-section .hd-section-side,
    .hd-blog-section .hd-section-side,
    .hd-feedback-section .hd-section-side {
        display: flex !important;
        align-items: flex-start !important;
        justify-content: space-between !important;
        gap: 12px !important;
        margin-bottom: 14px !important;
    }

    .hd-services-section .hd-section-side h2,
    .hd-process-section .hd-section-side h2,
    .hd-projects-section .hd-section-side h2,
    .hd-pricing-section .hd-section-side h2,
    .hd-blog-section .hd-section-side h2,
    .hd-feedback-section .hd-section-side h2 {
        max-width: 72% !important;
        font-size: 18px !important;
        line-height: 1.15 !important;
        text-transform: uppercase !important;
        margin: 0 !important;
    }

    .hd-section-side .hd-text-link {
        flex: 0 0 auto !important;
        font-size: 12px !important;
        line-height: 1.25 !important;
        margin-top: 2px !important;
        text-align: right !important;
        color: #f5b700 !important;
    }

    .hd-services-grid {
        display: grid !important;
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 10px !important;
        width: 100% !important;
        overflow: visible !important;
    }

    .hd-services-grid .hd-service-card:nth-child(n+5) {
        display: none !important;
    }

    .hd-service-card {
        width: 100% !important;
        min-height: 128px !important;
        padding: 16px 12px 13px !important;
        border-radius: 16px !important;
        display: grid !important;
        align-content: start !important;
        justify-items: start !important;
        text-align: left !important;
    }

    .hd-service-card span {
        width: 38px !important;
        height: 38px !important;
        min-width: 38px !important;
        border-radius: 12px !important;
        margin: 0 0 12px !important;
        font-size: 19px !important;
    }

    .hd-service-card h3 {
        font-size: 15px !important;
        line-height: 1.12 !important;
        min-height: 0 !important;
        margin: 0 0 10px !important;
        display: block !important;
        overflow: visible !important;
    }

    .hd-service-card p {
        display: none !important;
    }

    .hd-service-card strong {
        font-size: 15px !important;
        line-height: 1 !important;
        margin-top: auto !important;
    }

    .hd-service-card strong::before {
        content: "" !important;
    }

    .hd-service-card strong::after {
        content: "→" !important;
        font-size: 18px !important;
    }

    /* PRICING: dùng slider ngang an toàn thay vì 3 cột bị chật */
    .hd-pricing-grid {
        display: flex !important;
        grid-template-columns: none !important;
        gap: 12px !important;
        overflow-x: auto !important;
        overflow-y: hidden !important;
        padding: 2px 1px 12px !important;
        width: 100% !important;
        scroll-snap-type: x mandatory !important;
        scrollbar-width: none !important;
    }

    .hd-pricing-grid::-webkit-scrollbar {
        display: none !important;
    }

    .hd-price-card {
        flex: 0 0 82% !important;
        width: 82% !important;
        max-width: 310px !important;
        min-width: 0 !important;
        min-height: 330px !important;
        padding: 20px 18px !important;
        border-radius: 20px !important;
        scroll-snap-align: start !important;
    }

    .hd-price-card h3 {
        font-size: 18px !important;
        line-height: 1.2 !important;
        min-height: 0 !important;
        margin-bottom: 10px !important;
        padding-right: 60px !important;
    }

    .hd-price-card > strong {
        font-size: 27px !important;
        line-height: 1.05 !important;
        margin-bottom: 12px !important;
    }

    .hd-price-card p {
        display: block !important;
        font-size: 12px !important;
        line-height: 1.45 !important;
        margin-bottom: 12px !important;
    }

    .hd-price-card li {
        display: block !important;
        font-size: 12.3px !important;
        line-height: 1.35 !important;
        margin-bottom: 6px !important;
    }

    .hd-price-card li:nth-child(n+6) {
        display: none !important;
    }

    .hd-price-btn {
        min-height: 42px !important;
        font-size: 13px !important;
        border-radius: 13px !important;
    }

    /* FLOATING: ẩn trên mobile để không che nội dung */
    body #floating-contact-pro,
    .floating-contact-group {
        display: none !important;
    }
}

@media (max-width: 390px) {
    .hd-hero-layout {
        grid-template-columns: minmax(0, 1fr) 98px !important;
        min-height: 252px !important;
        padding: 24px 12px 20px !important;
    }

    .hd-hero-copy h1 {
        max-width: 196px !important;
        font-size: 20.5px !important;
    }

    .hd-hero-desc {
        max-width: 196px !important;
        font-size: 11.5px !important;
        -webkit-line-clamp: 3 !important;
    }

    .hd-hero-actions {
        max-width: 202px !important;
        gap: 6px !important;
    }

    .hd-hero-actions .hd-btn {
        height: 36px !important;
        min-height: 36px !important;
        padding: 0 8px !important;
        font-size: 10.8px !important;
    }

    .hd-hero-actions .hd-btn-primary,
    .hd-hero-actions .hd-btn-ghost {
        min-width: 96px !important;
    }

    .hd-hero-showcase {
        width: 98px !important;
        height: 158px !important;
    }

    .hd-feature-card {
        width: 102px !important;
        height: 132px !important;
        top: 12px !important;
    }

    .hd-hero-bg-mark {
        width: 140px !important;
        height: 140px !important;
        right: -48px !important;
        top: 72px !important;
    }

    .hd-stats-panel strong {
        font-size: 23px !important;
    }

    .hd-stats-panel p {
        font-size: 9.8px !important;
    }

    .hd-service-card h3 {
        font-size: 14px !important;
    }
}

/* =====================================================
   MOBILE HERO + CTA FIX V5 - 10BIT MEDIA
   Sửa hero banner mobile đẹp hơn và nút Đặt lịch tư vấn bị lệch.
   Đặt cuối style.css và cuối inline <style> trong index.php.
===================================================== */
@media (max-width: 768px) {
    /* HERO BANNER MOBILE - chuyển sang layout poster, không còn ép text + ảnh cùng 1 hàng */
    .home-dark-root .hd-hero-section {
        min-height: auto !important;
        padding: 0 0 10px !important;
        background:
            radial-gradient(circle at 18% 12%, rgba(193,18,31,0.20), transparent 34%),
            radial-gradient(circle at 92% 42%, rgba(245,183,0,0.18), transparent 38%),
            linear-gradient(180deg, #050505 0%, #070707 100%) !important;
        border-bottom: 1px solid rgba(245,183,0,0.10) !important;
        overflow: hidden !important;
    }

    .home-dark-root .hd-hero-section > .container {
        width: calc(100% - 28px) !important;
        max-width: 402px !important;
        margin-left: auto !important;
        margin-right: auto !important;
        padding-left: 0 !important;
        padding-right: 0 !important;
    }

    .home-dark-root .hd-hero-layout {
        position: relative !important;
        display: block !important;
        min-height: 470px !important;
        padding: 30px 22px 26px !important;
        border-radius: 0 0 28px 28px !important;
        border: 1px solid rgba(245,183,0,0.14) !important;
        border-top: 0 !important;
        background:
            linear-gradient(90deg, rgba(5,5,5,0.98) 0%, rgba(5,5,5,0.92) 54%, rgba(5,5,5,0.48) 100%),
            radial-gradient(circle at 96% 36%, rgba(245,183,0,0.24), transparent 32%),
            radial-gradient(circle at 10% 88%, rgba(193,18,31,0.20), transparent 34%),
            #050505 !important;
        overflow: hidden !important;
        box-shadow: inset 0 0 0 1px rgba(255,255,255,0.035) !important;
    }

    .home-dark-root .hd-hero-layout::before {
        content: "" !important;
        position: absolute !important;
        right: -84px !important;
        top: 92px !important;
        width: 238px !important;
        height: 238px !important;
        border-radius: 50% !important;
        background:
            conic-gradient(from 210deg, rgba(255,49,49,0.02), rgba(255,49,49,0.92), rgba(245,183,0,0.92), rgba(255,49,49,0.02) 74%);
        opacity: 0.72 !important;
        filter: saturate(1.08) !important;
        pointer-events: none !important;
        z-index: 1 !important;
    }

    .home-dark-root .hd-hero-layout::after {
        content: "" !important;
        position: absolute !important;
        right: -26px !important;
        top: 126px !important;
        width: 150px !important;
        height: 206px !important;
        border-radius: 28px !important;
        background: linear-gradient(180deg, rgba(255,255,255,0.10), rgba(255,255,255,0.00)) !important;
        border: 1px solid rgba(255,255,255,0.10) !important;
        pointer-events: none !important;
        z-index: 2 !important;
    }

    .home-dark-root .hd-hero-copy {
        position: relative !important;
        z-index: 5 !important;
        width: 100% !important;
        max-width: 100% !important;
        padding: 0 !important;
    }

    .home-dark-root .hd-hero-copy .hd-kicker {
        display: inline-flex !important;
        align-items: center !important;
        min-height: 28px !important;
        padding: 0 11px !important;
        margin: 0 0 15px !important;
        border-radius: 999px !important;
        background: rgba(245,183,0,0.10) !important;
        border: 1px solid rgba(245,183,0,0.20) !important;
        color: #f5b700 !important;
        font-size: 9.5px !important;
        line-height: 1 !important;
        letter-spacing: 1.6px !important;
        white-space: nowrap !important;
    }

    .home-dark-root .hd-hero-copy h1 {
        width: 100% !important;
        max-width: 316px !important;
        margin: 0 0 16px !important;
        font-size: clamp(31px, 8.25vw, 38px) !important;
        line-height: 1.03 !important;
        letter-spacing: -1.35px !important;
        text-transform: uppercase !important;
        text-wrap: balance !important;
    }

    .home-dark-root .hd-hero-desc {
        width: 100% !important;
        max-width: 260px !important;
        margin: 0 0 22px !important;
        font-size: 13.8px !important;
        line-height: 1.58 !important;
        color: rgba(255,255,255,0.72) !important;
        display: -webkit-box !important;
        -webkit-line-clamp: 4 !important;
        -webkit-box-orient: vertical !important;
        overflow: hidden !important;
    }

    .home-dark-root .hd-hero-actions {
        position: relative !important;
        z-index: 6 !important;
        display: flex !important;
        flex-wrap: nowrap !important;
        gap: 10px !important;
        width: 100% !important;
        max-width: 310px !important;
        margin-top: 0 !important;
    }

    .home-dark-root .hd-hero-actions .hd-btn {
        min-width: 0 !important;
        height: 46px !important;
        min-height: 46px !important;
        padding: 0 15px !important;
        border-radius: 14px !important;
        font-size: 13.2px !important;
        line-height: 1 !important;
        white-space: nowrap !important;
    }

    .home-dark-root .hd-hero-actions .hd-btn-primary {
        flex: 0 0 auto !important;
        box-shadow: 0 16px 34px rgba(255,49,49,0.28) !important;
    }

    .home-dark-root .hd-hero-actions .hd-btn-ghost {
        flex: 0 0 auto !important;
        background: rgba(255,255,255,0.035) !important;
        border-color: rgba(255,255,255,0.20) !important;
    }

    .home-dark-root .hd-hero-showcase {
        position: absolute !important;
        right: -8px !important;
        top: 148px !important;
        width: 146px !important;
        height: 206px !important;
        min-width: 0 !important;
        display: block !important;
        overflow: visible !important;
        z-index: 3 !important;
        pointer-events: none !important;
    }

    .home-dark-root .hd-feature-card {
        position: absolute !important;
        inset: 0 !important;
        width: 100% !important;
        height: 100% !important;
        min-height: 0 !important;
        border-radius: 28px !important;
        opacity: 0.54 !important;
        filter: saturate(1.08) brightness(0.72) !important;
        background-size: cover !important;
        background-position: center center !important;
        box-shadow: 0 28px 70px rgba(0,0,0,0.48) !important;
        border: 1px solid rgba(245,183,0,0.22) !important;
    }

    .home-dark-root .hd-feature-card::before {
        background: linear-gradient(180deg, rgba(0,0,0,0.10), rgba(0,0,0,0.58)) !important;
    }

    .home-dark-root .hd-feature-card .hd-card-content,
    .home-dark-root .hd-side-cards {
        display: none !important;
    }

    .home-dark-root .hd-hero-bg-mark {
        display: none !important;
    }

    /* Đẩy stats sát hero đẹp hơn sau khi hero cao hơn */
    .home-dark-root .hd-stats-section {
        margin-top: 0 !important;
        padding-top: 18px !important;
    }

    /* FIX CTA ĐẶT LỊCH: bỏ grid 2 cột gây lệch, chuyển thành card 1 cột */
    .home-dark-root .hd-cta-section {
        padding: 28px 0 24px !important;
        background: #050505 !important;
        overflow: hidden !important;
    }

    .home-dark-root .hd-cta-box {
        display: block !important;
        width: 100% !important;
        max-width: 100% !important;
        padding: 22px !important;
        border-radius: 24px !important;
        text-align: left !important;
        overflow: hidden !important;
        background:
            radial-gradient(circle at 100% 0%, rgba(245,183,0,0.34), transparent 34%),
            linear-gradient(135deg, #ff3131 0%, #ff6430 50%, #f5b700 100%) !important;
        border: 1px solid rgba(255,255,255,0.16) !important;
        box-shadow: 0 22px 60px rgba(0,0,0,0.36) !important;
    }

    .home-dark-root .hd-cta-box::before {
        content: "🚀" !important;
        position: static !important;
        display: grid !important;
        place-items: center !important;
        width: 54px !important;
        height: 54px !important;
        margin: 0 0 15px !important;
        border-radius: 17px !important;
        background: rgba(255,255,255,0.14) !important;
        font-size: 27px !important;
        grid-row: auto !important;
        grid-column: auto !important;
    }

    .home-dark-root .hd-cta-box > div {
        display: block !important;
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
        padding: 0 !important;
        margin: 0 !important;
    }

    .home-dark-root .hd-cta-box .hd-kicker {
        display: none !important;
    }

    .home-dark-root .hd-cta-box h2 {
        display: block !important;
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 0 8px !important;
        color: #fff !important;
        font-size: 24px !important;
        line-height: 1.12 !important;
        letter-spacing: -0.8px !important;
        text-wrap: balance !important;
    }

    .home-dark-root .hd-cta-box p:not(.hd-kicker) {
        display: block !important;
        max-width: 100% !important;
        margin: 0 !important;
        color: rgba(255,255,255,0.86) !important;
        font-size: 13.2px !important;
        line-height: 1.45 !important;
    }

    .home-dark-root .hd-cta-box .hd-btn {
        display: flex !important;
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
        height: 52px !important;
        min-height: 52px !important;
        margin: 18px 0 0 !important;
        padding: 0 18px !important;
        grid-column: auto !important;
        grid-row: auto !important;
        justify-self: auto !important;
        align-self: auto !important;
        border-radius: 15px !important;
        background: #050505 !important;
        color: #fff !important;
        box-shadow: 0 12px 26px rgba(0,0,0,0.28) !important;
        transform: none !important;
        font-size: 14px !important;
        text-align: center !important;
    }
}

@media (max-width: 390px) {
    .home-dark-root .hd-hero-layout {
        min-height: 448px !important;
        padding: 28px 18px 24px !important;
    }

    .home-dark-root .hd-hero-copy h1 {
        max-width: 292px !important;
        font-size: 29px !important;
        line-height: 1.04 !important;
    }

    .home-dark-root .hd-hero-desc {
        max-width: 238px !important;
        font-size: 13px !important;
    }

    .home-dark-root .hd-hero-actions {
        max-width: 286px !important;
        gap: 8px !important;
    }

    .home-dark-root .hd-hero-actions .hd-btn {
        height: 44px !important;
        min-height: 44px !important;
        padding: 0 12px !important;
        font-size: 12.4px !important;
    }

    .home-dark-root .hd-hero-showcase {
        right: -18px !important;
        top: 152px !important;
        width: 132px !important;
        height: 190px !important;
    }

    .home-dark-root .hd-hero-layout::before {
        right: -96px !important;
        top: 98px !important;
        width: 220px !important;
        height: 220px !important;
    }

    .home-dark-root .hd-hero-layout::after {
        right: -34px !important;
        top: 132px !important;
        width: 132px !important;
        height: 190px !important;
    }

    .home-dark-root .hd-cta-box {
        padding: 20px !important;
        border-radius: 22px !important;
    }

    .home-dark-root .hd-cta-box h2 {
        font-size: 22px !important;
    }
}

