/* =============================================
   Missing Tailwind utility classes
   ============================================= */

/* Spacing */
.px-3\.5 { padding-left: 0.875rem; padding-right: 0.875rem; }
.py-2\.5 { padding-top: 0.625rem; padding-bottom: 0.625rem; }
.pl-1 { padding-left: 0.25rem; }
.pl-3\.5 { padding-left: 0.875rem; }
.pr-2 { padding-right: 0.5rem; }
.pr-3\.5 { padding-right: 0.875rem; }
.mt-1\.5 { margin-top: 0.375rem; }
.mt-2\.5 { margin-top: 0.625rem; }
.p-4 { padding: 1rem; }

/* Outline */
.outline-1 { outline-width: 1px; outline-style: solid; }
.outline-2 { outline-width: 2px; outline-style: solid; }
.outline-gray-300 { outline-color: #d1d5db; }
.outline-gray-700 { outline-color: #374151; }
.\-outline-offset-1 { outline-offset: -1px; }
.\-outline-offset-2 { outline-offset: -2px; }

/* Focus outline */
.focus\:outline-2:focus { outline-width: 2px; outline-style: solid; }
.focus\:-outline-offset-2:focus { outline-offset: -2px; }
.focus\:outline-gray-700:focus { outline-color: #374151; }
.focus\:outline-none:focus { outline: none; }

/* Focus ring */
.focus\:ring-2:focus { box-shadow: 0 0 0 2px var(--tw-ring-color, #374151); }
.focus\:ring-gray-700:focus { --tw-ring-color: #374151; box-shadow: 0 0 0 2px #374151; }
.focus\:ring-offset-0:focus { --tw-ring-offset-width: 0px; }
.focus\:ring-offset-2:focus { --tw-ring-offset-width: 2px; }

/* has-[input:focus-within] variants */
.has-\[input\:focus-within\]\:outline-2:has(input:focus-within) { outline-width: 2px; outline-style: solid; }
.has-\[input\:focus-within\]\:-outline-offset-2:has(input:focus-within) { outline-offset: -2px; }
.has-\[input\:focus-within\]\:outline-gray-700:has(input:focus-within) { outline-color: #374151; }

/* Placeholder */
.placeholder\:text-gray-400::placeholder { color: #9ca3af; }

/* Text */
.text-sm\/6 { font-size: 0.875rem; line-height: 1.5rem; }
.text-balance { text-wrap: balance; }
.text-xs { font-size: 0.75rem; line-height: 1rem; }
.text-gray-400 { color: #9ca3af; }
.text-gray-500 { color: #6b7280; }
.text-gray-600 { color: #4b5563; }
.text-red-600 { color: #dc2626; }
.text-green-500 { color: #22c55e; }
.font-medium { font-weight: 500; }

/* Hover */
.hover\:text-gray-700:hover { color: #374151; }

/* Sizing */
.h-4 { height: 1rem; }
.h-5 { height: 1.25rem; }
.h-6 { height: 1.5rem; }
.w-4 { width: 1rem; }
.w-7 { width: 1.75rem; }
.min-w-0 { min-width: 0px; }
.grow { flex-grow: 1; }

/* Layout */
.contents { display: contents; }
.bg-transparent { background-color: transparent; }
.bg-gray-100 { background-color: #f3f4f6; }
.border-gray-300 { border-color: #d1d5db; }
.isolate { isolation: isolate; }
.inset-x-0 { left: 0; right: 0; }
.\-top-40 { top: -10rem; }
.\-z-10 { z-index: -10; }
.transform-gpu { transform: translateZ(0); }
.blur-3xl { filter: blur(64px); }
.opacity-30 { opacity: 0.3; }
.left-1\/2 { left: 50%; }
.\-translate-x-1\/2 { transform: translateX(-50%); }
.rotate-\[30deg\] { transform: rotate(30deg); }
.aspect-\[1155\/678\] { aspect-ratio: 1155/678; }
.w-\[36\.125rem\] { width: 36.125rem; }
.max-w-2xl { max-width: 42rem; }
.bg-gradient-to-tr { background-image: linear-gradient(to top right, var(--tw-gradient-from), var(--tw-gradient-to)); }
.from-\[\#cad3b0\] { --tw-gradient-from: #cad3b0; }
.to-\[\#ff0000\] { --tw-gradient-to: #ff0000; }

/* Responsive sm: (640px) */
@media (min-width: 640px) {
    .sm\:py-16 { padding-top: 4rem; padding-bottom: 4rem; }
    .sm\:mt-20 { margin-top: 5rem; }
    .sm\:-top-80 { top: -20rem; }
    .sm\:left-\[calc\(50\%-40rem\)\] { left: calc(50% - 40rem); }
    .sm\:w-\[72\.1875rem\] { width: 72.1875rem; }
    /* Hero text responsive */
    .sm\:px-6 { padding-left: 1.5rem; padding-right: 1.5rem; }
    .sm\:px-5 { padding-left: 1.25rem; padding-right: 1.25rem; }
    .sm\:w-\[200px\] { width: 200px; }
    .sm\:text-4xl { font-size: 2.25rem; line-height: 2.5rem; }
    .sm\:text-\[70px\] { font-size: 70px; }
    .sm\:text-sm { font-size: 0.875rem; line-height: 1.25rem; }
    .sm\:text-base { font-size: 1rem; line-height: 1.5rem; }
    .sm\:text-xl { font-size: 1.25rem; line-height: 1.75rem; }
    /* Sizing */
    .sm\:w-full { width: 100%; }
    .sm\:max-w-xl { max-width: 36rem; }
    .sm\:max-w-2xl { max-width: 42rem; }
    .sm\:max-w-3xl { max-width: 48rem; }
    /* Spacing */
    .sm\:ml-0 { margin-left: 0; }
    .sm\:ml-4 { margin-left: 1rem; }
    .sm\:ml-8 { margin-left: 2rem; }
    .sm\:ml-12 { margin-left: 3rem; }
    .sm\:ml-16 { margin-left: 4rem; }
    .sm\:ml-20 { margin-left: 5rem; }
    .sm\:ml-24 { margin-left: 6rem; }
    /* Flex & alignment */
    .sm\:items-start { align-items: flex-start; }
    .sm\:items-center { align-items: center; }
    .sm\:text-left { text-align: left; }
    .sm\:text-center { text-align: center; }
    .sm\:justify-start { justify-content: flex-start; }
    .sm\:justify-center { justify-content: center; }
    .sm\:flex-row { flex-direction: row; }
    /* Page sections */
    .sm\:h-8 { height: 2rem; }
    .sm\:grid-cols-6 { grid-template-columns: repeat(6, minmax(0, 1fr)); }
}

/* Responsive md: (768px) */
@media (min-width: 768px) {
    /* Spacing & layout */
    .md\:ml-0 { margin-left: 0; }
    .md\:ml-1 { margin-left: 0.25rem; }
    .md\:ml-2 { margin-left: 0.5rem; }
    .md\:ml-3 { margin-left: 0.75rem; }
    .md\:ml-4 { margin-left: 1rem; }
    .md\:ml-5 { margin-left: 1.25rem; }
    .md\:ml-6 { margin-left: 1.5rem; }
    .md\:ml-8 { margin-left: 2rem; }
    .md\:ml-10 { margin-left: 2.5rem; }
    .md\:ml-12 { margin-left: 3rem; }
    .md\:ml-16 { margin-left: 4rem; }
    .md\:ml-20 { margin-left: 5rem; }
    .md\:ml-24 { margin-left: 6rem; }
    .md\:ml-32 { margin-left: 8rem; }
    .md\:ml-40 { margin-left: 10rem; }
    .md\:ml-48 { margin-left: 12rem; }
    .md\:ml-60 { margin-left: 15rem; }
    .md\:ml-64 { margin-left: 16rem; }
    .md\:mx-0 { margin-left: 0; margin-right: 0; }
    .md\:mt-1 { margin-top: 0.25rem; }
    .md\:py-3 { padding-top: 0.75rem; padding-bottom: 0.75rem; }
    .md\:py-20 { padding-top: 5rem; padding-bottom: 5rem; }
    .md\:pr-6 { padding-right: 1.5rem; }
    .md\:px-5 { padding-left: 1.25rem; padding-right: 1.25rem; }
    .md\:px-6 { padding-left: 1.5rem; padding-right: 1.5rem; }
    /* Flex & alignment */
    .md\:items-start { align-items: flex-start; }
    .md\:items-center { align-items: center; }
    .md\:text-left { text-align: left; }
    .md\:justify-start { justify-content: flex-start; }
    .md\:flex-row { flex-direction: row; }
    /* Sizing */
    .md\:max-w-2xl { max-width: 42rem; }
    .md\:w-\[200px\] { width: 200px; }
    .md\:w-full { width: 100%; }
    .md\:w-20 { width: 5rem; }
    .md\:h-12 { height: 3rem; }
    /* Typography */
    .md\:text-5xl { font-size: 3rem; line-height: 1; }
    .md\:text-6xl { font-size: 3.75rem; line-height: 1; }
    .md\:text-\[120px\] { font-size: 120px; }
    .md\:text-base { font-size: 1rem; line-height: 1.5rem; }
    /* Grid */
    .md\:grid { display: grid; }
    .md\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .md\:grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
    .md\:grid-cols-8 { grid-template-columns: repeat(8, minmax(0, 1fr)); }
    .md\:col-span-2 { grid-column: span 2 / span 2; }
    .md\:gap-2 { gap: 0.5rem; }
    .md\:gap-3 { gap: 0.75rem; }
    .md\:gap-6 { gap: 1.5rem; }
    .md\:space-y-0 > :not(:first-child) { margin-top: 0; }
    /* Borders */
    .md\:border-b-0 { border-bottom-width: 0; }
    .md\:border-r { border-right-width: 1px; border-right-style: solid; }
}

/* Responsive lg: (1024px) */
@media (min-width: 1024px) {
    .lg\:px-8 { padding-left: 2rem; padding-right: 2rem; }
    .lg\:text-7xl { font-size: 4.5rem; line-height: 1; }
    .lg\:text-\[140px\] { font-size: 140px; }
    .lg\:grid-cols-10 { grid-template-columns: repeat(10, minmax(0, 1fr)); }
}

/* Hero scope: full width on mobile, constrained on md+ */
[data-hero-scope] {
    width: 100%;
}
@media (min-width: 768px) {
    [data-hero-scope] {
        width: auto;
    }
}

/* Hero title */
.hero-title {
    line-height: 1;
}

/* =============================================
   Custom styles
   ============================================= */

/* Page title */
.form-inscriere-title {
    font-size: 1.875rem;
    font-weight: 600;
    line-height: 1.2;
    letter-spacing: -0.025em;
}

@media (min-width: 640px) {
    .form-inscriere-title {
        font-size: 3rem;
    }
}

/* Form layout */
.form-inscriere {
    max-width: 36rem;
    width: 100%;
}

/* Vertical spacing between form sections */
.form-inscriere > * + * {
    margin-top: 2.5rem;
}

/* Section styling */
.section-parinte {
    padding-bottom: 2.5rem;
    border-bottom: 1px solid #e5e7eb;
}

.section-title {
    font-size: 1.125rem;
    font-weight: 600;
    color: #111827;
    margin-bottom: 1.5rem;
}

/* Form grid - 2 columns on larger screens */
.form-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem 2rem;
}

@media (min-width: 640px) {
    .form-grid {
        grid-template-columns: 1fr 1fr;
    }
}

.col-span-full {
    grid-column: 1 / -1;
}

/* Terms section */
.section-termeni {
    border-top: 1px solid #e5e7eb;
    padding-top: 2.5rem;
}

.section-termeni > .flex {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
}

/* Submit button */
.submit-btn {
    display: block;
    width: 100%;
    margin-top: 2.5rem;
    padding: 0.625rem 0.875rem;
    background-color: #111827;
    color: #fff;
    font-size: 0.875rem;
    font-weight: 600;
    border-radius: 0.375rem;
    border: none;
    cursor: pointer;
    text-align: center;
    box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
}

.submit-btn:hover:not(:disabled) {
    background-color: #1f2937;
}

.submit-btn:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

.back-btn {
    display: block;
    width: 100%;
    margin-top: 0.75rem;
    padding: 0.625rem 0.875rem;
    background-color: transparent;
    color: #374151;
    font-size: 0.875rem;
    font-weight: 600;
    border-radius: 0.375rem;
    border: 1px solid #d1d5db;
    cursor: pointer;
    text-align: center;
    text-decoration: none;
}

.back-btn:hover {
    background-color: #f3f4f6;
}

.submit-btn:focus-visible {
    outline: 2px solid #374151;
    outline-offset: 2px;
}

/* Error messages */
.error {
    color: var(--color-red-600, #dc2626);
    font-size: 0.75rem;
    line-height: 1rem;
    margin-top: 0.375rem;
}

/* =============================================
   Navbar
   ============================================= */
.top-0 { top: 0; }
.left-0 { left: 0; }
.right-0 { right: 0; }
.z-20 { z-index: 20; }
.h-8 { height: 2rem; }
.w-10 { width: 2.5rem; }
.h-10 { height: 2.5rem; }
.w-6 { width: 1.5rem; }
.bg-black\/80 { background-color: rgba(0, 0, 0, 0.8); }
.border-white\/10 { border-color: rgba(255, 255, 255, 0.1); }
.hover\:text-white\/80:hover { color: rgba(255, 255, 255, 0.8); }
.hover\:bg-white\/10:hover { background-color: rgba(255, 255, 255, 0.1); }
.justify-end { justify-content: flex-end; }

.nav-links {
    border-radius: 0.5rem;
    padding: 0.25rem;
}

.nav-link {
    color: #fff;
    font-size: 0.8125rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding: 0.4rem 1rem;
    border-radius: 0.375rem;
    transition: all 0.2s ease;
    text-decoration: none;
    background-color: rgba(185, 28, 28, 0.85);
}

.nav-link:hover {
    color: #fff;
    background-color: rgba(185, 28, 28, 1);
}

.nav-mobile-overlay {
    position: fixed;
    inset: 0;
    z-index: 19;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: rgba(0, 0, 0, 0.8);
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
}

.nav-mobile-overlay.hidden {
    display: none;
}

.nav-mobile-link {
    display: block;
    color: #fff;
    font-size: 1.25rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    padding: 0.875rem 2rem;
    border-radius: 0.5rem;
    text-decoration: none;
    text-align: center;
    background-color: rgba(185, 28, 28, 0.9);
    transition: background-color 0.2s ease;
}

.nav-mobile-link:hover {
    background-color: rgba(185, 28, 28, 1);
}

@media (min-width: 768px) {
    .md\:hidden { display: none; }
    .md\:flex { display: flex; }
}
