@import 'tailwindcss';

@source '../../vendor/laravel/framework/src/Illuminate/Pagination/resources/views/*.blade.php';
@source '../../storage/framework/views/*.php';
@source '../**/*.blade.php';
@source '../**/*.js';
@source '../../app/**/*.php';

/* English Fonts */
@font-face {
    font-family: 'Bebas';
    src: url('/public/fonts/english/Bebas/Bebas/Bebas-Regular.otf') format('opentype'),
        url('/public/fonts/english/Bebas/Bebas/Bebas-Regular.ttf') format('truetype');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Calibri';
    src: url('/public/fonts/english/Calibri/Calibri/Calibri.ttf') format('truetype');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Calibri';
    src: url('/public/fonts/english/Calibri/Calibri/calibrib.ttf') format('truetype');
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Calibri';
    src: url('/public/fonts/english/Calibri/Calibri/calibril.ttf') format('truetype');
    font-weight: 300;
    font-style: normal;
    font-display: swap;
}

/* Kurdish Fonts */
@font-face {
    font-family: 'Bahij Janna';
    src: url('/public/fonts/kurdish/Bahij Janna-Regular.ttf') format('truetype');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Bahij Janna';
    src: url('/public/fonts/kurdish/Bahij Janna-Bold.ttf') format('truetype');
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}

@theme {
    /* Default font stack */
    --font-sans: 'Instrument Sans', ui-sans-serif, system-ui, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji',
        'Segoe UI Symbol', 'Noto Color Emoji';

    /* English fonts */
    --font-english-sans: 'Calibri', 'Arial', sans-serif;
    --font-english-display: 'Bebas', 'Arial Black', sans-serif;

    /* Kurdish fonts */
    --font-kurdish-sans: 'Bahij Janna', 'Arial', sans-serif;

    /* Language-aware font family */
    --font-body: var(--font-sans);

    /* KUST Color Palette - Custom colors */
    --color-primary: #19367b;
    --color-primary-dark: #142a4d;
    --color-primary-grey: #74797a;
    --color-secondary: #ffce44;
    --color-secondary-dark: #e6b83a;
    --color-white: #ffffff;
}

/* Language-specific font classes */
html[lang="en"],
html[lang="en-US"],
html[lang="en-GB"] {
    --font-body: var(--font-english-sans);
    --font-display: var(--font-english-display);
}

html[lang="ku"],
html[lang="ckb"],
html[lang="ku-Arab"] {
    --font-body: var(--font-kurdish-sans);
    --font-display: var(--font-kurdish-sans);
}

html[lang="ar"],
html[lang="ar-IQ"],
html[lang="ar-SA"] {
    --font-body: var(--font-kurdish-sans);
    --font-display: var(--font-kurdish-sans);
}

/* Apply font to body */
body {
    font-family: var(--font-body);
}


/* Utility classes for fonts */
.font-display {
    font-family: var(--font-display, var(--font-body));
}

.font-english {
    font-family: var(--font-english-sans);
}

.font-kurdish {
    font-family: var(--font-kurdish-sans);
}

/* RTL Support */
[dir="rtl"] {
    direction: rtl;
    text-align: right;
}

[dir="rtl"] body {
    text-align: right;
}

/* RTL Text alignment */
[dir="rtl"] .text-left {
    text-align: right;
}

[dir="rtl"] .text-right {
    text-align: left;
}

/* RTL Margin adjustments */
[dir="rtl"] .ml-auto {
    margin-left: 0;
    margin-right: auto;
}

[dir="rtl"] .mr-auto {
    margin-right: 0;
    margin-left: auto;
}

/* RTL Header - reverse flex direction */
[dir="rtl"] header .flex.justify-between {
    flex-direction: row-reverse;
}

/* RTL Navigation */
[dir="rtl"] nav {
    direction: rtl;
}

/* RTL Footer */
[dir="rtl"] footer {
    direction: rtl;
    text-align: right;
}

[dir="rtl"] footer .text-center {
    text-align: center;
}

