/* Corner Ribbon Styles */
.corner-ribbon {
    position: relative;
    overflow: hidden;
}

.corner-ribbon::before {
    content: attr(data-ribbon-text);
    position: absolute;
    top: 20px;
    right: -40px;
    z-index: 10;
    width: 150px;
    padding: 10px 0;
    font-size: 13px;
    font-weight: 700;
    color: white;
    background: linear-gradient(135deg, var(--ribbon-color-start, var(--mantine-color-blue-6)) 0%, var(--ribbon-color-end, var(--mantine-color-blue-7)) 100%);
    transform: rotate(45deg);
    transform-origin: center center;
    box-shadow: 0 3px 10px rgba(0, 0, 0, 0.3);
    text-transform: uppercase;
    letter-spacing: 1px;
    text-align: center;
}

/* Ribbon Color Variants using Mantine color variables */
.corner-ribbon-blue::before {
    /* Tone down saturation by using indigo scale for a calmer accent */
    --ribbon-color-start: var(--mantine-color-indigo-6);
    --ribbon-color-end: var(--mantine-color-indigo-7);
}

.corner-ribbon-green::before {
    --ribbon-color-start: var(--mantine-color-green-6);
    --ribbon-color-end: var(--mantine-color-green-7);
}

.corner-ribbon-red::before {
    --ribbon-color-start: var(--mantine-color-red-6);
    --ribbon-color-end: var(--mantine-color-red-7);
}

.corner-ribbon-orange::before {
    --ribbon-color-start: var(--mantine-color-orange-6);
    --ribbon-color-end: var(--mantine-color-orange-7);
}

.corner-ribbon-yellow::before {
    --ribbon-color-start: var(--mantine-color-yellow-6);
    --ribbon-color-end: var(--mantine-color-yellow-7);
}

.corner-ribbon-purple::before {
    --ribbon-color-start: var(--mantine-color-indigo-6);
    --ribbon-color-end: var(--mantine-color-indigo-7);
}

.corner-ribbon-violet::before {
    --ribbon-color-start: #22a7d8;
    --ribbon-color-end: #15aabf;
}

.corner-ribbon-gray::before {
    --ribbon-color-start: var(--mantine-color-gray-6);
    --ribbon-color-end: var(--mantine-color-gray-7);
}

.corner-ribbon-dark::before {
    --ribbon-color-start: var(--mantine-color-dark-6);
    --ribbon-color-end: var(--mantine-color-dark-7);
}

/* Project Card Title Styles */
.project-card-title {
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    max-width: 100% !important;
}

/* Project Card Description Styles */
.project-card-description {
    display: -webkit-box !important;
    -webkit-line-clamp: 4 !important;
    line-clamp: 4 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    max-width: 100% !important;
}

/* Project Card Button Overrides */
/* Primary action buttons (Open, Open an example) */
.btn-primary {
    /* Primary CTA aligns with logo green */
    background-color: var(--mantine-color-green-6) !important;
    color: white !important;
}

.btn-primary:hover {
    background-color: var(--mantine-color-green-7) !important;
}

/* Primary accent buttons - purple/indigo like demo ribbon */
.btn-primary-accent {
    background-color: var(--mantine-color-indigo-6) !important;
    color: white !important;
}

.btn-primary-accent:hover {
    background-color: var(--mantine-color-indigo-7) !important;
}

/* Tag badges */
.badge-tag {
    background-color: var(--mantine-color-indigo-0) !important;
    color: var(--mantine-color-indigo-7) !important;
    border-color: var(--mantine-color-indigo-2) !important;
}

/* Secondary action buttons */
.btn-archive {
    color: var(--mantine-color-gray-8) !important;
    background-color: var(--mantine-color-gray-1) !important;
}

.btn-archive:hover {
    background-color: var(--mantine-color-gray-2) !important;
}

.btn-delete {
    color: var(--mantine-color-red-7) !important;
    background-color: var(--mantine-color-red-0) !important;
}

.btn-delete:hover {
    background-color: var(--mantine-color-red-1) !important;
}

/* Bootstrap/Placeholder View Styles */
.boot-banner-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    position: absolute;
    top: 0;
    left: 0;
    border-radius: var(--mantine-radius-lg);
}

