/*
Theme Name: Africa TIC Distribution
Theme URI: https://africaticdistribution.com
Author: Africa TIC Distribution
Description: Thème WordPress professionnel pour Africa TIC Distribution – Solutions Informatiques. Design bleu et rouge entièrement modifiable. Textes et images modifiables sans coder via Apparence > Personnaliser.
Version: 1.0.0
License: GNU General Public License v2 or later
Text Domain: africatic
Tags: business, technology, it, custom-colors, custom-logo, featured-images, full-width-template
*/

:root {
  --blue: #00AEEF;
  --blue-dark: #0088C8;
  --blue-light: #e8f4fd;
  --red: #C0212B;
  --red-dark: #9A1820;
  --white: #FFFFFF;
  --gray-bg: #F5F7FA;
  --gray-light: #EEF1F5;
  --gray-text: #6B7280;
  --dark: #1A1F2E;
  --dark-soft: #2D3548;
  --font-display: 'Rajdhani', sans-serif;
  --font-body: 'Nunito', sans-serif;
  --container: 1200px;
  --radius: 12px;
  --nav-h: 72px;
  --slogan-h: 38px;
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior: smooth; }
body { font-family: var(--font-body); background: var(--white); color: var(--dark); overflow-x: hidden; line-height: 1.7; }
img { max-width: 100%; display: block; }
a { text-decoration: none; color: inherit; }
.container { max-width: var(--container); margin: 0 auto; padding: 0 40px; }
.section { padding: 90px 0; }
.section-gray { background: var(--blue-light); }