/* RTL Grid adjustments */
[dir="rtl"] .grid {
    direction: rtl;
}

/* Alpine.js cloaking */
[x-cloak] {
    display: none !important;
}

/* Navigation Dropdown Styles */
.group:hover .group-hover\:block {
    display: block;
}

/* Smooth transitions for dropdowns - No underlines */
nav a,
nav a:hover,
nav a:focus,
nav a:active {
    text-decoration: none !important;
    outline: none;
}

nav a {
    position: relative;
    transition: all 0.3s ease;
}

/* Mega Menu Styles */
.mega-menu-enter {
    animation: fadeInDown 0.3s ease-out;
}

@keyframes fadeInDown {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Mega Menu Positioning - Centered on viewport */
.mega-menu-wrapper {
    position: fixed !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    max-width: min(1152px, calc(100vw - 2rem)) !important;
    width: min(1152px, calc(100vw - 2rem)) !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    z-index: 9999 !important;
}

/* Ensure mega menu doesn't overflow viewport */
@media (max-width: 1280px) {
    .mega-menu-wrapper {
        width: calc(100vw - 2rem) !important;
        max-width: calc(100vw - 2rem) !important;
    }
}

/* Container constraints - allow overflow for dropdowns */
header nav,
.bg-primary.relative,
.bg-primary .max-w-7xl {
    overflow: visible !important;
}

/* Responsive positioning for smaller screens */
@media (max-width: 1200px) {
    .mega-menu-wrapper {
        width: calc(100vw - 2rem) !important;
        max-width: calc(100vw - 2rem) !important;
    }
}

/* Quick Links Hover Effect */
.quick-link-icon {
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.quick-link-icon:hover {
    transform: scale(1.1);
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.2);
}

/* Slider Styles */
.swiper-container {
    position: relative;
    width: 100%;
    overflow: hidden;
}

.swiper-wrapper {
    position: relative;
    width: 100%;
    min-height: 300px;
}

@media (min-width: 640px) {
    .swiper-wrapper {
        min-height: 400px;
    }
}

@media (min-width: 768px) {
    .swiper-wrapper {
        min-height: 500px;
    }
}

@media (min-width: 1024px) {
    .swiper-wrapper {
        min-height: 600px;
    }
}

.swiper-slide {
    width: 100%;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    opacity: 1;
    transition: opacity 1s ease-in-out;
    z-index: 1;
}

.swiper-slide:first-child {
    position: relative;
    z-index: 1;
}

.swiper-slide.hidden {
    opacity: 0;
    pointer-events: none;
    z-index: 0;
}

.swiper-pagination {
    position: absolute;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 8px;
    z-index: 10;
}

.swiper-pagination-bullet {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.5);
    cursor: pointer;
    transition: background 0.3s;
}

.swiper-pagination-bullet-active {
    background: white;
}

.swiper-button-next,
.swiper-button-prev {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 44px;
    height: 44px;
    background: rgba(255, 255, 255, 0.3);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    z-index: 10;
    transition: background 0.3s;
    color: white;
    font-size: 20px;
}

.swiper-button-next:hover,
.swiper-button-prev:hover {
    background: rgba(255, 255, 255, 0.5);
}

.swiper-button-next {
    right: 20px;
}

.swiper-button-prev {
    left: 20px;
}

[dir="rtl"] .swiper-button-next {
    right: auto;
    left: 20px;
}

[dir="rtl"] .swiper-button-prev {
    left: auto;
    right: 20px;
}

/* Columns block: disable text justify */
.columns-block .prose,
.columns-block .rich-content {
    text-align: left;
}

.columns-block .prose p,
.columns-block .rich-content p,
.columns-block .prose li,
.columns-block .rich-content li {
    text-align: left;
}

/* Rich Text Content Styling - Matches Filament RichEditor */
.prose,
.rich-content {
    color: #374151;
    line-height: 1.75;
    font-size: 1rem;
}

.prose p,
.rich-content p {
    margin-top: 1.25em;
    margin-bottom: 1.25em;
}