.boot-hero-card {
    height: 600px;
    display: flex;
    flex-direction: column;
    width: 350px;
    box-sizing: border-box;
    position: relative;
    overflow: hidden;
}

.boot-upload-card {
    height: 600px;
    display: flex;
    flex-direction: column;
    width: 350px;
    box-sizing: border-box;
    /* Softer, neutral background with a hint of indigo */
    background: linear-gradient(135deg, var(--mantine-color-gray-0) 0%, var(--mantine-color-indigo-0) 100%);
}

.boot-card-stack {
    height: 100%;
}

.boot-space-flex {
    flex: 1;
}

.boot-upload-link {
    color: var(--mantine-color-green-7);
    font-size: 32px;
    font-weight: 600;
    text-decoration: none;
    margin: 20px 0 10px 0;
}

.boot-upload-link:hover {
    color: var(--mantine-color-green-8);
}

.boot-upload-text {
    font-size: 22px;
    font-weight: 600;
    color: var(--mantine-color-dark-3);
    margin: 20px 20px 0px 20px;
}

.boot-upload-content {
    text-align: center;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    height: 100%;
}

.boot-upload-area {
    cursor: pointer;
    user-select: none;
    height: 100%;
    width: 100%;
}

.boot-upload-container {
    border: 2px dashed var(--mantine-color-green-4);
    border-radius: 12px;
    width: 280px;
    height: 280px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--mantine-color-green-0) 0%, var(--mantine-color-green-1) 100%);
    box-shadow: 0 1px 3px var(--mantine-color-green-2),
                0 1px 2px rgba(0, 0, 0, 0.06),
                inset 0 1px 2px var(--mantine-color-green-1);
    transition: all 0.3s ease;
}

.boot-upload-container:hover {
    border-color: var(--mantine-color-green-5);
    background: linear-gradient(135deg, var(--mantine-color-green-1) 0%, var(--mantine-color-green-2) 100%);
    box-shadow: 0 4px 12px var(--mantine-color-green-3),
                0 2px 6px rgba(0, 0, 0, 0.1),
                inset 0 1px 3px var(--mantine-color-green-2);
    transform: translateY(-2px);
}

.boot-divider-container {
    width: 80%;
    margin: 0 auto;
}

.boot-signin-link {
    text-decoration: none;
}

.boot-fallback-card {
    height: 600px;
    display: flex;
    flex-direction: column;
    width: 350px;
    box-sizing: border-box;
}

.boot-fallback-stack {
    height: 100%;
}

/* Footer links - subtle by default, clear on hover/focus */
.footer-link {
    color: var(--mantine-color-gray-6);
    text-decoration: none;
    text-underline-offset: 3px;
    text-decoration-thickness: 1.5px;
    transition: color 120ms ease, text-decoration-color 120ms ease;
}

.footer-link:hover {
    color: var(--mantine-color-dark-6);
    text-decoration: underline;
    text-decoration-color: var(--mantine-color-indigo-5);
}

.footer-link:focus-visible {
    outline: 2px solid var(--mantine-color-indigo-5);
    outline-offset: 2px;
    border-radius: 4px;
    text-decoration: underline;
}

.footer-link:visited {
    color: var(--mantine-color-gray-6);
}

/* Model Select Dropdown Styles */
.model-select {
    background-color: transparent !important;
    font-size: 11px !important;
    border-radius: 6px !important;
}

.model-select input {
    background-color: transparent !important;
    font-size: 11px !important;
    border-radius: 6px !important;
}

.model-select .mantine-Select-input {
    background-color: transparent !important;
    font-size: 11px !important;
    border-radius: 6px !important;
}

/* Responsive header title - fixed width on small screens */
.appshell-header-title-responsive {
    width: 160px !important;
    min-width: 160px !important;
    max-width: 160px !important;
}

@media (min-width: 768px) {
    .appshell-header-title-responsive {
        width: auto !important;
        min-width: auto !important;
        max-width: none !important;
    }
}

#appshell-header-title:empty {
    width: 0 !important;
    min-width: 0 !important;
    max-width: 0 !important;
}

