/* ============================================================
   MADKHAL — webMap.css  (خريطة الموقع)
   ============================================================ */

:root {
  --bg:          #0b0d11;
  --surface:     #12151c;
  --surface-2:   #181c26;
  --surface-3:   #1e2230;
  --border:      rgba(255,255,255,0.07);
  --accent:      #2267e8;
  --accent-dim:  rgba(34, 103, 232, 0.12);
  --accent-glow: rgba(34, 103, 232, 0.35);
  --text:        #e8eaf0;
  --muted:       #7a8099;
  --faint:       #424866;
  --c-tool:      #60a5fa;
  --c-majors:    #a78bfa;
  --c-library:   #34d399;
  --c-news:      var(--accent);
  --header-bg:   rgba(11,13,17,0.88);
  --grid-line:   rgba(255,255,255,0.025);
  --nav-hover:   rgba(255,255,255,0.06);
  --mob-hover:   rgba(255,255,255,0.04);
  --shadow:      rgba(0,0,0,0.45);
  --font-h: 'Cairo', sans-serif;
  --font-b: 'Tajawal', sans-serif;
  --r-sm:8px; --r-md:14px; --r-lg:22px; --r-xl:32px; --r-full:999px;
  --ease:cubic-bezier(0.4,0,0.2,1);
  --spring:cubic-bezier(0.34,1.56,0.64,1);
  --dur:0.28s; --theme-dur:0.4s;
}

[data-theme="light"] {
  --bg:          #f4f6fb;
  --surface:     #ffffff;
  --surface-2:   #eef0f7;
  --surface-3:   #e6e9f4;
  --border:      rgba(0,0,0,0.08);
  --accent:      #0a4bc4;
  --accent-dim:  rgba(10, 75, 196, 0.1);
  --accent-glow: rgba(10, 91, 196, 0.28);
  --text:        #0f1117;
  --muted:       #4a5068;
  --faint:       #9aa0bc;
  --header-bg:   rgba(244,246,251,0.92);
  --grid-line:   rgba(0,0,0,0.04);
  --nav-hover:   rgba(0,0,0,0.05);
  --mob-hover:   rgba(0,0,0,0.03);
  --shadow:      rgba(0,0,0,0.10);
  --c-tool:      #2563eb;
  --c-majors:    #7c3aed;
  --c-library:   #059669;
}

/* transitions */
body,.header,.map-card,.map-section,.map-quicklink,footer,.mobile-nav {
  transition: background var(--theme-dur) var(--ease),
              border-color var(--theme-dur) var(--ease),
              color var(--theme-dur) var(--ease);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-b);background:var(--bg);color:var(--text);direction:rtl;overflow-x:hidden;min-height:100svh;display:flex;flex-direction:column}
a{color:inherit;text-decoration:none}
.container{max-width:1200px;margin:0 auto;padding:0 clamp(1rem,4vw,2rem)}

