/* ============================================================
   LATYNRAI CREATIVES PVT. LTD.
   Clean & Minimal — Modern SaaS Aesthetic
   ============================================================ */

:root {
  --dark:         #111827;
  --dark-alt:     #1f2937;
  --dark-card:    #1f2937;
  --dark-border:  rgba(255,255,255,.1);
  --dark-text:    #e5e7eb;
  --dark-muted:   #9ca3af;

  --light:        #fafafa;
  --light-alt:    #ffffff;
  --light-card:   #ffffff;
  --light-elevated: #f3f4f6;
  --light-border: #e5e7eb;
  --light-border-hover: #d1d5db;
  --light-text:   #111827;
  --light-text2:  #374151;
  --light-muted:  #6b7280;
  --light-dim:    #9ca3af;

  --white:        #ffffff;
  --accent:       #6366f1;
  --accent2:      #818cf8;
  --accent3:      #06b6d4;
  --accent-glow:  rgba(99,102,241,.18);

  --gradient:     linear-gradient(135deg, #6366f1 0%, #818cf8 100%);
  --gradient-text: linear-gradient(135deg, #6366f1 0%, #818cf8 50%, #06b6d4 100%);

  --shadow-xs:    0 1px 2px rgba(0,0,0,.04);
  --shadow-sm:    0 1px 3px rgba(0,0,0,.06);
  --shadow-md:    0 4px 12px rgba(0,0,0,.06);
  --shadow-lg:    0 8px 30px rgba(0,0,0,.08);

  --radius-sm:    8px;
  --radius:       12px;
  --radius-lg:    16px;
  --radius-xl:    24px;

  --font:         'Inter', system-ui, -apple-system, sans-serif;
  --font-display: 'Space Grotesk', var(--font);
  --nav-h:        68px;

  --ease:         cubic-bezier(.25,.46,.45,.94);
  --ease-bounce:  cubic-bezier(.34,1.56,.64,1);
  --ease-out:     cubic-bezier(.16,1,.3,1);

  --particle-1:   #6366f1;
  --particle-2:   #a78bfa;
  --particle-3:   #22d3ee;
}

/* ---- THEMES ---- */
[data-theme="ocean"]{--accent:#0ea5e9;--accent2:#38bdf8;--accent3:#06b6d4;--accent-glow:rgba(14,165,233,.18);--gradient:linear-gradient(135deg,#0ea5e9 0%,#38bdf8 100%);--gradient-text:linear-gradient(135deg,#0ea5e9 0%,#38bdf8 50%,#67e8f9 100%);--particle-1:#0ea5e9;--particle-2:#38bdf8;--particle-3:#06b6d4}
[data-theme="sunset"]{--accent:#f97316;--accent2:#fb923c;--accent3:#ef4444;--accent-glow:rgba(249,115,22,.18);--gradient:linear-gradient(135deg,#f97316 0%,#fb923c 100%);--gradient-text:linear-gradient(135deg,#f97316 0%,#fb923c 50%,#fbbf24 100%);--particle-1:#f97316;--particle-2:#fb923c;--particle-3:#ef4444}
[data-theme="emerald"]{--accent:#10b981;--accent2:#34d399;--accent3:#06b6d4;--accent-glow:rgba(16,185,129,.18);--gradient:linear-gradient(135deg,#10b981 0%,#34d399 100%);--gradient-text:linear-gradient(135deg,#10b981 0%,#34d399 50%,#6ee7b7 100%);--particle-1:#10b981;--particle-2:#34d399;--particle-3:#06b6d4}
[data-theme="rose"]{--accent:#f43f5e;--accent2:#fb7185;--accent3:#e879f9;--accent-glow:rgba(244,63,94,.18);--gradient:linear-gradient(135deg,#f43f5e 0%,#fb7185 100%);--gradient-text:linear-gradient(135deg,#f43f5e 0%,#fb7185 50%,#fda4af 100%);--particle-1:#f43f5e;--particle-2:#fb7185;--particle-3:#e879f9}
[data-theme="cyber"]{--accent:#eab308;--accent2:#fbbf24;--accent3:#a3e635;--accent-glow:rgba(234,179,8,.18);--gradient:linear-gradient(135deg,#eab308 0%,#fbbf24 100%);--gradient-text:linear-gradient(135deg,#eab308 0%,#fbbf24 50%,#fde047 100%);--particle-1:#eab308;--particle-2:#fbbf24;--particle-3:#a3e635}
[data-theme="violet"]{--accent:#7c5cfc;--accent2:#c084fc;--accent3:#38bdf8;--accent-glow:rgba(124,92,252,.18);--gradient:linear-gradient(135deg,#7c5cfc 0%,#c084fc 100%);--gradient-text:linear-gradient(135deg,#7c5cfc 0%,#c084fc 50%,#38bdf8 100%);--particle-1:#7c5cfc;--particle-2:#c084fc;--particle-3:#38bdf8}

/* ---- RESET ---- */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:var(--nav-h);overflow-x:hidden}
body{font-family:var(--font);background:var(--white);color:var(--light-text2);line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden;width:100%}
a{text-decoration:none;color:inherit;transition:color .3s}
ul{list-style:none}
img{display:block;max-width:100%}
button{font-family:inherit;cursor:pointer;border:none;background:none}
::selection{background:var(--accent);color:var(--white)}

.container{width:90%;max-width:1140px;margin:0 auto}
.gradient-text{background:var(--gradient-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.accent{color:var(--accent);-webkit-text-fill-color:var(--accent)}

/* ---- CANVAS ---- */
#particleCanvas{position:fixed;inset:0;z-index:2;pointer-events:none;opacity:1}

/* ---- THEME SWITCHER ---- */
.theme-switcher{position:fixed;bottom:6rem;right:1.5rem;z-index:950;display:flex;flex-direction:column;align-items:flex-end;gap:.5rem}
.theme-toggle{width:44px;height:44px;border-radius:50%;background:var(--gradient);color:var(--white);display:flex;align-items:center;justify-content:center;font-size:1.05rem;box-shadow:var(--shadow-md);transition:transform .35s var(--ease-bounce),box-shadow .35s}
.theme-toggle:hover{transform:scale(1.08);box-shadow:var(--shadow-lg)}
.theme-toggle.open{transform:scale(1.08) rotate(180deg)}
.theme-panel{background:var(--white);border:1px solid var(--light-border);border-radius:var(--radius);padding:.75rem 1rem;opacity:0;visibility:hidden;transform:translateY(6px) scale(.96);transition:all .25s var(--ease);min-width:150px;box-shadow:var(--shadow-lg)}
.theme-panel.open{opacity:1;visibility:visible;transform:translateY(0) scale(1)}
.theme-label{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:2px;color:var(--light-dim);margin-bottom:.5rem}
.theme-options{display:flex;gap:.45rem;flex-wrap:wrap}
.theme-dot{width:26px;height:26px;border-radius:50%;background:var(--dot-color);border:2.5px solid transparent;cursor:pointer;transition:all .3s var(--ease-bounce)}
.theme-dot:hover{transform:scale(1.15)}
.theme-dot.active{border-color:var(--light-text);box-shadow:0 0 0 3px var(--dot-color);transform:scale(1.1)}

/* ---- BUTTONS ---- */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;font-size:.9rem;padding:.65rem 1.5rem;border-radius:var(--radius-sm);transition:all .3s var(--ease);position:relative;overflow:hidden}
.btn i{font-size:.8rem;transition:transform .3s var(--ease)}
.btn:hover i{transform:translateX(3px)}
.btn-primary{background:var(--accent);color:var(--white);box-shadow:0 2px 8px var(--accent-glow)}
.btn-primary:hover{background:var(--accent2);box-shadow:0 4px 16px var(--accent-glow);transform:translateY(-1px)}
.btn-outline{border:1.5px solid var(--light-border-hover);color:var(--light-text2)}
.btn-outline:hover{border-color:var(--accent);color:var(--accent)}
.btn-white{background:var(--white);color:var(--dark);box-shadow:var(--shadow-sm)}
.btn-white:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn-outline-white{border:1.5px solid rgba(255,255,255,.25);color:var(--white)}
.btn-outline-white:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.4)}
.btn-lg{padding:.8rem 1.8rem;font-size:.95rem}
.btn-full{width:100%;justify-content:center}
.btn-nav{background:var(--accent);color:var(--white);padding:.5rem 1.2rem;font-size:.85rem;border-radius:var(--radius-sm);box-shadow:0 2px 8px var(--accent-glow)}
.btn-nav:hover{background:var(--accent2)}

/* ---- PRELOADER ---- */
#preloader{position:fixed;inset:0;z-index:10000;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--white);transition:opacity .5s ease,visibility .5s ease}
#preloader.loaded{opacity:0;visibility:hidden}
.loader-ring{position:relative;width:48px;height:48px}
.loader-ring span{position:absolute;inset:0;border:2px solid transparent;border-top-color:var(--accent);border-radius:50%;animation:spin 1.2s linear infinite}
.loader-ring span:nth-child(2){inset:5px;border-top-color:var(--accent2);animation-duration:.9s;animation-direction:reverse}
.loader-ring span:nth-child(3){inset:10px;border-top-color:var(--light-border);animation-duration:1.5s}
@keyframes spin{to{transform:rotate(360deg)}}
.loader-text{margin-top:1rem;font-family:var(--font-display);font-size:.8rem;letter-spacing:5px;color:var(--light-dim);font-weight:500}

/* ---- NAVIGATION ---- */
#navbar{position:fixed;top:0;left:0;width:100%;z-index:1000;height:var(--nav-h);display:flex;align-items:center;background:transparent;transition:background .3s,box-shadow .3s,backdrop-filter .3s}
#navbar.scrolled{background:rgba(255,255,255,.92);backdrop-filter:blur(16px) saturate(1.6);box-shadow:0 1px 0 var(--light-border)}
#navbar.scrolled.nav-dark-section{background:rgba(17,24,39,.88);backdrop-filter:blur(16px) saturate(1.4);box-shadow:0 1px 0 rgba(255,255,255,.06)}
#navbar.scrolled.nav-dark-section .logo-text{color:var(--white)}
#navbar.scrolled.nav-dark-section .nav-link{color:rgba(255,255,255,.6)}
#navbar.scrolled.nav-dark-section .nav-link:hover,#navbar.scrolled.nav-dark-section .nav-link.active{color:#fff}
#navbar.scrolled.nav-dark-section .hamburger span{background:#fff}
#navbar.scrolled.nav-dark-section .btn-nav{color:rgba(255,255,255,.8);border-color:rgba(255,255,255,.15)}
#navbar.scrolled.nav-dark-section .btn-nav:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.nav-container{display:flex;align-items:center;justify-content:space-between;width:90%;max-width:1140px;margin:0 auto}
.logo{display:flex;align-items:center;gap:.5rem}
.logo-icon{width:34px;height:34px;display:flex;align-items:center;justify-content:center;background:var(--accent);border-radius:var(--radius-sm);font-family:var(--font-display);font-weight:700;font-size:1rem;color:var(--white)}
.logo-text{font-family:var(--font-display);font-weight:700;font-size:1.15rem;color:var(--white);transition:color .3s}
#navbar.scrolled .logo-text{color:var(--light-text)}
.nav-links{display:flex;gap:2rem}
.nav-link{font-size:.88rem;font-weight:500;color:rgba(255,255,255,.6);position:relative;padding:.2rem 0;transition:color .3s}
.nav-link::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:2px;background:var(--accent);border-radius:2px;transition:width .3s}
.nav-link:hover,.nav-link.active{color:var(--white)}
.nav-link:hover::after,.nav-link.active::after{width:100%}
#navbar.scrolled .nav-link{color:var(--light-muted)}
#navbar.scrolled .nav-link:hover,#navbar.scrolled .nav-link.active{color:var(--light-text)}
#navbar.scrolled .hamburger span{background:var(--light-text)}

.hamburger{display:none;width:26px;height:18px;position:relative;z-index:1001}
.hamburger span{position:absolute;left:0;width:100%;height:2px;background:var(--white);border-radius:2px;transition:all .3s var(--ease)}
.hamburger span:nth-child(1){top:0}
.hamburger span:nth-child(2){top:50%;transform:translateY(-50%)}
.hamburger span:nth-child(3){bottom:0}
.hamburger.open span:nth-child(1){top:50%;transform:translateY(-50%) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){bottom:50%;transform:translateY(50%) rotate(-45deg)}

.mobile-menu{position:fixed;inset:0;z-index:999;background:rgba(255,255,255,.98);backdrop-filter:blur(20px);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:all .35s var(--ease)}
.mobile-menu.open{opacity:1;visibility:visible}
.mobile-nav{text-align:center;display:flex;flex-direction:column;gap:1.2rem}
.mobile-link{font-family:var(--font-display);font-size:1.4rem;font-weight:600;color:var(--light-muted);transition:color .3s}
.mobile-link:hover{color:var(--light-text)}

/* ---- HERO ---- */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:calc(var(--nav-h) + 3rem) 2rem 4rem;overflow:hidden;background:var(--dark);z-index:1}
.hero-bg{position:absolute;inset:0;z-index:0}
.gradient-orb{position:absolute;border-radius:50%;filter:blur(140px);opacity:.15}
.orb-1{width:500px;height:500px;top:-10%;right:-5%;background:var(--accent)}
.orb-2{width:400px;height:400px;bottom:-15%;left:-10%;background:var(--accent2)}
.orb-3{width:300px;height:300px;top:40%;left:45%;background:var(--accent3);opacity:.08}
.grid-overlay{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.015) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.015) 1px,transparent 1px);background-size:60px 60px}
.hero-content{position:relative;z-index:10;max-width:760px;text-align:center;color:var(--white)}
.hero-name{font-family:var(--font-display);font-weight:700;font-size:clamp(3rem,7vw,5rem);line-height:1.1;color:var(--white);margin-bottom:.6rem;letter-spacing:-0.03em}
.hero-cin{font-size:.78rem;color:rgba(255,255,255,.4);letter-spacing:.03em;margin-bottom:.8rem;font-weight:400}
.hero-tagline{font-family:var(--font-display);font-weight:600;font-size:clamp(1.2rem,2.5vw,1.7rem);line-height:1.4;color:rgba(255,255,255,.75);margin-bottom:1rem}
.hero-badge{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem 1rem;border-radius:var(--radius-sm);background:rgba(99,102,241,.1);border:1px solid rgba(99,102,241,.15);font-size:.78rem;font-weight:500;color:var(--accent2);margin-bottom:1.5rem}
.hero-subtitle{font-size:clamp(1rem,1.4vw,1.15rem);color:var(--dark-muted);max-width:600px;margin:0 auto 2rem;line-height:1.8}
.hero-cta{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap;margin-bottom:3rem}
.hero-stats{display:flex;align-items:center;justify-content:center;gap:2.5rem;flex-wrap:wrap}
.stat{text-align:center}
.stat-number{font-family:var(--font-display);font-weight:700;font-size:2rem;color:var(--white)}
.stat-plus{font-family:var(--font-display);font-weight:600;font-size:1.3rem;color:var(--accent2)}
.stat-label{display:block;font-size:.75rem;color:var(--dark-muted);margin-top:.1rem;letter-spacing:.02em}
.stat-divider{width:1px;height:32px;background:rgba(255,255,255,.1)}

.scroll-indicator{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.4rem;z-index:10}
.mouse{width:22px;height:34px;border:1.5px solid rgba(255,255,255,.2);border-radius:11px;position:relative}
.wheel{width:2px;height:6px;background:var(--accent);border-radius:2px;position:absolute;top:6px;left:50%;transform:translateX(-50%);animation:scrollWheel 1.8s ease-in-out infinite}
@keyframes scrollWheel{0%,100%{opacity:1;transform:translateX(-50%) translateY(0)}50%{opacity:.2;transform:translateX(-50%) translateY(8px)}}
.scroll-indicator span{font-size:.68rem;color:rgba(255,255,255,.3);letter-spacing:2px;text-transform:uppercase}

/* ---- SECTIONS ---- */
.section{padding:6rem 0;position:relative;z-index:3}
.section-header{text-align:center;max-width:620px;margin:0 auto 3.5rem}
.section-tag{display:inline-block;font-size:.72rem;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--accent);margin-bottom:.5rem}
.section-title{font-family:var(--font-display);font-weight:700;font-size:clamp(1.6rem,3vw,2.4rem);color:var(--light-text);line-height:1.2;margin-bottom:.8rem}
.section-desc{font-size:.95rem;color:var(--light-muted);line-height:1.75}