/* Sign-in button styles */
.auth-login-button {
    white-space: nowrap !important;
    flex-shrink: 0 !important;
    border-radius: 0 !important;
    border: 1px solid var(--mantine-color-gray-5) !important;
    height: calc(41px * var(--mantine-scale, 1)) !important;
}

.auth-login-icon {
    width: calc(21px * var(--mantine-scale, 1)) !important;
    height: calc(21px * var(--mantine-scale, 1)) !important;
}

.auth-login-text {
    font-weight: 600 !important;
    font-size: calc(15px * var(--mantine-scale, 1)) !important;
    color: var(--mantine-color-gray-7) !important;
}

.auth-login-group {
    white-space: nowrap !important;
    flex-shrink: 0 !important;
}

/* Add spacing and prevent shrinking for the user menu container */
#appshell-header-usermenu {
    padding-right: 16px !important;
    flex-shrink: 0 !important;
    min-width: fit-content !important;
}

.auth-login-button *,
.auth-login-button .mantine-Button-root,
.auth-login-button .mantine-Button-inner,
.auth-login-button .mantine-Group-root,
.auth-login-button .mantine-Text-root {
    white-space: nowrap !important;
    flex-shrink: 0 !important;
}

/* Fix breadcrumb separator alignment */
.mantine-Breadcrumbs-separator {
    vertical-align: middle !important;
    line-height: 1 !important;
    display: inline-flex !important;
    align-items: center !important;
}

/* Upload button in header */
.header-upload-group {
    cursor: pointer;
    user-select: none;
    height: 33px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.header-upload-wrapper {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
}

/* Pricing Page Styles - Fancy styling only */
.pricing-card {
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05) !important;
    transition: transform 0.2s ease, box-shadow 0.2s ease !important;
    height: 100% !important;
    padding-bottom: 0 !important;
}

.pricing-card:hover {
    transform: translateY(-4px) !important;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08) !important;
}

.pricing-card-popular {
    background: linear-gradient(180deg, var(--mantine-color-indigo-9) 0%, var(--mantine-color-indigo-8) 50%, var(--mantine-color-indigo-7) 100%) !important;
    color: white !important;
    box-shadow: 0 8px 32px var(--mantine-color-indigo-6) !important;
    position: relative;
    z-index: 1;
    /* Make popular card taller */
    min-height: 650px !important;
    padding-top: 2rem !important;
    padding-bottom: 2rem !important;
}

.pricing-card-popular:hover {
    box-shadow: 0 12px 40px var(--mantine-color-indigo-5) !important;
    transform: translateY(-8px) scale(1.02) !important;
}

