/* ============================== SOFTPAC THEME – Dark only (v2) ============================== */
:root{
  --bg-color:#0d1019;
  --card-bg:#111625;
  --border-color:#1b2233;
  --text-color:#e6efe8;
  --text-secondary:#a7b5ae;
  --primary:#59b95f;

  --shadow-soft:0 10px 30px rgba(89,185,95,.15);
  --radius:20px;

  --font-body:"Space Grotesk", system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --font-display:"Orbitron", system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;

  --logo-h-desktop:56px;
  --logo-h-mobile:46px;
}

/* Reset & base */
*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%}
body{
  font-family:var(--font-body);
  background:var(--bg-color);
  color:var(--text-color);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale
}
img{max-width:100%;display:block}
a{color:var(--primary);text-decoration:none;transition:opacity .2s ease}
a:hover{opacity:.92}

.container{max-width:1100px;margin:0 auto;padding:0 20px}
.center{text-align:center}
.mt-3{margin-top:1rem}
.mt-4{margin-top:1.5rem}

/* ============================== Header & Nav (burger mobile) ============================== */
.site-header{
  position:sticky;top:0;z-index:1000;width:100%;
  padding:.75rem 0;
  background:linear-gradient(180deg, rgba(13,16,25,.92), rgba(13,16,25,.75));
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--border-color)
}
.main-nav{
  display:flex;justify-content:space-between;align-items:center;
  max-width:1100px;margin:0 auto;padding:0 20px; position:relative;
}

