/* ==========================================================================
   my-tailwind.css (Color-Aligned & Expanded Edition)
   Strictly scoped styles mapping Tailwind structures to Theme CSS Variables.
   ========================================================================== */

/* ==========================================================================
   1. CONSOLIDATED SPACING UTILITIES (MARGINS & PADDINGS)
   Scales built systematically on 0.25rem grid values.
   ========================================================================== */

/* --- Universal Offsets & Center Engine --- */
.tw-zone .mx-auto {
    margin-left: auto;
    margin-right: auto;
}

.tw-zone .w-full {
    width: 100%;
}

/* --- MARGIN HIERARCHY (SCALE 1 to 12) --- */
.tw-zone .mt-1 {
    margin-top: 0.25rem;
}

.tw-zone .mb-1 {
    margin-bottom: 0.25rem;
}

.tw-zone .mt-2 {
    margin-top: 0.5rem;
}

.tw-zone .mb-2 {
    margin-bottom: 0.5rem;
}

.tw-zone .mt-3 {
    margin-top: 0.75rem;
}

.tw-zone .mb-3 {
    margin-bottom: 0.75rem;
}

.tw-zone .mt-4 {
    margin-top: 1rem;
}

.tw-zone .mb-4 {
    margin-bottom: 1rem;
}

.tw-zone .mt-5 {
    margin-top: 1.25rem;
}

.tw-zone .mb-5 {
    margin-bottom: 1.25rem;
}

.tw-zone .mt-6 {
    margin-top: 1.5rem;
}

.tw-zone .mb-6 {
    margin-bottom: 1.5rem;
}

.tw-zone .mt-7 {
    margin-top: 1.75rem;
}

.tw-zone .mb-7 {
    margin-bottom: 1.75rem;
}

.tw-zone .mt-8 {
    margin-top: 2rem;
}

.tw-zone .mb-8 {
    margin-bottom: 2rem;
}

.tw-zone .mt-9 {
    margin-top: 2.25rem;
}

.tw-zone .mb-9 {
    margin-bottom: 2.25rem;
}

.tw-zone .mt-10 {
    margin-top: 2.5rem;
}

.tw-zone .mb-10 {
    margin-bottom: 2.5rem;
}

.tw-zone .mt-11 {
    margin-top: 2.75rem;
}

.tw-zone .mb-11 {
    margin-bottom: 2.75rem;
}

.tw-zone .mt-12 {
    margin-top: 3rem;
}

.tw-zone .mb-12 {
    margin-bottom: 3rem;
}

/* Expanded Structural Separation Gaps */
.tw-zone .mb-16 {
    margin-bottom: 4rem;
}

.tw-zone .mb-20 {
    margin-bottom: 5rem;
}

/* Combined Margin Axes (X / Y) */
.tw-zone .mx-1 {
    margin-left: 0.25rem;
    margin-right: 0.25rem;
}

.tw-zone .my-1 {
    margin-top: 0.25rem;
    margin-bottom: 0.25rem;
}

.tw-zone .mx-2 {
    margin-left: 0.5rem;
    margin-right: 0.5rem;
}

.tw-zone .my-2 {
    margin-top: 0.5rem;
    margin-bottom: 0.5rem;
}

.tw-zone .mx-3 {
    margin-left: 0.75rem;
    margin-right: 0.75rem;
}

.tw-zone .my-3 {
    margin-top: 0.75rem;
    margin-bottom: 0.75rem;
}

.tw-zone .mx-4 {
    margin-left: 1rem;
    margin-right: 1rem;
}

.tw-zone .my-4 {
    margin-top: 1rem;
    margin-bottom: 1rem;
}

.tw-zone .mx-5 {
    margin-left: 1.25rem;
    margin-right: 1.25rem;
}

.tw-zone .my-5 {
    margin-top: 1.25rem;
    margin-bottom: 1.25rem;
}

.tw-zone .mx-6 {
    margin-left: 1.5rem;
    margin-right: 1.5rem;
}

.tw-zone .my-6 {
    margin-top: 1.5rem;
    margin-bottom: 1.5rem;
}

.tw-zone .mx-7 {
    margin-left: 1.75rem;
    margin-right: 1.75rem;
}