/* NAV */
.site-header { position:fixed; top:0; left:0; right:0; z-index:1000; background:rgba(255,255,255,0.97); border-bottom:2px solid var(--blue); backdrop-filter:blur(10px); box-shadow:0 2px 20px rgba(0,174,239,0.1); }
.nav-inner { display:flex; align-items:center; justify-content:space-between; height:var(--nav-h); padding:0 40px; max-width:var(--container); margin:0 auto; position:relative; }
.nav-brand-link { text-decoration:none; display:flex; align-items:center; }
.nav-brand { display:inline-flex; align-items:center; font-family:var(--font-display); font-weight:700; letter-spacing:2px; border:2px solid #000; padding:6px 14px; background:rgba(255,255,255,0.95); }
.nav-brand-africa { font-size:18px; color:var(--blue); letter-spacing:2px; }
.nav-brand-tic { font-size:18px; color:var(--red); letter-spacing:2px; font-weight:700; }
.nav-brand-dist { font-size:18px; color:#000; letter-spacing:2px; font-weight:700; }
.site-logo-img { height:52px; width:auto; }
.custom-logo { height:52px; width:auto; }
.main-navigation { position:absolute; left:50%; transform:translateX(-50%); }
.main-navigation ul { display:flex; align-items:center; gap:28px; list-style:none; margin:0; padding:0; }
.main-navigation a { font-family:var(--font-display); font-size:14px; font-weight:600; letter-spacing:2px; text-transform:uppercase; color:var(--dark-soft); transition:color 0.2s; white-space:nowrap; }
.main-navigation a:hover, .main-navigation .current-menu-item > a { color:var(--blue); }
.nav-devis { background:var(--red)!important; color:var(--white)!important; padding:9px 20px!important; border-radius:6px!important; font-weight:700!important; }
.nav-devis:hover { background:var(--red-dark)!important; }

/* SLOGAN */
.slogan-bar { background:var(--blue); padding:9px 0; overflow:hidden; position:fixed; top:var(--nav-h); left:0; right:0; z-index:999; border-bottom:1px solid rgba(255,255,255,0.15); }
.slogan-track { display:flex; animation:slogan 18s linear infinite; white-space:nowrap; }
.slogan-item { display:inline-flex; align-items:center; gap:20px; padding:0 40px; font-family:var(--font-display); font-size:13px; font-weight:700; letter-spacing:4px; text-transform:uppercase; color:var(--white); }
.slogan-item::before { content:'★'; font-size:10px; opacity:0.6; }
@keyframes slogan { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }

/* CAROUSEL */
.main-carousel { position:relative; width:100%; height:420px; overflow:hidden; margin-top:calc(var(--nav-h) + var(--slogan-h)); }
.mc-slide { position:absolute; inset:0; opacity:0; transition:opacity 1s ease; }
.mc-slide.active { opacity:1; }
.mc-slide img { width:100%; height:100%; object-fit:cover; display:block; }
.mc-overlay { position:absolute; inset:0; background:linear-gradient(to right,rgba(5,15,40,0.82) 42%,rgba(5,15,40,0.12) 100%); display:flex; align-items:center; }
.mc-content { max-width:var(--container); margin:0 auto; padding:0 60px; width:100%; }
.mc-label { display:inline-block; background:var(--blue); color:var(--white); padding:5px 16px; border-radius:4px; font-family:var(--font-display); font-size:12px; font-weight:700; letter-spacing:3px; text-transform:uppercase; margin-bottom:18px; }
.mc-title { font-family:var(--font-display); font-size:clamp(34px,5vw,60px); font-weight:700; color:var(--white); line-height:1.05; letter-spacing:1px; margin-bottom:16px; }
.mc-title span { color:var(--blue); }
.mc-desc { font-size:16px; color:rgba(255,255,255,0.72); max-width:440px; line-height:1.75; margin-bottom:30px; }
.mc-prev,.mc-next { position:absolute; top:50%; transform:translateY(-50%); background:rgba(0,0,0,0.4); border:1.5px solid rgba(255,255,255,0.2); color:white; width:48px; height:48px; border-radius:50%; display:flex; align-items:center; justify-content:center; cursor:pointer; z-index:10; font-size:26px; transition:background 0.2s,border-color 0.2s; }
.mc-prev { left:24px; } .mc-next { right:24px; }
.mc-prev:hover,.mc-next:hover { background:rgba(0,174,239,0.7); border-color:var(--blue); }
.mc-dots { position:absolute; bottom:20px; left:50%; transform:translateX(-50%); display:flex; gap:10px; z-index:10; }
.mc-dot { width:10px; height:10px; border-radius:50%; background:rgba(255,255,255,0.35); border:none; cursor:pointer; transition:background 0.3s,transform 0.3s; }
.mc-dot.active { background:var(--blue); transform:scale(1.35); }

/* BOUTONS */
.btn-primary { display:inline-flex; align-items:center; gap:10px; background:var(--blue); color:var(--white); padding:14px 28px; border-radius:8px; font-family:var(--font-display); font-size:14px; font-weight:700; letter-spacing:1px; text-transform:uppercase; transition:background 0.2s,transform 0.15s; }
.btn-primary:hover { background:var(--blue-dark); transform:translateY(-2px); }
.btn-outline { display:inline-flex; align-items:center; gap:10px; border:2px solid rgba(0,174,239,0.35); color:var(--blue); padding:13px 26px; border-radius:8px; font-family:var(--font-display); font-size:14px; font-weight:600; letter-spacing:1px; text-transform:uppercase; transition:border-color 0.2s,background 0.2s; }
.btn-outline:hover { border-color:var(--blue); background:var(--blue-light); }

/* UTILITAIRES */
.section-label { display:inline-flex; align-items:center; gap:10px; font-family:var(--font-display); font-size:12px; font-weight:700; letter-spacing:4px; text-transform:uppercase; color:var(--blue); margin-bottom:14px; }
.section-label::before { content:''; width:28px; height:2px; background:var(--blue); }
.section-title { font-family:var(--font-display); font-size:clamp(30px,4vw,52px); font-weight:700; line-height:1.1; letter-spacing:0.5px; margin-bottom:16px; }
.section-title .accent { color:var(--blue); }
.section-title .red { color:var(--red); }
.divider-blue { width:56px; height:3px; background:var(--blue); margin:20px 0; }

/* TICKER */
.ticker-bar { background:var(--red); padding:12px 0; overflow:hidden; }
.ticker-track { display:flex; animation:ticker 45s linear infinite; white-space:nowrap; }
.ticker-item { display:inline-flex; align-items:center; gap:16px; padding:0 28px; font-family:var(--font-display); font-size:13px; font-weight:600; letter-spacing:2px; text-transform:uppercase; color:var(--white); }
.ticker-item::before { content:''; width:5px; height:5px; background:var(--white); border-radius:50%; opacity:0.6; }
@keyframes ticker { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }

/* SERVICES */
.services-header { display:flex; justify-content:space-between; align-items:flex-end; gap:40px; flex-wrap:wrap; margin-bottom:0; }
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:52px; }
.service-card { background:var(--white); border:1px solid var(--gray-light); border-radius:var(--radius); padding:36px 28px; position:relative; overflow:hidden; transition:transform 0.3s,box-shadow 0.3s,border-color 0.3s; }
.service-card::before { content:''; position:absolute; top:0; left:0; width:100%; height:3px; background:var(--blue); transform:scaleX(0); transform-origin:left; transition:transform 0.35s; }
.service-card:hover { transform:translateY(-6px); box-shadow:0 16px 48px rgba(0,174,239,0.12); border-color:rgba(0,174,239,0.2); }
.service-card:hover::before { transform:scaleX(1); }
.service-icon { width:56px; height:56px; background:var(--blue-light); border-radius:12px; display:flex; align-items:center; justify-content:center; margin-bottom:20px; }
.service-icon svg { width:28px; height:28px; stroke:var(--blue); fill:none; stroke-width:1.5; }
.service-title { font-family:var(--font-display); font-size:22px; font-weight:700; color:var(--dark); margin-bottom:10px; }
.service-desc { font-size:14px; color:var(--gray-text); line-height:1.8; margin-bottom:20px; }
.service-link { display:inline-flex; align-items:center; gap:6px; font-family:var(--font-display); font-size:13px; font-weight:600; letter-spacing:1px; text-transform:uppercase; color:var(--blue); border-bottom:1px solid rgba(0,174,239,0.3); padding-bottom:2px; transition:gap 0.2s; }
.service-link:hover { gap:10px; }

/* À PROPOS */
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:72px; align-items:center; }
.about-img-box { position:relative; background:var(--gray-light); border-radius:var(--radius); height:480px; display:flex; align-items:center; justify-content:center; overflow:visible; }
.about-img-box img { width:100%; height:100%; object-fit:cover; border-radius:var(--radius); }
.about-img-placeholder { display:flex; flex-direction:column; align-items:center; gap:12px; color:var(--gray-text); font-family:var(--font-display); letter-spacing:2px; font-size:12px; text-transform:uppercase; text-align:center; }
.about-year-badge { position:absolute; bottom:-20px; right:-20px; background:var(--blue); color:var(--white); width:120px; height:120px; border-radius:50%; display:flex; flex-direction:column; align-items:center; justify-content:center; font-family:var(--font-display); box-shadow:0 8px 24px rgba(0,174,239,0.4); }
.about-year-badge .yr { font-size:32px; font-weight:700; line-height:1; }
.about-year-badge .lbl { font-size:10px; letter-spacing:2px; text-transform:uppercase; opacity:0.8; }
.about-text { font-size:15px; color:var(--gray-text); line-height:1.9; margin-bottom:16px; }
.about-list { list-style:none; display:flex; flex-direction:column; gap:12px; margin:24px 0 36px; }
.about-list li { display:flex; align-items:flex-start; gap:12px; font-size:15px; color:var(--dark-soft); line-height:1.6; }
.about-list li::before { content:''; flex-shrink:0; width:20px; height:2px; background:var(--blue); margin-top:12px; }