.pricing-button-popular {
    background: linear-gradient(135deg, #FFD700 0%, #FFA500 100%) !important;
    color: #8B4513 !important;
    border: none !important;
    transition: all 0.2s ease !important;
    font-weight: 700 !important;
}

.pricing-button-popular:hover {
    background: linear-gradient(135deg, #FFA500 0%, #FF8C00 100%) !important;
    color: #654321 !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 12px rgba(255, 215, 0, 0.4) !important;
}

/* Override for popular card - ensure button is visible with strong gradient */
.pricing-card-popular .mantine-Button-root.pricing-button-popular,
.pricing-card-popular button.pricing-button-popular,
.pricing-card-popular .mantine-Button-root.pricing-button-popular *,
.pricing-card-popular button.pricing-button-popular * {
    background: linear-gradient(135deg, #FFD700 0%, #FFA500 100%) !important;
    color: #8B4513 !important;
    border: none !important;
}

.pricing-card-popular .mantine-Button-root.pricing-button-popular:hover,
.pricing-card-popular button.pricing-button-popular:hover,
.pricing-card-popular .mantine-Button-root.pricing-button-popular:hover *,
.pricing-card-popular button.pricing-button-popular:hover * {
    background: linear-gradient(135deg, #FFA500 0%, #FF8C00 100%) !important;
    color: #654321 !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 12px rgba(255, 215, 0, 0.4) !important;
}

.pricing-button-outline {
    border-width: 2px !important;
    transition: all 0.2s ease !important;
    font-weight: 700 !important;
    background: transparent !important;
    color: var(--mantine-color-indigo-7) !important;
    border-color: var(--mantine-color-indigo-4) !important;
}

.pricing-button-outline:hover {
    transform: translateY(-2px) !important;
    background: var(--mantine-color-indigo-0) !important;
    border-color: var(--mantine-color-indigo-5) !important;
    color: var(--mantine-color-indigo-8) !important;
}

.pricing-button-greyed-out {
    opacity: 0.5 !important;
    background-color: var(--mantine-color-gray-2) !important;
    color: var(--mantine-color-gray-6) !important;
    border-color: var(--mantine-color-gray-3) !important;
    cursor: pointer !important;
    font-weight: 500 !important;
}

.pricing-button-greyed-out:hover {
    opacity: 0.5 !important;
    background-color: var(--mantine-color-gray-2) !important;
    color: var(--mantine-color-gray-6) !important;
    border-color: var(--mantine-color-gray-3) !important;
    transform: none !important;
    box-shadow: none !important;
}

.pricing-badge-popular {
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
}

/* Popular card text colors - very specific selectors to override Mantine */
.pricing-card-popular .mantine-Text-root {
    color: white !important;
}

.pricing-card-popular .mantine-Title-root {
    color: white !important;
}

.pricing-card-popular .pricing-feature-item {
    color: white !important;
}

.pricing-card-popular .mantine-Divider-root {
    border-color: rgba(255, 255, 255, 0.2) !important;
}

/* Ensure all direct text within popular cards is white */
.pricing-card-popular * {
    color: white !important;
}

/* IMPORTANT: Button text must be dark blue - this comes AFTER the wildcard */
.pricing-card-popular .mantine-Button-root.pricing-button-popular,
.pricing-card-popular .mantine-Button-root.pricing-button-popular *,
.pricing-card-popular button.pricing-button-popular,
.pricing-card-popular button.pricing-button-popular *,
.pricing-card-popular .mantine-Button-root.pricing-button-popular .mantine-Button-label,
.pricing-card-popular button.pricing-button-popular span {
    color: var(--mantine-color-indigo-8) !important;
}

.pricing-card-popular .mantine-Button-root.pricing-button-popular:hover,
.pricing-card-popular .mantine-Button-root.pricing-button-popular:hover *,
.pricing-card-popular button.pricing-button-popular:hover,
.pricing-card-popular button.pricing-button-popular:hover *,
.pricing-card-popular .mantine-Button-root.pricing-button-popular:hover .mantine-Button-label,
.pricing-card-popular button.pricing-button-popular:hover span {
    color: var(--mantine-color-indigo-9) !important;
}

/* But keep icons and badges their original colors */
.pricing-card-popular .mantine-Badge-root {
    color: inherit !important;
}

/* IMPORTANT: Keep checkmark icons green in popular card - must come AFTER wildcard */
/* These rules MUST be more specific than the wildcard above */

/* White circle background - very specific selectors */
.pricing-card-popular .popular-checkmark-circle.iconify,
.pricing-card-popular .popular-checkmark-circle.iconify svg,
.pricing-card-popular .popular-checkmark-circle.iconify svg path,
.pricing-card-popular .popular-checkmark-circle.iconify svg circle {
    color: #ffffff !important;
    fill: #ffffff !important;
    stroke: #ffffff !important;
    /* Add subtle separation from the dark blue background */
    filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.25));
}

/* Green checkmark inside - very specific selectors */
.pricing-card-popular .popular-checkmark-check.iconify,
.pricing-card-popular .popular-checkmark-check.iconify svg,
.pricing-card-popular .popular-checkmark-check.iconify svg path,
.pricing-card-popular .popular-checkmark-check.iconify svg circle,
.pricing-card-popular .popular-checkmark-check.iconify svg polyline {
    color: var(--mantine-color-green-7) !important;
    fill: var(--mantine-color-green-7) !important;
    stroke: var(--mantine-color-green-7) !important;
    /* Slight shadow to increase legibility against white circle */
    filter: drop-shadow(0 1px 1px rgba(0, 0, 0, 0.18));
}

/* Pricing text sizes */
.pricing-strikethrough-price {
    font-size: 1.5rem !important;
    letter-spacing: -0.02em !important;
    white-space: nowrap !important;
}

.pricing-main-price {
    font-size: 3.5rem !important;
    letter-spacing: -0.03em !important;
    white-space: nowrap !important;
}

/* Responsive pricing grid */
#pricing-grid {
    display: grid !important;
    width: 100% !important;
    align-items: start !important; /* Don't stretch cards to equal height */
}

@media (max-width: 1200px) {
    #pricing-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 1.5rem !important;
    }
    
    /* On tablet, stack the third card below */
    #pricing-grid > *:nth-child(3) {
        grid-column: 1 / -1 !important;
        max-width: 500px !important;
        margin: 0 auto !important;
    }
}

