/* ═══════════════════════════════════════════════════════
   IFDO Funding Intelligence Platform - Global Styles v2
   Responsive: Desktop + Tablet + Mobile
   ═══════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Cairo:wght@300;400;500;600;700;800;900&family=Inter:wght@300;400;500;600;700;800;900&display=swap');

/* ── Variables ─────────────────────────────────────────── */
:root {
  --primary:#2563EB; --primary-dark:#1D4ED8; --primary-light:#3B82F6;
  --secondary:#F59E0B; --accent:#10B981; --danger:#EF4444; --purple:#8B5CF6;
  --dark:#0F172A; --dark-2:#1E293B; --dark-3:#334155;
  --gray:#64748B; --gray-light:#94A3B8; --border:#E2E8F0;
  --bg:#F8FAFC; --white:#FFFFFF;
  --shadow-sm:0 1px 3px rgba(0,0,0,.08);
  --shadow:0 4px 6px -1px rgba(0,0,0,.07),0 2px 4px -1px rgba(0,0,0,.05);
  --shadow-lg:0 20px 25px -5px rgba(0,0,0,.1),0 10px 10px -5px rgba(0,0,0,.04);
  --shadow-xl:0 25px 50px -12px rgba(0,0,0,.25);
  --radius-sm:8px; --radius:12px; --radius-lg:16px; --radius-xl:20px;
  --sidebar-w:260px;
  --navbar-h:70px;
  --transition:.2s ease;
}

/* ── Reset ─────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Cairo','Inter',sans-serif;background:var(--bg);color:var(--dark);line-height:1.6;min-height:100vh;overflow-x:hidden}
body[dir="ltr"]{font-family:'Inter','Cairo',sans-serif}
img{max-width:100%;height:auto;display:block}
button,input,select,textarea{font-family:inherit}
a{text-decoration:none;color:inherit}

/* ── Scrollbar ─────────────────────────────────────────── */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:#f1f5f9}
::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:#94a3b8}

/* ── Animations ────────────────────────────────────────── */
@keyframes fadeIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
@keyframes fadeInScale{from{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}
@keyframes slideInRight{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:none}}
@keyframes slideInLeft{from{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:none}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.45}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes shimmer{0%{background-position:-1000px 0}100%{background-position:1000px 0}}
@keyframes countUp{from{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}
@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
@keyframes drawBar{from{width:0}to{width:var(--w)}}

.anim-fade{animation:fadeIn .6s ease-out both}
.anim-scale{animation:fadeInScale .3s ease-out both}
.anim-float{animation:float 3s ease-in-out infinite}
.anim-pulse{animation:pulse 2s ease-in-out infinite}
.anim-spin{animation:spin 1s linear infinite}

/* ══════════════════════════════════════════════════════════
   NAVBAR
══════════════════════════════════════════════════════════ */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  height:var(--navbar-h);
  background:rgba(255,255,255,.97);
  backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  padding:0 1.5rem;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  transition:box-shadow var(--transition);
}
.navbar.scrolled{box-shadow:0 4px 20px rgba(0,0,0,.08)}

.navbar-brand{display:flex;align-items:center;gap:10px;cursor:pointer;flex-shrink:0}
.navbar-logo{width:40px;height:40px;border-radius:10px;object-fit:contain}
.navbar-title{font-size:1rem;font-weight:700;color:var(--primary);line-height:1.2}
.navbar-subtitle{font-size:.62rem;color:var(--gray);font-weight:400}

.navbar-nav{display:flex;align-items:center;gap:4px;list-style:none}
.nav-link{
  padding:8px 14px;border-radius:var(--radius-sm);
  font-size:.84rem;font-weight:500;color:var(--dark-3);
  cursor:pointer;border:none;background:none;white-space:nowrap;
  transition:all var(--transition);
}
.nav-link:hover{color:var(--primary);background:#EFF6FF}
.nav-link.active{color:var(--primary);background:#EFF6FF;font-weight:600}

.navbar-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}

/* Hamburger */
.hamburger{
  display:none;flex-direction:column;justify-content:center;gap:5px;
  width:36px;height:36px;border:none;background:none;cursor:pointer;
  padding:4px;border-radius:var(--radius-sm);
  transition:background var(--transition);
}
.hamburger:hover{background:var(--bg)}
.hamburger span{width:22px;height:2px;background:var(--dark-3);border-radius:2px;transition:all .3s}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* Mobile Nav Drawer */
.mobile-nav{
  position:fixed;top:var(--navbar-h);left:0;right:0;bottom:0;
  background:white;z-index:999;
  padding:20px;
  transform:translateX(-100%);
  transition:transform .3s ease;
  overflow-y:auto;
  border-top:1px solid var(--border);
}
.mobile-nav.open{transform:translateX(0)}
.mobile-nav-item{
  display:block;padding:14px 16px;border-radius:var(--radius);
  font-size:.95rem;font-weight:600;color:var(--dark-3);
  cursor:pointer;border:none;background:none;width:100%;text-align:right;
  margin-bottom:4px;transition:all var(--transition);
}
.mobile-nav-item:hover{background:#EFF6FF;color:var(--primary)}
.mobile-nav-item.active{background:#EFF6FF;color:var(--primary)}

/* ══════════════════════════════════════════════════════════
   BUTTONS
══════════════════════════════════════════════════════════ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:7px;
  padding:10px 22px;border-radius:var(--radius);
  font-size:.875rem;font-weight:600;cursor:pointer;
  transition:all var(--transition);border:2px solid transparent;
  white-space:nowrap;font-family:inherit;line-height:1;
}
.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}
.btn-primary:hover{background:var(--primary-dark);border-color:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px rgba(37,99,235,.4)}
.btn-secondary{background:#fff;color:var(--primary);border-color:var(--primary)}
.btn-secondary:hover{background:#EFF6FF;transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--gray);border-color:var(--border)}
.btn-ghost:hover{background:var(--bg);color:var(--dark);border-color:var(--gray-light)}
.btn-success{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn-success:hover{background:#059669}
.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger)}
.btn-warning{background:var(--secondary);color:#fff;border-color:var(--secondary)}
.btn-dark{background:var(--dark);color:#fff;border-color:var(--dark)}
.btn-lg{padding:14px 30px;font-size:1rem;border-radius:var(--radius-lg)}
.btn-sm{padding:6px 14px;font-size:.8rem;border-radius:var(--radius-sm)}
.btn-xs{padding:4px 10px;font-size:.73rem;border-radius:6px}
.btn-icon{padding:9px;border-radius:var(--radius)}
.btn-full{width:100%}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}

/* ══════════════════════════════════════════════════════════
   LANG TOGGLE
══════════════════════════════════════════════════════════ */
.lang-toggle{
  display:flex;align-items:center;gap:5px;
  padding:6px 12px;border-radius:var(--radius-sm);
  border:1px solid var(--border);background:#fff;
  font-size:.78rem;font-weight:700;cursor:pointer;
  color:var(--dark-3);transition:all var(--transition);
}
.lang-toggle:hover{border-color:var(--primary);color:var(--primary)}

/* ══════════════════════════════════════════════════════════
   HERO
══════════════════════════════════════════════════════════ */
.hero{
  min-height:100vh;
  background:linear-gradient(135deg,#0F172A 0%,#1E3A8A 55%,#1D4ED8 100%);
  background-size:400% 400%;
  animation:gradientShift 9s ease infinite;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:calc(var(--navbar-h) + 60px) 1.5rem 70px;
  position:relative;overflow:hidden;
}
.hero::before{
  content:'';position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Ccircle cx='30' cy='30' r='2'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
  pointer-events:none;
}

.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.1);backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.2);color:#fff;
  padding:8px 20px;border-radius:50px;font-size:.83rem;font-weight:600;
  margin-bottom:1.8rem;animation:fadeIn .6s ease-out;
}
.hero-badge .dot{width:8px;height:8px;background:#22C55E;border-radius:50%;animation:pulse 2s infinite}

.hero h1{
  font-size:clamp(2rem,5vw,4.2rem);font-weight:900;color:#fff;
  line-height:1.15;margin-bottom:1.4rem;animation:fadeIn .6s .2s both;
}
.hero h1 .highlight{
  background:linear-gradient(135deg,#F59E0B,#EF4444);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.hero-subtitle{
  font-size:clamp(.9rem,2vw,1.2rem);color:rgba(255,255,255,.8);
  max-width:680px;margin:0 auto 2.5rem;line-height:1.85;
  animation:fadeIn .6s .4s both;
}
.hero-ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:3.5rem;animation:fadeIn .6s .6s both}
.hero-stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px;
  max-width:780px;width:100%;animation:fadeIn .6s .8s both;
}
.hero-stat{
  background:rgba(255,255,255,.08);backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-lg);
  padding:18px 12px;text-align:center;transition:all .3s;
}
.hero-stat:hover{background:rgba(255,255,255,.13);transform:translateY(-4px)}
.hero-stat-value{font-size:1.8rem;font-weight:800;color:#fff;line-height:1;margin-bottom:5px}
.hero-stat-label{font-size:.73rem;color:rgba(255,255,255,.6);font-weight:500}

.particles{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.particle{position:absolute;border-radius:50%;background:rgba(255,255,255,.25);animation:float 4s ease-in-out infinite}

/* ══════════════════════════════════════════════════════════
   SECTIONS
══════════════════════════════════════════════════════════ */
.section{padding:70px 1.5rem}
.section-header{text-align:center;margin-bottom:52px}
.section-badge{
  display:inline-block;background:#EFF6FF;color:var(--primary);
  padding:5px 16px;border-radius:50px;font-size:.78rem;font-weight:700;
  margin-bottom:14px;letter-spacing:.5px;
}
.section-title{font-size:clamp(1.6rem,3vw,2.6rem);font-weight:800;color:var(--dark);margin-bottom:14px;line-height:1.3}
.section-subtitle{font-size:1rem;color:var(--gray);max-width:580px;margin:0 auto;line-height:1.8}
.container{max-width:1240px;margin:0 auto;padding:0 1rem}

/* ══════════════════════════════════════════════════════════
   CARDS
══════════════════════════════════════════════════════════ */
.card{
  background:#fff;border-radius:var(--radius-lg);
  border:1px solid var(--border);padding:22px;
  transition:all .3s;box-shadow:var(--shadow);
}
.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px);border-color:rgba(37,99,235,.2)}
.card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px;gap:12px}

/* ── Opportunity Card ── */
.opportunity-card{
  background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border);
  padding:22px;transition:all .3s;box-shadow:var(--shadow);
  position:relative;overflow:hidden;cursor:pointer;
}
.opportunity-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--primary),var(--primary-light));
  opacity:0;transition:opacity .3s;
}
.opportunity-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px);border-color:rgba(37,99,235,.3)}
.opportunity-card:hover::before{opacity:1}