.about{background:var(--white)}
.portfolio{background:var(--dark);position:relative;overflow:hidden;padding:8rem 0}
.team{background:var(--light)}
.testimonials{background:var(--white)}
.contact{background:var(--light)}
.about,.team,.testimonials,.contact{border-top:1px solid var(--light-border)}
.services-training,.portfolio{border-top:none}

/* ---- ABOUT ---- */
.about-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:3rem}
.about-card{background:var(--white);border:1px solid var(--light-border);border-radius:var(--radius-lg);padding:2rem;box-shadow:var(--shadow-xs);transition:transform .3s var(--ease-out),box-shadow .3s,border-color .3s}
.about-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--accent)}
.about-icon{width:44px;height:44px;border-radius:var(--radius-sm);background:var(--light-elevated);display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:var(--accent);margin-bottom:1rem}
.about-card h3{font-family:var(--font-display);font-size:1.1rem;color:var(--light-text);margin-bottom:.5rem;font-weight:600}
.about-card p{font-size:.9rem;color:var(--light-muted);line-height:1.7}

.about-marquee{overflow:hidden;padding:1.2rem 0;border-top:1px solid var(--light-border);border-bottom:1px solid var(--light-border)}
.marquee-track{display:flex;gap:1.5rem;white-space:nowrap;animation:marquee 25s linear infinite}
.marquee-track span{font-family:var(--font-display);font-size:.95rem;font-weight:500;color:var(--light-dim)}
.marquee-track .dot{color:var(--accent);font-size:.4rem}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ---- SERVICES & TRAINING ---- */
.services-training{background:var(--dark);padding:8rem 0;position:relative;overflow:hidden;z-index:1}
.services-training .st-bg{position:absolute;inset:0;z-index:0}
.services-training .gradient-orb{position:absolute;border-radius:50%;filter:blur(140px);opacity:.15}
.services-training .st-orb-1{width:450px;height:450px;top:-15%;left:-8%;background:var(--accent3)}
.services-training .st-orb-2{width:350px;height:350px;bottom:-10%;right:-5%;background:var(--accent)}
.services-training .st-orb-3{width:280px;height:280px;top:50%;right:30%;background:var(--accent2);opacity:.08}
.services-training .grid-overlay{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.015) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.015) 1px,transparent 1px);background-size:60px 60px}
.services-training .container{position:relative;z-index:2}
.services-training .section-tag{color:rgba(255,255,255,.5);border-color:rgba(255,255,255,.15)}
.services-training .section-title{color:#fff}
.services-training .gradient-text{background:linear-gradient(135deg,#818cf8,#06b6d4,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.services-training .section-desc{color:rgba(255,255,255,.55)}
.st-panels{display:flex;gap:1.25rem;min-height:420px;justify-content:center;align-items:stretch;position:relative;z-index:1}

/* --- Trigger Buttons --- */
.st-trigger{position:relative;z-index:2;width:180px;min-width:160px;flex-shrink:0;cursor:pointer;border-radius:20px;border:2px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 4px 24px rgba(0,0,0,.2);transition:all .45s var(--ease-out);overflow:hidden}
.st-trigger--services::before{content:'';position:absolute;inset:0;border-radius:inherit;background:linear-gradient(135deg,rgba(249,115,22,.06),rgba(244,63,94,.06),rgba(168,85,247,.06));opacity:0;transition:opacity .4s}
.st-trigger--training::before{content:'';position:absolute;inset:0;border-radius:inherit;background:linear-gradient(135deg,rgba(34,211,238,.06),rgba(99,102,241,.06),rgba(168,85,247,.06));opacity:0;transition:opacity .4s}
.st-trigger:hover::before{opacity:1}
.st-trigger--services:hover{border-color:rgba(249,115,22,.5);box-shadow:0 8px 40px rgba(249,115,22,.2),0 0 60px rgba(244,63,94,.08);transform:translateY(-3px)}
.st-trigger--training:hover{border-color:rgba(34,211,238,.5);box-shadow:0 8px 40px rgba(34,211,238,.2),0 0 60px rgba(99,102,241,.08);transform:translateY(-3px)}
.st-trigger-inner{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;height:100%;padding:2.5rem 1.2rem;position:relative;z-index:1}
.st-trigger--services .st-icon{width:60px;height:60px;border-radius:16px;background:linear-gradient(135deg,rgba(249,115,22,.15),rgba(244,63,94,.1));display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:#f97316;margin-bottom:1.2rem;transition:all .4s var(--ease-out)}
.st-trigger--training .st-icon{width:60px;height:60px;border-radius:16px;background:linear-gradient(135deg,rgba(34,211,238,.15),rgba(99,102,241,.1));display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:#22d3ee;margin-bottom:1.2rem;transition:all .4s var(--ease-out)}
.st-trigger--services:hover .st-icon{background:linear-gradient(135deg,#f97316,#f43f5e);color:#fff;box-shadow:0 6px 24px rgba(249,115,22,.4);transform:scale(1.1) rotate(-3deg)}
.st-trigger--training:hover .st-icon{background:linear-gradient(135deg,#22d3ee,#6366f1);color:#fff;box-shadow:0 6px 24px rgba(34,211,238,.4);transform:scale(1.1) rotate(3deg)}
.st-trigger h3{font-family:var(--font-display);font-weight:700;font-size:1.15rem;color:#fff;margin-bottom:.35rem;letter-spacing:-.01em}
.st-trigger-count{font-size:.72rem;color:rgba(255,255,255,.45);font-weight:500;margin-bottom:.6rem}
.st-hint{font-size:.68rem;color:rgba(255,255,255,.3);font-weight:500;display:flex;align-items:center;gap:.3rem;opacity:.6;transition:all .35s}
.st-trigger--services:hover .st-hint{opacity:1;color:#f97316}
.st-trigger--training:hover .st-hint{opacity:1;color:#22d3ee}

/* --- Reveal Panels --- */
.st-reveal{flex:0 0 0px;overflow:hidden;opacity:0;transition:flex .5s cubic-bezier(.4,0,.2,1),opacity .4s .08s}
.st-reveal-inner{display:grid;grid-template-columns:1fr 1fr;gap:.9rem;padding:.6rem;min-width:460px;min-height:100%;align-content:start}
.st-reveal--training .st-reveal-inner{grid-template-columns:1fr 1fr;min-width:460px}
.st-panels.show-services .st-reveal--services,.st-panels.show-training .st-reveal--training{flex:1 1 auto;opacity:1}
.st-panels.show-services .st-trigger--services{border-color:rgba(249,115,22,.5);box-shadow:0 8px 40px rgba(249,115,22,.2)}
.st-panels.show-services .st-trigger--services .st-icon{background:linear-gradient(135deg,#f97316,#f43f5e);color:#fff;box-shadow:0 6px 24px rgba(249,115,22,.4)}
.st-panels.show-training .st-trigger--training{border-color:rgba(34,211,238,.5);box-shadow:0 8px 40px rgba(34,211,238,.2)}
.st-panels.show-training .st-trigger--training .st-icon{background:linear-gradient(135deg,#22d3ee,#6366f1);color:#fff;box-shadow:0 6px 24px rgba(34,211,238,.4)}

/* --- Service/Training Cards (each unique color) --- */
.st-card{position:relative;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:1.2rem 1.15rem;transition:all .35s var(--ease-out);overflow:hidden;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.st-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;border-radius:16px 16px 0 0;transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease-out)}
.st-card:hover::before{transform:scaleX(1)}
.st-card:hover{transform:translateY(-4px);background:rgba(255,255,255,.08)}

/* Per-card colors — Services */
.st-reveal--services .st-card:nth-child(1){--card-color:#f97316;--card-glow:rgba(249,115,22,.15)}
.st-reveal--services .st-card:nth-child(2){--card-color:#a855f7;--card-glow:rgba(168,85,247,.15)}
.st-reveal--services .st-card:nth-child(3){--card-color:#10b981;--card-glow:rgba(16,185,129,.15)}
.st-reveal--services .st-card:nth-child(4){--card-color:#3b82f6;--card-glow:rgba(59,130,246,.15)}
/* Per-card colors — Training */
.st-reveal--training .st-card:nth-child(1){--card-color:#22d3ee;--card-glow:rgba(34,211,238,.15)}
.st-reveal--training .st-card:nth-child(2){--card-color:#f43f5e;--card-glow:rgba(244,63,94,.15)}
.st-reveal--training .st-card:nth-child(3){--card-color:#8b5cf6;--card-glow:rgba(139,92,246,.15)}
.st-reveal--training .st-card:nth-child(4){--card-color:#eab308;--card-glow:rgba(234,179,8,.15)}

.st-card::before{background:var(--card-color,var(--accent))}
.st-card:hover{border-color:var(--card-color,var(--accent));box-shadow:0 12px 32px var(--card-glow,rgba(99,102,241,.1)),0 0 40px var(--card-glow,rgba(99,102,241,.05))}
.st-card-icon{width:42px;height:42px;border-radius:12px;background:rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;font-size:1.05rem;color:var(--card-color,var(--accent));margin-bottom:.65rem;transition:all .35s var(--ease-out);border:1px solid rgba(255,255,255,.06)}
.st-card:hover .st-card-icon{background:var(--card-color,var(--accent));color:#fff;box-shadow:0 4px 16px var(--card-glow,rgba(99,102,241,.3));transform:scale(1.08) rotate(-2deg);border-color:transparent}
.st-card h4{font-family:var(--font-display);font-weight:700;font-size:.88rem;color:#fff;margin-bottom:.3rem;letter-spacing:-.01em}
.st-card p{font-size:.76rem;color:rgba(255,255,255,.5);line-height:1.55}
.st-duration{display:inline-flex;align-items:center;gap:.3rem;font-size:.68rem;color:#fff;font-weight:600;margin-top:.55rem;padding:.22rem .65rem;border-radius:20px;background:var(--card-color,var(--accent));box-shadow:0 2px 12px var(--card-glow,rgba(99,102,241,.2))}
.st-duration i{font-size:.55rem}



/* ---- PORTFOLIO ---- */
.portfolio .pf-bg{position:absolute;inset:0;z-index:0}
.portfolio .gradient-orb{position:absolute;border-radius:50%;filter:blur(140px);opacity:.15}
.portfolio .pf-orb-1{width:420px;height:420px;top:-12%;right:-6%;background:var(--accent)}
.portfolio .pf-orb-2{width:340px;height:340px;bottom:-10%;left:-8%;background:var(--accent3)}
.portfolio .pf-orb-3{width:260px;height:260px;top:45%;left:40%;background:var(--accent2);opacity:.08}
.portfolio .grid-overlay{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.015) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.015) 1px,transparent 1px);background-size:60px 60px}
.portfolio .container{position:relative;z-index:2}
.portfolio .section-tag{color:rgba(255,255,255,.5)}
.portfolio .section-title{color:#fff}
.portfolio .gradient-text{background:linear-gradient(135deg,#818cf8,#06b6d4,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.portfolio .section-desc{color:rgba(255,255,255,.55)}

.pf-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem;position:relative;z-index:1;align-items:stretch}
.pf-card{position:relative;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:1.8rem 1.4rem;transition:all .35s var(--ease-out);overflow:hidden;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);text-decoration:none;display:flex;flex-direction:column;cursor:pointer;min-height:420px}
.pf-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;border-radius:16px 16px 0 0;background:var(--card-color,var(--accent));transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease-out)}
.pf-card:hover::before{transform:scaleX(1)}
.pf-card:hover{transform:translateY(-4px);background:rgba(255,255,255,.08);border-color:var(--card-color,var(--accent));box-shadow:0 12px 32px var(--card-glow,rgba(99,102,241,.1)),0 0 40px var(--card-glow,rgba(99,102,241,.05))}
.pf-card--showcase:hover{transform:translateY(-6px) scale(1.03)}

.pf-card-icon{width:48px;height:48px;border-radius:14px;background:rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;font-size:1.15rem;color:var(--card-color,var(--accent));margin-bottom:.8rem;transition:all .35s var(--ease-out);border:1px solid rgba(255,255,255,.06)}
.pf-card:hover .pf-card-icon{background:var(--card-color,var(--accent));color:#fff;box-shadow:0 4px 16px var(--card-glow,rgba(99,102,241,.3));transform:scale(1.08) rotate(-2deg);border-color:transparent}

.pf-badge{display:inline-block;font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--card-color,var(--accent));margin-bottom:.4rem;opacity:.7}
.pf-card h4{font-family:var(--font-display);font-weight:700;font-size:.95rem;color:#fff;margin-bottom:.4rem;letter-spacing:-.01em;line-height:1.3}
.pf-card p{font-size:.8rem;color:rgba(255,255,255,.5);line-height:1.6;margin-bottom:.8rem}

.pf-card-preview{width:100%;flex:1;display:flex;align-items:center;justify-content:center;padding:.5rem 0;overflow:hidden;border-radius:12px}
.pf-card-preview img{max-width:90%;max-height:360px;height:auto;border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.4);object-fit:contain}

/* R&D Card Graphic — Neural network style */
.pf-card-graphic{width:100%;flex:1;display:flex;align-items:center;justify-content:center;padding:1rem 0}
.rd-visual{position:relative;width:180px;height:180px}
.rd-node{position:absolute;width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;border:2px solid rgba(168,85,247,.3);background:rgba(168,85,247,.1);color:#a855f7;transition:all .4s;z-index:2}
.rd-node--center{width:56px;height:56px;font-size:1.3rem;top:50%;left:50%;transform:translate(-50%,-50%);background:linear-gradient(135deg,rgba(168,85,247,.2),rgba(99,102,241,.15));border-color:rgba(168,85,247,.5);box-shadow:0 0 24px rgba(168,85,247,.2);animation:rd-pulse 3s ease-in-out infinite}
.rd-node--1{top:0;left:50%;transform:translateX(-50%)}
.rd-node--2{top:50%;right:0;transform:translateY(-50%)}
.rd-node--3{bottom:0;left:50%;transform:translateX(-50%)}
.rd-node--4{top:50%;left:0;transform:translateY(-50%)}
.rd-line{position:absolute;background:linear-gradient(to bottom,rgba(168,85,247,.3),rgba(168,85,247,.05));z-index:1}
.rd-line--1{width:2px;height:42px;top:44px;left:50%;transform:translateX(-50%)}
.rd-line--2{width:42px;height:2px;right:44px;top:50%;transform:translateY(-50%)}
.rd-line--3{width:2px;height:42px;bottom:44px;left:50%;transform:translateX(-50%)}
.rd-line--4{width:42px;height:2px;left:44px;top:50%;transform:translateY(-50%)}
@keyframes rd-pulse{0%,100%{box-shadow:0 0 24px rgba(168,85,247,.2)}50%{box-shadow:0 0 40px rgba(168,85,247,.4)}}
.pf-card:hover .rd-node--center{box-shadow:0 0 40px rgba(168,85,247,.5);background:linear-gradient(135deg,#a855f7,#6366f1);color:#fff}
.pf-card:hover .rd-node{border-color:rgba(168,85,247,.6);background:rgba(168,85,247,.2)}

.pf-tags{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:auto;padding-top:.6rem}
.pf-tag{font-size:.6rem;font-weight:600;padding:.2rem .55rem;border-radius:20px;background:var(--card-glow,rgba(99,102,241,.1));color:var(--card-color,var(--accent));border:1px solid rgba(255,255,255,.06)}

.pf-link{font-size:.78rem;font-weight:700;color:#fff;background:var(--card-color,var(--accent));display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.5rem 1.2rem;border-radius:var(--radius-sm);transition:all .3s;margin:.6rem auto;text-align:center;box-shadow:0 2px 12px var(--card-glow,rgba(99,102,241,.2));align-self:center}
.pf-link i{font-size:.65rem}
.pf-card:hover .pf-link{transform:translateY(-1px);box-shadow:0 4px 18px var(--card-glow,rgba(99,102,241,.35))}

/* -- Student Works Slider -- */
.pf-slider{position:relative;border-radius:12px;overflow:hidden;margin-bottom:.8rem;background:rgba(0,0,0,.25);border:1px solid rgba(255,255,255,.06);flex:1;min-height:160px}
.pf-slider-track{display:flex;height:100%;transition:transform .5s var(--ease)}
.pf-slide{min-width:100%;height:100%;display:flex;align-items:center;justify-content:center}
.pf-slide img{width:100%;height:100%;object-fit:cover}
.pf-slide-placeholder{display:flex;flex-direction:column;align-items:center;gap:.4rem;color:rgba(255,255,255,.2);font-size:.7rem}
.pf-slide-placeholder i{font-size:1.8rem}
.pf-slider-dots{position:absolute;bottom:.5rem;left:50%;transform:translateX(-50%);display:flex;gap:.35rem;z-index:2}
.pf-dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.25);cursor:pointer;transition:all .3s}
.pf-dot.active{background:var(--card-color,#f43f5e);width:18px;border-radius:3px}

@media(max-width:1024px){.pf-grid{grid-template-columns:repeat(2,1fr)}}

/* ---- TEAM ---- */
.team-featured{display:flex;justify-content:center;margin-bottom:2rem}
.team-card--founder{width:100%;max-width:520px;background:var(--white);border:2px solid var(--accent);border-radius:var(--radius-xl);padding:2.2rem 2rem;text-align:center;box-shadow:0 8px 32px var(--accent-glow),var(--shadow-md);position:relative;overflow:hidden}
.team-card--founder::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:var(--gradient)}
.team-card--founder .team-avatar{width:72px;height:72px;border-radius:50%;background:var(--gradient);display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:var(--white);margin:0 auto .8rem;box-shadow:0 4px 20px var(--accent-glow)}
.team-card--founder h3{font-family:var(--font-display);font-size:1.15rem;color:var(--light-text);margin-bottom:.15rem;font-weight:700}
.team-card--founder .team-role{display:inline-block;font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:2px;color:var(--accent);margin-bottom:.6rem}
.team-card--founder p{font-size:.84rem;color:var(--light-muted);line-height:1.7;margin-bottom:.8rem}
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.team-card{background:var(--white);border:1px solid var(--light-border);border-radius:var(--radius-lg);padding:1.5rem 1.2rem;text-align:center;box-shadow:var(--shadow-xs);transition:transform .3s var(--ease-out),box-shadow .3s,border-color .3s}
.team-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--accent)}
.team-avatar{width:56px;height:56px;border-radius:50%;background:var(--light-elevated);display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:var(--accent);margin:0 auto .6rem}
.team-role{display:inline-block;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;color:var(--accent2);margin-bottom:.4rem}
.team-card h4{font-family:var(--font-display);font-size:.88rem;color:var(--light-text);margin-bottom:.15rem;font-weight:600}
.team-card p{font-size:.78rem;color:var(--light-muted);margin-bottom:.6rem;line-height:1.6}
.team-socials{display:flex;justify-content:center;gap:.5rem}
.team-socials a{width:30px;height:30px;border-radius:50%;background:var(--light-elevated);border:1px solid var(--light-border);display:flex;align-items:center;justify-content:center;font-size:.72rem;color:var(--light-muted);transition:all .3s}
.team-socials a:hover{background:var(--accent);color:var(--white);border-color:var(--accent)}

/* ---- TESTIMONIALS ---- */
.testimonial-slider{position:relative;overflow:hidden}
.testimonial-track{display:flex;transition:transform .45s var(--ease)}
.testimonial-card{min-width:100%;padding:2.2rem;background:var(--light);border:1px solid var(--light-border);border-radius:var(--radius-lg);text-align:center}
.stars{color:#f59e0b;font-size:.85rem;margin-bottom:.8rem;display:flex;justify-content:center;gap:.2rem}
.testimonial-card p{font-size:.98rem;color:var(--light-text2);line-height:1.8;max-width:560px;margin:0 auto 1.2rem;font-style:italic}
.testimonial-author strong{display:block;color:var(--light-text);font-size:.88rem}
.testimonial-author span{font-size:.78rem;color:var(--light-dim)}
.testimonial-nav{display:flex;align-items:center;justify-content:center;gap:.8rem;margin-top:1.2rem}
.t-nav-btn{width:36px;height:36px;border-radius:50%;border:1px solid var(--light-border);color:var(--light-muted);display:flex;align-items:center;justify-content:center;transition:all .3s}
.t-nav-btn:hover{border-color:var(--accent);color:var(--accent)}
.t-dots{display:flex;gap:.4rem}
.t-dot{width:6px;height:6px;border-radius:50%;background:var(--light-border);transition:all .3s;cursor:pointer}
.t-dot.active{background:var(--accent);width:20px;border-radius:3px}

/* ---- CTA BANNER ---- */
.cta-banner{position:relative;padding:5rem 0;overflow:hidden;z-index:3}
.cta-bg{position:absolute;inset:0;background:var(--dark)}
.cta-bg .orb-1{width:350px;height:350px;top:-20%;right:10%;background:var(--accent);opacity:.1}
.cta-bg .orb-2{width:250px;height:250px;bottom:-15%;left:5%;background:var(--accent2);opacity:.08}
.cta-content{position:relative;text-align:center;z-index:10}
.cta-content h2{font-family:var(--font-display);font-size:clamp(1.4rem,2.8vw,2.2rem);font-weight:700;color:var(--white);margin-bottom:.6rem}
.cta-content p{font-size:.95rem;color:var(--dark-muted);margin-bottom:1.8rem;max-width:500px;margin-left:auto;margin-right:auto}
.cta-buttons{display:flex;justify-content:center;gap:.8rem;flex-wrap:wrap}

/* ---- CONTACT ---- */
.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:2.5rem;align-items:start}
.contact-item{display:flex;gap:.8rem;align-items:flex-start;margin-bottom:1.2rem}
.contact-icon{width:42px;height:42px;min-width:42px;border-radius:var(--radius-sm);background:var(--light-elevated);display:flex;align-items:center;justify-content:center;font-size:1rem;color:var(--accent)}
.contact-item h4{font-family:var(--font-display);font-size:.88rem;color:var(--light-text);margin-bottom:.1rem;font-weight:600}
.contact-item p{font-size:.85rem;color:var(--light-muted)}
.contact-socials{display:flex;gap:.6rem;margin-top:1.2rem}
.contact-socials a{width:38px;height:38px;border-radius:50%;background:var(--light-elevated);border:1px solid var(--light-border);display:flex;align-items:center;justify-content:center;font-size:.9rem;color:var(--light-muted);transition:all .3s}
.contact-socials a:hover{background:var(--accent);color:var(--white);border-color:var(--accent)}

.contact-form{background:var(--white);border:1px solid var(--light-border);border-radius:var(--radius-lg);padding:2rem;box-shadow:var(--shadow-xs)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-group{position:relative;margin-bottom:1rem}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:.85rem 1rem;background:var(--light);border:1px solid var(--light-border);border-radius:var(--radius-sm);color:var(--light-text);font-family:var(--font);font-size:.88rem;transition:border-color .3s,box-shadow .3s;outline:none}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.form-group label{position:absolute;top:.85rem;left:1rem;font-size:.88rem;color:var(--light-dim);pointer-events:none;transition:all .2s var(--ease)}
.form-group input:focus~label,.form-group input:not(:placeholder-shown)~label,.form-group textarea:focus~label,.form-group textarea:not(:placeholder-shown)~label{top:-.55rem;left:.75rem;font-size:.68rem;background:var(--white);padding:0 .35rem;color:var(--accent)}
.form-group select{appearance:none;color:var(--light-dim)}
.form-group select option{background:var(--white);color:var(--light-text)}

/* ---- FOOTER ---- */
.footer{background:var(--dark);border-top:1px solid var(--dark-border);padding:3.5rem 0 0;position:relative;z-index:3;color:var(--dark-text)}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:2rem;padding-bottom:2.5rem}
.footer .logo-text{color:var(--white)}
.footer-brand p{font-size:.85rem;color:var(--dark-muted);margin-top:.6rem;line-height:1.7;max-width:280px}
.footer-links h4{font-family:var(--font-display);font-size:.88rem;color:var(--white);margin-bottom:.8rem;font-weight:600}
.footer-links a{display:block;font-size:.82rem;color:var(--dark-muted);margin-bottom:.5rem;transition:color .3s}
.footer-links a:hover{color:var(--accent)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding:1.2rem 0;border-top:1px solid var(--dark-border);flex-wrap:wrap;gap:.8rem}
.footer-bottom p{font-size:.78rem;color:var(--dark-muted)}
.footer-bottom-links{display:flex;gap:1.2rem}
.footer-bottom-links a{font-size:.78rem;color:var(--dark-muted);transition:color .3s}
.footer-bottom-links a:hover{color:var(--accent)}

/* ---- BACK TO TOP ---- */
.back-to-top{position:fixed;bottom:1.5rem;right:1.5rem;z-index:900;width:40px;height:40px;border-radius:var(--radius-sm);background:var(--accent);color:var(--white);display:flex;align-items:center;justify-content:center;font-size:.9rem;box-shadow:var(--shadow-sm);opacity:0;visibility:hidden;transform:translateY(10px);transition:all .35s}
.back-to-top.visible{opacity:1;visibility:visible;transform:translateY(0)}
.back-to-top:hover{background:var(--accent2);transform:translateY(-2px)}

/* ---- ANIMATIONS ---- */
[data-animate]{opacity:0;transform:translateY(24px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
[data-animate].animated{opacity:1;transform:translateY(0)}

/* ---- RESPONSIVE ---- */
@media(max-width:1024px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:768px){
  .nav-links,.btn-nav{display:none}
  .hamburger{display:block}
  .hero-name{font-size:clamp(2rem,5.5vw,3rem)}
  .hero-tagline{font-size:clamp(1rem,2.2vw,1.3rem)}
  .hero-stats{gap:1rem}
  .stat-number{font-size:1.6rem}
  .portfolio-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:1.2rem}
  .footer-bottom{flex-direction:column;text-align:center}
  .section{padding:4rem 0}
  .cta-banner{padding:3.5rem 0}
  .theme-switcher{bottom:4.5rem;right:1rem}
  .theme-toggle{width:38px;height:38px;font-size:.9rem}

  /* Team responsive */
  .team-grid{grid-template-columns:1fr 1fr;gap:1rem}
  .team-card--founder{max-width:100%;padding:1.8rem 1.5rem}
  .team-card--founder p{font-size:.8rem}

  /* Services & Training — Tab layout on mobile */
  .services-training{padding:5rem 0}
  .st-panels{flex-direction:row;flex-wrap:wrap;align-items:stretch;min-height:auto;gap:0}
  .st-trigger{width:50%;max-width:50%;min-width:0;flex-shrink:0;border-radius:0;border:none;border-bottom:3px solid transparent;background:rgba(255,255,255,.03);backdrop-filter:none;-webkit-backdrop-filter:none;box-shadow:none;transition:all .3s}
  .st-trigger:first-of-type{border-radius:12px 0 0 0}
  .st-trigger:last-of-type{border-radius:0 12px 0 0}
  .st-trigger.tab-active{background:rgba(255,255,255,.08)}
  .st-trigger--services.tab-active{border-bottom-color:#f97316}
  .st-trigger--training.tab-active{border-bottom-color:#22d3ee}
  .st-trigger--services.tab-active .st-icon{background:linear-gradient(135deg,#f97316,#f43f5e);color:#fff;box-shadow:0 4px 16px rgba(249,115,22,.3)}
  .st-trigger--training.tab-active .st-icon{background:linear-gradient(135deg,#22d3ee,#6366f1);color:#fff;box-shadow:0 4px 16px rgba(34,211,238,.3)}
  .st-trigger-inner{padding:1.2rem .8rem;flex-direction:column;gap:.5rem;justify-content:center;align-items:center;text-align:center}
  .st-trigger .st-icon{margin-bottom:0;width:44px;height:44px;font-size:1.1rem}
  .st-trigger h3{font-size:.9rem;text-align:center}
  .st-trigger-count{text-align:center;font-size:.65rem}
  .st-hint{display:none}
  .st-reveal{flex:0 0 auto!important;width:100%;max-width:100%;display:none;order:3}
  .st-reveal.active-mobile{display:block;opacity:1}
  .st-reveal-inner{min-width:0;grid-template-columns:1fr 1fr;gap:.75rem;padding:.8rem}
  .st-card{padding:1rem}
  .st-card h4{font-size:.82rem}
  .st-card p{font-size:.72rem}
  .st-card-icon{width:36px;height:36px;font-size:.95rem}

  /* Portfolio responsive */
  .pf-grid{grid-template-columns:1fr 1fr;gap:1rem}
  .pf-card h4{font-size:.85rem}
  .pf-card p{font-size:.72rem}
  .portfolio{padding:5rem 0}

  /* Contact responsive */
  .contact-item p{font-size:.78rem;word-break:break-word}
  .contact-item p a{word-break:break-all}
  .contact-form{padding:1.5rem}

  /* Showcase carousel responsive */
  .showcase-carousel{border-radius:10px;margin:0 .75rem}
  .carousel-arrow{width:38px;height:38px;font-size:.85rem}
  .carousel-prev{left:.5rem}
  .carousel-next{right:.5rem}
  .showcase-title{font-size:clamp(1.6rem,4vw,2.5rem)}
  .showcase-hero{min-height:35vh;padding:calc(var(--nav-h) + 2rem) 0 2rem}

  /* CTA responsive */
  .cta-content h2{font-size:clamp(1.2rem,4vw,1.8rem)}
  .cta-buttons{flex-direction:column;align-items:center;gap:.6rem}
  .cta-buttons .btn{width:100%;max-width:300px;justify-content:center}
}
@media(max-width:480px){
  .hero{padding:calc(var(--nav-h) + 2rem) 1rem 3rem}
  .hero-stats{flex-direction:column;gap:.8rem}
  .stat-divider{width:40px;height:1px}
  .hero-cta{flex-direction:column;align-items:center}
  .hero-cta .btn{width:100%;max-width:280px;justify-content:center}
  .hero-badge{font-size:.7rem;padding:.3rem .8rem}
  .hero-subtitle{font-size:.9rem}

  /* Team mobile */
  .team-grid{grid-template-columns:1fr}
  .team-card--founder{max-width:100%;padding:1.5rem 1.2rem}
  .team-card--founder .team-avatar{width:60px;height:60px;font-size:1.2rem}
  .team-card--founder h3{font-size:1rem}

  /* Portfolio single column */
  .pf-grid{grid-template-columns:1fr}
  .pf-card{min-height:auto}
  .pf-slider{min-height:140px}

  /* Services & Training single column cards */
  .st-reveal-inner{grid-template-columns:1fr}
  .st-trigger-inner{padding:1rem .6rem;gap:.4rem}
  .st-trigger h3{font-size:.85rem}
  .st-trigger .st-icon{width:38px;height:38px;font-size:1rem}
  .st-trigger-count{font-size:.6rem}
  .st-card{padding:.9rem}
  .st-card h4{font-size:.78rem}
  .st-card p{font-size:.68rem}

  /* Section header */
  .section-header{margin-bottom:2.5rem}
  .section-title{font-size:clamp(1.4rem,5vw,2rem)}
  .section-desc{font-size:.85rem}

  /* Contact further adjustments */
  .contact-icon{width:36px;height:36px;min-width:36px;font-size:.9rem}
  .contact-item h4{font-size:.82rem}

  /* Carousel */
  .carousel-arrow{width:34px;height:34px;font-size:.75rem}
  .carousel-dots{gap:.35rem}
  .carousel-dot{width:8px;height:8px}
  .carousel-counter{font-size:.65rem}
  .showcase-carousel{margin:0 .5rem}
  .showcase-subtitle{font-size:.85rem}

  /* Footer */
  .footer{padding:2.5rem 0 0}
  .footer-brand p{font-size:.8rem}
  .footer-links h4{font-size:.82rem}
  .footer-links a{font-size:.78rem}
}

/* ============================================================
   SHOWCASE PAGES (Student Works & Film/VFX)
   ============================================================ */

/* -- Hero -- */
.showcase-hero{position:relative;min-height:50vh;display:flex;align-items:flex-end;padding:calc(var(--nav-h) + 3rem) 0 3rem;background:var(--dark);overflow:hidden}
.showcase-hero-bg{position:absolute;inset:0;z-index:0}
.showcase-hero-bg .orb-1{width:450px;height:450px;top:-15%;right:-5%;background:var(--accent);opacity:.12}
.showcase-hero-bg .orb-2{width:350px;height:350px;bottom:-20%;left:-8%;background:var(--accent3);opacity:.1}
.showcase-hero .container{position:relative;z-index:2}
.showcase-back{display:inline-flex;align-items:center;gap:.4rem;font-size:.8rem;font-weight:500;color:rgba(255,255,255,.45);margin-bottom:1.5rem;transition:color .3s}
.showcase-back:hover{color:var(--accent2)}
.showcase-back i{font-size:.7rem}
.showcase-hero-content{max-width:620px}
.showcase-hero-content .section-tag{color:rgba(255,255,255,.5)}
.showcase-title{font-family:var(--font-display);font-weight:700;font-size:clamp(2rem,5vw,3.5rem);color:#fff;line-height:1.1;margin-bottom:.8rem;letter-spacing:-.02em}
.showcase-subtitle{font-size:1rem;color:var(--dark-muted);line-height:1.8;max-width:540px}

/* -- Gallery → Full-width Carousel -- */
.showcase-carousel-section{background:var(--dark);padding:0 0 4rem;position:relative;z-index:1}
.showcase-carousel{position:relative;width:100%;max-width:1100px;margin:0 auto;overflow:hidden;border-radius:16px;background:rgba(0,0,0,.3);border:1px solid rgba(255,255,255,.08)}

.carousel-track{display:flex;transition:transform .5s cubic-bezier(.4,0,.2,1);will-change:transform}
.carousel-slide{min-width:100%;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:#000}
.carousel-slide img{max-width:100%;max-height:80vh;width:auto;height:auto;object-fit:contain;margin:0 auto}
.carousel-slide-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%;background:linear-gradient(135deg,rgba(99,102,241,.08),rgba(6,182,212,.06));color:rgba(255,255,255,.1);font-size:4rem}

/* Arrows */
.carousel-arrow{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;border:1px solid rgba(255,255,255,.15);background:rgba(0,0,0,.45);backdrop-filter:blur(8px);color:rgba(255,255,255,.7);font-size:1rem;cursor:pointer;transition:all .3s;z-index:5;display:flex;align-items:center;justify-content:center}
.carousel-arrow:hover{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 4px 20px var(--accent-glow)}
.carousel-prev{left:1rem}
.carousel-next{right:1rem}

/* Dots */
.carousel-dots{display:flex;justify-content:center;gap:.5rem;padding:1rem 0 .4rem;position:absolute;bottom:1.2rem;left:50%;transform:translateX(-50%);z-index:5}
.carousel-dot{width:10px;height:10px;border-radius:50%;border:1px solid rgba(255,255,255,.25);background:rgba(255,255,255,.1);cursor:pointer;transition:all .3s;padding:0}
.carousel-dot.active{background:var(--accent);border-color:var(--accent);box-shadow:0 0 8px var(--accent-glow);transform:scale(1.2)}
.carousel-dot:hover{background:rgba(255,255,255,.3)}

/* Counter */
.carousel-counter{position:absolute;top:1rem;right:1.2rem;font-size:.75rem;font-weight:600;color:rgba(255,255,255,.4);letter-spacing:1px;z-index:5;font-family:var(--font-display)}
.carousel-current{color:#fff}

/* ============================================================
   TOUCH / MOBILE HOVER FIX
   Gate transform-based hovers to pointer devices only;
   provide :active tap feedback for touch screens.
   ============================================================ */

/* --- Only apply hover transforms on devices that support hover --- */
@media (hover: hover) and (pointer: fine){
  .about-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--accent)}
  .st-trigger--services:hover{transform:translateY(-3px)}
  .st-trigger--training:hover{transform:translateY(-3px)}
  .st-trigger--services:hover .st-icon{transform:scale(1.1) rotate(-3deg)}
  .st-trigger--training:hover .st-icon{transform:scale(1.1) rotate(3deg)}
  .st-card:hover{transform:translateY(-4px)}
  .st-card:hover .st-card-icon{transform:scale(1.08) rotate(-2deg)}
  .pf-card:hover{transform:translateY(-4px)}
  .pf-card--showcase:hover{transform:translateY(-6px) scale(1.03)}
  .pf-card:hover .pf-card-icon{transform:scale(1.08) rotate(-2deg)}
  .pf-card:hover .pf-link{transform:translateY(-1px)}
  .team-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--accent)}
  .btn-primary:hover{transform:translateY(-1px)}
  .btn-white:hover{transform:translateY(-1px)}
  .back-to-top:hover{transform:translateY(-2px)}
  .carousel-arrow:hover{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 4px 20px var(--accent-glow)}
  .theme-toggle:hover{transform:scale(1.08)}
  .theme-dot:hover{transform:scale(1.15)}
}

/* --- Remove transforms on touch-only devices --- */
@media (hover: none){
  .about-card:hover,
  .st-trigger--services:hover,
  .st-trigger--training:hover,
  .st-card:hover,
  .pf-card:hover,
  .pf-card--showcase:hover,
  .team-card:hover,
  .btn-primary:hover,
  .btn-white:hover,
  .back-to-top:hover,
  .theme-toggle:hover,
  .theme-dot:hover{transform:none !important}
}

/* --- Active / tap feedback for touch --- */
.about-card:active{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--accent);transition:transform .1s,box-shadow .1s}
.st-trigger:active::before{opacity:1}
.st-trigger--services:active{border-color:rgba(249,115,22,.5);box-shadow:0 8px 40px rgba(249,115,22,.2);transform:translateY(-2px);transition:transform .1s}
.st-trigger--training:active{border-color:rgba(34,211,238,.5);box-shadow:0 8px 40px rgba(34,211,238,.2);transform:translateY(-2px);transition:transform .1s}
.st-trigger--services:active .st-icon{background:linear-gradient(135deg,#f97316,#f43f5e);color:#fff;box-shadow:0 6px 24px rgba(249,115,22,.4);transform:scale(1.05)}
.st-trigger--training:active .st-icon{background:linear-gradient(135deg,#22d3ee,#6366f1);color:#fff;box-shadow:0 6px 24px rgba(34,211,238,.4);transform:scale(1.05)}
.st-card:active{transform:translateY(-2px);background:rgba(255,255,255,.08);border-color:var(--card-color,var(--accent));transition:transform .1s}
.st-card:active .st-card-icon{background:var(--card-color,var(--accent));color:#fff;transform:scale(1.05)}
.pf-card:active{transform:translateY(-2px);background:rgba(255,255,255,.08);border-color:var(--card-color,var(--accent));box-shadow:0 12px 32px var(--card-glow,rgba(99,102,241,.1));transition:transform .1s}
.pf-card--showcase:active{transform:translateY(-3px) scale(1.01)}
.pf-card:active .pf-card-icon{background:var(--card-color,var(--accent));color:#fff;transform:scale(1.05)}
.pf-card:active .pf-link{transform:translateY(-1px);box-shadow:0 4px 18px var(--card-glow,rgba(99,102,241,.35))}
.team-card:active{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--accent);transition:transform .1s}
.team-socials a:active{background:var(--accent);color:var(--white);border-color:var(--accent)}
.contact-socials a:active{background:var(--accent);color:var(--white);border-color:var(--accent)}
.btn-primary:active{background:var(--accent2);box-shadow:0 4px 16px var(--accent-glow);transform:translateY(0);transition:transform .1s}
.btn-outline:active{border-color:var(--accent);color:var(--accent)}
.btn-outline-white:active{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.4)}
.btn-white:active{transform:translateY(0);box-shadow:var(--shadow-md)}
.btn-nav:active{background:var(--accent2)}
.carousel-arrow:active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 4px 20px var(--accent-glow);transition:background .1s}
.carousel-dot:active{background:rgba(255,255,255,.3)}
.back-to-top:active{background:var(--accent2);transform:translateY(0);transition:transform .1s}
.footer-links a:active{color:var(--accent)}
.footer-bottom-links a:active{color:var(--accent)}
.showcase-back:active{color:var(--accent2)}
.nav-link:active{color:var(--white)}
.mobile-link:active{color:var(--light-text)}

/* Better touch responsiveness */
.btn,.st-trigger,.st-card,.pf-card,.about-card,.team-card,.carousel-arrow,.carousel-dot,.contact-socials a,.team-socials a,.back-to-top,.footer-links a,.footer-bottom-links a,.showcase-back,.nav-link,.mobile-link{
  -webkit-tap-highlight-color:transparent;
  touch-action:manipulation;
}