@media (max-width: 768px) {
    #pricing-grid {
        grid-template-columns: 1fr !important;
        gap: 1.5rem !important;
    }
    
    #pricing-grid > *:nth-child(3) {
        grid-column: auto !important;
        max-width: 100% !important;
    }
}

/* Billing toggle - prevent wrapping and match font sizes */
#billing-toggle {
    white-space: nowrap !important;
}

#billing-toggle .mantine-SegmentedControl-input:checked + .mantine-SegmentedControl-label,
#billing-toggle .mantine-SegmentedControl-input:not(:checked) + .mantine-SegmentedControl-label {
    white-space: nowrap !important;
    padding: 12px 20px !important;
    overflow: visible !important;
}

/* Target the first label (Annual with badge) using the exact selector from DOM */
#billing-toggle > div:nth-child(2) > label {
    width: auto !important;
    padding: 12px 24px !important;
}

/* Ensure the Group and Badge inside don't wrap and are visible */
#billing-toggle .mantine-Group-root {
    white-space: nowrap !important;
    flex-wrap: nowrap !important;
    overflow: visible !important;
    width: auto !important;
    min-width: max-content !important;
}

#billing-toggle .mantine-Badge-root {
    white-space: nowrap !important;
    flex-shrink: 0 !important;
    overflow: visible !important;
}

/* Navigation Menu Styles */
.navigation-container {
    flex-shrink: 0 !important;
    min-width: fit-content !important;
}

/* Make header fixed at top - don't scroll */
.mantine-AppShell-header,
#appshell > .mantine-AppShell-header,
[data-mantine-component="AppShellHeader"] {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    width: 100vw !important;
    z-index: 1000 !important;
    transform: none !important;
}

/* Ensure notifications appear above the header */
#notifications-container,
.mantine-NotificationContainer-root,
.mantine-Notification-root {
    z-index: 1100 !important;
}

/* Ensure AppShell container doesn't interfere with fixed positioning */
#appshell.mantine-AppShell-root,
.mantine-AppShell-root {
    position: relative !important;
    padding-top: 0 !important;
    transform: none !important;
}

/* Prevent AppShell root from creating stacking context that breaks fixed positioning */
/* But allow transforms on children (like navigation) */
#appshell.mantine-AppShell-root {
    transform: none !important;
}

/* Ensure the header stays fixed relative to viewport */
body,
html {
    overflow-x: hidden !important;
}

/* Center navigation menu horizontally on the window using flexbox balancing */
/* The fixed header container (.mantine-AppShell-header) is position: fixed and spans 100vw */
/* Navigation will be positioned relative to it */

#appshell-header {
    position: relative !important;
    width: 100% !important;
    max-width: 100% !important;
}

/* Make the header flex container balance left and right sections */
#appshell-header > .mantine-Group-root {
    position: relative !important;
    width: 100% !important;
    max-width: 100% !important;
}

/* Left section - flex to balance with right */
#appshell-header > .mantine-Group-root > .mantine-Group-root:first-child {
    flex: 1 1 auto !important;
    min-width: 0 !important;
}

/* Remove space elements from taking up flex space */
#appshell-header > .mantine-Group-root > .mantine-Space-root {
    flex: 0 0 0 !important;
    width: 0 !important;
    display: none !important;
}

/* Navigation section - centered relative to fixed header container (which spans 100vw) */
/* Fixed elements can serve as positioning contexts, so navigation positions relative to .mantine-AppShell-header */
.mantine-AppShell-header #appshell-header-navigation {
    position: absolute !important;
    left: 50% !important;
    top: 50% !important;
    transform: translate(-50%, -50%) !important;
    display: flex !important;
    align-items: center !important;
    z-index: 1 !important;
    pointer-events: auto !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
    overflow: visible !important;
}