/* ── HEADER ── */
.header{position:fixed;top:0;right:0;left:0;z-index:100;background:transparent;border-bottom:1px solid transparent;transition:background var(--theme-dur) var(--ease),border-color var(--dur) var(--ease),backdrop-filter var(--dur) var(--ease)}
.header.is-scrolled{background:var(--header-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-color:var(--border)}
.header__inner{max-width:1200px;margin:0 auto;padding:0 clamp(1rem,4vw,2rem);height:68px;display:flex;align-items:center;justify-content:space-between;gap:1rem}
/* ── LOGO ────────────────────────────────────────────────── */
/* ضبط مقاس الشعار */
.header__logo img {
  height: 45px; 
  width: auto;
}

/* الوضع الفاتح (الافتراضي): إخفاء شعار الدارك وإظهار شعار اللايت */
.logo-dark {
  display: none;
}
.logo-light {
  display: block;
}

/* الوضع الليلي: إخفاء شعار اللايت وإظهار شعار الدارك */
/* ضفت لك أشهر الكلاسات اللي تستخدمها سكربتات التبديل عشان يضبط معك مباشرة */
body.dark .logo-light,
body.dark-mode .logo-light,
[data-theme="dark"] .logo-light {
  display: none !important;
}

body.dark .logo-dark,
body.dark-mode .logo-dark,
[data-theme="dark"] .logo-dark {
  display: block !important;
}
.header__nav{display:flex;align-items:center;gap:.25rem}
.nav-link{padding:.42rem .85rem;border-radius:var(--r-full);font-family:var(--font-h);font-size:.88rem;font-weight:500;color:var(--muted);background:none;border:none;cursor:pointer;transition:color var(--dur) var(--ease),background var(--dur) var(--ease)}
.nav-link:hover,.nav-link.active{color:var(--text);background:var(--nav-hover)}
.nav-cta{padding:.42rem 1.1rem;background:var(--accent-dim);color:var(--accent);border:1px solid rgba(34, 103, 232, 0.3);border-radius:var(--r-full);font-family:var(--font-h);font-size:.88rem;font-weight:600;transition:background var(--dur) var(--ease),color var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
.nav-cta:hover{background:var(--accent);color:#fff;box-shadow:0 4px 18px var(--accent-glow)}
.theme-toggle{width:38px;height:38px;border-radius:50%;background:var(--surface-2);border:1.5px solid var(--border);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;transition:background var(--dur) var(--ease),border-color var(--dur) var(--ease),transform var(--dur) var(--spring),box-shadow var(--dur) var(--ease)}
.theme-toggle:hover{transform:scale(1.1) rotate(15deg);border-color:var(--accent);box-shadow:0 0 14px var(--accent-glow)}
.theme-toggle__icon{display:block;line-height:1}
.header__burger{display:none;flex-direction:column;gap:5px;width:32px;background:none;border:none;cursor:pointer;padding:4px}
.header__burger span{display:block;height:2px;background:var(--text);border-radius:2px;transition:transform var(--dur) var(--ease),opacity var(--dur) var(--ease),background var(--theme-dur) var(--ease)}
.header__burger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.header__burger.is-open span:nth-child(2){opacity:0}
.header__burger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-nav{display:none;flex-direction:column;background:var(--surface);border-top:1px solid var(--border);overflow:hidden;max-height:0;transition:max-height .4s var(--ease),background var(--theme-dur) var(--ease)}
.mobile-nav.is-open{max-height:320px}
.mobile-nav__link{display:block;padding:.85rem 1.5rem;font-family:var(--font-h);font-size:.95rem;font-weight:500;color:var(--muted);border-bottom:1px solid var(--border);transition:color var(--dur) var(--ease),background var(--dur) var(--ease)}
.mobile-nav__link:hover{color:var(--text);background:var(--mob-hover)}
.mobile-nav__theme{display:flex;align-items:center;gap:.7rem;padding:.85rem 1.5rem;font-family:var(--font-h);font-size:.9rem;color:var(--muted);cursor:pointer;background:none;border:none;width:100%;text-align:right;transition:color var(--dur) var(--ease),background var(--dur) var(--ease)}
.mobile-nav__theme:hover{color:var(--accent);background:var(--mob-hover)}

/* ── HERO ── */
.page-hero{position:relative;padding:calc(68px + 3rem) 0 3rem;text-align:center;overflow:hidden}
.page-hero__bg{position:absolute;inset:0;pointer-events:none}
.blob{position:absolute;border-radius:50%;filter:blur(90px)}
.blob--1{width:500px;height:500px;top:-140px;right:-80px;background:radial-gradient(circle,rgba(34, 120, 232, 0.13) 0%,transparent 70%)}
.blob--2{width:360px;height:360px;bottom:-60px;left:-60px;background:radial-gradient(circle,rgba(90,110,210,.10) 0%,transparent 70%)}
[data-theme="light"] .blob--1{background:radial-gradient(circle,rgba(10, 91, 196, 0.11) 0%,transparent 70%)}
[data-theme="light"] .blob--2{background:radial-gradient(circle,rgba(70,90,200,.07) 0%,transparent 70%)}
.grid-bg{position:absolute;inset:0;background-image:linear-gradient(var(--grid-line) 1px,transparent 1px),linear-gradient(90deg,var(--grid-line) 1px,transparent 1px);background-size:60px 60px;mask-image:radial-gradient(ellipse 80% 60% at 50% 40%,black 0%,transparent 100%)}
.page-hero__inner{position:relative;z-index:1;max-width:1200px;margin:0 auto;padding:0 clamp(1rem,4vw,2rem)}
.hero-badge{display:inline-flex;align-items:center;gap:.45rem;margin-bottom:1rem;padding:.35rem .95rem;background:var(--accent-dim);border:1px solid rgba(34, 97, 232, 0.25);border-radius:var(--r-full);font-family:var(--font-h);font-size:.78rem;font-weight:600;color:var(--accent)}
.badge-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);animation:pulse-dot 2s ease-in-out infinite}
@keyframes pulse-dot{0%,100%{box-shadow:0 0 0 0 var(--accent-glow)}50%{box-shadow:0 0 0 6px transparent}}
.page-hero__title{font-family:var(--font-h);font-size:clamp(1.8rem,5vw,3rem);font-weight:900;color:var(--text);margin-bottom:.6rem}
.page-hero__title span{color:var(--accent);text-shadow:0 0 40px var(--accent-glow)}
.page-hero__sub{font-size:.97rem;color:var(--muted);max-width:440px;margin:0 auto;line-height:1.7}

/* ── MAP MAIN ── */
.map-main{flex:1;padding:2rem 0 5rem}

/* ── MAP ROW ── */
.map-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1.5rem;
  margin-bottom:1.5rem;
}
.map-row--single{grid-template-columns:1fr}