.tw-zone .my-7 {
    margin-top: 1.75rem;
    margin-bottom: 1.75rem;
}

.tw-zone .mx-8 {
    margin-left: 2rem;
    margin-right: 2rem;
}

.tw-zone .my-8 {
    margin-top: 2rem;
    margin-bottom: 2rem;
}

/* --- PADDING HIERARCHY (SCALE 1 to 12) --- */
.tw-zone .p-1 {
    padding: 0.25rem;
}

.tw-zone .p-2 {
    padding: 0.5rem;
}

.tw-zone .p-3 {
    padding: 0.75rem;
}

.tw-zone .p-4 {
    padding: 1rem;
}

.tw-zone .p-5 {
    padding: 1.25rem;
}

.tw-zone .p-6 {
    padding: 1.5rem;
}

.tw-zone .p-7 {
    padding: 1.75rem;
}

.tw-zone .p-8 {
    padding: 2rem;
}

.tw-zone .p-9 {
    padding: 2.25rem;
}

.tw-zone .p-10 {
    padding: 2.5rem;
}

.tw-zone .p-11 {
    padding: 2.75rem;
}

.tw-zone .p-12 {
    padding: 3rem;
}

/* Directional Modifiers */
.tw-zone .pt-4 {
    padding-top: 1rem;
}

.tw-zone .pb-4 {
    padding-bottom: 1rem;
}

.tw-zone .pl-4 {
    padding-left: 1rem;
}

.tw-zone .pr-4 {
    padding-right: 1rem;
}

.tw-zone .pl-6 {
    padding-left: 1.5rem;
}

.tw-zone .pl-10 {
    padding-left: 2.5rem;
}

/* Combined Padding Axes (X / Y) */
.tw-zone .px-1 {
    padding-left: 0.25rem;
    padding-right: 0.25rem;
}

.tw-zone .py-1 {
    padding-top: 0.25rem;
    padding-bottom: 0.25rem;
}

.tw-zone .py-1.5 {
    padding-top: 0.375rem;
    padding-bottom: 0.375rem;
}

.tw-zone .px-2 {
    padding-left: 0.5rem;
    padding-right: 0.5rem;
}

.tw-zone .py-2 {
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
}

.tw-zone .px-3 {
    padding-left: 0.75rem;
    padding-right: 0.75rem;
}

.tw-zone .py-3 {
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
}

.tw-zone .px-4 {
    padding-left: 1rem;
    padding-right: 1rem;
}

.tw-zone .py-4 {
    padding-top: 1rem;
    padding-bottom: 1rem;
}

.tw-zone .px-5 {
    padding-left: 1.25rem;
    padding-right: 1.25rem;
}

.tw-zone .py-5 {
    padding-top: 1.25rem;
    padding-bottom: 1.25rem;
}

.tw-zone .px-6 {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
}

.tw-zone .py-6 {
    padding-top: 1.5rem;
    padding-bottom: 1.5rem;
}

.tw-zone .px-7 {
    padding-left: 1.75rem;
    padding-right: 1.75rem;
}

.tw-zone .py-7 {
    padding-top: 1.75rem;
    padding-bottom: 1.75rem;
}

.tw-zone .px-8 {
    padding-left: 2rem;
    padding-right: 2rem;
}

.tw-zone .py-8 {
    padding-top: 2rem;
    padding-bottom: 2rem;
}

/* Canvas Section Block Heights */
.tw-zone .py-12 {
    padding-top: 3rem;
    padding-bottom: 3rem;
}

.tw-zone .py-16 {
    padding-top: 4rem;
    padding-bottom: 4rem;
}

.tw-zone .py-20 {
    padding-top: 5rem;
    padding-bottom: 5rem;
}

.tw-zone .py-25 {
    padding-top: 6.25rem;
    padding-bottom: 6.25rem;
}

/* Layout Grid & Flex Matrix Gaps */
.tw-zone .gap-1\.5 {
    gap: 0.375rem;
}

.tw-zone .gap-3 {
    gap: 0.75rem;
}

.tw-zone .gap-4 {
    gap: 1rem;
}

.tw-zone .gap-6 {
    gap: 1.5rem;
}