/* CHIFFRES */
.numbers-section { background:var(--blue); padding:70px 0; }
.numbers-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:2px; background:rgba(255,255,255,0.15); }
.number-item { background:var(--blue); padding:40px 28px; text-align:center; }
.number-value { font-family:var(--font-display); font-size:60px; font-weight:700; color:var(--white); line-height:1; }
.number-label { font-family:var(--font-display); font-size:11px; font-weight:600; letter-spacing:3px; text-transform:uppercase; color:rgba(255,255,255,0.7); margin-top:8px; }

/* PRODUITS */
.products-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:52px; }
.product-card { background:var(--white); border:1px solid var(--gray-light); border-radius:var(--radius); overflow:hidden; transition:transform 0.3s,box-shadow 0.3s; }
.product-card:hover { transform:translateY(-4px); box-shadow:0 12px 36px rgba(0,0,0,0.1); }
.product-img { height:300px; overflow:hidden; display:flex; align-items:center; justify-content:center; background:var(--gray-light); }
.product-img img { width:100%; height:100%; object-fit:cover; object-position:center; display:block; }
.product-body { padding:20px; }
.product-title { font-family:var(--font-display); font-size:17px; font-weight:700; color:var(--dark); margin-bottom:6px; }
.product-desc { font-size:13px; color:var(--gray-text); line-height:1.7; }
.product-tag { display:inline-block; margin-top:12px; background:var(--blue-light); color:var(--blue); padding:4px 12px; border-radius:20px; font-size:11px; font-weight:700; letter-spacing:1px; text-transform:uppercase; }