.prose h1,
.rich-content h1 {
    font-size: 2.25em;
    font-weight: 800;
    line-height: 1.1111111;
    margin-top: 0;
    margin-bottom: 0.8888889em;
    color: #111827;
}

.prose h2,
.rich-content h2 {
    font-size: 1.5em;
    font-weight: 700;
    line-height: 1.3333333;
    margin-top: 2em;
    margin-bottom: 1em;
    color: #111827;
}

.prose h3,
.rich-content h3 {
    font-size: 1.25em;
    font-weight: 600;
    line-height: 1.6;
    margin-top: 1.6em;
    margin-bottom: 0.6em;
    color: #111827;
}

.prose h4,
.rich-content h4 {
    font-weight: 600;
    line-height: 1.5;
    margin-top: 1.5em;
    margin-bottom: 0.5em;
    color: #111827;
}

.prose h5,
.rich-content h5 {
    font-weight: 600;
    line-height: 1.5;
    margin-top: 1.5em;
    margin-bottom: 0.5em;
    color: #111827;
}

.prose h6,
.rich-content h6 {
    font-weight: 600;
    line-height: 1.5;
    margin-top: 1.5em;
    margin-bottom: 0.5em;
    color: #111827;
}

.prose strong,
.rich-content strong {
    font-weight: 600;
    color: #111827;
}

.prose a,
.rich-content a {
    color: #2563eb;
    text-decoration: underline;
    font-weight: 500;
}

.prose a:hover,
.rich-content a:hover {
    color: #1d4ed8;
}

.prose ul,
.prose ol,
.rich-content ul,
.rich-content ol {
    margin-top: 1.25em;
    margin-bottom: 1.25em;
    padding-left: 1.625em;
}

.prose ul,
.rich-content ul {
    list-style-type: disc;
}

.prose ol,
.rich-content ol {
    list-style-type: decimal;
}

.prose li,
.rich-content li {
    margin-top: 0.5em;
    margin-bottom: 0.5em;
}

.prose li>p,
.rich-content li>p {
    margin-top: 0.75em;
    margin-bottom: 0.75em;
}

.prose blockquote,
.rich-content blockquote {
    font-weight: 500;
    font-style: italic;
    color: #111827;
    border-left-width: 0.25rem;
    border-left-color: #e5e7eb;
    quotes: "\201C" "\201D" "\2018" "\2019";
    margin-top: 1.6em;
    margin-bottom: 1.6em;
    padding-left: 1em;
}

.prose code,
.rich-content code {
    color: #111827;
    font-weight: 600;
    font-size: 0.875em;
    background-color: #f3f4f6;
    padding: 0.2em 0.4em;
    border-radius: 0.25rem;
}

.prose pre,
.rich-content pre {
    color: #e5e7eb;
    background-color: #1f2937;
    overflow-x: auto;
    font-size: 0.875em;
    line-height: 1.7142857;
    margin-top: 1.7142857em;
    margin-bottom: 1.7142857em;
    border-radius: 0.375rem;
    padding: 0.8571429em 1.1428571em;
}

.prose pre code,
.rich-content pre code {
    background-color: transparent;
    border-width: 0;
    border-radius: 0;
    padding: 0;
    font-weight: 400;
    color: inherit;
    font-size: inherit;
    font-family: inherit;
    line-height: inherit;
}

.prose img,
.rich-content img {
    margin-top: 2em;
    margin-bottom: 2em;
    max-width: 100%;
    height: auto;
    border-radius: 0.375rem;
}

.prose hr,
.rich-content hr {
    border-color: #e5e7eb;
    border-top-width: 1px;
    margin-top: 3em;
    margin-bottom: 3em;
}

.prose table,
.rich-content table {
    width: 100%;
    table-layout: auto;
    text-align: left;
    margin-top: 2em;
    margin-bottom: 2em;
    font-size: 0.875em;
    line-height: 1.7142857;
}

.prose thead,
.rich-content thead {
    border-bottom-width: 1px;
    border-bottom-color: #d1d5db;
}

