/* ============================================================
   ANDROMIS — Ultra Premium Agency • Full Design & Motion
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&family=Syne:wght@400;500;600;700;800&family=Space+Grotesk:wght@400;500;600;700&display=swap');

:root{--bg:#06060b;--bg-alt:#0a0a14;--bg-card:#0e0e1a;--bg-card-hover:#12122a;--text:#ffffff;--text-dim:#a0a0b8;--text-muted:#606078;--accent:#7c3aed;--accent2:#06b6d4;--accent3:#f59e0b;--accent4:#ec4899;--gradient-1:linear-gradient(135deg,#7c3aed 0%,#a855f7 50%,#6366f1 100%);--gradient-2:linear-gradient(135deg,#06b6d4 0%,#22d3ee 100%);--gradient-3:linear-gradient(135deg,#f59e0b 0%,#fbbf24 100%);--border:rgba(255,255,255,0.06);--border-hover:rgba(255,255,255,0.12);--glass:rgba(14,14,26,0.8);--glass-border:rgba(255,255,255,0.08);--radius:14px;--radius-lg:20px;--radius-xl:28px;--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 20px 60px rgba(0,0,0,0.5);--shadow-glow:0 0 40px rgba(124,58,237,0.15);--transition:0.3s cubic-bezier(0.4,0,0.2,1);--nav-text:#a0a0b8;--logo-color:#fff;--btn-outline-border:rgba(255,255,255,0.2);--btn-outline-text:#fff}
*{margin:0;padding:0;box-sizing:border-box}
html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:'Plus Jakarta Sans',-apple-system,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;overflow-x:hidden;cursor:none}
a,button,.btn,input,select,textarea,.filter-btn,.quiz-option,.portfolio-item,.service-card,.chip-checkbox+label,.review-star{cursor:none}
h1,h2,h3,h4{font-family:'Syne',sans-serif}
h1{font-size:clamp(3rem,7vw,6rem);font-weight:800;line-height:1.05;letter-spacing:-0.02em}
h2{font-size:clamp(2rem,4vw,3.5rem);font-weight:700;line-height:1.1;letter-spacing:-0.01em}
h3{font-size:1.5rem;font-weight:600}
p{color:var(--text-dim);margin-bottom:1rem;font-size:1rem}
.container{width:100%;max-width:1280px;margin:0 auto;padding:0 2rem}
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--accent);border-radius:10px}
::selection{background:var(--accent);color:#fff}
#three-canvas{position:fixed;inset:0;z-index:0;pointer-events:none}

/* CUSTOM CURSOR */
.cursor-dot{position:fixed;width:6px;height:6px;border-radius:50%;background:#fff;pointer-events:none;z-index:99999;mix-blend-mode:difference;transition:width 0.2s,height 0.2s,background 0.2s}
.cursor-ring{position:fixed;width:32px;height:32px;border-radius:50%;border:1.5px solid rgba(255,255,255,0.5);pointer-events:none;z-index:99998;transition:width 0.25s,height 0.25s,border-color 0.25s,background 0.25s}
.cursor-dot.hover{width:24px;height:24px;background:var(--accent);mix-blend-mode:normal}
.cursor-ring.hover{width:48px;height:48px;border-color:var(--accent);background:rgba(124,58,237,0.08)}
[data-theme="light"] .cursor-dot{background:#1a1a2e;mix-blend-mode:normal}
[data-theme="light"] .cursor-dot.hover{background:var(--accent);mix-blend-mode:normal}
[data-theme="light"] .cursor-ring{border-color:rgba(0,0,0,0.3)}
[data-theme="light"] .cursor-ring.hover{border-color:var(--accent);background:rgba(124,58,237,0.06)}

/* PAGE TRANSITION */
.page-transition{position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:0;display:flex;align-items:center;justify-content:center;background:var(--bg)}
.page-transition.active{pointer-events:all;opacity:1}
.page-transition .pt-curtains{position:absolute;inset:0;display:flex}
.page-transition .pt-panel{flex:1;height:100%;background:var(--gradient-1);transform:scaleY(0);transform-origin:top;transition:transform 0.4s cubic-bezier(0.76,0,0.24,1)}
.page-transition.active .pt-panel{transform:scaleY(1)}
.page-transition.exiting .pt-panel{transform:scaleY(0);transform-origin:bottom}
.pt-panel:nth-child(1){transition-delay:0s}.pt-panel:nth-child(2){transition-delay:0.04s}.pt-panel:nth-child(3){transition-delay:0.08s}.pt-panel:nth-child(4){transition-delay:0.12s}.pt-panel:nth-child(5){transition-delay:0.16s}.pt-panel:nth-child(6){transition-delay:0.20s}.pt-panel:nth-child(7){transition-delay:0.24s}.pt-panel:nth-child(8){transition-delay:0.28s}
.page-transition .pt-logo{position:relative;z-index:2;font-family:'Syne',sans-serif;font-size:2.5rem;font-weight:800;color:#fff;opacity:0;transform:scale(0.8);transition:all 0.4s cubic-bezier(0.175,0.885,0.32,1.275)}
.page-transition.active .pt-logo{opacity:1;transform:scale(1)}

/* NAVBAR */
.navbar{position:fixed;top:15px;left:50%;transform:translateX(-50%);z-index:1000;width:calc(100% - 3rem);max-width:1200px;background:var(--glass);backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);border:1px solid var(--glass-border);border-radius:100px;padding:0.7rem 1.8rem;display:flex;align-items:center;justify-content:space-between;transition:all var(--transition)}
.navbar.scrolled{background:rgba(6,6,11,0.95);border-color:var(--border)}
.nav-logo{display:flex;align-items:center;gap:10px;font-family:'Syne',sans-serif;font-size:1.4rem;font-weight:700;color:var(--logo-color);text-decoration:none;letter-spacing:-0.02em}
.nav-logo .logo-dot{width:12px;height:12px;border-radius:4px;background:var(--gradient-1);animation:logoPulse 2s ease-in-out infinite}
@keyframes logoPulse{0%,100%{box-shadow:0 0 0 0 rgba(124,58,237,0.5)}50%{box-shadow:0 0 0 8px rgba(124,58,237,0)}}
.nav-links{display:none}
.nav-actions{display:flex;align-items:center;gap:8px}

/* HAMBURGER */
.hamburger{display:flex;background:none;border:none;flex-direction:column;gap:4px;cursor:none;padding:8px;z-index:1001;position:relative}
.hamburger span{display:block;width:20px;height:2px;background:var(--text);transition:all 0.3s;border-radius:1px}
.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(4px,4px)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(4px,-4px)}

/* FULLSCREEN MENU */
.fs-menu{position:fixed;inset:0;z-index:1002;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity 0.6s ease}
.fs-menu.active{opacity:1;pointer-events:all}
.fs-menu .fs-bg{position:absolute;inset:0}
.fs-menu .fs-bg::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 30% 0%,rgba(124,58,237,0.12) 0%,transparent 50%),radial-gradient(ellipse at 70% 100%,rgba(6,182,212,0.08) 0%,transparent 50%),var(--bg)}
.fs-menu .fs-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,0.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,0.02) 1px,transparent 1px);background-size:60px 60px;opacity:0.5}
.fs-menu .fs-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:0.8rem;max-width:600px;width:100%;padding:0 2rem}
.fs-menu .fs-link{font-family:'Syne',sans-serif;font-size:clamp(2.2rem,5vw,4rem);font-weight:800;color:var(--text-dim);text-decoration:none;letter-spacing:-0.02em;line-height:1.1;padding:0.5rem 1.5rem;border-radius:20px;transition:all 0.4s;transform:translateY(40px) rotateX(-15deg);opacity:0}
.fs-menu.active .fs-link{transform:translateY(0) rotateX(0);opacity:1}
.fs-link:nth-child(1){transition-delay:0s}.fs-link:nth-child(2){transition-delay:0.06s}.fs-link:nth-child(3){transition-delay:0.12s}.fs-link:nth-child(4){transition-delay:0.18s}.fs-link:nth-child(5){transition-delay:0.24s}.fs-link:nth-child(6){transition-delay:0.30s}
.fs-link:hover{color:#fff;background:rgba(124,58,237,0.08);transform:translateY(-4px) scale(1.03)}
.fs-link .fs-num{font-family:'Space Grotesk',monospace;font-size:0.8rem;opacity:0.4;margin-right:12px}
.fs-close{position:absolute;top:24px;right:24px;font-size:1.5rem;color:var(--text-dim);background:none;border:none;cursor:none;z-index:2;width:56px;height:56px;display:flex;align-items:center;justify-content:center;border-radius:50%;border:1px solid var(--border);transition:all 0.3s;backdrop-filter:blur(10px)}
.fs-close:hover{color:#fff;border-color:var(--accent);background:rgba(124,58,237,0.1)}
.fs-footer{position:absolute;bottom:30px;left:0;right:0;text-align:center;font-size:0.75rem;color:var(--text-muted);opacity:0;transition:opacity 0.5s 0.35s}
.fs-menu.active .fs-footer{opacity:1}
.fs-social{position:absolute;top:50%;right:40px;transform:translateY(-50%);display:flex;flex-direction:column;gap:16px;opacity:0;transition:opacity 0.5s 0.4s;z-index:2}
.fs-menu.active .fs-social{opacity:1}
.fs-social a{color:var(--text-muted);text-decoration:none;font-size:0.75rem;font-family:'Space Grotesk',monospace;text-transform:uppercase;letter-spacing:0.1em;transition:color 0.3s;writing-mode:vertical-rl}
.fs-social a:hover{color:var(--accent)}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 26px;border-radius:50px;font-weight:600;font-size:0.9rem;text-decoration:none;border:none;cursor:none;transition:all 0.3s;font-family:'Plus Jakarta Sans',sans-serif;position:relative;overflow:hidden}
.btn::after{content:'';position:absolute;inset:0;border-radius:inherit;opacity:0;transition:opacity 0.3s;background:linear-gradient(135deg,rgba(255,255,255,0.1) 0%,rgba(255,255,255,0.05) 100%)}
.btn:hover::after{opacity:1}
.btn:active{transform:scale(0.95)}
.btn-primary{background:var(--gradient-1);color:#fff;box-shadow:0 4px 20px rgba(124,58,237,0.25)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 12px 40px rgba(124,58,237,0.45)}
.btn-outline{background:transparent;border:1.5px solid var(--btn-outline-border);color:var(--btn-outline-text)}
.btn-outline:hover{border-color:var(--accent);background:rgba(124,58,237,0.06);transform:translateY(-2px)}
.btn-glass{background:rgba(124,58,237,0.06);backdrop-filter:blur(20px);border:1px solid rgba(124,58,237,0.12);color:var(--text)}
.btn-glass:hover{background:rgba(124,58,237,0.12);transform:translateY(-2px)}
.btn-sm{padding:8px 18px;font-size:0.8rem}
.btn-lg{padding:16px 36px;font-size:1.05rem}

/* WHATSAPP */
.whatsapp-contact-item .ci-icon{background:rgba(37,211,102,0.1);border-color:rgba(37,211,102,0.15)}

/* HERO */
.hero{min-height:100vh;display:flex;align-items:center;position:relative;z-index:1;padding-top:100px}
.hero .container{position:relative;z-index:2;text-align:center}
.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 18px;border-radius:50px;border:1px solid var(--border);font-size:0.8rem;color:var(--text-dim);margin-bottom:28px;backdrop-filter:blur(20px);background:rgba(14,14,26,0.6);animation:badgeFloat 3s ease-in-out infinite}
@keyframes badgeFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}
.hero-badge .live-dot{width:8px;height:8px;border-radius:50%;background:#22c55e;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.3}}
.hero h1{max-width:900px;margin:0 auto 1.5rem}
.gradient-text{background:var(--gradient-1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero p{font-size:1.2rem;max-width:550px;margin:0 auto 2.5rem}
.hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:4rem}
.hero-stats{display:flex;justify-content:center;gap:60px;flex-wrap:wrap}
.hero-stat{text-align:center}
.hero-stat .hs-icon{font-size:1.5rem;margin-bottom:8px;opacity:0.6}
.hero-stat h3{font-size:3rem;font-weight:800;font-family:'Space Grotesk',monospace;margin-bottom:2px}
.hero-stat p{font-size:0.85rem;margin-bottom:0;color:var(--text-muted)}

/* SECTION */
.section{padding:110px 0;position:relative;z-index:1}
.section-header{text-align:center;margin-bottom:60px}
.section-badge{display:inline-flex;align-items:center;gap:8px;font-family:'Space Grotesk',monospace;font-size:0.75rem;text-transform:uppercase;letter-spacing:0.15em;color:var(--accent);margin-bottom:16px;padding:4px 14px;border-radius:50px;background:rgba(124,58,237,0.08);border:1px solid rgba(124,58,237,0.15)}
.section-header h2{margin-bottom:14px}
.section-header p{max-width:550px;margin:0 auto}

/* SERVICES */
.services-scroll{position:relative;padding:20px 0}
.services-track{display:flex;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding:20px 0 30px;-webkit-overflow-scrolling:touch;cursor:grab}
.services-track::-webkit-scrollbar{height:4px}
.services-track::-webkit-scrollbar-track{background:var(--bg)}
.services-track::-webkit-scrollbar-thumb{background:var(--accent);border-radius:4px}
.services-track.active{cursor:grabbing}
.service-card{min-width:320px;max-width:380px;flex-shrink:0;scroll-snap-align:start;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:44px 32px;transition:all 0.5s cubic-bezier(0.175,0.885,0.32,1.275);position:relative;overflow:hidden}
.service-card:hover{transform:translateY(-10px) scale(1.02);background:var(--bg-card-hover);box-shadow:var(--shadow-glow);border-color:var(--accent)}
.service-card .sc-number{position:absolute;top:20px;right:24px;font-family:'Space Grotesk',monospace;font-size:3rem;font-weight:800;color:rgba(124,58,237,0.06);line-height:1;pointer-events:none}
.sc-icon{width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:1.8rem;margin-bottom:24px;background:rgba(124,58,237,0.1);transition:all 0.4s}
.sc-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}
.sc-tags span{padding:3px 10px;border-radius:50px;font-size:0.65rem;font-weight:500;background:var(--bg-alt);color:var(--text-muted);border:1px solid var(--border)}
.service-card:hover .sc-icon{transform:scale(1.1) rotate(-5deg);background:rgba(124,58,237,0.2)}
.service-card h3{margin-bottom:10px}
.service-card p{font-size:0.95rem;margin-bottom:20px}
.service-card .sc-link{color:var(--accent);font-weight:600;font-size:0.9rem;display:inline-flex;align-items:center;gap:6px;text-decoration:none;transition:gap 0.3s}
.service-card:hover .sc-link{gap:10px}
.services-nav{display:flex;justify-content:center;gap:10px;margin-top:10px}
.services-nav button{width:44px;height:44px;border-radius:50%;border:1px solid var(--border);background:var(--bg-card);color:var(--text);cursor:none;font-size:1.2rem;display:flex;align-items:center;justify-content:center;transition:all var(--transition)}
.services-nav button:hover{border-color:var(--accent);color:var(--accent);background:rgba(124,58,237,0.06)}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.services-grid .service-card{min-width:auto;max-width:none}

/* PORTFOLIO */
.portfolio-grid-home{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.portfolio-item-home{border-radius:var(--radius-xl);overflow:hidden;background:var(--bg-card);border:1px solid var(--border);transition:all 0.4s cubic-bezier(0.175,0.885,0.32,1.275);cursor:none;position:relative}
.portfolio-item-home:hover{transform:translateY(-8px);border-color:var(--accent);box-shadow:var(--shadow-glow)}
.pih-media{height:180px;display:flex;align-items:center;justify-content:center;position:relative}
.pih-logo{font-family:'Syne',sans-serif;font-size:3rem;font-weight:800;color:rgba(255,255,255,0.2);letter-spacing:0.05em}
.pih-info{padding:24px}
.pih-tag{display:inline-block;padding:4px 12px;border-radius:50px;font-size:0.65rem;font-weight:600;text-transform:uppercase;letter-spacing:0.06em;background:rgba(124,58,237,0.1);color:var(--accent);margin-bottom:10px}
.portfolio-item-home h4{font-size:1.15rem;margin-bottom:6px}
.portfolio-item-home p{font-size:0.85rem;color:var(--text-dim);margin-bottom:14px}
.pih-techs{display:flex;flex-wrap:wrap;gap:6px}
.pih-techs span{padding:3px 10px;border-radius:50px;font-size:0.65rem;font-weight:500;background:var(--bg-alt);color:var(--text-muted);border:1px solid var(--border)}

/* OLD PORTFOLIO CAROUSEL */
.portfolio-showcase{display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding:10px 0 30px;-webkit-overflow-scrolling:touch}
.portfolio-showcase::-webkit-scrollbar{height:4px}
.portfolio-showcase::-webkit-scrollbar-thumb{background:var(--accent);border-radius:4px}
.portfolio-card{min-width:300px;max-width:380px;flex-shrink:0;scroll-snap-align:start;border-radius:var(--radius-lg);overflow:hidden;position:relative;aspect-ratio:4/5;background:var(--bg-card);border:1px solid var(--border);transition:all 0.5s;cursor:none}
.portfolio-card:hover{transform:translateY(-8px) scale(1.02);border-color:var(--accent);box-shadow:var(--shadow-glow)}
.portfolio-card .pc-media{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:4rem;transition:transform 0.6s}
.portfolio-card:hover .pc-media{transform:scale(1.08)}
.portfolio-card .pc-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,0.95) 0%,transparent 50%);display:flex;flex-direction:column;justify-content:flex-end;padding:28px;opacity:0;transition:opacity 0.4s}
.portfolio-card:hover .pc-overlay{opacity:1}
.pc-overlay .pc-tag{display:inline-block;padding:4px 12px;border-radius:50px;font-size:0.65rem;font-weight:600;text-transform:uppercase;letter-spacing:0.06em;background:var(--accent);color:#fff;margin-bottom:8px;width:fit-content}
.pc-overlay h4{font-size:1.2rem;margin-bottom:2px}
.pc-overlay span{color:rgba(255,255,255,0.5);font-size:0.8rem}
.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.portfolio-item{border-radius:var(--radius-lg);overflow:hidden;position:relative;aspect-ratio:5/4;background:var(--bg-card);border:1px solid var(--border);transition:all 0.5s;cursor:none}
.portfolio-item:hover{transform:translateY(-8px) scale(1.03);border-color:var(--accent);box-shadow:var(--shadow-glow)}
.portfolio-item .pi-media{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:3rem;transition:transform 0.5s}
.portfolio-item:hover .pi-media{transform:scale(1.05)}
.portfolio-item .pi-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,0.9) 0%,transparent 60%);display:flex;flex-direction:column;justify-content:flex-end;padding:24px;opacity:0;transition:opacity 0.3s}
.portfolio-item:hover .pi-overlay{opacity:1}
.pi-overlay h4{margin-bottom:2px}
.pi-overlay span{color:rgba(255,255,255,0.6);font-size:0.85rem}
.portfolio-filter{display:flex;justify-content:center;gap:8px;margin-bottom:40px}
.filter-btn{padding:8px 20px;border-radius:50px;border:1px solid var(--border);background:transparent;color:var(--text-dim);font-weight:500;font-size:0.85rem;cursor:none;transition:all var(--transition)}
.filter-btn:hover,.filter-btn.active{border-color:var(--accent);background:rgba(124,58,237,0.1);color:var(--accent)}