.opp-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px;gap:10px}
.opp-donor{
  display:flex;align-items:center;gap:6px;font-size:.8rem;font-weight:600;
  color:var(--primary);background:#EFF6FF;padding:4px 11px;border-radius:20px;
  flex-shrink:0;
}
.opp-score{
  display:flex;align-items:center;gap:3px;font-size:.8rem;font-weight:700;
  color:#fff;background:linear-gradient(135deg,#10B981,#059669);
  padding:4px 11px;border-radius:20px;flex-shrink:0;
}
.opp-title{
  font-size:.95rem;font-weight:700;color:var(--dark);
  margin-bottom:8px;line-height:1.5;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.opp-summary{
  font-size:.83rem;color:var(--gray);line-height:1.7;margin-bottom:14px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.opp-meta{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}
.opp-tag{
  display:flex;align-items:center;gap:3px;font-size:.75rem;
  color:var(--gray);background:var(--bg);padding:3px 9px;
  border-radius:5px;border:1px solid var(--border);
}
.opp-footer{display:flex;justify-content:space-between;align-items:center;padding-top:12px;border-top:1px solid var(--border)}
.deadline-badge{display:flex;align-items:center;gap:5px;font-size:.78rem;font-weight:600}
.deadline-urgent{color:var(--danger)}
.deadline-soon{color:var(--secondary)}
.deadline-normal{color:var(--accent)}
.amount-badge{font-size:.9rem;font-weight:800;color:var(--primary)}

/* ── Feature Card ── */
.feature-card{
  background:#fff;border-radius:var(--radius-xl);padding:28px 24px;
  border:1px solid var(--border);transition:all .3s;position:relative;overflow:hidden;
}
.feature-card::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--primary),var(--primary-light));
  transform:scaleX(0);transition:transform .3s;
}
.feature-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-5px)}
.feature-card:hover::after{transform:scaleX(1)}
.feature-icon{
  width:60px;height:60px;border-radius:16px;
  background:linear-gradient(135deg,#EFF6FF,#DBEAFE);
  display:flex;align-items:center;justify-content:center;
  font-size:1.7rem;margin-bottom:18px;
}
.feature-title{font-size:1.08rem;font-weight:700;color:var(--dark);margin-bottom:9px}
.feature-desc{font-size:.85rem;color:var(--gray);line-height:1.7}

/* ── Donor Card ── */
.donor-card{
  background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border);
  padding:18px;display:flex;align-items:center;gap:14px;
  transition:all .3s;box-shadow:var(--shadow);
}
.donor-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.donor-logo{
  width:50px;height:50px;border-radius:11px;background:var(--bg);
  display:flex;align-items:center;justify-content:center;font-size:1.7rem;flex-shrink:0;
}

/* ══════════════════════════════════════════════════════════
   DASHBOARD LAYOUT
══════════════════════════════════════════════════════════ */
.dashboard-layout{display:flex;min-height:100vh;padding-top:var(--navbar-h)}

/* Sidebar */
.sidebar{
  width:var(--sidebar-w);background:var(--dark);
  position:fixed;top:var(--navbar-h);bottom:0;
  overflow-y:auto;padding:20px 12px;
  display:flex;flex-direction:column;gap:2px;
  z-index:100;transition:transform .3s ease;
}
[dir="rtl"] .sidebar{right:0;left:auto}
[dir="ltr"] .sidebar{left:0;right:auto}

.sidebar-section-title{
  font-size:.68rem;font-weight:700;color:#475569;
  text-transform:uppercase;letter-spacing:1.5px;
  padding:10px 12px 4px;margin-top:6px;
}
.sidebar-item{
  display:flex;align-items:center;gap:9px;
  padding:10px 13px;border-radius:var(--radius);
  font-size:.86rem;font-weight:500;color:#94A3B8;
  cursor:pointer;transition:all var(--transition);
  border:none;background:none;width:100%;
  font-family:inherit;
}
[dir="rtl"] .sidebar-item{text-align:right}
[dir="ltr"] .sidebar-item{text-align:left}
.sidebar-item:hover{background:rgba(255,255,255,.07);color:#fff}
.sidebar-item.active{background:rgba(37,99,235,.2);color:#60A5FA}
.sidebar-icon{font-size:1.05rem;min-width:18px;text-align:center;flex-shrink:0}
.sidebar-badge{
  background:var(--primary);color:#fff;font-size:.62rem;
  padding:2px 7px;border-radius:10px;font-weight:700;
  margin-left:auto;flex-shrink:0;
}
[dir="rtl"] .sidebar-badge{margin-left:0;margin-right:auto}

/* Sidebar toggle button (tablet/mobile) */
.sidebar-toggle{
  display:none;position:fixed;
  bottom:24px;left:24px;
  z-index:200;width:50px;height:50px;
  border-radius:50%;background:var(--primary);color:#fff;
  border:none;font-size:1.3rem;cursor:pointer;
  box-shadow:0 4px 20px rgba(37,99,235,.5);
  transition:all var(--transition);
}
[dir="rtl"] .sidebar-toggle{left:auto;right:24px}
.sidebar-toggle:hover{transform:scale(1.1)}

/* Sidebar overlay (mobile) */
.sidebar-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,.5);z-index:99;
  backdrop-filter:blur(2px);
}
.sidebar-overlay.show{display:block}

/* Main content */
.main-content{
  flex:1;padding:28px 24px;
  min-height:calc(100vh - var(--navbar-h));
  background:var(--bg);transition:margin .3s;
}
[dir="rtl"] .main-content{margin-right:var(--sidebar-w);margin-left:0}
[dir="ltr"] .main-content{margin-left:var(--sidebar-w);margin-right:0}

