/* ============================================
   GENICON AI - Matching live genicon.ai design
   ============================================ */
:root {
  --primary: #70B4AF;
  --secondary: #EE704A;
  --text: #292929;
  --bg: #FFFFFF;
  --surface: #F6F8FB;
  --stroke: #0000000D;
  --muted: #000000B3;
  --font-head: 'Instrument Sans', sans-serif;
  --font-body: 'Rubik', sans-serif;
  --font-accent: 'Caveat', cursive;
  --abr-ok: #56f39a;
  --abr-glow: 0 0 18px rgba(74,163,255,.45), 0 0 42px rgba(65,230,201,.22);
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; -webkit-font-smoothing:antialiased; }
body { font-family:var(--font-body); font-size:18px; font-weight:400; line-height:1.5; letter-spacing:.01em; color:var(--text); background:var(--bg); overflow-x:hidden; }
img { max-width:100%; height:auto; display:block; }
a { text-decoration:none; color:inherit; }
ul { list-style:none; }
button { border:none; background:none; cursor:pointer; font-family:inherit; color:inherit; }
.container { max-width:1120px; margin:0 auto; padding:0 20px; }

/* ===== PRELOADER ===== */
.preloader { position:fixed; inset:0; background:#fff; display:flex; align-items:center; justify-content:center; z-index:99999; transition:opacity .5s,visibility .5s; }
.preloader.hidden { opacity:0; visibility:hidden; }
.spinner { width:36px; height:36px; border:3px solid #eee; border-top-color:var(--text); border-radius:50%; animation:spin .7s linear infinite; }
@keyframes spin { to { transform:rotate(360deg); } }

/* ===== GDPR ===== */
.gdpr-banner { position:fixed; bottom:20px; left:50%; transform:translateX(-50%); z-index:9999; background:var(--text); color:#fff; padding:14px 24px; border-radius:12px; display:flex; align-items:center; gap:16px; font-size:14px; box-shadow:0 10px 40px rgba(0,0,0,.2); transition:opacity .3s,transform .3s; }
.gdpr-banner.hidden { opacity:0; transform:translateX(-50%) translateY(20px); pointer-events:none; }
.gdpr-accept { background:#fff; color:var(--text); padding:8px 20px; border-radius:8px; font-weight:500; font-size:13px; }

/* ===== HEADER ===== */
.site-header { position:fixed; top:0; left:0; width:100%; z-index:1000; transition:background .3s; }
.site-header.scrolled { background:rgba(255,255,255,.92); backdrop-filter:blur(12px); box-shadow:0 1px 0 rgba(0,0,0,.05); }
.site-header.scrolled .header-topbar { height:0; padding:0; overflow:hidden; opacity:0; }
.header-topbar { transition:all .3s; }
.topbar-inner { display:flex; align-items:center; justify-content:center; gap:10px; padding:10px 0; font-size:12px; }
.pill-badge { font-size:12px; padding:3px 12px; border:1px solid #29292912; border-radius:100px; }
.topbar-text { color:rgba(41,41,41,.5); }
.header-main { padding:25px 0; }
.header-row { display:flex; align-items:center; justify-content:space-between; }
.header-left { display:flex; align-items:center; gap:14px; width:25%; }
.drawer-trigger { width:50px; height:50px; border-radius:50%; border:1px solid rgba(0,0,0,.08); display:flex; align-items:center; justify-content:center; transition:all .25s; }
.drawer-trigger:hover { background:var(--text); color:#fff; border-color:var(--text); }
.logo img { height:28px; }
.header-nav { width:50%; display:flex; justify-content:center; }
.header-nav ul { display:flex; gap:0; }
.header-nav a { font-size:14px; font-weight:500; text-transform:capitalize; padding:10px 20px; border-radius:100px; transition:all .25s; color:var(--text); }
.header-nav a:hover, .header-nav a.active { background:rgba(41,41,41,.06); }
.header-nav:hover a:not(:hover) { opacity:.4; }
.logo-sticky { display:none; }
.header-right { width:25%; display:flex; justify-content:flex-end; }
.mobile-trigger { display:none; flex-direction:column; gap:5px; width:26px; }
.mobile-trigger span { height:2px; background:var(--text); border-radius:2px; transition:.25s; }
.mobile-trigger.active span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.mobile-trigger.active span:nth-child(2) { opacity:0; }
.mobile-trigger.active span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }
.mobile-menu { position:fixed; inset:0; background:#fff; z-index:999; display:flex; align-items:center; justify-content:center; opacity:0; visibility:hidden; transition:.3s; }
.mobile-menu.active { opacity:1; visibility:visible; }
.mobile-menu a { font-family:var(--font-head); font-size:32px; font-weight:600; display:block; margin:16px 0; }

/* ===== FLOATING BOTTOM NAV ===== */
.floating-nav { position:fixed; bottom:40px; left:50%; transform:translateX(-50%); z-index:99; background:#15161A99; backdrop-filter:blur(8.5px); padding:10px 12px; border-radius:100px; display:flex; gap:4px; opacity:0; visibility:hidden; transition:all .4s; }
.floating-nav.visible { opacity:1; visibility:visible; }
.floating-nav a { font-size:14px; font-weight:500; color:rgba(255,255,255,.6); padding:8px 18px; border-radius:100px; transition:all .25s; white-space:nowrap; }
.floating-nav a:hover, .floating-nav a.active { color:rgba(255,255,255,.9); background:rgba(255,255,255,.2); }

/* ===== HERO ===== */
.hero { position:relative; padding:50px 20px 0; }
.hero-bg { position:absolute; top:0; left:0; right:0; min-height:100%; z-index:0; overflow:hidden; opacity:.6; }
.hero-bg-img { width:100%; height:100%; object-fit:cover; }
.hero-card { position:relative; z-index:1; max-width:1120px; margin:0 auto; }
.hero-card-inner { background:#fff; border-radius:40px; padding:210px 70px 270px; position:relative; overflow:hidden; }
.hero-content { display:flex; align-items:center; justify-content:space-between; gap:40px; }
.hero-text { flex:0 0 50%; }
.hero-text h1 { font-family:var(--font-head); font-size:48px; font-weight:600; line-height:1.05; letter-spacing:-.03em; margin-bottom:20px; }
.hero-text p { color:rgba(41,41,41,.6); margin-bottom:28px; line-height:1.6; }
.hero-btns { display:flex; align-items:center; gap:20px; flex-wrap:wrap; }
.hero-visual { flex:0 0 42%; display:flex; justify-content:flex-end; }

/* ===== BUTTONS ===== */
.btn-solid { display:inline-block; padding:15px 35px; background:var(--text); color:#fff; border-radius:8px; font-size:16px; font-weight:500; transition:all .3s; }
.btn-solid:hover { background:linear-gradient(90deg, var(--primary), var(--secondary)); }
.btn-line { position:relative; font-size:16px; font-weight:500; padding-bottom:2px; }
.btn-line::after { content:''; position:absolute; bottom:0; left:0; width:100%; height:1px; background:currentColor; transition:transform .3s; transform-origin:left; }
.btn-line:hover::after { transform:scaleX(0); transform-origin:right; }
.btn-naked { display:inline-flex; align-items:center; gap:12px; font-weight:500; }
.btn-circle { width:42px; height:42px; border-radius:50%; border:1px solid rgba(0,0,0,.08); display:inline-flex; align-items:center; justify-content:center; transition:all .25s; }
.btn-naked:hover .btn-circle { background:var(--secondary); border-color:var(--secondary); color:#fff; }
.gradient-label { display:inline-block; font-size:19px; font-weight:500; line-height:1.2; letter-spacing:-.01em; background:linear-gradient(90deg, var(--primary), var(--secondary)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; margin-bottom:12px; }

/* ===== GLASSMORPHIC CARD SYSTEM ===== */
.glass-card { border-radius:18px; position:relative; overflow:hidden; background:radial-gradient(120% 90% at 18% 8%, rgba(74,163,255,.16), transparent 55%), radial-gradient(120% 90% at 82% 18%, rgba(65,230,201,.10), transparent 60%), linear-gradient(180deg, rgba(255,255,255,.92), rgba(246,248,252,.90)); border:1px solid rgba(0,0,0,.08); box-shadow:0 22px 65px rgba(0,0,0,.22), 0 8px 18px rgba(0,0,0,.10), inset 0 1px 0 rgba(255,255,255,.85), inset 0 0 0 1px rgba(255,255,255,.35); transition:transform .25s, box-shadow .25s; }
.glass-card:hover { transform:translateY(-3px) rotateX(1.1deg); }
.glass-rim { pointer-events:none; position:absolute; inset:0; border-radius:18px; background:linear-gradient(180deg, rgba(255,255,255,.75), transparent 40%), linear-gradient(90deg, rgba(255,255,255,.35), transparent 25%, transparent 75%, rgba(255,255,255,.28)); mix-blend-mode:screen; opacity:.55; }

/* LEFT CARD */
.abrL-wrap { width:100%; max-width:460px; font-family:ui-sans-serif,system-ui,-apple-system,sans-serif; perspective:900px; }
.abrL-card { border-radius:18px; position:relative; overflow:hidden; background:radial-gradient(120% 90% at 18% 8%, rgba(74,163,255,.16), transparent 55%), radial-gradient(120% 90% at 82% 18%, rgba(65,230,201,.10), transparent 60%), linear-gradient(180deg, rgba(255,255,255,.92), rgba(246,248,252,.90)); border:1px solid rgba(0,0,0,.08); box-shadow:0 22px 65px rgba(0,0,0,.22), 0 8px 18px rgba(0,0,0,.10), inset 0 1px 0 rgba(255,255,255,.85); transition:transform .25s; }
.abrL-card:hover { transform:translateY(-3px) rotateX(1.1deg); }
.abrL-cardHeader { display:flex; align-items:center; justify-content:space-between; padding:14px; border-bottom:1px solid rgba(0,0,0,.06); background:linear-gradient(180deg, rgba(0,0,0,.03), transparent); }
.abrL-title { display:flex; align-items:center; gap:8px; font-weight:700; font-size:13px; }
.abrL-titleDot { width:10px; height:10px; border-radius:3px; background:linear-gradient(180deg, rgba(65,230,201,.95), rgba(74,163,255,.85)); box-shadow:var(--abr-glow); }
.abrL-pill { font-size:11px; padding:5px 10px; border-radius:999px; border:1px solid rgba(0,0,0,.10); background:rgba(255,255,255,.60); display:flex; align-items:center; gap:6px; }
.abrL-dot { width:7px; height:7px; border-radius:50%; background:var(--abr-ok); box-shadow:0 0 12px rgba(86,243,154,.55); animation:blink 1.6s infinite; }
@keyframes blink { 0%,100%{opacity:.55;transform:scale(.95)} 50%{opacity:1;transform:scale(1.15)} }
.abrL-content { padding:14px; display:flex; flex-direction:column; gap:8px; }
.abrL-row { display:flex; align-items:center; justify-content:space-between; padding:10px 12px; border-radius:12px; border:1px solid rgba(0,0,0,.08); background:linear-gradient(180deg, rgba(255,255,255,.78), rgba(255,255,255,.58)); box-shadow:0 12px 20px rgba(0,0,0,.08), inset 0 1px 0 rgba(255,255,255,.85); }
.abrL-label { display:flex; align-items:center; gap:8px; font-size:12px; font-weight:500; }
.abrL-badge { font-size:11px; padding:3px 8px; border-radius:999px; font-weight:800; background:linear-gradient(90deg, rgba(74,163,255,.95), rgba(65,230,201,.95)); box-shadow:var(--abr-glow); }
.abrL-sub { color:rgba(0,0,0,.55); font-size:11px; line-height:1.3; padding:0 4px; margin-top:-4px; }
.abrL-chat { padding-top:10px; }
.abrL-msg { display:flex; gap:8px; }
.abrL-avatar { width:26px; height:26px; border-radius:8px; background:linear-gradient(135deg, rgba(74,163,255,.95), rgba(65,230,201,.88)); box-shadow:var(--abr-glow); flex-shrink:0; }
.abrL-bubble { flex:1; border-radius:12px; padding:8px 10px; background:rgba(255,255,255,.60); border:1px solid rgba(0,0,0,.08); font-size:12px; }
.typing-cursor { animation:blink-cursor 1s step-end infinite; }
@keyframes blink-cursor { 0%,100%{opacity:1} 50%{opacity:0} }
.abrL-kbd { margin-top:8px; display:flex; gap:6px; flex-wrap:wrap; }
.abrL-chip { font-size:11px; padding:5px 8px; border-radius:999px; border:1px solid rgba(0,0,0,.10); background:rgba(255,255,255,.55); cursor:pointer; transition:.2s; }
.abrL-chip:hover { background:rgba(74,163,255,.12); }

/* CENTER PIPELINE CARD */
.abrC-wrap { width:100%; max-width:420px; font-family:ui-sans-serif,system-ui,sans-serif; perspective:900px; }
.abrC-card { border-radius:18px; position:relative; overflow:hidden; background:radial-gradient(120% 90% at 18% 8%, rgba(74,163,255,.16), transparent 55%), radial-gradient(120% 90% at 82% 18%, rgba(65,230,201,.10), transparent 60%), linear-gradient(180deg, rgba(255,255,255,.92), rgba(246,248,252,.90)); border:1px solid rgba(0,0,0,.08); box-shadow:0 22px 65px rgba(0,0,0,.22), 0 8px 18px rgba(0,0,0,.10), inset 0 1px 0 rgba(255,255,255,.85); transition:transform .25s; }
.abrC-card:hover { transform:translateY(-3px) rotateX(1.1deg); }
.abrC-pipeWrap { display:grid; place-items:center; position:relative; padding:10px; background:radial-gradient(520px 240px at 50% 30%, rgba(74,163,255,.12), transparent 56%); }
.abrC-pipeWrap svg { width:100%; height:auto; display:block; color:#000; }
.abrC-note { position:absolute; bottom:14px; left:14px; right:14px; color:rgba(0,0,0,.55); font-size:11px; line-height:1.35; }

/* ===== MISSION + ACCORDION ===== */
.mission-section { margin-top:-130px; position:relative; z-index:2; }
.mission-row { display:flex; justify-content:space-between; align-items:flex-start; padding:208px 20px 180px; gap:40px; }
.mission-text { width:38%; }
.mission-text h2 { font-family:var(--font-head); font-size:46px; font-weight:600; letter-spacing:-.02em; line-height:.9; margin-bottom:20px; }
.mission-text p { color:rgba(41,41,41,.6); margin-bottom:24px; font-size:16px; line-height:1.6; }
.mission-accordion { width:50%; }

/* ACCORDION */
.accordion { display:flex; flex-direction:column; gap:15px; }
.acc-item { backdrop-filter:blur(2.9px); border-radius:14px; overflow:hidden; }
.acc-trigger { width:100%; display:flex; align-items:center; justify-content:space-between; padding:28px 30px; border:2px solid #00000012; border-radius:14px; font-size:18px; font-weight:500; font-family:var(--font-body); text-align:left; transition:all .3s; background:transparent; }
.acc-trigger span:first-child { flex:1; }
.acc-icon { font-size:24px; font-weight:300; width:26px; height:26px; display:flex; align-items:center; justify-content:center; transition:transform .3s; }
.acc-item.active .acc-trigger { background:#fff; border-color:#fff; box-shadow:0 6px 30px rgba(0,0,0,.08); }
.acc-item.active .acc-icon { transform:rotate(45deg); }
.acc-body { max-height:0; overflow:hidden; transition:max-height .4s ease; }
.acc-item.active .acc-body { max-height:400px; }
.acc-body > * { padding:0 30px 24px; }
.acc-body p { font-size:15px; color:rgba(41,41,41,.7); line-height:1.6; margin-bottom:12px; }
.acc-body ul { padding-left:20px; }
.acc-body li { font-size:14px; color:rgba(41,41,41,.6); line-height:1.8; list-style:disc; }

/* ===== STATS ===== */
.stats-section { padding:72px 0 0; }
.stats-row { display:flex; gap:0; }
.stats-text { width:50%; }
.stats-text h2 { font-family:var(--font-head); font-size:46px; font-weight:600; letter-spacing:-.02em; line-height:.9; margin-bottom:20px; }
.stats-text > p { color:rgba(41,41,41,.6); margin-bottom:20px; line-height:1.6; }
.stats-card { width:50%; padding-left:75px; display:flex; align-items:center; }
.client-list { font-size:15px; margin-top:16px; }
.client-list strong { display:block; margin-bottom:6px; }
.client-list li { color:rgba(41,41,41,.6); padding:2px 0; }

/* ===== ICON BOXES ===== */
.icons-section { padding:150px 20px 70px; }
.icons-row { display:flex; justify-content:center; gap:10px; flex-wrap:wrap; }
.icon-box { width:14%; background:var(--surface); padding:30px; border-radius:10px; text-align:center; transition:all .3s; cursor:default; }
.icon-box-icon { width:50px; height:50px; margin:0 auto 10px; color:#8EA4AF; transition:color .3s; display:flex; align-items:center; justify-content:center; }
.icon-box-icon svg { width:100%; height:100%; }
.icon-box span { font-size:14px; font-weight:500; text-transform:capitalize; color:#596D74; transition:color .3s; display:block; }
.icon-box:hover { transform:scale(1.05); }
.icon-box:hover .icon-box-icon { color:var(--hover-color); }
.icon-box:hover span { color:var(--hover-color); }
.icon-box:hover { background:color-mix(in srgb, var(--hover-color) 15%, white); }

/* ===== TRANSFORM / CURTAIN ===== */
.transform-section { padding:135px 20px; }
.transform-header { text-align:center; max-width:600px; margin:0 auto 80px; }
.transform-header h2 { font-family:var(--font-head); font-size:46px; font-weight:600; letter-spacing:-.02em; margin-bottom:16px; }
.transform-header p { color:rgba(41,41,41,.6); font-size:16px; }
.curtain-panels { display:flex; flex-direction:column; gap:20px; }
.curtain-item { border-radius:12px; overflow:hidden; backdrop-filter:blur(50px); background:var(--curtain-bg); }
.curtain-trigger { width:100%; display:flex; align-items:center; justify-content:space-between; padding:35px 45px; text-align:left; }
.curtain-trigger h4 { font-family:var(--font-head); font-size:22px; font-weight:600; }
.curtain-arrow { font-size:28px; transition:transform .3s; }
.curtain-item.active .curtain-arrow { transform:rotate(90deg); }
.curtain-body { max-height:0; overflow:hidden; transition:max-height .5s ease; }
.curtain-item.active .curtain-body { max-height:600px; }
.curtain-body-inner { display:flex; gap:40px; padding:0 60px 50px; align-items:flex-start; }
.curtain-text { flex:1; }
.curtain-text h3 { font-family:var(--font-head); font-size:32px; font-weight:600; margin-bottom:14px; }
.curtain-text p { font-size:15px; color:rgba(0,0,0,.6); line-height:1.6; margin-bottom:16px; }
.curtain-text ul { padding-left:18px; }
.curtain-text li { font-size:15px; color:rgba(0,0,0,.6); line-height:1.8; list-style:disc; }
.curtain-pills { display:flex; flex-wrap:wrap; gap:8px; }
.curtain-pills span { background:var(--stroke); padding:10px 16px; border-radius:100px; font-size:15px; }
.curtain-visual { width:38%; flex-shrink:0; }
.curtain-visual img { width:100%; border-radius:16px; }

/* ===== TECH CARD ===== */
.tech-section { padding:80px 0; }
.tech-wrap { max-width:980px; margin:0 auto; perspective:900px; padding:10px; font-family:ui-sans-serif,system-ui,sans-serif; }
.tech-card { border-radius:18px; position:relative; overflow:hidden; background:radial-gradient(120% 90% at 18% 8%, rgba(74,163,255,.16), transparent 55%), radial-gradient(120% 90% at 82% 18%, rgba(65,230,201,.10), transparent 60%), linear-gradient(180deg, rgba(255,255,255,.92), rgba(246,248,252,.90)); border:1px solid rgba(0,0,0,.08); box-shadow:0 22px 65px rgba(0,0,0,.22), 0 8px 18px rgba(0,0,0,.10), inset 0 1px 0 rgba(255,255,255,.85); }
.tech-header { display:flex; align-items:center; justify-content:space-between; padding:14px; border-bottom:1px solid rgba(0,0,0,.06); background:linear-gradient(180deg, rgba(0,0,0,.03), transparent); }
.tech-title { display:flex; align-items:center; gap:8px; font-weight:700; font-size:14px; }
.tech-dot { width:10px; height:10px; border-radius:3px; background:linear-gradient(180deg, rgba(65,230,201,.95), rgba(74,163,255,.85)); box-shadow:var(--abr-glow); }
.tech-pill { font-size:12px; padding:6px 10px; border-radius:999px; border:1px solid rgba(0,0,0,.10); background:rgba(255,255,255,.60); display:flex; align-items:center; gap:6px; }
.tech-live { width:8px; height:8px; border-radius:50%; background:var(--abr-ok); box-shadow:0 0 12px rgba(86,243,154,.55); animation:blink 1.6s infinite; }
.tech-body { padding:16px; }
.tech-sub { color:rgba(0,0,0,.55); font-size:13px; line-height:1.5; margin-bottom:16px; }
.tech-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.tech-item { display:flex; gap:10px; padding:12px; border-radius:14px; border:1px solid rgba(0,0,0,.08); background:linear-gradient(180deg, rgba(255,255,255,.78), rgba(255,255,255,.58)); box-shadow:0 12px 20px rgba(0,0,0,.08), inset 0 1px 0 rgba(255,255,255,.85); transition:.2s; }
.tech-item:hover { background:rgba(255,255,255,.85); box-shadow:0 8px 20px rgba(0,0,0,.06); }
.tech-wide { grid-column:span 2; }
.tech-ico { width:34px; height:34px; border-radius:12px; background:radial-gradient(circle at 30% 25%, rgba(255,255,255,.70), transparent 55%), linear-gradient(135deg, rgba(74,163,255,.95), rgba(65,230,201,.88)); color:#04121f; display:flex; align-items:center; justify-content:center; font-size:11px; font-weight:900; flex-shrink:0; box-shadow:var(--abr-glow); }
.tech-name { font-size:13px; font-weight:700; margin-bottom:2px; }
.tech-desc { font-size:11px; color:rgba(0,0,0,.55); line-height:1.35; }
.tech-footer { padding:14px 16px; border-top:1px solid rgba(0,0,0,.06); display:flex; align-items:center; justify-content:space-between; gap:12px; }
.tech-footnote { font-size:11px; color:rgba(0,0,0,.55); flex:1; }
.tech-metrics { display:flex; gap:12px; }
.tech-metrics span { display:flex; align-items:center; gap:5px; font-size:12px; font-weight:600; }
.tech-metrics i { width:6px; height:6px; border-radius:50%; background:linear-gradient(135deg, rgba(74,163,255,.95), rgba(65,230,201,.88)); display:inline-block; }

/* ===== MARQUEE ===== */
.marquee-section { padding:34px 0 40px; overflow:hidden; }
.marquee-row { overflow:hidden; }
.marquee-track { display:flex; width:max-content; }
.marquee-track .marquee-slide { display:flex; gap:40px; padding:0 20px; flex-shrink:0; }
.marquee-large .marquee-track { animation:marqueeL 25s linear infinite; }
.marquee-large span { font-family:var(--font-head); font-size:clamp(48px,14vw,172px); font-weight:500; white-space:nowrap; }
.marquee-small { margin-top:10px; }
.marquee-small .marquee-track { animation:marqueeR 20s linear infinite; }
.marquee-small span { font-size:20px; font-weight:400; white-space:nowrap; -webkit-text-stroke:1px var(--text); color:transparent; padding:8px 20px; background:#fff; border-radius:8px; }
@keyframes marqueeL { from{transform:translateX(0)} to{transform:translateX(-50%)} }
@keyframes marqueeR { from{transform:translateX(-50%)} to{transform:translateX(0)} }

/* ===== THROWABLE TAGS ===== */
.throwable-section { padding:0; }
.throwable-scene { position:relative; height:35vh; min-height:280px; overflow:hidden; }
.throw-tag { position:absolute; left:var(--tx); top:var(--ty); background:var(--surface); color:var(--text); border-radius:7em; padding:1em 2.25em; font-size:14px; white-space:nowrap; animation:floatTag 5s ease-in-out infinite; animation-delay:calc(var(--ty,0) * .02s); }
@keyframes floatTag { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-12px)} }

/* ===== PORTFOLIO STACKED CARDS ===== */
.portfolio-section { padding:130px 0; background:linear-gradient(180deg, #DFEBFF, #DEA9FF); }
.portfolio-header { text-align:center; max-width:45%; margin:0 auto 110px; }
.portfolio-header h2 { font-family:var(--font-head); font-size:46px; font-weight:600; margin-bottom:16px; }
.portfolio-header p { color:rgba(41,41,41,.6); }
.portfolio-stack { display:flex; flex-direction:column; gap:110px; }
.stack-card { position:sticky; min-height:700px; border-radius:30px; background:var(--card-bg); overflow:hidden; display:flex; flex-direction:column; }
.stack-card-bar { border-radius:30px 30px 0 0; background:var(--bar-bg); padding:15px 35px; display:flex; align-items:center; justify-content:space-between; }
.stack-card-bar h5 { font-family:var(--font-head); font-size:18px; font-weight:600; }
.stack-card-bar p { font-size:14px; opacity:.7; max-width:400px; }
.stack-card-img { flex:1; display:flex; align-items:center; justify-content:center; padding:40px; }
.stack-card-img img { max-height:500px; object-fit:contain; border-radius:16px; }

/* ===== LOGOS CAROUSEL ===== */
.logos-section { padding:50px 0; overflow:hidden; }
.logos-track { display:flex; width:max-content; animation:logosScroll 20s linear infinite; }
.logos-slide { display:flex; align-items:center; gap:60px; padding:0 30px; flex-shrink:0; }
.logos-slide img { height:50px; width:auto; max-width:140px; object-fit:contain; opacity:.5; filter:grayscale(100%); transition:.3s; }
.logos-slide img:hover { opacity:1; filter:none; }
@keyframes logosScroll { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ===== CTA ===== */
.cta-section { padding:10px 0 30px; }
.cta-card { min-height:500px; display:flex; align-items:stretch; border-radius:30px; overflow:hidden; background:url('../assets/img/cta-bg.svg') center/contain no-repeat var(--surface); padding:0 75px; }
.cta-left { width:40%; display:flex; flex-direction:column; justify-content:center; gap:20px; padding:60px 0; }
.cta-left h2 { font-family:var(--font-head); font-size:46px; font-weight:600; letter-spacing:-.02em; }
.cta-left p { color:rgba(41,41,41,.6); }
.cta-right { width:40%; margin-left:auto; display:flex; align-items:flex-end; justify-content:flex-end; padding-bottom:40px; }
.cta-words { display:flex; flex-direction:column; align-items:flex-end; gap:6px; }
.cta-words span { font-family:var(--font-head); font-size:36px; font-weight:600; color:#361B5C12; transition:all .4s; line-height:1.5; }
.cta-words span.active { background:linear-gradient(90deg, #361B5C, #6693A7); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }

/* ===== CONNECTED ===== */
.connected-section { padding:70px 0 40px; }
.connected-inner { display:flex; flex-direction:column; align-items:center; }
.connected-inner h4 { font-family:var(--font-head); font-size:22px; margin-bottom:16px; }
.connected-row { display:flex; align-items:center; gap:20px; }
.connected-row p { color:rgba(41,41,41,.5); font-size:15px; }
.email-link { display:flex; align-items:center; gap:10px; font-weight:600; font-size:18px; color:#476D83; transition:color .3s; }
.email-link:hover { color:var(--secondary); }

/* ===== FOOTER ===== */
.site-footer { background:linear-gradient(180deg, #FFE6E6, #E9E5FF); padding:90px 0 0; position:relative; overflow:hidden; border-top:1px solid #FFFFFF0D; }
.footer-deco { position:absolute; bottom:-220px; left:50%; transform:translateX(-50%); width:60%; filter:blur(60px); opacity:.5; pointer-events:none; }
.footer-main { display:flex; justify-content:space-between; align-items:flex-start; padding-bottom:85px; position:relative; z-index:1; gap:40px; }
.footer-brand { width:15%; }
.footer-brand img { height:28px; margin-bottom:20px; }
.footer-brand p { font-size:14px; color:var(--muted); line-height:1.6; }
.footer-links { }
.footer-label { display:inline-block; font-size:13px; padding:4px 15px; border:1px solid var(--stroke); border-radius:50px; margin-bottom:20px; background:linear-gradient(90deg, var(--primary), var(--secondary)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.footer-links ul { display:flex; flex-direction:column; gap:12px; }
.footer-links a { font-size:18px; color:var(--muted); transition:color .25s; }
.footer-links a:hover { color:var(--text); }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; padding-bottom:135px; position:relative; z-index:1; }
.footer-bottom p { font-size:12px; color:#00000080; width:66%; }
.footer-bottom span { font-size:14px; color:#00000080; text-transform:capitalize; }

/* ===== SCROLL ANIMATIONS ===== */
[data-animate] { opacity:0; transform:translateY(30px); transition:opacity 1s cubic-bezier(.16,1,.3,1), transform 1s cubic-bezier(.16,1,.3,1); }
[data-animate].visible { opacity:1; transform:translateY(0); }

/* ===== RESPONSIVE ===== */
@media (max-width:1200px) {
  .header-nav, .drawer-trigger { display:none; }
  .mobile-trigger { display:flex; }
  .header-left { width:auto; }
  .header-right { width:auto; }
  .floating-nav { display:none !important; }
}
@media (max-width:1024px) {
  .hero-card-inner { padding:120px 40px 180px; }
  .hero-content { flex-direction:column; }
  .hero-text { flex:none; width:100%; }
  .hero-visual { flex:none; width:100%; justify-content:center; margin-top:40px; }
  .mission-row { flex-direction:column; padding:100px 20px; }
  .mission-text, .mission-accordion { width:100%; }
  .stats-row { flex-direction:column; }
  .stats-text, .stats-card { width:100%; padding:0; }
  .stats-card { margin-top:40px; display:flex; justify-content:center; }
  .icons-row { gap:20px; }
  .icon-box { width:22%; }
  .curtain-body-inner { flex-direction:column; }
  .curtain-visual { width:100%; }
  .portfolio-header { max-width:75%; }
  .stack-card { min-height:500px; }
  .cta-card { flex-direction:column; padding:40px; min-height:auto; }
  .cta-left, .cta-right { width:100%; }
  .cta-right { margin:0; }
  .cta-words { flex-direction:row; flex-wrap:wrap; align-items:flex-start; }
  .cta-words span { font-size:24px; }
  .tech-grid { grid-template-columns:1fr; }
  .tech-wide { grid-column:auto; }
  .footer-brand { width:35%; }
}
@media (max-width:768px) {
  .hero-text h1 { font-size:36px; }
  .hero-card-inner { padding:100px 24px 140px; border-radius:24px; }
  .mission-row { padding:60px 0; }
  .acc-trigger { padding:20px; font-size:16px; }
  .icons-section { padding:90px 20px 50px; }
  .icon-box { width:45%; }
  .transform-section { padding:80px 20px; }
  .curtain-trigger { padding:20px 24px; }
  .curtain-body-inner { padding:0 24px 30px; }
  .portfolio-section { padding:80px 0; }
  .portfolio-header { max-width:90%; margin-bottom:60px; }
  .portfolio-stack { gap:60px; }
  .stack-card { min-height:40vh; position:relative !important; top:0 !important; }
  .footer-main { flex-direction:column; }
  .footer-brand { width:100%; }
  .footer-bottom { padding-bottom:60px; flex-direction:column; gap:12px; }
  .footer-bottom p { width:100%; }
  h2 { font-size:36px !important; }
}
@media (max-width:480px) {
  .icon-box { width:100%; }
  .marquee-large span { font-size:36px; }
}
