/* =====================================================
   PAP CONNECTING — v9
   Style Fortinet : sections sombres + blanc + bleu vif
   Inter — dark banners, photo sections, rich visuals
   ===================================================== */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap');

:root {
  --navy:    #0D1B3E;
  --navy2:   #162447;
  --blue:    #1A56DB;
  --blue-l:  #3B82F6;
  --blue-bg: #EFF4FF;
  --dark:    #111827;
  --dark2:   #1F2937;
  --white:   #FFFFFF;
  --off:     #F8FAFC;
  --gray:    #6B7280;
  --gray-l:  #E5E7EB;
  --text:    #1F2937;
  --font:    'Inter', -apple-system, sans-serif;
  --radius:  10px;
  --radius-lg: 16px;
  --shadow:  0 2px 20px rgba(0,0,0,.08);
  --shadow-lg: 0 8px 48px rgba(0,0,0,.14);
  --nav-h:   72px;
  --t:       .25s ease;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: var(--font); color: var(--text); background: var(--white); line-height: 1.65; -webkit-font-smoothing: antialiased; }
img { max-width: 100%; display: block; }
a { text-decoration: none; color: inherit; }
ul { list-style: none; }

.container { max-width: 1200px; margin: 0 auto; padding: 0 32px; }
.section { padding: 96px 0; }
.section--white  { background: var(--white); }
.section--off    { background: var(--off); }
.section--dark   { background: var(--dark); }
.section--navy   { background: var(--navy); }

.eyebrow { display:inline-flex; align-items:center; gap:8px; font-size:.7rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--blue); margin-bottom:14px; }
.eyebrow::before { content:''; display:block; width:20px; height:2px; background:currentColor; border-radius:2px; }
.eyebrow--white { color:rgba(255,255,255,.6); }
.eyebrow--white::before { background:rgba(255,255,255,.6); }

