:root { --navy: #0d2845; --green: #0f5f3f; --gold: #c89b3c; --ink: #182331; --muted: #607081; --line: #dfe6ec; --soft: #f3f7f6; --white: #ffffff; --shadow: 0 20px 50px rgba(13, 40, 69, .12); }
* { box-sizing: border-box; } html { scroll-behavior: smooth; } body { margin: 0; color: var(--ink); background: var(--white); font-family: "Cairo", "Tajawal", "Noto Kufi Arabic", "Segoe UI", Tahoma, Arial, sans-serif; line-height: 1.7; font-weight: 400; } html[lang="en"] body { font-family: Inter, "Segoe UI", Arial, sans-serif; } a { color: inherit; text-decoration: none; }
.site-header { position: sticky; top: 0; z-index: 10; display: grid; grid-template-columns: auto 1fr auto auto; align-items: center; gap: 18px; padding: 14px clamp(18px, 4vw, 56px); background: rgba(255,255,255,.96); border-bottom: 1px solid var(--line); backdrop-filter: blur(16px); }
.brand { display: inline-flex; align-items: center; gap: 12px; direction: ltr; } .brand-mark { display: grid; width: 46px; height: 46px; place-items: center; color: var(--white); background: var(--navy); border-radius: 8px; font-weight: 800; } .brand strong, .brand small { display: block; } .brand small { color: var(--muted); font-size: .84rem; }
.main-nav { display: flex; align-items: center; justify-content: center; gap: clamp(10px, 1.7vw, 20px); color: var(--navy); font-size: .94rem; font-weight: 700; } .main-nav a:hover { color: var(--gold); }
.language-switch { display: inline-flex; padding: 4px; border: 1px solid var(--line); border-radius: 8px; background: #f8fafb; direction: ltr; } .lang-btn { min-height: 36px; padding: 6px 12px; color: var(--navy); background: transparent; border: 0; border-radius: 6px; font: inherit; font-weight: 800; cursor: pointer; } .lang-btn.is-active { color: var(--white); background: var(--green); }
.nav-toggle { display: none; width: 44px; height: 44px; padding: 10px; background: var(--white); border: 1px solid var(--line); border-radius: 8px; } .nav-toggle span { display: block; height: 2px; margin: 5px 0; background: var(--navy); }
.section-pad { padding: clamp(64px, 9vw, 112px) clamp(18px, 5vw, 72px); } .section-pad.compact { padding-block: clamp(32px, 5vw, 58px); }
.hero { position: relative; display: grid; grid-template-columns: minmax(0, 1.1fr) minmax(280px, .9fr); gap: clamp(30px, 6vw, 72px); align-items: center; min-height: calc(100vh - 76px); overflow: hidden; color: var(--white); background: radial-gradient(circle at 20% 20%, rgba(200,137,45,.20), transparent 28%), linear-gradient(135deg, var(--navy), var(--green)); } .hero::before, .hero::after { content: ""; position: absolute; border-radius: 999px; border: 1px solid rgba(255,255,255,.14); pointer-events: none; } .hero::before { width: 420px; height: 420px; inset-inline-end: -120px; top: 90px; } .hero::after { width: 260px; height: 260px; inset-inline-start: -90px; bottom: 30px; } .hero-content, .hero-visual { position: relative; z-index: 1; }
.eyebrow { margin: 0 0 10px; color: var(--gold); font-size: .82rem; font-weight: 800; letter-spacing: 0; text-transform: uppercase; } .hero h1, .section-head h2, .about-grid h2 { margin: 0; color: inherit; font-size: clamp(2.2rem, 5.2vw, 5rem); line-height: 1.1; } .lead { max-width: 820px; margin: 22px 0 14px; color: #eef5f4; font-size: clamp(1.05rem, 1.6vw, 1.28rem); } .trust-line { max-width: 780px; margin: 18px 0 0; padding-inline-start: 18px; color: #f4dfbd; border-inline-start: 4px solid var(--gold); font-weight: 700; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 32px; } .btn { display: inline-flex; align-items: center; justify-content: center; min-height: 50px; padding: 12px 20px; border: 1px solid transparent; border-radius: 8px; font-weight: 800; cursor: pointer; } .btn.primary { color: var(--white); background: var(--gold); } .btn.secondary { color: var(--white); border-color: rgba(255,255,255,.46); }
.hero-visual { min-height: 360px; display: grid; place-items: center; } .route-shape { width: min(72vw, 360px); height: min(72vw, 360px); border: 2px dashed rgba(255,255,255,.34); border-radius: 999px; display: grid; place-items: center; background: radial-gradient(circle, rgba(255,255,255,.12), rgba(255,255,255,.03) 58%, transparent 59%); } .route-shape span { width: 58%; height: 58%; border-radius: inherit; background: linear-gradient(135deg, rgba(255,255,255,.18), rgba(200,137,45,.2)); box-shadow: inset 0 0 0 1px rgba(255,255,255,.18); } .orbit-card { position: absolute; display: flex; align-items: center; gap: 10px; min-width: 172px; padding: 14px 16px; color: var(--navy); background: rgba(255,255,255,.94); border: 1px solid rgba(255,255,255,.62); border-radius: 8px; box-shadow: var(--shadow); direction: ltr; } .orbit-card.top { top: 34px; inset-inline-start: 8%; } .orbit-card.bottom { bottom: 34px; inset-inline-end: 8%; }
.icon, .mini-icon, .card-icon { display: inline-grid; place-items: center; color: var(--white); background: var(--green); border-radius: 8px; font-weight: 800; } .icon { width: 42px; height: 42px; }
.trust-strip { background: #f8fafb; } .trust-grid { display: grid; grid-template-columns: repeat(6, minmax(0, 1fr)); gap: 14px; } .trust-grid article { display: flex; align-items: center; gap: 10px; min-height: 96px; padding: 16px; background: var(--white); border: 1px solid var(--line); border-radius: 8px; box-shadow: 0 10px 26px rgba(13,40,69,.05); } .mini-icon { flex: 0 0 34px; width: 34px; height: 34px; background: var(--navy); font-size: .82rem; }
.section-head { max-width: 820px; margin: 0 auto 34px; text-align: center; } .section-head h2, .about-grid h2 { color: var(--navy); font-size: clamp(2rem, 4vw, 3.5rem); } .section-head p { margin: 12px auto 0; color: var(--muted); font-size: 1.05rem; }
.grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 18px; } .cards article { min-height: 230px; padding: 24px; background: var(--white); border: 1px solid var(--line); border-radius: 8px; box-shadow: 0 10px 28px rgba(13,40,69,.06); } .card-icon { width: 38px; height: 38px; margin-bottom: 16px; background: var(--navy); font-size: .82rem; } .cards h3 { margin: 0 0 12px; color: var(--green); font-size: 1.03rem; } .cards p { margin: 0; color: var(--muted); }
.soft-section { background: var(--soft); } .source-list { display: flex; flex-wrap: wrap; justify-content: center; gap: 12px; max-width: 1050px; margin: 0 auto; } .source-list span { padding: 12px 16px; color: var(--navy); background: var(--white); border: 1px solid var(--line); border-radius: 8px; font-weight: 700; }
.steps { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; max-width: 1100px; margin: 0 auto; padding: 0; list-style: none; counter-reset: steps; } .steps li { min-height: 180px; padding: 26px; background: var(--white); border: 1px solid var(--line); border-radius: 8px; counter-increment: steps; } .steps li::before { content: counter(steps); display: grid; width: 42px; height: 42px; margin-bottom: 18px; place-items: center; color: var(--white); background: var(--green); border-radius: 8px; font-weight: 800; } .steps strong, .steps span { display: block; } .steps strong { color: var(--navy); } .steps span { color: var(--muted); }
.quote-section { background: #f8fafb; } .quote-form { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; max-width: 960px; margin: 0 auto; padding: clamp(20px, 4vw, 34px); background: var(--white); border: 1px solid var(--line); border-radius: 8px; box-shadow: var(--shadow); } .quote-form label { display: grid; gap: 7px; color: var(--navy); font-weight: 800; } .quote-form input, .quote-form select, .quote-form textarea { width: 100%; padding: 13px 14px; color: var(--ink); background: var(--white); border: 1px solid #cfd9e2; border-radius: 8px; font: inherit; } .quote-form input:focus, .quote-form select:focus, .quote-form textarea:focus { border-color: var(--gold); outline: 3px solid rgba(200,137,45,.18); } .wide { grid-column: 1 / -1; }
.about-grid { display: grid; grid-template-columns: minmax(0, .95fr) minmax(300px, 1.05fr); gap: clamp(26px, 5vw, 64px); align-items: start; } .about-grid p { max-width: 720px; color: var(--muted); font-size: 1.08rem; } .notes-card { padding: clamp(22px, 3vw, 34px); background: var(--navy); color: var(--white); border-radius: 8px; } .notes-card h3 { margin: 0 0 16px; font-size: 1.45rem; } .notes-card ul { margin: 0; padding: 0; list-style: none; } .notes-card li { padding: 12px 0; border-top: 1px solid rgba(255,255,255,.18); }
.contact-section { color: var(--white); background: var(--green); } .contact-section .section-head h2, .contact-section .section-head p { color: var(--white); } .contact-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 16px; direction: ltr; } .contact-grid a, .contact-grid div { min-height: 140px; padding: 22px; background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.2); border-radius: 8px; } .contact-grid strong, .contact-grid span { display: block; } .contact-grid strong { color: #f7d79d; }
.site-footer { padding: 24px clamp(18px, 4vw, 56px); color: #c9d3dc; background: #091d31; text-align: center; } .site-footer p { margin: 0; }
@media (max-width: 1180px) { .trust-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); } .grid, .contact-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } .hero, .about-grid { grid-template-columns: 1fr; } }
@media (max-width: 860px) { .site-header { grid-template-columns: auto auto auto; } .nav-toggle { display: block; order: 3; } .language-switch { order: 2; } .main-nav { position: absolute; inset: 74px 14px auto; display: none; flex-direction: column; align-items: stretch; padding: 14px; background: var(--white); border: 1px solid var(--line); border-radius: 8px; box-shadow: var(--shadow); } .main-nav.is-open { display: flex; } .main-nav a { padding: 10px; } .hero { min-height: auto; padding-top: 58px; } .steps, .quote-form { grid-template-columns: 1fr; } }
@media (max-width: 620px) { .site-header { padding-inline: 14px; gap: 10px; } .brand small { display: none; } .brand-mark { width: 42px; height: 42px; } .lang-btn { padding-inline: 9px; } .grid, .contact-grid, .trust-grid { grid-template-columns: 1fr; } .hero-actions .btn { width: 100%; } .hero-visual { min-height: 260px; } .orbit-card { min-width: 145px; } }

.legal-banner { background: #fff8ec; }
.notice-card { max-width: 1100px; margin: 0 auto; padding: clamp(20px, 3vw, 30px); color: var(--navy); background: var(--white); border: 1px solid rgba(200, 155, 60, .38); border-inline-start: 6px solid var(--gold); border-radius: 8px; box-shadow: 0 12px 30px rgba(13, 40, 69, .07); }
.notice-card strong { display: block; margin-bottom: 8px; color: var(--green); font-size: 1.15rem; }
.notice-card p { margin: 0; color: var(--muted); }
.nine-steps { grid-template-columns: repeat(3, minmax(0, 1fr)); }
@media (max-width: 860px) { .nine-steps { grid-template-columns: 1fr; } }

.footer-links { display: flex; justify-content: center; align-items: center; gap: 10px; margin-top: 10px; color: #f7d79d; direction: ltr; font-weight: 700; }
.footer-links a:hover { color: var(--white); }
.legal-page { background: #f8fafb; }
.legal-content { max-width: 900px; margin: 0 auto; padding: clamp(24px, 4vw, 42px); background: var(--white); border: 1px solid var(--line); border-radius: 8px; box-shadow: var(--shadow); }
.legal-content h1 { margin: 0; color: var(--navy); font-size: clamp(2rem, 4vw, 3.6rem); line-height: 1.15; }
.legal-updated { margin: 10px 0 24px; color: var(--muted); font-weight: 700; }
.legal-content ul { margin: 0; padding-inline-start: 24px; color: var(--ink); }
.legal-content li { margin: 0 0 14px; }
.legal-contact { margin: 24px 0 0; color: var(--muted); font-weight: 700; }
.legal-contact a { color: var(--green); }
.legal-nav { justify-content: flex-end; }
html[dir="ltr"] .legal-nav { justify-content: flex-start; }
@media (max-width: 860px) { .legal-nav { display: flex; position: static; grid-column: 1 / -1; box-shadow: none; border: 0; padding: 0; background: transparent; flex-direction: row; flex-wrap: wrap; } }
