/* المسار: /css/style.css */
/* =============================
   IFSS v4.1 — Professional Edition (Final)
   ============================= */
:root {
  /* -- Colors based on the new palette -- */
  --bg: #FFFFFF;
  --text: #333333;
  --brand-primary: #003366;        /* عناوين رئيسية */
  --brand-primary-light: #009933;  /* عناوين فرعية / درجات */
  --success: #009933;              /* نقاط إيجابية */
  --danger: #CC0000;               /* تنبيهات/تحذيرات */
  --button-primary: #007A3D;       /* أزرار افتراضية */
  --hover-gold: #D4AF37;           /* تأثير Hover */

  /* -- Original variables kept for structure -- */
  --white: #ffffff;
  --dark-blue: #003366; /* Mapped to new primary */
  --burgundy: #8f1838; /* Kept for potential dark mode use */
  --black: #000000;

  --bg-elev: #f7f8fc;
  --bg-soft: #f0f1f9;
  --muted: #64748b;
  
  --brand-secondary: var(--burgundy); /* Kept for structure */
  --brand-primary-dark: #002244; /* Darker shade of primary */

  --accent: var(--brand-secondary);
  --ring: rgba(0, 51, 102, 0.3);

  --radius: 16px; --radius-sm: 12px; --shadow:0 10px 30px rgba(0, 51, 102, .1); --shadow-lg:0 22px 60px rgba(0, 51, 102, .18);
  --max-w:1200px; --transition:.3s cubic-bezier(.2,.8,.2,1);
  --h1:clamp(38px,5.5vw,64px); --h2:clamp(28px,4vw,44px); --h3:clamp(20px,2.6vw,28px); --lead:clamp(18px,2vw,20px);
  --font-ar: 'Almarai', system-ui, sans-serif;
  --font-en: 'Poppins', system-ui, sans-serif;
}

:root[data-theme="dark"]{
  --bg: #0f172a; /* Slate 900 */
  --bg-elev: #1e293b; /* Slate 800 */
  --bg-soft: #182134; /* Custom Slate */
  --text: #f1f5f9; /* Slate 100 */
  --muted: #94a3b8; /* Slate 400 */
  
  --brand-primary: #60a5fa; /* Blue 400 */
  --brand-secondary: #f472b6; /* Pink 400 */
  --brand-primary-light: #93c5fd; /* Blue 300 */
  --brand-primary-dark: #2563eb; /* Blue 600 */
  --accent: var(--brand-secondary);

  --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);
  --ring: rgba(96, 165, 250, 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-uploader { display: none; }
.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:8px}
.navlinks>li{list-style:none;position:relative}
.navlinks>li>a{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:12px;color:var(--text);font-weight:700;}
.navlinks>li>a:hover, .navlinks>li>a.active{background:var(--bg-elev); color: var(--brand-primary);}
/* --- التعديل: تحديث القائمة المنسدلة --- */
.dropdown-menu{
    position:absolute;
    inset-inline-start:0;
    top:calc(100% + 10px);
    width: max-content; /* تجعل العرض يتناسب مع المحتوى */
    min-width: 220px; /* للحفاظ على شكل جيد إذا كانت الأسماء قصيرة */
    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;
    transform:translateY(-6px);
    transition:var(--transition);
}
html[lang="en"] .dropdown-menu { inset-inline-start: auto; inset-inline-end: 0; }
.dropdown:hover .dropdown-menu,.dropdown:focus-within .dropdown-menu{opacity:1;visibility:visible;transform:none}
.dropdown-menu a{
    display: block;
    padding: 10px 16px; /* تعديل الحشوة */
    border-radius:10px;
    color:var(--text);
    white-space: nowrap; /* يمنع التفاف النص إلى سطر جديد */
}
.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);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: #0f172a; }
.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;}
.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; /* Slate 700 */
  color: var(--muted);
}
:root[data-theme="dark"] .icon-btn:hover {
  background: var(--bg-elev);
  color: var(--text);
  border-color: #475569; /* Slate 600 */
}

.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-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-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 24px; margin-top: 40px; }
.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; }
.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; text-align: center; }

#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;}

/* --- 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; /* Make map fill available space */
    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;
}

footer{background:var(--brand-primary-dark);color:#eaf2ff;padding:80px 0 24px;}
:root[data-theme="dark"] footer { background: #0b1222; }
.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[data-theme="dark"] .footer-links a:hover { color: var(--brand-primary); }
html[lang="en"] .footer-links a:hover { transform: translateX(-4px); }

.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); }

.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);
}
.bottom-nav .track-button.active,
.bottom-nav .track-button:hover {
    background: var(--brand-primary-dark);
    color: var(--white);
}

.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);}
html[lang="en"] .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 (Toast Popups) - PROFESSIONAL
   ========================================================================== */
.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; /* Space for close button */
    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);
}

/* Progress bar */
.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 Slider (شريط شعارات الشركاء) - MODIFIED
   ========================================================================== */

.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(247, 249, 252, 0), var(--bg-soft));
}

.slider::after {
  right: 0;
  top: 0;
  background: linear-gradient(to right, rgba(247, 249, 252, 0), var(--bg-soft));
}

[data-theme="dark"] .slider::before {
    background: linear-gradient(to left, rgba(11, 19, 36, 0), var(--bg-soft));
}
[data-theme="dark"] .slider::after {
    background: linear-gradient(to right, rgba(11, 19, 36, 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);
}

@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); /* 24px default + 80px nav height */
  }
}
@media (max-width: 768px){
  .grid.cols-2, .grid.cols-5 { grid-template-columns: 1fr; }
  #why-us .grid { grid-template-columns: 1fr; }
  #why-us .about-img { order: -1; margin-bottom: 24px; }
  .about-content { text-align: center; }
  .about-content p { text-align: center; }
  .feature-list { margin-inline: auto; max-width: 380px; }
}
.actions #menuOpen { display: none; }

/* ========== Newsletter Section Styles ========== */
#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);
}

/* Responsive adjustments for newsletter */
@media (max-width: 991px) {
    #newsletter .newsletter-wrapper {
        grid-template-columns: 1fr;
        gap: 32px;
        padding: 32px;
        text-align: center;
    }
    .newsletter-text p {
        margin-inline: auto;
    }
    .newsletter-form {
        text-align: left;
    }
    html[dir="rtl"] .newsletter-form {
        text-align: right;
    }
}

@media (max-width: 480px) {
    .checkbox-grid {
        grid-template-columns: 1fr;
    }
}
