/* المسار: /css/style.css */
/* =============================
   IFCC v6.5 — Professional Edition
   ============================= */
:root {
  /* -- Colors for the new IFCC Identity -- */
  --bg: #FFFFFF;
  --text: #333333;
  --brand-primary: #680e36;        /* عنابي (أساسي) */
  --brand-secondary: #dca363;      /* ذهبي (ثانوي ومؤثرات) */
  
  /* -- Supporting Colors (can be managed from admin panel) -- */
  --success: #009933;
  --danger: #CC0000;
  
  /* -- Structural Variables -- */
  --white: #ffffff;
  --black: #000000;
  --bg-elev: #f9f9f9;
  --bg-soft: #fdfaf6; /* لون خلفية فاتح مستوحى من الذهبي */
  --muted: #64748b;
  
  --brand-primary-light: var(--brand-secondary); /* استخدام الذهبي للعناوين الفرعية */
  --brand-primary-dark: #4a0a26; /* درجة أغمق من العنابي */
  --button-primary: var(--brand-primary);
  --hover-gold: var(--brand-secondary);

  --accent: var(--brand-secondary);
  --ring: rgba(104, 14, 54, 0.2); /* شفافية من اللون العنابي */

  --radius: 16px; --radius-sm: 12px; --shadow:0 10px 30px rgba(104, 14, 54, .08); --shadow-lg:0 22px 60px rgba(104, 14, 54, .15);
  --max-w:1200px; --transition:.3s cubic-bezier(.2,.8,.2,1);
  
  /* -- Font Sizes (Adjusted for professionalism) -- */
  --h1:clamp(34px, 5vw, 50px); 
  --h2:clamp(26px, 3.5vw, 36px); 
  --h3:clamp(19px, 2.4vw, 24px); 
  --lead:clamp(17px, 1.8vw, 19px);

  --font-ar: 'Almarai', system-ui, sans-serif;
  --font-en: 'Poppins', system-ui, sans-serif;
}

:root[data-theme="dark"]{
  /* -- Dark Mode Colors (Simplified to White & Gold Palette) -- */
  --bg: #121212;
  --bg-elev: #1E1E1E;
  --bg-soft: #1a1a1a;
  --text: #FFFFFF;
  --muted: #a0a0a0;
  
  --brand-primary: #dca363; /* Gold as primary interactive color */
  --brand-secondary: #680e36; /* Lighter gold for highlights */
  
  --brand-primary-light: var(--brand-secondary);
  --brand-primary-dark: #dca363;
  --button-primary: var(--brand-primary);
  --hover-gold: #680e36;
  --accent: var(--brand-secondary);
  --ring: rgba(220, 163, 99, 0.2);

  --shadow: 0 10px 20px rgba(0,0,0,.25), 0 2px 5px rgba(0,0,0,.2);
  --shadow-lg: 0 20px 40px rgba(0,0,0,.35), 0 5px 15px rgba(0,0,0,.3);
}

/* Language Specific Styles */
:lang(ar) { font-family: var(--font-ar); }
:lang(en) { font-family: var(--font-en); }
h1,h2,h3,h4 { font-family: var(--font-en); }
:lang(ar) h1, :lang(ar) h2, :lang(ar) h3, :lang(ar) h4, :lang(ar) .btn, :lang(ar) .chip, :lang(ar) .pill, :lang(ar) .hero-subtitle { font-family: var(--font-ar); }

*,*:before,*:after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--text); transition: background .3s, color .3s;}
img{max-width:100%;height:auto;display:block}
a{color:var(--brand-primary);text-decoration:none;transition:var(--transition)}
a:hover{color:var(--hover-gold); text-shadow: 0 0 1px var(--hover-gold);}
.container{width:100%;max-width:var(--max-w);margin-inline:auto;padding-inline:24px}
h1,h2,h3,h4{margin:0 0 10px;font-weight:700;}
h1{font-size:var(--h1);line-height:1.2;color:var(--brand-primary); font-weight: 800;}
h2{font-size:var(--h2);color:var(--brand-primary)}
h3{font-size:var(--h3);color:var(--brand-primary-light)}
.lead{font-size:var(--lead);color:var(--muted);line-height:1.8;max-width: 680px; margin-inline: auto;}
p{line-height: 1.8; color: var(--muted);}