.tw-zone .gap-8 {
    gap: 2rem;
}

/* ==========================================================================
   2. BOX LAYOUT & STRUCTURE CHASSIS
   ========================================================================== */
.tw-zone .block {
    display: block;
}

.tw-zone .flex {
    display: flex;
}

.tw-zone .flex-col {
    flex-direction: column;
}

.tw-zone .inline-flex {
    display: inline-flex;
}

.tw-zone .grid {
    display: grid;
}

.tw-zone .justify-between {
    justify-content: space-between;
}

.tw-zone .justify-center {
    justify-content: center;
}

.tw-zone .items-center {
    align-items: center;
}

.tw-zone .items-start {
    align-items: flex-start;
}

.tw-zone .items-stretch {
    align-items: stretch;
}

.tw-zone .shrink-0 {
    flex-shrink: 0;
}

.tw-zone .relative {
    position: relative;
}

.tw-zone .overflow-hidden {
    overflow: hidden;
}

.tw-zone .pointer-events-none {
    pointer-events: none;
}

.tw-zone .cursor-pointer {
    cursor: pointer;
}

.tw-zone .select-none {
    user-select: none;
}

.tw-zone .z-10 {
    z-index: 10;
}

/* Geometric Dimensions */
.tw-zone .w-1\.5 {
    width: 0.375rem;
}

.tw-zone .h-1\.5 {
    height: 0.375rem;
}

.tw-zone .w-2 {
    width: 0.5rem;
}

.tw-zone .h-2 {
    height: 0.5rem;
}

.tw-zone .w-4 {
    width: 1rem;
}

.tw-zone .h-4 {
    height: 1rem;
}

.tw-zone .w-8 {
    width: 2rem;
}

.tw-zone .h-8 {
    height: 2rem;
}

.tw-zone .max-w-3xl {
    max-width: 48rem;
}

.tw-zone .max-w-4xl {
    max-width: 56rem;
}

.tw-zone .max-w-5xl {
    max-width: 64rem;
}

.tw-zone .max-w-6xl {
    max-width: 72rem;
}

/* ==========================================================================
   3. PROFESSIONAL TYPOGRAPHY SCALE
   ========================================================================== */
.tw-zone .text-center {
    text-align: center;
}

.tw-zone .text-left {
    text-align: left;
}

.tw-zone .text-xs {
    font-size: 0.75rem;
    line-height: 1rem;
}

.tw-zone .text-sm {
    font-size: 0.875rem;
    line-height: 1.25rem;
}

.tw-zone .text-base {
    font-size: 1rem;
    line-height: 1.625;
}

.tw-zone .text-lg {
    font-size: 1.125rem;
    line-height: 1.75;
}

.tw-zone .text-xl {
    font-size: 1.25rem;
    line-height: 1.875;
}

.tw-zone .text-2xl {
    font-size: 1.5rem;
    line-height: 2rem;
}

.tw-zone .text-3xl {
    font-size: 1.875rem;
    line-height: 2.25rem;
}

.tw-zone .font-light {
    font-weight: 300;
}

.tw-zone .font-normal {
    font-weight: 400;
}

.tw-zone .font-medium {
    font-weight: 500;
}

.tw-zone .font-semibold {
    font-weight: 600;
}

.tw-zone .font-bold {
    font-weight: 700;
}

.tw-zone .font-extrabold {
    font-weight: 800;
}

.tw-zone .font-black {
    font-weight: 900;
}

.tw-zone .font-mono {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
}

.tw-zone .uppercase {
    text-transform: uppercase;
}

.tw-zone .tracking-wider {
    letter-spacing: 0.05em;
}

.tw-zone .tracking-widest {
    letter-spacing: 0.15em;
}

.tw-zone .tracking-tight {
    letter-spacing: -0.025em;
}

.tw-zone .leading-none {
    line-height: 1;
}

.tw-zone .leading-tight {
    line-height: 1.25;
}

.tw-zone .leading-relaxed {
    line-height: 1.625;
}

/* ==========================================================================
   4. SYSTEM DESIGN COLORS & ACCENTS (THEME ALIGNED)
   ========================================================================== */
.tw-zone .bg-white {
    background-color: #ffffff;
}