/* Right section - flex to balance with left */
#appshell-header > .mantine-Group-root > .mantine-Group-root:last-child {
    flex: 1 1 auto !important;
    min-width: 0 !important;
    justify-content: flex-end !important;
}

/* Desktop navigation - show as horizontal links */
.desktop-nav {
    display: flex !important;
    align-items: center !important;
    gap: 1.5rem !important;
}

.desktop-nav .mantine-Anchor-root,
.desktop-nav .mantine-Text-root,
.desktop-nav .nav-link-internal,
.desktop-nav .nav-link-pricing {
    text-decoration: none !important;
    color: var(--mantine-color-dark-6) !important;
    font-weight: 500 !important;
    font-size: 14px !important;
    transition: color 0.2s ease !important;
}

.desktop-nav .mantine-Anchor-root:hover,
.desktop-nav .mantine-Text-root:hover,
.desktop-nav .nav-link-internal:hover,
.desktop-nav .nav-link-pricing:hover {
    color: var(--mantine-color-blue-6) !important;
    text-decoration: none !important;
}

.desktop-nav .nav-link-internal:hover .mantine-Text-root,
.desktop-nav .nav-link-pricing:hover .mantine-Text-root {
    color: var(--mantine-color-blue-6) !important;
}

/* Mobile navigation - burger menu */
.mobile-nav {
    display: none !important;
}

.mobile-nav-trigger {
    color: var(--mantine-color-dark-6) !important;
    background: transparent !important;
    border: none !important;
}

.mobile-nav-trigger:hover {
    background-color: rgba(0, 0, 0, 0.05) !important;
}

/* Hide desktop nav on mobile, show mobile nav */
@media (max-width: 767px) {
    .desktop-nav {
        display: none !important;
    }
    
    .mobile-nav {
        display: block !important;
    }
}

/* Mobile menu dropdown styling */
.mobile-nav .mantine-MenuDropdown {
    min-width: 200px !important;
    border-radius: 8px !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
}

.mobile-nav .mantine-MenuItem-root {
    padding: 8px 12px !important;
    font-size: 14px !important;
}

.mobile-nav .mantine-MenuLabel-root {
    font-weight: 600 !important;
    font-size: 12px !important;
    color: var(--mantine-color-gray-6) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    margin-bottom: 4px !important;
}

.mobile-nav .mantine-MenuDivider-root {
    margin: 8px 0 !important;
}

/* Hero Card Styles */
.hero-card,
.hero-card.mantine-Card-root,
.hero-card .mantine-Card-root,
.mantine-Card-root.hero-card {
    background-color: transparent !important;
    background: linear-gradient(135deg, var(--mantine-color-green-1) 0%, var(--mantine-color-green-2) 100%) !important;
    border: none !important;
    position: relative !important;
    overflow: hidden !important;
    width: 90% !important;
    max-width: 90% !important;
    padding: 2rem !important;
}

@media (min-width: 768px) {
    .hero-card,
    .hero-card.mantine-Card-root,
    .hero-card .mantine-Card-root,
    .mantine-Card-root.hero-card {
        width: 60vw !important;
        min-width: 60vw !important;
        max-width: 1000px !important;
        background-color: transparent !important;
        background: linear-gradient(135deg, var(--mantine-color-green-1) 0%, var(--mantine-color-green-2) 100%) !important;
    }
    
    /* Override any parent container constraints */
    .mantine-Center-root .hero-card {
        width: 60vw !important;
        min-width: 60vw !important;
        max-width: 1000px !important;
    }
}

.hero-card-container {
    position: relative !important;
    height: 440px !important;
    width: 100% !important;
}

@media (min-width: 768px) {
    .hero-card-container {
        height: 340px !important;
    }
}

