/* ═══════════════════════════════════════════════
   PAGES.CSS  —  Tadbir International Think Tank
   Page-specific styles (index · about · depts ·
   research · events · media · contact · login)
   ═══════════════════════════════════════════════ */

/* ════════════════ INDEX / HOME ════════════════ */

/* Hero */
.hero {
  min-height: 100vh; background: var(--primary);
  position: relative; display: flex; align-items: center;
  justify-content: center; overflow: hidden;
  padding-top: var(--header-h);
}
.hero-bg { position: absolute; inset: 0; pointer-events: none; }
.hero-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(200,160,70,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(200,160,70,.06) 1px, transparent 1px);
  background-size: 60px 60px;
}
.hero-geo { position: absolute; border-radius: 50%; filter: blur(80px); opacity: .15; }
.geo-1 { width: 600px; height: 600px; background: var(--secondary); top: -150px; left: -150px; }
.geo-2 { width: 400px; height: 400px; background: var(--accent); bottom: -100px; right: -100px; opacity: .10; }
.geo-3 { width: 300px; height: 300px; background: var(--secondary); top: 50%; right: 20%; opacity: .08; }

.hero-content {
  position: relative; z-index: 1; text-align: center;
  max-width: 820px; padding: 60px 24px;
  animation: fadeUp .9s ease both;
}
@keyframes fadeUp { from { opacity: 0; transform: translateY(40px); } to { opacity: 1; transform: none; } }

.hero-badge {
  display: inline-block;
  background: rgba(200,160,70,.12); border: 1px solid rgba(200,160,70,.4);
  color: var(--secondary); padding: 6px 20px; border-radius: 100px;
  font-size: .85rem; margin-bottom: 28px;
}
.hero-title { font-size: clamp(2.4rem,6vw,4.2rem); font-weight: 700; color: var(--white); line-height: 1.25; margin-bottom: 24px; }
.hero-desc  { font-size: 1.1rem; color: rgba(255,255,255,.68); max-width: 600px; margin: 0 auto 40px; line-height: 2; }
.hero-cta   { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }

.hero-scroll {
  position: absolute; bottom: 40px; left: 50%; transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  color: rgba(255,255,255,.38); font-size: .75rem;
}
.scroll-line {
  width: 1px; height: 50px;
  background: linear-gradient(to bottom, var(--secondary), transparent);
  animation: scrollPulse 2s ease infinite;
}
@keyframes scrollPulse { 0%,100% { opacity: .4; } 50% { opacity: 1; } }

/* Stats Strip */
.stats-strip { background: var(--primary); padding: 72px 0; }
.stats-strip .stats-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 2px; }

/* Departments on home */
.home-depts { padding: 96px 0; background: var(--bg); }
.dept-grid  { display: grid; grid-template-columns: repeat(4,1fr); gap: 20px; }
.dept-card  {
  background: var(--white); border: 1px solid var(--border); border-radius: var(--radius);
  padding: 32px 24px; transition: var(--transition); position: relative; overflow: hidden; display: block;
}
.dept-card::before {
  content: ''; position: absolute; top: 0; right: 0;
  width: 4px; height: 0; background: var(--secondary); transition: var(--transition);
  border-radius: 0 var(--radius) var(--radius) 0;
}
.dept-card:hover::before { height: 100%; }
.dept-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); border-color: rgba(200,160,70,.3); }
.dept-card.featured { background: linear-gradient(135deg,var(--primary),var(--primary-light)); border-color: var(--secondary); }
.dept-card.featured h3, .dept-card.featured .dept-link { color: var(--white); }
.dept-card.featured p  { color: rgba(255,255,255,.65); }
.dept-card.featured .dept-link { color: var(--secondary); }
.dept-icon  { font-size: 2rem; margin-bottom: 16px; }
.dept-card h3 { font-size: 1rem; font-weight: 700; color: var(--primary); margin-bottom: 10px; line-height: 1.5; }
.dept-card p  { font-size: .85rem; color: var(--text-light); line-height: 1.7; margin-bottom: 16px; }
.dept-link  { font-size: .82rem; color: var(--accent); font-weight: 700; transition: var(--transition); }
.dept-card:hover .dept-link { color: var(--secondary); }

