/* ============================================
   VADOM MEDIA - Main Stylesheet
   ============================================ */

:root {
    --bg-primary: #0a0a0f;
    --bg-secondary: #0f0f1a;
    --bg-tertiary: #141422;
    --bg-card: rgba(20, 20, 40, 0.6);
    --bg-card-hover: rgba(30, 30, 55, 0.8);
    --bg-glass: rgba(15, 15, 30, 0.7);
    --text-primary: #f0f0f5;
    --text-secondary: #a0a0b8;
    --text-muted: #6b6b80;
    --accent-1: #6366f1;
    --accent-2: #06b6d4;
    --accent-3: #8b5cf6;
    --gradient-main: linear-gradient(135deg, #6366f1 0%, #06b6d4 100%);
    --gradient-accent: linear-gradient(135deg, #8b5cf6 0%, #06b6d4 100%);
    --gradient-subtle: linear-gradient(135deg, rgba(99,102,241,0.1) 0%, rgba(6,182,212,0.1) 100%);
    --border-color: rgba(99,102,241,0.15);
    --border-glow: rgba(99,102,241,0.3);
    --radius-sm: 8px;
    --radius-md: 12px;
    --radius-lg: 16px;
    --radius-xl: 24px;
    --shadow-sm: 0 2px 8px rgba(0,0,0,0.3);
    --shadow-md: 0 8px 32px rgba(0,0,0,0.4);
    --shadow-lg: 0 16px 64px rgba(0,0,0,0.5);
    --shadow-glow: 0 0 40px rgba(99,102,241,0.15);
    --font-main: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
    --font-mono: 'JetBrains Mono', 'Fira Code', monospace;
    --transition: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    --transition-slow: 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; scroll-padding-top:80px; }
body { font-family:var(--font-main); background:var(--bg-primary); color:var(--text-primary); line-height:1.6; overflow-x:hidden; -webkit-font-smoothing:antialiased; }
a { color:inherit; text-decoration:none; }
img { max-width:100%; display:block; }

/* Background */
.bg-grid { position:fixed; inset:0; z-index:0; background-image:linear-gradient(rgba(99,102,241,0.03) 1px,transparent 1px),linear-gradient(90deg,rgba(99,102,241,0.03) 1px,transparent 1px); background-size:60px 60px; pointer-events:none; }
.bg-glow { position:fixed; border-radius:50%; filter:blur(120px); pointer-events:none; z-index:0; }
.bg-glow-1 { width:600px; height:600px; background:rgba(99,102,241,0.08); top:-200px; right:-200px; animation:floatGlow 15s ease-in-out infinite; }
.bg-glow-2 { width:500px; height:500px; background:rgba(6,182,212,0.06); bottom:-100px; left:-200px; animation:floatGlow 20s ease-in-out infinite reverse; }
@keyframes floatGlow { 0%,100%{transform:translate(0,0)} 33%{transform:translate(30px,-30px)} 66%{transform:translate(-20px,20px)} }

/* Container */
.container { max-width:1200px; margin:0 auto; padding:0 24px; position:relative; z-index:1; }

/* --- NAVBAR --- */
.navbar { position:fixed; top:0; left:0; right:0; z-index:1000; padding:16px 0; transition:var(--transition); }
.navbar.scrolled { padding:10px 0; background:rgba(10,10,15,0.85); backdrop-filter:blur(20px); border-bottom:1px solid var(--border-color); }
.nav-container { display:flex; align-items:center; justify-content:space-between; }
.logo { display:flex; align-items:center; gap:10px; font-size:1.25rem; font-weight:800; letter-spacing:0.5px; }
.logo-icon { display:flex; }
.logo-text { color:var(--text-primary); }
.logo-accent { background:var(--gradient-main); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.nav-links { display:flex; align-items:center; gap:32px; list-style:none; }
.nav-links a { font-size:0.9rem; font-weight:500; color:var(--text-secondary); transition:var(--transition); position:relative; }
.nav-links a:not(.nav-cta):hover, .nav-links a.active:not(.nav-cta) { color:var(--text-primary); }
.nav-links a:not(.nav-cta)::after { content:''; position:absolute; bottom:-4px; left:0; width:0; height:2px; background:var(--gradient-main); transition:var(--transition); }
.nav-links a:not(.nav-cta):hover::after, .nav-links a.active:not(.nav-cta)::after { width:100%; }
.nav-cta { padding:8px 20px; background:var(--gradient-main); border-radius:var(--radius-sm); color:white !important; font-weight:600; transition:var(--transition); }
.nav-cta:hover { opacity:0.9; box-shadow:0 0 20px rgba(99,102,241,0.4); }
.nav-toggle { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:4px; }
.nav-toggle span { display:block; width:24px; height:2px; background:var(--text-primary); transition:var(--transition); }

/* --- BUTTONS --- */
.btn { display:inline-flex; align-items:center; gap:8px; padding:12px 28px; border-radius:var(--radius-sm); font-size:0.95rem; font-weight:600; cursor:pointer; transition:var(--transition); border:none; font-family:var(--font-main); white-space:nowrap; }
.btn-primary { background:var(--gradient-main); color:white; box-shadow:0 4px 20px rgba(99,102,241,0.3); }
.btn-primary:hover { box-shadow:0 8px 30px rgba(99,102,241,0.5); transform:translateY(-2px); }
.btn-ghost { background:transparent; color:var(--text-primary); border:1px solid var(--border-color); }
.btn-ghost:hover { border-color:var(--border-glow); background:rgba(99,102,241,0.05); }
.btn-lg { padding:16px 36px; font-size:1.05rem; }
.btn-full { width:100%; justify-content:center; }

/* --- HERO --- */
.hero { min-height:100vh; display:flex; align-items:center; padding:120px 0 80px; position:relative; }
.hero .container { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.hero-badge { display:inline-flex; align-items:center; gap:8px; padding:6px 16px; background:var(--gradient-subtle); border:1px solid var(--border-color); border-radius:100px; font-size:0.85rem; font-weight:500; color:var(--accent-2); margin-bottom:24px; }
.badge-dot { width:8px; height:8px; background:var(--accent-2); border-radius:50%; animation:pulse 2s ease-in-out infinite; }
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:0.4} }
.hero h1 { font-size:clamp(2.5rem,5vw,4rem); font-weight:800; line-height:1.1; margin-bottom:24px; letter-spacing:-0.02em; }
.gradient-text { background:var(--gradient-main); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.hero-subtitle { font-size:1.15rem; color:var(--text-secondary); line-height:1.7; margin-bottom:36px; max-width:540px; }
.hero-actions { display:flex; gap:16px; margin-bottom:48px; }
.hero-stats { display:flex; align-items:center; gap:32px; }
.stat { display:flex; flex-direction:column; }
.stat-number { font-size:2rem; font-weight:800; background:var(--gradient-main); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; display:inline; }
.stat-suffix { font-size:1.5rem; font-weight:700; background:var(--gradient-main); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.stat-label { font-size:0.85rem; color:var(--text-muted); margin-top:2px; }
.stat-divider { width:1px; height:40px; background:var(--border-color); }

/* Code Window */
.hero-visual { perspective:1000px; }
.code-window { background:var(--bg-secondary); border:1px solid var(--border-color); border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-lg),var(--shadow-glow); transform:rotateY(-5deg) rotateX(2deg); transition:var(--transition-slow); }
.code-window:hover { transform:rotateY(0deg) rotateX(0deg); box-shadow:var(--shadow-lg),0 0 60px rgba(99,102,241,0.2); }
.code-header { display:flex; align-items:center; gap:12px; padding:14px 20px; background:rgba(0,0,0,0.3); border-bottom:1px solid var(--border-color); }
.code-dots { display:flex; gap:6px; }
.code-dots span { width:10px; height:10px; border-radius:50%; }
.code-dots span:nth-child(1) { background:#ff5f57; }
.code-dots span:nth-child(2) { background:#febc2e; }
.code-dots span:nth-child(3) { background:#28c840; }
.code-title { font-family:var(--font-mono); font-size:0.8rem; color:var(--text-muted); }
.code-body { padding:24px; font-family:var(--font-mono); font-size:0.85rem; line-height:1.8; overflow-x:auto; }
.code-body code { font-family:inherit; }
.code-keyword { color:#c678dd; }
.code-string { color:#98c379; }
.code-func { color:#61afef; }
.code-prop { color:#e06c75; }
.code-const { color:#d19a66; }
.code-bool { color:#d19a66; }
.code-comment { color:#5c6370; font-style:italic; }

/* --- HERO SHOWCASE --- */
.hero-showcase { position:relative; border-radius:var(--radius-xl); overflow:hidden; box-shadow:var(--shadow-lg),var(--shadow-glow); }
.showcase-container { position:relative; min-height:380px; }
.showcase-slide { position:absolute; inset:0; opacity:0; transform:scale(0.95) translateY(10px); transition:opacity 0.6s ease, transform 0.6s ease; pointer-events:none; z-index:0; }
.showcase-slide.active { opacity:1; transform:scale(1) translateY(0); pointer-events:auto; z-index:2; }
.showcase-slide.exit { opacity:0; transform:scale(1.02) translateY(-10px); z-index:1; }
.showcase-card { height:100%; display:flex; flex-direction:column; background:var(--bg-card); border:1px solid var(--border-color); border-radius:var(--radius-xl); overflow:hidden; }
.showcase-card-image { aspect-ratio:16/9; display:flex; align-items:center; justify-content:center; position:relative; overflow:hidden; }
.sc-gradient-1 { background:linear-gradient(135deg,#6366f1 0%,#3b82f6 50%,#06b6d4 100%); }
.sc-gradient-2 { background:linear-gradient(135deg,#8b5cf6 0%,#6366f1 50%,#ec4899 100%); }
.sc-gradient-3 { background:linear-gradient(135deg,#10b981 0%,#06b6d4 50%,#3b82f6 100%); }
.sc-gradient-4 { background:linear-gradient(135deg,#f59e0b 0%,#ef4444 50%,#ec4899 100%); }
.sc-gradient-5 { background:linear-gradient(135deg,#06b6d4 0%,#8b5cf6 50%,#6366f1 100%); }
.showcase-card-image::after { content:''; position:absolute; inset:0; background:url("data:image/svg+xml,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 0h60v60H0z' fill='none'/%3E%3Cpath d='M30 0v60M0 30h60' stroke='rgba(255,255,255,0.06)' stroke-width='1'/%3E%3C/svg%3E"); background-size:30px 30px; }
.sc-icon { position:relative; z-index:1; opacity:0.9; filter:drop-shadow(0 4px 20px rgba(0,0,0,0.3)); }
.showcase-card-body { padding:20px 24px; flex:1; }
.sc-badge { display:inline-block; padding:3px 10px; background:var(--gradient-subtle); border:1px solid var(--border-color); border-radius:100px; font-size:0.7rem; font-weight:600; color:var(--accent-2); text-transform:uppercase; letter-spacing:0.5px; margin-bottom:8px; }
.showcase-card-body h3 { font-size:1.05rem; font-weight:700; margin-bottom:6px; line-height:1.3; }
.showcase-card-body p { font-size:0.85rem; color:var(--text-secondary); line-height:1.5; }
.showcase-dots { display:flex; justify-content:center; gap:8px; padding:12px 0 8px; }
.dot { width:8px; height:8px; border-radius:50%; background:var(--border-color); border:none; cursor:pointer; transition:var(--transition); padding:0; }
.dot.active { background:var(--accent-1); width:24px; border-radius:4px; }
.showcase-progress { height:3px; background:rgba(99,102,241,0.1); border-radius:0 0 var(--radius-xl) var(--radius-xl); overflow:hidden; }
.progress-bar { height:100%; width:0; background:var(--gradient-main); border-radius:3px; }
.stat-row { display:flex; align-items:baseline; }

/* --- NOTRE HISTOIRE / STORY --- */
.story-layout { display:grid; grid-template-columns:1.2fr 1fr; gap:64px; align-items:start; }
.story-content .section-tag { margin-bottom:16px; }
.story-content h2 { font-size:clamp(1.8rem,3.5vw,2.5rem); font-weight:800; line-height:1.2; margin-bottom:20px; }
.story-lead { font-size:1.1rem; color:var(--text-secondary); line-height:1.7; margin-bottom:16px; }
.story-content > p { color:var(--text-secondary); line-height:1.7; margin-bottom:16px; }
.story-content strong { color:var(--text-primary); }
.story-values { display:flex; flex-direction:column; gap:16px; margin-top:32px; }
.story-value { display:flex; gap:16px; align-items:start; padding:16px 20px; background:var(--bg-card); border:1px solid var(--border-color); border-radius:var(--radius-md); transition:var(--transition); }
.story-value:hover { border-color:var(--border-glow); }
.sv-icon { display:flex; align-items:center; justify-content:center; width:44px; height:44px; background:var(--gradient-subtle); border-radius:var(--radius-sm); color:var(--accent-1); flex-shrink:0; }
.story-value strong { display:block; font-size:0.95rem; margin-bottom:4px; }
.story-value p { font-size:0.85rem; color:var(--text-secondary); line-height:1.5; margin:0; }

/* Timeline */
.story-timeline { position:relative; padding-left:32px; }
.tl-line { position:absolute; left:7px; top:8px; bottom:8px; width:2px; background:var(--border-color); }
.tl-item { position:relative; margin-bottom:24px; }
.tl-item:last-child { margin-bottom:0; }
.tl-dot { position:absolute; left:-28px; top:8px; width:14px; height:14px; background:var(--bg-secondary); border:2px solid var(--border-color); border-radius:50%; z-index:1; transition:var(--transition); }
.tl-dot.active { border-color:var(--accent-1); background:var(--accent-1); box-shadow:0 0 12px rgba(99,102,241,0.5); }
.tl-card { padding:16px 20px; background:var(--bg-card); border:1px solid var(--border-color); border-radius:var(--radius-md); transition:var(--transition); }
.tl-card:hover { border-color:var(--border-glow); }
.tl-year { font-family:var(--font-mono); font-size:0.75rem; font-weight:700; color:var(--accent-2); }
.tl-card h4 { font-size:0.95rem; font-weight:700; margin:4px 0; }
.tl-card p { font-size:0.85rem; color:var(--text-secondary); line-height:1.5; margin:0; }

/* Project result badge */
.project-client-badge { position:absolute; top:12px; right:12px; padding:4px 10px; background:rgba(10,10,15,0.8); backdrop-filter:blur(8px); border:1px solid var(--border-color); border-radius:100px; font-size:0.7rem; font-weight:500; color:var(--text-muted); z-index:1; }
.project-result { display:flex; align-items:center; gap:6px; font-size:0.8rem; color:var(--accent-2); font-weight:500; margin-bottom:12px; }

/* --- TRUSTED --- */
.trusted { padding:40px 0; border-top:1px solid var(--border-color); border-bottom:1px solid var(--border-color); }
.trusted-label { text-align:center; font-size:0.85rem; color:var(--text-muted); text-transform:uppercase; letter-spacing:2px; margin-bottom:24px; }
.trusted-logos { display:flex; justify-content:center; align-items:center; gap:48px; flex-wrap:wrap; }
.trusted-item { font-size:0.95rem; font-weight:600; color:var(--text-muted); opacity:0.6; transition:var(--transition); }
.trusted-item:hover { opacity:1; color:var(--text-secondary); }

/* --- SECTIONS --- */
.section-dark { padding:120px 0; }
.section-light { padding:120px 0; background:var(--bg-secondary); }
.section-header { text-align:center; max-width:640px; margin:0 auto 64px; }
.section-tag { display:inline-block; padding:4px 14px; background:var(--gradient-subtle); border:1px solid var(--border-color); border-radius:100px; font-size:0.8rem; font-weight:600; color:var(--accent-2); text-transform:uppercase; letter-spacing:1.5px; margin-bottom:16px; }
.section-header h2 { font-size:clamp(2rem,4vw,2.75rem); font-weight:800; line-height:1.2; margin-bottom:16px; letter-spacing:-0.02em; }
.section-header p { font-size:1.05rem; color:var(--text-secondary); line-height:1.7; }
.section-cta { text-align:center; margin-top:48px; }

/* --- PAGE HERO --- */
.page-hero { padding:160px 0 80px; text-align:center; }
.page-hero-content { max-width:720px; margin:0 auto; }
.page-hero h1 { font-size:clamp(2.2rem,4.5vw,3.2rem); font-weight:800; line-height:1.15; margin-bottom:20px; margin-top:16px; letter-spacing:-0.02em; }
.page-hero-desc { font-size:1.1rem; color:var(--text-secondary); line-height:1.7; }

/* --- SERVICE PREVIEW CARDS (Home) --- */
.services-preview { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.service-preview-card { padding:32px 24px; background:var(--bg-card); border:1px solid var(--border-color); border-radius:var(--radius-lg); transition:var(--transition); display:flex; flex-direction:column; }
.service-preview-card:hover { border-color:var(--border-glow); transform:translateY(-4px); box-shadow:var(--shadow-glow); }
.spc-icon { color:var(--accent-1); margin-bottom:20px; }
.service-preview-card h3 { font-size:1.1rem; font-weight:700; margin-bottom:10px; }
.service-preview-card p { font-size:0.9rem; color:var(--text-secondary); line-height:1.6; flex:1; }
.spc-link { display:inline-flex; align-items:center; gap:6px; margin-top:16px; font-size:0.85rem; font-weight:600; color:var(--accent-1); }

/* --- FEATURES (Home) --- */
.features-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.feature-card { padding:32px; background:var(--bg-card); border:1px solid var(--border-color); border-radius:var(--radius-lg); transition:var(--transition); }
.feature-card:hover { border-color:var(--border-glow); transform:translateY(-4px); }
.feature-number { font-family:var(--font-mono); font-size:2.5rem; font-weight:800; background:var(--gradient-main); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; opacity:0.4; margin-bottom:16px; }
.feature-card h3 { font-size:1.1rem; font-weight:700; margin-bottom:8px; }
.feature-card p { font-size:0.9rem; color:var(--text-secondary); line-height:1.6; }

/* --- PROJECT CARDS --- */
.projects-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.project-card { background:var(--bg-card); border:1px solid var(--border-color); border-radius:var(--radius-lg); overflow:hidden; transition:var(--transition); }
.project-card:hover { border-color:var(--border-glow); transform:translateY(-4px); box-shadow:var(--shadow-glow); }
.project-image { aspect-ratio:16/10; background:var(--bg-tertiary); display:flex; align-items:center; justify-content:center; border-bottom:1px solid var(--border-color); position:relative; overflow:hidden; }
.project-image::before { content:''; position:absolute; inset:0; background:var(--gradient-main); opacity:0.08; }
.project-category-badge { position:absolute; top:12px; left:12px; padding:4px 12px; background:rgba(10,10,15,0.8); backdrop-filter:blur(8px); border:1px solid var(--border-color); border-radius:100px; font-size:0.75rem; font-weight:600; color:var(--accent-2); z-index:1; }
.project-info { padding:24px; }
.project-info h3 { font-size:1.1rem; font-weight:700; margin-bottom:8px; }
.project-info p { font-size:0.9rem; color:var(--text-secondary); line-height:1.6; margin-bottom:16px; }
.project-tags { display:flex; gap:8px; flex-wrap:wrap; }
.project-tags span { padding:4px 10px; background:var(--gradient-subtle); border:1px solid var(--border-color); border-radius:100px; font-size:0.75rem; font-weight:500; color:var(--text-muted); }

/* --- TESTIMONIALS --- */
.testimonials-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.testimonial-card { padding:32px; background:var(--bg-card); border:1px solid var(--border-color); border-radius:var(--radius-lg); transition:var(--transition); }
.testimonial-card:hover { border-color:var(--border-glow); }
.testimonial-stars { color:#f59e0b; font-size:1.1rem; letter-spacing:2px; margin-bottom:16px; }
.testimonial-text { font-size:0.95rem; color:var(--text-secondary); line-height:1.7; font-style:italic; margin-bottom:24px; }
.testimonial-author { display:flex; align-items:center; gap:12px; }
.author-avatar { width:44px; height:44px; background:var(--gradient-main); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:0.85rem; font-weight:700; color:white; flex-shrink:0; }
.testimonial-author strong { display:block; font-size:0.95rem; }
.testimonial-author span { font-size:0.8rem; color:var(--text-muted); }

/* --- CTA --- */
.cta-section { padding:80px 0; background:var(--bg-secondary); }
.cta-content { text-align:center; max-width:640px; margin:0 auto; padding:64px; background:var(--bg-card); border:1px solid var(--border-color); border-radius:var(--radius-xl); box-shadow:var(--shadow-glow); }
.cta-content h2 { font-size:clamp(1.75rem,3vw,2.25rem); font-weight:800; line-height:1.2; margin-bottom:16px; }
.cta-content p { color:var(--text-secondary); margin-bottom:32px; line-height:1.7; }
.cta-actions { display:flex; justify-content:center; gap:16px; flex-wrap:wrap; }

/* --- SERVICE DETAIL (Services page) --- */
.service-section { padding:100px 0; }
.service-section.alt { background:var(--bg-secondary); }
.service-detail { display:grid; grid-template-columns:1.2fr 0.8fr; gap:64px; align-items:start; }
.service-detail.reverse { grid-template-columns:1.2fr 0.8fr; }
.service-detail-badge { font-family:var(--font-mono); font-size:3rem; font-weight:800; background:var(--gradient-main); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; opacity:0.3; margin-bottom:8px; }
.service-detail-content h2 { font-size:clamp(1.8rem,3.5vw,2.5rem); font-weight:800; line-height:1.2; margin-bottom:16px; }
.service-lead { font-size:1.1rem; color:var(--text-secondary); line-height:1.7; margin-bottom:16px; }
.service-detail-content > p { color:var(--text-secondary); line-height:1.7; margin-bottom:32px; }
.service-offerings { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.offering { padding:20px; background:var(--bg-card); border:1px solid var(--border-color); border-radius:var(--radius-md); transition:var(--transition); }
.offering:hover { border-color:var(--border-glow); }
.offering h4 { font-size:0.95rem; font-weight:700; margin-bottom:6px; }
.offering p { font-size:0.85rem; color:var(--text-secondary); line-height:1.6; }

/* Visual cards (service pages) */
.visual-card { background:var(--bg-card); border:1px solid var(--border-color); border-radius:var(--radius-lg); padding:32px; position:sticky; top:100px; }
.visual-stat { padding:20px 0; border-bottom:1px solid var(--border-color); }
.visual-stat:last-child { border-bottom:none; padding-bottom:0; }
.visual-stat:first-child { padding-top:0; }
.vs-number { display:block; font-size:2rem; font-weight:800; background:var(--gradient-main); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; margin-bottom:4px; }
.vs-label { font-size:0.9rem; color:var(--text-secondary); }

/* Process steps (services) */
.process-steps { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.p-step { padding:32px; background:var(--bg-card); border:1px solid var(--border-color); border-radius:var(--radius-lg); text-align:center; transition:var(--transition); }
.p-step:hover { border-color:var(--border-glow); transform:translateY(-4px); }
.p-step-num { font-family:var(--font-mono); font-size:2rem; font-weight:800; background:var(--gradient-main); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; opacity:0.5; margin-bottom:16px; }
.p-step h3 { font-size:1rem; font-weight:700; margin-bottom:8px; }
.p-step p { font-size:0.9rem; color:var(--text-secondary); line-height:1.6; }

/* --- EXPERTISE PAGE --- */
.expertise-intro { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }
.expertise-intro-text h2 { font-size:clamp(1.8rem,3vw,2.25rem); font-weight:800; margin-bottom:20px; }
.expertise-intro-text p { color:var(--text-secondary); line-height:1.7; margin-bottom:16px; }
.expertise-intro-text strong { color:var(--text-primary); }

/* Orbit visual */
.orbit-visual { position:relative; width:320px; height:320px; margin:0 auto; }
.orbit-center { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:80px; height:80px; background:var(--gradient-main); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:0.75rem; font-weight:700; color:white; text-align:center; z-index:2; box-shadow:0 0 40px rgba(99,102,241,0.4); }
.orbit-ring { position:absolute; inset:0; border-radius:50%; border:1px dashed var(--border-color); animation:spin 30s linear infinite; }
.orbit-ring.orbit-2 { inset:30px; animation-duration:25s; animation-direction:reverse; }
.orbit-dot { position:absolute; top:50%; left:50%; width:48px; height:48px; margin:-24px 0 0 -24px; transform:rotate(var(--angle)) translateX(calc(160px - 30px * var(--ring, 0))) rotate(calc(-1 * var(--angle))); }
.orbit-ring.orbit-2 .orbit-dot { transform:rotate(var(--angle)) translateX(calc(130px - 30px)) rotate(calc(-1 * var(--angle))); }
.orbit-dot span { display:flex; align-items:center; justify-content:center; width:48px; height:48px; background:var(--bg-card); border:1px solid var(--border-color); border-radius:50%; font-size:0.65rem; font-weight:600; color:var(--accent-2); animation:counterSpin 30s linear infinite; }
.orbit-ring.orbit-2 .orbit-dot span { animation-duration:25s; animation-direction:reverse; }
@keyframes spin { from{transform:rotate(0deg)} to{transform:rotate(360deg)} }
@keyframes counterSpin { from{transform:rotate(0deg)} to{transform:rotate(-360deg)} }

/* Capability grid */
.capability-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.capability-card { padding:32px; background:var(--bg-card); border:1px solid var(--border-color); border-radius:var(--radius-lg); transition:var(--transition); }
.capability-card:hover { border-color:var(--border-glow); transform:translateY(-4px); box-shadow:var(--shadow-glow); }
.cap-icon { color:var(--accent-1); margin-bottom:20px; }
.capability-card h3 { font-size:1.15rem; font-weight:700; margin-bottom:10px; }
.capability-card p { font-size:0.9rem; color:var(--text-secondary); line-height:1.6; margin-bottom:16px; }
.cap-highlights { display:flex; flex-wrap:wrap; gap:8px; }
.cap-highlights span { padding:4px 12px; background:var(--gradient-subtle); border:1px solid var(--border-color); border-radius:100px; font-size:0.8rem; color:var(--text-muted); font-weight:500; }

/* Approach grid */
.approach-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:24px; }
.approach-card { padding:32px; background:var(--bg-card); border:1px solid var(--border-color); border-radius:var(--radius-lg); transition:var(--transition); }
.approach-card:hover { border-color:var(--border-glow); }
.approach-num { font-family:var(--font-mono); font-size:2rem; font-weight:800; background:var(--gradient-main); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; opacity:0.4; margin-bottom:12px; }
.approach-card h3 { font-size:1.05rem; font-weight:700; margin-bottom:8px; }
.approach-card p { font-size:0.9rem; color:var(--text-secondary); line-height:1.6; }

/* Metrics */
.metrics-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.metric-card { padding:32px; background:var(--bg-card); border:1px solid var(--border-color); border-radius:var(--radius-lg); text-align:center; }
.metric-value { font-size:2.5rem; font-weight:800; background:var(--gradient-main); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; margin-bottom:8px; }
.metric-label { font-size:0.9rem; color:var(--text-secondary); }

/* --- REALISATIONS PAGE --- */
.project-filters { display:flex; gap:8px; margin-bottom:40px; flex-wrap:wrap; }
.filter-btn { padding:8px 20px; background:var(--bg-card); border:1px solid var(--border-color); border-radius:100px; color:var(--text-secondary); font-family:var(--font-main); font-size:0.9rem; font-weight:500; cursor:pointer; transition:var(--transition); }
.filter-btn:hover { border-color:var(--border-glow); color:var(--text-primary); }
.filter-btn.active { background:var(--gradient-main); border-color:transparent; color:white; }
.projects-showcase { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.project-showcase-card { background:var(--bg-card); border:1px solid var(--border-color); border-radius:var(--radius-lg); overflow:hidden; transition:var(--transition); }
.project-showcase-card:hover { border-color:var(--border-glow); transform:translateY(-4px); box-shadow:var(--shadow-glow); }
.psc-image { aspect-ratio:16/10; background:var(--bg-tertiary); position:relative; overflow:hidden; }
.psc-image::before { content:''; position:absolute; inset:0; background:var(--gradient-main); opacity:0.06; }
.psc-overlay { position:absolute; top:12px; left:12px; }
.psc-category { padding:4px 12px; background:rgba(10,10,15,0.8); backdrop-filter:blur(8px); border:1px solid var(--border-color); border-radius:100px; font-size:0.75rem; font-weight:600; color:var(--accent-2); }
.psc-content { padding:24px; }
.psc-content h3 { font-size:1.15rem; font-weight:700; margin-bottom:8px; }
.psc-content p { font-size:0.9rem; color:var(--text-secondary); line-height:1.6; margin-bottom:16px; }
.psc-tags { display:flex; gap:8px; flex-wrap:wrap; }
.psc-tags span { padding:4px 10px; background:var(--gradient-subtle); border:1px solid var(--border-color); border-radius:100px; font-size:0.75rem; color:var(--text-muted); }
@keyframes fadeInUp { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:translateY(0)} }

/* Results */
.results-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.result-card { padding:32px; background:var(--bg-card); border:1px solid var(--border-color); border-radius:var(--radius-lg); text-align:center; }
.result-number { font-size:2.5rem; font-weight:800; background:var(--gradient-main); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; margin-bottom:8px; }
.result-card p { font-size:0.9rem; color:var(--text-secondary); line-height:1.5; }

/* --- CONTACT PAGE --- */
.contact-layout { display:grid; grid-template-columns:1.4fr 1fr; gap:48px; align-items:start; }
.contact-form { padding:36px; background:var(--bg-card); border:1px solid var(--border-color); border-radius:var(--radius-lg); }
.contact-form h3 { font-size:1.25rem; font-weight:700; margin-bottom:24px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-group { margin-bottom:20px; }
.form-group label { display:block; font-size:0.85rem; font-weight:600; color:var(--text-secondary); margin-bottom:6px; }
.form-group input, .form-group select, .form-group textarea { width:100%; padding:12px 16px; background:var(--bg-primary); border:1px solid var(--border-color); border-radius:var(--radius-sm); color:var(--text-primary); font-family:var(--font-main); font-size:0.95rem; transition:var(--transition); outline:none; }
.form-group input::placeholder, .form-group textarea::placeholder { color:var(--text-muted); }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color:var(--accent-1); box-shadow:0 0 0 3px rgba(99,102,241,0.1); }
.form-group select { appearance:none; background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L6 6L11 1' stroke='%236b6b80' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 16px center; cursor:pointer; }
.form-group textarea { resize:vertical; min-height:120px; }
.form-message { margin-top:16px; padding:12px 16px; border-radius:var(--radius-sm); font-size:0.9rem; display:none; }
.form-message.success { display:block; background:rgba(16,185,129,0.1); border:1px solid rgba(16,185,129,0.3); color:#10b981; }
.form-message.error { display:block; background:rgba(239,68,68,0.1); border:1px solid rgba(239,68,68,0.3); color:#ef4444; }
.contact-sidebar { display:flex; flex-direction:column; gap:16px; }
.info-card { display:flex; align-items:center; gap:16px; padding:20px 24px; background:var(--bg-card); border:1px solid var(--border-color); border-radius:var(--radius-md); transition:var(--transition); }
.info-card:hover { border-color:var(--border-glow); }
.info-card.highlight { border-color:var(--accent-1); background:rgba(99,102,241,0.05); }
.info-icon { display:flex; align-items:center; justify-content:center; width:44px; height:44px; background:var(--gradient-subtle); border-radius:var(--radius-sm); color:var(--accent-1); flex-shrink:0; }
.info-card h4 { font-size:0.9rem; font-weight:600; margin-bottom:2px; }
.info-card a, .info-card p { font-size:0.9rem; color:var(--text-secondary); }
.info-card a:hover { color:var(--accent-1); }
.sidebar-cta { padding:24px; background:var(--bg-card); border:1px solid var(--border-color); border-radius:var(--radius-md); margin-top:8px; }
.sidebar-cta h4 { font-size:1rem; font-weight:700; margin-bottom:8px; }
.sidebar-cta p { font-size:0.9rem; color:var(--text-secondary); margin-bottom:16px; line-height:1.6; }

/* --- DEVIS PAGE --- */
.devis-layout { display:grid; grid-template-columns:1.5fr 1fr; gap:48px; align-items:start; }
.devis-form { padding:36px; background:var(--bg-card); border:1px solid var(--border-color); border-radius:var(--radius-lg); }
.form-steps { display:flex; gap:8px; margin-bottom:32px; }
.form-step-indicator { display:flex; align-items:center; gap:8px; padding:8px 16px; background:var(--bg-primary); border:1px solid var(--border-color); border-radius:100px; font-size:0.8rem; color:var(--text-muted); transition:var(--transition); }
.form-step-indicator.active { border-color:var(--accent-1); color:var(--accent-1); background:rgba(99,102,241,0.1); }
.step-num { width:24px; height:24px; background:var(--border-color); border-radius:50%; display:flex; align-items:center; justify-content:center; font-weight:700; font-size:0.75rem; }
.form-step-indicator.active .step-num { background:var(--accent-1); color:white; }
.step-label { display:none; }
@media(min-width:768px) { .step-label { display:inline; } }
.form-panel { display:none; }
.form-panel.active { display:block; }
.form-panel h3 { font-size:1.2rem; font-weight:700; margin-bottom:4px; }
.form-panel-desc { font-size:0.9rem; color:var(--text-secondary); margin-bottom:24px; }
.form-nav { display:flex; justify-content:space-between; margin-top:24px; }
.service-selector { display:grid; grid-template-columns:repeat(3,1fr); gap:10px; }
.service-option input { display:none; }
.so-content { padding:16px; background:var(--bg-primary); border:2px solid var(--border-color); border-radius:var(--radius-md); text-align:center; cursor:pointer; transition:var(--transition); display:flex; flex-direction:column; align-items:center; gap:8px; }
.so-content svg { color:var(--text-muted); }
.so-content span { font-size:0.85rem; font-weight:600; color:var(--text-secondary); }
.service-option input:checked + .so-content { border-color:var(--accent-1); background:rgba(99,102,241,0.08); }
.service-option input:checked + .so-content svg { color:var(--accent-1); }
.service-option input:checked + .so-content span { color:var(--accent-1); }
.devis-sidebar { display:flex; flex-direction:column; gap:16px; }
.sidebar-card { padding:24px; background:var(--bg-card); border:1px solid var(--border-color); border-radius:var(--radius-md); }
.sidebar-card h4 { font-size:1rem; font-weight:700; margin-bottom:12px; }
.sidebar-card p { font-size:0.9rem; color:var(--text-secondary); line-height:1.6; }
.highlight-card { border-color:var(--accent-1); background:rgba(99,102,241,0.05); }
.check-list { list-style:none; display:flex; flex-direction:column; gap:10px; }
.check-list li { display:flex; align-items:center; gap:8px; font-size:0.9rem; color:var(--text-secondary); }
.check-list li::before { content:'✓'; color:var(--accent-2); font-weight:700; }
.faq-item { padding:16px 0; border-bottom:1px solid var(--border-color); }
.faq-item:last-child { border-bottom:none; padding-bottom:0; }
.faq-item strong { display:block; font-size:0.9rem; margin-bottom:4px; color:var(--text-primary); }
.faq-item p { font-size:0.85rem; color:var(--text-muted); line-height:1.5; margin:0; }

/* --- FOOTER --- */
.footer { padding:64px 0 32px; background:var(--bg-secondary); border-top:1px solid var(--border-color); }
.footer-grid { display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:48px; margin-bottom:48px; }
.footer-brand p { color:var(--text-muted); font-size:0.9rem; line-height:1.6; margin-top:16px; max-width:280px; }
.footer-social { display:flex; gap:12px; margin-top:16px; }
.social-link { display:flex; align-items:center; justify-content:center; width:36px; height:36px; border:1px solid var(--border-color); border-radius:50%; color:var(--text-muted); transition:var(--transition); }
.social-link:hover { border-color:var(--accent-1); color:var(--accent-1); }
.footer-links h4 { font-size:0.85rem; font-weight:700; text-transform:uppercase; letter-spacing:1.5px; color:var(--text-primary); margin-bottom:16px; }
.footer-links ul { list-style:none; display:flex; flex-direction:column; gap:10px; }
.footer-links a { font-size:0.9rem; color:var(--text-muted); transition:var(--transition); }
.footer-links a:hover { color:var(--accent-1); }
.footer-bottom { display:flex; justify-content:center; padding-top:32px; border-top:1px solid var(--border-color); font-size:0.85rem; color:var(--text-muted); }

/* --- ANIMATIONS --- */
[data-animate] { opacity:0; transform:translateY(30px); transition:opacity 0.6s ease, transform 0.6s ease; }
[data-animate="fade-left"] { transform:translateX(40px); }
[data-animate].visible { opacity:1; transform:translateY(0) translateX(0); }

/* --- RESPONSIVE --- */
@media(max-width:1024px) {
    .hero .container { grid-template-columns:1fr; }
    .hero-visual { display:block; max-width:500px; margin:0 auto; }
    .showcase-container { min-height:320px; }
    .story-layout { grid-template-columns:1fr; }
    .services-preview { grid-template-columns:repeat(2,1fr); }
    .features-grid { grid-template-columns:repeat(2,1fr); }
    .projects-grid, .projects-showcase { grid-template-columns:repeat(2,1fr); }
    .testimonials-grid { grid-template-columns:1fr; }
    .service-detail, .service-detail.reverse { grid-template-columns:1fr; }
    .service-detail-visual { display:none; }
    .expertise-intro { grid-template-columns:1fr; }
    .orbit-visual { display:none; }
    .capability-grid { grid-template-columns:repeat(2,1fr); }
    .metrics-grid, .results-grid { grid-template-columns:repeat(2,1fr); }
    .process-steps { grid-template-columns:repeat(2,1fr); }
    .contact-layout, .devis-layout { grid-template-columns:1fr; }
    .footer-grid { grid-template-columns:1fr 1fr; gap:32px; }
}
@media(max-width:768px) {
    .nav-links { display:none; position:fixed; top:0; left:0; right:0; bottom:0; background:rgba(10,10,15,0.98); backdrop-filter:blur(20px); flex-direction:column; justify-content:center; align-items:center; gap:32px; z-index:999; }
    .nav-links.active { display:flex; }
    .nav-links a { font-size:1.2rem; }
    .nav-toggle { display:flex; z-index:1001; }
    .nav-toggle.active span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
    .nav-toggle.active span:nth-child(2) { opacity:0; }
    .nav-toggle.active span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }
    .hero { padding:100px 0 60px; }
    .hero-actions { flex-direction:column; }
    .hero-stats { flex-direction:column; gap:16px; align-items:flex-start; }
    .stat-divider { display:none; }
    .showcase-container { min-height:280px; }
    .services-preview, .features-grid, .capability-grid { grid-template-columns:1fr; }
    .projects-grid, .projects-showcase { grid-template-columns:1fr; }
    .metrics-grid, .results-grid { grid-template-columns:1fr 1fr; }
    .process-steps { grid-template-columns:1fr; }
    .service-offerings { grid-template-columns:1fr; }
    .approach-grid { grid-template-columns:1fr; }
    .form-row { grid-template-columns:1fr; }
    .service-selector { grid-template-columns:repeat(2,1fr); }
    .footer-grid { grid-template-columns:1fr; }
    .footer-bottom { text-align:center; }
    .cta-content { padding:36px 24px; }
    .page-hero { padding:120px 0 60px; }
}

/* Scrollbar */
::-webkit-scrollbar { width:8px; }
::-webkit-scrollbar-track { background:var(--bg-primary); }
::-webkit-scrollbar-thumb { background:var(--border-color); border-radius:4px; }
::-webkit-scrollbar-thumb:hover { background:var(--accent-1); }
::selection { background:rgba(99,102,241,0.3); color:var(--text-primary); }