/* PARTENAIRES */
.partners-section { background:var(--white); padding:40px 0; border-top:1px solid var(--gray-light); border-bottom:1px solid var(--gray-light); overflow:hidden; }
.partners-header { text-align:center; margin-bottom:28px; }
.partners-header span { font-family:var(--font-display); font-size:13px; font-weight:700; letter-spacing:4px; text-transform:uppercase; color:var(--gray-text); display:inline-flex; align-items:center; gap:14px; }
.partners-header span::before,.partners-header span::after { content:''; display:block; width:48px; height:1px; background:var(--gray-light); }
.partners-track-wrap { overflow:hidden; position:relative; }
.partners-track-wrap::before,.partners-track-wrap::after { content:''; position:absolute; top:0; bottom:0; width:120px; z-index:2; pointer-events:none; }
.partners-track-wrap::before { left:0; background:linear-gradient(to right,var(--white),transparent); }
.partners-track-wrap::after { right:0; background:linear-gradient(to left,var(--white),transparent); }
.partners-track { display:flex; align-items:center; animation:partners-scroll 40s linear infinite; white-space:nowrap; }
.partners-track:hover { animation-play-state:paused; }
.partner-item { display:inline-flex; align-items:center; justify-content:center; padding:0 40px; flex-shrink:0; }
.partner-item img { height:64px; width:auto; max-width:140px; object-fit:contain; filter:grayscale(40%) opacity(0.75); transition:filter 0.3s,transform 0.3s; }
.partner-item img:hover { filter:grayscale(0%) opacity(1); transform:scale(1.08); }
@keyframes partners-scroll { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }

/* CONTACT */
.contact-grid { display:grid; grid-template-columns:1fr 1.2fr; gap:72px; align-items:start; }
.contact-detail { display:flex; align-items:flex-start; gap:16px; margin-bottom:28px; padding-bottom:28px; border-bottom:1px solid var(--gray-light); }
.contact-detail:last-of-type { border-bottom:none; }
.contact-icon { width:44px; height:44px; background:var(--blue-light); border:1px solid rgba(0,174,239,0.2); border-radius:10px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.contact-icon svg { width:20px; height:20px; stroke:var(--blue); fill:none; }
.contact-lbl { font-family:var(--font-display); font-size:11px; font-weight:700; letter-spacing:3px; text-transform:uppercase; color:var(--blue); margin-bottom:4px; }
.contact-val { font-size:15px; color:var(--dark); line-height:1.6; }
input[type="text"],input[type="email"],input[type="tel"],select,textarea,.wpcf7-text,.wpcf7-email,.wpcf7-tel,.wpcf7-textarea,.wpcf7-select { background:var(--gray-bg); border:1.5px solid var(--gray-light); color:var(--dark); padding:13px 16px; font-family:var(--font-body); font-size:15px; border-radius:8px; outline:none; width:100%; transition:border-color 0.2s; appearance:none; }
input:focus,select:focus,textarea:focus { border-color:var(--blue); background:var(--white); }
textarea { min-height:130px; resize:vertical; }
input[type="submit"],.wpcf7-submit,.form-submit { display:flex; align-items:center; justify-content:center; gap:10px; background:var(--blue); color:var(--white); padding:16px 32px; border-radius:8px; font-family:var(--font-display); font-size:14px; font-weight:700; letter-spacing:1px; text-transform:uppercase; border:none; cursor:pointer; width:100%; transition:background 0.2s; }
input[type="submit"]:hover,.wpcf7-submit:hover { background:var(--blue-dark); }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-group { display:flex; flex-direction:column; gap:7px; }
.form-lbl { font-family:var(--font-display); font-size:11px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--gray-text); }

/* FOOTER */
.site-footer { background:#0D1B2A; padding:64px 0 0; border-top:3px solid var(--blue); }
.footer-grid { display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:48px; padding-bottom:52px; border-bottom:1px solid rgba(255,255,255,0.08); }
.footer-logo-img { height:56px; width:auto; margin-bottom:18px; }
.footer-desc { font-size:14px; color:rgba(255,255,255,0.5); line-height:1.8; max-width:260px; margin-bottom:24px; }
.footer-socials { display:flex; gap:10px; }
.social-btn { width:36px; height:36px; border-radius:8px; border:1px solid rgba(255,255,255,0.1); display:flex; align-items:center; justify-content:center; transition:border-color 0.2s,background 0.2s; }
.social-btn:hover { border-color:var(--blue); background:rgba(0,174,239,0.1); }
.social-btn svg { width:16px; height:16px; fill:rgba(255,255,255,0.5); transition:fill 0.2s; }
.social-btn:hover svg { fill:var(--blue); }
.footer-col-title { font-family:var(--font-display); font-size:11px; font-weight:700; letter-spacing:3px; text-transform:uppercase; color:var(--blue); margin-bottom:20px; }
.footer-links { list-style:none; display:flex; flex-direction:column; gap:10px; }
.footer-links a { font-size:14px; color:rgba(255,255,255,0.5); transition:color 0.2s,padding-left 0.2s; }
.footer-links a:hover { color:var(--white); padding-left:6px; }
.footer-bottom { display:flex; align-items:center; justify-content:space-between; padding:20px 0; gap:16px; flex-wrap:wrap; }
.footer-copy { font-size:12px; color:rgba(255,255,255,0.3); font-family:var(--font-display); letter-spacing:1px; }

/* RESPONSIVE */
@media(max-width:1024px) { .services-grid{grid-template-columns:repeat(2,1fr);} .products-grid{grid-template-columns:repeat(2,1fr);} .numbers-grid{grid-template-columns:repeat(2,1fr);} .footer-grid{grid-template-columns:1fr 1fr;gap:32px;} }
@media(max-width:768px) { .container{padding:0 20px;} .nav-inner{padding:0 20px;} .main-navigation{display:none;} .about-grid,.contact-grid{grid-template-columns:1fr;gap:40px;} .services-grid,.products-grid{grid-template-columns:1fr;} .numbers-grid{grid-template-columns:repeat(2,1fr);} .footer-grid{grid-template-columns:1fr;gap:28px;} .form-row{grid-template-columns:1fr;} .main-carousel{height:360px;} .mc-content{padding:0 20px;} }

/* RESET PLEINE LARGEUR - Compatibilité tous thèmes WordPress */
html, body { width: 100% !important; max-width: 100% !important; }
#page, .site, #content, #primary, main, article { max-width: 100% !important; width: 100% !important; padding: 0 !important; margin: 0 !important; }
.entry-content, .post-content { max-width: 100% !important; }