.progress{position:fixed;inset-inline:0;top:0;height:4px;background:linear-gradient(90deg,var(--hover-gold),var(--brand-primary));transform-origin:0 50%;transform:scaleX(0);z-index:2000}
.cursor-blob{position:fixed;inset:0;pointer-events:none;z-index:1; display: none;}
@media (pointer: fine) { .cursor-blob { display: block; } }
.blob{position:absolute;width:220px;height:220px;border-radius:50%;filter:blur(40px);opacity:.22;background:radial-gradient(circle at 30% 30%,var(--brand-primary),transparent 60%)}

.topbar{position:sticky;top:0;z-index:1000;backdrop-filter:blur(14px) saturate(140%);-webkit-backdrop-filter:blur(14px) saturate(140%);background:color-mix(in oklab,var(--bg) 85%,transparent);border-bottom:1px solid color-mix(in oklab,var(--text) 12%,transparent)}
.nav{display:flex;align-items:center;gap:16px;min-height:84px}
.brand{display:flex;align-items:center;gap:12px;font-weight:800}

.logo-container { position: relative; }
.logo { 
  width: 52px; height: 52px; border-radius: 50%; 
  display: grid; place-items: center; 
  color: var(--brand-primary); 
  background: var(--white); 
  box-shadow: 0 0 0 4px var(--bg), 0 0 0 5px color-mix(in oklab,var(--text) 12%,transparent);
  font-size: 26px; 
  overflow: hidden; 
  transition: var(--transition);
}
:root[data-theme="dark"] .logo { background: var(--bg-elev); }
.logo:hover {
  transform: scale(1.05) rotate(5deg);
  box-shadow: 0 0 0 4px var(--bg), 0 0 0 5px var(--brand-primary);
}
.logo img { width: 100%; height: 100%; object-fit: cover; }

.name{font-size:24px;color:var(--brand-primary)}
.navlinks{margin-inline:auto;display:flex;gap:4px}
.navlinks>li{list-style:none;position:relative}
.navlinks>li>a{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border-radius:10px;color:var(--text);font-weight:700;font-size: 15px;}
.navlinks>li>a:hover, .navlinks>li>a.active{background:var(--bg-elev); color: var(--brand-primary);}

.dropdown-menu{
    position:absolute;
    inset-inline-start: 50%;
    transform: translateX(-50%);
    top:calc(100% + 10px);
    width: max-content;
    min-width: 200px;
    background:var(--bg);
    border:1px solid color-mix(in oklab,var(--text) 10%,transparent);
    border-radius:14px;
    box-shadow:var(--shadow);
    padding:8px;
    opacity:0;
    visibility:hidden;
    transition: opacity var(--transition), transform .2s ease-out;
    transform-origin: top center;
    z-index: 1001;
}
:root[lang="ar"] .dropdown-menu {
    inset-inline-start: auto;
    inset-inline-end: 0;
    transform: none;
}

.dropdown:hover .dropdown-menu, .dropdown:focus-within .dropdown-menu{opacity:1;visibility:visible;}
.dropdown-menu a{
    display: block;
    padding: 10px 16px;
    border-radius:10px;
    color:var(--text);
    white-space: nowrap;
    font-size: 14px;
    font-weight: 600;
}
.dropdown-menu a:hover{background:var(--bg-elev)}

.btn{--_bg:var(--button-primary);--_fg:var(--white);display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:12px 24px;border-radius:14px;border:2px solid transparent;background:var(--_bg);color:var(--_fg) !important;font-weight:700;cursor:pointer;box-shadow:0 8px 24px color-mix(in oklab, var(--button-primary) 25%, transparent);transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease, color .15s ease}
:root[data-theme="dark"] .btn { --_bg: var(--brand-primary); --_fg: #121212; color: #121212 !important; }
.btn:hover{transform:translateY(-3px); box-shadow:0 12px 28px color-mix(in oklab, var(--button-primary) 30%, transparent), 0 0 0 2px var(--hover-gold); color: var(--hover-gold) !important;}
.btn.secondary{--_bg:transparent;--_fg:var(--brand-primary);border-color:var(--brand-primary);box-shadow:none}
.btn.secondary:hover{background: var(--bg-soft); border-color: var(--hover-gold); color: var(--hover-gold) !important;}
:root[data-theme="dark"] .btn.secondary { --_fg: var(--brand-primary); border-color: var(--brand-primary);}

.icon-btn{width:44px;height:44px;border-radius:12px;border:1px solid color-mix(in oklab,var(--text) 15%,transparent);background:transparent;display:grid;place-items:center;cursor:pointer;transition:var(--transition)}
.icon-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow); background: var(--bg-elev); color: var(--hover-gold);}