.tw-zone .bg-black {
    background-color: #000000 !important;
}

.tw-zone .border {
    border-width: 1px;
    border-style: solid;
}

.tw-zone .border-t {
    border-top-width: 1px;
    border-top-style: solid;
}

.tw-zone .border-l-2 {
    border-left-width: 2px;
    border-left-style: solid;
}

.tw-zone .rounded {
    border-radius: 0.25rem;
}

.tw-zone .rounded-2xl {
    border-radius: 1rem;
}

.tw-zone .rounded-full {
    border-radius: 9999px;
}

/* Precise Color Scapes */
.tw-zone .text-white {
    color: #ffffff !important;
}

.tw-zone .text-zinc-200 {
    color: #e4e4e7 !important;
}

.tw-zone .text-zinc-300 {
    color: #d4d4d8 !important;
}

.tw-zone .text-zinc-400 {
    color: #a1a1aa !important;
}

.tw-zone .text-zinc-500 {
    color: #71717a !important;
}

.tw-zone .text-theme-dark {
    color: var(--theme-blue);
}

.tw-zone .text-theme-muted {
    color: #555c66;
    opacity: 0.85;
}

/* ERROR FRAMEWORK */
.tw-zone .bg-red-400\/50 {
    background-color: rgba(248, 113, 113, 0.5);
}

.tw-zone .text-red-400 {
    color: #f87171 !important;
}

/* CRITICAL ALIGNMENT: Remapping all accents cleanly to your required --theme-blue-light color token */
.tw-zone .text-theme-light-teal {
    color: var(--theme-blue-light) !important;
}

.tw-zone .text-theme-cyan {
    color: var(--theme-blue-light) !important;
}

.tw-zone .bg-theme-blue-light {
    background-color: var(--theme-blue-light);
}

.tw-zone .bg-theme-fade-blue {
    background-color: var(--theme-fade-blue);
}

.tw-zone .dot-theme-accent {
    background-color: var(--highlight-color);
}

/* Semi-Transparent Background and Border Mappings */
.tw-zone .bg-white\/5 {
    background-color: rgba(255, 255, 255, 0.05);
}

.tw-zone .bg-white\/0.02 {
    background-color: rgba(255, 255, 255, 0.02);
}

.tw-zone .bg-theme-cyan\/5 {
    background-color: rgba(0, 185, 185, 0.05);
}

.tw-zone .bg-theme-cyan\/10 {
    background-color: rgba(0, 185, 185, 0.1);
}

.tw-zone .border-white\/10 {
    border-color: rgba(255, 255, 255, 0.1);
}

.tw-zone .border-theme-cyan\/20 {
    border-color: rgba(0, 185, 185, 0.2);
}

.tw-zone .card-theme-border {
    border-color: rgba(0, 141, 141, 0.08);
}

/* --- GRADIENTS --- */
.tw-zone .bg-gradient-to-b {
    background-image: linear-gradient(to bottom, var(--tw-gradient-stops));
}

.tw-zone .bg-gradient-to-r {
    background-image: linear-gradient(to right, var(--tw-gradient-stops));
}