.hero-card-background {
    position: absolute !important;
    top: -2rem !important;
    left: -2rem !important;
    right: -2rem !important;
    bottom: -2rem !important;
    background: 
        radial-gradient(circle at 20% 20%, rgba(255, 255, 255, 0.15) 0%, transparent 50%),
        radial-gradient(circle at 80% 80%, rgba(255, 255, 255, 0.12) 0%, transparent 50%),
        radial-gradient(circle at 40% 60%, rgba(255, 255, 255, 0.08) 0%, transparent 50%);
    pointer-events: none !important;
}

@media (min-width: 768px) {
    .hero-card-background {
        background-image: url('/assets/img/radiating_circles.webp');
        background-size: cover;
        background-position: center;
        background-repeat: no-repeat;
        opacity: 0.5;
        filter: invert(1) brightness(0.8);
        mix-blend-mode: overlay;
    }
}

.hero-card-content {
    position: relative !important;
    z-index: 1 !important;
    height: 100% !important;
    display: flex !important;
    flex-direction: column !important;
}

.hero-card-logo {
    height: 60px !important;
    width: auto !important;
}

/* Hero upload button - pill shaped, 2x bigger than header */
.hero-upload-group {
    cursor: pointer !important;
    user-select: none !important;
    height: 66px !important;
    min-height: 66px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 12px !important;
    border: none !important;
    transition: all 0.2s ease !important;
}

/* Green filled style when btn-primary-accent is applied */
.hero-upload-group.btn-primary-accent {
    background-color: var(--mantine-color-green-6) !important;
    color: white !important;
    height: 66px !important;
    min-height: 66px !important;
}

.hero-upload-group.btn-primary-accent:hover {
    background-color: var(--mantine-color-green-7) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 12px var(--mantine-color-green-4) !important;
}

.hero-upload-wrapper {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    height: 100% !important;
    gap: 12px !important;
}

/* Update primary accent color to green */
.btn-primary-accent {
    background-color: var(--mantine-color-green-6) !important;
    color: white !important;
}

.btn-primary-accent:hover {
    background-color: var(--mantine-color-green-7) !important;
}

/* Hero Card Responsive Heading */
.hero-card-heading-responsive {
    font-size: clamp(24px, 5vw, 36px) !important;
}

/* Hero Card Container */
.hero-card {
    overflow: hidden !important;
    max-width: 1105px !important;
}

/* FAQ Accordion */
.faq-accordion {
    width: 100% !important;
    max-width: 800px !important;
}

/* Support Email Link */
.support-email-link {
    color: inherit !important;
    text-decoration: underline !important;
}

/* Project Card Styles */
.project-card {
    height: 600px !important;
    display: flex !important;
    flex-direction: column !important;
    width: 350px !important;
    box-sizing: border-box !important;
}

.project-card-stack {
    height: 100% !important;
}

.project-card-tags-group {
    flex-wrap: wrap !important;
    padding: 0.25rem 0 !important;
}

.project-card-carousel-image {
    max-width: 100% !important;
    width: 100% !important;
}

.project-card-carousel-image img {
    max-width: 100% !important;
    object-fit: cover !important;
    width: 100% !important;
}