:root[data-theme="dark"] .icon-btn {
  border-color: #334155;
  color: var(--muted);
}
:root[data-theme="dark"] .icon-btn:hover {
  background: var(--bg-elev);
  color: var(--text);
  border-color: #475569;
}

.ripple{position:absolute;border-radius:50%;transform:translate(-50%,-50%);pointer-events:none;background:currentColor;opacity:.18;animation:ripple .6s ease-out forwards}
@keyframes ripple{to{opacity:0;transform:translate(-50%,-50%) scale(10)}}

.hero{position:relative;min-height:90vh;display:grid;place-items:center;overflow:clip;background: radial-gradient(600px 300px at 50% -10%,color-mix(in oklab,var(--brand-primary) 12%,transparent),transparent), linear-gradient(180deg,color-mix(in oklab,var(--bg) 96%,transparent),var(--bg))}
#heroFx{position:absolute;inset:0;z-index:0}
.hero .inner{position:relative;z-index:2;text-align:center;padding:120px 0 80px}

.hero-subtitle {
    font-size: clamp(18px, 2.2vw, 22px);
    font-weight: 700;
    color: var(--muted);
    margin-bottom: 16px;
    letter-spacing: 0.5px;
    text-shadow: 0 1px 2px color-mix(in oklab, var(--bg) 50%, transparent);
}
.hero h1 .highlight { color: var(--brand-primary-light); }

.cta-row{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:32px}

.layer{position:absolute;inset:auto;opacity:.4;filter:blur(6px)}

section{padding:100px 0;position:relative;z-index:2}
section.alt{background:var(--bg-soft)}
.section-header{text-align:center;margin-bottom:64px}
.section-desc{max-width:780px;margin:16px auto 0;}

.grid{display:grid;gap:24px}
.grid.cols-2{grid-template-columns:repeat(auto-fit,minmax(min(100%, 340px),1fr))}
.grid.cols-3{grid-template-columns:repeat(auto-fit,minmax(min(100%, 300px),1fr))}
.grid.cols-4{grid-template-columns:repeat(auto-fit,minmax(min(100%, 250px),1fr))}
.grid.cols-5{grid-template-columns:repeat(auto-fit,minmax(min(100%, 180px),1fr))}
.card{background:var(--bg);border:1px solid color-mix(in oklab,var(--text) 8%,transparent);border-radius:var(--radius);box-shadow:var(--shadow);transition:transform .2s ease, box-shadow .2s ease;will-change:transform;transform-style:preserve-3d}
.card:hover{transform: translateY(-8px); box-shadow:var(--shadow-lg)}
.card .pad{padding:28px}
.card .icon{font-size:42px;color:var(--brand-primary); margin-bottom: 16px; display: block;}
.card ul { margin-top: 16px; padding-inline-start: 20px; color: var(--muted); text-align: start; }
.card ul li { margin-bottom: 8px; }
.tilt{perspective:900px}

.about-content { display: flex; flex-direction: column; justify-content: center; height: 100%;}
.about-content p { text-align: justify; hyphens: auto; }
.about-img { border-radius: var(--radius); overflow: hidden;}

/* --- Vision/Mission Section (Equal Height Cards) --- */
.vision-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 24px; margin-top: 40px; align-items: stretch; }
.vision-card { background: var(--bg); border: 1px solid color-mix(in oklab,var(--text) 8%,transparent); border-radius: var(--radius); padding: 28px; text-align: center; box-shadow: var(--shadow); opacity: 0; transform: translateY(20px) scale(0.95); transition: opacity .6s ease, transform .6s ease, box-shadow .3s ease; display: flex; flex-direction: column; }
.vision-card.in { opacity: 1; transform: translateY(0) scale(1); }
.vision-card:hover { transform: translateY(-5px) scale(1.02); box-shadow: var(--shadow-lg); }
.vision-card .icon { font-size: 48px; color: var(--brand-primary-light); margin-bottom: 16px; display: inline-block; }
.vision-card h3 { color: var(--brand-primary); font-size: var(--h3); }
.vision-card p { margin: 8px 0 0; flex-grow: 1; }