.prose thead th,
.rich-content thead th {
    color: #111827;
    font-weight: 600;
    vertical-align: bottom;
    padding-right: 0.5714286em;
    padding-bottom: 0.5714286em;
    padding-left: 0.5714286em;
}

.prose tbody tr,
.rich-content tbody tr {
    border-bottom-width: 1px;
    border-bottom-color: #e5e7eb;
}

.prose tbody td,
.rich-content tbody td {
    vertical-align: baseline;
    padding-top: 0.5714286em;
    padding-right: 0.5714286em;
    padding-bottom: 0.5714286em;
    padding-left: 0.5714286em;
}

/* RTL adjustments for rich content */
[dir="rtl"] .prose ul,
[dir="rtl"] .prose ol,
[dir="rtl"] .rich-content ul,
[dir="rtl"] .rich-content ol {
    padding-left: 0;
    padding-right: 1.625em;
}

[dir="rtl"] .prose blockquote,
[dir="rtl"] .rich-content blockquote {
    border-left-width: 0;
    border-right-width: 0.25rem;
    border-right-color: #e5e7eb;
    padding-left: 0;
    padding-right: 1em;
}

/* Mobile Header Improvements */
@media (max-width: 640px) {
    /* Sticky header adjustments */
    header.sticky {
        top: 0;
    }
    
    /* Prevent body scroll when mobile menu is open */
    body.mobile-menu-open {
        overflow: hidden;
    }
    
    /* Mobile menu sidebar scroll */
    .mobile-menu-sidebar {
        -webkit-overflow-scrolling: touch;
    }
}

/* Mobile Menu Sidebar Styles */
.mobile-menu-sidebar {
    max-height: 100vh;
    overflow-y: auto;
}

/* Better touch targets for mobile */
@media (max-width: 1024px) {
    nav button,
    nav a {
        min-height: 44px;
        min-width: 44px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
    }
}

/* Prevent horizontal scroll on mobile */
@media (max-width: 640px) {
    body {
        overflow-x: hidden;
    }
    
    /* Ensure images don't overflow */
    img {
        max-width: 100%;
        height: auto;
    }
}

/* Smooth transitions for mobile menu */
@media (prefers-reduced-motion: no-preference) {
    .mobile-menu-sidebar {
        transition: transform 0.3s ease-in-out;
    }
}

/* RTL Mobile Menu Adjustments */
[dir="rtl"] .mobile-menu-sidebar {
    left: auto !important;
    right: 0 !important;
}

/* Ensure text alignment in mobile menu */
.mobile-menu-content {
    text-align: inherit;
}

/* LTR specific adjustments */
[dir="ltr"] .mobile-menu-content {
    text-align: left;
}

/* RTL specific adjustments */
[dir="rtl"] .mobile-menu-content {
    text-align: right;
}

/* Force text alignment in mobile navigation */
nav[dir="ltr"] button {
    text-align: left !important;
}

nav[dir="ltr"] a {
    text-align: left !important;
}

nav[dir="rtl"] button {
    text-align: right !important;
}

nav[dir="rtl"] a {
    text-align: right !important;
}

/* Rich editor text colors - spans have inline --color and --dark-color from Filament RichContentRenderer */
.prose .color,
.rich-content .color {
    color: var(--color);
}

@media (prefers-color-scheme: dark) {
    .prose .color,
    .rich-content .color {
        color: var(--dark-color);
    }
}

.dark .prose .color,
.dark .rich-content .color {
    color: var(--dark-color);
}

/* FacultyStaffBlock - full card styles when rendered inside rich editor */
.prose .faculty-staff-block,
.rich-content .faculty-staff-block {
    font-size: inherit;
    line-height: inherit;
}

.prose .faculty-staff-block .grid,
.rich-content .faculty-staff-block .grid {
    display: grid;
    grid-template-columns: repeat(1, minmax(0, 1fr));
    gap: 1.5rem;
}