/* Logo */
.logo{display:flex;align-items:center;gap:14px;color:#fff}
.logo-img{
  height:var(--logo-h-desktop);width:auto;
  filter:drop-shadow(0 4px 12px rgba(89,185,95,.25));
  transition:transform .18s ease, filter .18s ease
}
.logo-text{
  font-family:var(--font-display);font-weight:900;letter-spacing:1.2px;
  font-size:clamp(20px,2.2vw,26px);text-transform:uppercase;color:#fff
}
.logo:hover .logo-img{transform:translateY(-1px);filter:drop-shadow(0 6px 16px rgba(89,185,95,.35))}
@media (max-width:768px){.logo-img{height:var(--logo-h-mobile)}}

/* Nav links + icônes */
.nav-links{list-style:none;display:flex;align-items:center;gap:22px}
.nav-links a{
  display:inline-flex;align-items:center;gap:10px;
  color:var(--text-secondary);padding:8px 0;font-weight:800;
  font-family:var(--font-display);letter-spacing:.4px;position:relative
}
.nav-links a i{font-size:1.05em;color:var(--primary)}
.nav-links a:hover{color:var(--text-color)}
.nav-links a.active{color:#fff}
.nav-links a.active::after,.nav-links a:hover::after{
  content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;border-radius:2px;background:var(--primary)
}

/* Burger */
.nav-toggle{
  display:none;background:none;border:1px solid var(--border-color);
  color:#fff;border-radius:12px;padding:.4rem .6rem;font-size:1.1rem;cursor:pointer
}
.theme-switch-wrapper{display:none !important}

/* Menu mobile */
@media (max-width:768px){
  .nav-toggle{display:block}
  .nav-links{
    position:absolute;top:100%;left:0;right:0;display:none;flex-direction:column;gap:14px;
    background:rgba(13,16,25,.98);padding:12px 20px 18px;border-bottom:1px solid var(--border-color)
  }
  .main-nav.open .nav-links{display:flex}
}

/* ============================== Hero / Titres ============================== */
main{padding:4rem 0}
.hero{
  text-align:center;padding:6rem 0;border-bottom:1px solid var(--border-color);
  background:
    radial-gradient(800px 300px at 10% -10%, rgba(89,185,95,.10), transparent 60%),
    radial-gradient(800px 300px at 90% 0%,  rgba(89,185,95,.06), transparent 60%),
    var(--bg-color)
}
.hero-content{max-width:800px;margin:0 auto}
h1,h2,h3{font-family:var(--font-display);font-weight:800;line-height:1.2;color:var(--text-color)}
h1{font-size:clamp(2.4rem,5vw,4rem);margin-bottom:1.5rem}
h2{font-size:clamp(1.8rem,4vw,2.5rem);margin-bottom:.75rem}
h3{font-size:1.5rem}
.hero p{font-size:1.2rem;margin-bottom:2.2rem;color:var(--text-secondary)}

/* Icône dans le titre de page */
.page-header{ text-align:center; padding:2rem 0 4rem }
.page-header .page-title{ display:inline-flex;align-items:center;gap:10px }
.page-header .page-title i{ color:var(--primary) }

/* ============================== Boutons & Badges ============================== */
.btn,button,input[type="submit"]{
  display:inline-block;padding:14px 32px;border-radius:14px;border:1px solid transparent;
  font-weight:900;font-family:var(--font-display);font-size:1rem;cursor:pointer;
  background:var(--primary);color:#0b0f17;box-shadow:0 6px 16px rgba(89,185,95,.25);
  transition:transform .15s ease,filter .2s ease,box-shadow .2s ease
}
.btn:hover,button:hover,input[type="submit"]:hover{
  transform:translateY(-2px);filter:saturate(1.04) brightness(1.02);
  box-shadow:0 10px 24px rgba(89,185,95,.28)
}
.badge-cyber{
  display:inline-flex;align-items:center;gap:8px;margin-left:14px;
  background:rgba(89,185,95,.08);border:1px solid rgba(89,185,95,.35);
  color:var(--primary);padding:.35rem .65rem;border-radius:999px;font-weight:700;font-size:.85rem
}

/* ============================== Cartes / Grilles ============================== */
.card,.service-card,.testimonial-card,.project-card{
  background:var(--card-bg);
  border-radius:var(--radius);
  border:1px solid var(--border-color);
  padding:2.2rem;margin-bottom:2rem;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
  position:relative; 
  padding-bottom:4.5rem; 
}
.card:hover,.service-card:hover,.project-card:hover,.testimonial-card:hover{
  transform:translateY(-6px);
  border-color:rgba(89,185,95,.35);
  box-shadow:var(--shadow-soft)
}

/* Grilles + images adaptatives */
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem}
.projects-gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem}
.project-image{width:100%;height:clamp(180px,28vw,260px);background:#0f1421;display:flex;align-items:center;justify-content:center}
.project-image img{width:100%;height:100%;object-fit:cover}

/* Textes cartes */
.project-title{font-size:1.25rem;margin-bottom:.4rem}
.project-description{font-size:1rem;color:var(--text-secondary)}

/* ============================== Tags / Compétences – position FIXE ============================== */
.card-tags, .project-tags, .skills, .service-tags{
  position:absolute;left:1.5rem;right:1.5rem;bottom:1.2rem;
  display:flex;flex-wrap:wrap;gap:.5rem
}
.card-tag, .project-tags .tag, .skills .tag, .service-tags .tag, .badge-cyber{
  background:rgba(89,185,95,.08);
  border:1px solid rgba(89,185,95,.35);
  color:var(--primary);
  padding:.25rem .7rem;border-radius:20px;font-size:.8rem;font-weight:700
}

/* ============================== Contact ============================== */
.contact-layout{display:grid;grid-template-columns:2fr 1fr;gap:2rem;align-items:flex-start}
.contact-form .form-group{margin-bottom:1.5rem}
.contact-form label{display:block;margin-bottom:.5rem;font-weight:700;color:var(--text-secondary)}
.contact-form input,.contact-form textarea{
  width:100%;padding:1rem;border:1px solid var(--border-color);border-radius:12px;
  background:#0f1421;color:var(--text-color);font-size:1rem;transition:border-color .2s, box-shadow .2s
}
.contact-form input:focus,.contact-form textarea:focus{
  outline:none;border-color:rgba(89,185,95,.55);box-shadow:0 0 0 3px rgba(89,185,95,.18)
}
.contact-info-card{padding:2.5rem}
.contact-details{list-style:none;margin-top:1rem}
.contact-details li{margin-bottom:.5rem;color:var(--text-secondary)}
.contact-details a{color:var(--primary)}

/* ============================== Footer ============================== */
.site-footer{
  background:linear-gradient(180deg, rgba(17,22,37,.85), rgba(13,16,25,1));
  color:var(--text-secondary);
  padding:4rem 20px;margin-top:4rem;border-top:1px solid var(--border-color);text-align:left
}
.footer-content{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));
  gap:3rem;align-items:start;max-width:1100px;margin:0 auto
}
.footer-logo{font-size:1.8rem;font-weight:900;letter-spacing:1px;margin-bottom:.5rem;color:#fff;font-family:var(--font-display)}
.footer-about p{font-size:.95rem;line-height:1.7}
.footer-title{font-size:1.2rem;font-weight:900;margin-bottom:1rem;color:#fff;font-family:var(--font-display)}
.footer-links ul{list-style:none;display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem 2rem}
.footer-links a{color:var(--text-secondary)}
.footer-links a:hover{color:#fff}
.social-icons{display:flex;gap:1.1rem;flex-wrap:wrap}
.social-icons a{color:var(--text-secondary);font-size:1.6rem;transition:color .2s ease, transform .2s ease}
.social-icons a:hover{color:var(--primary);transform:translateY(-2px)}
.footer-bottom{text-align:center;margin-top:3rem;padding-top:2rem;border-top:1px solid var(--border-color);font-size:.9rem}
.footer-bottom a{color:var(--primary)}
.footer-bottom a:hover{opacity:.92}

/* ============================== Espaces demandés ============================== */
.home-services{margin-bottom:80px}
.home-services .btn{margin-bottom:12px}

/* ============================== Animations & Responsive ============================== */
.fade-in-section{opacity:0;transform:translateY(30px);transition:opacity .8s cubic-bezier(.645,.045,.355,1), transform .8s cubic-bezier(.645,.045,.355,1);transition-delay:.2s}
.fade-in-section.is-visible{opacity:1;transform:none}

@media (max-width:900px){.contact-layout{grid-template-columns:1fr}}
@media (max-width:768px){
  .hero{padding:4rem 0}
}
/* ======= Compact: supprimer l'espace entre navbar et titre (index + contact) ======= */
main.compact { padding-top: 0 !important; }              
.hero.compact-hero { padding-top: 1.5rem !important; }    
  .hero.compact-hero { padding-top: 0.75rem !important; }

/* ==== STOP CROP/ZOOM SUR LES IMAGES DE PROJETS ==== */
.project-image{
  height: clamp(180px, 28vw, 260px); 
  background: #0f1421;              
  display: flex; align-items: center; justify-content: center;
}
.project-image img{
  width: 100%;
  height: 100%;
  object-fit: contain !important;     
  transform: none !important;         
}