#why-us .grid { align-items: stretch; gap: 32px; }
.why-us-card {
  background: var(--bg-soft);
  padding: 32px;
  border-radius: var(--radius);
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.feature-list{list-style:none;padding:0;margin:24px 0 0 0;display:grid;gap:24px}
.feature-list li{display:flex;align-items:flex-start;gap:16px;color:var(--text);}
.feature-list li i{
  color:var(--success);
  font-size:24px; 
  background: color-mix(in oklab, var(--success) 15%, transparent);
  width: 48px;
  height: 48px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  flex-shrink: 0;
}
.feature-list li span { flex: 1; padding-top: 4px; }

.metric{background:var(--bg);border:1px solid color-mix(in oklab,var(--text) 10%,transparent);border-radius:16px;padding:24px;text-align:center;box-shadow:var(--shadow)}
.metric .num{font-size:48px;font-weight:800;color:var(--brand-primary);}
.metric .lbl{color:var(--muted); font-size: 16px;}

/* --- New Ports Section Styling --- */
.ports-tabs {
    display: flex;
    justify-content: center;
    gap: 12px;
    margin-bottom: 48px;
    flex-wrap: wrap;
}
.port-tab-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 24px;
    border-radius: 99px;
    border: 2px solid var(--bg-elev);
    background: transparent;
    color: var(--muted);
    font-weight: 700;
    cursor: pointer;
    transition: var(--transition);
}
.port-tab-btn:hover {
    background: var(--bg-elev);
    color: var(--text);
}
.port-tab-btn.active {
    background: var(--brand-primary);
    color: var(--white);
    border-color: var(--brand-primary);
}
:root[data-theme="dark"] .port-tab-btn.active { color: var(--bg); }
.port-tab-content {
    display: none;
    animation: fadeInTab 0.5s ease;
}
.port-tab-content.active {
    display: block;
}
@keyframes fadeInTab {
    from { opacity: 0; transform: translateY(15px); }
    to { opacity: 1; transform: translateY(0); }
}
.ports-grid-v2 {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 24px;
}
.port-card {
    background: var(--bg);
    border-radius: var(--radius);
    overflow: hidden;
    box-shadow: var(--shadow);
    transition: var(--transition);
    border: 1px solid transparent;
}
.port-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow-lg);
    border-color: var(--brand-primary-light);
}
.port-card-img {
    width: 100%;
    height: 180px;
    object-fit: cover;
}
.port-card-name {
    padding: 20px;
    font-weight: 700;
    font-size: 18px;
    text-align: center;
}

/* --- Contact Section Improvement --- */
.grid.cols-2-contact {
    display: grid;
    gap: 48px;
    grid-template-columns: repeat(2, 1fr);
}
.contact-info-wrapper {
    display: flex;
    flex-direction: column;
    gap: 32px;
}
.form-wrapper {
    background: var(--bg);
    padding: 32px;
    border-radius: var(--radius);
    box-shadow: var(--shadow-lg);
    border: 1px solid color-mix(in oklab,var(--text) 8%,transparent);
    height: 100%;
}
#contact h2, #contact p, #contact h4 { color: var(--text); }
.info-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
}
.info-item{
  display:flex;
  align-items:center;
  gap:20px; 
  background: var(--bg);
  padding: 20px;
  border-radius: var(--radius);
  border: 1px solid color-mix(in oklab,var(--text) 8%,transparent);
  box-shadow: var(--shadow);
  transition: var(--transition);
}
.info-item:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-lg);
}
.info-item i{
  font-size:28px;
  color:var(--brand-primary); 
  background: var(--bg-soft);
  width: 60px;
  height: 60px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  flex-shrink: 0;
}
.info-item div { flex: 1; }
.info-item h4 { font-size: 18px; color: var(--text); margin-bottom: 4px; font-weight: 700;}
.info-item p, .info-item a { margin: 0; color: var(--muted); line-height: 1.6; font-size: 15px; }
.info-item a:hover { color: var(--hover-gold); }

#contact form {
  display:grid;
  gap:16px;
}
.field{width:100%;padding:14px 16px;border:1px solid color-mix(in oklab,var(--text) 12%,transparent);border-radius:12px;background:var(--bg-elev);color:var(--text);outline:none;transition:var(--transition);}
.field::placeholder{color:var(--muted)}
.field:hover { border-color: color-mix(in oklab,var(--brand-primary) 50%, transparent); }
.field:focus{border-color:var(--brand-primary);box-shadow:0 0 0 4px var(--ring); background: var(--bg);}
textarea.field{min-height:120px;resize:vertical}