/* PROCESS */
.process-timeline{position:relative;padding:20px 0}
.process-line{position:absolute;top:40px;left:50%;transform:translateX(-50%);width:75%;height:2px;background:var(--gradient-1);opacity:0.2;z-index:0}
.process-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;position:relative;z-index:1}
.process-step{display:flex;flex-direction:column;align-items:center;gap:16px;transition:all 0.4s cubic-bezier(0.175,0.885,0.32,1.275)}
.process-step:hover{transform:translateY(-6px)}
.process-step .ps-dot{width:44px;height:44px;border-radius:50%;background:var(--gradient-1);display:flex;align-items:center;justify-content:center;font-family:'Space Grotesk',monospace;font-size:0.9rem;font-weight:700;color:#fff;box-shadow:0 4px 20px rgba(124,58,237,0.3);z-index:2}
.process-step .ps-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px 20px;text-align:center;transition:all 0.4s;width:100%}
.process-step:hover .ps-card{border-color:var(--accent);box-shadow:var(--shadow-glow)}
.process-step .ps-icon{display:none}
.process-step h3{margin-bottom:6px;font-size:1.1rem}
.process-step p{font-size:0.85rem;margin-bottom:12px}
.ps-deliverables{display:flex;flex-wrap:wrap;justify-content:center;gap:6px}
.ps-deliverables span{padding:3px 10px;border-radius:50px;font-size:0.65rem;font-weight:600;text-transform:uppercase;letter-spacing:0.04em;background:rgba(124,58,237,0.08);color:var(--accent);border:1px solid rgba(124,58,237,0.12)}

