/* =============================================
   Hirafi Platform — Modern Craft Aesthetic
   ============================================= */

/* ===== Khalid Art Bold — Arabic Display Font ===== */
@font-face {
    font-family: 'Khalid Art';
    src: url('../fonts/KhalidArtBold.woff2') format('woff2'),
         url('../fonts/KhalidArtBold.woff') format('woff'),
         url('../fonts/KhalidArtBold.ttf') format('truetype');
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Khalid Art';
    src: url('../fonts/KhalidArt.woff2') format('woff2'),
         url('../fonts/KhalidArt.woff') format('woff'),
         url('../fonts/KhalidArt.ttf') format('truetype');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

:root {
    --navy: #0c1929;
    --navy-light: #152238;
    --navy-mid: #1e3351;
    --slate: #334155;
    --amber: #f59e0b;
    --amber-hover: #d97706;
    --amber-light: #fef3c7;
    --amber-glow: rgba(245, 158, 11, 0.15);
    --emerald: #10b981;
    --rose: #f43f5e;
    --sky: #0ea5e9;
    --text: #1e293b;
    --text-muted: #64748b;
    --text-light: #94a3b8;
    --bg: #f8fafc;
    --bg-warm: #faf8f5;
    --card: #ffffff;
    --border: #e2e8f0;
    --border-light: #f1f5f9;
    --radius: 14px;
    --radius-sm: 8px;
    --radius-lg: 20px;
    --shadow-sm: 0 1px 2px rgba(0,0,0,.04);
    --shadow: 0 1px 3px rgba(0,0,0,.06), 0 6px 16px rgba(0,0,0,.04);
    --shadow-lg: 0 8px 30px rgba(0,0,0,.08);
    --shadow-glow: 0 0 40px rgba(245,158,11,.1);
    --transition: all .25s cubic-bezier(.4,0,.2,1);
    --font-ar: 'Khalid Art', 'Noto Kufi Arabic', 'Tajawal', sans-serif;
    --font-ar-body: 'Noto Kufi Arabic', 'Tajawal', sans-serif;
    --font-en: 'DM Sans', sans-serif;
    --font-mono: 'JetBrains Mono', monospace;
}

/* ===== Base ===== */
*, *::before, *::after { box-sizing: border-box; }

body {
    background: var(--bg);
    color: var(--text);
    line-height: 1.7;
    -webkit-font-smoothing: antialiased;
}

.lang-ar body, .lang-ar { font-family: var(--font-ar-body); }
.lang-en body, .lang-en { font-family: var(--font-en); }

/* Khalid Art Bold for Arabic headings, brand, and display text */
.lang-ar h1, .lang-ar h2, .lang-ar h3, .lang-ar h4, .lang-ar h5, .lang-ar h6,
.lang-ar .fw-bold, .lang-ar .fw-bolder,
.lang-ar .section-title, .lang-ar .brand-text,
.lang-ar .hero h1, .lang-ar .hero .highlight,
.lang-ar .stat-number, .lang-ar .step-heading,
.lang-ar .navbar-brand, .lang-ar .footer-brand,
.lang-ar .auth-card h4, .lang-ar .card-provider h6,
.lang-ar .category-card h6, .lang-ar .btn-cta,
.lang-ar .btn-amber, .lang-ar .btn-navy,
.lang-ar .cta-section h3 {
    font-family: var(--font-ar);
    font-weight: 700;
}

/* Ensure Arabic body text stays readable */
.lang-ar p, .lang-ar span, .lang-ar label, .lang-ar li,
.lang-ar .form-control, .lang-ar .form-select,
.lang-ar .dropdown-item, .lang-ar .nav-link,
.lang-ar .text-muted, .lang-ar small, .lang-ar .small,
.lang-ar td, .lang-ar th,
.lang-ar .alert, .lang-ar .badge {
    font-family: var(--font-ar-body);
}

/* Khalid Art fine-tuning — Arabic display text adjustments */
.lang-ar h1 { font-size: 3rem; line-height: 1.3; letter-spacing: 0; }
.lang-ar h2 { font-size: 1.9rem; line-height: 1.35; }
.lang-ar h3 { font-size: 1.5rem; line-height: 1.4; }
.lang-ar h4 { font-size: 1.25rem; line-height: 1.4; }
.lang-ar h5 { font-size: 1.1rem; line-height: 1.45; }
.lang-ar h6 { font-size: .95rem; line-height: 1.5; }
.lang-ar .hero h1 { font-size: 3.2rem; line-height: 1.25; }
.lang-ar .hero .highlight { font-size: 3.2rem; line-height: 1.25; }
.lang-ar .section-title { font-size: 2rem; line-height: 1.3; }
.lang-ar .brand-text { font-size: 1.4rem; letter-spacing: 0; }
.lang-ar .stat-number { letter-spacing: 0; }
.lang-ar .btn { letter-spacing: 0; }
.lang-ar .category-card h6 { font-size: .9rem; line-height: 1.5; }
.lang-ar .footer-brand { font-size: 1.4rem; }
.lang-ar .step-number { font-family: var(--font-en); }
@media (max-width: 768px) {
    .lang-ar h1 { font-size: 2rem; }
    .lang-ar .hero h1, .lang-ar .hero .highlight { font-size: 2rem; }
    .lang-ar .section-title { font-size: 1.5rem; }
}

a { color: var(--navy-mid); text-decoration: none; transition: var(--transition); }
a:hover { color: var(--amber); }

::selection { background: var(--amber-light); color: var(--navy); }

/* ===== Navbar ===== */
.hirafi-nav {
    background: rgba(12, 25, 41, .97);
    backdrop-filter: blur(20px) saturate(1.4);
    border-bottom: 1px solid rgba(255,255,255,.06);
    padding: .6rem 0;
    z-index: 1050;
}

.navbar-brand {
    display: flex; align-items: center; gap: 10px;
    text-decoration: none !important;
}

.brand-icon {
    width: 38px; height: 38px; border-radius: 10px;
    background: linear-gradient(135deg, var(--amber), var(--amber-hover));
    display: flex; align-items: center; justify-content: center;
    color: var(--navy); font-size: 1rem;
    box-shadow: 0 2px 12px rgba(245,158,11,.3);
}

.brand-text {
    font-size: 1.3rem; font-weight: 700; color: #fff;
    letter-spacing: -.5px;
}

.nav-links .nav-link {
    color: rgba(255,255,255,.7); font-weight: 500; font-size: .9rem;
    padding: .5rem 1rem !important; border-radius: var(--radius-sm);
    transition: var(--transition);
}
.nav-links .nav-link:hover, .nav-links .nav-link.active {
    color: #fff; background: rgba(255,255,255,.08);
}

.nav-actions { gap: 6px; align-items: center; }
.nav-actions .nav-link { color: rgba(255,255,255,.7); }
.nav-actions .nav-link:hover { color: #fff; }

.btn-cta {
    background: linear-gradient(135deg, var(--amber), var(--amber-hover));
    color: var(--navy) !important; font-weight: 600; font-size: .85rem;
    padding: .45rem 1.2rem; border-radius: 50px; border: none;
    transition: var(--transition);
}
.btn-cta:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 18px rgba(245,158,11,.35);
    color: var(--navy) !important;
}

/* Language Switcher */
.lang-switch { display: flex; align-items: center; gap: 6px; font-size: .85rem; cursor: pointer; }
.lang-label { color: rgba(255,255,255,.8); }
.lang-dropdown { min-width: 140px; border-radius: var(--radius-sm); }
.lang-dropdown .dropdown-item { display: flex; align-items: center; gap: 8px; font-size: .9rem; padding: .5rem 1rem; }
.lang-dropdown .dropdown-item.active { background: var(--amber-light); color: var(--navy); }
.lang-flag { font-size: 1.2rem; }

/* User Menu */
.user-menu-toggle { display: flex; align-items: center; gap: 8px; }
.user-avatar { width: 32px; height: 32px; border-radius: 50%; object-fit: cover; border: 2px solid rgba(255,255,255,.2); }
.user-avatar-placeholder {
    width: 32px; height: 32px; border-radius: 50%;
    background: linear-gradient(135deg, var(--amber), var(--amber-hover));
    display: flex; align-items: center; justify-content: center;
    color: var(--navy); font-weight: 700; font-size: .8rem;
}
.user-name { color: rgba(255,255,255,.85); font-size: .85rem; font-weight: 500; }
.notif-badge {
    position: absolute; top: 2px;
    font-size: .55rem; background: var(--rose); color: #fff;
    padding: 1px 5px; border-radius: 50px; font-weight: 700;
}
[dir="rtl"] .notif-badge { right: auto; left: 0; }
[dir="ltr"] .notif-badge { left: auto; right: 0; }

.navbar-toggler { border: 1px solid rgba(255,255,255,.15); padding: .35rem .6rem; }
.navbar-toggler-icon { filter: invert(1); width: 1.2em; height: 1.2em; }

/* ===== Hero ===== */
.hero {
    background: var(--navy);
    position: relative; overflow: hidden;
    padding: 5rem 0 4rem;
}

.hero::before {
    content: ''; position: absolute; inset: 0;
    background:
        radial-gradient(ellipse 80% 60% at 20% 80%, rgba(245,158,11,.06) 0%, transparent 60%),
        radial-gradient(ellipse 60% 50% at 80% 20%, rgba(14,165,233,.04) 0%, transparent 50%);
    pointer-events: none;
}

.hero-pattern {
    position: absolute; inset: 0; opacity: .03;
    background-image: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23ffffff' fill-opacity='1'%3E%3Cpath d='M30 0L60 30L30 60L0 30z' fill='none' stroke='%23fff' stroke-width='.5'/%3E%3C/g%3E%3C/svg%3E");
    pointer-events: none;
}

.hero h1 { font-size: 3rem; font-weight: 700; color: #fff; line-height: 1.2; letter-spacing: -.5px; }
.hero .highlight { color: var(--amber); display: block; }
.hero .subtitle { color: var(--text-light); font-size: 1.1rem; margin-top: .75rem; }

.search-box {
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.1);
    border-radius: var(--radius-lg); padding: 1.5rem;
    backdrop-filter: blur(12px); margin-top: 2rem;
}
.search-box .form-control, .search-box .form-select {
    border: none; border-radius: var(--radius-sm); padding: .75rem 1rem;
    font-size: .9rem; background: rgba(255,255,255,.95);
}
.btn-search {
    background: linear-gradient(135deg, var(--amber), var(--amber-hover));
    color: var(--navy); border: none; border-radius: var(--radius-sm);
    padding: .75rem 2rem; font-weight: 700; font-size: .95rem;
    transition: var(--transition);
}
.btn-search:hover {
    transform: translateY(-1px); box-shadow: 0 6px 20px rgba(245,158,11,.3);
    color: var(--navy);
}

.hero-badges { display: flex; gap: 1.5rem; flex-wrap: wrap; margin-top: 1.5rem; }
.hero-badges span { color: rgba(255,255,255,.6); font-size: .85rem; display: flex; align-items: center; gap: 6px; }
.hero-badges .fa-check-circle { color: var(--amber); }

/* ===== Cards ===== */
.card {
    border: 1px solid var(--border);
    border-radius: var(--radius);
    background: var(--card);
    box-shadow: var(--shadow-sm);
    transition: var(--transition);
    overflow: hidden;
}
.card:hover { box-shadow: var(--shadow); transform: translateY(-2px); }

/* Provider Card */
.card-provider .provider-avatar {
    width: 64px; height: 64px; border-radius: 50%; object-fit: cover;
    border: 3px solid var(--card); box-shadow: var(--shadow);
}
.provider-avatar-placeholder {
    width: 64px; height: 64px; border-radius: 50%;
    background: linear-gradient(135deg, var(--navy), var(--navy-mid));
    display: flex; align-items: center; justify-content: center;
    color: #fff; font-size: 1.5rem; font-weight: 700;
    border: 3px solid var(--card); box-shadow: var(--shadow);
}

.verified-badge {
    display: inline-flex; align-items: center; gap: 4px;
    background: #eff6ff; color: var(--sky); font-size: .7rem; font-weight: 600;
    padding: 3px 10px; border-radius: 50px;
}

/* Category Cards */
.category-card {
    text-align: center; padding: 1.5rem 1rem;
    border-radius: var(--radius); background: var(--card);
    border: 1px solid var(--border); transition: var(--transition); cursor: pointer;
    position: relative; overflow: hidden;
}
.category-card::after {
    content: ''; position: absolute; bottom: 0; left: 0; right: 0;
    height: 3px; background: linear-gradient(90deg, var(--amber), var(--amber-hover));
    transform: scaleX(0); transition: transform .3s ease;
}
.category-card:hover { border-color: var(--amber); box-shadow: var(--shadow-lg); transform: translateY(-4px); }
.category-card:hover::after { transform: scaleX(1); }

.category-card .icon {
    width: 52px; height: 52px; border-radius: 14px;
    background: linear-gradient(135deg, var(--navy), var(--navy-mid));
    display: flex; align-items: center; justify-content: center;
    margin: 0 auto .75rem; color: #fff; font-size: 1.2rem;
    transition: var(--transition);
}
.category-card:hover .icon {
    background: linear-gradient(135deg, var(--amber), var(--amber-hover));
    transform: scale(1.08) rotate(-3deg);
}

/* ===== Buttons ===== */
.btn-accent {
    background: linear-gradient(135deg, var(--amber), var(--amber-hover));
    border: none; color: var(--navy); font-weight: 600;
    border-radius: var(--radius-sm); transition: var(--transition);
}
.btn-accent:hover {
    transform: translateY(-1px); color: var(--navy);
    box-shadow: 0 4px 16px rgba(245,158,11,.3);
}

.btn-primary { background: var(--navy); border-color: var(--navy); }
.btn-primary:hover { background: var(--navy-mid); border-color: var(--navy-mid); }

/* ===== Section Titles ===== */
.section-title {
    font-size: 1.8rem; font-weight: 700; color: var(--navy); letter-spacing: -.5px;
}
.section-subtitle { color: var(--text-muted); font-size: 1rem; }

/* ===== Stars ===== */
.star-rating { direction: ltr; display: inline-flex; align-items: center; gap: 1px; }
.star-rating .fa-star, .star-rating .fa-star-half-alt { font-size: .8rem; color: var(--amber); }
.star-rating .far.fa-star { color: #d1d5db; }
.rating-number { font-size: .75rem; color: var(--text-muted); }
[dir="rtl"] .rating-number { margin-right: 4px; }
[dir="ltr"] .rating-number { margin-left: 4px; }

/* ===== How It Works ===== */
.step-card { text-align: center; padding: 2rem 1.5rem; }
.step-number {
    width: 52px; height: 52px; border-radius: 50%;
    background: linear-gradient(135deg, var(--amber), var(--amber-hover));
    color: var(--navy); display: flex; align-items: center; justify-content: center;
    font-size: 1.3rem; font-weight: 800; margin: 0 auto 1rem;
    box-shadow: 0 4px 16px rgba(245,158,11,.25);
}

/* ===== Stats ===== */
.stat-card {
    background: var(--card); border-radius: var(--radius); padding: 1.5rem;
    border: 1px solid var(--border); text-align: center;
}
.stat-card .stat-number { font-size: 2rem; font-weight: 800; color: var(--navy); line-height: 1; }
.stat-card .stat-label { font-size: .8rem; color: var(--text-muted); margin-top: .4rem; font-weight: 500; }

/* ===== Badges ===== */
.badge-warning  { background: var(--amber-light); color: #92400e; font-weight: 600; }
.badge-info     { background: #dbeafe; color: #1e40af; font-weight: 600; }
.badge-primary  { background: #e0e7ff; color: #3730a3; font-weight: 600; }
.badge-success  { background: #d1fae5; color: #065f46; font-weight: 600; }
.badge-danger   { background: #fee2e2; color: #991b1b; font-weight: 600; }
.badge-secondary{ background: #f1f5f9; color: #475569; font-weight: 600; }

/* ===== Forms ===== */
.form-control, .form-select {
    border: 1.5px solid var(--border); border-radius: var(--radius-sm);
    padding: .65rem 1rem; transition: var(--transition); font-size: .9rem;
}
.form-control:focus, .form-select:focus {
    border-color: var(--amber); box-shadow: 0 0 0 3px var(--amber-glow);
}
.form-label { font-weight: 500; font-size: .9rem; color: var(--slate); }

/* ===== Auth Pages ===== */
.auth-container { max-width: 500px; margin: 3rem auto; }
.auth-card {
    background: var(--card); border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg); padding: 2.5rem; border: 1px solid var(--border);
}

/* ===== CTA Section ===== */
.cta-section {
    background: linear-gradient(135deg, var(--amber), var(--amber-hover));
    border-radius: var(--radius-lg); position: relative; overflow: hidden;
}
.cta-section::before {
    content: ''; position: absolute; inset: 0; opacity: .08;
    background-image: url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M20 0L40 20L20 40L0 20z' fill='none' stroke='%23000' stroke-width='.5'/%3E%3C/svg%3E");
}

/* ===== Footer ===== */
.hirafi-footer {
    background: var(--navy); color: rgba(255,255,255,.6);
    position: relative; margin-top: 4rem;
}
.footer-wave {
    height: 60px;
    background: var(--bg);
    border-radius: 0 0 50% 50% / 0 0 100% 100%;
    margin-bottom: -1px;
}
.footer-brand {
    display: flex; align-items: center; gap: 10px;
    margin-bottom: 1rem; font-size: 1.3rem; font-weight: 700; color: #fff;
}
.footer-about { font-size: .85rem; line-height: 1.8; opacity: .7; }
.social-links { display: flex; gap: 12px; margin-top: 1rem; }
.social-links a {
    width: 36px; height: 36px; border-radius: 50%;
    background: rgba(255,255,255,.08); display: flex; align-items: center; justify-content: center;
    color: rgba(255,255,255,.6); transition: var(--transition); font-size: .85rem;
}
.social-links a:hover { background: var(--amber); color: var(--navy); transform: translateY(-2px); }
.footer-heading { color: #fff; font-weight: 600; font-size: .9rem; margin-bottom: 1rem; }
.footer-nav { list-style: none; padding: 0; margin: 0; }
.footer-nav li { margin-bottom: .5rem; }
.footer-nav a { color: rgba(255,255,255,.5); font-size: .85rem; transition: var(--transition); }
.footer-nav a:hover { color: var(--amber); }
.footer-contact-list { list-style: none; padding: 0; margin: 0; }
.footer-contact-list li { margin-bottom: .6rem; font-size: .85rem; display: flex; align-items: center; gap: 8px; }
.footer-contact-list i { color: var(--amber); font-size: .75rem; width: 16px; text-align: center; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.06); padding-top: 1.5rem; text-align: center; }
.footer-bottom p { font-size: .8rem; opacity: .5; margin: 0; }

/* ===== Booking Card ===== */
.booking-card {
    border-radius: var(--radius); border: 1px solid var(--border);
    padding: 1.25rem; margin-bottom: .75rem; background: var(--card);
    transition: var(--transition);
}
.booking-card:hover { box-shadow: var(--shadow); }

/* ===== Dashboard ===== */
.dashboard-sidebar {
    background: var(--card); border-radius: var(--radius);
    border: 1px solid var(--border); padding: 1rem 0;
}
.dashboard-sidebar .nav-link {
    padding: .65rem 1.25rem; color: var(--text); font-weight: 500;
    transition: var(--transition); font-size: .9rem;
}
.dashboard-sidebar .nav-link:hover, .dashboard-sidebar .nav-link.active {
    background: var(--amber-light); color: var(--navy);
}
[dir="rtl"] .dashboard-sidebar .nav-link.active { border-right: 3px solid var(--amber); }
[dir="ltr"] .dashboard-sidebar .nav-link.active { border-left: 3px solid var(--amber); }
.dashboard-sidebar .nav-link i { width: 22px; text-align: center; }

/* ===== Portfolio ===== */
.portfolio-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 1rem; }
.portfolio-item { border-radius: var(--radius-sm); overflow: hidden; aspect-ratio: 1; position: relative; }
.portfolio-item img { width: 100%; height: 100%; object-fit: cover; transition: var(--transition); }
.portfolio-item:hover img { transform: scale(1.06); }

/* ===== Profile ===== */
.profile-header { background: var(--navy); padding: 3rem 0 2rem; color: #fff; }
.profile-tabs .nav-link {
    color: var(--text-muted); font-weight: 500; border: none; padding: .75rem 1.25rem; border-radius: var(--radius-sm);
}
.profile-tabs .nav-link.active { color: var(--navy); background: var(--amber-light); font-weight: 700; }

/* ===== Flash Alert ===== */
.flash-alert { border-radius: var(--radius-sm); font-size: .9rem; border: none; }

/* ===== Responsive ===== */
@media (max-width: 768px) {
    .hero h1 { font-size: 1.8rem; }
    .hero { padding: 3rem 0 2rem; }
    .section-title { font-size: 1.4rem; }
    .stat-card .stat-number { font-size: 1.5rem; }
    .category-card { padding: 1rem .75rem; }
    .category-card .icon { width: 42px; height: 42px; font-size: 1rem; }
}

/* ===== Animations ===== */
@keyframes fadeInUp {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
}
.animate-in { animation: fadeInUp .5s ease forwards; }

/* ===== Utility ===== */
.text-accent { color: var(--amber) !important; }
.bg-accent { background: var(--amber) !important; }
.truncate-2 { display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.empty-state { text-align: center; padding: 3rem 1.5rem; color: var(--text-muted); }
.empty-state i { font-size: 3rem; margin-bottom: 1rem; opacity: .2; }
