/* ============================================
   AMEXPERTS & PARTNERS — Main Stylesheet v2
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;500;600;700&family=Barlow:wght@300;400;500;600;700&display=swap');

:root {
  --purple:        #8B35A0;
  --purple-dark:   #6B2080;
  --purple-light:  #B05CC8;
  --black:         #111111;
  --dark:          #1C1C1C;
  --gray-dark:     #3D3D3D;
  --gray:          #777777;
  --gray-light:    #BBBBBB;
  --bg-light:      #F7F4FA;
  --white:         #FFFFFF;
  --font-serif:    'Cormorant Garamond', Georgia, serif;
  --font-sans:     'Barlow', sans-serif;
  --transition:    0.3s ease;
  --shadow:        0 4px 24px rgba(0,0,0,0.08);
  --shadow-lg:     0 12px 48px rgba(0,0,0,0.15);
  --radius:        4px;
}

/* ============ RESET ============ */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { font-family:var(--font-sans); color:var(--black); background:var(--white); line-height:1.6; }
img { max-width:100%; display:block; }
a { text-decoration:none; color:inherit; }
ul { list-style:none; }
button { cursor:pointer; }

/* ============ TYPOGRAPHY ============ */
h1,h2,h3,h4 { font-family:var(--font-serif); font-weight:600; line-height:1.2; }
h1 { font-size:clamp(2rem,5vw,3.8rem); }
h2 { font-size:clamp(1.7rem,3.5vw,2.6rem); }
h3 { font-size:clamp(1.1rem,2vw,1.5rem); }
h3 { font-weight: bold;}
h4 { font-weight: bold;}
p  { font-size:.97rem; color:#FFD700; /* var(--gray-dark);*/ }

/* ============ BUTTONS ============ */
.btn-primary {
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.82rem 2rem; background:var(--purple); color:#fff;
  font-family:var(--font-sans); font-size:.87rem; font-weight:600;
  letter-spacing:.05em; text-transform:uppercase; border-radius:var(--radius);
  border:2px solid var(--purple); transition:all var(--transition);
}
.btn-primary:hover { background:var(--purple-dark); border-color:var(--purple-dark); transform:translateY(-2px); box-shadow:0 8px 24px rgba(139,53,160,.35); }

.btn-outline {
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.82rem 2rem; background:transparent; color:#fff;
  font-family:var(--font-sans); font-size:.87rem; font-weight:600;
  letter-spacing:.05em; text-transform:uppercase; border-radius:var(--radius);
  border:2px solid rgba(255,255,255,.35); transition:all var(--transition);
}
.btn-outline:hover { border-color:#fff; background:rgba(255,255,255,.07); }

.btn-purple-outline {
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.82rem 2rem; background:transparent; color:var(--purple);
  font-family:var(--font-sans); font-size:.87rem; font-weight:600;
  letter-spacing:.05em; text-transform:uppercase; border-radius:var(--radius);
  border:2px solid var(--purple); transition:all var(--transition);
}
.btn-purple-outline:hover { background:var(--purple); color:#fff; }

.btn-white {
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.82rem 2.5rem; background:#fff; color:var(--purple);
  font-family:var(--font-sans); font-size:.87rem; font-weight:700;
  letter-spacing:.05em; text-transform:uppercase; border-radius:var(--radius);
  border:2px solid #fff; transition:all var(--transition);
}
.btn-white:hover { background:transparent; color:#fff; }

/* ============ NAVBAR ============ */
#navbar {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  background:rgba(44,32,58,.97); backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(139,53,160,.25);
  transition:var(--transition);
}
.nav-inner {
  max-width:1300px; margin:0 auto; padding:0 2rem;
  display:flex; align-items:center; justify-content:space-between;
  height:72px;
}

/* Logo — rectangle complet (logo + nom intégrés dans l'image)                      
  .nav-logo {
  display:flex;
  align-items:center;
  text-decoration:none;
  flex-shrink:0;
}
.nav-logo img {
  height:44px;
  width:auto;
  max-width:240px;
  object-fit:contain;
  display:block;
  background:#ffffff;
  border-radius:4px;
  padding: 4px 8px;
}  */

.nav-logo {
  display: flex;
  align-items: center;
  text-decoration: none;
  flex-shrink: 0;
  /* On définit ici la zone maximale autorisée */
  height: 60px; 
  width: 260px; 
  margin: 60px 10px;
}

.nav-logo img {
  width: 100%;       /* Force l'image à prendre toute la largeur du parent */
  height: 100%;      /* Force l'image à prendre toute la hauteur du parent */
  display: block;
  object-fit: cover; /* Remplit tout l'espace (quitte à recadrer légèrement) */
  
  /* Supprimez ou réduisez ces valeurs si vous voulez que l'image touche les bords */
  padding: 0;        
  background: #ffffff;
  border-radius: 4px;
}

@media(max-width:480px){
  .nav-logo img { height:36px; max-width:180px; }
} 


/* Nav links */
.nav-links { display:flex; align-items:center; gap:.1rem; }
.nav-links > li { position:relative; }
.nav-links > li > a {
  display:block; padding:.5rem .8rem;
  color:rgba(255,255,255,.82); font-size:.82rem; font-weight:500;
  letter-spacing:.05em; text-transform:uppercase; transition:color var(--transition);
}
.nav-links > li > a:hover,
.nav-links > li > a.active { color:var(--purple-light); }

/* Dropdown */
.dropdown-menu {
  display:none; position:absolute; top:calc(100% + 2px); left:0;
  background:rgba(44,32,58,.98); border-top:2px solid var(--purple);
  min-width:250px; padding:.5rem 0; box-shadow:var(--shadow-lg);
}
.dropdown:hover .dropdown-menu { display:block; }
.dropdown-menu li a {
  display:block; padding:.55rem 1.2rem;
  color:rgba(255,255,255,.75); font-size:.82rem; transition:all var(--transition);
}
.dropdown-menu li a:hover { color:#fff; background:rgba(139,53,160,.2); padding-left:1.6rem; }

.nav-cta {
  background:var(--purple) !important; color:#fff !important;
  padding:.5rem 1.3rem !important; border-radius:var(--radius);
  font-weight:700 !important; margin-left:.5rem;
  transition:background var(--transition) !important;
}
.nav-cta:hover { background:var(--purple-dark) !important; }

/* Lang buttons */
.lang-btn {
  background:none; border:1px solid rgba(255,255,255,.2); color:#fff;
  padding:.22rem .55rem; font-size:.72rem; border-radius:2px;
  font-family:var(--font-sans); font-weight:600; letter-spacing:.05em;
  transition:all var(--transition);
}
.lang-btn.active, .lang-btn:hover { background:var(--purple); border-color:var(--purple); }

/* Mobile toggle */
.nav-toggle { display:none; flex-direction:column; gap:5px; background:none; border:none; }
.nav-toggle span { display:block; width:24px; height:2px; background:#fff; transition:var(--transition); }

/* ============ HERO — violet plus clair ============ */
.hero {
  position:relative; min-height:100vh; display:flex; align-items:center;
  background: linear-gradient(135deg, #2a0d38 0%, #8B35A0 38%, #6B2080 65%, #2a0d38 100%);
  overflow:hidden; padding-top:72px;
}
.hero::before {
  content:''; position:absolute; inset:0;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 80 80'%3E%3Cdefs%3E%3Cpattern id='g' width='10' height='10' patternUnits='userSpaceOnUse'%3E%3Cpath d='M10 0L0 0 0 10' fill='none' stroke='rgba(255,255,255,0.06)' stroke-width='0.5'/%3E%3C/pattern%3E%3C/defs%3E%3Crect width='80' height='80' fill='url(%23g)'/%3E%3C/svg%3E");
}
.hero-glow {
  position:absolute; width:700px; height:700px; border-radius:50%;
  background:radial-gradient(circle, rgba(176,92,200,.25) 0%, transparent 70%);
  right:-150px; top:-150px; pointer-events:none;
}
.hero-content {
  position:relative; z-index:1;
  max-width:1300px; margin:0 auto; padding:6rem 2rem;
  display:grid; grid-template-columns:1.1fr 1fr; gap:4rem; align-items:center;
}
.hero-badge {
  display:inline-block; padding:.3rem 1rem;
  background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.22);
  color:rgba(255,255,255,.95); font-size:.75rem; letter-spacing:.14em;
  text-transform:uppercase; font-weight:600; margin-bottom:1.5rem; border-radius:2px;
}
.hero h1 { color:#fff; margin-bottom:1.4rem; font-weight:700; }
.hero h1 span { color:#e0a8f0; }
.hero-desc { color:rgba(255,255,255,.8) !important; font-size:1.05rem !important; margin-bottom:2.5rem; max-width:520px; }
.hero-actions { display:flex; gap:1rem; flex-wrap:wrap; }

/* Hero stats */
.hero-stats { display:grid; grid-template-columns:1fr 1fr; gap:1.25rem; }
.stat-card {
  background:rgba(255,255,255,.09); border:1px solid rgba(255,255,255,.14);
  padding:1.5rem; border-radius:var(--radius); text-align:center; transition:all var(--transition);
}
.stat-card:hover { background:rgba(139,53,160,.25); border-color:rgba(176,92,200,.5); }
.stat-num { font-family:var(--font-serif); font-size:2.4rem; font-weight:700; color:#e0a8f0; line-height:1; }
.stat-label { font-size:.75rem; color:rgba(255,255,255,.6); text-transform:uppercase; letter-spacing:.1em; margin-top:.4rem; }

/* ============ PAGE HEADER ============ */
.page-header {
  background:linear-gradient(135deg, #2a0d38 0%, #6B2080 50%, #2a0d38 100%);
  padding:140px 2rem 80px; text-align:center;
}
.breadcrumb {
  display:flex; justify-content:center; align-items:center; gap:.5rem;
  margin-bottom:1.5rem; font-size:.78rem; color:rgba(255,255,255,.5);
  text-transform:uppercase; letter-spacing:.1em;
}
.breadcrumb a { color:var(--purple-light); }
.breadcrumb span { color:#fff; }
.page-header h1 { color:#fff; margin-bottom:1rem; }
.page-header > p { color:rgba(255,255,255,.72); font-size:1.08rem; max-width:600px; margin:0 auto; }

/* ============ SECTIONS ============ */
section { padding:96px 2rem; }
.section-inner { max-width:1300px; margin:0 auto; }
.section-label {
  display:inline-block; font-size:.73rem; font-weight:700;
  letter-spacing:.16em; text-transform:uppercase; color:var(--purple); margin-bottom:.9rem;
}
.section-title { margin-bottom:.8rem; color:var(--black); }
.section-subtitle { font-size:1.05rem; color:var(--gray); max-width:580px; margin-bottom:3rem; }
.section-header {
  display:flex; justify-content:space-between; align-items:flex-end;
  margin-bottom:3.5rem; flex-wrap:wrap; gap:1.5rem;
}

/* ============ PARTNERS STRIP ============ */
.partners-strip { background:#ede8f4; padding:36px 2rem; border-top:1px solid #ddd5ea; border-bottom:1px solid #ddd5ea; }
.partners-strip .inner {
  max-width:1300px; margin:0 auto;
  display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:1.5rem;
}
.partners-strip p { color:#5a4270; font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; }

/* ============ SERVICE CARDS ============ */
.services-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(275px,1fr)); gap:1.5rem; }
.service-card {
  background:#fff; border:1px solid #e8e0f0; padding:2rem;
  border-radius:var(--radius); transition:all var(--transition); position:relative; overflow:hidden;
}
.service-card::after {
  content:''; position:absolute; bottom:0; left:0;
  width:100%; height:3px; background:var(--purple);
  transform:scaleX(0); transition:transform var(--transition);
}
.service-card:hover { box-shadow:var(--shadow-lg); transform:translateY(-4px); border-color:rgba(139,53,160,.2); }
.service-card:hover::after { transform:scaleX(1); }
.service-icon {
  width:50px; height:50px; background:rgba(139,53,160,.09);
  border-radius:var(--radius); display:flex; align-items:center; justify-content:center;
  color:var(--purple); font-size:1.4rem; margin-bottom:1.2rem;
}
.service-card h3 { font-size:1.1rem; margin-bottom:.7rem; }
.service-card .link {
  display:inline-flex; align-items:center; gap:.4rem; margin-top:1.2rem;
  font-size:.82rem; font-weight:600; color:var(--purple); text-transform:uppercase; letter-spacing:.06em;
  transition:gap var(--transition);
}
.service-card .link:hover { gap:.7rem; }

/* ============ WHY US ============ */
.why-grid { display:grid; grid-template-columns:1fr 1fr; gap:4.5rem; align-items:center; }
.why-list { display:flex; flex-direction:column; gap:1.5rem; }
.why-item { display:flex; gap:1.2rem; align-items:flex-start; }
.why-icon {
  width:44px; height:44px; min-width:44px; background:var(--purple);
  border-radius:var(--radius); display:flex; align-items:center; justify-content:center; color:#fff; font-size:1.1rem;
}
.why-item h4 { font-size:.97rem; margin-bottom:.3rem; }

/* ============ REALISATION CARDS ============ */
.realisations-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(310px,1fr)); gap:2rem; }
.realisation-card {
  background:#fff; border-radius:var(--radius); overflow:hidden;
  box-shadow:var(--shadow); transition:all var(--transition);
}
.realisation-card:hover { box-shadow:var(--shadow-lg); transform:translateY(-4px); }
.realisation-card .card-img {
  height:220px; background:linear-gradient(135deg,var(--purple-dark),var(--purple));
  display:flex; align-items:center; justify-content:center; color:#fff; font-size:3rem;
  transition: transform 0.5s ease;
}
.realisation-card:hover .card-img {
  transform: scale(1.05);
}
.realisation-card .card-body { padding:1.5rem; }
.realisation-card .tag {
  font-size:.73rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  color:var(--purple); margin-bottom:.7rem;
}
.realisation-card h3 { font-size:1.1rem; margin-bottom:.7rem; }

/* ============ BLOG CARDS ============ */
.blog-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(310px,1fr)); gap:2rem; }
.blog-card {
  background:#fff; border-radius:var(--radius); overflow:hidden;
  border:1px solid #e8e0f0; transition:all var(--transition);
}
.blog-card:hover { box-shadow:var(--shadow-lg); transform:translateY(-4px); border-color:rgba(139,53,160,.2); }
.blog-card .card-img {
  height:200px; background:linear-gradient(135deg,#1a0a24,var(--purple-dark));
  display:flex; align-items:center; justify-content:center; color:#fff; font-size:2.5rem;
  overflow: hidden;
}
.blog-card .card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
}
.blog-card:hover .card-img img {
  transform: scale(1.08);
}
.blog-card .card-body { padding:1.5rem; }
.blog-card .meta {
  display:flex; gap:1rem; font-size:.76rem; color:var(--gray);
  margin-bottom:.7rem; text-transform:uppercase; letter-spacing:.06em;
}
.blog-card .meta span { color:var(--purple); }
.blog-card h3 { font-size:1.05rem; margin-bottom:.7rem; }
.blog-card .read-more {
  display:inline-flex; align-items:center; gap:.4rem; margin-top:.9rem;
  font-size:.8rem; font-weight:600; color:var(--purple);
  text-transform:uppercase; letter-spacing:.08em;
}

/* ============ PARTENAIRES CARDS ============ */
.partenaires-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:1.75rem; }
.partenaire-card {
  background:#fff; border:1px solid #e8e0f0; padding:2rem;
  border-radius:var(--radius); text-align:center; transition:all var(--transition);
}
.partenaire-card:hover { border-color:var(--purple); box-shadow:0 8px 32px rgba(139,53,160,.1); }
.partenaire-card .logo-area {
  width:76px; height:76px; margin:0 auto 1rem;
  background:rgba(139,53,160,.08); border-radius:50%;
  display:flex; align-items:center; justify-content:center; font-size:2rem; color:var(--purple);
}
.partenaire-card h3 { font-size:.97rem; margin-bottom:.5rem; }
.type {
  display:inline-block; margin-top:.9rem; padding:.22rem .72rem;
  background:rgba(139,53,160,.08); color:var(--purple);
  font-size:.73rem; border-radius:20px; font-weight:600; text-transform:uppercase; letter-spacing:.08em;
}

/* ============ FINANCEMENT TABLE ============ */
.table-wrapper { overflow-x:auto; border-radius:var(--radius); box-shadow:var(--shadow); }
.financement-table { width:100%; border-collapse:collapse; font-size:.88rem; }
.financement-table thead { background:var(--dark); color:#fff; }
.financement-table thead th { padding:.9rem 1.2rem; text-align:left; font-size:.76rem; letter-spacing:.08em; text-transform:uppercase; }
.financement-table tbody tr { border-bottom:1px solid #e8e0f0; transition:background var(--transition); }
.financement-table tbody tr:hover { background:rgba(139,53,160,.04); }
.financement-table tbody td { padding:.9rem 1.2rem; color:var(--gray-dark); }
.badge-status { display:inline-block; padding:.22rem .72rem; border-radius:20px; font-size:.73rem; font-weight:600; text-transform:uppercase; letter-spacing:.06em; }
.badge-status.open     { background:#e8f5e9; color:#2e7d32; }
.badge-status.progress { background:#fff8e1; color:#f57f17; }
.badge-status.closed   { background:#fce4ec; color:#c62828; }

/* ============ CONTACT ============ */
.contact-grid { display:grid; grid-template-columns:1fr 1.6fr; gap:4rem; }
.contact-info { display:flex; flex-direction:column; gap:1.4rem; }
.contact-item { display:flex; gap:1rem; align-items:flex-start; }
.contact-item .icon {
  width:44px; height:44px; min-width:44px; background:rgba(139,53,160,.09);
  border-radius:var(--radius); display:flex; align-items:center; justify-content:center; color:var(--purple); font-size:1.05rem;
}
.contact-item h4 { font-size:.82rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em; margin-bottom:.2rem; }
.contact-item a { color:var(--gray-dark); transition:color var(--transition); }
.contact-item a:hover { color:var(--purple); }
.contact-form { display:flex; flex-direction:column; gap:1.2rem; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1.2rem; }
.form-group { display:flex; flex-direction:column; gap:.38rem; }
.form-group label { font-size:.77rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--black); }
.form-group input, .form-group select, .form-group textarea {
  padding:.72rem 1rem; border:1px solid #ccc3d4; border-radius:3px;
  font-family:var(--font-sans); font-size:.9rem; color:var(--black); background:#fff;
  transition:border-color var(--transition); outline:none;
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color:var(--purple); }
.form-group textarea { resize:vertical; min-height:140px; }

/* ============ CTA BAND ============ */
.cta-band { background:linear-gradient(135deg,var(--purple-dark),var(--purple)); padding:76px 2rem; text-align:center; }
.cta-band h2 { color:#fff; margin-bottom:.9rem; }
.cta-band p { color:rgba(255,255,255,.8); font-size:1.05rem; margin-bottom:2rem; }

/* ============ TEAM ============ */
.team-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(250px,1fr)); gap:2rem; }
.team-card { background:#fff; border:1px solid #e8e0f0; border-radius:var(--radius); overflow:hidden; text-align:center; transition:all var(--transition); }
.team-card:hover { box-shadow:var(--shadow-lg); border-color:rgba(139,53,160,.2); }
.team-card .avatar { height:175px; background:linear-gradient(135deg,#1a0a24,var(--purple-dark)); display:flex; align-items:center; justify-content:center; font-size:3.8rem; color:rgba(255,255,255,.55); }
.team-card .team-info { padding:1.5rem; }
.team-card h3 { font-size:1.05rem; margin-bottom:.25rem; }
.team-card .role { font-size:.77rem; font-weight:700; color:var(--purple); text-transform:uppercase; letter-spacing:.08em; }

/* ============ VALUES ============ */
.values-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(215px,1fr)); gap:1.5rem; }
.value-card { text-align:center; padding:2rem 1.5rem; background:var(--bg-light); border-radius:var(--radius); border-top:3px solid var(--purple); }
.value-card .icon { font-size:2rem; margin-bottom:1rem; color:var(--purple); }
.value-card h3 { font-size:1rem; margin-bottom:.5rem; }

/* ============ BROCHURE ============ */
.brochure-content { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center; }
.mockup-page {
  background:linear-gradient(135deg,#1a0a24,var(--purple-dark)); border-radius:8px;
  padding:2.5rem; color:#fff; min-height:570px; display:flex; flex-direction:column;
  position:relative; overflow:hidden; box-shadow:0 32px 80px rgba(0,0,0,.3);
}
.mockup-page > * { position:relative; }
.download-section { background:var(--bg-light); border-radius:8px; padding:2.5rem; }
.download-option {
  display:flex; align-items:center; gap:1.25rem; padding:1.25rem;
  background:#fff; border:1px solid #e8e0f0; border-radius:var(--radius); margin-bottom:1rem;
  transition:all var(--transition); cursor:pointer;
}
.download-option:hover { border-color:var(--purple); box-shadow:0 4px 16px rgba(139,53,160,.1); }
.download-option .icon {
  width:48px; height:48px; background:rgba(139,53,160,.08); border-radius:var(--radius);
  display:flex; align-items:center; justify-content:center; font-size:1.4rem; color:var(--purple); flex-shrink:0;
}
.download-option .action { margin-left:auto; }

/* ============ FOOTER ============ */
footer { background:#2a1e38; color:rgba(255,255,255,.68); padding:76px 2rem 0; }
.footer-inner { max-width:1300px; margin:0 auto; display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:3rem; padding-bottom:3.5rem; }
.footer-brand .brand-name { font-family:var(--font-serif); color:#fff; font-size:1.05rem; font-weight:600; display:block; margin-bottom:1rem; }
.footer-brand p { font-size:.86rem; line-height:1.8; max-width:290px; }
.footer-col h4 { color:#fff; font-size:.76rem; font-weight:700; text-transform:uppercase; letter-spacing:.12em; margin-bottom:1.2rem; }
.footer-col ul { display:flex; flex-direction:column; gap:.55rem; }
.footer-col ul li a { font-size:.86rem; color:rgba(255,255,255,.57); transition:color var(--transition); }
.footer-col ul li a:hover { color:var(--purple-light); }
.footer-bottom {
  border-top:1px solid rgba(255,255,255,.08); padding:1.5rem 0;
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:1rem;
  max-width:1300px; margin:0 auto;
}
.footer-bottom p { font-size:.8rem; }
.footer-social { display:flex; gap:.65rem; }
.footer-social a {
  width:34px; height:34px; background:rgba(255,255,255,.06); border-radius:3px;
  display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.55); font-size:.88rem;
  transition:all var(--transition);
}
.footer-social a:hover { background:var(--purple); color:#fff; }

/* ============ WHATSAPP FLOAT ============ */
.whatsapp-float {
  position:fixed; bottom:2rem; right:2rem; z-index:999;
  width:54px; height:54px; background:#25D366; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  color:#fff; font-size:1.5rem;
  box-shadow:0 4px 20px rgba(37,211,102,.4); transition:all var(--transition);
}
.whatsapp-float:hover { transform:scale(1.1); box-shadow:0 8px 32px rgba(37,211,102,.5); }

/* ============ NOTIFICATION TOAST ============ */
#notification {
  position:fixed; top:100px; right:2rem; z-index:9999;
  padding:1rem 1.5rem; border-radius:var(--radius); max-width:420px;
  font-family:var(--font-sans); font-size:.88rem;
  box-shadow:0 8px 32px rgba(0,0,0,.15); transition:opacity .4s ease; opacity:0;
}

/* ============ FADE-UP ANIMATION ============ */
.fade-up { opacity:0; transform:translateY(28px); transition:opacity .6s ease, transform .6s ease; }
.fade-up.visible { opacity:1; transform:translateY(0); }
.fade-up:nth-child(1) { transition-delay:0s; }
.fade-up:nth-child(2) { transition-delay:.1s; }
.fade-up:nth-child(3) { transition-delay:.2s; }
.fade-up:nth-child(4) { transition-delay:.3s; }
.fade-up:nth-child(5) { transition-delay:.4s; }
.fade-up:nth-child(6) { transition-delay:.5s; }

/* ============ ADMIN BACKOFFICE ============ */
.admin-layout { display:flex; min-height:100vh; }
.admin-sidebar {
  width:260px; min-height:100vh; background:var(--dark);
  display:flex; flex-direction:column; flex-shrink:0; position:sticky; top:0; height:100vh; overflow-y:auto;
}
.admin-sidebar .sidebar-logo {
  padding:1.5rem; border-bottom:1px solid rgba(255,255,255,.08);
  font-family:var(--font-serif); font-size:.97rem; color:#fff; font-weight:600; line-height:1.4;
}
.admin-sidebar .sidebar-logo span { color:var(--purple-light); }
.sidebar-nav { padding:.75rem 0; flex:1; }
.sidebar-nav a {
  display:flex; align-items:center; gap:.75rem; padding:.68rem 1.5rem;
  color:rgba(255,255,255,.65); font-size:.84rem; font-weight:500;
  transition:all var(--transition); border-left:3px solid transparent;
}
.sidebar-nav a:hover, .sidebar-nav a.active { color:#fff; background:rgba(139,53,160,.18); border-left-color:var(--purple); }
.sidebar-nav a i { width:18px; text-align:center; color:var(--purple-light); }
.sidebar-nav .divider { height:1px; background:rgba(255,255,255,.07); margin:.5rem 1.5rem; }
.admin-main { flex:1; display:flex; flex-direction:column; background:#f4f1f8; min-width:0; }
.admin-topbar {
  background:#fff; padding:1rem 2rem;
  display:flex; align-items:center; justify-content:space-between;
  border-bottom:1px solid #e8e0f0; box-shadow:0 1px 4px rgba(0,0,0,.05); position:sticky; top:0; z-index:100;
}
.admin-topbar h1 { font-size:1.25rem; font-weight:600; font-family:var(--font-serif); }
.admin-content { padding:2rem; flex:1; }
.admin-tab { display:none; }
.admin-tab.active { display:block; }

/* Admin stat boxes */
.stat-boxes { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:1.25rem; margin-bottom:2rem; }
.stat-box {
  background:#fff; border-radius:var(--radius); padding:1.5rem;
  box-shadow:var(--shadow); display:flex; align-items:center; gap:1.25rem;
}
.stat-box .box-icon {
  width:50px; height:50px; border-radius:var(--radius);
  display:flex; align-items:center; justify-content:center; font-size:1.35rem; color:#fff;
}
.stat-box .box-num { font-family:var(--font-serif); font-size:2.1rem; font-weight:700; line-height:1; color:var(--black); }
.stat-box .box-label { font-size:.78rem; color:var(--gray); text-transform:uppercase; letter-spacing:.08em; margin-top:.2rem; }

/* Admin cards */
.admin-card { background:#fff; border-radius:var(--radius); box-shadow:var(--shadow); margin-bottom:2rem; overflow:hidden; }
.admin-card-header {
  padding:1.2rem 1.5rem; border-bottom:1px solid #f0ecf5;
  display:flex; justify-content:space-between; align-items:center;
}
.admin-card-header h3 { font-size:.97rem; font-weight:700; }
.admin-card-body { padding:1.5rem; }

/* Message rows */
.msg-row {
  display:flex; align-items:flex-start; gap:1rem; padding:1rem 0;
  border-bottom:1px solid #f0ecf5; cursor:pointer; transition:all var(--transition);
}
.msg-row:last-child { border-bottom:none; }
.msg-row:hover { background:#faf8fd; margin:0 -1.5rem; padding-left:1.5rem; padding-right:1.5rem; border-radius:var(--radius); }
.msg-row.unread .msg-subject { font-weight:700; color:var(--black); }
.msg-avatar {
  width:38px; height:38px; border-radius:50%; background:var(--purple);
  display:flex; align-items:center; justify-content:center; color:#fff; font-size:.88rem; font-weight:700; flex-shrink:0;
}
.msg-meta { flex:1; min-width:0; }
.msg-sender { font-size:.86rem; font-weight:600; color:var(--black); }
.msg-subject { font-size:.83rem; color:var(--gray-dark); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.msg-preview { font-size:.8rem; color:var(--gray); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.msg-time { font-size:.73rem; color:var(--gray); flex-shrink:0; }
.unread-dot { width:7px; height:7px; border-radius:50%; background:var(--purple); flex-shrink:0; margin-top:7px; }

/* Admin form */
.admin-form-grid { display:grid; grid-template-columns:1fr 1fr; gap:1.2rem; }
.admin-form-group { display:flex; flex-direction:column; gap:.35rem; }
.admin-form-group.full { grid-column:1/-1; }
.admin-form-group label { font-size:.76rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--black); }
.admin-form-group input, .admin-form-group select, .admin-form-group textarea {
  padding:.68rem 1rem; border:1px solid #ccc3d4; border-radius:3px;
  font-family:var(--font-sans); font-size:.88rem; outline:none; transition:border-color var(--transition);
}
.admin-form-group input:focus, .admin-form-group select:focus, .admin-form-group textarea:focus { border-color:var(--purple); }
.admin-form-group textarea { min-height:120px; resize:vertical; }

.badge-new  { background:rgba(139,53,160,.12); color:var(--purple); font-size:.7rem; font-weight:700; padding:.18rem .6rem; border-radius:20px; text-transform:uppercase; letter-spacing:.06em; }
.badge-read { background:#f0ecf5; color:var(--gray); font-size:.7rem; font-weight:700; padding:.18rem .6rem; border-radius:20px; text-transform:uppercase; letter-spacing:.06em; }

/* Published items table in admin */
.admin-table { width:100%; border-collapse:collapse; font-size:.86rem; }
.admin-table thead tr { background:#f7f4fa; }
.admin-table th { padding:.75rem 1rem; text-align:left; font-size:.73rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--gray-dark); border-bottom:2px solid #e8e0f0; }
.admin-table td { padding:.75rem 1rem; border-bottom:1px solid #f0ecf5; color:var(--gray-dark); vertical-align:middle; }
.admin-table tbody tr:hover { background:#faf8fd; }
.admin-table .actions { display:flex; gap:.5rem; }
.btn-sm {
  display:inline-flex; align-items:center; gap:.3rem;
  padding:.3rem .75rem; font-family:var(--font-sans); font-size:.76rem; font-weight:600;
  border-radius:3px; border:none; cursor:pointer; transition:all var(--transition);
}
.btn-sm.edit  { background:rgba(139,53,160,.1); color:var(--purple); }
.btn-sm.edit:hover  { background:var(--purple); color:#fff; }
.btn-sm.del   { background:rgba(198,40,40,.08); color:#c62828; }
.btn-sm.del:hover   { background:#c62828; color:#fff; }
.btn-sm.reply { background:rgba(46,125,50,.1); color:#2e7d32; }
.btn-sm.reply:hover { background:#2e7d32; color:#fff; }

/* Reply panel */
.reply-panel { background:#f7f4fa; border-radius:var(--radius); padding:1.5rem; margin-top:1.5rem; border:1px solid #e8e0f0; }

/* ============ RESPONSIVE ============ */
@media (max-width:1024px) {
  .footer-inner { grid-template-columns:1fr 1fr; }
  .hero-content { gap:2.5rem; }
  .admin-sidebar { width:220px; }
}
@media (max-width:768px) {
  .nav-links {
    display:none; flex-direction:column; position:absolute;
    top:72px; left:0; right:0; background:rgba(44,32,58,.98); padding:.75rem; gap:0;
  }
  .nav-links.open { display:flex; }
  .nav-links > li > a { padding:.7rem 1rem; border-radius:3px; }
  .dropdown-menu { position:static; box-shadow:none; border-top:none; background:rgba(255,255,255,.04); }
  .nav-toggle { display:flex; }
  .hero-content { grid-template-columns:1fr; text-align:center; }
  .hero-actions { justify-content:center; }
  .hero-stats { grid-template-columns:1fr 1fr; }
  .why-grid, .brochure-content, .contact-grid { grid-template-columns:1fr; }
  .form-row, .admin-form-grid { grid-template-columns:1fr; }
  .footer-inner { grid-template-columns:1fr; }
  .footer-bottom { flex-direction:column; text-align:center; }
  section { padding:60px 1.25rem; }
  .page-header { padding:120px 1.25rem 60px; }
  .admin-layout { flex-direction:column; }
  .admin-sidebar { width:100%; min-height:auto; position:static; height:auto; }
}

/* ── MAIL FLOAT BUTTON (replaces WhatsApp) ── */
.mail-float {
  background: var(--purple) !important;
}
.mail-float:hover {
  background: var(--purple-dark) !important;
}

/* ── ADMIN LOGIN LOGO RECTANGLE ── */
.login-logo-rect {
  text-align: center;
  margin: 0 auto 1.5rem;
  padding: .5rem 1rem;
  background: #f7f4fa;
  border-radius: 8px;
}

/* ── PROJECT CARDS IMAGES ── */
.project-img {
  width: 100%;
  height: 200px;
  object-fit: cover;
  display: block;
  transition: transform 0.5s ease;
}
.project-card:hover .project-img {
  transform: scale(1.03);
}

/* ── ARTICLE CARDS IMAGES ── */
.article-img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
}
.article-card:hover .article-img-wrap img {
  transform: scale(1.05);
}