.tw-zone .from-white {
    --tw-gradient-from: #ffffff;
    --tw-gradient-to: rgba(255, 255, 255, 0);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.tw-zone .via-zinc-200 {
    --tw-gradient-to: rgba(228, 228, 231, 0);
    --tw-gradient-stops: var(--tw-gradient-from), #e4e4e7 var(--tw-gradient-to);
}

.tw-zone .to-zinc-500 {
    --tw-gradient-to: #71717a;
}

.tw-zone .bg-clip-text {
    -webkit-background-clip: text;
    background-clip: text;
}

.tw-zone .text-transparent {
    color: transparent !important;
}

/* Shadows, Animation and Filters */
.tw-zone .shadow-xl {
    --tw-shadow: 0 20px 25px -5px rgba(0, 185, 185, 0.03), 0 8px 10px -6px rgba(0, 185, 185, 0.03);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.tw-zone .blur-3xl {
    filter: blur(64px);
}

.tw-zone .transition-all {
    transition-property: all;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 200ms;
}

.tw-zone .transition-transform {
    transition-property: transform;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 200ms;
}

.tw-zone .duration-300 {
    transition-duration: 300ms;
}

/* Interactive Hover States */
.tw-zone .hover\shadow-md:hover {
    box-shadow: 0 4px 6px -1px rgba(0, 141, 141, 0.04), 0 2px 4px -1px rgba(0, 141, 141, 0.02);
}

/* Accordion Specific Icon Rotation Hooks */
.tw-zone .faq-item [aria-expanded="true"] .faq-chevron-wrapper {
    transform: rotate(180deg);
    background-color: var(--theme-blue-light);
    color: #ffffff;
}

/* ==========================================================================
   Gradient System Extensions
   ========================================================================== */
.tw-zone .bg-gradient-to-b {
    background-image: linear-gradient(to bottom, var(--tw-gradient-stops));
}

/* Explicitly map your custom gray variable token */
.tw-zone .from-theme-gray {
    --tw-gradient-from: var(--theme-gray, #1e2229);
    /* Defaults to a deep premium charcoal if variable isn't globally declared */
    --tw-gradient-to: rgba(30, 34, 41, 0);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

/* Explicitly resolve the white destination stop and reset interpolation hooks */
.tw-zone .to-white {
    --tw-gradient-to: #ffffff !important;
}

.tw-zone .border-zinc-900 {
    border-color: #55555b !important;
}

/* ==========================================================================
   Refined Light Accent Accordion & Vector Fixes
   ========================================================================== */

/* Ultra-soft border mapping for crisp light-theme layouts */
.tw-zone .border-zinc-100 {
    border-color: #f4f4f5 !important;
}

.tw-zone .border-zinc-200 {
    border-color: #e4e4e7 !important;
}

/* Base Arrow SVG Layout Configuration */
.tw-zone .stroke-current {
    stroke: currentColor;
}

.tw-zone .fill-none {
    fill: none;
}

.tw-zone .shrink-0 {
    flex-shrink: 0;
}

/* Explicit Hover-State Definition (Native CSS handling fallback) */
.tw-zone .faq-item:hover {
    background-color: rgba(244, 244, 245, 0.4);
}

.tw-zone .faq-item:hover .faq-chevron-wrapper {
    border-color: #a1a1aa;
    color: #27272a;
}

/* Interactive States: Triggered when Bootstrap framework toggles visibility */
.tw-zone .faq-item [aria-expanded="true"] h3 {
    color: var(--theme-blue-light, #00b9b9) !important;
}

.tw-zone .faq-item [aria-expanded="true"] .faq-chevron-wrapper {
    transform: rotate(180deg);
    background-color: var(--theme-blue-light, #00b9b9);
    border-color: var(--theme-blue-light, #00b9b9);
    color: #ffffff !important;
}

/* ==========================================================================
   Text Gradient Utility Classes
   ========================================================================== */
.tw-zone .text-transparent {
    color: transparent !important;
    -webkit-text-fill-color: transparent;
    /* Ensures fallback stability on WebKit browsers */
}

.tw-zone .bg-clip-text {
    -webkit-background-clip: text !important;
    background-clip: text !important;
}

.tw-zone .bg-gradient-to-r {
    background-image: linear-gradient(to right, var(--tw-gradient-stops));
}

/* --- Gradient Color Stop Mappings --- */
.tw-zone .from-theme-cyan {
    --tw-gradient-from: var(--theme-blue-light, #00b9b9);
    /* Fallback value applied if variable is empty */
    --tw-gradient-to: rgba(0, 185, 185, 0);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.tw-zone .to-theme-blue-light {
    --tw-gradient-to: var(--theme-blue-light, #00b9b9) !important;
}



/* Fluid Animated Brand Gradient Canvas Configuration */
.tw-zone .assessment-bg-engine {
    /* Combines a dark base theme color (#111827) with your exact branding tokens */
    background: linear-gradient(135deg,
            #0b0f19 0%,
            #004e59 35%,
            #0b0f19 100%);
    background-size: 400% 400%;
    animation: driftFluidGradient 22s ease-in-out infinite;
}

@keyframes driftFluidGradient {
    0% {
        background-position: 0% 50%;
    }

    50% {
        /* Moves colors down and to the right smoothly */
        background-position: 100% 50%;
    }

    100% {
        /* Loops back to the initial starting position cleanly */
        background-position: 0% 50%;
    }
}





/* Additional Custom Mappings for 16-Question Grid Engine Configuration */
.tw-zone .grid-cols-16 {
    display: grid;
    grid-template-columns: repeat(16, minmax(0, 1fr));
}

.tw-zone .bg-zinc-100 {
    background-color: #f4f4f5;
}

.tw-zone .bg-zinc-200 {
    background-color: #e4e4e7;
}

.tw-zone .bg-emerald-50 {
    background-color: #ecfdf5;
}

.tw-zone .text-emerald-500 {
    color: #10b981 !important;
}

.tw-zone .border-emerald-100 {
    border-color: #d1fae5;
}

.tw-zone .rounded-xl {
    border-radius: 0.75rem;
}

.tw-zone .rounded-l-full {
    border-top-left-radius: 9999px;
    border-bottom-left-radius: 9999px;
}

.tw-zone .rounded-r-full {
    border-top-right-radius: 9999px;
    border-bottom-right-radius: 9999px;
}

.tw-zone .hidden {
    display: none !important;
}

.tw-zone .opacity-0 {
    opacity: 0;
}

.tw-zone .opacity-100 {
    opacity: 1;
}

.tw-zone .pointer-events-none {
    pointer-events: none;
}

.tw-zone .shrink-0 {
    flex-shrink: 0;
}

.tw-zone .group:hover .group-hover\:border-teal-400 {
    border-color: #2dd4bf;
}


/* Accessible Interactive Form Inputs styling override */
.tw-zone .quiz-radio-input {
    appearance: none;
    background-color: #fff;
    margin: 0;
    font: inherit;
    color: currentColor;
    width: 1.15em;
    height: 1.15em;
    border: 1px solid #d4d4d8;
    border-radius: 50%;
    display: grid;
    place-content: center;
    cursor: pointer;
}

.tw-zone .quiz-radio-input::before {
    content: "";
    width: 0.65em;
    height: 0.65em;
    border-radius: 50%;
    transform: scale(0);
    transition: 120ms transform ease-in-out;
    box-shadow: inset 1em 1em var(--theme-light-teal, #2dd4bf);
}

.tw-zone .quiz-radio-input:checked::before {
    transform: scale(1);
}

.tw-zone .rounded-none {
    border-radius: 0px !important;
}










/* ==========================================================================
   5. RESPONSIVE BREAKPOINTS (TABLET & DESKTOP DESIGNS)
   ========================================================================== */
@media (min-width: 640px) {
    .tw-zone .sm\:px-6 {
        padding-left: 1.5rem;
        padding-right: 1.5rem;
    }
}

@media (min-width: 768px) {
    .tw-zone .md\:py-24 {
        padding-top: 6rem;
        padding-bottom: 6rem;
    }

    .tw-zone .md\:py-25 {
        padding-top: 6.25rem;
        padding-bottom: 6.25rem;
    }

    .tw-zone .md:p-10 {
        padding: 2.5rem;
    }

    .tw-zone .md\:p-12 {
        padding: 3rem;
    }

    .tw-zone .md\:text-xl {
        font-size: 1.25rem;
    }

    .tw-zone .md\:text-3xl {
        font-size: 1.875rem;
        line-height: 2.25rem;
    }

    .tw-zone .md\:text-4xl {
        font-size: 2.25rem;
        line-height: 2.5rem;
    }

    .tw-zone .md\:text-5xl {
        font-size: 3rem;
        line-height: 1.15;
    }

    .tw-zone .md\:rounded-2xl {
        border-radius: 1.5rem !important;
    }

    .tw-zone .pl-12 {
        padding-left: 3rem;
    }
}

@media (min-width: 1024px) {
    .tw-zone .lg\:px-8 {
        padding-left: 2rem;
        padding-right: 2rem;
    }

    .tw-zone .lg\:grid-cols-12 {
        grid-template-columns: repeat(12, minmax(0, 1fr));
    }

    .tw-zone .lg\:col-span-5 {
        grid-column: span 5 / span 5;
    }

    .tw-zone .lg\:col-span-7 {
        grid-column: span 7 / span 7;
    }
}