/* Banner Card Container */
.banner-card-container {
    position: relative !important;
    width: 100% !important;
    height: 100% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

/* Banner Card Screenshot Base */
.banner-card-screenshot {
    position: absolute !important;
    top: 50% !important;
    left: 50% !important;
    transform-origin: center center !important;
    max-width: 100% !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
}

.banner-card-screenshot img {
    max-width: 100% !important;
    height: auto !important;
    display: block !important;
}

/* Banner Card Text Overlay Base */
.banner-card-text-overlay {
    position: absolute !important;
    top: 1.5rem !important;
    left: 1.5rem !important;
    font-weight: bold !important;
    text-align: left !important;
    z-index: 3 !important;
    max-width: calc(100% - 3rem) !important;
    line-height: 1.1 !important;
}

.banner-card-text-main {
    margin-bottom: 0.25rem !important;
}

.banner-card-text-sub {
    font-weight: normal !important;
    line-height: 1.3 !important;
    margin-top: 0.5rem !important;
}

/* Video Card Mobile Styles */
.video-card-mobile {
    display: flex !important;
    flex-direction: column !important;
    width: 350px !important;
    height: 600px !important;
    box-sizing: border-box !important;
}

.video-card-mobile-iframe-wrapper {
    width: 312px !important;
    max-width: 100% !important;
    aspect-ratio: 16/9 !important;
    overflow: hidden !important;
    height: 562px !important;
    border-radius: 8px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.video-card-mobile-center {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    height: 100% !important;
}

/* Video Card Desktop Styles */
.video-card-desktop {
    display: flex !important;
    flex-direction: column !important;
    width: 1105px !important;
    box-sizing: border-box !important;
}

.video-card-desktop-iframe-wrapper {
    width: 100% !important;
    max-width: 100% !important;
    aspect-ratio: 16/9 !important;
    overflow: hidden !important;
    border-radius: 8px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.video-card-desktop-center {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    height: 100% !important;
}

/* Iframe Card Mobile Styles */
.iframe-card-mobile {
    display: flex !important;
    flex-direction: column !important;
    width: 350px !important;
    height: 650px !important;
    box-sizing: border-box !important;
}

.iframe-card-mobile-iframe-wrapper {
    width: 100% !important;
    max-width: 100% !important;
    overflow: hidden !important;
    border-radius: 8px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.iframe-card-desktop-iframe-wrapper {
    width: 100% !important;
    max-width: 100% !important;
    overflow: hidden !important;
    border-radius: 8px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.iframe-card-mobile-container {
    position: relative !important;
    width: 100% !important;
    height: 100% !important;
    overflow: hidden !important;
}

/* Iframe Card Desktop Styles */
.iframe-card-desktop {
    display: flex !important;
    flex-direction: column !important;
    width: 1105px !important;
    box-sizing: border-box !important;
}

.iframe-card-desktop-iframe-wrapper {
    width: 100% !important;
    max-width: 100% !important;
    overflow: hidden !important;
    border-radius: 8px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.iframe-card-desktop-left {
    width: 720px !important;
    height: 100% !important;
    overflow: hidden !important;
    flex: 0 0 720px !important;
}

.iframe-card-desktop-right {
    flex: 1 !important;
    display: flex !important;
    align-items: flex-end !important;
    justify-content: center !important;
    min-width: 300px !important;
    padding-bottom: 20px !important;
}

.iframe-card-desktop-row {
    display: flex !important;
    flex-direction: row !important;
    width: 100% !important;
    height: 100% !important;
    gap: 20px !important;
}

.iframe-card-desktop-container {
    position: relative !important;
    width: 100% !important;
    height: 100% !important;
}

.iframe-card-text-overlay {
    position: absolute !important;
    top: 1.5rem !important;
    left: 0.5rem !important;
    font-weight: bold !important;
    text-align: left !important;
    z-index: 3 !important;
    max-width: calc(100% - 3rem) !important;
    line-height: 1.1 !important;
    padding: 0 0 0.5rem 0 !important;
}

/* Microsoft Signup Button Styles */
.ms-signup-button {
    width: 100% !important;
    height: 60px !important;
    font-size: 16px !important;
    border-color: var(--mantine-color-gray-5) !important;
}

.ms-button-image {
    margin-right: 8px !important;
}

.ms-upload-button {
    width: 100% !important;
    height: 60px !important;
    font-size: 16px !important;
}

.iframe-cta-stack {
    height: 100% !important;
    padding: 0 20px !important;
}

.iframe-upload-wrapper {
    width: 100% !important;
}

.iframe-signup-link {
    text-decoration: none !important;
    display: block !important;
    width: 100% !important;
}

/* Use Cases Iframe Responsive Styling */
.use-cases-iframe-container {
    width: 100%;
    margin: 0 auto;
}

.use-cases-iframe-container iframe {
    border: none;
    width: 100%;
    overflow: hidden;
}

/* Desktop - full height */
@media (min-width: 1024px) {
    .use-cases-iframe-container iframe {
        height: 250px;
    }
}

/* Narrow desktop / tablet - hide industry column below 900px */
@media (min-width: 769px) and (max-width: 1023px) {
    .use-cases-iframe-container iframe {
        height: 250px;
    }
}

/* Mobile - hide industry column */
@media (max-width: 768px) {
    .use-cases-iframe-container iframe {
        height: 250px;
    }
}