.h2 { font-size:clamp(1.8rem,3vw,2.6rem); font-weight:900; line-height:1.15; letter-spacing:-.025em; color:var(--navy); }
.h2--white { color:#fff; }
.section-sub { font-size:1.02rem; color:var(--gray); line-height:1.78; max-width:600px; }
.section-sub--white { color:rgba(255,255,255,.6); }
.divider { width:40px; height:3px; background:var(--blue); border-radius:2px; margin:16px 0 24px; }
.divider--center { margin-left:auto; margin-right:auto; }
.divider--white { background:rgba(255,255,255,.4); }
.section-header { text-align:center; max-width:720px; margin:0 auto 64px; }
.section-header .h2 { margin-bottom:16px; }

.btn { display:inline-flex; align-items:center; gap:8px; padding:13px 28px; border-radius:var(--radius); font-size:.9rem; font-weight:700; cursor:pointer; transition:var(--t); border:2px solid transparent; font-family:var(--font); letter-spacing:.01em; }
.btn-blue   { background:var(--blue); color:#fff; border-color:var(--blue); }
.btn-blue:hover   { background:#1344c0; transform:translateY(-2px); box-shadow:0 8px 24px rgba(26,86,219,.35); }
.btn-navy   { background:var(--navy); color:#fff; border-color:var(--navy); }
.btn-navy:hover   { background:#0a1530; transform:translateY(-2px); }
.btn-white  { background:#fff; color:var(--navy); border-color:#fff; }
.btn-white:hover  { background:#f1f5f9; transform:translateY(-2px); }
.btn-outline-white { background:transparent; color:#fff; border-color:rgba(255,255,255,.5); }
.btn-outline-white:hover { border-color:#fff; background:rgba(255,255,255,.08); }
.btn-outline-blue { background:transparent; color:var(--blue); border-color:var(--blue); }
.btn-outline-blue:hover { background:var(--blue); color:#fff; }
.btn-pill { border-radius:50px; }
.btn-lg { padding:16px 36px; font-size:1rem; }

/* NAV */
.nav { position:fixed; top:0; left:0; right:0; height:var(--nav-h); z-index:1000; background:rgba(255,255,255,.97); backdrop-filter:blur(12px); border-bottom:1px solid var(--gray-l); transition:box-shadow var(--t); }
.nav.scrolled { box-shadow:0 2px 24px rgba(0,0,0,.1); }
.nav-inner { display:flex; align-items:center; justify-content:space-between; height:100%; }
.nav-logo { display:flex; align-items:center; gap:12px; }
.nav-logo-img { height:40px; width:auto; }
.nav-logo-text { font-weight:800; font-size:.98rem; color:var(--navy); line-height:1.18; letter-spacing:-.015em; }
.nav-logo-text span { display:block; font-size:.58rem; font-weight:600; letter-spacing:.14em; color:var(--blue); text-transform:uppercase; }
.nav-links { display:flex; align-items:center; gap:2px; }
.nav-links a { padding:8px 16px; border-radius:8px; font-size:.82rem; font-weight:600; color:var(--gray); transition:color var(--t),background var(--t); text-transform:uppercase; letter-spacing:.05em; }
.nav-links a:hover, .nav-links a.active { color:var(--navy); background:var(--blue-bg); }
.nav-cta { margin-left:14px; }
.hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:8px; background:none; border:none; }
.hamburger span { display:block; width:22px; height:2px; background:var(--navy); border-radius:2px; transition:var(--t); }
.mobile-menu { display:none; position:fixed; top:var(--nav-h); left:0; right:0; background:#fff; padding:16px 28px 24px; z-index:999; border-top:1px solid var(--gray-l); flex-direction:column; gap:4px; box-shadow:var(--shadow-lg); }
.mobile-menu.open { display:flex; }
.mobile-menu a { display:block; padding:12px 16px; font-weight:600; color:var(--gray); border-radius:8px; font-size:.9rem; }
.mobile-menu a:hover { background:var(--off); color:var(--navy); }
.mobile-menu .btn { margin-top:10px; justify-content:center; }

/* PAGE HERO */
.page-hero { background:var(--navy); padding:calc(var(--nav-h) + 72px) 0 72px; position:relative; overflow:hidden; }
.page-hero-bg { position:absolute; inset:0; background-size:cover; background-position:center; opacity:.14; }
.page-hero-overlay { position:absolute; inset:0; background:linear-gradient(135deg, rgba(13,27,62,.97) 0%, rgba(26,86,219,.65) 100%); }
.page-hero .container { position:relative; z-index:2; }
.breadcrumb { display:flex; align-items:center; gap:8px; font-size:.75rem; color:rgba(255,255,255,.45); margin-bottom:20px; }
.breadcrumb a { color:rgba(255,255,255,.45); }
.breadcrumb a:hover { color:rgba(255,255,255,.85); }
.breadcrumb span { color:rgba(255,255,255,.25); }
.page-hero h1 { font-size:clamp(2rem,4.5vw,3.2rem); font-weight:900; color:#fff; line-height:1.1; margin-bottom:18px; letter-spacing:-.035em; }
.page-hero p { font-size:1.05rem; color:rgba(255,255,255,.65); max-width:580px; line-height:1.75; }

/* HERO */
.hero { min-height:100vh; background:var(--navy); display:flex; align-items:center; position:relative; overflow:hidden; padding-top:var(--nav-h); }
.hero-photo { position:absolute; inset:0; background:url('https://images.unsplash.com/photo-1558494949-ef010cbdcc31?w=1800&q=80') center/cover no-repeat; }
.hero-overlay { position:absolute; inset:0; background:linear-gradient(100deg, rgba(13,27,62,.97) 50%, rgba(26,86,219,.55) 100%); }
.hero-inner { position:relative; z-index:2; display:grid; grid-template-columns:1fr 420px; gap:72px; align-items:center; padding:96px 0; width:100%; }
.hero-badge { display:inline-flex; align-items:center; gap:8px; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.18); border-radius:50px; padding:6px 18px; font-size:.72rem; font-weight:700; color:rgba(255,255,255,.85); letter-spacing:.12em; text-transform:uppercase; margin-bottom:28px; }
.badge-dot { width:7px; height:7px; background:#34D399; border-radius:50%; animation:blink 2s ease-in-out infinite; flex-shrink:0; }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.35} }
.hero h1 { font-size:clamp(2.6rem,5.5vw,4.4rem); font-weight:900; color:#fff; line-height:1.08; letter-spacing:-.04em; margin-bottom:24px; }
.hero h1 em { font-style:normal; color:#60A5FA; }
.hero-desc { font-size:1.08rem; color:rgba(255,255,255,.68); line-height:1.8; max-width:540px; margin-bottom:44px; }
.hero-actions { display:flex; gap:14px; flex-wrap:wrap; margin-bottom:60px; }
.hero-certifs { display:flex; align-items:center; gap:14px; flex-wrap:wrap; }
.hero-certifs-label { font-size:.68rem; font-weight:700; color:rgba(255,255,255,.35); letter-spacing:.14em; text-transform:uppercase; }
.hero-pills { display:flex; gap:8px; flex-wrap:wrap; }
.hero-pill { padding:5px 13px; background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.16); border-radius:50px; font-size:.72rem; font-weight:700; color:rgba(255,255,255,.7); }
.hero-panel { display:flex; flex-direction:column; gap:14px; }
.hstat { background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.1); border-radius:var(--radius-lg); padding:22px 26px; border-left:3px solid var(--blue-l); transition:background var(--t); }
.hstat:hover { background:rgba(255,255,255,.09); }
.hstat-num { font-size:2.8rem; font-weight:900; color:#60A5FA; line-height:1; letter-spacing:-.05em; margin-bottom:5px; }
.hstat-label { font-size:.76rem; font-weight:600; color:rgba(255,255,255,.45); text-transform:uppercase; letter-spacing:.08em; }
.hstat-cta { background:rgba(26,86,219,.2); border-color:rgba(26,86,219,.4); }
.hstat-cta p { font-size:.9rem; font-weight:700; color:#fff; margin-bottom:14px; }

/* TICKER */
.clients-bar { background:var(--off); border-bottom:1px solid var(--gray-l); padding:20px 0; overflow:hidden; }
.clients-label { font-size:.68rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--gray); margin-bottom:12px; }
.ticker-wrap { overflow:hidden; position:relative; }
.ticker-wrap::before,.ticker-wrap::after { content:''; position:absolute; top:0; bottom:0; width:80px; z-index:2; }
.ticker-wrap::before { left:0; background:linear-gradient(to right,var(--off),transparent); }
.ticker-wrap::after  { right:0; background:linear-gradient(to left,var(--off),transparent); }
.ticker { display:flex; align-items:center; animation:ticker 32s linear infinite; width:max-content; }
.ticker-item { display:flex; align-items:center; gap:10px; padding:0 18px; }
.ticker-logo { display:flex; align-items:center; gap:7px; height:36px; padding:0 14px; background:#fff; border:1px solid var(--gray-l); border-radius:8px; font-size:.78rem; font-weight:800; color:var(--navy); white-space:nowrap; box-shadow:0 1px 4px rgba(0,0,0,.05); }
.ticker-logo-icon { font-size:.9rem; }
.ticker-sep { color:var(--blue); font-size:.6rem; }
@keyframes ticker { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }

/* ABOUT */
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.about-photo-wrap { position:relative; }
.about-photo { border-radius:var(--radius-lg); overflow:hidden; height:480px; box-shadow:var(--shadow-lg); position:relative; }
.about-photo img { width:100%; height:100%; object-fit:cover; }
.about-photo-overlay { position:absolute; inset:0; background:linear-gradient(to top, rgba(13,27,62,.65) 0%, transparent 55%); }
.about-photo-badge { position:absolute; bottom:24px; left:24px; z-index:2; background:var(--blue); color:#fff; padding:12px 20px; border-radius:var(--radius); font-weight:800; font-size:.88rem; }
.about-photo-badge span { display:block; font-size:1.7rem; font-weight:900; line-height:1; }
.about-kpi { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin:32px 0; }
.kpi-card { text-align:center; padding:18px 12px; background:var(--blue-bg); border-radius:var(--radius); border:1px solid rgba(26,86,219,.15); }
.kpi-num { font-size:2rem; font-weight:900; color:var(--blue); letter-spacing:-.04em; line-height:1; margin-bottom:4px; }
.kpi-lbl { font-size:.68rem; color:var(--gray); font-weight:700; text-transform:uppercase; letter-spacing:.1em; }

/* SERVICES CARDS */
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:56px; }
.svc-card { background:var(--white); border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--gray-l); transition:transform var(--t),box-shadow var(--t),border-color var(--t); }
.svc-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-lg); border-color:rgba(26,86,219,.3); }
.svc-card-photo { height:180px; overflow:hidden; position:relative; }
.svc-card-photo img { width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.svc-card:hover .svc-card-photo img { transform:scale(1.06); }
.svc-card-photo-overlay { position:absolute; inset:0; background:linear-gradient(to bottom,transparent 40%,rgba(13,27,62,.4)); }
.svc-card-body { padding:24px 22px; }
.svc-card-icon { width:46px; height:46px; border-radius:10px; background:var(--blue-bg); border:1px solid rgba(26,86,219,.2); display:flex; align-items:center; justify-content:center; margin-bottom:16px; }
.svc-card-icon svg { width:22px; height:22px; stroke:var(--blue); fill:none; }
.svc-card h3 { font-size:.9rem; font-weight:800; color:var(--navy); margin-bottom:8px; text-transform:uppercase; letter-spacing:.04em; }
.svc-card p { font-size:.84rem; color:var(--gray); line-height:1.65; }
.svc-tags { display:flex; flex-wrap:wrap; gap:6px; margin-top:14px; }
.svc-tag { padding:3px 10px; background:var(--blue-bg); border-radius:50px; font-size:.68rem; font-weight:700; color:var(--blue); }

/* PARTENAIRES DARK */
.partners-dark { background:var(--navy); padding:88px 0; position:relative; overflow:hidden; }
.partners-dark::before { content:''; position:absolute; inset:0; background:url('https://images.unsplash.com/photo-1451187580459-43490279c0fa?w=1600&q=50') center/cover; opacity:.06; }
.partners-grid-v2 { display:grid; grid-template-columns:repeat(7,1fr); gap:12px; margin-top:52px; }
.partner-badge { display:flex; flex-direction:column; align-items:center; justify-content:center; gap:8px; padding:20px 12px; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.1); border-radius:var(--radius); cursor:pointer; transition:var(--t); text-align:center; }
.partner-badge:hover { background:rgba(255,255,255,.12); border-color:rgba(59,130,246,.6); transform:translateY(-3px); }
.partner-badge-icon { font-size:1.6rem; line-height:1; }
.partner-badge-name { font-size:.76rem; font-weight:800; color:#fff; }
.partner-badge-cat { font-size:.58rem; color:rgba(255,255,255,.38); text-transform:uppercase; letter-spacing:.08em; font-weight:600; }

/* CLIENTS */
.clients-section { background:var(--off); padding:88px 0; }
.clients-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:16px; margin-top:52px; }
.client-card { background:var(--white); border:1px solid var(--gray-l); border-radius:var(--radius-lg); padding:28px 16px; display:flex; flex-direction:column; align-items:center; gap:10px; text-align:center; transition:var(--t); }
.client-card:hover { border-color:var(--blue); box-shadow:var(--shadow); transform:translateY(-4px); }
.client-icon { width:54px; height:54px; border-radius:14px; display:flex; align-items:center; justify-content:center; font-size:1.5rem; flex-shrink:0; }
.client-name { font-size:.86rem; font-weight:800; color:var(--navy); }
.client-sector { font-size:.64rem; color:var(--gray); font-weight:600; text-transform:uppercase; letter-spacing:.08em; }

/* SKILLS DARK */
.skills-section { background:var(--dark); padding:96px 0; position:relative; overflow:hidden; }
.skills-section::before { content:''; position:absolute; inset:0; background:url('https://images.unsplash.com/photo-1558494949-ef010cbdcc31?w=1600&q=40') center/cover; opacity:.04; }
.skills-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; margin-top:56px; background:rgba(255,255,255,.04); border-radius:var(--radius-lg); overflow:hidden; }
.skill-tile { background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.06); padding:36px 28px; transition:background var(--t); }
.skill-tile:hover { background:rgba(255,255,255,.07); }
.skill-tile-num { font-size:.65rem; font-weight:900; letter-spacing:.16em; color:rgba(255,255,255,.2); text-transform:uppercase; margin-bottom:14px; }
.skill-tile-icon { width:46px; height:46px; border-radius:12px; background:rgba(26,86,219,.15); border:1px solid rgba(26,86,219,.3); display:flex; align-items:center; justify-content:center; margin-bottom:18px; }
.skill-tile-icon svg { width:22px; height:22px; stroke:#60A5FA; fill:none; }
.skill-tile h3 { font-size:.95rem; font-weight:800; color:#fff; margin-bottom:8px; }
.skill-tile p { font-size:.83rem; color:rgba(255,255,255,.48); line-height:1.7; }

/* USE CASES */
.usecases-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:56px; }
.uc-card { background:var(--white); border:1px solid var(--gray-l); border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow); transition:var(--t); }
.uc-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); border-color:rgba(26,86,219,.25); }
.uc-card-photo { height:155px; overflow:hidden; position:relative; }
.uc-card-photo img { width:100%; height:100%; object-fit:cover; }
.uc-card-photo-overlay { position:absolute; inset:0; background:linear-gradient(to bottom,transparent,rgba(13,27,62,.45)); }
.uc-card-body { padding:22px; }
.uc-sector { font-size:.65rem; font-weight:800; letter-spacing:.14em; text-transform:uppercase; color:var(--blue); margin-bottom:14px; }
.uc-list { display:flex; flex-direction:column; gap:8px; }
.uc-list li { padding:8px 12px 8px 24px; background:var(--off); border-radius:6px; font-size:.82rem; color:var(--text); font-weight:500; position:relative; }
.uc-list li::before { content:''; position:absolute; left:9px; top:50%; transform:translateY(-50%); width:6px; height:6px; background:var(--blue); border-radius:50%; }

/* CTA DARK */
.cta-dark { background:var(--dark); padding:88px 0; position:relative; overflow:hidden; text-align:center; }
.cta-dark::before { content:''; position:absolute; inset:0; background:url('https://images.unsplash.com/photo-1506818144585-74b29c980d4b?w=1600&q=50') center/cover; opacity:.05; }
.cta-dark-accent { position:absolute; top:0; left:0; right:0; height:3px; background:linear-gradient(90deg,var(--blue),#60A5FA,var(--blue)); }
.cta-dark .container { position:relative; z-index:2; }
.cta-dark h2 { font-size:clamp(1.8rem,3.5vw,2.8rem); font-weight:900; color:#fff; margin-bottom:16px; letter-spacing:-.03em; }
.cta-dark p { font-size:1rem; color:rgba(255,255,255,.58); margin-bottom:40px; max-width:520px; margin-left:auto; margin-right:auto; line-height:1.75; }
.cta-dark-actions { display:flex; justify-content:center; gap:14px; flex-wrap:wrap; }

/* FOOTER */
footer { background:#060D24; padding:72px 0 0; }
.footer-grid { display:grid; grid-template-columns:320px 1fr 1fr 1fr; gap:56px; padding-bottom:64px; border-bottom:1px solid rgba(255,255,255,.07); }
.footer-brand p { font-size:.84rem; color:rgba(255,255,255,.4); line-height:1.75; margin:20px 0 28px; }
.footer-social { display:flex; gap:10px; }
.social-btn { width:38px; height:38px; border-radius:8px; background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.12); display:flex; align-items:center; justify-content:center; font-size:.78rem; font-weight:800; color:rgba(255,255,255,.55); transition:var(--t); }
.social-btn:hover { background:var(--blue); border-color:var(--blue); color:#fff; }
.footer-col h4 { font-size:.65rem; font-weight:800; letter-spacing:.18em; text-transform:uppercase; color:rgba(255,255,255,.3); margin-bottom:22px; }
.footer-col ul { display:flex; flex-direction:column; gap:10px; }
.footer-col ul li a { font-size:.84rem; color:rgba(255,255,255,.42); transition:color var(--t); }
.footer-col ul li a:hover { color:#fff; }
.footer-contact-item { display:flex; align-items:flex-start; gap:12px; margin-bottom:14px; }
.footer-contact-icon { width:30px; height:30px; border-radius:6px; background:rgba(26,86,219,.2); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.footer-contact-icon svg { width:14px; height:14px; stroke:#60A5FA; fill:none; }
.footer-contact-text { font-size:.82rem; color:rgba(255,255,255,.42); line-height:1.5; }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; padding:20px 0; font-size:.73rem; color:rgba(255,255,255,.2); }

/* SERVICE DETAIL */
.svc-detail { display:grid; grid-template-columns:1fr 440px; gap:72px; align-items:center; padding:80px 0; border-bottom:1px solid var(--gray-l); }
.svc-detail:last-child { border-bottom:none; }
.svc-detail.rev { direction:rtl; }
.svc-detail.rev > * { direction:ltr; }
.svc-detail-label { font-size:.65rem; font-weight:800; letter-spacing:.18em; text-transform:uppercase; color:var(--blue); margin-bottom:12px; }
.svc-detail h2 { font-size:clamp(1.6rem,2.5vw,2.1rem); font-weight:900; color:var(--navy); margin-bottom:8px; letter-spacing:-.025em; }
.svc-features { display:flex; flex-direction:column; gap:8px; margin:22px 0 28px; }
.svc-features li { padding:10px 14px 10px 30px; background:var(--off); border-radius:8px; font-size:.85rem; color:var(--text); font-weight:500; position:relative; }
.svc-features li::before { content:''; position:absolute; left:11px; top:50%; transform:translateY(-50%); width:7px; height:7px; background:var(--blue); border-radius:50%; }
.svc-detail-photo { border-radius:var(--radius-lg); overflow:hidden; height:320px; box-shadow:var(--shadow-lg); position:relative; }
.svc-detail-photo img { width:100%; height:100%; object-fit:cover; transition:transform .6s ease; }
.svc-detail:hover .svc-detail-photo img { transform:scale(1.04); }
.svc-detail-photo-overlay { position:absolute; inset:0; background:linear-gradient(135deg,rgba(13,27,62,.2),transparent); }

/* VALUES */
.values-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:56px; }
.value-card { background:var(--off); border:1px solid var(--gray-l); border-radius:var(--radius-lg); padding:28px 24px; transition:var(--t); position:relative; overflow:hidden; }
.value-card::after { content:''; position:absolute; bottom:0; left:0; right:0; height:3px; background:var(--blue); transform:scaleX(0); transition:transform var(--t); }
.value-card:hover { box-shadow:var(--shadow); transform:translateY(-4px); border-color:rgba(26,86,219,.2); }
.value-card:hover::after { transform:scaleX(1); }
.value-icon { width:48px; height:48px; border-radius:var(--radius); background:var(--blue-bg); border:1px solid rgba(26,86,219,.2); display:flex; align-items:center; justify-content:center; margin-bottom:18px; }
.value-icon svg { width:24px; height:24px; stroke:var(--blue); fill:none; }
.value-card h3 { font-size:.95rem; font-weight:800; color:var(--navy); margin-bottom:8px; }
.value-card p { font-size:.83rem; color:var(--gray); line-height:1.65; }

/* TIMELINE */
.timeline-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:20px; margin-top:52px; }
.timeline-card { background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.09); border-radius:var(--radius-lg); padding:30px 26px; transition:background var(--t); }
.timeline-card:hover { background:rgba(255,255,255,.08); }
.timeline-year { font-size:.65rem; font-weight:800; letter-spacing:.16em; text-transform:uppercase; color:#60A5FA; margin-bottom:14px; }
.timeline-card h3 { font-size:1rem; font-weight:800; color:#fff; margin-bottom:8px; }
.timeline-card p { font-size:.84rem; color:rgba(255,255,255,.52); line-height:1.7; }

/* CONTACT */
.contact-grid { display:grid; grid-template-columns:1fr 1.15fr; gap:72px; align-items:start; }
.contact-info-item { display:flex; align-items:flex-start; gap:16px; margin-bottom:26px; }
.cinfo-icon { width:46px; height:46px; border-radius:var(--radius); background:var(--blue-bg); border:1px solid rgba(26,86,219,.2); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.cinfo-icon svg { width:20px; height:20px; stroke:var(--blue); fill:none; }
.cinfo-label { font-size:.65rem; font-weight:800; letter-spacing:.12em; text-transform:uppercase; color:var(--gray); margin-bottom:4px; }
.cinfo-val { font-size:.9rem; color:var(--text); font-weight:500; }
.cinfo-val a { color:var(--blue); }
.cinfo-val a:hover { text-decoration:underline; }
.form-box { background:var(--off); border:1px solid var(--gray-l); border-radius:var(--radius-lg); padding:38px 34px; }
.form-box h3 { font-size:1.15rem; font-weight:800; color:var(--navy); margin-bottom:28px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.form-group { display:flex; flex-direction:column; gap:7px; margin-bottom:14px; }
.form-group label { font-size:.76rem; font-weight:700; color:var(--navy); letter-spacing:.04em; }
.form-group input,.form-group select,.form-group textarea { padding:12px 14px; border:1.5px solid var(--gray-l); border-radius:var(--radius); font-size:.88rem; font-family:var(--font); color:var(--text); background:#fff; transition:border-color var(--t),box-shadow var(--t); outline:none; }
.form-group input:focus,.form-group select:focus,.form-group textarea:focus { border-color:var(--blue); box-shadow:0 0 0 3px rgba(26,86,219,.1); }
.form-group textarea { min-height:120px; resize:vertical; }
.form-success { display:none; background:#f0fdf4; border:1px solid #bbf7d0; border-radius:var(--radius); padding:14px; color:#166534; font-size:.88rem; font-weight:700; margin-top:14px; }
.map-block { background:var(--off); border-top:1px solid var(--gray-l); padding:56px 0; text-align:center; }
.map-block h3 { font-size:1.05rem; font-weight:800; color:var(--navy); margin-bottom:8px; }
.map-block p { font-size:.88rem; color:var(--gray); margin-bottom:20px; }

/* ANIMATIONS */
.fade-up { opacity:0; transform:translateY(28px); transition:opacity .6s ease,transform .6s ease; }
.fade-up.visible { opacity:1; transform:translateY(0); }
.stagger-1 { transition-delay:.08s; }
.stagger-2 { transition-delay:.16s; }
.stagger-3 { transition-delay:.24s; }
.stagger-4 { transition-delay:.32s; }
.stagger-5 { transition-delay:.40s; }

/* RESPONSIVE */
@media(max-width:1100px){
  .partners-grid-v2 { grid-template-columns:repeat(4,1fr); }
  .footer-grid { grid-template-columns:1fr 1fr; gap:36px; }
  .hero-inner { grid-template-columns:1fr; gap:40px; }
  .hero-panel { flex-direction:row; flex-wrap:wrap; }
  .hstat { flex:1; min-width:160px; }
}
@media(max-width:860px){
  .about-grid { grid-template-columns:1fr; gap:40px; }
  .services-grid { grid-template-columns:repeat(2,1fr); }
  .skills-grid { grid-template-columns:repeat(2,1fr); }
  .values-grid { grid-template-columns:repeat(2,1fr); }
  .usecases-grid { grid-template-columns:1fr; }
  .clients-grid { grid-template-columns:repeat(3,1fr); }
  .svc-detail { grid-template-columns:1fr; gap:36px; }
  .svc-detail.rev { direction:ltr; }
  .svc-detail-photo { height:240px; }
  .contact-grid { grid-template-columns:1fr; gap:40px; }
  .timeline-grid { grid-template-columns:1fr; }
}
@media(max-width:640px){
  .nav-links,.nav-cta { display:none; }
  .hamburger { display:flex; }
  .services-grid,.skills-grid,.values-grid { grid-template-columns:1fr; }
  .partners-grid-v2 { grid-template-columns:repeat(3,1fr); }
  .clients-grid { grid-template-columns:repeat(2,1fr); }
  .section { padding:64px 0; }
  .hero-inner { padding:56px 0 72px; }
  .form-row { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:1fr; }
  .footer-bottom { flex-direction:column; gap:8px; text-align:center; }
}

/* ── PARTNER LOGO TILES (v9.1) ── */
.partners-logo-grid { display:grid; grid-template-columns:repeat(7,1fr); gap:14px; margin-top:52px; }
.partner-logo-tile {
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:10px;
  padding:18px 10px 14px;
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1);
  border-radius:var(--radius); cursor:pointer;
  transition:var(--t); text-align:center;
  text-decoration:none;
}
.partner-logo-tile:hover { background:rgba(255,255,255,.14); border-color:rgba(59,130,246,.6); transform:translateY(-4px); box-shadow:0 8px 24px rgba(0,0,0,.3); }
.partner-logo-tile img {
  height:36px; width:auto; max-width:90px;
  object-fit:contain;
  opacity:1;
  transition:opacity var(--t);
}
.partner-logo-tile:hover img { opacity:1; }
.partner-logo-tile-name { font-size:.65rem; font-weight:700; color:rgba(255,255,255,.5); letter-spacing:.06em; text-transform:uppercase; }
.partner-logo-tile-cat  { font-size:.58rem; color:rgba(255,255,255,.3); letter-spacing:.06em; }

/* ── CLIENT LOGO CARDS (v9.1) ── */
.clients-logo-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:18px; margin-top:52px; }
.client-logo-card {
  background:var(--white); border:1px solid var(--gray-l);
  border-radius:var(--radius-lg); padding:24px 16px 18px;
  display:flex; flex-direction:column; align-items:center; gap:12px;
  text-align:center; transition:var(--t); text-decoration:none;
}
.client-logo-card:hover { border-color:var(--blue); box-shadow:0 6px 28px rgba(26,86,219,.15); transform:translateY(-5px); }
.client-logo-card img {
  height:44px; width:auto; max-width:110px;
  object-fit:contain; filter:none; opacity:1;
  transition:transform var(--t);
}
.client-logo-card:hover img { filter:none; opacity:1; transform:scale(1.05); }
.client-logo-name { font-size:.82rem; font-weight:800; color:var(--navy); }
.client-logo-sector {
  font-size:.62rem; color:var(--gray); font-weight:600;
  text-transform:uppercase; letter-spacing:.08em;
  padding:3px 10px; background:var(--blue-bg); border-radius:50px;
  color:var(--blue);
}

/* ── CONTACT PAGE COLORS (v9.1) ── */
.contact-hero-stats { display:grid; grid-template-columns:repeat(2,1fr); gap:16px; margin-top:48px; }
.chstat { background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.15); border-radius:var(--radius-lg); padding:20px; text-align:center; }
.chstat-icon { font-size:1.8rem; margin-bottom:8px; }
.chstat-val { font-size:1.4rem; font-weight:900; color:#60A5FA; line-height:1; }
.chstat-lbl { font-size:.65rem; font-weight:700; color:rgba(255,255,255,.45); text-transform:uppercase; letter-spacing:.1em; margin-top:4px; }
.cinfo-icon-colored { width:50px; height:50px; border-radius:14px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.cinfo-icon-colored svg { width:22px; height:22px; fill:none; }
.cinfo-val-big { font-size:.95rem; color:var(--text); font-weight:600; }
.cinfo-val-big a { color:var(--blue); font-weight:700; }
.cinfo-val-big a:hover { text-decoration:underline; }
.contact-quick-actions { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin:32px 0 8px; }
.cqa-btn {
  display:flex; align-items:center; gap:12px;
  padding:14px 18px; border-radius:var(--radius);
  font-size:.88rem; font-weight:700;
  transition:var(--t); text-decoration:none; border:2px solid;
}
.cqa-btn--phone { background:#EFF4FF; border-color:rgba(26,86,219,.2); color:var(--blue); }
.cqa-btn--phone:hover { background:var(--blue); color:#fff; border-color:var(--blue); }
.cqa-btn--email { background:#F0FDF4; border-color:rgba(34,197,94,.2); color:#16A34A; }
.cqa-btn--email:hover { background:#16A34A; color:#fff; border-color:#16A34A; }
.cqa-btn-icon { width:36px; height:36px; border-radius:10px; display:flex; align-items:center; justify-content:center; background:currentColor; opacity:.15; flex-shrink:0; }
.cqa-btn svg { width:18px; height:18px; fill:none; stroke:currentColor; flex-shrink:0; }

@media(max-width:1100px){ .partners-logo-grid{ grid-template-columns:repeat(4,1fr); } }
@media(max-width:860px) { .clients-logo-grid{ grid-template-columns:repeat(3,1fr); } .partners-logo-grid{ grid-template-columns:repeat(3,1fr); } }
@media(max-width:560px) { .clients-logo-grid{ grid-template-columns:repeat(2,1fr); } .partners-logo-grid{ grid-template-columns:repeat(2,1fr); } .contact-quick-actions{ grid-template-columns:1fr; } }