/* ══════════════════════════════════════════════════════════
   STAT WIDGETS
══════════════════════════════════════════════════════════ */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px}
.stat-widget{
  background:#fff;border-radius:var(--radius-lg);padding:20px;
  border:1px solid var(--border);box-shadow:var(--shadow);
  display:flex;align-items:flex-start;gap:14px;
  transition:all .3s;
}
.stat-widget:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.stat-icon{
  width:50px;height:50px;border-radius:13px;
  display:flex;align-items:center;justify-content:center;
  font-size:1.35rem;flex-shrink:0;
}
.stat-icon-blue{background:#EFF6FF}
.stat-icon-green{background:#F0FDF4}
.stat-icon-orange{background:#FFF7ED}
.stat-icon-purple{background:#F5F3FF}
.stat-icon-red{background:#FEF2F2}
.stat-value{font-size:1.9rem;font-weight:800;color:var(--dark);line-height:1;margin-bottom:5px;animation:countUp .5s ease-out}
.stat-label{font-size:.8rem;color:var(--gray);font-weight:500}
.stat-change{font-size:.75rem;font-weight:600;margin-top:3px}
.stat-change.up{color:var(--accent)}
.stat-change.down{color:var(--danger)}

/* ══════════════════════════════════════════════════════════
   GRIDS
══════════════════════════════════════════════════════════ */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.grid-auto{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}

/* ══════════════════════════════════════════════════════════
   SEARCH & FILTERS
══════════════════════════════════════════════════════════ */
.search-bar{
  display:flex;gap:10px;background:#fff;
  border:2px solid var(--border);border-radius:var(--radius-lg);
  padding:8px 14px;align-items:center;transition:all .2s;
  box-shadow:var(--shadow);
}
.search-bar:focus-within{border-color:var(--primary);box-shadow:0 0 0 4px rgba(37,99,235,.1)}
.search-bar input{flex:1;border:none;outline:none;font-size:.93rem;font-family:inherit;color:var(--dark);background:transparent;min-width:0}
.search-bar input::placeholder{color:var(--gray-light)}

.filter-bar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}
.filter-select{
  padding:8px 13px;border-radius:var(--radius);border:1px solid var(--border);
  background:#fff;font-size:.83rem;font-family:inherit;color:var(--dark);
  cursor:pointer;transition:all var(--transition);min-width:130px;
  appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748B' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:left 10px center;
}
[dir="rtl"] .filter-select{background-position:right 10px center;padding-right:13px;padding-left:28px}
[dir="ltr"] .filter-select{background-position:right 10px center;padding-left:13px;padding-right:28px}
.filter-select:focus{outline:none;border-color:var(--primary)}

.filter-chip{
  display:flex;align-items:center;gap:5px;
  padding:6px 13px;border-radius:50px;font-size:.8rem;font-weight:600;
  cursor:pointer;transition:all var(--transition);
  border:1px solid var(--border);background:#fff;color:var(--dark-3);
}
.filter-chip.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.filter-chip:hover:not(.active){border-color:var(--primary);color:var(--primary)}

/* ══════════════════════════════════════════════════════════
   TABS
══════════════════════════════════════════════════════════ */
.tabs{
  display:flex;gap:3px;background:var(--bg);
  padding:4px;border-radius:var(--radius);border:1px solid var(--border);
  width:fit-content;
}
.tab{
  padding:7px 18px;border-radius:9px;font-size:.84rem;font-weight:600;
  cursor:pointer;transition:all var(--transition);
  border:none;background:none;color:var(--gray);font-family:inherit;
}
.tab.active{background:#fff;color:var(--primary);box-shadow:0 2px 8px rgba(0,0,0,.08)}
.tab:hover:not(.active){color:var(--dark)}

/* ══════════════════════════════════════════════════════════
   BADGES
══════════════════════════════════════════════════════════ */
.badge{
  display:inline-flex;align-items:center;gap:3px;
  padding:3px 9px;border-radius:20px;font-size:.73rem;font-weight:600;
}
.badge-blue{background:#EFF6FF;color:#2563EB}
.badge-green{background:#F0FDF4;color:#16A34A}
.badge-orange{background:#FFF7ED;color:#D97706}
.badge-red{background:#FEF2F2;color:#DC2626}
.badge-purple{background:#F5F3FF;color:#7C3AED}
.badge-gray{background:#F1F5F9;color:#475569}
.badge-teal{background:#F0FDFA;color:#0D9488}

/* ══════════════════════════════════════════════════════════
   AI AGENT
══════════════════════════════════════════════════════════ */
.ai-agent-container{
  background:linear-gradient(135deg,#0F172A 0%,#1E3A8A 100%);
  border-radius:var(--radius-xl);padding:28px;color:#fff;
  position:relative;overflow:hidden;
}
.ai-agent-container::before{
  content:'';position:absolute;top:-50%;right:-20%;
  width:350px;height:350px;
  background:radial-gradient(circle,rgba(37,99,235,.3),transparent 70%);
  pointer-events:none;
}
.ai-chat{
  background:rgba(255,255,255,.05);border-radius:var(--radius-lg);
  border:1px solid rgba(255,255,255,.1);
  height:380px;overflow-y:auto;padding:18px;
  display:flex;flex-direction:column;gap:14px;margin-bottom:14px;
}
.chat-msg{max-width:85%;animation:fadeIn .3s ease-out}
.chat-msg-user{
  align-self:flex-end;background:var(--primary);color:#fff;
  padding:11px 15px;border-radius:16px 16px 4px 16px;
  font-size:.88rem;line-height:1.6;
}
.chat-msg-ai{align-self:flex-start}
.chat-msg-ai-header{display:flex;align-items:center;gap:7px;margin-bottom:6px;font-size:.77rem;font-weight:600;color:#60A5FA}
.chat-msg-ai-content{
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);
  padding:12px 16px;border-radius:4px 16px 16px 16px;
  font-size:.88rem;line-height:1.7;color:rgba(255,255,255,.9);
}
.ai-suggestions{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:11px}
.ai-suggestion{
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);
  color:rgba(255,255,255,.8);padding:7px 13px;border-radius:20px;
  font-size:.78rem;cursor:pointer;transition:all var(--transition);font-family:inherit;
}
.ai-suggestion:hover{background:rgba(255,255,255,.16);color:#fff}
.ai-input-area{display:flex;gap:9px}
.ai-input{
  flex:1;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);
  border-radius:var(--radius);padding:11px 15px;color:#fff;
  font-family:inherit;font-size:.88rem;outline:none;transition:all var(--transition);
}
.ai-input:focus{border-color:var(--primary-light);background:rgba(255,255,255,.12)}
.ai-input::placeholder{color:rgba(255,255,255,.4)}

/* ══════════════════════════════════════════════════════════
   PRICING
══════════════════════════════════════════════════════════ */
.pricing-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;max-width:1180px;margin:0 auto}
.pricing-card{
  background:#fff;border-radius:var(--radius-xl);border:2px solid var(--border);
  padding:28px 22px;transition:all .3s;position:relative;overflow:hidden;
}
.pricing-card.popular{border-color:var(--primary);box-shadow:0 0 0 4px rgba(37,99,235,.1);transform:scale(1.03)}
.pricing-card:hover{box-shadow:var(--shadow-lg);border-color:var(--primary)}
.popular-badge{
  position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  background:linear-gradient(135deg,var(--primary),var(--purple));color:#fff;
  padding:5px 18px;border-radius:50px;font-size:.72rem;font-weight:700;white-space:nowrap;
}
.pricing-name{font-size:1.05rem;font-weight:700;color:var(--dark);margin-bottom:7px}
.pricing-price{font-size:2.6rem;font-weight:900;color:var(--primary);line-height:1;margin-bottom:4px}
.pricing-price span{font-size:.95rem;color:var(--gray);font-weight:400}
.pricing-features{list-style:none;margin:18px 0;display:flex;flex-direction:column;gap:9px}
.pricing-feature{display:flex;align-items:flex-start;gap:9px;font-size:.83rem;color:var(--dark-3)}
.pricing-feature .check{color:var(--accent);font-size:.87rem;flex-shrink:0;margin-top:1px}

/* ══════════════════════════════════════════════════════════
   TELEGRAM
══════════════════════════════════════════════════════════ */
.telegram-section{
  background:linear-gradient(135deg,#229ED9 0%,#1A7DB4 100%);
  border-radius:22px;padding:55px 40px;color:#fff;text-align:center;
  position:relative;overflow:hidden;
}
.telegram-commands{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;max-width:560px;margin:28px auto 0}
.telegram-cmd{
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);
  padding:9px 14px;border-radius:9px;font-family:'Courier New',monospace;
  font-size:.83rem;font-weight:600;transition:all var(--transition);cursor:pointer;color:#fff;
}
.telegram-cmd:hover{background:rgba(255,255,255,.2);transform:translateY(-2px)}

/* ══════════════════════════════════════════════════════════
   ADMIN TABLE
══════════════════════════════════════════════════════════ */
.admin-table{
  width:100%;border-collapse:separate;border-spacing:0;
  background:#fff;border-radius:var(--radius-lg);overflow:hidden;
  border:1px solid var(--border);box-shadow:var(--shadow);
}
.admin-table th{
  background:var(--bg);padding:12px 18px;
  font-size:.77rem;font-weight:700;color:var(--gray);
  text-transform:uppercase;letter-spacing:.5px;
  border-bottom:1px solid var(--border);white-space:nowrap;
}
[dir="rtl"] .admin-table th{text-align:right}
[dir="ltr"] .admin-table th{text-align:left}
.admin-table td{
  padding:12px 18px;font-size:.86rem;color:var(--dark-3);
  border-bottom:1px solid #f1f5f9;vertical-align:middle;
}
.admin-table tr:last-child td{border-bottom:none}
.admin-table tr:hover td{background:#f8fafc}

/* ══════════════════════════════════════════════════════════
   MODALS
══════════════════════════════════════════════════════════ */
.modal-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.55);
  backdrop-filter:blur(4px);z-index:2000;
  display:flex;align-items:center;justify-content:center;
  padding:20px;animation:fadeInScale .2s ease-out;
}
.modal{
  background:#fff;border-radius:var(--radius-xl);
  max-width:600px;width:100%;max-height:90vh;overflow-y:auto;
  padding:28px;position:relative;animation:fadeInScale .3s ease-out;
}
.modal-sm{max-width:420px}
.modal-lg{max-width:780px}
.modal-close{
  position:absolute;top:14px;font-size:1.3rem;
  cursor:pointer;color:var(--gray);padding:4px 8px;
  border-radius:6px;transition:all var(--transition);
  border:none;background:none;
}
[dir="rtl"] .modal-close{left:14px}
[dir="ltr"] .modal-close{right:14px}
.modal-close:hover{background:var(--bg);color:var(--dark)}

/* Admin auth modal */
.auth-modal-wrap{
  position:fixed;inset:0;background:linear-gradient(135deg,#0F172A,#1E3A8A);
  z-index:3000;display:flex;align-items:center;justify-content:center;padding:20px;
}

/* ══════════════════════════════════════════════════════════
   NOTIFICATIONS
══════════════════════════════════════════════════════════ */
.notification-panel{
  position:fixed;top:80px;width:330px;
  background:#fff;border-radius:var(--radius-lg);
  border:1px solid var(--border);box-shadow:0 20px 60px rgba(0,0,0,.15);
  z-index:999;overflow:hidden;animation:fadeIn .3s ease-out;
}
[dir="rtl"] .notification-panel{left:16px;right:auto}
[dir="ltr"] .notification-panel{right:16px;left:auto}
.notif-header{
  padding:14px 18px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
  background:var(--bg);
}
.notif-item{
  padding:12px 18px;border-bottom:1px solid #f1f5f9;
  cursor:pointer;transition:background var(--transition);
  display:flex;gap:11px;
}
.notif-item:hover{background:var(--bg)}
.notif-item.unread{background:#EFF6FF}
.notif-dot{width:8px;height:8px;background:var(--primary);border-radius:50%;margin-top:5px;flex-shrink:0}

/* ══════════════════════════════════════════════════════════
   TOAST
══════════════════════════════════════════════════════════ */
.toast{
  position:fixed;bottom:20px;z-index:9999;
  background:var(--dark);color:#fff;
  padding:12px 18px;border-radius:var(--radius);
  font-size:.85rem;font-weight:500;
  box-shadow:0 10px 30px rgba(0,0,0,.3);
  animation:fadeIn .3s ease-out;
  display:flex;align-items:center;gap:9px;
  min-width:260px;max-width:360px;
}
[dir="rtl"] .toast{left:20px;right:auto}
[dir="ltr"] .toast{right:20px;left:auto}
.toast-success{background:var(--accent)}
.toast-error{background:var(--danger)}
.toast-info{background:var(--primary)}

/* ══════════════════════════════════════════════════════════
   FORMS
══════════════════════════════════════════════════════════ */
.form-group{margin-bottom:16px}
.form-label{display:block;font-size:.83rem;font-weight:600;color:var(--dark-3);margin-bottom:5px}
.form-input{
  width:100%;padding:10px 14px;
  border:2px solid var(--border);border-radius:var(--radius);
  font-size:.9rem;font-family:inherit;color:var(--dark);
  background:#fff;outline:none;transition:border-color var(--transition);
}
.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.form-input:invalid{border-color:var(--danger)}
.form-select{
  appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748B' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;
  padding-right:36px;
}
.form-textarea{resize:vertical;min-height:100px;line-height:1.7}
.form-hint{font-size:.77rem;color:var(--gray-light);margin-top:4px}

/* ══════════════════════════════════════════════════════════
   PROGRESS
══════════════════════════════════════════════════════════ */
.progress-bar{background:var(--border);border-radius:50px;height:7px;overflow:hidden}
.progress-fill{height:100%;border-radius:50px;background:linear-gradient(90deg,var(--primary),var(--primary-light));transition:width 1s ease}

/* ══════════════════════════════════════════════════════════
   CHART
══════════════════════════════════════════════════════════ */
.chart-container{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border);padding:22px;box-shadow:var(--shadow)}
.chart-bars{display:flex;align-items:flex-end;gap:7px;height:110px;padding:0 6px}
.chart-bar{flex:1;background:linear-gradient(180deg,var(--primary-light),var(--primary));border-radius:5px 5px 0 0;transition:all .3s;cursor:pointer;min-width:16px}
.chart-bar:hover{opacity:.75}
.chart-bar.accent{background:linear-gradient(180deg,#34D399,#10B981)}

/* ══════════════════════════════════════════════════════════
   AVATAR
══════════════════════════════════════════════════════════ */
.avatar{
  width:34px;height:34px;border-radius:50%;
  background:linear-gradient(135deg,var(--primary),var(--purple));
  color:#fff;display:flex;align-items:center;justify-content:center;
  font-size:.82rem;font-weight:700;cursor:pointer;flex-shrink:0;
}

/* ══════════════════════════════════════════════════════════
   LOADING SKELETON
══════════════════════════════════════════════════════════ */
.skeleton{
  background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0 50%,#f1f5f9 75%);
  background-size:1000px 100%;animation:shimmer 2s infinite;border-radius:var(--radius-sm);
}
.loading-spinner{width:36px;height:36px;border:4px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}

/* ══════════════════════════════════════════════════════════
   DROPDOWN
══════════════════════════════════════════════════════════ */
.dropdown{position:relative;display:inline-block}
.dropdown-menu{
  position:absolute;top:calc(100% + 7px);
  background:#fff;border-radius:var(--radius);
  border:1px solid var(--border);box-shadow:0 20px 40px rgba(0,0,0,.12);
  min-width:190px;z-index:500;overflow:hidden;animation:fadeIn .2s ease-out;
}
[dir="rtl"] .dropdown-menu{left:0;right:auto}
[dir="ltr"] .dropdown-menu{right:0;left:auto}
.dropdown-item{
  padding:9px 15px;font-size:.86rem;cursor:pointer;
  transition:background var(--transition);display:flex;align-items:center;gap:9px;color:var(--dark-3);
  border:none;background:none;width:100%;font-family:inherit;
}
[dir="rtl"] .dropdown-item{text-align:right}
.dropdown-item:hover{background:var(--bg)}

/* ══════════════════════════════════════════════════════════
   FOOTER
══════════════════════════════════════════════════════════ */
.footer{background:var(--dark);color:rgba(255,255,255,.7);padding:55px 1.5rem 28px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:36px;margin-bottom:36px}
.footer-brand p{font-size:.85rem;line-height:1.8;margin-top:14px;color:rgba(255,255,255,.5)}
.footer-heading{color:#fff;font-size:.93rem;font-weight:700;margin-bottom:14px}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:9px}
.footer-links a{color:rgba(255,255,255,.5);font-size:.83rem;transition:color var(--transition);cursor:pointer}
.footer-links a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:22px;display:flex;justify-content:space-between;align-items:center;font-size:.8rem;color:rgba(255,255,255,.4);flex-wrap:wrap;gap:10px}

/* ══════════════════════════════════════════════════════════
   PROFILE PAGE
══════════════════════════════════════════════════════════ */
.profile-header{
  background:linear-gradient(135deg,#0F172A,#1E3A8A);
  border-radius:var(--radius-xl);padding:32px;color:#fff;
  display:flex;align-items:center;gap:24px;margin-bottom:24px;
  position:relative;overflow:hidden;
}
.profile-avatar-lg{
  width:90px;height:90px;border-radius:50%;
  background:linear-gradient(135deg,var(--primary),var(--purple));
  display:flex;align-items:center;justify-content:center;
  font-size:2.2rem;font-weight:900;color:#fff;
  border:4px solid rgba(255,255,255,.3);flex-shrink:0;
}
.profile-stat-box{
  background:rgba(255,255,255,.1);border-radius:var(--radius);
  padding:14px 20px;text-align:center;border:1px solid rgba(255,255,255,.15);
}

/* ══════════════════════════════════════════════════════════
   SETTINGS (API KEY)
══════════════════════════════════════════════════════════ */
.api-key-box{
  background:var(--dark);border-radius:var(--radius);padding:14px 18px;
  font-family:'Courier New',monospace;font-size:.85rem;color:#60A5FA;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  border:1px solid rgba(255,255,255,.1);
}
.api-key-mask{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ══════════════════════════════════════════════════════════
   UTILITIES
══════════════════════════════════════════════════════════ */
.w-full{width:100%}
.text-center{text-align:center}
.text-right{text-align:right}
.text-left{text-align:left}
.font-bold{font-weight:700}
.font-800{font-weight:800}
.flex{display:flex}
.flex-col{flex-direction:column}
.items-center{align-items:center}
.justify-between{justify-content:space-between}
.justify-center{justify-content:center}
.flex-wrap{flex-wrap:wrap}
.gap-1{gap:4px}
.gap-2{gap:8px}
.gap-3{gap:12px}
.gap-4{gap:16px}
.gap-6{gap:24px}
.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.mt-8{margin-top:32px}
.mb-1{margin-bottom:4px}.mb-2{margin-bottom:8px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.mb-8{margin-bottom:32px}
.p-4{padding:16px}.p-6{padding:24px}
.hidden{display:none!important}
.relative{position:relative}
.overflow-hidden{overflow:hidden}
.rounded{border-radius:var(--radius)}
.rounded-lg{border-radius:var(--radius-lg)}
.border{border:1px solid var(--border)}
.bg-white{background:#fff}
.bg-bg{background:var(--bg)}
.text-gray{color:var(--gray)}
.text-primary{color:var(--primary)}
.text-dark{color:var(--dark)}
.text-sm{font-size:.85rem}
.text-xs{font-size:.75rem}
.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.divider{height:1px;background:var(--border);margin:16px 0}

/* ══════════════════════════════════════════════════════════
   RESPONSIVE – TABLET (768px – 1024px)
══════════════════════════════════════════════════════════ */
@media(max-width:1024px){
  .pricing-grid{grid-template-columns:repeat(2,1fr)}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .features-grid{grid-template-columns:repeat(2,1fr)}
  .hero-stats{grid-template-columns:repeat(2,1fr)}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}

  /* Sidebar: hidden by default, toggled */
  .sidebar{
    transform:translateX(100%);
    box-shadow:var(--shadow-xl);
  }
  [dir="rtl"] .sidebar{transform:translateX(100%)}
  [dir="ltr"] .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:translateX(0)}
  .main-content{margin-right:0!important;margin-left:0!important}
  .sidebar-toggle{display:flex;align-items:center;justify-content:center}
}

/* ══════════════════════════════════════════════════════════
   RESPONSIVE – MOBILE (max 768px)
══════════════════════════════════════════════════════════ */
@media(max-width:768px){
  :root{--navbar-h:60px}

  /* Navbar */
  .navbar{padding:0 1rem}
  .navbar-nav{display:none}
  .navbar-brand .navbar-subtitle{display:none}
  .hamburger{display:flex}
  #nav-login,#nav-register{display:none}

  /* Hero */
  .hero{padding:calc(var(--navbar-h) + 40px) 1rem 50px}
  .hero h1{font-size:1.85rem}
  .hero-subtitle{font-size:.9rem}
  .hero-ctas{flex-direction:column;align-items:center}
  .hero-ctas .btn-lg{width:100%;max-width:300px}
  .hero-stats{grid-template-columns:repeat(2,1fr);gap:12px}
  .hero-stat-value{font-size:1.5rem}

  /* Grids */
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .pricing-grid{grid-template-columns:1fr}
  .pricing-card.popular{transform:none}
  .features-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr}

  /* Sections */
  .section{padding:44px 1rem}
  .section-title{font-size:1.6rem}
  .section-subtitle{font-size:.9rem}

  /* Dashboard */
  .main-content{padding:16px}
  .stats-grid{grid-template-columns:1fr 1fr;gap:12px}
  .stat-value{font-size:1.5rem}

  /* AI */
  .ai-chat{height:280px}
  .ai-agent-container{padding:18px}
  .ai-input-area{flex-direction:column}
  .ai-input-area .btn{width:100%}
  .ai-suggestions{gap:6px}
  .ai-suggestion{font-size:.75rem;padding:6px 10px}

  /* Telegram */
  .telegram-section{padding:36px 18px}
  .telegram-commands{grid-template-columns:repeat(2,1fr)}

  /* Table */
  .admin-table{font-size:.78rem}
  .admin-table th,.admin-table td{padding:9px 12px}

  /* Footer */
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;text-align:center}

  /* Notifications */
  .notification-panel{width:calc(100vw - 32px);left:16px!important;right:16px!important}

  /* Modals */
  .modal{padding:20px;border-radius:var(--radius-lg)}

  /* Profile */
  .profile-header{flex-direction:column;text-align:center;padding:22px}

  /* Hide some extras */
  .hide-mobile{display:none!important}

  /* Filter bar scroll */
  .filter-bar{overflow-x:auto;flex-wrap:nowrap;padding-bottom:6px;-webkit-overflow-scrolling:touch}
  .filter-bar::-webkit-scrollbar{height:3px}
  .filter-chip{flex-shrink:0}

  /* Tabs scrollable */
  .tabs{overflow-x:auto;width:100%;-webkit-overflow-scrolling:touch}
}

@media(max-width:480px){
  .hero-stats{grid-template-columns:1fr 1fr}
  .hero-stat{padding:14px 10px}
  .hero-stat-value{font-size:1.3rem}
  .stats-grid{grid-template-columns:1fr}
  .telegram-commands{grid-template-columns:1fr 1fr}
  .hero-ctas .btn{font-size:.85rem;padding:12px 20px}
}

/* ══════════════════════════════════════════════════════════
   RTL HELPERS
══════════════════════════════════════════════════════════ */
[dir="rtl"] .ms-auto{margin-left:0;margin-right:auto}
[dir="ltr"] .ms-auto{margin-right:0;margin-left:auto}

/* ══════════════════════════════════════════════════════════
   IFDO PLATFORM - ADDITIONAL COMPONENT STYLES
══════════════════════════════════════════════════════════ */

/* ── General Page Body ── */
.page-body { max-width:1200px; margin:0 auto; padding: 5rem 1.5rem 2rem; }
.page { min-height:100vh; }

/* ── Navbar (New) ── */
.navbar {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  background:linear-gradient(135deg,#1a1f3c,#2d3561);
  backdrop-filter:blur(10px);
  box-shadow:0 2px 20px rgba(0,0,0,.25);
}
.nav-container {
  max-width:1200px; margin:0 auto;
  display:flex; align-items:center; justify-content:space-between;
  padding:.75rem 1.5rem; gap:1rem;
}
.nav-brand { display:flex; align-items:center; gap:.5rem; color:#fff; }
.brand-icon { font-size:1.5rem; }
.brand-text { font-size:1.25rem; font-weight:700; color:#f9d423; }
.brand-sub { font-size:.75rem; color:#94a3b8; white-space:nowrap; }
.nav-links { display:flex; gap:.25rem; flex:1; justify-content:center; }
.nav-link {
  color:#cbd5e1; padding:.5rem .85rem; border-radius:8px;
  cursor:pointer; font-size:.85rem; transition:all .2s; white-space:nowrap; text-decoration:none;
}
.nav-link:hover, .nav-link.active { background:rgba(249,212,35,.15); color:#f9d423; }
.nav-actions { display:flex; align-items:center; gap:.5rem; }
.lang-switcher { display:flex; gap:2px; background:rgba(255,255,255,.1); border-radius:8px; padding:2px; }
.lang-btn {
  background:transparent; border:none; color:#94a3b8;
  padding:.3rem .5rem; border-radius:6px; cursor:pointer; font-size:.75rem; font-weight:600;
  transition:all .2s;
}
.lang-btn.active, .lang-btn:hover { background:rgba(249,212,35,.25); color:#f9d423; }
.notif-btn {
  background:transparent; border:none; color:#94a3b8; cursor:pointer;
  position:relative; padding:.5rem; font-size:1rem; transition:color .2s;
}
.notif-btn:hover { color:#f9d423; }
.notif-badge {
  position:absolute; top:0; right:0; background:#ef4444; color:#fff;
  font-size:.6rem; font-weight:700; border-radius:50%; width:16px; height:16px;
  display:flex; align-items:center; justify-content:center;
}
.hamburger {
  display:none; flex-direction:column; gap:5px; background:none; border:none;
  cursor:pointer; padding:.5rem;
}
.hamburger span {
  display:block; width:22px; height:2px; background:#cbd5e1; border-radius:2px;
  transition:all .3s;
}
.hamburger.open span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }

/* ── Mobile Nav ── */
.mobile-nav {
  position:fixed; top:0; right:0; bottom:0; width:280px; z-index:2000;
  background:linear-gradient(180deg,#1a1f3c,#2d3561);
  transform:translateX(100%); transition:transform .3s ease;
  display:flex; flex-direction:column; padding:0;
  box-shadow:-4px 0 20px rgba(0,0,0,.3);
}
[dir="rtl"] .mobile-nav { right:auto; left:0; transform:translateX(-100%); }
.mobile-nav.open { transform:translateX(0); }
[dir="rtl"] .mobile-nav.open { transform:translateX(0); }
.mobile-nav-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:1.25rem 1.5rem; border-bottom:1px solid rgba(255,255,255,.1);
  color:#f9d423; font-weight:700; font-size:1.1rem;
}
.mobile-nav-close {
  background:none; border:none; color:#94a3b8; font-size:1.2rem; cursor:pointer;
}
.mobile-nav-link {
  display:block; color:#cbd5e1; padding:1rem 1.5rem;
  border-bottom:1px solid rgba(255,255,255,.05); cursor:pointer;
  transition:all .2s; text-decoration:none; font-size:.95rem;
}
.mobile-nav-link:hover { background:rgba(249,212,35,.1); color:#f9d423; }
.mobile-lang-row {
  display:flex; gap:.5rem; padding:1rem 1.5rem; margin-top:auto;
  border-top:1px solid rgba(255,255,255,.1);
}
.mobile-overlay {
  display:none; position:fixed; inset:0; z-index:1500;
  background:rgba(0,0,0,.5); backdrop-filter:blur(2px);
}
.mobile-overlay.show { display:block; }

/* ── Notification Panel ── */
.notif-panel {
  position:fixed; top:64px; z-index:900;
  background:#fff; border-radius:12px; box-shadow:0 8px 32px rgba(0,0,0,.15);
  min-width:320px; max-width:380px; overflow:hidden;
}
[dir="rtl"] .notif-panel { right:1rem; }
[dir="ltr"] .notif-panel { left:1rem; }
.notif-header { padding:1rem 1.25rem; border-bottom:1px solid #e5e7eb; font-size:.9rem; }
.notif-item {
  padding:.85rem 1.25rem; border-bottom:1px solid #f3f4f6;
  font-size:.83rem; color:#4b5563; display:flex; align-items:flex-start;
  gap:.5rem; position:relative;
}
.notif-item.unread { background:#f0f4ff; }
.notif-item i { color:#3b82f6; margin-top:2px; min-width:14px; }
.notif-time { display:block; font-size:.72rem; color:#9ca3af; margin-top:.2rem; }

/* ── Hero Section ── */
.hero-section {
  min-height:100vh; display:flex; align-items:center; gap:3rem;
  background:linear-gradient(135deg,#0f172a 0%,#1e293b 50%,#0f3460 100%);
  padding:6rem 2rem 4rem;
  position:relative; overflow:hidden;
}
.hero-section::before {
  content:''; position:absolute; inset:0; opacity:.03;
  background:repeating-linear-gradient(45deg,#fff 0,#fff 1px,transparent 0,transparent 50%);
  background-size:20px 20px;
}
.hero-content { flex:1; max-width:600px; position:relative; z-index:1; }
.hero-badge {
  display:inline-flex; align-items:center; gap:.5rem;
  background:rgba(249,212,35,.15); border:1px solid rgba(249,212,35,.3);
  color:#f9d423; padding:.4rem 1rem; border-radius:50px; font-size:.83rem;
  margin-bottom:1.5rem;
}
.hero-title {
  font-size:clamp(2rem,4vw,3.25rem); font-weight:800; color:#fff;
  line-height:1.15; margin-bottom:1rem;
  background:linear-gradient(135deg,#fff,#f9d423);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
}
.hero-subtitle { color:#94a3b8; font-size:1.1rem; margin-bottom:2rem; line-height:1.6; }
.hero-actions { display:flex; gap:1rem; flex-wrap:wrap; margin-bottom:2rem; }
.hero-stats { display:flex; gap:1.5rem; flex-wrap:wrap; }
.stat-pill {
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.12);
  color:#e2e8f0; padding:.5rem 1rem; border-radius:8px; font-size:.83rem;
}
.stat-pill strong { color:#f9d423; margin-left:.25rem; }
[dir="ltr"] .stat-pill strong { margin-right:.25rem; margin-left:0; }
.hero-visual {
  flex:1; display:flex; flex-direction:column; gap:1rem;
  align-items:center; position:relative; z-index:1;
}
.hero-card-float {
  background:rgba(255,255,255,.07); backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.12); border-radius:16px;
  padding:1.25rem 1.5rem; display:flex; align-items:center; gap:1rem;
  color:#e2e8f0; font-size:.9rem; min-width:280px; max-width:320px;
  animation:floatCard 3s ease-in-out infinite;
}
.hero-card-float:nth-child(2) { animation-delay:.5s; }
.hero-card-float:nth-child(3) { animation-delay:1s; }
@keyframes floatCard {
  0%,100% { transform:translateY(0); }
  50% { transform:translateY(-8px); }
}
.float-icon { font-size:2rem; }
.score-badge {
  margin-right:auto; background:#10b981; color:#fff;
  padding:.3rem .7rem; border-radius:8px; font-size:.8rem; font-weight:700;
}
[dir="ltr"] .score-badge { margin-left:auto; margin-right:0; }

/* ── Stats Bar ── */
.stats-bar { background:#1e293b; padding:2rem 1.5rem; }
.stats-container { max-width:1200px; margin:0 auto; display:flex; justify-content:space-around; flex-wrap:wrap; gap:1rem; }
.stat-item { text-align:center; }
.stat-num { font-size:1.75rem; font-weight:800; color:#f9d423; }
.stat-label { font-size:.8rem; color:#94a3b8; margin-top:.2rem; }

/* ── Features ── */
.features-section { padding:5rem 2rem; background:#f8fafc; }
.section-header { text-align:center; margin-bottom:3rem; }
.section-header h2 { font-size:2rem; font-weight:700; color:#1a1f3c; margin-bottom:.5rem; }
.section-header p { color:#6b7280; font-size:1rem; }
.features-grid { max-width:1200px; margin:0 auto; display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:1.5rem; }
.feature-card {
  background:#fff; border-radius:16px; padding:2rem;
  box-shadow:0 2px 12px rgba(0,0,0,.06); transition:all .3s;
  border:1px solid #e5e7eb;
}
.feature-card:hover { transform:translateY(-4px); box-shadow:0 12px 40px rgba(0,0,0,.12); }
.feature-icon { font-size:2.5rem; margin-bottom:1rem; }
.feature-card h3 { font-size:1.1rem; font-weight:700; color:#1a1f3c; margin-bottom:.5rem; }
.feature-card p { color:#6b7280; font-size:.9rem; line-height:1.6; }

/* ── Opportunities Grid ── */
.opps-section { padding:5rem 2rem; background:#fff; }
.opps-grid { max-width:1200px; margin:0 auto; display:grid; grid-template-columns:repeat(auto-fill,minmax(340px,1fr)); gap:1.5rem; }
.opp-card {
  background:#fff; border-radius:16px; padding:1.5rem;
  box-shadow:0 2px 12px rgba(0,0,0,.06); border:1px solid #e5e7eb;
  transition:all .3s; display:flex; flex-direction:column; gap:.75rem;
}
.opp-card:hover { transform:translateY(-4px); box-shadow:0 12px 40px rgba(0,0,0,.12); }
.opp-card.urgent { border-left:4px solid #ef4444; }
.opp-card.soon { border-left:4px solid #f59e0b; }
[dir="rtl"] .opp-card.urgent { border-left:none; border-right:4px solid #ef4444; }
[dir="rtl"] .opp-card.soon { border-left:none; border-right:4px solid #f59e0b; }
.opp-card-header { display:flex; align-items:center; justify-content:space-between; }
.opp-donor { display:flex; align-items:center; gap:.5rem; font-size:.85rem; color:#4b5563; }
.donor-logo { font-size:1.5rem; }
.opp-score { background:linear-gradient(135deg,#667eea,#764ba2); color:#fff; padding:.3rem .7rem; border-radius:8px; font-size:.8rem; font-weight:700; }
.opp-title { font-size:1rem; font-weight:700; color:#1a1f3c; line-height:1.4; margin:0; }
.opp-summary { color:#6b7280; font-size:.85rem; line-height:1.5; flex:1; }
.opp-meta { display:flex; gap:.5rem; flex-wrap:wrap; }
.opp-amount { background:#f0fdf4; color:#10b981; padding:.25rem .65rem; border-radius:6px; font-size:.78rem; font-weight:600; }
.opp-deadline { background:#fef3c7; color:#d97706; padding:.25rem .65rem; border-radius:6px; font-size:.78rem; font-weight:600; }
.opp-deadline.urgent { background:#fef2f2; color:#ef4444; }
.opp-type { background:#eff6ff; color:#3b82f6; padding:.25rem .65rem; border-radius:6px; font-size:.78rem; font-weight:600; }
.opp-tags { display:flex; gap:.4rem; flex-wrap:wrap; }
.tag { background:#f3f4f6; color:#6b7280; padding:.2rem .55rem; border-radius:6px; font-size:.73rem; }
.opp-actions { display:flex; gap:.5rem; flex-wrap:wrap; margin-top:.25rem; }
.no-results { text-align:center; padding:3rem; color:#6b7280; font-size:1.1rem; }

/* ── Donors ── */
.donors-section { padding:5rem 2rem; background:#f8fafc; }
.donors-grid { max-width:1200px; margin:0 auto; display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); gap:1rem; }
.donor-card {
  background:#fff; border-radius:12px; padding:1.5rem; text-align:center;
  box-shadow:0 2px 8px rgba(0,0,0,.06); border:1px solid #e5e7eb;
  transition:all .3s; cursor:pointer;
}
.donor-card:hover { transform:translateY(-3px); box-shadow:0 8px 24px rgba(0,0,0,.1); }
.donor-logo { font-size:2.5rem; margin-bottom:.5rem; }
.donor-name { font-size:.9rem; font-weight:600; color:#1a1f3c; margin-bottom:.25rem; }
.donor-stats { font-size:.8rem; color:#3b82f6; }
.donor-funding { font-size:.75rem; color:#10b981; margin-top:.2rem; }

/* ── Sectors ── */
.sectors-section { padding:5rem 2rem; background:#fff; }
.sectors-grid { max-width:1200px; margin:0 auto; display:grid; grid-template-columns:repeat(auto-fill,minmax(180px,1fr)); gap:1rem; }
.sector-card {
  background:linear-gradient(135deg,#f8fafc,#e2e8f0); border-radius:12px;
  padding:1.25rem; display:flex; align-items:center; gap:.75rem;
  cursor:pointer; transition:all .2s; border:1px solid #e5e7eb;
}
.sector-card:hover { background:linear-gradient(135deg,#eff6ff,#dbeafe); }
.sector-icon { font-size:1.75rem; }
.sector-name { font-size:.85rem; font-weight:600; color:#1a1f3c; }
.sector-count { margin-right:auto; font-size:.75rem; color:#6b7280; background:#fff; padding:.2rem .5rem; border-radius:6px; }
[dir="ltr"] .sector-count { margin-left:auto; margin-right:0; }

/* ── Telegram Section ── */
.telegram-section { padding:5rem 2rem; background:linear-gradient(135deg,#0088cc,#0066aa); }
.telegram-content { max-width:800px; margin:0 auto; text-align:center; color:#fff; }
.telegram-icon { font-size:4rem; margin-bottom:1rem; }
.telegram-content h2 { font-size:2rem; font-weight:700; margin-bottom:.75rem; }
.telegram-content p { opacity:.9; margin-bottom:2rem; font-size:1rem; }
.telegram-channels { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }
.tg-channel {
  background:rgba(255,255,255,.15); backdrop-filter:blur(8px);
  border-radius:12px; padding:1rem 1.5rem; display:flex; align-items:center;
  gap:.75rem; color:#fff; text-decoration:none; transition:all .2s;
  border:1px solid rgba(255,255,255,.2);
}
.tg-channel:hover { background:rgba(255,255,255,.25); transform:translateY(-2px); }
.tg-channel span { font-size:2rem; }

/* ── Footer ── */
.footer { background:#0f172a; padding:3rem 2rem; }
.footer-content { max-width:1200px; margin:0 auto; }
.footer-brand { margin-bottom:1.5rem; }
.footer-brand span { font-size:1.5rem; }
.footer-brand strong { color:#f9d423; font-size:1.25rem; }
.footer-brand p { color:#64748b; font-size:.85rem; margin-top:.5rem; }
.footer-links { display:flex; gap:1.5rem; margin-bottom:1.5rem; }
.footer-links a { color:#94a3b8; cursor:pointer; font-size:.85rem; transition:color .2s; }
.footer-links a:hover { color:#f9d423; }
.footer-bottom { border-top:1px solid #1e293b; padding-top:1.5rem; color:#64748b; font-size:.8rem; }

/* ── Buttons ── */
.btn { display:inline-flex; align-items:center; gap:.4rem; padding:.6rem 1.25rem; border-radius:8px; cursor:pointer; font-size:.875rem; font-weight:600; transition:all .2s; border:2px solid transparent; white-space:nowrap; }
.btn-primary { background:linear-gradient(135deg,#f9d423,#f0c000); color:#1a1f3c; }
.btn-primary:hover { opacity:.9; transform:translateY(-1px); }
.btn-outline { background:transparent; border-color:#d1d5db; color:#374151; }
.btn-outline:hover { background:#f9fafb; }
.btn-outline.btn-danger { border-color:#ef4444; color:#ef4444; }
.btn-outline.btn-danger:hover { background:#fef2f2; }
.btn-lg { padding:.875rem 1.75rem; font-size:1rem; }
.btn-sm { padding:.4rem .875rem; font-size:.8rem; }
.btn-xs { padding:.25rem .6rem; font-size:.75rem; }
.btn-full { width:100%; justify-content:center; }

/* ── Explore Page ── */
.explore-header { margin-bottom:2rem; }
.explore-header h1 { font-size:2rem; font-weight:700; color:#1a1f3c; }
.explore-header p { color:#6b7280; }
.search-bar { display:flex; gap:.75rem; flex-wrap:wrap; margin-bottom:1.5rem; background:#fff; padding:1rem; border-radius:12px; box-shadow:0 2px 8px rgba(0,0,0,.06); }
.search-input-wrap { display:flex; align-items:center; gap:.5rem; flex:1; min-width:200px; background:#f9fafb; border:1px solid #e5e7eb; border-radius:8px; padding:.5rem .75rem; }
.search-input-wrap i { color:#9ca3af; }
.search-input-wrap input { border:none; background:none; outline:none; flex:1; font-size:.875rem; }
.search-bar select { padding:.5rem .75rem; border:1px solid #e5e7eb; border-radius:8px; font-size:.85rem; background:#f9fafb; cursor:pointer; }
.results-info { display:flex; align-items:center; justify-content:space-between; margin-bottom:1.5rem; color:#6b7280; font-size:.875rem; }
.sort-options { display:flex; gap:.5rem; }
.sort-btn { background:#f3f4f6; border:1px solid #e5e7eb; color:#6b7280; padding:.4rem .85rem; border-radius:6px; cursor:pointer; font-size:.78rem; transition:all .2s; }
.sort-btn.active { background:#1a1f3c; color:#f9d423; border-color:#1a1f3c; }

/* ── Dashboard Layout ── */
.dashboard-layout { display:flex; min-height:100vh; padding-top:4rem; }
.dashboard-sidebar {
  width:260px; background:linear-gradient(180deg,#1a1f3c,#2d3561);
  padding:1.5rem; flex-shrink:0; position:sticky; top:4rem; height:calc(100vh - 4rem);
  overflow-y:auto;
}
.sidebar-profile { text-align:center; margin-bottom:1.5rem; padding-bottom:1.5rem; border-bottom:1px solid rgba(255,255,255,.1); }
.profile-avatar { width:60px; height:60px; border-radius:50%; background:linear-gradient(135deg,#f9d423,#f0c000); display:flex; align-items:center; justify-content:center; font-size:1.5rem; font-weight:700; color:#1a1f3c; margin:0 auto .75rem; }
.profile-info strong { color:#fff; font-size:.95rem; display:block; }
.profile-info small { color:#94a3b8; font-size:.8rem; }
.sidebar-nav { display:flex; flex-direction:column; gap:.25rem; }
.sidebar-link { color:#94a3b8; padding:.75rem 1rem; border-radius:8px; cursor:pointer; font-size:.875rem; transition:all .2s; display:flex; align-items:center; gap:.5rem; }
.sidebar-link:hover, .sidebar-link.active { background:rgba(249,212,35,.15); color:#f9d423; }
.sidebar-toggle { display:none; position:fixed; bottom:24px; z-index:800; width:50px; height:50px; border-radius:50%; background:linear-gradient(135deg,#1a1f3c,#2d3561); color:#f9d423; font-size:1.25rem; border:none; cursor:pointer; box-shadow:0 4px 16px rgba(0,0,0,.3); }
[dir="rtl"] .sidebar-toggle { left:24px; }
[dir="ltr"] .sidebar-toggle { right:24px; }
.dashboard-main { flex:1; padding:2rem; background:#f8fafc; overflow-y:auto; }
.dash-title { font-size:1.5rem; font-weight:700; color:#1a1f3c; margin-bottom:1.5rem; }
.dash-stats-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); gap:1rem; margin-bottom:2rem; }
.dash-stat-card { background:#fff; border-radius:12px; padding:1.5rem; text-align:center; box-shadow:0 2px 8px rgba(0,0,0,.06); border-bottom:4px solid; }
.dash-stat-card.blue { border-color:#3b82f6; }
.dash-stat-card.green { border-color:#10b981; }
.dash-stat-card.orange { border-color:#f59e0b; }
.dash-stat-card.purple { border-color:#8b5cf6; }
.dash-stat-num { font-size:2rem; font-weight:800; color:#1a1f3c; }
.dash-stat-label { font-size:.8rem; color:#6b7280; margin-top:.25rem; }
.dash-row { display:grid; grid-template-columns:1fr 1fr; gap:1.5rem; margin-bottom:1.5rem; }
.dash-card { background:#fff; border-radius:12px; padding:1.5rem; box-shadow:0 2px 8px rgba(0,0,0,.06); }
.dash-card h3 { font-size:1rem; font-weight:700; color:#1a1f3c; margin-bottom:1rem; }
.dash-tab { }
.deadline-item { display:flex; justify-content:space-between; align-items:center; padding:.75rem 0; border-bottom:1px solid #f3f4f6; font-size:.85rem; color:#4b5563; }
.deadline-full-item { display:flex; align-items:center; gap:1rem; padding:1rem; background:#fff; border-radius:10px; margin-bottom:.75rem; box-shadow:0 1px 4px rgba(0,0,0,.06); }
.deadline-full-item.urgent { border-right:4px solid #ef4444; }
.deadline-full-item.soon { border-right:4px solid #f59e0b; }
.deadline-icon { font-size:1.5rem; }
.deadline-info { flex:1; }
.deadline-info strong { font-size:.9rem; color:#1a1f3c; }
.deadline-info small { color:#6b7280; font-size:.8rem; }
.deadline-days { text-align:center; }
.deadline-days strong { display:block; font-size:1.5rem; font-weight:800; color:#1a1f3c; }
.deadline-days small { font-size:.75rem; color:#6b7280; }
.sector-bar-item { display:flex; align-items:center; gap:1rem; margin-bottom:.75rem; font-size:.85rem; }
.sector-bar-item span { min-width:150px; color:#4b5563; }
.sector-bar-track { flex:1; background:#e5e7eb; border-radius:50px; height:8px; overflow:hidden; }
.sector-bar-fill { height:100%; background:linear-gradient(90deg,#667eea,#764ba2); border-radius:50px; transition:width .8s; }
.sector-bar-item strong { min-width:40px; text-align:right; color:#1a1f3c; }
.proposals-list { display:flex; flex-direction:column; gap:.75rem; }
.proposal-item { display:flex; align-items:center; gap:1rem; padding:1rem; background:#f9fafb; border-radius:10px; border:1px solid #e5e7eb; }
.proposal-info { flex:1; font-size:.875rem; }

/* ── AI Page ── */
.ai-layout { }
.ai-header { text-align:center; margin-bottom:2rem; }
.ai-header h1 { font-size:2rem; font-weight:700; color:#1a1f3c; }
.ai-header p { color:#6b7280; }
.api-key-banner { display:flex; align-items:center; gap:1rem; background:linear-gradient(135deg,#fffbeb,#fef3c7); border:1px solid #f9d423; border-radius:12px; padding:1rem 1.5rem; margin-bottom:1.5rem; font-size:.875rem; color:#92400e; }
.api-key-banner i { color:#d97706; }
.api-key-input-row { display:flex; align-items:center; gap:.75rem; background:#fff; border:2px solid #3b82f6; border-radius:12px; padding:.75rem 1.25rem; margin-bottom:1.5rem; }
.api-key-input-row i { color:#3b82f6; }
.api-key-input-row input { flex:1; border:none; outline:none; font-size:.875rem; }
.ai-container { display:grid; grid-template-columns:260px 1fr; gap:1.5rem; }
.ai-sidebar { background:#fff; border-radius:16px; padding:1.5rem; box-shadow:0 2px 8px rgba(0,0,0,.06); height:fit-content; }
.ai-sidebar h3 { font-size:.95rem; font-weight:700; color:#1a1f3c; margin-bottom:1rem; }
.suggested-questions { display:flex; flex-direction:column; gap:.5rem; }
.suggested-q { background:#f9fafb; border:1px solid #e5e7eb; border-radius:8px; padding:.65rem .875rem; cursor:pointer; text-align:right; font-size:.83rem; color:#4b5563; transition:all .2s; width:100%; }
[dir="ltr"] .suggested-q { text-align:left; }
.suggested-q:hover { background:#eff6ff; border-color:#3b82f6; color:#3b82f6; }
.model-status { display:flex; align-items:center; gap:.5rem; margin-top:.5rem; font-size:.83rem; color:#4b5563; }
.status-dot { width:8px; height:8px; border-radius:50%; }
.status-dot.built-in { background:#9ca3af; }
.status-dot.openai { background:#10b981; }
.ai-chat { background:#fff; border-radius:16px; box-shadow:0 2px 8px rgba(0,0,0,.06); display:flex; flex-direction:column; height:600px; }
.chat-messages { flex:1; overflow-y:auto; padding:1.5rem; display:flex; flex-direction:column; gap:1rem; }
.chat-message { display:flex; gap:.75rem; align-items:flex-start; }
.chat-message.user { flex-direction:row-reverse; }
.chat-avatar { width:36px; height:36px; border-radius:50%; background:#e5e7eb; display:flex; align-items:center; justify-content:center; font-size:1.1rem; flex-shrink:0; }
.chat-message.bot .chat-avatar { background:linear-gradient(135deg,#667eea,#764ba2); }
.chat-bubble { background:#f3f4f6; border-radius:12px; padding:.875rem 1.125rem; max-width:85%; font-size:.875rem; line-height:1.6; color:#374151; }
.chat-message.user .chat-bubble { background:linear-gradient(135deg,#667eea,#764ba2); color:#fff; }
.chat-input-row { display:flex; gap:.75rem; padding:1rem; border-top:1px solid #e5e7eb; }
.chat-input-row input { flex:1; padding:.75rem 1rem; border:2px solid #e5e7eb; border-radius:10px; outline:none; font-size:.875rem; transition:border-color .2s; }
.chat-input-row input:focus { border-color:#667eea; }

/* ── Profile Page ── */
.profile-header { margin-bottom:2rem; }
.profile-header h1 { font-size:1.75rem; font-weight:700; color:#1a1f3c; }
.profile-grid { display:grid; grid-template-columns:1fr 1fr; gap:1.5rem; }
.profile-card { background:#fff; border-radius:16px; padding:2rem; box-shadow:0 2px 12px rgba(0,0,0,.06); border:1px solid #e5e7eb; }
.profile-card h3 { font-size:1.1rem; font-weight:700; color:#1a1f3c; margin-bottom:1.5rem; }
.profile-card.full-width { grid-column:1/-1; }
.form-group { margin-bottom:1rem; }
.form-group label { display:block; font-size:.85rem; font-weight:600; color:#374151; margin-bottom:.4rem; }
.form-group input, .form-group select, .form-group textarea {
  width:100%; padding:.6rem .875rem; border:2px solid #e5e7eb;
  border-radius:8px; outline:none; font-size:.875rem; transition:border-color .2s;
  background:#f9fafb;
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color:#667eea; background:#fff; }
.api-key-info { background:#f0f4ff; border-radius:8px; padding:1rem; margin-bottom:1rem; font-size:.85rem; color:#4b5563; }
.api-key-status-box { padding:.75rem; border-radius:8px; background:#f9fafb; border:1px solid #e5e7eb; font-size:.85rem; }
.proposal-form-grid { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.proposal-form-grid .full-width { grid-column:1/-1; }
.proposal-output { margin-top:1.5rem; background:#f9fafb; border:1px solid #e5e7eb; border-radius:12px; overflow:hidden; }
.proposal-output-header { display:flex; align-items:center; justify-content:space-between; padding:1rem 1.25rem; border-bottom:1px solid #e5e7eb; background:#fff; }
.proposal-output-header h4 { font-size:.95rem; font-weight:700; color:#1a1f3c; margin:0; }
.proposal-output pre { padding:1.5rem; font-size:.83rem; color:#374151; white-space:pre-wrap; line-height:1.6; font-family:inherit; }

/* ── Pricing Page ── */
.pricing-header { text-align:center; margin-bottom:3rem; }
.pricing-header h1 { font-size:2rem; font-weight:700; color:#1a1f3c; margin-bottom:.5rem; }
.pricing-header p { color:#6b7280; margin-bottom:1.5rem; }
.billing-toggle { display:inline-flex; background:#f3f4f6; border-radius:10px; padding:4px; gap:4px; }
.billing-btn { background:transparent; border:none; padding:.5rem 1.25rem; border-radius:8px; cursor:pointer; font-size:.875rem; font-weight:600; color:#6b7280; transition:all .2s; }
.billing-btn.active { background:#fff; color:#1a1f3c; box-shadow:0 2px 8px rgba(0,0,0,.1); }
.pricing-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:1.5rem; max-width:1200px; margin:0 auto 3rem; }
.pricing-card { background:#fff; border-radius:16px; padding:2rem; box-shadow:0 2px 12px rgba(0,0,0,.06); border:2px solid #e5e7eb; position:relative; transition:all .3s; }
.pricing-card:hover { transform:translateY(-4px); box-shadow:0 12px 40px rgba(0,0,0,.12); }
.pricing-card.popular { border-color:#f9d423; box-shadow:0 8px 32px rgba(249,212,35,.25); }
.popular-badge { position:absolute; top:-12px; left:50%; transform:translateX(-50%); background:linear-gradient(135deg,#f9d423,#f0c000); color:#1a1f3c; padding:.3rem 1rem; border-radius:50px; font-size:.78rem; font-weight:700; white-space:nowrap; }
.plan-icon { font-size:2.5rem; margin-bottom:1rem; }
.plan-name { font-size:1.25rem; font-weight:700; color:#1a1f3c; margin-bottom:.5rem; }
.plan-price { font-size:2rem; font-weight:800; color:#1a1f3c; margin-bottom:1.5rem; }
.plan-price small { font-size:.85rem; font-weight:400; color:#6b7280; }
.plan-features { list-style:none; margin-bottom:2rem; display:flex; flex-direction:column; gap:.65rem; }
.plan-feature { display:flex; align-items:center; gap:.5rem; font-size:.875rem; color:#4b5563; }
.plan-feature i { color:#10b981; }
.plan-btn { margin-top:auto; }
.pricing-faq { max-width:800px; margin:0 auto; }
.pricing-faq h3 { font-size:1.5rem; font-weight:700; color:#1a1f3c; margin-bottom:1.5rem; text-align:center; }
.faq-item { background:#fff; border-radius:10px; padding:1.25rem; margin-bottom:1rem; box-shadow:0 1px 4px rgba(0,0,0,.06); }
.faq-item strong { display:block; color:#1a1f3c; margin-bottom:.5rem; font-size:.95rem; }
.faq-item p { color:#6b7280; font-size:.875rem; }

/* ── Admin Page ── */
.admin-modal-overlay {
  display:flex; position:fixed; inset:0; z-index:2000;
  background:rgba(0,0,0,.7); backdrop-filter:blur(8px);
  align-items:center; justify-content:center;
}
.admin-modal {
  background:#fff; border-radius:20px; padding:2.5rem; max-width:420px; width:100%;
  box-shadow:0 20px 60px rgba(0,0,0,.3); text-align:center;
}
.admin-modal-icon { font-size:3rem; margin-bottom:1rem; }
.admin-modal h2 { font-size:1.5rem; font-weight:700; color:#1a1f3c; margin-bottom:.5rem; }
.admin-modal p { color:#6b7280; font-size:.875rem; margin-bottom:1.5rem; }
.admin-modal .form-group { text-align:right; }
[dir="ltr"] .admin-modal .form-group { text-align:left; }
.error-msg { background:#fef2f2; color:#dc2626; border-radius:8px; padding:.75rem 1rem; font-size:.85rem; margin-bottom:1rem; }
.admin-content { max-width:1200px; margin:0 auto; padding: 5rem 1.5rem 2rem; }
.admin-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:1.5rem; }
.admin-header h1 { font-size:1.75rem; font-weight:700; color:#1a1f3c; }
.admin-header-actions { display:flex; align-items:center; gap:1rem; }
.admin-badge { background:#1a1f3c; color:#f9d423; padding:.4rem 1rem; border-radius:8px; font-size:.8rem; font-weight:600; display:flex; align-items:center; gap:.4rem; }
.admin-stats-row { display:flex; gap:1rem; flex-wrap:wrap; margin-bottom:1.5rem; }
.admin-stat { background:#fff; border-radius:10px; padding:1rem 1.5rem; box-shadow:0 2px 8px rgba(0,0,0,.06); text-align:center; flex:1; min-width:120px; }
.admin-stat strong { display:block; font-size:1.5rem; font-weight:800; color:#1a1f3c; }
.admin-stat small { color:#6b7280; font-size:.78rem; }
.admin-tabs-nav { display:flex; gap:.5rem; flex-wrap:wrap; margin-bottom:1.5rem; background:#fff; padding:.75rem; border-radius:12px; box-shadow:0 2px 8px rgba(0,0,0,.06); }
.admin-tab-btn { background:#f3f4f6; border:none; border-radius:8px; padding:.6rem 1rem; cursor:pointer; font-size:.83rem; color:#4b5563; transition:all .2s; display:flex; align-items:center; gap:.4rem; }
.admin-tab-btn.active { background:linear-gradient(135deg,#1a1f3c,#2d3561); color:#f9d423; }
.admin-tab-content { background:#fff; border-radius:12px; padding:1.5rem; box-shadow:0 2px 8px rgba(0,0,0,.06); }
.admin-tab-pane { }
.tab-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:1.5rem; }
.tab-header h3 { font-size:1.1rem; font-weight:700; color:#1a1f3c; }
.admin-table-wrap { overflow-x:auto; border-radius:8px; border:1px solid #e5e7eb; }
.admin-table { width:100%; border-collapse:collapse; font-size:.875rem; }
.admin-table th { background:#f9fafb; padding:.75rem 1rem; text-align:right; font-weight:600; color:#374151; border-bottom:2px solid #e5e7eb; white-space:nowrap; }
[dir="ltr"] .admin-table th { text-align:left; }
.admin-table td { padding:.75rem 1rem; border-bottom:1px solid #f3f4f6; color:#4b5563; }
.admin-table tr:last-child td { border-bottom:none; }
.admin-table tr:hover td { background:#f9fafb; }
.badge { padding:.25rem .65rem; border-radius:6px; font-size:.75rem; font-weight:600; }
.badge-success { background:#d1fae5; color:#059669; }
.badge-warning { background:#fef3c7; color:#d97706; }
.badge-danger,.badge-error { background:#fee2e2; color:#dc2626; }
.badge-blue { background:#dbeafe; color:#2563eb; }
.badge-green { background:#d1fae5; color:#059669; }
.badge-gray { background:#f3f4f6; color:#6b7280; }
.badge-purple { background:#ede9fe; color:#7c3aed; }
.sources-list { display:flex; flex-direction:column; gap:.75rem; }
.source-item { display:flex; align-items:center; gap:1rem; padding:1rem; background:#f9fafb; border-radius:10px; border:1px solid #e5e7eb; }
.source-info { display:flex; align-items:center; gap:.75rem; flex:1; }
.source-icon { font-size:1.75rem; }
.subs-summary { display:flex; gap:1rem; margin-bottom:1.5rem; }
.sub-stat { background:#f9fafb; border-radius:10px; padding:1rem 1.5rem; text-align:center; flex:1; }
.sub-stat strong { display:block; font-size:1.5rem; font-weight:700; color:#1a1f3c; }
.sub-stat small { color:#6b7280; font-size:.8rem; }
.analytics-grid { display:grid; grid-template-columns:1fr 1fr; gap:1.5rem; }
.analytics-card { background:#f9fafb; border-radius:12px; padding:1.5rem; border:1px solid #e5e7eb; }
.analytics-card h4 { font-size:.95rem; font-weight:700; color:#1a1f3c; margin-bottom:1rem; }
.bar-chart { display:flex; align-items:flex-end; gap:.5rem; height:100px; }
.bar-item { display:flex; flex-direction:column; align-items:center; gap:.25rem; flex:1; }
.bar-item .bar { width:100%; background:linear-gradient(180deg,#667eea,#764ba2); border-radius:4px 4px 0 0; }
.bar-item span { font-size:.7rem; color:#6b7280; }
.plan-dist { display:flex; flex-direction:column; gap:.75rem; }
.dist-item { display:flex; align-items:center; gap:.75rem; font-size:.85rem; }
.dist-item span { min-width:80px; color:#4b5563; }
.dist-bar { flex:1; background:#e5e7eb; border-radius:50px; height:8px; overflow:hidden; }
.dist-bar div { height:100%; border-radius:50px; }
.dist-item strong { min-width:35px; text-align:right; }
.top-list { display:flex; flex-direction:column; gap:.75rem; }
.top-item { display:flex; justify-content:space-between; font-size:.85rem; padding:.5rem 0; border-bottom:1px solid #f3f4f6; }
.top-item strong { color:#3b82f6; }
.revenue-stats { display:flex; flex-direction:column; gap:.75rem; }
.rev-item { text-align:center; padding:1rem; background:#fff; border-radius:8px; }
.rev-item strong { display:block; font-size:1.5rem; font-weight:800; color:#10b981; }
.rev-item small { color:#6b7280; font-size:.8rem; }
.telegram-admin-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:1.5rem; margin-bottom:2rem; }
.tg-channel-card { background:#f9fafb; border-radius:12px; padding:1.5rem; border:1px solid #e5e7eb; text-align:center; }
.tg-icon { font-size:2.5rem; margin-bottom:.75rem; }
.tg-channel-card h4 { font-weight:700; color:#1a1f3c; margin-bottom:.5rem; }
.tg-stats { font-size:.875rem; color:#6b7280; margin-bottom:1rem; }
.tg-broadcast-section { background:#f0f4ff; border-radius:12px; padding:1.5rem; }
.tg-broadcast-section h4 { font-weight:700; color:#1a1f3c; margin-bottom:1rem; }
.tg-broadcast-section textarea { width:100%; padding:.75rem; border:2px solid #e5e7eb; border-radius:8px; font-size:.875rem; resize:vertical; }
.tg-broadcast-section label { margin-right:.5rem; font-size:.875rem; cursor:pointer; }
.settings-grid { display:grid; grid-template-columns:1fr 1fr; gap:1.5rem; }
.settings-card { background:#f9fafb; border-radius:12px; padding:1.5rem; border:1px solid #e5e7eb; }
.settings-card h4 { font-weight:700; color:#1a1f3c; margin-bottom:1.5rem; }
.toggle-row { display:flex; align-items:center; gap:.5rem; margin-bottom:.75rem; font-size:.875rem; color:#4b5563; }
.logs-container { font-family:monospace; background:#0f172a; border-radius:10px; padding:1.5rem; max-height:500px; overflow-y:auto; }
.log-item { padding:.5rem .75rem; border-radius:6px; margin-bottom:.4rem; font-size:.8rem; color:#94a3b8; }
.log-item.success { color:#10b981; }
.log-item.warning { color:#f59e0b; }
.log-item.error { color:#ef4444; }
.log-time { color:#64748b; margin-left:.5rem; }
[dir="ltr"] .log-time { margin-right:.5rem; margin-left:0; }
.log-badge { padding:.1rem .5rem; border-radius:4px; font-size:.72rem; font-weight:700; margin:0 .4rem; }
.log-badge.success,.log-badge.INFO { background:#064e3b; color:#6ee7b7; }
.log-badge.info,.log-badge.AUTH,.log-badge.SYNC,.log-badge.AI,.log-badge.SYS { background:#1e3a5f; color:#60a5fa; }
.log-badge.warning,.log-badge.WARN { background:#451a03; color:#fcd34d; }
.log-badge.error,.log-badge.ERR { background:#450a0a; color:#f87171; }
.log-badge.BACKUP { background:#1a2e35; color:#34d399; }

/* ── Auth Pages ── */
.auth-container { min-height:100vh; display:flex; align-items:center; justify-content:center; padding:2rem; background:linear-gradient(135deg,#0f172a,#1e293b,#0f3460); }
.auth-card { background:#fff; border-radius:20px; padding:2.5rem; max-width:440px; width:100%; box-shadow:0 20px 60px rgba(0,0,0,.3); }
.auth-logo { font-size:2rem; font-weight:800; color:#1a1f3c; margin-bottom:1.5rem; }
.auth-logo span { color:#f9d423; }
.auth-card h2 { font-size:1.5rem; font-weight:700; color:#1a1f3c; margin-bottom:.25rem; }
.auth-card p { color:#6b7280; font-size:.875rem; margin-bottom:1.5rem; }
.auth-divider { text-align:center; margin:1.25rem 0; position:relative; color:#9ca3af; font-size:.875rem; }
.auth-divider::before { content:''; position:absolute; top:50%; left:0; right:0; height:1px; background:#e5e7eb; z-index:0; }
.auth-divider span { position:relative; z-index:1; background:#fff; padding:0 .75rem; }
.auth-demo { margin-top:1rem; text-align:center; padding:.75rem; background:#f9fafb; border-radius:8px; color:#6b7280; }

/* ── Toast ── */
.toast {
  position:fixed; bottom:1.5rem; left:50%; transform:translateX(-50%) translateY(100px);
  background:#1a1f3c; color:#fff; padding:.875rem 1.5rem; border-radius:12px;
  box-shadow:0 8px 32px rgba(0,0,0,.3); z-index:9999; font-size:.875rem;
  transition:transform .3s; white-space:nowrap;
}
.toast.show { transform:translateX(-50%) translateY(0); }
.toast.toast-success { background:linear-gradient(135deg,#059669,#10b981); }
.toast.toast-error { background:linear-gradient(135deg,#dc2626,#ef4444); }
.toast.toast-warning { background:linear-gradient(135deg,#d97706,#f59e0b); }
.toast.toast-info { background:linear-gradient(135deg,#2563eb,#3b82f6); }

/* ── Responsive ── */
@media(max-width:1024px){
  .dashboard-sidebar { position:fixed; top:4rem; bottom:0; z-index:700; transform:translateX(100%); transition:transform .3s; }
  [dir="rtl"] .dashboard-sidebar { transform:translateX(100%); }
  [dir="ltr"] .dashboard-sidebar { transform:translateX(-100%); }
  .dashboard-sidebar.open { transform:translateX(0); }
  .sidebar-toggle { display:flex; }
  .dashboard-main { padding:1rem; }
  .dash-row { grid-template-columns:1fr; }
  .analytics-grid { grid-template-columns:1fr; }
  .settings-grid { grid-template-columns:1fr; }
  .profile-grid { grid-template-columns:1fr; }
  .ai-container { grid-template-columns:1fr; }
  .ai-sidebar { order:-1; }
  .admin-tabs-nav { overflow-x:auto; flex-wrap:nowrap; }
  .admin-tab-btn { white-space:nowrap; flex-shrink:0; }
}

@media(max-width:768px){
  .hamburger { display:flex !important; }
  .nav-links { display:none !important; }
  .brand-sub { display:none; }
  .hero-section { flex-direction:column; text-align:center; padding:5rem 1.25rem 3rem; gap:2rem; }
  .hero-actions { justify-content:center; }
  .hero-stats { justify-content:center; }
  .hero-visual { display:none; }
  .stat-pill strong { display:inline; }
  .stats-container { grid-template-columns:repeat(3,1fr); }
  .features-grid { grid-template-columns:1fr; }
  .opps-grid { grid-template-columns:1fr; }
  .donors-grid { grid-template-columns:repeat(2,1fr); }
  .sectors-grid { grid-template-columns:repeat(2,1fr); }
  .telegram-channels { flex-direction:column; align-items:center; }
  .pricing-grid { grid-template-columns:1fr; }
  .telegram-admin-grid { grid-template-columns:1fr; }
  .search-bar { flex-direction:column; }
  .search-bar select { width:100%; }
  .results-info { flex-direction:column; align-items:flex-start; gap:.5rem; }
  .dash-stats-grid { grid-template-columns:1fr 1fr; }
  .proposal-form-grid { grid-template-columns:1fr; }
  .auth-card { padding:1.75rem; }
  .admin-modal { padding:1.75rem; }
  .subs-summary { flex-direction:column; }
  .footer-links { flex-wrap:wrap; gap:1rem; }
}

@media(max-width:480px){
  .page-body { padding:4.5rem 1rem 1.5rem; }
  .hero-title { font-size:1.75rem; }
  .features-section, .opps-section, .donors-section, .sectors-section, .telegram-section { padding:3rem 1rem; }
  .section-header h2 { font-size:1.5rem; }
  .dash-stats-grid { grid-template-columns:1fr; }
  .donors-grid { grid-template-columns:1fr; }
  .sectors-grid { grid-template-columns:repeat(2,1fr); }
  .stats-container { flex-direction:column; align-items:center; }
  .opp-actions { flex-direction:column; }
  .opp-actions .btn { width:100%; justify-content:center; }
}