.map-container {
    width: 100%;
    flex-grow: 1;
    min-height: 300px;
    border-radius: var(--radius);
    overflow: hidden;
    box-shadow: var(--shadow-lg);
    border: 1px solid color-mix(in oklab,var(--text) 8%,transparent);
}
.map-container iframe {
    width: 100%;
    height: 100%;
    border: 0;
}

/* --- Accreditations Section --- */
#accreditations .card h3 {
    font-size: 22px; /* Smaller title */
    line-height: 1.3;
    min-height: 58px; /* Ensure space for 2 lines */
    display: flex;
    align-items: center;
}
.accreditation-details summary {
    cursor: pointer;
    font-weight: 700;
    color: var(--brand-primary);
    margin-top: 16px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
}
.accreditation-details summary::marker {
    content: '';
}
.accreditation-details summary .icon {
    transition: transform 0.3s ease;
}
.accreditation-details[open] summary .icon {
    transform: rotate(180deg);
}
.accreditation-details-content {
    padding-top: 16px;
    border-top: 1px solid var(--bg-elev);
    margin-top: 16px;
}

/* --- Careers Section --- */
#careers .grid {
    align-items: center;
    gap: 48px;
}
.careers-content {
    display: flex;
    flex-direction: column;
    justify-content: center;
    height: 100%;
}
.careers-img {
    border-radius: var(--radius);
    overflow: hidden;
    box-shadow: var(--shadow);
}
/* --- Careers Page Specific Styles --- */
.careers-page-section {
    background: var(--bg);
    padding: 48px;
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    border: 1px solid color-mix(in oklab,var(--text) 8%,transparent);
    margin-bottom: 32px;
}
.careers-page-section h2 {
    font-size: var(--h3);
    margin-bottom: 16px;
}
.careers-page-section ul {
    list-style: none;
    padding: 0;
    margin-top: 16px;
}
.careers-page-section ul li {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    margin-bottom: 12px;
    color: var(--muted);
}
.careers-page-section ul li i {
    color: var(--brand-primary);
    font-size: 22px;
    margin-top: 2px;
}
.careers-page-section address {
    font-style: normal;
    line-height: 1.8;
    color: var(--muted);
}

