/* 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: var(--mantine-color-indigo-6);
    --ribbon-color-end: var(--mantine-color-indigo-7);
}

.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, #f9fafb 0%, #f6f8fb 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, rgba(34, 197, 94, 0.1) 0%, rgba(22, 163, 74, 0.05) 100%);
    box-shadow: 0 1px 3px rgba(34, 197, 94, 0.20),
                0 1px 2px rgba(0, 0, 0, 0.06),
                inset 0 1px 2px rgba(34, 197, 94, 0.15);
    transition: all 0.3s ease;
}

.boot-upload-container:hover {
    border-color: var(--mantine-color-green-5);
    background: linear-gradient(135deg, rgba(34, 197, 94, 0.15) 0%, rgba(22, 163, 74, 0.08) 100%);
    box-shadow: 0 4px 12px rgba(34, 197, 94, 0.25),
                0 2px 6px rgba(0, 0, 0, 0.1),
                inset 0 1px 3px rgba(34, 197, 94, 0.20);
    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 #8c8c8c !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: #5e5e5e !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;
}

.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, #1e3a8a 0%, #1e40af 50%, #2563eb 100%) !important;
    color: white !important;
    box-shadow: 0 8px 32px rgba(37, 99, 235, 0.4) !important;
    position: relative;
    z-index: 1;
    /* Make popular card taller */
    min-height: 750px !important;
    padding-top: 2rem !important;
    padding-bottom: 2rem !important;
}

.pricing-card-popular:hover {
    box-shadow: 0 12px 40px rgba(37, 99, 235, 0.5) !important;
    transform: translateY(-8px) scale(1.02) !important;
}

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

.pricing-button-popular:hover {
    background: linear-gradient(135deg, #f0f9ff 0%, #dbeafe 100%) !important;
    color: #1e3a8a !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 12px rgba(255, 255, 255, 0.3) !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, #ffffff 0%, #f0f9ff 100%) !important;
    color: #1e40af !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, #f0f9ff 0%, #dbeafe 100%) !important;
    color: #1e3a8a !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 12px rgba(255, 255, 255, 0.3) !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: rgba(37, 99, 235, 0.08) !important; /* subtle indigo wash */
    border-color: var(--mantine-color-indigo-5) !important;
    color: var(--mantine-color-indigo-8) !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: #1e40af !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: #1e3a8a !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: #16a34a !important;
    fill: #16a34a !important;
    stroke: #16a34a !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;
}

/* 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: #2c2e33 !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: #228be6 !important;
    text-decoration: none !important;
}

.desktop-nav .nav-link-internal:hover .mantine-Text-root,
.desktop-nav .nav-link-pricing:hover .mantine-Text-root {
    color: #228be6 !important;
}

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

.mobile-nav-trigger {
    color: #2c2e33 !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: #868e96 !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, rgba(34, 197, 94, 0.123) 0%, rgba(22, 163, 74, 0.315) 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, rgba(34, 197, 94, 0.123) 0%, rgba(22, 163, 74, 0.315) 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: 340px !important;
    width: 100% !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 rgba(34, 197, 94, 0.3) !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;
}