/* Latest research on home */
.home-research { padding: 96px 0; background: var(--primary); }
.research-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.rcard-type-bar { height: 3px; border-radius: 2px 2px 0 0; }
.rcard-type-bar.gold  { background: var(--secondary); }
.rcard-type-bar.blue  { background: var(--accent); }
.rcard-type-bar.green { background: #4ade80; }

/* Events on home */
.home-events { padding: 96px 0; background: var(--bg); }
.events-filter { display: flex; gap: 8px; margin-bottom: 40px; justify-content: center; }
.events-grid   { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.event-card    {
  background: var(--white); border: 1px solid var(--border); border-radius: var(--radius);
  padding: 28px; display: flex; gap: 20px; align-items: flex-start;
  transition: var(--transition); position: relative; overflow: hidden;
}
.event-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: var(--secondary); transform: scaleX(0); transition: var(--transition);
}
.event-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.event-card:hover::before { transform: scaleX(1); }
.event-type { position: absolute; top: 16px; left: 16px; font-size: .72rem; font-weight: 700; padding: 3px 10px; border-radius: 100px; }
.event-type.online   { background: rgba(58,180,166,.10); color: var(--accent); border: 1px solid rgba(58,180,166,.3); }
.event-type.inperson { background: rgba(200,160,70,.10); color: var(--secondary); border: 1px solid rgba(200,160,70,.3); }
.event-date {
  display: flex; flex-direction: column; align-items: center;
  background: var(--primary); color: var(--white); border-radius: var(--radius-sm);
  padding: 12px 16px; min-width: 64px; margin-top: 28px; flex-shrink: 0;
}
.event-date .day   { font-size: 1.8rem; font-weight: 700; color: var(--secondary); line-height: 1; }
.event-date .month { font-size: .75rem; opacity: .65; }
.event-info { flex: 1; padding-top: 28px; }
.event-info h3 { font-size: .95rem; font-weight: 700; color: var(--primary); margin-bottom: 8px; line-height: 1.6; }
.event-info p  { font-size: .82rem; color: var(--text-light); margin-bottom: 12px; }
.event-meta    { display: flex; flex-direction: column; gap: 4px; margin-bottom: 16px; }
.event-meta span { font-size: .78rem; color: var(--text-muted); }

/* Media strip on home */
.home-media { padding: 96px 0; background: var(--white); }
.media-layout { display: grid; grid-template-columns: 1.6fr 1fr; gap: 48px; }
.news-list { display: flex; flex-direction: column; gap: 20px; }
.news-item { padding: 20px; border: 1px solid var(--border); border-radius: var(--radius); transition: var(--transition); }
.news-item:hover { border-color: rgba(200,160,70,.3); box-shadow: var(--shadow); }
.news-item.big { display: grid; grid-template-columns: 140px 1fr; gap: 20px; }
.news-img { border-radius: var(--radius-sm); background: linear-gradient(135deg,var(--primary) 0%,var(--accent) 100%); min-height: 100px; }
.news-cat { display: inline-block; font-size: .72rem; color: var(--secondary); background: rgba(200,160,70,.10); border: 1px solid rgba(200,160,70,.3); padding: 2px 10px; border-radius: 100px; margin-bottom: 8px; }
.news-item h3 { font-size: .95rem; font-weight: 700; color: var(--primary); line-height: 1.6; margin-bottom: 8px; }
.news-item p  { font-size: .83rem; color: var(--text-light); line-height: 1.7; margin-bottom: 12px; }
.news-meta    { display: flex; align-items: center; justify-content: space-between; }
.news-meta span { font-size: .78rem; color: var(--text-muted); }
.news-meta a    { font-size: .82rem; color: var(--accent); font-weight: 700; }
.gallery-grid   { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 16px; }
.gallery-item   { aspect-ratio: 1; border-radius: var(--radius-sm); cursor: pointer; transition: var(--transition); }
.gallery-item:hover { opacity: .82; transform: scale(.97); }
.g1 { background: linear-gradient(135deg,#0A2540,#3AB4A6); }
.g2 { background: linear-gradient(135deg,#C8A046,#0A2540); }
.g3 { background: linear-gradient(135deg,#3AB4A6,#0d3060); }
.g4 { background: linear-gradient(135deg,#0d3060,#C8A046); }
.media-side { display: flex; flex-direction: column; gap: 32px; }
.podcast-item { display: flex; align-items: center; gap: 16px; padding: 14px; border: 1px solid var(--border); border-radius: var(--radius-sm); margin-bottom: 12px; transition: var(--transition); cursor: pointer; }
.podcast-item:hover { border-color: rgba(200,160,70,.3); background: rgba(200,160,70,.04); }
.pod-thumb { width: 44px; height: 44px; background: var(--primary); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1.1rem; flex-shrink: 0; }
.podcast-item h4  { font-size: .85rem; font-weight: 700; color: var(--primary); margin-bottom: 4px; }
.podcast-item span { font-size: .75rem; color: var(--text-muted); }

/* Collab strip */
.home-collab { padding: 100px 0; background: var(--primary); position: relative; overflow: hidden; }
.collab-geo { position: absolute; width: 700px; height: 700px; border-radius: 50%; background: radial-gradient(circle,rgba(200,160,70,.08) 0%,transparent 70%); top:50%; left:50%; transform:translate(-50%,-50%); pointer-events:none; }
.collab-content { position: relative; z-index: 1; text-align: center; }
.collab-content h2 { font-size: clamp(1.8rem,4vw,2.4rem); font-weight:700; color:var(--white); margin-bottom:16px; }
.collab-content > p { color: rgba(255,255,255,.62); max-width: 560px; margin: 0 auto 48px; line-height: 2; }
.collab-cards  { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; margin-bottom: 48px; }
.collab-card   { background: rgba(255,255,255,.04); border: 1px solid rgba(200,160,70,.14); border-radius: var(--radius); padding: 32px 24px; transition: var(--transition); }
.collab-card:hover { background: rgba(200,160,70,.08); border-color: rgba(200,160,70,.4); transform: translateY(-4px); }
.cc-icon { font-size: 2.5rem; margin-bottom: 16px; }
.collab-card h4 { font-size: 1rem; font-weight: 700; color: var(--secondary); margin-bottom: 10px; }
.collab-card p  { font-size: .85rem; color: rgba(255,255,255,.52); line-height: 1.7; }

/* ════════════════ ABOUT ═══════════════════════ */
.mission-grid  { display: grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }
.mission-visual { border-radius:var(--radius); background:linear-gradient(135deg,var(--primary) 0%,#0d3060 60%,var(--accent) 100%); aspect-ratio:4/3; overflow:hidden; position:relative; }
.mv-geo { position:absolute; border-radius:50%; filter:blur(60px); opacity:.18; }
.mv-geo-1 { width:300px; height:300px; background:var(--secondary); top:-60px; right:-60px; }
.mv-geo-2 { width:200px; height:200px; background:var(--accent); bottom:-30px; left:-30px; }
.mv-emblem { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; opacity:.28; }
.mv-bubbles { position:absolute; inset:0; z-index:2; display:flex; flex-direction:column; justify-content:flex-end; gap:12px; padding:28px; }
.mv-bubble { background:rgba(255,255,255,.08); backdrop-filter:blur(12px); border:1px solid rgba(255,255,255,.14); border-radius:var(--radius-sm); padding:12px 16px; display:flex; align-items:center; gap:12px; }
.mv-bubble-num { font-size:1.4rem; font-weight:700; color:var(--secondary); line-height:1; }
.mv-bubble-label { font-size:.8rem; color:rgba(255,255,255,.68); }
.value-list  { display:flex; flex-direction:column; gap:14px; margin-top:8px; }
.value-item  { display:flex; align-items:flex-start; gap:14px; }
.value-icon  { width:40px; height:40px; border-radius:10px; background:rgba(200,160,70,.10); border:1px solid rgba(200,160,70,.25); display:flex; align-items:center; justify-content:center; font-size:1.1rem; flex-shrink:0; }
.value-body h4 { font-size:.9rem; font-weight:700; color:var(--primary); margin-bottom:4px; }
.value-body p  { font-size:.83rem; color:var(--text-light); line-height:1.7; margin:0; }

/* Charter */
.charter-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.charter-card { background:var(--bg); border:1px solid var(--border); border-radius:var(--radius); padding:32px 28px; position:relative; overflow:hidden; }
.charter-card::before { content:''; position:absolute; top:0; right:0; left:0; height:3px; background:linear-gradient(90deg,var(--secondary),var(--accent)); }
.charter-num { font-size:3rem; font-weight:700; color:rgba(200,160,70,.15); line-height:1; margin-bottom:16px; }
.charter-card h3 { font-size:1rem; font-weight:700; color:var(--primary); margin-bottom:12px; }
.charter-card p  { font-size:.85rem; color:var(--text-light); line-height:1.8; margin:0; }

/* Timeline */
.timeline { position:relative; max-width:880px; margin:0 auto; }
.timeline::before { content:''; position:absolute; top:0; bottom:0; right:50%; width:2px; background:linear-gradient(to bottom,var(--secondary),rgba(200,160,70,.1)); }
.tl-item { display:grid; grid-template-columns:1fr 1fr; gap:0 60px; margin-bottom:56px; position:relative; }
.tl-item:nth-child(even) .tl-content { grid-column:2; grid-row:1; }
.tl-item:nth-child(even) .tl-year    { grid-column:1; grid-row:1; text-align:left; }
.tl-dot { position:absolute; top:6px; right:calc(50% - 10px); width:20px; height:20px; border-radius:50%; background:var(--secondary); border:3px solid var(--white); box-shadow:0 0 0 3px rgba(200,160,70,.3); z-index:1; }
.tl-year { font-size:1.8rem; font-weight:700; color:var(--secondary); text-align:right; padding-left:30px; }
.tl-content { background:var(--bg); border:1px solid var(--border); border-radius:var(--radius); padding:20px 24px; margin-right:30px; }
.tl-item:nth-child(even) .tl-content { margin-right:0; margin-left:30px; }
.tl-content h4 { font-size:.95rem; font-weight:700; color:var(--primary); margin-bottom:8px; }
.tl-content p  { font-size:.83rem; color:var(--text-light); line-height:1.7; margin:0; }

/* Team */
.team-tabs { display:flex; gap:8px; justify-content:center; margin-bottom:48px; flex-wrap:wrap; }
.team-tab { background:var(--white); border:1px solid var(--border); color:var(--text-light); padding:10px 24px; border-radius:100px; font-family:inherit; font-size:.88rem; cursor:pointer; transition:var(--transition); }
.team-tab.active, .team-tab:hover { background:var(--primary); color:var(--white); border-color:var(--primary); }
.team-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.member-card { background:var(--white); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; transition:var(--transition); text-align:center; }
.member-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-lg); }
.member-avatar { width:100%; aspect-ratio:1; background:linear-gradient(135deg,var(--primary),var(--accent)); position:relative; overflow:hidden; }
.avatar-ph { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; font-size:3.5rem; opacity:.28; }
.member-info { padding:20px 16px; }
.member-info h3   { font-size:.95rem; font-weight:700; color:var(--primary); margin-bottom:4px; }
.member-info .role { font-size:.78rem; color:var(--secondary); font-weight:700; margin-bottom:6px; }
.member-info .dept { font-size:.75rem; color:var(--text-muted); margin-bottom:10px; }
.member-info .bio  { font-size:.8rem; color:var(--text-light); line-height:1.7; }
.member-links { display:flex; justify-content:center; gap:8px; padding:12px 16px; border-top:1px solid var(--border); }
.member-link { width:32px; height:32px; border-radius:50%; border:1px solid var(--border); background:var(--bg); display:flex; align-items:center; justify-content:center; font-size:.78rem; color:var(--text-muted); transition:var(--transition); }
.member-link:hover { border-color:var(--secondary); color:var(--secondary); }

/* Partners */
.partners-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:20px; margin-top:48px; }
.partner-logo { background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.10); border-radius:var(--radius-sm); aspect-ratio:2/1; display:flex; align-items:center; justify-content:center; font-size:.8rem; color:rgba(255,255,255,.32); font-weight:700; transition:var(--transition); }
.partner-logo:hover { border-color:rgba(200,160,70,.3); color:var(--secondary); }

/* ════════════════ DEPARTMENTS HUB ════════════ */
.dept-hub-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:28px; }
.dept-hub-card { background:var(--white); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; display:flex; transition:var(--transition); }
.dept-hub-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); border-color:rgba(200,160,70,.3); }
.dept-hub-accent { width:6px; flex-shrink:0; background:linear-gradient(to bottom,var(--secondary),var(--accent)); }
.dept-hub-body { padding:28px; flex:1; }
.dept-hub-top { display:flex; align-items:flex-start; gap:16px; margin-bottom:16px; }
.dept-hub-icon { width:52px; height:52px; border-radius:12px; background:rgba(200,160,70,.10); border:1px solid rgba(200,160,70,.25); display:flex; align-items:center; justify-content:center; font-size:1.5rem; flex-shrink:0; }
.dept-hub-title h2 { font-size:1.1rem; font-weight:700; color:var(--primary); margin-bottom:4px; }
.dept-hub-title .sub { font-size:.75rem; color:var(--text-muted); }
.dept-hub-desc { font-size:.85rem; color:var(--text-light); line-height:1.8; margin-bottom:18px; }
.dept-hub-stats { display:flex; gap:20px; margin-bottom:18px; }
.dhs-item .n { font-size:1.3rem; font-weight:700; color:var(--secondary); line-height:1; }
.dhs-item .l { font-size:.72rem; color:var(--text-muted); }
.dept-hub-footer { display:flex; align-items:center; justify-content:space-between; padding-top:16px; border-top:1px solid var(--border); }
.mini-avatars { display:flex; }
.mini-av { width:26px; height:26px; border-radius:50%; background:linear-gradient(135deg,var(--primary),var(--accent)); border:2px solid var(--white); margin-left:-6px; }
.mini-av:first-child { margin-left:0; }
.dept-link-btn { font-size:.82rem; color:var(--accent); font-weight:700; transition:var(--transition); }
.dept-link-btn:hover { color:var(--secondary); }
/* Featured dept on hub */
.dept-hub-card.featured { background:linear-gradient(135deg,var(--primary),#0d3060); border-color:rgba(200,160,70,.3); }
.dept-hub-card.featured .dept-hub-title h2, .dept-hub-card.featured .dept-hub-desc { color:var(--white); }
.dept-hub-card.featured .dept-hub-title .sub { color:rgba(255,255,255,.42); }
.dept-hub-card.featured .dhs-item .l { color:rgba(255,255,255,.42); }
.dept-hub-card.featured .dept-hub-footer { border-top-color:rgba(255,255,255,.10); }
.dept-hub-card.featured .mini-av { border-color:rgba(10,37,64,.8); }
.dept-hub-card.featured.full-width { grid-column:1/-1; }

/* ════════════════ DEPT SINGLE ═════════════════ */
.dept-banner { padding:140px 0 0; background:var(--primary); position:relative; overflow:hidden; }
.dept-banner-grid { position:absolute; inset:0; background-image:linear-gradient(rgba(200,160,70,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(200,160,70,.06) 1px,transparent 1px); background-size:56px 56px; }
.dept-banner-glow { position:absolute; width:600px; height:600px; border-radius:50%; background:radial-gradient(circle,rgba(58,180,166,.12) 0%,transparent 65%); top:-150px; left:-100px; pointer-events:none; }
.dept-banner-inner { position:relative; z-index:1; }
.dept-banner-top { display:grid; grid-template-columns:auto 1fr; gap:24px; align-items:flex-start; margin-bottom:32px; }
.dept-big-icon { width:80px; height:80px; border-radius:20px; background:rgba(200,160,70,.12); border:1px solid rgba(200,160,70,.35); display:flex; align-items:center; justify-content:center; font-size:2.5rem; flex-shrink:0; }
.dept-banner-info h1 { font-size:clamp(1.8rem,4vw,2.8rem); font-weight:700; color:var(--white); margin-bottom:10px; }
.dept-banner-info p  { font-size:1rem; color:rgba(255,255,255,.62); max-width:640px; line-height:1.9; }
.dept-banner-stats { display:flex; gap:0; border-top:1px solid rgba(255,255,255,.08); margin-top:32px; }
.dbs-stat { flex:1; padding:24px 0; text-align:center; border-left:1px solid rgba(255,255,255,.08); }
.dbs-stat:last-child { border-left:none; }
.dbs-stat .n { font-size:2rem; font-weight:700; color:var(--secondary); line-height:1; }
.dbs-stat .l { font-size:.78rem; color:rgba(255,255,255,.42); margin-top:4px; }
.dept-tab-bar { background:var(--primary); border-bottom:1px solid rgba(200,160,70,.14); position:sticky; top:var(--header-h); z-index:100; }
.dept-tabs-row { display:flex; gap:0; overflow-x:auto; }
.d-tab { padding:16px 24px; color:rgba(255,255,255,.48); font-size:.88rem; font-family:inherit; background:none; border:none; border-bottom:2px solid transparent; cursor:pointer; white-space:nowrap; transition:var(--transition); }
.d-tab.active, .d-tab:hover { color:var(--secondary); border-bottom-color:var(--secondary); }
.info-block { background:var(--white); border:1px solid var(--border); border-radius:var(--radius); padding:32px; margin-bottom:28px; }
.info-block h3 { font-size:1.1rem; font-weight:700; color:var(--primary); margin-bottom:16px; }
.info-block p  { font-size:.88rem; color:var(--text-light); line-height:1.9; }
.info-block ul { padding-right:20px; }
.info-block ul li { font-size:.88rem; color:var(--text-light); line-height:1.9; list-style:disc; }
.res-row { background:var(--white); border:1px solid var(--border); border-radius:var(--radius-sm); padding:20px 24px; display:flex; gap:20px; align-items:center; transition:var(--transition); margin-bottom:12px; }
.res-row:hover { border-color:rgba(200,160,70,.3); box-shadow:var(--shadow); }
.res-row-body { flex:1; }
.res-row-body h4 { font-size:.92rem; font-weight:700; color:var(--primary); margin-bottom:6px; line-height:1.5; }
.res-row-meta { font-size:.78rem; color:var(--text-muted); display:flex; gap:14px; }
.icon-btn { width:34px; height:34px; border-radius:8px; border:1px solid var(--border); background:var(--bg); display:flex; align-items:center; justify-content:center; font-size:.85rem; cursor:pointer; transition:var(--transition); text-decoration:none; color:var(--text); }
.icon-btn:hover { border-color:var(--secondary); background:rgba(200,160,70,.08); }
.team-mini-card { display:flex; align-items:center; gap:12px; background:var(--bg); border:1px solid var(--border); border-radius:var(--radius-sm); padding:12px 14px; margin-bottom:10px; transition:var(--transition); }
.team-mini-card:hover { border-color:rgba(200,160,70,.3); }
.tm-av { width:40px; height:40px; border-radius:50%; background:linear-gradient(135deg,var(--primary),var(--accent)); flex-shrink:0; }
.tm-info h5   { font-size:.82rem; font-weight:700; color:var(--primary); margin-bottom:2px; }
.tm-info span { font-size:.72rem; color:var(--text-muted); }
.ev-mini { background:var(--bg); border:1px solid var(--border); border-radius:var(--radius-sm); padding:12px 14px; margin-bottom:10px; }
.ev-mini-date { font-size:.72rem; color:var(--secondary); font-weight:700; margin-bottom:4px; }
.ev-mini h5   { font-size:.82rem; color:var(--primary); font-weight:700; line-height:1.5; }

/* ════════════════ RESEARCH LIST ═══════════════ */
.featured-res {
  background:linear-gradient(135deg,var(--primary) 0%,#0d3060 100%);
  border-radius:var(--radius); padding:36px; margin-bottom:32px;
  display:grid; grid-template-columns:1fr auto; gap:32px; align-items:center;
  border:1px solid rgba(200,160,70,.25);
}
.featured-res h2 { font-size:1.5rem; font-weight:700; color:var(--white); margin-bottom:12px; line-height:1.5; }
.featured-res p  { font-size:.88rem; color:rgba(255,255,255,.62); line-height:1.9; margin-bottom:20px; }
.featured-res-meta { display:flex; gap:16px; margin-bottom:20px; flex-wrap:wrap; }
.featured-res-meta span { font-size:.78rem; color:rgba(255,255,255,.42); }
.featured-res-ctas { display:flex; gap:12px; flex-wrap:wrap; }
.pdf-preview { width:120px; aspect-ratio:3/4; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.10); border-radius:8px; display:flex; align-items:center; justify-content:center; font-size:2.5rem; }
.dl-pill { background:var(--secondary); color:var(--primary); border:none; padding:10px 20px; border-radius:var(--radius-sm); font-family:inherit; font-weight:700; font-size:.88rem; cursor:pointer; margin-top:8px; width:100%; text-align:center; transition:var(--transition); }
.dl-pill:hover { background:var(--secondary-light); }

/* ════════════════ RESEARCH SINGLE ════════════ */
.article-layout { display:grid; grid-template-columns:1fr 320px; gap:56px; padding:64px 0 96px; align-items:start; }
.article-header  { margin-bottom:40px; }
.article-tags    { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:18px; }
.article-title   { font-size:clamp(1.6rem,4vw,2.4rem); font-weight:700; color:var(--primary); line-height:1.4; margin-bottom:20px; }
.article-meta    { display:flex; align-items:center; gap:20px; flex-wrap:wrap; padding:20px 0; border-top:1px solid var(--border); border-bottom:1px solid var(--border); margin-bottom:28px; }
.article-meta .author-chip .author-avatar { width:36px; height:36px; }
.author-chip-info .name { font-size:.85rem; font-weight:700; color:var(--primary); }
.author-chip-info .role { font-size:.75rem; color:var(--text-muted); }
.meta-item .lbl  { font-size:.75rem; color:var(--text-muted); }
.meta-item .val  { font-size:.85rem; font-weight:700; color:var(--text); }
.article-share   { display:flex; align-items:center; gap:10px; margin-bottom:32px; }
.article-share span { font-size:.82rem; color:var(--text-muted); }
.share-btn { width:36px; height:36px; border-radius:50%; border:1px solid var(--border); background:var(--white); display:flex; align-items:center; justify-content:center; font-size:.85rem; cursor:pointer; transition:var(--transition); }
.share-btn:hover { border-color:var(--secondary); color:var(--secondary); }
.article-body          { font-size:.95rem; color:var(--text); line-height:2.0; }
.article-body h2       { font-size:1.3rem; font-weight:700; color:var(--primary); margin:36px 0 14px; padding-bottom:10px; border-bottom:2px solid rgba(200,160,70,.28); }
.article-body h3       { font-size:1.1rem; font-weight:700; color:var(--primary); margin:28px 0 10px; }
.article-body p        { margin-bottom:18px; }
.article-body ul, .article-body ol { padding-right:24px; margin-bottom:18px; }
.article-body li       { margin-bottom:8px; }
.article-body ul li    { list-style:disc; }
.article-body ol li    { list-style:decimal; }
.article-body blockquote { border-right:4px solid var(--secondary); padding:16px 20px; background:rgba(200,160,70,.06); border-radius:0 var(--radius-sm) var(--radius-sm) 0; margin:24px 0; font-size:1.05rem; color:var(--primary); font-style:italic; line-height:1.9; }
.article-body blockquote cite { display:block; font-size:.78rem; color:var(--text-muted); margin-top:8px; font-style:normal; }
.data-box { background:linear-gradient(135deg,var(--primary),#0d3060); border-radius:var(--radius); padding:28px; margin:32px 0; border:1px solid rgba(200,160,70,.2); }
.data-box h4 { color:var(--secondary); font-size:.88rem; margin-bottom:16px; }
.data-row { display:flex; align-items:center; gap:12px; margin-bottom:12px; }
.data-bar-wrap { flex:1; height:6px; background:rgba(255,255,255,.10); border-radius:3px; overflow:hidden; }
.data-bar { height:100%; background:linear-gradient(90deg,var(--secondary),var(--accent)); border-radius:3px; }
.data-label { font-size:.78rem; color:rgba(255,255,255,.58); min-width:120px; }
.data-pct   { font-size:.78rem; color:var(--secondary); font-weight:700; min-width:36px; text-align:left; }
.article-footer  { margin-top:48px; padding-top:32px; border-top:1px solid var(--border); }
.keywords        { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:28px; }
.keyword-tag     { background:rgba(10,37,64,.06); border:1px solid rgba(10,37,64,.12); color:var(--primary); padding:5px 14px; border-radius:100px; font-size:.78rem; transition:var(--transition); cursor:pointer; }
.keyword-tag:hover { background:var(--primary); color:var(--white); }
.cite-box        { background:var(--bg); border:1px solid var(--border); border-radius:var(--radius-sm); padding:16px 20px; }
.cite-box h5     { font-size:.82rem; font-weight:700; color:var(--primary); margin-bottom:8px; }
.cite-box pre    { font-size:.75rem; color:var(--text-muted); line-height:1.6; direction:ltr; text-align:left; white-space:pre-wrap; }
.cite-copy       { background:none; border:1px solid var(--border); padding:5px 12px; border-radius:6px; font-size:.75rem; cursor:pointer; color:var(--text-light); margin-top:8px; font-family:inherit; transition:var(--transition); }
.cite-copy:hover { border-color:var(--secondary); color:var(--secondary); }
/* Sticky sidebar article */
.sticky-sidebar  { position:sticky; top:calc(var(--header-h) + 24px); display:flex; flex-direction:column; gap:24px; }
.dl-box { background:linear-gradient(135deg,var(--primary),#0d3060); border:1px solid rgba(200,160,70,.25); border-radius:var(--radius); padding:24px; }
.dl-box h4  { color:var(--white); font-size:.92rem; font-weight:700; margin-bottom:16px; }
.dl-btn     { display:block; width:100%; padding:12px; border-radius:var(--radius-sm); font-family:inherit; font-weight:700; font-size:.88rem; cursor:pointer; margin-bottom:8px; transition:var(--transition); text-align:center; border:none; }
.dl-btn.solid   { background:var(--secondary); color:var(--primary); }
.dl-btn.solid:hover { background:var(--secondary-light); }
.dl-btn.ghost   { background:rgba(255,255,255,.06); color:rgba(255,255,255,.68); border:1px solid rgba(255,255,255,.14) !important; }
.dl-btn.ghost:hover { background:rgba(255,255,255,.12); color:var(--white); }
.dl-info { font-size:.75rem; color:rgba(255,255,255,.38); margin-top:10px; line-height:1.6; }
.toc-list a { display:block; padding:10px 20px; font-size:.83rem; color:var(--text-light); border-right:3px solid transparent; transition:var(--transition); }
.toc-list a:hover, .toc-list a.active { color:var(--primary); border-right-color:var(--secondary); background:rgba(200,160,70,.05); }
.toc-list a.h3 { padding-right:32px; font-size:.78rem; }

/* ════════════════ EVENTS ══════════════════════ */
.events-hero-stats { display:flex; gap:32px; flex-wrap:wrap; margin-top:32px; }
.ehs { text-align:center; }
.ehs .n { font-size:2rem; font-weight:700; color:var(--secondary); line-height:1; }
.ehs .l { font-size:.78rem; color:rgba(255,255,255,.42); margin-top:4px; }
.events-list-grid { display:flex; flex-direction:column; gap:20px; }
.event-row { background:var(--white); border:1px solid var(--border); border-radius:var(--radius); padding:24px 28px; display:grid; grid-template-columns:80px 1fr auto; gap:24px; align-items:center; transition:var(--transition); }
.event-row:hover { box-shadow:var(--shadow-lg); border-color:rgba(200,160,70,.3); transform:translateY(-2px); }
.event-row-date { text-align:center; background:var(--primary); border-radius:var(--radius-sm); padding:12px 8px; }
.event-row-date .day   { font-size:1.8rem; font-weight:700; color:var(--secondary); line-height:1; display:block; }
.event-row-date .month { font-size:.72rem; color:rgba(255,255,255,.55); }
.event-row-body h3 { font-size:1rem; font-weight:700; color:var(--primary); margin-bottom:8px; line-height:1.5; }
.event-row-meta { display:flex; gap:16px; flex-wrap:wrap; }
.event-row-meta span { font-size:.78rem; color:var(--text-muted); }
.event-row-actions { display:flex; flex-direction:column; gap:8px; align-items:flex-end; min-width:120px; }
/* Event Single */
.event-single-layout { display:grid; grid-template-columns:1fr 300px; gap:48px; padding:64px 0 96px; align-items:start; }
.event-detail-box { background:var(--white); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; margin-bottom:28px; }
.edb-header { background:var(--primary); padding:20px 24px; }
.edb-header h3 { color:var(--white); font-size:.95rem; font-weight:700; }
.edb-body   { padding:20px 24px; }
.edb-row    { display:flex; gap:12px; padding:10px 0; border-bottom:1px solid var(--border); align-items:flex-start; }
.edb-row:last-child { border-bottom:none; }
.edb-row .lbl { font-size:.78rem; color:var(--text-muted); min-width:80px; padding-top:2px; }
.edb-row .val { font-size:.85rem; color:var(--primary); font-weight:700; }
.speakers-list { display:flex; flex-direction:column; gap:14px; }
.speaker-card  { display:flex; align-items:center; gap:14px; background:var(--bg); border:1px solid var(--border); border-radius:var(--radius-sm); padding:14px; }
.speaker-av    { width:48px; height:48px; border-radius:50%; background:linear-gradient(135deg,var(--primary),var(--accent)); flex-shrink:0; }
.speaker-info h4 { font-size:.88rem; font-weight:700; color:var(--primary); margin-bottom:2px; }
.speaker-info span { font-size:.75rem; color:var(--text-muted); }

/* ════════════════ MEDIA ════════════════════════ */
.media-grid-layout { display:grid; grid-template-columns:1fr 300px; gap:48px; align-items:start; }
.news-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:24px; }
.news-card { background:var(--white); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; transition:var(--transition); }
.news-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); border-color:rgba(200,160,70,.3); }
.news-card-thumb { width:100%; aspect-ratio:16/9; background:linear-gradient(135deg,var(--primary),var(--accent)); }
.news-card-body  { padding:24px; }
.news-card h3    { font-size:1rem; font-weight:700; color:var(--primary); margin:10px 0; line-height:1.6; }
.news-card p     { font-size:.85rem; color:var(--text-light); line-height:1.8; margin-bottom:16px; }
.news-card-footer { display:flex; align-items:center; justify-content:space-between; padding-top:14px; border-top:1px solid var(--border); }
/* News Single */
.news-article-layout { display:grid; grid-template-columns:1fr 300px; gap:48px; padding:64px 0 96px; align-items:start; }

/* ════════════════ CONTACT ══════════════════════ */
.contact-layout { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:start; padding:80px 0 96px; }
.contact-form-wrap { background:var(--white); border:1px solid var(--border); border-radius:var(--radius); padding:36px; }
.contact-form-wrap h2 { font-size:1.5rem; font-weight:700; color:var(--primary); margin-bottom:8px; }
.contact-form-wrap > p { font-size:.88rem; color:var(--text-light); margin-bottom:28px; }
.form-group { margin-bottom:20px; }
.form-group label { display:block; font-size:.85rem; font-weight:700; color:var(--primary); margin-bottom:8px; }
.form-group input,
.form-group select,
.form-group textarea {
  width:100%; background:var(--bg); border:1.5px solid var(--border);
  color:var(--text); padding:12px 16px; border-radius:var(--radius-sm);
  font-family:inherit; font-size:.9rem; direction:rtl; transition:var(--transition);
}
.form-group textarea { resize:vertical; min-height:130px; }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { outline:none; border-color:var(--primary); box-shadow:0 0 0 3px rgba(10,37,64,.07); }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-submit { width:100%; background:var(--primary); color:var(--white); border:none; padding:14px; border-radius:var(--radius-sm); font-family:inherit; font-size:.95rem; font-weight:700; cursor:pointer; transition:var(--transition); }
.form-submit:hover { background:var(--primary-light); transform:translateY(-1px); box-shadow:0 8px 24px rgba(10,37,64,.25); }
.contact-info-wrap { display:flex; flex-direction:column; gap:32px; }
.contact-info-card { background:var(--white); border:1px solid var(--border); border-radius:var(--radius); padding:28px; }
.contact-info-card h3 { font-size:1rem; font-weight:700; color:var(--primary); margin-bottom:20px; display:flex; align-items:center; gap:10px; }
.contact-detail { display:flex; gap:14px; margin-bottom:18px; align-items:flex-start; }
.contact-detail-icon { width:40px; height:40px; border-radius:10px; background:rgba(200,160,70,.10); border:1px solid rgba(200,160,70,.25); display:flex; align-items:center; justify-content:center; font-size:1.1rem; flex-shrink:0; }
.contact-detail-info h5 { font-size:.85rem; font-weight:700; color:var(--primary); margin-bottom:3px; }
.contact-detail-info p  { font-size:.83rem; color:var(--text-light); line-height:1.6; }
.map-placeholder { width:100%; aspect-ratio:16/9; background:linear-gradient(135deg,var(--primary) 0%,var(--accent) 100%); border-radius:var(--radius); display:flex; align-items:center; justify-content:center; font-size:.85rem; color:rgba(255,255,255,.5); font-weight:700; position:relative; overflow:hidden; }
.map-overlay-text { text-align:center; }
.map-overlay-text .map-icon { font-size:3rem; display:block; margin-bottom:8px; }

/* ════════════════ LOGIN ════════════════════════ */
body.login-page { min-height:100vh; display:flex; background:var(--primary); overflow:hidden; }
.login-split { display:flex; width:100%; min-height:100vh; }
.login-visual { flex:1; background:var(--primary); position:relative; overflow:hidden; display:flex; flex-direction:column; justify-content:flex-end; padding:60px; }
.lv-grid { position:absolute; inset:0; background-image:linear-gradient(rgba(200,160,70,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(200,160,70,.07) 1px,transparent 1px); background-size:56px 56px; }
.lv-glow-1 { position:absolute; width:500px; height:500px; border-radius:50%; background:radial-gradient(circle,rgba(200,160,70,.18) 0%,transparent 70%); top:-100px; right:-100px; pointer-events:none; filter:blur(80px); }
.lv-glow-2 { position:absolute; width:400px; height:400px; border-radius:50%; background:radial-gradient(circle,rgba(58,180,166,.12) 0%,transparent 70%); bottom:100px; left:-50px; pointer-events:none; filter:blur(80px); }
.lv-emblem-bg { position:absolute; top:50%; left:50%; transform:translate(-50%,-55%); opacity:.06; }
.lv-emblem-bg svg { width:480px; height:480px; }
.lv-content { position:relative; z-index:1; }
.lv-logo { display:flex; align-items:center; gap:14px; margin-bottom:48px; }
.lv-quote { border-right:3px solid var(--secondary); padding-right:20px; margin-bottom:48px; }
.lv-quote blockquote { font-size:1.4rem; font-weight:300; color:rgba(255,255,255,.85); line-height:1.8; margin-bottom:12px; }
.lv-quote cite { font-size:.82rem; color:rgba(255,255,255,.38); font-style:normal; }
.lv-stats { display:flex; gap:32px; }
.lv-stat-num { font-size:2rem; font-weight:700; color:var(--secondary); line-height:1; display:block; }
.lv-stat-lbl { font-size:.75rem; color:rgba(255,255,255,.38); margin-top:4px; }
.login-panel-wrap { width:480px; flex-shrink:0; background:var(--bg); display:flex; flex-direction:column; justify-content:center; padding:60px 48px; position:relative; overflow-y:auto; }
.login-panel-wrap::before { content:''; position:absolute; top:0; bottom:0; right:0; width:1px; background:linear-gradient(to bottom,transparent,rgba(200,160,70,.3) 20%,rgba(200,160,70,.3) 80%,transparent); }
.back-link { position:absolute; top:24px; left:24px; font-size:.82rem; color:var(--text-light); display:flex; align-items:center; gap:6px; transition:var(--transition); }
.back-link:hover { color:var(--primary); }
.login-head h1 { font-size:1.9rem; font-weight:700; color:var(--primary); margin-bottom:8px; }
.login-head p  { color:var(--text-light); font-size:.9rem; margin-bottom:32px; }
.login-tabs    { display:flex; gap:0; background:rgba(10,37,64,.06); border-radius:var(--radius-sm); padding:4px; margin-bottom:28px; }
.ltab { flex:1; background:none; border:none; padding:10px 16px; border-radius:6px; font-family:inherit; font-size:.88rem; color:var(--text-light); cursor:pointer; transition:var(--transition); }
.ltab.active { background:var(--white); color:var(--primary); font-weight:700; box-shadow:0 2px 8px rgba(10,37,64,.10); }
.field-wrap { position:relative; }
.field-wrap input { width:100%; background:var(--white); border:1.5px solid var(--border); color:var(--text); padding:12px 44px 12px 16px; border-radius:var(--radius-sm); font-family:inherit; font-size:.9rem; direction:rtl; transition:var(--transition); }
.field-wrap input:focus { outline:none; border-color:var(--primary); box-shadow:0 0 0 3px rgba(10,37,64,.07); }
.field-icon { position:absolute; left:14px; top:50%; transform:translateY(-50%); color:var(--text-muted); pointer-events:none; font-size:1rem; }
.toggle-pass { position:absolute; left:14px; top:50%; transform:translateY(-50%); background:none; border:none; cursor:pointer; color:var(--text-muted); font-size:.9rem; transition:var(--transition); }
.toggle-pass:hover { color:var(--primary); }
.form-options { display:flex; justify-content:space-between; align-items:center; margin-bottom:20px; }
.remember-me  { display:flex; align-items:center; gap:8px; cursor:pointer; }
.remember-me span { font-size:.83rem; color:var(--text-light); }
.forgot-link  { font-size:.83rem; color:var(--accent); font-weight:700; }
.captcha-box { display:flex; align-items:center; gap:12px; background:var(--white); border:1.5px solid var(--border); border-radius:var(--radius-sm); padding:12px 16px; margin-bottom:20px; }
.captcha-logo { margin-right:auto; display:flex; flex-direction:column; align-items:center; font-size:.6rem; color:var(--text-muted); }
.login-submit { width:100%; background:var(--primary); color:var(--white); border:none; padding:14px; border-radius:var(--radius-sm); font-family:inherit; font-size:.95rem; font-weight:700; cursor:pointer; transition:var(--transition); margin-bottom:18px; }
.login-submit:hover { background:var(--primary-light); transform:translateY(-1px); box-shadow:0 8px 24px rgba(10,37,64,.28); }
.or-divider { display:flex; align-items:center; gap:12px; margin-bottom:18px; }
.or-divider::before, .or-divider::after { content:''; flex:1; height:1px; background:var(--border); }
.or-divider span { font-size:.78rem; color:var(--text-muted); white-space:nowrap; }
.sso-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:24px; }
.sso-btn { display:flex; align-items:center; justify-content:center; gap:8px; background:var(--white); border:1.5px solid var(--border); padding:10px 16px; border-radius:var(--radius-sm); font-family:inherit; font-size:.82rem; color:var(--text); cursor:pointer; transition:var(--transition); }
.sso-btn:hover { border-color:var(--primary); color:var(--primary); }
.login-footer-link { text-align:center; font-size:.85rem; color:var(--text-light); }
.login-footer-link a { color:var(--primary); font-weight:700; }
.login-alert { background:rgba(239,68,68,.08); border:1px solid rgba(239,68,68,.25); border-radius:var(--radius-sm); padding:12px 16px; font-size:.85rem; color:#c53030; margin-bottom:18px; display:none; }
.login-alert.show { display:block; }
.login-progress { height:3px; background:var(--border); border-radius:2px; margin-bottom:24px; overflow:hidden; display:none; }
.login-progress.active { display:block; }
.progress-bar { height:100%; width:0; background:linear-gradient(90deg,var(--primary),var(--secondary)); border-radius:2px; transition:width 1.8s ease; }
.login-success { text-align:center; padding:20px; display:none; }
.login-success.show { display:block; }

/* ════════════════ RESPONSIVE PAGES ═══════════ */
@media (max-width:1100px) {
  .dept-grid { grid-template-columns:repeat(2,1fr); }
  .team-grid { grid-template-columns:repeat(2,1fr); }
  .partners-grid { grid-template-columns:repeat(3,1fr); }
  .charter-grid { grid-template-columns:repeat(2,1fr); }
  .stats-strip .stats-grid { grid-template-columns:repeat(2,1fr); }
  .events-grid { grid-template-columns:repeat(2,1fr); }
  .news-grid { grid-template-columns:1fr; }
  .featured-res { grid-template-columns:1fr; }
  .featured-res-right { display:none; }
  .article-layout { grid-template-columns:1fr; }
  .sticky-sidebar { position:static; }
  .event-single-layout { grid-template-columns:1fr; }
  .media-grid-layout { grid-template-columns:1fr; }
  .news-article-layout { grid-template-columns:1fr; }
}
@media (max-width:900px) {
  .mission-grid { grid-template-columns:1fr; }
  .contact-layout { grid-template-columns:1fr; }
  .dept-hub-grid { grid-template-columns:1fr; }
  .timeline::before { right:20px; }
  .tl-item { grid-template-columns:1fr; padding-right:52px; }
  .tl-item .tl-year, .tl-item:nth-child(even) .tl-year { text-align:right; grid-column:1; font-size:1.3rem; }
  .tl-dot { right:10px; }
  .tl-content, .tl-item:nth-child(even) .tl-content { margin:0; grid-column:1; }
  .dept-banner-top { grid-template-columns:1fr; }
  .dept-banner-stats { flex-wrap:wrap; }
  .dbs-stat { min-width:50%; }
  .collab-cards { grid-template-columns:1fr; }
  .media-layout { grid-template-columns:1fr; }
}
@media (max-width:640px) {
  .dept-grid { grid-template-columns:1fr; }
  .team-grid { grid-template-columns:1fr 1fr; }
  .partners-grid { grid-template-columns:repeat(2,1fr); }
  .charter-grid { grid-template-columns:1fr; }
  .stats-strip .stats-grid { grid-template-columns:1fr 1fr; }
  .events-grid { grid-template-columns:1fr; }
  .hero-cta { flex-direction:column; align-items:center; }
  .news-item.big { grid-template-columns:1fr; }
  .event-row { grid-template-columns:60px 1fr; }
  .event-row-actions { display:none; }
  .form-row { grid-template-columns:1fr; }
  .login-visual { display:none; }
  .login-panel-wrap { width:100%; padding:40px 24px; }
  .sso-grid { grid-template-columns:1fr; }
}