/* ── MAP SECTION ── */
.map-section{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-xl);overflow:hidden;
  transition:border-color var(--dur) var(--ease),background var(--theme-dur) var(--ease);
}
.map-section--wide{/* full width handled by parent row */}
.map-section__header{
  display:flex;align-items:center;gap:.85rem;
  padding:1.2rem 1.5rem;
  border-bottom:1px solid var(--border);
  background:var(--surface-2);
  transition:background var(--theme-dur) var(--ease),border-color var(--theme-dur) var(--ease);
}
.map-section__icon{font-size:1.6rem;line-height:1}
.map-section__title{font-family:var(--font-h);font-size:1rem;font-weight:800;color:var(--text)}

/* ── MAP CARDS ── */
.map-cards{display:flex;flex-direction:column;gap:0}

.map-card{
  display:flex;align-items:center;gap:1rem;
  padding:.9rem 1.4rem;
  border-bottom:1px solid var(--border);
  transition:background var(--dur) var(--ease),border-color var(--dur) var(--ease);
  position:relative;
}
.map-card:last-child{border-bottom:none}
.map-card::before{
  content:'';
  position:absolute;right:0;top:0;bottom:0;width:3px;
  opacity:0;
  transition:opacity var(--dur) var(--ease);
  border-radius:0 var(--r-sm) var(--r-sm) 0;
}
.map-card:hover{background:var(--surface-2)}
.map-card:hover::before{opacity:1}

/* colour accent per category */
.map-card--tool  { --card-c: var(--c-tool);    }
.map-card--tool::before   { background: var(--c-tool);    }
.map-card--majors { --card-c: var(--c-majors);  }
.map-card--majors::before { background: var(--c-majors);  }
.map-card--library{ --card-c: var(--c-library); }
.map-card--library::before{ background: var(--c-library); }
.map-card--news   { --card-c: var(--c-news);    }
.map-card--news::before   { background: var(--c-news);    }

.map-card__icon{
  font-size:1.5rem;flex-shrink:0;line-height:1;
  width:40px;height:40px;border-radius:var(--r-md);
  display:flex;align-items:center;justify-content:center;
  background:color-mix(in srgb, var(--card-c,var(--accent)) 12%, transparent);
  transition:background var(--theme-dur) var(--ease);
}
.map-card__title{font-family:var(--font-h);font-size:.9rem;font-weight:700;color:var(--text);margin-bottom:.1rem}
.map-card__sub{font-size:.75rem;color:var(--muted)}
.map-card__arrow{
  margin-right:auto;
  font-size:.85rem;font-weight:700;
  color:var(--muted);flex-shrink:0;
  transition:color var(--dur) var(--ease),transform var(--dur) var(--spring);
}
.map-card:hover .map-card__arrow{color:var(--card-c,var(--accent));transform:translateX(-3px)}

/* ── QUICK LINKS ── */
.map-quicklinks{
  display:flex;flex-wrap:wrap;gap:.6rem;padding:1.2rem 1.5rem;
}
.map-quicklink{
  display:inline-flex;align-items:center;gap:.45rem;
  padding:.55rem 1.1rem;border-radius:var(--r-full);
  background:var(--surface-2);border:1.5px solid var(--border);
  font-family:var(--font-h);font-size:.85rem;font-weight:600;color:var(--muted);
  transition:background var(--dur) var(--ease),border-color var(--dur) var(--ease),
             color var(--dur) var(--ease),transform var(--dur) var(--spring),
             box-shadow var(--dur) var(--ease);
}
.map-quicklink:hover{
  background:var(--accent-dim);border-color:var(--accent);
  color:var(--accent);transform:translateY(-2px);
}
.map-quicklink--accent{
  background:var(--accent-dim);border-color:rgba(34, 97, 232, 0.3);color:var(--accent);
}
.map-quicklink--accent:hover{
  background:var(--accent);color:#fff;
  box-shadow:0 6px 20px var(--accent-glow);
}

/* ── FOOTER ── */
footer{border-top:1px solid var(--border);background:var(--surface);padding:1.4rem 0;margin-top:auto;transition:background var(--theme-dur) var(--ease),border-color var(--theme-dur) var(--ease)}
.footer__inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem}
.footer__brand{display:flex;align-items:center;gap:.5rem}
.footer__copy{font-size:.8rem;color:var(--faint);font-family:var(--font-h)}
.footer__link{font-family:var(--font-h);font-size:.8rem;color:var(--muted);border-bottom:1px solid var(--faint);padding-bottom:1px;transition:color var(--dur) var(--ease),border-color var(--dur) var(--ease)}
.footer__link:hover{color:var(--accent);border-color:var(--accent)}

/* ── REVEAL ── */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.is-visible{opacity:1;transform:translateY(0)}
.reveal:nth-child(2){transition-delay:.1s}
.reveal:nth-child(3){transition-delay:.2s}

/* ── RESPONSIVE ── */
@media(max-width:760px){
  .header__nav{display:none}
  .header__burger{display:flex}
  .mobile-nav{display:flex}
  .map-row{grid-template-columns:1fr}
  .footer__inner{flex-direction:column;align-items:center;text-align:center}
}
@media(max-width:420px){
  .map-card{padding:.8rem 1rem}
  .map-quicklink{font-size:.78rem;padding:.45rem .9rem}
}