@media (min-width: 768px) {
    .prose .faculty-staff-block .grid,
    .rich-content .faculty-staff-block .grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (min-width: 1024px) {
    .prose .faculty-staff-block .grid,
    .rich-content .faculty-staff-block .grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

.prose .faculty-staff-block [id^="member-"],
.rich-content .faculty-staff-block [id^="member-"] {
    background-color: #f9fafb;
    border-radius: 0.5rem;
    padding: 1.5rem;
    transition: box-shadow 0.2s;
}

.prose .faculty-staff-block [id^="member-"]:hover,
.rich-content .faculty-staff-block [id^="member-"]:hover {
    box-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
}

.prose .faculty-staff-block [id^="member-"] img,
.rich-content .faculty-staff-block [id^="member-"] img {
    width: 100%;
    height: 16rem;
    object-fit: cover;
    border-radius: 0.5rem;
    margin-top: 0;
    margin-bottom: 1rem;
}

.prose .faculty-staff-block [id^="member-"] .flex,
.rich-content .faculty-staff-block [id^="member-"] .flex {
    width: 100%;
    height: 16rem;
    background-color: #e5e7eb;
    border-radius: 0.5rem;
    margin-bottom: 1rem;
    display: flex;
    align-items: center;
    justify-content: center;
}

.prose .faculty-staff-block [id^="member-"] .flex span,
.rich-content .faculty-staff-block [id^="member-"] .flex span {
    color: #9ca3af;
    font-size: 2.25rem;
}

.prose .faculty-staff-block h3,
.rich-content .faculty-staff-block h3 {
    font-size: 1.25rem;
    font-weight: 600;
    color: #111827;
    margin-top: 0;
    margin-bottom: 0.25rem;
}

.prose .faculty-staff-block p,
.rich-content .faculty-staff-block p {
    margin-top: 0;
    margin-bottom: 0;
    font-size: 0.875rem;
    color: #4b5563;
}

.prose .faculty-staff-block .text-primary,
.rich-content .faculty-staff-block .text-primary {
    color: var(--color-primary, #19367b);
}

.prose .faculty-staff-block a,
.rich-content .faculty-staff-block a {
    color: var(--color-primary, #19367b);
    text-decoration: none;
}

.prose .faculty-staff-block a:hover,
.rich-content .faculty-staff-block a:hover {
    text-decoration: underline;
}

.prose .faculty-staff-block h3 a,
.rich-content .faculty-staff-block h3 a {
    color: #111827;
}

.prose .faculty-staff-block h3 a:hover,
.rich-content .faculty-staff-block h3 a:hover {
    color: var(--color-primary, #19367b);
}

.prose .faculty-staff-block .mb-1,
.rich-content .faculty-staff-block .mb-1 { margin-bottom: 0.25rem; }
.prose .faculty-staff-block .mb-2,
.rich-content .faculty-staff-block .mb-2 { margin-bottom: 0.5rem; }
.prose .faculty-staff-block .mb-3,
.rich-content .faculty-staff-block .mb-3 { margin-bottom: 0.75rem; }
.prose .faculty-staff-block .mb-4,
.rich-content .faculty-staff-block .mb-4 { margin-bottom: 1rem; }
.prose .faculty-staff-block .mb-6,
.rich-content .faculty-staff-block .mb-6 { margin-bottom: 1.5rem; }

/* Accordion block */
.prose .accordion-block summary::-webkit-details-marker,
.rich-content .accordion-block summary::-webkit-details-marker {
    display: none;
}
.prose .accordion-block summary,
.rich-content .accordion-block summary {
    list-style: none;
}
.prose .accordion-block details[open] .accordion-icon,
.rich-content .accordion-block details[open] .accordion-icon {
    transform: rotate(180deg);
}
.prose .accordion-block details[open] .accordion-trigger,
.rich-content .accordion-block details[open] .accordion-trigger {
    background-color: var(--color-primary-50, #eff6ff);
    color: var(--color-primary-700, #1d4ed8);
    border-left: 3px solid var(--color-primary, #19367b);
}