footer{background:var(--brand-primary-dark);color:#eaf2ff;padding:80px 0 24px;}
:root[data-theme="dark"] footer { background: #1a1a1a; }
.footer-grid{display:grid;grid-template-columns: 2fr 1fr 1fr 1.5fr;gap:48px}
footer h4 { color: var(--white); margin-bottom: 16px; font-weight: 700;}
:root[data-theme="dark"] footer h4 { color: var(--brand-primary-light); }
.footer-links{display:grid;gap:12px}
.footer-links a{color:#d6e6ff; display: inline-block;}
:root[data-theme="dark"] .footer-links a { color: var(--muted); }
.footer-links a:hover{color:var(--white);transform:translateX(4px)}
:root[lang="en"] .footer-links a:hover { transform: translateX(4px); }
:root[lang="ar"] .footer-links a:hover { transform: translateX(-4px); }
:root[data-theme="dark"] .footer-links a:hover { color: var(--brand-primary); }

.social-icons {
    display: flex;
    gap: 16px;
    margin-top: 16px;
}
.social-icons a {
    color: #d6e6ff;
    font-size: 24px;
    transition: transform 0.3s ease;
}
.social-icons a:hover {
    transform: translateY(-3px);
    color: var(--white);
}
:root[data-theme="dark"] .social-icons a {
    color: var(--muted);
}
:root[data-theme="dark"] .social-icons a:hover {
    color: var(--brand-primary);
}

.copyright {margin-top:64px;border-top:1px solid rgba(255,255,255,.15);text-align:center;padding-top:24px;font-size:14px; color: #d6e6ff;}
:root[data-theme="dark"] .copyright { color: var(--muted); border-top-color: color-mix(in oklab,var(--text) 12%,transparent); }
:root[data-theme="dark"] .copyright a { color: var(--muted); }

/* --- WhatsApp FAB Styling --- */
.whatsapp-fab {
    position: fixed;
    bottom: 20px;
    z-index: 1000;
    background-color: #25D366;
    color: white;
    width: 60px;
    height: 60px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 12px rgba(0,0,0,0.2);
    font-size: 30px;
    transition: transform 0.3s ease;
}
.whatsapp-fab:hover {
    transform: scale(1.1);
    color: white;
}
:root[lang="en"] .whatsapp-fab {
    right: 20px;
    left: auto;
}
:root[lang="ar"] .whatsapp-fab {
    left: auto;
    right: 20px;
}

.bottom-nav{position:fixed;inset-inline:12px;bottom:12px;z-index:999;background:color-mix(in oklab,var(--bg) 85%,transparent);backdrop-filter:blur(10px) saturate(160%);-webkit-backdrop-filter:blur(10px) saturate(160%);border:1px solid color-mix(in oklab,var(--text) 12%,transparent);border-radius:18px;box-shadow:var(--shadow-lg);padding:8px;display:none}
.bottom-nav a{flex:1;display:grid;place-items:center;gap:2px;padding:8px;border-radius:12px;color:var(--muted);font-size:11px;font-weight:700; transition: var(--transition);}
.bottom-nav a.active{color:var(--brand-primary);background:var(--bg-elev)}
.bottom-nav i{font-size:20px}
.bottom-nav .track-button {
    transform: translateY(-10px);
    background: var(--brand-primary);
    color: var(--white);
    border-radius: 14px;
    box-shadow: var(--shadow);
}
:root[data-theme="dark"] .bottom-nav .track-button { color: var(--bg); }
.bottom-nav .track-button.active,
.bottom-nav .track-button:hover {
    background: var(--brand-primary-dark);
    color: var(--white);
}
:root[data-theme="dark"] .bottom-nav .track-button:hover { color: var(--bg); }


.drawer{display:none;position:fixed;inset:0;z-index:1100}
.drawer.open{display:block}
.drawer .backdrop{position:absolute;inset:0;background:rgba(0,0,0,.5); backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px);}
.drawer .panel{position:absolute;inset-block:0;inset-inline-start:0;width:min(86vw,360px);background:var(--bg);padding:24px;box-shadow:var(--shadow-lg);overflow-y:auto; transform: translateX(-100%); transition: transform .4s cubic-bezier(.2,.8,.2,1);}
:root[lang="en"] .drawer .panel { transform: translateX(100%); inset-inline-start: auto; inset-inline-end: 0; }
:root[lang="ar"] .drawer .panel { transform: translateX(100%); inset-inline-start: auto; inset-inline-end: 0; }

.drawer.open .panel { transform: translateX(0); }
.drawer .m-item { display: flex; align-items: center; gap: 12px; padding: 14px; border-radius: 12px; font-weight: 700; font-size: 16px; margin-bottom: 8px; color: var(--text);}
.drawer .m-item:hover { background: var(--bg-elev); color: var(--brand-primary); }
.drawer .m-item i { font-size: 22px; }

.reveal{opacity:0;transform:translateY(25px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:translateY(0)}

/* Notification System */
.notification-container {
    position: fixed;
    bottom: 24px;
    z-index: 2000;
    display: grid;
    gap: 16px;
    width: calc(100% - 48px);
    max-width: 380px;
}
html[dir="rtl"] .notification-container { left: 24px; }
html[dir="ltr"] .notification-container { right: 24px; }

.toast {
    position: relative;
    padding: 16px;
    padding-inline-end: 40px;
    border-radius: var(--radius);
    box-shadow: var(--shadow-lg);
    display: flex;
    align-items: center;
    gap: 12px;
    color: var(--white);
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.2);
    animation: toast-in 0.5s cubic-bezier(0.21, 1.02, 0.73, 1) forwards;
}

.toast.closing {
    animation: toast-out 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards;
}

@keyframes toast-in { from { opacity: 0; transform: translateY(100%); } to { opacity: 1; transform: translateY(0); } }
@keyframes toast-out { from { opacity: 1; transform: translateY(0); } to { opacity: 0; transform: translateY(100%); } }

.toast.success { background: linear-gradient(135deg, var(--success), #15803d); }
.toast.error { background: linear-gradient(135deg, var(--danger), #991b1b); }
.toast > i { font-size: 28px; flex-shrink: 0; }
.toast-close { position: absolute; top: 8px; inset-inline-end: 8px; background: transparent; border: none; color: var(--white); opacity: 0.7; cursor: pointer; font-size: 24px; line-height: 1; padding: 4px; border-radius: 50%; transition: opacity 0.2s, background 0.2s; }
.toast-close:hover { opacity: 1; background: rgba(0,0,0,0.15); }
.toast::after { content: ''; position: absolute; bottom: 0; left: 0; height: 4px; width: 100%; background: rgba(255, 255, 255, 0.4); animation: progress-bar 4s linear forwards; }
@keyframes progress-bar { from { width: 100%; } to { width: 0%; } }

/* Partners & Clients Slider */
.slider {
  background: transparent;
  height: 120px;
  margin: auto;
  overflow: hidden;
  position: relative;
  width: 100%;
}
.slider::before, .slider::after { content: ""; height: 100%; position: absolute; width: 15%; z-index: 2; }
.slider::before { left: 0; top: 0; background: linear-gradient(to left, rgba(253, 250, 246, 0), var(--bg-soft)); }
.slider::after { right: 0; top: 0; background: linear-gradient(to right, rgba(253, 250, 246, 0), var(--bg-soft)); }
[data-theme="dark"] .slider::before { background: linear-gradient(to left, rgba(26, 26, 26, 0), var(--bg-soft)); }
[data-theme="dark"] .slider::after { background: linear-gradient(to right, rgba(26, 26, 26, 0), var(--bg-soft)); }

@keyframes scroll { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }
.slide-track { animation: scroll var(--duration, 40s) linear infinite; display: flex; width: max-content; }
.slider:hover .slide-track { animation-play-state: paused; }
.slide { height: 100px; width: 200px; display: flex; align-items: center; justify-content: center; padding: 15px; perspective: 100px; flex-shrink: 0; }
.slide img { max-width: 150px; max-height: 70px; width: auto; filter: grayscale(100%); opacity: 0.7; transition: all 0.4s ease; }
.slide:hover img { filter: grayscale(0); opacity: 1; transform: translateZ(10px); }

/* Newsletter Section */
#newsletter .newsletter-wrapper {
    background: var(--bg);
    padding: 48px;
    border-radius: var(--radius-lg, 24px);
    box-shadow: var(--shadow-lg);
    display: grid;
    grid-template-columns: 1fr 1.2fr;
    gap: 48px;
    align-items: center;
    border: 1px solid color-mix(in oklab, var(--text) 8%, transparent);
}
.newsletter-text i { font-size: 48px; color: var(--brand-primary-light); margin-bottom: 16px; display: block; }
.newsletter-text h2 { font-size: var(--h2); margin-bottom: 8px; }
.newsletter-text p { color: var(--muted); line-height: 1.7; max-width: 450px; }
.newsletter-form { display: grid; gap: 20px; }
.newsletter-form .field { padding: 16px; font-size: 16px; }
.interests-group p { font-weight: 700; color: var(--text); margin-bottom: 12px; }
.checkbox-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 12px; }
.checkbox-grid label { display: flex; align-items: center; gap: 8px; cursor: pointer; font-size: 15px; color: var(--muted); transition: color var(--transition); }
.checkbox-grid label:hover { color: var(--text); }
.checkbox-grid input[type="checkbox"] { width: 18px; height: 18px; accent-color: var(--brand-primary); }

@media (max-width: 991px){
  .navlinks, .actions .primary-only{display:none}
  .bottom-nav{display:flex}
  .actions #menuOpen { display: grid; }
  section{padding:80px 0}
  .hero .inner{padding-top:100px}
  .footer-grid { grid-template-columns: 1fr; }
  .grid.cols-2-contact { grid-template-columns: 1fr; }
  .map-container { margin-top: 40px; min-height: 400px; }
  .copyright { padding-bottom: calc(24px + 80px); }
  .whatsapp-fab { bottom: 100px; /* Raise WhatsApp FAB on mobile */ }
  #newsletter .newsletter-wrapper {
        grid-template-columns: 1fr;
        gap: 32px;
        padding: 32px;
  }
  .newsletter-text { text-align: center; }
  .newsletter-text p { margin-inline: auto; }
}
@media (max-width: 768px){
  .grid.cols-2, .grid.cols-5, .grid.cols-4 { grid-template-columns: 1fr; }
  #why-us .grid, #careers .grid { grid-template-columns: 1fr; }
  #why-us .about-img, #careers .careers-img { order: -1; margin-bottom: 24px; }
  .about-content, .careers-content { text-align: center; }
  .about-content p, .careers-content p { text-align: center; }
  .feature-list { margin-inline: auto; max-width: 380px; }
}
.actions #menuOpen { display: none; }

@media (max-width: 480px) {
    .checkbox-grid { grid-template-columns: 1fr; }
}