/* FAQ */
.faq-themes{display:grid;grid-template-columns:1fr 1fr;gap:32px}
.faq-theme{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-xl);padding:32px;transition:all 0.3s ease}
.faq-theme:hover{border-color:var(--accent)}
.faq-theme-header{display:flex;align-items:center;gap:14px;margin-bottom:20px}
.faq-theme-header .ft-icon{display:none}
.faq-theme-header h3{font-size:1.2rem}
.faq-list{display:flex;flex-direction:column;gap:6px}
.faq-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:all 0.3s cubic-bezier(0.175,0.885,0.32,1.275)}
.faq-item:hover{border-color:var(--border-hover);transform:translateX(4px)}
.faq-question{width:100%;padding:16px 20px;background:none;border:none;color:var(--text);font-family:'Syne',sans-serif;font-size:1rem;font-weight:600;text-align:left;cursor:none;display:flex;justify-content:space-between;align-items:center;gap:12px}
.faq-question .faq-arrow{font-size:1.1rem;transition:transform 0.4s;color:var(--accent)}
.faq-item.open .faq-arrow{transform:rotate(45deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height 0.4s ease,padding 0.4s ease}
.faq-item.open .faq-answer{max-height:300px;padding:0 20px 16px}
.faq-answer p{font-size:0.85rem;color:var(--text-dim)}

/* TESTIMONIALS */
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.testimonial-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;transition:all 0.4s cubic-bezier(0.175,0.885,0.32,1.275)}
.testimonial-card:hover{border-color:var(--border-hover);transform:translateY(-6px) scale(1.01);box-shadow:var(--shadow-glow)}
.testimonial-card .stars{color:var(--accent3);margin-bottom:14px;font-size:1rem}
.testimonial-card .tt-text{font-style:italic;margin-bottom:20px;font-size:0.95rem}
.testimonial-card .tt-author{display:flex;align-items:center;gap:12px}
.tt-author .tt-avatar{width:44px;height:44px;border-radius:50%;background:var(--gradient-1);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem}
.tt-author h4{font-size:0.95rem;margin-bottom:0}
.tt-author p{font-size:0.8rem;margin-bottom:0;color:var(--text-muted)}

/* REVIEW FORM */
.review-form-wrap{max-width:600px;margin:40px auto 0;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:36px}
.review-stars-input{display:flex;gap:6px;justify-content:center;margin-bottom:18px;font-size:1.8rem}
.review-star{cursor:none;color:var(--border);transition:color 0.15s,transform 0.2s}
.review-star.active,.review-star:hover{color:var(--accent3);transform:scale(1.2)}
.review-submitted{text-align:center;padding:40px;display:none}
.review-submitted.show{display:block}

/* TRUST BADGES */
.trust-badges{display:flex;justify-content:center;align-items:center;gap:50px;flex-wrap:wrap;margin-top:32px}
.trust-badge{text-align:center;opacity:0.6;transition:opacity 0.3s}
.trust-badge:hover{opacity:1}
.trust-badge .tb-icon{font-size:2.5rem;margin-bottom:4px}
.trust-badge .tb-label{font-size:0.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.05em;font-family:'Space Grotesk',monospace}

/* DEVIS */
.devis-wrapper{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start}
.devis-form,.devis-resume{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:36px}
.devis-resume{position:sticky;top:100px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-group{margin-bottom:18px}
.form-group label{display:block;font-weight:600;font-size:0.8rem;text-transform:uppercase;letter-spacing:0.04em;color:var(--text-dim);margin-bottom:6px}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 16px;border-radius:var(--radius);border:1.5px solid var(--border);background:var(--bg-alt);color:var(--text);font-family:inherit;font-size:0.95rem;transition:all var(--transition);cursor:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px rgba(124,58,237,0.08)}
.form-group textarea{resize:vertical;min-height:90px}
input[type=range]{-webkit-appearance:none;height:6px;border-radius:3px;background:var(--border);padding:0;border:none;cursor:none}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:22px;height:22px;border-radius:50%;background:var(--accent);cursor:none;box-shadow:0 0 12px rgba(124,58,237,0.3)}
.range-labels{display:flex;justify-content:space-between;font-size:0.75rem;color:var(--text-muted);margin-top:4px}
.checkbox-group{display:flex;flex-wrap:wrap;gap:6px}
.chip-checkbox{display:none}
.chip-checkbox+label{display:inline-block;padding:7px 16px;border-radius:50px;border:1.5px solid var(--border);font-size:0.8rem;font-weight:500;cursor:none;transition:all var(--transition);color:var(--text-dim)}
.chip-checkbox:checked+label{background:rgba(124,58,237,0.2);border-color:var(--accent);color:var(--accent)}
.devis-line{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border);font-size:0.9rem}
.devis-total{background:rgba(124,58,237,0.06);border:1px solid rgba(124,58,237,0.15);border-radius:var(--radius);padding:24px;text-align:center;margin-top:20px}
.total-price{font-family:'Space Grotesk',monospace;font-size:3rem;font-weight:800;background:var(--gradient-1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* ABOUT */
.about-grid-new{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-visual-new{aspect-ratio:1;border-radius:var(--radius-xl);background:var(--gradient-1);display:flex;align-items:center;justify-content:center;font-size:6rem;color:rgba(255,255,255,0.1);position:relative;overflow:hidden}
.avn-glow{position:absolute;inset:-40px;background:radial-gradient(circle at 50% 50%,rgba(124,58,237,0.3) 0%,transparent 70%);pointer-events:none}
.avn-shape{position:relative;z-index:1}
.avn-badge-top{position:absolute;top:-18px;left:50%;transform:translateX(-50%);background:var(--bg-card);border:1px solid var(--border);border-radius:50px;padding:8px 24px;font-family:'Syne',sans-serif;font-weight:700;font-size:0.9rem;color:var(--text);backdrop-filter:blur(20px);z-index:2;white-space:nowrap}
.avn-badge-bottom{position:absolute;bottom:0;left:0;right:0;display:flex;justify-content:center;gap:24px;padding:16px;background:rgba(0,0,0,0.4);backdrop-filter:blur(10px)}
.avn-stat{text-align:center}
.avn-num{font-family:'Space Grotesk',monospace;font-size:1.4rem;font-weight:800;color:#fff}
.avn-label{font-size:0.6rem;text-transform:uppercase;letter-spacing:0.05em;color:rgba(255,255,255,0.6)}
.about-points{display:flex;flex-direction:column;gap:8px;margin:20px 0}
.about-point{display:flex;align-items:center;gap:10px;font-size:0.9rem;color:var(--text-dim)}
.about-point .ap-check{color:var(--accent);font-weight:700;font-size:1rem}
.values-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:20px}
.value-pill{display:flex;align-items:center;gap:8px;padding:10px 16px;border-radius:50px;border:1px solid var(--border);font-size:0.9rem;font-weight:500;transition:all var(--transition);color:var(--text-dim)}
.value-pill:hover{border-color:var(--accent);color:var(--accent);background:rgba(124,58,237,0.05);transform:translateX(4px)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-visual{aspect-ratio:1;border-radius:var(--radius-xl);background:var(--gradient-1);display:flex;align-items:center;justify-content:center;font-size:8rem;color:rgba(255,255,255,0.15);position:relative;overflow:hidden}
.about-visual::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 30% 30%,rgba(255,255,255,0.08) 0%,transparent 60%)}
.about-badge{position:absolute;bottom:-18px;right:-18px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:18px 24px;display:flex;align-items:center;gap:10px;backdrop-filter:blur(20px)}
.about-badge .badge-num{font-family:'Space Grotesk',monospace;font-size:2.2rem;font-weight:800;background:var(--gradient-1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.about-badge .badge-label{font-size:0.8rem;color:var(--text-dim)}

/* CTA */
.cta-section{text-align:center;padding:120px 0;background:var(--bg-alt);border-top:1px solid var(--border);border-bottom:1px solid var(--border);position:relative;overflow:hidden}
.cta-section::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 50%,rgba(124,58,237,0.04) 0%,transparent 70%);pointer-events:none}
.cta-section h2{margin-bottom:14px}
.cta-section p{margin-bottom:32px;font-size:1.15rem;max-width:500px;margin-left:auto;margin-right:auto}

/* CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:30px}
.contact-info h2{margin-bottom:14px}
.contact-items{display:flex;flex-direction:column;gap:18px;margin-top:28px}
.contact-item{display:flex;align-items:center;gap:14px;padding:12px 16px;border-radius:var(--radius);border:1px solid var(--border);transition:all var(--transition);background:var(--bg-card)}
.contact-item:hover{border-color:var(--accent);transform:translateX(4px)}
.contact-item .ci-icon{width:48px;height:48px;border-radius:14px;background:rgba(124,58,237,0.08);display:flex;align-items:center;justify-content:center;font-size:1.3rem;border:1px solid rgba(124,58,237,0.15);flex-shrink:0}
.contact-item h4{font-size:0.95rem;margin-bottom:2px}
.contact-item p{font-size:0.85rem;margin-bottom:0}
.contact-form{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:36px}
.hours-list{list-style:none;display:flex;flex-direction:column;gap:8px;margin-top:16px}
.hours-list li{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border);font-size:0.85rem}
.hours-list li span:first-child{color:var(--text-dim)}
.hours-list li span:last-child{color:var(--text);font-weight:500}

/* FOOTER */
.footer{border-top:1px solid var(--border);padding:60px 0 20px;background:var(--bg-alt)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:40px;margin-bottom:40px}
.footer-col h4{font-family:'Syne',sans-serif;font-size:0.85rem;text-transform:uppercase;letter-spacing:0.05em;margin-bottom:18px;color:var(--text)}
.footer-col ul{list-style:none}
.footer-col ul li{margin-bottom:8px}
.footer-col ul li a{color:var(--text-dim);text-decoration:none;font-size:0.9rem;transition:color 0.2s}
.footer-col ul li a:hover{color:var(--accent)}
.footer-newsletter input{width:100%;padding:10px 14px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg);color:var(--text);font-family:inherit;margin-bottom:8px;cursor:none}
.footer-bottom{border-top:1px solid var(--border);padding-top:16px;display:flex;justify-content:space-between;font-size:0.8rem;color:var(--text-muted)}
.footer-bottom a{color:var(--text-muted);text-decoration:none}

/* PAGE HERO */
.page-hero{padding:160px 0 80px;text-align:center;position:relative;z-index:1}
.page-hero h1{margin-bottom:14px}
.page-hero p{font-size:1.15rem;max-width:500px;margin:0 auto}

/* DASHBOARD */
.dashboard-grid{display:grid;grid-template-columns:260px 1fr;gap:24px}
.dashboard-sidebar{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:24px;position:sticky;top:110px;height:fit-content}
.user-info{text-align:center;padding-bottom:20px;border-bottom:1px solid var(--border);margin-bottom:20px}
.user-avatar{width:60px;height:60px;border-radius:50%;background:var(--gradient-1);display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:800;margin:0 auto 10px;color:#fff}
.dashboard-nav{list-style:none}
.dashboard-nav li{margin-bottom:2px}
.dashboard-nav li a{display:block;padding:10px 16px;border-radius:var(--radius);color:var(--text-dim);font-weight:500;font-size:0.9rem;text-decoration:none;transition:all 0.2s;cursor:none}
.dashboard-nav li a:hover,.dashboard-nav li a.active{background:rgba(124,58,237,0.1);color:var(--accent)}
.dashboard-main{display:flex;flex-direction:column;gap:16px}
.dashboard-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px}
.status-badge{display:inline-block;padding:4px 12px;border-radius:50px;font-size:0.7rem;font-weight:600;text-transform:uppercase;letter-spacing:0.03em}
.status-badge.en-cours{background:rgba(124,58,237,0.15);color:var(--accent)}
.status-badge.termine{background:rgba(34,197,94,0.1);color:#22c55e}
.status-badge.en-attente{background:rgba(245,158,11,0.1);color:var(--accent3)}
.progress-bar{width:100%;height:5px;background:var(--bg);border-radius:3px;overflow:hidden;margin-top:8px}
.progress-fill{height:100%;background:var(--gradient-1);border-radius:3px;transition:width 0.5s}
.project-item-db{display:flex;align-items:center;justify-content:space-between;padding:14px;border-radius:var(--radius);background:var(--bg-alt);margin-bottom:8px;border:1px solid var(--border)}

/* MODALS */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.7);backdrop-filter:blur(12px);z-index:2000;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:all 0.3s}
.modal-overlay.active{opacity:1;visibility:visible}
.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:44px;max-width:440px;width:90%;position:relative;animation:modalIn 0.4s cubic-bezier(0.175,0.885,0.32,1.275)}
@keyframes modalIn{from{transform:scale(0.9) translateY(30px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}
.modal-close{position:absolute;top:14px;right:14px;width:34px;height:34px;border-radius:50%;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:1rem;cursor:none;display:flex;align-items:center;justify-content:center;transition:all 0.2s}
.modal-close:hover{border-color:var(--accent);color:var(--accent)}
.modal h3{text-align:center;margin-bottom:28px}
.modal .btn{width:100%;justify-content:center}
.modal-footer{text-align:center;margin-top:14px;font-size:0.85rem;color:var(--text-muted)}
.modal-footer a{color:var(--accent);cursor:none;font-weight:600}

/* TOAST */
.toast-container{position:fixed;top:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px}
.toast{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:12px 18px;display:flex;align-items:center;gap:10px;animation:toastIn 0.3s ease,toastOut 0.3s ease 2.8s forwards;backdrop-filter:blur(20px);font-size:0.9rem;box-shadow:var(--shadow-md)}
.toast.success{border-left:3px solid #22c55e}
.toast.error{border-left:3px solid #ef4444}
.toast.info{border-left:3px solid var(--accent)}
@keyframes toastIn{from{transform:translateX(80px);opacity:0}to{transform:translateX(0);opacity:1}}
@keyframes toastOut{to{opacity:0;transform:translateX(40px)}}

/* REVEAL */
.reveal{opacity:0;transition:opacity 0.8s ease,transform 0.8s ease}
.reveal.visible{opacity:1;transform:none}
.reveal-up{transform:translateY(50px)}
.reveal-down{transform:translateY(-50px)}
.reveal-left{transform:translateX(-40px)}
.reveal-right{transform:translateX(40px)}
.reveal-scale{transform:scale(0.85)}
.reveal-rotate{transform:rotate(-2deg) scale(0.9);opacity:0}
.reveal-stagger>*{opacity:0;transform:translateY(30px);transition:opacity 0.6s ease,transform 0.6s ease}
.reveal-stagger.visible>*:nth-child(1){transition-delay:0s;opacity:1;transform:translateY(0)}
.reveal-stagger.visible>*:nth-child(2){transition-delay:0.08s;opacity:1;transform:translateY(0)}
.reveal-stagger.visible>*:nth-child(3){transition-delay:0.16s;opacity:1;transform:translateY(0)}
.reveal-stagger.visible>*:nth-child(4){transition-delay:0.24s;opacity:1;transform:translateY(0)}
.reveal-stagger.visible>*:nth-child(5){transition-delay:0.32s;opacity:1;transform:translateY(0)}
.reveal-stagger.visible>*:nth-child(6){transition-delay:0.40s;opacity:1;transform:translateY(0)}

/* CARD GLOW */
.card-glow{position:absolute;inset:0;border-radius:inherit;opacity:0;transition:opacity 0.5s ease;pointer-events:none;background:radial-gradient(600px circle at var(--mx) var(--my),rgba(124,58,237,0.08),transparent 40%)}

/* DARK MODE BUTTON */
.darkmode-fixed-btn{position:fixed;bottom:30px;left:50%;transform:translateX(-50%);z-index:1099;display:flex;align-items:center;gap:14px;padding:16px 32px;border-radius:100px;background:var(--bg-card);border:1.5px solid var(--border);cursor:none;font-family:'Syne',sans-serif;font-size:1rem;font-weight:700;color:var(--text);backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);box-shadow:0 8px 40px rgba(0,0,0,0.4);transition:all 0.4s cubic-bezier(0.175,0.885,0.32,1.275)}
.darkmode-fixed-btn:hover{border-color:var(--accent);box-shadow:0 12px 50px rgba(124,58,237,0.3);transform:translateX(-50%) translateY(-3px)}
.darkmode-fixed-btn .dm-icon-wrap{width:44px;height:44px;border-radius:50%;background:var(--gradient-1);display:flex;align-items:center;justify-content:center;font-size:1.4rem;box-shadow:0 4px 20px rgba(124,58,237,0.3);transition:transform 0.4s ease}
.darkmode-fixed-btn:hover .dm-icon-wrap{transform:rotate(180deg)}
.darkmode-fixed-btn .dm-labels{display:flex;flex-direction:column;line-height:1.2}
.darkmode-fixed-btn .dm-label-main{font-size:0.95rem}
.darkmode-fixed-btn .dm-label-sub{font-size:0.7rem;color:var(--text-muted);font-family:'Space Grotesk',monospace;text-transform:uppercase;letter-spacing:0.08em}

/* LANGUAGE SELECTOR */
.lang-select-bottom{position:fixed;bottom:30px;left:30px;z-index:1100}
.lang-select-bottom select{appearance:none;-webkit-appearance:none;padding:10px 32px 10px 16px;border-radius:50px;border:1.5px solid var(--border);background:var(--bg-card);color:var(--text);font-family:'Space Grotesk',monospace;font-size:0.75rem;font-weight:600;cursor:none;outline:none;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 4px 20px rgba(0,0,0,0.3);transition:all var(--transition);background-image:url('data:image/svg+xml;utf8,<svg xmlns=%22http://www.w3.org/2000/svg%22 width=%2212%22 height=%2212%22 viewBox=%220 0 12 12%22><path fill=%22%23a0a0b8%22 d=%22M6 8L1 3h10z%22/></svg>');background-repeat:no-repeat;background-position:right 8px center}
.lang-select-bottom select:hover{border-color:var(--accent)}
.lang-select-bottom .lang-label{display:block;font-size:0.6rem;text-transform:uppercase;letter-spacing:0.1em;color:var(--text-muted);margin-bottom:6px;font-family:'Space Grotesk',monospace}

/* AMBIENT SOUND BUTTON */
.ambient-sound-btn{position:fixed;bottom:100px;left:30px;z-index:1100;width:40px;height:40px;border-radius:50%;border:1px solid var(--border);background:var(--bg-card);color:var(--text-dim);cursor:none;display:flex;align-items:center;justify-content:center;font-size:1rem;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);transition:all var(--transition);box-shadow:0 4px 20px rgba(0,0,0,0.3)}

/* CHATBOT */
.chatbot-widget{position:fixed;bottom:25px;right:24px;z-index:1500;font-family:'Plus Jakarta Sans',sans-serif}
.chatbot-toggle{width:56px;height:56px;border-radius:50%;background:var(--gradient-1);border:none;cursor:none;display:flex;align-items:center;justify-content:center;font-size:1.4rem;box-shadow:0 8px 30px rgba(124,58,237,0.35);transition:all 0.3s cubic-bezier(0.175,0.885,0.32,1.275);color:#fff}
.chatbot-toggle:hover{transform:scale(1.08);box-shadow:0 12px 40px rgba(124,58,237,0.45)}
.chatbot-toggle.active{transform:rotate(45deg)}
.chatbot-panel{position:absolute;bottom:70px;right:0;width:370px;max-height:520px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;overflow:hidden;opacity:0;visibility:hidden;transform:translateY(20px) scale(0.95);transition:all 0.3s cubic-bezier(0.175,0.885,0.32,1.275)}
.chatbot-panel.open{opacity:1;visibility:visible;transform:translateY(0) scale(1)}
.chatbot-header{padding:16px 20px;background:var(--gradient-1);color:#fff;display:flex;align-items:center;gap:10px}
.chatbot-header .cb-avatar{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,0.2);display:flex;align-items:center;justify-content:center;font-size:1.1rem}
.chatbot-header h4{font-size:0.95rem;margin-bottom:0;color:#fff}
.chatbot-header p{font-size:0.7rem;margin-bottom:0;color:rgba(255,255,255,0.7)}
.chatbot-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px;max-height:330px}
.chatbot-messages::-webkit-scrollbar{width:3px}
.chatbot-messages::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}
.cb-message{max-width:80%;padding:10px 14px;border-radius:16px;font-size:0.85rem;line-height:1.5;animation:cbIn 0.3s ease}
@keyframes cbIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.cb-message.bot{background:var(--bg-alt);border:1px solid var(--border);align-self:flex-start;border-bottom-left-radius:4px}
.cb-message.user{background:var(--gradient-1);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.cb-quick-actions{display:flex;flex-wrap:wrap;gap:6px;padding:8px 16px 12px}
.cb-quick-btn{padding:6px 14px;border-radius:50px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-dim);font-size:0.75rem;font-weight:500;cursor:none;transition:all 0.2s;font-family:inherit;white-space:nowrap}
.cb-quick-btn:hover{border-color:var(--accent);color:var(--accent);background:rgba(124,58,237,0.04)}
.chatbot-input-area{display:flex;gap:6px;padding:10px 16px 14px;border-top:1px solid var(--border)}
.chatbot-input-area input{flex:1;padding:10px 14px;border-radius:50px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-family:inherit;font-size:0.85rem;outline:none;cursor:none;transition:border-color 0.2s}
.chatbot-input-area input:focus{border-color:var(--accent)}
.chatbot-input-area button{width:38px;height:38px;border-radius:50%;border:none;background:var(--gradient-1);color:#fff;cursor:none;font-size:1rem;display:flex;align-items:center;justify-content:center;transition:transform 0.2s;flex-shrink:0}
.chatbot-input-area button:hover{transform:scale(1.05)}

/* QUIZ DEVIS */
.quiz-container{max-width:650px;margin:0 auto;position:relative;min-height:450px}
.quiz-progress{display:flex;gap:6px;margin-bottom:32px}
.quiz-step-dot{flex:1;height:4px;border-radius:2px;background:var(--border);transition:all 0.4s ease}
.quiz-step-dot.active{background:var(--accent)}
.quiz-step-dot.done{background:var(--accent);opacity:0.5}
.quiz-step{display:none;animation:quizSlide 0.4s ease}
.quiz-step.active{display:block}
@keyframes quizSlide{from{opacity:0;transform:translateX(30px)}to{opacity:1;transform:translateX(0)}}
.quiz-step h3{margin-bottom:8px}
.quiz-step p{color:var(--text-dim);margin-bottom:20px}
.quiz-options{display:flex;flex-direction:column;gap:10px}
.quiz-option{padding:16px 20px;border-radius:var(--radius);border:1.5px solid var(--border);background:var(--bg-card);cursor:none;transition:all 0.25s;display:flex;align-items:center;gap:12px;font-weight:500;font-size:0.95rem;color:var(--text-dim)}
.quiz-option:hover{border-color:var(--accent);background:rgba(124,58,237,0.03);color:var(--text);transform:translateX(4px)}
.quiz-option.selected{border-color:var(--accent);background:rgba(124,58,237,0.06);color:var(--accent);box-shadow:0 0 0 3px rgba(124,58,237,0.06)}
.quiz-option .qo-icon{font-size:1.5rem;width:36px;text-align:center;flex-shrink:0}
.quiz-option .qo-price{margin-left:auto;font-weight:700;color:var(--accent);font-size:0.9rem}
.quiz-nav{display:flex;gap:10px;margin-top:24px}
.quiz-nav .btn{flex:1;justify-content:center}
.quiz-result{text-align:center;padding:20px 0}
.quiz-result .total-price{font-family:'Space Grotesk',monospace;font-size:3.5rem;font-weight:800;background:var(--gradient-1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* EXIT POPUP */
.conversion-popup{position:fixed;inset:0;z-index:3000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity 0.4s ease}
.conversion-popup.active{opacity:1;pointer-events:all}
.conversion-popup .cp-backdrop{position:absolute;inset:0;background:rgba(0,0,0,0.75);backdrop-filter:blur(12px)}
.conversion-popup .cp-card{position:relative;z-index:1;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:44px 36px;max-width:440px;width:90%;text-align:center;box-shadow:var(--shadow-lg);animation:cpBounceIn 0.5s cubic-bezier(0.175,0.885,0.32,1.275)}
@keyframes cpBounceIn{0%{transform:scale(0.8);opacity:0}60%{transform:scale(1.03)}100%{transform:scale(1);opacity:1}}
.conversion-popup .cp-badge{display:inline-block;padding:4px 14px;border-radius:50px;background:rgba(124,58,237,0.15);color:var(--accent);font-size:0.65rem;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;margin-bottom:16px;font-family:'Space Grotesk',monospace}
.conversion-popup .cp-icon{width:64px;height:64px;border-radius:50%;background:var(--gradient-1);display:flex;align-items:center;justify-content:center;font-size:1.8rem;margin:0 auto 20px;box-shadow:0 8px 30px rgba(124,58,237,0.3)}
.conversion-popup .cp-title{font-family:'Syne',sans-serif;font-size:1.5rem;font-weight:700;margin-bottom:8px}
.conversion-popup .cp-desc{color:var(--text-dim);font-size:0.9rem;margin-bottom:16px}
.conversion-popup .cp-features{text-align:left;margin-bottom:20px;display:flex;flex-direction:column;gap:6px}
.conversion-popup .cp-feat{font-size:0.85rem;color:var(--text-dim);display:flex;align-items:center;gap:8px}
.conversion-popup .cp-check{color:var(--accent);font-weight:700}
.conversion-popup .cp-timer-wrap{margin-bottom:16px}
.conversion-popup .cp-timer-label{font-size:0.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.05em;display:block;margin-bottom:4px}
.conversion-popup .cp-timer{font-family:'Space Grotesk',monospace;font-size:1.4rem;font-weight:700;color:var(--accent)}
.conversion-popup .cp-close{position:absolute;top:16px;right:16px;background:none;border:none;color:var(--text-muted);font-size:1.2rem;cursor:none}

/* UFO WIN POPUP */
.ufo-win-overlay{position:fixed;inset:0;z-index:3100;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity 0.4s ease}
.ufo-win-overlay.active{opacity:1;pointer-events:all}
.ufo-win-backdrop{position:absolute;inset:0;background:rgba(0,0,0,0.8);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}
.ufo-win-card{position:relative;z-index:1;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:44px 36px;max-width:520px;width:90%;text-align:center;box-shadow:var(--shadow-lg);animation:ufoWinIn 0.5s cubic-bezier(0.175,0.885,0.32,1.275);max-height:90vh;overflow-y:auto}
@keyframes ufoWinIn{0%{transform:scale(0.7) translateY(40px);opacity:0}60%{transform:scale(1.04)}100%{transform:scale(1) translateY(0);opacity:1}}
.ufo-win-close{position:absolute;top:16px;right:16px;background:none;border:none;color:var(--text-muted);font-size:1.4rem;cursor:pointer;width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all 0.2s;border:1px solid var(--border);z-index:2}
.ufo-win-close:hover{border-color:var(--accent);color:var(--accent)}
.ufo-win-badge{display:inline-block;padding:5px 16px;border-radius:50px;background:var(--gradient-1);color:#fff;font-size:0.7rem;font-weight:700;text-transform:uppercase;letter-spacing:0.12em;margin-bottom:12px;font-family:'Space Grotesk',monospace;animation:ufoBadgeGlow 2s ease-in-out infinite}
@keyframes ufoBadgeGlow{0%,100%{box-shadow:0 0 0 0 rgba(124,58,237,0.5)}50%{box-shadow:0 0 20px 6px rgba(124,58,237,0.3)}}
.ufo-win-icon{font-size:3.5rem;margin-bottom:12px;animation:ufoFloat 2s ease-in-out infinite}
@keyframes ufoFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.ufo-win-title{font-family:'Syne',sans-serif;font-size:1.6rem;font-weight:800;margin-bottom:4px;line-height:1.2}
.ufo-win-subtitle{font-family:'Syne',sans-serif;font-size:1.2rem;font-weight:600;color:var(--accent);margin-bottom:8px;line-height:1.2}
.ufo-win-desc{color:var(--text-dim);font-size:0.9rem;margin-bottom:16px;line-height:1.5}
.ufo-win-features{text-align:left;margin-bottom:20px;display:flex;flex-direction:column;gap:6px;background:rgba(124,58,237,0.04);border:1px solid rgba(124,58,237,0.1);border-radius:var(--radius);padding:14px 16px}
.ufo-win-feat{font-size:0.85rem;color:var(--text-dim);display:flex;align-items:center;gap:8px}
.ufo-win-feat span{width:22px;height:22px;border-radius:50%;background:var(--gradient-1);display:flex;align-items:center;justify-content:center;font-size:0.7rem;color:#fff;flex-shrink:0}
.ufo-win-form{margin-top:8px}
.ufo-form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}

/* LIGHT MODE */
[data-theme="light"]{--bg:#f5f6f9;--bg-alt:#ffffff;--bg-card:#ffffff;--bg-card-hover:#f8f9fc;--text:#1a1a2e;--text-dim:#54547a;--text-muted:#9898b0;--border:rgba(0,0,0,0.08);--border-hover:rgba(0,0,0,0.15);--glass:rgba(255,255,255,0.92);--glass-border:rgba(0,0,0,0.08);--shadow-sm:0 2px 8px rgba(0,0,0,0.04);--shadow-md:0 8px 24px rgba(0,0,0,0.06);--shadow-lg:0 20px 60px rgba(0,0,0,0.08);--shadow-glow:0 0 40px rgba(124,58,237,0.08);--logo-color:#1a1a2e;--nav-text:#54547a;--btn-outline-border:rgba(0,0,0,0.2);--btn-outline-text:#1a1a2e}
[data-theme="light"] .navbar{background:rgba(255,255,255,0.9)}
[data-theme="light"] .navbar.scrolled{background:rgba(255,255,255,0.98)}
[data-theme="light"] .hero-badge{background:rgba(255,255,255,0.8);border-color:rgba(0,0,0,0.08)}
[data-theme="light"] .footer{background:#fff;border-color:rgba(0,0,0,0.08)}
[data-theme="light"] .cta-section{background:var(--bg-alt);border-color:rgba(0,0,0,0.08)}
[data-theme="light"] input,[data-theme="light"] select,[data-theme="light"] textarea{background:#f5f6f9;color:var(--text);border-color:rgba(0,0,0,0.12)}
[data-theme="light"] .modal{background:#fff}
[data-theme="light"] .toast{background:#fff}
[data-theme="light"] .darkmode-fixed-btn{box-shadow:0 8px 40px rgba(0,0,0,0.08)}
[data-theme="light"] .darkmode-fixed-btn:hover{box-shadow:0 12px 50px rgba(124,58,237,0.12)}
[data-theme="light"] .hamburger span{background:var(--text)}
[data-theme="light"] .btn-glass{background:rgba(124,58,237,0.06);border-color:rgba(124,58,237,0.12);color:var(--text)}
[data-theme="light"] .footer-col h4{color:#1a1a2e}
[data-theme="light"] .footer-col ul li a{color:#54547a}
[data-theme="light"] .footer-col ul li a:hover{color:var(--accent)}
[data-theme="light"] .value-pill{color:#54547a}
[data-theme="light"] .value-pill:hover{color:var(--accent)}
[data-theme="light"] .cb-message.bot{background:#f5f6f9;color:#1a1a2e}
[data-theme="light"] .fs-menu .fs-link{color:#54547a}
[data-theme="light"] .fs-menu .fs-link:hover{color:#1a1a2e}
[data-theme="light"] .fs-menu .fs-footer{color:#9898b0}
[data-theme="light"] .lang-select-bottom select{background:#fff;box-shadow:0 4px 20px rgba(0,0,0,0.05)}
[data-theme="light"] .contact-item{background:#fff}
[data-theme="light"] .hours-list li{border-color:rgba(0,0,0,0.06)}
[data-theme="light"] .ambient-sound-btn{box-shadow:0 4px 20px rgba(0,0,0,0.05)}
[data-theme="light"] .services-track::-webkit-scrollbar-track{background:#f5f6f9}
[data-theme="light"] .portfolio-showcase::-webkit-scrollbar-track{background:#f5f6f9}
[data-theme="light"] .ufo-win-card{background:#fff;border-color:rgba(0,0,0,0.1)}
[data-theme="light"] .ufo-win-features{background:rgba(124,58,237,0.03);border-color:rgba(124,58,237,0.08)}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media(max-width:1024px){
  .services-grid,.portfolio-grid,.testimonials-grid{grid-template-columns:repeat(2,1fr)}
  .process-steps{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:repeat(2,1fr)}
  .dashboard-grid{grid-template-columns:1fr}.dashboard-sidebar{position:static}
  .about-grid{grid-template-columns:1fr;gap:40px}.about-visual{max-width:380px;margin:0 auto}
  .service-card{min-width:280px;max-width:320px}
  .portfolio-card{min-width:260px;max-width:320px}
}
@media(max-width:768px){
  html{font-size:16px;touch-action:pan-y;max-width:100vw}
  body{overflow-x:hidden;overflow-y:auto;width:100%;max-width:100vw;cursor:auto}
  #three-canvas{pointer-events:auto}
  a,button,.btn,input,select,textarea,.filter-btn,.quiz-option,.portfolio-item,.service-card,.chip-checkbox+label,.review-star,.faq-question{cursor:pointer}
  .cursor-dot,.cursor-ring{display:none}
  .navbar{top:8px;border-radius:30px;padding:0.6rem 1rem;width:calc(100% - 1rem)}
  .nav-logo{font-size:1.2rem}.nav-logo .logo-dot{width:10px;height:10px}
  h1{font-size:2.5rem}h2{font-size:1.8rem}h3{font-size:1.2rem}
  .container{padding:0 1rem}
  .section{padding:50px 0}
  .section-header{margin-bottom:30px}.section-header p{font-size:0.9rem;max-width:100%}.section-badge{font-size:0.65rem}
  .hero{padding-top:80px;min-height:auto;padding-bottom:40px}
  .hero h1{max-width:100%}.hero p{font-size:1rem;max-width:100%}
  .hero-cta{flex-direction:column;align-items:center;gap:10px}.hero-cta .btn{width:100%;max-width:320px;justify-content:center}
  .hero-stats{gap:16px 20px;margin-top:2rem;padding-top:1.5rem}.hero-stat h3{font-size:1.6rem}.hero-stat p{font-size:0.7rem}
  .hero-badge{font-size:0.7rem;padding:4px 14px;margin-bottom:20px}
  .btn{padding:10px 20px;font-size:0.8rem}.btn-lg{padding:14px 28px;font-size:0.95rem}.btn-sm{padding:6px 14px;font-size:0.7rem}
  .footer-grid{grid-template-columns:1fr;gap:24px}.footer{padding:40px 0 16px}.footer-col h4{margin-bottom:12px}.footer-bottom{flex-direction:column;gap:8px;text-align:center}
  .fs-menu .fs-link{font-size:2rem}.fs-menu .fs-social{right:16px;gap:12px}
  .lang-select-bottom{bottom:20px;left:16px}.lang-select-bottom select{padding:8px 28px 8px 12px;font-size:0.7rem}
  .ambient-sound-btn{bottom:85px;left:16px;width:36px;height:36px}
  .chatbot-toggle{width:48px;height:48px}.chatbot-panel{width:calc(100vw - 24px);right:-8px;bottom:62px}
  .darkmode-fixed-btn{width:48px;height:48px;min-width:48px;max-width:48px;padding:0;gap:0;bottom:24px;right:16px;left:auto;transform:none;border-radius:50%;justify-content:center;z-index:999;display:flex;align-items:center}.darkmode-fixed-btn:hover{transform:none!important;box-shadow:0 0 20px rgba(124,58,237,0.4)}.darkmode-fixed-btn .dm-labels{display:none}.darkmode-fixed-btn .dm-icon-wrap{width:42px;height:42px;min-width:42px;max-width:42px}.darkmode-fixed-btn:hover .dm-icon-wrap{transform:none}
  .quiz-container{min-height:350px}.quiz-step h3{font-size:1.2rem}.quiz-step p{font-size:0.85rem}.quiz-option{padding:12px 16px;font-size:0.85rem}.quiz-option .qo-icon{font-size:1.2rem;width:28px}.quiz-option .qo-price{font-size:0.8rem}.quiz-result .total-price{font-size:2.5rem}.total-price{font-size:2rem}
  .cta-section{padding:60px 0}.cta-section h2{font-size:1.8rem}.cta-section p{font-size:0.95rem}
  .page-hero{padding:120px 0 40px}.page-hero h1{font-size:2.2rem}.page-hero p{font-size:0.9rem}
  .devis-wrapper{grid-template-columns:1fr}.devis-form,.devis-resume{padding:24px}.devis-resume{position:static;margin-top:20px}
  .form-row{grid-template-columns:1fr}.form-group{margin-bottom:14px}.form-group label{font-size:0.7rem}.form-group input,.form-group select,.form-group textarea{padding:10px 14px;font-size:0.85rem}
  .contact-grid{grid-template-columns:1fr;gap:24px}.contact-items{gap:12px;margin-top:20px}.contact-item .ci-icon{width:40px;height:40px;border-radius:10px;font-size:1.1rem}.contact-item h4{font-size:0.85rem}.contact-item p{font-size:0.75rem}.contact-form{padding:24px}
  .dashboard-grid{grid-template-columns:1fr}.dashboard-sidebar{position:static;margin-bottom:16px}.user-avatar{width:48px;height:48px;font-size:1.2rem}.dashboard-nav li a{font-size:0.8rem;padding:8px 14px}.dashboard-card{padding:16px}.project-item-db{padding:10px;flex-direction:column;align-items:flex-start;gap:8px}
  .ufo-win-card{padding:28px 20px;width:94%}
  .ufo-win-title{font-size:1.3rem}
  .ufo-win-subtitle{font-size:1rem}
  .ufo-form-row{grid-template-columns:1fr}

  /* --- SERVICES (mobile) --- */
  .services-grid{display:flex;flex-wrap:nowrap;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;gap:14px;padding:8px 16px 16px}
  .services-grid .service-card{flex:0 0 85vw;max-width:85vw;scroll-snap-align:center;padding:28px 24px;min-width:auto;max-width:none;border-width:1.5px;box-shadow:0 4px 20px rgba(0,0,0,0.25);transition:all 0.3s}
  .services-grid .service-card:active{transform:scale(0.97);border-color:var(--accent)}
  .services-grid .service-card .sc-icon{width:48px;height:48px;font-size:1.5rem;border-radius:14px;background:rgba(124,58,237,0.12)}

  /* --- PROCESS CAROUSEL (mobile) --- */
  .process-timeline{overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding:12px 0 20px}
  .process-line{display:none}
  .process-steps{display:flex;flex-wrap:nowrap;gap:14px;padding:0 16px}
  .process-step{flex:0 0 85vw;max-width:85vw;scroll-snap-align:center;padding:0;gap:12px}
  .process-step .ps-dot{width:52px;height:52px;font-size:1.1rem;flex-shrink:0}
  .process-step .ps-card{box-shadow:0 8px 30px rgba(0,0,0,0.35);border-width:1.5px;padding:20px 18px}
  .process-step h3{font-size:1rem}
  .process-step p{font-size:0.8rem}

  /* --- PORTFOLIO CAROUSEL (mobile) --- */
  .portfolio-grid-home{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;gap:14px;padding:8px 16px 16px}
  .portfolio-grid-home .portfolio-item-home{flex:0 0 84vw;max-width:84vw;scroll-snap-align:center;margin:0;border-width:1.5px;box-shadow:0 8px 25px rgba(0,0,0,0.3)}
  .portfolio-item-home h4{font-size:1.1rem}
  .portfolio-item-home p{font-size:0.82rem}
  .portfolio-card{min-width:75vw;max-width:75vw}
  .portfolio-filter{flex-wrap:wrap;gap:6px}.filter-btn{padding:6px 14px;font-size:0.75rem}
  .portfolio-item{aspect-ratio:4/3}.portfolio-item .pi-media{font-size:2rem}.pi-overlay{padding:16px}.pi-overlay h4{font-size:1rem}.pi-overlay span{font-size:0.75rem}

  /* --- TESTIMONIALS CAROUSEL (mobile) --- */
  .testimonials-grid{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;gap:12px;padding:8px 16px 16px}
  .testimonials-grid .testimonial-card{flex:0 0 85vw;max-width:85vw;scroll-snap-align:center;margin:0;border-width:1.5px;box-shadow:0 6px 20px rgba(0,0,0,0.25);padding:24px}
  .testimonial-card .tt-text{font-size:0.85rem}.tt-author h4{font-size:0.85rem}.tt-author p{font-size:0.7rem}

  /* --- FAQ INTERACTIVE (mobile) --- */
  .faq-theme-header .ft-icon{display:none}
  .faq-theme-header h3{font-size:1.1rem}
  .faq-themes{grid-template-columns:1fr;gap:16px}
  .faq-theme{padding:24px 20px;border-width:1.5px}
  .faq-item{border-width:1.5px}
  .faq-item:active{transform:scale(0.97);border-color:var(--accent)}
  .faq-question{padding:14px 16px;font-size:0.9rem}

  /* --- ABOUT (mobile) --- */
  .about-grid-new{grid-template-columns:1fr;gap:28px}
  .about-visual-new{max-width:280px;margin:0 auto;font-size:4rem}
  .about-content-new h2{font-size:1.6rem}
  .about-point{font-size:0.85rem;padding:6px 0}
  .about-points{gap:4px;margin:14px 0}
  .value-pill{padding:10px 14px;font-size:0.85rem}
  .value-pill:active{transform:scale(0.95);border-color:var(--accent)}
  .about-grid{grid-template-columns:1fr;gap:30px}.about-visual{max-width:320px;margin:0 auto;font-size:5rem}.about-badge{padding:12px 18px;bottom:-12px;right:-12px}.about-badge .badge-num{font-size:1.6rem}.about-badge .badge-label{font-size:0.65rem}.values-grid{gap:6px}.value-pill{padding:8px 12px;font-size:0.8rem}
}